@odoo/o-spreadsheet 18.1.6 → 18.1.7
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.
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
!function(e,t){"use strict";function o(e){return e.map(i).sort(((e,t)=>e.sequence-t.sequence))}let s=1;function i(e){const t=e.name,o=e.children,r=e.description,n=e.icon,a=e.secondaryIcon;return{id:(e.id||s++).toString(),name:"function"==typeof t?t:()=>t,isVisible:e.isVisible?e.isVisible:()=>!0,isEnabled:e.isEnabled?e.isEnabled:()=>!0,isActive:e.isActive,execute:e.execute,children:o?e=>o.map((t=>"function"==typeof t?t(e):t)).flat().map(i):()=>[],isReadonlyAllowed:e.isReadonlyAllowed||!1,separator:e.separator||!1,icon:"function"==typeof n?n:()=>n||"",iconColor:e.iconColor,secondaryIcon:"function"==typeof a?a:()=>a||"",description:"function"==typeof r?r:()=>r||"",textColor:e.textColor,sequence:e.sequence||0,onStartHover:e.onStartHover,onStopHover:e.onStopHover}}class r{content={};add(e,t){return this.content[e]=t,this}get(e){const t=this.content[e];if(!t&&!(e in this.content))throw new Error(`Cannot find ${e} in this registry!`);return t}contains(e){return e in this.content}getAll(){return Object.values(this.content)}getKeys(){return Object.keys(this.content)}remove(e){delete this.content[e]}}const n=.5,a="#37A850",l="#f5f5f5",c="#F8F9FA",h="#E8EAED",d="#595959",u="#666666",g="#c9ccd2",p="#3266ca",m="#FFFFFF",f="#CACACA",v=11982760,b="#017E84",S="#188038",y="#E0E2E4",C="#4A4F59",w="#999",E="#E2E3E3",x="#BCBCBC",I="#9B359B",R="#4EA7F2",T="#EA6175",A="#AAAAAA",_="#111827",D="#D8DADD",O="#E7E9ED",F="#F9FAFB",M="#374151",P=M+"C2",N="#111827",k="#714B67",L=O,V=D,H="#111827",U="#e6f2f3",B="#111827",z="#017E84",$="#D44C591A",W="#C34A41",G="#98DBE2",q="#E6F2F3",Z=20,j=10,Y=15,X=16,K=12,J="#F28C28",Q=["#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"],ee=26,te=48,oe=96,se=23,ie=15,re=4,ne=re,ae=21,le=17,ce=2*se,he=250,de={align:"left",verticalAlign:"bottom",wrapping:"overflow",bold:!1,italic:!1,strikethrough:!1,underline:!1,fontSize:10,fillColor:"",textColor:""},ue=de.verticalAlign,ge=de.wrapping,pe="400",me=de.fontSize,fe="'Roboto', arial",ve="thin",be="#000000",Se="START_REVISION",ye=1,Ce=20,we="??",Ee="difference",xe="#43C5B1",Ie="#EA6175",Re=.4,Te=2,Ae=["'","*","?","/","\\","[","]"],_e=/'|\*|\?|\/|\\|\[|\]/,De="|";var Oe;!function(e){e[e.Grid=0]="Grid",e[e.Highlight=5]="Highlight",e[e.HeaderGroupingButton=6]="HeaderGroupingButton",e[e.Figure=10]="Figure",e[e.ScrollBar=15]="ScrollBar",e[e.GridPopover=19]="GridPopover",e[e.GridComposer=20]="GridComposer",e[e.Dropdown=21]="Dropdown",e[e.IconPicker=25]="IconPicker",e[e.TopBarComposer=30]="TopBarComposer",e[e.Popover=35]="Popover",e[e.FigureAnchor=1e3]="FigureAnchor",e[e.FigureSnapLine=1001]="FigureSnapLine"}(Oe||(Oe={}));let Fe=0;function Me(){return Fe}const Pe="\n",Ne=[6,7,8,9,10,11,12,14,18,24,36],ke={hasFilters:!1,totalRow:!1,firstColumn:!0,lastColumn:!1,numberOfHeaders:1,bandedRows:!0,bandedColumns:!1,styleId:"TableStyleMedium5",automaticAutofill:!1},Le={symbol:"$",position:"before",decimalPlaces:2,code:"",name:"Dollar"},Ve=new RegExp(_e,"g");function He(e){return'"'===e[0]&&(e=e.slice(1)),'"'===e[e.length-1]&&"\\"!==e[e.length-2]?e.slice(0,e.length-1):e}function Ue(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Be(e){const t=Array.isArray(e)?[]:{};switch(typeof e){case"object":if(null===e)return e;if(function(e){return"clone"in e&&e.clone instanceof Function}(e))return e.clone();if(!(function(e){return"object"==typeof e&&null!==e&&(e?.constructor===Object||void 0===e?.constructor)}(e)||e instanceof Array))throw new Error("Unsupported type: only objects and arrays are supported");for(const o in e)t[o]=Be(e[o]);return t;case"number":case"string":case"boolean":case"function":case"undefined":return e;default:throw new Error("Unsupported type: "+typeof e)}}function ze(e){return $e(e,"'")}function $e(e,t='"'){return e.startsWith(t)&&(e=e.slice(1)),e.endsWith(t)&&(e=e.slice(0,-1)),e}function We(e){return e.match(/\w/g)?.length!==e.length&&(e=`'${e}'`),e}function Ge(e,t=" "){return e.replace(Ve,t)}function qe(e,t,o){return e<t?t:e>o?o:e}function Ze(e,t,o=1){if(t<=e&&o>0)return[];if(0===o)throw new Error("range() step must not be zero");const s=Math.ceil(Math.abs((t-e)/o)),i=Array(s);for(let t=0;t<s;t++)i[t]=e+t*o;return i}function je(e){return e.reduce(((e,t,o,s)=>{if(1===Math.abs(t-s[o-1])){e[e.length-1].push(t)}else e.push([t]);return e}),[])}function*Ye(e,t){t.next();for(const o of e){const e=t.next();yield{...o,next:e.done?void 0:e.value}}}function Xe(e){const t=e.toUpperCase();return"TRUE"===t||"FALSE"===t}const Ke=/^\[(.+)\]\((.+)\)$/,Je=/^https?:\/\/(www\.)?[-a-zA-Z0-9@:%._\+~#=]{2,256}\.[a-z]{2,4}\b([-a-zA-Z0-9@:%_\+.~#?&//=]*)$/;function Qe(e){return Ke.test(e)}function et(e){return Je.test(e)}function tt(e,t){return`[${e}](${t})`}function ot(e){const t=e.match(Ke)||[],o=t[1],s=t[2];if(!o||!s)throw new Error(`Could not parse markdown link ${e}.`);return{label:o,url:s}}const st="o-spreadsheet://";function it(e){return e.startsWith(st)}function rt(e){return`${st}${e}`}function nt(e){if(e.startsWith(st))return e.slice(st.length);throw new Error(`${e} is not a valid sheet link`)}function at(e){return void 0!==e}function lt(e){return null!==e}function ct(e){return void 0===e||Object.values(e).every((e=>"object"==typeof e?ct(e):!e))}function ht(e,t,o){let s;const i=function(){const i=this,r=Array.from(arguments);const n=o&&!s;clearTimeout(s),s=setTimeout((function(){s=void 0,o||e.apply(i,r)}),t),n&&e.apply(i,r)};return i.isDebouncePending=()=>void 0!==s,i.stopDebounce=()=>{clearTimeout(s)},i}function dt(e){let t="";for(let o=0,s=e.length;o<s;o++)t+=e[o];return t}function ut(e){let t,o=!1;const s=()=>(o||(t=e instanceof Function?e():e,o=!0),t);return s.map=e=>ut((()=>e(s()))),s}function gt(e,t){let o=e.slice(t).find((e=>e));return o||(o=e.slice(0,t).reverse().find((e=>e))),o||""}function pt(e,t){return"after"===e?t+1:t}function mt(e,t){if(e===t)return!0;if(e&&!t||t&&!e)return!1;if(typeof e!=typeof t)return!1;if("object"!=typeof e)return!1;for(const o in t)if(!(o in e)&&void 0!==t[o])return!1;for(const o in e){if(typeof e[o]!=typeof t[o])return!1;if("object"==typeof e[o]){if(!mt(e[o],t[o]))return!1}else if(e[o]!==t[o])return!1}return!0}function ft(e,t){if(e.length!==t.length)return!1;for(let o=0;o<e.length;o++)if(!mt(e[o],t[o]))return!1;return!0}function vt(e,t){return t.every((t=>e.includes(t)))}function bt(e){if(!e)return e;const t={...e};return Object.keys(t).forEach((e=>!t[e]&&delete t[e])),t}const St=[" ","\t","\f","\v",String.fromCharCode(parseInt("00a0",16)),String.fromCharCode(parseInt("1680",16)),String.fromCharCode(parseInt("2000",16)),String.fromCharCode(parseInt("200a",16)),String.fromCharCode(parseInt("2028",16)),String.fromCharCode(parseInt("2029",16)),String.fromCharCode(parseInt("202f",16)),String.fromCharCode(parseInt("205f",16)),String.fromCharCode(parseInt("3000",16)),String.fromCharCode(parseInt("feff",16))],yt=new RegExp(St.join("|"),"g"),Ct=/(\r\n|\r)/g;function wt(e){return e?e.replace(Ct,Pe):""}function Et(e){const t=Array.from(e).sort(((e,t)=>e-t));for(let e=1;e<t.length;e++)if(t[e]-t[e-1]!=1)return!1;return!0}function xt(e){const t=new Map,o=e.name?e.name+" (memoized)":"memoized";return{[o]:(...o)=>(t.has(o[0])||t.set(o[0],e(...o)),t.get(o[0]))}[o]}function It(e,t){return e.filter(((e,o)=>!t.includes(o)))}function Rt(e,t,o){const s=[...e];return s.splice(o,0,...t),s}function Tt(e){return e.split("\n").map((e=>e.replace(/\s+/g," ").trim())).join("\n")}function At(e,t,o){return t>o?At(e,o,t):e>=t&&e<=o}function _t(e,t){let o=Ue(e);const s=t.matchCase?"":"i";return t.exactMatch&&(o=`^${o}$`),RegExp(o,s)}function Dt(e){let t=e.length;if(t<1e5)return Math.max(...e);let o=-1/0;for(;t--;)o=e[t]>o?e[t]:o;return o}function Ot(e){let t=e.length;if(t<1e5)return Math.min(...e);let o=1/0;for(;t--;)o=e[t]<o?e[t]:o;return o}class Ft{text;currentIndex=0;current;constructor(e){this.text=e,this.current=e[0]}shift(){const e=this.current,t=this.text[++this.currentIndex];return this.current=t,e}advanceBy(e){this.currentIndex+=e,this.current=this.text[this.currentIndex]}isOver(){return this.currentIndex>=this.text.length}remaining(){return this.text.substring(this.currentIndex)}currentStartsWith(e){if(this.current!==e[0])return!1;for(let t=1;t<e.length;t++)if(this.text[this.currentIndex+t]!==e[t])return!1;return!0}}function Mt(e,t=(e=>e)){const o=new Set;return e.filter((e=>{const s=t(e);return!o.has(s)&&(o.add(s),!0)}))}function Pt(e){const t={};for(const o in e)for(const s in e[o])t[s]||(t[s]={}),t[s][o]=e[o][s];return t}const Nt=/rgba?\(|\s+|\)/gi,kt=/^#([A-F\d]{2}){3,4}$/,Lt=["#eb6d00","#0074d9","#ad8e00","#169ed4","#b10dc9","#00a82d","#00a3a3","#f012be","#3d9970","#111111","#62A300","#ff4136","#949494","#85144b","#001f3f"];function Vt(e){return Ut(e.toString(16).padStart(6,"0"))}function Ht(e){return"number"==typeof e?e:Number.parseInt(Ut(e).slice(1),16)}function Ut(e){let t=e;if(e.startsWith("rgb")?t=function(e){const t=e.replace(Nt,"").split(",");let o=255;if(3!==t.length&&4!==t.length)throw new Error("invalid color");if(4===t.length){const e=parseFloat(t.pop()||"1");o=Math.round(255*(e||1))}const s=t.map((e=>parseInt(e,10)));255!==o&&s.push(o);return"#"+dt(s.map((e=>e.toString(16).padStart(2,"0")))).toUpperCase()}(e):(t=e.replace("#","").toUpperCase(),3!==t.length&&4!==t.length||(t=t.split("").reduce(((e,t)=>e+t+t),"")),t=`#${t}`),!kt.test(t))throw new Error(`invalid color input: ${e}`);return t}function Bt(e){try{return Ut(e),!0}catch(e){return!1}}const zt=e=>e>=0&&e<=255;function $t(e,t,o,s=1){if(!zt(e)||!zt(t)||!zt(o)||s<0||s>1)throw new Error(`Invalid RGBA values ${[e,t,o,s]}`);return{a:s,b:o,g:t,r:e}}function Wt(e){let{r:t,g:o,b:s}=qt(e);t/=255,o/=255,s/=255;const i=e=>e<=.03928?e/12.92:((e+.055)/1.055)**2.4;return.2126*i(t)+.7152*i(o)+.0722*i(s)}function Gt(e){let t=e.r.toString(16),o=e.g.toString(16),s=e.b.toString(16),i=Math.round(255*e.a).toString(16);return 1===t.length&&(t="0"+t),1===o.length&&(o="0"+o),1===s.length&&(s="0"+s),1===i.length&&(i="0"+i),"ff"===i&&(i=""),("#"+t+o+s+i).toUpperCase()}function qt(e){let t,o,s,i;if(7===(e=Ut(e)).length)t=parseInt(e[1]+e[2],16),o=parseInt(e[3]+e[4],16),s=parseInt(e[5]+e[6],16),i=255;else{if(9!==e.length)throw new Error("Invalid color");t=parseInt(e[1]+e[2],16),o=parseInt(e[3]+e[4],16),s=parseInt(e[5]+e[6],16),i=parseInt(e[7]+e[8],16)}return i=+(i/255).toFixed(3),{a:i,r:t,g:o,b:s}}function Zt(e){(e={...e}).s/=100,e.l/=100;let t=(1-Math.abs(2*e.l-1))*e.s,o=t*(1-Math.abs(e.h/60%2-1)),s=e.l-t/2,i=0,r=0,n=0;return 0<=e.h&&e.h<60?(i=t,r=o,n=0):60<=e.h&&e.h<120?(i=o,r=t,n=0):120<=e.h&&e.h<180?(i=0,r=t,n=o):180<=e.h&&e.h<240?(i=0,r=o,n=t):240<=e.h&&e.h<300?(i=o,r=0,n=t):300<=e.h&&e.h<360&&(i=t,r=0,n=o),i=Math.round(255*(i+s)),r=Math.round(255*(r+s)),n=Math.round(255*(n+s)),{a:e.a,r:i,g:r,b:n}}function jt(e){const t=e.r/255,o=e.g/255,s=e.b/255;let i=Math.min(t,o,s),r=Math.max(t,o,s),n=r-i,a=0,l=0,c=0;return a=0===n?0:r===t?(o-s)/n%6:r===o?(s-t)/n+2:(t-o)/n+4,a=Math.round(60*a),a<0&&(a+=360),c=(r+i)/2,l=0===n?0:n/(1-Math.abs(2*c-1)),l=+(100*l).toFixed(1),c=+(100*c).toFixed(1),{a:e.a,h:a,s:l,l:c}}function Yt(e){return Gt(Zt(e))}function Xt(e){return jt(qt(e))}function Kt(e,t){return 1===t?Ut(e).slice(0,7):Gt({...qt(e),a:t})}function Jt(e,t){const o=Xt(e);return 1===t?"#fff":(o.l=t*(100-o.l)+o.l,Yt(o))}function Qt(e,t){const o=Xt(e);return 1===t?"#000":(o.l=o.l-t*o.l,Yt(o))}const eo=["#4EA7F2","#EA6175","#43C5B1","#F4A261","#8481DD","#FFD86D"],to=["#4EA7F2","#3188E6","#43C5B1","#00A78D","#EA6175","#CE4257","#F4A261","#F48935","#8481DD","#5752D1","#FFD86D","#FFBC2C"],oo=["#4EA7F2","#3188E6","#056BD9","#A76DBC","#7F4295","#6D2387","#EA6175","#CE4257","#982738","#43C5B1","#00A78D","#0E8270","#F4A261","#F48935","#BE5D10","#8481DD","#5752D1","#3A3580","#A4A8B6","#7E8290","#545B70","#FFD86D","#FFBC2C","#C08A16"],so=["#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"],io=["#4EA7F2","#43C5B1","#EA6175","#F4A261","#8481DD","#FFD86D","#3188E6","#00A78D","#CE4257","#F48935","#5752D1","#FFBC2C"],ro=["#4EA7F2","#A76DBC","#EA6175","#43C5B1","#F4A261","#8481DD","#A4A8B6","#FFD86D","#3188E6","#7F4295","#CE4257","#00A78D","#F48935","#5752D1","#7E8290","#FFBC2C","#056BD9","#6D2387","#982738","#0E8270","#BE5D10","#3A3580","#545B70","#C08A16"],no=["#4EA7F2","#A76DBC","#EA6175","#43C5B1","#F4A261","#8481DD","#A4A8B6","#FFD86D","#3188E6","#7F4295","#CE4257","#00A78D","#F48935","#5752D1","#7E8290","#FFBC2C","#056BD9","#6D2387","#982738","#0E8270","#BE5D10","#3A3580","#545B70","#C08A16","#155193","#4F1565","#791B29","#105F53","#7D380D","#26235F","#3F4250","#936A12"];function ao(e,t){return t[e%t.length]}function lo(e){return e<=6?eo:e<=12?to:e<=24?oo:so}class co{preferredColors;currentColorIndex=0;palette;constructor(e,t=[]){this.preferredColors=t,this.palette=lo(e).filter((e=>!t.includes(e)))}next(){return this.preferredColors?.[this.currentColorIndex]?this.preferredColors[this.currentColorIndex++]:ao(this.currentColorIndex++,this.palette)}}class ho extends co{constructor(e,t=[]){var o;super(e,t),this.palette=(o=e,o<=6?eo:o<=12?io:o<=24?ro:no).filter((e=>!t.includes(e)))}}function uo(e){if(e.length<2)throw new Error("Color scale must have at least 2 points");const t=[...e.sort(((e,t)=>e.value-t.value))],o=[];for(let e=1;e<t.length;e++){const s=Ht(t[e-1].color),i=Ht(t[e].color);o.push({min:t[e-1].value,max:t[e].value,minColor:s,maxColor:i,colorDiff:go(t[e-1].value,t[e].value,s,i)})}return e=>{if(e<o[0].min)return Vt(o[0].minColor);for(const t of o)if(e>=t.min&&e<=t.max)return Vt(po(e,t.min,t.minColor,t.colorDiff));return Vt(o[o.length-1].maxColor)}}function go(e,t,o,s){const i=t-e;return[((o>>16)%256-(s>>16)%256)/i,((o>>8)%256-(s>>8)%256)/i,(o%256-s%256)/i]}function po(e,t,o,s){const[i,r,n]=s;return Math.round((o>>16)%256-i*(e-t))<<16|Math.round((o>>8)%256-r*(e-t))<<8|Math.round(o%256-n*(e-t))}function mo(e){if(e<0)throw new Error(`number must be positive. Got ${e}`);return e<26?String.fromCharCode(65+e):mo(Math.floor(e/26)-1)+mo(e%26)}function fo(e){let t=0;const o=e.length;for(let s=0;s<o;s++){const o=e.charCodeAt(s);t=26*t+(o>=65&&o<=90?o-64:o-96)}return t-1}function vo(e){return e>="0"&&e<="9"}function bo(e){let t="",o="",s=0;for("$"===(e=e.trim())[s]&&s++;s<e.length&&((i=e[s])>="A"&&i<="Z"||i>="a"&&i<="z");)t+=e[s++];var i;if(0===t.length||t.length>3)throw new Error(`Invalid cell description: ${e}`);for("$"===e[s]&&s++;s<e.length&&vo(e[s]);)o+=e[s++];if(s!==e.length||0===o.length||o.length>7)throw new Error(`Invalid cell description: ${e}`);const r=fo(t),n=Number(o)-1;if(isNaN(n))throw new Error(`Invalid cell description: ${e}`);return{col:r,row:n}}function So(e,t,o={colFixed:!1,rowFixed:!1}){return(o.colFixed?"$":"")+mo(e)+(o.rowFixed?"$":"")+String(t+1)}function yo(e,t=[]){if(e.length<=1&&0===t.length)return e;const o=[0],s=new Map([[0,[]]]);return Co(o,s,e,!1),Co(o,s,t,!0),function(e,t){const o=[];let s=[];for(let i=0;i<e.length;i++){const r=e[i],n=t.get(r);if(!n||0===n.length){o.push(...s),s=[];continue}let a=e[i+1];void 0!==a&&a--;const l=[];for(let e=0;e<n.length;e+=2){const t=n[e];let o=n[e+1];void 0!==o&&o--;const i={top:t,left:r,bottom:o,right:a,hasHeader:void 0===o&&0!==t||void 0===a&&0!==r};let c=!1;for(let e=s.length-1;e>=0;e--){const t=s[e];if(t.top===i.top&&t.bottom===i.bottom){t.right=i.right,s.splice(e,1),l.push(t),c=!0;break}}c||l.push(i)}o.push(...s),s=l}return o.push(...s),o}(o,s)}function Co(e,t,o,s=!1){for(const i of o){const o=i.left,r=void 0===i.right?void 0:i.right+1,n=wo(e,t,o,!0,0),a=wo(e,t,r,!1,n);for(let o=n;o<=a;o++){Eo(t.get(e[o]),i,s)}xo(e,t,n,a)}}function wo(e,t,o,s,i){if(void 0===o)return e.length-1;const r=Io(e,o,i);return o!=e[r]?(e.splice(r+1,0,o),t.set(o,[...t.get(e[r])]),s?r+1:r):s?r:r-1}function Eo(e,t,o=!1){const s=t.top,i=void 0===t.bottom?void 0:t.bottom+1,r=[],n=Io(e,s,0,!1);if((n%2!=0&&!o||n%2==0&&o)&&r.push(s),void 0===i)return e.splice(n+1),void e.push(...r);const a=function(e,t,o=0,s=!0){let i=e.length-1,r=e.length;for(;o<=i;){const n=Math.floor((o+i)/2);if(e[n]===t&&s)return n;e[n]>t?(r=n,i=n-1):o=n+1}return r}(e,i,0,!1);(a%2==0&&!o||a%2!=0&&o)&&r.push(i),e.splice(n+1,a-n-1,...r)}function xo(e,t,o,s){const i=o-1==-1?0:o-1;for(let o=s===e.length-1?s:s+1;o>i;o--)ft(t.get(e[o]),t.get(e[o-1]))&&(t.delete(e[o]),e.splice(o,1))}function Io(e,t,o=0,s=!0){let i=e.length-1,r=-1;for(;o<=i;){const n=Math.floor((o+i)/2);if(e[n]===t&&s)return n;e[n]<t?(r=n,o=n+1):i=n-1}return r}const Ro=e=>e,To=()=>!1;let Ao=Ro,_o=To;function Do(e,...t){if(1!==t.length||"object"!=typeof t[0]||t[0]instanceof String)t.length>0&&(e=e.replace(/\%s/g,(()=>t.shift())));else{const o=t[0];e=e.replace(/\%\(([^\)]+)\)s/g,((e,t)=>o[t]))}return e}const Oo=function(e,...t){return _o()?Do(Ao(e),...t):new Fo(e,t)};class Fo extends String{values;constructor(e,t){super(e),this.values=t}valueOf(){const e=super.valueOf();return _o()?Do(Ao(e),...this.values):Do(e,...this.values)}toString(){return this.valueOf()}}const Mo=new RegExp(/\$?([A-Z]{1,3})\$?([0-9]{1,7})/,"i"),Po=new RegExp(/^\$?([A-Z]{1,3})\$?([0-9]{1,7})$/,"i"),No=new RegExp(/^\$?([A-Z]{1,3})+$/,"i"),ko=new RegExp(/^\$?([0-9]{1,7})+$/,"i"),Lo=new RegExp(/^\s*('.+'!|[^']+!)?\$?([A-Z]{1,3})$/,"i"),Vo=new RegExp(/^\s*('.+'!|[^']+!)?\$?([0-9]{1,7})$/,"i"),Ho=new RegExp(/^\s*('.+'!|[^']+!)?/.source+"("+[Mo.source,/(\$?[A-Z]{1,3})?\$?[0-9]{1,7}\s*:\s*(\$?[A-Z]{1,3})?\$?[0-9]{1,7}\s*/i.source,/\$?[A-Z]{1,3}(\$?[0-9]{1,7})?\s*:\s*\$?[A-Z]{1,3}(\$?[0-9]{1,7})?\s*/i.source].join("|")+")"+/$/.source,"i");function Uo(e){return Lo.test(e)}function Bo(e){return Vo.test(e)}function zo(e){return No.test(e)}function $o(e){return ko.test(e)}function Wo(e){return Po.test(e)}function Go(e){if(!e.includes("!"))return{xc:e};const t=e.split("!"),o=t.pop();return{sheetName:ze(t.join("!"))||void 0,xc:o}}function qo(e,t){return void 0!==e?`${We(e)}!${t}`:t}function Zo(e){const t=function(e){e.includes("!")&&(e=e.split("!").at(-1)),e.includes("$")&&(e=e.replaceAll("$",""));let t,o,s,i,r,n="";e.includes(":")?([n,t]=e.split(":"),n=n.trim(),t=t.trim()):n=e.trim();let a=!1,l=!1,c=!1;if(Uo(n))i=r=fo(n),o=s=0,a=!0;else if(Bo(n))o=s=parseInt(n,10)-1,i=r=0,l=!0;else{const e=bo(n);i=r=e.col,o=s=e.row,c=!0}if(t)if(Uo(t))r=fo(t),a=!0;else if(Bo(t))s=parseInt(t,10)-1,l=!0;else{const e=bo(t);r=e.col,s=e.row,o=a?s:o,i=l?r:i,c=!0}if(a&&l)throw new Error("Wrong zone xc. The zone cannot be at the same time a full column and a full row");const h={top:o,left:i,bottom:a?void 0:s,right:l?void 0:r};return c=c&&(l||a),c&&(h.hasHeader=c),h}(e);if(void 0!==t.right&&t.right<t.left){const e=t.left;t.left=t.right,t.right=e}if(void 0!==t.bottom&&t.bottom<t.top){const e=t.top;t.top=t.bottom,t.bottom=e}return t}function jo(e){const t=Zo(e);if(void 0===t.bottom||void 0===t.right)throw new Error("This does not support unbounded ranges");return t}function Yo(e){const{bottom:t,top:o,left:s,right:i}=e;return!(void 0!==t&&isNaN(t)||isNaN(o)||isNaN(s)||void 0!==i&&isNaN(i))&&(Xo(e)&&e.top>=0&&e.left>=0)}function Xo(e){return(void 0===e.bottom||e.bottom>=e.top&&e.bottom>=0)&&(void 0===e.right||e.right>=e.left&&e.right>=0)}function Ko(e){const{top:t,bottom:o,left:s,right:i}=e,r="hasHeader"in e&&e.hasHeader,n=t===o&&s===i;if(void 0===o&&void 0!==i)return 0!==t||r?`${So(s,t)}:${mo(i)}`:`${mo(s)}:${mo(i)}`;if(void 0===i&&void 0!==o)return 0!==s||r?`${So(s,t)}:${o+1}`:`${t+1}:${o+1}`;if(void 0!==o&&void 0!==i)return n?So(s,t):`${So(s,t)}:${So(i,o)}`;throw new Error(Oo("Bad zone format"))}function Jo(e,t,o,s,i){const r="left"===t?"columns":"rows",n="before"===s?o-1:o,a=e["left"===t?"right":"bottom"];return e[t]<=n&&a&&a>n?gs(e,r,"RESIZE",i):n<e[t]?gs(e,r,"MOVE",i):{...e}}function Qo(e,t,o,s,i){const r="left"===t?"columns":"rows",n="before"===s?o-1:o,a="left"===t?"right":"bottom";return e[t]<=n&&e[a]>n?gs(e,r,"RESIZE",i):n<e[t]?gs(e,r,"MOVE",i):{...e}}function es(e,t,o){const s="left"===t?"right":"bottom";let i=e[t],r=e[s];for(let n of o.sort(((e,t)=>t-e)))e[t]>n&&(i--,r--),e[t]<n&&e[s]>=n&&r--;return{...e,[t]:i,[s]:r}}function ts(e,t,o){const s="left"===t?"right":"bottom";let i=e[t],r=e[s];const n=e[s];for(let s of o.sort(((e,t)=>t-e)))e[t]>s&&(i--,void 0!==r&&r--),void 0!==n&&void 0!==r&&e[t]<=s&&n>=s&&r--;if(!(void 0!==r&&i>r))return{...e,[t]:i,[s]:r}}function os(...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 ss(e,t){if(rs(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 is(e,t){return e.left===t.left&&e.right===t.right&&e.top===t.top&&e.bottom===t.bottom}function rs(e,t){return!(e.bottom<t.top||t.bottom<e.top)&&!(e.right<t.left||t.right<e.left)}function ns(e,t,o){const{left:s,right:i,top:r,bottom:n}=o;return e>=s&&e<=i&&t>=r&&t<=n}function as(e,t){return is(os(t,e),t)}function ls(e){return{numberOfRows:e.bottom-e.top+1,numberOfCols:e.right-e.left+1}}function cs(e){const{numberOfCols:t,numberOfRows:o}=ls(e);return 1===t||1===o}function hs(e){const t={};for(const o of e)t[o.sheetId]??=[],t[o.sheetId].push(ms(o));for(const e in t)t[e]=yo(t[e]);return t}function ds(e){const t=[],{left:o,right:s,top:i,bottom:r}=us(e);for(const e of Ze(o,s+1))for(const o of Ze(i,r+1))t.push({col:e,row:o});return t}function us(e){return e.left>e.right&&(e={left:e.right,right:e.left,top:e.top,bottom:e.bottom}),e.top>e.bottom&&(e={left:e.left,right:e.right,top:e.bottom,bottom:e.top}),e}function gs(e,t,o,s){const i="both"===t?s[0]:"columns"===t?s:0,r="both"===t?s[1]:"rows"===t?s:0,n="hasHeader"in e&&e.hasHeader;let a;a=!function(e){return void 0===e.bottom}(e)||n?!(vs(e)&&!n)||"columns"!==t:"rows"!==t;const l={...e};return a&&"MOVE"===o&&(l.left+=i,l.top+=r),void 0!==l.right&&(l.right+=i),void 0!==l.bottom&&(l.bottom+=r),l}function ps(e,t){let o,s;const{left:i,right:r,top:n,bottom:a}=e,{left:l,right:c,top:h,bottom:d}=t;return o=l!=i?l:c!=r?c:l,s=h!=n?h:d!=a?d:h,{col:o,row:s}}function ms(e){return{left:e.col,right:e.col,top:e.row,bottom:e.row}}function fs(e){return{...e,right:e.left,bottom:e.top}}function vs(e){return void 0===e.right}function bs(e){return(e.bottom-e.top+1)*(e.right-e.left+1)}function Ss(e){return e.length<2||1===yo(e).length}function ys(e){const t=[...e];let o=!0;for(;o;){o=!1;for(let e=0;e<t.length;e++){const s=t[e],i=t.findIndex(((t,o)=>{return e!==o&&(r=s,((i=t).right+1===r.left||i.left===r.right+1?i.top<=r.bottom&&i.top>=r.top||r.top<=i.bottom&&r.top>=i.top:(i.bottom+1===r.top||i.top===r.bottom+1)&&(i.left<=r.right&&i.left>=r.left||r.left<=i.right&&r.left>=i.left))||rs(t,s));var i,r}));if(-1!==i){t[e]=os(t[i],s),t.splice(i,1),o=!0;break}}}return t}function Cs(e,t){for(const o in t)if(mt(t[o],e))return parseInt(o,10);const o=Object.keys(t),s=0===o.length?0:Dt(o.map((e=>parseInt(e,10))));return t[s+1]=e,s+1}function ws(e){const t={};for(const o in e){const s=yo(e[o].map(ms));for(const e of s)t[Ko(e)]=Number(o)}return t}function*Es(e,t){for(const o in t){const s=jo(o),i=t[o];for(let t=s.top;t<=s.bottom;t++)for(let o=s.left;o<=s.right;o++){const s={sheetId:e,col:o,row:t};yield[s,i]}}}class xs{jsDate;constructor(e,t,o,s=0,i=0,r=0){this.jsDate=new Date(Date.UTC(e,t,o,s,i,r,0))}static fromTimestamp(e){const t=new Date(e);return new xs(t.getUTCFullYear(),t.getUTCMonth(),t.getUTCDate(),t.getUTCHours(),t.getUTCMinutes(),t.getUTCSeconds())}static now(){const e=new Date;return new xs(e.getFullYear(),e.getMonth(),e.getDate(),e.getHours(),e.getMinutes(),e.getSeconds())}toString(){return this.jsDate.toString()}toLocaleDateString(){return this.jsDate.toLocaleDateString()}getTime(){return this.jsDate.getTime()}getFullYear(){return this.jsDate.getUTCFullYear()}getMonth(){return this.jsDate.getUTCMonth()}getQuarter(){return Math.floor(this.getMonth()/3)+1}getDate(){return this.jsDate.getUTCDate()}getDay(){return this.jsDate.getUTCDay()}getHours(){return this.jsDate.getUTCHours()}getMinutes(){return this.jsDate.getUTCMinutes()}getSeconds(){return this.jsDate.getUTCSeconds()}getIsoWeek(){const e=new Date(this.jsDate.getTime()),t=e.getUTCDay()||7;e.setUTCDate(e.getUTCDate()+4-t);const o=new Date(Date.UTC(e.getUTCFullYear(),0,1));return Math.ceil(((e.getTime()-o.getTime())/864e5+1)/7)}setFullYear(e){return this.jsDate.setUTCFullYear(e)}setMonth(e){return this.jsDate.setUTCMonth(e)}setDate(e){return this.jsDate.setUTCDate(e)}setHours(e){return this.jsDate.setUTCHours(e)}setMinutes(e){return this.jsDate.setUTCMinutes(e)}setSeconds(e){return this.jsDate.setUTCSeconds(e)}}const Is=new xs(1899,11,30),Rs=864e5,Ts=2e3,As=xs.now().getFullYear(),_s=xs.now().getMonth(),Ds=xs.fromTimestamp(0).getTime()-Is.getTime(),Os=/^\d{1,2}(\/|-|\s)\d{1,2}((\/|-|\s)\d{1,4})?$/,Fs=/^\d{3,4}(\/|-|\s)\d{1,2}(\/|-|\s)\d{1,2}$/,Ms=/\/|-|\s/,Ps=/^(\d{1,4})[\/-\s](\d{1,4})([\/-\s](\d{1,4}))?$/,Ns=/((\d+(:\d+)?(:\d+)?\s*(AM|PM))|(\d+:\d+(:\d+)?))$/;function ks(e,t){switch(typeof e){case"number":return e;case"string":return Ls(e,t)?Hs(e,t)?.value:!e||isNaN(Number(e))?void 0:Number(e);default:return}}function Ls(e,t){return null!==Hs(e,t)}const Vs=new Map;function Hs(e,t){return Vs.has(t)||Vs.set(t,new Map),Vs.get(t).has(e)||Vs.get(t).set(e,function(e,t){e=e.trim();let o=null;const s=e.match(Ns);if(s){if(o=function(e){if(e=e.trim(),Ns.test(e)){const t=/AM/i.test(e),o=/PM/i.test(e),s=(t||o?e.substring(0,e.length-2).trim():e).split(/:/),i=s.length>=2,r=3===s.length;let n=Number(s[0]),a=i?Number(s[1]):0,l=r?Number(s[2]):0,c=r?"hh:mm:ss":"hh:mm";if(t||o)c+=" a";else if(!i)return null;n>=12&&t?n-=12:n<12&&o&&(n+=12),a+=Math.floor(l/60),l%=60,n+=Math.floor(a/60),a%=60,n>=24&&(c="hhhh:mm:ss");return{value:n/24+a/1440+l/86400,format:c,jsDate:new xs(1899,11,30,n,a,l)}}return null}(s[0]),null===o)return null;e=e.replace(s[0],"").trim()}let i=null;const r=function(e,t){const o=e.match(Ps);if(!o)return null;const[,s,i,,r]=o;if(s.length>2&&r&&r.length>2)return null;if(s.length>2)return{year:s,month:i,day:r,dateString:e,type:"ymd"};const n=function(e){switch(e.dateFormat[0]){case"d":return"dmy";case"m":return"mdy";case"y":return"ymd"}throw new Error("Invalid date format in locale")}(t);if(!r)return i.length>2?{month:s,year:i,day:void 0,dateString:e,type:n}:"dmy"===n?{day:s,month:i,year:r,dateString:e,type:"dmy"}:{month:s,day:i,year:r,dateString:e,type:"mdy"};if(r.length>2)return"mdy"===n?{month:s,day:i,year:r,dateString:e,type:"mdy"}:{day:s,month:i,year:r,dateString:e,type:"dmy"};if("mdy"===n)return{month:s,day:i,year:r,dateString:e,type:"mdy"};if("ymd"===n)return{year:s,month:i,day:r,dateString:e,type:"ymd"};if("dmy"===n)return{day:s,month:i,year:r,dateString:e,type:"dmy"};return null}(e,t);if(r){const t=r.dateString.match(Ms)[0];if(i=function(e,t){let{year:o,month:s,day:i}=e;const r=function(e){if(!e)return _s;const t=Number(e);if(t>=1&&t<=12)return t-1;return null}(s),n=function(e){if(!e)return 1;const t=Number(e);if(t>=0&&t<=31)return t;return null}(i),a=function(e){if(!e)return As;const t=Number(e);switch(e.length){case 1:return Ts+t;case 2:return Ts+(Ts+t>As+10?-100:0)+t;case 3:case 4:return t}return null}(o);if(null===a||null===r||null===n)return null;const l=2===s?.length&&r+1<10||2===i?.length&&n<10,c=2!==o?.length,h=new xs(a,r,n);if(h.getMonth()!==r||h.getDate()!==n)return null;const d=h.getTime()-Is.getTime(),u=function(e,t,o,s){const i=e.year?s?"yyyy":"yy":void 0,r=e.month?o?"mm":"m":void 0,n=e.day?o?"dd":"d":void 0;switch(e.type){case"mdy":return[r,n,i].filter(at).join(t);case"ymd":return[i,r,n].filter(at).join(t);case"dmy":return[n,r,i].filter(at).join(t)}}(e,t,l,c);return{value:Math.round(d/Rs),format:u,jsDate:h}}(r,t),null===i)return null;e=e.replace(r.dateString,"").trim()}if(""!==e||!i&&!o)return null;if(i&&i.jsDate&&o&&o.jsDate)return{value:i.value+o.value,format:i.format+" "+("hhhh:mm:ss"===o.format?"hh:mm:ss":o.format),jsDate:new xs(i.jsDate.getFullYear()+o.jsDate.getFullYear()-1899,i.jsDate.getMonth()+o.jsDate.getMonth()-11,i.jsDate.getDate()+o.jsDate.getDate()-30,i.jsDate.getHours()+o.jsDate.getHours(),i.jsDate.getMinutes()+o.jsDate.getMinutes(),i.jsDate.getSeconds()+o.jsDate.getSeconds())};return i||o}(e,t)),Vs.get(t).get(e)}function Us(e){const t=Math.trunc(e);let o=xs.fromTimestamp(t*Rs-Ds),s=e-t;s=s<0?1+s:s;const i=Math.round(24*s),r=Math.round(24*(s-i/24)*60),n=Math.round(24*(s-i/24-r/24/60)*60*60);return o.setHours(i),o.setMinutes(r),o.setSeconds(n),o}function Bs(e){return Math.round(zs(e))}function zs(e){return(e.getTime()-Is.getTime())/Rs}function $s(e){return new xs(e.getFullYear(),e.getMonth()+1,0).getDate()}function Ws(e){return $s(e)===e.getDate()}function Gs(e,t,o){const s=e.getFullYear(),i=e.getMonth(),r=e.getDate(),n=new xs(s,i+t,1);return o&&r===$s(e)||r>$s(n)?n.setDate($s(n)):n.setDate(r),n}function qs(e){const t=Math.trunc(e);return t%4==0&&t%100!=0||t%400==0}function Zs(e,t,o){if(e===t)return 0;if(e>t){const o=t;t=e,e=o}const s=Us(e),i=Us(t);let r=s.getDate(),n=i.getDate();const a=s.getMonth(),l=i.getMonth(),c=s.getFullYear(),h=i.getFullYear();let d=0,u=0;switch(o){case 0:31===r&&(r=30),30===r&&31===n&&(n=30),1===a&&r===(qs(c)?29:28)&&(r=30,1===l&&n===(qs(h)?29:28)&&(n=30)),d=c+(30*a+r)/360,u=h+(30*l+n)/360;break;case 1:let o=365;const s=c===h;if(!s&&!(c+1===h)||!s&&a<l||!s&&a===l&&r<n){let e=0,t=0;for(let o=c;o<=h;o++)e++,t+=qs(o)?366:365;o=t/e}else s?qs(c)&&(o=366):(qs(c)&&a<2&&(o=366),qs(h)&&(l>1||1===l&&29===n)&&(o=366));d=e/o,u=t/o;break;case 2:d=e/360,u=t/360;break;case 3:d=e/365,u=t/365;break;case 4:31===r&&(r=30),31===n&&(n=30),d=c+(30*a+r)/360,u=h+(30*l+n)/360}return u-d}function js(e,t){const o=12*(t.getFullYear()-e.getFullYear())+t.getMonth()-e.getMonth();return e.getDate()>t.getDate()?o-1:o}function Ys(e,t){const o=e.getTime(),s=t.getTime();return Math.floor((s-o)/Rs)}function Xs(e,t){const o=t.getFullYear()-e.getFullYear(),s=e.getMonth(),i=t.getMonth(),r=e.getDate(),n=t.getDate();return i>s||i===s&&n>=r?o:o-1}function Ks(e,t,o){return t>o?Ks(e,o,t):(e=Math.trunc(e),t=Math.trunc(t),o=Math.trunc(o),e>=t&&e<=o)}const Js=xt((function(e){return e=Ue(e),new RegExp(`(?:^-?\\d+(?:${e}?\\d*(?:e\\d+)?)?|^-?${e}\\d+)(?!\\w|!)`)})),Qs=xt((function(e){const t=Ue(e.decimalSeparator),o="(?:\\s*"+`(?:\\d+(?:${Ue(e.thousandsSeparator||"")}\\d{3,})*(?:${t}\\d*)?)`+"|"+`(?:${t}\\d+)`+")(?:e(?:\\+|-)?\\d+)?(?:\\s*%)?",s="(?:\\s*-)?",i="(?:\\s*[\\$€])?",r="^(?:(?:"+[s+i+o,s+o+i,i+s+o].join(")|(?:")+"))$";return new RegExp(r,"i")}));function ei(e,t){return!!e&&Qs(t).test(e.trim())}const ti=xt((function(e){return new RegExp(`[$€${Ue(e.thousandsSeparator||"")}]`,"g")}));function oi(e,t){e=e.replace(ti(t),""),"."!==t.decimalSeparator&&(e=e.replace(t.decimalSeparator,"."));let o=Number(e);return isNaN(o)&&e.includes("%")&&(o=Number(e.split("%")[0]),!isNaN(o))?o/100:o}function si(e,t,o){const s=[...e].sort(((e,t)=>e-t));let i=(s.length+(o?-1:1))*t;if(o||i--,Number.isInteger(i))return s[i];const r=Math.ceil(i),n=Math.floor(i);return s[r]*(i-n)+s[n]*(r-i)}var ii,ri;!function(e){e.boolean="boolean",e.number="number",e.text="text",e.empty="empty",e.error="error"}(ii||(ii={})),function(e){e.PlainText="text/plain",e.Html="text/html"}(ri||(ri={}));const ni=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"]),ai=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"]),li=new Set(["MOVE_RANGES"]),ci=new Set(["DUPLICATE_SHEET","EVALUATE_CELLS","ADD_CONDITIONAL_FORMAT","REMOVE_CONDITIONAL_FORMAT","CHANGE_CONDITIONAL_FORMAT_PRIORITY"]),hi=new Set(["AUTOFILL_CELL","SET_BORDER","SET_ZONE_BORDERS"]),di=new Set(["START","ACTIVATE_SHEET","COPY","RESIZE_SHEETVIEW","SET_VIEWPORT_OFFSET","EVALUATE_CELLS","EVALUATE_CHARTS","SET_FORMULA_VISIBILITY","UPDATE_FILTER"]),ui=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","CREATE_CHART","UPDATE_CHART","CREATE_TABLE","REMOVE_TABLE","UPDATE_TABLE","CREATE_TABLE_STYLE","REMOVE_TABLE_STYLE","CREATE_IMAGE","GROUP_HEADERS","UNGROUP_HEADERS","UNFOLD_HEADER_GROUP","FOLD_HEADER_GROUP","FOLD_ALL_HEADER_GROUPS","UNFOLD_ALL_HEADER_GROUPS","UNFOLD_HEADER_GROUPS_IN_ZONE","FOLD_HEADER_GROUPS_IN_ZONE","ADD_DATA_VALIDATION_RULE","REMOVE_DATA_VALIDATION_RULE","UPDATE_LOCALE","ADD_PIVOT","UPDATE_PIVOT","INSERT_PIVOT","RENAME_PIVOT","REMOVE_PIVOT","DUPLICATE_PIVOT"]);function gi(e){return ui.has(e.type)}class pi{reasons;constructor(e=[]){Array.isArray(e)||(e=[e]),e=[...new Set(e)],this.reasons=e.filter((e=>"Success"!==e))}static get Success(){return mi}get isSuccessful(){return 0===this.reasons.length}isCancelledBecause(e){return this.reasons.includes(e)}}const mi=new pi;var fi;e.CommandResult=void 0,(fi=e.CommandResult||(e.CommandResult={})).Success="Success",fi.CancelledForUnknownReason="CancelledForUnknownReason",fi.WillRemoveExistingMerge="WillRemoveExistingMerge",fi.MergeIsDestructive="MergeIsDestructive",fi.CellIsMerged="CellIsMerged",fi.InvalidTarget="InvalidTarget",fi.EmptyUndoStack="EmptyUndoStack",fi.EmptyRedoStack="EmptyRedoStack",fi.NotEnoughElements="NotEnoughElements",fi.NotEnoughSheets="NotEnoughSheets",fi.MissingSheetName="MissingSheetName",fi.UnchangedSheetName="UnchangedSheetName",fi.DuplicatedSheetName="DuplicatedSheetName",fi.DuplicatedSheetId="DuplicatedSheetId",fi.ForbiddenCharactersInSheetName="ForbiddenCharactersInSheetName",fi.WrongSheetMove="WrongSheetMove",fi.WrongSheetPosition="WrongSheetPosition",fi.InvalidAnchorZone="InvalidAnchorZone",fi.SelectionOutOfBound="SelectionOutOfBound",fi.TargetOutOfSheet="TargetOutOfSheet",fi.WrongCutSelection="WrongCutSelection",fi.WrongPasteSelection="WrongPasteSelection",fi.WrongPasteOption="WrongPasteOption",fi.WrongFigurePasteOption="WrongFigurePasteOption",fi.EmptyClipboard="EmptyClipboard",fi.EmptyRange="EmptyRange",fi.InvalidRange="InvalidRange",fi.InvalidZones="InvalidZones",fi.InvalidSheetId="InvalidSheetId",fi.InvalidFigureId="InvalidFigureId",fi.InputAlreadyFocused="InputAlreadyFocused",fi.MaximumRangesReached="MaximumRangesReached",fi.MinimumRangesReached="MinimumRangesReached",fi.InvalidChartDefinition="InvalidChartDefinition",fi.InvalidDataSet="InvalidDataSet",fi.InvalidLabelRange="InvalidLabelRange",fi.InvalidScorecardKeyValue="InvalidScorecardKeyValue",fi.InvalidScorecardBaseline="InvalidScorecardBaseline",fi.InvalidGaugeDataRange="InvalidGaugeDataRange",fi.EmptyGaugeRangeMin="EmptyGaugeRangeMin",fi.GaugeRangeMinNaN="GaugeRangeMinNaN",fi.EmptyGaugeRangeMax="EmptyGaugeRangeMax",fi.GaugeRangeMaxNaN="GaugeRangeMaxNaN",fi.GaugeRangeMinBiggerThanRangeMax="GaugeRangeMinBiggerThanRangeMax",fi.GaugeLowerInflectionPointNaN="GaugeLowerInflectionPointNaN",fi.GaugeUpperInflectionPointNaN="GaugeUpperInflectionPointNaN",fi.GaugeLowerBiggerThanUpper="GaugeLowerBiggerThanUpper",fi.InvalidAutofillSelection="InvalidAutofillSelection",fi.MinBiggerThanMax="MinBiggerThanMax",fi.LowerBiggerThanUpper="LowerBiggerThanUpper",fi.MidBiggerThanMax="MidBiggerThanMax",fi.MinBiggerThanMid="MinBiggerThanMid",fi.FirstArgMissing="FirstArgMissing",fi.SecondArgMissing="SecondArgMissing",fi.MinNaN="MinNaN",fi.MidNaN="MidNaN",fi.MaxNaN="MaxNaN",fi.ValueUpperInflectionNaN="ValueUpperInflectionNaN",fi.ValueLowerInflectionNaN="ValueLowerInflectionNaN",fi.MinInvalidFormula="MinInvalidFormula",fi.MidInvalidFormula="MidInvalidFormula",fi.MaxInvalidFormula="MaxInvalidFormula",fi.ValueUpperInvalidFormula="ValueUpperInvalidFormula",fi.ValueLowerInvalidFormula="ValueLowerInvalidFormula",fi.InvalidSortAnchor="InvalidSortAnchor",fi.InvalidSortZone="InvalidSortZone",fi.SortZoneWithArrayFormulas="SortZoneWithArrayFormulas",fi.WaitingSessionConfirmation="WaitingSessionConfirmation",fi.MergeOverlap="MergeOverlap",fi.TooManyHiddenElements="TooManyHiddenElements",fi.Readonly="Readonly",fi.InvalidViewportSize="InvalidViewportSize",fi.InvalidScrollingDirection="InvalidScrollingDirection",fi.ViewportScrollLimitsReached="ViewportScrollLimitsReached",fi.FigureDoesNotExist="FigureDoesNotExist",fi.InvalidConditionalFormatId="InvalidConditionalFormatId",fi.InvalidCellPopover="InvalidCellPopover",fi.EmptyTarget="EmptyTarget",fi.InvalidFreezeQuantity="InvalidFreezeQuantity",fi.FrozenPaneOverlap="FrozenPaneOverlap",fi.ValuesNotChanged="ValuesNotChanged",fi.InvalidFilterZone="InvalidFilterZone",fi.TableNotFound="TableNotFound",fi.TableOverlap="TableOverlap",fi.InvalidTableConfig="InvalidTableConfig",fi.InvalidTableStyle="InvalidTableStyle",fi.FilterNotFound="FilterNotFound",fi.MergeInTable="MergeInTable",fi.NonContinuousTargets="NonContinuousTargets",fi.DuplicatedFigureId="DuplicatedFigureId",fi.InvalidSelectionStep="InvalidSelectionStep",fi.DuplicatedChartId="DuplicatedChartId",fi.ChartDoesNotExist="ChartDoesNotExist",fi.InvalidHeaderIndex="InvalidHeaderIndex",fi.InvalidQuantity="InvalidQuantity",fi.MoreThanOneColumnSelected="MoreThanOneColumnSelected",fi.EmptySplitSeparator="EmptySplitSeparator",fi.SplitWillOverwriteContent="SplitWillOverwriteContent",fi.NoSplitSeparatorInSelection="NoSplitSeparatorInSelection",fi.NoActiveSheet="NoActiveSheet",fi.InvalidLocale="InvalidLocale",fi.MoreThanOneRangeSelected="MoreThanOneRangeSelected",fi.NoColumnsProvided="NoColumnsProvided",fi.ColumnsNotIncludedInZone="ColumnsNotIncludedInZone",fi.DuplicatesColumnsSelected="DuplicatesColumnsSelected",fi.InvalidHeaderGroupStartEnd="InvalidHeaderGroupStartEnd",fi.HeaderGroupAlreadyExists="HeaderGroupAlreadyExists",fi.UnknownHeaderGroup="UnknownHeaderGroup",fi.UnknownDataValidationRule="UnknownDataValidationRule",fi.UnknownDataValidationCriterionType="UnknownDataValidationCriterionType",fi.InvalidDataValidationCriterionValue="InvalidDataValidationCriterionValue",fi.InvalidNumberOfCriterionValues="InvalidNumberOfCriterionValues",fi.InvalidCopyPasteSelection="InvalidCopyPasteSelection",fi.NoChanges="NoChanges",fi.InvalidInputId="InvalidInputId",fi.SheetIsHidden="SheetIsHidden",fi.InvalidTableResize="InvalidTableResize",fi.PivotIdNotFound="PivotIdNotFound",fi.PivotInError="PivotInError",fi.EmptyName="EmptyName",fi.ValueCellIsInvalidFormula="ValueCellIsInvalidFormula",fi.InvalidDefinition="InvalidDefinition",fi.InvalidColor="InvalidColor";const vi=[{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:";"}],bi=vi[0],Si=["thin","medium","thick","dashed","dotted"];function yi(e){return Array.isArray(e)&&Array.isArray(e[0])}var Ci;!function(e){e.UP="up",e.DOWN="down",e.LEFT="left",e.RIGHT="right"}(Ci||(Ci={}));const wi={Background:0,Highlights:1,Clipboard:2,Chart:4,Autofill:5,Selection:6,Headers:100},Ei=xt((()=>Object.keys(wi).sort(((e,t)=>wi[e]-wi[t]))));const xi={NotAvailable:"#N/A",InvalidReference:"#REF",BadExpression:"#BAD_EXPR",CircularDependency:"#CYCLE",UnknownFunction:"#NAME?",DivisionByZero:"#DIV/0!",SpilledBlocked:"#SPILL!",GenericError:"#ERROR",NullError:"#NULL!"},Ii=new Set(Object.values(xi));class Ri extends Error{value;constructor(e=Oo("Error"),t=xi.GenericError){super(e),this.value=t}}class Ti extends Ri{constructor(e=Oo("Invalid expression")){super(e,xi.BadExpression)}}class Ai extends Ri{constructor(e=Oo("Invalid reference")){super(e,xi.InvalidReference)}}class _i extends Ri{constructor(e=Oo("Data not available")){super(e,xi.NotAvailable)}}class Di extends Ri{constructor(e=Oo("Unknown function")){super(e,xi.UnknownFunction)}}class Oi extends Ri{constructor(e=Oo("Spill range is not empty")){super(e,xi.SpilledBlocked)}}const Fi=["number","string","boolean","undefined"];function Mi(e,t,o){if(!e())throw new Ri(t,o)}function Pi(e){if(void 0!==e)return yi(e)?e[0][0]?.format:e.format}function Ni(e){return"string"==typeof e&&Ii.has(e)}const ki=e=>Oo("The function [[FUNCTION_NAME]] expects a number value, but '%s' is a string, and cannot be coerced to a number.",e);function Li(e,t){const o=Xi(e);switch(typeof o){case"number":return o;case"boolean":return o?1:0;case"string":if(ei(o,t)||""===o)return oi(o,t);const e=Hs(o,t);if(e)return e.value;throw new Ri(ki(o));default:return 0}}function Vi(e,t){try{return Li(e,t)}catch(e){return}}function Hi(e,t){return fr(e).map((e=>e.map((e=>{if("number"!=typeof e.value)throw new Ri(Oo("Function [[FUNCTION_NAME]] expects number values for %s, but got a %s.",t,typeof e.value));return e.value}))))}function Ui(e,t){const o=Xi(e);if(""===o)throw new Ri(ki(o));return Li(o,t)}function Bi(e,t){return Math.trunc(Li(e,t))}function zi(e,t){return Math.trunc(Ui(e,t))}function $i(e){Mi((()=>e>=1),Oo("The function [[FUNCTION_NAME]] expects a number value to be greater than or equal to 1, but receives %s.",e.toString()))}function Wi(e){Mi((()=>0!==e),Oo("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error."),xi.DivisionByZero)}function Gi(e){const t=Xi(e);switch(typeof t){case"string":return t;case"number":return t.toString();case"boolean":return t?"TRUE":"FALSE";default:return""}}const qi=xt((function(e){return e.toLowerCase().normalize("NFD").replace(/[\u0300-\u036f]/g,"")})),Zi=e=>Oo("The function [[FUNCTION_NAME]] expects a boolean value, but '%s' is a text, and cannot be coerced to a boolean.",e);function ji(e){const t=Xi(e);switch(typeof t){case"boolean":return t;case"string":if(t){let e=t.toUpperCase();if("TRUE"===e)return!0;if("FALSE"===e)return!1;throw new Ri(Zi(t))}return!1;case"number":return!!t;default:return!1}}function Yi(e,t){return Us(Li(Xi(e),t))}function Xi(e){if("object"==typeof e&&null!==e&&"value"in e){if(Ni(e.value))throw e;return e.value}if(Ni(e))throw new Ri("",e);return e}function Ki(e,t,o){for(let s of e)if(yi(s)){const e=s.length,o=s[0].length;for(let i=0;i<o;i++)for(let o=0;o<e;o++)t(s[o][i])}else o(s)}function Ji(e,t){Ki(e,(e=>{if(Ni(e.value))throw e;t(e)}),(e=>{if(Ni(e?.value))throw e;t(e)}))}function Qi(e,t,o){Ki(e,(e=>{if("number"==typeof e?.value&&t(e),Ni(e?.value))throw e}),(e=>{t({value:Ui(e,o),format:e?.format})}))}function er(e,t,o,s,i="rowFirst"){let r=s;for(let s of e)if(yi(s)){const e=s.length,o=s[0].length;if("rowFirst"===i)for(let i=0;i<o;i++)for(let o=0;o<e;o++)r=t(r,s[o][i]);else for(let i=0;i<e;i++)for(let e=0;e<o;e++)r=t(r,s[i][e])}else r=o(r,s);return r}function tr(e,t,o,s="rowFirst"){return er(e,t,t,o,s)}function or(e,t,o,s){return er(e,((e,o)=>{const s=o?.value;if("number"==typeof s)return t(e,s);if(Ni(s))throw o;return e}),((e,o)=>t(e,Ui(o,s))),o)}function sr(e,t,o,s){return er(e,((e,o)=>{const i=o?.value;if(null!=i){if("number"==typeof i)return t(e,i);if("boolean"==typeof i)return t(e,Li(i,s));if(Ni(i))throw o;return t(e,0)}return e}),((e,o)=>t(e,Li(o,s))),o)}function ir(e,t,o){const s=Array(e);for(let i=0;i<e;i++){s[i]=Array(t);for(let e=0;e<t;e++)s[i][e]=o(i,e)}return s}function rr(e,t){return 0===e.length?[]:ir(e.length,e[0].length,((o,s)=>t(e[o][s])))}function nr(e){return e.length?ir(e[0].length,e.length,((t,o)=>e[o][t])):[]}function ar(e,t){return function(e,t,o){for(let s of e)if(yi(s)){const e=s.length,o=s[0].length;for(let i=0;i<o;i++)for(let o=0;o<e;o++)if(!t(s[o][i]??void 0))return}else if(!o(s))return}(e,(e=>{const o=e?.value;if("boolean"==typeof o)return t(o);if("number"==typeof o)return t(!!o);if(Ni(o))throw e;return!0}),(e=>void 0===e||null===e.value||t(function(e){const t=Xi(e);if(""===t)throw new Ri(Zi(t));return ji(t)}(e))))}function lr(e,t){let o,s,i=e.substring(0,2);return"<="===i||">="===i||"<>"===i?(o=i,s=e.substring(2)):(i=e.substring(0,1),"<"===i||">"===i||"="===i?(o=i,s=e.substring(1)):(o="=",s=e)),ei(s,t)||Ls(s,t)?s=Li(s,t):"TRUE"!==s&&"FALSE"!==s||(s=ji(s)),{operator:o,operand:s}}const cr=xt((function(e){if("*"===e)return/.+/;let t="",o="";for(let s of e)"?"===s&&"~"!==o?t+=".":"*"===s&&"~"!==o?t+=".*":("*"!==s&&"?"!==s||(t=t.slice(0,-1)),["^",".","[","]","$","(",")","*","+","?","|","{","}","\\"].includes(s)&&(t+="\\"),t+=s),o=s;return new RegExp("^"+t+"$","i")}));function hr(e="",t,o){const{operator:s,operand:i}=t;if(void 0===i||null===e||null===i)return!1;if("number"==typeof i&&"="===s)return"string"==typeof e&&(ei(e,o)||Ls(e,o))?Li(e,o)===i:e===i;if("<>"===s||"="===s){let t;return t=typeof e==typeof i&&("string"==typeof e&&"string"==typeof i?cr(i).test(e):e===i),"="===s?t:!t}if(typeof e==typeof i)switch(s){case"<":return e<i;case">":return e>i;case"<=":return e<=i;case">=":return e>=i}return!1}function dr(e,t,o,s=!1){const i=e.length;if(i%2==1)throw new Ri(Oo("Function [[FUNCTION_NAME]] expects criteria_range and criterion to be in pairs."));const r=fr(e[0]),n=r.length,a=r[0].length;let l=[];for(let t=0;t<i-1;t+=2){const i=fr(e[t]);if(i.length!==n||i[0].length!==a)throw new Ri(Oo("Function [[FUNCTION_NAME]] expects criteria_range to have the same dimension"));const r=lr(Gi(e[t+1]),o);s&&"string"==typeof r.operand&&(r.operand+="*"),l.push(r)}for(let s=0;s<n;s++)for(let r=0;r<a;r++){let n=!0;for(let t=0;t<i-1;t+=2){if(n=hr(fr(e[t])[s][r].value??void 0,l[t/2],o),!n)break}n&&t(s,r)}}function ur(e,t,o,s,i,r){if(void 0===t||null===t.value)return-1;if(Ni(t.value))throw t;const n=pr(t.value),a=typeof n;let l,c,h,d,u,g,p=0,m=i-1;const f="desc"===s?t=>pr(r(e,i-t-1)):t=>pr(r(e,t));for(;m-p>=0;){for(h=Math.floor((p+m)/2),d=h,u=f(d),g=typeof u;p<d&&a!==g;)d--,u=f(d),g=typeof u;g===a&&null!=u?("strict"===o&&u===n?(l=u,c=d):"nextSmaller"===o&&u<=n?(null==l||l<u||l===u&&c<d)&&(l=u,c=d):"nextGreater"===o&&u>=n&&(void 0===l||l>u||l===u&&c<d)&&(l=u,c=d),u>n||"strict"===o&&u===n?m=d-1:p=h+1):p=h+1}return void 0===c?-1:"desc"===s?i-c-1:c}function gr(e,t,o,s,i,r=!1){if(void 0===t||null===t.value)return-1;if(Ni(t.value))throw t;const n=pr(t.value),a=r?(e,t)=>i(e,s-t-1):i;let l,c=t=>pr(a(e,t))===n;if("wildcard"===o&&"string"==typeof n&&(n.includes("*")||n.includes("?"))){const t=cr(n);c=o=>{const s=pr(a(e,o));return"string"==typeof s&&t.test(s)}}let h=-1;"nextSmaller"===o&&(c=t=>{const o=pr(a(e,t));return(!l&&mr(n,o)>=0||mr(n,o)>=0&&mr(o,l)>0)&&(l=o,h=t),o===n}),"nextGreater"===o&&(c=t=>{const o=pr(a(e,t));return(!l&&mr(n,o)<=0||mr(n,o)<=0&&mr(o,l)<0)&&(l=o,h=t),o===n});for(let e=0;e<s;e++)if(c(e))return r?s-e-1:e;return r&&-1!==h?s-h-1:h}function pr(e){return"string"==typeof e?qi(e):e}function mr(e,t){let o=Fi.indexOf(typeof e)-Fi.indexOf(typeof t);return 0===o&&("string"==typeof e&&"string"==typeof t?o=e.localeCompare(t):"number"==typeof e&&"number"==typeof t?o=e-t:"boolean"==typeof e&&"boolean"==typeof t&&(o=Number(e)-Number(t))),o}function fr(e){return void 0===e?[[]]:yi(e)?e:[[e]]}function vr(e,t){return tr(e,((e,o)=>(e.push(t(o)),e)),[],"rowFirst")}function br(e){if(void 0===e)return!1;const{value:t}=e;return null!==t&&""!==t}function Sr(e){return/^https?:\/\//i.test(e)?e:`https://${e}`}const yr=new r;function Cr(e,t){return{url:e=Sr(e),label:t||e,isExternal:!0,isUrlEditable:!0}}yr.add("sheet_URL",{match:e=>it(e),createLink:(e,t)=>({label:t,url:e,isExternal:!1,isUrlEditable:!1}),urlRepresentation(e,t){const o=nt(e);return t.tryGetSheetName(o)||Oo("Invalid sheet")},open(e,t){const o=nt(e);t.model.dispatch("ACTIVATE_SHEET",{sheetIdFrom:t.model.getters.getActiveSheetId(),sheetIdTo:o}).isCancelledBecause("SheetIsHidden")&&t.notifyUser({type:"warning",sticky:!1,text:Oo("Cannot open the link because the linked sheet is hidden.")})},sequence:0});const wr={createLink:Cr,match:e=>et(e),open:e=>window.open(e,"_blank"),urlRepresentation:e=>e,sequence:0};function Er(e){return yr.getAll().sort(((e,t)=>e.sequence-t.sequence)).find((t=>t.match(e)))||wr}function xr(e,t){return Er(e.url).urlRepresentation(e.url,t)}function Ir(e,t){Er(e.url).open(e.url,t)}function Rr(e){if("string"==typeof e){if(Qe(e)){const{label:t,url:o}=ot(e);return Er(o).createLink(o,t)}return et(e)?Cr(e):void 0}}function Tr(e){let t;if('"'===e.current?(e.shift(),t='"'):e.currentStartsWith("[$")&&(e.advanceBy(2),t="]"),!t)return null;let o="";for(;e.current&&e.current!==t;)o+=e.shift();if(e.current!==t)throw new Error("Unterminated string in format");return e.shift(),{type:"STRING",value:o}}const Ar=new Set("$+-/():!^&~{}<>= ");function _r(e){if("\\"===e.current){e.shift();const t=e.shift();if(!t)throw new Error("Unexpected end of format string");return{type:"CHAR",value:t}}return Ar.has(e.current)?{type:"CHAR",value:e.shift()}:null}function Dr(e){return","===e.current?(e.shift(),{type:"THOUSANDS_SEPARATOR",value:","}):null}function Or(e){return"@"===e.current?(e.shift(),{type:"TEXT_PLACEHOLDER",value:"@"}):null}function Fr(e){return"."===e.current?(e.shift(),{type:"DECIMAL_POINT",value:"."}):null}function Mr(e){return"%"===e.current?(e.shift(),{type:"PERCENT",value:"%"}):null}function Pr(e){if("0"===e.current||"#"===e.current){const t=e.current;return e.shift(),{type:"DIGIT",value:t}}return null}const Nr=new Set("dmqyhsa");function kr(e){if(!Nr.has(e.current))return null;const t=e.current;let o="";for(;e.current===t;)o+=e.shift();return{type:"DATE_PART",value:o}}function Lr(e){if("*"!==e.current)return null;e.shift();const t=e.shift();if(!t)throw new Error("Unexpected end of format string");return{type:"REPEATED_CHAR",value:t}}const Vr=20,Hr={};function Ur(e){let t=Hr[e];return void 0===t&&(t=function(e){const t=function(e){const t=new Ft(e),o=[];let s=[];for(o.push(s);!t.isOver();){if(";"===t.current){s=[],o.push(s),t.shift();continue}let e=Pr(t)||Tr(t)||_r(t)||Dr(t)||Fr(t)||Mr(t)||kr(t)||Or(t)||Lr(t);if(!e)throw new Error("Unknown token at "+t.remaining());s.push(e)}return o}(e);for(const e of t){const t=e.filter((e=>"REPEATED_CHAR"===e.type));for(const e of t.slice(1))e.type="CHAR"}const o=zr(t[0])||Br(t[0])||$r(t[0]);if(!o)throw new Error("Invalid first format part of: "+e);if(t.length>1&&"text"===o.type)throw new Error("The first format in a multi-part format must be a number format: "+e);const s=zr(t[1])||Br(t[1]);if(t[1]?.length&&!s)throw new Error("Invalid second format part of: "+e);const i=zr(t[2])||Br(t[2]);if(t[2]?.length&&!i)throw new Error("Invalid third format part of: "+e);const r=$r(t[3]);if(t[3]?.length&&!r)throw new Error("Invalid fourth format part of: "+e);return{positive:o,negative:s,zero:i,text:r}}(e),Hr[e]=t),t}function Br(e){if(!e||!function(e){return e.every((e=>"DIGIT"===e.type||"DECIMAL_POINT"===e.type||"THOUSANDS_SEPARATOR"===e.type||"PERCENT"===e.type||"STRING"===e.type||"CHAR"===e.type||"REPEATED_CHAR"===e.type))}(e))return;const t=[];let o,s=t,i=0,r=0,n=e.findLastIndex((e=>"DIGIT"===e.type)),a=!1,l=0;for(let c=0;c<e.length;c++){const h=e[c];switch(h.type){case"DIGIT":s===t?s.push(h):l<Vr&&(s.push(h),l++);break;case"DECIMAL_POINT":if(s!==t)throw new Error("Multiple decimal points in a number format");o=[],s=o;break;case"REPEATED_CHAR":case"CHAR":case"STRING":s.push(h);break;case"PERCENT":i++,s.push(h);break;case"THOUSANDS_SEPARATOR":c-1===n?(r+=1,n++,s.push(h)):"DIGIT"===e[c+1]?.type&&"DIGIT"===e[c-1]?.type?(s===t&&(a=!0),s.push(h)):s.push({type:"CHAR",value:","})}}return{type:"number",integerPart:t,decimalPart:o,percentSymbols:i,thousandsSeparator:a,magnitude:r}}function zr(e){const t=e&&function(e){return e.every((e=>"DATE_PART"===e.type||"DECIMAL_POINT"===e.type||"THOUSANDS_SEPARATOR"===e.type||"STRING"===e.type||"CHAR"===e.type||"REPEATED_CHAR"===e.type))}(e)?{type:"date",tokens:e}:void 0;if(!t)return;if(t.tokens.length&&t.tokens.every((e=>"DATE_PART"===e.type&&"a"===e.value)))throw new Error("Invalid date format");const o=function(e){const t=e.filter((e=>"DATE_PART"===e.type));for(let e=0;e<t.length;e++)!t[e].value.startsWith("m")||t[e].value.length>2||(t[e-1]?.value.startsWith("h")||t[e+1]?.value.startsWith("s"))&&(t[e].value=t[e].value.replaceAll("m","M"));return e}(t.tokens.map((e=>"THOUSANDS_SEPARATOR"===e.type||"DECIMAL_POINT"===e.type?{type:"CHAR",value:e.value}:e)));return{type:"date",tokens:o}}function $r(e){return e&&function(e){return e.every((e=>"STRING"===e.type||"TEXT_PLACEHOLDER"===e.type||"CHAR"===e.type||"REPEATED_CHAR"===e.type))}(e)?{type:"text",tokens:e}:void 0}function Wr(e){return[Gr(e.positive),Gr(e.negative),Gr(e.zero),Gr(e.text)].filter(at).join(";")}function Gr(e){if(!e)return;let t="";const o="number"!==e.type?e.tokens:function(e){let t=[...e.integerPart];e.decimalPart&&(t.push({type:"DECIMAL_POINT",value:"."}),t.push(...e.decimalPart));return t}(e);for(let e of o)switch(e.type){case"STRING":t+=`[$${e.value}]`;break;case"CHAR":t+=(s=e.value,Ar.has(s)?e.value:`\\${e.value}`);break;case"REPEATED_CHAR":t+="*"+e.value;break;default:t+=e.value}var s;return t}const qr=11,Zr="REPEATED_CHAR_PLACEHOLDER_",jr={0:Oo("January"),1:Oo("February"),2:Oo("March"),3:Oo("April"),4:Oo("May"),5:Oo("June"),6:Oo("July"),7:Oo("August"),8:Oo("September"),9:Oo("October"),10:Oo("November"),11:Oo("December")},Yr={0:Oo("Sunday"),1:Oo("Monday"),2:Oo("Tuesday"),3:Oo("Wednesday"),4:Oo("Thursday"),5:Oo("Friday"),6:Oo("Saturday")};function Xr(e,{format:t,locale:o,formatWidth:s}){switch("boolean"==typeof e&&(e=e?"TRUE":"FALSE"),typeof e){case"string":{if(e.includes('\\"')&&(e=e.replaceAll(/\\"/g,'"')),!t)return e;const o=Ur(t);let i=o.text||o.positive;return i&&"text"===i.type?Kr(e,i,s):e}case"number":t||(t=ln(e));const i=Ur(t);if("text"===i.positive.type)return Kr(e.toString(),i.positive,s);let r=i.positive;if(e<0&&i.negative?(r=i.negative,e=-e):0===e&&i.zero&&(r=i.zero),"date"===r.type)return Jr(function(e,t){const o=Us(e),s=t.tokens.some((e=>"DATE_PART"===e.type&&"a"===e.value));let i="";for(const e of t.tokens)switch(e.type){case"DATE_PART":i+=nn(o,e.value,s);break;case"REPEATED_CHAR":i+=Zr+e.value;break;default:i+=e.value}return i}(e,r),s);const n=e<0,a=Jr(function(e,t,o){if(e===1/0)return"∞"+(t.percentSymbols?"%":"");const s=2*t.percentSymbols-3*t.magnitude;e*=10**s;let i=0;void 0!==t.decimalPart&&(i=t.decimalPart.filter((e=>"DIGIT"===e.type)).length);const{integerDigits:r,decimalDigits:n}=en(Math.abs(e),i);let a=function(e,t,o){let s=t.integerPart;s.some((e=>"DIGIT"===e.type))||(s=[...s,{type:"DIGIT",value:"#"}]);"0"===e&&(e="");let i="";const r=s.findIndex((e=>"DIGIT"===e.type));let n=e.length-1;function a(t,s){if("0"===s&&(t=t||"0"),!t)return;const r=e.length-1-n;i=o&&r>0&&r%3==0?t+o+i:t+i}for(let t=s.length-1;t>=0;t--){const o=s[t];switch(o.type){case"DIGIT":if(a(e[n],o.value),n--,r===t)for(;n>=0;)a(e[n],"0"),n--;break;case"THOUSANDS_SEPARATOR":break;case"REPEATED_CHAR":i=Zr+o.value+i;break;default:i=o.value+i}}return i}(r,t,t.thousandsSeparator?o.thousandsSeparator:void 0);void 0!==t.decimalPart&&(a+=o.decimalSeparator+function(e,t){if(!t.decimalPart)return"";let o="",s=0;for(const i of t.decimalPart)switch(i.type){case"DIGIT":o+="#"===i.value?e[s]||"":e[s]||"0",s++;break;case"THOUSANDS_SEPARATOR":break;case"REPEATED_CHAR":o+=Zr+i.value;break;default:o+=i.value}return o}(n||"",t));return a}(Math.abs(e),r,o),s);return n?"-"+a:a;case"object":return""}}function Kr(e,t,o){let s="";for(const o of t.tokens)switch(o.type){case"TEXT_PLACEHOLDER":s+=e;break;case"CHAR":case"STRING":s+=o.value;break;case"REPEATED_CHAR":s+=Zr+o.value}return Jr(s,o)}function Jr(e,t){const o=e.indexOf(Zr);if(-1===o)return e;const s=e.slice(0,o),i=e.slice(o+Zr.length+1),r=e[o+Zr.length];const{timesToRepeat:n,padding:a}=function(){if(!t)return{timesToRepeat:0,padding:""};const e=t.measureText(s+i),o=t.measureText(r),n=t.availableWidth-e;if(n<=0)return{timesToRepeat:0,padding:""};const a=Math.floor(n/o),l=n-a*o,c=t.measureText(" ");return{timesToRepeat:a,padding:" ".repeat(Math.floor(l/c))}}();return s+r.repeat(n)+a+i}const Qr=[];function en(e,t=Vr){const o=e.toString();if(o.includes("e"))return function(e,t=Vr){let o=Qr[t];o||(o=new Intl.NumberFormat("en-US",{maximumFractionDigits:t,useGrouping:!1}),Qr[t]=o);const[s,i]=o.format(e).split(".");return{integerDigits:s,decimalDigits:i}}(e,t);if(Number.isInteger(e))return{integerDigits:o,decimalDigits:void 0};const s=o.indexOf(".");let i=o.substring(0,s),r=o.substring(s+1);if(0===t)return Number(r[0])>=5&&(i=(Number(i)+1).toString()),{integerDigits:i,decimalDigits:void 0};if(r.length>t){const{integerDigits:e,decimalDigits:o}=function(e,t){let o="0",s=e,i=e.slice(0,t);const r=t;if(Number(e[r])<5)return{integerDigits:o,decimalDigits:i};const n=i.match(on)?.[0]||"",a=(Number(i)+1).toString(),l=i.slice(n.length),c=a.length>l.length;c&&!n?(o="1",s=void 0):s=c?n.slice(0,-1)+a:n+a;return{integerDigits:o,decimalDigits:s}}(r,t);r=o,"0"!==e&&(i=(Number(i)+Number(e)).toString())}return{integerDigits:i,decimalDigits:tn(r||"")}}function tn(e){let t=e.length-1;for(;t>=0&&"0"===e[t];)t--;return e.slice(0,t+1)||void 0}const on=/^0+/;function sn(e,t){const{integerDigits:o,decimalDigits:s}=en(e,20);return s?o+t+s:o}const rn=xt((function(e){if(!e)return!1;try{return"date"===Ur(e).positive.type}catch(e){return!1}}));function nn(e,t,o){switch(t){case"d":return e.getDate();case"dd":return e.getDate().toString().padStart(2,"0");case"ddd":return Yr[e.getDay()].slice(0,3);case"dddd":return Yr[e.getDay()].toString();case"m":return e.getMonth()+1;case"mm":return String(e.getMonth()+1).padStart(2,"0");case"mmm":return jr[e.getMonth()].slice(0,3);case"mmmm":return jr[e.getMonth()].toString();case"mmmmm":return jr[e.getMonth()].slice(0,1);case"qq":return Oo("Q%(quarter)s",{quarter:e.getQuarter()}).toString();case"qqqq":return Oo("Quarter %(quarter)s",{quarter:e.getQuarter()}).toString();case"yy":const s=String(e.getFullYear()).replace("-","").padStart(2,"0");return s.slice(s.length-2);case"yyyy":return e.getFullYear();case"hhhh":return Math.floor((e.getTime()-Is.getTime())/36e5).toString();case"hh":let i=e.getHours();return o&&(i=0===i?12:i>12?i-12:i),i.toString().padStart(2,"0");case"MM":return e.getMinutes().toString().padStart(2,"0");case"ss":return e.getSeconds().toString().padStart(2,"0");case"a":return e.getHours()>=12?"PM":"AM";default:throw new Error(`invalid date format token: ${t}`)}}const an=xt((function(e){return new RegExp(`[0-9]+${Ue(e.decimalSeparator)}[0-9]`)}));function ln(e){let{integerDigits:t,decimalDigits:o}=en(e);if(!o)return"0";const s=t.replace("-","").length;if(s+2>qr)return"0";const i=qr-s-1;return({decimalDigits:o}=en(e,Math.min(i,o.length))),o?"0."+"0".repeat(o.length):"0"}function cn(e,t){if(!Ls(e,t))return;return Hs(e,t).format}function hn(e){const t=e.includes(".")?"0.00":"0",o=e.match(/[\$€]/);if(o){const s=e.match(/[\d]/),i="[$"+o.values().next().value+"]";return s.index<o.index?"#,##"+t+i:i+"#,##"+t}if(e.includes("%"))return t+"%"}function dn(e){const t=e.decimalPlaces??2,o=e.position??"before",s=e.code??"",i=e.symbol??"",r="#,##0"+(t?"."+"0".repeat(t):"");let n=`${s} ${i}`.trim();return"after"===o&&s&&(n=" "+n),function(e,t,o){const s=`[$${e}]`;return"before"===t?s+o:o+s}(n,o,r)}function un(e){const t=e.decimalPlaces??2,o=e.position??"before",s=e.code??"",i=e.symbol??"",r="#,##0"+(t?"."+"0".repeat(t):"");let n=`${s} ${i}`.trim();"after"===o&&s&&(n=" "+n);return[gn(n,o,` ${r} `),gn(n,o,`(${r})`),gn(n,o," - ")].join(";")}function gn(e,t,o){const s=`[$${e}]`;return"before"===t?s+"* "+o:o+"* "+s}function pn(e){const t=Ur(e);return Wr({positive:mn(t.positive),negative:t.negative?mn(t.negative):void 0,zero:t.zero?mn(t.zero):void 0,text:t.text})}function mn(e){if("number"!==e.type||!e.decimalPart)return e;const t=e.decimalPart.filter((e=>"DIGIT"!==e.type));return{...e,decimalPart:void 0,integerPart:[...e.integerPart,...t]}}function fn({value:e,format:t},o){return Xr(e,{format:vn({value:e,format:t},void 0,o),locale:o})}function vn(e,t,o){let s=0;try{s=Math.abs(Li(e?.value,o))}catch(e){return""}const i=e?.format;if(void 0!==t){const e=t?.value;switch(e){case"k":return bn(i,1,"k");case"m":return bn(i,2,"m");case"b":return bn(i,3,"b");default:throw new Ri(Oo("The formatting unit should be 'k', 'm' or 'b'."))}}return s<1e5?bn(i,0,""):s<1e8?bn(i,1,"k"):s<1e11?bn(i,2,"m"):bn(i,3,"b")}function bn(e,t,o,s){const i=Ur(e||"#,##0");return Wr({positive:Sn(i.positive,t,o),negative:i.negative?Sn(i.negative,t,o):void 0,zero:i.zero?Sn(i.zero,t,o):void 0,text:i.text})}function Sn(e,t,o){if("number"!==e.type)return e;const s={type:"STRING",value:o};let i=[...e.integerPart];const r=i.findLastIndex((e=>"DIGIT"===e.type));if(-1===r)throw new Error("Cannot create a large number format from a format with no digit.");for(;"THOUSANDS_SEPARATOR"===i[r+1]?.type;)i=It(i,[r+1]);const n=i[r+1];i="STRING"===n?.type&&["m","k","b"].includes(n.value)?function(e,t,o){const s=[...e];return s.splice(o,1,t),s}(i,s,r+1):Rt(i,[s],r+1),t>0&&(i=Rt(i,Array(t).fill({type:"THOUSANDS_SEPARATOR",value:","}),r+1));const a=e.percentSymbols-i.filter((e=>"PERCENT"===e.type)).length;return i.push(...new Array(a).fill({type:"PERCENT",value:"%"})),{...e,integerPart:i,decimalPart:void 0,magnitude:t}}function yn(e,t){const o=Ur(e);return Wr(Ur(Wr({positive:Cn(o.positive,t),negative:o.negative?Cn(o.negative,t):void 0,zero:o.zero?Cn(o.zero,t):void 0,text:o.text})))}function Cn(e,t){return"number"!==e.type?e:t>0?function(e,t){let o=e.integerPart,s=e.decimalPart;if(!s){const e=o.findLastIndex((e=>"DIGIT"===e.type));s=o.slice(e+1),o=o.slice(0,e+1)}const i=Ze(0,t).map((()=>({type:"DIGIT",value:"0"}))),r=s.findLastIndex((e=>"DIGIT"===e.type));s=-1===r?[...i,...s]:Rt(s,i,r+1);return{...e,decimalPart:s,integerPart:o}}(e,t):function(e,t){let o=e.decimalPart;if(!o)return e;const s=[];let i=0;for(let e=o.length-1;e>=0&&!(i>=Math.abs(t));e--)"DIGIT"===o[e].type&&(i++,s.push(e));if(o=It(o,s),o.some((e=>"DIGIT"===e.type)))return{...e,decimalPart:o};return{...e,decimalPart:void 0,integerPart:[...e.integerPart,...o]}}(e,Math.abs(t))}function wn(e){const t=Ur(e);for(const e of[t.positive,t.negative,t.zero])if(e&&"date"===e.type&&e.tokens.some((e=>"DATE_PART"===e.type&&e.value.includes("q"))))return!1;return!0}function En(e){if(!e)return!1;try{return"text"===Ur(e).positive.type}catch{return!1}}function xn(e,t){return Rn({value:En(t.format)?e.content:e.parsedValue,format:t.format},t.locale)}function In(e,t){if(e.startsWith("="))throw new Error(`Cannot parse "${e}" because it's not a literal value. It's a formula`);if(""===e)return null;if(ei(e,bi))return oi(e,bi);const o=Hs(e,t);return o?o.value:Xe(e)?"TRUE"===e.toUpperCase():e}function Rn(e,t=bi,o){const s=Rr(e.value);if(!s)return Tn(e,t,o);const i=In(s.label,t);return{...Tn({value:i,format:e.format||("number"==typeof i?cn(s.label,t)||hn(s.label):void 0)},t,o),link:s}}function Tn(e,t,o){let{value:s,format:i,message:r}=e;i=o?.format||i;const n=Xr(s,{format:i,locale:t});return Ni(s)?function(e,t){return{value:e,formattedValue:e,message:t,type:ii.error,isAutoSummable:!1,defaultAlign:"center"}}(s,r):En(i)?An(Gi(s),i,n):null===s?_n(i):"number"==typeof s?rn(i||"")?function(e,t,o){return{value:e,format:t,formattedValue:o,type:ii.number,isAutoSummable:!1,defaultAlign:"right"}}(s,i,n):function(e,t,o){return{value:e||0,format:t,formattedValue:o,type:ii.number,isAutoSummable:!0,defaultAlign:"right"}}(s,i,n):"boolean"==typeof s?function(e,t,o){return{value:e,format:t,formattedValue:o,type:ii.boolean,isAutoSummable:!1,defaultAlign:"center"}}(s,i,n):An(s,i,n)}function An(e,t,o){return{value:e,format:t,formattedValue:o,type:ii.text,isAutoSummable:!0,defaultAlign:"left"}}const _n=xt((function(e){return{value:null,format:e,formattedValue:"",type:ii.empty,isAutoSummable:!0,defaultAlign:"left"}}));function Dn(e){const t=xs.now();switch(e){case"today":return zs(t);case"yesterday":return zs(xs.fromTimestamp(t.setDate(t.getDate()-1)));case"tomorrow":return zs(xs.fromTimestamp(t.setDate(t.getDate()+1)));case"lastWeek":return zs(xs.fromTimestamp(t.setDate(t.getDate()-7)));case"lastMonth":return zs(xs.fromTimestamp(t.setMonth(t.getMonth()-1)));case"lastYear":return zs(xs.fromTimestamp(t.setFullYear(t.getFullYear()-1)))}}function On(e,t){return"dateValue"in e&&"exactDate"!==e.dateValue?[Dn(e.dateValue)]:e.values.map((e=>ks(e,t)))}function Fn(e,t){return e.values.map((e=>Vi(e,t)))}function Mn(e,t){return e.map((e=>{if(e.startsWith("="))return e;const o=In(e,t);return"number"==typeof o?Xr(o,{format:t.dateFormat,locale:t}):""}))}function Pn(e){return 20+120*Math.exp(-.035*(e-1))}class Nn{getSheetSize;_zone;parts;invalidXc;prefixSheet=!1;sheetId;invalidSheetName;constructor(e,t){this.getSheetSize=t,this._zone=e.zone,this.prefixSheet=e.prefixSheet,this.invalidXc=e.invalidXc,this.sheetId=e.sheetId,this.invalidSheetName=e.invalidSheetName;let o=[...e.parts];1===e.parts.length&&bs(this.zone)>1?o.push({...e.parts[0]}):2===e.parts.length&&1===bs(this.zone)&&o.pop(),this.parts=o}static fromRange(e,t){return e instanceof Nn?e:new Nn(e,t.getSheetSize)}get unboundedZone(){return this._zone}get zone(){const{left:e,top:t,bottom:o,right:s}=this._zone;if(void 0!==s&&void 0!==o)return this._zone;if(void 0===o&&void 0!==s)return{right:s,top:t,left:e,bottom:this.getSheetSize(this.sheetId).numberOfRows-1};if(void 0===s&&void 0!==o)return{bottom:o,left:e,top:t,right:this.getSheetSize(this.sheetId).numberOfCols-1};throw new Error(Oo("Bad zone format"))}static getRangeParts(e,t){const o=e.split(":").map((e=>{const t=Bo(e);return{colFixed:!t&&e.startsWith("$"),rowFixed:t?e.startsWith("$"):e.includes("$",1)}})),s=void 0===t.bottom,i=void 0===t.right;return s&&(o[0].rowFixed=o[0].rowFixed||o[1].rowFixed,o[1].rowFixed=o[0].rowFixed||o[1].rowFixed),i&&(o[0].colFixed=o[0].colFixed||o[1].colFixed,o[1].colFixed=o[0].colFixed||o[1].colFixed),o}get isFullCol(){return void 0===this._zone.bottom}get isFullRow(){return void 0===this._zone.right}get rangeData(){return{_zone:this._zone,_sheetId:this.sheetId}}orderZone(){if(Xo(this._zone))return this;const e={...this._zone};let t=this.parts;if(void 0!==e.right&&e.right<e.left){let o=e.right;e.right=e.left,e.left=o,t=[{colFixed:t[1]?.colFixed||!1,rowFixed:t[0]?.rowFixed||!1},{colFixed:t[0]?.colFixed||!1,rowFixed:t[1]?.rowFixed||!1}]}if(void 0!==e.bottom&&e.bottom<e.top){let o=e.bottom;e.bottom=e.top,e.top=o,t=[{colFixed:t[0]?.colFixed||!1,rowFixed:t[1]?.rowFixed||!1},{colFixed:t[1]?.colFixed||!1,rowFixed:t[0]?.rowFixed||!1}]}return this.clone({zone:e,parts:t})}clone(e){return new Nn({zone:e?.zone?e.zone:{...this._zone},sheetId:e?.sheetId?e.sheetId:this.sheetId,invalidSheetName:e&&"invalidSheetName"in e?e.invalidSheetName:this.invalidSheetName,invalidXc:e&&"invalidXc"in e?e.invalidXc:this.invalidXc,parts:e?.parts?e.parts:this.parts.map((e=>({rowFixed:e.rowFixed,colFixed:e.colFixed}))),prefixSheet:void 0!==e?.prefixSheet?e.prefixSheet:this.prefixSheet},this.getSheetSize)}}function kn(e,t,o){const s=o.sheetId===e?t:o.sheetId;return o.clone({sheetId:s})}function Ln(e,t,o){if(!o)return;const s=e.getRangeFromSheetXC(t,o);return s.invalidSheetName||s.invalidXc?void 0:s}function Vn(e,t){const o=[];for(const s of t){const t=s.dataRange;if(!e.isRangeValid(t)){o.push(s);continue}const{sheetName:i}=Go(t),r=i?`${i}!`:"",n=Zo(t);if(n.bottom!==n.top&&n.left!=n.right)if(n.right)for(let e=n.left;e<=n.right;++e)o.push({...s,dataRange:`${r}${Ko({left:e,right:e,top:n.top,bottom:n.bottom})}`});else for(let e=n.top;e<=n.bottom;++e)o.push({...s,dataRange:`${r}${Ko({left:n.left,right:n.right,top:e,bottom:e})}`});else o.push(s)}return o}function Hn(e){const t=[];for(const o of e)for(const e of ds(o.zone))t.push({...e,sheetId:o.sheetId});return t}function Un(e,t,o){const s=[];return t.forEach((t=>{const i=function(e,t){e=e.toLocaleLowerCase();let o=0,s=0,i=(t=t.toLocaleLowerCase()).length,r=0;for(let n=0;n<i;n++)t[n]===e[r]?(r++,s+=100+s-n/200):s=0,o+=s;return r===e.length?o:0}(e,o(t));i>0&&s.push({score:i,elem:t})})),s.sort(((e,t)=>t.score-e.score)),s.map((e=>e.elem))}function Bn(e){const t=[];for(let o=0;o<e;o++){const e={cells:{}};t.push(e)}return t}function zn(e,t,o){return o.map((o=>o>=e?o+t:o))}function $n(e,t){return e=[...e].sort(((e,t)=>t-e)),t.map((t=>{for(const o of e)if(t>o)t--;else if(t===o)return;return t})).filter(at)}function Wn(e,t=1){return t*(e+re)-re}function Gn(e,t=!1,o=!1){return`${o?"italic":""} ${t?"bold":""} ${e}px ${fe}`}const qn={};function Zn(e,t,o,s="pt"){const i=Jn(o,s);e.save(),e.font=i;const r=jn(e,t);return e.restore(),r}function jn(e,t){const o=e.font;return qn[o]||(qn[o]={}),void 0===qn[o][t]&&(qn[o][t]=e.measureText(t).width),qn[o][t]}const Yn={};function Xn(e,t,o,s="pt"){const i=Jn(o,s);e.save(),e.font=i;const r=function(e,t){const o=e.font;Yn[o]||(Yn[o]={});if(void 0===Yn[o][t]){const s=e.measureText(t),i=s.width,r=s.fontBoundingBoxAscent+s.fontBoundingBoxDescent;Yn[o][t]={width:i,height:r}}return Yn[o][t]}(e,t);return e.restore(),r}function Kn(e){return Math.round(96*e/72)}function Jn(e,t="pt"){return`${e.italic?"italic ":""}${e.bold?"bold":pe} ${("pt"===t?Qn(e):e.fontSize)??me}px ${fe}`}function Qn(e){return Kn(e?.fontSize||me)}function ea(e,t,o,s){if(Zn(e,t,s)<=o)return[t];const i=[];let r="";for(let n of t){Zn(e,r+n,s)>o?(i.push(r),r=n):r+=n}return i.push(r),i}function ta(e,t,o,s){o||(o={});const i=[],r=t.includes(Pe)?t.split(Pe):[t];for(const t of r){const r=t.includes(" ")?t.split(" "):[t];if(!s){i.push(t);continue}let n="",a=s;for(let t of r){const r=ea(e,t,s,o),l=r.pop(),c=Zn(e,l,o);if(r.length)""!==n&&(i.push(n),n="",a=s),r.forEach((e=>{i.push(e)})),n=l,a=s-c;else{const t=""===n?l:" "+l,r=Zn(e,t,o);r<=a?(n+=t,a-=r):(i.push(n),n=l,a=s-c)}}""!==n&&i.push(n)}return i}function oa(e){return e?e.toLowerCase():""}const sa=/([0-9\.]*)px/;function ia(e,t,o){let s=jn(e,t);if(s<=o)return t;const i=jn(e,"…");if(s<=i)return t;let r=t.length;for(;s>=o-i&&r-- >0;)s=jn(e,t=t.substring(0,r));return t+"…"}function ra(e,t,o,s=!1,i=!1,r=function(e){return Number(e.match(sa)?.[1])}(e.font)/10){if(e.fillText(t,o.x,o.y),!s&&!i)return;const n=e.measureText(t),a=n.width,l=n.actualBoundingBoxAscent+n.actualBoundingBoxDescent,c=n.fontBoundingBoxAscent+n.fontBoundingBoxDescent;let{x:h,y:d}=o,u=d,g=d;switch(e.textAlign){case"center":h-=a/2;break;case"right":h-=a}switch(e.textBaseline){case"top":g+=c-2*r,u+=c/2-r;break;case"middle":g+=c/2-r;break;case"alphabetic":g+=2*r,u-=3*r;break;case"bottom":g=d,u-=l/2-r/2}s&&(e.lineWidth=r,e.strokeStyle=e.fillStyle,e.beginPath(),e.moveTo(h,g),e.lineTo(h+a,g),e.stroke()),i&&(e.lineWidth=r,e.strokeStyle=e.fillStyle,e.beginPath(),e.moveTo(h,u),e.lineTo(h+a,u),e.stroke())}class na{uuidv4(){return window.crypto&&window.crypto.getRandomValues?([1e7]+-1e3+-4e3+-8e3+-1e11).replace(/[018]/g,(e=>(e^crypto.getRandomValues(new Uint8Array(1))[0]&15>>e/4).toString(16))):"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,(function(e){const t=16*Math.random()|0;return("x"===e?t:3&t|8).toString(16)}))}}function aa(e,t){const o=new Set(t.map((e=>e.left))),s=new Set(t.map((e=>e.right))),i=new Set(t.map((e=>e.top))),r=new Set(t.map((e=>e.bottom))),n=1===i.size&&1===r.size||1===o.size&&1===s.size?function(e){return e.reduce(((e,t)=>{const o=e.length;for(let s=0;s<o;s++)if(rs(e[s],t))return e[s]=os(e[s],t),e;return e[o]=t,e}),[])}(t):[t[t.length-1]],a=n.map((e=>ds(e))).flat();return{sheetId:e,zones:t,clippedZones:n,columnsIndexes:[...new Set(a.map((e=>e.col)))].sort(((e,t)=>e-t)),rowsIndexes:[...new Set(a.map((e=>e.row)))].sort(((e,t)=>e-t))}}function la(e,t){if(!t.length||!t[0].length)return e;const o=t[0].length,s=t.length;return e.map((e=>function(e,t,o){const s=Math.max(e.right-t+1,e.left),i=Math.max(e.bottom-o+1,e.top),r=[];for(let n=e.left;n<=s;n+=t)for(let s=e.top;s<=i;s+=o)r.push({left:n,top:s,bottom:s+o-1,right:n+t-1});return r}(e,o,s))).flat()}function ca(e){if(!e[ri.Html])return{text:e[ri.PlainText]};const t=(new DOMParser).parseFromString(e[ri.Html],"text/html"),o=t.querySelector("div")?.getAttribute("data-osheet-clipboard"),s=o&&JSON.parse(o);return{text:e[ri.PlainText],data:s}}class ha{getters;dispatch;constructor(e,t){this.getters=e,this.dispatch=t}copy(e){}paste(e,t,o){}isPasteAllowed(e,t,o,s){return"Success"}isCutAllowed(e){return"Success"}getPasteTarget(e,t,o,s){return{zones:[],sheetId:e}}convertTextToClipboardData(e){}}class da extends ha{copy(e){}pasteFromCopy(e,t,o,s){if(1===t.length)for(const i of la(t,o))this.pasteZone(e,i.left,i.top,o,s);else for(const i of yo(t))for(let t=i.left;t<=i.right;t++)for(let r=i.top;r<=i.bottom;r++)this.pasteZone(e,t,r,o,s)}pasteZone(e,t,o,s,i){}}class ua extends da{copy(e){const t=e.sheetId;if(0===e.zones.length)return;const{rowsIndexes:o,columnsIndexes:s}=e,i=[];for(const e of o){const o=[];for(const i of s){const s={col:i,row:e,sheetId:t};o.push(this.getters.getCellBorder(s))}i.push(o)}return{borders:i}}paste(e,t,o){const s=e.sheetId;if("asValue"===o.pasteOption)return;const i=e.zones;if(o.isCutOperation){const{left:e,top:o}=i[0];this.pasteZone(s,e,o,t.borders)}else this.pasteFromCopy(s,i,t.borders)}pasteZone(e,t,o,s){for(const[i,r]of s.entries())for(const[s,n]of r.entries()){const r={col:t+s,row:o+i,sheetId:e};this.pasteBorder(n,r)}}pasteBorder(e,t){const o={...this.getters.getCellBorder(t),...e};this.dispatch("SET_BORDER",{...t,border:o})}}const ga=["%"],pa="+,-,*,/,:,=,<>,>=,>,<=,<,^,&".split(",").concat(ga);function ma(e,t=bi){e=wt(e);const o=new Ft(e),s=[];for(;!o.isOver();){let e=Ra(o)||Sa(o,t)||ba(o)||ya(o)||Ea(o)||fa(o)||Ta(o)||wa(o,t)||Ia(o);e||(e={type:"UNKNOWN",value:o.shift()}),s.push(e)}return s}function fa(e){return"?"===e.current?(e.shift(),{type:"DEBUGGER",value:"?"}):null}const va={"(":{type:"LEFT_PAREN",value:"("},")":{type:"RIGHT_PAREN",value:")"}};function ba(e){if("("===e.current||")"===e.current){const t=e.shift();return va[t]}return null}function Sa(e,t){if(e.current===t.formulaArgSeparator){return{type:"ARG_SEPARATOR",value:e.shift()}}return null}function ya(e){for(let t of pa)if(e.currentStartsWith(t))return e.advanceBy(t.length),{type:"OPERATOR",value:t};return null}const Ca=new Set("0123456789");function wa(e,t){if(!Ca.has(e.current)&&e.current!==t.decimalSeparator)return null;const o=e.remaining().match(Js(t.decimalSeparator));return o?(e.advanceBy(o[0].length),{type:"NUMBER",value:o[0]}):null}function Ea(e){if('"'===e.current){const t=e.shift();let o=t;for(;e.current&&(e.current!==t||"\\"===o[o.length-1]);)o+=e.shift();return'"'===e.current&&(o+=e.shift()),{type:"STRING",value:o}}return null}const xa=new Set("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789_.!$");function Ia(e){let t="";if("'"===e.current){let o=e.shift();for(t+=o;e.current;)if(o=e.shift(),t+=o,"'"===o){if(!e.current||"'"!==e.current)break;o=e.shift(),t+=o}if("'"!==o)return{type:"UNKNOWN",value:t}}for(;e.current&&xa.has(e.current);)t+=e.shift();if(t.length){const e=t;return Ho.test(e)?{type:"REFERENCE",value:e}:{type:"SYMBOL",value:e}}return null}function Ra(e){let t=0;for(;e.current===Pe;)t++,e.shift();if(t)return{type:"SPACE",value:Pe.repeat(t)};let o="";for(;e.current&&e.current.match(yt);)o+=e.shift();return o?{type:"SPACE",value:o}:null}function Ta(e){return e.currentStartsWith(xi.InvalidReference)?(e.advanceBy(xi.InvalidReference.length),{type:"INVALID_REFERENCE",value:xi.InvalidReference}):null}function Aa(e){if(!e||"object"!=typeof e||e.thousandsSeparator&&"string"!=typeof e.thousandsSeparator)return!1;for(const t of["code","name","decimalSeparator","dateFormat","timeFormat","formulaArgSeparator"])if(!e[t]||"string"!=typeof e[t])return!1;if(e.formulaArgSeparator===e.decimalSeparator)return!1;if(e.thousandsSeparator===e.decimalSeparator)return!1;try{Xr(1,{locale:e,format:"#,##0.00"}),Xr(1,{locale:e,format:e.dateFormat}),Xr(1,{locale:e,format:e.timeFormat})}catch{return!1}return!0}function _a(e,t){return e.startsWith("=")?Fa(e,t):Na(e,t)}function Da(e,t){return e.startsWith("=")?Fa(e,t):function(e,t){if(Ls(e,t)){const o=Li(e,t);let s=bi.dateFormat;return Number.isInteger(o)||(s+=" "+bi.timeFormat),Xr(o,{locale:bi,format:s})}return Na(e,t)}(e,t)}function Oa(e,t){return e.startsWith("=")?Ma(e,t):function(e,t){if(Ls(e,bi)){const o=Li(e,bi);let s=t.dateFormat;return Number.isInteger(o)||(s+=" "+t.timeFormat),Xr(o,{locale:t,format:s})}return function(e,t){if("."===t.decimalSeparator||!ei(e,bi))return e;const o=an(bi);return e.replace(o,(e=>e.replace(".",t.decimalSeparator)))}(e,t)}(e,t)}function Fa(e,t){return Pa(e,t,bi)}function Ma(e,t){return Pa(e,bi,t)}function Pa(e,t,o){if(t.formulaArgSeparator===o.formulaArgSeparator&&t.decimalSeparator===o.decimalSeparator)return e;const s=ma(e,t);let i="";for(const e of s)"NUMBER"===e.type?i+=e.value.replace(t.decimalSeparator,o.decimalSeparator):"ARG_SEPARATOR"===e.type?i+=o.formulaArgSeparator:i+=e.value;return i}function Na(e,t){return"."!==t.decimalSeparator&&ei(e,t)?(t.thousandsSeparator&&(e=e.replaceAll(t.thousandsSeparator,"")),e.replace(t.decimalSeparator,".")):e}function ka(e,t){return Ha(e,(e=>Da(e,t)))}function La(e,t){return Ha(e,(e=>Oa(e,t)))}function Va(e,t){const o=Be(e);return o.criterion.values=o.criterion.values.map((e=>Oa(e,t))),o}function Ha(e,t){switch((e=Be(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=Ua(e.minimum,t),e.maximum=Ua(e.maximum,t),e.midpoint&&(e.midpoint=Ua(e.midpoint,t)),e;case"IconSetRule":return e.lowerInflectionPoint.value=t(e.lowerInflectionPoint.value),e.upperInflectionPoint.value=t(e.upperInflectionPoint.value),e}}function Ua(e,t){if(!e?.value)return e;const o=t("formula"===e.type?"="+e.value:e.value),s="formula"===e.type?o.slice(1):o;return{...e,value:s}}function Ba(e){return e.dateFormat+" "+e.timeFormat}function za(e,t){return e.startsWith("=")?function(e,t){return function(e,t,o){if(t.formulaArgSeparator===o.formulaArgSeparator&&t.decimalSeparator===o.decimalSeparator)return e;const s=ma(e,t);let i="";for(const e of s)"NUMBER"===e.type?i+=e.value.replace(t.decimalSeparator,o.decimalSeparator):"ARG_SEPARATOR"===e.type?i+=o.formulaArgSeparator:i+=e.value;return i}(e,t,bi)}(e,t):Na(e,t)}function $a(e){let t=!1,o=!0;return ar(e,(e=>(t=!0,o=o&&e,o))),{foundBoolean:t,result:o}}function Wa(e){let t=!1,o=!1;return ar(e,(e=>(t=!0,o=o||e,!o))),{foundBoolean:t,result:o}}function Ga(e,t){return or(e,((e,t)=>e+t),0,t)}function qa(e){return tr(e,((e,t)=>br(t)?e.add(t?.value):e),new Set).size}function Za(e){const t=Array(e);for(let o=0;o<e;o++)t[o]=Array(e).fill(0),t[o][o]=1;return t}function ja(e){if(e.length!==e[0].length)throw new Ri(Oo("Function [[FUNCTION_NAME]] invert matrix error, only square matrices are invertible"));let t=1;const o=e.length,s=Za(o),i=e.map((e=>e.slice()));for(let e=0;e<o;e++){let r=i[e][e];if(0===r){for(let r=e+1;r<o;r++)if(0!=i[e][r]){Ya(i,e,r),Ya(s,e,r),t*=-1;break}if(r=i[e][e],0===r)return{determinant:0}}for(let t=0;t<o;t++)i[t][e]=i[t][e]/r,s[t][e]=s[t][e]/r;t*=r;for(let t=0;t<o;t++){if(t===e)continue;const r=i[e][t];for(let n=0;n<o;n++)i[n][t]-=r*i[n][e],s[n][t]-=r*s[n][e]}}return{inverted:s,determinant:t}}function Ya(e,t,o){for(let s=0;s<e.length;s++){const i=e[s][t];e[s][t]=e[s][o],e[s][o]=i}}function Xa(e,t){if(e.length!==t[0].length)throw new Ri(Oo("Cannot multiply matrices : incompatible matrices size."));const o=e[0].length,s=t.length,i=e.length,r=Array(s);for(let n=0;n<s;n++){r[n]=Array(o);for(let s=0;s<o;s++){let o=0;for(let r=0;r<i;r++)o+=e[r][s]*t[n][r];r[n][s]=o}}return r}function Ka(e){if(!yi(e))return e;if(1!==e.length||1!==e[0].length)throw new Ri(Oo("The value should be a scalar or a 1x1 matrix"));return e[0][0]}function Ja(...e){const t=e[0].length;e.forEach(((e,o)=>Mi((()=>e.length===t),Oo("[[FUNCTION_NAME]] has mismatched dimensions for argument %s (%s vs %s).",o.toString(),t.toString(),e.length.toString()))))}function Qa(e,t){let o=0;const s=or(e,((e,t)=>(o+=1,e+t)),0,t);return Wi(o),s/o}function el(e,t){let o=0;for(let s of e)if(yi(s))for(let e of s)for(let t of e)"number"==typeof t.value&&(o+=1);else{const e=s?.value;Ni(e)||"string"==typeof e&&!ei(e,t)&&!Hs(e,t)||(o+=1)}return o}function tl(e){return tr(e,((e,t)=>void 0!==t&&null!==t.value?e+1:e),0)}function ol(e,t){let o={value:-1/0};return Qi(e,(e=>{e.value>=o.value&&(o=e)}),t),o.value===-1/0?{value:0}:o}function sl(e,t){let o={value:1/0};return Qi(e,(e=>{e.value<=o.value&&(o=e)}),t),o.value===1/0?{value:0}:o}function il(e,t,o){const s=e[0].length?e:[Ze(1,t.flat().length+1)],i=s.length;let r=o[0].length?o:s;return r=r.length===i?nr(r):r,{_X:s,_newX:r}}function rl(e,t,o=!0,s=!1){const i=t.flat(),r=i.length;let{_X:n}=il(e,t,[[]]);n=n.length===r?nr(n):n.slice(),Ja(n[0],i);const a=n.length,l=r-a-(o?1:0),c=[i],h=nr(n.reverse());let d=[];for(let e=0;e<a;e++)if(d.push(0),o){for(const t of n[e])d[e]+=t;d[e]/=r}let u=0;if(o){for(const e of i)u+=e;u/=r}const g=h.map((e=>e.map(((e,t)=>e-d[t]))));o&&h.forEach((e=>e.push(1)));const p=al(h,c);if(o||p.push([0]),!s)return p;const m=Xa(g,nr(g)),{inverted:f}=ja(m);if(void 0===f)throw new Ri(Oo("Matrix is not invertible"));let v=0,b=0;for(let e=0;e<r;e++){const t=i[e]-u;let o=0;for(let t=0;t<a;t++){o+=g[e][t]*p[t][0]}const s=t-o;v+=s*s,b+=o*o}const S=Math.sqrt(v/l),y=b/(b+v),C=b/a/(v/l),w=[];for(let e=0;e<a;e++)w.push(S*Math.sqrt(f[e][e]));if(o){const e=Xa(f,[d]),t=Xa(nr([d]),e);w.push(S*Math.sqrt(t[0][0]+1/i.length))}const E=[[p[0][0],w[0],y,C,b],[p[1][0],w[1],S,l,v]];for(let e=2;e<a;e++)E.push([p[e][0],w[e],"","",""]);return o?E.push([p[a][0],w[a],"","",""]):E.push([0,"","","",""]),E}function nl(e,t,o,s){Ja(t,e),Mi((()=>o>=1),Oo("Function [[FUNCTION_NAME]] A regression of order less than 1 cannot be possible."));const i=[e],r=t.map((e=>Ze(0,o).map((t=>Math.pow(e,o-t)))));s&&r.forEach((e=>e.push(1)));const n=al(r,i);return s||n.push([0]),n}function al(e,t){const o=Xa(e,nr(e)),{inverted:s}=ja(o);if(void 0===s)throw new Ri(Oo("Matrix is not invertible"));const i=Xa(e,t);return nr(Xa(s,i))}function ll(e,t,o){return e.reduce(((e,s,i)=>e+s*Math.pow(t,o-i)),0)}function cl(e){return e.map((e=>e.map((e=>Math.exp(e)))))}function hl(e){return e.map((e=>e.map((e=>Math.log(e)))))}function dl(e,t,o,s){const{_X:i,_newX:r}=il(t,e,o),n=rl(i,e,s,!1),a=n.length-1,l=r.map((e=>{let t=0;for(let o=0;o<a;o++)t+=n[o][0]*e[a-o-1];return t+=n[a][0],[t]}));return l.length===o.length?l:nr(l)}const ul="(previous)",gl="(next)";function pl(e,t){const o=e.definition.rows.map((e=>e.nameWithGranularity)),s=t.filter((e=>o.includes(e.field))),i=e.definition.columns.map((e=>e.nameWithGranularity));return{colDomain:t.filter((e=>i.includes(e.field))),rowDomain:s}}function ml(e,t,o){return"column"===t?pl(e,o).colDomain:pl(e,o).rowDomain}function fl(e,t){return void 0!==vl(e,t)}function vl(e,t,o){let s=t;for(const t of e){const e=s.find((e=>e.value===t.value));if(!e)return;if(e.field===o)return s;s=e.children}return s}function bl(e,t,o){const s=(e=Be(e)).find((e=>e.field===t));return s?(s.value=o,e):e}function Sl(e,t){return t.some((t=>t.field===e))}function yl(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 new Error(`Field ${t} not found in pivot`)}function Cl(e){return e?e.map(wl).join(", "):""}function wl(e){return e?`${e.field}=${e.value}`:""}function El(e,t){const o=e.findIndex((e=>e.field===t));if(-1===o)return"";const s=e.slice(0,o),i=e.at(-1);return Cl(i.field===t?s:[...s,i])}function xl(e,t){const o=e.findIndex((e=>e.field===t));return-1===o?"":Cl([...e.slice(0,o),...e.slice(o+1)])}function Il(e,t,o){const s=[...e],i=[...t];s.sort(((e,t)=>o([...i,e],[...i,t])));for(const t of e){const e=Il(t.children,[...i,t],o);t.children=e}return s}const Rl=new r;function Tl(e){return Rl.get(e)}const Al={normalizeFunctionValue:e=>Li(e,bi),toValueAndFormat:(e,t)=>({value:Li(e,bi),format:"dd mmm yyyy"}),toFunctionValue:e=>`"${Xr(Li(e,bi),{locale:bi,format:"mm/dd/yyyy"})}"`},_l={normalizeFunctionValue(e){const t=Li(e,bi);if(t<1||t>31)throw new Ri(Oo("%s is not a valid day of month (it should be a number between 1 and 31)",t));return t},toValueAndFormat:e=>({value:Li(e,bi),format:"0"}),toFunctionValue:e=>`${e}`},Dl={normalizeFunctionValue(e){const t=Li(e,bi);if(t<1||t>7)throw new Ri(Oo("%s is not a valid day of week (it should be a number between 1 and 7)",t));return t},toValueAndFormat(e,t){const o=(e-1+(t||bi).weekStart)%7;return{value:Yr[o].toString(),format:"@"}},toFunctionValue:e=>`${e}`},Ol={normalizeFunctionValue(e){const t=Li(e,bi);if(t<0||t>53)throw new Ri(Oo("%s is not a valid week (it should be a number between 0 and 53)",t));return t},toValueAndFormat:e=>({value:Li(e,bi),format:"0"}),toFunctionValue:e=>`${e}`},Fl={normalizeFunctionValue(e){const t=Li(e,bi);if(t<1||t>12)throw new Ri(Oo("%s is not a valid month (it should be a number between 1 and 12)",t));return t},toValueAndFormat:e=>({value:jr[Li(e,bi)-1].toString(),format:"@"}),toFunctionValue:e=>`${e}`},Ml={normalizeFunctionValue(e){const t=Li(e,bi);if(t<1||t>4)throw new Ri(Oo("%s is not a valid quarter (it should be a number between 1 and 4)",t));return t},toValueAndFormat:e=>({value:Oo("Q%(quarter_number)s",{quarter_number:e}),format:"@"}),toFunctionValue:e=>`${e}`},Pl={normalizeFunctionValue:e=>Li(e,bi),toValueAndFormat:e=>({value:Li(e,bi),format:"0"}),toFunctionValue:e=>`${e}`},Nl={normalizeFunctionValue(e){const t=Li(e,bi);if(t<0||t>23)throw new Ri(Oo("%s is not a valid hour (it should be a number between 0 and 23)",t));return t},toValueAndFormat:e=>({value:Oo("%(hour_number)sh",{hour_number:e}),format:"@"}),toFunctionValue:e=>`${e}`},kl={normalizeFunctionValue(e){const t=Li(e,bi);if(t<0||t>59)throw new Ri(Oo("%s is not a valid minute (it should be a number between 0 and 59)",t));return t},toValueAndFormat:e=>({value:Oo("%(minute_number)s'",{minute_number:e}),format:"@"}),toFunctionValue:e=>`${e}`},Ll={normalizeFunctionValue(e){const t=Li(e,bi);if(t<0||t>59)throw new Ri(Oo("%s is not a valid second (it should be a number between 0 and 59)",t));return t},toValueAndFormat:e=>({value:Oo("%(second_number)s''",{second_number:e}),format:"@"}),toFunctionValue:e=>`${e}`};function Vl(e){return{normalizeFunctionValue:t=>null===t?null:e.normalizeFunctionValue(t),toValueAndFormat:(t,o)=>null===t?{value:Oo("(Undefined)")}:e.toValueAndFormat(t,o),toFunctionValue:t=>null===t?"false":e.toFunctionValue(t)}}Rl.add("day",Vl(Al)).add("year",Vl(Pl)).add("day_of_month",Vl(_l)).add("iso_week_number",Vl(Ol)).add("month_number",Vl(Fl)).add("quarter_number",Vl(Ml)).add("day_of_week",Vl(Dl)).add("hour_number",Vl(Nl)).add("minute_number",Vl(kl)).add("second_number",Vl(Ll));const Hl={count:Oo("Count"),count_distinct:Oo("Count Distinct"),bool_and:Oo("Boolean And"),bool_or:Oo("Boolean Or"),max:Oo("Maximum"),min:Oo("Minimum"),avg:Oo("Average"),sum:Oo("Sum")},Ul=["max","min","avg","sum","count_distinct","count"],Bl={integer:Ul,char:Ul,boolean:["count_distinct","count","bool_and","bool_or"]},zl={};for(const e in Bl){zl[e]={};for(const t of Bl[e])zl[e][t]=Hl[t]}const $l={count:e=>({value:tl([e]),format:"0"}),count_distinct:e=>({value:qa([e]),format:"0"}),bool_and:e=>({value:$a([e]).result}),bool_or:e=>({value:Wa([e]).result}),max:(e,t)=>ol([e],t),min:(e,t)=>sl([e],t),avg:(e,t)=>({value:Qa([e],t),format:Pi(e)}),sum:(e,t)=>({value:Ga([e],t),format:Pi(e)})};function Wl(e){const t=Object.keys(e);if(!t.length)return 0;const o=t.map((e=>parseInt(e,10)));return Math.max(...o)}const Gl={year:Oo("Year"),quarter:Oo("Quarter & Year"),month:Oo("Month & Year"),week:Oo("Week & Year"),day:Oo("Day"),quarter_number:Oo("Quarter"),month_number:Oo("Month"),iso_week_number:Oo("Week"),day_of_month:Oo("Day of Month"),day_of_week:Oo("Day of Week"),hour_number:Oo("Hour"),minute_number:Oo("Minute"),second_number:Oo("Second")},ql=["date","datetime"];function Zl(e){const[t,o]=e.split(":");return o?{fieldName:t,granularity:o}:{fieldName:t}}function jl(e){return ql.includes(e.type)}function Yl(e,t,o){const s=[e];o&&s.push(`"${o}"`);for(const{field:e,value:o,type:i}of t){if("measure"===e){s.push('"measure"',`"${o}"`);continue}const{granularity:t}=Zl(e),r=ec(o,{type:i,granularity:t});s.push(`"${e}"`,r)}return s}function Xl(e,t){let o=0,s=0;const i=t.columns.map((e=>e.nameWithGranularity)),r=t.rows.map((e=>e.nameWithGranularity));for(;void 0!==e[o]&&e[o]===r[s];)o++,s++;for(s=0;void 0!==e[o]&&e[o]===i[s];)o++,s++;return e.length===o}function Kl(e,t){switch(t.type){case"HEADER":return`=PIVOT.HEADER(${Yl(e,t.domain).join(",")})`;case"VALUE":return`=PIVOT.VALUE(${Yl(e,t.domain,t.measure).join(",")})`;case"MEASURE_HEADER":return`=PIVOT.HEADER(${Yl(e,[...t.domain,{field:"measure",value:t.measure,type:"char"}]).join(",")})`}return""}function Jl(e,t){if(null===t||"null"===t)return null;const o="boolean"==typeof t?Gi(t).toLocaleLowerCase():Gi(t);if("null"===o)return null;if(!oc.contains(e.type))throw new Ri(Oo("Field %(field)s is not supported because of its type (%(type)s)",{field:e.displayName,type:e.type}));if("false"===o.toLowerCase())return!1;return oc.get(e.type)(o,e.granularity)}function Ql(e,t){if(!t)throw new Error("Missing granularity");return Tl(t).normalizeFunctionValue(e)}function ec(e,t){return null===e?'"null"':sc.contains(t.type)?sc.get(t.type)(e,t.granularity):`"${e}"`}function tc(e,t){if(!t)throw new Error("Missing granularity");return Tl(t).toFunctionValue(e)}const oc=new r;oc.add("date",Ql).add("datetime",Ql).add("integer",(e=>Li(e,bi))).add("boolean",(e=>ji(e))).add("char",(e=>Gi(e)));const sc=new r;function ic(e){return e.displayName+(e.granularity?` (${Gl[e.granularity]})`:"")}function rc(e,t,o){const{rowDomain:s,colDomain:i}=pl(e,t);if(0===s.length&&0===i.length)return o;if(0===s.length&&i.length>0)return{...o,format:(o.format||"@")+"* "};const r=s.length-1,n=o.format||"@";return{...o,format:`${" ".repeat(r)}${n}* `}}function nc(e,t){try{if(!t.getMeasure(e.measure))return!1;const o=t.definition.columns;for(let s=0;s<e.domain.length;s++){if(o[s].nameWithGranularity!==e.domain[s].field)return!1;if(!t.getPossibleFieldValues(o[s]).map((e=>e.value)).includes(e.domain[s].value))return!1}return!0}catch(e){return!1}}sc.add("date",tc).add("datetime",tc).add("integer",(e=>`${Li(e,bi)}`)).add("boolean",(e=>ji(e)?"TRUE":"FALSE")).add("char",(e=>`"${Gi(e).replace(/"/g,'\\"')}"`));class ac extends da{isCutAllowed(e){return 1!==e.zones.length?"WrongCutSelection":"Success"}copy(e){const t=e.sheetId,{clippedZones:o,rowsIndexes:s,columnsIndexes:i}=e,r=[],n=1==s.length&&1==i.length;for(let o of s){let a=[];for(let r of i){const l={col:r,row:o,sheetId:t};let c=this.getters.getCell(l);const h=this.getters.getEvaluatedCell(l),d=this.getters.getPivotIdFromPosition(l),u=this.getters.getArrayFormulaSpreadingOn(l);if(d&&u){const t=this.getters.getSpreadZone(u);if((!mt(u,l)||!n)&&t&&!e.zones.some((e=>as(t,e)))){const e=this.getters.getPivotCellFromPosition(l),t=Kl(this.getters.getPivotFormulaId(d),e);c={id:c?.id||"",style:c?.style,format:c?.format,content:t,isFormula:!1,parsedValue:h.value}}}else if(u&&!mt(u,l)){const e=s.includes(u.row)&&i.includes(u.col)?"":Xr(h.value,{locale:this.getters.getLocale()});c={id:c?.id||"",style:c?.style,format:h.format,content:e,isFormula:!1,parsedValue:h.value}}a.push({content:c?.content??"",style:c?.style,format:c?.format,tokens:c?.isFormula?c.compiledFormula.tokens.map((({value:e,type:t})=>({value:e,type:t}))):[],border:this.getters.getCellBorder(l)||void 0,evaluatedCell:h,position:l})}r.push(a)}return{cells:r,zones:o,sheetId:e.sheetId}}isPasteAllowed(e,t,o,s){if(!o.cells)return"Success";if(s?.isCutOperation&&void 0!==s?.pasteOption)return"WrongPasteOption";if(t.length>1&&(o.cells.length>1||o.cells[0].length>1))return"WrongPasteSelection";const i=o.cells.length,r=o.cells[0].length;for(const s of la(t,o.cells))if(this.getters.doesIntersectMerge(e,s)&&(t.length>1||!this.getters.isSingleCellOrMerge(e,t[0])||i*r!=1))return"WillRemoveExistingMerge";return"Success"}paste(e,t,o){const s=e.zones,i=e.sheetId;o.isCutOperation?this.pasteFromCut(i,s,t,o):this.pasteFromCopy(i,s,t.cells,o)}getPasteTarget(e,t,o,s){const i=o.cells[0].length,r=o.cells.length;return s?.isCutOperation?{sheetId:e,zones:[{left:t[0].left,top:t[0].top,right:t[0].left+i-1,bottom:t[0].top+r-1}]}:1===i&&1===r?{zones:[],sheetId:e}:{sheetId:e,zones:la(t,o.cells)}}pasteFromCut(e,t,o,s){this.clearClippedZones(o);const i=t[0];this.pasteZone(e,i.left,i.top,o.cells,s),this.dispatch("MOVE_RANGES",{target:o.zones,sheetId:o.sheetId,targetSheetId:e,col:i.left,row:i.top})}clearClippedZones(e){this.dispatch("CLEAR_CELLS",{sheetId:e.sheetId,target:e.zones}),this.dispatch("CLEAR_FORMATTING",{sheetId:e.sheetId,target:e.zones})}pasteZone(e,t,o,s,i){for(const[r,n]of s.entries())for(const[s,a]of n.entries()){if(!a)continue;const n={col:t+s,row:o+r,sheetId:e};this.pasteCell(a,n,i)}}pasteCell(e,t,o){const{sheetId:s,col:i,row:r}=t,n=this.getters.getEvaluatedCell(t),a=e?.format??e.evaluatedCell.format;if("asValue"===o?.pasteOption)return void this.dispatch("UPDATE_CELL",{...t,content:e.evaluatedCell.value?.toString()||"",format:a});if("onlyFormat"===o?.pasteOption)return void this.dispatch("UPDATE_CELL",{...t,style:e?.style??null,format:a??n.format});let l=e?.content;e?.tokens&&e.tokens.length>0&&!o?.isCutOperation?l=this.getters.getTranslatedCellFormula(s,i-e.position.col,r-e.position.row,e.tokens):e?.tokens&&e.tokens.length>0&&(l=this.getters.getFormulaMovedInSheet(e.position.sheetId,s,e.tokens)),""!==l||e?.format||e?.style?this.dispatch("UPDATE_CELL",{...t,content:l,style:e?.style||null,format:e?.format}):n&&this.dispatch("CLEAR_CELL",t)}convertTextToClipboardData(e){const t=this.getters.getLocale(),o={cells:[]},s=[];let i=0;for(const[t,o]of e.replace(/\r/g,"").split("\n").entries())s.push(o.split("\t")),s[t].length>i&&(i=s[t].length);for(const e of s){const s=[];for(let o=0;o<i;o++){const i=za(e[o]||"",t);s.push({content:i,evaluatedCell:{formattedValue:i}})}o.cells.push(s)}return o}}class lc extends ha{copy(e){}}class cc extends da{uuidGenerator=new na;queuedChanges={};copy(e){if(!e.zones.length)return;const{rowsIndexes:t,columnsIndexes:o}=e,s=e.sheetId,i=[];for(const e of t){const t=[];for(const i of o){const o=Array.from(this.getters.getRulesByCell(s,i,e));t.push({position:{col:i,row:e,sheetId:s},rules:o})}i.push(t)}return{cfRules:i}}paste(e,t,o){if(this.queuedChanges={},"asValue"===o.pasteOption)return;const s=e.zones,i=e.sheetId;o.isCutOperation?this.pasteFromCut(i,s,t):this.pasteFromCopy(i,s,t.cfRules,o),this.executeQueuedChanges()}pasteFromCut(e,t,o){const s=t[0];this.pasteZone(e,s.left,s.top,o.cfRules,{isCutOperation:!0})}pasteZone(e,t,o,s,i){for(const[r,n]of s.entries())for(const[s,a]of n.entries()){const n={col:t+s,row:o+r,sheetId:e};this.pasteCf(a,n,i?.isCutOperation)}}pasteCf(e,t,o){if(e?.rules&&e.rules.length>0){const s=ms(t);for(const i of e.rules){const r=[];if(o&&r.push(ms(e.position)),e.position.sheetId===t.sheetId)this.adaptCFRules(e.position.sheetId,i,[s],r);else{this.adaptCFRules(e.position.sheetId,i,[],r);const o=this.getCFToCopyTo(t.sheetId,i);this.adaptCFRules(t.sheetId,o,[s],[])}}}}adaptCFRules(e,t,o,s){this.queuedChanges[e]||(this.queuedChanges[e]=[]);const i=this.queuedChanges[e].find((e=>e.cf.id===t.id));i?(i.toAdd.push(...o),i.toRemove.push(...s)):this.queuedChanges[e].push({toAdd:o,toRemove:s,cf:t})}executeQueuedChanges(){for(const e in this.queuedChanges)for(const{toAdd:t,toRemove:o,cf:s}of this.queuedChanges[e]){const i=this.getters.getAdaptedCfRanges(e,s,t,o);i&&(0!==i.length?this.dispatch("ADD_CONDITIONAL_FORMAT",{cf:{id:s.id,rule:s.rule,stopIfTrue:s.stopIfTrue},ranges:i,sheetId:e}):this.dispatch("REMOVE_CONDITIONAL_FORMAT",{id:s.id,sheetId:e}))}}getCFToCopyTo(e,t){let o=this.getters.getConditionalFormats(e).find((e=>e.stopIfTrue===t.stopIfTrue&&mt(e.rule,t.rule)));const s=this.queuedChanges[e];return!o&&s&&(o=s.find((e=>e.cf.stopIfTrue===t.stopIfTrue&&mt(e.cf.rule,t.rule)))?.cf),o||{...t,id:this.uuidGenerator.uuidv4(),ranges:[]}}}class hc extends da{copy(e){const t=e.sheetId,{rowsIndexes:o,columnsIndexes:s,zones:i}=e,r=new Set,n=[];for(let e of o){let o=[];n.push(o);for(let n of s){const s={col:n,row:e,sheetId:t},a=this.getters.getTable(s);if(!a){o.push({});continue}const l=this.getters.getCoreTable(s),c=l?.range.zone;let h;!r.has(a.id)&&l&&c&&i.some((e=>as(c,e)))&&(r.add(a.id),h={range:l.range.rangeData,config:l.config,type:l.type}),o.push({table:h,style:this.getTableStyleToCopy(s),isWholeTableCopied:r.has(a.id)})}}return{tableCells:n,sheetId:e.sheetId}}getTableStyleToCopy(e){const t=this.getters.getCellTableStyle(e),o=this.getters.getCellStyle(e),s=this.getters.getCellTableBorder(e),i=this.getters.getCellBorder(e);return{style:{...t,...bt(o)},border:{...s,...bt(i)}}}paste(e,t,o){const s=e.zones,i=e.sheetId;o.isCutOperation?this.pasteFromCut(i,s,t,o):this.pasteFromCopy(i,s,t.tableCells,o)}pasteFromCut(e,t,o,s){for(const e of o.tableCells)for(const t of e)t.table&&this.dispatch("REMOVE_TABLE",{sheetId:o.sheetId,target:[this.getters.getRangeFromRangeData(t.table.range).zone]});const i=t[0];this.pasteZone(e,i.left,i.top,o.tableCells,s)}pasteZone(e,t,o,s,i){for(let r=0;r<s.length;r++){const n=s[r];for(let s=0;s<n.length;s++){const a=n[s];if(!a)continue;const l={col:t+s,row:o+r,sheetId:e};this.pasteTableCell(e,a,l,i)}}if(1===s.length)for(let i=0;i<s[0].length;i++)this.dispatch("AUTOFILL_TABLE_COLUMN",{col:t+i,row:o,sheetId:e})}pasteTableCell(e,t,o,s){if(t.table&&!s?.pasteOption){const{range:s}=t.table,i=ls(this.getters.getRangeFromRangeData(s).zone),r={left:o.col,top:o.row,right:o.col+i.numberOfCols-1,bottom:o.row+i.numberOfRows-1};this.dispatch("CREATE_TABLE",{sheetId:o.sheetId,ranges:[this.getters.getRangeDataFromZone(e,r)],config:t.table.config,tableType:t.table.type})}this.getters.getCoreTable(o)||"asValue"===s?.pasteOption||(s?.pasteOption||t.isWholeTableCopied)&&"onlyFormat"!==s?.pasteOption||(t.style?.style&&this.dispatch("UPDATE_CELL",{...o,style:t.style.style}),t.style?.border&&this.dispatch("SET_BORDER",{...o,border:t.style.border}))}}const dc={figureHandlers:new r,cellHandlers:new r};function uc(e,t){return"REMOVE_COLUMNS_ROWS"===t.type?ts(e,"COL"===t.dimension?"left":"top",t.elements):"ADD_COLUMNS_ROWS"===t.type?Jo(e,"COL"===t.dimension?"left":"top",t.base,t.position,t.quantity):{...e}}function gc(e,t){const o="DELETE_SHEET"===t.type&&t.sheetId;if("sheetId"in t&&e._sheetId!==t.sheetId)return e;{const s=uc(e._zone,t);if(s&&o!==e._sheetId)return{...e,_zone:s}}}dc.figureHandlers.add("chart",class extends lc{copy(e){const t=e.sheetId,o=this.getters.getFigure(t,e.figureId);if(!o)throw new Error(`No figure for the given id: ${e.figureId}`);if("chart"!==o.tag)return;const s={...o},i=this.getters.getChart(e.figureId);if(!i)throw new Error(`No chart for the given id: ${e.figureId}`);const r=i.copyInSheetId(t);return{figureId:e.figureId,copiedFigure:s,copiedChart:r}}getPasteTarget(e,t,o,s){return{zones:[],figureId:(new na).uuidv4(),sheetId:e}}paste(e,t,o){if(!e.figureId)return;const{zones:s,figureId:i}=e,r=e.sheetId,n=this.getters.getNumberCols(r),a=this.getters.getNumberRows(r),l=this.getters.getColDimensions(r,s[0].left).start,c=this.getters.getRowDimensions(r,s[0].top).start,h=this.getters.getColDimensions(r,n-1).end,d=this.getters.getRowDimensions(r,a-1).end,{width:u,height:g}=t.copiedFigure,p={x:h<u?0:Math.min(l,h-u),y:d<g?0:Math.min(c,d-g)},m=t.copiedChart.copyInSheetId(r);this.dispatch("CREATE_CHART",{id:i,sheetId:r,position:p,size:{height:g,width:u},definition:m.getDefinition()}),o.isCutOperation&&this.dispatch("DELETE_FIGURE",{sheetId:t.copiedChart.sheetId,id:t.copiedFigure.id}),this.dispatch("SELECT_FIGURE",{id:i})}isPasteAllowed(e,t,o,s){return 0===t.length?"EmptyTarget":void 0!==s?.pasteOption?"WrongFigurePasteOption":"Success"}}).add("image",class extends lc{copy(e){const t=e.sheetId,o=this.getters.getFigure(t,e.figureId);if(!o)throw new Error(`No figure for the given id: ${e.figureId}`);const s={...o};if("image"!==o.tag)return;const i=Be(this.getters.getImage(e.figureId));return{figureId:e.figureId,copiedFigure:s,copiedImage:i,sheetId:t}}getPasteTarget(e,t,o,s){return{sheetId:e,zones:[],figureId:(new na).uuidv4()}}paste(e,t,o){if(!e.figureId)return;const{zones:s,figureId:i}=e,r=this.getters.getActiveSheetId(),n=this.getters.getNumberCols(r),a=this.getters.getNumberRows(r),l=this.getters.getColDimensions(r,s[0].left).start,c=this.getters.getRowDimensions(r,s[0].top).start,h=this.getters.getColDimensions(r,n-1).end,d=this.getters.getRowDimensions(r,a-1).end,{width:u,height:g}=t.copiedFigure,p={x:h<u?0:Math.min(l,h-u),y:d<g?0:Math.min(c,d-g)},m=Be(t.copiedImage);this.dispatch("CREATE_IMAGE",{figureId:i,sheetId:r,position:p,size:{height:g,width:u},definition:m}),o.isCutOperation&&this.dispatch("DELETE_FIGURE",{sheetId:t.sheetId,id:t.copiedFigure.id}),this.dispatch("SELECT_FIGURE",{id:i})}isPasteAllowed(e,t,o,s){return 0===t.length?"EmptyTarget":void 0!==s?.pasteOption?"WrongFigurePasteOption":"Success"}}),dc.cellHandlers.add("dataValidation",class extends da{uuidGenerator=new na;queuedChanges={};copy(e){const{rowsIndexes:t,columnsIndexes:o}=e,s=e.sheetId,i=[];for(const e of t){const t=[];for(const i of o){const o={sheetId:s,col:i,row:e},r=this.getters.getValidationRuleForCell(o);t.push({position:o,rule:r})}i.push(t)}return{dvRules:i}}paste(e,t,o){if(this.queuedChanges={},o.pasteOption)return;const s=e.zones,i=e.sheetId;o.isCutOperation?this.pasteFromCut(i,s,t):this.pasteFromCopy(i,s,t.dvRules),this.executeQueuedChanges()}pasteFromCut(e,t,o){const s=t[0];this.pasteZone(e,s.left,s.top,o.dvRules,{isCutOperation:!0})}pasteZone(e,t,o,s,i){for(const[r,n]of s.entries())for(const[s,a]of n.entries()){const n={col:t+s,row:o+r,sheetId:e};this.pasteDataValidation(a,n,i?.isCutOperation)}}pasteDataValidation(e,t,o){if(e){const s=ms(t),i=e.rule;if(!i){const e=this.getters.getValidationRuleForCell(t);return void(e&&this.adaptDataValidationRule(t.sheetId,e,[],[s]))}const r=[];if(o&&r.push(ms(e.position)),e.position.sheetId===t.sheetId){const o=this.getDataValidationRuleToCopyTo(t.sheetId,i,!1);this.adaptDataValidationRule(e.position.sheetId,o,[s],r)}else{const o=this.getters.getValidationRuleForCell(e.position);o&&this.adaptDataValidationRule(e.position.sheetId,o,[],r);const n=this.getDataValidationRuleToCopyTo(t.sheetId,i);this.adaptDataValidationRule(t.sheetId,n,[s],[])}}}getDataValidationRuleToCopyTo(e,t,o=!0){let s=this.getters.getDataValidationRules(e).find((e=>mt(t.criterion,e.criterion)&&t.isBlocking===e.isBlocking));const i=this.queuedChanges[e];return!s&&i&&(s=i.find((e=>mt(t.criterion,e.rule.criterion)&&t.isBlocking===e.rule.isBlocking))?.rule),s||{...t,id:o?this.uuidGenerator.uuidv4():t.id,ranges:[]}}adaptDataValidationRule(e,t,o,s){this.queuedChanges[e]||(this.queuedChanges[e]=[]);const i=this.queuedChanges[e].find((e=>e.rule.id===t.id));i?(i.toAdd.push(...o),i.toRemove.push(...s)):this.queuedChanges[e].push({toAdd:o,toRemove:s,rule:t})}executeQueuedChanges(){for(const e in this.queuedChanges)for(const{toAdd:t,toRemove:o,rule:s}of this.queuedChanges[e]){const i=s.ranges.map((e=>e.zone)),r=yo(i,o),n=yo([...r,...t],[]);0!==n.length?this.dispatch("ADD_DATA_VALIDATION_RULE",{rule:s,ranges:n.map((t=>this.getters.getRangeDataFromZone(e,t))),sheetId:e}):this.dispatch("REMOVE_DATA_VALIDATION_RULE",{sheetId:e,id:s.id})}}}).add("cell",ac).add("sheet",class extends da{isPasteAllowed(e,t,o,s){if(!("cells"in o))return"Success";const{xSplit:i,ySplit:r}=this.getters.getPaneDivisions(e);for(const e of la(t,o.cells))if(e.left<i&&e.right>=i||e.top<r&&e.bottom>=r)return"FrozenPaneOverlap";return"Success"}}).add("merge",class extends da{copy(e){const t=this.getters.getActiveSheetId(),{rowsIndexes:o,columnsIndexes:s}=e,i=[];for(const e of o){const o=[];for(const i of s){const s={col:i,row:e,sheetId:t};o.push(this.getters.getMerge(s))}i.push(o)}return{merges:i}}paste(e,t,o){o.isCutOperation||this.pasteFromCopy(e.sheetId,e.zones,t.merges,o)}pasteZone(e,t,o,s){for(const[i,r]of s.entries())for(const[s,n]of r.entries()){const r={col:t+s,row:o+i,sheetId:e};this.pasteMerge(n,r)}}pasteMerge(e,t){if(!e)return;if(this.getters.isInMerge(t))return;const{sheetId:o,col:s,row:i}=t;this.dispatch("ADD_MERGE",{sheetId:o,force:!0,target:[{left:s,top:i,right:s+e.right-e.left,bottom:i+e.bottom-e.top}]})}}).add("border",ua).add("table",hc).add("conditionalFormat",cc);class pc{subscriptions={};on(e,t,o){if(!o)throw new Error("Missing callback");this.subscriptions[e]||(this.subscriptions[e]=[]),this.subscriptions[e].push({owner:t,callback:o})}trigger(e,t){const o=this.subscriptions[e]||[];for(let e=0,s=o.length;e<s;e++){const s=o[e];s.callback.call(s.owner,t)}}off(e,t){const o=this.subscriptions[e];o&&(this.subscriptions[e]=o.filter((e=>e.owner!==t)))}clear(){this.subscriptions={}}}class mc extends pc{dependencies=new Map;factory=new fc(this.get.bind(this));inject(e,t){if(this.dependencies.has(e)&&this.dependencies.get(e)!==t)throw new Error(`Store ${e.name} already has an instance`);this.dependencies.set(e,t)}get(e){return this.dependencies.has(e)||this.dependencies.set(e,this.instantiate(e)),this.dependencies.get(e)}instantiate(e,...t){return this.factory.build(e,...t)}resetStores(){this.dependencies.clear()}}class fc{get;pendingBuilds=new Set;constructor(e){this.get=e}build(e,...t){if(this.pendingBuilds.has(e))throw new Error(`Circular dependency detected: ${[...this.pendingBuilds,e].map((e=>e.name)).join(" -> ")}`);this.pendingBuilds.add(e);const o=new e(this.get,...t);return this.pendingBuilds.delete(e),o}}class vc{get;disposeCallbacks=[];constructor(e){this.get=e}onDispose(e){this.disposeCallbacks.push(e)}dispose(){this.disposeCallbacks.forEach((e=>e()))}}function bc(){const e=t.useEnv();if(e.__spreadsheet_stores__ instanceof mc)return e.__spreadsheet_stores__;const o=new mc;return t.useSubEnv({__spreadsheet_stores__:o,getStore:e=>wc(o.get(e),(()=>o.trigger("store-updated")))}),o}function Sc(e){const o=Ec(t.useEnv()),s=o.get(e);return Cc(o,s)}function yc(e,...o){const s=Ec(t.useEnv()),i=s.instantiate(e,...o);return t.onWillUnmount((()=>i.dispose())),Cc(s,i)}function Cc(e,o){const s=t.useComponent();return wc(o,(()=>{"mounted"===t.status(s)&&e.trigger("store-updated")}))}function wc(e,t){return new Proxy(e,{get(o,s,i){const r=o,n=Reflect.get(o,s,r);if(e.mutators?.includes(s)){const e=new Proxy(n,{apply(e,o,s){Reflect.apply(e,r,s),t()}});return e}return n}})}function Ec(e){const t=e.__spreadsheet_stores__;if(!(t instanceof mc))throw new Error("No store provider found. Did you forget to call useStoreProvider()?");return t}const xc=(Ic="Model",class{constructor(e){throw new Error(`This is a abstract store for ${Ic}, it cannot be instantiated.\nDid you forget to inject your store instance?\n\nconst stores = useStoreProvider();\nstores.inject(MyMetaStore, storeInstance);\n`)}});var Ic;class Rc{mutators=["register","unRegister"];renderers={};register(e){if(e.renderingLayers.length)for(const t of e.renderingLayers)this.renderers[t]||(this.renderers[t]=[]),this.renderers[t].push(e)}unRegister(e){for(const t of Object.keys(this.renderers))this.renderers[t]=this.renderers[t].filter((t=>t!==e))}drawLayer(e,t){const o=this.renderers[t];if(o)for(const s of o)e.ctx.save(),s.drawLayer(e,t),e.ctx.restore()}}class Tc extends vc{model=this.get(xc);getters=this.model.getters;renderer=this.get(Rc);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){}}const Ac={id:"void-composer",get editionMode(){return"inactive"},startEdition:()=>{throw new Error("No composer is registered")},stopEdition:()=>{throw new Error("No composer is registered")},setCurrentContent:()=>{throw new Error("No composer is registered")}};class _c extends Tc{mutators=["focusComposer","focusActiveComposer"];activeComposer=Ac;_focusMode="inactive";get focusMode(){return"inactive"===this.activeComposer.editionMode?"inactive":this._focusMode}focusComposer(e,t){this.activeComposer=e,this.getters.isReadonly()||(this._focusMode=t.focusMode||"contentFocus","inactive"!==this._focusMode&&this.setComposerContent(t))}focusActiveComposer(e){if(!this.getters.isReadonly()){if(!this.activeComposer)throw new Error("No composer is registered");this._focusMode=e.focusMode||"contentFocus","inactive"!==this._focusMode&&this.setComposerContent(e)}}setComposerContent({content:e,selection:t}){"inactive"===this.activeComposer.editionMode?this.activeComposer.startEdition(e,t):e&&this.activeComposer.setCurrentContent(e,t)}}const Dc="x1";function Oc(e,t,o,s){let i=!1;const r=[];for(let s in o){let n=o[s];if(n.labelCell){const e=Pc(n.labelCell,t);n.labelCell!==e&&(i=!0,n={...n,labelCell:e})}const a=Pc(n.dataRange,t);void 0===a||e.getRangeString(a,a.sheetId)===xi.InvalidReference?(i=!0,n=void 0):a!==n.dataRange&&(i=!0,n={...n,dataRange:a}),r[s]=n}let n=s;const a=Pc(n,t);a!==n&&(i=!0,n=a);return{isStale:i,dataSets:r.filter(at),labelRange:n}}function Fc(e,t,o){return o.map((o=>({dataRange:kn(e,t,o.dataRange),labelCell:o.labelCell?kn(e,t,o.labelCell):void 0})))}function Mc(e,t,o){return o?kn(e,t,o):void 0}function Pc(e,t){if(!e)return;const o=t(e);switch(o.changeType){case"NONE":return e;case"REMOVE":return;default:return o.range}}function Nc(e,t,o,s){const i=[];for(const r of t){const t=e.getRangeFromSheetXC(o,r.dataRange),{unboundedZone:n,sheetId:a,invalidSheetName:l,invalidXc:c}=t;if(!l&&!c)if(n.left!==n.right&&n.top!==n.bottom){if(void 0===n.right)continue;for(let t=n.left;t<=n.right;t++){const o={...n,left:t,right:t};i.push({...kc(e,a,o,s?{top:o.top,bottom:o.top,left:o.left,right:o.left}:void 0),backgroundColor:r.backgroundColor,rightYAxis:"y1"===r.yAxisId,customLabel:r.label})}}else i.push({...kc(e,a,n,s?{top:n.top,bottom:n.top,left:n.left,right:n.left}:void 0),backgroundColor:r.backgroundColor,rightYAxis:"y1"===r.yAxisId,customLabel:r.label})}return i}function kc(e,t,o,s){if(o.left!==o.right&&o.top!==o.bottom)throw new Error(`Zone should be a single column or row: ${Ko(o)}`);if(s){const i=Ko(o),r=Ko(s);return{labelCell:e.getRangeFromSheetXC(t,r),dataRange:e.getRangeFromSheetXC(t,i)}}return{labelCell:void 0,dataRange:e.getRangeFromSheetXC(t,Ko(o))}}function Lc(e,t){const o=t.labelCell?.zone;let s=t.dataRange.zone;if(o){const{numberOfRows:e,numberOfCols:t}=ls(s);1===e?s={...s,left:s.left+1}:1===t&&(s={...s,top:s.top+1})}const i=t.dataRange.clone({zone:s});let r={};return t.customLabel?r={text:t.customLabel}:t.labelCell&&(r={reference:e.getRangeString(t.labelCell,"forceSheetReference",{useBoundedReference:!0})}),{label:r,range:e.getRangeString(i,"forceSheetReference",{useBoundedReference:!0}),backgroundColor:t.backgroundColor,rightYAxis:t.rightYAxis}}function Vc(e,t,o){if(!t)return;let s={...t.zone};o&&t.zone.bottom>t.zone.top&&(s.top=s.top+1);const i=t.clone({zone:s});return e.getRangeString(i,"forceSheetReference",{useBoundedReference:!0})}function Hc(e,t){let o;if(e.labelRange){const s=uc(Zo(e.labelRange),t);o=s?Ko(s):void 0}const s=e.dataSets.map((e=>Zo(e.dataRange))).map((e=>uc(e,t))).filter(at).map((e=>({dataRange:Ko(e)})));return{...e,labelRange:o,dataSets:s}}function Uc(e){return e&&Wt(e)<.3?"#FFFFFF":"#000000"}function Bc(e){return e&&Wt(e)<.3?"#C8C8C8":"#666666"}function zc(e){if(e.dataSets){const t=void 0!==e.dataSets.find((e=>!Ho.test(e.dataRange)));if(t)return"InvalidDataSet";if(e.dataSets.map((e=>Zo(e.dataRange))).some((e=>e.top!==e.bottom&&vs(e))))return"InvalidDataSet"}return"Success"}function $c(e){if(e.labelRange){if(!Ho.test(e.labelRange||""))return"InvalidLabelRange"}return"Success"}function Wc(e,t,o){if(!o)return!1;if(!e)return!1;if(!t)return!0;const s=bs(t.dataRange.zone);return!(bs(e.zone)<s)}function Gc(e,t){const{x:o,y:s}=e.getMainViewportCoordinates(),{scrollX:i,scrollY:r}=e.getActiveSheetScrollInfo(),{width:n,height:a}=e.getVisibleRect(e.getActiveMainViewport());return{x:o+i+Math.max(0,(n-t.width)/2),y:s+r+Math.max(0,(a-t.height)/2)}}function qc(e){let t=!1,o=!1;if("horizontal"in e&&e.horizontal)return{useLeftAxis:!0,useRightAxis:!1};for(const s of e.dataSets||[])"y1"===s.yAxisId?o=!0:t=!0;return t||=!o,{useLeftAxis:t,useRightAxis:o}}function Zc(e,t){return(o,s)=>jc({format:s?e?.[s]:void 0,locale:t})(o)}function jc(e){return t=>{if(t=Number(t),isNaN(t))return t;const{locale:o,format:s}=e;return Xr(t,{locale:o,format:!s&&Math.abs(t)>=1e3?"#,##":s})}}const Yc=[{value:"left",label:Oo("Left")},{value:"right",label:Oo("Right")}];function Xc(e,t){const o=[],s=Dt(t.map((e=>e.data.length)));for(let t=0;t<=s;t++)o.push(e.next());return o}const Kc={id:"chartShowValuesPlugin",afterDatasetsDraw(e,t,o){if(!o.showValues)return;const s=e._metasets?.[0]?.data;if(!s)return;const i=e.ctx;switch(i.save(),i.textAlign="center",i.textBaseline="middle",i.miterLimit=1,e.config.type){case"pie":case"doughnut":!function(e,t,o){for(const s of e._metasets)for(let e=0;e<s._parsed.length;e++){const i=Number(s._parsed[e]);if(isNaN(i)||0===i)continue;const r=s.data[e],{startAngle:n,endAngle:a,innerRadius:l,outerRadius:c}=r,h=(n+a)/2,d=(l+c)/2,u=r.x+d*Math.cos(h),g=r.y+d*Math.sin(h)+7;o.fillStyle=Uc(t.background),o.strokeStyle=t.background||"#ffffff";Jc(t.callback(i),u,g,o)}}(e,o,i);break;case"bar":case"line":case"radar":o.horizontal?function(e,t,o){const s=e.chartArea.right,i=e.chartArea.left,r={};for(const n of e._metasets){if(n.xAxisID===Dc)return;for(let e=0;e<n._parsed.length;e++){const a=Number(n._parsed[e].x);if(isNaN(a))continue;const l=t.callback(a,n.xAxisID),c=n.data[e],h=c.y;let d=a<0?c.x+c.width/2:c.x-c.width/2;d=Math.min(d,s),d=Math.max(d,i),r[h]||(r[h]=[]);const u=Zn(o,l,{fontSize:12},"px");for(const e of r[h])Math.abs(e-d)<u&&(d=e+u+3);r[h].push(d),o.fillStyle=c.options.backgroundColor,o.strokeStyle=t.background||"#ffffff",Jc(l,d,h,o)}}}(e,o,i):function(e,t,o){const s=e.chartArea.bottom,i=e.chartArea.top,r={};for(const n of e._metasets)if(n.xAxisID!==Dc&&!n.hidden)for(let a=0;a<n._parsed.length;a++){const l=n._parsed[a],c=Number("radar"===e.config.type?l.r:l.y);if(isNaN(c))continue;const h="radar"===e.config.type?n.rAxisID:n.yAxisID,d=t.callback(Number(c),h),u=n.data[a],g=u.x;let p=0;p="line"===e.config.type||"radar"===e.config.type?u.y-10:c<0?u.y-u.height/2:u.y+u.height/2,p=Math.min(p,s),p=Math.max(p,i),r[g]||(r[g]=[]);for(const e of r[g]||[])Math.abs(e-p)<13&&(p=e-13);r[g].push(p),o.fillStyle=u.options.backgroundColor,o.strokeStyle=t.background||"#ffffff",Jc(d,g,p,o)}}(e,o,i)}i.restore()}};function Jc(e,t,o,s){s.lineWidth=3,s.strokeText(e,t,o),s.lineWidth=1,s.fillText(e,t,o)}const Qc={id:"waterfallLinesPlugin",beforeDraw(e,t,o){if(!o.showConnectorLines)return;const s=e._metasets?.[0]?.data;if(!s)return;const i=e.ctx;i.save(),i.setLineDash([3,2]);for(let e=0;e<s.length;e++){const t=s[e];if(0===t.height)continue;const o=th(s,e);if(!o)break;const r=eh(t),n=eh(o),a=t.$context.raw,l=a[1]-a[0],c=Math.round(l<0?r.bottom-1:r.top),h=Math.round(r.right),d=Math.round(n.left);i.strokeStyle="#999",i.beginPath(),i.moveTo(h+1,c+.5),i.lineTo(d,c+.5),i.stroke()}i.restore()}};function eh(e){const t=e.base<e.y;return{left:e.x-e.width/2,right:e.x+e.width/2,bottom:t?e.base+e.height:e.y+e.height,top:t?e.base:e.y}}function th(e,t){return e.find(((e,o)=>o>t&&0!==e.height))}window.Chart?.register(Qc),window.Chart?.register(Kc);class oh extends t.Component{static template="o-spreadsheet-ChartJsComponent";static props={figure:Object};canvas=t.useRef("graphContainer");chart;currentRuntime;get background(){return this.chartRuntime.background}get canvasStyle(){return`background-color: ${this.background}`}get chartRuntime(){const e=this.env.model.getters.getChartRuntime(this.props.figure.id);if(!("chartJsConfig"in e))throw new Error("Unsupported chart runtime");return e}setup(){t.onMounted((()=>{const e=this.chartRuntime;this.currentRuntime=e,this.createChart(Be(e.chartJsConfig))})),t.onWillUnmount((()=>this.chart?.destroy())),t.useEffect((()=>{const e=this.chartRuntime;e!==this.currentRuntime&&(e.chartJsConfig.type!==this.currentRuntime.chartJsConfig.type?(this.chart?.destroy(),this.createChart(Be(e.chartJsConfig))):this.updateChartJs(Be(e)),this.currentRuntime=e)}))}createChart(e){const t=this.canvas.el.getContext("2d");this.chart=new window.Chart(t,e)}updateChartJs(e){const t=e.chartJsConfig;t.data&&t.data.datasets?(this.chart.data=t.data,t.options?.plugins?.title&&(this.chart.config.options.plugins.title=t.options.plugins.title)):this.chart.data.datasets=[],this.chart.config.options=t.options,this.chart.update()}}class sh{sheetId;title;getters;constructor(e,t,o){this.title=e.title,this.sheetId=t,this.getters=o}static validateChartDefinition(e,t){throw new Error("This method should be implemented by sub class")}static transformDefinition(e,t){throw new Error("This method should be implemented by sub class")}static getDefinitionFromContextCreation(e){throw new Error("This method should be implemented by sub class")}}function ih(e,t,o,s,i){if("text"===t||"progress"===t||e?.type!==ii.number||o?.type!==ii.number)return;const r=o.value-e.value;return r>0?s:r<0?i:void 0}function rh(e,t,o){if("text"===o||e?.type!==ii.number||t?.type!==ii.number)return"neutral";const s=t.value-e.value;return s>0?"up":s<0?"down":"neutral"}function nh(e){return e.keyValue&&!Ho.test(e.keyValue)?"InvalidScorecardKeyValue":"Success"}function ah(e){return e.baseline&&!Ho.test(e.baseline)?"InvalidScorecardBaseline":"Success"}const lh=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"),ch=new window.Path2D("M8.7 5.5a.5.5 0 0 0 0-.75l-3.8-4a.5.5 0 0 0-.75 0l-3.8 4a.5.5 0 0 0 0 .75l.4.4a.5.5 0 0 0 .75 0l2.3-2.4v5.8c0 .25.25.5.5.5h.6c.25 0 .5-.25.5-.5v-5.8l2.2 2.4a.5.5 0 0 0 .75 0z");let hh=class e extends sh{keyValue;baseline;baselineMode;baselineDescr;progressBar=!1;background;baselineColorUp;baselineColorDown;fontColor;humanize;type="scorecard";constructor(e,t,o){super(e,t,o),this.keyValue=Ln(o,t,e.keyValue),this.baseline=Ln(o,t,e.baseline),this.baselineMode=e.baselineMode,this.baselineDescr=e.baselineDescr,this.background=e.background,this.baselineColorUp=e.baselineColorUp??xe,this.baselineColorDown=e.baselineColorDown??Ie,this.humanize=e.humanize??!1}static validateChartDefinition(e,t){return e.checkValidations(t,nh,ah)}static getDefinitionFromContextCreation(e){return{background:e.background,type:"scorecard",keyValue:e.range?e.range[0].dataRange:void 0,title:e.title||{text:""},baselineMode:Ee,baselineColorUp:xe,baselineColorDown:Ie,baseline:e.auxiliaryRange||""}}static transformDefinition(e,t){let o,s;return e.baseline&&(o=uc(Zo(e.baseline),t)),e.keyValue&&(s=uc(Zo(e.keyValue),t)),{...e,baseline:o?Ko(o):void 0,keyValue:s?Ko(s):void 0}}copyForSheetId(t){const o=Mc(this.sheetId,t,this.baseline),s=Mc(this.sheetId,t,this.keyValue),i=this.getDefinitionWithSpecificRanges(o,s,t);return new e(i,t,this.getters)}copyInSheetId(t){const o=this.getDefinitionWithSpecificRanges(this.baseline,this.keyValue,t);return new e(o,t,this.getters)}getDefinition(){return this.getDefinitionWithSpecificRanges(this.baseline,this.keyValue)}getContextCreation(){return{...this,range:this.keyValue?[{dataRange:this.getters.getRangeString(this.keyValue,this.sheetId)}]:void 0,auxiliaryRange:this.baseline?this.getters.getRangeString(this.baseline,this.sheetId):void 0}}getDefinitionWithSpecificRanges(e,t,o){return{baselineColorDown:this.baselineColorDown,baselineColorUp:this.baselineColorUp,baselineMode:this.baselineMode,title:this.title,type:"scorecard",background:this.background,baseline:e?this.getters.getRangeString(e,o||this.sheetId):void 0,baselineDescr:this.baselineDescr,keyValue:t?this.getters.getRangeString(t,o||this.sheetId):void 0,humanize:this.humanize}}getDefinitionForExcel(){}updateRanges(t){const o=Pc(this.baseline,t),s=Pc(this.keyValue,t);if(this.baseline===o&&this.keyValue===s)return this;const i=this.getDefinitionWithSpecificRanges(o,s);return new e(i,this.sheetId,this.getters)}};function dh(e,t){const o=t.getContext("2d");t.width=e.canvas.width;const s=t.width-2*Z;if(t.height=e.canvas.height,o.fillStyle=e.canvas.backgroundColor,o.fillRect(0,0,e.canvas.width,e.canvas.height),e.title){o.font=e.title.style.font,o.fillStyle=e.title.style.color;const t=o.textBaseline;o.textBaseline="middle",o.fillText(ia(o,e.title.text,s-e.title.position.x),e.title.position.x,e.title.position.y),o.textBaseline=t}if(e.baseline&&(o.font=e.baseline.style.font,o.fillStyle=e.baseline.style.color,ra(o,e.baseline.text,e.baseline.position,e.baseline.style.underline,e.baseline.style.strikethrough)),e.baselineArrow&&e.baselineArrow.style.size>0){o.save(),o.fillStyle=e.baselineArrow.style.color,o.translate(e.baselineArrow.position.x,e.baselineArrow.position.y);const t=e.baselineArrow.style.size/10;switch(o.scale(t,t),e.baselineArrow.direction){case"down":o.fill(lh);break;case"up":o.fill(ch)}o.restore()}if(e.baselineDescr){const t=e.baselineDescr[0];o.font=t.style.font,o.fillStyle=t.style.color;for(const t of e.baselineDescr)o.fillText(ia(o,t.text,s-t.position.x),t.position.x,t.position.y)}if(e.key&&(o.font=e.key.style.font,o.fillStyle=e.key.style.color,ra(o,ia(o,e.key.text,s-e.key.position.x),e.key.position,e.key.style.underline,e.key.style.strikethrough)),e.progressBar){if(o.fillStyle=e.progressBar.style.backgroundColor,o.beginPath(),o.roundRect(e.progressBar.position.x,e.progressBar.position.y,e.progressBar.dimension.width,e.progressBar.dimension.height,e.progressBar.dimension.height/2),o.fill(),o.fillStyle=e.progressBar.style.color,o.beginPath(),e.progressBar.value>0)o.roundRect(e.progressBar.position.x,e.progressBar.position.y,e.progressBar.dimension.width*Math.max(0,Math.min(1,e.progressBar.value)),e.progressBar.dimension.height,e.progressBar.dimension.height/2);else{const t=e.progressBar.dimension.width*Math.max(0,Math.min(1,-e.progressBar.value));o.roundRect(e.progressBar.position.x+e.progressBar.dimension.width-t,e.progressBar.position.y,t,e.progressBar.dimension.height,e.progressBar.dimension.height/2)}o.fill()}}function uh(e,t){let o,s="";const i=t.getLocale();if(e.keyValue){const r={sheetId:e.keyValue.sheetId,col:e.keyValue.zone.left,row:e.keyValue.zone.top};o=t.getEvaluatedCell(r),s=function(e,t,o){return e?t?fn(e,o):e.formattedValue??String(e.value??""):""}(o,e.humanize??!1,i)}let r;const n=e.baseline;if(n){const e={sheetId:n.sheetId,col:n.zone.left,row:n.zone.top};r=t.getEvaluatedCell(e)}const{background:a,fontColor:l}=t.getStyleOfSingleCellChart(e.background,e.keyValue),c=function(e,t,o,s,i){if(!e)return"";if("text"===o||t?.type!==ii.number||e.type!==ii.number)return s?fn(e,i):e.formattedValue;let{value:r,format:n}=e;return"progress"===o?(r=t.value/r,n="0.0%"):(r=Math.abs(t.value-r),"percentage"===o&&0!==r&&(r/=e.value),"percentage"===o&&(n="0.0%"),n||(r=Math.round(100*r)/100)),s?fn({value:r,format:n},i):Xr(r,{format:n,locale:i})}(r,o,e.baselineMode,e.humanize??!1,i),h="progress"===e.baselineMode&&ei(c,i)?Li(c,i):0;return{title:{...e.title,text:e.title.text?Oo(e.title.text):""},keyValue:s,baselineDisplay:c,baselineArrow:rh(r,o,e.baselineMode),baselineColor:ih(r,e.baselineMode,o,e.baselineColorUp,e.baselineColorDown),baselineDescr:"progress"!==e.baselineMode&&e.baselineDescr?Oo(e.baselineDescr):"",fontColor:l,background:a,baselineStyle:"percentage"!==e.baselineMode&&"progress"!==e.baselineMode&&n?t.getCellStyle({sheetId:n.sheetId,col:n.zone.left,row:n.zone.top}):void 0,keyValueStyle:e.keyValue?t.getCellStyle({sheetId:e.keyValue.sheetId,col:e.keyValue.zone.left,row:e.keyValue.zone.top}):void 0,progressBar:"progress"===e.baselineMode?{value:h,color:h>0?e.baselineColorUp:e.baselineColorDown}:void 0}}const gh=10,ph=.05;function mh({width:e,height:t},o){return new fh({width:e,height:t},o).computeDesign()}class fh{runtime;context;width;height;constructor({width:e,height:t},o){this.runtime=o;const s=document.createElement("canvas");this.width=s.width=e,this.height=s.height=t,this.context=s.getContext("2d")}computeDesign(){const e={canvas:{width:this.width,height:this.height,backgroundColor:this.backgroundColor}},t=this.getTextStyles();let o=0;if(this.title){let s,i;switch(({height:o,width:i}=this.getFullTextDimensions(this.title,t.title.font)),this.runtime.title.align){case"center":s=(this.width-i)/2;break;case"right":s=this.width-i-gh;break;default:s=gh}e.title={text:this.title,style:t.title,position:{x:s,y:gh+o/2}}}const s=t.baselineArrow?.size??0;let{height:i,width:r}=this.getTextDimensions(this.baseline,t.baselineValue.font);this.baseline||(i=this.getTextDimensions(this.baselineDescr,t.baselineDescr.font).height);const n=this.getTextDimensions(this.baselineDescr,t.baselineDescr.font).width;e.baseline={text:this.baseline,style:t.baselineValue,position:{x:(this.width-r-n+s)/2,y:this.keyValue?this.height*(1-ph*(this.runtime.progressBar?1:2)):this.height-(this.height-o-i)/2-gh}};const a=s+20;if(e.baseline.position.x<a&&(e.baseline.position.x=a),t.baselineArrow&&!this.runtime.progressBar&&(e.baselineArrow={direction:this.baselineArrow,style:t.baselineArrow,position:{x:e.baseline.position.x-s,y:e.baseline.position.y-(i+s)/2}}),this.baselineDescr){const o={x:e.baseline.position.x+r,y:e.baseline.position.y};e.baselineDescr=[{text:this.baselineDescr,style:t.baselineDescr,position:o}]}let l=0;this.runtime.progressBar&&(l=.05*this.height,e.progressBar={position:{x:20,y:.9*this.height-i-l},dimension:{height:l,width:this.width-40},value:this.runtime.progressBar.value,style:{color:this.runtime.progressBar.color,backgroundColor:this.secondaryFontColor}});const{width:c,height:h}=this.getFullTextDimensions(this.keyValue,t.keyValue.font);return this.keyValue&&(e.key={text:this.keyValue,style:t.keyValue,position:{x:Math.max(gh,(this.width-c)/2),y:.4*this.height+5+(o+h/2)/2}}),e}get title(){return this.runtime.title.text??""}get keyValue(){return this.runtime.keyValue}get baseline(){return this.runtime.baselineDisplay}get baselineDescr(){return function(e,t){const o=e||"";return t&&o?" "+o:o}(this.runtime.baselineDescr,this.baseline)}get baselineArrow(){return this.runtime.baselineArrow}get backgroundColor(){return this.runtime.background}get secondaryFontColor(){return Bc(this.backgroundColor)}getTextDimensions(e,t){this.context.font=t;const o=this.context.measureText(e);return{width:o.width,height:o.actualBoundingBoxAscent+o.actualBoundingBoxDescent}}getFullTextDimensions(e,t){this.context.font=t;const o=this.context.measureText(e);return{width:o.width,height:o.fontBoundingBoxAscent+o.fontBoundingBoxDescent}}getTextStyles(){let e=16;const t=Math.floor(.9*e);return this.runtime.progressBar&&(e/=1.5),{title:{font:Gn(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:Gn(32,this.runtime.keyValueStyle?.bold,this.runtime.keyValueStyle?.italic),strikethrough:this.runtime.keyValueStyle?.strikethrough,underline:this.runtime.keyValueStyle?.underline},baselineValue:{font:Gn(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:Gn(t),color:this.secondaryFontColor},baselineArrow:"neutral"===this.baselineArrow||this.runtime.progressBar?void 0:{size:this.keyValue?.8*e:0,color:this.runtime.baselineColor||this.secondaryFontColor}}}}class vh extends t.Component{static template="o-spreadsheet-ScorecardChart";static props={figure:Object};canvas=t.useRef("chartContainer");get runtime(){return this.env.model.getters.getChartRuntime(this.props.figure.id)}get title(){const e=this.env.model.getters.getChartDefinition(this.props.figure.id).title.text??"";return Oo(e)}setup(){t.useEffect(this.createChart.bind(this),(()=>{const e=this.canvas.el.getBoundingClientRect();return[e.width,e.height,this.runtime,this.canvas.el]}))}createChart(){const e=this.canvas.el;dh(mh(e.getBoundingClientRect(),this.runtime),e)}}const bh=new r;function Sh(e,t,o,s){const i=[];e=e.toLowerCase();for(const r of e){const e=t.toLocaleLowerCase().indexOf(r);-1!==e&&(i.push({value:t.slice(0,e),color:""},{value:t[e],color:o,class:s}),t=t.slice(e+1))}return i.push({value:t}),i.filter((e=>e.value))}bh.add("dataValidation",{getProposals(e,t){if(t.startsWith("="))return[];if(!this.composer.currentEditedCell)return[];const o=this.composer.currentEditedCell,s=this.getters.getValidationRuleForCell(o);if(!s||"isValueInList"!==s.criterion.type&&"isValueInRange"!==s.criterion.type)return[];let i;if("isValueInList"===s.criterion.type)i=s.criterion.values;else{const e=this.getters.getRangeFromSheetXC(o.sheetId,s.criterion.values[0]);i=Array.from(new Set(this.getters.getRangeValues(e).filter(lt).map((e=>e.toString())).filter((e=>""!==e))))}return i.map((e=>({text:e})))},selectProposal(e,t){this.composer.setCurrentContent(t),this.composer.stopEdition()}});const yh=/(.*?)\((.*?)\)(.*)/,Ch=["ANY","BOOLEAN","DATE","NUMBER","STRING","RANGE","RANGE<BOOLEAN>","RANGE<DATE>","RANGE<NUMBER>","RANGE<STRING>","META"];function wh(e,t=""){return function(e,t){let o=e.match(yh),s=o[1].trim();if(!s)throw new Error(`Function argument definition is missing a name: '${e}'.`);let i,r=[],n=!1,a=!1;for(let e of o[2].split(",")){const t=e.trim().toUpperCase();let o=Ch.find((e=>t===e));o?r.push(o):"RANGE<ANY>"===t?r.push("RANGE"):"OPTIONAL"===t?n=!0:"REPEATING"===t?a=!0:t.startsWith("DEFAULT=")&&(i=e.trim().slice(8))}const l={name:s,description:t,type:r};(r.includes("ANY")||r.includes("RANGE"))&&(l.acceptErrors=!0);n&&(l.optional=!0);a&&(l.repeating=!0);void 0!==i&&(l.default=!0,l.defaultValue=i);r.some((e=>e.startsWith("RANGE")))&&(l.acceptMatrix=!0);r.every((e=>e.startsWith("RANGE")))&&(l.acceptMatrixOnly=!0);return l}(e,t)}function Eh(e){let t=0,o=0,s=0;for(let i of e.args)t++,i.optional||i.repeating||i.default||o++,i.repeating&&s++;const i=e;return i.minArgRequired=o,i.maxArgPossible=s?1/0:t,i.nbrArgRepeating=s,i.getArgToFocus=function(e,t){if(!t)return e=>e;if(1===t)return t=>Math.min(t,e);const o=e-t;return e=>{if(e<=o)return e;return o+((e-o)%t||t)}}(t,s),i.hidden=e.hidden||!1,i}function xh(e,t){Mi((()=>1===t.length||1===t[0].length),e)}function Ih(e,...t){if(t.every(yi)){const o=t[0].length,s=t[0][0].length;for(const i of t)Mi((()=>i.length===o&&i[0].length===s),e)}else if(t.some((e=>Array.isArray(e)&&(1!==e.length||1!==e[0].length))))throw new Ri(e)}function Rh(e,t){Mi((()=>t>0),e)}function Th(e,t){Mi((()=>t.length===t[0].length),e)}const Ah={description:Oo("Returns a result array constrained to a specific width and height."),args:[wh("input_range (any, range<any>)",Oo("The range to constrain.")),wh("rows (number)",Oo("The number of rows in the constrained array.")),wh("columns (number)",Oo("The number of columns in the constrained array."))],compute:function(e,t,o){const s=fr(e),i=Bi(t?.value,this.locale),r=Bi(o?.value,this.locale);Rh(Oo("The rows argument (%s) must be strictly positive.",i.toString()),i),Rh(Oo("The columns argument (%s) must be strictly positive.",i.toString()),r);const n=Math.min(i,s[0].length);return ir(Math.min(r,s.length),n,((e,t)=>s[e][t]))},isExported:!1},_h={description:Oo("Creates a new array from the selected columns in the existing range."),args:[wh("array (any, range<any>)",Oo("The array that contains the columns to be returned.")),wh("col_num (number, range<number>)",Oo("The first column index of the columns to be returned.")),wh("col_num2 (number, range<number>, repeating)",Oo("The columns indexes of the columns to be returned."))],compute:function(e,...t){const o=fr(e),s=vr(t,(e=>Bi(e?.value,this.locale))),i=s.filter((e=>0===e||o.length<Math.abs(e)));Mi((()=>0===i.length),Oo("The columns arguments must be between -%s and %s (got %s), excluding 0.",o.length.toString(),o.length.toString(),i.join(",")));const r=Array(s.length);for(let e=0;e<s.length;e++)s[e]>0?r[e]=o[s[e]-1]:r[e]=o[o.length+s[e]];return r},isExported:!0},Dh={description:Oo("Creates a new array from the selected rows in the existing range."),args:[wh("array (any, range<any>)",Oo("The array that contains the rows to be returned.")),wh("row_num (number, range<number>)",Oo("The first row index of the rows to be returned.")),wh("row_num2 (number, range<number>, repeating)",Oo("The rows indexes of the rows to be returned."))],compute:function(e,...t){const o=fr(e),s=vr(t,(e=>Bi(e?.value,this.locale))),i=o.length,r=s.filter((e=>0===e||o[0].length<Math.abs(e)));return Mi((()=>0===r.length),Oo("The rows arguments must be between -%s and %s (got %s), excluding 0.",o[0].length.toString(),o[0].length.toString(),r.join(","))),ir(i,s.length,((e,t)=>s[t]>0?o[e][s[t]-1]:o[e][o[e].length+s[t]]))},isExported:!0},Oh={description:Oo("Expands or pads an array to specified row and column dimensions."),args:[wh("array (any, range<any>)",Oo("The array to expand.")),wh("rows (number)",Oo("The number of rows in the expanded array. If missing, rows will not be expanded.")),wh("columns (number, optional)",Oo("The number of columns in the expanded array. If missing, columns will not be expanded.")),wh("pad_with (any, default=0)",Oo("The value with which to pad."))],compute:function(e,t,o,s={value:0}){const i=fr(e),r=Bi(t?.value,this.locale),n=void 0!==o?Bi(o.value,this.locale):i.length;return Mi((()=>r>=i[0].length),Oo("The rows arguments (%s) must be greater or equal than the number of rows of the array.",r.toString())),Mi((()=>n>=i.length),Oo("The columns arguments (%s) must be greater or equal than the number of columns of the array.",n.toString())),ir(n,r,((e,t)=>e>=i.length||t>=i[e].length?s:i[e][t]))},isExported:!0},Fh={description:Oo("Flattens all the values from one or more ranges into a single column."),args:[wh("range (any, range<any>)",Oo("The first range to flatten.")),wh("range2 (any, range<any>, repeating)",Oo("Additional ranges to flatten."))],compute:function(...e){return[vr(e,(e=>void 0===e?{value:""}:e))]},isExported:!1},Mh={description:Oo("Calculates the frequency distribution of a range."),args:[wh("data (range<number>)",Oo("The array of ranges containing the values to be counted.")),wh("classes (number, range<number>)",Oo("The range containing the set of classes."))],compute:function(e,t){const o=vr([e],(e=>e.value)).filter((e=>"number"==typeof e)),s=vr([t],(e=>e.value)).filter((e=>"number"==typeof e)),i=s.map(((e,t)=>({initialIndex:t,value:e,count:0}))).sort(((e,t)=>e.value-t.value));i.push({initialIndex:i.length,value:1/0,count:0});const r=o.sort(((e,t)=>e-t));let n=0;for(const e of r){for(;e>i[n].value&&n<i.length-1;)n++;i[n].count++}return[i.sort(((e,t)=>e.initialIndex-t.initialIndex)).map((e=>e.count))]},isExported:!0},Ph={description:Oo("Appends ranges horizontally and in sequence to return a larger array."),args:[wh("range1 (any, range<any>)",Oo("The first range to be appended.")),wh("range2 (any, range<any>, repeating)",Oo("Additional ranges to add to range1."))],compute:function(...e){const t=Math.max(...e.map((e=>e?.[0]?.length??0))),o=[];for(const s of e){const e=fr(s);for(let s=0;s<e.length;s++){const i=Array(t).fill({value:null});for(let t=0;t<e[s].length;t++)i[t]=e[s][t];o.push(i)}}return o},isExported:!0},Nh={description:Oo("Returns the matrix determinant of a square matrix."),args:[wh("square_matrix (number, range<number>)",Oo("An range with an equal number of rows and columns representing a matrix whose determinant will be calculated."))],compute:function(e){const t=Hi(e,"square_matrix");return Th(Oo("The argument square_matrix must have the same number of columns and rows."),t),ja(t).determinant},isExported:!0},kh={description:Oo("Returns the multiplicative inverse of a square matrix."),args:[wh("square_matrix (number, range<number>)",Oo("An range with an equal number of rows and columns representing a matrix whose multiplicative inverse will be calculated."))],compute:function(e){const t=Hi(e,"square_matrix");Th(Oo("The argument square_matrix must have the same number of columns and rows."),t);const{inverted:o}=ja(t);return o||new Ri(Oo("The matrix is not invertible."))},isExported:!0},Lh={description:Oo("Calculates the matrix product of two matrices."),args:[wh("matrix1 (number, range<number>)",Oo("The first matrix in the matrix multiplication operation.")),wh("matrix2 (number, range<number>)",Oo("The second matrix in the matrix multiplication operation."))],compute:function(e,t){const o=Hi(e,"matrix1"),s=Hi(t,"matrix2");return Mi((()=>o.length===s[0].length),Oo("In [[FUNCTION_NAME]], the number of columns of the first matrix (%s) must be equal to the number of rows of the second matrix (%s).",o.length.toString(),s[0].length.toString())),Xa(o,s)},isExported:!0},Vh={description:Oo("Calculates the sum of the products of corresponding entries in equal-sized ranges."),args:[wh("range1 (number, range<number>)",Oo("The first range whose entries will be multiplied with corresponding entries in the other ranges.")),wh("range2 (number, range<number>, repeating)",Oo("The other range whose entries will be multiplied with corresponding entries in the other ranges."))],compute:function(...e){Ih(Oo("All the ranges must have the same dimensions."),...e);const t=e.map(fr);let o=0;for(let e=0;e<t[0].length;e++)for(let s=0;s<t[0][e].length;s++){if(!t.every((t=>"number"==typeof t[e][s].value)))continue;let i=1;for(const o of t)i*=Li(o[e][s],this.locale);o+=i}return o},isExported:!0};function Hh(e,t,o){Ih("The arguments array_x and array_y must have the same dimensions.",e,t);const s=fr(e),i=fr(t);let r=!1,n=0;for(const e in s)for(const t in s[e]){const a=s[e][t].value,l=i[e][t].value;"number"==typeof a&&"number"==typeof l&&(r=!0,n+=o(a,l))}return r?n:new Ri(Oo("The arguments array_x and array_y must contain at least one pair of numbers."))}const Uh={description:Oo("Calculates the sum of the difference of the squares of the values in two array."),args:[wh("array_x (number, range<number>)",Oo("The array or range of values whose squares will be reduced by the squares of corresponding entries in array_y and added together.")),wh("array_y (number, range<number>)",Oo("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 Hh(e,t,((e,t)=>e**2-t**2))},isExported:!0},Bh={description:Oo("Calculates the sum of the sum of the squares of the values in two array."),args:[wh("array_x (number, range<number>)",Oo("The array or range of values whose squares will be added to the squares of corresponding entries in array_y and added together.")),wh("array_y (number, range<number>)",Oo("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 Hh(e,t,((e,t)=>e**2+t**2))},isExported:!0},zh={description:Oo("Calculates the sum of squares of the differences of values in two array."),args:[wh("array_x (number, range<number>)",Oo("The array or range of values that will be reduced by corresponding entries in array_y, squared, and added together.")),wh("array_y (number, range<number>)",Oo("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 Hh(e,t,((e,t)=>(e-t)**2))},isExported:!0},$h=!1,Wh=[wh("array (any, range<any>)",Oo("The array which will be transformed.")),wh("ignore (number, default=0)",Oo("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.")),wh("scan_by_column (number, default=false)",Oo("Whether the array should be scanned by column. True scans the array by column and false (default) scans the array by row."))];function Gh(e){const t=Math.trunc(e);if(0===t)return()=>!0;if(1===t)return e=>null!==e.value;if(2===t)return e=>!Ni(e.value);if(3===t)return e=>null!==e.value&&!Ni(e.value);throw new Ri(Oo("Argument ignore must be between 0 and 3"))}const qh={description:Oo("Transforms a range of cells into a single column."),args:Wh,compute:function(e,t={value:0},o={value:$h}){const s=fr(e),i=Li(t.value,this.locale),r=(ji(o.value)?s:nr(s)).flat().filter(Gh(i));return 0===r.length?new _i(Oo("No results for the given arguments of TOCOL.")):[r]},isExported:!0},Zh={description:Oo("Transforms a range of cells into a single row."),args:Wh,compute:function(e,t={value:0},o={value:$h}){const s=fr(e),i=Li(t.value,this.locale),r=(ji(o.value)?s:nr(s)).flat().filter(Gh(i)).map((e=>[e]));return 0===r.length||0===r[0].length?new _i(Oo("No results for the given arguments of TOROW.")):r},isExported:!0},jh={description:Oo("Transposes the rows and columns of a range."),args:[wh("range (any, range<any>)",Oo("The range to be transposed."))],compute:function(e){const t=fr(e);return ir(t[0].length,t.length,((e,o)=>t[o][e]))},isExported:!0},Yh={description:Oo("Appends ranges vertically and in sequence to return a larger array."),args:[wh("range1 (any, range<any>)",Oo("The first range to be appended.")),wh("range2 (any, range<any>, repeating)",Oo("Additional ranges to add to range1."))],compute:function(...e){const t=Math.max(...e.map((e=>fr(e).length))),o=e.reduce(((e,t)=>e+fr(t)[0].length),0),s=Array(t).fill([]).map((()=>Array(o).fill({value:0})));let i=0;for(const t of e){const e=fr(t);for(let t=0;t<e.length;t++)for(let o=0;o<e[t].length;o++)s[t][i+o]=e[t][o];i+=e[0].length}return s},isExported:!0},Xh={description:Oo("Wraps the provided row or column of cells by columns after a specified number of elements to form a new array."),args:[wh("range (any, range<any>)",Oo("The range to wrap.")),wh("wrap_count (number)",Oo("The maximum number of cells for each column, rounded down to the nearest whole number.")),wh("pad_with (any, default=0)",Oo("The value with which to fill the extra cells in the range."))],compute:function(e,t,o={value:0}){const s=fr(e),i=Bi(t?.value,this.locale);xh(Oo("Argument range must be a single row or column."),s);const r=s.flat();return ir(Math.ceil(r.length/i),i,((e,t)=>{const s=e*i+t;return s<r.length?r[s]:o}))},isExported:!0},Kh={description:Oo("Wraps the provided row or column of cells by rows after a specified number of elements to form a new array."),args:[wh("range (any, range<any>)",Oo("The range to wrap.")),wh("wrap_count (number)",Oo("The maximum number of cells for each row, rounded down to the nearest whole number.")),wh("pad_with (any, default=0)",Oo("The value with which to fill the extra cells in the range."))],compute:function(e,t,o={value:0}){const s=fr(e),i=Bi(t?.value,this.locale);xh(Oo("Argument range must be a single row or column."),s);const r=s.flat(),n=Math.ceil(r.length/i);return ir(i,n,((e,t)=>{const s=t*i+e;return s<r.length?r[s]:o}))},isExported:!0};var Jh=Object.freeze({__proto__:null,ARRAY_CONSTRAIN:Ah,CHOOSECOLS:_h,CHOOSEROWS:Dh,EXPAND:Oh,FLATTEN:Fh,FREQUENCY:Mh,HSTACK:Ph,MDETERM:Nh,MINVERSE:kh,MMULT:Lh,SUMPRODUCT:Vh,SUMX2MY2:Uh,SUMX2PY2:Bh,SUMXMY2:zh,TOCOL:qh,TOROW:Zh,TRANSPOSE:jh,VSTACK:Yh,WRAPCOLS:Xh,WRAPROWS:Kh});const Qh={description:Oo("Apply a large number format"),args:[wh("value (number)",Oo("The number.")),wh("unit (string, optional)",Oo("The formatting unit. Use 'k', 'm', or 'b' to force the unit"))],compute:function(e,t){return{value:Li(e,this.locale),format:vn(e,t,this.locale)}}};var ed=Object.freeze({__proto__:null,FORMAT_LARGE_NUMBER:Qh});const td=/^-?[a-z0-9]+$/i,od={description:Oo("Absolute value of a number."),args:[wh("value (number)",Oo("The number of which to return the absolute value."))],compute:function(e){return Math.abs(Li(e,this.locale))},isExported:!0},sd={description:Oo("Inverse cosine of a value, in radians."),args:[wh("value (number)",Oo("The value for which to calculate the inverse cosine. Must be between -1 and 1, inclusive."))],compute:function(e){const t=Li(e,this.locale);return Mi((()=>Math.abs(t)<=1),Oo("The value (%s) must be between -1 and 1 inclusive.",t.toString())),Math.acos(t)},isExported:!0},id={description:Oo("Inverse hyperbolic cosine of a number."),args:[wh("value (number)",Oo("The value for which to calculate the inverse hyperbolic cosine. Must be greater than or equal to 1."))],compute:function(e){const t=Li(e,this.locale);return Mi((()=>t>=1),Oo("The value (%s) must be greater than or equal to 1.",t.toString())),Math.acosh(t)},isExported:!0},rd={description:Oo("Inverse cotangent of a value."),args:[wh("value (number)",Oo("The value for which to calculate the inverse cotangent."))],compute:function(e){const t=Li(e,this.locale);return(Math.sign(t)||1)*Math.PI/2-Math.atan(t)},isExported:!0},nd={description:Oo("Inverse hyperbolic cotangent of a value."),args:[wh("value (number)",Oo("The value for which to calculate the inverse hyperbolic cotangent. Must not be between -1 and 1, inclusive."))],compute:function(e){const t=Li(e,this.locale);return Mi((()=>Math.abs(t)>1),Oo("The value (%s) cannot be between -1 and 1 inclusive.",t.toString())),Math.log((t+1)/(t-1))/2},isExported:!0},ad={description:Oo("Inverse sine of a value, in radians."),args:[wh("value (number)",Oo("The value for which to calculate the inverse sine. Must be between -1 and 1, inclusive."))],compute:function(e){const t=Li(e,this.locale);return Mi((()=>Math.abs(t)<=1),Oo("The value (%s) must be between -1 and 1 inclusive.",t.toString())),Math.asin(t)},isExported:!0},ld={description:Oo("Inverse hyperbolic sine of a number."),args:[wh("value (number)",Oo("The value for which to calculate the inverse hyperbolic sine."))],compute:function(e){return Math.asinh(Li(e,this.locale))},isExported:!0},cd={description:Oo("Inverse tangent of a value, in radians."),args:[wh("value (number)",Oo("The value for which to calculate the inverse tangent."))],compute:function(e){return Math.atan(Li(e,this.locale))},isExported:!0},hd={description:Oo("Angle from the X axis to a point (x,y), in radians."),args:[wh("x (number)",Oo("The x coordinate of the endpoint of the line segment for which to calculate the angle from the x-axis.")),wh("y (number)",Oo("The y coordinate of the endpoint of the line segment for which to calculate the angle from the x-axis."))],compute:function(e,t){const o=Li(e,this.locale),s=Li(t,this.locale);return Mi((()=>0!==o||0!==s),Oo("Function [[FUNCTION_NAME]] caused a divide by zero error."),xi.DivisionByZero),Math.atan2(s,o)},isExported:!0},dd={description:Oo("Inverse hyperbolic tangent of a number."),args:[wh("value (number)",Oo("The value for which to calculate the inverse hyperbolic tangent. Must be between -1 and 1, exclusive."))],compute:function(e){const t=Li(e,this.locale);return Mi((()=>Math.abs(t)<1),Oo("The value (%s) must be between -1 and 1 exclusive.",t.toString())),Math.atanh(t)},isExported:!0},ud={description:Oo("Rounds number up to nearest multiple of factor."),args:[wh("value (number)",Oo("The value to round up to the nearest integer multiple of factor.")),wh("factor (number, default=1)",Oo("The number to whose multiples value will be rounded."))],compute:function(e,t={value:1}){const o=Li(e,this.locale),s=Li(t,this.locale);return Mi((()=>s>=0||o<=0),Oo("The factor (%s) must be positive when the value (%s) is positive.",s.toString(),o.toString())),{value:s?Math.ceil(o/s)*s:0,format:e?.format}},isExported:!0};function gd(e,t,o=0){return 0===t?0:(t=Math.abs(t),e>=0?Math.ceil(e/t)*t:0===o?-Math.floor(Math.abs(e)/t)*t:-Math.ceil(Math.abs(e)/t)*t)}const pd={description:Oo("Rounds number up to nearest multiple of factor."),args:[wh("number (number)",Oo("The value to round up to the nearest integer multiple of significance.")),wh("significance (number, default=1)",Oo("The number to whose multiples number will be rounded. The sign of significance will be ignored.")),wh("mode (number, default=0)",Oo("If number is negative, specifies the rounding direction. If 0 or blank, it is rounded towards zero. Otherwise, it is rounded away from zero."))],compute:function(e,t={value:1},o={value:0}){const s=Li(t,this.locale);return{value:gd(Li(e,this.locale),s,Li(o,this.locale)),format:e?.format}},isExported:!0},md={description:Oo("Rounds number up to nearest multiple of factor."),args:[wh("number (number)",Oo("The value to round up to the nearest integer multiple of significance.")),wh("significance (number, default=1)",Oo("The number to whose multiples number will be rounded."))],compute:function(e,t={value:1}){const o=Li(t,this.locale);return{value:gd(Li(e,this.locale),o),format:e?.format}},isExported:!0},fd={description:Oo("Cosine of an angle provided in radians."),args:[wh("angle (number)",Oo("The angle to find the cosine of, in radians."))],compute:function(e){return Math.cos(Li(e,this.locale))},isExported:!0},vd={description:Oo("Hyperbolic cosine of any real number."),args:[wh("value (number)",Oo("Any real value to calculate the hyperbolic cosine of."))],compute:function(e){return Math.cosh(Li(e,this.locale))},isExported:!0},bd={description:Oo("Cotangent of an angle provided in radians."),args:[wh("angle (number)",Oo("The angle to find the cotangent of, in radians."))],compute:function(e){const t=Li(e,this.locale);return Wi(t),1/Math.tan(t)},isExported:!0},Sd={description:Oo("Hyperbolic cotangent of any real number."),args:[wh("value (number)",Oo("Any real value to calculate the hyperbolic cotangent of."))],compute:function(e){const t=Li(e,this.locale);return Wi(t),1/Math.tanh(t)},isExported:!0},yd={description:Oo("Number of empty values."),args:[wh("value1 (any, range)",Oo("The first value or range in which to count the number of blanks.")),wh("value2 (any, range, repeating)",Oo("Additional values or ranges in which to count the number of blanks."))],compute:function(...e){return tr(e,((e,t)=>void 0===t||null===t.value||""===t.value?e+1:e),0)},isExported:!0},Cd={description:Oo("A conditional count across a range."),args:[wh("range (range)",Oo("The range that is tested against criterion.")),wh("criterion (string)",Oo("The pattern or test to apply to range."))],compute:function(...e){let t=0;return dr(e,((e,o)=>{t+=1}),this.locale),t},isExported:!0},wd={description:Oo("Count values depending on multiple criteria."),args:[wh("criteria_range1 (range)",Oo("The range to check against criterion1.")),wh("criterion1 (string)",Oo("The pattern or test to apply to criteria_range1.")),wh("criteria_range2 (any, range, repeating)",Oo("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.")),wh("criterion2 (string, repeating)",Oo("Additional criteria to check."))],compute:function(...e){let t=0;return dr(e,((e,o)=>{t+=1}),this.locale),t},isExported:!0},Ed={description:Oo("Counts number of unique values in a range."),args:[wh("value1 (any, range)",Oo("The first value or range to consider for uniqueness.")),wh("value2 (any, range, repeating)",Oo("Additional values or ranges to consider for uniqueness."))],compute:function(...e){return qa(e)}},xd={description:Oo("Counts number of unique values in a range, filtered by a set of criteria."),args:[wh("range (range)",Oo("The range of cells from which the number of unique values will be counted.")),wh("criteria_range1 (range)",Oo("The range of cells over which to evaluate criterion1.")),wh("criterion1 (string)",Oo("The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.")),wh("criteria_range2 (any, range, repeating)",Oo("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.")),wh("criterion2 (string, repeating)",Oo("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){let o=new Set;return dr(t,((t,s)=>{const i=e[t]?.[s];br(i)&&o.add(i.value)}),this.locale),o.size}},Id={description:Oo("Cosecant of an angle provided in radians."),args:[wh("angle (number)",Oo("The angle to find the cosecant of, in radians."))],compute:function(e){const t=Li(e,this.locale);return Wi(t),1/Math.sin(t)},isExported:!0},Rd={description:Oo("Hyperbolic cosecant of any real number."),args:[wh("value (number)",Oo("Any real value to calculate the hyperbolic cosecant of."))],compute:function(e){const t=Li(e,this.locale);return Wi(t),1/Math.sinh(t)},isExported:!0},Td={description:Oo("Converts from another base to decimal."),args:[wh("value (string)",Oo("The number to convert.")),wh("base (number)",Oo("The base to convert the value from."))],compute:function(e,t){let o=Li(t,this.locale);o=Math.floor(o),Mi((()=>2<=o&&o<=36),Oo("The base (%s) must be between 2 and 36 inclusive.",o.toString()));const s=Gi(e);if(""===s)return 0;Mi((()=>td.test(s)),Oo("The value (%s) must be a valid base %s representation.",s,o.toString()));const i=parseInt(s,o);return Mi((()=>!isNaN(i)),Oo("The value (%s) must be a valid base %s representation.",s,o.toString())),i},isExported:!0},Ad={description:Oo("Converts an angle value in radians to degrees."),args:[wh("angle (number)",Oo("The angle to convert from radians to degrees."))],compute:function(e){return 180*Li(e,this.locale)/Math.PI},isExported:!0},_d={description:Oo("Euler's number, e (~2.718) raised to a power."),args:[wh("value (number)",Oo("The exponent to raise e."))],compute:function(e){return Math.exp(Li(e,this.locale))},isExported:!0},Dd={description:Oo("Rounds number down to nearest multiple of factor."),args:[wh("value (number)",Oo("The value to round down to the nearest integer multiple of factor.")),wh("factor (number, default=1)",Oo("The number to whose multiples value will be rounded."))],compute:function(e,t={value:1}){const o=Li(e,this.locale),s=Li(t,this.locale);return Mi((()=>s>=0||o<=0),Oo("The factor (%s) must be positive when the value (%s) is positive.",s.toString(),o.toString())),{value:s?Math.floor(o/s)*s:0,format:e?.format}},isExported:!0};function Od(e,t,o=0){return 0===t?0:(t=Math.abs(t),e>=0?Math.floor(e/t)*t:0===o?-Math.ceil(Math.abs(e)/t)*t:-Math.floor(Math.abs(e)/t)*t)}const Fd={description:Oo("Rounds number down to nearest multiple of factor."),args:[wh("number (number)",Oo("The value to round down to the nearest integer multiple of significance.")),wh("significance (number, default=1)",Oo("The number to whose multiples number will be rounded. The sign of significance will be ignored.")),wh("mode (number, default=0)",Oo("If number is negative, specifies the rounding direction. If 0 or blank, it is rounded away from zero. Otherwise, it is rounded towards zero."))],compute:function(e,t={value:1},o={value:0}){const s=Li(t,this.locale);return{value:Od(Li(e,this.locale),s,Li(o,this.locale)),format:e?.format}},isExported:!0},Md={description:Oo("Rounds number down to nearest multiple of factor."),args:[wh("number (number)",Oo("The value to round down to the nearest integer multiple of significance.")),wh("significance (number, default=1)",Oo("The number to whose multiples number will be rounded."))],compute:function(e,t={value:1}){const o=Li(t,this.locale);return{value:Od(Li(e,this.locale),o),format:e?.format}},isExported:!0},Pd={description:Oo("Whether the provided value is even."),args:[wh("value (number)",Oo("The value to be verified as even."))],compute:function(e){const t=Ui(e,this.locale);return!(1&Math.floor(Math.abs(t)))},isExported:!0},Nd={description:Oo("Rounds number up to nearest multiple of factor."),args:[wh("number (number)",Oo("The value to round up to the nearest integer multiple of significance.")),wh("significance (number, default=1)",Oo("The number to whose multiples number will be rounded."))],compute:function(e,t={value:1}){return{value:gd(Li(e,this.locale),Li(t,this.locale)),format:e?.format}},isExported:!0},kd={description:Oo("Whether the provided value is even."),args:[wh("value (number)",Oo("The value to be verified as even."))],compute:function(e){const t=Ui(e,this.locale);return!!(1&Math.floor(Math.abs(t)))},isExported:!0},Ld={description:Oo("The logarithm of a number, base e (euler's number)."),args:[wh("value (number)",Oo("The value for which to calculate the logarithm, base e."))],compute:function(e){const t=Li(e,this.locale);return Mi((()=>t>0),Oo("The value (%s) must be strictly positive.",t.toString())),Math.log(t)},isExported:!0};function Vd(e,t){Mi((()=>0!==t),Oo("The divisor must be different from 0."),xi.DivisionByZero);const o=e%t;return o>0&&t<0||o<0&&t>0?o+t:o}const Hd={description:Oo("Modulo (remainder) operator."),args:[wh("dividend (number)",Oo("The number to be divided to find the remainder.")),wh("divisor (number)",Oo("The number to divide by."))],compute:function(e,t){const o=Li(t,this.locale);return{value:Vd(Li(e,this.locale),o),format:e?.format}},isExported:!0},Ud={description:Oo("Returns a n x n unit matrix, where n is the input dimension."),args:[wh("dimension (number)",Oo("An integer specifying the dimension size of the unit matrix. It must be positive."))],compute:function(e){const t=Bi(e,this.locale);return Rh(Oo("The argument dimension must be positive"),t),Za(t)},isExported:!0},Bd={description:Oo("Rounds a number up to the nearest odd integer."),args:[wh("value (number)",Oo("The value to round to the next greatest odd number."))],compute:function(e){const t=Li(e,this.locale);let o=Math.ceil(Math.abs(t));return o=1&o?o:o+1,{value:t<0?-o:o,format:e?.format}},isExported:!0},zd={description:Oo("The number pi."),args:[],compute:function(){return Math.PI},isExported:!0},$d={description:Oo("A number raised to a power."),args:[wh("base (number)",Oo("The number to raise to the exponent power.")),wh("exponent (number)",Oo("The exponent to raise base to."))],compute:function(e,t){const o=Li(e,this.locale),s=Li(t,this.locale);return Mi((()=>o>=0||Number.isInteger(s)),Oo("The exponent (%s) must be an integer when the base is negative.",s.toString())),{value:Math.pow(o,s),format:e?.format}},isExported:!0},Wd={description:Oo("Result of multiplying a series of numbers together."),args:[wh("factor1 (number, range<number>)",Oo("The first number or range to calculate for the product.")),wh("factor2 (number, range<number>, repeating)",Oo("More numbers or ranges to calculate for the product."))],compute:function(...e){let t=0,o=1;for(let s of e)if(yi(s))for(let e of s)for(let s of e){const e=s.value;if("number"==typeof e&&(o*=e,t+=1),Ni(e))return s}else void 0!==s&&null!==s.value&&(o*=Ui(s,this.locale),t+=1);return{value:0===t?0:o,format:Pi(e[0])}},isExported:!0},Gd={description:Oo("A random number between 0 inclusive and 1 exclusive."),args:[],compute:function(){return Math.random()},isExported:!0},qd={description:Oo("Returns a grid of random numbers between 0 inclusive and 1 exclusive."),args:[wh("rows (number, default=1)",Oo("The number of rows to be returned.")),wh("columns (number, default=1)",Oo("The number of columns to be returned.")),wh("min (number, default=0)",Oo("The minimum number you would like returned.")),wh("max (number, default=1)",Oo("The maximum number you would like returned.")),wh("whole_number (number, default=FALSE)",Oo("Return a whole number or a decimal value."))],compute:function(e={value:1},t={value:1},o={value:0},s={value:1},i={value:!1}){const r=Bi(t,this.locale),n=Bi(e,this.locale),a=Li(o,this.locale),l=Li(s,this.locale),c=ji(i);Rh(Oo("The number of columns (%s) must be positive.",r.toString()),r),Rh(Oo("The number of rows (%s) must be positive.",n.toString()),n),Mi((()=>a<=l),Oo("The maximum (%s) must be greater than or equal to the minimum (%s).",l.toString(),a.toString())),c&&Mi((()=>Number.isInteger(a)&&Number.isInteger(l)),Oo("The maximum (%s) and minimum (%s) must be integers when whole_number is TRUE.",l.toString(),a.toString()));const h=Array(r);for(let e=0;e<r;e++){h[e]=Array(n);for(let t=0;t<n;t++)h[e][t]=c?Math.floor(Math.random()*(l-a+1)+a):a+Math.random()*(l-a)}return h},isExported:!0},Zd={description:Oo("Random integer between two values, inclusive."),args:[wh("low (number)",Oo("The low end of the random range.")),wh("high (number)",Oo("The high end of the random range."))],compute:function(e,t){let o=Li(e,this.locale);Number.isInteger(o)||(o=Math.ceil(o));let s=Li(t,this.locale);return Number.isInteger(s)||(s=Math.floor(s)),Mi((()=>o<=s),Oo("The high (%s) must be greater than or equal to the low (%s).",s.toString(),o.toString())),{value:o+Math.ceil((s-o+1)*Math.random())-1,format:e?.format}},isExported:!0},jd={description:Oo("Rounds a number according to standard rules."),args:[wh("value (number)",Oo("The value to round to places number of places.")),wh("places (number, default=0)",Oo("The number of decimal places to which to round."))],compute:function(e,t={value:0}){const o=Li(e,this.locale);let s=Li(t,this.locale);const i=Math.abs(o);let r;return 0===s?r=Math.round(i):(Number.isInteger(s)||(s=Math.trunc(s)),r=Math.round(i*Math.pow(10,s))/Math.pow(10,s)),{value:o>=0?r:-r,format:e?.format}},isExported:!0},Yd={description:Oo("Rounds down a number."),args:[wh("value (number)",Oo("The value to round to places number of places, always rounding down.")),wh("places (number, default=0)",Oo("The number of decimal places to which to round."))],compute:function(e,t={value:0}){const o=Li(e,this.locale);let s=Li(t,this.locale);const i=Math.abs(o);let r;return 0===s?r=Math.floor(i):(Number.isInteger(s)||(s=Math.trunc(s)),r=Math.floor(i*Math.pow(10,s))/Math.pow(10,s)),{value:o>=0?r:-r,format:e?.format}},isExported:!0},Xd={description:Oo("Rounds up a number."),args:[wh("value (number)",Oo("The value to round to places number of places, always rounding up.")),wh("places (number, default=0)",Oo("The number of decimal places to which to round."))],compute:function(e,t={value:0}){const o=Li(e,this.locale);let s=Li(t,this.locale);const i=Math.abs(o);let r;return 0===s?r=Math.ceil(i):(Number.isInteger(s)||(s=Math.trunc(s)),r=Math.ceil(i*Math.pow(10,s))/Math.pow(10,s)),{value:o>=0?r:-r,format:e?.format}},isExported:!0},Kd={description:Oo("Secant of an angle provided in radians."),args:[wh("angle (number)",Oo("The angle to find the secant of, in radians."))],compute:function(e){return 1/Math.cos(Li(e,this.locale))},isExported:!0},Jd={description:Oo("Hyperbolic secant of any real number."),args:[wh("value (number)",Oo("Any real value to calculate the hyperbolic secant of."))],compute:function(e){return 1/Math.cosh(Li(e,this.locale))},isExported:!0},Qd={description:Oo("Returns a sequence of numbers."),args:[wh("rows (number)",Oo("The number of rows to return")),wh("columns (number, optional, default=1)",Oo("The number of columns to return")),wh("start (number, optional, default=1)",Oo("The first number in the sequence")),wh("step (number, optional, default=1)",Oo("The amount to increment each value in the sequence"))],compute:function(e,t={value:1},o={value:1},s={value:1}){const i=Li(o,this.locale),r=Li(s,this.locale),n=Bi(e,this.locale),a=Bi(t,this.locale);return Rh(Oo("The number of columns (%s) must be positive.",a),a),Rh(Oo("The number of rows (%s) must be positive.",n),n),ir(a,n,((e,t)=>({value:i+t*a*r+e*r})))},isExported:!0},eu={description:Oo("Sine of an angle provided in radians."),args:[wh("angle (number)",Oo("The angle to find the sine of, in radians."))],compute:function(e){return Math.sin(Li(e,this.locale))},isExported:!0},tu={description:Oo("Hyperbolic sine of any real number."),args:[wh("value (number)",Oo("Any real value to calculate the hyperbolic sine of."))],compute:function(e){return Math.sinh(Li(e,this.locale))},isExported:!0},ou={description:Oo("Positive square root of a positive number."),args:[wh("value (number)",Oo("The number for which to calculate the positive square root."))],compute:function(e){const t=Li(e,this.locale);return Mi((()=>t>=0),Oo("The value (%s) must be positive or null.",t.toString())),{value:Math.sqrt(t),format:e?.format}},isExported:!0},su={description:Oo("Sum of a series of numbers and/or cells."),args:[wh("value1 (number, range<number>)",Oo("The first number or range to add together.")),wh("value2 (number, range<number>, repeating)",Oo("Additional numbers or ranges to add to value1."))],compute:function(...e){const t=e[0];return{value:Ga(e,this.locale),format:Pi(t)}},isExported:!0},iu={description:Oo("A conditional sum across a range."),args:[wh("criteria_range (range)",Oo("The range which is tested against criterion.")),wh("criterion (string)",Oo("The pattern or test to apply to range.")),wh("sum_range (range, default=criteria_range)",Oo("The range to be summed, if different from range."))],compute:function(e,t,o){void 0===o&&(o=e);let s=0;return dr([e,t],((e,t)=>{const i=o[e]?.[t]?.value;"number"==typeof i&&(s+=i)}),this.locale),s},isExported:!0},ru={description:Oo("Sums a range depending on multiple criteria."),args:[wh("sum_range (range)",Oo("The range to sum.")),wh("criteria_range1 (range)",Oo("The range to check against criterion1.")),wh("criterion1 (string)",Oo("The pattern or test to apply to criteria_range1.")),wh("criteria_range2 (any, range, repeating)",Oo("Additional ranges to check.")),wh("criterion2 (string, repeating)",Oo("Additional criteria to check."))],compute:function(e,...t){let o=0;return dr(t,((t,s)=>{const i=e[t]?.[s]?.value;"number"==typeof i&&(o+=i)}),this.locale),o},isExported:!0},nu={description:Oo("Tangent of an angle provided in radians."),args:[wh("angle (number)",Oo("The angle to find the tangent of, in radians."))],compute:function(e){return Math.tan(Li(e,this.locale))},isExported:!0},au={description:Oo("Hyperbolic tangent of any real number."),args:[wh("value (number)",Oo("Any real value to calculate the hyperbolic tangent of."))],compute:function(e){return Math.tanh(Li(e,this.locale))},isExported:!0};function lu(e,t){return 0===t?Math.trunc(e):(Number.isInteger(t)||(t=Math.trunc(t)),Math.trunc(e*Math.pow(10,t))/Math.pow(10,t))}const cu={description:Oo("Truncates a number."),args:[wh("value (number)",Oo("The value to be truncated.")),wh("places (number, default=0)",Oo("The number of significant digits to the right of the decimal point to retain."))],compute:function(e,t={value:0}){return{value:lu(Li(e,this.locale),Li(t,this.locale)),format:e?.format}},isExported:!0},hu={description:Oo("Rounds a number down to the nearest integer that is less than or equal to it."),args:[wh("value (number)",Oo("The number to round down to the nearest integer."))],compute:function(e){return Math.floor(Li(e,this.locale))},isExported:!0};var du=Object.freeze({__proto__:null,ABS:od,ACOS:sd,ACOSH:id,ACOT:rd,ACOTH:nd,ASIN:ad,ASINH:ld,ATAN:cd,ATAN2:hd,ATANH:dd,CEILING:ud,CEILING_MATH:pd,CEILING_PRECISE:md,COS:fd,COSH:vd,COT:bd,COTH:Sd,COUNTBLANK:yd,COUNTIF:Cd,COUNTIFS:wd,COUNTUNIQUE:Ed,COUNTUNIQUEIFS:xd,CSC:Id,CSCH:Rd,DECIMAL:Td,DEGREES:Ad,EXP:_d,FLOOR:Dd,FLOOR_MATH:Fd,FLOOR_PRECISE:Md,INT:hu,ISEVEN:Pd,ISODD:kd,ISO_CEILING:Nd,LN:Ld,MOD:Hd,MUNIT:Ud,ODD:Bd,PI:zd,POWER:$d,PRODUCT:Wd,RAND:Gd,RANDARRAY:qd,RANDBETWEEN:Zd,ROUND:jd,ROUNDDOWN:Yd,ROUNDUP:Xd,SEC:Kd,SECH:Jd,SEQUENCE:Qd,SIN:eu,SINH:tu,SQRT:ou,SUM:su,SUMIF:iu,SUMIFS:ru,TAN:nu,TANH:au,TRUNC:cu});function uu(e,t){const o=[],s=[];let i=0,r=0;Ji([e],(e=>{o.push(e),i+=1})),Ji([t],(e=>{s.push(e),r+=1})),Mi((()=>i===r),Oo("[[FUNCTION_NAME]] has mismatched argument count %s vs %s.",i,r));const n=[],a=[];for(let e=0;e<i;e++){const t=o[e]?.value,i=s[e]?.value;"number"==typeof t&&"number"==typeof i&&(a.push(t),n.push(i))}return{flatDataX:n,flatDataY:a}}function gu(e,t,o){const{flatDataX:s,flatDataY:i}=uu(e,t),r=i.length;Mi((()=>0!==r&&(!o||1!==r)),Oo("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error."),xi.DivisionByZero);let n=0,a=0;for(let e=0;e<r;e++)n+=i[e],a+=s[e];const l=n/r,c=a/r;let h=0;for(let e=0;e<r;e++)h+=(i[e]-l)*(s[e]-c);return h/(r-(o?1:0))}function pu(e,t,o,s){let i=0;const r=o?sr:or,n=r(e,((e,t)=>(i+=1,e+t)),0,s);Mi((()=>0!==i&&(!t||1!==i)),Oo("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error."),xi.DivisionByZero);const a=n/i;return r(e,((e,t)=>e+Math.pow(t-a,2)),0,s)/(i-(t?1:0))}function mu(e,t,o,s){const i=Li(t,s);Mi((()=>o?0<=i&&i<=1:0<i&&i<1),Oo("Function [[FUNCTION_NAME]] parameter 2 value is out of range."));let r,n=[],a=0;return Ji(e,(e=>{const t=e?.value;"number"==typeof t&&(r=ur(n,e,"nextSmaller","asc",n.length,((e,t)=>e[t])),n.splice(r+1,0,t),a++)})),Mi((()=>0!==a),Oo("[[FUNCTION_NAME]] has no valid input data.")),o||Mi((()=>1/(a+1)<=i&&i<=a/(a+1)),Oo("Function [[FUNCTION_NAME]] parameter 2 value is out of range.")),si(n,i,o)}const fu={description:Oo("Average magnitude of deviations from mean."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the sample.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the sample."))],compute:function(...e){let t=0;const o=or(e,((e,o)=>(t+=1,e+o)),0,this.locale);Wi(t);const s=o/t;return or(e,((e,t)=>e+Math.abs(s-t)),0,this.locale)/t},isExported:!0},vu={description:Oo("Numerical average value in a dataset, ignoring text."),args:[wh("value1 (number, range<number>)",Oo("The first value or range to consider when calculating the average value.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to consider when calculating the average value."))],compute:function(...e){return{value:Qa(e,this.locale),format:Pi(e[0])}},isExported:!0},bu=Oo("[[FUNCTION_NAME]] has mismatched range sizes."),Su=Oo("[[FUNCTION_NAME]] expects the weight to be positive or equal to 0."),yu={description:Oo("Weighted average."),args:[wh("values (number, range<number>)",Oo("Values to average.")),wh("weights (number, range<number>)",Oo("Weights for each corresponding value.")),wh("additional_values (number, range<number>, repeating)",Oo("Additional values to average.")),wh("additional_weights (number, range<number>, repeating)",Oo("Additional weights."))],compute:function(...e){let t=0,o=0;for(let s=0;s<e.length-1;s+=2){const i=e[s],r=e[s+1];if(Ih(bu,i,r),yi(i))for(let e=0;e<i.length;e++)for(let s=0;s<i[0].length;s++){const n=i[e][s].value,a=yi(r)?r?.[e][s].value:Li(r,this.locale),l="number"==typeof n,c="number"==typeof a;l&&c?(Mi((()=>a>=0),Su),t+=n*a,o+=a):Mi((()=>l===c),Oo("[[FUNCTION_NAME]] expects number values."))}else{const e=Li(i,this.locale),s=yi(r)?r?.[0][0].value:Li(r,this.locale);"number"==typeof s&&(Mi((()=>s>=0),Su),t+=e*s,o+=s)}}return Wi(o),{value:t/o,format:Pi(e[0])}}},Cu={description:Oo("Numerical average value in a dataset."),args:[wh("value1 (number, range<number>)",Oo("The first value or range to consider when calculating the average value.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to consider when calculating the average value."))],compute:function(...e){let t=0;const o=sr(e,((e,o)=>(t+=1,e+o)),0,this.locale);return Wi(t),{value:o/t,format:Pi(e[0])}},isExported:!0},wu={description:Oo("Average of values depending on criteria."),args:[wh("criteria_range (number, range<number>)",Oo("The range to check against criterion.")),wh("criterion (string)",Oo("The pattern or test to apply to criteria_range.")),wh("average_range (number, range<number>, default=criteria_range)",Oo("The range to average. If not included, criteria_range is used for the average instead."))],compute:function(e,t,o){const s=fr(void 0===o?e:o);let i=0,r=0;return dr([e,t],((e,t)=>{const o=s[e]?.[t]?.value;"number"==typeof o&&(i+=1,r+=o)}),this.locale),Wi(i),r/i},isExported:!0},Eu={description:Oo("Average of values depending on multiple criteria."),args:[wh("average_range (range)",Oo("The range to average.")),wh("criteria_range1 (range)",Oo("The range to check against criterion1.")),wh("criterion1 (string)",Oo("The pattern or test to apply to criteria_range1.")),wh("criteria_range2 (any, range, repeating)",Oo("Additional criteria_range and criterion to check.")),wh("criterion2 (string, repeating)",Oo("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){const o=fr(e);let s=0,i=0;return dr(t,((e,t)=>{const r=o[e]?.[t]?.value;"number"==typeof r&&(s+=1,i+=r)}),this.locale),Wi(s),i/s},isExported:!0},xu={description:Oo("The number of numeric values in dataset."),args:[wh("value1 (number, any, range<number>)",Oo("The first value or range to consider when counting.")),wh("value2 (number, any, range<number>, repeating)",Oo("Additional values or ranges to consider when counting."))],compute:function(...e){return el(e,this.locale)},isExported:!0},Iu={description:Oo("The number of values in a dataset."),args:[wh("value1 (any, range)",Oo("The first value or range to consider when counting.")),wh("value2 (any, range, repeating)",Oo("Additional values or ranges to consider when counting."))],compute:function(...e){return tl(e)},isExported:!0},Ru={description:Oo("The covariance of a dataset."),args:[wh("data_y (any, range)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (any, range)",Oo("The range representing the array or matrix of independent data."))],compute:function(e,t){return gu(e,t,!1)},isExported:!0},Tu={description:Oo("The covariance of a dataset."),args:[wh("data_y (any, range)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (any, range)",Oo("The range representing the array or matrix of independent data."))],compute:function(e,t){return gu(e,t,!1)},isExported:!0},Au={description:Oo("The sample covariance of a dataset."),args:[wh("data_y (any, range)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (any, range)",Oo("The range representing the array or matrix of independent data."))],compute:function(e,t){return gu(e,t,!0)},isExported:!0},_u={description:Oo("Calculates the expected y-value for a specified x based on a linear regression of a dataset."),args:[wh("x (number, range<number>)",Oo("The value(s) on the x-axis to forecast.")),wh("data_y (range<number>)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (range<number>)",Oo("The range representing the array or matrix of independent data."))],compute:function(e,t,o){const{flatDataX:s,flatDataY:i}=uu(t,o);return dl([i],[s],rr(fr(e),(e=>Li(e,this.locale))),!0)},isExported:!0},Du={description:Oo("Fits points to exponential growth trend."),args:[wh("known_data_y (range<number>)",Oo("The array or range containing dependent (y) values that are already known, used to curve fit an ideal exponential growth curve.")),wh("known_data_x (range<number>, default={1;2;3;...})",Oo("The values of the independent variable(s) corresponding with known_data_y.")),wh("new_data_x (any, range, default=known_data_x)",Oo("The data points to return the y values for on the ideal curve fit.")),wh("b (boolean, default=TRUE)",Oo("Given a general exponential form of y = b*m^x for a curve fit, calculates b if TRUE or forces b to be 1 and only calculates the m values if FALSE."))],compute:function(e,t=[[]],o=[[]],s={value:!0}){return cl(dl(hl(Hi(e,"the first argument (known_data_y)")),Hi(t,"the second argument (known_data_x)"),Hi(o,"the third argument (new_data_y)"),ji(s)))}},Ou={description:Oo("Compute the intercept of the linear regression."),args:[wh("data_y (range<number>)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (range<number>)",Oo("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=uu(e,t),[[],[i]]=rl([o],[s]);return i},isExported:!0},Fu={description:Oo("Nth largest element from a data set."),args:[wh("data (any, range)",Oo("Array or range containing the dataset to consider.")),wh("n (number)",Oo("The rank from largest to smallest of the element to return."))],compute:function(e,t){const o=Math.trunc(Li(t?.value,this.locale));let s,i=[],r=0;Ji([e],(e=>{"number"==typeof e?.value&&(s=ur(i,e,"nextSmaller","asc",i.length,((e,t)=>e[t].value)),i.splice(s+1,0,e),r++,r>o&&(i.shift(),r--))}));const n=i.shift();return Mi((()=>void 0!==n),Oo("[[FUNCTION_NAME]] has no valid input data.")),Mi((()=>r>=o),Oo("Function [[FUNCTION_NAME]] parameter 2 value (%s) is out of range.",o)),n},isExported:!0},Mu={description:Oo("Given partial data about a linear trend, calculates various parameters about the ideal linear trend using the least-squares method."),args:[wh("data_y (range<number>)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (range<number>, default={1;2;3;...})",Oo("The range representing the array or matrix of independent data.")),wh("calculate_b (boolean, default=TRUE)",Oo("A flag specifying wheter to compute the slope or not")),wh("verbose (boolean, default=FALSE)",Oo("A flag specifying whether to return additional regression statistics or only the linear coefficients and the y-intercept"))],compute:function(e,t=[[]],o={value:!0},s={value:!1}){return rl(Hi(t,"the first argument (data_y)"),Hi(e,"the second argument (data_x)"),ji(o),ji(s))},isExported:!0},Pu={description:Oo("Given partial data about an exponential growth curve, calculates various parameters about the best fit ideal exponential growth curve."),args:[wh("data_y (range<number>)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (range<number>, optional, default={1;2;3;...})",Oo("The range representing the array or matrix of independent data.")),wh("calculate_b (boolean, default=TRUE)",Oo("A flag specifying wheter to compute the slope or not")),wh("verbose (boolean, default=FALSE)",Oo("A flag specifying whether to return additional regression statistics or only the linear coefficients and the y-intercept"))],compute:function(e,t=[[]],o={value:!0},s={value:!1}){const i=rl(Hi(t,"the second argument (data_x)"),hl(Hi(e,"the first argument (data_y)")),ji(o),ji(s));for(let e=0;e<i.length;e++)i[e][0]=Math.exp(i[e][0]);return i},isExported:!0},Nu={description:Oo("Compute the Matthews correlation coefficient of a dataset."),args:[wh("data_x (range)",Oo("The range representing the array or matrix of observed data.")),wh("data_y (range)",Oo("The range representing the array or matrix of predicted data."))],compute:function(e,t){const o=e.flat(),s=t.flat();if(Ja(o,s),0===o.length)return new Ri(Oo("[[FUNCTION_NAME]] expects non-empty ranges for both parameters."));const i=o.length;let r=0,n=0,a=0,l=0;for(let e=0;e<i;++e){const t=ji(o[e]);t===ji(s[e])?t?n++:r++:t?l++:a++}return(n*r-a*l)/Math.sqrt((n+a)*(n+l)*(r+a)*(r+l))},isExported:!1},ku={description:Oo("Maximum value in a numeric dataset."),args:[wh("value1 (number, range<number>)",Oo("The first value or range to consider when calculating the maximum value.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to consider when calculating the maximum value."))],compute:function(...e){return ol(e,this.locale)},isExported:!0},Lu={description:Oo("Maximum numeric value in a dataset."),args:[wh("value1 (any, range)",Oo("The first value or range to consider when calculating the maximum value.")),wh("value2 (any, range, repeating)",Oo("Additional values or ranges to consider when calculating the maximum value."))],compute:function(...e){const t=sr(e,((e,t)=>Math.max(t,e)),-1/0,this.locale);return{value:t===-1/0?0:t,format:Pi(e[0])}},isExported:!0},Vu={description:Oo("Returns the maximum value in a range of cells, filtered by a set of criteria."),args:[wh("range (range)",Oo("The range of cells from which the maximum will be determined.")),wh("criteria_range1 (range)",Oo("The range of cells over which to evaluate criterion1.")),wh("criterion1 (string)",Oo("The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.")),wh("criteria_range2 (any, range, repeating)",Oo("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.")),wh("criterion2 (string, repeating)",Oo("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){let o=-1/0;return dr(t,((t,s)=>{const i=e[t]?.[s]?.value;"number"==typeof i&&(o=o<i?i:o)}),this.locale),o===-1/0?0:o},isExported:!0},Hu={description:Oo("Median value in a numeric dataset."),args:[wh("value1 (any, range)",Oo("The first value or range to consider when calculating the median value.")),wh("value2 (any, range, repeating)",Oo("Additional values or ranges to consider when calculating the median value."))],compute:function(...e){let t=[];return Qi(e,(e=>{t.push(e)}),this.locale),{value:mu(t,{value:.5},!0,this.locale),format:Pi(t[0])}},isExported:!0},Uu={description:Oo("Minimum value in a numeric dataset."),args:[wh("value1 (number, range<number>)",Oo("The first value or range to consider when calculating the minimum value.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to consider when calculating the minimum value."))],compute:function(...e){return sl(e,this.locale)},isExported:!0},Bu={description:Oo("Minimum numeric value in a dataset."),args:[wh("value1 (number, range<number>)",Oo("The first value or range to consider when calculating the minimum value.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to consider when calculating the minimum value."))],compute:function(...e){const t=sr(e,((e,t)=>Math.min(t,e)),1/0,this.locale);return{value:t===1/0?0:t,format:Pi(e[0])}},isExported:!0},zu={description:Oo("Returns the minimum value in a range of cells, filtered by a set of criteria."),args:[wh("range (range)",Oo("The range of cells from which the minimum will be determined.")),wh("criteria_range1 (range)",Oo("The range of cells over which to evaluate criterion1.")),wh("criterion1 (string)",Oo("The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.")),wh("criteria_range2 (any, range, repeating)",Oo("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.")),wh("criterion2 (string, repeating)",Oo("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){let o=1/0;return dr(t,((t,s)=>{const i=e[t]?.[s]?.value;"number"==typeof i&&(o=o>i?i:o)}),this.locale),o===1/0?0:o},isExported:!0};function $u(e,t){const{flatDataX:o,flatDataY:s}=uu(e,t);if(0===o.length)throw new Ri(Oo("[[FUNCTION_NAME]] expects non-empty ranges for both parameters."));if(o.length<2)throw new Ri(Oo("[[FUNCTION_NAME]] needs at least two values for both parameters."));const i=o.length;let r=0,n=0,a=0,l=0,c=0;for(let e=0;e<i;e++){const t=o[e],i=s[e];r+=t,n+=i,a+=t*i,l+=t*t,c+=i*i}return(i*a-r*n)/Math.sqrt((i*l-r*r)*(i*c-n*n))}const Wu={description:Oo("Compute the Pearson product-moment correlation coefficient of a dataset."),args:[wh("data_y (range<number>)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (range<number>)",Oo("The range representing the array or matrix of independent data."))],compute:function(e,t){return $u(e,t)},isExported:!0},Gu=Wu,qu={description:Oo("Value at a given percentile of a dataset."),args:[wh("data (any, range)",Oo("The array or range containing the dataset to consider.")),wh("percentile (number)",Oo("The percentile whose value within data will be calculated and returned."))],compute:function(e,t){return ju.compute.bind(this)(e,t)},isExported:!0},Zu={description:Oo("Value at a given percentile of a dataset exclusive of 0 and 1."),args:[wh("data (any, range)",Oo("The array or range containing the dataset to consider.")),wh("percentile (number)",Oo("The percentile, exclusive of 0 and 1, whose value within 'data' will be calculated and returned."))],compute:function(e,t){return{value:mu([e],t,!1,this.locale),format:Pi(e)}},isExported:!0},ju={description:Oo("Value at a given percentile of a dataset."),args:[wh("data (any, range)",Oo("The array or range containing the dataset to consider.")),wh("percentile (number)",Oo("The percentile whose value within data will be calculated and returned."))],compute:function(e,t){return{value:mu([e],t,!0,this.locale),format:Pi(e)}},isExported:!0},Yu={description:Oo("Compute the coefficients of polynomial regression of the dataset."),args:[wh("data_y (range<number>)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (range<number>)",Oo("The range representing the array or matrix of independent data.")),wh("order (number)",Oo("The order of the polynomial to fit the data, between 1 and 6.")),wh("intercept (boolean, default=TRUE)",Oo("A flag specifying whether to compute the intercept or not."))],compute:function(e,t,o,s={value:!0}){const{flatDataX:i,flatDataY:r}=uu(e,t);return nl(r,i,Li(o,this.locale),ji(s))},isExported:!1},Xu={description:Oo("Predict value by computing a polynomial regression of the dataset."),args:[wh("x (number, range<number>)",Oo("The value(s) on the x-axis to forecast.")),wh("data_y (range<number>)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (range<number>)",Oo("The range representing the array or matrix of independent data.")),wh("order (number)",Oo("The order of the polynomial to fit the data, between 1 and 6.")),wh("intercept (boolean, default=TRUE)",Oo("A flag specifying whether to compute the intercept or not."))],compute:function(e,t,o,s,i={value:!0}){const r=Li(s,this.locale),{flatDataX:n,flatDataY:a}=uu(t,o),l=nl(a,n,r,ji(i)).flat();return rr(fr(e),(e=>ll(l,Li(e,this.locale),r)))},isExported:!1},Ku={description:Oo("Value nearest to a specific quartile of a dataset."),args:[wh("data (any, range)",Oo("The array or range containing the dataset to consider.")),wh("quartile_number (number)",Oo("Which quartile value to return."))],compute:function(e,t){return Qu.compute.bind(this)(e,t)},isExported:!0},Ju={description:Oo("Value nearest to a specific quartile of a dataset exclusive of 0 and 4."),args:[wh("data (any, range)",Oo("The array or range containing the dataset to consider.")),wh("quartile_number (number)",Oo("Which quartile value, exclusive of 0 and 4, to return."))],compute:function(e,t){return{value:mu([e],{value:.25*Math.trunc(Li(t,this.locale))},!1,this.locale),format:Pi(e)}},isExported:!0},Qu={description:Oo("Value nearest to a specific quartile of a dataset."),args:[wh("data (any, range)",Oo("The array or range containing the dataset to consider.")),wh("quartile_number (number)",Oo("Which quartile value to return."))],compute:function(e,t){return{value:mu([e],{value:.25*Math.trunc(Li(t,this.locale))},!0,this.locale),format:Pi(e)}},isExported:!0},eg={description:Oo("Returns the rank of a specified value in a dataset."),args:[wh("value (number)",Oo("The value whose rank will be determined.")),wh("data (range)",Oo("The range containing the dataset to consider.")),wh("is_ascending (boolean, default=FALSE)",Oo("Whether to consider the values in data in descending or ascending order."))],compute:function(e,t,o={value:!1}){const s=ji(o),i=Li(e,this.locale);let r=1,n=!1;for(const e of t)for(const t of e){if("number"!=typeof t.value)continue;const e=Li(t,this.locale);e===i?n=!0:e>i!==s&&r++}if(!n)throw new _i(Oo("Value not found in the given data."));return r},isExported:!0},tg={description:Oo("Compute the square of r, the Pearson product-moment correlation coefficient of a dataset."),args:[wh("data_y (range<number>)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (range<number>)",Oo("The range representing the array or matrix of independent data."))],compute:function(e,t){return Math.pow($u(t,e),2)},isExported:!0},og={description:Oo("Compute the slope of the linear regression."),args:[wh("data_y (range<number>)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (range<number>)",Oo("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=uu(e,t),[[i]]=rl([o],[s]);return i},isExported:!0},sg={description:Oo("Nth smallest element in a data set."),args:[wh("data (any, range)",Oo("The array or range containing the dataset to consider.")),wh("n (number)",Oo("The rank from smallest to largest of the element to return."))],compute:function(e,t){const o=Math.trunc(Li(t?.value,this.locale));let s,i=[],r=0;Ji([e],(e=>{"number"==typeof e?.value&&(s=ur(i,e,"nextSmaller","asc",i.length,((e,t)=>e[t].value)),i.splice(s+1,0,e),r++,r>o&&(i.pop(),r--))}));const n=i.pop();return Mi((()=>void 0!==n),Oo("[[FUNCTION_NAME]] has no valid input data.")),Mi((()=>r>=o),Oo("Function [[FUNCTION_NAME]] parameter 2 value (%s) is out of range.",o)),n},isExported:!0},ig={description:Oo("Compute the Spearman rank correlation coefficient of a dataset."),args:[wh("data_y (range<number>)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (range<number>)",Oo("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=uu(t,e),i=o.length,r=o.map(((e,t)=>[e,s[t]]));r.sort(((e,t)=>e[0]-t[0]));for(let e=0;e<i;++e)r[e][0]=e;r.sort(((e,t)=>e[1]-t[1]));let n=0;for(let e=0;e<i;++e)n+=(r[e][0]-e)**2;return 1-6*n/(i**3-i)},isExported:!1},rg={description:Oo("Standard deviation."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the sample.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the sample."))],compute:function(...e){return Math.sqrt(gg.compute.bind(this)(...e))},isExported:!0},ng={description:Oo("Standard deviation of entire population."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the population.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the population."))],compute:function(...e){return Math.sqrt(pg.compute.bind(this)(...e))},isExported:!0},ag={description:Oo("Standard deviation."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the sample.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the sample."))],compute:function(...e){return Math.sqrt(mg.compute.bind(this)(...e))},isExported:!0},lg={description:Oo("Standard deviation of sample (text as 0)."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the sample.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the sample."))],compute:function(...e){return Math.sqrt(fg.compute.bind(this)(...e))},isExported:!0},cg={description:Oo("Standard deviation of entire population."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the population.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the population."))],compute:function(...e){return Math.sqrt(vg.compute.bind(this)(...e))},isExported:!0},hg={description:Oo("Standard deviation of entire population (text as 0)."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the population.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the population."))],compute:function(...e){return Math.sqrt(bg.compute.bind(this)(...e))},isExported:!0},dg={description:Oo("Calculates the standard error of the predicted y-value for each x in the regression of a dataset."),args:[wh("data_y (range<number>)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (range<number>)",Oo("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=uu(e,t);return rl([o],[s],!0,!0)[1][2]},isExported:!0},ug={description:Oo("Fits points to linear trend derived via least-squares."),args:[wh("known_data_y (number, range<number>)",Oo("The array or range containing dependent (y) values that are already known, used to curve fit an ideal linear trend.")),wh("known_data_x (number, range<number>, optional, default={1;2;3;...})",Oo("The values of the independent variable(s) corresponding with known_data_y.")),wh("new_data_x (number, range<number>, optional, default=known_data_x)",Oo("The data points to return the y values for on the ideal curve fit.")),wh("b (boolean, optional, default=TRUE)",Oo("Given a general linear form of y = m*x+b for a curve fit, calculates b if TRUE or forces b to be 0 and only calculates the m values if FALSE, i.e. forces the curve fit to pass through the origin."))],compute:function(e,t=[[]],o=[[]],s={value:!0}){return dl(Hi(e,"the first argument (known_data_y)"),Hi(t,"the second argument (known_data_x)"),Hi(o,"the third argument (new_data_y)"),ji(s))}},gg={description:Oo("Variance."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the sample.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the sample."))],compute:function(...e){return pu(e,!0,!1,this.locale)},isExported:!0},pg={description:Oo("Variance of entire population."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the population.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the population."))],compute:function(...e){return pu(e,!1,!1,this.locale)},isExported:!0},mg={description:Oo("Variance."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the sample.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the sample."))],compute:function(...e){return pu(e,!0,!1,this.locale)},isExported:!0},fg={description:Oo("Variance of sample (text as 0)."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the sample.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the sample."))],compute:function(...e){return pu(e,!0,!0,this.locale)},isExported:!0},vg={description:Oo("Variance of entire population."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the population.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the population."))],compute:function(...e){return pu(e,!1,!1,this.locale)},isExported:!0},bg={description:Oo("Variance of entire population (text as 0)."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the population.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the population."))],compute:function(...e){return pu(e,!1,!0,this.locale)},isExported:!0};var Sg=Object.freeze({__proto__:null,AVEDEV:fu,AVERAGE:vu,AVERAGEA:Cu,AVERAGEIF:wu,AVERAGEIFS:Eu,AVERAGE_WEIGHTED:yu,CORREL:Gu,COUNT:xu,COUNTA:Iu,COVAR:Ru,COVARIANCE_P:Tu,COVARIANCE_S:Au,FORECAST:_u,GROWTH:Du,INTERCEPT:Ou,LARGE:Fu,LINEST:Mu,LOGEST:Pu,MATTHEWS:Nu,MAX:ku,MAXA:Lu,MAXIFS:Vu,MEDIAN:Hu,MIN:Uu,MINA:Bu,MINIFS:zu,PEARSON:Wu,PERCENTILE:qu,PERCENTILE_EXC:Zu,PERCENTILE_INC:ju,POLYFIT_COEFFS:Yu,POLYFIT_FORECAST:Xu,QUARTILE:Ku,QUARTILE_EXC:Ju,QUARTILE_INC:Qu,RANK:eg,RSQ:tg,SLOPE:og,SMALL:sg,SPEARMAN:ig,STDEV:rg,STDEVA:lg,STDEVP:cg,STDEVPA:hg,STDEV_P:ng,STDEV_S:ag,STEYX:dg,TREND:ug,VAR:gg,VARA:fg,VARP:vg,VARPA:bg,VAR_P:pg,VAR_S:mg});function yg(e,t,o,s){const i=new Map,r=e.length;for(let t=r-1;t>=0;t--)i.set(Gi(e[t][0]).toUpperCase(),t);const n=t?.value;if("number"!=typeof n&&"string"!=typeof n)throw new Ri(Oo("The field must be a number or a string"));let a;if("number"==typeof n){if(a=Math.trunc(n)-1,a<0||r-1<a)throw new Ri(Oo("The field (%(fieldValue)s) must be one of %(dimRowDB)s or must be a number between 1 and %s inclusive.",{fieldValue:n.toString(),dimRowDB:r.toString()}))}else{const e=Gi(t).toUpperCase();if(a=i.get(e)??-1,-1===a)throw new Ri(Oo("The field (%s) must be one of %s.",Gi(t),[...i.keys()].toString()))}const l=o[0].length;if(l<2)throw new Ri(Oo("The criteria range contains %s row, it must be at least 2 rows.",l.toString()));let c=new Set;const h=e[0].length;for(let t=1;t<l;t++){let r=[],n=!0;for(let s=0;s<o.length;s++){const a=Gi(o[s][0]).toUpperCase(),l=i.get(a),c=o[s][t];if(null!==c.value){if(void 0===l){n=!1;break}r.push([e[l].slice(1,h)]),r.push(c)}}if(n){if(!(r.length>0)){c=new Set(Array(h-1).keys());break}dr(r,((e,t)=>{c.add(t)}),s,!0)}}const d=e[a];return[...c].map((e=>d[e+1]))}const Cg=[wh("database (range)",Oo("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.")),wh("field (number, string)",Oo("Indicates which column in database contains the values to be extracted and operated on.")),wh("criteria (range)",Oo("An array or range containing zero or more criteria to filter the database values by before operating."))],wg={description:Oo("Average of a set of values from a table-like range."),args:Cg,compute:function(e,t,o){const s=yg(e,t,o,this.locale);return vu.compute.bind(this)([s])},isExported:!0},Eg={description:Oo("Counts values from a table-like range."),args:Cg,compute:function(e,t,o){const s=yg(e,t,o,this.locale);return xu.compute.bind(this)([s])},isExported:!0},xg={description:Oo("Counts values and text from a table-like range."),args:Cg,compute:function(e,t,o){const s=yg(e,t,o,this.locale);return Iu.compute.bind(this)([s])},isExported:!0},Ig={description:Oo("Single value from a table-like range."),args:Cg,compute:function(e,t,o){const s=yg(e,t,o,this.locale);return Mi((()=>1===s.length),Oo("More than one match found in DGET evaluation.")),s[0]},isExported:!0},Rg={description:Oo("Maximum of values from a table-like range."),args:Cg,compute:function(e,t,o){const s=yg(e,t,o,this.locale);return ku.compute.bind(this)([s])},isExported:!0},Tg={description:Oo("Minimum of values from a table-like range."),args:Cg,compute:function(e,t,o){const s=yg(e,t,o,this.locale);return Uu.compute.bind(this)([s])},isExported:!0},Ag={description:Oo("Product of values from a table-like range."),args:Cg,compute:function(e,t,o){const s=yg(e,t,o,this.locale);return Wd.compute.bind(this)([s])},isExported:!0},_g={description:Oo("Standard deviation of population sample from table."),args:Cg,compute:function(e,t,o){const s=yg(e,t,o,this.locale);return rg.compute.bind(this)([s])},isExported:!0},Dg={description:Oo("Standard deviation of entire population from table."),args:Cg,compute:function(e,t,o){const s=yg(e,t,o,this.locale);return cg.compute.bind(this)([s])},isExported:!0},Og={description:Oo("Sum of values from a table-like range."),args:Cg,compute:function(e,t,o){const s=yg(e,t,o,this.locale);return su.compute.bind(this)([s])},isExported:!0},Fg={description:Oo("Variance of population sample from table-like range."),args:Cg,compute:function(e,t,o){const s=yg(e,t,o,this.locale);return gg.compute.bind(this)([s])},isExported:!0},Mg={description:Oo("Variance of a population from a table-like range."),args:Cg,compute:function(e,t,o){const s=yg(e,t,o,this.locale);return vg.compute.bind(this)([s])},isExported:!0};var Pg=Object.freeze({__proto__:null,DAVERAGE:wg,DCOUNT:Eg,DCOUNTA:xg,DGET:Ig,DMAX:Rg,DMIN:Tg,DPRODUCT:Ag,DSTDEV:_g,DSTDEVP:Dg,DSUM:Og,DVAR:Fg,DVARP:Mg});var Ng;!function(e){e.WHOLE_YEARS="Y",e.WHOLE_MONTHS="M",e.WHOLE_DAYS="D",e.DAYS_WITHOUT_WHOLE_MONTHS="MD",e.MONTH_WITHOUT_WHOLE_YEARS="YM",e.DAYS_BETWEEN_NO_MORE_THAN_ONE_YEAR="YD"}(Ng||(Ng={}));const kg={description:Oo("Converts year/month/day into a date."),args:[wh("year (number)",Oo("The year component of the date.")),wh("month (number)",Oo("The month component of the date.")),wh("day (number)",Oo("The day component of the date."))],compute:function(e,t,o){let s=Math.trunc(Li(e,this.locale));const i=Math.trunc(Li(t,this.locale)),r=Math.trunc(Li(o,this.locale));Mi((()=>0<=s&&s<=9999),Oo("The year (%s) must be between 0 and 9999 inclusive.",s.toString())),s<1900&&(s+=1900);const n=Bs(new xs(s,i-1,r));return Mi((()=>n>=0),Oo("The function [[FUNCTION_NAME]] result must be greater than or equal 01/01/1900.")),{value:n,format:this.locale.dateFormat}},isExported:!0},Lg={description:Oo("Calculates the number of days, months, or years between two dates."),args:[wh("start_date (date)",Oo("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.")),wh("end_date (date)",Oo("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.")),wh("unit (string)",Oo('A text abbreviation for unit of time. Accepted values are "Y" (the number of whole years between start_date and end_date), "M" (the number of whole months between start_date and end_date), "D" (the number of days between start_date and end_date), "MD" (the number of days between start_date and end_date after subtracting whole months), "YM" (the number of whole months between start_date and end_date after subtracting whole years), "YD" (the number of days between start_date and end_date, assuming start_date and end_date were no more than one year apart).'))],compute:function(e,t,o){const s=Gi(o).toUpperCase();Mi((()=>Object.values(Ng).includes(s)),((e,t)=>{const o=e.map((e=>`'${e}'`)).join(", ");return Oo("The function [[FUNCTION_NAME]] has an argument with value '%s'. It should be one of: %s.",t,o)})(Object.values(Ng),Gi(o)));const i=Math.trunc(Li(e,this.locale)),r=Math.trunc(Li(t,this.locale)),n=Us(i),a=Us(r);switch(Mi((()=>r>=i),Oo("start_date (%s) should be on or before end_date (%s).",n.toLocaleDateString(),a.toLocaleDateString())),s){case Ng.WHOLE_YEARS:return Xs(n,a);case Ng.WHOLE_MONTHS:return js(n,a);case Ng.WHOLE_DAYS:return Ys(n,a);case Ng.MONTH_WITHOUT_WHOLE_YEARS:return js(n,a)-12*Xs(n,a);case Ng.DAYS_WITHOUT_WHOLE_MONTHS:let e=a.getDate()-n.getDate();if(e<0){e=$s(new xs(a.getFullYear(),a.getMonth()-1,1))-Math.abs(e)}return e;case Ng.DAYS_BETWEEN_NO_MORE_THAN_ONE_YEAR:{if(function(e,t){return Zs(e,t,1)<1}(i,r))return Ys(n,a);const e=new xs(n.getFullYear(),a.getMonth(),a.getDate());let t=Ys(n,e);return t<0&&(e.setFullYear(n.getFullYear()+1),t=Ys(n,e)),t}}},isExported:!0},Vg={description:Oo("Converts a date string to a date value."),args:[wh("date_string (string)",Oo("The string representing the date."))],compute:function(e){const t=Gi(e),o=Hs(t,this.locale);return Mi((()=>null!==o),Oo("The date_string (%s) cannot be parsed to date/time.",t.toString())),Math.trunc(o.value)},isExported:!0},Hg={description:Oo("Day of the month that a specific date falls on."),args:[wh("date (string)",Oo("The date from which to extract the day."))],compute:function(e){return Yi(e,this.locale).getDate()},isExported:!0},Ug={description:Oo("Number of days between two dates."),args:[wh("end_date (date)",Oo("The end of the date range.")),wh("start_date (date)",Oo("The start of the date range."))],compute:function(e,t){const o=Yi(e,this.locale),s=Yi(t,this.locale),i=o.getTime()-s.getTime();return Math.round(i/Rs)},isExported:!0},Bg={description:Oo("Number of days between two dates on a 360-day year (months of 30 days)."),args:[wh("start_date (date)",Oo("The start date to consider in the calculation.")),wh("end_date (date)",Oo("The end date to consider in the calculation.")),wh("method (number, default=0)",Oo("An indicator of what day count method to use. (0) US NASD method (1) European method"))],compute:function(e,t,o={value:0}){const s=Math.trunc(Li(e,this.locale)),i=Math.trunc(Li(t,this.locale)),r=Zs(s,i,ji(o)?4:0);return Math.sign(i-s)*Math.round(360*r)},isExported:!0},zg={description:Oo("Date a number of months before/after another date."),args:[wh("start_date (date)",Oo("The date from which to calculate the result.")),wh("months (number)",Oo("The number of months before (negative) or after (positive) 'start_date' to calculate."))],compute:function(e,t){return{value:Bs(Gs(Yi(e,this.locale),Math.trunc(Li(t,this.locale)),!1)),format:this.locale.dateFormat}},isExported:!0},$g={description:Oo("Last day of a month before or after a date."),args:[wh("start_date (date)",Oo("The date from which to calculate the result.")),wh("months (number)",Oo("The number of months before (negative) or after (positive) 'start_date' to consider."))],compute:function(e,t){const o=Yi(e,this.locale),s=Math.trunc(Li(t,this.locale)),i=o.getFullYear(),r=o.getMonth();return{value:Bs(new xs(i,r+s+1,0)),format:this.locale.dateFormat}},isExported:!0},Wg={description:Oo("Hour component of a specific time."),args:[wh("time (date)",Oo("The time from which to calculate the hour component."))],compute:function(e){return Yi(e,this.locale).getHours()},isExported:!0},Gg={description:Oo("ISO week number of the year."),args:[wh("date (date)",Oo("The date for which to determine the ISO week number. Must be a reference to a cell containing a date, a function returning a date type, or a number."))],compute:function(e){const t=Yi(e,this.locale),o=t.getFullYear();let s=1;for(;4!==new xs(o,0,s).getDay();)s+=1;const i=new xs(o,0,s-3);let r=31;for(;4!==new xs(o,11,r).getDay();)r-=1;const n=new xs(o,11,r+3);let a,l;switch(a=i.getTime()<=t.getTime()?t.getTime()<=n.getTime()?0:1:-1,a){case 0:l=i;break;case 1:l=new xs(o,11,r+3+1);break;case-1:let e=1;for(;4!==new xs(o-1,0,e).getDay();)e+=1;l=new xs(o-1,0,e-3)}const c=(t.getTime()-l.getTime())/Rs;return Math.floor(c/7)+1},isExported:!0},qg={description:Oo("Minute component of a specific time."),args:[wh("time (date)",Oo("The time from which to calculate the minute component."))],compute:function(e){return Yi(e,this.locale).getMinutes()},isExported:!0},Zg={description:Oo("Month of the year a specific date falls in"),args:[wh("date (date)",Oo("The date from which to extract the month."))],compute:function(e){return Yi(e,this.locale).getMonth()+1},isExported:!0},jg={description:Oo("Net working days between two provided days."),args:[wh("start_date (date)",Oo("The start date of the period from which to calculate the number of net working days.")),wh("end_date (date)",Oo("The end date of the period from which to calculate the number of net working days.")),wh("holidays (date, range<date>, optional)",Oo("A range or array constant containing the date serial numbers to consider holidays."))],compute:function(e,t,o){return Xg.compute.bind(this)(e,t,{value:1},o)},isExported:!0};function Yg(e){const t=e?.value;if("string"==typeof t){Mi((()=>{if(7!==t.length)return!1;for(let e of t)if("0"!==e&&"1"!==e)return!1;return!0}),Oo('When weekend is a string (%s) it must be composed of "0" or "1".',t));let e=[];for(let o=0;o<7;o++)"1"===t[o]&&e.push((o+1)%7);return e}if("number"==typeof t)return Mi((()=>1<=t&&t<=7||11<=t&&t<=17),Oo("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 Ri(Oo("The weekend must be a number or a string."))}const Xg={description:Oo("Net working days between two dates (specifying weekends)."),args:[wh("start_date (date)",Oo("The start date of the period from which to calculate the number of net working days.")),wh("end_date (date)",Oo("The end date of the period from which to calculate the number of net working days.")),wh("weekend (any, default=1)",Oo("A number or string representing which days of the week are considered weekends.")),wh("holidays (date, range<date>, optional)",Oo("A range or array constant containing the dates to consider as holidays."))],compute:function(e,t,o={value:1},s){const i=Yi(e,this.locale),r=Yi(t,this.locale),n=Yg(o);let a=new Set;void 0!==s&&Ji([s],(e=>{const t=Yi(e,this.locale);a.add(t.getTime())}));const l=i.getTime()>r.getTime(),c=xs.fromTimestamp((l?i:r).getTime());let h=xs.fromTimestamp((l?r:i).getTime());const d=c.getTime();let u=h.getTime(),g=0;for(;u<=d;)n.includes(h.getDay())||a.has(u)||(g+=1),h.setDate(h.getDate()+1),u=h.getTime();return l?-g:g},isExported:!0},Kg={description:Oo("Current date and time as a date value."),args:[],compute:function(){const e=xs.now(),t=e.getTime()-Is.getTime(),o=e.getHours()/24+e.getMinutes()/1440+e.getSeconds()/86400;return{value:Math.floor(t/Rs)+o,format:Ba(this.locale)}},isExported:!0},Jg={description:Oo("Minute component of a specific time."),args:[wh("time (date)",Oo("The time from which to calculate the second component."))],compute:function(e){return Yi(e,this.locale).getSeconds()},isExported:!0},Qg={description:Oo("Converts hour/minute/second into a time."),args:[wh("hour (number)",Oo("The hour component of the time.")),wh("minute (number)",Oo("The minute component of the time.")),wh("second (number)",Oo("The second component of the time."))],compute:function(e,t,o){let s=Math.trunc(Li(e,this.locale)),i=Math.trunc(Li(t,this.locale)),r=Math.trunc(Li(o,this.locale));return i+=Math.floor(r/60),r=r%60+(r<0?60:0),s+=Math.floor(i/60),i=i%60+(i<0?60:0),s%=24,Mi((()=>s>=0),Oo("The function [[FUNCTION_NAME]] result cannot be negative")),{value:s/24+i/1440+r/86400,format:this.locale.timeFormat}},isExported:!0},ep={description:Oo("Converts a time string into its serial number representation."),args:[wh("time_string (string)",Oo("The string that holds the time representation."))],compute:function(e){const t=Gi(e),o=Hs(t,this.locale);Mi((()=>null!==o),Oo("The time_string (%s) cannot be parsed to date/time.",t));const s=o.value-Math.trunc(o.value);return s<0?1+s:s},isExported:!0},tp={description:Oo("Current date as a date value."),args:[],compute:function(){const e=xs.now();return{value:Bs(new xs(e.getFullYear(),e.getMonth(),e.getDate())),format:this.locale.dateFormat}},isExported:!0},op={description:Oo("Day of the week of the date provided (as number)."),args:[wh("date (date)",Oo("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.")),wh("type (number, default=1)",Oo("A number indicating which numbering system to use to represent weekdays. By default, counts starting with Sunday = 1."))],compute:function(e,t={value:1}){const o=Yi(e,this.locale),s=Math.round(Li(t,this.locale)),i=o.getDay();return Mi((()=>[1,2,3].includes(s)),Oo("The type (%s) must be 1, 2 or 3.",s.toString())),1===s?i+1:2===s?0===i?7:i:0===i?6:i-1},isExported:!0},sp={description:Oo("Week number of the year."),args:[wh("date (date)",Oo("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.")),wh("type (number, default=1)",Oo("A number representing the day that a week starts on. Sunday = 1."))],compute:function(e,t={value:1}){const o=Yi(e,this.locale),s=Math.round(Li(t,this.locale));if(Mi((()=>1===s||2===s||11<=s&&s<=17||21===s),Oo("The type (%s) is out of range.",s.toString())),21===s)return Gg.compute.bind(this)(e);let i;i=1===s||2===s?s-1:s-10==7?0:s-10;const r=o.getFullYear();let n=1,a=new xs(r,0,n);for(;a.getDay()!==i;)n+=1,a=new xs(r,0,n);const l=(o.getTime()-a.getTime())/Rs;return l<0?1:Math.floor(l/7)+(1===n?1:2)},isExported:!0},ip={description:Oo("Date after a number of workdays."),args:[wh("start_date (date)",Oo("The date from which to begin counting.")),wh("num_days (number)",Oo("The number of working days to advance from start_date. If negative, counts backwards.")),wh("holidays (date, range<date>, optional)",Oo("A range or array constant containing the dates to consider holidays."))],compute:function(e,t,o={value:null}){return rp.compute.bind(this)(e,t,{value:1},o)},isExported:!0},rp={description:Oo("Date after a number of workdays (specifying weekends)."),args:[wh("start_date (date)",Oo("The date from which to begin counting.")),wh("num_days (number)",Oo("The number of working days to advance from start_date. If negative, counts backwards.")),wh("weekend (any, default=1)",Oo("A number or string representing which days of the week are considered weekends.")),wh("holidays (date, range<date>, optional)",Oo("A range or array constant containing the dates to consider holidays."))],compute:function(e,t,o={value:1},s){let i=Yi(e,this.locale),r=Math.trunc(Li(t,this.locale));"string"==typeof o.value&&Mi((()=>"1111111"!==o.value),Oo("The weekend must be different from '1111111'."));const n=Yg(o);let a=new Set;void 0!==s&&Ji([s],(e=>{const t=Yi(e,this.locale);a.add(t.getTime())}));let l=xs.fromTimestamp(i.getTime()),c=l.getTime();const h=Math.sign(r);let d=Math.abs(r);for(;d>0;)l.setDate(l.getDate()+h),c=l.getTime(),n.includes(l.getDay())||a.has(c)||(d-=1);const u=c-Is.getTime();return{value:Math.round(u/Rs),format:this.locale.dateFormat}},isExported:!0},np={description:Oo("Year specified by a given date."),args:[wh("date (date)",Oo("The date from which to extract the year."))],compute:function(e){return Yi(e,this.locale).getFullYear()},isExported:!0},ap={description:Oo("Exact number of years between two dates."),args:[wh("start_date (date)",Oo("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.")),wh("end_date (date)",Oo("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.")),wh("day_count_convention (number, default=0)",Oo("An indicator of what day count method to use."))],compute:function(e,t,o={value:0}){let s=Math.trunc(Li(e,this.locale)),i=Math.trunc(Li(t,this.locale));const r=Math.trunc(Li(o,this.locale));return Mi((()=>s>=0),Oo("The start_date (%s) must be positive or null.",s.toString())),Mi((()=>i>=0),Oo("The end_date (%s) must be positive or null.",i.toString())),Mi((()=>0<=r&&r<=4),Oo("The day_count_convention (%s) must be between 0 and 4 inclusive.",r.toString())),Zs(s,i,r)}},lp={description:Oo("First day of the month preceding a date."),args:[wh("date (date)",Oo("The date from which to calculate the result."))],compute:function(e){const t=Yi(e,this.locale),o=t.getFullYear(),s=t.getMonth();return{value:Bs(new xs(o,s,1)),format:this.locale.dateFormat}}},cp={description:Oo("Last day of the month following a date."),args:[wh("date (date)",Oo("The date from which to calculate the result."))],compute:function(e){return $g.compute.bind(this)(e,{value:0})}},hp={description:Oo("Quarter of the year a specific date falls in"),args:[wh("date (date)",Oo("The date from which to extract the quarter."))],compute:function(e){return Math.ceil((Yi(e,this.locale).getMonth()+1)/3)}},dp={description:Oo("First day of the quarter of the year a specific date falls in."),args:[wh("date (date)",Oo("The date from which to calculate the start of quarter."))],compute:function(e){const t=hp.compute.bind(this)(e),o=np.compute.bind(this)(e);return{value:Bs(new xs(o,3*(t-1),1)),format:this.locale.dateFormat}}},up={description:Oo("Last day of the quarter of the year a specific date falls in."),args:[wh("date (date)",Oo("The date from which to calculate the end of quarter."))],compute:function(e){const t=hp.compute.bind(this)(e),o=np.compute.bind(this)(e);return{value:Bs(new xs(o,3*t,0)),format:this.locale.dateFormat}}},gp={description:Oo("First day of the year a specific date falls in."),args:[wh("date (date)",Oo("The date from which to calculate the start of the year."))],compute:function(e){const t=np.compute.bind(this)(e);return{value:Bs(new xs(t,0,1)),format:this.locale.dateFormat}}},pp={description:Oo("Last day of the year a specific date falls in."),args:[wh("date (date)",Oo("The date from which to calculate the end of the year."))],compute:function(e){const t=np.compute.bind(this)(e);return{value:Bs(new xs(t+1,0,0)),format:this.locale.dateFormat}}};var mp=Object.freeze({__proto__:null,DATE:kg,DATEDIF:Lg,DATEVALUE:Vg,DAY:Hg,DAYS:Ug,DAYS360:Bg,EDATE:zg,EOMONTH:$g,HOUR:Wg,ISOWEEKNUM:Gg,MINUTE:qg,MONTH:Zg,MONTH_END:cp,MONTH_START:lp,NETWORKDAYS:jg,NETWORKDAYS_INTL:Xg,NOW:Kg,QUARTER:hp,QUARTER_END:up,QUARTER_START:dp,SECOND:Jg,TIME:Qg,TIMEVALUE:ep,TODAY:tp,WEEKDAY:op,WEEKNUM:sp,WORKDAY:ip,WORKDAY_INTL:rp,YEAR:np,YEARFRAC:ap,YEAR_END:pp,YEAR_START:gp});const fp={description:Oo("Compare two numeric values, returning 1 if they're equal."),args:[wh("number1 (number)",Oo("The first number to compare.")),wh("number2 (number, default=0)",Oo("The second number to compare."))],compute:function(e,t={value:0}){return Li(e,this.locale)===Li(t,this.locale)?1:0},isExported:!0};var vp=Object.freeze({__proto__:null,DELTA:fp});const bp=[ii.number,ii.error,ii.text,ii.boolean];function Sp(e){const t="asc"===e?1:-1;return(e,o)=>{if(e.type===ii.empty)return o.type===ii.empty?0:1;if(o.type===ii.empty)return-1;let s=bp.indexOf(e.type)-bp.indexOf(o.type);return 0===s&&(s=e.type===ii.text||e.type===ii.error?e.value.localeCompare(o.value):e.value-o.value),t*s}}function yp(e,t,o,s,i){let r=s.right>s.left;if(e.model.getters.doesIntersectMerge(t,s)){let o;r=!1;for(let i=s.top;i<=s.bottom;i++){o=[];for(let r=s.left;r<=s.right;r++){let s=e.model.getters.getMerge({sheetId:t,col:r,row:i});s&&!o.includes(s.id.toString())&&o.push(s.id.toString())}if(o.length>=2){r=!0;break}}}if(r)return void Cp(e,t,o,s,i);const n=e.model.getters.getContiguousZone(t,s);is(n,s)?Cp(e,t,o,s,i):e.askConfirmation(Oo("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?"),(()=>Cp(e,t,o,n,i)),(()=>Cp(e,t,o,s,i)))}function Cp(e,t,o,s,i,r){const n=e.model.dispatch("SORT_CELLS",{sheetId:t,col:o.col,row:o.row,zone:s,sortDirection:i,sortOptions:r});if(n.isCancelledBecause("InvalidSortZone")){const{col:t,row:i}=o;e.model.selection.selectZone({cell:{col:t,row:i},zone:s}),e.raiseError(Oo("Cannot sort. To sort, select only cells or only merges that have the same size."))}if(n.isCancelledBecause("SortZoneWithArrayFormulas")){const{col:t,row:i}=o;e.model.selection.selectZone({cell:{col:t,row:i},zone:s}),e.raiseError(Oo("Cannot sort a zone with array formulas."))}}function wp(e,t,...o){for(const[e,t]of o.entries())Mi((()=>void 0!==t),Oo("Value for parameter %d is missing, while the function [[FUNCTION_NAME]] expect a number or a range.",e+1));const s=[],i=[],r=e.length;for(let n=0;n<o.length;n+=2){s.push(ji(Ka(o[n+1])?.value)?"asc":"desc");const a=o[n];if(yi(a)&&(a.length>1||a[0].length>1))Mi((()=>1===a.length&&a[0].length===r),Oo("Wrong size for %s. Expected a range of size 1x%s. Got %sx%s.",`sort_column${n+1}`,r,a.length,a[0].length)),i.push(a.flat().map((e=>e.value)));else{const o=Li(Ka(a)?.value,t);if(o<1||o>e[0].length)return e;i.push(e.map((e=>e[o-1].value)))}}if(0===i.length)for(let t=0;t<e[0].length;t++)i.push(e.map((e=>e[t].value))),s.push("asc");const n={desc:Sp("desc"),asc:Sp("asc")},a=Ze(0,e.length);return a.sort(((e,t)=>{for(const[o,r]of i.entries()){const i=r[e],a=r[t],l={value:i,type:null===i?ii.empty:"string"==typeof i?ii.text:typeof i},c={value:a,type:null===a?ii.empty:"string"==typeof a?ii.text:typeof a},h=n[s[o]](l,c);if(0!==h)return h}return 0})),a.map((t=>e[t]))}const Ep={description:Oo("Returns a filtered version of the source range, returning only rows or columns that meet the specified conditions."),args:[wh("range (any, range<any>)",Oo("The data to be filtered.")),wh("condition1 (boolean, range<boolean>)",Oo("A column or row containing true or false values corresponding to the first column or row of range.")),wh("condition2 (boolean, range<boolean>, repeating)",Oo("Additional column or row containing true or false values."))],compute:function(e,...t){let o=fr(e);const s=t.map((e=>rr(fr(e),(e=>e.value))));s.map((e=>xh(Oo("The arguments condition must be a single column or row."),e))),Ih(Oo("The arguments conditions must have the same dimensions."),...t);const i=s.map((e=>e.flat())),r=1===s[0].length?"row":"col";o="row"===r?nr(o):o,Mi((()=>i.every((e=>e.length===o.length))),Oo("FILTER has mismatched sizes on the range and conditions."));const n=[];for(let e=0;e<o.length;e++){const t=o[e];i.every((t=>("boolean"==typeof t[e]||"number"==typeof t[e])&&t[e]))&&n.push(t)}return n.length?"row"===r?nr(n):n:new _i(Oo("No match found in FILTER evaluation"))},isExported:!0},xp={description:Oo("Sorts the rows of a given array or range by the values in one or more columns."),args:[wh("range (range)",Oo("The data to be sorted.")),wh("sort_column (any, range<number>, repeating)",Oo("The index of the column in range or a range outside of range containing the values by which to sort.")),wh("is_ascending (boolean, repeating)",Oo("TRUE or FALSE indicating whether to sort sort_column in ascending order. FALSE sorts in descending order."))],compute:function(e,...t){const o=nr(e);return nr(wp(o,this.locale,...t))},isExported:!0},Ip={description:Oo("Returns the first n items in a data set after performing a sort."),args:[wh("range (range)",Oo("The data to be sorted.")),wh("n (number, default=1)",Oo("The number of items to return.")),wh("display_ties_mode (number, default=0)",Oo("A number representing the way to display ties.")),wh("sort_column (number, range<number>, repeating)",Oo("The index of the column in range or a range outside of range containing the values by which to sort.")),wh("is_ascending (boolean, repeating)",Oo("TRUE or FALSE indicating whether to sort sort_column in ascending order. FALSE sorts in descending order."))],compute:function(e,t,o,...s){const i=Li(t?.value??1,this.locale);Mi((()=>i>=0),Oo("Wrong value of 'n'. Expected a positive number. Got %s.",i));const r=Li(o?.value??0,this.locale);Mi((()=>r>=0&&r<=3),Oo("Wrong value of 'display_ties_mode'. Expected a positive number between 0 and 3. Got %s.",r));const n=wp(nr(e),this.locale,...s),a=(e,t)=>JSON.stringify(n[e].map((e=>e.value)))===JSON.stringify(n[t].map((e=>e.value)));switch(r){case 0:return nr(n.slice(0,i));case 1:for(let e=i;e<n.length;e++)if(!a(e,i-1))return nr(n.slice(0,e));return nr(n);case 2:{const e=[n[0]];for(let t=1;t<n.length;t++)for(let o=0;o<t&&!a(t,o);o++)o===t-1&&e.push(n[t]);return nr(e.slice(0,i))}case 3:{const e=[n[0]];let t=1;for(let o=1;o<n.length&&(a(o,o-1)||t++,!(t>i));o++)e.push(n[o]);return nr(e)}}},isExported:!0},Rp={description:Oo("Unique rows in the provided source range."),args:[wh("range (any, range<any>)",Oo("The data to filter by unique entries.")),wh("by_column (boolean, default=FALSE)",Oo("Whether to filter the data by columns or by rows.")),wh("exactly_once (boolean, default=FALSE)",Oo("Whether to return only entries with no duplicates."))],compute:function(e={value:""},t,o){if(!yi(e))return[[e]];const s=ji(t?.value)||!1,i=ji(o?.value)||!1;s||(e=nr(e));const r=new Map;for(const t of e){const e=JSON.stringify(t.map((e=>e.value))),o=r.get(e);o?o.count++:r.set(e,{data:t,count:1})}const n=[];for(const e of r.values())i&&e.count>1||n.push(e.data);if(!n.length)throw new Ri(Oo("No unique values found"));return s?n:nr(n)},isExported:!0};var Tp=Object.freeze({__proto__:null,FILTER:Ep,SORT:xp,SORTN:Ip,UNIQUE:Rp});function Ap(e,t){Mi((()=>e<t),Oo("The maturity (%s) must be strictly greater than the settlement (%s).",t.toString(),e.toString()))}function _p(e,t){Mi((()=>t<e),Oo("The settlement date (%s) must be strictly greater than the issue date (%s).",e.toString(),t.toString()))}function Dp(e){Mi((()=>[1,2,4].includes(e)),Oo("The frequency (%s) must be one of %s",e.toString(),[1,2,4].toString()))}function Op(e){Mi((()=>0<=e&&e<=4),Oo("The day_count_convention (%s) must be between 0 and 4 inclusive.",e.toString()))}function Fp(e){Mi((()=>e>0),Oo("The redemption (%s) must be strictly positive.",e.toString()))}function Mp(e){Mi((()=>e>0),Oo("The price (%s) must be strictly positive.",e.toString()))}function Pp(e){Mi((()=>e>0),Oo("The number_of_periods (%s) must be greater than 0.",e.toString()))}function Np(e){Mi((()=>e>0),Oo("The rate (%s) must be strictly positive.",e.toString()))}function kp(e){Mi((()=>e>0),Oo("The life (%s) must be strictly positive.",e.toString()))}function Lp(e){Mi((()=>e>=0),Oo("The cost (%s) must be positive or null.",e.toString()))}function Vp(e){Mi((()=>e>0),Oo("The period (%s) must be strictly positive.",e.toString()))}function Hp(e){Mi((()=>e>=0),Oo("The salvage (%s) must be positive or null.",e.toString()))}function Up(e){Mi((()=>e>0),Oo("The present value (%s) must be strictly positive.",e.toString()))}function Bp(e,t){Mi((()=>e<=t),Oo("The period (%s) must be less than or equal life (%s).",e.toString(),t.toString()))}function zp(e){Mi((()=>e>0),Oo("The investment (%s) must be strictly positive.",e.toString()))}function $p(e){Mi((()=>e>0),Oo("The discount (%s) must be strictly positive.",e.toString()))}function Wp(e){Mi((()=>e<1),Oo("The discount (%s) must be smaller than 1.",e.toString()))}function Gp(e){Mi((()=>e>0),Oo("The depreciation factor (%s) must be strictly positive.",e.toString()))}function qp(e,t,o){const s=Yi(e,o),i=Yi(t,o),r=Yi(e,o);r.setFullYear(s.getFullYear()+1),Mi((()=>i.getTime()<=r.getTime()),Oo("The settlement date (%s) must at most one year after the maturity date (%s).",e.toString(),t.toString()))}function Zp(e,t,o){Pp(o),Mi((()=>e>0),Oo("The first_period (%s) must be strictly positive.",e.toString())),Mi((()=>t>0),Oo("The last_period (%s) must be strictly positive.",t.toString())),Mi((()=>e<=t),Oo("The first_period (%s) must be smaller or equal to the last_period (%s).",e.toString(),t.toString())),Mi((()=>t<=o),Oo("The last_period (%s) must be smaller or equal to the number_of_periods (%s).",e.toString(),o.toString()))}function jp(e){Mi((()=>e>-1),Oo("The rate_guess (%s) must be strictly greater than -1.",e.toString()))}function Yp(e,t){Mi((()=>e.length===t.length&&e[0].length===t[0].length),Oo("The cashflow_amounts and cashflow_dates ranges must have the same dimensions."))}function Xp(e){Mi((()=>e.every((t=>t>=e[0]))),Oo("All the dates should be greater or equal to the first date in cashflow_dates (%s).",e[0].toString()))}const Kp=[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("frequency (number)",Oo("The number of interest or coupon payments per year (1, 2, or 4).")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))];function Jp(e,t,o,s,i=1e-10,r){let n,a,l,c,h=o,d=!1,u=0;do{l=e(h),isNaN(l)?(Mi((()=>u<s&&void 0!==r),Oo("Function [[FUNCTION_NAME]] didn't find any result.")),u++,h=r(c),c=h):(n=h-l/t(h),a=Math.abs(n-h),h=n,d=a<i||Math.abs(l)<i,Mi((()=>u<s),Oo("Function [[FUNCTION_NAME]] didn't find any result.")),u++)}while(!d);return h}const Qp={description:Oo("Accrued interest of security paying at maturity."),args:[wh("issue (date)",Oo("The date the security was initially issued.")),wh("maturity (date)",Oo("The maturity date of the security.")),wh("rate (number)",Oo("The annualized rate of interest.")),wh("redemption (number)",Oo("The redemption amount per 100 face value, or par.")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){const r=Math.trunc(Li(e,this.locale)),n=Math.trunc(Li(t,this.locale)),a=Li(s,this.locale),l=Li(o,this.locale),c=Math.trunc(Li(i,this.locale));!function(e){Mi((()=>e>=0),Oo("The issue (%s) must be positive or null.",e.toString()))}(r),_p(n,r),Op(c),Fp(a),Np(l);return a*l*Zs(r,n,c)},isExported:!0},em={description:Oo("Depreciation for an accounting period."),args:[wh("cost (number)",Oo("The initial cost of the asset.")),wh("purchase_date (date)",Oo("The date the asset was purchased.")),wh("first_period_end (date)",Oo("The date the first period ended.")),wh("salvage (number)",Oo("The value of the asset at the end of depreciation.")),wh("period (number)",Oo("The single period within life for which to calculate depreciation.")),wh("rate (number)",Oo("The deprecation rate.")),wh("day_count_convention (number, optional)",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,r,n={value:0}){n=n||0;const a=Li(e,this.locale),l=Math.trunc(Li(t,this.locale)),c=Math.trunc(Li(o,this.locale)),h=Li(s,this.locale),d=Li(i,this.locale),u=Li(r,this.locale),g=Math.trunc(Li(n,this.locale));!function(e){Mi((()=>e>0),Oo("The cost (%s) must be strictly positive.",e.toString()))}(a),function(e){Mi((()=>e>=0),Oo("The purchase_date (%s) must be positive or null.",e.toString()))}(l),Hp(h),function(e,t){Mi((()=>e<=t),Oo("The salvage (%s) must be smaller or equal than the cost (%s).",e.toString(),t.toString()))}(h,a),function(e){Mi((()=>e>=0),Oo("The period (%s) must be positive or null.",e.toString()))}(d),Np(u),Op(g),Mi((()=>l<=c),Oo("The purchase_date (%s) must be before the first_period_end (%s).",l.toString(),c.toString()));const p=d<1&&d>0?1:Math.trunc(d),m=a*u,f=Zs(l,c,g),v=l===c?m:m*f,b=a-v-m*p;return b>=h?0===p?v:m:h-b<m?m-(h-b):0},isExported:!0},tm={description:Oo("Days in coupon period containing settlement date."),args:Kp,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Li(e,this.locale)),r=Math.trunc(Li(t,this.locale)),n=Math.trunc(Li(o,this.locale)),a=Math.trunc(Li(s,this.locale));if(Ap(i,r),Dp(n),Op(a),1===a){const i=nm.compute.bind(this)(e,t,o,s).value;return im.compute.bind(this)(e,t,o,s).value-i}return(3===a?365:360)/n},isExported:!0},om={description:Oo("Days from settlement until next coupon."),args:Kp,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Li(e,this.locale)),r=Math.trunc(Li(t,this.locale)),n=Math.trunc(Li(o,this.locale)),a=Math.trunc(Li(s,this.locale));Ap(i,r),Dp(n),Op(a);const l=nm.compute.bind(this)(e,t,o,s).value;if([1,2,3].includes(a))return i-l;if(4===a){const e=Zs(l,i,a);return Math.round(360*e)}const c=Yi(i,this.locale),h=Yi(l,this.locale),d=h.getFullYear(),u=c.getFullYear(),g=h.getMonth()+1,p=c.getMonth()+1;let m=h.getDate(),f=c.getDate();return 2===g&&2===p&&Ws(h)&&Ws(c)&&(f=30),31!==f||30!==m&&31!==m||(f=30),2===g&&Ws(h)&&(m=30),31===m&&(m=30),360*(u-d)+30*(p-g)+(f-m)},isExported:!0},sm={description:Oo("Days from settlement until next coupon."),args:Kp,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Li(e,this.locale)),r=Math.trunc(Li(t,this.locale)),n=Math.trunc(Li(o,this.locale)),a=Math.trunc(Li(s,this.locale));Ap(i,r),Dp(n),Op(a);const l=im.compute.bind(this)(e,t,o,s).value;if([1,2,3].includes(a))return l-i;if(4===a){const e=Zs(i,l,a);return Math.round(360*e)}const c=om.compute.bind(this)(e,t,o,s);return tm.compute.bind(this)(e,t,o,s)-c},isExported:!0},im={description:Oo("Next coupon date after the settlement date."),args:Kp,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Li(e,this.locale)),r=Math.trunc(Li(t,this.locale)),n=Math.trunc(Li(o,this.locale)),a=Math.trunc(Li(s,this.locale));Ap(i,r),Dp(n),Op(a);const l=12/n,c=rm.compute.bind(this)(e,t,o,s);return{value:Bs(Gs(Yi(r,this.locale),-(c-1)*l,!0)),format:this.locale.dateFormat}},isExported:!0},rm={description:Oo("Number of coupons between settlement and maturity."),args:Kp,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Li(e,this.locale)),r=Math.trunc(Li(t,this.locale)),n=Math.trunc(Li(o,this.locale)),a=Math.trunc(Li(s,this.locale));Ap(i,r),Dp(n),Op(a);let l=1,c=r;const h=12/n;for(;c>i;)c=Bs(Gs(Yi(c,this.locale),-h,!1)),l++;return l-1},isExported:!0},nm={description:Oo("Last coupon date prior to or on the settlement date."),args:Kp,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Li(e,this.locale)),r=Math.trunc(Li(t,this.locale)),n=Math.trunc(Li(o,this.locale)),a=Math.trunc(Li(s,this.locale));Ap(i,r),Dp(n),Op(a);const l=12/n,c=rm.compute.bind(this)(e,t,o,s);return{value:Bs(Gs(Yi(r,this.locale),-c*l,!0)),format:this.locale.dateFormat}},isExported:!0},am={description:Oo("Cumulative interest paid over a set of periods."),args:[wh("rate (number)",Oo("The interest rate.")),wh("number_of_periods (number)",Oo("The number of payments to be made.")),wh("present_value (number)",Oo("The current value of the annuity.")),wh("first_period (number)",Oo("The number of the payment period to begin the cumulative calculation.")),wh("last_period (number)",Oo("The number of the payment period to end the cumulative calculation.")),wh("end_or_beginning (number, default=0)",Oo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s,i,r={value:0}){const n=Li(s,this.locale),a=Li(i,this.locale),l=Li(e,this.locale),c=Li(o,this.locale),h=Li(t,this.locale),d=ji(r)?1:0;Zp(n,a,h),Np(l),Up(c);let u=0;for(let e=n;e<=a;e++)u+=Cm(l,e,h,c,0,d);return u},isExported:!0},lm={description:Oo("Cumulative principal paid over a set of periods."),args:[wh("rate (number)",Oo("The interest rate.")),wh("number_of_periods (number)",Oo("The number of payments to be made.")),wh("present_value (number)",Oo("The current value of the annuity.")),wh("first_period (number)",Oo("The number of the payment period to begin the cumulative calculation.")),wh("last_period (number)",Oo("The number of the payment period to end the cumulative calculation.")),wh("end_or_beginning (number, default=0)",Oo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s,i,r={value:0}){const n=Li(s,this.locale),a=Li(i,this.locale),l=Li(e,this.locale),c=Li(o,this.locale),h=Li(t,this.locale),d=ji(r)?1:0;Zp(n,a,h),Np(l),Up(c);let u=0;for(let e=n;e<=a;e++)u+=Pm(l,e,h,c,0,d);return u},isExported:!0},cm={description:Oo("Depreciation via declining balance method."),args:[wh("cost (number)",Oo("The initial cost of the asset.")),wh("salvage (number)",Oo("The value of the asset at the end of depreciation.")),wh("life (number)",Oo("The number of periods over which the asset is depreciated.")),wh("period (number)",Oo("The single period within life for which to calculate depreciation.")),wh("month (number, optional)",Oo("The number of months in the first year of depreciation."))],compute:function(e,t,o,s,...i){const r=Li(e,this.locale),n=Li(t,this.locale),a=Li(o,this.locale),l=Math.trunc(Li(s,this.locale)),c=i.length?Math.trunc(Li(i[0],this.locale)):12,h=a+(12===c?0:1);Lp(r),Hp(n),Vp(l),kp(a),Mi((()=>1<=c&&c<=12),Oo("The month (%s) must be between 1 and 12 inclusive.",c.toString())),Mi((()=>l<=h),Oo("The period (%s) must be less than or equal to %s.",l.toString(),h.toString()));const d=c/12;let u=1-Math.pow(n/r,1/a);u=Math.round(1e3*u)/1e3;let g=r,p=r*(1-u*d);for(let e=1;e<l;e++)g=p,p=g*(1-u),e===a&&(p=g*(1-u*(1-d)));return{value:g-p,format:"#,##0.00"}},isExported:!0};function hm(e,t,o,s,i){if(Lp(e),Hp(t),Vp(s),kp(o),Bp(s,o),Gp(i),0===e||t>=e)return 0;const r=i/o;if(r>1)return 1===s?e-t:0;if(s<=1)return e*r;const n=e*Math.pow(1-r,s-1),a=e*Math.pow(1-r,s),l=a<t?n-t:n-a;return Math.max(l,0)}const dm={description:Oo("Depreciation via double-declining balance method."),args:[wh("cost (number)",Oo("The initial cost of the asset.")),wh("salvage (number)",Oo("The value of the asset at the end of depreciation.")),wh("life (number)",Oo("The number of periods over which the asset is depreciated.")),wh("period (number)",Oo("The single period within life for which to calculate depreciation.")),wh("factor (number, default=2)",Oo("The factor by which depreciation decreases."))],compute:function(e,t,o,s,i={value:2}){return{value:hm(Li(e,this.locale),Li(t,this.locale),Li(o,this.locale),Li(s,this.locale),Li(i,this.locale)),format:"#,##0.00"}},isExported:!0},um={description:Oo("Discount rate of a security based on price."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("price (number)",Oo("The price at which the security is bought per 100 face value.")),wh("redemption (number)",Oo("The redemption amount per 100 face value, or par.")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){i=i||0;const r=Math.trunc(Li(e,this.locale)),n=Math.trunc(Li(t,this.locale)),a=Li(o,this.locale),l=Li(s,this.locale),c=Math.trunc(Li(i,this.locale));Ap(r,n),Op(c),Mp(a),Fp(l);return(l-a)/l/Zs(r,n,c)},isExported:!0},gm={description:Oo("Convert a decimal fraction to decimal value."),args:[wh("fractional_price (number)",Oo("The price quotation given using fractional decimal conventions.")),wh("unit (number)",Oo("The units of the fraction, e.g. 8 for 1/8ths or 32 for 1/32nds."))],compute:function(e,t){const o=Li(e,this.locale),s=Math.trunc(Li(t,this.locale));Mi((()=>s>0),Oo("The unit (%s) must be strictly positive.",s.toString()));const i=Math.trunc(o);return i+(o-i)*(10**Math.ceil(Math.log10(s))/s)},isExported:!0},pm={description:Oo("Convert a decimal value to decimal fraction."),args:[wh("decimal_price (number)",Oo("The price quotation given as a decimal value.")),wh("unit (number)",Oo("The units of the desired fraction, e.g. 8 for 1/8ths or 32 for 1/32nds."))],compute:function(e,t){const o=Li(e,this.locale),s=Math.trunc(Li(t,this.locale));Mi((()=>s>0),Oo("The unit (%s) must be strictly positive.",s.toString()));const i=Math.trunc(o);return i+(o-i)*(s/10**Math.ceil(Math.log10(s)))},isExported:!0},mm={description:Oo("Number of periods for an investment to reach a value."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("rate (number)",Oo("The annualized rate of interest.")),wh("yield (number)",Oo("The expected annual yield of the security.")),wh("frequency (number)",Oo("The number of interest or coupon payments per year (1, 2, or 4).")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,r={value:0}){const n=Math.trunc(Li(e,this.locale)),a=Math.trunc(Li(t,this.locale)),l=Li(o,this.locale),c=Li(s,this.locale),h=Math.trunc(Li(i,this.locale)),d=Math.trunc(Li(r,this.locale));Ap(n,a),Dp(h),Op(d),Mi((()=>l>=0),Oo("The rate (%s) must be positive or null.",l.toString())),Mi((()=>c>=0),Oo("The yield (%s) must be positive or null.",c.toString()));const u=Zs(n,a,d),g=u-Math.trunc(u)||1/h,p=Math.ceil(u*h),m=l/h,f=c/h;let v=0,b=0;for(let e=1;e<=p;e++){const t=(m+(e===p?1:0))/(1+f)**e;b+=(g+(e-1)/h)*t,v+=t}return 0===v?0:b/v},isExported:!0},fm={description:Oo("Annual effective interest rate."),args:[wh("nominal_rate (number)",Oo("The nominal interest rate per year.")),wh("periods_per_year (number)",Oo("The number of compounding periods per year."))],compute:function(e,t){const o=Li(e,this.locale),s=Math.trunc(Li(t,this.locale));return Mi((()=>o>0),Oo("The nominal rate (%s) must be strictly greater than 0.",o.toString())),Mi((()=>s>0),Oo("The number of periods by year (%s) must strictly greater than 0.",s.toString())),Math.pow(1+o/s,s)-1},isExported:!0};function vm(e,t,o,s,i){return 0===e?-(s+o*t):-s*(1+e)**t-o*(1+e*i)*((1+e)**t-1)/e}const bm={description:Oo("Future value of an annuity investment."),args:[wh("rate (number)",Oo("The interest rate.")),wh("number_of_periods (number)",Oo("The number of payments to be made.")),wh("payment_amount (number)",Oo("The amount per period to be paid.")),wh("present_value (number, default=0)",Oo("The current value of the annuity.")),wh("end_or_beginning (number, default=0)",Oo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s={value:0},i={value:0}){s=s||0,i=i||0;return{value:vm(Li(e,this.locale),Li(t,this.locale),Li(o,this.locale),Li(s,this.locale),ji(i)?1:0),format:"#,##0.00"}},isExported:!0},Sm={description:Oo("Future value of principal from series of rates."),args:[wh("principal (number)",Oo("The amount of initial capital or value to compound against.")),wh("rate_schedule (number, range<number>)",Oo("A series of interest rates to compound against the principal."))],compute:function(e,t){return tr([t],((e,t)=>e*(1+Li(t,this.locale))),Li(e,this.locale))},isExported:!0},ym={description:Oo("Calculates effective interest rate."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("investment (number)",Oo("The amount invested in the security.")),wh("redemption (number)",Oo("The amount to be received at maturity.")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){const r=Math.trunc(Li(e,this.locale)),n=Math.trunc(Li(t,this.locale)),a=Li(s,this.locale),l=Li(o,this.locale),c=Math.trunc(Li(i,this.locale));Ap(r,n),zp(l),Fp(a),Op(c);return(a-l)/l/Zs(r,n,c)},isExported:!0};function Cm(e,t,o,s,i,r){return Fm(e,o,s,i,r)-Pm(e,t,o,s,i,r)}const wm={description:Oo("Payment on the principal of an investment."),args:[wh("rate (number)",Oo("The annualized rate of interest.")),wh("period (number)",Oo("The amortization period, in terms of number of periods.")),wh("number_of_periods (number)",Oo("The number of payments to be made.")),wh("present_value (number)",Oo("The current value of the annuity.")),wh("future_value (number, default=0)",Oo("The future value remaining after the final payment has been made.")),wh("end_or_beginning (number, default=0)",Oo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s,i={value:0},r={value:0}){return{value:Cm(Li(e,this.locale),Li(t,this.locale),Li(o,this.locale),Li(s,this.locale),Li(i,this.locale),ji(r)?1:0),format:"#,##0.00"}},isExported:!0},Em={description:Oo("Internal rate of return given periodic cashflows."),args:[wh("cashflow_amounts (number, range<number>)",Oo("An array or range containing the income or payments associated with the investment.")),wh("rate_guess (number, default=0.1)",Oo("An estimate for what the internal rate of return will be."))],compute:function(e,t={value:.1}){const o=Li(t,this.locale);jp(o);let s=!1,i=!1,r=[];Qi([e],(({value:e})=>{e>0&&(s=!0),e<0&&(i=!0),r.push(e)}),this.locale),Mi((()=>s&&i),Oo("The cashflow_amounts must include negative and positive values."));const n=r.shift();return{value:Jp((function(e){return function(e,t,o){const s=o.length;let i=0;return o.reduce(((t,o)=>(i++,t+o*e**(s-i))),t*e**s)}(e,n,r)}),(function(e){return function(e,t,o){const s=o.length;let i=0;return o.reduce(((t,o)=>(i++,t+o*(s-i)*e**(s-i-1))),t*s*e**(s-1))}(e,n,r)}),o+1,20,1e-5)-1,format:"0%"}},isExported:!0},xm={description:Oo("Returns the interest paid at a particular period of an investment."),args:[wh("rate (number)",Oo("The interest rate.")),wh("period (number)",Oo("The period for which you want to view the interest payment.")),wh("number_of_periods (number)",Oo("The number of payments to be made.")),wh("present_value (number)",Oo("The current value of the annuity."))],compute:function(e,t,o,s){const i=Li(e,this.locale),r=Li(t,this.locale),n=Li(o,this.locale),a=Li(s,this.locale);Mi((()=>0!==n),Oo("The number of periods must be different than 0.",n.toString()));return-1*(a-a*(r/n))*i},isExported:!0},Im={description:Oo("Modified Macaulay duration."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("rate (number)",Oo("The annualized rate of interest.")),wh("yield (number)",Oo("The expected annual yield of the security.")),wh("frequency (number)",Oo("The number of interest or coupon payments per year (1, 2, or 4).")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,r={value:0}){return mm.compute.bind(this)(e,t,o,s,i,r)/(1+Li(s,this.locale)/Math.trunc(Li(i,this.locale)))},isExported:!0},Rm={description:Oo("Modified internal rate of return."),args:[wh("cashflow_amounts (range<number>)",Oo("A range containing the income or payments associated with the investment. The array should contain bot payments and incomes.")),wh("financing_rate (number)",Oo("The interest rate paid on funds invested.")),wh("reinvestment_return_rate (number)",Oo("The return (as a percentage) earned on reinvestment of income received from the investment."))],compute:function(e,t,o){const s=Li(t,this.locale),i=Li(o,this.locale),r=nr(e).flat().filter((e=>null!==e.value)).map((e=>Li(e,this.locale))),n=r.length;let a=0,l=0;for(const e of Ze(0,n)){const t=r[e];t>=0?a+=t*(i+1)**(n-e-1):l+=t/(s+1)**e}Mi((()=>0!==l&&0!==a),Oo("There must be both positive and negative values in cashflow_amounts."));return(-a/l)**(1/(n-1))-1},isExported:!0},Tm={description:Oo("Annual nominal interest rate."),args:[wh("effective_rate (number)",Oo("The effective interest rate per year.")),wh("periods_per_year (number)",Oo("The number of compounding periods per year."))],compute:function(e,t){const o=Li(e,this.locale),s=Math.trunc(Li(t,this.locale));return Mi((()=>o>0),Oo("The effective rate (%s) must must strictly greater than 0.",o.toString())),Mi((()=>s>0),Oo("The number of periods by year (%s) must strictly greater than 0.",s.toString())),(Math.pow(o+1,1/s)-1)*s},isExported:!0},Am={description:Oo("Number of payment periods for an investment."),args:[wh("rate (number)",Oo("The interest rate.")),wh("payment_amount (number)",Oo("The amount of each payment made.")),wh("present_value (number)",Oo("The current value of the annuity.")),wh("future_value (number, default=0)",Oo("The future value remaining after the final payment has been made.")),wh("end_or_beginning (number, default=0)",Oo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s={value:0},i={value:0}){s=s||0,i=i||0;const r=Li(e,this.locale),n=Li(t,this.locale),a=Li(o,this.locale),l=Li(s,this.locale),c=ji(i)?1:0;if(0===r)return-(l+a)/n;const h=n*(1+r*c)/r;return Math.log((h-l)/(a+h))/Math.log(1+r)},isExported:!0};function _m(e,t,o,s){let i=0;return or(o,((t,o)=>(i++,t+o/(1+e)**i)),t,s)}const Dm={description:Oo("The net present value of an investment based on a series of periodic cash flows and a discount rate."),args:[wh("discount (number)",Oo("The discount rate of the investment over one period.")),wh("cashflow1 (number, range<number>)",Oo("The first future cash flow.")),wh("cashflow2 (number, range<number>, repeating)",Oo("Additional future cash flows."))],compute:function(e,...t){const o=Li(e,this.locale);return Mi((()=>-1!==o),Oo("The discount (%s) must be different from -1.",o.toString())),{value:_m(o,0,t,this.locale),format:"#,##0.00"}},isExported:!0},Om={description:Oo("Computes the number of periods needed for an investment to reach a value."),args:[wh("rate (number)",Oo("The rate at which the investment grows each period.")),wh("present_value (number)",Oo("The investment's current value.")),wh("future_value (number)",Oo("The investment's desired future value."))],compute:function(e,t,o){const s=Li(e,this.locale),i=Li(t,this.locale),r=Li(o,this.locale);return Np(s),Mi((()=>i>0),Oo("The present_value (%s) must be strictly positive.",i.toString())),Mi((()=>r>0),Oo("The future_value (%s) must be strictly positive.",r.toString())),(Math.log(r)-Math.log(i))/Math.log(1+s)},isExported:!0};function Fm(e,t,o,s,i){if(Pp(t),0===e)return-(s+o)/t;let r=-(o*(1+e)**t+s);return r=r*e/((1+e*i)*((1+e)**t-1)),r}const Mm={description:Oo("Periodic payment for an annuity investment."),args:[wh("rate (number)",Oo("The annualized rate of interest.")),wh("number_of_periods (number)",Oo("The number of payments to be made.")),wh("present_value (number)",Oo("The current value of the annuity.")),wh("future_value (number, default=0)",Oo("The future value remaining after the final payment has been made.")),wh("end_or_beginning (number, default=0)",Oo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s={value:0},i={value:0}){const r=Li(t,this.locale),n=Li(e,this.locale),a=ji(i)?1:0,l=Li(s,this.locale);return{value:Fm(n,r,Li(o,this.locale),l,a),format:"#,##0.00"}},isExported:!0};function Pm(e,t,o,s,i,r){Pp(o),Mi((()=>t>0&&t<=o),Oo("The period must be between 1 and number_of_periods (%s)",o));const n=Fm(e,o,s,i,r);if(1===r&&1===t)return n;return n+-vm(e,0===r?t-1:t-2,n,s+n*r,0)*e}const Nm={description:Oo("Payment on the principal of an investment."),args:[wh("rate (number)",Oo("The annualized rate of interest.")),wh("period (number)",Oo("The amortization period, in terms of number of periods.")),wh("number_of_periods (number)",Oo("The number of payments to be made.")),wh("present_value (number)",Oo("The current value of the annuity.")),wh("future_value (number, default=0)",Oo("The future value remaining after the final payment has been made.")),wh("end_or_beginning (number, default=0)",Oo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s,i={value:0},r={value:0}){const n=Li(o,this.locale),a=Li(e,this.locale),l=Li(t,this.locale),c=ji(r)?1:0,h=Li(i,this.locale);return{value:Pm(a,l,n,Li(s,this.locale),h,c),format:"#,##0.00"}},isExported:!0},km={description:Oo("Present value of an annuity investment."),args:[wh("rate (number)",Oo("The interest rate.")),wh("number_of_periods (number)",Oo("The number of payments to be made.")),wh("payment_amount (number)",Oo("The amount per period to be paid.")),wh("future_value (number, default=0)",Oo("The future value remaining after the final payment has been made.")),wh("end_or_beginning (number, default=0)",Oo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s={value:0},i={value:0}){s=s||0,i=i||0;const r=Li(e,this.locale),n=Li(t,this.locale),a=Li(o,this.locale),l=Li(s,this.locale),c=ji(i)?1:0;return{value:r?-(a*(1+r*c)*((1+r)**n-1)/r+l)/(1+r)**n:-(l+a*n),format:"#,##0.00"}},isExported:!0},Lm={description:Oo("Price of a security paying periodic interest."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("rate (number)",Oo("The annualized rate of interest.")),wh("yield (number)",Oo("The expected annual yield of the security.")),wh("redemption (number)",Oo("The redemption amount per 100 face value, or par.")),wh("frequency (number)",Oo("The number of interest or coupon payments per year (1, 2, or 4).")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,r,n={value:0}){n=n||0;const a=Math.trunc(Li(e,this.locale)),l=Math.trunc(Li(t,this.locale)),c=Li(o,this.locale),h=Li(s,this.locale),d=Li(i,this.locale),u=Math.trunc(Li(r,this.locale)),g=Math.trunc(Li(n,this.locale));Ap(a,l),Dp(u),Op(g),Mi((()=>c>=0),Oo("The rate (%s) must be positive or null.",c.toString())),Mi((()=>h>=0),Oo("The yield (%s) must be positive or null.",h.toString())),Fp(d);const p=Zs(a,l,g)*u,m=Math.ceil(p),f=p-Math.floor(p)||1,v=1+h/u,b=100*c/u;if(1===m)return(b+d)/(f*h/u+1)-b*(1-f);let S=0;for(let e=1;e<=m;e++)S+=b/v**(e-1+f);return d/v**(m-1+f)+S-b*(1-f)},isExported:!0},Vm={description:Oo("Price of a discount security."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("discount (number)",Oo("The discount rate of the security at time of purchase.")),wh("redemption (number)",Oo("The redemption amount per 100 face value, or par.")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){i=i||0;const r=Math.trunc(Li(e,this.locale)),n=Math.trunc(Li(t,this.locale)),a=Li(o,this.locale),l=Li(s,this.locale),c=Math.trunc(Li(i,this.locale));Ap(r,n),Op(c),$p(a),Fp(l);return l-a*l*Zs(r,n,c)},isExported:!0},Hm={description:Oo("Calculates the price of a security paying interest at maturity, based on expected yield."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("issue (date)",Oo("The date the security was initially issued.")),wh("rate (number)",Oo("The annualized rate of interest.")),wh("yield (number)",Oo("The expected annual yield of the security.")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,r={value:0}){r=r||0;const n=Math.trunc(Li(e,this.locale)),a=Math.trunc(Li(t,this.locale)),l=Math.trunc(Li(o,this.locale)),c=Li(s,this.locale),h=Li(i,this.locale),d=Math.trunc(Li(r,this.locale));_p(n,l),Ap(n,a),Op(d),Mi((()=>c>=0),Oo("The rate (%s) must be positive or null.",c.toString())),Mi((()=>h>=0),Oo("The yield (%s) must be positive or null.",h.toString()));const u=Zs(n,a,d),g=Zs(n,l,d);return(100+Zs(l,a,d)*c*100)/(1+u*h)-g*c*100},isExported:!0},Um=.1,Bm={description:Oo("Interest rate of an annuity investment."),args:[wh("number_of_periods (number)",Oo("The number of payments to be made.")),wh("payment_per_period (number)",Oo("The amount per period to be paid.")),wh("present_value (number)",Oo("The current value of the annuity.")),wh("future_value (number, default=0)",Oo("The future value remaining after the final payment has been made.")),wh("end_or_beginning (number, default=0)",Oo("Whether payments are due at the end (0) or beginning (1) of each period.")),wh("rate_guess (number, default=0.1)",Oo("An estimate for what the interest rate will be."))],compute:function(e,t,o,s={value:0},i={value:0},r={value:Um}){const n=Li(e,this.locale),a=Li(t,this.locale),l=ji(i)?1:0,c=Li(r,this.locale)||Um;let h=Li(s,this.locale),d=Li(o,this.locale);Pp(n),Mi((()=>[a,d,h].some((e=>e>0))&&[a,d,h].some((e=>e<0))),Oo("There must be both positive and negative values in [payment_amount, present_value, future_value].",n.toString())),jp(c),h-=a*l,d+=a*l;return{value:Jp((e=>{const t=Math.pow(1+e,n);return h+d*t+a*((t-1)/e)}),(e=>{const t=Math.pow(1+e,n-1),o=Math.pow(1+e,n);return d*n*t+a*(n*t/e-(o-1)/e/e)}),c,40,1e-5),format:"0%"}},isExported:!0},zm={description:Oo("Amount received at maturity for a security."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("investment (number)",Oo("The amount invested (irrespective of face value of each security).")),wh("discount (number)",Oo("The discount rate of the security invested in.")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){i=i||0;const r=Math.trunc(Li(e,this.locale)),n=Math.trunc(Li(t,this.locale)),a=Li(o,this.locale),l=Li(s,this.locale),c=Math.trunc(Li(i,this.locale));Ap(r,n),Op(c),zp(a),$p(l);return a/(1-l*Zs(r,n,c))},isExported:!0},$m={description:Oo("Computes the rate needed for an investment to reach a specific value within a specific number of periods."),args:[wh("number_of_periods (number)",Oo("The number of periods.")),wh("present_value (number)",Oo("The present value of the investment.")),wh("future_value (number)",Oo("The future value of the investment."))],compute:function(e,t,o){const s=Li(e,this.locale),i=Li(t,this.locale),r=Li(o,this.locale);return Pp(s),(r/i)**(1/s)-1},isExported:!0},Wm={description:Oo("Depreciation of an asset using the straight-line method."),args:[wh("cost (number)",Oo("The initial cost of the asset.")),wh("salvage (number)",Oo("The value of the asset at the end of depreciation.")),wh("life (number)",Oo("The number of periods over which the asset is depreciated."))],compute:function(e,t,o){return{value:(Li(e,this.locale)-Li(t,this.locale))/Li(o,this.locale),format:"#,##0.00"}},isExported:!0},Gm={description:Oo("Depreciation via sum of years digit method."),args:[wh("cost (number)",Oo("The initial cost of the asset.")),wh("salvage (number)",Oo("The value of the asset at the end of depreciation.")),wh("life (number)",Oo("The number of periods over which the asset is depreciated.")),wh("period (number)",Oo("The single period within life for which to calculate depreciation."))],compute:function(e,t,o,s){const i=Li(e,this.locale),r=Li(t,this.locale),n=Li(o,this.locale),a=Li(s,this.locale);Vp(a),kp(n),Bp(a,n);return{value:(n-a+1)/(n*(n+1)/2)*(i-r),format:"#,##0.00"}},isExported:!0};function qm(e,t,o){return 100*(1-o*Zs(e,t,2))}const Zm={description:Oo("Price of a US Treasury bill."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("discount (number)",Oo("The discount rate of the bill at time of purchase."))],compute:function(e,t,o){const s=Math.trunc(Li(e,this.locale)),i=Math.trunc(Li(t,this.locale)),r=Li(o,this.locale);return Ap(s,i),qp(s,i,this.locale),$p(r),Wp(r),qm(s,i,r)},isExported:!0},jm={description:Oo("Equivalent rate of return for a US Treasury bill."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("discount (number)",Oo("The discount rate of the bill at time of purchase."))],compute:function(e,t,o){const s=Math.trunc(Li(e,this.locale)),i=Math.trunc(Li(t,this.locale)),r=Li(o,this.locale);Ap(s,i),qp(s,i,this.locale),$p(r),Wp(r);const n=Ug.compute.bind(this)({value:i},{value:s});if(n<=182)return 365*r/(360-r*n);const a=qm(s,i,r)/100,l=n/(366===n?366:365);return(-2*l+2*Math.sqrt(l**2-(2*l-1)*(1-1/a)))/(2*l-1)},isExported:!0},Ym={description:Oo("The yield of a US Treasury bill based on price."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("price (number)",Oo("The price at which the security is bought per 100 face value."))],compute:function(e,t,o){const s=Math.trunc(Li(e,this.locale)),i=Math.trunc(Li(t,this.locale)),r=Li(o,this.locale);Ap(s,i),qp(s,i,this.locale),Mp(r);return(100-r)/r*(1/Zs(s,i,2))},isExported:!0},Xm={description:Oo("Variable declining balance. WARNING : does not handle decimal periods."),args:[wh("cost (number)",Oo("The initial cost of the asset.")),wh("salvage (number)",Oo("The value of the asset at the end of depreciation.")),wh("life (number)",Oo("The number of periods over which the asset is depreciated.")),wh("start (number)",Oo("Starting period to calculate depreciation.")),wh("end (number)",Oo("Ending period to calculate depreciation.")),wh("factor (number, default=2)",Oo("The number of months in the first year of depreciation.")),wh("no_switch (number, default=false)",Oo("Whether to switch to straight-line depreciation when the depreciation is greater than the declining balance calculation."))],compute:function(e,t,o,s,i,r={value:2},n={value:false}){r=r||0;const a=Li(e,this.locale),l=Li(t,this.locale),c=Li(o,this.locale),h=Math.trunc(Li(s,this.locale)),d=Math.trunc(Li(i,this.locale)),u=Li(r,this.locale),g=ji(n);if(Lp(a),Hp(l),function(e,t,o){kp(o),Mi((()=>e>=0),Oo("The start_period (%s) must be greater or equal than 0.",e.toString())),Mi((()=>t>=0),Oo("The end_period (%s) must be greater or equal than 0.",t.toString())),Mi((()=>e<=t),Oo("The start_period (%s) must be smaller or equal to the end_period (%s).",e.toString(),t.toString())),Mi((()=>t<=o),Oo("The end_period (%s) must be smaller or equal to the life (%s).",e.toString(),o.toString()))}(h,d,c),Gp(u),0===a)return 0;if(l>=a)return h<1?a-l:0;const p=u/c;if(p>=1)return h<1?a-l:0;let m=a,f=0,v=0,b=!1;for(let e=0;e<d;e++){if(!b||g){const t=m*p,o=(m-l)/(c-e);!g&&o>t?(b=!0,f=o):f=t}const t=Math.max(m-f,l);e>=h&&(v+=m-t),m=t}return v},isExported:!0},Km={description:Oo("Internal rate of return given non-periodic cash flows."),args:[wh("cashflow_amounts (range<number>)",Oo("An range containing the income or payments associated with the investment.")),wh("cashflow_dates (range<number>)",Oo("An range with dates corresponding to the cash flows in cashflow_amounts.")),wh("rate_guess (number, default=0.1)",Oo("An estimate for what the internal rate of return will be."))],compute:function(e,t,o={value:Um}){const s=Li(o,this.locale),i=e.flat().map((e=>Li(e,this.locale))),r=t.flat().map((e=>Li(e,this.locale)));var n;Yp(e,t),n=i,Mi((()=>n.some((e=>e>0))&&n.some((e=>e<0))),Oo("There must be both positive and negative values in cashflow_amounts.")),Xp(r),jp(s);const a=new Map;for(const e of Ze(0,r.length)){const t=r[e];a.has(t)?a.set(t,a.get(t)+i[e]):a.set(t,i[e])}const l=Array.from(a.keys()),c=l.map((e=>a.get(e)));return Jp((e=>{let t=c[0];for(const o of Ze(1,c.length)){const s=(l[0]-l[o])/365;t+=c[o]*(1+e)**s}return t}),(e=>{let t=0;for(const o of Ze(1,c.length)){const s=(l[0]-l[o])/365;t+=s*c[o]*(1+e)**(s-1)}return t}),s,40,1e-5,(e=>e?e/10-.9:-.9))},isExported:!0},Jm={description:Oo("Net present value given to non-periodic cash flows.."),args:[wh("discount (number)",Oo("The discount rate of the investment over one period.")),wh("cashflow_amounts (number, range<number>)",Oo("An range containing the income or payments associated with the investment.")),wh("cashflow_dates (number, range<number>)",Oo("An range with dates corresponding to the cash flows in cashflow_amounts."))],compute:function(e,t,o){const s=Li(e,this.locale),i=yi(t)?t.flat().map((e=>Ui(e,this.locale))):[Ui(t,this.locale)],r=yi(o)?o.flat().map((e=>Ui(e,this.locale))):[Ui(o,this.locale)];if(yi(o)&&yi(t)?Yp(t,o):Mi((()=>i.length===r.length),Oo("There must be the same number of values in cashflow_amounts and cashflow_dates.")),Xp(r),Np(s),1===i.length)return i[0];const n=new Map;for(const e of Ze(0,r.length)){const t=r[e];n.has(t)?n.set(t,n.get(t)+i[e]):n.set(t,i[e])}const a=Array.from(n.keys()),l=a.map((e=>n.get(e)));let c=l[0];for(const e of Ze(1,l.length)){const t=(a[0]-a[e])/365;c+=l[e]*(1+s)**t}return c},isExported:!0},Qm={description:Oo("Annual yield of a security paying periodic interest."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("rate (number)",Oo("The annualized rate of interest.")),wh("price (number)",Oo("The price at which the security is bought per 100 face value.")),wh("redemption (number)",Oo("The redemption amount per 100 face value, or par.")),wh("frequency (number)",Oo("The number of interest or coupon payments per year (1, 2, or 4).")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,r,n={value:0}){n=n||0;const a=Math.trunc(Li(e,this.locale)),l=Math.trunc(Li(t,this.locale)),c=Li(o,this.locale),h=Li(s,this.locale),d=Li(i,this.locale),u=Math.trunc(Li(r,this.locale)),g=Math.trunc(Li(n,this.locale));Ap(a,l),Dp(u),Op(g),Mi((()=>c>=0),Oo("The rate (%s) must be positive or null.",c.toString())),Mp(h),Fp(d);const p=Zs(a,l,g)*u,m=Math.ceil(p),f=p-Math.floor(p)||1,v=100*c/u;if(1===m){const e=h+v*(1-f);return(d+v-e)*u*(1/f)/e}const b=Jp((function(e){return function(e,t,o,s,i,r){let n=r-(e+i*(1-t))*s**(o-1+t);for(let e=1;e<=o;e++)n+=i*s**(e-1);return n}(h,f,m,e,v,d)}),(function(e){return function(e,t,o,s,i){let r=-(e+i*(1-t))*(o-1+t)*s**(o-2+t);for(let e=1;e<=o;e++)r+=i*(e-1)*s**(e-2);return r}(h,f,m,e,v)}),1+(c+1)/u,100,1e-5);return(b-1)*u},isExported:!0},ef={description:Oo("Annual yield of a discount security."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("price (number)",Oo("The price at which the security is bought per 100 face value.")),wh("redemption (number)",Oo("The redemption amount per 100 face value, or par.")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){i=i||0;const r=Math.trunc(Li(e,this.locale)),n=Math.trunc(Li(t,this.locale)),a=Li(o,this.locale),l=Li(s,this.locale),c=Math.trunc(Li(i,this.locale));Ap(r,n),Op(c),Mp(a),Fp(l);return(l/a-1)/Zs(r,n,c)},isExported:!0},tf={description:Oo("Annual yield of a security paying interest at maturity."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("issue (date)",Oo("The date the security was initially issued.")),wh("rate (number)",Oo("The annualized rate of interest.")),wh("price (number)",Oo("The price at which the security is bought.")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,r={value:0}){r=r||0;const n=Math.trunc(Li(e,this.locale)),a=Math.trunc(Li(t,this.locale)),l=Math.trunc(Li(o,this.locale)),c=Li(s,this.locale),h=Li(i,this.locale),d=Math.trunc(Li(r,this.locale));Ap(n,a),Op(d),Mi((()=>n>=l),Oo("The settlement (%s) must be greater than or equal to the issue (%s).",n.toString(),l.toString())),Mi((()=>c>=0),Oo("The rate (%s) must be positive or null.",c.toString())),Mp(h);const u=Zs(l,a,d),g=Zs(l,n,d),p=Zs(n,a,d);return(100*(1+c*u)/(h+100*c*g)-1)/p},isExported:!0};var of,sf=Object.freeze({__proto__:null,ACCRINTM:Qp,AMORLINC:em,COUPDAYBS:om,COUPDAYS:tm,COUPDAYSNC:sm,COUPNCD:im,COUPNUM:rm,COUPPCD:nm,CUMIPMT:am,CUMPRINC:lm,DB:cm,DDB:dm,DISC:um,DOLLARDE:gm,DOLLARFR:pm,DURATION:mm,EFFECT:fm,FV:bm,FVSCHEDULE:Sm,INTRATE:ym,IPMT:wm,IRR:Em,ISPMT:xm,MDURATION:Im,MIRR:Rm,NOMINAL:Tm,NPER:Am,NPV:Dm,PDURATION:Om,PMT:Mm,PPMT:Nm,PRICE:Lm,PRICEDISC:Vm,PRICEMAT:Hm,PV:km,RATE:Bm,RECEIVED:zm,RRI:$m,SLN:Wm,SYD:Gm,TBILLEQ:jm,TBILLPRICE:Zm,TBILLYIELD:Ym,VDB:Xm,XIRR:Km,XNPV:Jm,YIELD:Qm,YIELDDISC:ef,YIELDMAT:tf});!function(e){e[e.LeftRef=0]="LeftRef",e[e.RightRef=1]="RightRef",e[e.Separator=2]="Separator",e[e.FullColumnSeparator=3]="FullColumnSeparator",e[e.FullRowSeparator=4]="FullRowSeparator",e[e.RightColumnRef=5]="RightColumnRef",e[e.RightRowRef=6]="RightRowRef",e[e.Found=7]="Found"}(of||(of={}));const rf=(e,t=(()=>!0))=>[{goTo:e,guard:t}],nf=(e,t=(()=>!0))=>({goTo:e,guard:t}),af={[of.LeftRef]:{REFERENCE:rf(of.Separator),NUMBER:rf(of.FullRowSeparator),SYMBOL:[nf(of.FullColumnSeparator,(e=>Uo(e.value))),nf(of.FullRowSeparator,(e=>Bo(e.value)))]},[of.FullColumnSeparator]:{SPACE:rf(of.FullColumnSeparator),OPERATOR:rf(of.RightColumnRef,(e=>":"===e.value))},[of.FullRowSeparator]:{SPACE:rf(of.FullRowSeparator),OPERATOR:rf(of.RightRowRef,(e=>":"===e.value))},[of.Separator]:{SPACE:rf(of.Separator),OPERATOR:rf(of.RightRef,(e=>":"===e.value))},[of.RightRef]:{SPACE:rf(of.RightRef),NUMBER:rf(of.Found),REFERENCE:rf(of.Found,(e=>Wo(e.value))),SYMBOL:rf(of.Found,(e=>zo(e.value)||$o(e.value)))},[of.RightColumnRef]:{SPACE:rf(of.RightColumnRef),SYMBOL:rf(of.Found,(e=>zo(e.value))),REFERENCE:rf(of.Found,(e=>Wo(e.value)))},[of.RightRowRef]:{SPACE:rf(of.RightRowRef),NUMBER:rf(of.Found),REFERENCE:rf(of.Found,(e=>Wo(e.value))),SYMBOL:rf(of.Found,(e=>$o(e.value)))},[of.Found]:{}};function lf(e){let t=0,o=af[of.LeftRef],s="";for(;void 0!==o;){const i=e[t++];if(!i)return null;const r=o[i.type]?.find((e=>e.guard(i))),n=r?r.goTo:void 0;switch(n){case void 0:return null;case of.Found:return s+=i.value,e.splice(0,t),{type:"REFERENCE",value:s};default:o=af[n],s+=i.value}}return null}function cf(e,t=bi){const o=ma(e,t),s=[];for(;o.length;)s.push(lf(o)||o.shift());return s}const hf=/[a-zA-Z0-9\_]+(\.[a-zA-Z0-9\_]+)*/,df=["-","+"],uf=["%"],gf=["*","+","&"],pf={"^":30,"%":30,"*":20,"/":20,"+":15,"-":15,"&":13,">":10,"<>":10,">=":10,"<":10,"<=":10,"=":10};function mf(e){const t=e.shift();if(!t)throw new Ti;switch(t.type){case"DEBUGGER":const o=bf(e,1e3);return o.debug=!0,o;case"NUMBER":return{type:"NUMBER",value:oi(t.value,bi)};case"STRING":return{type:"STRING",value:He(t.value)};case"INVALID_REFERENCE":return{type:"REFERENCE",value:xi.InvalidReference};case"REFERENCE":if(":"===e[0]?.value&&"REFERENCE"===e[1]?.type){e.shift();const o=e.shift();return{type:"REFERENCE",value:`${t.value}:${o?.value}`}}return{type:"REFERENCE",value:t.value};case"SYMBOL":const s=t.value,i=e[0];if("LEFT_PAREN"===i?.type&&hf.test(t.value)&&s===$e(s,"'")){const t=function(e){vf(e,"LEFT_PAREN",Oo("Missing opening parenthesis"));const t=e[0];if("RIGHT_PAREN"===t?.type)return vf(e,"RIGHT_PAREN"),[];const o=[];o.push(ff(e));for(;"RIGHT_PAREN"!==e[0]?.type;)vf(e,"ARG_SEPARATOR",Oo("Wrong function call")),o.push(ff(e));return vf(e,"RIGHT_PAREN"),o}(e);return{type:"FUNCALL",value:s,args:t}}const r=s.toUpperCase();return"TRUE"===r||"FALSE"===r?{type:"BOOLEAN",value:"TRUE"===r}:{type:"SYMBOL",value:$e(t.value,"'")};case"LEFT_PAREN":const n=bf(e);return vf(e,"RIGHT_PAREN",Oo("Missing closing parenthesis")),n;case"OPERATOR":const a=t.value;if(df.includes(a))return{type:"UNARY_OPERATION",value:a,operand:bf(e,pf[a])};throw new Ti(Oo("Unexpected token: %s",t.value));default:throw new Ti(Oo("Unexpected token: %s",t.value))}}function ff(e){const t=e[0];return"ARG_SEPARATOR"===t?.type||"RIGHT_PAREN"===t?.type?{type:"EMPTY",value:""}:bf(e)}function vf(e,t,o){const s=e.shift();if(!s||s.type!==t)throw new Ti(o)}function bf(e,t=0){if(0===e.length)throw new Ti;let o=mf(e);for(;"OPERATOR"===e[0]?.type&&pf[e[0].value]>t;){const t=e.shift().value;if(uf.includes(t))o={type:"UNARY_OPERATION",value:t,operand:o,postfix:!0};else{o={type:"BIN_OPERATION",value:t,left:o,right:bf(e,pf[t])}}}return o}function Sf(e){return yf(cf(e))}function yf(e){e=e.filter((e=>"SPACE"!==e.type)),"="===e[0]?.value&&e.splice(0,1);const t=bf(e);if(e.length)throw new Ti;return t}function Cf(e,t,o){return xf(e,(e=>e.type===t?o(e):e))}function wf(e){return Array.from(Ef(e))}function*Ef(e){switch(yield e,e.type){case"FUNCALL":for(const t of e.args)yield*Ef(t);break;case"UNARY_OPERATION":yield*Ef(e.operand);break;case"BIN_OPERATION":yield*Ef(e.left),yield*Ef(e.right)}}function xf(e,t){switch((e=t(e)).type){case"FUNCALL":return{...e,args:e.args.map((e=>xf(e,t)))};case"UNARY_OPERATION":return{...e,operand:xf(e.operand,t)};case"BIN_OPERATION":return{...e,right:xf(e.right,t),left:xf(e.left,t)};default:return e}}function If(e){switch(e.type){case"FUNCALL":const t=e.args.map((e=>If(e)));return`${e.value}(${t.join(",")})`;case"NUMBER":return e.value.toString();case"REFERENCE":default:return e.value;case"STRING":return`"${e.value}"`;case"BOOLEAN":return e.value?"TRUE":"FALSE";case"UNARY_OPERATION":return e.postfix?Rf(e)+e.value:e.value+Tf(e);case"BIN_OPERATION":return Rf(e)+e.value+Tf(e)}}function Rf(e){const t=e.value,o="left"in e?e.left:e.operand,s=o.value;return"BIN_OPERATION"===o.type&&pf[s]<pf[t]?`(${If(o)})`:If(o)}function Tf(e){const t=e.value,o="right"in e?e.right:e.operand,s=pf[o.value],i=pf[t];let r=!1;return"BIN_OPERATION"!==o.type?r=!1:s<i?r=!0:s!==i||gf.includes(t)||(r=!0),r?`(${If(o)})`:If(o)}function Af(e,t){return function(e){for(const t of e)if(t.functionContext){const{argsTokens:e,args:o}=t.functionContext;if(delete t.functionContext.argsTokens,o.length||!e)continue;"LEFT_PAREN"===e[0]?.[0]?.type&&(e[0]=e[0].slice(1));for(const t of e){let e=t;"ARG_SEPARATOR"===e.at(-1)?.type&&(e=e.slice(0,-1));try{o.push(yf(e))}catch(e){o.push(void 0)}}}return e}(function(e){let t=[],o="";function s(e){if(0===t.length)return;const o=t.at(-1);if(o&&o.argsTokens){const{argsTokens:t,argPosition:s}=o;t[s]||(t[s]=[]),t[s].push({value:e.value,type:e.type})}}return e.map(((e,i)=>{switch(["SPACE","LEFT_PAREN"].includes(e.type)||(o=""),e.type){case"SYMBOL":s(e),o=e.value;break;case"LEFT_PAREN":t.push({parent:o,argPosition:0,argsTokens:[],args:[]}),s(e),o="";break;case"RIGHT_PAREN":const i=t.pop();i?.argsTokens?.flat().forEach(s),s(e);break;case"ARG_SEPARATOR":s(e),t.length&&t[t.length-1].argPosition++;break;default:s(e)}if(t.length){const o=t[t.length-1];o.parent&&(e.functionContext=Object.assign({},o))}return e}))}(function(e){let t=[],o=0;return e.map(((s,i)=>{if("LEFT_PAREN"===s.type){t.push(o+1),o=0;for(let o=i-1;o>=0;o--){if("SPACE"!==e[o].type){"SYMBOL"===e[o].type&&(e[o].parenthesesCode=t.join(":"));break}e[o].parenthesesCode=t.join(":")}}return s.parenthesesCode=t.join(":"),"RIGHT_PAREN"===s.type&&t.length&&(o=t.pop()),s}))}(function(e){let t=0;return e.map((e=>{const o=e.value.toString().length,s=Object.assign({},e,{start:t,end:t+o,length:o});return t=s.end,s}))}(cf(e,t)))))}function _f(e){if("REFERENCE"!==e.type)return e;const{xc:t,sheetName:o}=Go(e.value),[s,i]=t.split(":"),r=Df(s),n=i?`:${Df(i)}`:"";return{...e,value:qo(o,r+n)}}function Df(e){switch(function(e){if(function(e){return e.startsWith("$")&&e.length>1&&e.slice(1).includes("$")}(e))return"colrow";if(function(e){return e.startsWith("$")}(e))return"col";if(function(e){return e.includes("$",1)}(e))return"row";return"none"}(e)){case"none":e=Of(e,"colrow");break;case"colrow":e=Of(e,"row");break;case"row":e=Of(e,"col");break;case"col":e=Of(e,"none")}return e}function Of(e,t){if(e.includes("!"))throw new Error("The given XC should not contain a sheet name");let o;switch(e=e.replace(/\$/g,""),t){case"col":return"$"+e;case"row":return o=e.search(/[0-9]/),e.slice(0,o)+"$"+e.slice(o);case"colrow":return o=e.search(/[0-9]/),-1===o||0===o?"$"+e:"$"+(e=e.slice(0,o)+"$"+e.slice(o));case"none":return e}}function Ff(e,t,o){const s=(t.startsWith("=")?Af(t,o):[]).filter((t=>t.start<=e.start&&t.end>=e.start||t.start>=e.start&&t.start<e.end)),i=s.filter((e=>"REFERENCE"===e.type));if(0===i.length)return;const r=s.map(_f).map((e=>e.value)).join(""),n=s[0].start,a=s[s.length-1].end,l=t.slice(0,n)+r+t.slice(a),c=l.length-t.length,h={start:i[0].start,end:i[i.length-1].end+c};return 1===i.length&&e.start===e.end&&(h.start=h.end),{content:l,selection:h}}const Mf=["address","col","contents","format","row","type"],Pf={description:Oo("Gets information about a cell."),args:[wh("info_type (string)",Oo("The type of information requested. Can be one of %s",Mf.join(", "))),wh("reference (meta)",Oo("The reference to the cell."))],compute:function(e,t){const o=Gi(e).toLowerCase();Mi((()=>Mf.includes(o)),Oo("The info_type should be one of %s.",Mf.join(", ")));const s=this.__originSheetId,i=Gi(t),r=i.includes(":")?i.split(":")[0]:i;let{sheetName:n,xc:a}=Go(r);n=n===this.getters.getSheetName(s)?void 0:n;const l=qo(n,Of(a,"colrow")),c=this.getters.getRangeFromSheetXC(s,l);switch(o){case"address":return this.getters.getRangeString(c,s);case"col":return c.zone.left+1;case"contents":{const e={sheetId:c.sheetId,col:c.zone.left,row:c.zone.top};return this.getters.getEvaluatedCell(e).value}case"format":{const e={sheetId:c.sheetId,col:c.zone.left,row:c.zone.top};return this.getters.getEvaluatedCell(e).format||""}case"row":return c.zone.top+1;case"type":{const e={sheetId:c.sheetId,col:c.zone.left,row:c.zone.top},t=this.getters.getEvaluatedCell(e).type;return t===ii.empty?"b":t===ii.text?"l":"v"}}return""},isExported:!0},Nf={description:Oo("Whether a value is an error other than #N/A."),args:[wh("value (any)",Oo("The value to be verified as an error type."))],compute:function(e){const t=e?.value;return Ni(t)&&t!==xi.NotAvailable},isExported:!0},kf={description:Oo("Whether a value is an error."),args:[wh("value (any)",Oo("The value to be verified as an error type."))],compute:function(e){const t=e?.value;return Ni(t)},isExported:!0},Lf={description:Oo("Whether a value is `true` or `false`."),args:[wh("value (any)",Oo("The value to be verified as a logical TRUE or FALSE."))],compute:function(e){return"boolean"==typeof e?.value},isExported:!0},Vf={description:Oo("Whether a value is the error #N/A."),args:[wh("value (any)",Oo("The value to be verified as an error type."))],compute:function(e){return e?.value===xi.NotAvailable},isExported:!0},Hf={description:Oo("Whether a value is non-textual."),args:[wh("value (any)",Oo("The value to be checked."))],compute:function(e){return!Bf.compute.bind(this)(e)},isExported:!0},Uf={description:Oo("Whether a value is a number."),args:[wh("value (any)",Oo("The value to be verified as a number."))],compute:function(e){return"number"==typeof e?.value},isExported:!0},Bf={description:Oo("Whether a value is text."),args:[wh("value (any)",Oo("The value to be verified as text."))],compute:function(e){return"string"==typeof e?.value&&!1===Ni(e?.value)},isExported:!0},zf={description:Oo("Whether the referenced cell is empty"),args:[wh("value (any)",Oo("Reference to the cell that will be checked for emptiness."))],compute:function(e){return null===e?.value},isExported:!0},$f={description:Oo("Returns the error value #N/A."),args:[],compute:function(){return{value:xi.NotAvailable}},isExported:!0};var Wf=Object.freeze({__proto__:null,CELL:Pf,ISBLANK:zf,ISERR:Nf,ISERROR:kf,ISLOGICAL:Lf,ISNA:Vf,ISNONTEXT:Hf,ISNUMBER:Uf,ISTEXT:Bf,NA:$f});const Gf={description:Oo("Logical `and` operator."),args:[wh("logical_expression1 (boolean, range<boolean>)",Oo("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.")),wh("logical_expression2 (boolean, range<boolean>, repeating)",Oo("More expressions that represent logical values."))],compute:function(...e){const{result:t,foundBoolean:o}=$a(e);return Mi((()=>o),Oo("[[FUNCTION_NAME]] has no valid input data.")),t},isExported:!0},qf={description:Oo("Logical value `false`."),args:[],compute:function(){return!1},isExported:!0},Zf={description:Oo("Returns value depending on logical expression."),args:[wh("logical_expression (boolean)",Oo("An expression or reference to a cell containing an expression that represents some logical value, i.e. TRUE or FALSE.")),wh("value_if_true (any)",Oo("The value the function returns if logical_expression is TRUE.")),wh("value_if_false (any, default=FALSE)",Oo("The value the function returns if logical_expression is FALSE."))],compute:function(e,t,o){const s=ji(e?.value)?t:o;return void 0===s?{value:""}:(null===s.value&&(s.value=""),s)},isExported:!0},jf={description:Oo("Value if it is not an error, otherwise 2nd argument."),args:[wh("value (any)",Oo("The value to return if value itself is not an error.")),wh('value_if_error (any, default="empty")',Oo("The value the function returns if value is an error."))],compute:function(e,t={value:""}){const o=Ni(e?.value)?t:e;return void 0===o?{value:""}:(null===o.value&&(o.value=""),o)},isExported:!0},Yf={description:Oo("Value if it is not an #N/A error, otherwise 2nd argument."),args:[wh("value (any)",Oo("The value to return if value itself is not #N/A an error.")),wh('value_if_error (any, default="empty")',Oo("The value the function returns if value is an #N/A error."))],compute:function(e,t={value:""}){const o=e?.value===xi.NotAvailable?t:e;return void 0===o?{value:""}:(null===o.value&&(o.value=""),o)},isExported:!0},Xf={description:Oo("Returns a value depending on multiple logical expressions."),args:[wh("condition1 (boolean)",Oo("The first condition to be evaluated. This can be a boolean, a number, an array, or a reference to any of those.")),wh("value1 (any)",Oo("The returned value if condition1 is TRUE.")),wh("condition2 (boolean, any, repeating)",Oo("Additional conditions to be evaluated if the previous ones are FALSE.")),wh("value2 (any, repeating)",Oo("Additional values to be returned if their corresponding conditions are TRUE."))],compute:function(...e){Mi((()=>e.length%2==0),Oo("Wrong number of arguments. Expected an even number of arguments."));for(let t=0;t<e.length-1;t+=2)if(ji(e[t]?.value)){const o=e[t+1];return void 0===o?{value:""}:(null===o.value&&(o.value=""),o)}return new Ri(Oo("No match."))},isExported:!0},Kf={description:Oo("Returns opposite of provided logical value."),args:[wh("logical_expression (boolean)",Oo("An expression or reference to a cell holding an expression that represents some logical value."))],compute:function(e){return!ji(e)},isExported:!0},Jf={description:Oo("Logical `or` operator."),args:[wh("logical_expression1 (boolean, range<boolean>)",Oo("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.")),wh("logical_expression2 (boolean, range<boolean>, repeating)",Oo("More expressions that evaluate to logical values."))],compute:function(...e){const{result:t,foundBoolean:o}=Wa(e);return Mi((()=>o),Oo("[[FUNCTION_NAME]] has no valid input data.")),t},isExported:!0},Qf={description:Oo("Logical value `true`."),args:[],compute:function(){return!0},isExported:!0},ev={description:Oo("Logical `xor` operator."),args:[wh("logical_expression1 (boolean, range<boolean>)",Oo("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.")),wh("logical_expression2 (boolean, range<boolean>, repeating)",Oo("More expressions that evaluate to logical values."))],compute:function(...e){let t=!1,o=!1;return ar(e,(e=>(t=!0,o=o?!e:e,!0))),Mi((()=>t),Oo("[[FUNCTION_NAME]] has no valid input data.")),o},isExported:!0};var tv=Object.freeze({__proto__:null,AND:Gf,FALSE:qf,IF:Zf,IFERROR:jf,IFNA:Yf,IFS:Xf,NOT:Kf,OR:Jf,TRUE:Qf,XOR:ev});function ov(e,t){const o=t.getPivotId(e);if(!o)throw new Ri(Oo('There is no pivot with id "%s"',e));return o}function sv(e){if(e.length%2!=0)throw new Ri(Oo("Function PIVOT takes an even number of arguments."))}function iv(e,t,o){const s=[];if("SPREADSHEET"===t.type&&t.dataSet){const{sheetId:o,zone:i}=t.dataSet,r=Ko(i),n=e.getters.getRangeFromSheetXC(o,r);if(void 0===n||n.invalidXc||n.invalidSheetName)throw new Ai;s.push(n)}for(const t of o)if(t.computedBy){const o=e.getters.getMeasureCompiledFormula(t);s.push(...o.dependencies.filter((e=>!e.invalidXc)))}const i=e.__originCellPosition;i&&s.length&&(e.updateDependencies?.(i),e.addDependencies?.(i,s))}const rv=!0;function nv(e){return{value:xi.NotAvailable,message:Oo("Did not find value '%s' in [[FUNCTION_NAME]] evaluation.",Gi(e))}}const av={description:Oo("Returns a cell reference as a string. "),args:[wh("row (number)",Oo("The row number of the cell reference. ")),wh("column (number)",Oo("The column number (not name) of the cell reference. A is column number 1. ")),wh("absolute_relative_mode (number, default=1)",Oo("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).")),wh("use_a1_notation (boolean, default=TRUE)",Oo("A boolean indicating whether to use A1 style notation (TRUE) or R1C1 style notation (FALSE).")),wh("sheet (string, optional)",Oo("A string indicating the name of the sheet into which the address points."))],compute:function(e,t,o={value:1},s={value:!0},i){const r=zi(e,this.locale),n=zi(t,this.locale);$i(r),$i(n);const a=zi(o,this.locale);var l,c;Mi((()=>[1,2,3,4].includes(a)),(l=4,c=a,Oo("The function [[FUNCTION_NAME]] expects a number value between %s and %s inclusive, but receives %s.",1..toString(),l.toString(),c.toString())));let h;if(ji(s)){h=So(n-1,r-1,{rowFixed:[1,2].includes(a),colFixed:[1,3].includes(a)})}else{h=([1,2].includes(a)?`R${r}`:`R[${r}]`)+([1,3].includes(a)?`C${n}`:`C[${n}]`)}return void 0!==i?qo(Gi(i),h):h},isExported:!0},lv={description:Oo("Column number of a specified cell."),args:[wh("cell_reference (meta, default='this cell')",Oo("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(Ni(e?.value))return e;const t=void 0===e?this.__originCellPosition?.col:jo(e.value).left;return Mi((()=>void 0!==t),"In this context, the function [[FUNCTION_NAME]] needs to have a cell or range in parameter."),t+1},isExported:!0},cv={description:Oo("Number of columns in a specified array or range."),args:[wh("range (meta)",Oo("The range whose column count will be returned."))],compute:function(e){if(Ni(e?.value))return e;const t=jo(e.value);return t.right-t.left+1},isExported:!0},hv={description:Oo("Horizontal lookup"),args:[wh("search_key (string, number, boolean)",Oo("The value to search for. For example, 42, 'Cats', or I24.")),wh("range (any, range)",Oo("The range to consider for the search. The first row in the range is searched for the key specified in search_key.")),wh("index (number)",Oo("The row index of the value to be returned, where the first row in range is numbered 1.")),wh("is_sorted (boolean, default=true)",Oo("Indicates whether the row to be searched (the first row of the specified range) is sorted, in which case the closest match for search_key will be returned."))],compute:function(e,t,o,s={value:rv}){const i=Math.trunc(Li(o?.value,this.locale)),r=fr(t);Mi((()=>1<=i&&i<=r[0].length),Oo("[[FUNCTION_NAME]] evaluates to an out of bounds range."));const n=(e,t)=>e[t][0].value,a=ji(s.value)?ur(r,e,"nextSmaller","asc",r.length,n):gr(r,e,"wildcard",r.length,n),l=r[a];return void 0===l?nv(e):l[i-1]},isExported:!0},dv={description:Oo("Returns the content of a cell, specified by row and column offset."),args:[wh("reference (any, range)",Oo("The range of cells from which the values are returned.")),wh("row (number, default=0)",Oo("The index of the row to be returned from within the reference range of cells.")),wh("column (number, default=0)",Oo("The index of the column to be returned from within the reference range of cells."))],compute:function(e,t={value:0},o={value:0}){const s=fr(e),i=Li(t.value,this.locale),r=Li(o.value,this.locale);return Mi((()=>r>=0&&r-1<s.length&&i>=0&&i-1<s[0].length),Oo("Index out of range.")),0===i&&0===r?s:0===i?[s[r-1]]:0===r?s.map((e=>[e[i-1]])):s[r-1][i-1]},isExported:!0},uv={description:Oo("Returns the content of a cell, specified by a string."),args:[wh("reference (string)",Oo("The range of cells from which the values are returned.")),wh("use_a1_notation (boolean, default=TRUE)",Oo("A boolean indicating whether to use A1 style notation (TRUE) or R1C1 style notation (FALSE)."))],compute:function(e,t={value:!0}){let o=e?.value?.toString();if(!o)return new Ai(Oo("Reference should be defined."));if(!ji(t))return new Ri(Oo("R1C1 notation is not supported."));const s=this.__originSheetId,i=this.__originCellPosition;i&&this.updateDependencies?.(i);const r=this.getters.getRangeFromSheetXC(s,o);if(void 0===r||r.invalidXc||r.invalidSheetName)return new Ai;i&&this.addDependencies?.(i,[r]);const n=[];for(let e=r.zone.left;e<=r.zone.right;e++){const t=[];for(let o=r.zone.top;o<=r.zone.bottom;o++){const s={sheetId:r.sheetId,col:e,row:o};t.push(this.getters.getEvaluatedCell(s))}n.push(t)}return 1===n.length&&1===n[0].length?n[0][0]:n},isExported:!0},gv={description:Oo("Look up a value."),args:[wh("search_key (string, number, boolean)",Oo("The value to search for. For example, 42, 'Cats', or I24.")),wh("search_array (any, range)",Oo("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.")),wh("result_range (any, range, optional)",Oo("The range from which to return a result. The value returned corresponds to the location where search_key is found in search_range. This range must be only a single row or column and should not be used if using the search_result_array method."))],compute:function(e,t,o){const s=fr(t),i=fr(o);let r=s.length,n=s[0].length;const a=n>=r,l=a?(e,t)=>e[0][t].value:(e,t)=>e[t][0].value,c=ur(s,e,"nextSmaller","asc",a?n:r,l);return-1===c||a&&void 0===s[0][c]||!a&&void 0===s[c][n-1]?nv(e):0===i[0].length?a?s[r-1][c]:s[c][n-1]:(r=i.length,n=i[0].length,Mi((()=>1===r||1===n),Oo("The result_range must be a single row or a single column.")),r>1?(Mi((()=>c<=r-1),Oo("[[FUNCTION_NAME]] evaluates to an out of range row value %s.",(c+1).toString())),i[c][0]):(Mi((()=>c<=n-1),Oo("[[FUNCTION_NAME]] evaluates to an out of range column value %s.",(c+1).toString())),i[0][c]))},isExported:!0},pv={description:Oo("Position of item in range that matches value."),args:[wh("search_key (string, number, boolean)",Oo("The value to search for. For example, 42, 'Cats', or I24.")),wh("range (any, range)",Oo("The one-dimensional array to be searched.")),wh("search_type (number, default=1)",Oo("The search method. 1 (default) finds the largest value less than or equal to search_key when range is sorted in ascending order. 0 finds the exact value when range is unsorted. -1 finds the smallest value greater than or equal to search_key when range is sorted in descending order."))],compute:function(e,t,o={value:1}){let s=Li(o,this.locale);const i=fr(t),r=i.length,n=i[0].length;Mi((()=>1===r||1===n),Oo("The range must be a single row or a single column."));let a=-1;const l=1===r?(e,t)=>e[0][t].value:(e,t)=>e[t][0].value,c=1===r?i[0].length:i.length;switch(s=Math.sign(s),s){case 1:a=ur(i,e,"nextSmaller","asc",c,l);break;case 0:a=gr(i,e,"wildcard",c,l);break;case-1:a=ur(i,e,"nextGreater","desc",c,l)}return 1===r&&void 0===i[0][a]||1!==r&&void 0===i[a]?nv(e):a+1},isExported:!0},mv={description:Oo("Row number of a specified cell."),args:[wh("cell_reference (meta, default='this cell')",Oo("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(Ni(e?.value))return e;const t=void 0===e?this.__originCellPosition?.row:jo(e.value).top;return Mi((()=>void 0!==t),"In this context, the function [[FUNCTION_NAME]] needs to have a cell or range in parameter."),t+1},isExported:!0},fv={description:Oo("Number of rows in a specified array or range."),args:[wh("range (meta)",Oo("The range whose row count will be returned."))],compute:function(e){if(Ni(e?.value))return e;const t=jo(e.value);return t.bottom-t.top+1},isExported:!0},vv={description:Oo("Vertical lookup."),args:[wh("search_key (string, number, boolean)",Oo("The value to search for. For example, 42, 'Cats', or I24.")),wh("range (any, range)",Oo("The range to consider for the search. The first column in the range is searched for the key specified in search_key.")),wh("index (number)",Oo("The column index of the value to be returned, where the first column in range is numbered 1.")),wh("is_sorted (boolean, default=true)",Oo("Indicates whether the column to be searched (the first column of the specified range) is sorted, in which case the closest match for search_key will be returned."))],compute:function(e,t,o,s={value:rv}){const i=Math.trunc(Li(o?.value,this.locale)),r=fr(t);Mi((()=>1<=i&&i<=r.length),Oo("[[FUNCTION_NAME]] evaluates to an out of bounds range."));const n=(e,t)=>e[0][t].value,a=ji(s.value)?ur(r,e,"nextSmaller","asc",r[0].length,n):gr(r,e,"wildcard",r[0].length,n),l=r[i-1][a];return void 0===l?nv(e):l},isExported:!0},bv={0:"strict",1:"nextGreater","-1":"nextSmaller",2:"wildcard"},Sv={description:Oo("Search a range for a match and return the corresponding item from a second range."),args:[wh("search_key (string,number,boolean)",Oo("The value to search for.")),wh("lookup_range (any, range)",Oo("The range to consider for the search. Should be a single column or a single row.")),wh("return_range (any, range)",Oo("The range containing the return value. Should have the same dimensions as lookup_range.")),wh("if_not_found (any, optional)",Oo("If a valid match is not found, return this value.")),wh("match_mode (any, default=0)",Oo("(0) Exact match. (-1) Return next smaller item if no match. (1) Return next greater item if no match. (2) Wildcard match.")),wh("search_mode (any, default=1)",Oo("(1) Search starting at first item. (-1) Search starting at last item. (2) Perform a binary search that relies on lookup_array being sorted in ascending order. If not sorted, invalid results will be returned. (-2) Perform a binary search that relies on lookup_array being sorted in descending order. If not sorted, invalid results will be returned. "))],compute:function(e,t,o,s,i={value:0},r={value:1}){const n=Math.trunc(Li(i.value,this.locale)),a=Math.trunc(Li(r.value,this.locale)),l=fr(t),c=fr(o);Mi((()=>1===l.length||1===l[0].length),Oo("lookup_range should be either a single row or single column.")),Mi((()=>[-1,1,-2,2].includes(a)),Oo("search_mode should be a value in [-1, 1, -2, 2].")),Mi((()=>[-1,0,1,2].includes(n)),Oo("match_mode should be a value in [-1, 0, 1, 2]."));const h=1===l.length?"col":"row";Mi((()=>!(2===n&&[-2,2].includes(a))),Oo("the search and match mode combination is not supported for XLOOKUP evaluation.")),Mi((()=>"col"===h?c[0].length===l[0].length:c.length===l.length),Oo("return_range should have the same dimensions as lookup_range."));const d="col"===h?(e,t)=>e[0][t].value:(e,t)=>e[t][0].value,u="col"===h?l[0].length:l.length,g=bv[n],p=-1===a,m=2===a||-2===a?ur(l,e,g,2===a?"asc":"desc",u,d):gr(l,e,g,u,d,p);return-1!==m?"col"===h?c.map((e=>[e[m]])):[c[m]]:void 0===s?nv(e):[[s]]},isExported:!0},yv={description:Oo("Get the value from a pivot."),args:[wh("pivot_id (number,string)",Oo("ID of the pivot.")),wh("measure_name (string)",Oo("Name of the measure.")),wh("domain_field_name (string,optional,repeating)",Oo("Field name.")),wh("domain_value (number,string,boolean,optional,repeating)",Oo("Value."))],compute:function(e,t,...o){const s=Gi(e),i=Gi(t),r=ov(s,this.getters);!function(e,t,o){const{measures:s}=o.getPivotCoreDefinition(e);if(!s.find((e=>e.id===t))){const e=`(${s.map((e=>e.id)).join(", ")})`;throw new Ri(Oo("The argument %s is not a valid measure. Here are the measures: %s",t,e))}}(r,i,this.getters),sv(o);const n=this.getters.getPivot(r),a=this.getters.getPivotCoreDefinition(r);iv(this,a,a.measures.filter((e=>e.id===i))),n.init({reload:n.needsReevaluation});const l=n.assertIsValid({throwOnError:!1});if(l)return l;if(!n.areDomainArgsFieldsValid(o)){const e=Oo("Consider using a dynamic pivot formula: %s. Or re-insert the static pivot from the Data menu.",`=PIVOT(${s})`);return{value:xi.GenericError,message:Oo("Dimensions don't match the pivot definition")+". "+e}}const c=n.parseArgsToPivotDomain(o);return n.getPivotCellValueAndFormat(i,c)}},Cv={description:Oo("Get the header of a pivot."),args:[wh("pivot_id (number,string)",Oo("ID of the pivot.")),wh("domain_field_name (string,optional,repeating)",Oo("Field name.")),wh("domain_value (number,string,value,optional,repeating)",Oo("Value."))],compute:function(e,...t){const o=Gi(e),s=ov(o,this.getters);sv(t);const i=this.getters.getPivot(s);iv(this,this.getters.getPivotCoreDefinition(s),[]),i.init({reload:i.needsReevaluation});const r=i.assertIsValid({throwOnError:!1});if(r)return r;if(!i.areDomainArgsFieldsValid(t)){const e=Oo("Consider using a dynamic pivot formula: %s. Or re-insert the static pivot from the Data menu.",`=PIVOT(${o})`);return{value:xi.GenericError,message:Oo("Dimensions don't match the pivot definition")+". "+e}}const n=i.parseArgsToPivotDomain(t),a=n.at(-1);if("measure"===a?.field)return i.getPivotMeasureValue(Gi(a.value),n);const{value:l,format:c}=i.getPivotHeaderValueAndFormat(n);return{value:l,format:a&&"measure"!==a.field&&"false"!==a.value?c:void 0}}},wv={description:Oo("Get a pivot table."),args:[wh("pivot_id (string)",Oo("ID of the pivot.")),wh("row_count (number, optional)",Oo("number of rows")),wh("include_total (boolean, default=TRUE)",Oo("Whether to include total/sub-totals or not.")),wh("include_column_titles (boolean, default=TRUE)",Oo("Whether to include the column titles or not.")),wh("column_count (number, optional)",Oo("number of columns"))],compute:function(e,t={value:1e4},o={value:!0},s={value:!0},i={value:Number.MAX_VALUE}){const r=Gi(e),n=Li(t,this.locale);if(n<0)return new Ri(Oo("The number of rows must be positive."));const a=Li(i,this.locale);if(a<0)return new Ri(Oo("The number of columns must be positive."));const l=ji(s),c=ji(o),h=ov(r,this.getters),d=this.getters.getPivot(h),u=this.getters.getPivotCoreDefinition(h);iv(this,u,u.measures),d.init({reload:d.needsReevaluation});const g=d.assertIsValid({throwOnError:!1});if(g)return g;const p=d.getTableStructure(),m=p.getPivotCells(c,l),f=l?p.columns.length:0,v=this.getters.getPivotDisplayName(h),b=Math.min(f+n,m[0].length);if(0===b)return[[{value:v}]];const S=Math.min(1+a,m.length),y=[];for(const e of Ze(0,S)){y[e]=[];for(const t of Ze(0,b)){const o=m[e][t];switch(o.type){case"EMPTY":y[e].push({value:""});break;case"HEADER":const t=d.getPivotHeaderValueAndFormat(o.domain);y[e].push(rc(d,o.domain,t));break;case"MEASURE_HEADER":y[e].push(d.getPivotMeasureValue(o.measure,o.domain));break;case"VALUE":y[e].push(d.getPivotCellValueAndFormat(o.measure,o.domain))}}}return l&&(y[0][0]={value:v}),y}},Ev={description:Oo("Returns a range reference shifted by a specified number of rows and columns from a starting cell reference."),args:[wh("cell_reference (meta)",Oo("The starting point from which to count the offset rows and columns.")),wh("offset_rows (number)",Oo("The number of rows to offset by.")),wh("offset_columns (number)",Oo("The number of columns to offset by.")),wh("height (number, default='height of cell_reference')",Oo("The number of rows of the range to return starting at the offset target.")),wh("width (number, default='width of cell_reference')",Oo("The number of columns of the range to return starting at the offset target."))],compute:function(e,t,o,s,i){if(Ni(e?.value))return e;const r=e?.value;if(!r)throw new Error("In this context, the function OFFSET needs to have a cell or range in parameter.");const n=jo(r);let a=n.bottom-n.top+1,l=n.right-n.left+1;if(s){const e=Li(s,this.locale);Rh(Oo("Height value is %(_height)s. It should be greater than or equal to 1.",{_height:e}),e),a=e}if(i){const e=Li(i,this.locale);Rh(Oo("Width value is %(_width)s. It should be greater than or equal to 1.",{_width:e}),e),l=e}const{sheetName:c}=Go(r),h=c&&this.getters.getSheetIdByName(c)||this.getters.getActiveSheetId(),d=Li(t,this.locale),u=Li(o,this.locale),g=this.__originCellPosition;g&&this.updateDependencies?.(g);const p=n.left+u,m=n.top+d;if(p<0||m<0)return new Ai(Oo("OFFSET evaluates to an out of bounds range."));const f={left:p,top:m,right:p+l-1,bottom:m+a-1},v=this.getters.getRangeFromZone(this.__originSheetId,f);return v.invalidXc||v.invalidSheetName?new Ai:(g&&this.addDependencies?.(g,[v]),ir(l,a,((e,t)=>this.getters.getEvaluatedCell({sheetId:h,col:p+e,row:m+t}))))}};var xv=Object.freeze({__proto__:null,ADDRESS:av,COLUMN:lv,COLUMNS:cv,HLOOKUP:hv,INDEX:dv,INDIRECT:uv,LOOKUP:gv,MATCH:pv,OFFSET:Ev,PIVOT:wv,PIVOT_HEADER:Cv,PIVOT_VALUE:yv,ROW:mv,ROWS:fv,VLOOKUP:vv,XLOOKUP:Sv});const Iv={description:Oo("Sum of two numbers."),args:[wh("value1 (number)",Oo("The first addend.")),wh("value2 (number)",Oo("The second addend."))],compute:function(e,t){return{value:Li(e,this.locale)+Li(t,this.locale),format:e?.format||t?.format}}},Rv={description:Oo("Concatenation of two values."),args:[wh("value1 (string)",Oo("The value to which value2 will be appended.")),wh("value2 (string)",Oo("The value to append to value1."))],compute:function(e,t){return Gi(e)+Gi(t)},isExported:!0},Tv={description:Oo("One number divided by another."),args:[wh("dividend (number)",Oo("The number to be divided.")),wh("divisor (number)",Oo("The number to divide by."))],compute:function(e,t){const o=Li(t,this.locale);return Mi((()=>0!==o),Oo("The divisor must be different from zero."),xi.DivisionByZero),{value:Li(e,this.locale)/o,format:e?.format||t?.format}}};function Av(e){return void 0===e||null===e.value}const _v={number:0,string:"",boolean:!1},Dv={description:Oo("Equal."),args:[wh("value1 (string, number, boolean)",Oo("The first value.")),wh("value2 (string, number, boolean)",Oo("The value to test against value1 for equality."))],compute:function(e,t){if(Ni(e?.value))return e;if(Ni(t?.value))return t;let o=Av(e)?_v[typeof t?.value]:e?.value,s=Av(t)?_v[typeof e?.value]:t?.value;return"string"==typeof o&&(o=o.toUpperCase()),"string"==typeof s&&(s=s.toUpperCase()),{value:o===s}}};function Ov(e,t,o){if(Ni(e?.value))return e;if(Ni(t?.value))return t;let s=Av(e)?_v[typeof t?.value]:e?.value,i=Av(t)?_v[typeof e?.value]:t?.value;"number"!=typeof s&&(s=Gi(s).toUpperCase()),"number"!=typeof i&&(i=Gi(i).toUpperCase());const r=typeof s,n=typeof i;return"string"===r&&"number"===n?{value:!0}:"string"===n&&"number"===r?{value:!1}:{value:o(s,i)}}const Fv={description:Oo("Strictly greater than."),args:[wh("value1 (number, string, boolean)",Oo("The value to test as being greater than value2.")),wh("value2 (number, string, boolean)",Oo("The second value."))],compute:function(e,t){return Ov(e,t,((e,t)=>e>t))}},Mv={description:Oo("Greater than or equal to."),args:[wh("value1 (number, string, boolean)",Oo("The value to test as being greater than or equal to value2.")),wh("value2 (number, string, boolean)",Oo("The second value."))],compute:function(e,t){return Ov(e,t,((e,t)=>e>=t))}},Pv={description:Oo("Less than."),args:[wh("value1 (number, string, boolean)",Oo("The value to test as being less than value2.")),wh("value2 (number, string, boolean)",Oo("The second value."))],compute:function(e,t){const o=Mv.compute.bind(this)(e,t);return Ni(o.value)?o:{value:!o.value}}},Nv={description:Oo("Less than or equal to."),args:[wh("value1 (number, string, boolean)",Oo("The value to test as being less than or equal to value2.")),wh("value2 (number, string, boolean)",Oo("The second value."))],compute:function(e,t){const o=Fv.compute.bind(this)(e,t);return Ni(o.value)?o:{value:!o.value}}},kv={description:Oo("Difference of two numbers."),args:[wh("value1 (number)",Oo("The minuend, or number to be subtracted from.")),wh("value2 (number)",Oo("The subtrahend, or number to subtract from value1."))],compute:function(e,t){return{value:Li(e,this.locale)-Li(t,this.locale),format:e?.format||t?.format}}},Lv={description:Oo("Product of two numbers"),args:[wh("factor1 (number)",Oo("The first multiplicand.")),wh("factor2 (number)",Oo("The second multiplicand."))],compute:function(e,t){return{value:Li(e,this.locale)*Li(t,this.locale),format:e?.format||t?.format}}},Vv={description:Oo("Not equal."),args:[wh("value1 (string, number, boolean)",Oo("The first value.")),wh("value2 (string, number, boolean)",Oo("The value to test against value1 for inequality."))],compute:function(e,t){const o=Dv.compute.bind(this)(e,t);return Ni(o.value)?o:{value:!o.value}}},Hv={description:Oo("A number raised to a power."),args:[wh("base (number)",Oo("The number to raise to the exponent power.")),wh("exponent (number)",Oo("The exponent to raise base to."))],compute:function(e,t){return $d.compute.bind(this)(e,t)}},Uv={description:Oo("A number with the sign reversed."),args:[wh("value (number)",Oo("The number to have its sign reversed. Equivalently, the number to multiply by -1."))],compute:function(e){return{value:-Li(e,this.locale),format:e?.format}}},Bv={description:Oo("Value interpreted as a percentage."),args:[wh("percentage (number)",Oo("The value to interpret as a percentage."))],compute:function(e){return Li(e,this.locale)/100}},zv={description:Oo("A specified number, unchanged."),args:[wh("value (any)",Oo("The number to return."))],compute:function(e={value:null}){return e}};var $v=Object.freeze({__proto__:null,ADD:Iv,CONCAT:Rv,DIVIDE:Tv,EQ:Dv,GT:Fv,GTE:Mv,LT:Pv,LTE:Nv,MINUS:kv,MULTIPLY:Lv,NE:Vv,POW:Hv,UMINUS:Uv,UNARY_PERCENT:Bv,UPLUS:zv});const Wv=e=>({transform:t=>t*e,inverseTransform:t=>t/e}),Gv={transform:e=>e,inverseTransform:e=>e},qv=1e-10,Zv=.0254,jv=Zv/72,Yv=.3048,Xv=.9144,Kv=1609.34,Jv=1852,Qv=946073047258e4,eb={g:{...Gv,category:"weight"},u:{...Wv(166053e-29),category:"weight"},grain:{...Wv(.0647989),category:"weight"},ozm:{...Wv(28.3495),category:"weight"},lbm:{...Wv(453.592),category:"weight"},stone:{...Wv(6350.29),category:"weight"},sg:{...Wv(14593.90294),category:"weight"},cwt:{...Wv(45359.237),category:"weight"},uk_cwt:{...Wv(50802.3),category:"weight"},ton:{...Wv(907184.74),category:"weight"},uk_ton:{...Wv(1016046.9),category:"weight"},m:{...Gv,category:"distance"},km:{...Wv(1e3),category:"distance"},ang:{...Wv(qv),category:"distance"},Picapt:{...Wv(jv),category:"distance"},pica:{...Wv(Zv/6),category:"distance"},in:{...Wv(Zv),category:"distance"},ft:{...Wv(Yv),category:"distance"},yd:{...Wv(Xv),category:"distance"},ell:{...Wv(1.143),category:"distance"},mi:{...Wv(Kv),category:"distance"},survey_mi:{...Wv(1609.34),category:"distance"},Nmi:{...Wv(Jv),category:"distance"},ly:{...Wv(Qv),category:"distance"},parsec:{...Wv(0x6da012f95c9fd0),category:"distance"},sec:{...Gv,category:"time"},min:{...Wv(60),category:"time"},hr:{...Wv(3600),category:"time"},day:{...Wv(86400),category:"time"},yr:{...Wv(31556952),category:"time"},Pa:{...Gv,category:"pressure"},bar:{...Wv(1e5),category:"pressure"},mmHg:{...Wv(133.322),category:"pressure"},Torr:{...Wv(133.322),category:"pressure"},psi:{...Wv(6894.76),category:"pressure"},atm:{...Wv(101325),category:"pressure"},N:{...Gv,category:"force"},dyn:{...Wv(1e-5),category:"force"},pond:{...Wv(.00980665),category:"force"},lbf:{...Wv(4.44822),category:"force"},J:{...Gv,category:"energy"},eV:{...Wv(160218e-24),category:"energy"},e:{...Wv(1e-7),category:"energy"},flb:{...Wv(1.3558179483),category:"energy"},c:{...Wv(4.184),category:"energy"},cal:{...Wv(4.1868),category:"energy"},BTU:{...Wv(1055.06),category:"energy"},Wh:{...Wv(3600),category:"energy"},HPh:{...Wv(2684520),category:"energy"},W:{...Gv,category:"power"},PS:{...Wv(735.499),category:"power"},HP:{...Wv(745.7),category:"power"},T:{...Gv,category:"magnetism"},ga:{...Wv(1e-4),category:"magnetism"},K:{...Gv,category:"temperature"},C:{transform:e=>e+273.15,inverseTransform:e=>e-273.15,category:"temperature"},F:{transform:e=>5*(e-32)/9+273.15,inverseTransform:e=>9*(e-273.15)/5+32,category:"temperature"},Rank:{...Wv(5/9),category:"temperature"},Reau:{transform:e=>1.25*e+273.15,inverseTransform:e=>(e-273.15)/1.25,category:"temperature"},"m^3":{...Gv,category:"volume",order:3},"ang^3":{...Wv(Math.pow(qv,3)),category:"volume",order:3},"Picapt^3":{...Wv(Math.pow(jv,3)),category:"volume",order:3},tsp:{...Wv(492892e-11),category:"volume"},tspm:{...Wv(5e-6),category:"volume"},tbs:{...Wv(14786764825785619e-21),category:"volume"},"in^3":{...Wv(Math.pow(Zv,3)),category:"volume",order:3},oz:{...Wv(295735295625e-16),category:"volume"},cup:{...Wv(237e-6),category:"volume"},pt:{...Wv(.0004731765),category:"volume"},uk_pt:{...Wv(568261e-9),category:"volume"},qt:{...Wv(.0009463529),category:"volume"},l:{...Wv(.001),category:"volume"},uk_qt:{...Wv(.0011365225),category:"volume"},gal:{...Wv(.0037854118),category:"volume"},uk_gal:{...Wv(.00454609),category:"volume"},"ft^3":{...Wv(Math.pow(Yv,3)),category:"volume",order:3},bushel:{...Wv(.0352390704),category:"volume"},barrel:{...Wv(.158987295),category:"volume"},"yd^3":{...Wv(Math.pow(Xv,3)),category:"volume",order:3},MTON:{...Wv(1.13267386368),category:"volume"},GRT:{...Wv(2.83168),category:"volume"},"mi^3":{...Wv(Math.pow(Kv,3)),category:"volume",order:3},"Nmi^3":{...Wv(Math.pow(Jv,3)),category:"volume",order:3},"ly^3":{...Wv(Math.pow(Qv,3)),category:"volume",order:3},"m^2":{...Gv,category:"area",order:2},"ang^2":{...Wv(Math.pow(qv,2)),category:"area",order:2},"Picapt^2":{...Wv(Math.pow(jv,2)),category:"area",order:2},"in^2":{...Wv(Math.pow(Zv,2)),category:"area",order:2},"ft^2":{...Wv(Math.pow(Yv,2)),category:"area",order:2},"yd^2":{...Wv(Math.pow(Xv,2)),category:"area",order:2},ar:{...Wv(100),category:"area"},Morgen:{...Wv(2500),category:"area"},uk_acre:{...Wv(4046.8564224),category:"area"},us_acre:{...Wv(4046.8726098743),category:"area"},ha:{...Wv(1e4),category:"area"},"mi^2":{...Wv(Math.pow(Kv,2)),category:"area",order:2},"Nmi^2":{...Wv(Math.pow(Jv,2)),category:"area",order:2},"ly^2":{...Wv(Math.pow(Qv,2)),category:"area",order:2},bit:{...Gv,category:"information"},byte:{...Wv(8),category:"information"},"m/s":{...Gv,category:"speed"},"m/hr":{...Wv(1/3600),category:"speed"},"km/hr":{...Wv(1/3.6),category:"speed"},mph:{...Wv(.44704),category:"speed"},kn:{...Wv(.5144444444),category:"speed"},admkn:{...Wv(.5147733333),category:"speed"}},tb={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"},ob={"":1,Y:1e24,Z:1e21,E:1e18,P:1e15,T:1e12,G:1e9,M:1e6,k:1e3,h:100,da:10,e:10,d:.1,c:.01,m:.001,u:1e-6,n:1e-9,p:1e-12,f:1e-15,a:1e-18,z:1e-21,y:1e-21,Yi:Math.pow(2,80),Zi:Math.pow(2,70),Ei:Math.pow(2,60),Pi:Math.pow(2,50),Ti:Math.pow(2,40),Gi:Math.pow(2,30),Mi:Math.pow(2,20),ki:Math.pow(2,10)},sb={weight:Oo("Weight"),distance:Oo("Distance"),time:Oo("Time"),pressure:Oo("Pressure"),force:Oo("Force"),energy:Oo("Energy"),power:Oo("Power"),magnetism:Oo("Magnetism"),temperature:Oo("Temperature"),volume:Oo("Volume"),area:Oo("Area"),information:Oo("Information"),speed:Oo("Speed")};function ib(e){return sb[e]??""}function rb(e){for(const[t,o]of Object.entries(ob)){if(t&&!e.startsWith(t))continue;const s=e.slice(t.length);let i=eb[s];if(!i&&tb[s]&&(i=eb[tb[s]]),i)return{...i,factor:i.order?Math.pow(o,i.order):o}}}const nb={description:Oo("Converts a numeric value to a different unit of measure."),args:[wh("value (number)",Oo("the numeric value in start_unit to convert to end_unit")),wh("start_unit (string)",Oo("The starting unit, the unit currently assigned to value")),wh("end_unit (string)",Oo("The unit of measure into which to convert value"))],compute:function(e,t,o){const s=Li(e,this.locale),i=Gi(t),r=Gi(o),n=rb(i),a=rb(r);return n?a?n.category!==a.category?{value:xi.GenericError,message:Oo("Incompatible units of measure ('%s' vs '%s')",ib(n.category),ib(a.category))}:{value:a.inverseTransform(n.factor*n.transform(s))/a.factor,format:e?.format}:{value:xi.GenericError,message:Oo("Invalid units of measure ('%s')",r)}:{value:xi.GenericError,message:Oo("Invalid units of measure ('%s')",i)}},isExported:!0};var ab=Object.freeze({__proto__:null,CONVERT:nb});const lb=/[A-Za-zÀ-ÖØ-öø-ÿ]+/g,cb={description:Oo("Gets character associated with number."),args:[wh("table_number (number)",Oo("The number of the character to look up from the current Unicode table in decimal format."))],compute:function(e){const t=Math.trunc(Li(e,this.locale));return Mi((()=>t>=1),Oo("The table_number (%s) is out of range.",t.toString())),String.fromCharCode(t)},isExported:!0},hb={description:Oo("Remove non-printable characters from a piece of text."),args:[wh("text (string)",Oo("The text whose non-printable characters are to be removed."))],compute:function(e){const t=Gi(e);let o="";for(const e of t)e&&e.charCodeAt(0)>31&&(o+=e);return o},isExported:!0},db={description:Oo("Appends strings to one another."),args:[wh("string1 (string, range<string>)",Oo("The initial string.")),wh("string2 (string, range<string>, repeating)",Oo("More strings to append in sequence."))],compute:function(...e){return tr(e,((e,t)=>e+Gi(t)),"")},isExported:!0},ub={description:Oo("Tests whether two strings are identical."),args:[wh("string1 (string)",Oo("The first string to compare.")),wh("string2 (string)",Oo("The second string to compare."))],compute:function(e,t){return Gi(e)===Gi(t)},isExported:!0},gb={description:Oo("First position of string found in text, case-sensitive."),args:[wh("search_for (string)",Oo("The string to look for within text_to_search.")),wh("text_to_search (string)",Oo("The text to search for the first occurrence of search_for.")),wh("starting_at (number, default=1)",Oo("The character within text_to_search at which to start the search."))],compute:function(e,t,o={value:1}){const s=Gi(e),i=Gi(t),r=Li(o,this.locale);Mi((()=>""!==i),Oo("The text_to_search must be non-empty.")),Mi((()=>r>=1),Oo("The starting_at (%s) must be greater than or equal to 1.",r.toString()));const n=i.indexOf(s,r-1);return Mi((()=>n>=0),Oo("In [[FUNCTION_NAME]] evaluation, cannot find '%s' within '%s'.",s.toString(),i)),n+1},isExported:!0},pb={description:Oo("Concatenates elements of arrays with delimiter."),args:[wh("delimiter (string)",Oo("The character or string to place between each concatenated value.")),wh("value_or_array1 (string, range<string>)",Oo("The value or values to be appended using delimiter.")),wh("value_or_array2 (string, range<string>, repeating)",Oo("More values to be appended using delimiter."))],compute:function(e,...t){const o=Gi(e);return tr(t,((e,t)=>(e?e+o:"")+Gi(t)),"")}},mb={description:Oo("Substring from beginning of specified string."),args:[wh("text (string)",Oo("The string from which the left portion will be returned.")),wh("number_of_characters (number, optional)",Oo("The number of characters to return from the left side of string."))],compute:function(e,...t){const o=t.length?Li(t[0],this.locale):1;return Mi((()=>o>=0),Oo("The number_of_characters (%s) must be positive or null.",o.toString())),Gi(e).substring(0,o)},isExported:!0},fb={description:Oo("Length of a string."),args:[wh("text (string)",Oo("The string whose length will be returned."))],compute:function(e){return Gi(e).length},isExported:!0},vb={description:Oo("Converts a specified string to lowercase."),args:[wh("text (string)",Oo("The string to convert to lowercase."))],compute:function(e){return Gi(e).toLowerCase()},isExported:!0},bb={description:Oo("A segment of a string."),args:[wh("text (string)",Oo("The string to extract a segment from.")),wh("starting_at (number)",Oo("The index from the left of string from which to begin extracting. The first character in string has the index 1.")),wh("extract_length (number)",Oo("The length of the segment to extract."))],compute:function(e,t,o){const s=Gi(e),i=Li(t,this.locale),r=Li(o,this.locale);return Mi((()=>i>=1),Oo("The starting_at argument (%s) must be positive greater than one.",i.toString())),Mi((()=>r>=0),Oo("The extract_length argument (%s) must be positive or null.",r.toString())),s.slice(i-1,i+r-1)},isExported:!0},Sb={description:Oo("Capitalizes each word in a specified string."),args:[wh("text_to_capitalize (string)",Oo("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 Gi(e).replace(lb,(e=>e.charAt(0).toUpperCase()+e.slice(1).toLowerCase()))},isExported:!0},yb={description:Oo("Replaces part of a text string with different text."),args:[wh("text (string)",Oo("The text, a part of which will be replaced.")),wh("position (number)",Oo("The position where the replacement will begin (starting from 1).")),wh("length (number)",Oo("The number of characters in the text to be replaced.")),wh("new_text (string)",Oo("The text which will be inserted into the original text."))],compute:function(e,t,o,s){const i=Li(t,this.locale);Mi((()=>i>=1),Oo("The position (%s) must be greater than or equal to 1.",i.toString()));const r=Gi(e),n=Li(o,this.locale),a=Gi(s);return r.substring(0,i-1)+a+r.substring(i-1+n)},isExported:!0},Cb={description:Oo("A substring from the end of a specified string."),args:[wh("text (string)",Oo("The string from which the right portion will be returned.")),wh("number_of_characters (number, optional)",Oo("The number of characters to return from the right side of string."))],compute:function(e,...t){const o=t.length?Li(t[0],this.locale):1;Mi((()=>o>=0),Oo("The number_of_characters (%s) must be positive or null.",o.toString()));const s=Gi(e),i=s.length;return s.substring(i-o,i)},isExported:!0},wb={description:Oo("First position of string found in text, ignoring case."),args:[wh("search_for (string)",Oo("The string to look for within text_to_search.")),wh("text_to_search (string)",Oo("The text to search for the first occurrence of search_for.")),wh("starting_at (number, default=1)",Oo("The character within text_to_search at which to start the search."))],compute:function(e,t,o={value:1}){const s=Gi(e).toLowerCase(),i=Gi(t).toLowerCase(),r=Li(o,this.locale);Mi((()=>""!==i),Oo("The text_to_search must be non-empty.")),Mi((()=>r>=1),Oo("The starting_at (%s) must be greater than or equal to 1.",r.toString()));const n=i.indexOf(s,r-1);return Mi((()=>n>=0),Oo("In [[FUNCTION_NAME]] evaluation, cannot find '%s' within '%s'.",s,i)),n+1},isExported:!0},Eb={description:Oo("Split text by specific character delimiter(s)."),args:[wh("text (string)",Oo("The text to divide.")),wh("delimiter (string)",Oo("The character or characters to use to split text.")),wh("split_by_each (boolean, default=true})",Oo("Whether or not to divide text around each character contained in delimiter.")),wh("remove_empty_text (boolean, default=true)",Oo("Whether or not to remove empty text messages from the split results. The default behavior is to treat consecutive delimiters as one (if TRUE). If FALSE, empty cells values are added between consecutive delimiters."))],compute:function(e,t,o={value:true},s={value:true}){const i=Gi(e),r=Ue(Gi(t)),n=ji(o),a=ji(s);Mi((()=>r.length>0),Oo("The _delimiter (%s) must be not be empty.",r));const l=n?new RegExp(`[${r}]`,"g"):new RegExp(r,"g");let c=i.split(l);return a&&(c=c.filter((e=>""!==e))),nr([c])},isExported:!0},xb={description:Oo("Replaces existing text with new text in a string."),args:[wh("text_to_search (string)",Oo("The text within which to search and replace.")),wh("search_for (string)",Oo("The string to search for within text_to_search.")),wh("replace_with (string)",Oo("The string that will replace search_for.")),wh("occurrence_number (number, optional)",Oo("The instance of search_for within text_to_search to replace with replace_with. By default, all occurrences of search_for are replaced; however, if occurrence_number is specified, only the indicated instance of search_for is replaced."))],compute:function(e,t,o,s){const i=Li(s,this.locale);Mi((()=>i>=0),Oo("The occurrenceNumber (%s) must be positive or null.",i.toString()));const r=Gi(e),n=Gi(t);if(""===n)return r;const a=Gi(o),l=new RegExp(Ue(n),"g");if(0===i)return r.replace(l,a);let c=0;return r.replace(l,(e=>++c===i?a:e))},isExported:!0},Ib={description:Oo("Combines text from multiple strings and/or arrays."),args:[wh("delimiter (string)",Oo(" A string, possible empty, or a reference to a valid string. If empty, the text will be simply concatenated.")),wh("ignore_empty (boolean)",Oo("A boolean; if TRUE, empty cells selected in the text arguments won't be included in the result.")),wh("text1 (string, range<string>)",Oo("Any text item. This could be a string, or an array of strings in a range.")),wh("text2 (string, range<string>, repeating)",Oo("Additional text item(s)."))],compute:function(e,t,...o){const s=Gi(e),i=ji(t);let r=0;return tr(o,((e,t)=>i&&""===Gi(t)?e:(r++?e+s:"")+Gi(t)),"")},isExported:!0},Rb={description:Oo("Removes space characters."),args:[wh("text (string)",Oo("The text or reference to a cell containing text to be trimmed."))],compute:function(e){return Tt(Gi(e))},isExported:!0},Tb={description:Oo("Converts a specified string to uppercase."),args:[wh("text (string)",Oo("The string to convert to uppercase."))],compute:function(e){return Gi(e).toUpperCase()},isExported:!0},Ab={description:Oo("Converts a number to text according to a specified format."),args:[wh("number (number)",Oo("The number, date or time to format.")),wh("format (string)",Oo("The pattern by which to format the number, enclosed in quotation marks."))],compute:function(e,t){return Xr(Li(e,this.locale),{format:Gi(t),locale:this.locale})},isExported:!0},_b={description:Oo("Converts a string to a numeric value."),args:[wh("value (number)",Oo("the string to be converted"))],compute:function(e){return Li(e,this.locale)},isExported:!0};var Db=Object.freeze({__proto__:null,CHAR:cb,CLEAN:hb,CONCATENATE:db,EXACT:ub,FIND:gb,JOIN:pb,LEFT:mb,LEN:fb,LOWER:vb,MID:bb,PROPER:Sb,REPLACE:yb,RIGHT:Cb,SEARCH:wb,SPLIT:Eb,SUBSTITUTE:xb,TEXT:Ab,TEXTJOIN:Ib,TRIM:Rb,UPPER:Tb,VALUE:_b});const Ob={description:Oo("Creates a hyperlink in a cell."),args:[wh("url (string)",Oo("The full URL of the link enclosed in quotation marks.")),wh("link_label (string, optional)",Oo("The text to display in the cell, enclosed in quotation marks."))],compute:function(e,t){const o=Gi(e).trim(),s=Gi(t)||o;return""===o?s:tt(s,o)},isExported:!0};var Fb=Object.freeze({__proto__:null,HYPERLINK:Ob});const Mb=[{name:Oo("Array"),functions:Jh},{name:Oo("Database"),functions:Pg},{name:Oo("Date"),functions:mp},{name:Oo("Filter"),functions:Tp},{name:Oo("Financial"),functions:sf},{name:Oo("Info"),functions:Wf},{name:Oo("Lookup"),functions:xv},{name:Oo("Logical"),functions:tv},{name:Oo("Math"),functions:du},{name:Oo("Misc"),functions:ed},{name:Oo("Operator"),functions:$v},{name:Oo("Statistical"),functions:Sg},{name:Oo("Text"),functions:Db},{name:Oo("Engineering"),functions:vp},{name:Oo("Web"),functions:Fb},{name:Oo("Parser"),functions:ab}],Pb=/^[A-Z0-9\_\.]+$/;const Nb=new class extends r{mapping={};add(e,t){if(e=e.toUpperCase(),!Pb.test(e))throw new Error(Oo("Invalid function name %s. Function names can exclusively contain alphanumerical values separated by dots (.) or underscore (_)",e));const o=Eh(t);return function(e){let t=!1,o=!1,s=!1;for(let i of e){if(i.type.includes("META")&&i.type.length>1)throw new Error(Oo("Function ${name} has an argument that has been declared with more than one type whose type 'META'. The 'META' type can only be declared alone."));if(t&&!i.repeating)throw new Error(Oo("Function ${name} has no-repeatable arguments declared after repeatable ones. All repeatable arguments must be declared last."));const e=o||t||s,r=!(i.optional||i.repeating||i.default);if(e&&r)throw new Error(Oo("Function ${name} has at mandatory arguments declared after optional ones. All optional arguments must be after all mandatory arguments."));t=i.repeating,o=i.optional,s=i.default}}(o.args),this.mapping[e]=function(e,t){function o(...o){let i,r=1,n=1,a=1/0,l=1/0;for(let s=0;s<o.length;s++){const c=e.args[e.getArgToFocus(s+1)-1],h=o[s];if(yi(h)&&!c.acceptMatrix){const e=h.length,t=h[0].length;1!==e||1!==t?(i??=new Array(o.length),1!==e&&1!==t?(i[s]="matrix",r=Math.max(r,e),n=Math.max(n,t),a=Math.min(a,e),l=Math.min(l,t)):1!==e?(i[s]="horizontal",r=Math.max(r,e),a=Math.min(a,e)):1!==t&&(i[s]="vertical",n=Math.max(n,t),l=Math.min(l,t))):o[s]=h[0][0]}if(!yi(h)&&c.acceptMatrixOnly)throw new Ti(Oo("Function %s expects the parameter '%s' to be reference to a cell or range.",t,(s+1).toString()))}if(1===r&&1===n)return s.apply(this,o);const c=(e,t)=>o.map(((o,s)=>{switch(i?.[s]){case"matrix":return o[e][t];case"horizontal":return o[e][0];case"vertical":return o[0][t];case void 0:return o}}));return ir(r,n,((e,t)=>{if(e>a-1||t>l-1)return kb;const o=s.apply(this,c(e,t));return yi(o)?o[0][0]:o}))}function s(...o){for(let t=0;t<o.length;t++){const s=o[t];if(!e.args[e.getArgToFocus(t+1)-1].acceptErrors&&!yi(s)&&Ni(s?.value))return s}try{return i.apply(this,o)}catch(e){return Lb(e,t)}}function i(...o){this.debug;const s=e.compute.apply(this,o);return yi(s)?"object"==typeof s[0][0]&&null!==s[0][0]&&"value"in s[0][0]?(function(e,t){const o=e.length,s=e[0]?.length??0;for(let i=0;i<o;i++)for(let o=0;o<s;o++)t(e[i][o])}(s,(e=>Vb(e,t))),s):rr(s,(e=>({value:e}))):"object"==typeof s&&null!==s&&"value"in s?(Vb(s,t),s):{value:s}}return o}(o,e),super.add(e,o),this}};for(let e of Mb){const t=e.functions;for(let o in t){const s=t[o];s.category=s.category||e.name,o=o.replace(/_/g,"."),Nb.add(o,{isExported:!1,...s})}}const kb=new _i(Oo("Array arguments to [[FUNCTION_NAME]] are of different size."));function Lb(e,t){return o=e,void 0!==o?.value&&"string"==typeof o.value&&Ni(e.value)?(Ub(e)&&Vb(e,t),e):(console.error(e),new Ri(Hb+(Ub(e)?" "+e.message:"")));var o}function Vb(e,t){e.message?.includes("[[FUNCTION_NAME]]")&&(e.message=e.message.replace("[[FUNCTION_NAME]]",t))}const Hb=Oo("An unexpected error occurred. Submit a support ticket at odoo.com/help.");function Ub(e){return void 0!==e?.message&&"string"==typeof e.message}function Bb(e,t,o){const{x:s,y:i,width:r,height:n}=o;if(r<0||n<0)return;const l=t.color||a,{ctx:c}=e;c.save(),t.noBorder||(t.dashed&&c.setLineDash([5,3]),c.strokeStyle=l,t.thinLine?(c.lineWidth=1,c.strokeRect(s,i,r,n)):(c.lineWidth=2,c.strokeRect(s+.5,i+.5,r,n))),t.noFill||(c.fillStyle=Kt(Ut(l),t.fillAlpha??.12),c.fillRect(s,i,r,n)),c.restore()}bh.add("functions",{sequence:100,autoSelectFirstProposal:!0,maxDisplayedProposals:10,getProposals(e){if("SYMBOL"!==e.type)return[];const t=e.value;if(!this.composer.currentContent.startsWith("="))return[];const o=Object.entries(Nb.content).filter((([e,{hidden:t}])=>!t)).map((([e,{description:o}])=>({text:e,description:o,htmlContent:Sh(t,e,I,"o-semi-bold")}))).sort(((e,t)=>e.text.length-t.text.length||e.text.localeCompare(t.text)));return o},selectProposal(e,t){let o=e.end,s=e.end;["SYMBOL","FUNCTION"].includes(e.type)&&(o=e.start);const i=this.composer.currentTokens;t+="(";const r=i.map((e=>e.start)).indexOf(e.start);if(r+1<i.length){const e=i[r+1];"LEFT_PAREN"===e?.type&&s++}this.composer.changeComposerCursorSelection(o,s),this.composer.replaceComposerCursorSelection(t)}});class zb extends Tc{mutators=["register","unRegister"];providers=[];constructor(e){super(e),this.onDispose((()=>{this.providers=[]}))}get renderingLayers(){return["Highlights"]}get highlights(){const e=this.getters.getActiveSheetId();return this.providers.flatMap((e=>e.highlights)).filter((t=>t.sheetId===e)).map((e=>{const{numberOfRows:t,numberOfCols:o}=ls(e.zone),s=t*o==1?this.getters.expandZone(e.sheetId,e.zone):e.zone;return{...e,zone:s}}))}register(e){this.providers.push(e)}unRegister(e){this.providers=this.providers.filter((t=>t!==e))}drawLayer(e,t){if("Highlights"===t)for(const t of this.highlights){Bb(e,t,this.getters.getVisibleRect(t.zone))}}}class $b{mutators=["notifyUser","raiseError","askConfirmation","updateNotificationCallbacks"];notifyUser=e=>window.alert(e.text);askConfirmation=(e,t,o)=>{window.confirm(e)?t():o?.()};raiseError=(e,t)=>{window.alert(e),t?.()};updateNotificationCallbacks(e){this.notifyUser=e.notifyUser||this.notifyUser,this.raiseError=e.raiseError||this.raiseError,this.askConfirmation=e.askConfirmation||this.askConfirmation}}const Wb="#000000",Gb="#3da4ab",qb={OPERATOR:Gb,NUMBER:"#02c39a",STRING:"#00a82d",FUNCTION:Wb,DEBUGGER:Gb,LEFT_PAREN:Wb,RIGHT_PAREN:Wb,ARG_SEPARATOR:Wb,ORPHAN_RIGHT_PAREN:"#ff0000"};class Zb extends Tc{mutators=["startEdition","setCurrentContent","stopEdition","stopComposerRangeSelection","cancelEdition","cycleReferences","toggleEditionMode","changeComposerCursorSelection","replaceComposerCursorSelection"];col=0;row=0;editionMode="inactive";sheetId="";_currentContent="";currentTokens=[];selectionStart=0;selectionEnd=0;initialContent="";colorIndexByRange={};notificationStore=this.get($b);highlightStore=this.get(zb);constructor(e){super(e),this.highlightStore.register(this),this.onDispose((()=>{this.highlightStore.unRegister(this)}))}handleEvent(e){const t=this.getters.getActiveSheetId();let o;if(o=e.options.unbounded?this.getters.getUnboundedZone(t,e.anchor.zone):e.anchor.zone,"newAnchor"===e.mode)"selecting"===this.editionMode&&this.insertSelectedRange(o);else"selecting"===this.editionMode?this.replaceSelectedRange(o):this.updateComposerRange(e.previousAnchor.zone,o)}changeComposerCursorSelection(e,t){this.isSelectionValid(this._currentContent.length,e,t)&&(this.selectionStart=e,this.selectionEnd=t,this.computeFormulaCursorContext(),this.computeParenthesisRelatedToCursor())}stopComposerRangeSelection(){this.isSelectingRange&&(this.editionMode="editing")}startEdition(e,t){if(t){const o=e||this.getComposerContent(this.getters.getActivePosition());if(!this.isSelectionValid(o.length,t.start,t.end))return}const{col:o,row:s}=this.getters.getActivePosition();this.model.dispatch("SELECT_FIGURE",{id:null}),this.model.dispatch("SCROLL_TO_CELL",{col:o,row:s}),"inactive"!==this.editionMode&&e?this.setContent(e,t):this._startEdition(e,t),this.updateTokenColor(),this.computeFormulaCursorContext(),this.computeParenthesisRelatedToCursor()}cancelEdition(){this.cancelEditionAndActivateSheet(),this.resetContent()}setCurrentContent(e,t){t&&!this.isSelectionValid(e.length,t.start,t.end)||(this.setContent(e,t,!0),this.updateTokenColor(),this.computeFormulaCursorContext(),this.computeParenthesisRelatedToCursor())}replaceComposerCursorSelection(e){this.replaceSelection(e)}handle(e){switch(e.type){case"SELECT_FIGURE":e.id&&(this.cancelEditionAndActivateSheet(),this.resetContent());break;case"START_CHANGE_HIGHLIGHT":const{left:t,top:o}=e.zone;this.isSelectingRange&&(this.editionMode="editing"),this.model.selection.resetAnchor(this,{cell:{col:t,row:o},zone:e.zone})}}get currentContent(){return"inactive"===this.editionMode?this.getComposerContent(this.getters.getActivePosition()):this._currentContent}get composerSelection(){return{start:this.selectionStart,end:this.selectionEnd}}get isSelectingRange(){return"selecting"===this.editionMode}get showSelectionIndicator(){return this.isSelectingRange&&this.canStartComposerRangeSelection()}get tokenAtCursor(){const e=Math.min(this.selectionStart,this.selectionEnd),t=Math.max(this.selectionStart,this.selectionEnd);return e===t&&0===t?void 0:this.currentTokens.find((o=>o.start<=e&&o.end>=t))}cycleReferences(){const e=this.getters.getLocale(),t=Ff(this.composerSelection,this._currentContent,e);void 0!==t&&this.setCurrentContent(t.content,t.selection)}toggleEditionMode(){if("inactive"===this.editionMode)return;const e=Math.min(this.selectionStart,this.selectionEnd),t=Math.max(this.selectionStart,this.selectionEnd),o=[...this.currentTokens].reverse().find((o=>o.end>=e&&t>=o.start&&"REFERENCE"===o.type));if("editing"===this.editionMode&&o){const e=this.getters.getActiveSheetId(),{sheetName:t,xc:s}=Go(o.value),i=this.getters.getSheetIdByName(t);i&&i!==e&&this.model.dispatch("ACTIVATE_SHEET",{sheetIdFrom:e,sheetIdTo:i}),this.selectionStart=this.selectionEnd=o.end;const r=this.getters.getRangeFromSheetXC(this.sheetId,s).zone;this.captureSelection(r),this.editionMode="selecting"}else this.editionMode="editing"}captureSelection(e,t,o){this.model.selection.capture(this,{cell:{col:t||e.left,row:o||e.right},zone:e},{handleEvent:this.handleEvent.bind(this),release:()=>{this._stopEdition()}})}isSelectionValid(e,t,o){return t>=0&&t<=e&&o>=0&&o<=e}startComposerRangeSelection(){if(this.sheetId===this.getters.getActiveSheetId()){const e=ms({col:this.col,row:this.row});this.model.selection.resetAnchor(this,{cell:{col:this.col,row:this.row},zone:e})}this.editionMode="selecting"}_startEdition(e,t){const o=this.getters.getActiveCell(),s=this.getters.getLocale();e&&o.format?.includes("%")&&ei(e,s)&&(t=t||{start:e.length,end:e.length},e=`${e}%`);const{col:i,row:r,sheetId:n}=this.getters.getActivePosition();this.col=i,this.sheetId=n,this.row=r,this.initialContent=this.getComposerContent({sheetId:n,col:i,row:r}),this.editionMode="editing",this.setContent(e||this.initialContent,t),this.colorIndexByRange={};const a=ms({col:this.col,row:this.row});this.captureSelection(a,i,r)}_stopEdition(){if("inactive"!==this.editionMode){this.cancelEditionAndActivateSheet();let e=this.getCurrentCanonicalContent();if(!(this.initialContent!==e))return;if(e&&e.startsWith("=")){const t=this.currentTokens.filter((e=>"LEFT_PAREN"===e.type)).length-this.currentTokens.filter((e=>"RIGHT_PAREN"===e.type)).length;t>0&&(e+=dt(new Array(t).fill(")")))}this.confirmEdition(e)}}getCurrentCanonicalContent(){return _a(this._currentContent,this.getters.getLocale())}cancelEditionAndActivateSheet(){if("inactive"===this.editionMode)return;this._cancelEdition();this.getters.getActiveSheetId()!==this.sheetId&&this.model.dispatch("ACTIVATE_SHEET",{sheetIdFrom:this.getters.getActiveSheetId(),sheetIdTo:this.sheetId})}_cancelEdition(){"inactive"!==this.editionMode&&(this.editionMode="inactive",this.model.selection.release(this),this.colorIndexByRange={})}resetContent(){this.setContent(this.initialContent||"")}setContent(e,t,o){const s=this._currentContent!==e;if(this._currentContent=e,t?(this.selectionStart=t.start,this.selectionEnd=t.end):this.selectionStart=this.selectionEnd=e.length,s||"inactive"!==this.editionMode){const t=this.getters.getLocale();this.currentTokens=e.startsWith("=")?Af(e,t):[],this.currentTokens.length>100&&o&&this.notificationStore.raiseError(Oo("This formula has over 100 parts. It can't be processed properly, consider splitting it into multiple cells"))}this.canStartComposerRangeSelection()&&this.startComposerRangeSelection()}getAutoCompleteProviders(){return bh.getAll()}insertSelectedRange(e){const t=Math.min(this.selectionStart,this.selectionEnd),o=this.getZoneReference(e);this.canStartComposerRangeSelection()?this.insertText(o,t):this.insertText(","+o,t)}replaceSelectedRange(e){const t=this.getZoneReference(e),o=this.tokenAtCursor,s="REFERENCE"===o?.type?o.start:this.selectionStart;this.replaceText(t,s,this.selectionEnd)}updateComposerRange(e,t){const o=this.getters.getActiveSheetId(),s=this.tokenAtCursor,i=(s?[s,...this.currentTokens]:this.currentTokens).filter((e=>"REFERENCE"===e.type)).find((t=>{const{xc:s,sheetName:i}=Go(t.value),r=i||this.getters.getSheetName(this.sheetId);if(this.getters.getSheetName(o)!==r)return!1;const n=this.getters.getRangeFromSheetXC(o,s);return is(this.getters.expandZone(o,n.zone),e)}));if(!i)return;const r=this.getters.getRangeFromSheetXC(o,i.value);this.selectionStart=i.start,this.selectionEnd=this.selectionStart+i.value.length;const n=this.getters.getRangeFromZone(o,t),a=this.getRangeReference(n,r.parts);this.replaceSelection(a)}getZoneReference(e){const t=this.sheetId,o=this.getters.getActiveSheetId(),s=this.getters.getRangeFromZone(o,e);return this.getters.getSelectionRangeString(s,t)}getRangeReference(e,t){let o=[...t];const s=e.clone({parts:o});return this.getters.getSelectionRangeString(s,this.sheetId)}replaceSelection(e){const t=Math.min(this.selectionStart,this.selectionEnd),o=Math.max(this.selectionStart,this.selectionEnd);this.replaceText(e,t,o)}replaceText(e,t,o){this._currentContent=this._currentContent.slice(0,t)+this._currentContent.slice(o,this._currentContent.length),this.insertText(e,t)}insertText(e,t){const o=this._currentContent.slice(0,t)+e+this._currentContent.slice(t),s=t+e.length;this.setCurrentContent(o,{start:s,end:s})}updateTokenColor(){this.updateRangeColor();for(let e=0;e<this.currentTokens.length;e++)this.currentTokens[e].color=this.getTokenColor(this.currentTokens[e])}getTokenColor(e){if("REFERENCE"===e.type){const{xc:t,sheetName:o}=Go(e.value);return this.rangeColor(t,o)||Wb}if("SYMBOL"===e.type){const t=e.value.toUpperCase();if("TRUE"===t||"FALSE"===t)return qb.NUMBER;if(t in Nb.content)return qb.FUNCTION}return["LEFT_PAREN","RIGHT_PAREN"].includes(e.type)&&""===e.parenthesesCode?qb.ORPHAN_RIGHT_PAREN:qb[e.type]||Wb}rangeColor(e,t){const o=t?this.model.getters.getSheetIdByName(t):this.sheetId,s=this.highlights.find((t=>{if(t.sheetId!==o)return!1;let s=this.model.getters.getRangeFromSheetXC(o,e).zone;return s=1===bs(s)?this.model.getters.expandZone(o,s):s,is(s,t.zone)}));return s&&s.color?s.color:void 0}computeFormulaCursorContext(){for(let e=0;e<this.currentTokens.length;e++)this.currentTokens[e].isBlurred=!1;if(this.selectionStart!==this.selectionEnd)return;const e=this.getParenthesesCodeAfterCursor(),t=[...this.currentTokens].reverse().find((t=>e.startsWith(t.parenthesesCode)&&"SYMBOL"===t.type));if(t)for(let e=0;e<this.currentTokens.length;e++)(this.currentTokens[e].parenthesesCode||"").startsWith(t.parenthesesCode||"")||(this.currentTokens[e].isBlurred=!0)}getParenthesesCodeAfterCursor(){const e=this.tokenAtCursor?.parenthesesCode||"";return"RIGHT_PAREN"===this.tokenAtCursor?.type?e.slice(0,-1)||"":e}computeParenthesisRelatedToCursor(){for(let e=0;e<this.currentTokens.length;e++)this.currentTokens[e].isParenthesisLinkedToCursor=!1;const e=this.tokenAtCursor;if(e&&""!==e.parenthesesCode&&["LEFT_PAREN","RIGHT_PAREN"].includes(e.type))for(let t=0;t<this.currentTokens.length;t++){const o=this.currentTokens[t];["LEFT_PAREN","RIGHT_PAREN"].includes(o.type)&&o.parenthesesCode===e.parenthesesCode&&o!==e&&(this.currentTokens[t].isParenthesisLinkedToCursor=!0,this.tokenAtCursor.isParenthesisLinkedToCursor=!0)}}updateRangeColor(){if(!this._currentContent.startsWith("=")||"inactive"===this.editionMode)return;const e=this.sheetId,t=this.getReferencedRanges().map((t=>this.getters.getRangeString(t,e))),o={};for(const e of t)void 0!==this.colorIndexByRange[e]&&(o[e]=this.colorIndexByRange[e]);const s=new Set(Object.values(o));let i=0;const r=()=>{for(;s.has(i);)i++;return s.add(i),i};for(const e of t){const t=e in o?o[e]:r();o[e]=t}this.colorIndexByRange=o}get highlights(){if(!this.currentContent.startsWith("=")||"inactive"===this.editionMode)return[];const e=this.sheetId,t=e=>{const t=this.colorIndexByRange[e];return Lt[t%Lt.length]};return this.getReferencedRanges().map((o=>{const s=this.getters.getRangeString(o,e),{numberOfRows:i,numberOfCols:r}=ls(o.zone);return{zone:i*r==1?this.getters.expandZone(o.sheetId,o.zone):o.zone,color:t(s),sheetId:o.sheetId,interactive:!0}}))}getReferencedRanges(){const e=this.sheetId;return this.currentTokens.filter((e=>"REFERENCE"===e.type)).map((t=>this.getters.getRangeFromSheetXC(e,t.value))).filter((e=>!e.invalidSheetName&&!e.invalidXc))}get autocompleteProvider(){const e=this.currentContent,t=e.startsWith("=")?this.tokenAtCursor:{type:"STRING",value:e};if("inactive"===this.editionMode||!t||["TRUE","FALSE"].includes(t.value.toUpperCase())||!this.canStartComposerRangeSelection()&&!["SYMBOL","STRING","UNKNOWN"].includes(t.type))return;const o={composer:this,getters:this.getters},s=this.getAutoCompleteProviders().sort(((e,t)=>(e.sequence??1/0)-(t.sequence??1/0))).map((s=>({...s,getProposals:s.getProposals.bind(o,t,e),selectProposal:s.selectProposal.bind(o,t)})));for(const e of s){let o=e.getProposals();const s=o?.find((e=>e.text===t.value)),i=t.value.replace(/[ ,\(\)]/g,"");if(s&&this._currentContent!==this.initialContent)return;if(i&&o&&!["ARG_SEPARATOR","LEFT_PAREN","OPERATOR"].includes(t.type)){const e=Un(i,o,(e=>e.fuzzySearchKey||e.text));(!s||e.length>1)&&(o=e)}if(e.maxDisplayedProposals&&(o=o?.slice(0,e.maxDisplayedProposals)),o?.length)return{proposals:o,selectProposal:e.selectProposal,autoSelectFirstProposal:e.autoSelectFirstProposal??!1}}}canStartComposerRangeSelection(){if(this._currentContent.startsWith("=")){const e=this.tokenAtCursor;if(!e)return!1;const t=this.currentTokens.map((e=>e.start)).indexOf(e.start);let o=t,s=e;for(;!["ARG_SEPARATOR","LEFT_PAREN","OPERATOR"].includes(s.type)||ga.includes(s.value);){if("SPACE"!==s.type||o<1)return!1;o--,s=this.currentTokens[o]}for(o=t+1,s=this.currentTokens[o];s&&!["ARG_SEPARATOR","RIGHT_PAREN","OPERATOR"].includes(s.type);){if("SPACE"!==s.type)return!1;o++,s=this.currentTokens[o]}return!0}return!1}}class jb{scope;code="";constructor(e=new Xb){this.scope=e}append(...e){this.code+=e.map((e=>e.toString())).join("\n")+"\n"}return(e){return new Yb(this.scope,this.code,e)}toString(){return Kb(this.code)}}class Yb{scope;returnExpression;code;constructor(e,t,o){this.scope=e,this.returnExpression=o,this.code=Kb(t)}toString(){return this.code}assignResultToVariable(){if(this.scope.isAlreadyDeclared(this.returnExpression))return this;const e=this.scope.nextVariableName(),t=new jb(this.scope);return t.append(this.code),t.append(`const ${e} = ${this.returnExpression};`),t.return(e)}}class Xb{nextId=1;declaredVariables=new Set;nextVariableName(){const e="_"+this.nextId++;return this.declaredVariables.add(e),e}isAlreadyDeclared(e){return this.declaredVariables.has(e)}}function Kb(e){let t="",o=0;const s=e.split("\n").map((e=>e.trim())).filter((e=>""!==e));for(const e of s)e.startsWith("}")&&o--,t+="\t".repeat(o)+e+"\n",e.endsWith("{")&&o++;return t.trim()}const Jb=Nb.content,Qb={"=":"EQ","+":"ADD","-":"MINUS","*":"MULTIPLY","/":"DIVIDE",">=":"GTE","<>":"NE",">":"GT","<=":"LTE","<":"LT","^":"POWER","&":"CONCATENATE"},eS={"-":"UMINUS","+":"UPLUS","%":"UNARY.PERCENT"},tS={};function oS(e){return sS(cf(e))}function sS(e){try{return function(e){const{dependencies:t,constantValues:o,symbols:s}=function(e){const t={numbers:[],strings:[]},o=[],s=[];for(const i of e)switch(i.type){case"INVALID_REFERENCE":case"REFERENCE":o.push(i.value);break;case"STRING":const e=He(i.value);t.strings.includes(e)||t.strings.push(e);break;case"NUMBER":{const e=oi(i.value,bi);t.numbers.includes(e)||t.numbers.push(e);break}case"SYMBOL":s.push($e(i.value,"'"))}return{dependencies:o,constantValues:t,symbols:s}}(e),i=function(e,t,o,s){let i="";for(const s of e)switch(s.type){case"STRING":const e=He(s.value);i+=`|S${o.strings.indexOf(e)}|`;break;case"NUMBER":i+=`|N${o.numbers.indexOf(oi(s.value,bi))}|`;break;case"REFERENCE":case"INVALID_REFERENCE":s.value.includes(":")?i+=`R|${t.indexOf(s.value)}|`:i+=`C|${t.indexOf(s.value)}|`;break;case"SPACE":i+="";break;default:i+=s.value}return i}(e,t,o);if(!tS[i]){const n=yf([...e]),a=new Xb;if("BIN_OPERATION"===n.type&&":"===n.value)throw new Ti(Oo("Invalid formula"));if("EMPTY"===n.type)throw new Ti(Oo("Invalid formula"));const l=u(n),c=new jb;c.append(`// ${i}`),c.append(l),c.append(`return ${l.returnExpression};`);let h=new Function("deps","ref","range","getSymbolValue","ctx",c.toString());function d(e){const{args:t}=e,o=e.value.toUpperCase(),s=Jb[o];if(!s)throw new Di(Oo('Unknown function: "%s"',e.value));!function(e){const t=e.args.length,o=e.value.toUpperCase(),s=Jb[o];if(t<s.minArgRequired)throw new Ti(Oo("Invalid number of arguments for the %s function. Expected %s minimum, but got %s instead.",o,s.minArgRequired.toString(),t.toString()));if(t>s.maxArgPossible)throw new Ti(Oo("Invalid number of arguments for the %s function. Expected %s maximum, but got %s instead.",o,s.maxArgPossible.toString(),t.toString()));const i=s.nbrArgRepeating;if(i>1){const e=s.args.length-i;if((t-e)%i!=0)throw new Ti(Oo("Invalid number of arguments for the %s function. Expected all arguments after position %s to be supplied by groups of %s arguments",o,e.toString(),i.toString()))}}(e);const i=[];for(let e=0;e<t.length;e++){const o=s.getArgToFocus(e+1)-1,r=s.args[o],n=t[e],a=r.type||[],l=a.includes("META"),c=a.some((e=>iS(e)));i.push(u(n,l,c))}return i}function u(e,i=!1,r=!1){const n=new jb(a);if("REFERENCE"!==e.type&&("BIN_OPERATION"!==e.type||":"!==e.value)&&i)throw new Ti(Oo("Argument must be a reference to a cell or range."));switch(e.debug&&(n.append("debugger;"),n.append('ctx["debug"] = true;')),e.type){case"BOOLEAN":return n.return(`{ value: ${e.value} }`);case"NUMBER":return n.return(`{ value: this.constantValues.numbers[${o.numbers.indexOf(e.value)}] }`);case"STRING":return n.return(`{ value: this.constantValues.strings[${o.strings.indexOf(e.value)}] }`);case"REFERENCE":const a=t.indexOf(e.value);return!i&&e.value.includes(":")||r?n.return(`range(deps[${a}])`):n.return(`ref(deps[${a}], ${i?"true":"false"})`);case"FUNCALL":const l=d(e).map((e=>e.assignResultToVariable()));n.append(...l);const c=e.value.toUpperCase();return n.return(`ctx['${c}'](${l.map((e=>e.returnExpression))})`);case"UNARY_OPERATION":{const t=eS[e.value],o=u(e.operand,!1,!1).assignResultToVariable();return n.append(o),n.return(`ctx['${t}'](${o.returnExpression})`)}case"BIN_OPERATION":{const t=Qb[e.value],o=u(e.left,!1,!1).assignResultToVariable(),s=u(e.right,!1,!1).assignResultToVariable();return n.append(o),n.append(s),n.return(`ctx['${t}'](${o.returnExpression}, ${s.returnExpression})`)}case"SYMBOL":const h=s.indexOf(e.value);return n.return(`getSymbolValue(this.symbols[${h}])`);case"EMPTY":return n.return("undefined")}}tS[i]=h}const r={execute:tS[i],dependencies:t,constantValues:o,symbols:s,tokens:e,isBadExpression:!1,normalizedFormula:i};return r}(e)}catch(t){return{tokens:e,dependencies:[],execute:function(){return t},isBadExpression:!0,normalizedFormula:e.map((e=>e.value)).join("")}}}function iS(e){return e.startsWith("RANGE")}const rS=Nb.content;function nS(e){try{return 0===wf(yf(e)).filter((e=>"FUNCALL"===e.type&&!rS[e.value.toUpperCase()]?.isExported)).length}catch(e){return!1}}function aS(e,t){if(!e.some((e=>"SYMBOL"===e.type&&t.includes(e.value.toUpperCase()))))return[];let o;try{o=yf(e)}catch{return[]}return function(e,t){return wf(e).filter((e=>"FUNCALL"===e.type&&t.includes(e.value.toUpperCase()))).map((e=>({functionName:e.value.toUpperCase(),args:e.args})))}(o,t)}const lS=["PIVOT.VALUE","PIVOT.HEADER","PIVOT"];function cS(e,t){const o=`"${t?`${e.name}:${t}`:e.name}"`,s=e.string!==e.name?e.string+o:o;return{text:o,description:e.string+(e.help?` (${e.help})`:""),htmlContent:[{value:o,color:qb.STRING}],fuzzySearchKey:s}}function hS(e,t){let o=e.end;const s=e.end;"ARG_SEPARATOR"!==e.type&&(o=e.start),this.composer.stopComposerRangeSelection(),this.composer.changeComposerCursorSelection(o,s),this.composer.replaceComposerCursorSelection(t)}function dS(e,t){let o=e.end;const s=e.end;"LEFT_PAREN"!==e.type&&(o=e.start),this.composer.stopComposerRangeSelection(),this.composer.changeComposerCursorSelection(o,s),this.composer.replaceComposerCursorSelection(t)}function uS(e){const t=e.functionContext?.args[0];if(t&&["STRING","NUMBER"].includes(t.type))return t.value}function gS(e){return aS(e,lS)[0]}function pS(e){return aS(e,lS).length}const mS=new r;mS.add("SPREADSHEET",!1),bh.add("pivot_ids",{sequence:50,autoSelectFirstProposal:!0,getProposals(e){const t=e.functionContext;if(!t||!["PIVOT.VALUE","PIVOT.HEADER","PIVOT"].includes(t.parent.toUpperCase())||0!==t.argPosition)return;const o=this.getters.getPivotIds();return o.includes(e.value)?void 0:o.map((e=>{const t=this.getters.getPivotCoreDefinition(e),o=`${this.getters.getPivotFormulaId(e)}`;return{text:o,description:t.name,htmlContent:[{value:o,color:qb.NUMBER}],fuzzySearchKey:o+t.name,alwaysExpanded:!0}})).filter(at)},selectProposal:dS}),bh.add("pivot_measures",{sequence:50,autoSelectFirstProposal:!0,getProposals(e){const t=e.functionContext;if("PIVOT.VALUE"!==t?.parent.toUpperCase()||1!==t.argPosition)return[];const o=uS(e),s=this.getters.getPivotId(o);if(!s||!this.getters.isExistingPivot(s))return[];const i=this.getters.getPivot(s);return i.init(),i.isValid()?i.definition.measures.map((e=>{if("__count"===e.fieldName){const e='"__count"';return{text:e,description:Oo("Count"),htmlContent:[{value:e,color:qb.STRING}],fuzzySearchKey:Oo("Count")+e}}return function(e){const t=`"${e.id}"`,o=e.displayName+e.fieldName+t;return{text:t,description:e.displayName,htmlContent:[{value:t,color:qb.STRING}],fuzzySearchKey:o}}(e)})).filter(at):[]},selectProposal:hS}),bh.add("pivot_group_fields",{sequence:50,autoSelectFirstProposal:!0,getProposals(e){const t=e.functionContext;if(!t||!function(e){const t=e.functionContext;return"PIVOT.VALUE"===t?.parent.toUpperCase()&&t.argPosition>=2&&t.argPosition%2==0}(e)&&!function(e){const t=e.functionContext;return"PIVOT.HEADER"===t?.parent.toUpperCase()&&t.argPosition>=1&&t.argPosition%2==1}(e))return;const o=uS(e),s=this.getters.getPivotId(o);if(!s||!this.getters.isExistingPivot(s))return;const i=this.getters.getPivot(s);i.init();const r=i.getFields(),{columns:n,rows:a}=i.definition;let l=t.args;"PIVOT.VALUE"===t?.parent.toUpperCase()?(l=l.filter(((e,t)=>t%2==0)),l=l.slice(1,t.argPosition)):l=l.filter(((e,t)=>t%2==1));const c=l.map((e=>e?.value)).filter(at),h=n.map((e=>e.nameWithGranularity)),d=a.map((e=>e.nameWithGranularity)),u=[];let g=["ARG_SEPARATOR","SPACE"].includes(e.type)?c.at(-1):c.at(-2);const p=mS.get(i.type);if(p&&g?.startsWith("#")&&(g=g.slice(1)),void 0===g&&(u.push(h[0]),u.push(d[0])),d.includes(g)){const e=d[d.indexOf(g)+1];u.push(e),u.push(h[0])}if(h.includes(g)){const e=h[h.indexOf(g)+1];u.push(e)}const m=u.filter(at);return m.map((e=>{const[t,o]=e.split(":"),s=r[t];return s?cS(s,o):void 0})).concat(m.map((e=>{if(!p)return;const t=e.split(":")[0],o=r[t];if(!o)return;const s=`"#${e}"`;return{text:s,description:Oo("%s (positional)",o.string)+(o.help?` (${o.help})`:""),htmlContent:[{value:s,color:qb.STRING}],fuzzySearchKey:o.string+s}}))).filter(at)},selectProposal:hS}),bh.add("pivot_group_values",{sequence:50,autoSelectFirstProposal:!0,getProposals(e){const t=e.functionContext;if(!t||!e||!function(e){const t=e.functionContext;return"PIVOT.VALUE"===t?.parent.toUpperCase()&&t.argPosition>=2&&t.argPosition%2==1}(e)&&!function(e){const t=e.functionContext;return"PIVOT.HEADER"===t?.parent.toUpperCase()&&t.argPosition>=1&&t.argPosition%2==0}(e))return;const o=uS(e),s=this.getters.getPivotId(o);if(!s||!this.getters.isExistingPivot(s))return;const i=this.getters.getPivot(s);if(!i.isValid())return;const r=t.argPosition,n=e.functionContext?.args[r-1]?.value;if(!n)return;let a;try{a=i.definition.getDimension(n)}catch(e){return}return"month_number"===a.granularity?Object.values(jr).map(((e,t)=>({text:`${t+1}`,fuzzySearchKey:e.toString(),description:e.toString(),htmlContent:[{value:`${t+1}`,color:qb.NUMBER}]}))):"quarter_number"===a.granularity?[1,2,3,4].map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:Oo("Quarter %s",e),htmlContent:[{value:`${e}`,color:qb.NUMBER}]}))):"day_of_month"===a.granularity?Ze(1,32).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:qb.NUMBER}]}))):"iso_week_number"===a.granularity?Ze(0,54).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:qb.NUMBER}]}))):"day_of_week"===a.granularity?Ze(1,8).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:qb.NUMBER}]}))):"hour_number"===a.granularity?Ze(0,24).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:qb.NUMBER}]}))):"minute_number"===a.granularity?Ze(0,60).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:qb.NUMBER}]}))):"second_number"===a.granularity?Ze(0,60).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:qb.NUMBER}]}))):i.getPossibleFieldValues(a).map((({value:e,label:t})=>{const o="string"==typeof e,s=o?`"${e}"`:e.toString(),i=t===e?"":t;return{text:s,description:i,htmlContent:[{value:s,color:o?qb.STRING:qb.NUMBER}],fuzzySearchKey:e+i}}))},selectProposal:hS}),bh.add("sheet_names",{sequence:150,autoSelectFirstProposal:!0,getProposals(e){return"SYMBOL"===e.type||"UNKNOWN"===e.type&&e.value.startsWith("'")?this.getters.getSheetIds().map((e=>{const t=We(this.getters.getSheetName(e));return{text:t,fuzzySearchKey:t.startsWith("'")?t:"'"+t}})):[]},selectProposal(e,t){const o=e.start,s=e.end;this.composer.changeComposerCursorSelection(o,s),this.composer.replaceComposerCursorSelection(t+"!")}});const fS=new r;fS.add("ALPHANUMERIC_INCREMENT_MODIFIER",{apply:(e,t)=>{e.current+=e.increment;const o=`${e.prefix}${e.current.toString().padStart(e.numberPostfixLength||0,"0")}`;return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:o},tooltip:{props:{content:o}}}}}).add("INCREMENT_MODIFIER",{apply:(e,t,o)=>{e.current+=e.increment;const s=e.current.toString(),i=o.getLocale(),r=Xr(e.current,{format:t.cell?.format,locale:i});return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:s},tooltip:s?{props:{content:r}}:void 0}}}).add("DATE_INCREMENT_MODIFIER",{apply:(e,t,o)=>{const s=Yi(e.current,o.getLocale());s.setFullYear(s.getFullYear()+e.increment.years||0),s.setMonth(s.getMonth()+e.increment.months||0),s.setDate(s.getDate()+e.increment.days||0);const i=zs(s);e.current=i;const r=o.getLocale(),n=Xr(i,{format:t.cell?.format,locale:r});return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:i.toString()},tooltip:i?{props:{content:n}}:void 0}}}).add("COPY_MODIFIER",{apply:(e,t,o)=>{const s=t.cell?.content||"",i={locale:o.getLocale(),format:t.cell?.format};return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:s},tooltip:s?{props:{content:t.cell?xn(t.cell,i).formattedValue:""}}:void 0}}}).add("FORMULA_MODIFIER",{apply:(e,t,o,s)=>{e.current+=e.increment;let i=0,r=0;switch(s){case"up":i=0,r=-e.current;break;case"down":i=0,r=e.current;break;case"left":i=-e.current,r=0;break;case"right":i=e.current,r=0}const n=t.cell;if(!n||!n.isFormula)return{cellData:{}};const a=t.sheetId,l=o.getTranslatedCellFormula(a,i,r,n.compiledFormula.tokens);return{cellData:{border:t.border,style:n.style,format:n.format,content:l},tooltip:l?{props:{content:l}}:void 0}}});const vS=new r,bS=/(\d+)$/,SS=/^(.*\D+)/,yS=/^(.*\D+)(\d+)$/;function CS(e,t,o){let s=[],i=!1;for(let r of t){r===e&&(i=!0);const t=void 0===r||r.isFormula?void 0:xn(r,{locale:bi,format:r.format});if(t&&o(t))s.push(t);else{if(i)return s;s=[]}}return s}function wS(e){let t=1;return e.length>=2&&(t=function(e){const t=[];let o=e[0];for(let s=1;s<e.length;s++){const i=e[s];t.push(i-o),o=i}return t.reduce(((e,t)=>e+t),0)/t.length}(e)*e.length),t}function ES(e){if(e.length<2)return 1;const t=e.map((e=>Yi(e,bi))),o=function(e){if(e.length<2)return[{years:0,months:0,days:0}];const t=e.map(((t,o)=>{if(0===o)return{years:0,months:0,days:0};const s=xs.fromTimestamp(e[o-1].getTime()),i=Xs(s,t),r=js(s,t)%12;s.setFullYear(s.getFullYear()+i),s.setMonth(s.getMonth()+r);return{years:i,months:r,days:Ys(s,t)}}));return t.slice(1)}(t),s=(i=o).length<2?i[0]||{years:0,months:0,days:0}:i.every((e=>e.years===i[0].years&&e.months===i[0].months&&e.days===i[0].days))?i[0]:void 0;var i;if(void 0===s)return;const r=1===Object.values(s).filter((e=>0!==e)).length,n=Object.values(s).every((e=>0===e));if(!r||n){const o=t.map(((e,o)=>{if(0===o)return 0;const s=t[o-1];return Math.floor(e.getTime())-Math.floor(s.getTime())})).slice(1);if(o.every((e=>e===o[0])))return e.length*(e[1]-e[0])}return{years:s.years*e.length,months:s.months*e.length,days:s.days*e.length}}vS.add("simple_value_copy",{condition:(e,t)=>!(1!==t.length||e.isFormula||e.format&&rn(e.format)),generateRule:()=>({type:"COPY_MODIFIER"}),sequence:10}).add("increment_alphanumeric_value",{condition:e=>!e.isFormula&&xn(e,{locale:bi}).type===ii.text&&yS.test(e.content),generateRule:(e,t)=>{const o=parseInt(e.content.match(bS)[0]),s=e.content.match(SS)[0],i=e.content.length-s.length,r=wS(CS(e,t,(e=>e.type===ii.text&&yS.test(e.value))).filter((e=>s===(e.value??"").toString().match(SS)[0])).map((e=>parseInt((e.value??"").toString().match(bS)[0]))));return{type:"ALPHANUMERIC_INCREMENT_MODIFIER",prefix:s,current:o,increment:r,numberPostfixLength:i}},sequence:15}).add("copy_text",{condition:e=>!e.isFormula&&xn(e,{locale:bi}).type===ii.text,generateRule:()=>({type:"COPY_MODIFIER"}),sequence:20}).add("update_formula",{condition:e=>e.isFormula,generateRule:(e,t)=>({type:"FORMULA_MODIFIER",increment:t.length,current:0}),sequence:30}).add("increment_dates",{condition:(e,t)=>!e.isFormula&&xn(e,{locale:bi}).type===ii.number&&!!e.format&&rn(e.format),generateRule:(e,t)=>{const o=ES(CS(e,t,(e=>e.type===ii.number&&!!e.format&&rn(e.format))).map((e=>Number(e.value))));if(void 0===o)return{type:"COPY_MODIFIER"};const s=xn(e,{locale:bi});return"object"==typeof o?{type:"DATE_INCREMENT_MODIFIER",increment:o,current:s.type===ii.number?s.value:0}:{type:"INCREMENT_MODIFIER",increment:o,current:s.type===ii.number?s.value:0}},sequence:25}).add("increment_number",{condition:e=>!e.isFormula&&xn(e,{locale:bi}).type===ii.number,generateRule:(e,t)=>{const o=wS(CS(e,t,(e=>e.type===ii.number&&!rn(e.format||""))).map((e=>Number(e.value)))),s=xn(e,{locale:bi});return{type:"INCREMENT_MODIFIER",increment:o,current:s.type===ii.number?s.value:0}},sequence:40});const xS=new r,IS=30,RS=10,TS=20,AS=12,_S=80,DS="#F3F2F1",OS=6,FS=25;function MS(e,t){const o=e.getBoundingClientRect();e.width=o.width,e.height=o.height;const s=e.getContext("2d"),i=function(e,t,o){const s=t.maxValue,i=t.minValue,r=t.gaugeValue,n=function(e,t){const o=t?FS:0,s=e.height-TS-o-RS,i=e.width-2*IS;let r,n;i>2*s?(r=2*s,n=s):(r=i,n=i/2);const a=o+RS+(s-n)/2;return{x:IS+(i-r)/2,y:a,width:r,height:n}}(e,t.title.text),a=n.width/6,l=r?(r.value-i.value)/(s.value-i.value):0,c={x:e.width/2,y:n.y+n.height-n.height/12};let h=_S;n.height<300&&(h*=n.height/300);const d=n.width/2,u=r?.label||"-";Zn(o,u,{fontSize:h},"px")>d&&(h=function(e,t,o,s=.25){let i=1;if(o(i)>e)return i;if(o(t)<e)return t;let r=(i+t)/2,n=o(r),a=0;for(;Math.abs(n-e)>s&&a<20;)n>=e?t=(i+t)/2:i=(i+t)/2,r=(i+t)/2,n=o(r),a++;return r}(d,h,(e=>Zn(o,u,{fontSize:e},"px"))));const g={x:n.x+a/2,y:n.y+n.height+AS},p={x:n.x+n.width-a/2,y:n.y+n.height+AS},m=Bc(t.background),f=function(e,t,o,s){const i=e.maxValue,r=e.minValue,n={x:t.x+t.width/2,y:t.y+t.height},a={fontSize:AS},l=[],c=[];for(const h of e.inflectionValues){const e=(h.value-r.value)/(i.value-r.value),d=Zn(s,h.label,a,"px"),u=Math.PI-Math.PI*e,g=VS(u,t.height+OS,n.x,n.y,d+2,AS);let p=c.some((e=>LS(e,g)))?AS:0;c.push(g),l.push({rotation:u,label:h.label,fontSize:AS,color:o,offset:p})}return l}(t,n,m,o);let v=0,b=0,S=0;t.title.text&&({width:b,height:S}=Xn(o,t.title.text,{fontSize:X,...t.title},"px"));switch(t.title.align){case"right":v=e.width-b-Z;break;case"center":v=(e.width-b)/2;break;default:v=Z}return{width:e.width,height:e.height,title:{label:t.title.text??"",fontSize:t.title.fontSize??X,textPosition:{x:v,y:Y+S/2},color:t.title.color??m,bold:t.title.bold,italic:t.title.italic},backgroundColor:t.background,gauge:{rect:n,arcWidth:a,percentage:qe(l,0,1),color:PS(t)},inflectionValues:f,gaugeValue:{label:u,textPosition:c,fontSize:h,color:m},minLabel:{label:t.minValue.label,textPosition:g,fontSize:AS,color:m},maxLabel:{label:t.maxValue.label,textPosition:p,fontSize:AS,color:m}}}(o,t,s);!function(e,t){e.save(),e.fillStyle=t.backgroundColor,e.fillRect(0,0,t.width,t.height),e.restore()}(s,i),function(e,t){e.save();const o=t.gauge,s=o.rect.x+o.rect.width/2,i=o.rect.y+o.rect.height,r=o.rect.height-o.arcWidth/2;if(r<0)return;const n=1===o.percentage?0:Math.PI*(1+o.percentage);e.strokeStyle=DS,e.beginPath(),e.lineWidth=o.arcWidth,e.arc(s,i,r,n,0),e.stroke(),e.strokeStyle=o.color,e.beginPath(),e.arc(s,i,r,Math.PI,n),e.stroke(),e.restore()}(s,i),function(e,t){const{x:o,y:s,width:i,height:r}=t.gauge.rect;for(const n of t.inflectionValues){e.save(),e.translate(o+i/2-.5,s+r-.5),e.rotate(Math.PI/2-n.rotation),e.lineWidth=2,e.strokeStyle=Bc(t.backgroundColor)+"aa",e.beginPath(),e.moveTo(0,-(r-t.gauge.arcWidth)),e.lineTo(0,-r-3),e.stroke(),e.textAlign="center",e.font=`${n.fontSize}px ${fe}`,e.fillStyle=n.color;const a=-r-OS-n.offset;e.fillText(n.label,0,a),e.restore()}}(s,i),function(e,t){for(const o of[t.minLabel,t.maxLabel,t.gaugeValue])e.save(),e.textAlign="center",e.fillStyle=o.color,e.font=`${o.fontSize}px ${fe}`,e.fillText(o.label,o.textPosition.x,o.textPosition.y),e.restore()}(s,i),function(e,t){e.save();const o=t.title;e.font=Gn(o.fontSize,o.bold,o.italic),e.textBaseline="middle",e.fillStyle=o.color,e.fillText(o.label,o.textPosition.x,o.textPosition.y),e.restore()}(s,i)}function PS(e){const t=e.gaugeValue?.value;if(void 0===t)return DS;for(let o=0;o<e.inflectionValues.length;o++){const s=e.inflectionValues[o];if("<"===s.operator&&t<s.value)return e.colors[o];if("<="===s.operator&&t<=s.value)return e.colors[o]}return e.colors.at(-1)}function NS(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 kS(e,t){const o=e.start,s=e.end,i=t.start,r=t.end;function n(e,t,o){return(o.y-e.y)*(t.x-e.x)>(t.y-e.y)*(o.x-e.x)}return n(o,i,r)!==n(s,i,r)&&n(o,s,i)!==n(o,s,r)}function LS(e,t){const o=NS(e),s=NS(t);for(const e of o)for(const t of s)if(kS(e,t))return!0;return!1}function VS(e,t,o,s,i,r){const n=Math.cos(e),a=Math.sin(e),l=n*t,c=a*t,h=a*(i/2),d=n*(i/2),u=n*(t+r),g=a*(t+r);return{bottomLeft:{x:l-h+o,y:s-(c+d)},bottomRight:{x:l+h+o,y:s-(c-d)},topRight:{x:u+h+o,y:s-(g-d)},topLeft:{x:u-h+o,y:s-(g+d)}}}class HS extends t.Component{static template="o-spreadsheet-GaugeChartComponent";canvas=t.useRef("chartContainer");get runtime(){return this.env.model.getters.getChartRuntime(this.props.figure.id)}setup(){t.useEffect((()=>MS(this.canvas.el,this.runtime)),(()=>{const e=this.canvas.el.getBoundingClientRect();return[e.width,e.height,this.runtime,this.canvas.el]}))}}function US(e){return 8===(e=Ut(e).replace("#","")).length?e.slice(6)+e.slice(0,6):e}HS.props={figure:Object};const BS={responsive:!0,maintainAspectRatio:!1,elements:{line:{fill:!1},point:{hitRadius:15}},animation:!1};function zS(e){return e?e.length>Ce?e.substring(0,Ce)+"…":e:""}function $S(e,t,o){const s=document.createElement("div");s.style.width=`${t.width}px`,s.style.height=`${t.height}px`;const i=document.createElement("canvas");if(s.append(i),i.setAttribute("width",t.width.toString()),i.setAttribute("height",t.height.toString()),document.body.append(s),"chartJsConfig"in e){const t=Be(e.chartJsConfig);t.plugins=[WS];const o=new window.Chart(i,t),r=o.toBase64Image();return o.destroy(),s.remove(),r}if("scorecard"===o){dh(mh(t,e),i);const o=i.toDataURL();return s.remove(),o}if("gauge"===o){MS(i,e);const t=i.toDataURL();return s.remove(),t}}const WS={id:"customCanvasBackgroundColor",beforeDraw:e=>{const{ctx:t}=e;t.save(),t.globalCompositeOperation="destination-over",t.fillStyle="#ffffff",t.fillRect(0,0,e.width,e.height),t.restore()}};class GS{xmlString;constructor(e){this.xmlString=e}toString(){return this.xmlString}}const qS=["areaChart","area3DChart","lineChart","line3DChart","stockChart","radarChart","scatterChart","pieChart","pie3DChart","doughnutChart","barChart","bar3DChart","ofPieChart","surfaceChart","surface3DChart","bubbleChart","comboChart","radarChart"],ZS="000000",jS={arrow:"3Arrows",smiley:"3Symbols",dot:"3TrafficLights1"},YS={styleSheet:"http://schemas.openxmlformats.org/spreadsheetml/2006/main",sst:"http://schemas.openxmlformats.org/spreadsheetml/2006/main",Relationships:"http://schemas.openxmlformats.org/package/2006/relationships",Types:"http://schemas.openxmlformats.org/package/2006/content-types",worksheet:"http://schemas.openxmlformats.org/spreadsheetml/2006/main",workbook:"http://schemas.openxmlformats.org/spreadsheetml/2006/main",drawing:"http://schemas.openxmlformats.org/drawingml/2006/spreadsheetDrawing",table:"http://schemas.openxmlformats.org/spreadsheetml/2006/main",revision:"http://schemas.microsoft.com/office/spreadsheetml/2014/revision",revision3:"http://schemas.microsoft.com/office/spreadsheetml/2016/revision3",markupCompatibility:"http://schemas.openxmlformats.org/markup-compatibility/2006"},XS="http://schemas.openxmlformats.org/drawingml/2006/main",KS="http://schemas.openxmlformats.org/drawingml/2006/chart",JS={workbook:"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.main+xml",sheet:"application/vnd.openxmlformats-officedocument.spreadsheetml.worksheet+xml",sharedStrings:"application/vnd.openxmlformats-officedocument.spreadsheetml.sharedStrings+xml",styles:"application/vnd.openxmlformats-officedocument.spreadsheetml.styles+xml",drawing:"application/vnd.openxmlformats-officedocument.drawing+xml",chart:"application/vnd.openxmlformats-officedocument.drawingml.chart+xml",themes:"application/vnd.openxmlformats-officedocument.theme+xml",table:"application/vnd.openxmlformats-officedocument.spreadsheetml.table+xml",pivot:"application/vnd.openxmlformats-officedocument.spreadsheetml.pivotTable+xml",externalLink:"application/vnd.openxmlformats-officedocument.spreadsheetml.externalLink+xml"},QS={document:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument",sheet:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/worksheet",sharedStrings:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/sharedStrings",styles:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/styles",drawing:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/drawing",chart:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/chart",theme:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/theme",table:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/table",hyperlink:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/hyperlink",image:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/image"},ey="http://schemas.openxmlformats.org/officeDocument/2006/relationships",ty=.75,oy=.143,sy=8.43,iy=12.75,ry=30,ny=100,ay=164,ly={FLOOR:[{type:"NUMBER",value:1}],CEILING:[{type:"NUMBER",value:1}],ROUND:[{type:"NUMBER",value:0}],ROUNDUP:[{type:"NUMBER",value:0}],ROUNDDOWN:[{type:"NUMBER",value:0}]},cy=["ACOT","ACOTH","AGGREGATE","ARABIC","BASE","BETA.DIST","BETA.INV","BINOM.DIST","BINOM.DIST.RANGE","BINOM.INV","BITAND","BITLSHIFT","BITOR","BITRSHIFT","BITXOR","BYCOL","BYROW","CEILING.MATH","CEILING.PRECISE","CHISQ.DIST","CHISQ.DIST.RT","CHISQ.INV","CHISQ.INV.RT","CHISQ.TEST","CHOOSECOLS","CHOOSEROWS","COMBINA","CONCAT","CONFIDENCE.NORM","CONFIDENCE.T","COT","COTH","COVARIANCE.P","COVARIANCE.S","CSC","CSCH","DAYS","DECIMAL","DROP","ERF.PRECISE","ERFC.PRECISE","EXPAND","EXPON.DIST","F.DIST","F.DIST.RT","F.INV","F.INV.RT","F.TEST","FIELDVALUE","FILTERXML","FLOOR.MATH","FLOOR.PRECISE","FORECAST.ETS","FORECAST.ETS.CONFINT","FORECAST.ETS.SEASONALITY","FORECAST.ETS.STAT","FORECAST.LINEAR","FORMULATEXT","GAMMA","GAMMA.DIST","GAMMA.INV","GAMMALN.PRECISE","GAUSS","HSTACK","HYPGEOM.DIST","IFNA","IFS","IMCOSH","IMCOT","IMCSC","IMCSCH","IMSEC","IMSECH","IMSINH","IMTAN","ISFORMULA","ISOMITTED","ISOWEEKNUM","LAMBDA","LET","LOGNORM.DIST","LOGNORM.INV","MAKEARRAY","MAP","MAXIFS","MINIFS","MODE.MULT","MODE.SNGL","MUNIT","NEGBINOM.DIST","NORM.DIST","NORM.INV","NORM.S.DIST","NORM.S.INV","NUMBERVALUE","PDURATION","PERCENTILE.EXC","PERCENTILE.INC","PERCENTRANK.EXC","PERCENTRANK.INC","PERMUTATIONA","PHI","POISSON.DIST","PQSOURCE","PYTHON_STR","PYTHON_TYPE","PYTHON_TYPENAME","QUARTILE.EXC","QUARTILE.INC","QUERYSTRING","RANDARRAY","RANK.AVG","RANK.EQ","REDUCE","RRI","SCAN","SEC","SECH","SEQUENCE","SHEET","SHEETS","SKEW.P","SORTBY","STDEV.P","STDEV.S","SWITCH","T.DIST","T.DIST.2T","T.DIST.RT","T.INV","T.INV.2T","T.TEST","TAKE","TEXTAFTER","TEXTBEFORE","TEXTJOIN","TEXTSPLIT","TOCOL","TOROW","UNICHAR","UNICODE","UNIQUE","VAR.P","VAR.S","VSTACK","WEBSERVICE","WEIBULL.DIST","WRAPCOLS","WRAPROWS","XLOOKUP","XOR","Z.TEST"],hy="[Content_Types].xml",dy=new r,uy={};let gy=0;function py(e,...t){const o="__sheet__"+gy++;return function(e,t){const o=document.createElement("style");o.textContent=function(e){const t=e.split(/(\{|\}|;)/).map((e=>e.trim())),o=[],s=[];let i=[];function r(e,t){const s=[];for(const i of o[e]){let n=t&&t+" "+i||i;n.includes("&")&&(n=i.replace(/&/g,t||"")),e<o.length-1&&(n=r(e+1,n)),s.push(n)}return s.join(", ")}function n(){i.length&&(s.push(r(0)+" {"),s.push(...i),s.push("}"),i=[])}for(;t.length;){let e=t.shift();"}"===e?(n(),o.pop()):("{"===t[0]&&(n(),o.push(e.split(/\s*,\s*/)),t.shift()),";"===t[0]&&i.push(" "+e+";"))}return s.join("\n")}(t),uy[e]=o}(o,String.raw(e,...t)),function(e){const t=uy[e];t.setAttribute("component",e),document.head.appendChild(t)}(o),o}function my({strikethrough:e,underline:t}){return e||t?`${e?"line-through":""} ${t?"underline":""}`:"none"}function fy(e){const t=function(e){const t={};if(!e)return t;e.bold&&(t["font-weight"]="bold");e.italic&&(t["font-style"]="italic");if(e.strikethrough||e.underline){let o=e.strikethrough?"line-through":"";o=e.underline?o+" underline":o,t["text-decoration"]=o}e.textColor&&(t.color=e.textColor);return t}(e);return e?(e.fillColor&&(t.background=e.fillColor),t):t}function vy(e){let t="";for(const o in e)e[o]&&(t+=`${o}:${e[o]}; `);return t}py`
|
|
1
|
+
!function(e,t){"use strict";function o(e){return e.map(i).sort(((e,t)=>e.sequence-t.sequence))}let s=1;function i(e){const t=e.name,o=e.children,r=e.description,n=e.icon,a=e.secondaryIcon;return{id:(e.id||s++).toString(),name:"function"==typeof t?t:()=>t,isVisible:e.isVisible?e.isVisible:()=>!0,isEnabled:e.isEnabled?e.isEnabled:()=>!0,isActive:e.isActive,execute:e.execute,children:o?e=>o.map((t=>"function"==typeof t?t(e):t)).flat().map(i):()=>[],isReadonlyAllowed:e.isReadonlyAllowed||!1,separator:e.separator||!1,icon:"function"==typeof n?n:()=>n||"",iconColor:e.iconColor,secondaryIcon:"function"==typeof a?a:()=>a||"",description:"function"==typeof r?r:()=>r||"",textColor:e.textColor,sequence:e.sequence||0,onStartHover:e.onStartHover,onStopHover:e.onStopHover}}class r{content={};add(e,t){return this.content[e]=t,this}get(e){const t=this.content[e];if(!t&&!(e in this.content))throw new Error(`Cannot find ${e} in this registry!`);return t}contains(e){return e in this.content}getAll(){return Object.values(this.content)}getKeys(){return Object.keys(this.content)}remove(e){delete this.content[e]}}const n=.5,a="#37A850",l="#f5f5f5",c="#F8F9FA",h="#E8EAED",d="#595959",u="#666666",g="#c9ccd2",p="#3266ca",m="#FFFFFF",f="#CACACA",v=11982760,b="#017E84",S="#188038",y="#E0E2E4",C="#4A4F59",w="#999",E="#E2E3E3",x="#BCBCBC",I="#9B359B",R="#4EA7F2",T="#EA6175",A="#AAAAAA",_="#111827",D="#D8DADD",O="#E7E9ED",F="#F9FAFB",M="#374151",P=M+"C2",N="#111827",k="#714B67",L=O,V=D,H="#111827",U="#e6f2f3",B="#111827",z="#017E84",$="#D44C591A",W="#C34A41",G="#98DBE2",q="#E6F2F3",Z=20,j=10,Y=15,X=16,K=12,J="#F28C28",Q=["#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"],ee=26,te=48,oe=96,se=23,ie=15,re=4,ne=re,ae=21,le=17,ce=2*se,he=250,de={align:"left",verticalAlign:"bottom",wrapping:"overflow",bold:!1,italic:!1,strikethrough:!1,underline:!1,fontSize:10,fillColor:"",textColor:""},ue=de.verticalAlign,ge=de.wrapping,pe="400",me=de.fontSize,fe="'Roboto', arial",ve="thin",be="#000000",Se="START_REVISION",ye=1,Ce=20,we="??",Ee="difference",xe="#43C5B1",Ie="#EA6175",Re=.4,Te=2,Ae=["'","*","?","/","\\","[","]"],_e=/'|\*|\?|\/|\\|\[|\]/,De="|";var Oe;!function(e){e[e.Grid=0]="Grid",e[e.Highlight=5]="Highlight",e[e.HeaderGroupingButton=6]="HeaderGroupingButton",e[e.Figure=10]="Figure",e[e.ScrollBar=15]="ScrollBar",e[e.GridPopover=19]="GridPopover",e[e.GridComposer=20]="GridComposer",e[e.Dropdown=21]="Dropdown",e[e.IconPicker=25]="IconPicker",e[e.TopBarComposer=30]="TopBarComposer",e[e.Popover=35]="Popover",e[e.FigureAnchor=1e3]="FigureAnchor",e[e.FigureSnapLine=1001]="FigureSnapLine"}(Oe||(Oe={}));let Fe=0;function Me(){return Fe}const Pe="\n",Ne=[6,7,8,9,10,11,12,14,18,24,36],ke={hasFilters:!1,totalRow:!1,firstColumn:!0,lastColumn:!1,numberOfHeaders:1,bandedRows:!0,bandedColumns:!1,styleId:"TableStyleMedium5",automaticAutofill:!1},Le={symbol:"$",position:"before",decimalPlaces:2,code:"",name:"Dollar"},Ve=new RegExp(_e,"g");function He(e){return'"'===e[0]&&(e=e.slice(1)),'"'===e[e.length-1]&&"\\"!==e[e.length-2]?e.slice(0,e.length-1):e}function Ue(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Be(e){const t=Array.isArray(e)?[]:{};switch(typeof e){case"object":if(null===e)return e;if(function(e){return"clone"in e&&e.clone instanceof Function}(e))return e.clone();if(!(function(e){return"object"==typeof e&&null!==e&&(e?.constructor===Object||void 0===e?.constructor)}(e)||e instanceof Array))throw new Error("Unsupported type: only objects and arrays are supported");for(const o in e)t[o]=Be(e[o]);return t;case"number":case"string":case"boolean":case"function":case"undefined":return e;default:throw new Error("Unsupported type: "+typeof e)}}function ze(e){return $e(e,"'")}function $e(e,t='"'){return e.startsWith(t)&&(e=e.slice(1)),e.endsWith(t)&&(e=e.slice(0,-1)),e}function We(e){return e.match(/\w/g)?.length!==e.length&&(e=`'${e}'`),e}function Ge(e,t=" "){return e.replace(Ve,t)}function qe(e,t,o){return e<t?t:e>o?o:e}function Ze(e,t,o=1){if(t<=e&&o>0)return[];if(0===o)throw new Error("range() step must not be zero");const s=Math.ceil(Math.abs((t-e)/o)),i=Array(s);for(let t=0;t<s;t++)i[t]=e+t*o;return i}function je(e){return e.reduce(((e,t,o,s)=>{if(1===Math.abs(t-s[o-1])){e[e.length-1].push(t)}else e.push([t]);return e}),[])}function*Ye(e,t){t.next();for(const o of e){const e=t.next();yield{...o,next:e.done?void 0:e.value}}}function Xe(e){const t=e.toUpperCase();return"TRUE"===t||"FALSE"===t}const Ke=/^\[(.+)\]\((.+)\)$/,Je=/^https?:\/\/(www\.)?[-a-zA-Z0-9@:%._\+~#=]{2,256}\.[a-z]{2,4}\b([-a-zA-Z0-9@:%_\+.~#?&//=]*)$/;function Qe(e){return Ke.test(e)}function et(e){return Je.test(e)}function tt(e,t){return`[${e}](${t})`}function ot(e){const t=e.match(Ke)||[],o=t[1],s=t[2];if(!o||!s)throw new Error(`Could not parse markdown link ${e}.`);return{label:o,url:s}}const st="o-spreadsheet://";function it(e){return e.startsWith(st)}function rt(e){return`${st}${e}`}function nt(e){if(e.startsWith(st))return e.slice(st.length);throw new Error(`${e} is not a valid sheet link`)}function at(e){return void 0!==e}function lt(e){return null!==e}function ct(e){return void 0===e||Object.values(e).every((e=>"object"==typeof e?ct(e):!e))}function ht(e,t,o){let s;const i=function(){const i=this,r=Array.from(arguments);const n=o&&!s;clearTimeout(s),s=setTimeout((function(){s=void 0,o||e.apply(i,r)}),t),n&&e.apply(i,r)};return i.isDebouncePending=()=>void 0!==s,i.stopDebounce=()=>{clearTimeout(s)},i}function dt(e){let t="";for(let o=0,s=e.length;o<s;o++)t+=e[o];return t}function ut(e){let t,o=!1;const s=()=>(o||(t=e instanceof Function?e():e,o=!0),t);return s.map=e=>ut((()=>e(s()))),s}function gt(e,t){let o=e.slice(t).find((e=>e));return o||(o=e.slice(0,t).reverse().find((e=>e))),o||""}function pt(e,t){return"after"===e?t+1:t}function mt(e,t){if(e===t)return!0;if(e&&!t||t&&!e)return!1;if(typeof e!=typeof t)return!1;if("object"!=typeof e)return!1;for(const o in t)if(!(o in e)&&void 0!==t[o])return!1;for(const o in e){if(typeof e[o]!=typeof t[o])return!1;if("object"==typeof e[o]){if(!mt(e[o],t[o]))return!1}else if(e[o]!==t[o])return!1}return!0}function ft(e,t){if(e.length!==t.length)return!1;for(let o=0;o<e.length;o++)if(!mt(e[o],t[o]))return!1;return!0}function vt(e,t){if(e.length<t.length)return!1;const o=new Set(e);return t.every((e=>o.has(e)))}function bt(e){if(!e)return e;const t={...e};return Object.keys(t).forEach((e=>!t[e]&&delete t[e])),t}const St=[" ","\t","\f","\v",String.fromCharCode(parseInt("00a0",16)),String.fromCharCode(parseInt("1680",16)),String.fromCharCode(parseInt("2000",16)),String.fromCharCode(parseInt("200a",16)),String.fromCharCode(parseInt("2028",16)),String.fromCharCode(parseInt("2029",16)),String.fromCharCode(parseInt("202f",16)),String.fromCharCode(parseInt("205f",16)),String.fromCharCode(parseInt("3000",16)),String.fromCharCode(parseInt("feff",16))],yt=new RegExp(St.join("|"),"g"),Ct=/(\r\n|\r)/g;function wt(e){return e?e.replace(Ct,Pe):""}function Et(e){const t=Array.from(e).sort(((e,t)=>e-t));for(let e=1;e<t.length;e++)if(t[e]-t[e-1]!=1)return!1;return!0}function xt(e){const t=new Map,o=e.name?e.name+" (memoized)":"memoized";return{[o]:(...o)=>(t.has(o[0])||t.set(o[0],e(...o)),t.get(o[0]))}[o]}function It(e,t){return e.filter(((e,o)=>!t.includes(o)))}function Rt(e,t,o){const s=[...e];return s.splice(o,0,...t),s}function Tt(e){return e.split("\n").map((e=>e.replace(/\s+/g," ").trim())).join("\n")}function At(e,t,o){return t>o?At(e,o,t):e>=t&&e<=o}function _t(e,t){let o=Ue(e);const s=t.matchCase?"":"i";return t.exactMatch&&(o=`^${o}$`),RegExp(o,s)}function Dt(e){let t=e.length;if(t<1e5)return Math.max(...e);let o=-1/0;for(;t--;)o=e[t]>o?e[t]:o;return o}function Ot(e){let t=e.length;if(t<1e5)return Math.min(...e);let o=1/0;for(;t--;)o=e[t]<o?e[t]:o;return o}class Ft{text;currentIndex=0;current;constructor(e){this.text=e,this.current=e[0]}shift(){const e=this.current,t=this.text[++this.currentIndex];return this.current=t,e}advanceBy(e){this.currentIndex+=e,this.current=this.text[this.currentIndex]}isOver(){return this.currentIndex>=this.text.length}remaining(){return this.text.substring(this.currentIndex)}currentStartsWith(e){if(this.current!==e[0])return!1;for(let t=1;t<e.length;t++)if(this.text[this.currentIndex+t]!==e[t])return!1;return!0}}function Mt(e,t=(e=>e)){const o=new Set;return e.filter((e=>{const s=t(e);return!o.has(s)&&(o.add(s),!0)}))}function Pt(e){const t={};for(const o in e)for(const s in e[o])t[s]||(t[s]={}),t[s][o]=e[o][s];return t}const Nt=/rgba?\(|\s+|\)/gi,kt=/^#([A-F\d]{2}){3,4}$/,Lt=["#eb6d00","#0074d9","#ad8e00","#169ed4","#b10dc9","#00a82d","#00a3a3","#f012be","#3d9970","#111111","#62A300","#ff4136","#949494","#85144b","#001f3f"];function Vt(e){return Ut(e.toString(16).padStart(6,"0"))}function Ht(e){return"number"==typeof e?e:Number.parseInt(Ut(e).slice(1),16)}function Ut(e){let t=e;if(e.startsWith("rgb")?t=function(e){const t=e.replace(Nt,"").split(",");let o=255;if(3!==t.length&&4!==t.length)throw new Error("invalid color");if(4===t.length){const e=parseFloat(t.pop()||"1");o=Math.round(255*(e||1))}const s=t.map((e=>parseInt(e,10)));255!==o&&s.push(o);return"#"+dt(s.map((e=>e.toString(16).padStart(2,"0")))).toUpperCase()}(e):(t=e.replace("#","").toUpperCase(),3!==t.length&&4!==t.length||(t=t.split("").reduce(((e,t)=>e+t+t),"")),t=`#${t}`),!kt.test(t))throw new Error(`invalid color input: ${e}`);return t}function Bt(e){try{return Ut(e),!0}catch(e){return!1}}const zt=e=>e>=0&&e<=255;function $t(e,t,o,s=1){if(!zt(e)||!zt(t)||!zt(o)||s<0||s>1)throw new Error(`Invalid RGBA values ${[e,t,o,s]}`);return{a:s,b:o,g:t,r:e}}function Wt(e){let{r:t,g:o,b:s}=qt(e);t/=255,o/=255,s/=255;const i=e=>e<=.03928?e/12.92:((e+.055)/1.055)**2.4;return.2126*i(t)+.7152*i(o)+.0722*i(s)}function Gt(e){let t=e.r.toString(16),o=e.g.toString(16),s=e.b.toString(16),i=Math.round(255*e.a).toString(16);return 1===t.length&&(t="0"+t),1===o.length&&(o="0"+o),1===s.length&&(s="0"+s),1===i.length&&(i="0"+i),"ff"===i&&(i=""),("#"+t+o+s+i).toUpperCase()}function qt(e){let t,o,s,i;if(7===(e=Ut(e)).length)t=parseInt(e[1]+e[2],16),o=parseInt(e[3]+e[4],16),s=parseInt(e[5]+e[6],16),i=255;else{if(9!==e.length)throw new Error("Invalid color");t=parseInt(e[1]+e[2],16),o=parseInt(e[3]+e[4],16),s=parseInt(e[5]+e[6],16),i=parseInt(e[7]+e[8],16)}return i=+(i/255).toFixed(3),{a:i,r:t,g:o,b:s}}function Zt(e){(e={...e}).s/=100,e.l/=100;let t=(1-Math.abs(2*e.l-1))*e.s,o=t*(1-Math.abs(e.h/60%2-1)),s=e.l-t/2,i=0,r=0,n=0;return 0<=e.h&&e.h<60?(i=t,r=o,n=0):60<=e.h&&e.h<120?(i=o,r=t,n=0):120<=e.h&&e.h<180?(i=0,r=t,n=o):180<=e.h&&e.h<240?(i=0,r=o,n=t):240<=e.h&&e.h<300?(i=o,r=0,n=t):300<=e.h&&e.h<360&&(i=t,r=0,n=o),i=Math.round(255*(i+s)),r=Math.round(255*(r+s)),n=Math.round(255*(n+s)),{a:e.a,r:i,g:r,b:n}}function jt(e){const t=e.r/255,o=e.g/255,s=e.b/255;let i=Math.min(t,o,s),r=Math.max(t,o,s),n=r-i,a=0,l=0,c=0;return a=0===n?0:r===t?(o-s)/n%6:r===o?(s-t)/n+2:(t-o)/n+4,a=Math.round(60*a),a<0&&(a+=360),c=(r+i)/2,l=0===n?0:n/(1-Math.abs(2*c-1)),l=+(100*l).toFixed(1),c=+(100*c).toFixed(1),{a:e.a,h:a,s:l,l:c}}function Yt(e){return Gt(Zt(e))}function Xt(e){return jt(qt(e))}function Kt(e,t){return 1===t?Ut(e).slice(0,7):Gt({...qt(e),a:t})}function Jt(e,t){const o=Xt(e);return 1===t?"#fff":(o.l=t*(100-o.l)+o.l,Yt(o))}function Qt(e,t){const o=Xt(e);return 1===t?"#000":(o.l=o.l-t*o.l,Yt(o))}const eo=["#4EA7F2","#EA6175","#43C5B1","#F4A261","#8481DD","#FFD86D"],to=["#4EA7F2","#3188E6","#43C5B1","#00A78D","#EA6175","#CE4257","#F4A261","#F48935","#8481DD","#5752D1","#FFD86D","#FFBC2C"],oo=["#4EA7F2","#3188E6","#056BD9","#A76DBC","#7F4295","#6D2387","#EA6175","#CE4257","#982738","#43C5B1","#00A78D","#0E8270","#F4A261","#F48935","#BE5D10","#8481DD","#5752D1","#3A3580","#A4A8B6","#7E8290","#545B70","#FFD86D","#FFBC2C","#C08A16"],so=["#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"],io=["#4EA7F2","#43C5B1","#EA6175","#F4A261","#8481DD","#FFD86D","#3188E6","#00A78D","#CE4257","#F48935","#5752D1","#FFBC2C"],ro=["#4EA7F2","#A76DBC","#EA6175","#43C5B1","#F4A261","#8481DD","#A4A8B6","#FFD86D","#3188E6","#7F4295","#CE4257","#00A78D","#F48935","#5752D1","#7E8290","#FFBC2C","#056BD9","#6D2387","#982738","#0E8270","#BE5D10","#3A3580","#545B70","#C08A16"],no=["#4EA7F2","#A76DBC","#EA6175","#43C5B1","#F4A261","#8481DD","#A4A8B6","#FFD86D","#3188E6","#7F4295","#CE4257","#00A78D","#F48935","#5752D1","#7E8290","#FFBC2C","#056BD9","#6D2387","#982738","#0E8270","#BE5D10","#3A3580","#545B70","#C08A16","#155193","#4F1565","#791B29","#105F53","#7D380D","#26235F","#3F4250","#936A12"];function ao(e,t){return t[e%t.length]}function lo(e){return e<=6?eo:e<=12?to:e<=24?oo:so}class co{preferredColors;currentColorIndex=0;palette;constructor(e,t=[]){this.preferredColors=t,this.palette=lo(e).filter((e=>!t.includes(e)))}next(){return this.preferredColors?.[this.currentColorIndex]?this.preferredColors[this.currentColorIndex++]:ao(this.currentColorIndex++,this.palette)}}class ho extends co{constructor(e,t=[]){var o;super(e,t),this.palette=(o=e,o<=6?eo:o<=12?io:o<=24?ro:no).filter((e=>!t.includes(e)))}}function uo(e){if(e.length<2)throw new Error("Color scale must have at least 2 points");const t=[...e.sort(((e,t)=>e.value-t.value))],o=[];for(let e=1;e<t.length;e++){const s=Ht(t[e-1].color),i=Ht(t[e].color);o.push({min:t[e-1].value,max:t[e].value,minColor:s,maxColor:i,colorDiff:go(t[e-1].value,t[e].value,s,i)})}return e=>{if(e<o[0].min)return Vt(o[0].minColor);for(const t of o)if(e>=t.min&&e<=t.max)return Vt(po(e,t.min,t.minColor,t.colorDiff));return Vt(o[o.length-1].maxColor)}}function go(e,t,o,s){const i=t-e;return[((o>>16)%256-(s>>16)%256)/i,((o>>8)%256-(s>>8)%256)/i,(o%256-s%256)/i]}function po(e,t,o,s){const[i,r,n]=s;return Math.round((o>>16)%256-i*(e-t))<<16|Math.round((o>>8)%256-r*(e-t))<<8|Math.round(o%256-n*(e-t))}function mo(e){if(e<0)throw new Error(`number must be positive. Got ${e}`);return e<26?String.fromCharCode(65+e):mo(Math.floor(e/26)-1)+mo(e%26)}function fo(e){let t=0;const o=e.length;for(let s=0;s<o;s++){const o=e.charCodeAt(s);t=26*t+(o>=65&&o<=90?o-64:o-96)}return t-1}function vo(e){return e>="0"&&e<="9"}function bo(e){let t="",o="",s=0;for("$"===(e=e.trim())[s]&&s++;s<e.length&&((i=e[s])>="A"&&i<="Z"||i>="a"&&i<="z");)t+=e[s++];var i;if(0===t.length||t.length>3)throw new Error(`Invalid cell description: ${e}`);for("$"===e[s]&&s++;s<e.length&&vo(e[s]);)o+=e[s++];if(s!==e.length||0===o.length||o.length>7)throw new Error(`Invalid cell description: ${e}`);const r=fo(t),n=Number(o)-1;if(isNaN(n))throw new Error(`Invalid cell description: ${e}`);return{col:r,row:n}}function So(e,t,o={colFixed:!1,rowFixed:!1}){return(o.colFixed?"$":"")+mo(e)+(o.rowFixed?"$":"")+String(t+1)}function yo(e,t=[]){if(e.length<=1&&0===t.length)return e;const o=[0],s=new Map([[0,[]]]);return Co(o,s,e,!1),Co(o,s,t,!0),function(e,t){const o=[];let s=[];for(let i=0;i<e.length;i++){const r=e[i],n=t.get(r);if(!n||0===n.length){o.push(...s),s=[];continue}let a=e[i+1];void 0!==a&&a--;const l=[];for(let e=0;e<n.length;e+=2){const t=n[e];let o=n[e+1];void 0!==o&&o--;const i={top:t,left:r,bottom:o,right:a,hasHeader:void 0===o&&0!==t||void 0===a&&0!==r};let c=!1;for(let e=s.length-1;e>=0;e--){const t=s[e];if(t.top===i.top&&t.bottom===i.bottom){t.right=i.right,s.splice(e,1),l.push(t),c=!0;break}}c||l.push(i)}o.push(...s),s=l}return o.push(...s),o}(o,s)}function Co(e,t,o,s=!1){for(const i of o){const o=i.left,r=void 0===i.right?void 0:i.right+1,n=wo(e,t,o,!0,0),a=wo(e,t,r,!1,n);for(let o=n;o<=a;o++){Eo(t.get(e[o]),i,s)}xo(e,t,n,a)}}function wo(e,t,o,s,i){if(void 0===o)return e.length-1;const r=Io(e,o,i);return o!=e[r]?(e.splice(r+1,0,o),t.set(o,[...t.get(e[r])]),s?r+1:r):s?r:r-1}function Eo(e,t,o=!1){const s=t.top,i=void 0===t.bottom?void 0:t.bottom+1,r=[],n=Io(e,s,0,!1);if((n%2!=0&&!o||n%2==0&&o)&&r.push(s),void 0===i)return e.splice(n+1),void e.push(...r);const a=function(e,t,o=0,s=!0){let i=e.length-1,r=e.length;for(;o<=i;){const n=Math.floor((o+i)/2);if(e[n]===t&&s)return n;e[n]>t?(r=n,i=n-1):o=n+1}return r}(e,i,0,!1);(a%2==0&&!o||a%2!=0&&o)&&r.push(i),e.splice(n+1,a-n-1,...r)}function xo(e,t,o,s){const i=o-1==-1?0:o-1;for(let o=s===e.length-1?s:s+1;o>i;o--)ft(t.get(e[o]),t.get(e[o-1]))&&(t.delete(e[o]),e.splice(o,1))}function Io(e,t,o=0,s=!0){let i=e.length-1,r=-1;for(;o<=i;){const n=Math.floor((o+i)/2);if(e[n]===t&&s)return n;e[n]<t?(r=n,o=n+1):i=n-1}return r}const Ro=e=>e,To=()=>!1;let Ao=Ro,_o=To;function Do(e,...t){if(1!==t.length||"object"!=typeof t[0]||t[0]instanceof String)t.length>0&&(e=e.replace(/\%s/g,(()=>t.shift())));else{const o=t[0];e=e.replace(/\%\(([^\)]+)\)s/g,((e,t)=>o[t]))}return e}const Oo=function(e,...t){return _o()?Do(Ao(e),...t):new Fo(e,t)};class Fo extends String{values;constructor(e,t){super(e),this.values=t}valueOf(){const e=super.valueOf();return _o()?Do(Ao(e),...this.values):Do(e,...this.values)}toString(){return this.valueOf()}}const Mo=new RegExp(/\$?([A-Z]{1,3})\$?([0-9]{1,7})/,"i"),Po=new RegExp(/^\$?([A-Z]{1,3})\$?([0-9]{1,7})$/,"i"),No=new RegExp(/^\$?([A-Z]{1,3})+$/,"i"),ko=new RegExp(/^\$?([0-9]{1,7})+$/,"i"),Lo=new RegExp(/^\s*('.+'!|[^']+!)?\$?([A-Z]{1,3})$/,"i"),Vo=new RegExp(/^\s*('.+'!|[^']+!)?\$?([0-9]{1,7})$/,"i"),Ho=new RegExp(/^\s*('.+'!|[^']+!)?/.source+"("+[Mo.source,/(\$?[A-Z]{1,3})?\$?[0-9]{1,7}\s*:\s*(\$?[A-Z]{1,3})?\$?[0-9]{1,7}\s*/i.source,/\$?[A-Z]{1,3}(\$?[0-9]{1,7})?\s*:\s*\$?[A-Z]{1,3}(\$?[0-9]{1,7})?\s*/i.source].join("|")+")"+/$/.source,"i");function Uo(e){return Lo.test(e)}function Bo(e){return Vo.test(e)}function zo(e){return No.test(e)}function $o(e){return ko.test(e)}function Wo(e){return Po.test(e)}function Go(e){if(!e.includes("!"))return{xc:e};const t=e.split("!"),o=t.pop();return{sheetName:ze(t.join("!"))||void 0,xc:o}}function qo(e,t){return void 0!==e?`${We(e)}!${t}`:t}function Zo(e){const t=function(e){e.includes("!")&&(e=e.split("!").at(-1)),e.includes("$")&&(e=e.replaceAll("$",""));let t,o,s,i,r,n="";e.includes(":")?([n,t]=e.split(":"),n=n.trim(),t=t.trim()):n=e.trim();let a=!1,l=!1,c=!1;if(Uo(n))i=r=fo(n),o=s=0,a=!0;else if(Bo(n))o=s=parseInt(n,10)-1,i=r=0,l=!0;else{const e=bo(n);i=r=e.col,o=s=e.row,c=!0}if(t)if(Uo(t))r=fo(t),a=!0;else if(Bo(t))s=parseInt(t,10)-1,l=!0;else{const e=bo(t);r=e.col,s=e.row,o=a?s:o,i=l?r:i,c=!0}if(a&&l)throw new Error("Wrong zone xc. The zone cannot be at the same time a full column and a full row");const h={top:o,left:i,bottom:a?void 0:s,right:l?void 0:r};return c=c&&(l||a),c&&(h.hasHeader=c),h}(e);if(void 0!==t.right&&t.right<t.left){const e=t.left;t.left=t.right,t.right=e}if(void 0!==t.bottom&&t.bottom<t.top){const e=t.top;t.top=t.bottom,t.bottom=e}return t}function jo(e){const t=Zo(e);if(void 0===t.bottom||void 0===t.right)throw new Error("This does not support unbounded ranges");return t}function Yo(e){const{bottom:t,top:o,left:s,right:i}=e;return!(void 0!==t&&isNaN(t)||isNaN(o)||isNaN(s)||void 0!==i&&isNaN(i))&&(Xo(e)&&e.top>=0&&e.left>=0)}function Xo(e){return(void 0===e.bottom||e.bottom>=e.top&&e.bottom>=0)&&(void 0===e.right||e.right>=e.left&&e.right>=0)}function Ko(e){const{top:t,bottom:o,left:s,right:i}=e,r="hasHeader"in e&&e.hasHeader,n=t===o&&s===i;if(void 0===o&&void 0!==i)return 0!==t||r?`${So(s,t)}:${mo(i)}`:`${mo(s)}:${mo(i)}`;if(void 0===i&&void 0!==o)return 0!==s||r?`${So(s,t)}:${o+1}`:`${t+1}:${o+1}`;if(void 0!==o&&void 0!==i)return n?So(s,t):`${So(s,t)}:${So(i,o)}`;throw new Error(Oo("Bad zone format"))}function Jo(e,t,o,s,i){const r="left"===t?"columns":"rows",n="before"===s?o-1:o,a=e["left"===t?"right":"bottom"];return e[t]<=n&&a&&a>n?gs(e,r,"RESIZE",i):n<e[t]?gs(e,r,"MOVE",i):{...e}}function Qo(e,t,o,s,i){const r="left"===t?"columns":"rows",n="before"===s?o-1:o,a="left"===t?"right":"bottom";return e[t]<=n&&e[a]>n?gs(e,r,"RESIZE",i):n<e[t]?gs(e,r,"MOVE",i):{...e}}function es(e,t,o){const s="left"===t?"right":"bottom";let i=e[t],r=e[s];for(let n of o.sort(((e,t)=>t-e)))e[t]>n&&(i--,r--),e[t]<n&&e[s]>=n&&r--;return{...e,[t]:i,[s]:r}}function ts(e,t,o){const s="left"===t?"right":"bottom";let i=e[t],r=e[s];const n=e[s];for(let s of o.sort(((e,t)=>t-e)))e[t]>s&&(i--,void 0!==r&&r--),void 0!==n&&void 0!==r&&e[t]<=s&&n>=s&&r--;if(!(void 0!==r&&i>r))return{...e,[t]:i,[s]:r}}function os(...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 ss(e,t){if(rs(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 is(e,t){return e.left===t.left&&e.right===t.right&&e.top===t.top&&e.bottom===t.bottom}function rs(e,t){return!(e.bottom<t.top||t.bottom<e.top)&&!(e.right<t.left||t.right<e.left)}function ns(e,t,o){const{left:s,right:i,top:r,bottom:n}=o;return e>=s&&e<=i&&t>=r&&t<=n}function as(e,t){return is(os(t,e),t)}function ls(e){return{numberOfRows:e.bottom-e.top+1,numberOfCols:e.right-e.left+1}}function cs(e){const{numberOfCols:t,numberOfRows:o}=ls(e);return 1===t||1===o}function hs(e){const t={};for(const o of e)t[o.sheetId]??=[],t[o.sheetId].push(ms(o));for(const e in t)t[e]=yo(t[e]);return t}function ds(e){const t=[],{left:o,right:s,top:i,bottom:r}=us(e);for(const e of Ze(o,s+1))for(const o of Ze(i,r+1))t.push({col:e,row:o});return t}function us(e){return e.left>e.right&&(e={left:e.right,right:e.left,top:e.top,bottom:e.bottom}),e.top>e.bottom&&(e={left:e.left,right:e.right,top:e.bottom,bottom:e.top}),e}function gs(e,t,o,s){const i="both"===t?s[0]:"columns"===t?s:0,r="both"===t?s[1]:"rows"===t?s:0,n="hasHeader"in e&&e.hasHeader;let a;a=!function(e){return void 0===e.bottom}(e)||n?!(vs(e)&&!n)||"columns"!==t:"rows"!==t;const l={...e};return a&&"MOVE"===o&&(l.left+=i,l.top+=r),void 0!==l.right&&(l.right+=i),void 0!==l.bottom&&(l.bottom+=r),l}function ps(e,t){let o,s;const{left:i,right:r,top:n,bottom:a}=e,{left:l,right:c,top:h,bottom:d}=t;return o=l!=i?l:c!=r?c:l,s=h!=n?h:d!=a?d:h,{col:o,row:s}}function ms(e){return{left:e.col,right:e.col,top:e.row,bottom:e.row}}function fs(e){return{...e,right:e.left,bottom:e.top}}function vs(e){return void 0===e.right}function bs(e){return(e.bottom-e.top+1)*(e.right-e.left+1)}function Ss(e){return e.length<2||1===yo(e).length}function ys(e){const t=[...e];let o=!0;for(;o;){o=!1;for(let e=0;e<t.length;e++){const s=t[e],i=t.findIndex(((t,o)=>{return e!==o&&(r=s,((i=t).right+1===r.left||i.left===r.right+1?i.top<=r.bottom&&i.top>=r.top||r.top<=i.bottom&&r.top>=i.top:(i.bottom+1===r.top||i.top===r.bottom+1)&&(i.left<=r.right&&i.left>=r.left||r.left<=i.right&&r.left>=i.left))||rs(t,s));var i,r}));if(-1!==i){t[e]=os(t[i],s),t.splice(i,1),o=!0;break}}}return t}function Cs(e,t){for(const o in t)if(mt(t[o],e))return parseInt(o,10);const o=Object.keys(t),s=0===o.length?0:Dt(o.map((e=>parseInt(e,10))));return t[s+1]=e,s+1}function ws(e){const t={};for(const o in e){const s=yo(e[o].map(ms));for(const e of s)t[Ko(e)]=Number(o)}return t}function*Es(e,t){for(const o in t){const s=jo(o),i=t[o];for(let t=s.top;t<=s.bottom;t++)for(let o=s.left;o<=s.right;o++){const s={sheetId:e,col:o,row:t};yield[s,i]}}}class xs{jsDate;constructor(e,t,o,s=0,i=0,r=0){this.jsDate=new Date(Date.UTC(e,t,o,s,i,r,0))}static fromTimestamp(e){const t=new Date(e);return new xs(t.getUTCFullYear(),t.getUTCMonth(),t.getUTCDate(),t.getUTCHours(),t.getUTCMinutes(),t.getUTCSeconds())}static now(){const e=new Date;return new xs(e.getFullYear(),e.getMonth(),e.getDate(),e.getHours(),e.getMinutes(),e.getSeconds())}toString(){return this.jsDate.toString()}toLocaleDateString(){return this.jsDate.toLocaleDateString()}getTime(){return this.jsDate.getTime()}getFullYear(){return this.jsDate.getUTCFullYear()}getMonth(){return this.jsDate.getUTCMonth()}getQuarter(){return Math.floor(this.getMonth()/3)+1}getDate(){return this.jsDate.getUTCDate()}getDay(){return this.jsDate.getUTCDay()}getHours(){return this.jsDate.getUTCHours()}getMinutes(){return this.jsDate.getUTCMinutes()}getSeconds(){return this.jsDate.getUTCSeconds()}getIsoWeek(){const e=new Date(this.jsDate.getTime()),t=e.getUTCDay()||7;e.setUTCDate(e.getUTCDate()+4-t);const o=new Date(Date.UTC(e.getUTCFullYear(),0,1));return Math.ceil(((e.getTime()-o.getTime())/864e5+1)/7)}setFullYear(e){return this.jsDate.setUTCFullYear(e)}setMonth(e){return this.jsDate.setUTCMonth(e)}setDate(e){return this.jsDate.setUTCDate(e)}setHours(e){return this.jsDate.setUTCHours(e)}setMinutes(e){return this.jsDate.setUTCMinutes(e)}setSeconds(e){return this.jsDate.setUTCSeconds(e)}}const Is=new xs(1899,11,30),Rs=864e5,Ts=2e3,As=xs.now().getFullYear(),_s=xs.now().getMonth(),Ds=xs.fromTimestamp(0).getTime()-Is.getTime(),Os=/^\d{1,2}(\/|-|\s)\d{1,2}((\/|-|\s)\d{1,4})?$/,Fs=/^\d{3,4}(\/|-|\s)\d{1,2}(\/|-|\s)\d{1,2}$/,Ms=/\/|-|\s/,Ps=/^(\d{1,4})[\/-\s](\d{1,4})([\/-\s](\d{1,4}))?$/,Ns=/((\d+(:\d+)?(:\d+)?\s*(AM|PM))|(\d+:\d+(:\d+)?))$/;function ks(e,t){switch(typeof e){case"number":return e;case"string":return Ls(e,t)?Hs(e,t)?.value:!e||isNaN(Number(e))?void 0:Number(e);default:return}}function Ls(e,t){return null!==Hs(e,t)}const Vs=new Map;function Hs(e,t){return Vs.has(t)||Vs.set(t,new Map),Vs.get(t).has(e)||Vs.get(t).set(e,function(e,t){e=e.trim();let o=null;const s=e.match(Ns);if(s){if(o=function(e){if(e=e.trim(),Ns.test(e)){const t=/AM/i.test(e),o=/PM/i.test(e),s=(t||o?e.substring(0,e.length-2).trim():e).split(/:/),i=s.length>=2,r=3===s.length;let n=Number(s[0]),a=i?Number(s[1]):0,l=r?Number(s[2]):0,c=r?"hh:mm:ss":"hh:mm";if(t||o)c+=" a";else if(!i)return null;n>=12&&t?n-=12:n<12&&o&&(n+=12),a+=Math.floor(l/60),l%=60,n+=Math.floor(a/60),a%=60,n>=24&&(c="hhhh:mm:ss");return{value:n/24+a/1440+l/86400,format:c,jsDate:new xs(1899,11,30,n,a,l)}}return null}(s[0]),null===o)return null;e=e.replace(s[0],"").trim()}let i=null;const r=function(e,t){const o=e.match(Ps);if(!o)return null;const[,s,i,,r]=o;if(s.length>2&&r&&r.length>2)return null;if(s.length>2)return{year:s,month:i,day:r,dateString:e,type:"ymd"};const n=function(e){switch(e.dateFormat[0]){case"d":return"dmy";case"m":return"mdy";case"y":return"ymd"}throw new Error("Invalid date format in locale")}(t);if(!r)return i.length>2?{month:s,year:i,day:void 0,dateString:e,type:n}:"dmy"===n?{day:s,month:i,year:r,dateString:e,type:"dmy"}:{month:s,day:i,year:r,dateString:e,type:"mdy"};if(r.length>2)return"mdy"===n?{month:s,day:i,year:r,dateString:e,type:"mdy"}:{day:s,month:i,year:r,dateString:e,type:"dmy"};if("mdy"===n)return{month:s,day:i,year:r,dateString:e,type:"mdy"};if("ymd"===n)return{year:s,month:i,day:r,dateString:e,type:"ymd"};if("dmy"===n)return{day:s,month:i,year:r,dateString:e,type:"dmy"};return null}(e,t);if(r){const t=r.dateString.match(Ms)[0];if(i=function(e,t){let{year:o,month:s,day:i}=e;const r=function(e){if(!e)return _s;const t=Number(e);if(t>=1&&t<=12)return t-1;return null}(s),n=function(e){if(!e)return 1;const t=Number(e);if(t>=0&&t<=31)return t;return null}(i),a=function(e){if(!e)return As;const t=Number(e);switch(e.length){case 1:return Ts+t;case 2:return Ts+(Ts+t>As+10?-100:0)+t;case 3:case 4:return t}return null}(o);if(null===a||null===r||null===n)return null;const l=2===s?.length&&r+1<10||2===i?.length&&n<10,c=2!==o?.length,h=new xs(a,r,n);if(h.getMonth()!==r||h.getDate()!==n)return null;const d=h.getTime()-Is.getTime(),u=function(e,t,o,s){const i=e.year?s?"yyyy":"yy":void 0,r=e.month?o?"mm":"m":void 0,n=e.day?o?"dd":"d":void 0;switch(e.type){case"mdy":return[r,n,i].filter(at).join(t);case"ymd":return[i,r,n].filter(at).join(t);case"dmy":return[n,r,i].filter(at).join(t)}}(e,t,l,c);return{value:Math.round(d/Rs),format:u,jsDate:h}}(r,t),null===i)return null;e=e.replace(r.dateString,"").trim()}if(""!==e||!i&&!o)return null;if(i&&i.jsDate&&o&&o.jsDate)return{value:i.value+o.value,format:i.format+" "+("hhhh:mm:ss"===o.format?"hh:mm:ss":o.format),jsDate:new xs(i.jsDate.getFullYear()+o.jsDate.getFullYear()-1899,i.jsDate.getMonth()+o.jsDate.getMonth()-11,i.jsDate.getDate()+o.jsDate.getDate()-30,i.jsDate.getHours()+o.jsDate.getHours(),i.jsDate.getMinutes()+o.jsDate.getMinutes(),i.jsDate.getSeconds()+o.jsDate.getSeconds())};return i||o}(e,t)),Vs.get(t).get(e)}function Us(e){const t=Math.trunc(e);let o=xs.fromTimestamp(t*Rs-Ds),s=e-t;s=s<0?1+s:s;const i=Math.round(24*s),r=Math.round(24*(s-i/24)*60),n=Math.round(24*(s-i/24-r/24/60)*60*60);return o.setHours(i),o.setMinutes(r),o.setSeconds(n),o}function Bs(e){return Math.round(zs(e))}function zs(e){return(e.getTime()-Is.getTime())/Rs}function $s(e){return new xs(e.getFullYear(),e.getMonth()+1,0).getDate()}function Ws(e){return $s(e)===e.getDate()}function Gs(e,t,o){const s=e.getFullYear(),i=e.getMonth(),r=e.getDate(),n=new xs(s,i+t,1);return o&&r===$s(e)||r>$s(n)?n.setDate($s(n)):n.setDate(r),n}function qs(e){const t=Math.trunc(e);return t%4==0&&t%100!=0||t%400==0}function Zs(e,t,o){if(e===t)return 0;if(e>t){const o=t;t=e,e=o}const s=Us(e),i=Us(t);let r=s.getDate(),n=i.getDate();const a=s.getMonth(),l=i.getMonth(),c=s.getFullYear(),h=i.getFullYear();let d=0,u=0;switch(o){case 0:31===r&&(r=30),30===r&&31===n&&(n=30),1===a&&r===(qs(c)?29:28)&&(r=30,1===l&&n===(qs(h)?29:28)&&(n=30)),d=c+(30*a+r)/360,u=h+(30*l+n)/360;break;case 1:let o=365;const s=c===h;if(!s&&!(c+1===h)||!s&&a<l||!s&&a===l&&r<n){let e=0,t=0;for(let o=c;o<=h;o++)e++,t+=qs(o)?366:365;o=t/e}else s?qs(c)&&(o=366):(qs(c)&&a<2&&(o=366),qs(h)&&(l>1||1===l&&29===n)&&(o=366));d=e/o,u=t/o;break;case 2:d=e/360,u=t/360;break;case 3:d=e/365,u=t/365;break;case 4:31===r&&(r=30),31===n&&(n=30),d=c+(30*a+r)/360,u=h+(30*l+n)/360}return u-d}function js(e,t){const o=12*(t.getFullYear()-e.getFullYear())+t.getMonth()-e.getMonth();return e.getDate()>t.getDate()?o-1:o}function Ys(e,t){const o=e.getTime(),s=t.getTime();return Math.floor((s-o)/Rs)}function Xs(e,t){const o=t.getFullYear()-e.getFullYear(),s=e.getMonth(),i=t.getMonth(),r=e.getDate(),n=t.getDate();return i>s||i===s&&n>=r?o:o-1}function Ks(e,t,o){return t>o?Ks(e,o,t):(e=Math.trunc(e),t=Math.trunc(t),o=Math.trunc(o),e>=t&&e<=o)}const Js=xt((function(e){return e=Ue(e),new RegExp(`(?:^-?\\d+(?:${e}?\\d*(?:e\\d+)?)?|^-?${e}\\d+)(?!\\w|!)`)})),Qs=xt((function(e){const t=Ue(e.decimalSeparator),o="(?:\\s*"+`(?:\\d+(?:${Ue(e.thousandsSeparator||"")}\\d{3,})*(?:${t}\\d*)?)`+"|"+`(?:${t}\\d+)`+")(?:e(?:\\+|-)?\\d+)?(?:\\s*%)?",s="(?:\\s*-)?",i="(?:\\s*[\\$€])?",r="^(?:(?:"+[s+i+o,s+o+i,i+s+o].join(")|(?:")+"))$";return new RegExp(r,"i")}));function ei(e,t){return!!e&&Qs(t).test(e.trim())}const ti=xt((function(e){return new RegExp(`[$€${Ue(e.thousandsSeparator||"")}]`,"g")}));function oi(e,t){e=e.replace(ti(t),""),"."!==t.decimalSeparator&&(e=e.replace(t.decimalSeparator,"."));let o=Number(e);return isNaN(o)&&e.includes("%")&&(o=Number(e.split("%")[0]),!isNaN(o))?o/100:o}function si(e,t,o){const s=[...e].sort(((e,t)=>e-t));let i=(s.length+(o?-1:1))*t;if(o||i--,Number.isInteger(i))return s[i];const r=Math.ceil(i),n=Math.floor(i);return s[r]*(i-n)+s[n]*(r-i)}var ii,ri;!function(e){e.boolean="boolean",e.number="number",e.text="text",e.empty="empty",e.error="error"}(ii||(ii={})),function(e){e.PlainText="text/plain",e.Html="text/html"}(ri||(ri={}));const ni=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"]),ai=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"]),li=new Set(["MOVE_RANGES"]),ci=new Set(["DUPLICATE_SHEET","EVALUATE_CELLS","ADD_CONDITIONAL_FORMAT","REMOVE_CONDITIONAL_FORMAT","CHANGE_CONDITIONAL_FORMAT_PRIORITY"]),hi=new Set(["AUTOFILL_CELL","SET_BORDER","SET_ZONE_BORDERS"]),di=new Set(["START","ACTIVATE_SHEET","COPY","RESIZE_SHEETVIEW","SET_VIEWPORT_OFFSET","EVALUATE_CELLS","EVALUATE_CHARTS","SET_FORMULA_VISIBILITY","UPDATE_FILTER"]),ui=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","CREATE_CHART","UPDATE_CHART","CREATE_TABLE","REMOVE_TABLE","UPDATE_TABLE","CREATE_TABLE_STYLE","REMOVE_TABLE_STYLE","CREATE_IMAGE","GROUP_HEADERS","UNGROUP_HEADERS","UNFOLD_HEADER_GROUP","FOLD_HEADER_GROUP","FOLD_ALL_HEADER_GROUPS","UNFOLD_ALL_HEADER_GROUPS","UNFOLD_HEADER_GROUPS_IN_ZONE","FOLD_HEADER_GROUPS_IN_ZONE","ADD_DATA_VALIDATION_RULE","REMOVE_DATA_VALIDATION_RULE","UPDATE_LOCALE","ADD_PIVOT","UPDATE_PIVOT","INSERT_PIVOT","RENAME_PIVOT","REMOVE_PIVOT","DUPLICATE_PIVOT"]);function gi(e){return ui.has(e.type)}class pi{reasons;constructor(e=[]){Array.isArray(e)||(e=[e]),e=[...new Set(e)],this.reasons=e.filter((e=>"Success"!==e))}static get Success(){return mi}get isSuccessful(){return 0===this.reasons.length}isCancelledBecause(e){return this.reasons.includes(e)}}const mi=new pi;var fi;e.CommandResult=void 0,(fi=e.CommandResult||(e.CommandResult={})).Success="Success",fi.CancelledForUnknownReason="CancelledForUnknownReason",fi.WillRemoveExistingMerge="WillRemoveExistingMerge",fi.MergeIsDestructive="MergeIsDestructive",fi.CellIsMerged="CellIsMerged",fi.InvalidTarget="InvalidTarget",fi.EmptyUndoStack="EmptyUndoStack",fi.EmptyRedoStack="EmptyRedoStack",fi.NotEnoughElements="NotEnoughElements",fi.NotEnoughSheets="NotEnoughSheets",fi.MissingSheetName="MissingSheetName",fi.UnchangedSheetName="UnchangedSheetName",fi.DuplicatedSheetName="DuplicatedSheetName",fi.DuplicatedSheetId="DuplicatedSheetId",fi.ForbiddenCharactersInSheetName="ForbiddenCharactersInSheetName",fi.WrongSheetMove="WrongSheetMove",fi.WrongSheetPosition="WrongSheetPosition",fi.InvalidAnchorZone="InvalidAnchorZone",fi.SelectionOutOfBound="SelectionOutOfBound",fi.TargetOutOfSheet="TargetOutOfSheet",fi.WrongCutSelection="WrongCutSelection",fi.WrongPasteSelection="WrongPasteSelection",fi.WrongPasteOption="WrongPasteOption",fi.WrongFigurePasteOption="WrongFigurePasteOption",fi.EmptyClipboard="EmptyClipboard",fi.EmptyRange="EmptyRange",fi.InvalidRange="InvalidRange",fi.InvalidZones="InvalidZones",fi.InvalidSheetId="InvalidSheetId",fi.InvalidFigureId="InvalidFigureId",fi.InputAlreadyFocused="InputAlreadyFocused",fi.MaximumRangesReached="MaximumRangesReached",fi.MinimumRangesReached="MinimumRangesReached",fi.InvalidChartDefinition="InvalidChartDefinition",fi.InvalidDataSet="InvalidDataSet",fi.InvalidLabelRange="InvalidLabelRange",fi.InvalidScorecardKeyValue="InvalidScorecardKeyValue",fi.InvalidScorecardBaseline="InvalidScorecardBaseline",fi.InvalidGaugeDataRange="InvalidGaugeDataRange",fi.EmptyGaugeRangeMin="EmptyGaugeRangeMin",fi.GaugeRangeMinNaN="GaugeRangeMinNaN",fi.EmptyGaugeRangeMax="EmptyGaugeRangeMax",fi.GaugeRangeMaxNaN="GaugeRangeMaxNaN",fi.GaugeRangeMinBiggerThanRangeMax="GaugeRangeMinBiggerThanRangeMax",fi.GaugeLowerInflectionPointNaN="GaugeLowerInflectionPointNaN",fi.GaugeUpperInflectionPointNaN="GaugeUpperInflectionPointNaN",fi.GaugeLowerBiggerThanUpper="GaugeLowerBiggerThanUpper",fi.InvalidAutofillSelection="InvalidAutofillSelection",fi.MinBiggerThanMax="MinBiggerThanMax",fi.LowerBiggerThanUpper="LowerBiggerThanUpper",fi.MidBiggerThanMax="MidBiggerThanMax",fi.MinBiggerThanMid="MinBiggerThanMid",fi.FirstArgMissing="FirstArgMissing",fi.SecondArgMissing="SecondArgMissing",fi.MinNaN="MinNaN",fi.MidNaN="MidNaN",fi.MaxNaN="MaxNaN",fi.ValueUpperInflectionNaN="ValueUpperInflectionNaN",fi.ValueLowerInflectionNaN="ValueLowerInflectionNaN",fi.MinInvalidFormula="MinInvalidFormula",fi.MidInvalidFormula="MidInvalidFormula",fi.MaxInvalidFormula="MaxInvalidFormula",fi.ValueUpperInvalidFormula="ValueUpperInvalidFormula",fi.ValueLowerInvalidFormula="ValueLowerInvalidFormula",fi.InvalidSortAnchor="InvalidSortAnchor",fi.InvalidSortZone="InvalidSortZone",fi.SortZoneWithArrayFormulas="SortZoneWithArrayFormulas",fi.WaitingSessionConfirmation="WaitingSessionConfirmation",fi.MergeOverlap="MergeOverlap",fi.TooManyHiddenElements="TooManyHiddenElements",fi.Readonly="Readonly",fi.InvalidViewportSize="InvalidViewportSize",fi.InvalidScrollingDirection="InvalidScrollingDirection",fi.ViewportScrollLimitsReached="ViewportScrollLimitsReached",fi.FigureDoesNotExist="FigureDoesNotExist",fi.InvalidConditionalFormatId="InvalidConditionalFormatId",fi.InvalidCellPopover="InvalidCellPopover",fi.EmptyTarget="EmptyTarget",fi.InvalidFreezeQuantity="InvalidFreezeQuantity",fi.FrozenPaneOverlap="FrozenPaneOverlap",fi.ValuesNotChanged="ValuesNotChanged",fi.InvalidFilterZone="InvalidFilterZone",fi.TableNotFound="TableNotFound",fi.TableOverlap="TableOverlap",fi.InvalidTableConfig="InvalidTableConfig",fi.InvalidTableStyle="InvalidTableStyle",fi.FilterNotFound="FilterNotFound",fi.MergeInTable="MergeInTable",fi.NonContinuousTargets="NonContinuousTargets",fi.DuplicatedFigureId="DuplicatedFigureId",fi.InvalidSelectionStep="InvalidSelectionStep",fi.DuplicatedChartId="DuplicatedChartId",fi.ChartDoesNotExist="ChartDoesNotExist",fi.InvalidHeaderIndex="InvalidHeaderIndex",fi.InvalidQuantity="InvalidQuantity",fi.MoreThanOneColumnSelected="MoreThanOneColumnSelected",fi.EmptySplitSeparator="EmptySplitSeparator",fi.SplitWillOverwriteContent="SplitWillOverwriteContent",fi.NoSplitSeparatorInSelection="NoSplitSeparatorInSelection",fi.NoActiveSheet="NoActiveSheet",fi.InvalidLocale="InvalidLocale",fi.MoreThanOneRangeSelected="MoreThanOneRangeSelected",fi.NoColumnsProvided="NoColumnsProvided",fi.ColumnsNotIncludedInZone="ColumnsNotIncludedInZone",fi.DuplicatesColumnsSelected="DuplicatesColumnsSelected",fi.InvalidHeaderGroupStartEnd="InvalidHeaderGroupStartEnd",fi.HeaderGroupAlreadyExists="HeaderGroupAlreadyExists",fi.UnknownHeaderGroup="UnknownHeaderGroup",fi.UnknownDataValidationRule="UnknownDataValidationRule",fi.UnknownDataValidationCriterionType="UnknownDataValidationCriterionType",fi.InvalidDataValidationCriterionValue="InvalidDataValidationCriterionValue",fi.InvalidNumberOfCriterionValues="InvalidNumberOfCriterionValues",fi.InvalidCopyPasteSelection="InvalidCopyPasteSelection",fi.NoChanges="NoChanges",fi.InvalidInputId="InvalidInputId",fi.SheetIsHidden="SheetIsHidden",fi.InvalidTableResize="InvalidTableResize",fi.PivotIdNotFound="PivotIdNotFound",fi.PivotInError="PivotInError",fi.EmptyName="EmptyName",fi.ValueCellIsInvalidFormula="ValueCellIsInvalidFormula",fi.InvalidDefinition="InvalidDefinition",fi.InvalidColor="InvalidColor";const vi=[{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:";"}],bi=vi[0],Si=["thin","medium","thick","dashed","dotted"];function yi(e){return Array.isArray(e)&&Array.isArray(e[0])}var Ci;!function(e){e.UP="up",e.DOWN="down",e.LEFT="left",e.RIGHT="right"}(Ci||(Ci={}));const wi={Background:0,Highlights:1,Clipboard:2,Chart:4,Autofill:5,Selection:6,Headers:100},Ei=xt((()=>Object.keys(wi).sort(((e,t)=>wi[e]-wi[t]))));const xi={NotAvailable:"#N/A",InvalidReference:"#REF",BadExpression:"#BAD_EXPR",CircularDependency:"#CYCLE",UnknownFunction:"#NAME?",DivisionByZero:"#DIV/0!",SpilledBlocked:"#SPILL!",GenericError:"#ERROR",NullError:"#NULL!"},Ii=new Set(Object.values(xi));class Ri extends Error{value;constructor(e=Oo("Error"),t=xi.GenericError){super(e),this.value=t}}class Ti extends Ri{constructor(e=Oo("Invalid expression")){super(e,xi.BadExpression)}}class Ai extends Ri{constructor(e=Oo("Invalid reference")){super(e,xi.InvalidReference)}}class _i extends Ri{constructor(e=Oo("Data not available")){super(e,xi.NotAvailable)}}class Di extends Ri{constructor(e=Oo("Unknown function")){super(e,xi.UnknownFunction)}}class Oi extends Ri{constructor(e=Oo("Spill range is not empty")){super(e,xi.SpilledBlocked)}}const Fi=["number","string","boolean","undefined"];function Mi(e,t,o){if(!e())throw new Ri(t,o)}function Pi(e){if(void 0!==e)return yi(e)?e[0][0]?.format:e.format}function Ni(e){return"string"==typeof e&&Ii.has(e)}const ki=e=>Oo("The function [[FUNCTION_NAME]] expects a number value, but '%s' is a string, and cannot be coerced to a number.",e);function Li(e,t){const o=Xi(e);switch(typeof o){case"number":return o;case"boolean":return o?1:0;case"string":if(ei(o,t)||""===o)return oi(o,t);const e=Hs(o,t);if(e)return e.value;throw new Ri(ki(o));default:return 0}}function Vi(e,t){try{return Li(e,t)}catch(e){return}}function Hi(e,t){return fr(e).map((e=>e.map((e=>{if("number"!=typeof e.value)throw new Ri(Oo("Function [[FUNCTION_NAME]] expects number values for %s, but got a %s.",t,typeof e.value));return e.value}))))}function Ui(e,t){const o=Xi(e);if(""===o)throw new Ri(ki(o));return Li(o,t)}function Bi(e,t){return Math.trunc(Li(e,t))}function zi(e,t){return Math.trunc(Ui(e,t))}function $i(e){Mi((()=>e>=1),Oo("The function [[FUNCTION_NAME]] expects a number value to be greater than or equal to 1, but receives %s.",e.toString()))}function Wi(e){Mi((()=>0!==e),Oo("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error."),xi.DivisionByZero)}function Gi(e){const t=Xi(e);switch(typeof t){case"string":return t;case"number":return t.toString();case"boolean":return t?"TRUE":"FALSE";default:return""}}const qi=xt((function(e){return e.toLowerCase().normalize("NFD").replace(/[\u0300-\u036f]/g,"")})),Zi=e=>Oo("The function [[FUNCTION_NAME]] expects a boolean value, but '%s' is a text, and cannot be coerced to a boolean.",e);function ji(e){const t=Xi(e);switch(typeof t){case"boolean":return t;case"string":if(t){let e=t.toUpperCase();if("TRUE"===e)return!0;if("FALSE"===e)return!1;throw new Ri(Zi(t))}return!1;case"number":return!!t;default:return!1}}function Yi(e,t){return Us(Li(Xi(e),t))}function Xi(e){if("object"==typeof e&&null!==e&&"value"in e){if(Ni(e.value))throw e;return e.value}if(Ni(e))throw new Ri("",e);return e}function Ki(e,t,o){for(let s of e)if(yi(s)){const e=s.length,o=s[0].length;for(let i=0;i<o;i++)for(let o=0;o<e;o++)t(s[o][i])}else o(s)}function Ji(e,t){Ki(e,(e=>{if(Ni(e.value))throw e;t(e)}),(e=>{if(Ni(e?.value))throw e;t(e)}))}function Qi(e,t,o){Ki(e,(e=>{if("number"==typeof e?.value&&t(e),Ni(e?.value))throw e}),(e=>{t({value:Ui(e,o),format:e?.format})}))}function er(e,t,o,s,i="rowFirst"){let r=s;for(let s of e)if(yi(s)){const e=s.length,o=s[0].length;if("rowFirst"===i)for(let i=0;i<o;i++)for(let o=0;o<e;o++)r=t(r,s[o][i]);else for(let i=0;i<e;i++)for(let e=0;e<o;e++)r=t(r,s[i][e])}else r=o(r,s);return r}function tr(e,t,o,s="rowFirst"){return er(e,t,t,o,s)}function or(e,t,o,s){return er(e,((e,o)=>{const s=o?.value;if("number"==typeof s)return t(e,s);if(Ni(s))throw o;return e}),((e,o)=>t(e,Ui(o,s))),o)}function sr(e,t,o,s){return er(e,((e,o)=>{const i=o?.value;if(null!=i){if("number"==typeof i)return t(e,i);if("boolean"==typeof i)return t(e,Li(i,s));if(Ni(i))throw o;return t(e,0)}return e}),((e,o)=>t(e,Li(o,s))),o)}function ir(e,t,o){const s=Array(e);for(let i=0;i<e;i++){s[i]=Array(t);for(let e=0;e<t;e++)s[i][e]=o(i,e)}return s}function rr(e,t){return 0===e.length?[]:ir(e.length,e[0].length,((o,s)=>t(e[o][s])))}function nr(e){return e.length?ir(e[0].length,e.length,((t,o)=>e[o][t])):[]}function ar(e,t){return function(e,t,o){for(let s of e)if(yi(s)){const e=s.length,o=s[0].length;for(let i=0;i<o;i++)for(let o=0;o<e;o++)if(!t(s[o][i]??void 0))return}else if(!o(s))return}(e,(e=>{const o=e?.value;if("boolean"==typeof o)return t(o);if("number"==typeof o)return t(!!o);if(Ni(o))throw e;return!0}),(e=>void 0===e||null===e.value||t(function(e){const t=Xi(e);if(""===t)throw new Ri(Zi(t));return ji(t)}(e))))}function lr(e,t){let o,s,i=e.substring(0,2);return"<="===i||">="===i||"<>"===i?(o=i,s=e.substring(2)):(i=e.substring(0,1),"<"===i||">"===i||"="===i?(o=i,s=e.substring(1)):(o="=",s=e)),ei(s,t)||Ls(s,t)?s=Li(s,t):"TRUE"!==s&&"FALSE"!==s||(s=ji(s)),{operator:o,operand:s}}const cr=xt((function(e){if("*"===e)return/.+/;let t="",o="";for(let s of e)"?"===s&&"~"!==o?t+=".":"*"===s&&"~"!==o?t+=".*":("*"!==s&&"?"!==s||(t=t.slice(0,-1)),["^",".","[","]","$","(",")","*","+","?","|","{","}","\\"].includes(s)&&(t+="\\"),t+=s),o=s;return new RegExp("^"+t+"$","i")}));function hr(e="",t,o){const{operator:s,operand:i}=t;if(void 0===i||null===e||null===i)return!1;if("number"==typeof i&&"="===s)return"string"==typeof e&&(ei(e,o)||Ls(e,o))?Li(e,o)===i:e===i;if("<>"===s||"="===s){let t;return t=typeof e==typeof i&&("string"==typeof e&&"string"==typeof i?cr(i).test(e):e===i),"="===s?t:!t}if(typeof e==typeof i)switch(s){case"<":return e<i;case">":return e>i;case"<=":return e<=i;case">=":return e>=i}return!1}function dr(e,t,o,s=!1){const i=e.length;if(i%2==1)throw new Ri(Oo("Function [[FUNCTION_NAME]] expects criteria_range and criterion to be in pairs."));const r=fr(e[0]),n=r.length,a=r[0].length;let l=[];for(let t=0;t<i-1;t+=2){const i=fr(e[t]);if(i.length!==n||i[0].length!==a)throw new Ri(Oo("Function [[FUNCTION_NAME]] expects criteria_range to have the same dimension"));const r=lr(Gi(e[t+1]),o);s&&"string"==typeof r.operand&&(r.operand+="*"),l.push(r)}for(let s=0;s<n;s++)for(let r=0;r<a;r++){let n=!0;for(let t=0;t<i-1;t+=2){if(n=hr(fr(e[t])[s][r].value??void 0,l[t/2],o),!n)break}n&&t(s,r)}}function ur(e,t,o,s,i,r){if(void 0===t||null===t.value)return-1;if(Ni(t.value))throw t;const n=pr(t.value),a=typeof n;let l,c,h,d,u,g,p=0,m=i-1;const f="desc"===s?t=>pr(r(e,i-t-1)):t=>pr(r(e,t));for(;m-p>=0;){for(h=Math.floor((p+m)/2),d=h,u=f(d),g=typeof u;p<d&&a!==g;)d--,u=f(d),g=typeof u;g===a&&null!=u?("strict"===o&&u===n?(l=u,c=d):"nextSmaller"===o&&u<=n?(null==l||l<u||l===u&&c<d)&&(l=u,c=d):"nextGreater"===o&&u>=n&&(void 0===l||l>u||l===u&&c<d)&&(l=u,c=d),u>n||"strict"===o&&u===n?m=d-1:p=h+1):p=h+1}return void 0===c?-1:"desc"===s?i-c-1:c}function gr(e,t,o,s,i,r=!1){if(void 0===t||null===t.value)return-1;if(Ni(t.value))throw t;const n=pr(t.value),a=r?(e,t)=>i(e,s-t-1):i;let l,c=t=>pr(a(e,t))===n;if("wildcard"===o&&"string"==typeof n&&(n.includes("*")||n.includes("?"))){const t=cr(n);c=o=>{const s=pr(a(e,o));return"string"==typeof s&&t.test(s)}}let h=-1;"nextSmaller"===o&&(c=t=>{const o=pr(a(e,t));return(!l&&mr(n,o)>=0||mr(n,o)>=0&&mr(o,l)>0)&&(l=o,h=t),o===n}),"nextGreater"===o&&(c=t=>{const o=pr(a(e,t));return(!l&&mr(n,o)<=0||mr(n,o)<=0&&mr(o,l)<0)&&(l=o,h=t),o===n});for(let e=0;e<s;e++)if(c(e))return r?s-e-1:e;return r&&-1!==h?s-h-1:h}function pr(e){return"string"==typeof e?qi(e):e}function mr(e,t){let o=Fi.indexOf(typeof e)-Fi.indexOf(typeof t);return 0===o&&("string"==typeof e&&"string"==typeof t?o=e.localeCompare(t):"number"==typeof e&&"number"==typeof t?o=e-t:"boolean"==typeof e&&"boolean"==typeof t&&(o=Number(e)-Number(t))),o}function fr(e){return void 0===e?[[]]:yi(e)?e:[[e]]}function vr(e,t){return tr(e,((e,o)=>(e.push(t(o)),e)),[],"rowFirst")}function br(e){if(void 0===e)return!1;const{value:t}=e;return null!==t&&""!==t}function Sr(e){return/^https?:\/\//i.test(e)?e:`https://${e}`}const yr=new r;function Cr(e,t){return{url:e=Sr(e),label:t||e,isExternal:!0,isUrlEditable:!0}}yr.add("sheet_URL",{match:e=>it(e),createLink:(e,t)=>({label:t,url:e,isExternal:!1,isUrlEditable:!1}),urlRepresentation(e,t){const o=nt(e);return t.tryGetSheetName(o)||Oo("Invalid sheet")},open(e,t){const o=nt(e);t.model.dispatch("ACTIVATE_SHEET",{sheetIdFrom:t.model.getters.getActiveSheetId(),sheetIdTo:o}).isCancelledBecause("SheetIsHidden")&&t.notifyUser({type:"warning",sticky:!1,text:Oo("Cannot open the link because the linked sheet is hidden.")})},sequence:0});const wr={createLink:Cr,match:e=>et(e),open:e=>window.open(e,"_blank"),urlRepresentation:e=>e,sequence:0};function Er(e){return yr.getAll().sort(((e,t)=>e.sequence-t.sequence)).find((t=>t.match(e)))||wr}function xr(e,t){return Er(e.url).urlRepresentation(e.url,t)}function Ir(e,t){Er(e.url).open(e.url,t)}function Rr(e){if("string"==typeof e){if(Qe(e)){const{label:t,url:o}=ot(e);return Er(o).createLink(o,t)}return et(e)?Cr(e):void 0}}function Tr(e){let t;if('"'===e.current?(e.shift(),t='"'):e.currentStartsWith("[$")&&(e.advanceBy(2),t="]"),!t)return null;let o="";for(;e.current&&e.current!==t;)o+=e.shift();if(e.current!==t)throw new Error("Unterminated string in format");return e.shift(),{type:"STRING",value:o}}const Ar=new Set("$+-/():!^&~{}<>= ");function _r(e){if("\\"===e.current){e.shift();const t=e.shift();if(!t)throw new Error("Unexpected end of format string");return{type:"CHAR",value:t}}return Ar.has(e.current)?{type:"CHAR",value:e.shift()}:null}function Dr(e){return","===e.current?(e.shift(),{type:"THOUSANDS_SEPARATOR",value:","}):null}function Or(e){return"@"===e.current?(e.shift(),{type:"TEXT_PLACEHOLDER",value:"@"}):null}function Fr(e){return"."===e.current?(e.shift(),{type:"DECIMAL_POINT",value:"."}):null}function Mr(e){return"%"===e.current?(e.shift(),{type:"PERCENT",value:"%"}):null}function Pr(e){if("0"===e.current||"#"===e.current){const t=e.current;return e.shift(),{type:"DIGIT",value:t}}return null}const Nr=new Set("dmqyhsa");function kr(e){if(!Nr.has(e.current))return null;const t=e.current;let o="";for(;e.current===t;)o+=e.shift();return{type:"DATE_PART",value:o}}function Lr(e){if("*"!==e.current)return null;e.shift();const t=e.shift();if(!t)throw new Error("Unexpected end of format string");return{type:"REPEATED_CHAR",value:t}}const Vr=20,Hr={};function Ur(e){let t=Hr[e];return void 0===t&&(t=function(e){const t=function(e){const t=new Ft(e),o=[];let s=[];for(o.push(s);!t.isOver();){if(";"===t.current){s=[],o.push(s),t.shift();continue}let e=Pr(t)||Tr(t)||_r(t)||Dr(t)||Fr(t)||Mr(t)||kr(t)||Or(t)||Lr(t);if(!e)throw new Error("Unknown token at "+t.remaining());s.push(e)}return o}(e);for(const e of t){const t=e.filter((e=>"REPEATED_CHAR"===e.type));for(const e of t.slice(1))e.type="CHAR"}const o=zr(t[0])||Br(t[0])||$r(t[0]);if(!o)throw new Error("Invalid first format part of: "+e);if(t.length>1&&"text"===o.type)throw new Error("The first format in a multi-part format must be a number format: "+e);const s=zr(t[1])||Br(t[1]);if(t[1]?.length&&!s)throw new Error("Invalid second format part of: "+e);const i=zr(t[2])||Br(t[2]);if(t[2]?.length&&!i)throw new Error("Invalid third format part of: "+e);const r=$r(t[3]);if(t[3]?.length&&!r)throw new Error("Invalid fourth format part of: "+e);return{positive:o,negative:s,zero:i,text:r}}(e),Hr[e]=t),t}function Br(e){if(!e||!function(e){return e.every((e=>"DIGIT"===e.type||"DECIMAL_POINT"===e.type||"THOUSANDS_SEPARATOR"===e.type||"PERCENT"===e.type||"STRING"===e.type||"CHAR"===e.type||"REPEATED_CHAR"===e.type))}(e))return;const t=[];let o,s=t,i=0,r=0,n=e.findLastIndex((e=>"DIGIT"===e.type)),a=!1,l=0;for(let c=0;c<e.length;c++){const h=e[c];switch(h.type){case"DIGIT":s===t?s.push(h):l<Vr&&(s.push(h),l++);break;case"DECIMAL_POINT":if(s!==t)throw new Error("Multiple decimal points in a number format");o=[],s=o;break;case"REPEATED_CHAR":case"CHAR":case"STRING":s.push(h);break;case"PERCENT":i++,s.push(h);break;case"THOUSANDS_SEPARATOR":c-1===n?(r+=1,n++,s.push(h)):"DIGIT"===e[c+1]?.type&&"DIGIT"===e[c-1]?.type?(s===t&&(a=!0),s.push(h)):s.push({type:"CHAR",value:","})}}return{type:"number",integerPart:t,decimalPart:o,percentSymbols:i,thousandsSeparator:a,magnitude:r}}function zr(e){const t=e&&function(e){return e.every((e=>"DATE_PART"===e.type||"DECIMAL_POINT"===e.type||"THOUSANDS_SEPARATOR"===e.type||"STRING"===e.type||"CHAR"===e.type||"REPEATED_CHAR"===e.type))}(e)?{type:"date",tokens:e}:void 0;if(!t)return;if(t.tokens.length&&t.tokens.every((e=>"DATE_PART"===e.type&&"a"===e.value)))throw new Error("Invalid date format");const o=function(e){const t=e.filter((e=>"DATE_PART"===e.type));for(let e=0;e<t.length;e++)!t[e].value.startsWith("m")||t[e].value.length>2||(t[e-1]?.value.startsWith("h")||t[e+1]?.value.startsWith("s"))&&(t[e].value=t[e].value.replaceAll("m","M"));return e}(t.tokens.map((e=>"THOUSANDS_SEPARATOR"===e.type||"DECIMAL_POINT"===e.type?{type:"CHAR",value:e.value}:e)));return{type:"date",tokens:o}}function $r(e){return e&&function(e){return e.every((e=>"STRING"===e.type||"TEXT_PLACEHOLDER"===e.type||"CHAR"===e.type||"REPEATED_CHAR"===e.type))}(e)?{type:"text",tokens:e}:void 0}function Wr(e){return[Gr(e.positive),Gr(e.negative),Gr(e.zero),Gr(e.text)].filter(at).join(";")}function Gr(e){if(!e)return;let t="";const o="number"!==e.type?e.tokens:function(e){let t=[...e.integerPart];e.decimalPart&&(t.push({type:"DECIMAL_POINT",value:"."}),t.push(...e.decimalPart));return t}(e);for(let e of o)switch(e.type){case"STRING":t+=`[$${e.value}]`;break;case"CHAR":t+=(s=e.value,Ar.has(s)?e.value:`\\${e.value}`);break;case"REPEATED_CHAR":t+="*"+e.value;break;default:t+=e.value}var s;return t}const qr=11,Zr="REPEATED_CHAR_PLACEHOLDER_",jr={0:Oo("January"),1:Oo("February"),2:Oo("March"),3:Oo("April"),4:Oo("May"),5:Oo("June"),6:Oo("July"),7:Oo("August"),8:Oo("September"),9:Oo("October"),10:Oo("November"),11:Oo("December")},Yr={0:Oo("Sunday"),1:Oo("Monday"),2:Oo("Tuesday"),3:Oo("Wednesday"),4:Oo("Thursday"),5:Oo("Friday"),6:Oo("Saturday")};function Xr(e,{format:t,locale:o,formatWidth:s}){switch("boolean"==typeof e&&(e=e?"TRUE":"FALSE"),typeof e){case"string":{if(e.includes('\\"')&&(e=e.replaceAll(/\\"/g,'"')),!t)return e;const o=Ur(t);let i=o.text||o.positive;return i&&"text"===i.type?Kr(e,i,s):e}case"number":t||(t=ln(e));const i=Ur(t);if("text"===i.positive.type)return Kr(e.toString(),i.positive,s);let r=i.positive;if(e<0&&i.negative?(r=i.negative,e=-e):0===e&&i.zero&&(r=i.zero),"date"===r.type)return Jr(function(e,t){const o=Us(e),s=t.tokens.some((e=>"DATE_PART"===e.type&&"a"===e.value));let i="";for(const e of t.tokens)switch(e.type){case"DATE_PART":i+=nn(o,e.value,s);break;case"REPEATED_CHAR":i+=Zr+e.value;break;default:i+=e.value}return i}(e,r),s);const n=e<0,a=Jr(function(e,t,o){if(e===1/0)return"∞"+(t.percentSymbols?"%":"");const s=2*t.percentSymbols-3*t.magnitude;e*=10**s;let i=0;void 0!==t.decimalPart&&(i=t.decimalPart.filter((e=>"DIGIT"===e.type)).length);const{integerDigits:r,decimalDigits:n}=en(Math.abs(e),i);let a=function(e,t,o){let s=t.integerPart;s.some((e=>"DIGIT"===e.type))||(s=[...s,{type:"DIGIT",value:"#"}]);"0"===e&&(e="");let i="";const r=s.findIndex((e=>"DIGIT"===e.type));let n=e.length-1;function a(t,s){if("0"===s&&(t=t||"0"),!t)return;const r=e.length-1-n;i=o&&r>0&&r%3==0?t+o+i:t+i}for(let t=s.length-1;t>=0;t--){const o=s[t];switch(o.type){case"DIGIT":if(a(e[n],o.value),n--,r===t)for(;n>=0;)a(e[n],"0"),n--;break;case"THOUSANDS_SEPARATOR":break;case"REPEATED_CHAR":i=Zr+o.value+i;break;default:i=o.value+i}}return i}(r,t,t.thousandsSeparator?o.thousandsSeparator:void 0);void 0!==t.decimalPart&&(a+=o.decimalSeparator+function(e,t){if(!t.decimalPart)return"";let o="",s=0;for(const i of t.decimalPart)switch(i.type){case"DIGIT":o+="#"===i.value?e[s]||"":e[s]||"0",s++;break;case"THOUSANDS_SEPARATOR":break;case"REPEATED_CHAR":o+=Zr+i.value;break;default:o+=i.value}return o}(n||"",t));return a}(Math.abs(e),r,o),s);return n?"-"+a:a;case"object":return""}}function Kr(e,t,o){let s="";for(const o of t.tokens)switch(o.type){case"TEXT_PLACEHOLDER":s+=e;break;case"CHAR":case"STRING":s+=o.value;break;case"REPEATED_CHAR":s+=Zr+o.value}return Jr(s,o)}function Jr(e,t){const o=e.indexOf(Zr);if(-1===o)return e;const s=e.slice(0,o),i=e.slice(o+Zr.length+1),r=e[o+Zr.length];const{timesToRepeat:n,padding:a}=function(){if(!t)return{timesToRepeat:0,padding:""};const e=t.measureText(s+i),o=t.measureText(r),n=t.availableWidth-e;if(n<=0)return{timesToRepeat:0,padding:""};const a=Math.floor(n/o),l=n-a*o,c=t.measureText(" ");return{timesToRepeat:a,padding:" ".repeat(Math.floor(l/c))}}();return s+r.repeat(n)+a+i}const Qr=[];function en(e,t=Vr){const o=e.toString();if(o.includes("e"))return function(e,t=Vr){let o=Qr[t];o||(o=new Intl.NumberFormat("en-US",{maximumFractionDigits:t,useGrouping:!1}),Qr[t]=o);const[s,i]=o.format(e).split(".");return{integerDigits:s,decimalDigits:i}}(e,t);if(Number.isInteger(e))return{integerDigits:o,decimalDigits:void 0};const s=o.indexOf(".");let i=o.substring(0,s),r=o.substring(s+1);if(0===t)return Number(r[0])>=5&&(i=(Number(i)+1).toString()),{integerDigits:i,decimalDigits:void 0};if(r.length>t){const{integerDigits:e,decimalDigits:o}=function(e,t){let o="0",s=e,i=e.slice(0,t);const r=t;if(Number(e[r])<5)return{integerDigits:o,decimalDigits:i};const n=i.match(on)?.[0]||"",a=(Number(i)+1).toString(),l=i.slice(n.length),c=a.length>l.length;c&&!n?(o="1",s=void 0):s=c?n.slice(0,-1)+a:n+a;return{integerDigits:o,decimalDigits:s}}(r,t);r=o,"0"!==e&&(i=(Number(i)+Number(e)).toString())}return{integerDigits:i,decimalDigits:tn(r||"")}}function tn(e){let t=e.length-1;for(;t>=0&&"0"===e[t];)t--;return e.slice(0,t+1)||void 0}const on=/^0+/;function sn(e,t){const{integerDigits:o,decimalDigits:s}=en(e,20);return s?o+t+s:o}const rn=xt((function(e){if(!e)return!1;try{return"date"===Ur(e).positive.type}catch(e){return!1}}));function nn(e,t,o){switch(t){case"d":return e.getDate();case"dd":return e.getDate().toString().padStart(2,"0");case"ddd":return Yr[e.getDay()].slice(0,3);case"dddd":return Yr[e.getDay()].toString();case"m":return e.getMonth()+1;case"mm":return String(e.getMonth()+1).padStart(2,"0");case"mmm":return jr[e.getMonth()].slice(0,3);case"mmmm":return jr[e.getMonth()].toString();case"mmmmm":return jr[e.getMonth()].slice(0,1);case"qq":return Oo("Q%(quarter)s",{quarter:e.getQuarter()}).toString();case"qqqq":return Oo("Quarter %(quarter)s",{quarter:e.getQuarter()}).toString();case"yy":const s=String(e.getFullYear()).replace("-","").padStart(2,"0");return s.slice(s.length-2);case"yyyy":return e.getFullYear();case"hhhh":return Math.floor((e.getTime()-Is.getTime())/36e5).toString();case"hh":let i=e.getHours();return o&&(i=0===i?12:i>12?i-12:i),i.toString().padStart(2,"0");case"MM":return e.getMinutes().toString().padStart(2,"0");case"ss":return e.getSeconds().toString().padStart(2,"0");case"a":return e.getHours()>=12?"PM":"AM";default:throw new Error(`invalid date format token: ${t}`)}}const an=xt((function(e){return new RegExp(`[0-9]+${Ue(e.decimalSeparator)}[0-9]`)}));function ln(e){let{integerDigits:t,decimalDigits:o}=en(e);if(!o)return"0";const s=t.replace("-","").length;if(s+2>qr)return"0";const i=qr-s-1;return({decimalDigits:o}=en(e,Math.min(i,o.length))),o?"0."+"0".repeat(o.length):"0"}function cn(e,t){if(!Ls(e,t))return;return Hs(e,t).format}function hn(e){const t=e.includes(".")?"0.00":"0",o=e.match(/[\$€]/);if(o){const s=e.match(/[\d]/),i="[$"+o.values().next().value+"]";return s.index<o.index?"#,##"+t+i:i+"#,##"+t}if(e.includes("%"))return t+"%"}function dn(e){const t=e.decimalPlaces??2,o=e.position??"before",s=e.code??"",i=e.symbol??"",r="#,##0"+(t?"."+"0".repeat(t):"");let n=`${s} ${i}`.trim();return"after"===o&&s&&(n=" "+n),function(e,t,o){const s=`[$${e}]`;return"before"===t?s+o:o+s}(n,o,r)}function un(e){const t=e.decimalPlaces??2,o=e.position??"before",s=e.code??"",i=e.symbol??"",r="#,##0"+(t?"."+"0".repeat(t):"");let n=`${s} ${i}`.trim();"after"===o&&s&&(n=" "+n);return[gn(n,o,` ${r} `),gn(n,o,`(${r})`),gn(n,o," - ")].join(";")}function gn(e,t,o){const s=`[$${e}]`;return"before"===t?s+"* "+o:o+"* "+s}function pn(e){const t=Ur(e);return Wr({positive:mn(t.positive),negative:t.negative?mn(t.negative):void 0,zero:t.zero?mn(t.zero):void 0,text:t.text})}function mn(e){if("number"!==e.type||!e.decimalPart)return e;const t=e.decimalPart.filter((e=>"DIGIT"!==e.type));return{...e,decimalPart:void 0,integerPart:[...e.integerPart,...t]}}function fn({value:e,format:t},o){return Xr(e,{format:vn({value:e,format:t},void 0,o),locale:o})}function vn(e,t,o){let s=0;try{s=Math.abs(Li(e?.value,o))}catch(e){return""}const i=e?.format;if(void 0!==t){const e=t?.value;switch(e){case"k":return bn(i,1,"k");case"m":return bn(i,2,"m");case"b":return bn(i,3,"b");default:throw new Ri(Oo("The formatting unit should be 'k', 'm' or 'b'."))}}return s<1e5?bn(i,0,""):s<1e8?bn(i,1,"k"):s<1e11?bn(i,2,"m"):bn(i,3,"b")}function bn(e,t,o,s){const i=Ur(e||"#,##0");return Wr({positive:Sn(i.positive,t,o),negative:i.negative?Sn(i.negative,t,o):void 0,zero:i.zero?Sn(i.zero,t,o):void 0,text:i.text})}function Sn(e,t,o){if("number"!==e.type)return e;const s={type:"STRING",value:o};let i=[...e.integerPart];const r=i.findLastIndex((e=>"DIGIT"===e.type));if(-1===r)throw new Error("Cannot create a large number format from a format with no digit.");for(;"THOUSANDS_SEPARATOR"===i[r+1]?.type;)i=It(i,[r+1]);const n=i[r+1];i="STRING"===n?.type&&["m","k","b"].includes(n.value)?function(e,t,o){const s=[...e];return s.splice(o,1,t),s}(i,s,r+1):Rt(i,[s],r+1),t>0&&(i=Rt(i,Array(t).fill({type:"THOUSANDS_SEPARATOR",value:","}),r+1));const a=e.percentSymbols-i.filter((e=>"PERCENT"===e.type)).length;return i.push(...new Array(a).fill({type:"PERCENT",value:"%"})),{...e,integerPart:i,decimalPart:void 0,magnitude:t}}function yn(e,t){const o=Ur(e);return Wr(Ur(Wr({positive:Cn(o.positive,t),negative:o.negative?Cn(o.negative,t):void 0,zero:o.zero?Cn(o.zero,t):void 0,text:o.text})))}function Cn(e,t){return"number"!==e.type?e:t>0?function(e,t){let o=e.integerPart,s=e.decimalPart;if(!s){const e=o.findLastIndex((e=>"DIGIT"===e.type));s=o.slice(e+1),o=o.slice(0,e+1)}const i=Ze(0,t).map((()=>({type:"DIGIT",value:"0"}))),r=s.findLastIndex((e=>"DIGIT"===e.type));s=-1===r?[...i,...s]:Rt(s,i,r+1);return{...e,decimalPart:s,integerPart:o}}(e,t):function(e,t){let o=e.decimalPart;if(!o)return e;const s=[];let i=0;for(let e=o.length-1;e>=0&&!(i>=Math.abs(t));e--)"DIGIT"===o[e].type&&(i++,s.push(e));if(o=It(o,s),o.some((e=>"DIGIT"===e.type)))return{...e,decimalPart:o};return{...e,decimalPart:void 0,integerPart:[...e.integerPart,...o]}}(e,Math.abs(t))}function wn(e){const t=Ur(e);for(const e of[t.positive,t.negative,t.zero])if(e&&"date"===e.type&&e.tokens.some((e=>"DATE_PART"===e.type&&e.value.includes("q"))))return!1;return!0}function En(e){if(!e)return!1;try{return"text"===Ur(e).positive.type}catch{return!1}}function xn(e,t){return Rn({value:En(t.format)?e.content:e.parsedValue,format:t.format},t.locale)}function In(e,t){if(e.startsWith("="))throw new Error(`Cannot parse "${e}" because it's not a literal value. It's a formula`);if(""===e)return null;if(ei(e,bi))return oi(e,bi);const o=Hs(e,t);return o?o.value:Xe(e)?"TRUE"===e.toUpperCase():e}function Rn(e,t=bi,o){const s=Rr(e.value);if(!s)return Tn(e,t,o);const i=In(s.label,t);return{...Tn({value:i,format:e.format||("number"==typeof i?cn(s.label,t)||hn(s.label):void 0)},t,o),link:s}}function Tn(e,t,o){let{value:s,format:i,message:r}=e;i=o?.format||i;const n=Xr(s,{format:i,locale:t});return Ni(s)?function(e,t){return{value:e,formattedValue:e,message:t,type:ii.error,isAutoSummable:!1,defaultAlign:"center"}}(s,r):En(i)?An(Gi(s),i,n):null===s?_n(i):"number"==typeof s?rn(i||"")?function(e,t,o){return{value:e,format:t,formattedValue:o,type:ii.number,isAutoSummable:!1,defaultAlign:"right"}}(s,i,n):function(e,t,o){return{value:e||0,format:t,formattedValue:o,type:ii.number,isAutoSummable:!0,defaultAlign:"right"}}(s,i,n):"boolean"==typeof s?function(e,t,o){return{value:e,format:t,formattedValue:o,type:ii.boolean,isAutoSummable:!1,defaultAlign:"center"}}(s,i,n):An(s,i,n)}function An(e,t,o){return{value:e,format:t,formattedValue:o,type:ii.text,isAutoSummable:!0,defaultAlign:"left"}}const _n=xt((function(e){return{value:null,format:e,formattedValue:"",type:ii.empty,isAutoSummable:!0,defaultAlign:"left"}}));function Dn(e){const t=xs.now();switch(e){case"today":return zs(t);case"yesterday":return zs(xs.fromTimestamp(t.setDate(t.getDate()-1)));case"tomorrow":return zs(xs.fromTimestamp(t.setDate(t.getDate()+1)));case"lastWeek":return zs(xs.fromTimestamp(t.setDate(t.getDate()-7)));case"lastMonth":return zs(xs.fromTimestamp(t.setMonth(t.getMonth()-1)));case"lastYear":return zs(xs.fromTimestamp(t.setFullYear(t.getFullYear()-1)))}}function On(e,t){return"dateValue"in e&&"exactDate"!==e.dateValue?[Dn(e.dateValue)]:e.values.map((e=>ks(e,t)))}function Fn(e,t){return e.values.map((e=>Vi(e,t)))}function Mn(e,t){return e.map((e=>{if(e.startsWith("="))return e;const o=In(e,t);return"number"==typeof o?Xr(o,{format:t.dateFormat,locale:t}):""}))}function Pn(e){return 20+120*Math.exp(-.035*(e-1))}class Nn{getSheetSize;_zone;parts;invalidXc;prefixSheet=!1;sheetId;invalidSheetName;constructor(e,t){this.getSheetSize=t,this._zone=e.zone,this.prefixSheet=e.prefixSheet,this.invalidXc=e.invalidXc,this.sheetId=e.sheetId,this.invalidSheetName=e.invalidSheetName;let o=[...e.parts];1===e.parts.length&&bs(this.zone)>1?o.push({...e.parts[0]}):2===e.parts.length&&1===bs(this.zone)&&o.pop(),this.parts=o}static fromRange(e,t){return e instanceof Nn?e:new Nn(e,t.getSheetSize)}get unboundedZone(){return this._zone}get zone(){const{left:e,top:t,bottom:o,right:s}=this._zone;if(void 0!==s&&void 0!==o)return this._zone;if(void 0===o&&void 0!==s)return{right:s,top:t,left:e,bottom:this.getSheetSize(this.sheetId).numberOfRows-1};if(void 0===s&&void 0!==o)return{bottom:o,left:e,top:t,right:this.getSheetSize(this.sheetId).numberOfCols-1};throw new Error(Oo("Bad zone format"))}static getRangeParts(e,t){const o=e.split(":").map((e=>{const t=Bo(e);return{colFixed:!t&&e.startsWith("$"),rowFixed:t?e.startsWith("$"):e.includes("$",1)}})),s=void 0===t.bottom,i=void 0===t.right;return s&&(o[0].rowFixed=o[0].rowFixed||o[1].rowFixed,o[1].rowFixed=o[0].rowFixed||o[1].rowFixed),i&&(o[0].colFixed=o[0].colFixed||o[1].colFixed,o[1].colFixed=o[0].colFixed||o[1].colFixed),o}get isFullCol(){return void 0===this._zone.bottom}get isFullRow(){return void 0===this._zone.right}get rangeData(){return{_zone:this._zone,_sheetId:this.sheetId}}orderZone(){if(Xo(this._zone))return this;const e={...this._zone};let t=this.parts;if(void 0!==e.right&&e.right<e.left){let o=e.right;e.right=e.left,e.left=o,t=[{colFixed:t[1]?.colFixed||!1,rowFixed:t[0]?.rowFixed||!1},{colFixed:t[0]?.colFixed||!1,rowFixed:t[1]?.rowFixed||!1}]}if(void 0!==e.bottom&&e.bottom<e.top){let o=e.bottom;e.bottom=e.top,e.top=o,t=[{colFixed:t[0]?.colFixed||!1,rowFixed:t[1]?.rowFixed||!1},{colFixed:t[1]?.colFixed||!1,rowFixed:t[0]?.rowFixed||!1}]}return this.clone({zone:e,parts:t})}clone(e){return new Nn({zone:e?.zone?e.zone:{...this._zone},sheetId:e?.sheetId?e.sheetId:this.sheetId,invalidSheetName:e&&"invalidSheetName"in e?e.invalidSheetName:this.invalidSheetName,invalidXc:e&&"invalidXc"in e?e.invalidXc:this.invalidXc,parts:e?.parts?e.parts:this.parts.map((e=>({rowFixed:e.rowFixed,colFixed:e.colFixed}))),prefixSheet:void 0!==e?.prefixSheet?e.prefixSheet:this.prefixSheet},this.getSheetSize)}}function kn(e,t,o){const s=o.sheetId===e?t:o.sheetId;return o.clone({sheetId:s})}function Ln(e,t,o){if(!o)return;const s=e.getRangeFromSheetXC(t,o);return s.invalidSheetName||s.invalidXc?void 0:s}function Vn(e,t){const o=[];for(const s of t){const t=s.dataRange;if(!e.isRangeValid(t)){o.push(s);continue}const{sheetName:i}=Go(t),r=i?`${i}!`:"",n=Zo(t);if(n.bottom!==n.top&&n.left!=n.right)if(n.right)for(let e=n.left;e<=n.right;++e)o.push({...s,dataRange:`${r}${Ko({left:e,right:e,top:n.top,bottom:n.bottom})}`});else for(let e=n.top;e<=n.bottom;++e)o.push({...s,dataRange:`${r}${Ko({left:n.left,right:n.right,top:e,bottom:e})}`});else o.push(s)}return o}function Hn(e){const t=[];for(const o of e)for(const e of ds(o.zone))t.push({...e,sheetId:o.sheetId});return t}function Un(e,t,o){const s=[];return t.forEach((t=>{const i=function(e,t){e=e.toLocaleLowerCase();let o=0,s=0,i=(t=t.toLocaleLowerCase()).length,r=0;for(let n=0;n<i;n++)t[n]===e[r]?(r++,s+=100+s-n/200):s=0,o+=s;return r===e.length?o:0}(e,o(t));i>0&&s.push({score:i,elem:t})})),s.sort(((e,t)=>t.score-e.score)),s.map((e=>e.elem))}function Bn(e){const t=[];for(let o=0;o<e;o++){const e={cells:{}};t.push(e)}return t}function zn(e,t,o){return o.map((o=>o>=e?o+t:o))}function $n(e,t){return e=[...e].sort(((e,t)=>t-e)),t.map((t=>{for(const o of e)if(t>o)t--;else if(t===o)return;return t})).filter(at)}function Wn(e,t=1){return t*(e+re)-re}function Gn(e,t=!1,o=!1){return`${o?"italic":""} ${t?"bold":""} ${e}px ${fe}`}const qn={};function Zn(e,t,o,s="pt"){const i=Jn(o,s);e.save(),e.font=i;const r=jn(e,t);return e.restore(),r}function jn(e,t){const o=e.font;return qn[o]||(qn[o]={}),void 0===qn[o][t]&&(qn[o][t]=e.measureText(t).width),qn[o][t]}const Yn={};function Xn(e,t,o,s="pt"){const i=Jn(o,s);e.save(),e.font=i;const r=function(e,t){const o=e.font;Yn[o]||(Yn[o]={});if(void 0===Yn[o][t]){const s=e.measureText(t),i=s.width,r=s.fontBoundingBoxAscent+s.fontBoundingBoxDescent;Yn[o][t]={width:i,height:r}}return Yn[o][t]}(e,t);return e.restore(),r}function Kn(e){return Math.round(96*e/72)}function Jn(e,t="pt"){return`${e.italic?"italic ":""}${e.bold?"bold":pe} ${("pt"===t?Qn(e):e.fontSize)??me}px ${fe}`}function Qn(e){return Kn(e?.fontSize||me)}function ea(e,t,o,s){if(Zn(e,t,s)<=o)return[t];const i=[];let r="";for(let n of t){Zn(e,r+n,s)>o?(i.push(r),r=n):r+=n}return i.push(r),i}function ta(e,t,o,s){o||(o={});const i=[],r=t.includes(Pe)?t.split(Pe):[t];for(const t of r){const r=t.includes(" ")?t.split(" "):[t];if(!s){i.push(t);continue}let n="",a=s;for(let t of r){const r=ea(e,t,s,o),l=r.pop(),c=Zn(e,l,o);if(r.length)""!==n&&(i.push(n),n="",a=s),r.forEach((e=>{i.push(e)})),n=l,a=s-c;else{const t=""===n?l:" "+l,r=Zn(e,t,o);r<=a?(n+=t,a-=r):(i.push(n),n=l,a=s-c)}}""!==n&&i.push(n)}return i}function oa(e){return e?e.toLowerCase():""}const sa=/([0-9\.]*)px/;function ia(e,t,o){let s=jn(e,t);if(s<=o)return t;const i=jn(e,"…");if(s<=i)return t;let r=t.length;for(;s>=o-i&&r-- >0;)s=jn(e,t=t.substring(0,r));return t+"…"}function ra(e,t,o,s=!1,i=!1,r=function(e){return Number(e.match(sa)?.[1])}(e.font)/10){if(e.fillText(t,o.x,o.y),!s&&!i)return;const n=e.measureText(t),a=n.width,l=n.actualBoundingBoxAscent+n.actualBoundingBoxDescent,c=n.fontBoundingBoxAscent+n.fontBoundingBoxDescent;let{x:h,y:d}=o,u=d,g=d;switch(e.textAlign){case"center":h-=a/2;break;case"right":h-=a}switch(e.textBaseline){case"top":g+=c-2*r,u+=c/2-r;break;case"middle":g+=c/2-r;break;case"alphabetic":g+=2*r,u-=3*r;break;case"bottom":g=d,u-=l/2-r/2}s&&(e.lineWidth=r,e.strokeStyle=e.fillStyle,e.beginPath(),e.moveTo(h,g),e.lineTo(h+a,g),e.stroke()),i&&(e.lineWidth=r,e.strokeStyle=e.fillStyle,e.beginPath(),e.moveTo(h,u),e.lineTo(h+a,u),e.stroke())}class na{uuidv4(){return window.crypto&&window.crypto.getRandomValues?([1e7]+-1e3+-4e3+-8e3+-1e11).replace(/[018]/g,(e=>(e^crypto.getRandomValues(new Uint8Array(1))[0]&15>>e/4).toString(16))):"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,(function(e){const t=16*Math.random()|0;return("x"===e?t:3&t|8).toString(16)}))}}function aa(e,t){const o=new Set(t.map((e=>e.left))),s=new Set(t.map((e=>e.right))),i=new Set(t.map((e=>e.top))),r=new Set(t.map((e=>e.bottom))),n=1===i.size&&1===r.size||1===o.size&&1===s.size?function(e){return e.reduce(((e,t)=>{const o=e.length;for(let s=0;s<o;s++)if(rs(e[s],t))return e[s]=os(e[s],t),e;return e[o]=t,e}),[])}(t):[t[t.length-1]],a=n.map((e=>ds(e))).flat();return{sheetId:e,zones:t,clippedZones:n,columnsIndexes:[...new Set(a.map((e=>e.col)))].sort(((e,t)=>e-t)),rowsIndexes:[...new Set(a.map((e=>e.row)))].sort(((e,t)=>e-t))}}function la(e,t){if(!t.length||!t[0].length)return e;const o=t[0].length,s=t.length;return e.map((e=>function(e,t,o){const s=Math.max(e.right-t+1,e.left),i=Math.max(e.bottom-o+1,e.top),r=[];for(let n=e.left;n<=s;n+=t)for(let s=e.top;s<=i;s+=o)r.push({left:n,top:s,bottom:s+o-1,right:n+t-1});return r}(e,o,s))).flat()}function ca(e){if(!e[ri.Html])return{text:e[ri.PlainText]};const t=(new DOMParser).parseFromString(e[ri.Html],"text/html"),o=t.querySelector("div")?.getAttribute("data-osheet-clipboard"),s=o&&JSON.parse(o);return{text:e[ri.PlainText],data:s}}class ha{getters;dispatch;constructor(e,t){this.getters=e,this.dispatch=t}copy(e){}paste(e,t,o){}isPasteAllowed(e,t,o,s){return"Success"}isCutAllowed(e){return"Success"}getPasteTarget(e,t,o,s){return{zones:[],sheetId:e}}convertTextToClipboardData(e){}}class da extends ha{copy(e){}pasteFromCopy(e,t,o,s){if(1===t.length)for(const i of la(t,o))this.pasteZone(e,i.left,i.top,o,s);else for(const i of yo(t))for(let t=i.left;t<=i.right;t++)for(let r=i.top;r<=i.bottom;r++)this.pasteZone(e,t,r,o,s)}pasteZone(e,t,o,s,i){}}class ua extends da{copy(e){const t=e.sheetId;if(0===e.zones.length)return;const{rowsIndexes:o,columnsIndexes:s}=e,i=[];for(const e of o){const o=[];for(const i of s){const s={col:i,row:e,sheetId:t};o.push(this.getters.getCellBorder(s))}i.push(o)}return{borders:i}}paste(e,t,o){const s=e.sheetId;if("asValue"===o.pasteOption)return;const i=e.zones;if(o.isCutOperation){const{left:e,top:o}=i[0];this.pasteZone(s,e,o,t.borders)}else this.pasteFromCopy(s,i,t.borders)}pasteZone(e,t,o,s){for(const[i,r]of s.entries())for(const[s,n]of r.entries()){const r={col:t+s,row:o+i,sheetId:e};this.pasteBorder(n,r)}}pasteBorder(e,t){const o={...this.getters.getCellBorder(t),...e};this.dispatch("SET_BORDER",{...t,border:o})}}const ga=["%"],pa="+,-,*,/,:,=,<>,>=,>,<=,<,^,&".split(",").concat(ga);function ma(e,t=bi){e=wt(e);const o=new Ft(e),s=[];for(;!o.isOver();){let e=Ra(o)||Sa(o,t)||ba(o)||ya(o)||Ea(o)||fa(o)||Ta(o)||wa(o,t)||Ia(o);e||(e={type:"UNKNOWN",value:o.shift()}),s.push(e)}return s}function fa(e){return"?"===e.current?(e.shift(),{type:"DEBUGGER",value:"?"}):null}const va={"(":{type:"LEFT_PAREN",value:"("},")":{type:"RIGHT_PAREN",value:")"}};function ba(e){if("("===e.current||")"===e.current){const t=e.shift();return va[t]}return null}function Sa(e,t){if(e.current===t.formulaArgSeparator){return{type:"ARG_SEPARATOR",value:e.shift()}}return null}function ya(e){for(let t of pa)if(e.currentStartsWith(t))return e.advanceBy(t.length),{type:"OPERATOR",value:t};return null}const Ca=new Set("0123456789");function wa(e,t){if(!Ca.has(e.current)&&e.current!==t.decimalSeparator)return null;const o=e.remaining().match(Js(t.decimalSeparator));return o?(e.advanceBy(o[0].length),{type:"NUMBER",value:o[0]}):null}function Ea(e){if('"'===e.current){const t=e.shift();let o=t;for(;e.current&&(e.current!==t||"\\"===o[o.length-1]);)o+=e.shift();return'"'===e.current&&(o+=e.shift()),{type:"STRING",value:o}}return null}const xa=new Set("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789_.!$");function Ia(e){let t="";if("'"===e.current){let o=e.shift();for(t+=o;e.current;)if(o=e.shift(),t+=o,"'"===o){if(!e.current||"'"!==e.current)break;o=e.shift(),t+=o}if("'"!==o)return{type:"UNKNOWN",value:t}}for(;e.current&&xa.has(e.current);)t+=e.shift();if(t.length){const e=t;return Ho.test(e)?{type:"REFERENCE",value:e}:{type:"SYMBOL",value:e}}return null}function Ra(e){let t=0;for(;e.current===Pe;)t++,e.shift();if(t)return{type:"SPACE",value:Pe.repeat(t)};let o="";for(;e.current&&e.current.match(yt);)o+=e.shift();return o?{type:"SPACE",value:o}:null}function Ta(e){return e.currentStartsWith(xi.InvalidReference)?(e.advanceBy(xi.InvalidReference.length),{type:"INVALID_REFERENCE",value:xi.InvalidReference}):null}function Aa(e){if(!e||"object"!=typeof e||e.thousandsSeparator&&"string"!=typeof e.thousandsSeparator)return!1;for(const t of["code","name","decimalSeparator","dateFormat","timeFormat","formulaArgSeparator"])if(!e[t]||"string"!=typeof e[t])return!1;if(e.formulaArgSeparator===e.decimalSeparator)return!1;if(e.thousandsSeparator===e.decimalSeparator)return!1;try{Xr(1,{locale:e,format:"#,##0.00"}),Xr(1,{locale:e,format:e.dateFormat}),Xr(1,{locale:e,format:e.timeFormat})}catch{return!1}return!0}function _a(e,t){return e.startsWith("=")?Fa(e,t):Na(e,t)}function Da(e,t){return e.startsWith("=")?Fa(e,t):function(e,t){if(Ls(e,t)){const o=Li(e,t);let s=bi.dateFormat;return Number.isInteger(o)||(s+=" "+bi.timeFormat),Xr(o,{locale:bi,format:s})}return Na(e,t)}(e,t)}function Oa(e,t){return e.startsWith("=")?Ma(e,t):function(e,t){if(Ls(e,bi)){const o=Li(e,bi);let s=t.dateFormat;return Number.isInteger(o)||(s+=" "+t.timeFormat),Xr(o,{locale:t,format:s})}return function(e,t){if("."===t.decimalSeparator||!ei(e,bi))return e;const o=an(bi);return e.replace(o,(e=>e.replace(".",t.decimalSeparator)))}(e,t)}(e,t)}function Fa(e,t){return Pa(e,t,bi)}function Ma(e,t){return Pa(e,bi,t)}function Pa(e,t,o){if(t.formulaArgSeparator===o.formulaArgSeparator&&t.decimalSeparator===o.decimalSeparator)return e;const s=ma(e,t);let i="";for(const e of s)"NUMBER"===e.type?i+=e.value.replace(t.decimalSeparator,o.decimalSeparator):"ARG_SEPARATOR"===e.type?i+=o.formulaArgSeparator:i+=e.value;return i}function Na(e,t){return"."!==t.decimalSeparator&&ei(e,t)?(t.thousandsSeparator&&(e=e.replaceAll(t.thousandsSeparator,"")),e.replace(t.decimalSeparator,".")):e}function ka(e,t){return Ha(e,(e=>Da(e,t)))}function La(e,t){return Ha(e,(e=>Oa(e,t)))}function Va(e,t){const o=Be(e);return o.criterion.values=o.criterion.values.map((e=>Oa(e,t))),o}function Ha(e,t){switch((e=Be(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=Ua(e.minimum,t),e.maximum=Ua(e.maximum,t),e.midpoint&&(e.midpoint=Ua(e.midpoint,t)),e;case"IconSetRule":return e.lowerInflectionPoint.value=t(e.lowerInflectionPoint.value),e.upperInflectionPoint.value=t(e.upperInflectionPoint.value),e}}function Ua(e,t){if(!e?.value)return e;const o=t("formula"===e.type?"="+e.value:e.value),s="formula"===e.type?o.slice(1):o;return{...e,value:s}}function Ba(e){return e.dateFormat+" "+e.timeFormat}function za(e,t){return e.startsWith("=")?function(e,t){return function(e,t,o){if(t.formulaArgSeparator===o.formulaArgSeparator&&t.decimalSeparator===o.decimalSeparator)return e;const s=ma(e,t);let i="";for(const e of s)"NUMBER"===e.type?i+=e.value.replace(t.decimalSeparator,o.decimalSeparator):"ARG_SEPARATOR"===e.type?i+=o.formulaArgSeparator:i+=e.value;return i}(e,t,bi)}(e,t):Na(e,t)}function $a(e){let t=!1,o=!0;return ar(e,(e=>(t=!0,o=o&&e,o))),{foundBoolean:t,result:o}}function Wa(e){let t=!1,o=!1;return ar(e,(e=>(t=!0,o=o||e,!o))),{foundBoolean:t,result:o}}function Ga(e,t){return or(e,((e,t)=>e+t),0,t)}function qa(e){return tr(e,((e,t)=>br(t)?e.add(t?.value):e),new Set).size}function Za(e){const t=Array(e);for(let o=0;o<e;o++)t[o]=Array(e).fill(0),t[o][o]=1;return t}function ja(e){if(e.length!==e[0].length)throw new Ri(Oo("Function [[FUNCTION_NAME]] invert matrix error, only square matrices are invertible"));let t=1;const o=e.length,s=Za(o),i=e.map((e=>e.slice()));for(let e=0;e<o;e++){let r=i[e][e];if(0===r){for(let r=e+1;r<o;r++)if(0!=i[e][r]){Ya(i,e,r),Ya(s,e,r),t*=-1;break}if(r=i[e][e],0===r)return{determinant:0}}for(let t=0;t<o;t++)i[t][e]=i[t][e]/r,s[t][e]=s[t][e]/r;t*=r;for(let t=0;t<o;t++){if(t===e)continue;const r=i[e][t];for(let n=0;n<o;n++)i[n][t]-=r*i[n][e],s[n][t]-=r*s[n][e]}}return{inverted:s,determinant:t}}function Ya(e,t,o){for(let s=0;s<e.length;s++){const i=e[s][t];e[s][t]=e[s][o],e[s][o]=i}}function Xa(e,t){if(e.length!==t[0].length)throw new Ri(Oo("Cannot multiply matrices : incompatible matrices size."));const o=e[0].length,s=t.length,i=e.length,r=Array(s);for(let n=0;n<s;n++){r[n]=Array(o);for(let s=0;s<o;s++){let o=0;for(let r=0;r<i;r++)o+=e[r][s]*t[n][r];r[n][s]=o}}return r}function Ka(e){if(!yi(e))return e;if(1!==e.length||1!==e[0].length)throw new Ri(Oo("The value should be a scalar or a 1x1 matrix"));return e[0][0]}function Ja(...e){const t=e[0].length;e.forEach(((e,o)=>Mi((()=>e.length===t),Oo("[[FUNCTION_NAME]] has mismatched dimensions for argument %s (%s vs %s).",o.toString(),t.toString(),e.length.toString()))))}function Qa(e,t){let o=0;const s=or(e,((e,t)=>(o+=1,e+t)),0,t);return Wi(o),s/o}function el(e,t){let o=0;for(let s of e)if(yi(s))for(let e of s)for(let t of e)"number"==typeof t.value&&(o+=1);else{const e=s?.value;Ni(e)||"string"==typeof e&&!ei(e,t)&&!Hs(e,t)||(o+=1)}return o}function tl(e){return tr(e,((e,t)=>void 0!==t&&null!==t.value?e+1:e),0)}function ol(e,t){let o={value:-1/0};return Qi(e,(e=>{e.value>=o.value&&(o=e)}),t),o.value===-1/0?{value:0}:o}function sl(e,t){let o={value:1/0};return Qi(e,(e=>{e.value<=o.value&&(o=e)}),t),o.value===1/0?{value:0}:o}function il(e,t,o){const s=e[0].length?e:[Ze(1,t.flat().length+1)],i=s.length;let r=o[0].length?o:s;return r=r.length===i?nr(r):r,{_X:s,_newX:r}}function rl(e,t,o=!0,s=!1){const i=t.flat(),r=i.length;let{_X:n}=il(e,t,[[]]);n=n.length===r?nr(n):n.slice(),Ja(n[0],i);const a=n.length,l=r-a-(o?1:0),c=[i],h=nr(n.reverse());let d=[];for(let e=0;e<a;e++)if(d.push(0),o){for(const t of n[e])d[e]+=t;d[e]/=r}let u=0;if(o){for(const e of i)u+=e;u/=r}const g=h.map((e=>e.map(((e,t)=>e-d[t]))));o&&h.forEach((e=>e.push(1)));const p=al(h,c);if(o||p.push([0]),!s)return p;const m=Xa(g,nr(g)),{inverted:f}=ja(m);if(void 0===f)throw new Ri(Oo("Matrix is not invertible"));let v=0,b=0;for(let e=0;e<r;e++){const t=i[e]-u;let o=0;for(let t=0;t<a;t++){o+=g[e][t]*p[t][0]}const s=t-o;v+=s*s,b+=o*o}const S=Math.sqrt(v/l),y=b/(b+v),C=b/a/(v/l),w=[];for(let e=0;e<a;e++)w.push(S*Math.sqrt(f[e][e]));if(o){const e=Xa(f,[d]),t=Xa(nr([d]),e);w.push(S*Math.sqrt(t[0][0]+1/i.length))}const E=[[p[0][0],w[0],y,C,b],[p[1][0],w[1],S,l,v]];for(let e=2;e<a;e++)E.push([p[e][0],w[e],"","",""]);return o?E.push([p[a][0],w[a],"","",""]):E.push([0,"","","",""]),E}function nl(e,t,o,s){Ja(t,e),Mi((()=>o>=1),Oo("Function [[FUNCTION_NAME]] A regression of order less than 1 cannot be possible."));const i=[e],r=t.map((e=>Ze(0,o).map((t=>Math.pow(e,o-t)))));s&&r.forEach((e=>e.push(1)));const n=al(r,i);return s||n.push([0]),n}function al(e,t){const o=Xa(e,nr(e)),{inverted:s}=ja(o);if(void 0===s)throw new Ri(Oo("Matrix is not invertible"));const i=Xa(e,t);return nr(Xa(s,i))}function ll(e,t,o){return e.reduce(((e,s,i)=>e+s*Math.pow(t,o-i)),0)}function cl(e){return e.map((e=>e.map((e=>Math.exp(e)))))}function hl(e){return e.map((e=>e.map((e=>Math.log(e)))))}function dl(e,t,o,s){const{_X:i,_newX:r}=il(t,e,o),n=rl(i,e,s,!1),a=n.length-1,l=r.map((e=>{let t=0;for(let o=0;o<a;o++)t+=n[o][0]*e[a-o-1];return t+=n[a][0],[t]}));return l.length===o.length?l:nr(l)}const ul="(previous)",gl="(next)";function pl(e,t){const o=e.definition.rows.map((e=>e.nameWithGranularity)),s=t.filter((e=>o.includes(e.field))),i=e.definition.columns.map((e=>e.nameWithGranularity));return{colDomain:t.filter((e=>i.includes(e.field))),rowDomain:s}}function ml(e,t,o){return"column"===t?pl(e,o).colDomain:pl(e,o).rowDomain}function fl(e,t){return void 0!==vl(e,t)}function vl(e,t,o){let s=t;for(const t of e){const e=s.find((e=>e.value===t.value));if(!e)return;if(e.field===o)return s;s=e.children}return s}function bl(e,t,o){const s=(e=Be(e)).find((e=>e.field===t));return s?(s.value=o,e):e}function Sl(e,t){return t.some((t=>t.field===e))}function yl(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 new Error(`Field ${t} not found in pivot`)}function Cl(e){return e?e.map(wl).join(", "):""}function wl(e){return e?`${e.field}=${e.value}`:""}function El(e,t){const o=e.findIndex((e=>e.field===t));if(-1===o)return"";const s=e.slice(0,o),i=e.at(-1);return Cl(i.field===t?s:[...s,i])}function xl(e,t){const o=e.findIndex((e=>e.field===t));return-1===o?"":Cl([...e.slice(0,o),...e.slice(o+1)])}function Il(e,t,o){const s=[...e],i=[...t];s.sort(((e,t)=>o([...i,e],[...i,t])));for(const t of e){const e=Il(t.children,[...i,t],o);t.children=e}return s}const Rl=new r;function Tl(e){return Rl.get(e)}const Al={normalizeFunctionValue:e=>Li(e,bi),toValueAndFormat:(e,t)=>({value:Li(e,bi),format:"dd mmm yyyy"}),toFunctionValue:e=>`"${Xr(Li(e,bi),{locale:bi,format:"mm/dd/yyyy"})}"`},_l={normalizeFunctionValue(e){const t=Li(e,bi);if(t<1||t>31)throw new Ri(Oo("%s is not a valid day of month (it should be a number between 1 and 31)",t));return t},toValueAndFormat:e=>({value:Li(e,bi),format:"0"}),toFunctionValue:e=>`${e}`},Dl={normalizeFunctionValue(e){const t=Li(e,bi);if(t<1||t>7)throw new Ri(Oo("%s is not a valid day of week (it should be a number between 1 and 7)",t));return t},toValueAndFormat(e,t){const o=(e-1+(t||bi).weekStart)%7;return{value:Yr[o].toString(),format:"@"}},toFunctionValue:e=>`${e}`},Ol={normalizeFunctionValue(e){const t=Li(e,bi);if(t<0||t>53)throw new Ri(Oo("%s is not a valid week (it should be a number between 0 and 53)",t));return t},toValueAndFormat:e=>({value:Li(e,bi),format:"0"}),toFunctionValue:e=>`${e}`},Fl={normalizeFunctionValue(e){const t=Li(e,bi);if(t<1||t>12)throw new Ri(Oo("%s is not a valid month (it should be a number between 1 and 12)",t));return t},toValueAndFormat:e=>({value:jr[Li(e,bi)-1].toString(),format:"@"}),toFunctionValue:e=>`${e}`},Ml={normalizeFunctionValue(e){const t=Li(e,bi);if(t<1||t>4)throw new Ri(Oo("%s is not a valid quarter (it should be a number between 1 and 4)",t));return t},toValueAndFormat:e=>({value:Oo("Q%(quarter_number)s",{quarter_number:e}),format:"@"}),toFunctionValue:e=>`${e}`},Pl={normalizeFunctionValue:e=>Li(e,bi),toValueAndFormat:e=>({value:Li(e,bi),format:"0"}),toFunctionValue:e=>`${e}`},Nl={normalizeFunctionValue(e){const t=Li(e,bi);if(t<0||t>23)throw new Ri(Oo("%s is not a valid hour (it should be a number between 0 and 23)",t));return t},toValueAndFormat:e=>({value:Oo("%(hour_number)sh",{hour_number:e}),format:"@"}),toFunctionValue:e=>`${e}`},kl={normalizeFunctionValue(e){const t=Li(e,bi);if(t<0||t>59)throw new Ri(Oo("%s is not a valid minute (it should be a number between 0 and 59)",t));return t},toValueAndFormat:e=>({value:Oo("%(minute_number)s'",{minute_number:e}),format:"@"}),toFunctionValue:e=>`${e}`},Ll={normalizeFunctionValue(e){const t=Li(e,bi);if(t<0||t>59)throw new Ri(Oo("%s is not a valid second (it should be a number between 0 and 59)",t));return t},toValueAndFormat:e=>({value:Oo("%(second_number)s''",{second_number:e}),format:"@"}),toFunctionValue:e=>`${e}`};function Vl(e){return{normalizeFunctionValue:t=>null===t?null:e.normalizeFunctionValue(t),toValueAndFormat:(t,o)=>null===t?{value:Oo("(Undefined)")}:e.toValueAndFormat(t,o),toFunctionValue:t=>null===t?"false":e.toFunctionValue(t)}}Rl.add("day",Vl(Al)).add("year",Vl(Pl)).add("day_of_month",Vl(_l)).add("iso_week_number",Vl(Ol)).add("month_number",Vl(Fl)).add("quarter_number",Vl(Ml)).add("day_of_week",Vl(Dl)).add("hour_number",Vl(Nl)).add("minute_number",Vl(kl)).add("second_number",Vl(Ll));const Hl={count:Oo("Count"),count_distinct:Oo("Count Distinct"),bool_and:Oo("Boolean And"),bool_or:Oo("Boolean Or"),max:Oo("Maximum"),min:Oo("Minimum"),avg:Oo("Average"),sum:Oo("Sum")},Ul=["max","min","avg","sum","count_distinct","count"],Bl={integer:Ul,char:Ul,boolean:["count_distinct","count","bool_and","bool_or"]},zl={};for(const e in Bl){zl[e]={};for(const t of Bl[e])zl[e][t]=Hl[t]}const $l={count:e=>({value:tl([e]),format:"0"}),count_distinct:e=>({value:qa([e]),format:"0"}),bool_and:e=>({value:$a([e]).result}),bool_or:e=>({value:Wa([e]).result}),max:(e,t)=>ol([e],t),min:(e,t)=>sl([e],t),avg:(e,t)=>({value:Qa([e],t),format:Pi(e)}),sum:(e,t)=>({value:Ga([e],t),format:Pi(e)})};function Wl(e){const t=Object.keys(e);if(!t.length)return 0;const o=t.map((e=>parseInt(e,10)));return Math.max(...o)}const Gl={year:Oo("Year"),quarter:Oo("Quarter & Year"),month:Oo("Month & Year"),week:Oo("Week & Year"),day:Oo("Day"),quarter_number:Oo("Quarter"),month_number:Oo("Month"),iso_week_number:Oo("Week"),day_of_month:Oo("Day of Month"),day_of_week:Oo("Day of Week"),hour_number:Oo("Hour"),minute_number:Oo("Minute"),second_number:Oo("Second")},ql=["date","datetime"];function Zl(e){const[t,o]=e.split(":");return o?{fieldName:t,granularity:o}:{fieldName:t}}function jl(e){return ql.includes(e.type)}function Yl(e,t,o){const s=[e];o&&s.push(`"${o}"`);for(const{field:e,value:o,type:i}of t){if("measure"===e){s.push('"measure"',`"${o}"`);continue}const{granularity:t}=Zl(e),r=ec(o,{type:i,granularity:t});s.push(`"${e}"`,r)}return s}function Xl(e,t){let o=0,s=0;const i=t.columns.map((e=>e.nameWithGranularity)),r=t.rows.map((e=>e.nameWithGranularity));for(;void 0!==e[o]&&e[o]===r[s];)o++,s++;for(s=0;void 0!==e[o]&&e[o]===i[s];)o++,s++;return e.length===o}function Kl(e,t){switch(t.type){case"HEADER":return`=PIVOT.HEADER(${Yl(e,t.domain).join(",")})`;case"VALUE":return`=PIVOT.VALUE(${Yl(e,t.domain,t.measure).join(",")})`;case"MEASURE_HEADER":return`=PIVOT.HEADER(${Yl(e,[...t.domain,{field:"measure",value:t.measure,type:"char"}]).join(",")})`}return""}function Jl(e,t){if(null===t||"null"===t)return null;const o="boolean"==typeof t?Gi(t).toLocaleLowerCase():Gi(t);if("null"===o)return null;if(!oc.contains(e.type))throw new Ri(Oo("Field %(field)s is not supported because of its type (%(type)s)",{field:e.displayName,type:e.type}));if("false"===o.toLowerCase())return!1;return oc.get(e.type)(o,e.granularity)}function Ql(e,t){if(!t)throw new Error("Missing granularity");return Tl(t).normalizeFunctionValue(e)}function ec(e,t){return null===e?'"null"':sc.contains(t.type)?sc.get(t.type)(e,t.granularity):`"${e}"`}function tc(e,t){if(!t)throw new Error("Missing granularity");return Tl(t).toFunctionValue(e)}const oc=new r;oc.add("date",Ql).add("datetime",Ql).add("integer",(e=>Li(e,bi))).add("boolean",(e=>ji(e))).add("char",(e=>Gi(e)));const sc=new r;function ic(e){return e.displayName+(e.granularity?` (${Gl[e.granularity]})`:"")}function rc(e,t,o){const{rowDomain:s,colDomain:i}=pl(e,t);if(0===s.length&&0===i.length)return o;if(0===s.length&&i.length>0)return{...o,format:(o.format||"@")+"* "};const r=s.length-1,n=o.format||"@";return{...o,format:`${" ".repeat(r)}${n}* `}}function nc(e,t){try{if(!t.getMeasure(e.measure))return!1;const o=t.definition.columns;for(let s=0;s<e.domain.length;s++){if(o[s].nameWithGranularity!==e.domain[s].field)return!1;if(!t.getPossibleFieldValues(o[s]).map((e=>e.value)).includes(e.domain[s].value))return!1}return!0}catch(e){return!1}}sc.add("date",tc).add("datetime",tc).add("integer",(e=>`${Li(e,bi)}`)).add("boolean",(e=>ji(e)?"TRUE":"FALSE")).add("char",(e=>`"${Gi(e).replace(/"/g,'\\"')}"`));class ac extends da{isCutAllowed(e){return 1!==e.zones.length?"WrongCutSelection":"Success"}copy(e){const t=e.sheetId,{clippedZones:o,rowsIndexes:s,columnsIndexes:i}=e,r=[],n=1==s.length&&1==i.length;for(let o of s){let a=[];for(let r of i){const l={col:r,row:o,sheetId:t};let c=this.getters.getCell(l);const h=this.getters.getEvaluatedCell(l),d=this.getters.getPivotIdFromPosition(l),u=this.getters.getArrayFormulaSpreadingOn(l);if(d&&u){const t=this.getters.getSpreadZone(u);if((!mt(u,l)||!n)&&t&&!e.zones.some((e=>as(t,e)))){const e=this.getters.getPivotCellFromPosition(l),t=Kl(this.getters.getPivotFormulaId(d),e);c={id:c?.id||"",style:c?.style,format:c?.format,content:t,isFormula:!1,parsedValue:h.value}}}else if(u&&!mt(u,l)){const e=s.includes(u.row)&&i.includes(u.col)?"":Xr(h.value,{locale:this.getters.getLocale()});c={id:c?.id||"",style:c?.style,format:h.format,content:e,isFormula:!1,parsedValue:h.value}}a.push({content:c?.content??"",style:c?.style,format:c?.format,tokens:c?.isFormula?c.compiledFormula.tokens.map((({value:e,type:t})=>({value:e,type:t}))):[],border:this.getters.getCellBorder(l)||void 0,evaluatedCell:h,position:l})}r.push(a)}return{cells:r,zones:o,sheetId:e.sheetId}}isPasteAllowed(e,t,o,s){if(!o.cells)return"Success";if(s?.isCutOperation&&void 0!==s?.pasteOption)return"WrongPasteOption";if(t.length>1&&(o.cells.length>1||o.cells[0].length>1))return"WrongPasteSelection";const i=o.cells.length,r=o.cells[0].length;for(const s of la(t,o.cells))if(this.getters.doesIntersectMerge(e,s)&&(t.length>1||!this.getters.isSingleCellOrMerge(e,t[0])||i*r!=1))return"WillRemoveExistingMerge";return"Success"}paste(e,t,o){const s=e.zones,i=e.sheetId;o.isCutOperation?this.pasteFromCut(i,s,t,o):this.pasteFromCopy(i,s,t.cells,o)}getPasteTarget(e,t,o,s){const i=o.cells[0].length,r=o.cells.length;return s?.isCutOperation?{sheetId:e,zones:[{left:t[0].left,top:t[0].top,right:t[0].left+i-1,bottom:t[0].top+r-1}]}:1===i&&1===r?{zones:[],sheetId:e}:{sheetId:e,zones:la(t,o.cells)}}pasteFromCut(e,t,o,s){this.clearClippedZones(o);const i=t[0];this.pasteZone(e,i.left,i.top,o.cells,s),this.dispatch("MOVE_RANGES",{target:o.zones,sheetId:o.sheetId,targetSheetId:e,col:i.left,row:i.top})}clearClippedZones(e){this.dispatch("CLEAR_CELLS",{sheetId:e.sheetId,target:e.zones}),this.dispatch("CLEAR_FORMATTING",{sheetId:e.sheetId,target:e.zones})}pasteZone(e,t,o,s,i){for(const[r,n]of s.entries())for(const[s,a]of n.entries()){if(!a)continue;const n={col:t+s,row:o+r,sheetId:e};this.pasteCell(a,n,i)}}pasteCell(e,t,o){const{sheetId:s,col:i,row:r}=t,n=this.getters.getEvaluatedCell(t),a=e?.format??e.evaluatedCell.format;if("asValue"===o?.pasteOption)return void this.dispatch("UPDATE_CELL",{...t,content:e.evaluatedCell.value?.toString()||"",format:a});if("onlyFormat"===o?.pasteOption)return void this.dispatch("UPDATE_CELL",{...t,style:e?.style??null,format:a??n.format});let l=e?.content;e?.tokens&&e.tokens.length>0&&!o?.isCutOperation?l=this.getters.getTranslatedCellFormula(s,i-e.position.col,r-e.position.row,e.tokens):e?.tokens&&e.tokens.length>0&&(l=this.getters.getFormulaMovedInSheet(e.position.sheetId,s,e.tokens)),""!==l||e?.format||e?.style?this.dispatch("UPDATE_CELL",{...t,content:l,style:e?.style||null,format:e?.format}):n&&this.dispatch("CLEAR_CELL",t)}convertTextToClipboardData(e){const t=this.getters.getLocale(),o={cells:[]},s=[];let i=0;for(const[t,o]of e.replace(/\r/g,"").split("\n").entries())s.push(o.split("\t")),s[t].length>i&&(i=s[t].length);for(const e of s){const s=[];for(let o=0;o<i;o++){const i=za(e[o]||"",t);s.push({content:i,evaluatedCell:{formattedValue:i}})}o.cells.push(s)}return o}}class lc extends ha{copy(e){}}class cc extends da{uuidGenerator=new na;queuedChanges={};copy(e){if(!e.zones.length)return;const{rowsIndexes:t,columnsIndexes:o}=e,s=e.sheetId,i=[];for(const e of t){const t=[];for(const i of o){const o=Array.from(this.getters.getRulesByCell(s,i,e));t.push({position:{col:i,row:e,sheetId:s},rules:o})}i.push(t)}return{cfRules:i}}paste(e,t,o){if(this.queuedChanges={},"asValue"===o.pasteOption)return;const s=e.zones,i=e.sheetId;o.isCutOperation?this.pasteFromCut(i,s,t):this.pasteFromCopy(i,s,t.cfRules,o),this.executeQueuedChanges()}pasteFromCut(e,t,o){const s=t[0];this.pasteZone(e,s.left,s.top,o.cfRules,{isCutOperation:!0})}pasteZone(e,t,o,s,i){for(const[r,n]of s.entries())for(const[s,a]of n.entries()){const n={col:t+s,row:o+r,sheetId:e};this.pasteCf(a,n,i?.isCutOperation)}}pasteCf(e,t,o){if(e?.rules&&e.rules.length>0){const s=ms(t);for(const i of e.rules){const r=[];if(o&&r.push(ms(e.position)),e.position.sheetId===t.sheetId)this.adaptCFRules(e.position.sheetId,i,[s],r);else{this.adaptCFRules(e.position.sheetId,i,[],r);const o=this.getCFToCopyTo(t.sheetId,i);this.adaptCFRules(t.sheetId,o,[s],[])}}}}adaptCFRules(e,t,o,s){this.queuedChanges[e]||(this.queuedChanges[e]=[]);const i=this.queuedChanges[e].find((e=>e.cf.id===t.id));i?(i.toAdd.push(...o),i.toRemove.push(...s)):this.queuedChanges[e].push({toAdd:o,toRemove:s,cf:t})}executeQueuedChanges(){for(const e in this.queuedChanges)for(const{toAdd:t,toRemove:o,cf:s}of this.queuedChanges[e]){const i=this.getters.getAdaptedCfRanges(e,s,t,o);i&&(0!==i.length?this.dispatch("ADD_CONDITIONAL_FORMAT",{cf:{id:s.id,rule:s.rule,stopIfTrue:s.stopIfTrue},ranges:i,sheetId:e}):this.dispatch("REMOVE_CONDITIONAL_FORMAT",{id:s.id,sheetId:e}))}}getCFToCopyTo(e,t){let o=this.getters.getConditionalFormats(e).find((e=>e.stopIfTrue===t.stopIfTrue&&mt(e.rule,t.rule)));const s=this.queuedChanges[e];return!o&&s&&(o=s.find((e=>e.cf.stopIfTrue===t.stopIfTrue&&mt(e.cf.rule,t.rule)))?.cf),o||{...t,id:this.uuidGenerator.uuidv4(),ranges:[]}}}class hc extends da{copy(e){const t=e.sheetId,{rowsIndexes:o,columnsIndexes:s,zones:i}=e,r=new Set,n=[];for(let e of o){let o=[];n.push(o);for(let n of s){const s={col:n,row:e,sheetId:t},a=this.getters.getTable(s);if(!a){o.push({});continue}const l=this.getters.getCoreTable(s),c=l?.range.zone;let h;!r.has(a.id)&&l&&c&&i.some((e=>as(c,e)))&&(r.add(a.id),h={range:l.range.rangeData,config:l.config,type:l.type}),o.push({table:h,style:this.getTableStyleToCopy(s),isWholeTableCopied:r.has(a.id)})}}return{tableCells:n,sheetId:e.sheetId}}getTableStyleToCopy(e){const t=this.getters.getCellTableStyle(e),o=this.getters.getCellStyle(e),s=this.getters.getCellTableBorder(e),i=this.getters.getCellBorder(e);return{style:{...t,...bt(o)},border:{...s,...bt(i)}}}paste(e,t,o){const s=e.zones,i=e.sheetId;o.isCutOperation?this.pasteFromCut(i,s,t,o):this.pasteFromCopy(i,s,t.tableCells,o)}pasteFromCut(e,t,o,s){for(const e of o.tableCells)for(const t of e)t.table&&this.dispatch("REMOVE_TABLE",{sheetId:o.sheetId,target:[this.getters.getRangeFromRangeData(t.table.range).zone]});const i=t[0];this.pasteZone(e,i.left,i.top,o.tableCells,s)}pasteZone(e,t,o,s,i){for(let r=0;r<s.length;r++){const n=s[r];for(let s=0;s<n.length;s++){const a=n[s];if(!a)continue;const l={col:t+s,row:o+r,sheetId:e};this.pasteTableCell(e,a,l,i)}}if(1===s.length)for(let i=0;i<s[0].length;i++)this.dispatch("AUTOFILL_TABLE_COLUMN",{col:t+i,row:o,sheetId:e})}pasteTableCell(e,t,o,s){if(t.table&&!s?.pasteOption){const{range:s}=t.table,i=ls(this.getters.getRangeFromRangeData(s).zone),r={left:o.col,top:o.row,right:o.col+i.numberOfCols-1,bottom:o.row+i.numberOfRows-1};this.dispatch("CREATE_TABLE",{sheetId:o.sheetId,ranges:[this.getters.getRangeDataFromZone(e,r)],config:t.table.config,tableType:t.table.type})}this.getters.getCoreTable(o)||"asValue"===s?.pasteOption||(s?.pasteOption||t.isWholeTableCopied)&&"onlyFormat"!==s?.pasteOption||(t.style?.style&&this.dispatch("UPDATE_CELL",{...o,style:t.style.style}),t.style?.border&&this.dispatch("SET_BORDER",{...o,border:t.style.border}))}}const dc={figureHandlers:new r,cellHandlers:new r};function uc(e,t){return"REMOVE_COLUMNS_ROWS"===t.type?ts(e,"COL"===t.dimension?"left":"top",t.elements):"ADD_COLUMNS_ROWS"===t.type?Jo(e,"COL"===t.dimension?"left":"top",t.base,t.position,t.quantity):{...e}}function gc(e,t){const o="DELETE_SHEET"===t.type&&t.sheetId;if("sheetId"in t&&e._sheetId!==t.sheetId)return e;{const s=uc(e._zone,t);if(s&&o!==e._sheetId)return{...e,_zone:s}}}dc.figureHandlers.add("chart",class extends lc{copy(e){const t=e.sheetId,o=this.getters.getFigure(t,e.figureId);if(!o)throw new Error(`No figure for the given id: ${e.figureId}`);if("chart"!==o.tag)return;const s={...o},i=this.getters.getChart(e.figureId);if(!i)throw new Error(`No chart for the given id: ${e.figureId}`);const r=i.copyInSheetId(t);return{figureId:e.figureId,copiedFigure:s,copiedChart:r}}getPasteTarget(e,t,o,s){return{zones:[],figureId:(new na).uuidv4(),sheetId:e}}paste(e,t,o){if(!e.figureId)return;const{zones:s,figureId:i}=e,r=e.sheetId,n=this.getters.getNumberCols(r),a=this.getters.getNumberRows(r),l=this.getters.getColDimensions(r,s[0].left).start,c=this.getters.getRowDimensions(r,s[0].top).start,h=this.getters.getColDimensions(r,n-1).end,d=this.getters.getRowDimensions(r,a-1).end,{width:u,height:g}=t.copiedFigure,p={x:h<u?0:Math.min(l,h-u),y:d<g?0:Math.min(c,d-g)},m=t.copiedChart.copyInSheetId(r);this.dispatch("CREATE_CHART",{id:i,sheetId:r,position:p,size:{height:g,width:u},definition:m.getDefinition()}),o.isCutOperation&&this.dispatch("DELETE_FIGURE",{sheetId:t.copiedChart.sheetId,id:t.copiedFigure.id}),this.dispatch("SELECT_FIGURE",{id:i})}isPasteAllowed(e,t,o,s){return 0===t.length?"EmptyTarget":void 0!==s?.pasteOption?"WrongFigurePasteOption":"Success"}}).add("image",class extends lc{copy(e){const t=e.sheetId,o=this.getters.getFigure(t,e.figureId);if(!o)throw new Error(`No figure for the given id: ${e.figureId}`);const s={...o};if("image"!==o.tag)return;const i=Be(this.getters.getImage(e.figureId));return{figureId:e.figureId,copiedFigure:s,copiedImage:i,sheetId:t}}getPasteTarget(e,t,o,s){return{sheetId:e,zones:[],figureId:(new na).uuidv4()}}paste(e,t,o){if(!e.figureId)return;const{zones:s,figureId:i}=e,r=this.getters.getActiveSheetId(),n=this.getters.getNumberCols(r),a=this.getters.getNumberRows(r),l=this.getters.getColDimensions(r,s[0].left).start,c=this.getters.getRowDimensions(r,s[0].top).start,h=this.getters.getColDimensions(r,n-1).end,d=this.getters.getRowDimensions(r,a-1).end,{width:u,height:g}=t.copiedFigure,p={x:h<u?0:Math.min(l,h-u),y:d<g?0:Math.min(c,d-g)},m=Be(t.copiedImage);this.dispatch("CREATE_IMAGE",{figureId:i,sheetId:r,position:p,size:{height:g,width:u},definition:m}),o.isCutOperation&&this.dispatch("DELETE_FIGURE",{sheetId:t.sheetId,id:t.copiedFigure.id}),this.dispatch("SELECT_FIGURE",{id:i})}isPasteAllowed(e,t,o,s){return 0===t.length?"EmptyTarget":void 0!==s?.pasteOption?"WrongFigurePasteOption":"Success"}}),dc.cellHandlers.add("dataValidation",class extends da{uuidGenerator=new na;queuedChanges={};copy(e){const{rowsIndexes:t,columnsIndexes:o}=e,s=e.sheetId,i=[];for(const e of t){const t=[];for(const i of o){const o={sheetId:s,col:i,row:e},r=this.getters.getValidationRuleForCell(o);t.push({position:o,rule:r})}i.push(t)}return{dvRules:i}}paste(e,t,o){if(this.queuedChanges={},o.pasteOption)return;const s=e.zones,i=e.sheetId;o.isCutOperation?this.pasteFromCut(i,s,t):this.pasteFromCopy(i,s,t.dvRules),this.executeQueuedChanges()}pasteFromCut(e,t,o){const s=t[0];this.pasteZone(e,s.left,s.top,o.dvRules,{isCutOperation:!0})}pasteZone(e,t,o,s,i){for(const[r,n]of s.entries())for(const[s,a]of n.entries()){const n={col:t+s,row:o+r,sheetId:e};this.pasteDataValidation(a,n,i?.isCutOperation)}}pasteDataValidation(e,t,o){if(e){const s=ms(t),i=e.rule;if(!i){const e=this.getters.getValidationRuleForCell(t);return void(e&&this.adaptDataValidationRule(t.sheetId,e,[],[s]))}const r=[];if(o&&r.push(ms(e.position)),e.position.sheetId===t.sheetId){const o=this.getDataValidationRuleToCopyTo(t.sheetId,i,!1);this.adaptDataValidationRule(e.position.sheetId,o,[s],r)}else{const o=this.getters.getValidationRuleForCell(e.position);o&&this.adaptDataValidationRule(e.position.sheetId,o,[],r);const n=this.getDataValidationRuleToCopyTo(t.sheetId,i);this.adaptDataValidationRule(t.sheetId,n,[s],[])}}}getDataValidationRuleToCopyTo(e,t,o=!0){let s=this.getters.getDataValidationRules(e).find((e=>mt(t.criterion,e.criterion)&&t.isBlocking===e.isBlocking));const i=this.queuedChanges[e];return!s&&i&&(s=i.find((e=>mt(t.criterion,e.rule.criterion)&&t.isBlocking===e.rule.isBlocking))?.rule),s||{...t,id:o?this.uuidGenerator.uuidv4():t.id,ranges:[]}}adaptDataValidationRule(e,t,o,s){this.queuedChanges[e]||(this.queuedChanges[e]=[]);const i=this.queuedChanges[e].find((e=>e.rule.id===t.id));i?(i.toAdd.push(...o),i.toRemove.push(...s)):this.queuedChanges[e].push({toAdd:o,toRemove:s,rule:t})}executeQueuedChanges(){for(const e in this.queuedChanges)for(const{toAdd:t,toRemove:o,rule:s}of this.queuedChanges[e]){const i=s.ranges.map((e=>e.zone)),r=yo(i,o),n=yo([...r,...t],[]);0!==n.length?this.dispatch("ADD_DATA_VALIDATION_RULE",{rule:s,ranges:n.map((t=>this.getters.getRangeDataFromZone(e,t))),sheetId:e}):this.dispatch("REMOVE_DATA_VALIDATION_RULE",{sheetId:e,id:s.id})}}}).add("cell",ac).add("sheet",class extends da{isPasteAllowed(e,t,o,s){if(!("cells"in o))return"Success";const{xSplit:i,ySplit:r}=this.getters.getPaneDivisions(e);for(const e of la(t,o.cells))if(e.left<i&&e.right>=i||e.top<r&&e.bottom>=r)return"FrozenPaneOverlap";return"Success"}}).add("merge",class extends da{copy(e){const t=this.getters.getActiveSheetId(),{rowsIndexes:o,columnsIndexes:s}=e,i=[];for(const e of o){const o=[];for(const i of s){const s={col:i,row:e,sheetId:t};o.push(this.getters.getMerge(s))}i.push(o)}return{merges:i}}paste(e,t,o){o.isCutOperation||this.pasteFromCopy(e.sheetId,e.zones,t.merges,o)}pasteZone(e,t,o,s){for(const[i,r]of s.entries())for(const[s,n]of r.entries()){const r={col:t+s,row:o+i,sheetId:e};this.pasteMerge(n,r)}}pasteMerge(e,t){if(!e)return;if(this.getters.isInMerge(t))return;const{sheetId:o,col:s,row:i}=t;this.dispatch("ADD_MERGE",{sheetId:o,force:!0,target:[{left:s,top:i,right:s+e.right-e.left,bottom:i+e.bottom-e.top}]})}}).add("border",ua).add("table",hc).add("conditionalFormat",cc);class pc{subscriptions={};on(e,t,o){if(!o)throw new Error("Missing callback");this.subscriptions[e]||(this.subscriptions[e]=[]),this.subscriptions[e].push({owner:t,callback:o})}trigger(e,t){const o=this.subscriptions[e]||[];for(let e=0,s=o.length;e<s;e++){const s=o[e];s.callback.call(s.owner,t)}}off(e,t){const o=this.subscriptions[e];o&&(this.subscriptions[e]=o.filter((e=>e.owner!==t)))}clear(){this.subscriptions={}}}class mc extends pc{dependencies=new Map;factory=new fc(this.get.bind(this));inject(e,t){if(this.dependencies.has(e)&&this.dependencies.get(e)!==t)throw new Error(`Store ${e.name} already has an instance`);this.dependencies.set(e,t)}get(e){return this.dependencies.has(e)||this.dependencies.set(e,this.instantiate(e)),this.dependencies.get(e)}instantiate(e,...t){return this.factory.build(e,...t)}resetStores(){this.dependencies.clear()}}class fc{get;pendingBuilds=new Set;constructor(e){this.get=e}build(e,...t){if(this.pendingBuilds.has(e))throw new Error(`Circular dependency detected: ${[...this.pendingBuilds,e].map((e=>e.name)).join(" -> ")}`);this.pendingBuilds.add(e);const o=new e(this.get,...t);return this.pendingBuilds.delete(e),o}}class vc{get;disposeCallbacks=[];constructor(e){this.get=e}onDispose(e){this.disposeCallbacks.push(e)}dispose(){this.disposeCallbacks.forEach((e=>e()))}}function bc(){const e=t.useEnv();if(e.__spreadsheet_stores__ instanceof mc)return e.__spreadsheet_stores__;const o=new mc;return t.useSubEnv({__spreadsheet_stores__:o,getStore:e=>wc(o.get(e),(()=>o.trigger("store-updated")))}),o}function Sc(e){const o=Ec(t.useEnv()),s=o.get(e);return Cc(o,s)}function yc(e,...o){const s=Ec(t.useEnv()),i=s.instantiate(e,...o);return t.onWillUnmount((()=>i.dispose())),Cc(s,i)}function Cc(e,o){const s=t.useComponent();return wc(o,(()=>{"mounted"===t.status(s)&&e.trigger("store-updated")}))}function wc(e,t){return new Proxy(e,{get(o,s,i){const r=o,n=Reflect.get(o,s,r);if(e.mutators?.includes(s)){const e=new Proxy(n,{apply(e,o,s){Reflect.apply(e,r,s),t()}});return e}return n}})}function Ec(e){const t=e.__spreadsheet_stores__;if(!(t instanceof mc))throw new Error("No store provider found. Did you forget to call useStoreProvider()?");return t}const xc=(Ic="Model",class{constructor(e){throw new Error(`This is a abstract store for ${Ic}, it cannot be instantiated.\nDid you forget to inject your store instance?\n\nconst stores = useStoreProvider();\nstores.inject(MyMetaStore, storeInstance);\n`)}});var Ic;class Rc{mutators=["register","unRegister"];renderers={};register(e){if(e.renderingLayers.length)for(const t of e.renderingLayers)this.renderers[t]||(this.renderers[t]=[]),this.renderers[t].push(e)}unRegister(e){for(const t of Object.keys(this.renderers))this.renderers[t]=this.renderers[t].filter((t=>t!==e))}drawLayer(e,t){const o=this.renderers[t];if(o)for(const s of o)e.ctx.save(),s.drawLayer(e,t),e.ctx.restore()}}class Tc extends vc{model=this.get(xc);getters=this.model.getters;renderer=this.get(Rc);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){}}const Ac={id:"void-composer",get editionMode(){return"inactive"},startEdition:()=>{throw new Error("No composer is registered")},stopEdition:()=>{throw new Error("No composer is registered")},setCurrentContent:()=>{throw new Error("No composer is registered")}};class _c extends Tc{mutators=["focusComposer","focusActiveComposer"];activeComposer=Ac;_focusMode="inactive";get focusMode(){return"inactive"===this.activeComposer.editionMode?"inactive":this._focusMode}focusComposer(e,t){this.activeComposer=e,this.getters.isReadonly()||(this._focusMode=t.focusMode||"contentFocus","inactive"!==this._focusMode&&this.setComposerContent(t))}focusActiveComposer(e){if(!this.getters.isReadonly()){if(!this.activeComposer)throw new Error("No composer is registered");this._focusMode=e.focusMode||"contentFocus","inactive"!==this._focusMode&&this.setComposerContent(e)}}setComposerContent({content:e,selection:t}){"inactive"===this.activeComposer.editionMode?this.activeComposer.startEdition(e,t):e&&this.activeComposer.setCurrentContent(e,t)}}const Dc="x1";function Oc(e,t,o,s){let i=!1;const r=[];for(let s in o){let n=o[s];if(n.labelCell){const e=Pc(n.labelCell,t);n.labelCell!==e&&(i=!0,n={...n,labelCell:e})}const a=Pc(n.dataRange,t);void 0===a||e.getRangeString(a,a.sheetId)===xi.InvalidReference?(i=!0,n=void 0):a!==n.dataRange&&(i=!0,n={...n,dataRange:a}),r[s]=n}let n=s;const a=Pc(n,t);a!==n&&(i=!0,n=a);return{isStale:i,dataSets:r.filter(at),labelRange:n}}function Fc(e,t,o){return o.map((o=>({dataRange:kn(e,t,o.dataRange),labelCell:o.labelCell?kn(e,t,o.labelCell):void 0})))}function Mc(e,t,o){return o?kn(e,t,o):void 0}function Pc(e,t){if(!e)return;const o=t(e);switch(o.changeType){case"NONE":return e;case"REMOVE":return;default:return o.range}}function Nc(e,t,o,s){const i=[];for(const r of t){const t=e.getRangeFromSheetXC(o,r.dataRange),{unboundedZone:n,sheetId:a,invalidSheetName:l,invalidXc:c}=t;if(!l&&!c)if(n.left!==n.right&&n.top!==n.bottom){if(void 0===n.right)continue;for(let t=n.left;t<=n.right;t++){const o={...n,left:t,right:t};i.push({...kc(e,a,o,s?{top:o.top,bottom:o.top,left:o.left,right:o.left}:void 0),backgroundColor:r.backgroundColor,rightYAxis:"y1"===r.yAxisId,customLabel:r.label})}}else i.push({...kc(e,a,n,s?{top:n.top,bottom:n.top,left:n.left,right:n.left}:void 0),backgroundColor:r.backgroundColor,rightYAxis:"y1"===r.yAxisId,customLabel:r.label})}return i}function kc(e,t,o,s){if(o.left!==o.right&&o.top!==o.bottom)throw new Error(`Zone should be a single column or row: ${Ko(o)}`);if(s){const i=Ko(o),r=Ko(s);return{labelCell:e.getRangeFromSheetXC(t,r),dataRange:e.getRangeFromSheetXC(t,i)}}return{labelCell:void 0,dataRange:e.getRangeFromSheetXC(t,Ko(o))}}function Lc(e,t){const o=t.labelCell?.zone;let s=t.dataRange.zone;if(o){const{numberOfRows:e,numberOfCols:t}=ls(s);1===e?s={...s,left:s.left+1}:1===t&&(s={...s,top:s.top+1})}const i=t.dataRange.clone({zone:s});let r={};return t.customLabel?r={text:t.customLabel}:t.labelCell&&(r={reference:e.getRangeString(t.labelCell,"forceSheetReference",{useBoundedReference:!0})}),{label:r,range:e.getRangeString(i,"forceSheetReference",{useBoundedReference:!0}),backgroundColor:t.backgroundColor,rightYAxis:t.rightYAxis}}function Vc(e,t,o){if(!t)return;let s={...t.zone};o&&t.zone.bottom>t.zone.top&&(s.top=s.top+1);const i=t.clone({zone:s});return e.getRangeString(i,"forceSheetReference",{useBoundedReference:!0})}function Hc(e,t){let o;if(e.labelRange){const s=uc(Zo(e.labelRange),t);o=s?Ko(s):void 0}const s=e.dataSets.map((e=>Zo(e.dataRange))).map((e=>uc(e,t))).filter(at).map((e=>({dataRange:Ko(e)})));return{...e,labelRange:o,dataSets:s}}function Uc(e){return e&&Wt(e)<.3?"#FFFFFF":"#000000"}function Bc(e){return e&&Wt(e)<.3?"#C8C8C8":"#666666"}function zc(e){if(e.dataSets){const t=void 0!==e.dataSets.find((e=>!Ho.test(e.dataRange)));if(t)return"InvalidDataSet";if(e.dataSets.map((e=>Zo(e.dataRange))).some((e=>e.top!==e.bottom&&vs(e))))return"InvalidDataSet"}return"Success"}function $c(e){if(e.labelRange){if(!Ho.test(e.labelRange||""))return"InvalidLabelRange"}return"Success"}function Wc(e,t,o){if(!o)return!1;if(!e)return!1;if(!t)return!0;const s=bs(t.dataRange.zone);return!(bs(e.zone)<s)}function Gc(e,t){const{x:o,y:s}=e.getMainViewportCoordinates(),{scrollX:i,scrollY:r}=e.getActiveSheetScrollInfo(),{width:n,height:a}=e.getVisibleRect(e.getActiveMainViewport());return{x:o+i+Math.max(0,(n-t.width)/2),y:s+r+Math.max(0,(a-t.height)/2)}}function qc(e){let t=!1,o=!1;if("horizontal"in e&&e.horizontal)return{useLeftAxis:!0,useRightAxis:!1};for(const s of e.dataSets||[])"y1"===s.yAxisId?o=!0:t=!0;return t||=!o,{useLeftAxis:t,useRightAxis:o}}function Zc(e,t){return(o,s)=>jc({format:s?e?.[s]:void 0,locale:t})(o)}function jc(e){return t=>{if(t=Number(t),isNaN(t))return t;const{locale:o,format:s}=e;return Xr(t,{locale:o,format:!s&&Math.abs(t)>=1e3?"#,##":s})}}const Yc=[{value:"left",label:Oo("Left")},{value:"right",label:Oo("Right")}];function Xc(e,t){const o=[],s=Dt(t.map((e=>e.data.length)));for(let t=0;t<=s;t++)o.push(e.next());return o}const Kc={id:"chartShowValuesPlugin",afterDatasetsDraw(e,t,o){if(!o.showValues)return;const s=e._metasets?.[0]?.data;if(!s)return;const i=e.ctx;switch(i.save(),i.textAlign="center",i.textBaseline="middle",i.miterLimit=1,e.config.type){case"pie":case"doughnut":!function(e,t,o){for(const s of e._metasets)for(let e=0;e<s._parsed.length;e++){const i=Number(s._parsed[e]);if(isNaN(i)||0===i)continue;const r=s.data[e],{startAngle:n,endAngle:a,innerRadius:l,outerRadius:c}=r,h=(n+a)/2,d=(l+c)/2,u=r.x+d*Math.cos(h),g=r.y+d*Math.sin(h)+7;o.fillStyle=Uc(t.background),o.strokeStyle=t.background||"#ffffff";Jc(t.callback(i),u,g,o)}}(e,o,i);break;case"bar":case"line":case"radar":o.horizontal?function(e,t,o){const s=e.chartArea.right,i=e.chartArea.left,r={};for(const n of e._metasets){if(n.xAxisID===Dc)return;for(let e=0;e<n._parsed.length;e++){const a=Number(n._parsed[e].x);if(isNaN(a))continue;const l=t.callback(a,n.xAxisID),c=n.data[e],h=c.y;let d=a<0?c.x+c.width/2:c.x-c.width/2;d=Math.min(d,s),d=Math.max(d,i),r[h]||(r[h]=[]);const u=Zn(o,l,{fontSize:12},"px");for(const e of r[h])Math.abs(e-d)<u&&(d=e+u+3);r[h].push(d),o.fillStyle=c.options.backgroundColor,o.strokeStyle=t.background||"#ffffff",Jc(l,d,h,o)}}}(e,o,i):function(e,t,o){const s=e.chartArea.bottom,i=e.chartArea.top,r={};for(const n of e._metasets)if(n.xAxisID!==Dc&&!n.hidden)for(let a=0;a<n._parsed.length;a++){const l=n._parsed[a],c=Number("radar"===e.config.type?l.r:l.y);if(isNaN(c))continue;const h="radar"===e.config.type?n.rAxisID:n.yAxisID,d=t.callback(Number(c),h),u=n.data[a],g=u.x;let p=0;p="line"===e.config.type||"radar"===e.config.type?u.y-10:c<0?u.y-u.height/2:u.y+u.height/2,p=Math.min(p,s),p=Math.max(p,i),r[g]||(r[g]=[]);for(const e of r[g]||[])Math.abs(e-p)<13&&(p=e-13);r[g].push(p),o.fillStyle=u.options.backgroundColor,o.strokeStyle=t.background||"#ffffff",Jc(d,g,p,o)}}(e,o,i)}i.restore()}};function Jc(e,t,o,s){s.lineWidth=3,s.strokeText(e,t,o),s.lineWidth=1,s.fillText(e,t,o)}const Qc={id:"waterfallLinesPlugin",beforeDraw(e,t,o){if(!o.showConnectorLines)return;const s=e._metasets?.[0]?.data;if(!s)return;const i=e.ctx;i.save(),i.setLineDash([3,2]);for(let e=0;e<s.length;e++){const t=s[e];if(0===t.height)continue;const o=th(s,e);if(!o)break;const r=eh(t),n=eh(o),a=t.$context.raw,l=a[1]-a[0],c=Math.round(l<0?r.bottom-1:r.top),h=Math.round(r.right),d=Math.round(n.left);i.strokeStyle="#999",i.beginPath(),i.moveTo(h+1,c+.5),i.lineTo(d,c+.5),i.stroke()}i.restore()}};function eh(e){const t=e.base<e.y;return{left:e.x-e.width/2,right:e.x+e.width/2,bottom:t?e.base+e.height:e.y+e.height,top:t?e.base:e.y}}function th(e,t){return e.find(((e,o)=>o>t&&0!==e.height))}window.Chart?.register(Qc),window.Chart?.register(Kc);class oh extends t.Component{static template="o-spreadsheet-ChartJsComponent";static props={figure:Object};canvas=t.useRef("graphContainer");chart;currentRuntime;get background(){return this.chartRuntime.background}get canvasStyle(){return`background-color: ${this.background}`}get chartRuntime(){const e=this.env.model.getters.getChartRuntime(this.props.figure.id);if(!("chartJsConfig"in e))throw new Error("Unsupported chart runtime");return e}setup(){t.onMounted((()=>{const e=this.chartRuntime;this.currentRuntime=e,this.createChart(Be(e.chartJsConfig))})),t.onWillUnmount((()=>this.chart?.destroy())),t.useEffect((()=>{const e=this.chartRuntime;e!==this.currentRuntime&&(e.chartJsConfig.type!==this.currentRuntime.chartJsConfig.type?(this.chart?.destroy(),this.createChart(Be(e.chartJsConfig))):this.updateChartJs(Be(e)),this.currentRuntime=e)}))}createChart(e){const t=this.canvas.el.getContext("2d");this.chart=new window.Chart(t,e)}updateChartJs(e){const t=e.chartJsConfig;t.data&&t.data.datasets?(this.chart.data=t.data,t.options?.plugins?.title&&(this.chart.config.options.plugins.title=t.options.plugins.title)):this.chart.data.datasets=[],this.chart.config.options=t.options,this.chart.update()}}class sh{sheetId;title;getters;constructor(e,t,o){this.title=e.title,this.sheetId=t,this.getters=o}static validateChartDefinition(e,t){throw new Error("This method should be implemented by sub class")}static transformDefinition(e,t){throw new Error("This method should be implemented by sub class")}static getDefinitionFromContextCreation(e){throw new Error("This method should be implemented by sub class")}}function ih(e,t,o,s,i){if("text"===t||"progress"===t||e?.type!==ii.number||o?.type!==ii.number)return;const r=o.value-e.value;return r>0?s:r<0?i:void 0}function rh(e,t,o){if("text"===o||e?.type!==ii.number||t?.type!==ii.number)return"neutral";const s=t.value-e.value;return s>0?"up":s<0?"down":"neutral"}function nh(e){return e.keyValue&&!Ho.test(e.keyValue)?"InvalidScorecardKeyValue":"Success"}function ah(e){return e.baseline&&!Ho.test(e.baseline)?"InvalidScorecardBaseline":"Success"}const lh=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"),ch=new window.Path2D("M8.7 5.5a.5.5 0 0 0 0-.75l-3.8-4a.5.5 0 0 0-.75 0l-3.8 4a.5.5 0 0 0 0 .75l.4.4a.5.5 0 0 0 .75 0l2.3-2.4v5.8c0 .25.25.5.5.5h.6c.25 0 .5-.25.5-.5v-5.8l2.2 2.4a.5.5 0 0 0 .75 0z");let hh=class e extends sh{keyValue;baseline;baselineMode;baselineDescr;progressBar=!1;background;baselineColorUp;baselineColorDown;fontColor;humanize;type="scorecard";constructor(e,t,o){super(e,t,o),this.keyValue=Ln(o,t,e.keyValue),this.baseline=Ln(o,t,e.baseline),this.baselineMode=e.baselineMode,this.baselineDescr=e.baselineDescr,this.background=e.background,this.baselineColorUp=e.baselineColorUp??xe,this.baselineColorDown=e.baselineColorDown??Ie,this.humanize=e.humanize??!1}static validateChartDefinition(e,t){return e.checkValidations(t,nh,ah)}static getDefinitionFromContextCreation(e){return{background:e.background,type:"scorecard",keyValue:e.range?e.range[0].dataRange:void 0,title:e.title||{text:""},baselineMode:Ee,baselineColorUp:xe,baselineColorDown:Ie,baseline:e.auxiliaryRange||""}}static transformDefinition(e,t){let o,s;return e.baseline&&(o=uc(Zo(e.baseline),t)),e.keyValue&&(s=uc(Zo(e.keyValue),t)),{...e,baseline:o?Ko(o):void 0,keyValue:s?Ko(s):void 0}}copyForSheetId(t){const o=Mc(this.sheetId,t,this.baseline),s=Mc(this.sheetId,t,this.keyValue),i=this.getDefinitionWithSpecificRanges(o,s,t);return new e(i,t,this.getters)}copyInSheetId(t){const o=this.getDefinitionWithSpecificRanges(this.baseline,this.keyValue,t);return new e(o,t,this.getters)}getDefinition(){return this.getDefinitionWithSpecificRanges(this.baseline,this.keyValue)}getContextCreation(){return{...this,range:this.keyValue?[{dataRange:this.getters.getRangeString(this.keyValue,this.sheetId)}]:void 0,auxiliaryRange:this.baseline?this.getters.getRangeString(this.baseline,this.sheetId):void 0}}getDefinitionWithSpecificRanges(e,t,o){return{baselineColorDown:this.baselineColorDown,baselineColorUp:this.baselineColorUp,baselineMode:this.baselineMode,title:this.title,type:"scorecard",background:this.background,baseline:e?this.getters.getRangeString(e,o||this.sheetId):void 0,baselineDescr:this.baselineDescr,keyValue:t?this.getters.getRangeString(t,o||this.sheetId):void 0,humanize:this.humanize}}getDefinitionForExcel(){}updateRanges(t){const o=Pc(this.baseline,t),s=Pc(this.keyValue,t);if(this.baseline===o&&this.keyValue===s)return this;const i=this.getDefinitionWithSpecificRanges(o,s);return new e(i,this.sheetId,this.getters)}};function dh(e,t){const o=t.getContext("2d");t.width=e.canvas.width;const s=t.width-2*Z;if(t.height=e.canvas.height,o.fillStyle=e.canvas.backgroundColor,o.fillRect(0,0,e.canvas.width,e.canvas.height),e.title){o.font=e.title.style.font,o.fillStyle=e.title.style.color;const t=o.textBaseline;o.textBaseline="middle",o.fillText(ia(o,e.title.text,s-e.title.position.x),e.title.position.x,e.title.position.y),o.textBaseline=t}if(e.baseline&&(o.font=e.baseline.style.font,o.fillStyle=e.baseline.style.color,ra(o,e.baseline.text,e.baseline.position,e.baseline.style.underline,e.baseline.style.strikethrough)),e.baselineArrow&&e.baselineArrow.style.size>0){o.save(),o.fillStyle=e.baselineArrow.style.color,o.translate(e.baselineArrow.position.x,e.baselineArrow.position.y);const t=e.baselineArrow.style.size/10;switch(o.scale(t,t),e.baselineArrow.direction){case"down":o.fill(lh);break;case"up":o.fill(ch)}o.restore()}if(e.baselineDescr){const t=e.baselineDescr[0];o.font=t.style.font,o.fillStyle=t.style.color;for(const t of e.baselineDescr)o.fillText(ia(o,t.text,s-t.position.x),t.position.x,t.position.y)}if(e.key&&(o.font=e.key.style.font,o.fillStyle=e.key.style.color,ra(o,ia(o,e.key.text,s-e.key.position.x),e.key.position,e.key.style.underline,e.key.style.strikethrough)),e.progressBar){if(o.fillStyle=e.progressBar.style.backgroundColor,o.beginPath(),o.roundRect(e.progressBar.position.x,e.progressBar.position.y,e.progressBar.dimension.width,e.progressBar.dimension.height,e.progressBar.dimension.height/2),o.fill(),o.fillStyle=e.progressBar.style.color,o.beginPath(),e.progressBar.value>0)o.roundRect(e.progressBar.position.x,e.progressBar.position.y,e.progressBar.dimension.width*Math.max(0,Math.min(1,e.progressBar.value)),e.progressBar.dimension.height,e.progressBar.dimension.height/2);else{const t=e.progressBar.dimension.width*Math.max(0,Math.min(1,-e.progressBar.value));o.roundRect(e.progressBar.position.x+e.progressBar.dimension.width-t,e.progressBar.position.y,t,e.progressBar.dimension.height,e.progressBar.dimension.height/2)}o.fill()}}function uh(e,t){let o,s="";const i=t.getLocale();if(e.keyValue){const r={sheetId:e.keyValue.sheetId,col:e.keyValue.zone.left,row:e.keyValue.zone.top};o=t.getEvaluatedCell(r),s=function(e,t,o){return e?t?fn(e,o):e.formattedValue??String(e.value??""):""}(o,e.humanize??!1,i)}let r;const n=e.baseline;if(n){const e={sheetId:n.sheetId,col:n.zone.left,row:n.zone.top};r=t.getEvaluatedCell(e)}const{background:a,fontColor:l}=t.getStyleOfSingleCellChart(e.background,e.keyValue),c=function(e,t,o,s,i){if(!e)return"";if("text"===o||t?.type!==ii.number||e.type!==ii.number)return s?fn(e,i):e.formattedValue;let{value:r,format:n}=e;return"progress"===o?(r=t.value/r,n="0.0%"):(r=Math.abs(t.value-r),"percentage"===o&&0!==r&&(r/=e.value),"percentage"===o&&(n="0.0%"),n||(r=Math.round(100*r)/100)),s?fn({value:r,format:n},i):Xr(r,{format:n,locale:i})}(r,o,e.baselineMode,e.humanize??!1,i),h="progress"===e.baselineMode&&ei(c,i)?Li(c,i):0;return{title:{...e.title,text:e.title.text?Oo(e.title.text):""},keyValue:s,baselineDisplay:c,baselineArrow:rh(r,o,e.baselineMode),baselineColor:ih(r,e.baselineMode,o,e.baselineColorUp,e.baselineColorDown),baselineDescr:"progress"!==e.baselineMode&&e.baselineDescr?Oo(e.baselineDescr):"",fontColor:l,background:a,baselineStyle:"percentage"!==e.baselineMode&&"progress"!==e.baselineMode&&n?t.getCellStyle({sheetId:n.sheetId,col:n.zone.left,row:n.zone.top}):void 0,keyValueStyle:e.keyValue?t.getCellStyle({sheetId:e.keyValue.sheetId,col:e.keyValue.zone.left,row:e.keyValue.zone.top}):void 0,progressBar:"progress"===e.baselineMode?{value:h,color:h>0?e.baselineColorUp:e.baselineColorDown}:void 0}}const gh=10,ph=.05;function mh({width:e,height:t},o){return new fh({width:e,height:t},o).computeDesign()}class fh{runtime;context;width;height;constructor({width:e,height:t},o){this.runtime=o;const s=document.createElement("canvas");this.width=s.width=e,this.height=s.height=t,this.context=s.getContext("2d")}computeDesign(){const e={canvas:{width:this.width,height:this.height,backgroundColor:this.backgroundColor}},t=this.getTextStyles();let o=0;if(this.title){let s,i;switch(({height:o,width:i}=this.getFullTextDimensions(this.title,t.title.font)),this.runtime.title.align){case"center":s=(this.width-i)/2;break;case"right":s=this.width-i-gh;break;default:s=gh}e.title={text:this.title,style:t.title,position:{x:s,y:gh+o/2}}}const s=t.baselineArrow?.size??0;let{height:i,width:r}=this.getTextDimensions(this.baseline,t.baselineValue.font);this.baseline||(i=this.getTextDimensions(this.baselineDescr,t.baselineDescr.font).height);const n=this.getTextDimensions(this.baselineDescr,t.baselineDescr.font).width;e.baseline={text:this.baseline,style:t.baselineValue,position:{x:(this.width-r-n+s)/2,y:this.keyValue?this.height*(1-ph*(this.runtime.progressBar?1:2)):this.height-(this.height-o-i)/2-gh}};const a=s+20;if(e.baseline.position.x<a&&(e.baseline.position.x=a),t.baselineArrow&&!this.runtime.progressBar&&(e.baselineArrow={direction:this.baselineArrow,style:t.baselineArrow,position:{x:e.baseline.position.x-s,y:e.baseline.position.y-(i+s)/2}}),this.baselineDescr){const o={x:e.baseline.position.x+r,y:e.baseline.position.y};e.baselineDescr=[{text:this.baselineDescr,style:t.baselineDescr,position:o}]}let l=0;this.runtime.progressBar&&(l=.05*this.height,e.progressBar={position:{x:20,y:.9*this.height-i-l},dimension:{height:l,width:this.width-40},value:this.runtime.progressBar.value,style:{color:this.runtime.progressBar.color,backgroundColor:this.secondaryFontColor}});const{width:c,height:h}=this.getFullTextDimensions(this.keyValue,t.keyValue.font);return this.keyValue&&(e.key={text:this.keyValue,style:t.keyValue,position:{x:Math.max(gh,(this.width-c)/2),y:.4*this.height+5+(o+h/2)/2}}),e}get title(){return this.runtime.title.text??""}get keyValue(){return this.runtime.keyValue}get baseline(){return this.runtime.baselineDisplay}get baselineDescr(){return function(e,t){const o=e||"";return t&&o?" "+o:o}(this.runtime.baselineDescr,this.baseline)}get baselineArrow(){return this.runtime.baselineArrow}get backgroundColor(){return this.runtime.background}get secondaryFontColor(){return Bc(this.backgroundColor)}getTextDimensions(e,t){this.context.font=t;const o=this.context.measureText(e);return{width:o.width,height:o.actualBoundingBoxAscent+o.actualBoundingBoxDescent}}getFullTextDimensions(e,t){this.context.font=t;const o=this.context.measureText(e);return{width:o.width,height:o.fontBoundingBoxAscent+o.fontBoundingBoxDescent}}getTextStyles(){let e=16;const t=Math.floor(.9*e);return this.runtime.progressBar&&(e/=1.5),{title:{font:Gn(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:Gn(32,this.runtime.keyValueStyle?.bold,this.runtime.keyValueStyle?.italic),strikethrough:this.runtime.keyValueStyle?.strikethrough,underline:this.runtime.keyValueStyle?.underline},baselineValue:{font:Gn(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:Gn(t),color:this.secondaryFontColor},baselineArrow:"neutral"===this.baselineArrow||this.runtime.progressBar?void 0:{size:this.keyValue?.8*e:0,color:this.runtime.baselineColor||this.secondaryFontColor}}}}class vh extends t.Component{static template="o-spreadsheet-ScorecardChart";static props={figure:Object};canvas=t.useRef("chartContainer");get runtime(){return this.env.model.getters.getChartRuntime(this.props.figure.id)}get title(){const e=this.env.model.getters.getChartDefinition(this.props.figure.id).title.text??"";return Oo(e)}setup(){t.useEffect(this.createChart.bind(this),(()=>{const e=this.canvas.el.getBoundingClientRect();return[e.width,e.height,this.runtime,this.canvas.el]}))}createChart(){const e=this.canvas.el;dh(mh(e.getBoundingClientRect(),this.runtime),e)}}const bh=new r;function Sh(e,t,o,s){const i=[];e=e.toLowerCase();for(const r of e){const e=t.toLocaleLowerCase().indexOf(r);-1!==e&&(i.push({value:t.slice(0,e),color:""},{value:t[e],color:o,class:s}),t=t.slice(e+1))}return i.push({value:t}),i.filter((e=>e.value))}bh.add("dataValidation",{getProposals(e,t){if(t.startsWith("="))return[];if(!this.composer.currentEditedCell)return[];const o=this.composer.currentEditedCell,s=this.getters.getValidationRuleForCell(o);if(!s||"isValueInList"!==s.criterion.type&&"isValueInRange"!==s.criterion.type)return[];let i;if("isValueInList"===s.criterion.type)i=s.criterion.values;else{const e=this.getters.getRangeFromSheetXC(o.sheetId,s.criterion.values[0]);i=Array.from(new Set(this.getters.getRangeValues(e).filter(lt).map((e=>e.toString())).filter((e=>""!==e))))}return i.map((e=>({text:e})))},selectProposal(e,t){this.composer.setCurrentContent(t),this.composer.stopEdition()}});const yh=/(.*?)\((.*?)\)(.*)/,Ch=["ANY","BOOLEAN","DATE","NUMBER","STRING","RANGE","RANGE<BOOLEAN>","RANGE<DATE>","RANGE<NUMBER>","RANGE<STRING>","META"];function wh(e,t=""){return function(e,t){let o=e.match(yh),s=o[1].trim();if(!s)throw new Error(`Function argument definition is missing a name: '${e}'.`);let i,r=[],n=!1,a=!1;for(let e of o[2].split(",")){const t=e.trim().toUpperCase();let o=Ch.find((e=>t===e));o?r.push(o):"RANGE<ANY>"===t?r.push("RANGE"):"OPTIONAL"===t?n=!0:"REPEATING"===t?a=!0:t.startsWith("DEFAULT=")&&(i=e.trim().slice(8))}const l={name:s,description:t,type:r};(r.includes("ANY")||r.includes("RANGE"))&&(l.acceptErrors=!0);n&&(l.optional=!0);a&&(l.repeating=!0);void 0!==i&&(l.default=!0,l.defaultValue=i);r.some((e=>e.startsWith("RANGE")))&&(l.acceptMatrix=!0);r.every((e=>e.startsWith("RANGE")))&&(l.acceptMatrixOnly=!0);return l}(e,t)}function Eh(e){let t=0,o=0,s=0;for(let i of e.args)t++,i.optional||i.repeating||i.default||o++,i.repeating&&s++;const i=e;return i.minArgRequired=o,i.maxArgPossible=s?1/0:t,i.nbrArgRepeating=s,i.getArgToFocus=function(e,t){if(!t)return e=>e;if(1===t)return t=>Math.min(t,e);const o=e-t;return e=>{if(e<=o)return e;return o+((e-o)%t||t)}}(t,s),i.hidden=e.hidden||!1,i}function xh(e,t){Mi((()=>1===t.length||1===t[0].length),e)}function Ih(e,...t){if(t.every(yi)){const o=t[0].length,s=t[0][0].length;for(const i of t)Mi((()=>i.length===o&&i[0].length===s),e)}else if(t.some((e=>Array.isArray(e)&&(1!==e.length||1!==e[0].length))))throw new Ri(e)}function Rh(e,t){Mi((()=>t>0),e)}function Th(e,t){Mi((()=>t.length===t[0].length),e)}const Ah={description:Oo("Returns a result array constrained to a specific width and height."),args:[wh("input_range (any, range<any>)",Oo("The range to constrain.")),wh("rows (number)",Oo("The number of rows in the constrained array.")),wh("columns (number)",Oo("The number of columns in the constrained array."))],compute:function(e,t,o){const s=fr(e),i=Bi(t?.value,this.locale),r=Bi(o?.value,this.locale);Rh(Oo("The rows argument (%s) must be strictly positive.",i.toString()),i),Rh(Oo("The columns argument (%s) must be strictly positive.",i.toString()),r);const n=Math.min(i,s[0].length);return ir(Math.min(r,s.length),n,((e,t)=>s[e][t]))},isExported:!1},_h={description:Oo("Creates a new array from the selected columns in the existing range."),args:[wh("array (any, range<any>)",Oo("The array that contains the columns to be returned.")),wh("col_num (number, range<number>)",Oo("The first column index of the columns to be returned.")),wh("col_num2 (number, range<number>, repeating)",Oo("The columns indexes of the columns to be returned."))],compute:function(e,...t){const o=fr(e),s=vr(t,(e=>Bi(e?.value,this.locale))),i=s.filter((e=>0===e||o.length<Math.abs(e)));Mi((()=>0===i.length),Oo("The columns arguments must be between -%s and %s (got %s), excluding 0.",o.length.toString(),o.length.toString(),i.join(",")));const r=Array(s.length);for(let e=0;e<s.length;e++)s[e]>0?r[e]=o[s[e]-1]:r[e]=o[o.length+s[e]];return r},isExported:!0},Dh={description:Oo("Creates a new array from the selected rows in the existing range."),args:[wh("array (any, range<any>)",Oo("The array that contains the rows to be returned.")),wh("row_num (number, range<number>)",Oo("The first row index of the rows to be returned.")),wh("row_num2 (number, range<number>, repeating)",Oo("The rows indexes of the rows to be returned."))],compute:function(e,...t){const o=fr(e),s=vr(t,(e=>Bi(e?.value,this.locale))),i=o.length,r=s.filter((e=>0===e||o[0].length<Math.abs(e)));return Mi((()=>0===r.length),Oo("The rows arguments must be between -%s and %s (got %s), excluding 0.",o[0].length.toString(),o[0].length.toString(),r.join(","))),ir(i,s.length,((e,t)=>s[t]>0?o[e][s[t]-1]:o[e][o[e].length+s[t]]))},isExported:!0},Oh={description:Oo("Expands or pads an array to specified row and column dimensions."),args:[wh("array (any, range<any>)",Oo("The array to expand.")),wh("rows (number)",Oo("The number of rows in the expanded array. If missing, rows will not be expanded.")),wh("columns (number, optional)",Oo("The number of columns in the expanded array. If missing, columns will not be expanded.")),wh("pad_with (any, default=0)",Oo("The value with which to pad."))],compute:function(e,t,o,s={value:0}){const i=fr(e),r=Bi(t?.value,this.locale),n=void 0!==o?Bi(o.value,this.locale):i.length;return Mi((()=>r>=i[0].length),Oo("The rows arguments (%s) must be greater or equal than the number of rows of the array.",r.toString())),Mi((()=>n>=i.length),Oo("The columns arguments (%s) must be greater or equal than the number of columns of the array.",n.toString())),ir(n,r,((e,t)=>e>=i.length||t>=i[e].length?s:i[e][t]))},isExported:!0},Fh={description:Oo("Flattens all the values from one or more ranges into a single column."),args:[wh("range (any, range<any>)",Oo("The first range to flatten.")),wh("range2 (any, range<any>, repeating)",Oo("Additional ranges to flatten."))],compute:function(...e){return[vr(e,(e=>void 0===e?{value:""}:e))]},isExported:!1},Mh={description:Oo("Calculates the frequency distribution of a range."),args:[wh("data (range<number>)",Oo("The array of ranges containing the values to be counted.")),wh("classes (number, range<number>)",Oo("The range containing the set of classes."))],compute:function(e,t){const o=vr([e],(e=>e.value)).filter((e=>"number"==typeof e)),s=vr([t],(e=>e.value)).filter((e=>"number"==typeof e)),i=s.map(((e,t)=>({initialIndex:t,value:e,count:0}))).sort(((e,t)=>e.value-t.value));i.push({initialIndex:i.length,value:1/0,count:0});const r=o.sort(((e,t)=>e-t));let n=0;for(const e of r){for(;e>i[n].value&&n<i.length-1;)n++;i[n].count++}return[i.sort(((e,t)=>e.initialIndex-t.initialIndex)).map((e=>e.count))]},isExported:!0},Ph={description:Oo("Appends ranges horizontally and in sequence to return a larger array."),args:[wh("range1 (any, range<any>)",Oo("The first range to be appended.")),wh("range2 (any, range<any>, repeating)",Oo("Additional ranges to add to range1."))],compute:function(...e){const t=Math.max(...e.map((e=>e?.[0]?.length??0))),o=[];for(const s of e){const e=fr(s);for(let s=0;s<e.length;s++){const i=Array(t).fill({value:null});for(let t=0;t<e[s].length;t++)i[t]=e[s][t];o.push(i)}}return o},isExported:!0},Nh={description:Oo("Returns the matrix determinant of a square matrix."),args:[wh("square_matrix (number, range<number>)",Oo("An range with an equal number of rows and columns representing a matrix whose determinant will be calculated."))],compute:function(e){const t=Hi(e,"square_matrix");return Th(Oo("The argument square_matrix must have the same number of columns and rows."),t),ja(t).determinant},isExported:!0},kh={description:Oo("Returns the multiplicative inverse of a square matrix."),args:[wh("square_matrix (number, range<number>)",Oo("An range with an equal number of rows and columns representing a matrix whose multiplicative inverse will be calculated."))],compute:function(e){const t=Hi(e,"square_matrix");Th(Oo("The argument square_matrix must have the same number of columns and rows."),t);const{inverted:o}=ja(t);return o||new Ri(Oo("The matrix is not invertible."))},isExported:!0},Lh={description:Oo("Calculates the matrix product of two matrices."),args:[wh("matrix1 (number, range<number>)",Oo("The first matrix in the matrix multiplication operation.")),wh("matrix2 (number, range<number>)",Oo("The second matrix in the matrix multiplication operation."))],compute:function(e,t){const o=Hi(e,"matrix1"),s=Hi(t,"matrix2");return Mi((()=>o.length===s[0].length),Oo("In [[FUNCTION_NAME]], the number of columns of the first matrix (%s) must be equal to the number of rows of the second matrix (%s).",o.length.toString(),s[0].length.toString())),Xa(o,s)},isExported:!0},Vh={description:Oo("Calculates the sum of the products of corresponding entries in equal-sized ranges."),args:[wh("range1 (number, range<number>)",Oo("The first range whose entries will be multiplied with corresponding entries in the other ranges.")),wh("range2 (number, range<number>, repeating)",Oo("The other range whose entries will be multiplied with corresponding entries in the other ranges."))],compute:function(...e){Ih(Oo("All the ranges must have the same dimensions."),...e);const t=e.map(fr);let o=0;for(let e=0;e<t[0].length;e++)for(let s=0;s<t[0][e].length;s++){if(!t.every((t=>"number"==typeof t[e][s].value)))continue;let i=1;for(const o of t)i*=Li(o[e][s],this.locale);o+=i}return o},isExported:!0};function Hh(e,t,o){Ih("The arguments array_x and array_y must have the same dimensions.",e,t);const s=fr(e),i=fr(t);let r=!1,n=0;for(const e in s)for(const t in s[e]){const a=s[e][t].value,l=i[e][t].value;"number"==typeof a&&"number"==typeof l&&(r=!0,n+=o(a,l))}return r?n:new Ri(Oo("The arguments array_x and array_y must contain at least one pair of numbers."))}const Uh={description:Oo("Calculates the sum of the difference of the squares of the values in two array."),args:[wh("array_x (number, range<number>)",Oo("The array or range of values whose squares will be reduced by the squares of corresponding entries in array_y and added together.")),wh("array_y (number, range<number>)",Oo("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 Hh(e,t,((e,t)=>e**2-t**2))},isExported:!0},Bh={description:Oo("Calculates the sum of the sum of the squares of the values in two array."),args:[wh("array_x (number, range<number>)",Oo("The array or range of values whose squares will be added to the squares of corresponding entries in array_y and added together.")),wh("array_y (number, range<number>)",Oo("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 Hh(e,t,((e,t)=>e**2+t**2))},isExported:!0},zh={description:Oo("Calculates the sum of squares of the differences of values in two array."),args:[wh("array_x (number, range<number>)",Oo("The array or range of values that will be reduced by corresponding entries in array_y, squared, and added together.")),wh("array_y (number, range<number>)",Oo("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 Hh(e,t,((e,t)=>(e-t)**2))},isExported:!0},$h=!1,Wh=[wh("array (any, range<any>)",Oo("The array which will be transformed.")),wh("ignore (number, default=0)",Oo("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.")),wh("scan_by_column (number, default=false)",Oo("Whether the array should be scanned by column. True scans the array by column and false (default) scans the array by row."))];function Gh(e){const t=Math.trunc(e);if(0===t)return()=>!0;if(1===t)return e=>null!==e.value;if(2===t)return e=>!Ni(e.value);if(3===t)return e=>null!==e.value&&!Ni(e.value);throw new Ri(Oo("Argument ignore must be between 0 and 3"))}const qh={description:Oo("Transforms a range of cells into a single column."),args:Wh,compute:function(e,t={value:0},o={value:$h}){const s=fr(e),i=Li(t.value,this.locale),r=(ji(o.value)?s:nr(s)).flat().filter(Gh(i));return 0===r.length?new _i(Oo("No results for the given arguments of TOCOL.")):[r]},isExported:!0},Zh={description:Oo("Transforms a range of cells into a single row."),args:Wh,compute:function(e,t={value:0},o={value:$h}){const s=fr(e),i=Li(t.value,this.locale),r=(ji(o.value)?s:nr(s)).flat().filter(Gh(i)).map((e=>[e]));return 0===r.length||0===r[0].length?new _i(Oo("No results for the given arguments of TOROW.")):r},isExported:!0},jh={description:Oo("Transposes the rows and columns of a range."),args:[wh("range (any, range<any>)",Oo("The range to be transposed."))],compute:function(e){const t=fr(e);return ir(t[0].length,t.length,((e,o)=>t[o][e]))},isExported:!0},Yh={description:Oo("Appends ranges vertically and in sequence to return a larger array."),args:[wh("range1 (any, range<any>)",Oo("The first range to be appended.")),wh("range2 (any, range<any>, repeating)",Oo("Additional ranges to add to range1."))],compute:function(...e){const t=Math.max(...e.map((e=>fr(e).length))),o=e.reduce(((e,t)=>e+fr(t)[0].length),0),s=Array(t).fill([]).map((()=>Array(o).fill({value:0})));let i=0;for(const t of e){const e=fr(t);for(let t=0;t<e.length;t++)for(let o=0;o<e[t].length;o++)s[t][i+o]=e[t][o];i+=e[0].length}return s},isExported:!0},Xh={description:Oo("Wraps the provided row or column of cells by columns after a specified number of elements to form a new array."),args:[wh("range (any, range<any>)",Oo("The range to wrap.")),wh("wrap_count (number)",Oo("The maximum number of cells for each column, rounded down to the nearest whole number.")),wh("pad_with (any, default=0)",Oo("The value with which to fill the extra cells in the range."))],compute:function(e,t,o={value:0}){const s=fr(e),i=Bi(t?.value,this.locale);xh(Oo("Argument range must be a single row or column."),s);const r=s.flat();return ir(Math.ceil(r.length/i),i,((e,t)=>{const s=e*i+t;return s<r.length?r[s]:o}))},isExported:!0},Kh={description:Oo("Wraps the provided row or column of cells by rows after a specified number of elements to form a new array."),args:[wh("range (any, range<any>)",Oo("The range to wrap.")),wh("wrap_count (number)",Oo("The maximum number of cells for each row, rounded down to the nearest whole number.")),wh("pad_with (any, default=0)",Oo("The value with which to fill the extra cells in the range."))],compute:function(e,t,o={value:0}){const s=fr(e),i=Bi(t?.value,this.locale);xh(Oo("Argument range must be a single row or column."),s);const r=s.flat(),n=Math.ceil(r.length/i);return ir(i,n,((e,t)=>{const s=t*i+e;return s<r.length?r[s]:o}))},isExported:!0};var Jh=Object.freeze({__proto__:null,ARRAY_CONSTRAIN:Ah,CHOOSECOLS:_h,CHOOSEROWS:Dh,EXPAND:Oh,FLATTEN:Fh,FREQUENCY:Mh,HSTACK:Ph,MDETERM:Nh,MINVERSE:kh,MMULT:Lh,SUMPRODUCT:Vh,SUMX2MY2:Uh,SUMX2PY2:Bh,SUMXMY2:zh,TOCOL:qh,TOROW:Zh,TRANSPOSE:jh,VSTACK:Yh,WRAPCOLS:Xh,WRAPROWS:Kh});const Qh={description:Oo("Apply a large number format"),args:[wh("value (number)",Oo("The number.")),wh("unit (string, optional)",Oo("The formatting unit. Use 'k', 'm', or 'b' to force the unit"))],compute:function(e,t){return{value:Li(e,this.locale),format:vn(e,t,this.locale)}}};var ed=Object.freeze({__proto__:null,FORMAT_LARGE_NUMBER:Qh});const td=/^-?[a-z0-9]+$/i,od={description:Oo("Absolute value of a number."),args:[wh("value (number)",Oo("The number of which to return the absolute value."))],compute:function(e){return Math.abs(Li(e,this.locale))},isExported:!0},sd={description:Oo("Inverse cosine of a value, in radians."),args:[wh("value (number)",Oo("The value for which to calculate the inverse cosine. Must be between -1 and 1, inclusive."))],compute:function(e){const t=Li(e,this.locale);return Mi((()=>Math.abs(t)<=1),Oo("The value (%s) must be between -1 and 1 inclusive.",t.toString())),Math.acos(t)},isExported:!0},id={description:Oo("Inverse hyperbolic cosine of a number."),args:[wh("value (number)",Oo("The value for which to calculate the inverse hyperbolic cosine. Must be greater than or equal to 1."))],compute:function(e){const t=Li(e,this.locale);return Mi((()=>t>=1),Oo("The value (%s) must be greater than or equal to 1.",t.toString())),Math.acosh(t)},isExported:!0},rd={description:Oo("Inverse cotangent of a value."),args:[wh("value (number)",Oo("The value for which to calculate the inverse cotangent."))],compute:function(e){const t=Li(e,this.locale);return(Math.sign(t)||1)*Math.PI/2-Math.atan(t)},isExported:!0},nd={description:Oo("Inverse hyperbolic cotangent of a value."),args:[wh("value (number)",Oo("The value for which to calculate the inverse hyperbolic cotangent. Must not be between -1 and 1, inclusive."))],compute:function(e){const t=Li(e,this.locale);return Mi((()=>Math.abs(t)>1),Oo("The value (%s) cannot be between -1 and 1 inclusive.",t.toString())),Math.log((t+1)/(t-1))/2},isExported:!0},ad={description:Oo("Inverse sine of a value, in radians."),args:[wh("value (number)",Oo("The value for which to calculate the inverse sine. Must be between -1 and 1, inclusive."))],compute:function(e){const t=Li(e,this.locale);return Mi((()=>Math.abs(t)<=1),Oo("The value (%s) must be between -1 and 1 inclusive.",t.toString())),Math.asin(t)},isExported:!0},ld={description:Oo("Inverse hyperbolic sine of a number."),args:[wh("value (number)",Oo("The value for which to calculate the inverse hyperbolic sine."))],compute:function(e){return Math.asinh(Li(e,this.locale))},isExported:!0},cd={description:Oo("Inverse tangent of a value, in radians."),args:[wh("value (number)",Oo("The value for which to calculate the inverse tangent."))],compute:function(e){return Math.atan(Li(e,this.locale))},isExported:!0},hd={description:Oo("Angle from the X axis to a point (x,y), in radians."),args:[wh("x (number)",Oo("The x coordinate of the endpoint of the line segment for which to calculate the angle from the x-axis.")),wh("y (number)",Oo("The y coordinate of the endpoint of the line segment for which to calculate the angle from the x-axis."))],compute:function(e,t){const o=Li(e,this.locale),s=Li(t,this.locale);return Mi((()=>0!==o||0!==s),Oo("Function [[FUNCTION_NAME]] caused a divide by zero error."),xi.DivisionByZero),Math.atan2(s,o)},isExported:!0},dd={description:Oo("Inverse hyperbolic tangent of a number."),args:[wh("value (number)",Oo("The value for which to calculate the inverse hyperbolic tangent. Must be between -1 and 1, exclusive."))],compute:function(e){const t=Li(e,this.locale);return Mi((()=>Math.abs(t)<1),Oo("The value (%s) must be between -1 and 1 exclusive.",t.toString())),Math.atanh(t)},isExported:!0},ud={description:Oo("Rounds number up to nearest multiple of factor."),args:[wh("value (number)",Oo("The value to round up to the nearest integer multiple of factor.")),wh("factor (number, default=1)",Oo("The number to whose multiples value will be rounded."))],compute:function(e,t={value:1}){const o=Li(e,this.locale),s=Li(t,this.locale);return Mi((()=>s>=0||o<=0),Oo("The factor (%s) must be positive when the value (%s) is positive.",s.toString(),o.toString())),{value:s?Math.ceil(o/s)*s:0,format:e?.format}},isExported:!0};function gd(e,t,o=0){return 0===t?0:(t=Math.abs(t),e>=0?Math.ceil(e/t)*t:0===o?-Math.floor(Math.abs(e)/t)*t:-Math.ceil(Math.abs(e)/t)*t)}const pd={description:Oo("Rounds number up to nearest multiple of factor."),args:[wh("number (number)",Oo("The value to round up to the nearest integer multiple of significance.")),wh("significance (number, default=1)",Oo("The number to whose multiples number will be rounded. The sign of significance will be ignored.")),wh("mode (number, default=0)",Oo("If number is negative, specifies the rounding direction. If 0 or blank, it is rounded towards zero. Otherwise, it is rounded away from zero."))],compute:function(e,t={value:1},o={value:0}){const s=Li(t,this.locale);return{value:gd(Li(e,this.locale),s,Li(o,this.locale)),format:e?.format}},isExported:!0},md={description:Oo("Rounds number up to nearest multiple of factor."),args:[wh("number (number)",Oo("The value to round up to the nearest integer multiple of significance.")),wh("significance (number, default=1)",Oo("The number to whose multiples number will be rounded."))],compute:function(e,t={value:1}){const o=Li(t,this.locale);return{value:gd(Li(e,this.locale),o),format:e?.format}},isExported:!0},fd={description:Oo("Cosine of an angle provided in radians."),args:[wh("angle (number)",Oo("The angle to find the cosine of, in radians."))],compute:function(e){return Math.cos(Li(e,this.locale))},isExported:!0},vd={description:Oo("Hyperbolic cosine of any real number."),args:[wh("value (number)",Oo("Any real value to calculate the hyperbolic cosine of."))],compute:function(e){return Math.cosh(Li(e,this.locale))},isExported:!0},bd={description:Oo("Cotangent of an angle provided in radians."),args:[wh("angle (number)",Oo("The angle to find the cotangent of, in radians."))],compute:function(e){const t=Li(e,this.locale);return Wi(t),1/Math.tan(t)},isExported:!0},Sd={description:Oo("Hyperbolic cotangent of any real number."),args:[wh("value (number)",Oo("Any real value to calculate the hyperbolic cotangent of."))],compute:function(e){const t=Li(e,this.locale);return Wi(t),1/Math.tanh(t)},isExported:!0},yd={description:Oo("Number of empty values."),args:[wh("value1 (any, range)",Oo("The first value or range in which to count the number of blanks.")),wh("value2 (any, range, repeating)",Oo("Additional values or ranges in which to count the number of blanks."))],compute:function(...e){return tr(e,((e,t)=>void 0===t||null===t.value||""===t.value?e+1:e),0)},isExported:!0},Cd={description:Oo("A conditional count across a range."),args:[wh("range (range)",Oo("The range that is tested against criterion.")),wh("criterion (string)",Oo("The pattern or test to apply to range."))],compute:function(...e){let t=0;return dr(e,((e,o)=>{t+=1}),this.locale),t},isExported:!0},wd={description:Oo("Count values depending on multiple criteria."),args:[wh("criteria_range1 (range)",Oo("The range to check against criterion1.")),wh("criterion1 (string)",Oo("The pattern or test to apply to criteria_range1.")),wh("criteria_range2 (any, range, repeating)",Oo("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.")),wh("criterion2 (string, repeating)",Oo("Additional criteria to check."))],compute:function(...e){let t=0;return dr(e,((e,o)=>{t+=1}),this.locale),t},isExported:!0},Ed={description:Oo("Counts number of unique values in a range."),args:[wh("value1 (any, range)",Oo("The first value or range to consider for uniqueness.")),wh("value2 (any, range, repeating)",Oo("Additional values or ranges to consider for uniqueness."))],compute:function(...e){return qa(e)}},xd={description:Oo("Counts number of unique values in a range, filtered by a set of criteria."),args:[wh("range (range)",Oo("The range of cells from which the number of unique values will be counted.")),wh("criteria_range1 (range)",Oo("The range of cells over which to evaluate criterion1.")),wh("criterion1 (string)",Oo("The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.")),wh("criteria_range2 (any, range, repeating)",Oo("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.")),wh("criterion2 (string, repeating)",Oo("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){let o=new Set;return dr(t,((t,s)=>{const i=e[t]?.[s];br(i)&&o.add(i.value)}),this.locale),o.size}},Id={description:Oo("Cosecant of an angle provided in radians."),args:[wh("angle (number)",Oo("The angle to find the cosecant of, in radians."))],compute:function(e){const t=Li(e,this.locale);return Wi(t),1/Math.sin(t)},isExported:!0},Rd={description:Oo("Hyperbolic cosecant of any real number."),args:[wh("value (number)",Oo("Any real value to calculate the hyperbolic cosecant of."))],compute:function(e){const t=Li(e,this.locale);return Wi(t),1/Math.sinh(t)},isExported:!0},Td={description:Oo("Converts from another base to decimal."),args:[wh("value (string)",Oo("The number to convert.")),wh("base (number)",Oo("The base to convert the value from."))],compute:function(e,t){let o=Li(t,this.locale);o=Math.floor(o),Mi((()=>2<=o&&o<=36),Oo("The base (%s) must be between 2 and 36 inclusive.",o.toString()));const s=Gi(e);if(""===s)return 0;Mi((()=>td.test(s)),Oo("The value (%s) must be a valid base %s representation.",s,o.toString()));const i=parseInt(s,o);return Mi((()=>!isNaN(i)),Oo("The value (%s) must be a valid base %s representation.",s,o.toString())),i},isExported:!0},Ad={description:Oo("Converts an angle value in radians to degrees."),args:[wh("angle (number)",Oo("The angle to convert from radians to degrees."))],compute:function(e){return 180*Li(e,this.locale)/Math.PI},isExported:!0},_d={description:Oo("Euler's number, e (~2.718) raised to a power."),args:[wh("value (number)",Oo("The exponent to raise e."))],compute:function(e){return Math.exp(Li(e,this.locale))},isExported:!0},Dd={description:Oo("Rounds number down to nearest multiple of factor."),args:[wh("value (number)",Oo("The value to round down to the nearest integer multiple of factor.")),wh("factor (number, default=1)",Oo("The number to whose multiples value will be rounded."))],compute:function(e,t={value:1}){const o=Li(e,this.locale),s=Li(t,this.locale);return Mi((()=>s>=0||o<=0),Oo("The factor (%s) must be positive when the value (%s) is positive.",s.toString(),o.toString())),{value:s?Math.floor(o/s)*s:0,format:e?.format}},isExported:!0};function Od(e,t,o=0){return 0===t?0:(t=Math.abs(t),e>=0?Math.floor(e/t)*t:0===o?-Math.ceil(Math.abs(e)/t)*t:-Math.floor(Math.abs(e)/t)*t)}const Fd={description:Oo("Rounds number down to nearest multiple of factor."),args:[wh("number (number)",Oo("The value to round down to the nearest integer multiple of significance.")),wh("significance (number, default=1)",Oo("The number to whose multiples number will be rounded. The sign of significance will be ignored.")),wh("mode (number, default=0)",Oo("If number is negative, specifies the rounding direction. If 0 or blank, it is rounded away from zero. Otherwise, it is rounded towards zero."))],compute:function(e,t={value:1},o={value:0}){const s=Li(t,this.locale);return{value:Od(Li(e,this.locale),s,Li(o,this.locale)),format:e?.format}},isExported:!0},Md={description:Oo("Rounds number down to nearest multiple of factor."),args:[wh("number (number)",Oo("The value to round down to the nearest integer multiple of significance.")),wh("significance (number, default=1)",Oo("The number to whose multiples number will be rounded."))],compute:function(e,t={value:1}){const o=Li(t,this.locale);return{value:Od(Li(e,this.locale),o),format:e?.format}},isExported:!0},Pd={description:Oo("Whether the provided value is even."),args:[wh("value (number)",Oo("The value to be verified as even."))],compute:function(e){const t=Ui(e,this.locale);return!(1&Math.floor(Math.abs(t)))},isExported:!0},Nd={description:Oo("Rounds number up to nearest multiple of factor."),args:[wh("number (number)",Oo("The value to round up to the nearest integer multiple of significance.")),wh("significance (number, default=1)",Oo("The number to whose multiples number will be rounded."))],compute:function(e,t={value:1}){return{value:gd(Li(e,this.locale),Li(t,this.locale)),format:e?.format}},isExported:!0},kd={description:Oo("Whether the provided value is even."),args:[wh("value (number)",Oo("The value to be verified as even."))],compute:function(e){const t=Ui(e,this.locale);return!!(1&Math.floor(Math.abs(t)))},isExported:!0},Ld={description:Oo("The logarithm of a number, base e (euler's number)."),args:[wh("value (number)",Oo("The value for which to calculate the logarithm, base e."))],compute:function(e){const t=Li(e,this.locale);return Mi((()=>t>0),Oo("The value (%s) must be strictly positive.",t.toString())),Math.log(t)},isExported:!0};function Vd(e,t){Mi((()=>0!==t),Oo("The divisor must be different from 0."),xi.DivisionByZero);const o=e%t;return o>0&&t<0||o<0&&t>0?o+t:o}const Hd={description:Oo("Modulo (remainder) operator."),args:[wh("dividend (number)",Oo("The number to be divided to find the remainder.")),wh("divisor (number)",Oo("The number to divide by."))],compute:function(e,t){const o=Li(t,this.locale);return{value:Vd(Li(e,this.locale),o),format:e?.format}},isExported:!0},Ud={description:Oo("Returns a n x n unit matrix, where n is the input dimension."),args:[wh("dimension (number)",Oo("An integer specifying the dimension size of the unit matrix. It must be positive."))],compute:function(e){const t=Bi(e,this.locale);return Rh(Oo("The argument dimension must be positive"),t),Za(t)},isExported:!0},Bd={description:Oo("Rounds a number up to the nearest odd integer."),args:[wh("value (number)",Oo("The value to round to the next greatest odd number."))],compute:function(e){const t=Li(e,this.locale);let o=Math.ceil(Math.abs(t));return o=1&o?o:o+1,{value:t<0?-o:o,format:e?.format}},isExported:!0},zd={description:Oo("The number pi."),args:[],compute:function(){return Math.PI},isExported:!0},$d={description:Oo("A number raised to a power."),args:[wh("base (number)",Oo("The number to raise to the exponent power.")),wh("exponent (number)",Oo("The exponent to raise base to."))],compute:function(e,t){const o=Li(e,this.locale),s=Li(t,this.locale);return Mi((()=>o>=0||Number.isInteger(s)),Oo("The exponent (%s) must be an integer when the base is negative.",s.toString())),{value:Math.pow(o,s),format:e?.format}},isExported:!0},Wd={description:Oo("Result of multiplying a series of numbers together."),args:[wh("factor1 (number, range<number>)",Oo("The first number or range to calculate for the product.")),wh("factor2 (number, range<number>, repeating)",Oo("More numbers or ranges to calculate for the product."))],compute:function(...e){let t=0,o=1;for(let s of e)if(yi(s))for(let e of s)for(let s of e){const e=s.value;if("number"==typeof e&&(o*=e,t+=1),Ni(e))return s}else void 0!==s&&null!==s.value&&(o*=Ui(s,this.locale),t+=1);return{value:0===t?0:o,format:Pi(e[0])}},isExported:!0},Gd={description:Oo("A random number between 0 inclusive and 1 exclusive."),args:[],compute:function(){return Math.random()},isExported:!0},qd={description:Oo("Returns a grid of random numbers between 0 inclusive and 1 exclusive."),args:[wh("rows (number, default=1)",Oo("The number of rows to be returned.")),wh("columns (number, default=1)",Oo("The number of columns to be returned.")),wh("min (number, default=0)",Oo("The minimum number you would like returned.")),wh("max (number, default=1)",Oo("The maximum number you would like returned.")),wh("whole_number (number, default=FALSE)",Oo("Return a whole number or a decimal value."))],compute:function(e={value:1},t={value:1},o={value:0},s={value:1},i={value:!1}){const r=Bi(t,this.locale),n=Bi(e,this.locale),a=Li(o,this.locale),l=Li(s,this.locale),c=ji(i);Rh(Oo("The number of columns (%s) must be positive.",r.toString()),r),Rh(Oo("The number of rows (%s) must be positive.",n.toString()),n),Mi((()=>a<=l),Oo("The maximum (%s) must be greater than or equal to the minimum (%s).",l.toString(),a.toString())),c&&Mi((()=>Number.isInteger(a)&&Number.isInteger(l)),Oo("The maximum (%s) and minimum (%s) must be integers when whole_number is TRUE.",l.toString(),a.toString()));const h=Array(r);for(let e=0;e<r;e++){h[e]=Array(n);for(let t=0;t<n;t++)h[e][t]=c?Math.floor(Math.random()*(l-a+1)+a):a+Math.random()*(l-a)}return h},isExported:!0},Zd={description:Oo("Random integer between two values, inclusive."),args:[wh("low (number)",Oo("The low end of the random range.")),wh("high (number)",Oo("The high end of the random range."))],compute:function(e,t){let o=Li(e,this.locale);Number.isInteger(o)||(o=Math.ceil(o));let s=Li(t,this.locale);return Number.isInteger(s)||(s=Math.floor(s)),Mi((()=>o<=s),Oo("The high (%s) must be greater than or equal to the low (%s).",s.toString(),o.toString())),{value:o+Math.ceil((s-o+1)*Math.random())-1,format:e?.format}},isExported:!0},jd={description:Oo("Rounds a number according to standard rules."),args:[wh("value (number)",Oo("The value to round to places number of places.")),wh("places (number, default=0)",Oo("The number of decimal places to which to round."))],compute:function(e,t={value:0}){const o=Li(e,this.locale);let s=Li(t,this.locale);const i=Math.abs(o);let r;return 0===s?r=Math.round(i):(Number.isInteger(s)||(s=Math.trunc(s)),r=Math.round(i*Math.pow(10,s))/Math.pow(10,s)),{value:o>=0?r:-r,format:e?.format}},isExported:!0},Yd={description:Oo("Rounds down a number."),args:[wh("value (number)",Oo("The value to round to places number of places, always rounding down.")),wh("places (number, default=0)",Oo("The number of decimal places to which to round."))],compute:function(e,t={value:0}){const o=Li(e,this.locale);let s=Li(t,this.locale);const i=Math.abs(o);let r;return 0===s?r=Math.floor(i):(Number.isInteger(s)||(s=Math.trunc(s)),r=Math.floor(i*Math.pow(10,s))/Math.pow(10,s)),{value:o>=0?r:-r,format:e?.format}},isExported:!0},Xd={description:Oo("Rounds up a number."),args:[wh("value (number)",Oo("The value to round to places number of places, always rounding up.")),wh("places (number, default=0)",Oo("The number of decimal places to which to round."))],compute:function(e,t={value:0}){const o=Li(e,this.locale);let s=Li(t,this.locale);const i=Math.abs(o);let r;return 0===s?r=Math.ceil(i):(Number.isInteger(s)||(s=Math.trunc(s)),r=Math.ceil(i*Math.pow(10,s))/Math.pow(10,s)),{value:o>=0?r:-r,format:e?.format}},isExported:!0},Kd={description:Oo("Secant of an angle provided in radians."),args:[wh("angle (number)",Oo("The angle to find the secant of, in radians."))],compute:function(e){return 1/Math.cos(Li(e,this.locale))},isExported:!0},Jd={description:Oo("Hyperbolic secant of any real number."),args:[wh("value (number)",Oo("Any real value to calculate the hyperbolic secant of."))],compute:function(e){return 1/Math.cosh(Li(e,this.locale))},isExported:!0},Qd={description:Oo("Returns a sequence of numbers."),args:[wh("rows (number)",Oo("The number of rows to return")),wh("columns (number, optional, default=1)",Oo("The number of columns to return")),wh("start (number, optional, default=1)",Oo("The first number in the sequence")),wh("step (number, optional, default=1)",Oo("The amount to increment each value in the sequence"))],compute:function(e,t={value:1},o={value:1},s={value:1}){const i=Li(o,this.locale),r=Li(s,this.locale),n=Bi(e,this.locale),a=Bi(t,this.locale);return Rh(Oo("The number of columns (%s) must be positive.",a),a),Rh(Oo("The number of rows (%s) must be positive.",n),n),ir(a,n,((e,t)=>({value:i+t*a*r+e*r})))},isExported:!0},eu={description:Oo("Sine of an angle provided in radians."),args:[wh("angle (number)",Oo("The angle to find the sine of, in radians."))],compute:function(e){return Math.sin(Li(e,this.locale))},isExported:!0},tu={description:Oo("Hyperbolic sine of any real number."),args:[wh("value (number)",Oo("Any real value to calculate the hyperbolic sine of."))],compute:function(e){return Math.sinh(Li(e,this.locale))},isExported:!0},ou={description:Oo("Positive square root of a positive number."),args:[wh("value (number)",Oo("The number for which to calculate the positive square root."))],compute:function(e){const t=Li(e,this.locale);return Mi((()=>t>=0),Oo("The value (%s) must be positive or null.",t.toString())),{value:Math.sqrt(t),format:e?.format}},isExported:!0},su={description:Oo("Sum of a series of numbers and/or cells."),args:[wh("value1 (number, range<number>)",Oo("The first number or range to add together.")),wh("value2 (number, range<number>, repeating)",Oo("Additional numbers or ranges to add to value1."))],compute:function(...e){const t=e[0];return{value:Ga(e,this.locale),format:Pi(t)}},isExported:!0},iu={description:Oo("A conditional sum across a range."),args:[wh("criteria_range (range)",Oo("The range which is tested against criterion.")),wh("criterion (string)",Oo("The pattern or test to apply to range.")),wh("sum_range (range, default=criteria_range)",Oo("The range to be summed, if different from range."))],compute:function(e,t,o){void 0===o&&(o=e);let s=0;return dr([e,t],((e,t)=>{const i=o[e]?.[t]?.value;"number"==typeof i&&(s+=i)}),this.locale),s},isExported:!0},ru={description:Oo("Sums a range depending on multiple criteria."),args:[wh("sum_range (range)",Oo("The range to sum.")),wh("criteria_range1 (range)",Oo("The range to check against criterion1.")),wh("criterion1 (string)",Oo("The pattern or test to apply to criteria_range1.")),wh("criteria_range2 (any, range, repeating)",Oo("Additional ranges to check.")),wh("criterion2 (string, repeating)",Oo("Additional criteria to check."))],compute:function(e,...t){let o=0;return dr(t,((t,s)=>{const i=e[t]?.[s]?.value;"number"==typeof i&&(o+=i)}),this.locale),o},isExported:!0},nu={description:Oo("Tangent of an angle provided in radians."),args:[wh("angle (number)",Oo("The angle to find the tangent of, in radians."))],compute:function(e){return Math.tan(Li(e,this.locale))},isExported:!0},au={description:Oo("Hyperbolic tangent of any real number."),args:[wh("value (number)",Oo("Any real value to calculate the hyperbolic tangent of."))],compute:function(e){return Math.tanh(Li(e,this.locale))},isExported:!0};function lu(e,t){return 0===t?Math.trunc(e):(Number.isInteger(t)||(t=Math.trunc(t)),Math.trunc(e*Math.pow(10,t))/Math.pow(10,t))}const cu={description:Oo("Truncates a number."),args:[wh("value (number)",Oo("The value to be truncated.")),wh("places (number, default=0)",Oo("The number of significant digits to the right of the decimal point to retain."))],compute:function(e,t={value:0}){return{value:lu(Li(e,this.locale),Li(t,this.locale)),format:e?.format}},isExported:!0},hu={description:Oo("Rounds a number down to the nearest integer that is less than or equal to it."),args:[wh("value (number)",Oo("The number to round down to the nearest integer."))],compute:function(e){return Math.floor(Li(e,this.locale))},isExported:!0};var du=Object.freeze({__proto__:null,ABS:od,ACOS:sd,ACOSH:id,ACOT:rd,ACOTH:nd,ASIN:ad,ASINH:ld,ATAN:cd,ATAN2:hd,ATANH:dd,CEILING:ud,CEILING_MATH:pd,CEILING_PRECISE:md,COS:fd,COSH:vd,COT:bd,COTH:Sd,COUNTBLANK:yd,COUNTIF:Cd,COUNTIFS:wd,COUNTUNIQUE:Ed,COUNTUNIQUEIFS:xd,CSC:Id,CSCH:Rd,DECIMAL:Td,DEGREES:Ad,EXP:_d,FLOOR:Dd,FLOOR_MATH:Fd,FLOOR_PRECISE:Md,INT:hu,ISEVEN:Pd,ISODD:kd,ISO_CEILING:Nd,LN:Ld,MOD:Hd,MUNIT:Ud,ODD:Bd,PI:zd,POWER:$d,PRODUCT:Wd,RAND:Gd,RANDARRAY:qd,RANDBETWEEN:Zd,ROUND:jd,ROUNDDOWN:Yd,ROUNDUP:Xd,SEC:Kd,SECH:Jd,SEQUENCE:Qd,SIN:eu,SINH:tu,SQRT:ou,SUM:su,SUMIF:iu,SUMIFS:ru,TAN:nu,TANH:au,TRUNC:cu});function uu(e,t){const o=[],s=[];let i=0,r=0;Ji([e],(e=>{o.push(e),i+=1})),Ji([t],(e=>{s.push(e),r+=1})),Mi((()=>i===r),Oo("[[FUNCTION_NAME]] has mismatched argument count %s vs %s.",i,r));const n=[],a=[];for(let e=0;e<i;e++){const t=o[e]?.value,i=s[e]?.value;"number"==typeof t&&"number"==typeof i&&(a.push(t),n.push(i))}return{flatDataX:n,flatDataY:a}}function gu(e,t,o){const{flatDataX:s,flatDataY:i}=uu(e,t),r=i.length;Mi((()=>0!==r&&(!o||1!==r)),Oo("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error."),xi.DivisionByZero);let n=0,a=0;for(let e=0;e<r;e++)n+=i[e],a+=s[e];const l=n/r,c=a/r;let h=0;for(let e=0;e<r;e++)h+=(i[e]-l)*(s[e]-c);return h/(r-(o?1:0))}function pu(e,t,o,s){let i=0;const r=o?sr:or,n=r(e,((e,t)=>(i+=1,e+t)),0,s);Mi((()=>0!==i&&(!t||1!==i)),Oo("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error."),xi.DivisionByZero);const a=n/i;return r(e,((e,t)=>e+Math.pow(t-a,2)),0,s)/(i-(t?1:0))}function mu(e,t,o,s){const i=Li(t,s);Mi((()=>o?0<=i&&i<=1:0<i&&i<1),Oo("Function [[FUNCTION_NAME]] parameter 2 value is out of range."));let r,n=[],a=0;return Ji(e,(e=>{const t=e?.value;"number"==typeof t&&(r=ur(n,e,"nextSmaller","asc",n.length,((e,t)=>e[t])),n.splice(r+1,0,t),a++)})),Mi((()=>0!==a),Oo("[[FUNCTION_NAME]] has no valid input data.")),o||Mi((()=>1/(a+1)<=i&&i<=a/(a+1)),Oo("Function [[FUNCTION_NAME]] parameter 2 value is out of range.")),si(n,i,o)}const fu={description:Oo("Average magnitude of deviations from mean."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the sample.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the sample."))],compute:function(...e){let t=0;const o=or(e,((e,o)=>(t+=1,e+o)),0,this.locale);Wi(t);const s=o/t;return or(e,((e,t)=>e+Math.abs(s-t)),0,this.locale)/t},isExported:!0},vu={description:Oo("Numerical average value in a dataset, ignoring text."),args:[wh("value1 (number, range<number>)",Oo("The first value or range to consider when calculating the average value.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to consider when calculating the average value."))],compute:function(...e){return{value:Qa(e,this.locale),format:Pi(e[0])}},isExported:!0},bu=Oo("[[FUNCTION_NAME]] has mismatched range sizes."),Su=Oo("[[FUNCTION_NAME]] expects the weight to be positive or equal to 0."),yu={description:Oo("Weighted average."),args:[wh("values (number, range<number>)",Oo("Values to average.")),wh("weights (number, range<number>)",Oo("Weights for each corresponding value.")),wh("additional_values (number, range<number>, repeating)",Oo("Additional values to average.")),wh("additional_weights (number, range<number>, repeating)",Oo("Additional weights."))],compute:function(...e){let t=0,o=0;for(let s=0;s<e.length-1;s+=2){const i=e[s],r=e[s+1];if(Ih(bu,i,r),yi(i))for(let e=0;e<i.length;e++)for(let s=0;s<i[0].length;s++){const n=i[e][s].value,a=yi(r)?r?.[e][s].value:Li(r,this.locale),l="number"==typeof n,c="number"==typeof a;l&&c?(Mi((()=>a>=0),Su),t+=n*a,o+=a):Mi((()=>l===c),Oo("[[FUNCTION_NAME]] expects number values."))}else{const e=Li(i,this.locale),s=yi(r)?r?.[0][0].value:Li(r,this.locale);"number"==typeof s&&(Mi((()=>s>=0),Su),t+=e*s,o+=s)}}return Wi(o),{value:t/o,format:Pi(e[0])}}},Cu={description:Oo("Numerical average value in a dataset."),args:[wh("value1 (number, range<number>)",Oo("The first value or range to consider when calculating the average value.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to consider when calculating the average value."))],compute:function(...e){let t=0;const o=sr(e,((e,o)=>(t+=1,e+o)),0,this.locale);return Wi(t),{value:o/t,format:Pi(e[0])}},isExported:!0},wu={description:Oo("Average of values depending on criteria."),args:[wh("criteria_range (number, range<number>)",Oo("The range to check against criterion.")),wh("criterion (string)",Oo("The pattern or test to apply to criteria_range.")),wh("average_range (number, range<number>, default=criteria_range)",Oo("The range to average. If not included, criteria_range is used for the average instead."))],compute:function(e,t,o){const s=fr(void 0===o?e:o);let i=0,r=0;return dr([e,t],((e,t)=>{const o=s[e]?.[t]?.value;"number"==typeof o&&(i+=1,r+=o)}),this.locale),Wi(i),r/i},isExported:!0},Eu={description:Oo("Average of values depending on multiple criteria."),args:[wh("average_range (range)",Oo("The range to average.")),wh("criteria_range1 (range)",Oo("The range to check against criterion1.")),wh("criterion1 (string)",Oo("The pattern or test to apply to criteria_range1.")),wh("criteria_range2 (any, range, repeating)",Oo("Additional criteria_range and criterion to check.")),wh("criterion2 (string, repeating)",Oo("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){const o=fr(e);let s=0,i=0;return dr(t,((e,t)=>{const r=o[e]?.[t]?.value;"number"==typeof r&&(s+=1,i+=r)}),this.locale),Wi(s),i/s},isExported:!0},xu={description:Oo("The number of numeric values in dataset."),args:[wh("value1 (number, any, range<number>)",Oo("The first value or range to consider when counting.")),wh("value2 (number, any, range<number>, repeating)",Oo("Additional values or ranges to consider when counting."))],compute:function(...e){return el(e,this.locale)},isExported:!0},Iu={description:Oo("The number of values in a dataset."),args:[wh("value1 (any, range)",Oo("The first value or range to consider when counting.")),wh("value2 (any, range, repeating)",Oo("Additional values or ranges to consider when counting."))],compute:function(...e){return tl(e)},isExported:!0},Ru={description:Oo("The covariance of a dataset."),args:[wh("data_y (any, range)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (any, range)",Oo("The range representing the array or matrix of independent data."))],compute:function(e,t){return gu(e,t,!1)},isExported:!0},Tu={description:Oo("The covariance of a dataset."),args:[wh("data_y (any, range)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (any, range)",Oo("The range representing the array or matrix of independent data."))],compute:function(e,t){return gu(e,t,!1)},isExported:!0},Au={description:Oo("The sample covariance of a dataset."),args:[wh("data_y (any, range)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (any, range)",Oo("The range representing the array or matrix of independent data."))],compute:function(e,t){return gu(e,t,!0)},isExported:!0},_u={description:Oo("Calculates the expected y-value for a specified x based on a linear regression of a dataset."),args:[wh("x (number, range<number>)",Oo("The value(s) on the x-axis to forecast.")),wh("data_y (range<number>)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (range<number>)",Oo("The range representing the array or matrix of independent data."))],compute:function(e,t,o){const{flatDataX:s,flatDataY:i}=uu(t,o);return dl([i],[s],rr(fr(e),(e=>Li(e,this.locale))),!0)},isExported:!0},Du={description:Oo("Fits points to exponential growth trend."),args:[wh("known_data_y (range<number>)",Oo("The array or range containing dependent (y) values that are already known, used to curve fit an ideal exponential growth curve.")),wh("known_data_x (range<number>, default={1;2;3;...})",Oo("The values of the independent variable(s) corresponding with known_data_y.")),wh("new_data_x (any, range, default=known_data_x)",Oo("The data points to return the y values for on the ideal curve fit.")),wh("b (boolean, default=TRUE)",Oo("Given a general exponential form of y = b*m^x for a curve fit, calculates b if TRUE or forces b to be 1 and only calculates the m values if FALSE."))],compute:function(e,t=[[]],o=[[]],s={value:!0}){return cl(dl(hl(Hi(e,"the first argument (known_data_y)")),Hi(t,"the second argument (known_data_x)"),Hi(o,"the third argument (new_data_y)"),ji(s)))}},Ou={description:Oo("Compute the intercept of the linear regression."),args:[wh("data_y (range<number>)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (range<number>)",Oo("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=uu(e,t),[[],[i]]=rl([o],[s]);return i},isExported:!0},Fu={description:Oo("Nth largest element from a data set."),args:[wh("data (any, range)",Oo("Array or range containing the dataset to consider.")),wh("n (number)",Oo("The rank from largest to smallest of the element to return."))],compute:function(e,t){const o=Math.trunc(Li(t?.value,this.locale));let s,i=[],r=0;Ji([e],(e=>{"number"==typeof e?.value&&(s=ur(i,e,"nextSmaller","asc",i.length,((e,t)=>e[t].value)),i.splice(s+1,0,e),r++,r>o&&(i.shift(),r--))}));const n=i.shift();return Mi((()=>void 0!==n),Oo("[[FUNCTION_NAME]] has no valid input data.")),Mi((()=>r>=o),Oo("Function [[FUNCTION_NAME]] parameter 2 value (%s) is out of range.",o)),n},isExported:!0},Mu={description:Oo("Given partial data about a linear trend, calculates various parameters about the ideal linear trend using the least-squares method."),args:[wh("data_y (range<number>)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (range<number>, default={1;2;3;...})",Oo("The range representing the array or matrix of independent data.")),wh("calculate_b (boolean, default=TRUE)",Oo("A flag specifying wheter to compute the slope or not")),wh("verbose (boolean, default=FALSE)",Oo("A flag specifying whether to return additional regression statistics or only the linear coefficients and the y-intercept"))],compute:function(e,t=[[]],o={value:!0},s={value:!1}){return rl(Hi(t,"the first argument (data_y)"),Hi(e,"the second argument (data_x)"),ji(o),ji(s))},isExported:!0},Pu={description:Oo("Given partial data about an exponential growth curve, calculates various parameters about the best fit ideal exponential growth curve."),args:[wh("data_y (range<number>)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (range<number>, optional, default={1;2;3;...})",Oo("The range representing the array or matrix of independent data.")),wh("calculate_b (boolean, default=TRUE)",Oo("A flag specifying wheter to compute the slope or not")),wh("verbose (boolean, default=FALSE)",Oo("A flag specifying whether to return additional regression statistics or only the linear coefficients and the y-intercept"))],compute:function(e,t=[[]],o={value:!0},s={value:!1}){const i=rl(Hi(t,"the second argument (data_x)"),hl(Hi(e,"the first argument (data_y)")),ji(o),ji(s));for(let e=0;e<i.length;e++)i[e][0]=Math.exp(i[e][0]);return i},isExported:!0},Nu={description:Oo("Compute the Matthews correlation coefficient of a dataset."),args:[wh("data_x (range)",Oo("The range representing the array or matrix of observed data.")),wh("data_y (range)",Oo("The range representing the array or matrix of predicted data."))],compute:function(e,t){const o=e.flat(),s=t.flat();if(Ja(o,s),0===o.length)return new Ri(Oo("[[FUNCTION_NAME]] expects non-empty ranges for both parameters."));const i=o.length;let r=0,n=0,a=0,l=0;for(let e=0;e<i;++e){const t=ji(o[e]);t===ji(s[e])?t?n++:r++:t?l++:a++}return(n*r-a*l)/Math.sqrt((n+a)*(n+l)*(r+a)*(r+l))},isExported:!1},ku={description:Oo("Maximum value in a numeric dataset."),args:[wh("value1 (number, range<number>)",Oo("The first value or range to consider when calculating the maximum value.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to consider when calculating the maximum value."))],compute:function(...e){return ol(e,this.locale)},isExported:!0},Lu={description:Oo("Maximum numeric value in a dataset."),args:[wh("value1 (any, range)",Oo("The first value or range to consider when calculating the maximum value.")),wh("value2 (any, range, repeating)",Oo("Additional values or ranges to consider when calculating the maximum value."))],compute:function(...e){const t=sr(e,((e,t)=>Math.max(t,e)),-1/0,this.locale);return{value:t===-1/0?0:t,format:Pi(e[0])}},isExported:!0},Vu={description:Oo("Returns the maximum value in a range of cells, filtered by a set of criteria."),args:[wh("range (range)",Oo("The range of cells from which the maximum will be determined.")),wh("criteria_range1 (range)",Oo("The range of cells over which to evaluate criterion1.")),wh("criterion1 (string)",Oo("The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.")),wh("criteria_range2 (any, range, repeating)",Oo("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.")),wh("criterion2 (string, repeating)",Oo("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){let o=-1/0;return dr(t,((t,s)=>{const i=e[t]?.[s]?.value;"number"==typeof i&&(o=o<i?i:o)}),this.locale),o===-1/0?0:o},isExported:!0},Hu={description:Oo("Median value in a numeric dataset."),args:[wh("value1 (any, range)",Oo("The first value or range to consider when calculating the median value.")),wh("value2 (any, range, repeating)",Oo("Additional values or ranges to consider when calculating the median value."))],compute:function(...e){let t=[];return Qi(e,(e=>{t.push(e)}),this.locale),{value:mu(t,{value:.5},!0,this.locale),format:Pi(t[0])}},isExported:!0},Uu={description:Oo("Minimum value in a numeric dataset."),args:[wh("value1 (number, range<number>)",Oo("The first value or range to consider when calculating the minimum value.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to consider when calculating the minimum value."))],compute:function(...e){return sl(e,this.locale)},isExported:!0},Bu={description:Oo("Minimum numeric value in a dataset."),args:[wh("value1 (number, range<number>)",Oo("The first value or range to consider when calculating the minimum value.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to consider when calculating the minimum value."))],compute:function(...e){const t=sr(e,((e,t)=>Math.min(t,e)),1/0,this.locale);return{value:t===1/0?0:t,format:Pi(e[0])}},isExported:!0},zu={description:Oo("Returns the minimum value in a range of cells, filtered by a set of criteria."),args:[wh("range (range)",Oo("The range of cells from which the minimum will be determined.")),wh("criteria_range1 (range)",Oo("The range of cells over which to evaluate criterion1.")),wh("criterion1 (string)",Oo("The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.")),wh("criteria_range2 (any, range, repeating)",Oo("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.")),wh("criterion2 (string, repeating)",Oo("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){let o=1/0;return dr(t,((t,s)=>{const i=e[t]?.[s]?.value;"number"==typeof i&&(o=o>i?i:o)}),this.locale),o===1/0?0:o},isExported:!0};function $u(e,t){const{flatDataX:o,flatDataY:s}=uu(e,t);if(0===o.length)throw new Ri(Oo("[[FUNCTION_NAME]] expects non-empty ranges for both parameters."));if(o.length<2)throw new Ri(Oo("[[FUNCTION_NAME]] needs at least two values for both parameters."));const i=o.length;let r=0,n=0,a=0,l=0,c=0;for(let e=0;e<i;e++){const t=o[e],i=s[e];r+=t,n+=i,a+=t*i,l+=t*t,c+=i*i}return(i*a-r*n)/Math.sqrt((i*l-r*r)*(i*c-n*n))}const Wu={description:Oo("Compute the Pearson product-moment correlation coefficient of a dataset."),args:[wh("data_y (range<number>)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (range<number>)",Oo("The range representing the array or matrix of independent data."))],compute:function(e,t){return $u(e,t)},isExported:!0},Gu=Wu,qu={description:Oo("Value at a given percentile of a dataset."),args:[wh("data (any, range)",Oo("The array or range containing the dataset to consider.")),wh("percentile (number)",Oo("The percentile whose value within data will be calculated and returned."))],compute:function(e,t){return ju.compute.bind(this)(e,t)},isExported:!0},Zu={description:Oo("Value at a given percentile of a dataset exclusive of 0 and 1."),args:[wh("data (any, range)",Oo("The array or range containing the dataset to consider.")),wh("percentile (number)",Oo("The percentile, exclusive of 0 and 1, whose value within 'data' will be calculated and returned."))],compute:function(e,t){return{value:mu([e],t,!1,this.locale),format:Pi(e)}},isExported:!0},ju={description:Oo("Value at a given percentile of a dataset."),args:[wh("data (any, range)",Oo("The array or range containing the dataset to consider.")),wh("percentile (number)",Oo("The percentile whose value within data will be calculated and returned."))],compute:function(e,t){return{value:mu([e],t,!0,this.locale),format:Pi(e)}},isExported:!0},Yu={description:Oo("Compute the coefficients of polynomial regression of the dataset."),args:[wh("data_y (range<number>)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (range<number>)",Oo("The range representing the array or matrix of independent data.")),wh("order (number)",Oo("The order of the polynomial to fit the data, between 1 and 6.")),wh("intercept (boolean, default=TRUE)",Oo("A flag specifying whether to compute the intercept or not."))],compute:function(e,t,o,s={value:!0}){const{flatDataX:i,flatDataY:r}=uu(e,t);return nl(r,i,Li(o,this.locale),ji(s))},isExported:!1},Xu={description:Oo("Predict value by computing a polynomial regression of the dataset."),args:[wh("x (number, range<number>)",Oo("The value(s) on the x-axis to forecast.")),wh("data_y (range<number>)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (range<number>)",Oo("The range representing the array or matrix of independent data.")),wh("order (number)",Oo("The order of the polynomial to fit the data, between 1 and 6.")),wh("intercept (boolean, default=TRUE)",Oo("A flag specifying whether to compute the intercept or not."))],compute:function(e,t,o,s,i={value:!0}){const r=Li(s,this.locale),{flatDataX:n,flatDataY:a}=uu(t,o),l=nl(a,n,r,ji(i)).flat();return rr(fr(e),(e=>ll(l,Li(e,this.locale),r)))},isExported:!1},Ku={description:Oo("Value nearest to a specific quartile of a dataset."),args:[wh("data (any, range)",Oo("The array or range containing the dataset to consider.")),wh("quartile_number (number)",Oo("Which quartile value to return."))],compute:function(e,t){return Qu.compute.bind(this)(e,t)},isExported:!0},Ju={description:Oo("Value nearest to a specific quartile of a dataset exclusive of 0 and 4."),args:[wh("data (any, range)",Oo("The array or range containing the dataset to consider.")),wh("quartile_number (number)",Oo("Which quartile value, exclusive of 0 and 4, to return."))],compute:function(e,t){return{value:mu([e],{value:.25*Math.trunc(Li(t,this.locale))},!1,this.locale),format:Pi(e)}},isExported:!0},Qu={description:Oo("Value nearest to a specific quartile of a dataset."),args:[wh("data (any, range)",Oo("The array or range containing the dataset to consider.")),wh("quartile_number (number)",Oo("Which quartile value to return."))],compute:function(e,t){return{value:mu([e],{value:.25*Math.trunc(Li(t,this.locale))},!0,this.locale),format:Pi(e)}},isExported:!0},eg={description:Oo("Returns the rank of a specified value in a dataset."),args:[wh("value (number)",Oo("The value whose rank will be determined.")),wh("data (range)",Oo("The range containing the dataset to consider.")),wh("is_ascending (boolean, default=FALSE)",Oo("Whether to consider the values in data in descending or ascending order."))],compute:function(e,t,o={value:!1}){const s=ji(o),i=Li(e,this.locale);let r=1,n=!1;for(const e of t)for(const t of e){if("number"!=typeof t.value)continue;const e=Li(t,this.locale);e===i?n=!0:e>i!==s&&r++}if(!n)throw new _i(Oo("Value not found in the given data."));return r},isExported:!0},tg={description:Oo("Compute the square of r, the Pearson product-moment correlation coefficient of a dataset."),args:[wh("data_y (range<number>)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (range<number>)",Oo("The range representing the array or matrix of independent data."))],compute:function(e,t){return Math.pow($u(t,e),2)},isExported:!0},og={description:Oo("Compute the slope of the linear regression."),args:[wh("data_y (range<number>)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (range<number>)",Oo("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=uu(e,t),[[i]]=rl([o],[s]);return i},isExported:!0},sg={description:Oo("Nth smallest element in a data set."),args:[wh("data (any, range)",Oo("The array or range containing the dataset to consider.")),wh("n (number)",Oo("The rank from smallest to largest of the element to return."))],compute:function(e,t){const o=Math.trunc(Li(t?.value,this.locale));let s,i=[],r=0;Ji([e],(e=>{"number"==typeof e?.value&&(s=ur(i,e,"nextSmaller","asc",i.length,((e,t)=>e[t].value)),i.splice(s+1,0,e),r++,r>o&&(i.pop(),r--))}));const n=i.pop();return Mi((()=>void 0!==n),Oo("[[FUNCTION_NAME]] has no valid input data.")),Mi((()=>r>=o),Oo("Function [[FUNCTION_NAME]] parameter 2 value (%s) is out of range.",o)),n},isExported:!0},ig={description:Oo("Compute the Spearman rank correlation coefficient of a dataset."),args:[wh("data_y (range<number>)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (range<number>)",Oo("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=uu(t,e),i=o.length,r=o.map(((e,t)=>[e,s[t]]));r.sort(((e,t)=>e[0]-t[0]));for(let e=0;e<i;++e)r[e][0]=e;r.sort(((e,t)=>e[1]-t[1]));let n=0;for(let e=0;e<i;++e)n+=(r[e][0]-e)**2;return 1-6*n/(i**3-i)},isExported:!1},rg={description:Oo("Standard deviation."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the sample.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the sample."))],compute:function(...e){return Math.sqrt(gg.compute.bind(this)(...e))},isExported:!0},ng={description:Oo("Standard deviation of entire population."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the population.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the population."))],compute:function(...e){return Math.sqrt(pg.compute.bind(this)(...e))},isExported:!0},ag={description:Oo("Standard deviation."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the sample.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the sample."))],compute:function(...e){return Math.sqrt(mg.compute.bind(this)(...e))},isExported:!0},lg={description:Oo("Standard deviation of sample (text as 0)."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the sample.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the sample."))],compute:function(...e){return Math.sqrt(fg.compute.bind(this)(...e))},isExported:!0},cg={description:Oo("Standard deviation of entire population."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the population.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the population."))],compute:function(...e){return Math.sqrt(vg.compute.bind(this)(...e))},isExported:!0},hg={description:Oo("Standard deviation of entire population (text as 0)."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the population.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the population."))],compute:function(...e){return Math.sqrt(bg.compute.bind(this)(...e))},isExported:!0},dg={description:Oo("Calculates the standard error of the predicted y-value for each x in the regression of a dataset."),args:[wh("data_y (range<number>)",Oo("The range representing the array or matrix of dependent data.")),wh("data_x (range<number>)",Oo("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=uu(e,t);return rl([o],[s],!0,!0)[1][2]},isExported:!0},ug={description:Oo("Fits points to linear trend derived via least-squares."),args:[wh("known_data_y (number, range<number>)",Oo("The array or range containing dependent (y) values that are already known, used to curve fit an ideal linear trend.")),wh("known_data_x (number, range<number>, optional, default={1;2;3;...})",Oo("The values of the independent variable(s) corresponding with known_data_y.")),wh("new_data_x (number, range<number>, optional, default=known_data_x)",Oo("The data points to return the y values for on the ideal curve fit.")),wh("b (boolean, optional, default=TRUE)",Oo("Given a general linear form of y = m*x+b for a curve fit, calculates b if TRUE or forces b to be 0 and only calculates the m values if FALSE, i.e. forces the curve fit to pass through the origin."))],compute:function(e,t=[[]],o=[[]],s={value:!0}){return dl(Hi(e,"the first argument (known_data_y)"),Hi(t,"the second argument (known_data_x)"),Hi(o,"the third argument (new_data_y)"),ji(s))}},gg={description:Oo("Variance."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the sample.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the sample."))],compute:function(...e){return pu(e,!0,!1,this.locale)},isExported:!0},pg={description:Oo("Variance of entire population."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the population.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the population."))],compute:function(...e){return pu(e,!1,!1,this.locale)},isExported:!0},mg={description:Oo("Variance."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the sample.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the sample."))],compute:function(...e){return pu(e,!0,!1,this.locale)},isExported:!0},fg={description:Oo("Variance of sample (text as 0)."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the sample.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the sample."))],compute:function(...e){return pu(e,!0,!0,this.locale)},isExported:!0},vg={description:Oo("Variance of entire population."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the population.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the population."))],compute:function(...e){return pu(e,!1,!1,this.locale)},isExported:!0},bg={description:Oo("Variance of entire population (text as 0)."),args:[wh("value1 (number, range<number>)",Oo("The first value or range of the population.")),wh("value2 (number, range<number>, repeating)",Oo("Additional values or ranges to include in the population."))],compute:function(...e){return pu(e,!1,!0,this.locale)},isExported:!0};var Sg=Object.freeze({__proto__:null,AVEDEV:fu,AVERAGE:vu,AVERAGEA:Cu,AVERAGEIF:wu,AVERAGEIFS:Eu,AVERAGE_WEIGHTED:yu,CORREL:Gu,COUNT:xu,COUNTA:Iu,COVAR:Ru,COVARIANCE_P:Tu,COVARIANCE_S:Au,FORECAST:_u,GROWTH:Du,INTERCEPT:Ou,LARGE:Fu,LINEST:Mu,LOGEST:Pu,MATTHEWS:Nu,MAX:ku,MAXA:Lu,MAXIFS:Vu,MEDIAN:Hu,MIN:Uu,MINA:Bu,MINIFS:zu,PEARSON:Wu,PERCENTILE:qu,PERCENTILE_EXC:Zu,PERCENTILE_INC:ju,POLYFIT_COEFFS:Yu,POLYFIT_FORECAST:Xu,QUARTILE:Ku,QUARTILE_EXC:Ju,QUARTILE_INC:Qu,RANK:eg,RSQ:tg,SLOPE:og,SMALL:sg,SPEARMAN:ig,STDEV:rg,STDEVA:lg,STDEVP:cg,STDEVPA:hg,STDEV_P:ng,STDEV_S:ag,STEYX:dg,TREND:ug,VAR:gg,VARA:fg,VARP:vg,VARPA:bg,VAR_P:pg,VAR_S:mg});function yg(e,t,o,s){const i=new Map,r=e.length;for(let t=r-1;t>=0;t--)i.set(Gi(e[t][0]).toUpperCase(),t);const n=t?.value;if("number"!=typeof n&&"string"!=typeof n)throw new Ri(Oo("The field must be a number or a string"));let a;if("number"==typeof n){if(a=Math.trunc(n)-1,a<0||r-1<a)throw new Ri(Oo("The field (%(fieldValue)s) must be one of %(dimRowDB)s or must be a number between 1 and %s inclusive.",{fieldValue:n.toString(),dimRowDB:r.toString()}))}else{const e=Gi(t).toUpperCase();if(a=i.get(e)??-1,-1===a)throw new Ri(Oo("The field (%s) must be one of %s.",Gi(t),[...i.keys()].toString()))}const l=o[0].length;if(l<2)throw new Ri(Oo("The criteria range contains %s row, it must be at least 2 rows.",l.toString()));let c=new Set;const h=e[0].length;for(let t=1;t<l;t++){let r=[],n=!0;for(let s=0;s<o.length;s++){const a=Gi(o[s][0]).toUpperCase(),l=i.get(a),c=o[s][t];if(null!==c.value){if(void 0===l){n=!1;break}r.push([e[l].slice(1,h)]),r.push(c)}}if(n){if(!(r.length>0)){c=new Set(Array(h-1).keys());break}dr(r,((e,t)=>{c.add(t)}),s,!0)}}const d=e[a];return[...c].map((e=>d[e+1]))}const Cg=[wh("database (range)",Oo("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.")),wh("field (number, string)",Oo("Indicates which column in database contains the values to be extracted and operated on.")),wh("criteria (range)",Oo("An array or range containing zero or more criteria to filter the database values by before operating."))],wg={description:Oo("Average of a set of values from a table-like range."),args:Cg,compute:function(e,t,o){const s=yg(e,t,o,this.locale);return vu.compute.bind(this)([s])},isExported:!0},Eg={description:Oo("Counts values from a table-like range."),args:Cg,compute:function(e,t,o){const s=yg(e,t,o,this.locale);return xu.compute.bind(this)([s])},isExported:!0},xg={description:Oo("Counts values and text from a table-like range."),args:Cg,compute:function(e,t,o){const s=yg(e,t,o,this.locale);return Iu.compute.bind(this)([s])},isExported:!0},Ig={description:Oo("Single value from a table-like range."),args:Cg,compute:function(e,t,o){const s=yg(e,t,o,this.locale);return Mi((()=>1===s.length),Oo("More than one match found in DGET evaluation.")),s[0]},isExported:!0},Rg={description:Oo("Maximum of values from a table-like range."),args:Cg,compute:function(e,t,o){const s=yg(e,t,o,this.locale);return ku.compute.bind(this)([s])},isExported:!0},Tg={description:Oo("Minimum of values from a table-like range."),args:Cg,compute:function(e,t,o){const s=yg(e,t,o,this.locale);return Uu.compute.bind(this)([s])},isExported:!0},Ag={description:Oo("Product of values from a table-like range."),args:Cg,compute:function(e,t,o){const s=yg(e,t,o,this.locale);return Wd.compute.bind(this)([s])},isExported:!0},_g={description:Oo("Standard deviation of population sample from table."),args:Cg,compute:function(e,t,o){const s=yg(e,t,o,this.locale);return rg.compute.bind(this)([s])},isExported:!0},Dg={description:Oo("Standard deviation of entire population from table."),args:Cg,compute:function(e,t,o){const s=yg(e,t,o,this.locale);return cg.compute.bind(this)([s])},isExported:!0},Og={description:Oo("Sum of values from a table-like range."),args:Cg,compute:function(e,t,o){const s=yg(e,t,o,this.locale);return su.compute.bind(this)([s])},isExported:!0},Fg={description:Oo("Variance of population sample from table-like range."),args:Cg,compute:function(e,t,o){const s=yg(e,t,o,this.locale);return gg.compute.bind(this)([s])},isExported:!0},Mg={description:Oo("Variance of a population from a table-like range."),args:Cg,compute:function(e,t,o){const s=yg(e,t,o,this.locale);return vg.compute.bind(this)([s])},isExported:!0};var Pg=Object.freeze({__proto__:null,DAVERAGE:wg,DCOUNT:Eg,DCOUNTA:xg,DGET:Ig,DMAX:Rg,DMIN:Tg,DPRODUCT:Ag,DSTDEV:_g,DSTDEVP:Dg,DSUM:Og,DVAR:Fg,DVARP:Mg});var Ng;!function(e){e.WHOLE_YEARS="Y",e.WHOLE_MONTHS="M",e.WHOLE_DAYS="D",e.DAYS_WITHOUT_WHOLE_MONTHS="MD",e.MONTH_WITHOUT_WHOLE_YEARS="YM",e.DAYS_BETWEEN_NO_MORE_THAN_ONE_YEAR="YD"}(Ng||(Ng={}));const kg={description:Oo("Converts year/month/day into a date."),args:[wh("year (number)",Oo("The year component of the date.")),wh("month (number)",Oo("The month component of the date.")),wh("day (number)",Oo("The day component of the date."))],compute:function(e,t,o){let s=Math.trunc(Li(e,this.locale));const i=Math.trunc(Li(t,this.locale)),r=Math.trunc(Li(o,this.locale));Mi((()=>0<=s&&s<=9999),Oo("The year (%s) must be between 0 and 9999 inclusive.",s.toString())),s<1900&&(s+=1900);const n=Bs(new xs(s,i-1,r));return Mi((()=>n>=0),Oo("The function [[FUNCTION_NAME]] result must be greater than or equal 01/01/1900.")),{value:n,format:this.locale.dateFormat}},isExported:!0},Lg={description:Oo("Calculates the number of days, months, or years between two dates."),args:[wh("start_date (date)",Oo("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.")),wh("end_date (date)",Oo("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.")),wh("unit (string)",Oo('A text abbreviation for unit of time. Accepted values are "Y" (the number of whole years between start_date and end_date), "M" (the number of whole months between start_date and end_date), "D" (the number of days between start_date and end_date), "MD" (the number of days between start_date and end_date after subtracting whole months), "YM" (the number of whole months between start_date and end_date after subtracting whole years), "YD" (the number of days between start_date and end_date, assuming start_date and end_date were no more than one year apart).'))],compute:function(e,t,o){const s=Gi(o).toUpperCase();Mi((()=>Object.values(Ng).includes(s)),((e,t)=>{const o=e.map((e=>`'${e}'`)).join(", ");return Oo("The function [[FUNCTION_NAME]] has an argument with value '%s'. It should be one of: %s.",t,o)})(Object.values(Ng),Gi(o)));const i=Math.trunc(Li(e,this.locale)),r=Math.trunc(Li(t,this.locale)),n=Us(i),a=Us(r);switch(Mi((()=>r>=i),Oo("start_date (%s) should be on or before end_date (%s).",n.toLocaleDateString(),a.toLocaleDateString())),s){case Ng.WHOLE_YEARS:return Xs(n,a);case Ng.WHOLE_MONTHS:return js(n,a);case Ng.WHOLE_DAYS:return Ys(n,a);case Ng.MONTH_WITHOUT_WHOLE_YEARS:return js(n,a)-12*Xs(n,a);case Ng.DAYS_WITHOUT_WHOLE_MONTHS:let e=a.getDate()-n.getDate();if(e<0){e=$s(new xs(a.getFullYear(),a.getMonth()-1,1))-Math.abs(e)}return e;case Ng.DAYS_BETWEEN_NO_MORE_THAN_ONE_YEAR:{if(function(e,t){return Zs(e,t,1)<1}(i,r))return Ys(n,a);const e=new xs(n.getFullYear(),a.getMonth(),a.getDate());let t=Ys(n,e);return t<0&&(e.setFullYear(n.getFullYear()+1),t=Ys(n,e)),t}}},isExported:!0},Vg={description:Oo("Converts a date string to a date value."),args:[wh("date_string (string)",Oo("The string representing the date."))],compute:function(e){const t=Gi(e),o=Hs(t,this.locale);return Mi((()=>null!==o),Oo("The date_string (%s) cannot be parsed to date/time.",t.toString())),Math.trunc(o.value)},isExported:!0},Hg={description:Oo("Day of the month that a specific date falls on."),args:[wh("date (string)",Oo("The date from which to extract the day."))],compute:function(e){return Yi(e,this.locale).getDate()},isExported:!0},Ug={description:Oo("Number of days between two dates."),args:[wh("end_date (date)",Oo("The end of the date range.")),wh("start_date (date)",Oo("The start of the date range."))],compute:function(e,t){const o=Yi(e,this.locale),s=Yi(t,this.locale),i=o.getTime()-s.getTime();return Math.round(i/Rs)},isExported:!0},Bg={description:Oo("Number of days between two dates on a 360-day year (months of 30 days)."),args:[wh("start_date (date)",Oo("The start date to consider in the calculation.")),wh("end_date (date)",Oo("The end date to consider in the calculation.")),wh("method (number, default=0)",Oo("An indicator of what day count method to use. (0) US NASD method (1) European method"))],compute:function(e,t,o={value:0}){const s=Math.trunc(Li(e,this.locale)),i=Math.trunc(Li(t,this.locale)),r=Zs(s,i,ji(o)?4:0);return Math.sign(i-s)*Math.round(360*r)},isExported:!0},zg={description:Oo("Date a number of months before/after another date."),args:[wh("start_date (date)",Oo("The date from which to calculate the result.")),wh("months (number)",Oo("The number of months before (negative) or after (positive) 'start_date' to calculate."))],compute:function(e,t){return{value:Bs(Gs(Yi(e,this.locale),Math.trunc(Li(t,this.locale)),!1)),format:this.locale.dateFormat}},isExported:!0},$g={description:Oo("Last day of a month before or after a date."),args:[wh("start_date (date)",Oo("The date from which to calculate the result.")),wh("months (number)",Oo("The number of months before (negative) or after (positive) 'start_date' to consider."))],compute:function(e,t){const o=Yi(e,this.locale),s=Math.trunc(Li(t,this.locale)),i=o.getFullYear(),r=o.getMonth();return{value:Bs(new xs(i,r+s+1,0)),format:this.locale.dateFormat}},isExported:!0},Wg={description:Oo("Hour component of a specific time."),args:[wh("time (date)",Oo("The time from which to calculate the hour component."))],compute:function(e){return Yi(e,this.locale).getHours()},isExported:!0},Gg={description:Oo("ISO week number of the year."),args:[wh("date (date)",Oo("The date for which to determine the ISO week number. Must be a reference to a cell containing a date, a function returning a date type, or a number."))],compute:function(e){const t=Yi(e,this.locale),o=t.getFullYear();let s=1;for(;4!==new xs(o,0,s).getDay();)s+=1;const i=new xs(o,0,s-3);let r=31;for(;4!==new xs(o,11,r).getDay();)r-=1;const n=new xs(o,11,r+3);let a,l;switch(a=i.getTime()<=t.getTime()?t.getTime()<=n.getTime()?0:1:-1,a){case 0:l=i;break;case 1:l=new xs(o,11,r+3+1);break;case-1:let e=1;for(;4!==new xs(o-1,0,e).getDay();)e+=1;l=new xs(o-1,0,e-3)}const c=(t.getTime()-l.getTime())/Rs;return Math.floor(c/7)+1},isExported:!0},qg={description:Oo("Minute component of a specific time."),args:[wh("time (date)",Oo("The time from which to calculate the minute component."))],compute:function(e){return Yi(e,this.locale).getMinutes()},isExported:!0},Zg={description:Oo("Month of the year a specific date falls in"),args:[wh("date (date)",Oo("The date from which to extract the month."))],compute:function(e){return Yi(e,this.locale).getMonth()+1},isExported:!0},jg={description:Oo("Net working days between two provided days."),args:[wh("start_date (date)",Oo("The start date of the period from which to calculate the number of net working days.")),wh("end_date (date)",Oo("The end date of the period from which to calculate the number of net working days.")),wh("holidays (date, range<date>, optional)",Oo("A range or array constant containing the date serial numbers to consider holidays."))],compute:function(e,t,o){return Xg.compute.bind(this)(e,t,{value:1},o)},isExported:!0};function Yg(e){const t=e?.value;if("string"==typeof t){Mi((()=>{if(7!==t.length)return!1;for(let e of t)if("0"!==e&&"1"!==e)return!1;return!0}),Oo('When weekend is a string (%s) it must be composed of "0" or "1".',t));let e=[];for(let o=0;o<7;o++)"1"===t[o]&&e.push((o+1)%7);return e}if("number"==typeof t)return Mi((()=>1<=t&&t<=7||11<=t&&t<=17),Oo("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 Ri(Oo("The weekend must be a number or a string."))}const Xg={description:Oo("Net working days between two dates (specifying weekends)."),args:[wh("start_date (date)",Oo("The start date of the period from which to calculate the number of net working days.")),wh("end_date (date)",Oo("The end date of the period from which to calculate the number of net working days.")),wh("weekend (any, default=1)",Oo("A number or string representing which days of the week are considered weekends.")),wh("holidays (date, range<date>, optional)",Oo("A range or array constant containing the dates to consider as holidays."))],compute:function(e,t,o={value:1},s){const i=Yi(e,this.locale),r=Yi(t,this.locale),n=Yg(o);let a=new Set;void 0!==s&&Ji([s],(e=>{const t=Yi(e,this.locale);a.add(t.getTime())}));const l=i.getTime()>r.getTime(),c=xs.fromTimestamp((l?i:r).getTime());let h=xs.fromTimestamp((l?r:i).getTime());const d=c.getTime();let u=h.getTime(),g=0;for(;u<=d;)n.includes(h.getDay())||a.has(u)||(g+=1),h.setDate(h.getDate()+1),u=h.getTime();return l?-g:g},isExported:!0},Kg={description:Oo("Current date and time as a date value."),args:[],compute:function(){const e=xs.now(),t=e.getTime()-Is.getTime(),o=e.getHours()/24+e.getMinutes()/1440+e.getSeconds()/86400;return{value:Math.floor(t/Rs)+o,format:Ba(this.locale)}},isExported:!0},Jg={description:Oo("Minute component of a specific time."),args:[wh("time (date)",Oo("The time from which to calculate the second component."))],compute:function(e){return Yi(e,this.locale).getSeconds()},isExported:!0},Qg={description:Oo("Converts hour/minute/second into a time."),args:[wh("hour (number)",Oo("The hour component of the time.")),wh("minute (number)",Oo("The minute component of the time.")),wh("second (number)",Oo("The second component of the time."))],compute:function(e,t,o){let s=Math.trunc(Li(e,this.locale)),i=Math.trunc(Li(t,this.locale)),r=Math.trunc(Li(o,this.locale));return i+=Math.floor(r/60),r=r%60+(r<0?60:0),s+=Math.floor(i/60),i=i%60+(i<0?60:0),s%=24,Mi((()=>s>=0),Oo("The function [[FUNCTION_NAME]] result cannot be negative")),{value:s/24+i/1440+r/86400,format:this.locale.timeFormat}},isExported:!0},ep={description:Oo("Converts a time string into its serial number representation."),args:[wh("time_string (string)",Oo("The string that holds the time representation."))],compute:function(e){const t=Gi(e),o=Hs(t,this.locale);Mi((()=>null!==o),Oo("The time_string (%s) cannot be parsed to date/time.",t));const s=o.value-Math.trunc(o.value);return s<0?1+s:s},isExported:!0},tp={description:Oo("Current date as a date value."),args:[],compute:function(){const e=xs.now();return{value:Bs(new xs(e.getFullYear(),e.getMonth(),e.getDate())),format:this.locale.dateFormat}},isExported:!0},op={description:Oo("Day of the week of the date provided (as number)."),args:[wh("date (date)",Oo("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.")),wh("type (number, default=1)",Oo("A number indicating which numbering system to use to represent weekdays. By default, counts starting with Sunday = 1."))],compute:function(e,t={value:1}){const o=Yi(e,this.locale),s=Math.round(Li(t,this.locale)),i=o.getDay();return Mi((()=>[1,2,3].includes(s)),Oo("The type (%s) must be 1, 2 or 3.",s.toString())),1===s?i+1:2===s?0===i?7:i:0===i?6:i-1},isExported:!0},sp={description:Oo("Week number of the year."),args:[wh("date (date)",Oo("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.")),wh("type (number, default=1)",Oo("A number representing the day that a week starts on. Sunday = 1."))],compute:function(e,t={value:1}){const o=Yi(e,this.locale),s=Math.round(Li(t,this.locale));if(Mi((()=>1===s||2===s||11<=s&&s<=17||21===s),Oo("The type (%s) is out of range.",s.toString())),21===s)return Gg.compute.bind(this)(e);let i;i=1===s||2===s?s-1:s-10==7?0:s-10;const r=o.getFullYear();let n=1,a=new xs(r,0,n);for(;a.getDay()!==i;)n+=1,a=new xs(r,0,n);const l=(o.getTime()-a.getTime())/Rs;return l<0?1:Math.floor(l/7)+(1===n?1:2)},isExported:!0},ip={description:Oo("Date after a number of workdays."),args:[wh("start_date (date)",Oo("The date from which to begin counting.")),wh("num_days (number)",Oo("The number of working days to advance from start_date. If negative, counts backwards.")),wh("holidays (date, range<date>, optional)",Oo("A range or array constant containing the dates to consider holidays."))],compute:function(e,t,o={value:null}){return rp.compute.bind(this)(e,t,{value:1},o)},isExported:!0},rp={description:Oo("Date after a number of workdays (specifying weekends)."),args:[wh("start_date (date)",Oo("The date from which to begin counting.")),wh("num_days (number)",Oo("The number of working days to advance from start_date. If negative, counts backwards.")),wh("weekend (any, default=1)",Oo("A number or string representing which days of the week are considered weekends.")),wh("holidays (date, range<date>, optional)",Oo("A range or array constant containing the dates to consider holidays."))],compute:function(e,t,o={value:1},s){let i=Yi(e,this.locale),r=Math.trunc(Li(t,this.locale));"string"==typeof o.value&&Mi((()=>"1111111"!==o.value),Oo("The weekend must be different from '1111111'."));const n=Yg(o);let a=new Set;void 0!==s&&Ji([s],(e=>{const t=Yi(e,this.locale);a.add(t.getTime())}));let l=xs.fromTimestamp(i.getTime()),c=l.getTime();const h=Math.sign(r);let d=Math.abs(r);for(;d>0;)l.setDate(l.getDate()+h),c=l.getTime(),n.includes(l.getDay())||a.has(c)||(d-=1);const u=c-Is.getTime();return{value:Math.round(u/Rs),format:this.locale.dateFormat}},isExported:!0},np={description:Oo("Year specified by a given date."),args:[wh("date (date)",Oo("The date from which to extract the year."))],compute:function(e){return Yi(e,this.locale).getFullYear()},isExported:!0},ap={description:Oo("Exact number of years between two dates."),args:[wh("start_date (date)",Oo("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.")),wh("end_date (date)",Oo("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.")),wh("day_count_convention (number, default=0)",Oo("An indicator of what day count method to use."))],compute:function(e,t,o={value:0}){let s=Math.trunc(Li(e,this.locale)),i=Math.trunc(Li(t,this.locale));const r=Math.trunc(Li(o,this.locale));return Mi((()=>s>=0),Oo("The start_date (%s) must be positive or null.",s.toString())),Mi((()=>i>=0),Oo("The end_date (%s) must be positive or null.",i.toString())),Mi((()=>0<=r&&r<=4),Oo("The day_count_convention (%s) must be between 0 and 4 inclusive.",r.toString())),Zs(s,i,r)}},lp={description:Oo("First day of the month preceding a date."),args:[wh("date (date)",Oo("The date from which to calculate the result."))],compute:function(e){const t=Yi(e,this.locale),o=t.getFullYear(),s=t.getMonth();return{value:Bs(new xs(o,s,1)),format:this.locale.dateFormat}}},cp={description:Oo("Last day of the month following a date."),args:[wh("date (date)",Oo("The date from which to calculate the result."))],compute:function(e){return $g.compute.bind(this)(e,{value:0})}},hp={description:Oo("Quarter of the year a specific date falls in"),args:[wh("date (date)",Oo("The date from which to extract the quarter."))],compute:function(e){return Math.ceil((Yi(e,this.locale).getMonth()+1)/3)}},dp={description:Oo("First day of the quarter of the year a specific date falls in."),args:[wh("date (date)",Oo("The date from which to calculate the start of quarter."))],compute:function(e){const t=hp.compute.bind(this)(e),o=np.compute.bind(this)(e);return{value:Bs(new xs(o,3*(t-1),1)),format:this.locale.dateFormat}}},up={description:Oo("Last day of the quarter of the year a specific date falls in."),args:[wh("date (date)",Oo("The date from which to calculate the end of quarter."))],compute:function(e){const t=hp.compute.bind(this)(e),o=np.compute.bind(this)(e);return{value:Bs(new xs(o,3*t,0)),format:this.locale.dateFormat}}},gp={description:Oo("First day of the year a specific date falls in."),args:[wh("date (date)",Oo("The date from which to calculate the start of the year."))],compute:function(e){const t=np.compute.bind(this)(e);return{value:Bs(new xs(t,0,1)),format:this.locale.dateFormat}}},pp={description:Oo("Last day of the year a specific date falls in."),args:[wh("date (date)",Oo("The date from which to calculate the end of the year."))],compute:function(e){const t=np.compute.bind(this)(e);return{value:Bs(new xs(t+1,0,0)),format:this.locale.dateFormat}}};var mp=Object.freeze({__proto__:null,DATE:kg,DATEDIF:Lg,DATEVALUE:Vg,DAY:Hg,DAYS:Ug,DAYS360:Bg,EDATE:zg,EOMONTH:$g,HOUR:Wg,ISOWEEKNUM:Gg,MINUTE:qg,MONTH:Zg,MONTH_END:cp,MONTH_START:lp,NETWORKDAYS:jg,NETWORKDAYS_INTL:Xg,NOW:Kg,QUARTER:hp,QUARTER_END:up,QUARTER_START:dp,SECOND:Jg,TIME:Qg,TIMEVALUE:ep,TODAY:tp,WEEKDAY:op,WEEKNUM:sp,WORKDAY:ip,WORKDAY_INTL:rp,YEAR:np,YEARFRAC:ap,YEAR_END:pp,YEAR_START:gp});const fp={description:Oo("Compare two numeric values, returning 1 if they're equal."),args:[wh("number1 (number)",Oo("The first number to compare.")),wh("number2 (number, default=0)",Oo("The second number to compare."))],compute:function(e,t={value:0}){return Li(e,this.locale)===Li(t,this.locale)?1:0},isExported:!0};var vp=Object.freeze({__proto__:null,DELTA:fp});const bp=[ii.number,ii.error,ii.text,ii.boolean];function Sp(e){const t="asc"===e?1:-1;return(e,o)=>{if(e.type===ii.empty)return o.type===ii.empty?0:1;if(o.type===ii.empty)return-1;let s=bp.indexOf(e.type)-bp.indexOf(o.type);return 0===s&&(s=e.type===ii.text||e.type===ii.error?e.value.localeCompare(o.value):e.value-o.value),t*s}}function yp(e,t,o,s,i){let r=s.right>s.left;if(e.model.getters.doesIntersectMerge(t,s)){let o;r=!1;for(let i=s.top;i<=s.bottom;i++){o=[];for(let r=s.left;r<=s.right;r++){let s=e.model.getters.getMerge({sheetId:t,col:r,row:i});s&&!o.includes(s.id.toString())&&o.push(s.id.toString())}if(o.length>=2){r=!0;break}}}if(r)return void Cp(e,t,o,s,i);const n=e.model.getters.getContiguousZone(t,s);is(n,s)?Cp(e,t,o,s,i):e.askConfirmation(Oo("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?"),(()=>Cp(e,t,o,n,i)),(()=>Cp(e,t,o,s,i)))}function Cp(e,t,o,s,i,r){const n=e.model.dispatch("SORT_CELLS",{sheetId:t,col:o.col,row:o.row,zone:s,sortDirection:i,sortOptions:r});if(n.isCancelledBecause("InvalidSortZone")){const{col:t,row:i}=o;e.model.selection.selectZone({cell:{col:t,row:i},zone:s}),e.raiseError(Oo("Cannot sort. To sort, select only cells or only merges that have the same size."))}if(n.isCancelledBecause("SortZoneWithArrayFormulas")){const{col:t,row:i}=o;e.model.selection.selectZone({cell:{col:t,row:i},zone:s}),e.raiseError(Oo("Cannot sort a zone with array formulas."))}}function wp(e,t,...o){for(const[e,t]of o.entries())Mi((()=>void 0!==t),Oo("Value for parameter %d is missing, while the function [[FUNCTION_NAME]] expect a number or a range.",e+1));const s=[],i=[],r=e.length;for(let n=0;n<o.length;n+=2){s.push(ji(Ka(o[n+1])?.value)?"asc":"desc");const a=o[n];if(yi(a)&&(a.length>1||a[0].length>1))Mi((()=>1===a.length&&a[0].length===r),Oo("Wrong size for %s. Expected a range of size 1x%s. Got %sx%s.",`sort_column${n+1}`,r,a.length,a[0].length)),i.push(a.flat().map((e=>e.value)));else{const o=Li(Ka(a)?.value,t);if(o<1||o>e[0].length)return e;i.push(e.map((e=>e[o-1].value)))}}if(0===i.length)for(let t=0;t<e[0].length;t++)i.push(e.map((e=>e[t].value))),s.push("asc");const n={desc:Sp("desc"),asc:Sp("asc")},a=Ze(0,e.length);return a.sort(((e,t)=>{for(const[o,r]of i.entries()){const i=r[e],a=r[t],l={value:i,type:null===i?ii.empty:"string"==typeof i?ii.text:typeof i},c={value:a,type:null===a?ii.empty:"string"==typeof a?ii.text:typeof a},h=n[s[o]](l,c);if(0!==h)return h}return 0})),a.map((t=>e[t]))}const Ep={description:Oo("Returns a filtered version of the source range, returning only rows or columns that meet the specified conditions."),args:[wh("range (any, range<any>)",Oo("The data to be filtered.")),wh("condition1 (boolean, range<boolean>)",Oo("A column or row containing true or false values corresponding to the first column or row of range.")),wh("condition2 (boolean, range<boolean>, repeating)",Oo("Additional column or row containing true or false values."))],compute:function(e,...t){let o=fr(e);const s=t.map((e=>rr(fr(e),(e=>e.value))));s.map((e=>xh(Oo("The arguments condition must be a single column or row."),e))),Ih(Oo("The arguments conditions must have the same dimensions."),...t);const i=s.map((e=>e.flat())),r=1===s[0].length?"row":"col";o="row"===r?nr(o):o,Mi((()=>i.every((e=>e.length===o.length))),Oo("FILTER has mismatched sizes on the range and conditions."));const n=[];for(let e=0;e<o.length;e++){const t=o[e];i.every((t=>("boolean"==typeof t[e]||"number"==typeof t[e])&&t[e]))&&n.push(t)}return n.length?"row"===r?nr(n):n:new _i(Oo("No match found in FILTER evaluation"))},isExported:!0},xp={description:Oo("Sorts the rows of a given array or range by the values in one or more columns."),args:[wh("range (range)",Oo("The data to be sorted.")),wh("sort_column (any, range<number>, repeating)",Oo("The index of the column in range or a range outside of range containing the values by which to sort.")),wh("is_ascending (boolean, repeating)",Oo("TRUE or FALSE indicating whether to sort sort_column in ascending order. FALSE sorts in descending order."))],compute:function(e,...t){const o=nr(e);return nr(wp(o,this.locale,...t))},isExported:!0},Ip={description:Oo("Returns the first n items in a data set after performing a sort."),args:[wh("range (range)",Oo("The data to be sorted.")),wh("n (number, default=1)",Oo("The number of items to return.")),wh("display_ties_mode (number, default=0)",Oo("A number representing the way to display ties.")),wh("sort_column (number, range<number>, repeating)",Oo("The index of the column in range or a range outside of range containing the values by which to sort.")),wh("is_ascending (boolean, repeating)",Oo("TRUE or FALSE indicating whether to sort sort_column in ascending order. FALSE sorts in descending order."))],compute:function(e,t,o,...s){const i=Li(t?.value??1,this.locale);Mi((()=>i>=0),Oo("Wrong value of 'n'. Expected a positive number. Got %s.",i));const r=Li(o?.value??0,this.locale);Mi((()=>r>=0&&r<=3),Oo("Wrong value of 'display_ties_mode'. Expected a positive number between 0 and 3. Got %s.",r));const n=wp(nr(e),this.locale,...s),a=(e,t)=>JSON.stringify(n[e].map((e=>e.value)))===JSON.stringify(n[t].map((e=>e.value)));switch(r){case 0:return nr(n.slice(0,i));case 1:for(let e=i;e<n.length;e++)if(!a(e,i-1))return nr(n.slice(0,e));return nr(n);case 2:{const e=[n[0]];for(let t=1;t<n.length;t++)for(let o=0;o<t&&!a(t,o);o++)o===t-1&&e.push(n[t]);return nr(e.slice(0,i))}case 3:{const e=[n[0]];let t=1;for(let o=1;o<n.length&&(a(o,o-1)||t++,!(t>i));o++)e.push(n[o]);return nr(e)}}},isExported:!0},Rp={description:Oo("Unique rows in the provided source range."),args:[wh("range (any, range<any>)",Oo("The data to filter by unique entries.")),wh("by_column (boolean, default=FALSE)",Oo("Whether to filter the data by columns or by rows.")),wh("exactly_once (boolean, default=FALSE)",Oo("Whether to return only entries with no duplicates."))],compute:function(e={value:""},t,o){if(!yi(e))return[[e]];const s=ji(t?.value)||!1,i=ji(o?.value)||!1;s||(e=nr(e));const r=new Map;for(const t of e){const e=JSON.stringify(t.map((e=>e.value))),o=r.get(e);o?o.count++:r.set(e,{data:t,count:1})}const n=[];for(const e of r.values())i&&e.count>1||n.push(e.data);if(!n.length)throw new Ri(Oo("No unique values found"));return s?n:nr(n)},isExported:!0};var Tp=Object.freeze({__proto__:null,FILTER:Ep,SORT:xp,SORTN:Ip,UNIQUE:Rp});function Ap(e,t){Mi((()=>e<t),Oo("The maturity (%s) must be strictly greater than the settlement (%s).",t.toString(),e.toString()))}function _p(e,t){Mi((()=>t<e),Oo("The settlement date (%s) must be strictly greater than the issue date (%s).",e.toString(),t.toString()))}function Dp(e){Mi((()=>[1,2,4].includes(e)),Oo("The frequency (%s) must be one of %s",e.toString(),[1,2,4].toString()))}function Op(e){Mi((()=>0<=e&&e<=4),Oo("The day_count_convention (%s) must be between 0 and 4 inclusive.",e.toString()))}function Fp(e){Mi((()=>e>0),Oo("The redemption (%s) must be strictly positive.",e.toString()))}function Mp(e){Mi((()=>e>0),Oo("The price (%s) must be strictly positive.",e.toString()))}function Pp(e){Mi((()=>e>0),Oo("The number_of_periods (%s) must be greater than 0.",e.toString()))}function Np(e){Mi((()=>e>0),Oo("The rate (%s) must be strictly positive.",e.toString()))}function kp(e){Mi((()=>e>0),Oo("The life (%s) must be strictly positive.",e.toString()))}function Lp(e){Mi((()=>e>=0),Oo("The cost (%s) must be positive or null.",e.toString()))}function Vp(e){Mi((()=>e>0),Oo("The period (%s) must be strictly positive.",e.toString()))}function Hp(e){Mi((()=>e>=0),Oo("The salvage (%s) must be positive or null.",e.toString()))}function Up(e){Mi((()=>e>0),Oo("The present value (%s) must be strictly positive.",e.toString()))}function Bp(e,t){Mi((()=>e<=t),Oo("The period (%s) must be less than or equal life (%s).",e.toString(),t.toString()))}function zp(e){Mi((()=>e>0),Oo("The investment (%s) must be strictly positive.",e.toString()))}function $p(e){Mi((()=>e>0),Oo("The discount (%s) must be strictly positive.",e.toString()))}function Wp(e){Mi((()=>e<1),Oo("The discount (%s) must be smaller than 1.",e.toString()))}function Gp(e){Mi((()=>e>0),Oo("The depreciation factor (%s) must be strictly positive.",e.toString()))}function qp(e,t,o){const s=Yi(e,o),i=Yi(t,o),r=Yi(e,o);r.setFullYear(s.getFullYear()+1),Mi((()=>i.getTime()<=r.getTime()),Oo("The settlement date (%s) must at most one year after the maturity date (%s).",e.toString(),t.toString()))}function Zp(e,t,o){Pp(o),Mi((()=>e>0),Oo("The first_period (%s) must be strictly positive.",e.toString())),Mi((()=>t>0),Oo("The last_period (%s) must be strictly positive.",t.toString())),Mi((()=>e<=t),Oo("The first_period (%s) must be smaller or equal to the last_period (%s).",e.toString(),t.toString())),Mi((()=>t<=o),Oo("The last_period (%s) must be smaller or equal to the number_of_periods (%s).",e.toString(),o.toString()))}function jp(e){Mi((()=>e>-1),Oo("The rate_guess (%s) must be strictly greater than -1.",e.toString()))}function Yp(e,t){Mi((()=>e.length===t.length&&e[0].length===t[0].length),Oo("The cashflow_amounts and cashflow_dates ranges must have the same dimensions."))}function Xp(e){Mi((()=>e.every((t=>t>=e[0]))),Oo("All the dates should be greater or equal to the first date in cashflow_dates (%s).",e[0].toString()))}const Kp=[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("frequency (number)",Oo("The number of interest or coupon payments per year (1, 2, or 4).")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))];function Jp(e,t,o,s,i=1e-10,r){let n,a,l,c,h=o,d=!1,u=0;do{l=e(h),isNaN(l)?(Mi((()=>u<s&&void 0!==r),Oo("Function [[FUNCTION_NAME]] didn't find any result.")),u++,h=r(c),c=h):(n=h-l/t(h),a=Math.abs(n-h),h=n,d=a<i||Math.abs(l)<i,Mi((()=>u<s),Oo("Function [[FUNCTION_NAME]] didn't find any result.")),u++)}while(!d);return h}const Qp={description:Oo("Accrued interest of security paying at maturity."),args:[wh("issue (date)",Oo("The date the security was initially issued.")),wh("maturity (date)",Oo("The maturity date of the security.")),wh("rate (number)",Oo("The annualized rate of interest.")),wh("redemption (number)",Oo("The redemption amount per 100 face value, or par.")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){const r=Math.trunc(Li(e,this.locale)),n=Math.trunc(Li(t,this.locale)),a=Li(s,this.locale),l=Li(o,this.locale),c=Math.trunc(Li(i,this.locale));!function(e){Mi((()=>e>=0),Oo("The issue (%s) must be positive or null.",e.toString()))}(r),_p(n,r),Op(c),Fp(a),Np(l);return a*l*Zs(r,n,c)},isExported:!0},em={description:Oo("Depreciation for an accounting period."),args:[wh("cost (number)",Oo("The initial cost of the asset.")),wh("purchase_date (date)",Oo("The date the asset was purchased.")),wh("first_period_end (date)",Oo("The date the first period ended.")),wh("salvage (number)",Oo("The value of the asset at the end of depreciation.")),wh("period (number)",Oo("The single period within life for which to calculate depreciation.")),wh("rate (number)",Oo("The deprecation rate.")),wh("day_count_convention (number, optional)",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,r,n={value:0}){n=n||0;const a=Li(e,this.locale),l=Math.trunc(Li(t,this.locale)),c=Math.trunc(Li(o,this.locale)),h=Li(s,this.locale),d=Li(i,this.locale),u=Li(r,this.locale),g=Math.trunc(Li(n,this.locale));!function(e){Mi((()=>e>0),Oo("The cost (%s) must be strictly positive.",e.toString()))}(a),function(e){Mi((()=>e>=0),Oo("The purchase_date (%s) must be positive or null.",e.toString()))}(l),Hp(h),function(e,t){Mi((()=>e<=t),Oo("The salvage (%s) must be smaller or equal than the cost (%s).",e.toString(),t.toString()))}(h,a),function(e){Mi((()=>e>=0),Oo("The period (%s) must be positive or null.",e.toString()))}(d),Np(u),Op(g),Mi((()=>l<=c),Oo("The purchase_date (%s) must be before the first_period_end (%s).",l.toString(),c.toString()));const p=d<1&&d>0?1:Math.trunc(d),m=a*u,f=Zs(l,c,g),v=l===c?m:m*f,b=a-v-m*p;return b>=h?0===p?v:m:h-b<m?m-(h-b):0},isExported:!0},tm={description:Oo("Days in coupon period containing settlement date."),args:Kp,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Li(e,this.locale)),r=Math.trunc(Li(t,this.locale)),n=Math.trunc(Li(o,this.locale)),a=Math.trunc(Li(s,this.locale));if(Ap(i,r),Dp(n),Op(a),1===a){const i=nm.compute.bind(this)(e,t,o,s).value;return im.compute.bind(this)(e,t,o,s).value-i}return(3===a?365:360)/n},isExported:!0},om={description:Oo("Days from settlement until next coupon."),args:Kp,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Li(e,this.locale)),r=Math.trunc(Li(t,this.locale)),n=Math.trunc(Li(o,this.locale)),a=Math.trunc(Li(s,this.locale));Ap(i,r),Dp(n),Op(a);const l=nm.compute.bind(this)(e,t,o,s).value;if([1,2,3].includes(a))return i-l;if(4===a){const e=Zs(l,i,a);return Math.round(360*e)}const c=Yi(i,this.locale),h=Yi(l,this.locale),d=h.getFullYear(),u=c.getFullYear(),g=h.getMonth()+1,p=c.getMonth()+1;let m=h.getDate(),f=c.getDate();return 2===g&&2===p&&Ws(h)&&Ws(c)&&(f=30),31!==f||30!==m&&31!==m||(f=30),2===g&&Ws(h)&&(m=30),31===m&&(m=30),360*(u-d)+30*(p-g)+(f-m)},isExported:!0},sm={description:Oo("Days from settlement until next coupon."),args:Kp,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Li(e,this.locale)),r=Math.trunc(Li(t,this.locale)),n=Math.trunc(Li(o,this.locale)),a=Math.trunc(Li(s,this.locale));Ap(i,r),Dp(n),Op(a);const l=im.compute.bind(this)(e,t,o,s).value;if([1,2,3].includes(a))return l-i;if(4===a){const e=Zs(i,l,a);return Math.round(360*e)}const c=om.compute.bind(this)(e,t,o,s);return tm.compute.bind(this)(e,t,o,s)-c},isExported:!0},im={description:Oo("Next coupon date after the settlement date."),args:Kp,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Li(e,this.locale)),r=Math.trunc(Li(t,this.locale)),n=Math.trunc(Li(o,this.locale)),a=Math.trunc(Li(s,this.locale));Ap(i,r),Dp(n),Op(a);const l=12/n,c=rm.compute.bind(this)(e,t,o,s);return{value:Bs(Gs(Yi(r,this.locale),-(c-1)*l,!0)),format:this.locale.dateFormat}},isExported:!0},rm={description:Oo("Number of coupons between settlement and maturity."),args:Kp,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Li(e,this.locale)),r=Math.trunc(Li(t,this.locale)),n=Math.trunc(Li(o,this.locale)),a=Math.trunc(Li(s,this.locale));Ap(i,r),Dp(n),Op(a);let l=1,c=r;const h=12/n;for(;c>i;)c=Bs(Gs(Yi(c,this.locale),-h,!1)),l++;return l-1},isExported:!0},nm={description:Oo("Last coupon date prior to or on the settlement date."),args:Kp,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Li(e,this.locale)),r=Math.trunc(Li(t,this.locale)),n=Math.trunc(Li(o,this.locale)),a=Math.trunc(Li(s,this.locale));Ap(i,r),Dp(n),Op(a);const l=12/n,c=rm.compute.bind(this)(e,t,o,s);return{value:Bs(Gs(Yi(r,this.locale),-c*l,!0)),format:this.locale.dateFormat}},isExported:!0},am={description:Oo("Cumulative interest paid over a set of periods."),args:[wh("rate (number)",Oo("The interest rate.")),wh("number_of_periods (number)",Oo("The number of payments to be made.")),wh("present_value (number)",Oo("The current value of the annuity.")),wh("first_period (number)",Oo("The number of the payment period to begin the cumulative calculation.")),wh("last_period (number)",Oo("The number of the payment period to end the cumulative calculation.")),wh("end_or_beginning (number, default=0)",Oo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s,i,r={value:0}){const n=Li(s,this.locale),a=Li(i,this.locale),l=Li(e,this.locale),c=Li(o,this.locale),h=Li(t,this.locale),d=ji(r)?1:0;Zp(n,a,h),Np(l),Up(c);let u=0;for(let e=n;e<=a;e++)u+=Cm(l,e,h,c,0,d);return u},isExported:!0},lm={description:Oo("Cumulative principal paid over a set of periods."),args:[wh("rate (number)",Oo("The interest rate.")),wh("number_of_periods (number)",Oo("The number of payments to be made.")),wh("present_value (number)",Oo("The current value of the annuity.")),wh("first_period (number)",Oo("The number of the payment period to begin the cumulative calculation.")),wh("last_period (number)",Oo("The number of the payment period to end the cumulative calculation.")),wh("end_or_beginning (number, default=0)",Oo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s,i,r={value:0}){const n=Li(s,this.locale),a=Li(i,this.locale),l=Li(e,this.locale),c=Li(o,this.locale),h=Li(t,this.locale),d=ji(r)?1:0;Zp(n,a,h),Np(l),Up(c);let u=0;for(let e=n;e<=a;e++)u+=Pm(l,e,h,c,0,d);return u},isExported:!0},cm={description:Oo("Depreciation via declining balance method."),args:[wh("cost (number)",Oo("The initial cost of the asset.")),wh("salvage (number)",Oo("The value of the asset at the end of depreciation.")),wh("life (number)",Oo("The number of periods over which the asset is depreciated.")),wh("period (number)",Oo("The single period within life for which to calculate depreciation.")),wh("month (number, optional)",Oo("The number of months in the first year of depreciation."))],compute:function(e,t,o,s,...i){const r=Li(e,this.locale),n=Li(t,this.locale),a=Li(o,this.locale),l=Math.trunc(Li(s,this.locale)),c=i.length?Math.trunc(Li(i[0],this.locale)):12,h=a+(12===c?0:1);Lp(r),Hp(n),Vp(l),kp(a),Mi((()=>1<=c&&c<=12),Oo("The month (%s) must be between 1 and 12 inclusive.",c.toString())),Mi((()=>l<=h),Oo("The period (%s) must be less than or equal to %s.",l.toString(),h.toString()));const d=c/12;let u=1-Math.pow(n/r,1/a);u=Math.round(1e3*u)/1e3;let g=r,p=r*(1-u*d);for(let e=1;e<l;e++)g=p,p=g*(1-u),e===a&&(p=g*(1-u*(1-d)));return{value:g-p,format:"#,##0.00"}},isExported:!0};function hm(e,t,o,s,i){if(Lp(e),Hp(t),Vp(s),kp(o),Bp(s,o),Gp(i),0===e||t>=e)return 0;const r=i/o;if(r>1)return 1===s?e-t:0;if(s<=1)return e*r;const n=e*Math.pow(1-r,s-1),a=e*Math.pow(1-r,s),l=a<t?n-t:n-a;return Math.max(l,0)}const dm={description:Oo("Depreciation via double-declining balance method."),args:[wh("cost (number)",Oo("The initial cost of the asset.")),wh("salvage (number)",Oo("The value of the asset at the end of depreciation.")),wh("life (number)",Oo("The number of periods over which the asset is depreciated.")),wh("period (number)",Oo("The single period within life for which to calculate depreciation.")),wh("factor (number, default=2)",Oo("The factor by which depreciation decreases."))],compute:function(e,t,o,s,i={value:2}){return{value:hm(Li(e,this.locale),Li(t,this.locale),Li(o,this.locale),Li(s,this.locale),Li(i,this.locale)),format:"#,##0.00"}},isExported:!0},um={description:Oo("Discount rate of a security based on price."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("price (number)",Oo("The price at which the security is bought per 100 face value.")),wh("redemption (number)",Oo("The redemption amount per 100 face value, or par.")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){i=i||0;const r=Math.trunc(Li(e,this.locale)),n=Math.trunc(Li(t,this.locale)),a=Li(o,this.locale),l=Li(s,this.locale),c=Math.trunc(Li(i,this.locale));Ap(r,n),Op(c),Mp(a),Fp(l);return(l-a)/l/Zs(r,n,c)},isExported:!0},gm={description:Oo("Convert a decimal fraction to decimal value."),args:[wh("fractional_price (number)",Oo("The price quotation given using fractional decimal conventions.")),wh("unit (number)",Oo("The units of the fraction, e.g. 8 for 1/8ths or 32 for 1/32nds."))],compute:function(e,t){const o=Li(e,this.locale),s=Math.trunc(Li(t,this.locale));Mi((()=>s>0),Oo("The unit (%s) must be strictly positive.",s.toString()));const i=Math.trunc(o);return i+(o-i)*(10**Math.ceil(Math.log10(s))/s)},isExported:!0},pm={description:Oo("Convert a decimal value to decimal fraction."),args:[wh("decimal_price (number)",Oo("The price quotation given as a decimal value.")),wh("unit (number)",Oo("The units of the desired fraction, e.g. 8 for 1/8ths or 32 for 1/32nds."))],compute:function(e,t){const o=Li(e,this.locale),s=Math.trunc(Li(t,this.locale));Mi((()=>s>0),Oo("The unit (%s) must be strictly positive.",s.toString()));const i=Math.trunc(o);return i+(o-i)*(s/10**Math.ceil(Math.log10(s)))},isExported:!0},mm={description:Oo("Number of periods for an investment to reach a value."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("rate (number)",Oo("The annualized rate of interest.")),wh("yield (number)",Oo("The expected annual yield of the security.")),wh("frequency (number)",Oo("The number of interest or coupon payments per year (1, 2, or 4).")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,r={value:0}){const n=Math.trunc(Li(e,this.locale)),a=Math.trunc(Li(t,this.locale)),l=Li(o,this.locale),c=Li(s,this.locale),h=Math.trunc(Li(i,this.locale)),d=Math.trunc(Li(r,this.locale));Ap(n,a),Dp(h),Op(d),Mi((()=>l>=0),Oo("The rate (%s) must be positive or null.",l.toString())),Mi((()=>c>=0),Oo("The yield (%s) must be positive or null.",c.toString()));const u=Zs(n,a,d),g=u-Math.trunc(u)||1/h,p=Math.ceil(u*h),m=l/h,f=c/h;let v=0,b=0;for(let e=1;e<=p;e++){const t=(m+(e===p?1:0))/(1+f)**e;b+=(g+(e-1)/h)*t,v+=t}return 0===v?0:b/v},isExported:!0},fm={description:Oo("Annual effective interest rate."),args:[wh("nominal_rate (number)",Oo("The nominal interest rate per year.")),wh("periods_per_year (number)",Oo("The number of compounding periods per year."))],compute:function(e,t){const o=Li(e,this.locale),s=Math.trunc(Li(t,this.locale));return Mi((()=>o>0),Oo("The nominal rate (%s) must be strictly greater than 0.",o.toString())),Mi((()=>s>0),Oo("The number of periods by year (%s) must strictly greater than 0.",s.toString())),Math.pow(1+o/s,s)-1},isExported:!0};function vm(e,t,o,s,i){return 0===e?-(s+o*t):-s*(1+e)**t-o*(1+e*i)*((1+e)**t-1)/e}const bm={description:Oo("Future value of an annuity investment."),args:[wh("rate (number)",Oo("The interest rate.")),wh("number_of_periods (number)",Oo("The number of payments to be made.")),wh("payment_amount (number)",Oo("The amount per period to be paid.")),wh("present_value (number, default=0)",Oo("The current value of the annuity.")),wh("end_or_beginning (number, default=0)",Oo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s={value:0},i={value:0}){s=s||0,i=i||0;return{value:vm(Li(e,this.locale),Li(t,this.locale),Li(o,this.locale),Li(s,this.locale),ji(i)?1:0),format:"#,##0.00"}},isExported:!0},Sm={description:Oo("Future value of principal from series of rates."),args:[wh("principal (number)",Oo("The amount of initial capital or value to compound against.")),wh("rate_schedule (number, range<number>)",Oo("A series of interest rates to compound against the principal."))],compute:function(e,t){return tr([t],((e,t)=>e*(1+Li(t,this.locale))),Li(e,this.locale))},isExported:!0},ym={description:Oo("Calculates effective interest rate."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("investment (number)",Oo("The amount invested in the security.")),wh("redemption (number)",Oo("The amount to be received at maturity.")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){const r=Math.trunc(Li(e,this.locale)),n=Math.trunc(Li(t,this.locale)),a=Li(s,this.locale),l=Li(o,this.locale),c=Math.trunc(Li(i,this.locale));Ap(r,n),zp(l),Fp(a),Op(c);return(a-l)/l/Zs(r,n,c)},isExported:!0};function Cm(e,t,o,s,i,r){return Fm(e,o,s,i,r)-Pm(e,t,o,s,i,r)}const wm={description:Oo("Payment on the principal of an investment."),args:[wh("rate (number)",Oo("The annualized rate of interest.")),wh("period (number)",Oo("The amortization period, in terms of number of periods.")),wh("number_of_periods (number)",Oo("The number of payments to be made.")),wh("present_value (number)",Oo("The current value of the annuity.")),wh("future_value (number, default=0)",Oo("The future value remaining after the final payment has been made.")),wh("end_or_beginning (number, default=0)",Oo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s,i={value:0},r={value:0}){return{value:Cm(Li(e,this.locale),Li(t,this.locale),Li(o,this.locale),Li(s,this.locale),Li(i,this.locale),ji(r)?1:0),format:"#,##0.00"}},isExported:!0},Em={description:Oo("Internal rate of return given periodic cashflows."),args:[wh("cashflow_amounts (number, range<number>)",Oo("An array or range containing the income or payments associated with the investment.")),wh("rate_guess (number, default=0.1)",Oo("An estimate for what the internal rate of return will be."))],compute:function(e,t={value:.1}){const o=Li(t,this.locale);jp(o);let s=!1,i=!1,r=[];Qi([e],(({value:e})=>{e>0&&(s=!0),e<0&&(i=!0),r.push(e)}),this.locale),Mi((()=>s&&i),Oo("The cashflow_amounts must include negative and positive values."));const n=r.shift();return{value:Jp((function(e){return function(e,t,o){const s=o.length;let i=0;return o.reduce(((t,o)=>(i++,t+o*e**(s-i))),t*e**s)}(e,n,r)}),(function(e){return function(e,t,o){const s=o.length;let i=0;return o.reduce(((t,o)=>(i++,t+o*(s-i)*e**(s-i-1))),t*s*e**(s-1))}(e,n,r)}),o+1,20,1e-5)-1,format:"0%"}},isExported:!0},xm={description:Oo("Returns the interest paid at a particular period of an investment."),args:[wh("rate (number)",Oo("The interest rate.")),wh("period (number)",Oo("The period for which you want to view the interest payment.")),wh("number_of_periods (number)",Oo("The number of payments to be made.")),wh("present_value (number)",Oo("The current value of the annuity."))],compute:function(e,t,o,s){const i=Li(e,this.locale),r=Li(t,this.locale),n=Li(o,this.locale),a=Li(s,this.locale);Mi((()=>0!==n),Oo("The number of periods must be different than 0.",n.toString()));return-1*(a-a*(r/n))*i},isExported:!0},Im={description:Oo("Modified Macaulay duration."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("rate (number)",Oo("The annualized rate of interest.")),wh("yield (number)",Oo("The expected annual yield of the security.")),wh("frequency (number)",Oo("The number of interest or coupon payments per year (1, 2, or 4).")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,r={value:0}){return mm.compute.bind(this)(e,t,o,s,i,r)/(1+Li(s,this.locale)/Math.trunc(Li(i,this.locale)))},isExported:!0},Rm={description:Oo("Modified internal rate of return."),args:[wh("cashflow_amounts (range<number>)",Oo("A range containing the income or payments associated with the investment. The array should contain bot payments and incomes.")),wh("financing_rate (number)",Oo("The interest rate paid on funds invested.")),wh("reinvestment_return_rate (number)",Oo("The return (as a percentage) earned on reinvestment of income received from the investment."))],compute:function(e,t,o){const s=Li(t,this.locale),i=Li(o,this.locale),r=nr(e).flat().filter((e=>null!==e.value)).map((e=>Li(e,this.locale))),n=r.length;let a=0,l=0;for(const e of Ze(0,n)){const t=r[e];t>=0?a+=t*(i+1)**(n-e-1):l+=t/(s+1)**e}Mi((()=>0!==l&&0!==a),Oo("There must be both positive and negative values in cashflow_amounts."));return(-a/l)**(1/(n-1))-1},isExported:!0},Tm={description:Oo("Annual nominal interest rate."),args:[wh("effective_rate (number)",Oo("The effective interest rate per year.")),wh("periods_per_year (number)",Oo("The number of compounding periods per year."))],compute:function(e,t){const o=Li(e,this.locale),s=Math.trunc(Li(t,this.locale));return Mi((()=>o>0),Oo("The effective rate (%s) must must strictly greater than 0.",o.toString())),Mi((()=>s>0),Oo("The number of periods by year (%s) must strictly greater than 0.",s.toString())),(Math.pow(o+1,1/s)-1)*s},isExported:!0},Am={description:Oo("Number of payment periods for an investment."),args:[wh("rate (number)",Oo("The interest rate.")),wh("payment_amount (number)",Oo("The amount of each payment made.")),wh("present_value (number)",Oo("The current value of the annuity.")),wh("future_value (number, default=0)",Oo("The future value remaining after the final payment has been made.")),wh("end_or_beginning (number, default=0)",Oo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s={value:0},i={value:0}){s=s||0,i=i||0;const r=Li(e,this.locale),n=Li(t,this.locale),a=Li(o,this.locale),l=Li(s,this.locale),c=ji(i)?1:0;if(0===r)return-(l+a)/n;const h=n*(1+r*c)/r;return Math.log((h-l)/(a+h))/Math.log(1+r)},isExported:!0};function _m(e,t,o,s){let i=0;return or(o,((t,o)=>(i++,t+o/(1+e)**i)),t,s)}const Dm={description:Oo("The net present value of an investment based on a series of periodic cash flows and a discount rate."),args:[wh("discount (number)",Oo("The discount rate of the investment over one period.")),wh("cashflow1 (number, range<number>)",Oo("The first future cash flow.")),wh("cashflow2 (number, range<number>, repeating)",Oo("Additional future cash flows."))],compute:function(e,...t){const o=Li(e,this.locale);return Mi((()=>-1!==o),Oo("The discount (%s) must be different from -1.",o.toString())),{value:_m(o,0,t,this.locale),format:"#,##0.00"}},isExported:!0},Om={description:Oo("Computes the number of periods needed for an investment to reach a value."),args:[wh("rate (number)",Oo("The rate at which the investment grows each period.")),wh("present_value (number)",Oo("The investment's current value.")),wh("future_value (number)",Oo("The investment's desired future value."))],compute:function(e,t,o){const s=Li(e,this.locale),i=Li(t,this.locale),r=Li(o,this.locale);return Np(s),Mi((()=>i>0),Oo("The present_value (%s) must be strictly positive.",i.toString())),Mi((()=>r>0),Oo("The future_value (%s) must be strictly positive.",r.toString())),(Math.log(r)-Math.log(i))/Math.log(1+s)},isExported:!0};function Fm(e,t,o,s,i){if(Pp(t),0===e)return-(s+o)/t;let r=-(o*(1+e)**t+s);return r=r*e/((1+e*i)*((1+e)**t-1)),r}const Mm={description:Oo("Periodic payment for an annuity investment."),args:[wh("rate (number)",Oo("The annualized rate of interest.")),wh("number_of_periods (number)",Oo("The number of payments to be made.")),wh("present_value (number)",Oo("The current value of the annuity.")),wh("future_value (number, default=0)",Oo("The future value remaining after the final payment has been made.")),wh("end_or_beginning (number, default=0)",Oo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s={value:0},i={value:0}){const r=Li(t,this.locale),n=Li(e,this.locale),a=ji(i)?1:0,l=Li(s,this.locale);return{value:Fm(n,r,Li(o,this.locale),l,a),format:"#,##0.00"}},isExported:!0};function Pm(e,t,o,s,i,r){Pp(o),Mi((()=>t>0&&t<=o),Oo("The period must be between 1 and number_of_periods (%s)",o));const n=Fm(e,o,s,i,r);if(1===r&&1===t)return n;return n+-vm(e,0===r?t-1:t-2,n,s+n*r,0)*e}const Nm={description:Oo("Payment on the principal of an investment."),args:[wh("rate (number)",Oo("The annualized rate of interest.")),wh("period (number)",Oo("The amortization period, in terms of number of periods.")),wh("number_of_periods (number)",Oo("The number of payments to be made.")),wh("present_value (number)",Oo("The current value of the annuity.")),wh("future_value (number, default=0)",Oo("The future value remaining after the final payment has been made.")),wh("end_or_beginning (number, default=0)",Oo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s,i={value:0},r={value:0}){const n=Li(o,this.locale),a=Li(e,this.locale),l=Li(t,this.locale),c=ji(r)?1:0,h=Li(i,this.locale);return{value:Pm(a,l,n,Li(s,this.locale),h,c),format:"#,##0.00"}},isExported:!0},km={description:Oo("Present value of an annuity investment."),args:[wh("rate (number)",Oo("The interest rate.")),wh("number_of_periods (number)",Oo("The number of payments to be made.")),wh("payment_amount (number)",Oo("The amount per period to be paid.")),wh("future_value (number, default=0)",Oo("The future value remaining after the final payment has been made.")),wh("end_or_beginning (number, default=0)",Oo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s={value:0},i={value:0}){s=s||0,i=i||0;const r=Li(e,this.locale),n=Li(t,this.locale),a=Li(o,this.locale),l=Li(s,this.locale),c=ji(i)?1:0;return{value:r?-(a*(1+r*c)*((1+r)**n-1)/r+l)/(1+r)**n:-(l+a*n),format:"#,##0.00"}},isExported:!0},Lm={description:Oo("Price of a security paying periodic interest."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("rate (number)",Oo("The annualized rate of interest.")),wh("yield (number)",Oo("The expected annual yield of the security.")),wh("redemption (number)",Oo("The redemption amount per 100 face value, or par.")),wh("frequency (number)",Oo("The number of interest or coupon payments per year (1, 2, or 4).")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,r,n={value:0}){n=n||0;const a=Math.trunc(Li(e,this.locale)),l=Math.trunc(Li(t,this.locale)),c=Li(o,this.locale),h=Li(s,this.locale),d=Li(i,this.locale),u=Math.trunc(Li(r,this.locale)),g=Math.trunc(Li(n,this.locale));Ap(a,l),Dp(u),Op(g),Mi((()=>c>=0),Oo("The rate (%s) must be positive or null.",c.toString())),Mi((()=>h>=0),Oo("The yield (%s) must be positive or null.",h.toString())),Fp(d);const p=Zs(a,l,g)*u,m=Math.ceil(p),f=p-Math.floor(p)||1,v=1+h/u,b=100*c/u;if(1===m)return(b+d)/(f*h/u+1)-b*(1-f);let S=0;for(let e=1;e<=m;e++)S+=b/v**(e-1+f);return d/v**(m-1+f)+S-b*(1-f)},isExported:!0},Vm={description:Oo("Price of a discount security."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("discount (number)",Oo("The discount rate of the security at time of purchase.")),wh("redemption (number)",Oo("The redemption amount per 100 face value, or par.")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){i=i||0;const r=Math.trunc(Li(e,this.locale)),n=Math.trunc(Li(t,this.locale)),a=Li(o,this.locale),l=Li(s,this.locale),c=Math.trunc(Li(i,this.locale));Ap(r,n),Op(c),$p(a),Fp(l);return l-a*l*Zs(r,n,c)},isExported:!0},Hm={description:Oo("Calculates the price of a security paying interest at maturity, based on expected yield."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("issue (date)",Oo("The date the security was initially issued.")),wh("rate (number)",Oo("The annualized rate of interest.")),wh("yield (number)",Oo("The expected annual yield of the security.")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,r={value:0}){r=r||0;const n=Math.trunc(Li(e,this.locale)),a=Math.trunc(Li(t,this.locale)),l=Math.trunc(Li(o,this.locale)),c=Li(s,this.locale),h=Li(i,this.locale),d=Math.trunc(Li(r,this.locale));_p(n,l),Ap(n,a),Op(d),Mi((()=>c>=0),Oo("The rate (%s) must be positive or null.",c.toString())),Mi((()=>h>=0),Oo("The yield (%s) must be positive or null.",h.toString()));const u=Zs(n,a,d),g=Zs(n,l,d);return(100+Zs(l,a,d)*c*100)/(1+u*h)-g*c*100},isExported:!0},Um=.1,Bm={description:Oo("Interest rate of an annuity investment."),args:[wh("number_of_periods (number)",Oo("The number of payments to be made.")),wh("payment_per_period (number)",Oo("The amount per period to be paid.")),wh("present_value (number)",Oo("The current value of the annuity.")),wh("future_value (number, default=0)",Oo("The future value remaining after the final payment has been made.")),wh("end_or_beginning (number, default=0)",Oo("Whether payments are due at the end (0) or beginning (1) of each period.")),wh("rate_guess (number, default=0.1)",Oo("An estimate for what the interest rate will be."))],compute:function(e,t,o,s={value:0},i={value:0},r={value:Um}){const n=Li(e,this.locale),a=Li(t,this.locale),l=ji(i)?1:0,c=Li(r,this.locale)||Um;let h=Li(s,this.locale),d=Li(o,this.locale);Pp(n),Mi((()=>[a,d,h].some((e=>e>0))&&[a,d,h].some((e=>e<0))),Oo("There must be both positive and negative values in [payment_amount, present_value, future_value].",n.toString())),jp(c),h-=a*l,d+=a*l;return{value:Jp((e=>{const t=Math.pow(1+e,n);return h+d*t+a*((t-1)/e)}),(e=>{const t=Math.pow(1+e,n-1),o=Math.pow(1+e,n);return d*n*t+a*(n*t/e-(o-1)/e/e)}),c,40,1e-5),format:"0%"}},isExported:!0},zm={description:Oo("Amount received at maturity for a security."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("investment (number)",Oo("The amount invested (irrespective of face value of each security).")),wh("discount (number)",Oo("The discount rate of the security invested in.")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){i=i||0;const r=Math.trunc(Li(e,this.locale)),n=Math.trunc(Li(t,this.locale)),a=Li(o,this.locale),l=Li(s,this.locale),c=Math.trunc(Li(i,this.locale));Ap(r,n),Op(c),zp(a),$p(l);return a/(1-l*Zs(r,n,c))},isExported:!0},$m={description:Oo("Computes the rate needed for an investment to reach a specific value within a specific number of periods."),args:[wh("number_of_periods (number)",Oo("The number of periods.")),wh("present_value (number)",Oo("The present value of the investment.")),wh("future_value (number)",Oo("The future value of the investment."))],compute:function(e,t,o){const s=Li(e,this.locale),i=Li(t,this.locale),r=Li(o,this.locale);return Pp(s),(r/i)**(1/s)-1},isExported:!0},Wm={description:Oo("Depreciation of an asset using the straight-line method."),args:[wh("cost (number)",Oo("The initial cost of the asset.")),wh("salvage (number)",Oo("The value of the asset at the end of depreciation.")),wh("life (number)",Oo("The number of periods over which the asset is depreciated."))],compute:function(e,t,o){return{value:(Li(e,this.locale)-Li(t,this.locale))/Li(o,this.locale),format:"#,##0.00"}},isExported:!0},Gm={description:Oo("Depreciation via sum of years digit method."),args:[wh("cost (number)",Oo("The initial cost of the asset.")),wh("salvage (number)",Oo("The value of the asset at the end of depreciation.")),wh("life (number)",Oo("The number of periods over which the asset is depreciated.")),wh("period (number)",Oo("The single period within life for which to calculate depreciation."))],compute:function(e,t,o,s){const i=Li(e,this.locale),r=Li(t,this.locale),n=Li(o,this.locale),a=Li(s,this.locale);Vp(a),kp(n),Bp(a,n);return{value:(n-a+1)/(n*(n+1)/2)*(i-r),format:"#,##0.00"}},isExported:!0};function qm(e,t,o){return 100*(1-o*Zs(e,t,2))}const Zm={description:Oo("Price of a US Treasury bill."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("discount (number)",Oo("The discount rate of the bill at time of purchase."))],compute:function(e,t,o){const s=Math.trunc(Li(e,this.locale)),i=Math.trunc(Li(t,this.locale)),r=Li(o,this.locale);return Ap(s,i),qp(s,i,this.locale),$p(r),Wp(r),qm(s,i,r)},isExported:!0},jm={description:Oo("Equivalent rate of return for a US Treasury bill."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("discount (number)",Oo("The discount rate of the bill at time of purchase."))],compute:function(e,t,o){const s=Math.trunc(Li(e,this.locale)),i=Math.trunc(Li(t,this.locale)),r=Li(o,this.locale);Ap(s,i),qp(s,i,this.locale),$p(r),Wp(r);const n=Ug.compute.bind(this)({value:i},{value:s});if(n<=182)return 365*r/(360-r*n);const a=qm(s,i,r)/100,l=n/(366===n?366:365);return(-2*l+2*Math.sqrt(l**2-(2*l-1)*(1-1/a)))/(2*l-1)},isExported:!0},Ym={description:Oo("The yield of a US Treasury bill based on price."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("price (number)",Oo("The price at which the security is bought per 100 face value."))],compute:function(e,t,o){const s=Math.trunc(Li(e,this.locale)),i=Math.trunc(Li(t,this.locale)),r=Li(o,this.locale);Ap(s,i),qp(s,i,this.locale),Mp(r);return(100-r)/r*(1/Zs(s,i,2))},isExported:!0},Xm={description:Oo("Variable declining balance. WARNING : does not handle decimal periods."),args:[wh("cost (number)",Oo("The initial cost of the asset.")),wh("salvage (number)",Oo("The value of the asset at the end of depreciation.")),wh("life (number)",Oo("The number of periods over which the asset is depreciated.")),wh("start (number)",Oo("Starting period to calculate depreciation.")),wh("end (number)",Oo("Ending period to calculate depreciation.")),wh("factor (number, default=2)",Oo("The number of months in the first year of depreciation.")),wh("no_switch (number, default=false)",Oo("Whether to switch to straight-line depreciation when the depreciation is greater than the declining balance calculation."))],compute:function(e,t,o,s,i,r={value:2},n={value:false}){r=r||0;const a=Li(e,this.locale),l=Li(t,this.locale),c=Li(o,this.locale),h=Math.trunc(Li(s,this.locale)),d=Math.trunc(Li(i,this.locale)),u=Li(r,this.locale),g=ji(n);if(Lp(a),Hp(l),function(e,t,o){kp(o),Mi((()=>e>=0),Oo("The start_period (%s) must be greater or equal than 0.",e.toString())),Mi((()=>t>=0),Oo("The end_period (%s) must be greater or equal than 0.",t.toString())),Mi((()=>e<=t),Oo("The start_period (%s) must be smaller or equal to the end_period (%s).",e.toString(),t.toString())),Mi((()=>t<=o),Oo("The end_period (%s) must be smaller or equal to the life (%s).",e.toString(),o.toString()))}(h,d,c),Gp(u),0===a)return 0;if(l>=a)return h<1?a-l:0;const p=u/c;if(p>=1)return h<1?a-l:0;let m=a,f=0,v=0,b=!1;for(let e=0;e<d;e++){if(!b||g){const t=m*p,o=(m-l)/(c-e);!g&&o>t?(b=!0,f=o):f=t}const t=Math.max(m-f,l);e>=h&&(v+=m-t),m=t}return v},isExported:!0},Km={description:Oo("Internal rate of return given non-periodic cash flows."),args:[wh("cashflow_amounts (range<number>)",Oo("An range containing the income or payments associated with the investment.")),wh("cashflow_dates (range<number>)",Oo("An range with dates corresponding to the cash flows in cashflow_amounts.")),wh("rate_guess (number, default=0.1)",Oo("An estimate for what the internal rate of return will be."))],compute:function(e,t,o={value:Um}){const s=Li(o,this.locale),i=e.flat().map((e=>Li(e,this.locale))),r=t.flat().map((e=>Li(e,this.locale)));var n;Yp(e,t),n=i,Mi((()=>n.some((e=>e>0))&&n.some((e=>e<0))),Oo("There must be both positive and negative values in cashflow_amounts.")),Xp(r),jp(s);const a=new Map;for(const e of Ze(0,r.length)){const t=r[e];a.has(t)?a.set(t,a.get(t)+i[e]):a.set(t,i[e])}const l=Array.from(a.keys()),c=l.map((e=>a.get(e)));return Jp((e=>{let t=c[0];for(const o of Ze(1,c.length)){const s=(l[0]-l[o])/365;t+=c[o]*(1+e)**s}return t}),(e=>{let t=0;for(const o of Ze(1,c.length)){const s=(l[0]-l[o])/365;t+=s*c[o]*(1+e)**(s-1)}return t}),s,40,1e-5,(e=>e?e/10-.9:-.9))},isExported:!0},Jm={description:Oo("Net present value given to non-periodic cash flows.."),args:[wh("discount (number)",Oo("The discount rate of the investment over one period.")),wh("cashflow_amounts (number, range<number>)",Oo("An range containing the income or payments associated with the investment.")),wh("cashflow_dates (number, range<number>)",Oo("An range with dates corresponding to the cash flows in cashflow_amounts."))],compute:function(e,t,o){const s=Li(e,this.locale),i=yi(t)?t.flat().map((e=>Ui(e,this.locale))):[Ui(t,this.locale)],r=yi(o)?o.flat().map((e=>Ui(e,this.locale))):[Ui(o,this.locale)];if(yi(o)&&yi(t)?Yp(t,o):Mi((()=>i.length===r.length),Oo("There must be the same number of values in cashflow_amounts and cashflow_dates.")),Xp(r),Np(s),1===i.length)return i[0];const n=new Map;for(const e of Ze(0,r.length)){const t=r[e];n.has(t)?n.set(t,n.get(t)+i[e]):n.set(t,i[e])}const a=Array.from(n.keys()),l=a.map((e=>n.get(e)));let c=l[0];for(const e of Ze(1,l.length)){const t=(a[0]-a[e])/365;c+=l[e]*(1+s)**t}return c},isExported:!0},Qm={description:Oo("Annual yield of a security paying periodic interest."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("rate (number)",Oo("The annualized rate of interest.")),wh("price (number)",Oo("The price at which the security is bought per 100 face value.")),wh("redemption (number)",Oo("The redemption amount per 100 face value, or par.")),wh("frequency (number)",Oo("The number of interest or coupon payments per year (1, 2, or 4).")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,r,n={value:0}){n=n||0;const a=Math.trunc(Li(e,this.locale)),l=Math.trunc(Li(t,this.locale)),c=Li(o,this.locale),h=Li(s,this.locale),d=Li(i,this.locale),u=Math.trunc(Li(r,this.locale)),g=Math.trunc(Li(n,this.locale));Ap(a,l),Dp(u),Op(g),Mi((()=>c>=0),Oo("The rate (%s) must be positive or null.",c.toString())),Mp(h),Fp(d);const p=Zs(a,l,g)*u,m=Math.ceil(p),f=p-Math.floor(p)||1,v=100*c/u;if(1===m){const e=h+v*(1-f);return(d+v-e)*u*(1/f)/e}const b=Jp((function(e){return function(e,t,o,s,i,r){let n=r-(e+i*(1-t))*s**(o-1+t);for(let e=1;e<=o;e++)n+=i*s**(e-1);return n}(h,f,m,e,v,d)}),(function(e){return function(e,t,o,s,i){let r=-(e+i*(1-t))*(o-1+t)*s**(o-2+t);for(let e=1;e<=o;e++)r+=i*(e-1)*s**(e-2);return r}(h,f,m,e,v)}),1+(c+1)/u,100,1e-5);return(b-1)*u},isExported:!0},ef={description:Oo("Annual yield of a discount security."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("price (number)",Oo("The price at which the security is bought per 100 face value.")),wh("redemption (number)",Oo("The redemption amount per 100 face value, or par.")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){i=i||0;const r=Math.trunc(Li(e,this.locale)),n=Math.trunc(Li(t,this.locale)),a=Li(o,this.locale),l=Li(s,this.locale),c=Math.trunc(Li(i,this.locale));Ap(r,n),Op(c),Mp(a),Fp(l);return(l/a-1)/Zs(r,n,c)},isExported:!0},tf={description:Oo("Annual yield of a security paying interest at maturity."),args:[wh("settlement (date)",Oo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),wh("maturity (date)",Oo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),wh("issue (date)",Oo("The date the security was initially issued.")),wh("rate (number)",Oo("The annualized rate of interest.")),wh("price (number)",Oo("The price at which the security is bought.")),wh("day_count_convention (number, default=0 )",Oo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,r={value:0}){r=r||0;const n=Math.trunc(Li(e,this.locale)),a=Math.trunc(Li(t,this.locale)),l=Math.trunc(Li(o,this.locale)),c=Li(s,this.locale),h=Li(i,this.locale),d=Math.trunc(Li(r,this.locale));Ap(n,a),Op(d),Mi((()=>n>=l),Oo("The settlement (%s) must be greater than or equal to the issue (%s).",n.toString(),l.toString())),Mi((()=>c>=0),Oo("The rate (%s) must be positive or null.",c.toString())),Mp(h);const u=Zs(l,a,d),g=Zs(l,n,d),p=Zs(n,a,d);return(100*(1+c*u)/(h+100*c*g)-1)/p},isExported:!0};var of,sf=Object.freeze({__proto__:null,ACCRINTM:Qp,AMORLINC:em,COUPDAYBS:om,COUPDAYS:tm,COUPDAYSNC:sm,COUPNCD:im,COUPNUM:rm,COUPPCD:nm,CUMIPMT:am,CUMPRINC:lm,DB:cm,DDB:dm,DISC:um,DOLLARDE:gm,DOLLARFR:pm,DURATION:mm,EFFECT:fm,FV:bm,FVSCHEDULE:Sm,INTRATE:ym,IPMT:wm,IRR:Em,ISPMT:xm,MDURATION:Im,MIRR:Rm,NOMINAL:Tm,NPER:Am,NPV:Dm,PDURATION:Om,PMT:Mm,PPMT:Nm,PRICE:Lm,PRICEDISC:Vm,PRICEMAT:Hm,PV:km,RATE:Bm,RECEIVED:zm,RRI:$m,SLN:Wm,SYD:Gm,TBILLEQ:jm,TBILLPRICE:Zm,TBILLYIELD:Ym,VDB:Xm,XIRR:Km,XNPV:Jm,YIELD:Qm,YIELDDISC:ef,YIELDMAT:tf});!function(e){e[e.LeftRef=0]="LeftRef",e[e.RightRef=1]="RightRef",e[e.Separator=2]="Separator",e[e.FullColumnSeparator=3]="FullColumnSeparator",e[e.FullRowSeparator=4]="FullRowSeparator",e[e.RightColumnRef=5]="RightColumnRef",e[e.RightRowRef=6]="RightRowRef",e[e.Found=7]="Found"}(of||(of={}));const rf=(e,t=(()=>!0))=>[{goTo:e,guard:t}],nf=(e,t=(()=>!0))=>({goTo:e,guard:t}),af={[of.LeftRef]:{REFERENCE:rf(of.Separator),NUMBER:rf(of.FullRowSeparator),SYMBOL:[nf(of.FullColumnSeparator,(e=>Uo(e.value))),nf(of.FullRowSeparator,(e=>Bo(e.value)))]},[of.FullColumnSeparator]:{SPACE:rf(of.FullColumnSeparator),OPERATOR:rf(of.RightColumnRef,(e=>":"===e.value))},[of.FullRowSeparator]:{SPACE:rf(of.FullRowSeparator),OPERATOR:rf(of.RightRowRef,(e=>":"===e.value))},[of.Separator]:{SPACE:rf(of.Separator),OPERATOR:rf(of.RightRef,(e=>":"===e.value))},[of.RightRef]:{SPACE:rf(of.RightRef),NUMBER:rf(of.Found),REFERENCE:rf(of.Found,(e=>Wo(e.value))),SYMBOL:rf(of.Found,(e=>zo(e.value)||$o(e.value)))},[of.RightColumnRef]:{SPACE:rf(of.RightColumnRef),SYMBOL:rf(of.Found,(e=>zo(e.value))),REFERENCE:rf(of.Found,(e=>Wo(e.value)))},[of.RightRowRef]:{SPACE:rf(of.RightRowRef),NUMBER:rf(of.Found),REFERENCE:rf(of.Found,(e=>Wo(e.value))),SYMBOL:rf(of.Found,(e=>$o(e.value)))},[of.Found]:{}};function lf(e){let t=0,o=af[of.LeftRef],s="";for(;void 0!==o;){const i=e[t++];if(!i)return null;const r=o[i.type]?.find((e=>e.guard(i))),n=r?r.goTo:void 0;switch(n){case void 0:return null;case of.Found:return s+=i.value,e.splice(0,t),{type:"REFERENCE",value:s};default:o=af[n],s+=i.value}}return null}function cf(e,t=bi){const o=ma(e,t),s=[];for(;o.length;)s.push(lf(o)||o.shift());return s}const hf=/[a-zA-Z0-9\_]+(\.[a-zA-Z0-9\_]+)*/,df=["-","+"],uf=["%"],gf=["*","+","&"],pf={"^":30,"%":30,"*":20,"/":20,"+":15,"-":15,"&":13,">":10,"<>":10,">=":10,"<":10,"<=":10,"=":10};function mf(e){const t=e.shift();if(!t)throw new Ti;switch(t.type){case"DEBUGGER":const o=bf(e,1e3);return o.debug=!0,o;case"NUMBER":return{type:"NUMBER",value:oi(t.value,bi)};case"STRING":return{type:"STRING",value:He(t.value)};case"INVALID_REFERENCE":return{type:"REFERENCE",value:xi.InvalidReference};case"REFERENCE":if(":"===e[0]?.value&&"REFERENCE"===e[1]?.type){e.shift();const o=e.shift();return{type:"REFERENCE",value:`${t.value}:${o?.value}`}}return{type:"REFERENCE",value:t.value};case"SYMBOL":const s=t.value,i=e[0];if("LEFT_PAREN"===i?.type&&hf.test(t.value)&&s===$e(s,"'")){const t=function(e){vf(e,"LEFT_PAREN",Oo("Missing opening parenthesis"));const t=e[0];if("RIGHT_PAREN"===t?.type)return vf(e,"RIGHT_PAREN"),[];const o=[];o.push(ff(e));for(;"RIGHT_PAREN"!==e[0]?.type;)vf(e,"ARG_SEPARATOR",Oo("Wrong function call")),o.push(ff(e));return vf(e,"RIGHT_PAREN"),o}(e);return{type:"FUNCALL",value:s,args:t}}const r=s.toUpperCase();return"TRUE"===r||"FALSE"===r?{type:"BOOLEAN",value:"TRUE"===r}:{type:"SYMBOL",value:$e(t.value,"'")};case"LEFT_PAREN":const n=bf(e);return vf(e,"RIGHT_PAREN",Oo("Missing closing parenthesis")),n;case"OPERATOR":const a=t.value;if(df.includes(a))return{type:"UNARY_OPERATION",value:a,operand:bf(e,pf[a])};throw new Ti(Oo("Unexpected token: %s",t.value));default:throw new Ti(Oo("Unexpected token: %s",t.value))}}function ff(e){const t=e[0];return"ARG_SEPARATOR"===t?.type||"RIGHT_PAREN"===t?.type?{type:"EMPTY",value:""}:bf(e)}function vf(e,t,o){const s=e.shift();if(!s||s.type!==t)throw new Ti(o)}function bf(e,t=0){if(0===e.length)throw new Ti;let o=mf(e);for(;"OPERATOR"===e[0]?.type&&pf[e[0].value]>t;){const t=e.shift().value;if(uf.includes(t))o={type:"UNARY_OPERATION",value:t,operand:o,postfix:!0};else{o={type:"BIN_OPERATION",value:t,left:o,right:bf(e,pf[t])}}}return o}function Sf(e){return yf(cf(e))}function yf(e){e=e.filter((e=>"SPACE"!==e.type)),"="===e[0]?.value&&e.splice(0,1);const t=bf(e);if(e.length)throw new Ti;return t}function Cf(e,t,o){return xf(e,(e=>e.type===t?o(e):e))}function wf(e){return Array.from(Ef(e))}function*Ef(e){switch(yield e,e.type){case"FUNCALL":for(const t of e.args)yield*Ef(t);break;case"UNARY_OPERATION":yield*Ef(e.operand);break;case"BIN_OPERATION":yield*Ef(e.left),yield*Ef(e.right)}}function xf(e,t){switch((e=t(e)).type){case"FUNCALL":return{...e,args:e.args.map((e=>xf(e,t)))};case"UNARY_OPERATION":return{...e,operand:xf(e.operand,t)};case"BIN_OPERATION":return{...e,right:xf(e.right,t),left:xf(e.left,t)};default:return e}}function If(e){switch(e.type){case"FUNCALL":const t=e.args.map((e=>If(e)));return`${e.value}(${t.join(",")})`;case"NUMBER":return e.value.toString();case"REFERENCE":default:return e.value;case"STRING":return`"${e.value}"`;case"BOOLEAN":return e.value?"TRUE":"FALSE";case"UNARY_OPERATION":return e.postfix?Rf(e)+e.value:e.value+Tf(e);case"BIN_OPERATION":return Rf(e)+e.value+Tf(e)}}function Rf(e){const t=e.value,o="left"in e?e.left:e.operand,s=o.value;return"BIN_OPERATION"===o.type&&pf[s]<pf[t]?`(${If(o)})`:If(o)}function Tf(e){const t=e.value,o="right"in e?e.right:e.operand,s=pf[o.value],i=pf[t];let r=!1;return"BIN_OPERATION"!==o.type?r=!1:s<i?r=!0:s!==i||gf.includes(t)||(r=!0),r?`(${If(o)})`:If(o)}function Af(e,t){return function(e){for(const t of e)if(t.functionContext){const{argsTokens:e,args:o}=t.functionContext;if(delete t.functionContext.argsTokens,o.length||!e)continue;"LEFT_PAREN"===e[0]?.[0]?.type&&(e[0]=e[0].slice(1));for(const t of e){let e=t;"ARG_SEPARATOR"===e.at(-1)?.type&&(e=e.slice(0,-1));try{o.push(yf(e))}catch(e){o.push(void 0)}}}return e}(function(e){let t=[],o="";function s(e){if(0===t.length)return;const o=t.at(-1);if(o&&o.argsTokens){const{argsTokens:t,argPosition:s}=o;t[s]||(t[s]=[]),t[s].push({value:e.value,type:e.type})}}return e.map(((e,i)=>{switch(["SPACE","LEFT_PAREN"].includes(e.type)||(o=""),e.type){case"SYMBOL":s(e),o=e.value;break;case"LEFT_PAREN":t.push({parent:o,argPosition:0,argsTokens:[],args:[]}),s(e),o="";break;case"RIGHT_PAREN":const i=t.pop();i?.argsTokens?.flat().forEach(s),s(e);break;case"ARG_SEPARATOR":s(e),t.length&&t[t.length-1].argPosition++;break;default:s(e)}if(t.length){const o=t[t.length-1];o.parent&&(e.functionContext=Object.assign({},o))}return e}))}(function(e){let t=[],o=0;return e.map(((s,i)=>{if("LEFT_PAREN"===s.type){t.push(o+1),o=0;for(let o=i-1;o>=0;o--){if("SPACE"!==e[o].type){"SYMBOL"===e[o].type&&(e[o].parenthesesCode=t.join(":"));break}e[o].parenthesesCode=t.join(":")}}return s.parenthesesCode=t.join(":"),"RIGHT_PAREN"===s.type&&t.length&&(o=t.pop()),s}))}(function(e){let t=0;return e.map((e=>{const o=e.value.toString().length,s=Object.assign({},e,{start:t,end:t+o,length:o});return t=s.end,s}))}(cf(e,t)))))}function _f(e){if("REFERENCE"!==e.type)return e;const{xc:t,sheetName:o}=Go(e.value),[s,i]=t.split(":"),r=Df(s),n=i?`:${Df(i)}`:"";return{...e,value:qo(o,r+n)}}function Df(e){switch(function(e){if(function(e){return e.startsWith("$")&&e.length>1&&e.slice(1).includes("$")}(e))return"colrow";if(function(e){return e.startsWith("$")}(e))return"col";if(function(e){return e.includes("$",1)}(e))return"row";return"none"}(e)){case"none":e=Of(e,"colrow");break;case"colrow":e=Of(e,"row");break;case"row":e=Of(e,"col");break;case"col":e=Of(e,"none")}return e}function Of(e,t){if(e.includes("!"))throw new Error("The given XC should not contain a sheet name");let o;switch(e=e.replace(/\$/g,""),t){case"col":return"$"+e;case"row":return o=e.search(/[0-9]/),e.slice(0,o)+"$"+e.slice(o);case"colrow":return o=e.search(/[0-9]/),-1===o||0===o?"$"+e:"$"+(e=e.slice(0,o)+"$"+e.slice(o));case"none":return e}}function Ff(e,t,o){const s=(t.startsWith("=")?Af(t,o):[]).filter((t=>t.start<=e.start&&t.end>=e.start||t.start>=e.start&&t.start<e.end)),i=s.filter((e=>"REFERENCE"===e.type));if(0===i.length)return;const r=s.map(_f).map((e=>e.value)).join(""),n=s[0].start,a=s[s.length-1].end,l=t.slice(0,n)+r+t.slice(a),c=l.length-t.length,h={start:i[0].start,end:i[i.length-1].end+c};return 1===i.length&&e.start===e.end&&(h.start=h.end),{content:l,selection:h}}const Mf=["address","col","contents","format","row","type"],Pf={description:Oo("Gets information about a cell."),args:[wh("info_type (string)",Oo("The type of information requested. Can be one of %s",Mf.join(", "))),wh("reference (meta)",Oo("The reference to the cell."))],compute:function(e,t){const o=Gi(e).toLowerCase();Mi((()=>Mf.includes(o)),Oo("The info_type should be one of %s.",Mf.join(", ")));const s=this.__originSheetId,i=Gi(t),r=i.includes(":")?i.split(":")[0]:i;let{sheetName:n,xc:a}=Go(r);n=n===this.getters.getSheetName(s)?void 0:n;const l=qo(n,Of(a,"colrow")),c=this.getters.getRangeFromSheetXC(s,l);switch(o){case"address":return this.getters.getRangeString(c,s);case"col":return c.zone.left+1;case"contents":{const e={sheetId:c.sheetId,col:c.zone.left,row:c.zone.top};return this.getters.getEvaluatedCell(e).value}case"format":{const e={sheetId:c.sheetId,col:c.zone.left,row:c.zone.top};return this.getters.getEvaluatedCell(e).format||""}case"row":return c.zone.top+1;case"type":{const e={sheetId:c.sheetId,col:c.zone.left,row:c.zone.top},t=this.getters.getEvaluatedCell(e).type;return t===ii.empty?"b":t===ii.text?"l":"v"}}return""},isExported:!0},Nf={description:Oo("Whether a value is an error other than #N/A."),args:[wh("value (any)",Oo("The value to be verified as an error type."))],compute:function(e){const t=e?.value;return Ni(t)&&t!==xi.NotAvailable},isExported:!0},kf={description:Oo("Whether a value is an error."),args:[wh("value (any)",Oo("The value to be verified as an error type."))],compute:function(e){const t=e?.value;return Ni(t)},isExported:!0},Lf={description:Oo("Whether a value is `true` or `false`."),args:[wh("value (any)",Oo("The value to be verified as a logical TRUE or FALSE."))],compute:function(e){return"boolean"==typeof e?.value},isExported:!0},Vf={description:Oo("Whether a value is the error #N/A."),args:[wh("value (any)",Oo("The value to be verified as an error type."))],compute:function(e){return e?.value===xi.NotAvailable},isExported:!0},Hf={description:Oo("Whether a value is non-textual."),args:[wh("value (any)",Oo("The value to be checked."))],compute:function(e){return!Bf.compute.bind(this)(e)},isExported:!0},Uf={description:Oo("Whether a value is a number."),args:[wh("value (any)",Oo("The value to be verified as a number."))],compute:function(e){return"number"==typeof e?.value},isExported:!0},Bf={description:Oo("Whether a value is text."),args:[wh("value (any)",Oo("The value to be verified as text."))],compute:function(e){return"string"==typeof e?.value&&!1===Ni(e?.value)},isExported:!0},zf={description:Oo("Whether the referenced cell is empty"),args:[wh("value (any)",Oo("Reference to the cell that will be checked for emptiness."))],compute:function(e){return null===e?.value},isExported:!0},$f={description:Oo("Returns the error value #N/A."),args:[],compute:function(){return{value:xi.NotAvailable}},isExported:!0};var Wf=Object.freeze({__proto__:null,CELL:Pf,ISBLANK:zf,ISERR:Nf,ISERROR:kf,ISLOGICAL:Lf,ISNA:Vf,ISNONTEXT:Hf,ISNUMBER:Uf,ISTEXT:Bf,NA:$f});const Gf={description:Oo("Logical `and` operator."),args:[wh("logical_expression1 (boolean, range<boolean>)",Oo("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.")),wh("logical_expression2 (boolean, range<boolean>, repeating)",Oo("More expressions that represent logical values."))],compute:function(...e){const{result:t,foundBoolean:o}=$a(e);return Mi((()=>o),Oo("[[FUNCTION_NAME]] has no valid input data.")),t},isExported:!0},qf={description:Oo("Logical value `false`."),args:[],compute:function(){return!1},isExported:!0},Zf={description:Oo("Returns value depending on logical expression."),args:[wh("logical_expression (boolean)",Oo("An expression or reference to a cell containing an expression that represents some logical value, i.e. TRUE or FALSE.")),wh("value_if_true (any)",Oo("The value the function returns if logical_expression is TRUE.")),wh("value_if_false (any, default=FALSE)",Oo("The value the function returns if logical_expression is FALSE."))],compute:function(e,t,o){const s=ji(e?.value)?t:o;return void 0===s?{value:""}:(null===s.value&&(s.value=""),s)},isExported:!0},jf={description:Oo("Value if it is not an error, otherwise 2nd argument."),args:[wh("value (any)",Oo("The value to return if value itself is not an error.")),wh('value_if_error (any, default="empty")',Oo("The value the function returns if value is an error."))],compute:function(e,t={value:""}){const o=Ni(e?.value)?t:e;return void 0===o?{value:""}:(null===o.value&&(o.value=""),o)},isExported:!0},Yf={description:Oo("Value if it is not an #N/A error, otherwise 2nd argument."),args:[wh("value (any)",Oo("The value to return if value itself is not #N/A an error.")),wh('value_if_error (any, default="empty")',Oo("The value the function returns if value is an #N/A error."))],compute:function(e,t={value:""}){const o=e?.value===xi.NotAvailable?t:e;return void 0===o?{value:""}:(null===o.value&&(o.value=""),o)},isExported:!0},Xf={description:Oo("Returns a value depending on multiple logical expressions."),args:[wh("condition1 (boolean)",Oo("The first condition to be evaluated. This can be a boolean, a number, an array, or a reference to any of those.")),wh("value1 (any)",Oo("The returned value if condition1 is TRUE.")),wh("condition2 (boolean, any, repeating)",Oo("Additional conditions to be evaluated if the previous ones are FALSE.")),wh("value2 (any, repeating)",Oo("Additional values to be returned if their corresponding conditions are TRUE."))],compute:function(...e){Mi((()=>e.length%2==0),Oo("Wrong number of arguments. Expected an even number of arguments."));for(let t=0;t<e.length-1;t+=2)if(ji(e[t]?.value)){const o=e[t+1];return void 0===o?{value:""}:(null===o.value&&(o.value=""),o)}return new Ri(Oo("No match."))},isExported:!0},Kf={description:Oo("Returns opposite of provided logical value."),args:[wh("logical_expression (boolean)",Oo("An expression or reference to a cell holding an expression that represents some logical value."))],compute:function(e){return!ji(e)},isExported:!0},Jf={description:Oo("Logical `or` operator."),args:[wh("logical_expression1 (boolean, range<boolean>)",Oo("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.")),wh("logical_expression2 (boolean, range<boolean>, repeating)",Oo("More expressions that evaluate to logical values."))],compute:function(...e){const{result:t,foundBoolean:o}=Wa(e);return Mi((()=>o),Oo("[[FUNCTION_NAME]] has no valid input data.")),t},isExported:!0},Qf={description:Oo("Logical value `true`."),args:[],compute:function(){return!0},isExported:!0},ev={description:Oo("Logical `xor` operator."),args:[wh("logical_expression1 (boolean, range<boolean>)",Oo("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.")),wh("logical_expression2 (boolean, range<boolean>, repeating)",Oo("More expressions that evaluate to logical values."))],compute:function(...e){let t=!1,o=!1;return ar(e,(e=>(t=!0,o=o?!e:e,!0))),Mi((()=>t),Oo("[[FUNCTION_NAME]] has no valid input data.")),o},isExported:!0};var tv=Object.freeze({__proto__:null,AND:Gf,FALSE:qf,IF:Zf,IFERROR:jf,IFNA:Yf,IFS:Xf,NOT:Kf,OR:Jf,TRUE:Qf,XOR:ev});function ov(e,t){const o=t.getPivotId(e);if(!o)throw new Ri(Oo('There is no pivot with id "%s"',e));return o}function sv(e){if(e.length%2!=0)throw new Ri(Oo("Function PIVOT takes an even number of arguments."))}function iv(e,t,o){const s=[];if("SPREADSHEET"===t.type&&t.dataSet){const{sheetId:o,zone:i}=t.dataSet,r=Ko(i),n=e.getters.getRangeFromSheetXC(o,r);if(void 0===n||n.invalidXc||n.invalidSheetName)throw new Ai;s.push(n)}for(const t of o)if(t.computedBy){const o=e.getters.getMeasureCompiledFormula(t);s.push(...o.dependencies.filter((e=>!e.invalidXc)))}const i=e.__originCellPosition;i&&s.length&&(e.updateDependencies?.(i),e.addDependencies?.(i,s))}const rv=!0;function nv(e){return{value:xi.NotAvailable,message:Oo("Did not find value '%s' in [[FUNCTION_NAME]] evaluation.",Gi(e))}}const av={description:Oo("Returns a cell reference as a string. "),args:[wh("row (number)",Oo("The row number of the cell reference. ")),wh("column (number)",Oo("The column number (not name) of the cell reference. A is column number 1. ")),wh("absolute_relative_mode (number, default=1)",Oo("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).")),wh("use_a1_notation (boolean, default=TRUE)",Oo("A boolean indicating whether to use A1 style notation (TRUE) or R1C1 style notation (FALSE).")),wh("sheet (string, optional)",Oo("A string indicating the name of the sheet into which the address points."))],compute:function(e,t,o={value:1},s={value:!0},i){const r=zi(e,this.locale),n=zi(t,this.locale);$i(r),$i(n);const a=zi(o,this.locale);var l,c;Mi((()=>[1,2,3,4].includes(a)),(l=4,c=a,Oo("The function [[FUNCTION_NAME]] expects a number value between %s and %s inclusive, but receives %s.",1..toString(),l.toString(),c.toString())));let h;if(ji(s)){h=So(n-1,r-1,{rowFixed:[1,2].includes(a),colFixed:[1,3].includes(a)})}else{h=([1,2].includes(a)?`R${r}`:`R[${r}]`)+([1,3].includes(a)?`C${n}`:`C[${n}]`)}return void 0!==i?qo(Gi(i),h):h},isExported:!0},lv={description:Oo("Column number of a specified cell."),args:[wh("cell_reference (meta, default='this cell')",Oo("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(Ni(e?.value))return e;const t=void 0===e?this.__originCellPosition?.col:jo(e.value).left;return Mi((()=>void 0!==t),"In this context, the function [[FUNCTION_NAME]] needs to have a cell or range in parameter."),t+1},isExported:!0},cv={description:Oo("Number of columns in a specified array or range."),args:[wh("range (meta)",Oo("The range whose column count will be returned."))],compute:function(e){if(Ni(e?.value))return e;const t=jo(e.value);return t.right-t.left+1},isExported:!0},hv={description:Oo("Horizontal lookup"),args:[wh("search_key (string, number, boolean)",Oo("The value to search for. For example, 42, 'Cats', or I24.")),wh("range (any, range)",Oo("The range to consider for the search. The first row in the range is searched for the key specified in search_key.")),wh("index (number)",Oo("The row index of the value to be returned, where the first row in range is numbered 1.")),wh("is_sorted (boolean, default=true)",Oo("Indicates whether the row to be searched (the first row of the specified range) is sorted, in which case the closest match for search_key will be returned."))],compute:function(e,t,o,s={value:rv}){const i=Math.trunc(Li(o?.value,this.locale)),r=fr(t);Mi((()=>1<=i&&i<=r[0].length),Oo("[[FUNCTION_NAME]] evaluates to an out of bounds range."));const n=(e,t)=>e[t][0].value,a=ji(s.value)?ur(r,e,"nextSmaller","asc",r.length,n):gr(r,e,"wildcard",r.length,n),l=r[a];return void 0===l?nv(e):l[i-1]},isExported:!0},dv={description:Oo("Returns the content of a cell, specified by row and column offset."),args:[wh("reference (any, range)",Oo("The range of cells from which the values are returned.")),wh("row (number, default=0)",Oo("The index of the row to be returned from within the reference range of cells.")),wh("column (number, default=0)",Oo("The index of the column to be returned from within the reference range of cells."))],compute:function(e,t={value:0},o={value:0}){const s=fr(e),i=Li(t.value,this.locale),r=Li(o.value,this.locale);return Mi((()=>r>=0&&r-1<s.length&&i>=0&&i-1<s[0].length),Oo("Index out of range.")),0===i&&0===r?s:0===i?[s[r-1]]:0===r?s.map((e=>[e[i-1]])):s[r-1][i-1]},isExported:!0},uv={description:Oo("Returns the content of a cell, specified by a string."),args:[wh("reference (string)",Oo("The range of cells from which the values are returned.")),wh("use_a1_notation (boolean, default=TRUE)",Oo("A boolean indicating whether to use A1 style notation (TRUE) or R1C1 style notation (FALSE)."))],compute:function(e,t={value:!0}){let o=e?.value?.toString();if(!o)return new Ai(Oo("Reference should be defined."));if(!ji(t))return new Ri(Oo("R1C1 notation is not supported."));const s=this.__originSheetId,i=this.__originCellPosition;i&&this.updateDependencies?.(i);const r=this.getters.getRangeFromSheetXC(s,o);if(void 0===r||r.invalidXc||r.invalidSheetName)return new Ai;i&&this.addDependencies?.(i,[r]);const n=[];for(let e=r.zone.left;e<=r.zone.right;e++){const t=[];for(let o=r.zone.top;o<=r.zone.bottom;o++){const s={sheetId:r.sheetId,col:e,row:o};t.push(this.getters.getEvaluatedCell(s))}n.push(t)}return 1===n.length&&1===n[0].length?n[0][0]:n},isExported:!0},gv={description:Oo("Look up a value."),args:[wh("search_key (string, number, boolean)",Oo("The value to search for. For example, 42, 'Cats', or I24.")),wh("search_array (any, range)",Oo("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.")),wh("result_range (any, range, optional)",Oo("The range from which to return a result. The value returned corresponds to the location where search_key is found in search_range. This range must be only a single row or column and should not be used if using the search_result_array method."))],compute:function(e,t,o){const s=fr(t),i=fr(o);let r=s.length,n=s[0].length;const a=n>=r,l=a?(e,t)=>e[0][t].value:(e,t)=>e[t][0].value,c=ur(s,e,"nextSmaller","asc",a?n:r,l);return-1===c||a&&void 0===s[0][c]||!a&&void 0===s[c][n-1]?nv(e):0===i[0].length?a?s[r-1][c]:s[c][n-1]:(r=i.length,n=i[0].length,Mi((()=>1===r||1===n),Oo("The result_range must be a single row or a single column.")),r>1?(Mi((()=>c<=r-1),Oo("[[FUNCTION_NAME]] evaluates to an out of range row value %s.",(c+1).toString())),i[c][0]):(Mi((()=>c<=n-1),Oo("[[FUNCTION_NAME]] evaluates to an out of range column value %s.",(c+1).toString())),i[0][c]))},isExported:!0},pv={description:Oo("Position of item in range that matches value."),args:[wh("search_key (string, number, boolean)",Oo("The value to search for. For example, 42, 'Cats', or I24.")),wh("range (any, range)",Oo("The one-dimensional array to be searched.")),wh("search_type (number, default=1)",Oo("The search method. 1 (default) finds the largest value less than or equal to search_key when range is sorted in ascending order. 0 finds the exact value when range is unsorted. -1 finds the smallest value greater than or equal to search_key when range is sorted in descending order."))],compute:function(e,t,o={value:1}){let s=Li(o,this.locale);const i=fr(t),r=i.length,n=i[0].length;Mi((()=>1===r||1===n),Oo("The range must be a single row or a single column."));let a=-1;const l=1===r?(e,t)=>e[0][t].value:(e,t)=>e[t][0].value,c=1===r?i[0].length:i.length;switch(s=Math.sign(s),s){case 1:a=ur(i,e,"nextSmaller","asc",c,l);break;case 0:a=gr(i,e,"wildcard",c,l);break;case-1:a=ur(i,e,"nextGreater","desc",c,l)}return 1===r&&void 0===i[0][a]||1!==r&&void 0===i[a]?nv(e):a+1},isExported:!0},mv={description:Oo("Row number of a specified cell."),args:[wh("cell_reference (meta, default='this cell')",Oo("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(Ni(e?.value))return e;const t=void 0===e?this.__originCellPosition?.row:jo(e.value).top;return Mi((()=>void 0!==t),"In this context, the function [[FUNCTION_NAME]] needs to have a cell or range in parameter."),t+1},isExported:!0},fv={description:Oo("Number of rows in a specified array or range."),args:[wh("range (meta)",Oo("The range whose row count will be returned."))],compute:function(e){if(Ni(e?.value))return e;const t=jo(e.value);return t.bottom-t.top+1},isExported:!0},vv={description:Oo("Vertical lookup."),args:[wh("search_key (string, number, boolean)",Oo("The value to search for. For example, 42, 'Cats', or I24.")),wh("range (any, range)",Oo("The range to consider for the search. The first column in the range is searched for the key specified in search_key.")),wh("index (number)",Oo("The column index of the value to be returned, where the first column in range is numbered 1.")),wh("is_sorted (boolean, default=true)",Oo("Indicates whether the column to be searched (the first column of the specified range) is sorted, in which case the closest match for search_key will be returned."))],compute:function(e,t,o,s={value:rv}){const i=Math.trunc(Li(o?.value,this.locale)),r=fr(t);Mi((()=>1<=i&&i<=r.length),Oo("[[FUNCTION_NAME]] evaluates to an out of bounds range."));const n=(e,t)=>e[0][t].value,a=ji(s.value)?ur(r,e,"nextSmaller","asc",r[0].length,n):gr(r,e,"wildcard",r[0].length,n),l=r[i-1][a];return void 0===l?nv(e):l},isExported:!0},bv={0:"strict",1:"nextGreater","-1":"nextSmaller",2:"wildcard"},Sv={description:Oo("Search a range for a match and return the corresponding item from a second range."),args:[wh("search_key (string,number,boolean)",Oo("The value to search for.")),wh("lookup_range (any, range)",Oo("The range to consider for the search. Should be a single column or a single row.")),wh("return_range (any, range)",Oo("The range containing the return value. Should have the same dimensions as lookup_range.")),wh("if_not_found (any, optional)",Oo("If a valid match is not found, return this value.")),wh("match_mode (any, default=0)",Oo("(0) Exact match. (-1) Return next smaller item if no match. (1) Return next greater item if no match. (2) Wildcard match.")),wh("search_mode (any, default=1)",Oo("(1) Search starting at first item. (-1) Search starting at last item. (2) Perform a binary search that relies on lookup_array being sorted in ascending order. If not sorted, invalid results will be returned. (-2) Perform a binary search that relies on lookup_array being sorted in descending order. If not sorted, invalid results will be returned. "))],compute:function(e,t,o,s,i={value:0},r={value:1}){const n=Math.trunc(Li(i.value,this.locale)),a=Math.trunc(Li(r.value,this.locale)),l=fr(t),c=fr(o);Mi((()=>1===l.length||1===l[0].length),Oo("lookup_range should be either a single row or single column.")),Mi((()=>[-1,1,-2,2].includes(a)),Oo("search_mode should be a value in [-1, 1, -2, 2].")),Mi((()=>[-1,0,1,2].includes(n)),Oo("match_mode should be a value in [-1, 0, 1, 2]."));const h=1===l.length?"col":"row";Mi((()=>!(2===n&&[-2,2].includes(a))),Oo("the search and match mode combination is not supported for XLOOKUP evaluation.")),Mi((()=>"col"===h?c[0].length===l[0].length:c.length===l.length),Oo("return_range should have the same dimensions as lookup_range."));const d="col"===h?(e,t)=>e[0][t].value:(e,t)=>e[t][0].value,u="col"===h?l[0].length:l.length,g=bv[n],p=-1===a,m=2===a||-2===a?ur(l,e,g,2===a?"asc":"desc",u,d):gr(l,e,g,u,d,p);return-1!==m?"col"===h?c.map((e=>[e[m]])):[c[m]]:void 0===s?nv(e):[[s]]},isExported:!0},yv={description:Oo("Get the value from a pivot."),args:[wh("pivot_id (number,string)",Oo("ID of the pivot.")),wh("measure_name (string)",Oo("Name of the measure.")),wh("domain_field_name (string,optional,repeating)",Oo("Field name.")),wh("domain_value (number,string,boolean,optional,repeating)",Oo("Value."))],compute:function(e,t,...o){const s=Gi(e),i=Gi(t),r=ov(s,this.getters);!function(e,t,o){const{measures:s}=o.getPivotCoreDefinition(e);if(!s.find((e=>e.id===t))){const e=`(${s.map((e=>e.id)).join(", ")})`;throw new Ri(Oo("The argument %s is not a valid measure. Here are the measures: %s",t,e))}}(r,i,this.getters),sv(o);const n=this.getters.getPivot(r),a=this.getters.getPivotCoreDefinition(r);iv(this,a,a.measures.filter((e=>e.id===i))),n.init({reload:n.needsReevaluation});const l=n.assertIsValid({throwOnError:!1});if(l)return l;if(!n.areDomainArgsFieldsValid(o)){const e=Oo("Consider using a dynamic pivot formula: %s. Or re-insert the static pivot from the Data menu.",`=PIVOT(${s})`);return{value:xi.GenericError,message:Oo("Dimensions don't match the pivot definition")+". "+e}}const c=n.parseArgsToPivotDomain(o);return n.getPivotCellValueAndFormat(i,c)}},Cv={description:Oo("Get the header of a pivot."),args:[wh("pivot_id (number,string)",Oo("ID of the pivot.")),wh("domain_field_name (string,optional,repeating)",Oo("Field name.")),wh("domain_value (number,string,value,optional,repeating)",Oo("Value."))],compute:function(e,...t){const o=Gi(e),s=ov(o,this.getters);sv(t);const i=this.getters.getPivot(s);iv(this,this.getters.getPivotCoreDefinition(s),[]),i.init({reload:i.needsReevaluation});const r=i.assertIsValid({throwOnError:!1});if(r)return r;if(!i.areDomainArgsFieldsValid(t)){const e=Oo("Consider using a dynamic pivot formula: %s. Or re-insert the static pivot from the Data menu.",`=PIVOT(${o})`);return{value:xi.GenericError,message:Oo("Dimensions don't match the pivot definition")+". "+e}}const n=i.parseArgsToPivotDomain(t),a=n.at(-1);if("measure"===a?.field)return i.getPivotMeasureValue(Gi(a.value),n);const{value:l,format:c}=i.getPivotHeaderValueAndFormat(n);return{value:l,format:a&&"measure"!==a.field&&"false"!==a.value?c:void 0}}},wv={description:Oo("Get a pivot table."),args:[wh("pivot_id (string)",Oo("ID of the pivot.")),wh("row_count (number, optional)",Oo("number of rows")),wh("include_total (boolean, default=TRUE)",Oo("Whether to include total/sub-totals or not.")),wh("include_column_titles (boolean, default=TRUE)",Oo("Whether to include the column titles or not.")),wh("column_count (number, optional)",Oo("number of columns"))],compute:function(e,t={value:1e4},o={value:!0},s={value:!0},i={value:Number.MAX_VALUE}){const r=Gi(e),n=Li(t,this.locale);if(n<0)return new Ri(Oo("The number of rows must be positive."));const a=Li(i,this.locale);if(a<0)return new Ri(Oo("The number of columns must be positive."));const l=ji(s),c=ji(o),h=ov(r,this.getters),d=this.getters.getPivot(h),u=this.getters.getPivotCoreDefinition(h);iv(this,u,u.measures),d.init({reload:d.needsReevaluation});const g=d.assertIsValid({throwOnError:!1});if(g)return g;const p=d.getTableStructure(),m=p.getPivotCells(c,l),f=l?p.columns.length:0,v=this.getters.getPivotDisplayName(h),b=Math.min(f+n,m[0].length);if(0===b)return[[{value:v}]];const S=Math.min(1+a,m.length),y=[];for(const e of Ze(0,S)){y[e]=[];for(const t of Ze(0,b)){const o=m[e][t];switch(o.type){case"EMPTY":y[e].push({value:""});break;case"HEADER":const t=d.getPivotHeaderValueAndFormat(o.domain);y[e].push(rc(d,o.domain,t));break;case"MEASURE_HEADER":y[e].push(d.getPivotMeasureValue(o.measure,o.domain));break;case"VALUE":y[e].push(d.getPivotCellValueAndFormat(o.measure,o.domain))}}}return l&&(y[0][0]={value:v}),y}},Ev={description:Oo("Returns a range reference shifted by a specified number of rows and columns from a starting cell reference."),args:[wh("cell_reference (meta)",Oo("The starting point from which to count the offset rows and columns.")),wh("offset_rows (number)",Oo("The number of rows to offset by.")),wh("offset_columns (number)",Oo("The number of columns to offset by.")),wh("height (number, default='height of cell_reference')",Oo("The number of rows of the range to return starting at the offset target.")),wh("width (number, default='width of cell_reference')",Oo("The number of columns of the range to return starting at the offset target."))],compute:function(e,t,o,s,i){if(Ni(e?.value))return e;const r=e?.value;if(!r)throw new Error("In this context, the function OFFSET needs to have a cell or range in parameter.");const n=jo(r);let a=n.bottom-n.top+1,l=n.right-n.left+1;if(s){const e=Li(s,this.locale);Rh(Oo("Height value is %(_height)s. It should be greater than or equal to 1.",{_height:e}),e),a=e}if(i){const e=Li(i,this.locale);Rh(Oo("Width value is %(_width)s. It should be greater than or equal to 1.",{_width:e}),e),l=e}const{sheetName:c}=Go(r),h=c&&this.getters.getSheetIdByName(c)||this.getters.getActiveSheetId(),d=Li(t,this.locale),u=Li(o,this.locale),g=this.__originCellPosition;g&&this.updateDependencies?.(g);const p=n.left+u,m=n.top+d;if(p<0||m<0)return new Ai(Oo("OFFSET evaluates to an out of bounds range."));const f={left:p,top:m,right:p+l-1,bottom:m+a-1},v=this.getters.getRangeFromZone(this.__originSheetId,f);return v.invalidXc||v.invalidSheetName?new Ai:(g&&this.addDependencies?.(g,[v]),ir(l,a,((e,t)=>this.getters.getEvaluatedCell({sheetId:h,col:p+e,row:m+t}))))}};var xv=Object.freeze({__proto__:null,ADDRESS:av,COLUMN:lv,COLUMNS:cv,HLOOKUP:hv,INDEX:dv,INDIRECT:uv,LOOKUP:gv,MATCH:pv,OFFSET:Ev,PIVOT:wv,PIVOT_HEADER:Cv,PIVOT_VALUE:yv,ROW:mv,ROWS:fv,VLOOKUP:vv,XLOOKUP:Sv});const Iv={description:Oo("Sum of two numbers."),args:[wh("value1 (number)",Oo("The first addend.")),wh("value2 (number)",Oo("The second addend."))],compute:function(e,t){return{value:Li(e,this.locale)+Li(t,this.locale),format:e?.format||t?.format}}},Rv={description:Oo("Concatenation of two values."),args:[wh("value1 (string)",Oo("The value to which value2 will be appended.")),wh("value2 (string)",Oo("The value to append to value1."))],compute:function(e,t){return Gi(e)+Gi(t)},isExported:!0},Tv={description:Oo("One number divided by another."),args:[wh("dividend (number)",Oo("The number to be divided.")),wh("divisor (number)",Oo("The number to divide by."))],compute:function(e,t){const o=Li(t,this.locale);return Mi((()=>0!==o),Oo("The divisor must be different from zero."),xi.DivisionByZero),{value:Li(e,this.locale)/o,format:e?.format||t?.format}}};function Av(e){return void 0===e||null===e.value}const _v={number:0,string:"",boolean:!1},Dv={description:Oo("Equal."),args:[wh("value1 (string, number, boolean)",Oo("The first value.")),wh("value2 (string, number, boolean)",Oo("The value to test against value1 for equality."))],compute:function(e,t){if(Ni(e?.value))return e;if(Ni(t?.value))return t;let o=Av(e)?_v[typeof t?.value]:e?.value,s=Av(t)?_v[typeof e?.value]:t?.value;return"string"==typeof o&&(o=o.toUpperCase()),"string"==typeof s&&(s=s.toUpperCase()),{value:o===s}}};function Ov(e,t,o){if(Ni(e?.value))return e;if(Ni(t?.value))return t;let s=Av(e)?_v[typeof t?.value]:e?.value,i=Av(t)?_v[typeof e?.value]:t?.value;"number"!=typeof s&&(s=Gi(s).toUpperCase()),"number"!=typeof i&&(i=Gi(i).toUpperCase());const r=typeof s,n=typeof i;return"string"===r&&"number"===n?{value:!0}:"string"===n&&"number"===r?{value:!1}:{value:o(s,i)}}const Fv={description:Oo("Strictly greater than."),args:[wh("value1 (number, string, boolean)",Oo("The value to test as being greater than value2.")),wh("value2 (number, string, boolean)",Oo("The second value."))],compute:function(e,t){return Ov(e,t,((e,t)=>e>t))}},Mv={description:Oo("Greater than or equal to."),args:[wh("value1 (number, string, boolean)",Oo("The value to test as being greater than or equal to value2.")),wh("value2 (number, string, boolean)",Oo("The second value."))],compute:function(e,t){return Ov(e,t,((e,t)=>e>=t))}},Pv={description:Oo("Less than."),args:[wh("value1 (number, string, boolean)",Oo("The value to test as being less than value2.")),wh("value2 (number, string, boolean)",Oo("The second value."))],compute:function(e,t){const o=Mv.compute.bind(this)(e,t);return Ni(o.value)?o:{value:!o.value}}},Nv={description:Oo("Less than or equal to."),args:[wh("value1 (number, string, boolean)",Oo("The value to test as being less than or equal to value2.")),wh("value2 (number, string, boolean)",Oo("The second value."))],compute:function(e,t){const o=Fv.compute.bind(this)(e,t);return Ni(o.value)?o:{value:!o.value}}},kv={description:Oo("Difference of two numbers."),args:[wh("value1 (number)",Oo("The minuend, or number to be subtracted from.")),wh("value2 (number)",Oo("The subtrahend, or number to subtract from value1."))],compute:function(e,t){return{value:Li(e,this.locale)-Li(t,this.locale),format:e?.format||t?.format}}},Lv={description:Oo("Product of two numbers"),args:[wh("factor1 (number)",Oo("The first multiplicand.")),wh("factor2 (number)",Oo("The second multiplicand."))],compute:function(e,t){return{value:Li(e,this.locale)*Li(t,this.locale),format:e?.format||t?.format}}},Vv={description:Oo("Not equal."),args:[wh("value1 (string, number, boolean)",Oo("The first value.")),wh("value2 (string, number, boolean)",Oo("The value to test against value1 for inequality."))],compute:function(e,t){const o=Dv.compute.bind(this)(e,t);return Ni(o.value)?o:{value:!o.value}}},Hv={description:Oo("A number raised to a power."),args:[wh("base (number)",Oo("The number to raise to the exponent power.")),wh("exponent (number)",Oo("The exponent to raise base to."))],compute:function(e,t){return $d.compute.bind(this)(e,t)}},Uv={description:Oo("A number with the sign reversed."),args:[wh("value (number)",Oo("The number to have its sign reversed. Equivalently, the number to multiply by -1."))],compute:function(e){return{value:-Li(e,this.locale),format:e?.format}}},Bv={description:Oo("Value interpreted as a percentage."),args:[wh("percentage (number)",Oo("The value to interpret as a percentage."))],compute:function(e){return Li(e,this.locale)/100}},zv={description:Oo("A specified number, unchanged."),args:[wh("value (any)",Oo("The number to return."))],compute:function(e={value:null}){return e}};var $v=Object.freeze({__proto__:null,ADD:Iv,CONCAT:Rv,DIVIDE:Tv,EQ:Dv,GT:Fv,GTE:Mv,LT:Pv,LTE:Nv,MINUS:kv,MULTIPLY:Lv,NE:Vv,POW:Hv,UMINUS:Uv,UNARY_PERCENT:Bv,UPLUS:zv});const Wv=e=>({transform:t=>t*e,inverseTransform:t=>t/e}),Gv={transform:e=>e,inverseTransform:e=>e},qv=1e-10,Zv=.0254,jv=Zv/72,Yv=.3048,Xv=.9144,Kv=1609.34,Jv=1852,Qv=946073047258e4,eb={g:{...Gv,category:"weight"},u:{...Wv(166053e-29),category:"weight"},grain:{...Wv(.0647989),category:"weight"},ozm:{...Wv(28.3495),category:"weight"},lbm:{...Wv(453.592),category:"weight"},stone:{...Wv(6350.29),category:"weight"},sg:{...Wv(14593.90294),category:"weight"},cwt:{...Wv(45359.237),category:"weight"},uk_cwt:{...Wv(50802.3),category:"weight"},ton:{...Wv(907184.74),category:"weight"},uk_ton:{...Wv(1016046.9),category:"weight"},m:{...Gv,category:"distance"},km:{...Wv(1e3),category:"distance"},ang:{...Wv(qv),category:"distance"},Picapt:{...Wv(jv),category:"distance"},pica:{...Wv(Zv/6),category:"distance"},in:{...Wv(Zv),category:"distance"},ft:{...Wv(Yv),category:"distance"},yd:{...Wv(Xv),category:"distance"},ell:{...Wv(1.143),category:"distance"},mi:{...Wv(Kv),category:"distance"},survey_mi:{...Wv(1609.34),category:"distance"},Nmi:{...Wv(Jv),category:"distance"},ly:{...Wv(Qv),category:"distance"},parsec:{...Wv(0x6da012f95c9fd0),category:"distance"},sec:{...Gv,category:"time"},min:{...Wv(60),category:"time"},hr:{...Wv(3600),category:"time"},day:{...Wv(86400),category:"time"},yr:{...Wv(31556952),category:"time"},Pa:{...Gv,category:"pressure"},bar:{...Wv(1e5),category:"pressure"},mmHg:{...Wv(133.322),category:"pressure"},Torr:{...Wv(133.322),category:"pressure"},psi:{...Wv(6894.76),category:"pressure"},atm:{...Wv(101325),category:"pressure"},N:{...Gv,category:"force"},dyn:{...Wv(1e-5),category:"force"},pond:{...Wv(.00980665),category:"force"},lbf:{...Wv(4.44822),category:"force"},J:{...Gv,category:"energy"},eV:{...Wv(160218e-24),category:"energy"},e:{...Wv(1e-7),category:"energy"},flb:{...Wv(1.3558179483),category:"energy"},c:{...Wv(4.184),category:"energy"},cal:{...Wv(4.1868),category:"energy"},BTU:{...Wv(1055.06),category:"energy"},Wh:{...Wv(3600),category:"energy"},HPh:{...Wv(2684520),category:"energy"},W:{...Gv,category:"power"},PS:{...Wv(735.499),category:"power"},HP:{...Wv(745.7),category:"power"},T:{...Gv,category:"magnetism"},ga:{...Wv(1e-4),category:"magnetism"},K:{...Gv,category:"temperature"},C:{transform:e=>e+273.15,inverseTransform:e=>e-273.15,category:"temperature"},F:{transform:e=>5*(e-32)/9+273.15,inverseTransform:e=>9*(e-273.15)/5+32,category:"temperature"},Rank:{...Wv(5/9),category:"temperature"},Reau:{transform:e=>1.25*e+273.15,inverseTransform:e=>(e-273.15)/1.25,category:"temperature"},"m^3":{...Gv,category:"volume",order:3},"ang^3":{...Wv(Math.pow(qv,3)),category:"volume",order:3},"Picapt^3":{...Wv(Math.pow(jv,3)),category:"volume",order:3},tsp:{...Wv(492892e-11),category:"volume"},tspm:{...Wv(5e-6),category:"volume"},tbs:{...Wv(14786764825785619e-21),category:"volume"},"in^3":{...Wv(Math.pow(Zv,3)),category:"volume",order:3},oz:{...Wv(295735295625e-16),category:"volume"},cup:{...Wv(237e-6),category:"volume"},pt:{...Wv(.0004731765),category:"volume"},uk_pt:{...Wv(568261e-9),category:"volume"},qt:{...Wv(.0009463529),category:"volume"},l:{...Wv(.001),category:"volume"},uk_qt:{...Wv(.0011365225),category:"volume"},gal:{...Wv(.0037854118),category:"volume"},uk_gal:{...Wv(.00454609),category:"volume"},"ft^3":{...Wv(Math.pow(Yv,3)),category:"volume",order:3},bushel:{...Wv(.0352390704),category:"volume"},barrel:{...Wv(.158987295),category:"volume"},"yd^3":{...Wv(Math.pow(Xv,3)),category:"volume",order:3},MTON:{...Wv(1.13267386368),category:"volume"},GRT:{...Wv(2.83168),category:"volume"},"mi^3":{...Wv(Math.pow(Kv,3)),category:"volume",order:3},"Nmi^3":{...Wv(Math.pow(Jv,3)),category:"volume",order:3},"ly^3":{...Wv(Math.pow(Qv,3)),category:"volume",order:3},"m^2":{...Gv,category:"area",order:2},"ang^2":{...Wv(Math.pow(qv,2)),category:"area",order:2},"Picapt^2":{...Wv(Math.pow(jv,2)),category:"area",order:2},"in^2":{...Wv(Math.pow(Zv,2)),category:"area",order:2},"ft^2":{...Wv(Math.pow(Yv,2)),category:"area",order:2},"yd^2":{...Wv(Math.pow(Xv,2)),category:"area",order:2},ar:{...Wv(100),category:"area"},Morgen:{...Wv(2500),category:"area"},uk_acre:{...Wv(4046.8564224),category:"area"},us_acre:{...Wv(4046.8726098743),category:"area"},ha:{...Wv(1e4),category:"area"},"mi^2":{...Wv(Math.pow(Kv,2)),category:"area",order:2},"Nmi^2":{...Wv(Math.pow(Jv,2)),category:"area",order:2},"ly^2":{...Wv(Math.pow(Qv,2)),category:"area",order:2},bit:{...Gv,category:"information"},byte:{...Wv(8),category:"information"},"m/s":{...Gv,category:"speed"},"m/hr":{...Wv(1/3600),category:"speed"},"km/hr":{...Wv(1/3.6),category:"speed"},mph:{...Wv(.44704),category:"speed"},kn:{...Wv(.5144444444),category:"speed"},admkn:{...Wv(.5147733333),category:"speed"}},tb={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"},ob={"":1,Y:1e24,Z:1e21,E:1e18,P:1e15,T:1e12,G:1e9,M:1e6,k:1e3,h:100,da:10,e:10,d:.1,c:.01,m:.001,u:1e-6,n:1e-9,p:1e-12,f:1e-15,a:1e-18,z:1e-21,y:1e-21,Yi:Math.pow(2,80),Zi:Math.pow(2,70),Ei:Math.pow(2,60),Pi:Math.pow(2,50),Ti:Math.pow(2,40),Gi:Math.pow(2,30),Mi:Math.pow(2,20),ki:Math.pow(2,10)},sb={weight:Oo("Weight"),distance:Oo("Distance"),time:Oo("Time"),pressure:Oo("Pressure"),force:Oo("Force"),energy:Oo("Energy"),power:Oo("Power"),magnetism:Oo("Magnetism"),temperature:Oo("Temperature"),volume:Oo("Volume"),area:Oo("Area"),information:Oo("Information"),speed:Oo("Speed")};function ib(e){return sb[e]??""}function rb(e){for(const[t,o]of Object.entries(ob)){if(t&&!e.startsWith(t))continue;const s=e.slice(t.length);let i=eb[s];if(!i&&tb[s]&&(i=eb[tb[s]]),i)return{...i,factor:i.order?Math.pow(o,i.order):o}}}const nb={description:Oo("Converts a numeric value to a different unit of measure."),args:[wh("value (number)",Oo("the numeric value in start_unit to convert to end_unit")),wh("start_unit (string)",Oo("The starting unit, the unit currently assigned to value")),wh("end_unit (string)",Oo("The unit of measure into which to convert value"))],compute:function(e,t,o){const s=Li(e,this.locale),i=Gi(t),r=Gi(o),n=rb(i),a=rb(r);return n?a?n.category!==a.category?{value:xi.GenericError,message:Oo("Incompatible units of measure ('%s' vs '%s')",ib(n.category),ib(a.category))}:{value:a.inverseTransform(n.factor*n.transform(s))/a.factor,format:e?.format}:{value:xi.GenericError,message:Oo("Invalid units of measure ('%s')",r)}:{value:xi.GenericError,message:Oo("Invalid units of measure ('%s')",i)}},isExported:!0};var ab=Object.freeze({__proto__:null,CONVERT:nb});const lb=/[A-Za-zÀ-ÖØ-öø-ÿ]+/g,cb={description:Oo("Gets character associated with number."),args:[wh("table_number (number)",Oo("The number of the character to look up from the current Unicode table in decimal format."))],compute:function(e){const t=Math.trunc(Li(e,this.locale));return Mi((()=>t>=1),Oo("The table_number (%s) is out of range.",t.toString())),String.fromCharCode(t)},isExported:!0},hb={description:Oo("Remove non-printable characters from a piece of text."),args:[wh("text (string)",Oo("The text whose non-printable characters are to be removed."))],compute:function(e){const t=Gi(e);let o="";for(const e of t)e&&e.charCodeAt(0)>31&&(o+=e);return o},isExported:!0},db={description:Oo("Appends strings to one another."),args:[wh("string1 (string, range<string>)",Oo("The initial string.")),wh("string2 (string, range<string>, repeating)",Oo("More strings to append in sequence."))],compute:function(...e){return tr(e,((e,t)=>e+Gi(t)),"")},isExported:!0},ub={description:Oo("Tests whether two strings are identical."),args:[wh("string1 (string)",Oo("The first string to compare.")),wh("string2 (string)",Oo("The second string to compare."))],compute:function(e,t){return Gi(e)===Gi(t)},isExported:!0},gb={description:Oo("First position of string found in text, case-sensitive."),args:[wh("search_for (string)",Oo("The string to look for within text_to_search.")),wh("text_to_search (string)",Oo("The text to search for the first occurrence of search_for.")),wh("starting_at (number, default=1)",Oo("The character within text_to_search at which to start the search."))],compute:function(e,t,o={value:1}){const s=Gi(e),i=Gi(t),r=Li(o,this.locale);Mi((()=>""!==i),Oo("The text_to_search must be non-empty.")),Mi((()=>r>=1),Oo("The starting_at (%s) must be greater than or equal to 1.",r.toString()));const n=i.indexOf(s,r-1);return Mi((()=>n>=0),Oo("In [[FUNCTION_NAME]] evaluation, cannot find '%s' within '%s'.",s.toString(),i)),n+1},isExported:!0},pb={description:Oo("Concatenates elements of arrays with delimiter."),args:[wh("delimiter (string)",Oo("The character or string to place between each concatenated value.")),wh("value_or_array1 (string, range<string>)",Oo("The value or values to be appended using delimiter.")),wh("value_or_array2 (string, range<string>, repeating)",Oo("More values to be appended using delimiter."))],compute:function(e,...t){const o=Gi(e);return tr(t,((e,t)=>(e?e+o:"")+Gi(t)),"")}},mb={description:Oo("Substring from beginning of specified string."),args:[wh("text (string)",Oo("The string from which the left portion will be returned.")),wh("number_of_characters (number, optional)",Oo("The number of characters to return from the left side of string."))],compute:function(e,...t){const o=t.length?Li(t[0],this.locale):1;return Mi((()=>o>=0),Oo("The number_of_characters (%s) must be positive or null.",o.toString())),Gi(e).substring(0,o)},isExported:!0},fb={description:Oo("Length of a string."),args:[wh("text (string)",Oo("The string whose length will be returned."))],compute:function(e){return Gi(e).length},isExported:!0},vb={description:Oo("Converts a specified string to lowercase."),args:[wh("text (string)",Oo("The string to convert to lowercase."))],compute:function(e){return Gi(e).toLowerCase()},isExported:!0},bb={description:Oo("A segment of a string."),args:[wh("text (string)",Oo("The string to extract a segment from.")),wh("starting_at (number)",Oo("The index from the left of string from which to begin extracting. The first character in string has the index 1.")),wh("extract_length (number)",Oo("The length of the segment to extract."))],compute:function(e,t,o){const s=Gi(e),i=Li(t,this.locale),r=Li(o,this.locale);return Mi((()=>i>=1),Oo("The starting_at argument (%s) must be positive greater than one.",i.toString())),Mi((()=>r>=0),Oo("The extract_length argument (%s) must be positive or null.",r.toString())),s.slice(i-1,i+r-1)},isExported:!0},Sb={description:Oo("Capitalizes each word in a specified string."),args:[wh("text_to_capitalize (string)",Oo("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 Gi(e).replace(lb,(e=>e.charAt(0).toUpperCase()+e.slice(1).toLowerCase()))},isExported:!0},yb={description:Oo("Replaces part of a text string with different text."),args:[wh("text (string)",Oo("The text, a part of which will be replaced.")),wh("position (number)",Oo("The position where the replacement will begin (starting from 1).")),wh("length (number)",Oo("The number of characters in the text to be replaced.")),wh("new_text (string)",Oo("The text which will be inserted into the original text."))],compute:function(e,t,o,s){const i=Li(t,this.locale);Mi((()=>i>=1),Oo("The position (%s) must be greater than or equal to 1.",i.toString()));const r=Gi(e),n=Li(o,this.locale),a=Gi(s);return r.substring(0,i-1)+a+r.substring(i-1+n)},isExported:!0},Cb={description:Oo("A substring from the end of a specified string."),args:[wh("text (string)",Oo("The string from which the right portion will be returned.")),wh("number_of_characters (number, optional)",Oo("The number of characters to return from the right side of string."))],compute:function(e,...t){const o=t.length?Li(t[0],this.locale):1;Mi((()=>o>=0),Oo("The number_of_characters (%s) must be positive or null.",o.toString()));const s=Gi(e),i=s.length;return s.substring(i-o,i)},isExported:!0},wb={description:Oo("First position of string found in text, ignoring case."),args:[wh("search_for (string)",Oo("The string to look for within text_to_search.")),wh("text_to_search (string)",Oo("The text to search for the first occurrence of search_for.")),wh("starting_at (number, default=1)",Oo("The character within text_to_search at which to start the search."))],compute:function(e,t,o={value:1}){const s=Gi(e).toLowerCase(),i=Gi(t).toLowerCase(),r=Li(o,this.locale);Mi((()=>""!==i),Oo("The text_to_search must be non-empty.")),Mi((()=>r>=1),Oo("The starting_at (%s) must be greater than or equal to 1.",r.toString()));const n=i.indexOf(s,r-1);return Mi((()=>n>=0),Oo("In [[FUNCTION_NAME]] evaluation, cannot find '%s' within '%s'.",s,i)),n+1},isExported:!0},Eb={description:Oo("Split text by specific character delimiter(s)."),args:[wh("text (string)",Oo("The text to divide.")),wh("delimiter (string)",Oo("The character or characters to use to split text.")),wh("split_by_each (boolean, default=true})",Oo("Whether or not to divide text around each character contained in delimiter.")),wh("remove_empty_text (boolean, default=true)",Oo("Whether or not to remove empty text messages from the split results. The default behavior is to treat consecutive delimiters as one (if TRUE). If FALSE, empty cells values are added between consecutive delimiters."))],compute:function(e,t,o={value:true},s={value:true}){const i=Gi(e),r=Ue(Gi(t)),n=ji(o),a=ji(s);Mi((()=>r.length>0),Oo("The _delimiter (%s) must be not be empty.",r));const l=n?new RegExp(`[${r}]`,"g"):new RegExp(r,"g");let c=i.split(l);return a&&(c=c.filter((e=>""!==e))),nr([c])},isExported:!0},xb={description:Oo("Replaces existing text with new text in a string."),args:[wh("text_to_search (string)",Oo("The text within which to search and replace.")),wh("search_for (string)",Oo("The string to search for within text_to_search.")),wh("replace_with (string)",Oo("The string that will replace search_for.")),wh("occurrence_number (number, optional)",Oo("The instance of search_for within text_to_search to replace with replace_with. By default, all occurrences of search_for are replaced; however, if occurrence_number is specified, only the indicated instance of search_for is replaced."))],compute:function(e,t,o,s){const i=Li(s,this.locale);Mi((()=>i>=0),Oo("The occurrenceNumber (%s) must be positive or null.",i.toString()));const r=Gi(e),n=Gi(t);if(""===n)return r;const a=Gi(o),l=new RegExp(Ue(n),"g");if(0===i)return r.replace(l,a);let c=0;return r.replace(l,(e=>++c===i?a:e))},isExported:!0},Ib={description:Oo("Combines text from multiple strings and/or arrays."),args:[wh("delimiter (string)",Oo(" A string, possible empty, or a reference to a valid string. If empty, the text will be simply concatenated.")),wh("ignore_empty (boolean)",Oo("A boolean; if TRUE, empty cells selected in the text arguments won't be included in the result.")),wh("text1 (string, range<string>)",Oo("Any text item. This could be a string, or an array of strings in a range.")),wh("text2 (string, range<string>, repeating)",Oo("Additional text item(s)."))],compute:function(e,t,...o){const s=Gi(e),i=ji(t);let r=0;return tr(o,((e,t)=>i&&""===Gi(t)?e:(r++?e+s:"")+Gi(t)),"")},isExported:!0},Rb={description:Oo("Removes space characters."),args:[wh("text (string)",Oo("The text or reference to a cell containing text to be trimmed."))],compute:function(e){return Tt(Gi(e))},isExported:!0},Tb={description:Oo("Converts a specified string to uppercase."),args:[wh("text (string)",Oo("The string to convert to uppercase."))],compute:function(e){return Gi(e).toUpperCase()},isExported:!0},Ab={description:Oo("Converts a number to text according to a specified format."),args:[wh("number (number)",Oo("The number, date or time to format.")),wh("format (string)",Oo("The pattern by which to format the number, enclosed in quotation marks."))],compute:function(e,t){return Xr(Li(e,this.locale),{format:Gi(t),locale:this.locale})},isExported:!0},_b={description:Oo("Converts a string to a numeric value."),args:[wh("value (number)",Oo("the string to be converted"))],compute:function(e){return Li(e,this.locale)},isExported:!0};var Db=Object.freeze({__proto__:null,CHAR:cb,CLEAN:hb,CONCATENATE:db,EXACT:ub,FIND:gb,JOIN:pb,LEFT:mb,LEN:fb,LOWER:vb,MID:bb,PROPER:Sb,REPLACE:yb,RIGHT:Cb,SEARCH:wb,SPLIT:Eb,SUBSTITUTE:xb,TEXT:Ab,TEXTJOIN:Ib,TRIM:Rb,UPPER:Tb,VALUE:_b});const Ob={description:Oo("Creates a hyperlink in a cell."),args:[wh("url (string)",Oo("The full URL of the link enclosed in quotation marks.")),wh("link_label (string, optional)",Oo("The text to display in the cell, enclosed in quotation marks."))],compute:function(e,t){const o=Gi(e).trim(),s=Gi(t)||o;return""===o?s:tt(s,o)},isExported:!0};var Fb=Object.freeze({__proto__:null,HYPERLINK:Ob});const Mb=[{name:Oo("Array"),functions:Jh},{name:Oo("Database"),functions:Pg},{name:Oo("Date"),functions:mp},{name:Oo("Filter"),functions:Tp},{name:Oo("Financial"),functions:sf},{name:Oo("Info"),functions:Wf},{name:Oo("Lookup"),functions:xv},{name:Oo("Logical"),functions:tv},{name:Oo("Math"),functions:du},{name:Oo("Misc"),functions:ed},{name:Oo("Operator"),functions:$v},{name:Oo("Statistical"),functions:Sg},{name:Oo("Text"),functions:Db},{name:Oo("Engineering"),functions:vp},{name:Oo("Web"),functions:Fb},{name:Oo("Parser"),functions:ab}],Pb=/^[A-Z0-9\_\.]+$/;const Nb=new class extends r{mapping={};add(e,t){if(e=e.toUpperCase(),!Pb.test(e))throw new Error(Oo("Invalid function name %s. Function names can exclusively contain alphanumerical values separated by dots (.) or underscore (_)",e));const o=Eh(t);return function(e){let t=!1,o=!1,s=!1;for(let i of e){if(i.type.includes("META")&&i.type.length>1)throw new Error(Oo("Function ${name} has an argument that has been declared with more than one type whose type 'META'. The 'META' type can only be declared alone."));if(t&&!i.repeating)throw new Error(Oo("Function ${name} has no-repeatable arguments declared after repeatable ones. All repeatable arguments must be declared last."));const e=o||t||s,r=!(i.optional||i.repeating||i.default);if(e&&r)throw new Error(Oo("Function ${name} has at mandatory arguments declared after optional ones. All optional arguments must be after all mandatory arguments."));t=i.repeating,o=i.optional,s=i.default}}(o.args),this.mapping[e]=function(e,t){function o(...o){let i,r=1,n=1,a=1/0,l=1/0;for(let s=0;s<o.length;s++){const c=e.args[e.getArgToFocus(s+1)-1],h=o[s];if(yi(h)&&!c.acceptMatrix){const e=h.length,t=h[0].length;1!==e||1!==t?(i??=new Array(o.length),1!==e&&1!==t?(i[s]="matrix",r=Math.max(r,e),n=Math.max(n,t),a=Math.min(a,e),l=Math.min(l,t)):1!==e?(i[s]="horizontal",r=Math.max(r,e),a=Math.min(a,e)):1!==t&&(i[s]="vertical",n=Math.max(n,t),l=Math.min(l,t))):o[s]=h[0][0]}if(!yi(h)&&c.acceptMatrixOnly)throw new Ti(Oo("Function %s expects the parameter '%s' to be reference to a cell or range.",t,(s+1).toString()))}if(1===r&&1===n)return s.apply(this,o);const c=(e,t)=>o.map(((o,s)=>{switch(i?.[s]){case"matrix":return o[e][t];case"horizontal":return o[e][0];case"vertical":return o[0][t];case void 0:return o}}));return ir(r,n,((e,t)=>{if(e>a-1||t>l-1)return kb;const o=s.apply(this,c(e,t));return yi(o)?o[0][0]:o}))}function s(...o){for(let t=0;t<o.length;t++){const s=o[t];if(!e.args[e.getArgToFocus(t+1)-1].acceptErrors&&!yi(s)&&Ni(s?.value))return s}try{return i.apply(this,o)}catch(e){return Lb(e,t)}}function i(...o){this.debug;const s=e.compute.apply(this,o);return yi(s)?"object"==typeof s[0][0]&&null!==s[0][0]&&"value"in s[0][0]?(function(e,t){const o=e.length,s=e[0]?.length??0;for(let i=0;i<o;i++)for(let o=0;o<s;o++)t(e[i][o])}(s,(e=>Vb(e,t))),s):rr(s,(e=>({value:e}))):"object"==typeof s&&null!==s&&"value"in s?(Vb(s,t),s):{value:s}}return o}(o,e),super.add(e,o),this}};for(let e of Mb){const t=e.functions;for(let o in t){const s=t[o];s.category=s.category||e.name,o=o.replace(/_/g,"."),Nb.add(o,{isExported:!1,...s})}}const kb=new _i(Oo("Array arguments to [[FUNCTION_NAME]] are of different size."));function Lb(e,t){return o=e,void 0!==o?.value&&"string"==typeof o.value&&Ni(e.value)?(Ub(e)&&Vb(e,t),e):(console.error(e),new Ri(Hb+(Ub(e)?" "+e.message:"")));var o}function Vb(e,t){e.message?.includes("[[FUNCTION_NAME]]")&&(e.message=e.message.replace("[[FUNCTION_NAME]]",t))}const Hb=Oo("An unexpected error occurred. Submit a support ticket at odoo.com/help.");function Ub(e){return void 0!==e?.message&&"string"==typeof e.message}function Bb(e,t,o){const{x:s,y:i,width:r,height:n}=o;if(r<0||n<0)return;const l=t.color||a,{ctx:c}=e;c.save(),t.noBorder||(t.dashed&&c.setLineDash([5,3]),c.strokeStyle=l,t.thinLine?(c.lineWidth=1,c.strokeRect(s,i,r,n)):(c.lineWidth=2,c.strokeRect(s+.5,i+.5,r,n))),t.noFill||(c.fillStyle=Kt(Ut(l),t.fillAlpha??.12),c.fillRect(s,i,r,n)),c.restore()}bh.add("functions",{sequence:100,autoSelectFirstProposal:!0,maxDisplayedProposals:10,getProposals(e){if("SYMBOL"!==e.type)return[];const t=e.value;if(!this.composer.currentContent.startsWith("="))return[];const o=Object.entries(Nb.content).filter((([e,{hidden:t}])=>!t)).map((([e,{description:o}])=>({text:e,description:o,htmlContent:Sh(t,e,I,"o-semi-bold")}))).sort(((e,t)=>e.text.length-t.text.length||e.text.localeCompare(t.text)));return o},selectProposal(e,t){let o=e.end,s=e.end;["SYMBOL","FUNCTION"].includes(e.type)&&(o=e.start);const i=this.composer.currentTokens;t+="(";const r=i.map((e=>e.start)).indexOf(e.start);if(r+1<i.length){const e=i[r+1];"LEFT_PAREN"===e?.type&&s++}this.composer.changeComposerCursorSelection(o,s),this.composer.replaceComposerCursorSelection(t)}});class zb extends Tc{mutators=["register","unRegister"];providers=[];constructor(e){super(e),this.onDispose((()=>{this.providers=[]}))}get renderingLayers(){return["Highlights"]}get highlights(){const e=this.getters.getActiveSheetId();return this.providers.flatMap((e=>e.highlights)).filter((t=>t.sheetId===e)).map((e=>{const{numberOfRows:t,numberOfCols:o}=ls(e.zone),s=t*o==1?this.getters.expandZone(e.sheetId,e.zone):e.zone;return{...e,zone:s}}))}register(e){this.providers.push(e)}unRegister(e){this.providers=this.providers.filter((t=>t!==e))}drawLayer(e,t){if("Highlights"===t)for(const t of this.highlights){Bb(e,t,this.getters.getVisibleRect(t.zone))}}}class $b{mutators=["notifyUser","raiseError","askConfirmation","updateNotificationCallbacks"];notifyUser=e=>window.alert(e.text);askConfirmation=(e,t,o)=>{window.confirm(e)?t():o?.()};raiseError=(e,t)=>{window.alert(e),t?.()};updateNotificationCallbacks(e){this.notifyUser=e.notifyUser||this.notifyUser,this.raiseError=e.raiseError||this.raiseError,this.askConfirmation=e.askConfirmation||this.askConfirmation}}const Wb="#000000",Gb="#3da4ab",qb={OPERATOR:Gb,NUMBER:"#02c39a",STRING:"#00a82d",FUNCTION:Wb,DEBUGGER:Gb,LEFT_PAREN:Wb,RIGHT_PAREN:Wb,ARG_SEPARATOR:Wb,ORPHAN_RIGHT_PAREN:"#ff0000"};class Zb extends Tc{mutators=["startEdition","setCurrentContent","stopEdition","stopComposerRangeSelection","cancelEdition","cycleReferences","toggleEditionMode","changeComposerCursorSelection","replaceComposerCursorSelection"];col=0;row=0;editionMode="inactive";sheetId="";_currentContent="";currentTokens=[];selectionStart=0;selectionEnd=0;initialContent="";colorIndexByRange={};notificationStore=this.get($b);highlightStore=this.get(zb);constructor(e){super(e),this.highlightStore.register(this),this.onDispose((()=>{this.highlightStore.unRegister(this)}))}handleEvent(e){const t=this.getters.getActiveSheetId();let o;if(o=e.options.unbounded?this.getters.getUnboundedZone(t,e.anchor.zone):e.anchor.zone,"newAnchor"===e.mode)"selecting"===this.editionMode&&this.insertSelectedRange(o);else"selecting"===this.editionMode?this.replaceSelectedRange(o):this.updateComposerRange(e.previousAnchor.zone,o)}changeComposerCursorSelection(e,t){this.isSelectionValid(this._currentContent.length,e,t)&&(this.selectionStart=e,this.selectionEnd=t,this.computeFormulaCursorContext(),this.computeParenthesisRelatedToCursor())}stopComposerRangeSelection(){this.isSelectingRange&&(this.editionMode="editing")}startEdition(e,t){if(t){const o=e||this.getComposerContent(this.getters.getActivePosition());if(!this.isSelectionValid(o.length,t.start,t.end))return}const{col:o,row:s}=this.getters.getActivePosition();this.model.dispatch("SELECT_FIGURE",{id:null}),this.model.dispatch("SCROLL_TO_CELL",{col:o,row:s}),"inactive"!==this.editionMode&&e?this.setContent(e,t):this._startEdition(e,t),this.updateTokenColor(),this.computeFormulaCursorContext(),this.computeParenthesisRelatedToCursor()}cancelEdition(){this.cancelEditionAndActivateSheet(),this.resetContent()}setCurrentContent(e,t){t&&!this.isSelectionValid(e.length,t.start,t.end)||(this.setContent(e,t,!0),this.updateTokenColor(),this.computeFormulaCursorContext(),this.computeParenthesisRelatedToCursor())}replaceComposerCursorSelection(e){this.replaceSelection(e)}handle(e){switch(e.type){case"SELECT_FIGURE":e.id&&(this.cancelEditionAndActivateSheet(),this.resetContent());break;case"START_CHANGE_HIGHLIGHT":const{left:t,top:o}=e.zone;this.isSelectingRange&&(this.editionMode="editing"),this.model.selection.resetAnchor(this,{cell:{col:t,row:o},zone:e.zone})}}get currentContent(){return"inactive"===this.editionMode?this.getComposerContent(this.getters.getActivePosition()):this._currentContent}get composerSelection(){return{start:this.selectionStart,end:this.selectionEnd}}get isSelectingRange(){return"selecting"===this.editionMode}get showSelectionIndicator(){return this.isSelectingRange&&this.canStartComposerRangeSelection()}get tokenAtCursor(){const e=Math.min(this.selectionStart,this.selectionEnd),t=Math.max(this.selectionStart,this.selectionEnd);return e===t&&0===t?void 0:this.currentTokens.find((o=>o.start<=e&&o.end>=t))}cycleReferences(){const e=this.getters.getLocale(),t=Ff(this.composerSelection,this._currentContent,e);void 0!==t&&this.setCurrentContent(t.content,t.selection)}toggleEditionMode(){if("inactive"===this.editionMode)return;const e=Math.min(this.selectionStart,this.selectionEnd),t=Math.max(this.selectionStart,this.selectionEnd),o=[...this.currentTokens].reverse().find((o=>o.end>=e&&t>=o.start&&"REFERENCE"===o.type));if("editing"===this.editionMode&&o){const e=this.getters.getActiveSheetId(),{sheetName:t,xc:s}=Go(o.value),i=this.getters.getSheetIdByName(t);i&&i!==e&&this.model.dispatch("ACTIVATE_SHEET",{sheetIdFrom:e,sheetIdTo:i}),this.selectionStart=this.selectionEnd=o.end;const r=this.getters.getRangeFromSheetXC(this.sheetId,s).zone;this.captureSelection(r),this.editionMode="selecting"}else this.editionMode="editing"}captureSelection(e,t,o){this.model.selection.capture(this,{cell:{col:t||e.left,row:o||e.right},zone:e},{handleEvent:this.handleEvent.bind(this),release:()=>{this._stopEdition()}})}isSelectionValid(e,t,o){return t>=0&&t<=e&&o>=0&&o<=e}startComposerRangeSelection(){if(this.sheetId===this.getters.getActiveSheetId()){const e=ms({col:this.col,row:this.row});this.model.selection.resetAnchor(this,{cell:{col:this.col,row:this.row},zone:e})}this.editionMode="selecting"}_startEdition(e,t){const o=this.getters.getActiveCell(),s=this.getters.getLocale();e&&o.format?.includes("%")&&ei(e,s)&&(t=t||{start:e.length,end:e.length},e=`${e}%`);const{col:i,row:r,sheetId:n}=this.getters.getActivePosition();this.col=i,this.sheetId=n,this.row=r,this.initialContent=this.getComposerContent({sheetId:n,col:i,row:r}),this.editionMode="editing",this.setContent(e||this.initialContent,t),this.colorIndexByRange={};const a=ms({col:this.col,row:this.row});this.captureSelection(a,i,r)}_stopEdition(){if("inactive"!==this.editionMode){this.cancelEditionAndActivateSheet();let e=this.getCurrentCanonicalContent();if(!(this.initialContent!==e))return;if(e&&e.startsWith("=")){const t=this.currentTokens.filter((e=>"LEFT_PAREN"===e.type)).length-this.currentTokens.filter((e=>"RIGHT_PAREN"===e.type)).length;t>0&&(e+=dt(new Array(t).fill(")")))}this.confirmEdition(e)}}getCurrentCanonicalContent(){return _a(this._currentContent,this.getters.getLocale())}cancelEditionAndActivateSheet(){if("inactive"===this.editionMode)return;this._cancelEdition();this.getters.getActiveSheetId()!==this.sheetId&&this.model.dispatch("ACTIVATE_SHEET",{sheetIdFrom:this.getters.getActiveSheetId(),sheetIdTo:this.sheetId})}_cancelEdition(){"inactive"!==this.editionMode&&(this.editionMode="inactive",this.model.selection.release(this),this.colorIndexByRange={})}resetContent(){this.setContent(this.initialContent||"")}setContent(e,t,o){const s=this._currentContent!==e;if(this._currentContent=e,t?(this.selectionStart=t.start,this.selectionEnd=t.end):this.selectionStart=this.selectionEnd=e.length,s||"inactive"!==this.editionMode){const t=this.getters.getLocale();this.currentTokens=e.startsWith("=")?Af(e,t):[],this.currentTokens.length>100&&o&&this.notificationStore.raiseError(Oo("This formula has over 100 parts. It can't be processed properly, consider splitting it into multiple cells"))}this.canStartComposerRangeSelection()&&this.startComposerRangeSelection()}getAutoCompleteProviders(){return bh.getAll()}insertSelectedRange(e){const t=Math.min(this.selectionStart,this.selectionEnd),o=this.getZoneReference(e);this.canStartComposerRangeSelection()?this.insertText(o,t):this.insertText(","+o,t)}replaceSelectedRange(e){const t=this.getZoneReference(e),o=this.tokenAtCursor,s="REFERENCE"===o?.type?o.start:this.selectionStart;this.replaceText(t,s,this.selectionEnd)}updateComposerRange(e,t){const o=this.getters.getActiveSheetId(),s=this.tokenAtCursor,i=(s?[s,...this.currentTokens]:this.currentTokens).filter((e=>"REFERENCE"===e.type)).find((t=>{const{xc:s,sheetName:i}=Go(t.value),r=i||this.getters.getSheetName(this.sheetId);if(this.getters.getSheetName(o)!==r)return!1;const n=this.getters.getRangeFromSheetXC(o,s);return is(this.getters.expandZone(o,n.zone),e)}));if(!i)return;const r=this.getters.getRangeFromSheetXC(o,i.value);this.selectionStart=i.start,this.selectionEnd=this.selectionStart+i.value.length;const n=this.getters.getRangeFromZone(o,t),a=this.getRangeReference(n,r.parts);this.replaceSelection(a)}getZoneReference(e){const t=this.sheetId,o=this.getters.getActiveSheetId(),s=this.getters.getRangeFromZone(o,e);return this.getters.getSelectionRangeString(s,t)}getRangeReference(e,t){let o=[...t];const s=e.clone({parts:o});return this.getters.getSelectionRangeString(s,this.sheetId)}replaceSelection(e){const t=Math.min(this.selectionStart,this.selectionEnd),o=Math.max(this.selectionStart,this.selectionEnd);this.replaceText(e,t,o)}replaceText(e,t,o){this._currentContent=this._currentContent.slice(0,t)+this._currentContent.slice(o,this._currentContent.length),this.insertText(e,t)}insertText(e,t){const o=this._currentContent.slice(0,t)+e+this._currentContent.slice(t),s=t+e.length;this.setCurrentContent(o,{start:s,end:s})}updateTokenColor(){this.updateRangeColor();for(let e=0;e<this.currentTokens.length;e++)this.currentTokens[e].color=this.getTokenColor(this.currentTokens[e])}getTokenColor(e){if("REFERENCE"===e.type){const{xc:t,sheetName:o}=Go(e.value);return this.rangeColor(t,o)||Wb}if("SYMBOL"===e.type){const t=e.value.toUpperCase();if("TRUE"===t||"FALSE"===t)return qb.NUMBER;if(t in Nb.content)return qb.FUNCTION}return["LEFT_PAREN","RIGHT_PAREN"].includes(e.type)&&""===e.parenthesesCode?qb.ORPHAN_RIGHT_PAREN:qb[e.type]||Wb}rangeColor(e,t){const o=t?this.model.getters.getSheetIdByName(t):this.sheetId,s=this.highlights.find((t=>{if(t.sheetId!==o)return!1;let s=this.model.getters.getRangeFromSheetXC(o,e).zone;return s=1===bs(s)?this.model.getters.expandZone(o,s):s,is(s,t.zone)}));return s&&s.color?s.color:void 0}computeFormulaCursorContext(){for(let e=0;e<this.currentTokens.length;e++)this.currentTokens[e].isBlurred=!1;if(this.selectionStart!==this.selectionEnd)return;const e=this.getParenthesesCodeAfterCursor(),t=[...this.currentTokens].reverse().find((t=>e.startsWith(t.parenthesesCode)&&"SYMBOL"===t.type));if(t)for(let e=0;e<this.currentTokens.length;e++)(this.currentTokens[e].parenthesesCode||"").startsWith(t.parenthesesCode||"")||(this.currentTokens[e].isBlurred=!0)}getParenthesesCodeAfterCursor(){const e=this.tokenAtCursor?.parenthesesCode||"";return"RIGHT_PAREN"===this.tokenAtCursor?.type?e.slice(0,-1)||"":e}computeParenthesisRelatedToCursor(){for(let e=0;e<this.currentTokens.length;e++)this.currentTokens[e].isParenthesisLinkedToCursor=!1;const e=this.tokenAtCursor;if(e&&""!==e.parenthesesCode&&["LEFT_PAREN","RIGHT_PAREN"].includes(e.type))for(let t=0;t<this.currentTokens.length;t++){const o=this.currentTokens[t];["LEFT_PAREN","RIGHT_PAREN"].includes(o.type)&&o.parenthesesCode===e.parenthesesCode&&o!==e&&(this.currentTokens[t].isParenthesisLinkedToCursor=!0,this.tokenAtCursor.isParenthesisLinkedToCursor=!0)}}updateRangeColor(){if(!this._currentContent.startsWith("=")||"inactive"===this.editionMode)return;const e=this.sheetId,t=this.getReferencedRanges().map((t=>this.getters.getRangeString(t,e))),o={};for(const e of t)void 0!==this.colorIndexByRange[e]&&(o[e]=this.colorIndexByRange[e]);const s=new Set(Object.values(o));let i=0;const r=()=>{for(;s.has(i);)i++;return s.add(i),i};for(const e of t){const t=e in o?o[e]:r();o[e]=t}this.colorIndexByRange=o}get highlights(){if(!this.currentContent.startsWith("=")||"inactive"===this.editionMode)return[];const e=this.sheetId,t=e=>{const t=this.colorIndexByRange[e];return Lt[t%Lt.length]};return this.getReferencedRanges().map((o=>{const s=this.getters.getRangeString(o,e),{numberOfRows:i,numberOfCols:r}=ls(o.zone);return{zone:i*r==1?this.getters.expandZone(o.sheetId,o.zone):o.zone,color:t(s),sheetId:o.sheetId,interactive:!0}}))}getReferencedRanges(){const e=this.sheetId;return this.currentTokens.filter((e=>"REFERENCE"===e.type)).map((t=>this.getters.getRangeFromSheetXC(e,t.value))).filter((e=>!e.invalidSheetName&&!e.invalidXc))}get autocompleteProvider(){const e=this.currentContent,t=e.startsWith("=")?this.tokenAtCursor:{type:"STRING",value:e};if("inactive"===this.editionMode||!t||["TRUE","FALSE"].includes(t.value.toUpperCase())||!this.canStartComposerRangeSelection()&&!["SYMBOL","STRING","UNKNOWN"].includes(t.type))return;const o={composer:this,getters:this.getters},s=this.getAutoCompleteProviders().sort(((e,t)=>(e.sequence??1/0)-(t.sequence??1/0))).map((s=>({...s,getProposals:s.getProposals.bind(o,t,e),selectProposal:s.selectProposal.bind(o,t)})));for(const e of s){let o=e.getProposals();const s=o?.find((e=>e.text===t.value)),i=t.value.replace(/[ ,\(\)]/g,"");if(s&&this._currentContent!==this.initialContent)return;if(i&&o&&!["ARG_SEPARATOR","LEFT_PAREN","OPERATOR"].includes(t.type)){const e=Un(i,o,(e=>e.fuzzySearchKey||e.text));(!s||e.length>1)&&(o=e)}if(e.maxDisplayedProposals&&(o=o?.slice(0,e.maxDisplayedProposals)),o?.length)return{proposals:o,selectProposal:e.selectProposal,autoSelectFirstProposal:e.autoSelectFirstProposal??!1}}}canStartComposerRangeSelection(){if(this._currentContent.startsWith("=")){const e=this.tokenAtCursor;if(!e)return!1;const t=this.currentTokens.map((e=>e.start)).indexOf(e.start);let o=t,s=e;for(;!["ARG_SEPARATOR","LEFT_PAREN","OPERATOR"].includes(s.type)||ga.includes(s.value);){if("SPACE"!==s.type||o<1)return!1;o--,s=this.currentTokens[o]}for(o=t+1,s=this.currentTokens[o];s&&!["ARG_SEPARATOR","RIGHT_PAREN","OPERATOR"].includes(s.type);){if("SPACE"!==s.type)return!1;o++,s=this.currentTokens[o]}return!0}return!1}}class jb{scope;code="";constructor(e=new Xb){this.scope=e}append(...e){this.code+=e.map((e=>e.toString())).join("\n")+"\n"}return(e){return new Yb(this.scope,this.code,e)}toString(){return Kb(this.code)}}class Yb{scope;returnExpression;code;constructor(e,t,o){this.scope=e,this.returnExpression=o,this.code=Kb(t)}toString(){return this.code}assignResultToVariable(){if(this.scope.isAlreadyDeclared(this.returnExpression))return this;const e=this.scope.nextVariableName(),t=new jb(this.scope);return t.append(this.code),t.append(`const ${e} = ${this.returnExpression};`),t.return(e)}}class Xb{nextId=1;declaredVariables=new Set;nextVariableName(){const e="_"+this.nextId++;return this.declaredVariables.add(e),e}isAlreadyDeclared(e){return this.declaredVariables.has(e)}}function Kb(e){let t="",o=0;const s=e.split("\n").map((e=>e.trim())).filter((e=>""!==e));for(const e of s)e.startsWith("}")&&o--,t+="\t".repeat(o)+e+"\n",e.endsWith("{")&&o++;return t.trim()}const Jb=Nb.content,Qb={"=":"EQ","+":"ADD","-":"MINUS","*":"MULTIPLY","/":"DIVIDE",">=":"GTE","<>":"NE",">":"GT","<=":"LTE","<":"LT","^":"POWER","&":"CONCATENATE"},eS={"-":"UMINUS","+":"UPLUS","%":"UNARY.PERCENT"},tS={};function oS(e){return sS(cf(e))}function sS(e){try{return function(e){const{dependencies:t,constantValues:o,symbols:s}=function(e){const t={numbers:[],strings:[]},o=[],s=[];for(const i of e)switch(i.type){case"INVALID_REFERENCE":case"REFERENCE":o.push(i.value);break;case"STRING":const e=He(i.value);t.strings.includes(e)||t.strings.push(e);break;case"NUMBER":{const e=oi(i.value,bi);t.numbers.includes(e)||t.numbers.push(e);break}case"SYMBOL":s.push($e(i.value,"'"))}return{dependencies:o,constantValues:t,symbols:s}}(e),i=function(e,t,o,s){let i="";for(const s of e)switch(s.type){case"STRING":const e=He(s.value);i+=`|S${o.strings.indexOf(e)}|`;break;case"NUMBER":i+=`|N${o.numbers.indexOf(oi(s.value,bi))}|`;break;case"REFERENCE":case"INVALID_REFERENCE":s.value.includes(":")?i+=`R|${t.indexOf(s.value)}|`:i+=`C|${t.indexOf(s.value)}|`;break;case"SPACE":i+="";break;default:i+=s.value}return i}(e,t,o);if(!tS[i]){const n=yf([...e]),a=new Xb;if("BIN_OPERATION"===n.type&&":"===n.value)throw new Ti(Oo("Invalid formula"));if("EMPTY"===n.type)throw new Ti(Oo("Invalid formula"));const l=u(n),c=new jb;c.append(`// ${i}`),c.append(l),c.append(`return ${l.returnExpression};`);let h=new Function("deps","ref","range","getSymbolValue","ctx",c.toString());function d(e){const{args:t}=e,o=e.value.toUpperCase(),s=Jb[o];if(!s)throw new Di(Oo('Unknown function: "%s"',e.value));!function(e){const t=e.args.length,o=e.value.toUpperCase(),s=Jb[o];if(t<s.minArgRequired)throw new Ti(Oo("Invalid number of arguments for the %s function. Expected %s minimum, but got %s instead.",o,s.minArgRequired.toString(),t.toString()));if(t>s.maxArgPossible)throw new Ti(Oo("Invalid number of arguments for the %s function. Expected %s maximum, but got %s instead.",o,s.maxArgPossible.toString(),t.toString()));const i=s.nbrArgRepeating;if(i>1){const e=s.args.length-i;if((t-e)%i!=0)throw new Ti(Oo("Invalid number of arguments for the %s function. Expected all arguments after position %s to be supplied by groups of %s arguments",o,e.toString(),i.toString()))}}(e);const i=[];for(let e=0;e<t.length;e++){const o=s.getArgToFocus(e+1)-1,r=s.args[o],n=t[e],a=r.type||[],l=a.includes("META"),c=a.some((e=>iS(e)));i.push(u(n,l,c))}return i}function u(e,i=!1,r=!1){const n=new jb(a);if("REFERENCE"!==e.type&&("BIN_OPERATION"!==e.type||":"!==e.value)&&i)throw new Ti(Oo("Argument must be a reference to a cell or range."));switch(e.debug&&(n.append("debugger;"),n.append('ctx["debug"] = true;')),e.type){case"BOOLEAN":return n.return(`{ value: ${e.value} }`);case"NUMBER":return n.return(`{ value: this.constantValues.numbers[${o.numbers.indexOf(e.value)}] }`);case"STRING":return n.return(`{ value: this.constantValues.strings[${o.strings.indexOf(e.value)}] }`);case"REFERENCE":const a=t.indexOf(e.value);return!i&&e.value.includes(":")||r?n.return(`range(deps[${a}])`):n.return(`ref(deps[${a}], ${i?"true":"false"})`);case"FUNCALL":const l=d(e).map((e=>e.assignResultToVariable()));n.append(...l);const c=e.value.toUpperCase();return n.return(`ctx['${c}'](${l.map((e=>e.returnExpression))})`);case"UNARY_OPERATION":{const t=eS[e.value],o=u(e.operand,!1,!1).assignResultToVariable();return n.append(o),n.return(`ctx['${t}'](${o.returnExpression})`)}case"BIN_OPERATION":{const t=Qb[e.value],o=u(e.left,!1,!1).assignResultToVariable(),s=u(e.right,!1,!1).assignResultToVariable();return n.append(o),n.append(s),n.return(`ctx['${t}'](${o.returnExpression}, ${s.returnExpression})`)}case"SYMBOL":const h=s.indexOf(e.value);return n.return(`getSymbolValue(this.symbols[${h}])`);case"EMPTY":return n.return("undefined")}}tS[i]=h}const r={execute:tS[i],dependencies:t,constantValues:o,symbols:s,tokens:e,isBadExpression:!1,normalizedFormula:i};return r}(e)}catch(t){return{tokens:e,dependencies:[],execute:function(){return t},isBadExpression:!0,normalizedFormula:e.map((e=>e.value)).join("")}}}function iS(e){return e.startsWith("RANGE")}const rS=Nb.content;function nS(e){try{return 0===wf(yf(e)).filter((e=>"FUNCALL"===e.type&&!rS[e.value.toUpperCase()]?.isExported)).length}catch(e){return!1}}function aS(e,t){if(!e.some((e=>"SYMBOL"===e.type&&t.includes(e.value.toUpperCase()))))return[];let o;try{o=yf(e)}catch{return[]}return function(e,t){return wf(e).filter((e=>"FUNCALL"===e.type&&t.includes(e.value.toUpperCase()))).map((e=>({functionName:e.value.toUpperCase(),args:e.args})))}(o,t)}const lS=["PIVOT.VALUE","PIVOT.HEADER","PIVOT"];function cS(e,t){const o=`"${t?`${e.name}:${t}`:e.name}"`,s=e.string!==e.name?e.string+o:o;return{text:o,description:e.string+(e.help?` (${e.help})`:""),htmlContent:[{value:o,color:qb.STRING}],fuzzySearchKey:s}}function hS(e,t){let o=e.end;const s=e.end;"ARG_SEPARATOR"!==e.type&&(o=e.start),this.composer.stopComposerRangeSelection(),this.composer.changeComposerCursorSelection(o,s),this.composer.replaceComposerCursorSelection(t)}function dS(e,t){let o=e.end;const s=e.end;"LEFT_PAREN"!==e.type&&(o=e.start),this.composer.stopComposerRangeSelection(),this.composer.changeComposerCursorSelection(o,s),this.composer.replaceComposerCursorSelection(t)}function uS(e){const t=e.functionContext?.args[0];if(t&&["STRING","NUMBER"].includes(t.type))return t.value}function gS(e){return aS(e,lS)[0]}function pS(e){return aS(e,lS).length}const mS=new r;mS.add("SPREADSHEET",!1),bh.add("pivot_ids",{sequence:50,autoSelectFirstProposal:!0,getProposals(e){const t=e.functionContext;if(!t||!["PIVOT.VALUE","PIVOT.HEADER","PIVOT"].includes(t.parent.toUpperCase())||0!==t.argPosition)return;const o=this.getters.getPivotIds();return o.includes(e.value)?void 0:o.map((e=>{const t=this.getters.getPivotCoreDefinition(e),o=`${this.getters.getPivotFormulaId(e)}`;return{text:o,description:t.name,htmlContent:[{value:o,color:qb.NUMBER}],fuzzySearchKey:o+t.name,alwaysExpanded:!0}})).filter(at)},selectProposal:dS}),bh.add("pivot_measures",{sequence:50,autoSelectFirstProposal:!0,getProposals(e){const t=e.functionContext;if("PIVOT.VALUE"!==t?.parent.toUpperCase()||1!==t.argPosition)return[];const o=uS(e),s=this.getters.getPivotId(o);if(!s||!this.getters.isExistingPivot(s))return[];const i=this.getters.getPivot(s);return i.init(),i.isValid()?i.definition.measures.map((e=>{if("__count"===e.fieldName){const e='"__count"';return{text:e,description:Oo("Count"),htmlContent:[{value:e,color:qb.STRING}],fuzzySearchKey:Oo("Count")+e}}return function(e){const t=`"${e.id}"`,o=e.displayName+e.fieldName+t;return{text:t,description:e.displayName,htmlContent:[{value:t,color:qb.STRING}],fuzzySearchKey:o}}(e)})).filter(at):[]},selectProposal:hS}),bh.add("pivot_group_fields",{sequence:50,autoSelectFirstProposal:!0,getProposals(e){const t=e.functionContext;if(!t||!function(e){const t=e.functionContext;return"PIVOT.VALUE"===t?.parent.toUpperCase()&&t.argPosition>=2&&t.argPosition%2==0}(e)&&!function(e){const t=e.functionContext;return"PIVOT.HEADER"===t?.parent.toUpperCase()&&t.argPosition>=1&&t.argPosition%2==1}(e))return;const o=uS(e),s=this.getters.getPivotId(o);if(!s||!this.getters.isExistingPivot(s))return;const i=this.getters.getPivot(s);i.init();const r=i.getFields(),{columns:n,rows:a}=i.definition;let l=t.args;"PIVOT.VALUE"===t?.parent.toUpperCase()?(l=l.filter(((e,t)=>t%2==0)),l=l.slice(1,t.argPosition)):l=l.filter(((e,t)=>t%2==1));const c=l.map((e=>e?.value)).filter(at),h=n.map((e=>e.nameWithGranularity)),d=a.map((e=>e.nameWithGranularity)),u=[];let g=["ARG_SEPARATOR","SPACE"].includes(e.type)?c.at(-1):c.at(-2);const p=mS.get(i.type);if(p&&g?.startsWith("#")&&(g=g.slice(1)),void 0===g&&(u.push(h[0]),u.push(d[0])),d.includes(g)){const e=d[d.indexOf(g)+1];u.push(e),u.push(h[0])}if(h.includes(g)){const e=h[h.indexOf(g)+1];u.push(e)}const m=u.filter(at);return m.map((e=>{const[t,o]=e.split(":"),s=r[t];return s?cS(s,o):void 0})).concat(m.map((e=>{if(!p)return;const t=e.split(":")[0],o=r[t];if(!o)return;const s=`"#${e}"`;return{text:s,description:Oo("%s (positional)",o.string)+(o.help?` (${o.help})`:""),htmlContent:[{value:s,color:qb.STRING}],fuzzySearchKey:o.string+s}}))).filter(at)},selectProposal:hS}),bh.add("pivot_group_values",{sequence:50,autoSelectFirstProposal:!0,getProposals(e){const t=e.functionContext;if(!t||!e||!function(e){const t=e.functionContext;return"PIVOT.VALUE"===t?.parent.toUpperCase()&&t.argPosition>=2&&t.argPosition%2==1}(e)&&!function(e){const t=e.functionContext;return"PIVOT.HEADER"===t?.parent.toUpperCase()&&t.argPosition>=1&&t.argPosition%2==0}(e))return;const o=uS(e),s=this.getters.getPivotId(o);if(!s||!this.getters.isExistingPivot(s))return;const i=this.getters.getPivot(s);if(!i.isValid())return;const r=t.argPosition,n=e.functionContext?.args[r-1]?.value;if(!n)return;let a;try{a=i.definition.getDimension(n)}catch(e){return}return"month_number"===a.granularity?Object.values(jr).map(((e,t)=>({text:`${t+1}`,fuzzySearchKey:e.toString(),description:e.toString(),htmlContent:[{value:`${t+1}`,color:qb.NUMBER}]}))):"quarter_number"===a.granularity?[1,2,3,4].map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:Oo("Quarter %s",e),htmlContent:[{value:`${e}`,color:qb.NUMBER}]}))):"day_of_month"===a.granularity?Ze(1,32).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:qb.NUMBER}]}))):"iso_week_number"===a.granularity?Ze(0,54).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:qb.NUMBER}]}))):"day_of_week"===a.granularity?Ze(1,8).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:qb.NUMBER}]}))):"hour_number"===a.granularity?Ze(0,24).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:qb.NUMBER}]}))):"minute_number"===a.granularity?Ze(0,60).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:qb.NUMBER}]}))):"second_number"===a.granularity?Ze(0,60).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:qb.NUMBER}]}))):i.getPossibleFieldValues(a).map((({value:e,label:t})=>{const o="string"==typeof e,s=o?`"${e}"`:e.toString(),i=t===e?"":t;return{text:s,description:i,htmlContent:[{value:s,color:o?qb.STRING:qb.NUMBER}],fuzzySearchKey:e+i}}))},selectProposal:hS}),bh.add("sheet_names",{sequence:150,autoSelectFirstProposal:!0,getProposals(e){return"SYMBOL"===e.type||"UNKNOWN"===e.type&&e.value.startsWith("'")?this.getters.getSheetIds().map((e=>{const t=We(this.getters.getSheetName(e));return{text:t,fuzzySearchKey:t.startsWith("'")?t:"'"+t}})):[]},selectProposal(e,t){const o=e.start,s=e.end;this.composer.changeComposerCursorSelection(o,s),this.composer.replaceComposerCursorSelection(t+"!")}});const fS=new r;fS.add("ALPHANUMERIC_INCREMENT_MODIFIER",{apply:(e,t)=>{e.current+=e.increment;const o=`${e.prefix}${e.current.toString().padStart(e.numberPostfixLength||0,"0")}`;return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:o},tooltip:{props:{content:o}}}}}).add("INCREMENT_MODIFIER",{apply:(e,t,o)=>{e.current+=e.increment;const s=e.current.toString(),i=o.getLocale(),r=Xr(e.current,{format:t.cell?.format,locale:i});return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:s},tooltip:s?{props:{content:r}}:void 0}}}).add("DATE_INCREMENT_MODIFIER",{apply:(e,t,o)=>{const s=Yi(e.current,o.getLocale());s.setFullYear(s.getFullYear()+e.increment.years||0),s.setMonth(s.getMonth()+e.increment.months||0),s.setDate(s.getDate()+e.increment.days||0);const i=zs(s);e.current=i;const r=o.getLocale(),n=Xr(i,{format:t.cell?.format,locale:r});return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:i.toString()},tooltip:i?{props:{content:n}}:void 0}}}).add("COPY_MODIFIER",{apply:(e,t,o)=>{const s=t.cell?.content||"",i={locale:o.getLocale(),format:t.cell?.format};return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:s},tooltip:s?{props:{content:t.cell?xn(t.cell,i).formattedValue:""}}:void 0}}}).add("FORMULA_MODIFIER",{apply:(e,t,o,s)=>{e.current+=e.increment;let i=0,r=0;switch(s){case"up":i=0,r=-e.current;break;case"down":i=0,r=e.current;break;case"left":i=-e.current,r=0;break;case"right":i=e.current,r=0}const n=t.cell;if(!n||!n.isFormula)return{cellData:{}};const a=t.sheetId,l=o.getTranslatedCellFormula(a,i,r,n.compiledFormula.tokens);return{cellData:{border:t.border,style:n.style,format:n.format,content:l},tooltip:l?{props:{content:l}}:void 0}}});const vS=new r,bS=/(\d+)$/,SS=/^(.*\D+)/,yS=/^(.*\D+)(\d+)$/;function CS(e,t,o){let s=[],i=!1;for(let r of t){r===e&&(i=!0);const t=void 0===r||r.isFormula?void 0:xn(r,{locale:bi,format:r.format});if(t&&o(t))s.push(t);else{if(i)return s;s=[]}}return s}function wS(e){let t=1;return e.length>=2&&(t=function(e){const t=[];let o=e[0];for(let s=1;s<e.length;s++){const i=e[s];t.push(i-o),o=i}return t.reduce(((e,t)=>e+t),0)/t.length}(e)*e.length),t}function ES(e){if(e.length<2)return 1;const t=e.map((e=>Yi(e,bi))),o=function(e){if(e.length<2)return[{years:0,months:0,days:0}];const t=e.map(((t,o)=>{if(0===o)return{years:0,months:0,days:0};const s=xs.fromTimestamp(e[o-1].getTime()),i=Xs(s,t),r=js(s,t)%12;s.setFullYear(s.getFullYear()+i),s.setMonth(s.getMonth()+r);return{years:i,months:r,days:Ys(s,t)}}));return t.slice(1)}(t),s=(i=o).length<2?i[0]||{years:0,months:0,days:0}:i.every((e=>e.years===i[0].years&&e.months===i[0].months&&e.days===i[0].days))?i[0]:void 0;var i;if(void 0===s)return;const r=1===Object.values(s).filter((e=>0!==e)).length,n=Object.values(s).every((e=>0===e));if(!r||n){const o=t.map(((e,o)=>{if(0===o)return 0;const s=t[o-1];return Math.floor(e.getTime())-Math.floor(s.getTime())})).slice(1);if(o.every((e=>e===o[0])))return e.length*(e[1]-e[0])}return{years:s.years*e.length,months:s.months*e.length,days:s.days*e.length}}vS.add("simple_value_copy",{condition:(e,t)=>!(1!==t.length||e.isFormula||e.format&&rn(e.format)),generateRule:()=>({type:"COPY_MODIFIER"}),sequence:10}).add("increment_alphanumeric_value",{condition:e=>!e.isFormula&&xn(e,{locale:bi}).type===ii.text&&yS.test(e.content),generateRule:(e,t)=>{const o=parseInt(e.content.match(bS)[0]),s=e.content.match(SS)[0],i=e.content.length-s.length,r=wS(CS(e,t,(e=>e.type===ii.text&&yS.test(e.value))).filter((e=>s===(e.value??"").toString().match(SS)[0])).map((e=>parseInt((e.value??"").toString().match(bS)[0]))));return{type:"ALPHANUMERIC_INCREMENT_MODIFIER",prefix:s,current:o,increment:r,numberPostfixLength:i}},sequence:15}).add("copy_text",{condition:e=>!e.isFormula&&xn(e,{locale:bi}).type===ii.text,generateRule:()=>({type:"COPY_MODIFIER"}),sequence:20}).add("update_formula",{condition:e=>e.isFormula,generateRule:(e,t)=>({type:"FORMULA_MODIFIER",increment:t.length,current:0}),sequence:30}).add("increment_dates",{condition:(e,t)=>!e.isFormula&&xn(e,{locale:bi}).type===ii.number&&!!e.format&&rn(e.format),generateRule:(e,t)=>{const o=ES(CS(e,t,(e=>e.type===ii.number&&!!e.format&&rn(e.format))).map((e=>Number(e.value))));if(void 0===o)return{type:"COPY_MODIFIER"};const s=xn(e,{locale:bi});return"object"==typeof o?{type:"DATE_INCREMENT_MODIFIER",increment:o,current:s.type===ii.number?s.value:0}:{type:"INCREMENT_MODIFIER",increment:o,current:s.type===ii.number?s.value:0}},sequence:25}).add("increment_number",{condition:e=>!e.isFormula&&xn(e,{locale:bi}).type===ii.number,generateRule:(e,t)=>{const o=wS(CS(e,t,(e=>e.type===ii.number&&!rn(e.format||""))).map((e=>Number(e.value)))),s=xn(e,{locale:bi});return{type:"INCREMENT_MODIFIER",increment:o,current:s.type===ii.number?s.value:0}},sequence:40});const xS=new r,IS=30,RS=10,TS=20,AS=12,_S=80,DS="#F3F2F1",OS=6,FS=25;function MS(e,t){const o=e.getBoundingClientRect();e.width=o.width,e.height=o.height;const s=e.getContext("2d"),i=function(e,t,o){const s=t.maxValue,i=t.minValue,r=t.gaugeValue,n=function(e,t){const o=t?FS:0,s=e.height-TS-o-RS,i=e.width-2*IS;let r,n;i>2*s?(r=2*s,n=s):(r=i,n=i/2);const a=o+RS+(s-n)/2;return{x:IS+(i-r)/2,y:a,width:r,height:n}}(e,t.title.text),a=n.width/6,l=r?(r.value-i.value)/(s.value-i.value):0,c={x:e.width/2,y:n.y+n.height-n.height/12};let h=_S;n.height<300&&(h*=n.height/300);const d=n.width/2,u=r?.label||"-";Zn(o,u,{fontSize:h},"px")>d&&(h=function(e,t,o,s=.25){let i=1;if(o(i)>e)return i;if(o(t)<e)return t;let r=(i+t)/2,n=o(r),a=0;for(;Math.abs(n-e)>s&&a<20;)n>=e?t=(i+t)/2:i=(i+t)/2,r=(i+t)/2,n=o(r),a++;return r}(d,h,(e=>Zn(o,u,{fontSize:e},"px"))));const g={x:n.x+a/2,y:n.y+n.height+AS},p={x:n.x+n.width-a/2,y:n.y+n.height+AS},m=Bc(t.background),f=function(e,t,o,s){const i=e.maxValue,r=e.minValue,n={x:t.x+t.width/2,y:t.y+t.height},a={fontSize:AS},l=[],c=[];for(const h of e.inflectionValues){const e=(h.value-r.value)/(i.value-r.value),d=Zn(s,h.label,a,"px"),u=Math.PI-Math.PI*e,g=VS(u,t.height+OS,n.x,n.y,d+2,AS);let p=c.some((e=>LS(e,g)))?AS:0;c.push(g),l.push({rotation:u,label:h.label,fontSize:AS,color:o,offset:p})}return l}(t,n,m,o);let v=0,b=0,S=0;t.title.text&&({width:b,height:S}=Xn(o,t.title.text,{fontSize:X,...t.title},"px"));switch(t.title.align){case"right":v=e.width-b-Z;break;case"center":v=(e.width-b)/2;break;default:v=Z}return{width:e.width,height:e.height,title:{label:t.title.text??"",fontSize:t.title.fontSize??X,textPosition:{x:v,y:Y+S/2},color:t.title.color??m,bold:t.title.bold,italic:t.title.italic},backgroundColor:t.background,gauge:{rect:n,arcWidth:a,percentage:qe(l,0,1),color:PS(t)},inflectionValues:f,gaugeValue:{label:u,textPosition:c,fontSize:h,color:m},minLabel:{label:t.minValue.label,textPosition:g,fontSize:AS,color:m},maxLabel:{label:t.maxValue.label,textPosition:p,fontSize:AS,color:m}}}(o,t,s);!function(e,t){e.save(),e.fillStyle=t.backgroundColor,e.fillRect(0,0,t.width,t.height),e.restore()}(s,i),function(e,t){e.save();const o=t.gauge,s=o.rect.x+o.rect.width/2,i=o.rect.y+o.rect.height,r=o.rect.height-o.arcWidth/2;if(r<0)return;const n=1===o.percentage?0:Math.PI*(1+o.percentage);e.strokeStyle=DS,e.beginPath(),e.lineWidth=o.arcWidth,e.arc(s,i,r,n,0),e.stroke(),e.strokeStyle=o.color,e.beginPath(),e.arc(s,i,r,Math.PI,n),e.stroke(),e.restore()}(s,i),function(e,t){const{x:o,y:s,width:i,height:r}=t.gauge.rect;for(const n of t.inflectionValues){e.save(),e.translate(o+i/2-.5,s+r-.5),e.rotate(Math.PI/2-n.rotation),e.lineWidth=2,e.strokeStyle=Bc(t.backgroundColor)+"aa",e.beginPath(),e.moveTo(0,-(r-t.gauge.arcWidth)),e.lineTo(0,-r-3),e.stroke(),e.textAlign="center",e.font=`${n.fontSize}px ${fe}`,e.fillStyle=n.color;const a=-r-OS-n.offset;e.fillText(n.label,0,a),e.restore()}}(s,i),function(e,t){for(const o of[t.minLabel,t.maxLabel,t.gaugeValue])e.save(),e.textAlign="center",e.fillStyle=o.color,e.font=`${o.fontSize}px ${fe}`,e.fillText(o.label,o.textPosition.x,o.textPosition.y),e.restore()}(s,i),function(e,t){e.save();const o=t.title;e.font=Gn(o.fontSize,o.bold,o.italic),e.textBaseline="middle",e.fillStyle=o.color,e.fillText(o.label,o.textPosition.x,o.textPosition.y),e.restore()}(s,i)}function PS(e){const t=e.gaugeValue?.value;if(void 0===t)return DS;for(let o=0;o<e.inflectionValues.length;o++){const s=e.inflectionValues[o];if("<"===s.operator&&t<s.value)return e.colors[o];if("<="===s.operator&&t<=s.value)return e.colors[o]}return e.colors.at(-1)}function NS(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 kS(e,t){const o=e.start,s=e.end,i=t.start,r=t.end;function n(e,t,o){return(o.y-e.y)*(t.x-e.x)>(t.y-e.y)*(o.x-e.x)}return n(o,i,r)!==n(s,i,r)&&n(o,s,i)!==n(o,s,r)}function LS(e,t){const o=NS(e),s=NS(t);for(const e of o)for(const t of s)if(kS(e,t))return!0;return!1}function VS(e,t,o,s,i,r){const n=Math.cos(e),a=Math.sin(e),l=n*t,c=a*t,h=a*(i/2),d=n*(i/2),u=n*(t+r),g=a*(t+r);return{bottomLeft:{x:l-h+o,y:s-(c+d)},bottomRight:{x:l+h+o,y:s-(c-d)},topRight:{x:u+h+o,y:s-(g-d)},topLeft:{x:u-h+o,y:s-(g+d)}}}class HS extends t.Component{static template="o-spreadsheet-GaugeChartComponent";canvas=t.useRef("chartContainer");get runtime(){return this.env.model.getters.getChartRuntime(this.props.figure.id)}setup(){t.useEffect((()=>MS(this.canvas.el,this.runtime)),(()=>{const e=this.canvas.el.getBoundingClientRect();return[e.width,e.height,this.runtime,this.canvas.el]}))}}function US(e){return 8===(e=Ut(e).replace("#","")).length?e.slice(6)+e.slice(0,6):e}HS.props={figure:Object};const BS={responsive:!0,maintainAspectRatio:!1,elements:{line:{fill:!1},point:{hitRadius:15}},animation:!1};function zS(e){return e?e.length>Ce?e.substring(0,Ce)+"…":e:""}function $S(e,t,o){const s=document.createElement("div");s.style.width=`${t.width}px`,s.style.height=`${t.height}px`;const i=document.createElement("canvas");if(s.append(i),i.setAttribute("width",t.width.toString()),i.setAttribute("height",t.height.toString()),document.body.append(s),"chartJsConfig"in e){const t=Be(e.chartJsConfig);t.plugins=[WS];const o=new window.Chart(i,t),r=o.toBase64Image();return o.destroy(),s.remove(),r}if("scorecard"===o){dh(mh(t,e),i);const o=i.toDataURL();return s.remove(),o}if("gauge"===o){MS(i,e);const t=i.toDataURL();return s.remove(),t}}const WS={id:"customCanvasBackgroundColor",beforeDraw:e=>{const{ctx:t}=e;t.save(),t.globalCompositeOperation="destination-over",t.fillStyle="#ffffff",t.fillRect(0,0,e.width,e.height),t.restore()}};class GS{xmlString;constructor(e){this.xmlString=e}toString(){return this.xmlString}}const qS=["areaChart","area3DChart","lineChart","line3DChart","stockChart","radarChart","scatterChart","pieChart","pie3DChart","doughnutChart","barChart","bar3DChart","ofPieChart","surfaceChart","surface3DChart","bubbleChart","comboChart","radarChart"],ZS="000000",jS={arrow:"3Arrows",smiley:"3Symbols",dot:"3TrafficLights1"},YS={styleSheet:"http://schemas.openxmlformats.org/spreadsheetml/2006/main",sst:"http://schemas.openxmlformats.org/spreadsheetml/2006/main",Relationships:"http://schemas.openxmlformats.org/package/2006/relationships",Types:"http://schemas.openxmlformats.org/package/2006/content-types",worksheet:"http://schemas.openxmlformats.org/spreadsheetml/2006/main",workbook:"http://schemas.openxmlformats.org/spreadsheetml/2006/main",drawing:"http://schemas.openxmlformats.org/drawingml/2006/spreadsheetDrawing",table:"http://schemas.openxmlformats.org/spreadsheetml/2006/main",revision:"http://schemas.microsoft.com/office/spreadsheetml/2014/revision",revision3:"http://schemas.microsoft.com/office/spreadsheetml/2016/revision3",markupCompatibility:"http://schemas.openxmlformats.org/markup-compatibility/2006"},XS="http://schemas.openxmlformats.org/drawingml/2006/main",KS="http://schemas.openxmlformats.org/drawingml/2006/chart",JS={workbook:"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.main+xml",sheet:"application/vnd.openxmlformats-officedocument.spreadsheetml.worksheet+xml",sharedStrings:"application/vnd.openxmlformats-officedocument.spreadsheetml.sharedStrings+xml",styles:"application/vnd.openxmlformats-officedocument.spreadsheetml.styles+xml",drawing:"application/vnd.openxmlformats-officedocument.drawing+xml",chart:"application/vnd.openxmlformats-officedocument.drawingml.chart+xml",themes:"application/vnd.openxmlformats-officedocument.theme+xml",table:"application/vnd.openxmlformats-officedocument.spreadsheetml.table+xml",pivot:"application/vnd.openxmlformats-officedocument.spreadsheetml.pivotTable+xml",externalLink:"application/vnd.openxmlformats-officedocument.spreadsheetml.externalLink+xml"},QS={document:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument",sheet:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/worksheet",sharedStrings:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/sharedStrings",styles:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/styles",drawing:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/drawing",chart:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/chart",theme:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/theme",table:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/table",hyperlink:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/hyperlink",image:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/image"},ey="http://schemas.openxmlformats.org/officeDocument/2006/relationships",ty=.75,oy=.143,sy=8.43,iy=12.75,ry=30,ny=100,ay=164,ly={FLOOR:[{type:"NUMBER",value:1}],CEILING:[{type:"NUMBER",value:1}],ROUND:[{type:"NUMBER",value:0}],ROUNDUP:[{type:"NUMBER",value:0}],ROUNDDOWN:[{type:"NUMBER",value:0}]},cy=["ACOT","ACOTH","AGGREGATE","ARABIC","BASE","BETA.DIST","BETA.INV","BINOM.DIST","BINOM.DIST.RANGE","BINOM.INV","BITAND","BITLSHIFT","BITOR","BITRSHIFT","BITXOR","BYCOL","BYROW","CEILING.MATH","CEILING.PRECISE","CHISQ.DIST","CHISQ.DIST.RT","CHISQ.INV","CHISQ.INV.RT","CHISQ.TEST","CHOOSECOLS","CHOOSEROWS","COMBINA","CONCAT","CONFIDENCE.NORM","CONFIDENCE.T","COT","COTH","COVARIANCE.P","COVARIANCE.S","CSC","CSCH","DAYS","DECIMAL","DROP","ERF.PRECISE","ERFC.PRECISE","EXPAND","EXPON.DIST","F.DIST","F.DIST.RT","F.INV","F.INV.RT","F.TEST","FIELDVALUE","FILTERXML","FLOOR.MATH","FLOOR.PRECISE","FORECAST.ETS","FORECAST.ETS.CONFINT","FORECAST.ETS.SEASONALITY","FORECAST.ETS.STAT","FORECAST.LINEAR","FORMULATEXT","GAMMA","GAMMA.DIST","GAMMA.INV","GAMMALN.PRECISE","GAUSS","HSTACK","HYPGEOM.DIST","IFNA","IFS","IMCOSH","IMCOT","IMCSC","IMCSCH","IMSEC","IMSECH","IMSINH","IMTAN","ISFORMULA","ISOMITTED","ISOWEEKNUM","LAMBDA","LET","LOGNORM.DIST","LOGNORM.INV","MAKEARRAY","MAP","MAXIFS","MINIFS","MODE.MULT","MODE.SNGL","MUNIT","NEGBINOM.DIST","NORM.DIST","NORM.INV","NORM.S.DIST","NORM.S.INV","NUMBERVALUE","PDURATION","PERCENTILE.EXC","PERCENTILE.INC","PERCENTRANK.EXC","PERCENTRANK.INC","PERMUTATIONA","PHI","POISSON.DIST","PQSOURCE","PYTHON_STR","PYTHON_TYPE","PYTHON_TYPENAME","QUARTILE.EXC","QUARTILE.INC","QUERYSTRING","RANDARRAY","RANK.AVG","RANK.EQ","REDUCE","RRI","SCAN","SEC","SECH","SEQUENCE","SHEET","SHEETS","SKEW.P","SORTBY","STDEV.P","STDEV.S","SWITCH","T.DIST","T.DIST.2T","T.DIST.RT","T.INV","T.INV.2T","T.TEST","TAKE","TEXTAFTER","TEXTBEFORE","TEXTJOIN","TEXTSPLIT","TOCOL","TOROW","UNICHAR","UNICODE","UNIQUE","VAR.P","VAR.S","VSTACK","WEBSERVICE","WEIBULL.DIST","WRAPCOLS","WRAPROWS","XLOOKUP","XOR","Z.TEST"],hy="[Content_Types].xml",dy=new r,uy={};let gy=0;function py(e,...t){const o="__sheet__"+gy++;return function(e,t){const o=document.createElement("style");o.textContent=function(e){const t=e.split(/(\{|\}|;)/).map((e=>e.trim())),o=[],s=[];let i=[];function r(e,t){const s=[];for(const i of o[e]){let n=t&&t+" "+i||i;n.includes("&")&&(n=i.replace(/&/g,t||"")),e<o.length-1&&(n=r(e+1,n)),s.push(n)}return s.join(", ")}function n(){i.length&&(s.push(r(0)+" {"),s.push(...i),s.push("}"),i=[])}for(;t.length;){let e=t.shift();"}"===e?(n(),o.pop()):("{"===t[0]&&(n(),o.push(e.split(/\s*,\s*/)),t.shift()),";"===t[0]&&i.push(" "+e+";"))}return s.join("\n")}(t),uy[e]=o}(o,String.raw(e,...t)),function(e){const t=uy[e];t.setAttribute("component",e),document.head.appendChild(t)}(o),o}function my({strikethrough:e,underline:t}){return e||t?`${e?"line-through":""} ${t?"underline":""}`:"none"}function fy(e){const t=function(e){const t={};if(!e)return t;e.bold&&(t["font-weight"]="bold");e.italic&&(t["font-style"]="italic");if(e.strikethrough||e.underline){let o=e.strikethrough?"line-through":"";o=e.underline?o+" underline":o,t["text-decoration"]=o}e.textColor&&(t.color=e.textColor);return t}(e);return e?(e.fillColor&&(t.background=e.fillColor),t):t}function vy(e){let t="";for(const o in e)e[o]&&(t+=`${o}:${e[o]}; `);return t}py`
|
|
2
2
|
.o-spreadsheet {
|
|
3
3
|
.o-icon {
|
|
4
4
|
display: flex;
|
|
@@ -932,7 +932,7 @@
|
|
|
932
932
|
outline: ${z} solid 1px;
|
|
933
933
|
}
|
|
934
934
|
}
|
|
935
|
-
`;class GD extends t.Component{static template="o-spreadsheet-IconPicker";static props={onIconPicked:Function};icons=Sy;iconSets=yy;onIconClick(e){e&&this.props.onIconPicked(e)}}function qD(){let e;const o=document.body.style.cursor;let s=[];const i=()=>{e=void 0,document.body.style.cursor=o,s.forEach((e=>e())),s=[]};t.onWillUnmount((()=>{i()}));const r=t.useState({itemsStyle:{},draggedItemId:void 0,start:(t,n)=>{r.cancel=()=>{r.draggedItemId=void 0,r.itemsStyle={},document.body.style.cursor=o,n.onCancel?.(),i()};document.body.style.cursor="move",r.draggedItemId=n.draggedItemId;const a="horizontal"===t?new XD(n.
|
|
935
|
+
`;class GD extends t.Component{static template="o-spreadsheet-IconPicker";static props={onIconPicked:Function};icons=Sy;iconSets=yy;onIconClick(e){e&&this.props.onIconPicked(e)}}function qD(){let e;const o=document.body.style.cursor;let s=[];const i=()=>{e=void 0,document.body.style.cursor=o,s.forEach((e=>e())),s=[]};t.onWillUnmount((()=>{i()}));const r=t.useState({itemsStyle:{},draggedItemId:void 0,start:(t,n)=>{r.cancel=()=>{r.draggedItemId=void 0,r.itemsStyle={},document.body.style.cursor=o,n.onCancel?.(),i()};document.body.style.cursor="move",r.draggedItemId=n.draggedItemId;const a="horizontal"===t?new XD(n.scrollableContainerEl):new YD(n.scrollableContainerEl);e=new ZD({...n,container:a,onChange:()=>{document.body.style.cursor="move",e&&(Object.assign(r.itemsStyle,e.getItemStyles()),n.onChange?.())},onDragEnd:(e,t)=>{r.draggedItemId=void 0,r.itemsStyle={},document.body.style.cursor=o,n.onDragEnd?.(e,t),i()},onCancel:r.cancel});const l=Q_(e.onMouseMove.bind(e),e.onMouseUp.bind(e));s.push(l);const c=e.onScroll.bind(e);n.scrollableContainerEl.addEventListener("scroll",c),s.push((()=>n.scrollableContainerEl.removeEventListener("scroll",c))),s.push(e.destroy.bind(e))},cancel:()=>{}});return r}class ZD{draggedItemId;items;container;initialMousePosition;currentMousePosition;initialScroll;minPosition;maxPosition;edgeScrollIntervalId;onChange;onCancel;onDragEnd;deadZone;constructor(e){this.items=e.items.map((e=>({...e,positionAtStart:e.position}))),this.draggedItemId=e.draggedItemId,this.container=e.container,this.onChange=e.onChange,this.onCancel=e.onCancel,this.onDragEnd=e.onDragEnd,this.initialMousePosition=e.initialMousePosition,this.currentMousePosition=e.initialMousePosition,this.initialScroll=this.container.scroll,this.minPosition=this.items[0].position,this.maxPosition=this.items[this.items.length-1].position+this.items[this.items.length-1].size}getItemStyles(){const e={};for(let t of this.items)e[t.id]=this.getItemStyle(t.id);return e}getItemStyle(e){const t=this.container.cssPositionProperty,o={position:"relative"};return o[t]=(this.getItemsPositions()[e]||0)+"px",o.transition=`${t} 0.5s`,o["pointer-events"]="none",this.draggedItemId===e&&(o.transition=`${t} 0s`,o["z-index"]="1000"),vy(o)}onScroll(){this.moveDraggedItemToPosition(this.currentMousePosition+this.scrollOffset)}onMouseMove(e){if(e.button>1)return void this.onCancel();const t=this.container.getMousePosition(e);this.currentMousePosition=t,t<this.container.start||t>this.container.end?this.startEdgeScroll(t<this.container.start?-1:1):(this.stopEdgeScroll(),this.moveDraggedItemToPosition(t+this.scrollOffset))}moveDraggedItemToPosition(e){const t=this.getHoveredItemIndex(e,this.items),o=this.items.findIndex((e=>e.id===this.draggedItemId)),s=this.items[o];if(this.deadZone&&this.isInZone(e,this.deadZone))return void this.onChange(this.getItemsPositions());if(this.isInZone(e,{start:s.position,end:s.position+s.size})&&(this.deadZone=void 0),o===t)return void this.onChange(this.getItemsPositions());const i=Math.min(o,t),r=Math.max(o,t),n=Math.sign(t-o);let a=0;for(let e=i;e<=r;e++)e!==o&&(this.items[e].position-=n*s.size,a+=this.items[e].size);s.position+=n*a,this.items.sort(((e,t)=>e.position-t.position)),this.deadZone=n>0?{start:e,end:s.position}:{start:s.position+s.size,end:e},this.onChange(this.getItemsPositions())}onMouseUp(e){0!==e.button&&this.onCancel(),e.stopPropagation(),e.preventDefault();const t=this.items.findIndex((e=>e.id===this.draggedItemId));return this.onDragEnd(this.draggedItemId,t),this.stopEdgeScroll(),!1}startEdgeScroll(e){this.edgeScrollIntervalId||(this.edgeScrollIntervalId=window.setInterval((()=>{const t=3*e;this.container.scroll+=t}),5))}stopEdgeScroll(){window.clearInterval(this.edgeScrollIntervalId),this.edgeScrollIntervalId=void 0}getHoveredItemIndex(e,t){return e<=this.minPosition?0:e>=this.maxPosition?t.length-1:t.findIndex((t=>t.position+t.size>=e))}getItemsPositions(){const e={};for(let t of this.items){if(t.id!==this.draggedItemId){e[t.id]=t.position-t.positionAtStart;continue}let o=this.currentMousePosition-this.initialMousePosition+this.scrollOffset;o=Math.max(this.minPosition-t.positionAtStart,o),o=Math.min(this.maxPosition-t.positionAtStart-t.size,o),e[t.id]=o}return e}isInZone(e,t){return e>=t.start&&e<=t.end}get scrollOffset(){return this.container.scroll-this.initialScroll}destroy(){this.stopEdgeScroll()}}class jD{el;constructor(e){this.el=e}get containerRect(){return this.el.getBoundingClientRect()}}class YD extends jD{get start(){return this.containerRect.top}get end(){return this.containerRect.bottom}get cssPositionProperty(){return"top"}get scroll(){return this.el.scrollTop}set scroll(e){this.el.scrollTop=e}getMousePosition(e){return e.clientY}}class XD extends jD{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}}function KD(e,...o){t.useEffect((e=>(e?.addEventListener(...o),()=>e?.removeEventListener(...o))),(()=>[e.el]))}function JD(e,o){const s=function(e){const o=t.useState({hovered:!1});return KD(e,"mouseenter",(()=>o.hovered=!0)),KD(e,"mouseleave",(()=>o.hovered=!1)),o}(e);QD({get highlights(){return s.hovered?o.highlights:[]}})}function QD(e){const o=bc(),s=yc(zb);t.onMounted((()=>{s.register(e)}));let i=e.highlights;t.useEffect((e=>{mt(e,i)||(i=e,o.trigger("store-updated"))}),(()=>[e.highlights]))}py`
|
|
936
936
|
.o-cf-preview {
|
|
937
937
|
&.o-cf-cursor-ptr {
|
|
938
938
|
cursor: pointer;
|
|
@@ -1002,7 +1002,7 @@
|
|
|
1002
1002
|
color: #6aa84f;
|
|
1003
1003
|
}
|
|
1004
1004
|
}
|
|
1005
|
-
`;class eO extends t.Component{static template="o-spreadsheet-ConditionalFormatPreview";icons=Sy;ref=t.useRef("cfPreview");setup(){JD(this.ref,this)}getPreviewImageStyle(){const e=this.props.conditionalFormat.rule;if("CellIsRule"===e.type)return vy(fy(e.style));if("ColorScaleRule"===e.type){const t=Vt(e.minimum.color),o=e.midpoint?Vt(e.midpoint.color):null,s=Vt(e.maximum.color),i="background-image: linear-gradient(to right, ";return o?i+t+", "+o+", "+s+")":i+t+", "+s+")"}if("DataBarRule"===e.type){return`background-image: linear-gradient(to right, ${Vt(e.color)} 50%, white 50%)`}return""}getDescription(){const e=this.props.conditionalFormat;switch(e.rule.type){case"CellIsRule":const t=dE[e.rule.operator];return 1===e.rule.values.length?`${t} ${e.rule.values[0]}`:2===e.rule.values.length?Oo("%s %s and %s",t,e.rule.values[0],e.rule.values[1]):t;case"ColorScaleRule":return hE.ColorScale;case"IconSetRule":return hE.IconSet;case"DataBarRule":return hE.DataBar}}deleteConditionalFormat(){this.env.model.dispatch("REMOVE_CONDITIONAL_FORMAT",{id:this.props.conditionalFormat.id,sheetId:this.env.model.getters.getActiveSheetId()})}onMouseDown(e){this.props.onMouseDown(e)}get highlights(){const e=this.env.model.getters.getActiveSheetId();return this.props.conditionalFormat.ranges.map((t=>({sheetId:e,zone:this.env.model.getters.getRangeFromSheetXC(e,t).zone,color:a,fillAlpha:.06})))}}eO.props={conditionalFormat:Object,onPreviewClick:Function,onMouseDown:Function,class:String};class tO extends t.Component{static template="o-spreadsheet-ConditionalFormatPreviewList";static props={conditionalFormats:Array,onPreviewClick:Function,onAddConditionalFormat:Function};static components={ConditionalFormatPreview:eO};icons=Sy;dragAndDrop=qD();cfListRef=t.useRef("cfList");setup(){t.onWillUpdateProps((e=>{mt(this.props.conditionalFormats,e.conditionalFormats)||this.dragAndDrop.cancel()}))}getPreviewDivStyle(e){return this.dragAndDrop.itemsStyle[e.id]||""}onPreviewMouseDown(e,t){if(0!==t.button)return;const o=Array.from(this.cfListRef.el.children).map((e=>KI(e))),s=this.props.conditionalFormats.map(((e,t)=>({id:e.id,size:o[t].height,position:o[t].y})));this.dragAndDrop.start("vertical",{draggedItemId:e.id,initialMousePosition:t.clientY,items:s,
|
|
1005
|
+
`;class eO extends t.Component{static template="o-spreadsheet-ConditionalFormatPreview";icons=Sy;ref=t.useRef("cfPreview");setup(){JD(this.ref,this)}getPreviewImageStyle(){const e=this.props.conditionalFormat.rule;if("CellIsRule"===e.type)return vy(fy(e.style));if("ColorScaleRule"===e.type){const t=Vt(e.minimum.color),o=e.midpoint?Vt(e.midpoint.color):null,s=Vt(e.maximum.color),i="background-image: linear-gradient(to right, ";return o?i+t+", "+o+", "+s+")":i+t+", "+s+")"}if("DataBarRule"===e.type){return`background-image: linear-gradient(to right, ${Vt(e.color)} 50%, white 50%)`}return""}getDescription(){const e=this.props.conditionalFormat;switch(e.rule.type){case"CellIsRule":const t=dE[e.rule.operator];return 1===e.rule.values.length?`${t} ${e.rule.values[0]}`:2===e.rule.values.length?Oo("%s %s and %s",t,e.rule.values[0],e.rule.values[1]):t;case"ColorScaleRule":return hE.ColorScale;case"IconSetRule":return hE.IconSet;case"DataBarRule":return hE.DataBar}}deleteConditionalFormat(){this.env.model.dispatch("REMOVE_CONDITIONAL_FORMAT",{id:this.props.conditionalFormat.id,sheetId:this.env.model.getters.getActiveSheetId()})}onMouseDown(e){this.props.onMouseDown(e)}get highlights(){const e=this.env.model.getters.getActiveSheetId();return this.props.conditionalFormat.ranges.map((t=>({sheetId:e,zone:this.env.model.getters.getRangeFromSheetXC(e,t).zone,color:a,fillAlpha:.06})))}}eO.props={conditionalFormat:Object,onPreviewClick:Function,onMouseDown:Function,class:String};class tO extends t.Component{static template="o-spreadsheet-ConditionalFormatPreviewList";static props={conditionalFormats:Array,onPreviewClick:Function,onAddConditionalFormat:Function};static components={ConditionalFormatPreview:eO};icons=Sy;dragAndDrop=qD();cfListRef=t.useRef("cfList");setup(){t.onWillUpdateProps((e=>{mt(this.props.conditionalFormats,e.conditionalFormats)||this.dragAndDrop.cancel()}))}getPreviewDivStyle(e){return this.dragAndDrop.itemsStyle[e.id]||""}onPreviewMouseDown(e,t){if(0!==t.button)return;const o=Array.from(this.cfListRef.el.children).map((e=>KI(e))),s=this.props.conditionalFormats.map(((e,t)=>({id:e.id,size:o[t].height,position:o[t].y})));this.dragAndDrop.start("vertical",{draggedItemId:e.id,initialMousePosition:t.clientY,items:s,scrollableContainerEl:this.cfListRef.el,onDragEnd:(e,t)=>this.onDragEnd(e,t)})}onDragEnd(e,t){const o=this.props.conditionalFormats.findIndex((t=>t.id===e))-t;0!==o&&this.env.model.dispatch("CHANGE_CONDITIONAL_FORMAT_PRIORITY",{cfId:e,delta:o,sheetId:this.env.model.getters.getActiveSheetId()})}}py`
|
|
1006
1006
|
.o-cf-ruleEditor {
|
|
1007
1007
|
.o-cf-preview-display {
|
|
1008
1008
|
border: 1px solid ${D};
|
|
@@ -1288,7 +1288,7 @@
|
|
|
1288
1288
|
.add-calculated-measure {
|
|
1289
1289
|
cursor: pointer;
|
|
1290
1290
|
}
|
|
1291
|
-
`;class UO extends t.Component{static template="o-spreadsheet-PivotLayoutConfigurator";static components={AddDimensionButton:FO,PivotDimension:NO,PivotDimensionOrder:LO,PivotDimensionGranularity:kO,PivotMeasureEditor:VO,PivotSortSection:HO};static props={definition:Object,onDimensionsUpdated:Function,unusedGroupableFields:Array,measureFields:Array,unusedGranularities:Object,dateGranularities:Array,datetimeGranularities:Array,pivotId:String};dimensionsRef=t.useRef("pivot-dimensions");dragAndDrop=qD();AGGREGATORS=zl;composerFocus;isDateOrDatetimeField=jl;setup(){this.composerFocus=Sc(_c)}startDragAndDrop(e,t){if(0!==t.button||"SELECT"===t.target.tagName)return;const o=this.getDimensionElementsRects(),s=this.props.definition,{columns:i,rows:r}=s,n=[...i.map((e=>e.nameWithGranularity)),"__rows_title__",...r.map((e=>e.nameWithGranularity))],a=i.concat(r),l=n.map(((e,t)=>({id:e,size:o[t+1].height,position:o[t+1].y})));this.dragAndDrop.start("vertical",{draggedItemId:e.nameWithGranularity,initialMousePosition:t.clientY,items:l,containerEl:this.dimensionsRef.el,onDragEnd:(e,t)=>{const o=n.findIndex((t=>t===e));if(o===t)return;const s=[...n];s.splice(o,1),s.splice(t,0,e);const i=s.slice(0,s.indexOf("__rows_title__")),r=s.slice(s.indexOf("__rows_title__")+1);this.props.onDimensionsUpdated({columns:i.map((e=>a.find((t=>t.nameWithGranularity===e)))).filter(at),rows:r.map((e=>a.find((t=>t.nameWithGranularity===e)))).filter(at)})}})}getGranularitiesFor(e){return jl(e)?"date"===e.type?this.props.dateGranularities:this.props.datetimeGranularities:[]}startDragAndDropMeasures(e,t){if(0!==t.button||"SELECT"===t.target.tagName||"INPUT"===t.target.tagName||"inactive"!==this.composerFocus.focusMode)return;const o=this.getDimensionElementsRects(),s=this.props.definition,{measures:i,columns:r,rows:n}=s,a=i.map((e=>e.id)),l=3+r.length+n.length,c=a.map(((e,t)=>({id:e,size:o[t+l].height,position:o[t+l].y})));this.dragAndDrop.start("vertical",{draggedItemId:e.id,initialMousePosition:t.clientY,items:c,containerEl:this.dimensionsRef.el,onDragEnd:(e,t)=>{const o=a.findIndex((t=>t===e));if(o===t)return;const s=[...a];s.splice(o,1),s.splice(t,0,e),this.props.onDimensionsUpdated({measures:s.map((e=>i.find((t=>t.id===e)))).filter(at)})}})}getDimensionElementsRects(){return Array.from(this.dimensionsRef.el.children).map((e=>{const t=getComputedStyle(e),o=e.getBoundingClientRect();return{x:o.x,y:o.y,width:o.width+parseInt(t.marginLeft||"0")+parseInt(t.marginRight||"0"),height:o.height+parseInt(t.marginTop||"0")+parseInt(t.marginBottom||"0")}}))}removeDimension(e){const{columns:t,rows:o}=this.props.definition;this.props.onDimensionsUpdated({columns:t.filter((t=>t.nameWithGranularity!==e.nameWithGranularity)),rows:o.filter((t=>t.nameWithGranularity!==e.nameWithGranularity))})}removeMeasureDimension(e){const{measures:t}=this.props.definition;this.props.onDimensionsUpdated({measures:t.filter((t=>t.id!==e.id))})}addColumnDimension(e){const{columns:t}=this.props.definition;this.props.onDimensionsUpdated({columns:t.concat([{fieldName:e,order:"asc"}])})}addRowDimension(e){const{rows:t}=this.props.definition;this.props.onDimensionsUpdated({rows:t.concat([{fieldName:e,order:"asc"}])})}addMeasureDimension(e){const{measures:t}=this.props.definition,o=this.getDefaultMeasureAggregator(e);this.props.onDimensionsUpdated({measures:t.concat([{id:this.getMeasureId(e,o),fieldName:e,aggregator:o}])})}updateMeasure(e,t){const{measures:o}=this.props.definition,s={measures:o.map((o=>o.id===e.id?t:o))};this.props.definition.sortedColumn?.measure===e.id&&(s.sortedColumn={...this.props.definition.sortedColumn,measure:t.id}),this.props.onDimensionsUpdated(s)}getMeasureId(e,t){const o=e+(t?`:${t}`:"");let s=o,i=2;for(;this.props.definition.measures.some((e=>e.id===s));)s=`${o}:${i}`,i++;return s}getDefaultMeasureAggregator(e){const t=this.props.measureFields.find((t=>t.name===e));return t?.aggregator?t.aggregator:"count"}addCalculatedMeasure(){const{measures:e}=this.props.definition,t=this.env.model.getters.generateNewCalculatedMeasureName(e);this.props.onDimensionsUpdated({measures:e.concat([{id:this.getMeasureId(t),fieldName:t,aggregator:"sum",computedBy:{sheetId:this.env.model.getters.getActiveSheetId(),formula:"=0"}}])})}updateOrder(e,t){const{rows:o,columns:s}=this.props.definition;this.props.onDimensionsUpdated({rows:o.map((o=>o.nameWithGranularity===e.nameWithGranularity?{...o,order:t||void 0}:o)),columns:s.map((o=>o.nameWithGranularity===e.nameWithGranularity?{...o,order:t||void 0}:o))})}updateGranularity(e,t){const{rows:o,columns:s}=this.props.definition;this.props.onDimensionsUpdated({rows:o.map((o=>o.nameWithGranularity===e.nameWithGranularity?{...o,granularity:t}:o)),columns:s.map((o=>o.nameWithGranularity===e.nameWithGranularity?{...o,granularity:t}:o))})}getMeasureDescription(e){const t=e.display;if(!t||"no_calculations"===t.type)return"";const o=this.env.model.getters.getPivot(this.props.pivotId),s=[...o.definition.columns,...o.definition.rows].find((e=>e.nameWithGranularity===t.fieldNameWithGranularity)),i=s?ic(s):"";return SE.descriptions[t.type](i)}}class BO extends t.Component{static template="o-spreadsheet-PivotTitleSection";static components={CogWheelMenu:PO,Section:V_,TextInput:MO};static props={pivotId:String,flipAxis:Function};get cogWheelMenuItems(){return[{name:Oo("Flip axes"),icon:"o-spreadsheet-Icon.EXCHANGE",execute:this.props.flipAxis},{name:Oo("Duplicate"),icon:"o-spreadsheet-Icon.COPY",execute:()=>this.duplicatePivot()},{name:Oo("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(){const e=this.env.model.uuidGenerator.uuidv4(),t=this.env.model.uuidGenerator.uuidv4(),o=this.env.model.dispatch("DUPLICATE_PIVOT_IN_NEW_SHEET",{pivotId:this.props.pivotId,newPivotId:e,newSheetId:t});let s;s=o.isSuccessful?Oo("Pivot duplicated."):o.isCancelledBecause("PivotInError")?Oo("Cannot duplicate a pivot in error."):Oo("Pivot duplication failed.");const i=o.isSuccessful?"success":"danger";this.env.notifyUser({text:s,sticky:!1,type:i}),o.isSuccessful&&this.env.openSidePanel("PivotSidePanel",{pivotId:e})}delete(){this.env.askConfirmation(Oo("Are you sure you want to delete this pivot?"),(()=>{this.env.model.dispatch("REMOVE_PIVOT",{pivotId:this.props.pivotId})}))}onNameChanged(e){const t=this.env.model.getters.getPivotCoreDefinition(this.props.pivotId);this.env.model.dispatch("UPDATE_PIVOT",{pivotId:this.props.pivotId,pivot:{...t,name:e}})}}class zO{measures;columns;rows;sortedColumn;constructor(e,t){this.measures=e.measures.map((e=>function(e,t){const o=t.fieldName,s="__count"===o?{name:"__count",string:Oo("Count"),type:"integer",aggregator:"sum"}:e[o],i=t.aggregator;return{id:t.id,get displayName(){return t.userDefinedName??s?.string??t.fieldName},userDefinedName:t.userDefinedName,fieldName:o,aggregator:i,type:"__count"===o?"integer":s?.type??"integer",isValid:!(!s&&!t.computedBy),isHidden:t.isHidden,format:t.format,computedBy:t.computedBy,display:t.display}}(t,e))),this.columns=e.columns.map((e=>$O(t,e))),this.rows=e.rows.map((e=>$O(t,e))),this.sortedColumn=e.sortedColumn}getDimension(e){const t=this.columns.find((t=>t.nameWithGranularity===e))||this.rows.find((t=>t.nameWithGranularity===e));if(!t)throw new Ri(Oo("Dimension %s does not exist",e));return t}getMeasure(e){const t=this.measures.find((t=>t.id===e));if(!t)throw new Ri(Oo("Field %s is not a measure",e));return t}}function $O(e,t){const o=e[t.fieldName],s=o?.type??"integer",i=o&&jl(o)?t.granularity:void 0;return{displayName:o?.string??t.fieldName,nameWithGranularity:t.fieldName+(i?`:${i}`:""),fieldName:t.fieldName,granularity:i,type:s,order:t.order,isValid:!!o}}class WO extends zO{range;constructor(e,t,o){if(super(e,t),e.dataSet){const{sheetId:t,zone:s}=e.dataSet;this.range=o.getRangeFromZone(t,s)}}}class GO{columns;rows;measures;fieldsType;maxIndent;pivotCells={};rowTree;colTree;isSorted=!1;constructor(e,t,o,s){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=o,this.fieldsType=s,this.maxIndent=Math.max(...this.rows.map((e=>e.indent))),this.rowTree=ut((()=>this.buildRowsTree())),this.colTree=ut((()=>this.buildColumnsTree()))}getNumberOfDataColumns(){return this.columns.at(-1)?.length||0}getPivotCells(e=!0,t=!0){const o=JSON.stringify({includeTotal:e,includeColumnHeaders:t});if(!this.pivotCells[o]){const s=this.rows.length,i=this.getNumberOfDataColumns();let r=this.columns.length+s,n=1+i;e||1===s||(r-=1),e||i===this.measures.length||(n-=this.measures.length);const a=[],l=t?0:this.columns.length;for(let t=0;t<n;t++){a.push([]);for(let o=l;o<r;o++)(e||o!==r)&&a[t].push(this.getPivotCell(t,o,e))}this.pivotCells[o]=a}return this.pivotCells[o]}getRowTree(){return this.rowTree()}getColTree(){return this.colTree()}isTotalRow(e){return this.rows[e].indent!==this.maxIndent}getPivotCell(e,t,o=!0){const s=this.columns.length;if(e>0&&t===s-1){const o=this.getColHeaderDomain(e,t);if(!o)return qO;const s=o.at(-1)?.value?.toString()||"";return{type:"MEASURE_HEADER",domain:o.slice(0,-1),measure:s}}if(t<=s-1){const o=this.getColHeaderDomain(e,t);return o?{type:"HEADER",domain:o}:qO}if(0===e){const e=t-s;return{type:"HEADER",domain:this.getRowDomain(e)}}{const i=t-s;if(!o&&this.isTotalRow(i))return qO;return{type:"VALUE",domain:[...this.getRowDomain(i),...this.getColDomain(e)],measure:this.getColMeasure(e)}}}getColHeaderDomain(e,t){if(0===e)return;const o=[],s=this.columns[t].find((t=>t.offset===e));if(s){for(let e=0;e<s.fields.length;e++){const t=s.fields[e];if("measure"===t)o.push({type:"char",field:t,value:Jl({displayName:"measure",type:"char"},s.values[e])});else{const{fieldName:i,granularity:r}=Zl(t),n=this.fieldsType[i]||"char";o.push({type:n,field:t,value:Jl({displayName:i,type:n,granularity:r},s.values[e])})}}return o}}getColDomain(e){const t=this.getColHeaderDomain(e,this.columns.length-1);return t?t.slice(0,-1):[]}getColMeasure(e){const t=this.getColHeaderDomain(e,this.columns.length-1),o=t?.at(-1)?.value;if(null==o)throw new Error("Measure is missing");return o.toString()}getRowDomain(e){const t=[];for(let o=0;o<this.rows[e].fields.length;o++){const s=this.rows[e].fields[o],{fieldName:i,granularity:r}=Zl(s),n=this.fieldsType[i]||"char";t.push({type:n,field:s,value:Jl({displayName:i,type:n,granularity:r},this.rows[e].values[o])})}return t}buildRowsTree(){const e=[];let t=0;const o={};o[0]=e;for(const s of this.rows){if(0===s.fields.length||0===s.values.length)return e;const i=s.fields.length-1,r=s.fields[i],{fieldName:n,granularity:a}=Zl(r),l=Jl({displayName:n,type:this.fieldsType[n]??"char",granularity:a},s.values[i]);if(i>t){t=i,o[t]=[];const e=o[t-1].at(-1);e&&(e.children=o[t])}t=i;const c={value:l,field:s.fields[i],children:[],type:this.fieldsType[n]||"char",width:0};o[t].push(c)}return e}buildColumnsTree(){const e=[],t=this.columns.at(-2)||[],o={};o[0]=e;for(const e of t)for(let t=0;t<e.fields.length;t++){const s=e.fields[t],{fieldName:i,granularity:r}=Zl(s),n=Jl({displayName:i,type:this.fieldsType[i]??"char",granularity:r},e.values[t]),a={value:n,field:e.fields[t],children:[],width:e.width,type:this.fieldsType[i]||"char"};o[t]?.at(-1)?.value!==n&&(o[t+1]=[],a.children=o[t+1],o[t].push(a))}return e}export(){return{cols:this.columns,rows:this.rows,measures:this.measures,fieldsType:this.fieldsType}}sort(e,t,o){if(this.isSorted)return;const s=(e,t)=>{const s=o(e,t).value;return"number"==typeof s?s:-1/0},i=t.domain,r=Il(this.rowTree(),[],((o,r)=>{const n=s(e,[...o,...i]),a=s(e,[...r,...i]);return"asc"===t.order?n-a:a-n}));this.rowTree=ut(r),this.rows=[...this.rowTreeToRows(r),this.rows[this.rows.length-1]],this.isSorted=!0}rowTreeToRows(e,t){return e.flatMap((e=>{const o={indent:t?t.indent+1:0,fields:[...t?.fields||[],e.field],values:[...t?.values||[],e.value]};return[o,...this.rowTreeToRows(e.children,o)]}))}}const qO={type:"EMPTY"};function ZO(e,t){const o=t.measures.filter((e=>!e.isHidden)).map((e=>e.id)),s=YO(e,t.columns,0);XO(s,o.length);const i=function(e,t){const o=t.columns.map((e=>e.nameWithGranularity)),s=o.length,i=t.measures.filter((e=>!e.isHidden)),r=i.length,n=new Array(s).fill(0).map((()=>[]));function a(e,t,i){const r=n[t];for(const n of e){const e=i.concat([n.value]),l={fields:o.slice(0,t+1),values:e,width:n.width,offset:0};r.push(l),t<=s-1&&a(n.children,t+1,e)}}a(e,0,[]);const l=o.length>0,c=[];l&&n[n.length-1].forEach((e=>{i.forEach((t=>{const o={fields:[...e.fields,"measure"],values:[...e.values,t.id],width:1,offset:0};c.push(o)}))}));i.forEach((e=>{const t={fields:["measure"],values:[e.id],width:1,offset:0};c.push(t)})),n.push(c),1===n.length&&n.unshift([]);return n[n.length-2].push({fields:[],values:[],width:r,offset:0}),n}(s,t),r=jO(e,0,t.rows,[],[]);r.push({fields:[],values:[],indent:0});const n={};for(const e of t.columns)n[e.fieldName]=e.type;for(const e of t.rows)n[e.fieldName]=e.type;return new GO(i,r,o,n)}function jO(e,t,o,s,i){if(t>=o.length)return[];const r=o[t],n=r.nameWithGranularity,a=KO(e,r),l=JO(a,r),c=[],h=s.concat(n);for(const e of l){const s=i.concat(e);c.push({fields:h,values:s,indent:t});const r=a[e];r&&c.push(...jO(r,t+1,o,h,s))}return c}function YO(e,t,o){if(o>=t.length)return[];const s=t[o],i=t[o].nameWithGranularity,r=KO(e,s);return JO(r,t[o]).map((e=>({value:r[e]?.[0]?.[s.nameWithGranularity]?.value??null,field:i,children:YO(r[e]||[],t,o+1),type:s.type,width:0})))}function XO(e,t){for(const o in e){const s=e[o];0===s.children.length?s.width=t:(XO(s.children,t),s.width=s.children.reduce(((e,t)=>e+t.width),0))}}function KO(e,t){return Object.groupBy(e,function(e){const t=e.nameWithGranularity;return e=>`${e[t]?.value??null}`}(t))}function JO(e,t){return t.order?Object.keys(e).sort(((e,o)=>function(e,t,o){if("null"===t)return"asc"===e.order?1:-1;if("null"===o)return"asc"===e.order?-1:1;if("integer"===e.type||"datetime"===e.type)return"asc"===e.order?Number(t)-Number(o):Number(o)-Number(t);return"asc"===e.order?t.localeCompare(o):o.localeCompare(t)}(t,e,o))):Object.keys(e)}const QO=Symbol("NULL");function eF(e,t,o){const s=e.granularity;if(!s||!(s in tF))throw new Error(`Unknown date granularity: ${s}`);const i="number"==typeof t||"string"==typeof t?t:QO;if(!tF[s].set.has(t)){tF[s].set.add(t);let r=null;if("number"==typeof t||"string"==typeof t){const e=Yi(t,o);switch(s){case"year":r=e.getFullYear();break;case"quarter_number":r=Math.floor(e.getMonth()/3)+1;break;case"month_number":r=e.getMonth()+1;break;case"iso_week_number":r=e.getIsoWeek();break;case"day_of_month":r=e.getDate();break;case"day":r=Math.floor(Li(t,o));break;case"day_of_week":r=(e.getDay()+7-o.weekStart)%7+1;break;case"hour_number":r=e.getHours();break;case"minute_number":r=e.getMinutes();break;case"second_number":r=e.getSeconds()}}tF[s].values[i]=Jl(e,r)}return tF[s].values[i]}const tF={year:{set:new Set,values:{}},quarter_number:{set:new Set,values:{}},month_number:{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:{}}};var oF;!function(e){e[e.NONE=0]="NONE",e[e.TABLE=1]="TABLE",e[e.DATA=2]="DATA",e[e.DEFINITION=3]="DEFINITION",e[e.ALL=4]="ALL"}(oF||(oF={}));const sF=new r,iF=["year","quarter_number","month_number","iso_week_number","day_of_month","day","day_of_week"];sF.add("SPREADSHEET",{ui: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(oF.ALL),this.needsReevaluation=!1)}reload(e){e===oF.ALL&&(this.metaData=this.loadMetaData()),e>=oF.DEFINITION&&(this._definition=this.loadRuntimeDefinition()),e>=oF.DATA&&(this.dataEntries=this.loadData()),e>=oF.TABLE&&(this.table=void 0)}onDefinitionChange(e){const t=this.coreDefinition;if(this.coreDefinition=e,this._definition){const o=Math.max(this.computeShouldReload(t,e),oF.NONE);this.reload(o)}}computeShouldReload(e,t){return mt(e.dataSet,t.dataSet)?oF.DEFINITION:oF.ALL}get isInvalidRange(){return!!this.invalidRangeError}get invalidRangeMessage(){return this.invalidRangeError?.message}get definition(){if(this._definition||this.init(),!this._definition)throw new Error("Pivot definition should be defined at this point.");return this._definition}isValid(){if(this.invalidRangeError||!this.definition)return!1;for(const e of this.definition.measures)if(!e.isValid)return!1;for(const e of this.definition.columns)if(!e.isValid)return!1;for(const 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 Ri(Oo("At least one measure and/or dimension is not correct."));return{value:xi.GenericError,message:this.invalidRangeError?.message??Oo("At least one measure and/or dimension is not correct.")}}}areDomainArgsFieldsValid(e){let t=e.filter(((e,t)=>t%2==0)).map(Gi);return t.length&&"measure"===t.at(-1)&&(t=t.slice(0,-1)),Xl(t,this.definition)}parseArgsToPivotDomain(e){const t=[];for(let o=0;o<e.length-1;o+=2){const s=Gi(e[o]),i=this.getTypeOfDimension(s),r="measure"===s?Gi(e[o+1]):Jl(this.getDimension(s),e[o+1]);t.push({field:s,value:r,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){const t=e.at(-1);if(!t)return{value:Oo("Total")};const o=this.getDimension(t.field),s=this.filterDataEntriesFromDomain(this.dataEntries,e),i=s[0]?.[o.nameWithGranularity];if("datetime"===o.type){return Tl(o.granularity).toValueAndFormat(t.value,this.getters.getLocale())}return i?null===i.value?{value:Oo("(Undefined)")}:{value:i.value,format:i.format}:{value:""}}getPivotCellValueAndFormat(e,t){const o=this.filterDataEntriesFromDomain(this.dataEntries,t);if(0===o.length)return{value:""};const s=this.getMeasure(e),i=o.map((e=>e[s.fieldName])).filter(at),r=i.filter((e=>e.type!==ii.empty)),n=s.aggregator,a=$l[n];if(!a)throw new Error(`Aggregator ${n} does not exist`);try{const e=a([i],this.getters.getLocale());return 0===r.length?{...e,value:""}:e}catch(e){return Lb(e,n.toUpperCase())}}getPossibleFieldValues(e){const t=[],o=KO(this.dataEntries,e),s=JO(o,e);for(const i of s)t.push({value:o[i]?.[0]?.[e.nameWithGranularity]?.value??"",label:o[i]?.[0]?.[e.nameWithGranularity]?.formattedValue||""});return t}getTableStructure(){if(!this.isValid())throw new Error("Pivot is not valid !");return this.table||(this.table=ZO(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)return this.invalidRangeError=new Ri(Oo("The pivot cannot be created because the dataset is missing.")),{fields:{},fieldKeys:[]};{const{zone:e,sheetId:t}=this.coreDefinition.dataSet,o=this.getters.getRangeFromZone(t,e);try{return this.extractFieldsFromRange(o)}catch(e){return this.invalidRangeError=e,{fields:{},fieldKeys:[]}}}}loadRuntimeDefinition(){return new WO(this.coreDefinition,this.fields,this.getters)}loadData(){const e=this._definition?.range;return this.isValid()&&e?this.extractDataEntriesFromRange(e):[]}getTypeOfDimension(e){if("measure"===e)return"char";const{fieldName:t}=Zl(e),o=this.fields[t]?.type;if(!o)throw new Error(`Field ${t} does not exist`);return o}filterDataEntriesFromDomain(e,t){return t.reduce(((e,t)=>this.filterDataEntriesFromDomainNode(e,t)),e)}filterDataEntriesFromDomainNode(e,t){const{field:o,value:s}=t,{nameWithGranularity:i}=this.getDimension(o);return e.filter((e=>e[i]?.value===s))}getDimension(e){return this.definition.getDimension(e)}getTypeFromZone(e,t){const o=this.getters.getEvaluatedCellsInZone(e,t).filter((e=>e.type!==ii.empty));return 0===o.length?"integer":o.every((e=>e.format&&rn(e.format)))?"datetime":o.every((e=>e.type===ii.boolean))?"boolean":o.some((e=>e.type===ii.text))?"char":"integer"}assertCellIsValidField(e,t,o){if(o.type===ii.error)throw new Ri(Oo("The pivot cannot be created because cell %s contains an error",So(e,t)));if(o.type===ii.empty||""===o.value)throw new Ri(Oo("The pivot cannot be created because cell %s is empty",So(e,t)));if("__count"===o.value)throw new Ri(Oo("The pivot cannot be created because cell %s contains a reserved value",So(e,t)))}extractFieldsFromRange(e){const t={},o=[],s=e.sheetId,i=e.zone.top;for(let r=e.zone.left;r<=e.zone.right;r++){const n=this.getters.getEvaluatedCell({sheetId:s,col:r,row:i});this.assertCellIsValidField(r,i,n);const a=n.value?.toString();if(a){const i=this.getTypeFromZone(s,{top:e.zone.top+1,left:r,bottom:e.zone.bottom,right:r}),n=this.findName(a,t);t[n]={name:n,type:i,string:n,aggregator:"integer"===i?"sum":"count"},o.push(n)}}return{fields:t,fieldKeys:o}}findName(e,t){let o=1;const s=e;for(;e in t;)e=`${s}${++o}`;return e}extractDataEntriesFromRange(e){const t=[];for(let o=e.zone.top+1;o<=e.zone.bottom;o++){const s={top:o,bottom:o,left:e.zone.left,right:e.zone.right},i=this.getters.getEvaluatedCellsInZone(e.sheetId,s),r={};for(const e in i){const t=i[e],o=this.fields[this.metaData.fieldKeys[e]];if(!o)throw new Error(`Field ${this.metaData.fieldKeys[e]} does not exist`);""===t.value?r[o.name]={value:null,type:ii.empty,formattedValue:""}:r[o.name]=t}r.__count={value:1,type:ii.number,formattedValue:"1"},t.push(r)}const o=this.definition.columns.concat(this.definition.rows).filter((e=>"datetime"===e.type));if(o.length){const e=this.getters.getLocale();for(const s of t)for(const t of o){const o=eF(t,s[t.fieldName]?.value||null,this.getters.getLocale()),i=Tl(t.granularity),{format:r,value:n}=i.toValueAndFormat(o,e);s[t.nameWithGranularity]={value:o,type:s[t.fieldName]?.type||ii.empty,format:s[t.fieldName]?.format,formattedValue:Xr(n,{locale:e,format:r})}}}return t}},definition:WO,externalData:!1,onIterationEndEvaluation:e=>e.markAsDirtyForEvaluation(),dateGranularities:[...iF],datetimeGranularities:[...iF,"hour_number","minute_number","second_number"],isMeasureCandidate:e=>!["datetime","boolean"].includes(e.type),isGroupable:()=>!0});class rF extends Tc{pivotId;mutators=["reset","deferUpdates","applyUpdate","discardPendingUpdate","update"];updatesAreDeferred;draft=null;notification=this.get($b);alreadyNotified=!1;constructor(e,t){super(e),this.pivotId=t,this.updatesAreDeferred=this.getters.getPivotCoreDefinition(this.pivotId).deferUpdates??!1}handle(e){if("UPDATE_PIVOT"===e.type)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(){const e=sF.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(){const e=[{name:"__count",string:Oo("Count"),type:"integer",aggregator:"sum"}],t=this.fields;for(const o in t){const s=t[o];s&&(sF.get(this.pivot.type).isMeasureCandidate(s)&&e.push(s))}return e.sort(((e,t)=>e.string.localeCompare(t.string)))}get unusedGroupableFields(){const e=[],t=this.fields;for(const o in t){const s=t[o];s&&(sF.get(this.pivot.type).isGroupable(s)&&e.push(s))}const{columns:o,rows:s,measures:i}=this.definition,r=i.concat(s).concat(o).map((e=>e.fieldName)),n=this.unusedGranularities;return e.filter((e=>jl(e)?!r.includes(e.name)||n[e.name].size>0:!r.includes(e.name))).sort(((e,t)=>e.string.localeCompare(t.string)))}get datetimeGranularities(){return sF.get(this.pivot.type).datetimeGranularities}get dateGranularities(){return sF.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){!1===e&&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.isDynamicPivotInViewport()&&this.isStaticPivotInViewport())){const e=`=PIVOT(${this.getters.getPivotFormulaId(this.pivotId)})`;this.alreadyNotified=!0,this.notification.notifyUser({type:"info",text:Oo("Pivot updates only work with dynamic pivot tables. Use %s or re-insert the static pivot from the Data menu.",e),sticky:!1})}}discardPendingUpdate(){this.draft=null}update(e){const t=this.getters.getPivotCoreDefinition(this.pivotId),o={...t,...this.draft,...e},s={...o,columns:o.columns.map((e=>({fieldName:e.fieldName,order:e.order,granularity:e.granularity}))),rows:o.rows.map((e=>({fieldName:e.fieldName,order:e.order,granularity:e.granularity}))),measures:o.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(o)?o.sortedColumn:void 0};if(!this.draft&&mt(t,s))return;const i=this.addDefaultDateTimeGranularity(this.fields,s);this.draft=i,this.updatesAreDeferred||this.applyUpdate()}isDynamicPivotInViewport(){const e=this.getters.getActiveSheetId();for(const t of this.getters.getSheetViewVisibleCols())for(const o of this.getters.getSheetViewVisibleRows()){if(this.getters.isSpillPivotFormula({sheetId:e,col:t,row:o}))return!0}return!1}isStaticPivotInViewport(){for(const e of this.getters.getVisibleCellPositions()){const t=this.getters.getCell(e);if(t?.isFormula){const e=gS(t.compiledFormula.tokens);if(e&&"PIVOT"!==e.functionName)return!0}}return!1}addDefaultDateTimeGranularity(e,t){const{columns:o,rows:s}=t,i=Be(o),r=Be(s),n=this.getUnusedGranularities(e,t);for(const t of i.concat(r)){const o=e[t.fieldName]?.type;if(("date"===o||"datetime"===o)&&!t.granularity){const e=n[t.fieldName]?.values().next().value||"year";n[t.fieldName]?.delete(e),t.granularity=e}}return{...t,columns:i,rows:r}}getUnusedGranularities(e,t){const{columns:o,rows:s}=t,i=o.concat(s).filter((t=>{const o=e[t.fieldName]?.type;return"date"===o||"datetime"===o})),r={};for(const t of i)r[t.fieldName]=new Set("date"===e[t.fieldName]?.type?this.dateGranularities:this.datetimeGranularities);for(const e of i)r[e.fieldName].delete(e.granularity);return r}shouldKeepSortedColumn(e){const{sortedColumn:t}=e;if(!t)return!0;const o=this.getters.getPivotCoreDefinition(this.pivotId);return e.measures.find((e=>e.id===t.measure))&&mt(o.columns,e.columns)}}class nF extends t.Component{static template="o-spreadsheet-PivotSpreadsheetSidePanel";static props={pivotId:String,onCloseSidePanel:Function};static components={PivotLayoutConfigurator:UO,Section:V_,SelectionInput:$_,Checkbox:OI,PivotDeferUpdate:OO,PivotTitleSection:BO};store;state;setup(){this.store=yc(rF,this.props.pivotId),this.state=t.useState({range:void 0,rangeHasChanged:!1})}get shouldDisplayInvalidRangeError(){return(!this.store.isDirty||!this.state.rangeHasChanged)&&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}onSelectionChanged(e){this.state.rangeHasChanged=!0,this.state.range=e[0]}onSelectionConfirmed(){if(this.state.range){const e=this.env.model.getters.getRangeFromSheetXC(this.env.model.getters.getActiveSheetId(),this.state.range);if(e.invalidSheetName||e.invalidXc)return;const t={sheetId:e.sheetId,zone:e.zone};this.store.update({dataSet:t}),this.store.applyUpdate()}}flipAxis(){const{rows:e,columns:t}=this.definition;this.onDimensionsUpdated({rows:t,columns:e})}onDimensionsUpdated(e){this.store.update(e)}}const aF=new r;aF.add("SPREADSHEET",{editor:nF});class lF extends t.Component{static template="o-spreadsheet-PivotSidePanel";static props={pivotId:String,onCloseSidePanel:Function};static components={PivotLayoutConfigurator:UO,Section:V_};setup(){QD(this)}get sidePanelEditor(){const e=this.env.model.getters.getPivotCoreDefinition(this.props.pivotId);if(!e)throw new Error("pivotId does not correspond to a pivot.");return aF.get(e.type).editor}get highlights(){return N_(this.env.model.getters,this.props.pivotId)}}py`
|
|
1291
|
+
`;class UO extends t.Component{static template="o-spreadsheet-PivotLayoutConfigurator";static components={AddDimensionButton:FO,PivotDimension:NO,PivotDimensionOrder:LO,PivotDimensionGranularity:kO,PivotMeasureEditor:VO,PivotSortSection:HO};static props={definition:Object,onDimensionsUpdated:Function,unusedGroupableFields:Array,measureFields:Array,unusedGranularities:Object,dateGranularities:Array,datetimeGranularities:Array,getScrollableContainerEl:{type:Function,optional:!0},pivotId:String};dimensionsRef=t.useRef("pivot-dimensions");dragAndDrop=qD();AGGREGATORS=zl;composerFocus;isDateOrDatetimeField=jl;setup(){this.composerFocus=Sc(_c)}startDragAndDrop(e,t){if(0!==t.button||"SELECT"===t.target.tagName)return;const o=this.getDimensionElementsRects(),s=this.props.definition,{columns:i,rows:r}=s,n=[...i.map((e=>e.nameWithGranularity)),"__rows_title__",...r.map((e=>e.nameWithGranularity))],a=i.concat(r),l=n.map(((e,t)=>({id:e,size:o[t+1].height,position:o[t+1].y})));this.dragAndDrop.start("vertical",{draggedItemId:e.nameWithGranularity,initialMousePosition:t.clientY,items:l,scrollableContainerEl:this.props.getScrollableContainerEl?.()||this.dimensionsRef.el,onDragEnd:(e,t)=>{const o=n.findIndex((t=>t===e));if(o===t)return;const s=[...n];s.splice(o,1),s.splice(t,0,e);const i=s.slice(0,s.indexOf("__rows_title__")),r=s.slice(s.indexOf("__rows_title__")+1);this.props.onDimensionsUpdated({columns:i.map((e=>a.find((t=>t.nameWithGranularity===e)))).filter(at),rows:r.map((e=>a.find((t=>t.nameWithGranularity===e)))).filter(at)})}})}getGranularitiesFor(e){return jl(e)?"date"===e.type?this.props.dateGranularities:this.props.datetimeGranularities:[]}startDragAndDropMeasures(e,t){if(0!==t.button||"SELECT"===t.target.tagName||"INPUT"===t.target.tagName||"inactive"!==this.composerFocus.focusMode)return;const o=this.getDimensionElementsRects(),s=this.props.definition,{measures:i,columns:r,rows:n}=s,a=i.map((e=>e.id)),l=3+r.length+n.length,c=a.map(((e,t)=>({id:e,size:o[t+l].height,position:o[t+l].y})));this.dragAndDrop.start("vertical",{draggedItemId:e.id,initialMousePosition:t.clientY,items:c,scrollableContainerEl:this.props.getScrollableContainerEl?.()||this.dimensionsRef.el,onDragEnd:(e,t)=>{const o=a.findIndex((t=>t===e));if(o===t)return;const s=[...a];s.splice(o,1),s.splice(t,0,e),this.props.onDimensionsUpdated({measures:s.map((e=>i.find((t=>t.id===e)))).filter(at)})}})}getDimensionElementsRects(){return Array.from(this.dimensionsRef.el.children).map((e=>{const t=getComputedStyle(e),o=e.getBoundingClientRect();return{x:o.x,y:o.y,width:o.width+parseInt(t.marginLeft||"0")+parseInt(t.marginRight||"0"),height:o.height+parseInt(t.marginTop||"0")+parseInt(t.marginBottom||"0")}}))}removeDimension(e){const{columns:t,rows:o}=this.props.definition;this.props.onDimensionsUpdated({columns:t.filter((t=>t.nameWithGranularity!==e.nameWithGranularity)),rows:o.filter((t=>t.nameWithGranularity!==e.nameWithGranularity))})}removeMeasureDimension(e){const{measures:t}=this.props.definition;this.props.onDimensionsUpdated({measures:t.filter((t=>t.id!==e.id))})}addColumnDimension(e){const{columns:t}=this.props.definition;this.props.onDimensionsUpdated({columns:t.concat([{fieldName:e,order:"asc"}])})}addRowDimension(e){const{rows:t}=this.props.definition;this.props.onDimensionsUpdated({rows:t.concat([{fieldName:e,order:"asc"}])})}addMeasureDimension(e){const{measures:t}=this.props.definition,o=this.getDefaultMeasureAggregator(e);this.props.onDimensionsUpdated({measures:t.concat([{id:this.getMeasureId(e,o),fieldName:e,aggregator:o}])})}updateMeasure(e,t){const{measures:o}=this.props.definition,s={measures:o.map((o=>o.id===e.id?t:o))};this.props.definition.sortedColumn?.measure===e.id&&(s.sortedColumn={...this.props.definition.sortedColumn,measure:t.id}),this.props.onDimensionsUpdated(s)}getMeasureId(e,t){const o=e+(t?`:${t}`:"");let s=o,i=2;for(;this.props.definition.measures.some((e=>e.id===s));)s=`${o}:${i}`,i++;return s}getDefaultMeasureAggregator(e){const t=this.props.measureFields.find((t=>t.name===e));return t?.aggregator?t.aggregator:"count"}addCalculatedMeasure(){const{measures:e}=this.props.definition,t=this.env.model.getters.generateNewCalculatedMeasureName(e);this.props.onDimensionsUpdated({measures:e.concat([{id:this.getMeasureId(t),fieldName:t,aggregator:"sum",computedBy:{sheetId:this.env.model.getters.getActiveSheetId(),formula:"=0"}}])})}updateOrder(e,t){const{rows:o,columns:s}=this.props.definition;this.props.onDimensionsUpdated({rows:o.map((o=>o.nameWithGranularity===e.nameWithGranularity?{...o,order:t||void 0}:o)),columns:s.map((o=>o.nameWithGranularity===e.nameWithGranularity?{...o,order:t||void 0}:o))})}updateGranularity(e,t){const{rows:o,columns:s}=this.props.definition;this.props.onDimensionsUpdated({rows:o.map((o=>o.nameWithGranularity===e.nameWithGranularity?{...o,granularity:t}:o)),columns:s.map((o=>o.nameWithGranularity===e.nameWithGranularity?{...o,granularity:t}:o))})}getMeasureDescription(e){const t=e.display;if(!t||"no_calculations"===t.type)return"";const o=this.env.model.getters.getPivot(this.props.pivotId),s=[...o.definition.columns,...o.definition.rows].find((e=>e.nameWithGranularity===t.fieldNameWithGranularity)),i=s?ic(s):"";return SE.descriptions[t.type](i)}}class BO extends t.Component{static template="o-spreadsheet-PivotTitleSection";static components={CogWheelMenu:PO,Section:V_,TextInput:MO};static props={pivotId:String,flipAxis:Function};get cogWheelMenuItems(){return[{name:Oo("Flip axes"),icon:"o-spreadsheet-Icon.EXCHANGE",execute:this.props.flipAxis},{name:Oo("Duplicate"),icon:"o-spreadsheet-Icon.COPY",execute:()=>this.duplicatePivot()},{name:Oo("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(){const e=this.env.model.uuidGenerator.uuidv4(),t=this.env.model.uuidGenerator.uuidv4(),o=this.env.model.dispatch("DUPLICATE_PIVOT_IN_NEW_SHEET",{pivotId:this.props.pivotId,newPivotId:e,newSheetId:t});let s;s=o.isSuccessful?Oo("Pivot duplicated."):o.isCancelledBecause("PivotInError")?Oo("Cannot duplicate a pivot in error."):Oo("Pivot duplication failed.");const i=o.isSuccessful?"success":"danger";this.env.notifyUser({text:s,sticky:!1,type:i}),o.isSuccessful&&this.env.openSidePanel("PivotSidePanel",{pivotId:e})}delete(){this.env.askConfirmation(Oo("Are you sure you want to delete this pivot?"),(()=>{this.env.model.dispatch("REMOVE_PIVOT",{pivotId:this.props.pivotId})}))}onNameChanged(e){const t=this.env.model.getters.getPivotCoreDefinition(this.props.pivotId);this.env.model.dispatch("UPDATE_PIVOT",{pivotId:this.props.pivotId,pivot:{...t,name:e}})}}class zO{measures;columns;rows;sortedColumn;constructor(e,t){this.measures=e.measures.map((e=>function(e,t){const o=t.fieldName,s="__count"===o?{name:"__count",string:Oo("Count"),type:"integer",aggregator:"sum"}:e[o],i=t.aggregator;return{id:t.id,get displayName(){return t.userDefinedName??s?.string??t.fieldName},userDefinedName:t.userDefinedName,fieldName:o,aggregator:i,type:"__count"===o?"integer":s?.type??"integer",isValid:!(!s&&!t.computedBy),isHidden:t.isHidden,format:t.format,computedBy:t.computedBy,display:t.display}}(t,e))),this.columns=e.columns.map((e=>$O(t,e))),this.rows=e.rows.map((e=>$O(t,e))),this.sortedColumn=e.sortedColumn}getDimension(e){const t=this.columns.find((t=>t.nameWithGranularity===e))||this.rows.find((t=>t.nameWithGranularity===e));if(!t)throw new Ri(Oo("Dimension %s does not exist",e));return t}getMeasure(e){const t=this.measures.find((t=>t.id===e));if(!t)throw new Ri(Oo("Field %s is not a measure",e));return t}}function $O(e,t){const o=e[t.fieldName],s=o?.type??"integer",i=o&&jl(o)?t.granularity:void 0;return{displayName:o?.string??t.fieldName,nameWithGranularity:t.fieldName+(i?`:${i}`:""),fieldName:t.fieldName,granularity:i,type:s,order:t.order,isValid:!!o}}class WO extends zO{range;constructor(e,t,o){if(super(e,t),e.dataSet){const{sheetId:t,zone:s}=e.dataSet;this.range=o.getRangeFromZone(t,s)}}}class GO{columns;rows;measures;fieldsType;maxIndent;pivotCells={};rowTree;colTree;isSorted=!1;constructor(e,t,o,s){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=o,this.fieldsType=s,this.maxIndent=Math.max(...this.rows.map((e=>e.indent))),this.rowTree=ut((()=>this.buildRowsTree())),this.colTree=ut((()=>this.buildColumnsTree()))}getNumberOfDataColumns(){return this.columns.at(-1)?.length||0}getPivotCells(e=!0,t=!0){const o=JSON.stringify({includeTotal:e,includeColumnHeaders:t});if(!this.pivotCells[o]){const s=this.rows.length,i=this.getNumberOfDataColumns();let r=this.columns.length+s,n=1+i;e||1===s||(r-=1),e||i===this.measures.length||(n-=this.measures.length);const a=[],l=t?0:this.columns.length;for(let t=0;t<n;t++){a.push([]);for(let o=l;o<r;o++)(e||o!==r)&&a[t].push(this.getPivotCell(t,o,e))}this.pivotCells[o]=a}return this.pivotCells[o]}getRowTree(){return this.rowTree()}getColTree(){return this.colTree()}isTotalRow(e){return this.rows[e].indent!==this.maxIndent}getPivotCell(e,t,o=!0){const s=this.columns.length;if(e>0&&t===s-1){const o=this.getColHeaderDomain(e,t);if(!o)return qO;const s=o.at(-1)?.value?.toString()||"";return{type:"MEASURE_HEADER",domain:o.slice(0,-1),measure:s}}if(t<=s-1){const o=this.getColHeaderDomain(e,t);return o?{type:"HEADER",domain:o}:qO}if(0===e){const e=t-s;return{type:"HEADER",domain:this.getRowDomain(e)}}{const i=t-s;if(!o&&this.isTotalRow(i))return qO;return{type:"VALUE",domain:[...this.getRowDomain(i),...this.getColDomain(e)],measure:this.getColMeasure(e)}}}getColHeaderDomain(e,t){if(0===e)return;const o=[],s=this.columns[t].find((t=>t.offset===e));if(s){for(let e=0;e<s.fields.length;e++){const t=s.fields[e];if("measure"===t)o.push({type:"char",field:t,value:Jl({displayName:"measure",type:"char"},s.values[e])});else{const{fieldName:i,granularity:r}=Zl(t),n=this.fieldsType[i]||"char";o.push({type:n,field:t,value:Jl({displayName:i,type:n,granularity:r},s.values[e])})}}return o}}getColDomain(e){const t=this.getColHeaderDomain(e,this.columns.length-1);return t?t.slice(0,-1):[]}getColMeasure(e){const t=this.getColHeaderDomain(e,this.columns.length-1),o=t?.at(-1)?.value;if(null==o)throw new Error("Measure is missing");return o.toString()}getRowDomain(e){const t=[];for(let o=0;o<this.rows[e].fields.length;o++){const s=this.rows[e].fields[o],{fieldName:i,granularity:r}=Zl(s),n=this.fieldsType[i]||"char";t.push({type:n,field:s,value:Jl({displayName:i,type:n,granularity:r},this.rows[e].values[o])})}return t}buildRowsTree(){const e=[];let t=0;const o={};o[0]=e;for(const s of this.rows){if(0===s.fields.length||0===s.values.length)return e;const i=s.fields.length-1,r=s.fields[i],{fieldName:n,granularity:a}=Zl(r),l=Jl({displayName:n,type:this.fieldsType[n]??"char",granularity:a},s.values[i]);if(i>t){t=i,o[t]=[];const e=o[t-1].at(-1);e&&(e.children=o[t])}t=i;const c={value:l,field:s.fields[i],children:[],type:this.fieldsType[n]||"char",width:0};o[t].push(c)}return e}buildColumnsTree(){const e=[],t=this.columns.at(-2)||[],o={};o[0]=e;for(const e of t)for(let t=0;t<e.fields.length;t++){const s=e.fields[t],{fieldName:i,granularity:r}=Zl(s),n=Jl({displayName:i,type:this.fieldsType[i]??"char",granularity:r},e.values[t]),a={value:n,field:e.fields[t],children:[],width:e.width,type:this.fieldsType[i]||"char"};o[t]?.at(-1)?.value!==n&&(o[t+1]=[],a.children=o[t+1],o[t].push(a))}return e}export(){return{cols:this.columns,rows:this.rows,measures:this.measures,fieldsType:this.fieldsType}}sort(e,t,o){if(this.isSorted)return;const s=(e,t)=>{const s=o(e,t).value;return"number"==typeof s?s:-1/0},i=t.domain,r=Il(this.rowTree(),[],((o,r)=>{const n=s(e,[...o,...i]),a=s(e,[...r,...i]);return"asc"===t.order?n-a:a-n}));this.rowTree=ut(r),this.rows=[...this.rowTreeToRows(r),this.rows[this.rows.length-1]],this.isSorted=!0}rowTreeToRows(e,t){return e.flatMap((e=>{const o={indent:t?t.indent+1:1,fields:[...t?.fields||[],e.field],values:[...t?.values||[],e.value]};return[o,...this.rowTreeToRows(e.children,o)]}))}}const qO={type:"EMPTY"};function ZO(e,t){const o=t.measures.filter((e=>!e.isHidden)).map((e=>e.id)),s=YO(e,t.columns,0);XO(s,o.length);const i=function(e,t){const o=t.columns.map((e=>e.nameWithGranularity)),s=o.length,i=t.measures.filter((e=>!e.isHidden)),r=i.length,n=new Array(s).fill(0).map((()=>[]));function a(e,t,i){const r=n[t];for(const n of e){const e=i.concat([n.value]),l={fields:o.slice(0,t+1),values:e,width:n.width,offset:0};r.push(l),t<=s-1&&a(n.children,t+1,e)}}a(e,0,[]);const l=o.length>0,c=[];l&&n[n.length-1].forEach((e=>{i.forEach((t=>{const o={fields:[...e.fields,"measure"],values:[...e.values,t.id],width:1,offset:0};c.push(o)}))}));i.forEach((e=>{const t={fields:["measure"],values:[e.id],width:1,offset:0};c.push(t)})),n.push(c),1===n.length&&n.unshift([]);return n[n.length-2].push({fields:[],values:[],width:r,offset:0}),n}(s,t),r=jO(e,0,t.rows,[],[]);r.push({fields:[],values:[],indent:0});const n={};for(const e of t.columns)n[e.fieldName]=e.type;for(const e of t.rows)n[e.fieldName]=e.type;return new GO(i,r,o,n)}function jO(e,t,o,s,i){if(t>=o.length)return[];const r=o[t],n=r.nameWithGranularity,a=KO(e,r),l=JO(a,r),c=[],h=s.concat(n);for(const e of l){const s=i.concat(e);c.push({fields:h,values:s,indent:t+1});const r=a[e];r&&c.push(...jO(r,t+1,o,h,s))}return c}function YO(e,t,o){if(o>=t.length)return[];const s=t[o],i=t[o].nameWithGranularity,r=KO(e,s);return JO(r,t[o]).map((e=>({value:r[e]?.[0]?.[s.nameWithGranularity]?.value??null,field:i,children:YO(r[e]||[],t,o+1),type:s.type,width:0})))}function XO(e,t){for(const o in e){const s=e[o];0===s.children.length?s.width=t:(XO(s.children,t),s.width=s.children.reduce(((e,t)=>e+t.width),0))}}function KO(e,t){return Object.groupBy(e,function(e){const t=e.nameWithGranularity;return e=>`${e[t]?.value??null}`}(t))}function JO(e,t){return t.order?Object.keys(e).sort(((e,o)=>function(e,t,o){if("null"===t)return"asc"===e.order?1:-1;if("null"===o)return"asc"===e.order?-1:1;if("integer"===e.type||"datetime"===e.type)return"asc"===e.order?Number(t)-Number(o):Number(o)-Number(t);return"asc"===e.order?t.localeCompare(o):o.localeCompare(t)}(t,e,o))):Object.keys(e)}const QO=Symbol("NULL");function eF(e,t,o){const s=e.granularity;if(!s||!(s in tF))throw new Error(`Unknown date granularity: ${s}`);const i="number"==typeof t||"string"==typeof t?t:QO;if(!tF[s].set.has(t)){tF[s].set.add(t);let r=null;if("number"==typeof t||"string"==typeof t){const e=Yi(t,o);switch(s){case"year":r=e.getFullYear();break;case"quarter_number":r=Math.floor(e.getMonth()/3)+1;break;case"month_number":r=e.getMonth()+1;break;case"iso_week_number":r=e.getIsoWeek();break;case"day_of_month":r=e.getDate();break;case"day":r=Math.floor(Li(t,o));break;case"day_of_week":r=(e.getDay()+7-o.weekStart)%7+1;break;case"hour_number":r=e.getHours();break;case"minute_number":r=e.getMinutes();break;case"second_number":r=e.getSeconds()}}tF[s].values[i]=Jl(e,r)}return tF[s].values[i]}const tF={year:{set:new Set,values:{}},quarter_number:{set:new Set,values:{}},month_number:{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:{}}};var oF;!function(e){e[e.NONE=0]="NONE",e[e.TABLE=1]="TABLE",e[e.DATA=2]="DATA",e[e.DEFINITION=3]="DEFINITION",e[e.ALL=4]="ALL"}(oF||(oF={}));const sF=new r,iF=["year","quarter_number","month_number","iso_week_number","day_of_month","day","day_of_week"];sF.add("SPREADSHEET",{ui: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(oF.ALL),this.needsReevaluation=!1)}reload(e){e===oF.ALL&&(this.metaData=this.loadMetaData()),e>=oF.DEFINITION&&(this._definition=this.loadRuntimeDefinition()),e>=oF.DATA&&(this.dataEntries=this.loadData()),e>=oF.TABLE&&(this.table=void 0)}onDefinitionChange(e){const t=this.coreDefinition;if(this.coreDefinition=e,this._definition){const o=Math.max(this.computeShouldReload(t,e),oF.NONE);this.reload(o)}}computeShouldReload(e,t){return mt(e.dataSet,t.dataSet)?oF.DEFINITION:oF.ALL}get isInvalidRange(){return!!this.invalidRangeError}get invalidRangeMessage(){return this.invalidRangeError?.message}get definition(){if(this._definition||this.init(),!this._definition)throw new Error("Pivot definition should be defined at this point.");return this._definition}isValid(){if(this.invalidRangeError||!this.definition)return!1;for(const e of this.definition.measures)if(!e.isValid)return!1;for(const e of this.definition.columns)if(!e.isValid)return!1;for(const 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 Ri(Oo("At least one measure and/or dimension is not correct."));return{value:xi.GenericError,message:this.invalidRangeError?.message??Oo("At least one measure and/or dimension is not correct.")}}}areDomainArgsFieldsValid(e){let t=e.filter(((e,t)=>t%2==0)).map(Gi);return t.length&&"measure"===t.at(-1)&&(t=t.slice(0,-1)),Xl(t,this.definition)}parseArgsToPivotDomain(e){const t=[];for(let o=0;o<e.length-1;o+=2){const s=Gi(e[o]),i=this.getTypeOfDimension(s),r="measure"===s?Gi(e[o+1]):Jl(this.getDimension(s),e[o+1]);t.push({field:s,value:r,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){const t=e.at(-1);if(!t)return{value:Oo("Total")};const o=this.getDimension(t.field),s=this.filterDataEntriesFromDomain(this.dataEntries,e),i=s[0]?.[o.nameWithGranularity];if("datetime"===o.type){return Tl(o.granularity).toValueAndFormat(t.value,this.getters.getLocale())}return i?null===i.value?{value:Oo("(Undefined)")}:{value:i.value,format:i.format}:{value:""}}getPivotCellValueAndFormat(e,t){const o=this.filterDataEntriesFromDomain(this.dataEntries,t);if(0===o.length)return{value:""};const s=this.getMeasure(e),i=o.map((e=>e[s.fieldName])).filter(at),r=i.filter((e=>e.type!==ii.empty)),n=s.aggregator,a=$l[n];if(!a)throw new Error(`Aggregator ${n} does not exist`);try{const e=a([i],this.getters.getLocale());return 0===r.length?{...e,value:""}:e}catch(e){return Lb(e,n.toUpperCase())}}getPossibleFieldValues(e){const t=[],o=KO(this.dataEntries,e),s=JO(o,e);for(const i of s)t.push({value:o[i]?.[0]?.[e.nameWithGranularity]?.value??"",label:o[i]?.[0]?.[e.nameWithGranularity]?.formattedValue||""});return t}getTableStructure(){if(!this.isValid())throw new Error("Pivot is not valid !");return this.table||(this.table=ZO(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)return this.invalidRangeError=new Ri(Oo("The pivot cannot be created because the dataset is missing.")),{fields:{},fieldKeys:[]};{const{zone:e,sheetId:t}=this.coreDefinition.dataSet,o=this.getters.getRangeFromZone(t,e);try{return this.extractFieldsFromRange(o)}catch(e){return this.invalidRangeError=e,{fields:{},fieldKeys:[]}}}}loadRuntimeDefinition(){return new WO(this.coreDefinition,this.fields,this.getters)}loadData(){const e=this._definition?.range;return this.isValid()&&e?this.extractDataEntriesFromRange(e):[]}getTypeOfDimension(e){if("measure"===e)return"char";const{fieldName:t}=Zl(e),o=this.fields[t]?.type;if(!o)throw new Error(`Field ${t} does not exist`);return o}filterDataEntriesFromDomain(e,t){return t.reduce(((e,t)=>this.filterDataEntriesFromDomainNode(e,t)),e)}filterDataEntriesFromDomainNode(e,t){const{field:o,value:s}=t,{nameWithGranularity:i}=this.getDimension(o);return e.filter((e=>e[i]?.value===s))}getDimension(e){return this.definition.getDimension(e)}getTypeFromZone(e,t){const o=this.getters.getEvaluatedCellsInZone(e,t).filter((e=>e.type!==ii.empty));return 0===o.length?"integer":o.every((e=>e.format&&rn(e.format)))?"datetime":o.every((e=>e.type===ii.boolean))?"boolean":o.some((e=>e.type===ii.text))?"char":"integer"}assertCellIsValidField(e,t,o){if(o.type===ii.error)throw new Ri(Oo("The pivot cannot be created because cell %s contains an error",So(e,t)));if(o.type===ii.empty||""===o.value)throw new Ri(Oo("The pivot cannot be created because cell %s is empty",So(e,t)));if("__count"===o.value)throw new Ri(Oo("The pivot cannot be created because cell %s contains a reserved value",So(e,t)))}extractFieldsFromRange(e){const t={},o=[],s=e.sheetId,i=e.zone.top;for(let r=e.zone.left;r<=e.zone.right;r++){const n=this.getters.getEvaluatedCell({sheetId:s,col:r,row:i});this.assertCellIsValidField(r,i,n);const a=n.value?.toString();if(a){const i=this.getTypeFromZone(s,{top:e.zone.top+1,left:r,bottom:e.zone.bottom,right:r}),n=this.findName(a,t);t[n]={name:n,type:i,string:n,aggregator:"integer"===i?"sum":"count"},o.push(n)}}return{fields:t,fieldKeys:o}}findName(e,t){let o=1;const s=e;for(;e in t;)e=`${s}${++o}`;return e}extractDataEntriesFromRange(e){const t=[];for(let o=e.zone.top+1;o<=e.zone.bottom;o++){const s={top:o,bottom:o,left:e.zone.left,right:e.zone.right},i=this.getters.getEvaluatedCellsInZone(e.sheetId,s),r={};for(const e in i){const t=i[e],o=this.fields[this.metaData.fieldKeys[e]];if(!o)throw new Error(`Field ${this.metaData.fieldKeys[e]} does not exist`);""===t.value?r[o.name]={value:null,type:ii.empty,formattedValue:""}:r[o.name]=t}r.__count={value:1,type:ii.number,formattedValue:"1"},t.push(r)}const o=this.definition.columns.concat(this.definition.rows).filter((e=>"datetime"===e.type));if(o.length){const e=this.getters.getLocale();for(const s of t)for(const t of o){const o=eF(t,s[t.fieldName]?.value||null,this.getters.getLocale()),i=Tl(t.granularity),{format:r,value:n}=i.toValueAndFormat(o,e);s[t.nameWithGranularity]={value:o,type:s[t.fieldName]?.type||ii.empty,format:s[t.fieldName]?.format,formattedValue:Xr(n,{locale:e,format:r})}}}return t}},definition:WO,externalData:!1,onIterationEndEvaluation:e=>e.markAsDirtyForEvaluation(),dateGranularities:[...iF],datetimeGranularities:[...iF,"hour_number","minute_number","second_number"],isMeasureCandidate:e=>!["datetime","boolean"].includes(e.type),isGroupable:()=>!0});class rF extends Tc{pivotId;mutators=["reset","deferUpdates","applyUpdate","discardPendingUpdate","update"];updatesAreDeferred;draft=null;notification=this.get($b);alreadyNotified=!1;constructor(e,t){super(e),this.pivotId=t,this.updatesAreDeferred=this.getters.getPivotCoreDefinition(this.pivotId).deferUpdates??!1}handle(e){if("UPDATE_PIVOT"===e.type)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(){const e=sF.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(){const e=[{name:"__count",string:Oo("Count"),type:"integer",aggregator:"sum"}],t=this.fields;for(const o in t){const s=t[o];s&&(sF.get(this.pivot.type).isMeasureCandidate(s)&&e.push(s))}return e.sort(((e,t)=>e.string.localeCompare(t.string)))}get unusedGroupableFields(){const e=[],t=this.fields;for(const o in t){const s=t[o];s&&(sF.get(this.pivot.type).isGroupable(s)&&e.push(s))}const{columns:o,rows:s,measures:i}=this.definition,r=i.concat(s).concat(o).map((e=>e.fieldName)),n=this.unusedGranularities;return e.filter((e=>jl(e)?!r.includes(e.name)||n[e.name].size>0:!r.includes(e.name))).sort(((e,t)=>e.string.localeCompare(t.string)))}get datetimeGranularities(){return sF.get(this.pivot.type).datetimeGranularities}get dateGranularities(){return sF.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){!1===e&&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.isDynamicPivotInViewport()&&this.isStaticPivotInViewport())){const e=`=PIVOT(${this.getters.getPivotFormulaId(this.pivotId)})`;this.alreadyNotified=!0,this.notification.notifyUser({type:"info",text:Oo("Pivot updates only work with dynamic pivot tables. Use %s or re-insert the static pivot from the Data menu.",e),sticky:!1})}}discardPendingUpdate(){this.draft=null}update(e){const t=this.getters.getPivotCoreDefinition(this.pivotId),o={...t,...this.draft,...e},s={...o,columns:o.columns.map((e=>({fieldName:e.fieldName,order:e.order,granularity:e.granularity}))),rows:o.rows.map((e=>({fieldName:e.fieldName,order:e.order,granularity:e.granularity}))),measures:o.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(o)?o.sortedColumn:void 0};if(!this.draft&&mt(t,s))return;const i=this.addDefaultDateTimeGranularity(this.fields,s);this.draft=i,this.updatesAreDeferred||this.applyUpdate()}isDynamicPivotInViewport(){const e=this.getters.getActiveSheetId();for(const t of this.getters.getSheetViewVisibleCols())for(const o of this.getters.getSheetViewVisibleRows()){if(this.getters.isSpillPivotFormula({sheetId:e,col:t,row:o}))return!0}return!1}isStaticPivotInViewport(){for(const e of this.getters.getVisibleCellPositions()){const t=this.getters.getCell(e);if(t?.isFormula){const e=gS(t.compiledFormula.tokens);if(e&&"PIVOT"!==e.functionName)return!0}}return!1}addDefaultDateTimeGranularity(e,t){const{columns:o,rows:s}=t,i=Be(o),r=Be(s),n=this.getUnusedGranularities(e,t);for(const t of i.concat(r)){const o=e[t.fieldName]?.type;if(("date"===o||"datetime"===o)&&!t.granularity){const e=n[t.fieldName]?.values().next().value||"year";n[t.fieldName]?.delete(e),t.granularity=e}}return{...t,columns:i,rows:r}}getUnusedGranularities(e,t){const{columns:o,rows:s}=t,i=o.concat(s).filter((t=>{const o=e[t.fieldName]?.type;return"date"===o||"datetime"===o})),r={};for(const t of i)r[t.fieldName]=new Set("date"===e[t.fieldName]?.type?this.dateGranularities:this.datetimeGranularities);for(const e of i)r[e.fieldName].delete(e.granularity);return r}shouldKeepSortedColumn(e){const{sortedColumn:t}=e;if(!t)return!0;const o=this.getters.getPivotCoreDefinition(this.pivotId);return e.measures.find((e=>e.id===t.measure))&&mt(o.columns,e.columns)}}class nF extends t.Component{static template="o-spreadsheet-PivotSpreadsheetSidePanel";static props={pivotId:String,onCloseSidePanel:Function};static components={PivotLayoutConfigurator:UO,Section:V_,SelectionInput:$_,Checkbox:OI,PivotDeferUpdate:OO,PivotTitleSection:BO};store;state;pivotSidePanelRef=t.useRef("pivotSidePanel");setup(){this.store=yc(rF,this.props.pivotId),this.state=t.useState({range:void 0,rangeHasChanged:!1})}get shouldDisplayInvalidRangeError(){return(!this.store.isDirty||!this.state.rangeHasChanged)&&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){const e=this.env.model.getters.getRangeFromSheetXC(this.env.model.getters.getActiveSheetId(),this.state.range);if(e.invalidSheetName||e.invalidXc)return;const t={sheetId:e.sheetId,zone:e.zone};this.store.update({dataSet:t}),this.store.applyUpdate()}}flipAxis(){const{rows:e,columns:t}=this.definition;this.onDimensionsUpdated({rows:t,columns:e})}onDimensionsUpdated(e){this.store.update(e)}}const aF=new r;aF.add("SPREADSHEET",{editor:nF});class lF extends t.Component{static template="o-spreadsheet-PivotSidePanel";static props={pivotId:String,onCloseSidePanel:Function};static components={PivotLayoutConfigurator:UO,Section:V_};setup(){QD(this)}get sidePanelEditor(){const e=this.env.model.getters.getPivotCoreDefinition(this.props.pivotId);if(!e)throw new Error("pivotId does not correspond to a pivot.");return aF.get(e.type).editor}get highlights(){return N_(this.env.model.getters,this.props.pivotId)}}py`
|
|
1292
1292
|
.o-checkbox-selection {
|
|
1293
1293
|
max-height: 300px;
|
|
1294
1294
|
}
|
|
@@ -1954,7 +1954,7 @@
|
|
|
1954
1954
|
}
|
|
1955
1955
|
}
|
|
1956
1956
|
}
|
|
1957
|
-
`;class SN extends t.Component{static template="o-spreadsheet-BottomBar";static props={onClick:Function};static components={Menu:sR,Ripple:pN,BottomBarSheet:mN,BottomBarStatistic:bN};bottomBarRef=t.useRef("bottomBar");sheetListRef=t.useRef("sheetList");dragAndDrop=qD();targetScroll=void 0;state=t.useState({isSheetListScrollableLeft:!1,isSheetListScrollableRight:!1});menuMaxHeight=250;menuState=t.useState({isOpen:!1,menuId:void 0,position:null,menuItems:[]});sheetList=this.getVisibleSheets();setup(){t.onWillUpdateProps((()=>{this.updateScrollState();const e=this.getVisibleSheets();mt(this.sheetList,e)||this.dragAndDrop.cancel(),this.sheetList=e}))}clickAddSheet(e){const t=this.env.model.getters.getActiveSheetId(),o=this.env.model.getters.getSheetIds().findIndex((e=>e===t))+1,s=this.env.model.uuidGenerator.uuidv4(),i=this.env.model.getters.getNextSheetName(Oo("Sheet"));this.env.model.dispatch("CREATE_SHEET",{sheetId:s,position:o,name:i}),this.env.model.dispatch("ACTIVATE_SHEET",{sheetIdFrom:t,sheetIdTo:s})}getVisibleSheets(){return this.env.model.getters.getVisibleSheetIds().map((e=>{const t=this.env.model.getters.getSheet(e);return{id:t.id,name:t.name}}))}clickListSheets(e){const t=new mI,o=this.env.model.getters.getActiveSheetId();let s=0;for(const e of this.env.model.getters.getSheetIds()){const i=this.env.model.getters.getSheet(e);t.add(e,{name:i.name,sequence:s,isReadonlyAllowed:!0,textColor:i.isVisible?void 0:"#808080",execute:t=>{this.env.model.getters.isSheetVisible(e)||this.env.model.dispatch("SHOW_SHEET",{sheetId:e}),t.model.dispatch("ACTIVATE_SHEET",{sheetIdFrom:o,sheetIdTo:e})},isEnabled:e=>!e.model.getters.isReadonly()||i.isVisible,icon:i.color?"o-spreadsheet-Icon.SMALL_DOT_RIGHT_ALIGN":void 0,iconColor:i.color}),s++}const i=e.currentTarget,{left:r}=i.getBoundingClientRect(),n=this.bottomBarRef.el.getBoundingClientRect().top;this.openContextMenu(r,n,"listSheets",t)}openContextMenu(e,t,o,s){this.menuState.isOpen=!0,this.menuState.menuId=o,this.menuState.menuItems=s.getMenuItems(),this.menuState.position={x:e,y:t}}onSheetContextMenu(e,t,o){const s=o.currentTarget,{top:i,left:r}=s.getBoundingClientRect();o.closedMenuId!==e?this.openContextMenu(r,i,e,t):this.closeMenu()}closeMenu(){this.menuState.isOpen=!1,this.menuState.menuId=void 0,this.menuState.menuItems=[],this.menuState.position=null}closeContextMenuWithId(e){this.menuState.menuId===e&&this.closeMenu()}onWheel(e){this.targetScroll=void 0;e.currentTarget.scrollLeft+=.5*e.deltaY}onScroll(){this.updateScrollState(),this.targetScroll===this.sheetListCurrentScroll&&(this.targetScroll=void 0)}onArrowLeft(e){if(!this.state.isSheetListScrollableLeft)return;this.targetScroll||(this.targetScroll=this.sheetListCurrentScroll);const t=this.targetScroll-this.sheetListWidth;this.scrollSheetListTo(Math.max(0,t))}onArrowRight(e){if(!this.state.isSheetListScrollableRight)return;this.targetScroll||(this.targetScroll=this.sheetListCurrentScroll);const t=this.targetScroll+this.sheetListWidth;this.scrollSheetListTo(Math.min(this.sheetListMaxScroll,t))}updateScrollState(){this.state.isSheetListScrollableLeft=this.sheetListCurrentScroll>0,this.state.isSheetListScrollableRight=this.sheetListCurrentScroll<this.sheetListMaxScroll}scrollSheetListTo(e){this.sheetListRef.el&&(this.targetScroll=e,this.sheetListRef.el.scrollTo({top:0,left:e,behavior:"smooth"}))}onSheetMouseDown(e,t){if(0!==t.button||this.env.model.getters.isReadonly())return;this.closeMenu();const o=this.getVisibleSheets(),s=this.getSheetItemRects(),i=o.map(((e,t)=>({id:e.id,size:s[t].width,position:s[t].x})));this.dragAndDrop.start("horizontal",{draggedItemId:e,initialMousePosition:t.clientX,items:i,
|
|
1957
|
+
`;class SN extends t.Component{static template="o-spreadsheet-BottomBar";static props={onClick:Function};static components={Menu:sR,Ripple:pN,BottomBarSheet:mN,BottomBarStatistic:bN};bottomBarRef=t.useRef("bottomBar");sheetListRef=t.useRef("sheetList");dragAndDrop=qD();targetScroll=void 0;state=t.useState({isSheetListScrollableLeft:!1,isSheetListScrollableRight:!1});menuMaxHeight=250;menuState=t.useState({isOpen:!1,menuId:void 0,position:null,menuItems:[]});sheetList=this.getVisibleSheets();setup(){t.onWillUpdateProps((()=>{this.updateScrollState();const e=this.getVisibleSheets();mt(this.sheetList,e)||this.dragAndDrop.cancel(),this.sheetList=e}))}clickAddSheet(e){const t=this.env.model.getters.getActiveSheetId(),o=this.env.model.getters.getSheetIds().findIndex((e=>e===t))+1,s=this.env.model.uuidGenerator.uuidv4(),i=this.env.model.getters.getNextSheetName(Oo("Sheet"));this.env.model.dispatch("CREATE_SHEET",{sheetId:s,position:o,name:i}),this.env.model.dispatch("ACTIVATE_SHEET",{sheetIdFrom:t,sheetIdTo:s})}getVisibleSheets(){return this.env.model.getters.getVisibleSheetIds().map((e=>{const t=this.env.model.getters.getSheet(e);return{id:t.id,name:t.name}}))}clickListSheets(e){const t=new mI,o=this.env.model.getters.getActiveSheetId();let s=0;for(const e of this.env.model.getters.getSheetIds()){const i=this.env.model.getters.getSheet(e);t.add(e,{name:i.name,sequence:s,isReadonlyAllowed:!0,textColor:i.isVisible?void 0:"#808080",execute:t=>{this.env.model.getters.isSheetVisible(e)||this.env.model.dispatch("SHOW_SHEET",{sheetId:e}),t.model.dispatch("ACTIVATE_SHEET",{sheetIdFrom:o,sheetIdTo:e})},isEnabled:e=>!e.model.getters.isReadonly()||i.isVisible,icon:i.color?"o-spreadsheet-Icon.SMALL_DOT_RIGHT_ALIGN":void 0,iconColor:i.color}),s++}const i=e.currentTarget,{left:r}=i.getBoundingClientRect(),n=this.bottomBarRef.el.getBoundingClientRect().top;this.openContextMenu(r,n,"listSheets",t)}openContextMenu(e,t,o,s){this.menuState.isOpen=!0,this.menuState.menuId=o,this.menuState.menuItems=s.getMenuItems(),this.menuState.position={x:e,y:t}}onSheetContextMenu(e,t,o){const s=o.currentTarget,{top:i,left:r}=s.getBoundingClientRect();o.closedMenuId!==e?this.openContextMenu(r,i,e,t):this.closeMenu()}closeMenu(){this.menuState.isOpen=!1,this.menuState.menuId=void 0,this.menuState.menuItems=[],this.menuState.position=null}closeContextMenuWithId(e){this.menuState.menuId===e&&this.closeMenu()}onWheel(e){this.targetScroll=void 0;e.currentTarget.scrollLeft+=.5*e.deltaY}onScroll(){this.updateScrollState(),this.targetScroll===this.sheetListCurrentScroll&&(this.targetScroll=void 0)}onArrowLeft(e){if(!this.state.isSheetListScrollableLeft)return;this.targetScroll||(this.targetScroll=this.sheetListCurrentScroll);const t=this.targetScroll-this.sheetListWidth;this.scrollSheetListTo(Math.max(0,t))}onArrowRight(e){if(!this.state.isSheetListScrollableRight)return;this.targetScroll||(this.targetScroll=this.sheetListCurrentScroll);const t=this.targetScroll+this.sheetListWidth;this.scrollSheetListTo(Math.min(this.sheetListMaxScroll,t))}updateScrollState(){this.state.isSheetListScrollableLeft=this.sheetListCurrentScroll>0,this.state.isSheetListScrollableRight=this.sheetListCurrentScroll<this.sheetListMaxScroll}scrollSheetListTo(e){this.sheetListRef.el&&(this.targetScroll=e,this.sheetListRef.el.scrollTo({top:0,left:e,behavior:"smooth"}))}onSheetMouseDown(e,t){if(0!==t.button||this.env.model.getters.isReadonly())return;this.closeMenu();const o=this.getVisibleSheets(),s=this.getSheetItemRects(),i=o.map(((e,t)=>({id:e.id,size:s[t].width,position:s[t].x})));this.dragAndDrop.start("horizontal",{draggedItemId:e,initialMousePosition:t.clientX,items:i,scrollableContainerEl:this.sheetListRef.el,onDragEnd:(e,t)=>this.onDragEnd(e,t)})}onDragEnd(e,t){const o=t-this.getVisibleSheets().findIndex((t=>t.id===e));e&&0!==o&&this.env.model.dispatch("MOVE_SHEET",{sheetId:e,delta:o})}getSheetStyle(e){return this.dragAndDrop.itemsStyle[e]||""}getSheetItemRects(){return Array.from(this.bottomBarRef.el.querySelectorAll(".o-sheet")).map((e=>e.getBoundingClientRect())).map((e=>({x:e.x,width:e.width-1,y:e.y,height:e.height})))}get sheetListCurrentScroll(){return this.sheetListRef.el?this.sheetListRef.el.scrollLeft:0}get sheetListWidth(){return this.sheetListRef.el?this.sheetListRef.el.clientWidth:0}get sheetListMaxScroll(){return this.sheetListRef.el?this.sheetListRef.el.scrollWidth-this.sheetListRef.el.clientWidth:0}}class yN extends Tc{_clickableCells=t.markRaw({});_registryItems=t.markRaw(hN.getAll().sort(((e,t)=>e.sequence-t.sequence)));handle(e){(ni.has(e.type)||"EVALUATE_CELLS"===e.type||"UPDATE_CELL"===e.type&&("content"in e||"format"in e))&&(this._clickableCells=t.markRaw({}),this._registryItems=t.markRaw(hN.getAll().sort(((e,t)=>e.sequence-t.sequence))))}getClickableAction(e){const{sheetId:t,col:o,row:s}=e,i=this._clickableCells,r=So(o,s);return i[t]||(i[t]={}),r in i[t]||(i[t][r]=this.findClickableAction(e)),i[t][r]}findClickableAction(e){const t=this.getters;for(const o of this._registryItems)if(o.condition(e,t))return o.execute;return!1}get clickableCells(){const e=[],t=this.getters,o=t.getActiveSheetId();for(const s of t.getSheetViewVisibleCols())for(const i of t.getSheetViewVisibleRows()){const r={sheetId:o,col:s,row:i};if(!t.isMainCellPosition(r))continue;const n=this.getClickableAction(r);if(!n)continue;const a=t.expandZone(o,ms(r));e.push({coordinates:t.getVisibleRect(a),position:r,action:n})}return e}}py`
|
|
1958
1958
|
.o-dashboard-clickable-cell {
|
|
1959
1959
|
position: absolute;
|
|
1960
1960
|
cursor: pointer;
|
|
@@ -3259,4 +3259,4 @@
|
|
|
3259
3259
|
<tableParts count="${e.tables.length}">
|
|
3260
3260
|
${Tw(a)}
|
|
3261
3261
|
</tableParts>
|
|
3262
|
-
`}var Yk;!function(e){e[e.Ready=0]="Ready",e[e.Running=1]="Running",e[e.RunningCore=2]="RunningCore",e[e.Finalizing=3]="Finalizing"}(Yk||(Yk={}));function Xk(e,t={}){const o=Be(t);return o.type=e,o}const Kk={},Jk={MIN_ROW_HEIGHT:10,MIN_COL_WIDTH:5,HEADER_HEIGHT:ee,HEADER_WIDTH:te,BOTTOMBAR_HEIGHT:36,DEFAULT_CELL_WIDTH:oe,DEFAULT_CELL_HEIGHT:se,SCROLLBAR_WIDTH:ie},Qk={autoCompleteProviders:bh,autofillModifiersRegistry:fS,autofillRulesRegistry:vS,cellMenuRegistry:UT,colMenuRegistry:D_,errorTypes:Ii,linkMenuRegistry:qI,functionRegistry:Nb,featurePluginRegistry:aN,iconsOnCellRegistry:dy,statefulUIPluginRegistry:lN,coreViewsPluginRegistry:cN,corePluginRegistry:nN,rowMenuRegistry:P_,sidePanelRegistry:OF,figureRegistry:cI,chartSidePanelComponentRegistry:AD,chartComponentRegistry:oI,chartRegistry:tI,chartSubtypeRegistry:iI,topbarMenuRegistry:k_,topbarComponentRegistry:FF,clickableCellRegistry:hN,otRegistry:L_,inverseCommandRegistry:gI,urlRegistry:yr,cellPopoverRegistry:xS,numberFormatMenuRegistry:O_,repeatLocalCommandTransformRegistry:oN,repeatCommandTransformRegistry:tN,clipboardHandlersRegistries:dc,pivotRegistry:sF,pivotTimeAdapterRegistry:Rl,pivotSidePanelRegistry:aF,pivotNormalizationValueRegistry:oc,supportedPivotPositionalFormulaRegistry:mS,pivotToFunctionValueRegistry:sc,migrationStepRegistry:Xw},eL={arg:wh,isEvaluationError:Ni,toBoolean:ji,toJsDate:Yi,toNumber:Li,toString:Gi,toNormalizedPivotValue:Jl,toXC:So,toZone:jo,toUnboundedZone:Zo,toCartesian:bo,numberToLetters:mo,lettersToNumber:fo,UuidGenerator:na,formatValue:Xr,createCurrencyFormat:dn,ColorGenerator:co,computeTextWidth:Zn,createEmptyWorkbookData:iE,createEmptySheet:sE,createEmptyExcelSheet:rE,rgbaToHex:Gt,colorToRGBA:qt,positionToZone:ms,isDefined:at,isMatrix:yi,lazy:ut,genericRepeat:sN,createAction:i,createActions:o,transformRangeData:gc,deepEquals:mt,overlap:rs,union:os,isInside:ns,deepCopy:Be,expandZoneOnInsertion:Jo,reduceZoneOnDeletion:ts,unquote:$e,getMaxObjectId:Wl,getFunctionsFromTokens:aS,getFirstPivotFunction:gS,getNumberOfPivotFunctions:pS,parseDimension:Zl,isDateOrDatetimeField:jl,makeFieldProposal:cS,insertTokenAfterArgSeparator:hS,insertTokenAfterLeftParenthesis:dS,mergeContiguousZones:ys,getPivotHighlights:N_,pivotTimeAdapter:Tl,UNDO_REDO_PIVOT_COMMANDS:_P,createPivotFormula:Kl,areDomainArgsFieldsValid:Xl,splitReference:Go,sanitizeSheetName:Ge,isNumber:ei,isDateTime:Ls},tL={isMarkdownLink:Qe,parseMarkdownLink:ot,markdownLink:tt,openLink:Ir,urlRepresentation:xr},oL={Checkbox:OI,Section:V_,RoundColorPicker:lD,ChartDataSeries:W_,ChartErrorSection:q_,ChartLabelRange:Z_,ChartTitle:nD,ChartPanel:OD,ChartFigure:nI,ChartJsComponent:oh,Grid:FM,GridOverlay:dM,ScorecardChart:vh,LineConfigPanel:wD,BarConfigPanel:Y_,PieChartDesignPanel:ED,GenericChartConfigPanel:j_,ChartWithAxisDesignPanel:pD,GaugeChartConfigPanel:fD,GaugeChartDesignPanel:vD,ScorecardChartConfigPanel:ID,ScorecardChartDesignPanel:RD,RadarChartDesignPanel:xD,WaterfallChartDesignPanel:TD,ComboChartDesignPanel:mD,ChartTypePicker:_D,FigureComponent:MF,Menu:sR,Popover:II,SelectionInput:$_,ValidationMessages:G_,AddDimensionButton:FO,PivotDimensionGranularity:kO,PivotDimensionOrder:LO,PivotDimension:NO,PivotLayoutConfigurator:UO,PivotDeferUpdate:OO,PivotTitleSection:BO,CogWheelMenu:PO,TextInput:MO,SidePanelCollapsible:K_,RadioSelection:dD},sL={useDragAndDropListItems:qD,useHighlights:QD,useHighlightsOnHover:JD},iL={useStoreProvider:bc,DependencyContainer:mc,CellPopoverStore:SI,ComposerFocusStore:_c,CellComposerStore:WF,FindAndReplaceStore:IO,HighlightStore:zb,HoveredCellStore:bI,ModelStore:xc,NotificationStore:$b,RendererStore:Rc,SelectionInputStore:z_,SpreadsheetStore:Tc,useStore:Sc,useLocalStore:yc,SidePanelStore:AM,PivotSidePanelStore:rF,PivotMeasureDisplayPanelStore:_O};const rL={DEFAULT_LOCALE:bi,HIGHLIGHT_COLOR:a,PIVOT_TABLE_CONFIG:ke,ChartTerms:uE},nL={...dR,...Mx};e.AbstractCellClipboardHandler=da,e.AbstractChart=sh,e.AbstractFigureClipboardHandler=lc,e.CellErrorType=xi,e.CorePlugin=PM,e.DispatchResult=pi,e.EvaluationError=Ri,e.Model=class extends pc{corePlugins=[];statefulUIPlugins=[];range;session;isReplayingCommand=!1;renderers={};status=0;config;corePluginConfig;uiPluginConfig;state;selection;getters;coreGetters;uuidGenerator;handlers=[];uiHandlers=[];coreHandlers=[];constructor(e={},o={},s=[],i=new na,r=!1){const n=performance.now();console.debug("##### Model creation #####"),super(),Ao===Ro&&_o===To&&(_o=()=>!0),s=tE(e,s);const a=eE(e,r);this.state=new XN,this.uuidGenerator=i,this.config=this.setupConfig(o),this.session=this.setupSession(a.revisionId),this.coreGetters={},this.range=new UM(this.coreGetters),this.coreGetters.getRangeString=this.range.getRangeString.bind(this.range),this.coreGetters.getRangeFromSheetXC=this.range.getRangeFromSheetXC.bind(this.range),this.coreGetters.createAdaptedRanges=this.range.createAdaptedRanges.bind(this.range),this.coreGetters.getRangeDataFromXc=this.range.getRangeDataFromXc.bind(this.range),this.coreGetters.getRangeDataFromZone=this.range.getRangeDataFromZone.bind(this.range),this.coreGetters.getRangeFromRangeData=this.range.getRangeFromRangeData.bind(this.range),this.coreGetters.getRangeFromZone=this.range.getRangeFromZone.bind(this.range),this.coreGetters.recomputeRanges=this.range.recomputeRanges.bind(this.range),this.coreGetters.isRangeValid=this.range.isRangeValid.bind(this.range),this.coreGetters.extendRange=this.range.extendRange.bind(this.range),this.coreGetters.getRangesUnion=this.range.getRangesUnion.bind(this.range),this.coreGetters.removeRangesSheetPrefix=this.range.removeRangesSheetPrefix.bind(this.range),this.getters={isReadonly:()=>"readonly"===this.config.mode||"dashboard"===this.config.mode,isDashboard:()=>"dashboard"===this.config.mode},this.selection=new jN(this.getters),this.coreHandlers.push(this.range),this.handlers.push(this.range),this.corePluginConfig=this.setupCorePluginConfig(),this.uiPluginConfig=this.setupUiPluginConfig();for(let e of nN.getAll())this.setupCorePlugin(e,a);Object.assign(this.getters,this.coreGetters),this.session.loadInitialMessages(s);for(let e of cN.getAll()){const t=this.setupUiPlugin(e);this.handlers.push(t),this.uiHandlers.push(t),this.coreHandlers.push(t)}for(let e of lN.getAll()){const t=this.setupUiPlugin(e);this.statefulUIPlugins.push(t),this.handlers.push(t),this.uiHandlers.push(t)}for(let e of aN.getAll()){const t=this.setupUiPlugin(e);this.handlers.push(t),this.uiHandlers.push(t)}if(this.dispatch("START"),this.selection.observe(this,{handleEvent:()=>this.trigger("update")}),this.setupSessionEvents(),this.joinSession(),o.snapshotRequested||e["[Content_Types].xml"]&&!this.getters.isReadonly()){const e=performance.now();console.debug("Snapshot requested"),this.session.snapshot(this.exportData()),this.garbageCollectExternalResources(),console.debug("Snapshot taken in",performance.now()-e,"ms")}t.markRaw(this),console.debug("Model created in",performance.now()-n,"ms"),console.debug("######")}joinSession(){this.session.join(this.config.client)}async leaveSession(){const e=this.getters.isReadonly()?void 0:ut((()=>this.exportData()));await this.session.leave(e)}setupUiPlugin(e){const t=new e(this.uiPluginConfig);for(let o of e.getters){if(!(o in t))throw new Error(`Invalid getter name: ${o} for plugin ${t.constructor}`);if(o in this.getters)throw new Error(`Getter "${o}" is already defined.`);this.getters[o]=t[o].bind(t)}for(const o of e.layers)this.renderers[o]||(this.renderers[o]=[]),this.renderers[o].push(t);return t}setupCorePlugin(e,t){const o=new e(this.corePluginConfig);for(let t of e.getters){if(!(t in o))throw new Error(`Invalid getter name: ${t} for plugin ${o.constructor}`);if(t in this.coreGetters)throw new Error(`Getter "${t}" is already defined.`);this.coreGetters[t]=o[t].bind(o)}o.import(t),this.corePlugins.push(o),this.coreHandlers.push(o),this.handlers.push(o)}onRemoteRevisionReceived({commands:e}){for(let t of e){const e=this.status;this.status=2,this.dispatchToHandlers(this.statefulUIPlugins,t),this.status=e}this.finalize()}setupSession(e){return new WP(GN({initialRevisionId:e,recordChanges:this.state.recordChanges.bind(this.state),dispatch:e=>{this.checkDispatchAllowed(e).isSuccessful&&(this.isReplayingCommand=!0,this.dispatchToHandlers(this.coreHandlers,e),this.isReplayingCommand=!1)}}),this.config.transportService,e)}setupSessionEvents(){this.session.on("remote-revision-received",this,this.onRemoteRevisionReceived),this.session.on("revision-undone",this,(({commands:e})=>{this.dispatchFromCorePlugin("UNDO",{commands:e}),this.finalize()})),this.session.on("revision-redone",this,(({commands:e})=>{this.dispatchFromCorePlugin("REDO",{commands:e}),this.finalize()})),this.session.on("unexpected-revision-id",this,(()=>this.trigger("unexpected-revision-id"))),this.session.on("collaborative-event-received",this,(()=>{this.trigger("update")}))}setupConfig(e){const t=e.client||{id:this.uuidGenerator.uuidv4(),name:Oo("Anonymous").toString()},o=e.transportService||new LN;return{...e,mode:e.mode||"normal",custom:e.custom||{},external:this.setupExternalConfig(e.external||{}),transportService:o,client:t,moveClient:()=>{},snapshotRequested:!1,notifyUI:e=>this.trigger("notify-ui",e),raiseBlockingErrorUI:e=>this.trigger("raise-error-ui",{text:e}),customColors:e.customColors||[]}}setupExternalConfig(e){const t=e.loadLocales||(()=>Promise.resolve(vi));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}}setupUiPluginConfig(){return{getters:this.getters,stateObserver:this.state,dispatch:this.dispatch,canDispatch:this.canDispatch,selection:this.selection,moveClient:this.session.move.bind(this.session),custom:this.config.custom,uiActions:this.config,session:this.session,defaultCurrency:this.config.defaultCurrency,customColors:this.config.customColors||[],external:this.config.external}}checkDispatchAllowed(e){const t=gi(e)?this.checkDispatchAllowedCoreCommand(e):this.checkDispatchAllowedLocalCommand(e);return t.some((e=>"Success"!==e))?new pi(t.flat()):pi.Success}checkDispatchAllowedCoreCommand(e){const t=this.corePlugins.map((t=>t.allowDispatch(e)));return t.push(this.range.allowDispatch(e)),t}checkDispatchAllowedLocalCommand(e){return this.uiHandlers.map((t=>t.allowDispatch(e)))}finalize(){this.status=3;for(const e of this.handlers)e.finalize();this.status=0,this.trigger("command-finalized")}canDispatch=(e,t)=>this.checkDispatchAllowed(Xk(e,t));dispatch=(e,t)=>{const o=Xk(e,t);let s=this.status;if(this.getters.isReadonly()&&(i=o,!di.has(i.type)))return new pi("Readonly");var i;if(!this.session.canApplyOptimisticUpdate())return new pi("WaitingSessionConfirmation");switch(s){case 0:const t=this.checkDispatchAllowed(o);if(!t.isSuccessful)return this.trigger("update"),t;this.status=1;const{changes:s,commands:i}=this.state.recordChanges((()=>{const t=performance.now();gi(o)&&this.state.addCommand(o),this.dispatchToHandlers(this.handlers,o),this.finalize();const s=performance.now()-t;s>5&&console.debug(e,s,"ms")}));this.session.save(o,i,s),this.status=0,this.trigger("update");break;case 1:if(gi(o)){const e=this.checkDispatchAllowed(o);if(!e.isSuccessful)return e;this.state.addCommand(o)}this.dispatchToHandlers(this.handlers,o);break;case 3:throw new Error("Cannot dispatch commands in the finalize state");case 2:if(gi(o))throw new Error(`A UI plugin cannot dispatch ${e} while handling a core command`);this.dispatchToHandlers(this.handlers,o)}return pi.Success};dispatchFromCorePlugin=(e,t)=>{const o=Xk(e,t),s=this.status;this.status=2;const i=this.isReplayingCommand?this.coreHandlers:this.handlers;return this.dispatchToHandlers(i,o),this.status=s,pi.Success};dispatchToHandlers(e,t){const o=gi(t);for(const s of e)!o&&s instanceof PM||s.beforeHandle(t);for(const s of e)!o&&s instanceof PM||s.handle(t);this.trigger("command-dispatched",t)}drawLayer(e,t){const o=this.renderers[t];if(o)for(const s of o)e.ctx.save(),s.drawLayer(e,t),e.ctx.restore()}exportData(){let e=iE();for(let t of this.handlers)t instanceof PM&&t.export(e);return e.revisionId=this.session.getRevisionId()||Se,e=Be(e),e}updateMode(e){this.config.mode=e,this.trigger("update")}exportXLSX(){this.dispatch("EVALUATE_CELLS");let e={...iE(),sheets:[rE(Qw,"Sheet1")]};for(let t of this.handlers)t instanceof MM&&t.exportForExcel(e);return e=Be(e),Zk(e)}garbageCollectExternalResources(){for(const e of this.corePlugins)e.garbageCollectExternalResources()}},e.PivotRuntimeDefinition=zO,e.Registry=r,e.Revision=zP,e.SPREADSHEET_DIMENSIONS=Jk,e.Spreadsheet=kN,e.SpreadsheetPivotTable=GO,e.UIPlugin=$M,e.__info__=Kk,e.addFunction=function e(t,o){return Nb.add(t,o),{addFunction:(t,o)=>e(t,o)}},e.addRenderingLayer=function(e,t){if(wi[e])throw new Error(`Layer ${e} already exists`);wi[e]=t},e.astToFormula=If,e.chartHelpers=nL,e.compile=oS,e.compileTokens=sS,e.components=oL,e.constants=rL,e.convertAstNodes=Cf,e.coreTypes=ui,e.findCellInNewZone=ps,e.functionCache=tS,e.helpers=eL,e.hooks=sL,e.invalidateCFEvaluationCommands=ci,e.invalidateDependenciesCommands=li,e.invalidateEvaluationCommands=ni,e.iterateAstNodes=wf,e.links=tL,e.load=eE,e.parse=Sf,e.parseTokens=yf,e.readonlyAllowedCommands=di,e.registries=Qk,e.setDefaultSheetViewSize=function(e){Fe=e},e.setTranslationMethod=function(e,t=(()=>!0)){Ao=e,_o=t},e.stores=iL,e.tokenColors=qb,e.tokenize=ma,Kk.version="18.1.6",Kk.date="2025-02-05T07:18:57.089Z",Kk.hash="f5b97e0"}(this.o_spreadsheet=this.o_spreadsheet||{},owl);
|
|
3262
|
+
`}var Yk;!function(e){e[e.Ready=0]="Ready",e[e.Running=1]="Running",e[e.RunningCore=2]="RunningCore",e[e.Finalizing=3]="Finalizing"}(Yk||(Yk={}));function Xk(e,t={}){const o=Be(t);return o.type=e,o}const Kk={},Jk={MIN_ROW_HEIGHT:10,MIN_COL_WIDTH:5,HEADER_HEIGHT:ee,HEADER_WIDTH:te,BOTTOMBAR_HEIGHT:36,DEFAULT_CELL_WIDTH:oe,DEFAULT_CELL_HEIGHT:se,SCROLLBAR_WIDTH:ie},Qk={autoCompleteProviders:bh,autofillModifiersRegistry:fS,autofillRulesRegistry:vS,cellMenuRegistry:UT,colMenuRegistry:D_,errorTypes:Ii,linkMenuRegistry:qI,functionRegistry:Nb,featurePluginRegistry:aN,iconsOnCellRegistry:dy,statefulUIPluginRegistry:lN,coreViewsPluginRegistry:cN,corePluginRegistry:nN,rowMenuRegistry:P_,sidePanelRegistry:OF,figureRegistry:cI,chartSidePanelComponentRegistry:AD,chartComponentRegistry:oI,chartRegistry:tI,chartSubtypeRegistry:iI,topbarMenuRegistry:k_,topbarComponentRegistry:FF,clickableCellRegistry:hN,otRegistry:L_,inverseCommandRegistry:gI,urlRegistry:yr,cellPopoverRegistry:xS,numberFormatMenuRegistry:O_,repeatLocalCommandTransformRegistry:oN,repeatCommandTransformRegistry:tN,clipboardHandlersRegistries:dc,pivotRegistry:sF,pivotTimeAdapterRegistry:Rl,pivotSidePanelRegistry:aF,pivotNormalizationValueRegistry:oc,supportedPivotPositionalFormulaRegistry:mS,pivotToFunctionValueRegistry:sc,migrationStepRegistry:Xw},eL={arg:wh,isEvaluationError:Ni,toBoolean:ji,toJsDate:Yi,toNumber:Li,toString:Gi,toNormalizedPivotValue:Jl,toXC:So,toZone:jo,toUnboundedZone:Zo,toCartesian:bo,numberToLetters:mo,lettersToNumber:fo,UuidGenerator:na,formatValue:Xr,createCurrencyFormat:dn,ColorGenerator:co,computeTextWidth:Zn,createEmptyWorkbookData:iE,createEmptySheet:sE,createEmptyExcelSheet:rE,rgbaToHex:Gt,colorToRGBA:qt,positionToZone:ms,isDefined:at,isMatrix:yi,lazy:ut,genericRepeat:sN,createAction:i,createActions:o,transformRangeData:gc,deepEquals:mt,overlap:rs,union:os,isInside:ns,deepCopy:Be,expandZoneOnInsertion:Jo,reduceZoneOnDeletion:ts,unquote:$e,getMaxObjectId:Wl,getFunctionsFromTokens:aS,getFirstPivotFunction:gS,getNumberOfPivotFunctions:pS,parseDimension:Zl,isDateOrDatetimeField:jl,makeFieldProposal:cS,insertTokenAfterArgSeparator:hS,insertTokenAfterLeftParenthesis:dS,mergeContiguousZones:ys,getPivotHighlights:N_,pivotTimeAdapter:Tl,UNDO_REDO_PIVOT_COMMANDS:_P,createPivotFormula:Kl,areDomainArgsFieldsValid:Xl,splitReference:Go,sanitizeSheetName:Ge,isNumber:ei,isDateTime:Ls},tL={isMarkdownLink:Qe,parseMarkdownLink:ot,markdownLink:tt,openLink:Ir,urlRepresentation:xr},oL={Checkbox:OI,Section:V_,RoundColorPicker:lD,ChartDataSeries:W_,ChartErrorSection:q_,ChartLabelRange:Z_,ChartTitle:nD,ChartPanel:OD,ChartFigure:nI,ChartJsComponent:oh,Grid:FM,GridOverlay:dM,ScorecardChart:vh,LineConfigPanel:wD,BarConfigPanel:Y_,PieChartDesignPanel:ED,GenericChartConfigPanel:j_,ChartWithAxisDesignPanel:pD,GaugeChartConfigPanel:fD,GaugeChartDesignPanel:vD,ScorecardChartConfigPanel:ID,ScorecardChartDesignPanel:RD,RadarChartDesignPanel:xD,WaterfallChartDesignPanel:TD,ComboChartDesignPanel:mD,ChartTypePicker:_D,FigureComponent:MF,Menu:sR,Popover:II,SelectionInput:$_,ValidationMessages:G_,AddDimensionButton:FO,PivotDimensionGranularity:kO,PivotDimensionOrder:LO,PivotDimension:NO,PivotLayoutConfigurator:UO,PivotDeferUpdate:OO,PivotTitleSection:BO,CogWheelMenu:PO,TextInput:MO,SidePanelCollapsible:K_,RadioSelection:dD},sL={useDragAndDropListItems:qD,useHighlights:QD,useHighlightsOnHover:JD},iL={useStoreProvider:bc,DependencyContainer:mc,CellPopoverStore:SI,ComposerFocusStore:_c,CellComposerStore:WF,FindAndReplaceStore:IO,HighlightStore:zb,HoveredCellStore:bI,ModelStore:xc,NotificationStore:$b,RendererStore:Rc,SelectionInputStore:z_,SpreadsheetStore:Tc,useStore:Sc,useLocalStore:yc,SidePanelStore:AM,PivotSidePanelStore:rF,PivotMeasureDisplayPanelStore:_O};const rL={DEFAULT_LOCALE:bi,HIGHLIGHT_COLOR:a,PIVOT_TABLE_CONFIG:ke,ChartTerms:uE},nL={...dR,...Mx};e.AbstractCellClipboardHandler=da,e.AbstractChart=sh,e.AbstractFigureClipboardHandler=lc,e.CellErrorType=xi,e.CorePlugin=PM,e.DispatchResult=pi,e.EvaluationError=Ri,e.Model=class extends pc{corePlugins=[];statefulUIPlugins=[];range;session;isReplayingCommand=!1;renderers={};status=0;config;corePluginConfig;uiPluginConfig;state;selection;getters;coreGetters;uuidGenerator;handlers=[];uiHandlers=[];coreHandlers=[];constructor(e={},o={},s=[],i=new na,r=!1){const n=performance.now();console.debug("##### Model creation #####"),super(),Ao===Ro&&_o===To&&(_o=()=>!0),s=tE(e,s);const a=eE(e,r);this.state=new XN,this.uuidGenerator=i,this.config=this.setupConfig(o),this.session=this.setupSession(a.revisionId),this.coreGetters={},this.range=new UM(this.coreGetters),this.coreGetters.getRangeString=this.range.getRangeString.bind(this.range),this.coreGetters.getRangeFromSheetXC=this.range.getRangeFromSheetXC.bind(this.range),this.coreGetters.createAdaptedRanges=this.range.createAdaptedRanges.bind(this.range),this.coreGetters.getRangeDataFromXc=this.range.getRangeDataFromXc.bind(this.range),this.coreGetters.getRangeDataFromZone=this.range.getRangeDataFromZone.bind(this.range),this.coreGetters.getRangeFromRangeData=this.range.getRangeFromRangeData.bind(this.range),this.coreGetters.getRangeFromZone=this.range.getRangeFromZone.bind(this.range),this.coreGetters.recomputeRanges=this.range.recomputeRanges.bind(this.range),this.coreGetters.isRangeValid=this.range.isRangeValid.bind(this.range),this.coreGetters.extendRange=this.range.extendRange.bind(this.range),this.coreGetters.getRangesUnion=this.range.getRangesUnion.bind(this.range),this.coreGetters.removeRangesSheetPrefix=this.range.removeRangesSheetPrefix.bind(this.range),this.getters={isReadonly:()=>"readonly"===this.config.mode||"dashboard"===this.config.mode,isDashboard:()=>"dashboard"===this.config.mode},this.selection=new jN(this.getters),this.coreHandlers.push(this.range),this.handlers.push(this.range),this.corePluginConfig=this.setupCorePluginConfig(),this.uiPluginConfig=this.setupUiPluginConfig();for(let e of nN.getAll())this.setupCorePlugin(e,a);Object.assign(this.getters,this.coreGetters),this.session.loadInitialMessages(s);for(let e of cN.getAll()){const t=this.setupUiPlugin(e);this.handlers.push(t),this.uiHandlers.push(t),this.coreHandlers.push(t)}for(let e of lN.getAll()){const t=this.setupUiPlugin(e);this.statefulUIPlugins.push(t),this.handlers.push(t),this.uiHandlers.push(t)}for(let e of aN.getAll()){const t=this.setupUiPlugin(e);this.handlers.push(t),this.uiHandlers.push(t)}if(this.dispatch("START"),this.selection.observe(this,{handleEvent:()=>this.trigger("update")}),this.setupSessionEvents(),this.joinSession(),o.snapshotRequested||e["[Content_Types].xml"]&&!this.getters.isReadonly()){const e=performance.now();console.debug("Snapshot requested"),this.session.snapshot(this.exportData()),this.garbageCollectExternalResources(),console.debug("Snapshot taken in",performance.now()-e,"ms")}t.markRaw(this),console.debug("Model created in",performance.now()-n,"ms"),console.debug("######")}joinSession(){this.session.join(this.config.client)}async leaveSession(){const e=this.getters.isReadonly()?void 0:ut((()=>this.exportData()));await this.session.leave(e)}setupUiPlugin(e){const t=new e(this.uiPluginConfig);for(let o of e.getters){if(!(o in t))throw new Error(`Invalid getter name: ${o} for plugin ${t.constructor}`);if(o in this.getters)throw new Error(`Getter "${o}" is already defined.`);this.getters[o]=t[o].bind(t)}for(const o of e.layers)this.renderers[o]||(this.renderers[o]=[]),this.renderers[o].push(t);return t}setupCorePlugin(e,t){const o=new e(this.corePluginConfig);for(let t of e.getters){if(!(t in o))throw new Error(`Invalid getter name: ${t} for plugin ${o.constructor}`);if(t in this.coreGetters)throw new Error(`Getter "${t}" is already defined.`);this.coreGetters[t]=o[t].bind(o)}o.import(t),this.corePlugins.push(o),this.coreHandlers.push(o),this.handlers.push(o)}onRemoteRevisionReceived({commands:e}){for(let t of e){const e=this.status;this.status=2,this.dispatchToHandlers(this.statefulUIPlugins,t),this.status=e}this.finalize()}setupSession(e){return new WP(GN({initialRevisionId:e,recordChanges:this.state.recordChanges.bind(this.state),dispatch:e=>{this.checkDispatchAllowed(e).isSuccessful&&(this.isReplayingCommand=!0,this.dispatchToHandlers(this.coreHandlers,e),this.isReplayingCommand=!1)}}),this.config.transportService,e)}setupSessionEvents(){this.session.on("remote-revision-received",this,this.onRemoteRevisionReceived),this.session.on("revision-undone",this,(({commands:e})=>{this.dispatchFromCorePlugin("UNDO",{commands:e}),this.finalize()})),this.session.on("revision-redone",this,(({commands:e})=>{this.dispatchFromCorePlugin("REDO",{commands:e}),this.finalize()})),this.session.on("unexpected-revision-id",this,(()=>this.trigger("unexpected-revision-id"))),this.session.on("collaborative-event-received",this,(()=>{this.trigger("update")}))}setupConfig(e){const t=e.client||{id:this.uuidGenerator.uuidv4(),name:Oo("Anonymous").toString()},o=e.transportService||new LN;return{...e,mode:e.mode||"normal",custom:e.custom||{},external:this.setupExternalConfig(e.external||{}),transportService:o,client:t,moveClient:()=>{},snapshotRequested:!1,notifyUI:e=>this.trigger("notify-ui",e),raiseBlockingErrorUI:e=>this.trigger("raise-error-ui",{text:e}),customColors:e.customColors||[]}}setupExternalConfig(e){const t=e.loadLocales||(()=>Promise.resolve(vi));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}}setupUiPluginConfig(){return{getters:this.getters,stateObserver:this.state,dispatch:this.dispatch,canDispatch:this.canDispatch,selection:this.selection,moveClient:this.session.move.bind(this.session),custom:this.config.custom,uiActions:this.config,session:this.session,defaultCurrency:this.config.defaultCurrency,customColors:this.config.customColors||[],external:this.config.external}}checkDispatchAllowed(e){const t=gi(e)?this.checkDispatchAllowedCoreCommand(e):this.checkDispatchAllowedLocalCommand(e);return t.some((e=>"Success"!==e))?new pi(t.flat()):pi.Success}checkDispatchAllowedCoreCommand(e){const t=this.corePlugins.map((t=>t.allowDispatch(e)));return t.push(this.range.allowDispatch(e)),t}checkDispatchAllowedLocalCommand(e){return this.uiHandlers.map((t=>t.allowDispatch(e)))}finalize(){this.status=3;for(const e of this.handlers)e.finalize();this.status=0,this.trigger("command-finalized")}canDispatch=(e,t)=>this.checkDispatchAllowed(Xk(e,t));dispatch=(e,t)=>{const o=Xk(e,t);let s=this.status;if(this.getters.isReadonly()&&(i=o,!di.has(i.type)))return new pi("Readonly");var i;if(!this.session.canApplyOptimisticUpdate())return new pi("WaitingSessionConfirmation");switch(s){case 0:const t=this.checkDispatchAllowed(o);if(!t.isSuccessful)return this.trigger("update"),t;this.status=1;const{changes:s,commands:i}=this.state.recordChanges((()=>{const t=performance.now();gi(o)&&this.state.addCommand(o),this.dispatchToHandlers(this.handlers,o),this.finalize();const s=performance.now()-t;s>5&&console.debug(e,s,"ms")}));this.session.save(o,i,s),this.status=0,this.trigger("update");break;case 1:if(gi(o)){const e=this.checkDispatchAllowed(o);if(!e.isSuccessful)return e;this.state.addCommand(o)}this.dispatchToHandlers(this.handlers,o);break;case 3:throw new Error("Cannot dispatch commands in the finalize state");case 2:if(gi(o))throw new Error(`A UI plugin cannot dispatch ${e} while handling a core command`);this.dispatchToHandlers(this.handlers,o)}return pi.Success};dispatchFromCorePlugin=(e,t)=>{const o=Xk(e,t),s=this.status;this.status=2;const i=this.isReplayingCommand?this.coreHandlers:this.handlers;return this.dispatchToHandlers(i,o),this.status=s,pi.Success};dispatchToHandlers(e,t){const o=gi(t);for(const s of e)!o&&s instanceof PM||s.beforeHandle(t);for(const s of e)!o&&s instanceof PM||s.handle(t);this.trigger("command-dispatched",t)}drawLayer(e,t){const o=this.renderers[t];if(o)for(const s of o)e.ctx.save(),s.drawLayer(e,t),e.ctx.restore()}exportData(){let e=iE();for(let t of this.handlers)t instanceof PM&&t.export(e);return e.revisionId=this.session.getRevisionId()||Se,e=Be(e),e}updateMode(e){this.config.mode=e,this.trigger("update")}exportXLSX(){this.dispatch("EVALUATE_CELLS");let e={...iE(),sheets:[rE(Qw,"Sheet1")]};for(let t of this.handlers)t instanceof MM&&t.exportForExcel(e);return e=Be(e),Zk(e)}garbageCollectExternalResources(){for(const e of this.corePlugins)e.garbageCollectExternalResources()}},e.PivotRuntimeDefinition=zO,e.Registry=r,e.Revision=zP,e.SPREADSHEET_DIMENSIONS=Jk,e.Spreadsheet=kN,e.SpreadsheetPivotTable=GO,e.UIPlugin=$M,e.__info__=Kk,e.addFunction=function e(t,o){return Nb.add(t,o),{addFunction:(t,o)=>e(t,o)}},e.addRenderingLayer=function(e,t){if(wi[e])throw new Error(`Layer ${e} already exists`);wi[e]=t},e.astToFormula=If,e.chartHelpers=nL,e.compile=oS,e.compileTokens=sS,e.components=oL,e.constants=rL,e.convertAstNodes=Cf,e.coreTypes=ui,e.findCellInNewZone=ps,e.functionCache=tS,e.helpers=eL,e.hooks=sL,e.invalidateCFEvaluationCommands=ci,e.invalidateDependenciesCommands=li,e.invalidateEvaluationCommands=ni,e.iterateAstNodes=wf,e.links=tL,e.load=eE,e.parse=Sf,e.parseTokens=yf,e.readonlyAllowedCommands=di,e.registries=Qk,e.setDefaultSheetViewSize=function(e){Fe=e},e.setTranslationMethod=function(e,t=(()=>!0)){Ao=e,_o=t},e.stores=iL,e.tokenColors=qb,e.tokenize=ma,Kk.version="18.1.7",Kk.date="2025-02-10T09:00:28.556Z",Kk.hash="338d8a1"}(this.o_spreadsheet=this.o_spreadsheet||{},owl);
|