@odoo/o-spreadsheet 19.0.9 → 19.0.10

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,n=e.description,r=e.icon,a=e.secondaryIcon,l=e.id||s++,c=e.isEnabled?e.isEnabled:()=>!0;return{id:l.toString(),name:"function"==typeof t?t:()=>t,isVisible:e.isVisible?e.isVisible:()=>!0,isEnabled:c,isActive:e.isActive,execute:e.execute?(t,o)=>{if(c(t))return e.execute(t,o)}:void 0,children:o?e=>o.map((t=>"function"==typeof t?t(e):t)).flat().map(i):()=>[],isReadonlyAllowed:e.isReadonlyAllowed||!1,separator:e.separator||!1,icon:"function"==typeof r?r:()=>r||"",iconColor:e.iconColor,secondaryIcon:"function"==typeof a?a:()=>a||"",description:"function"==typeof n?n:()=>n||"",textColor:e.textColor,sequence:e.sequence||0,onStartHover:e.onStartHover,onStopHover:e.onStopHover}}class n{content={};add(e,t){if(e in this.content)throw new Error(`${e} is already present in this registry!`);return this.replace(e,t)}replace(e,t){return this.content[e]=t,this}get(e){const t=this.content[e];if(!t&&!(e in this.content))throw new Error(`Cannot find ${e} in this registry!`);return t}contains(e){return e in this.content}getAll(){return Object.values(this.content)}getKeys(){return Object.keys(this.content)}remove(e){delete this.content[e]}}var r,a;!function(e){e.boolean="boolean",e.number="number",e.text="text",e.empty="empty",e.error="error"}(r||(r={})),function(e){e.PlainText="text/plain",e.Html="text/html",e.Image="image"}(a||(a={}));const l=new Set(["RENAME_SHEET","DELETE_SHEET","CREATE_SHEET","DUPLICATE_SHEET","ADD_COLUMNS_ROWS","REMOVE_COLUMNS_ROWS","UNDO","REDO","ADD_MERGE","REMOVE_MERGE","DUPLICATE_SHEET","UPDATE_LOCALE","ADD_PIVOT","UPDATE_PIVOT","INSERT_PIVOT","RENAME_PIVOT","REMOVE_PIVOT","DUPLICATE_PIVOT"]),c=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"]),h=new Set(["MOVE_RANGES"]),d=new Set(["EVALUATE_CELLS","ADD_CONDITIONAL_FORMAT","REMOVE_CONDITIONAL_FORMAT","CHANGE_CONDITIONAL_FORMAT_PRIORITY"]),u=new Set(["AUTOFILL_CELL","SET_BORDER","SET_ZONE_BORDERS","SET_BORDERS_ON_TARGET"]),g=new Set(["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"]),p=new Set(["START","ACTIVATE_SHEET","COPY","RESIZE_SHEETVIEW","SET_VIEWPORT_OFFSET","EVALUATE_CELLS","EVALUATE_CHARTS","SET_FORMULA_VISIBILITY","UPDATE_FILTER","UPDATE_CHART","UPDATE_CAROUSEL_ACTIVE_ITEM","UPDATE_PIVOT"]),m=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","CREATE_CAROUSEL","UPDATE_CAROUSEL","SET_FORMATTING","CLEAR_FORMATTING","SET_BORDER","SET_ZONE_BORDERS","SET_BORDERS_ON_TARGET","CREATE_CHART","UPDATE_CHART","DELETE_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 f(e){return m.has(e.type)}class v{reasons;constructor(e=[]){Array.isArray(e)||(e=[e]),e=[...new Set(e)],this.reasons=e.filter((e=>"Success"!==e))}static get Success(){return b}get isSuccessful(){return 0===this.reasons.length}isCancelledBecause(e){return this.reasons.includes(e)}}const b=new v;var S;e.CommandResult=void 0,(S=e.CommandResult||(e.CommandResult={})).Success="Success",S.CancelledForUnknownReason="CancelledForUnknownReason",S.WillRemoveExistingMerge="WillRemoveExistingMerge",S.CannotMoveTableHeader="CannotMoveTableHeader",S.MergeIsDestructive="MergeIsDestructive",S.CellIsMerged="CellIsMerged",S.InvalidTarget="InvalidTarget",S.EmptyUndoStack="EmptyUndoStack",S.EmptyRedoStack="EmptyRedoStack",S.NotEnoughElements="NotEnoughElements",S.NotEnoughSheets="NotEnoughSheets",S.MissingSheetName="MissingSheetName",S.UnchangedSheetName="UnchangedSheetName",S.DuplicatedSheetName="DuplicatedSheetName",S.DuplicatedSheetId="DuplicatedSheetId",S.ForbiddenCharactersInSheetName="ForbiddenCharactersInSheetName",S.WrongSheetMove="WrongSheetMove",S.WrongSheetPosition="WrongSheetPosition",S.InvalidAnchorZone="InvalidAnchorZone",S.SelectionOutOfBound="SelectionOutOfBound",S.TargetOutOfSheet="TargetOutOfSheet",S.WrongCutSelection="WrongCutSelection",S.WrongPasteSelection="WrongPasteSelection",S.WrongPasteOption="WrongPasteOption",S.WrongFigurePasteOption="WrongFigurePasteOption",S.EmptyClipboard="EmptyClipboard",S.EmptyRange="EmptyRange",S.InvalidRange="InvalidRange",S.InvalidZones="InvalidZones",S.InvalidSheetId="InvalidSheetId",S.InvalidCellId="InvalidCellId",S.InvalidFigureId="InvalidFigureId",S.InputAlreadyFocused="InputAlreadyFocused",S.MaximumRangesReached="MaximumRangesReached",S.MinimumRangesReached="MinimumRangesReached",S.InvalidChartDefinition="InvalidChartDefinition",S.InvalidDataSet="InvalidDataSet",S.InvalidLabelRange="InvalidLabelRange",S.InvalidScorecardKeyValue="InvalidScorecardKeyValue",S.InvalidScorecardBaseline="InvalidScorecardBaseline",S.InvalidGaugeDataRange="InvalidGaugeDataRange",S.EmptyGaugeRangeMin="EmptyGaugeRangeMin",S.GaugeRangeMinNaN="GaugeRangeMinNaN",S.EmptyGaugeRangeMax="EmptyGaugeRangeMax",S.GaugeRangeMaxNaN="GaugeRangeMaxNaN",S.GaugeLowerInflectionPointNaN="GaugeLowerInflectionPointNaN",S.GaugeUpperInflectionPointNaN="GaugeUpperInflectionPointNaN",S.InvalidAutofillSelection="InvalidAutofillSelection",S.MinBiggerThanMax="MinBiggerThanMax",S.LowerBiggerThanUpper="LowerBiggerThanUpper",S.MidBiggerThanMax="MidBiggerThanMax",S.MinBiggerThanMid="MinBiggerThanMid",S.FirstArgMissing="FirstArgMissing",S.SecondArgMissing="SecondArgMissing",S.MinNaN="MinNaN",S.MidNaN="MidNaN",S.MaxNaN="MaxNaN",S.ValueUpperInflectionNaN="ValueUpperInflectionNaN",S.ValueLowerInflectionNaN="ValueLowerInflectionNaN",S.MinInvalidFormula="MinInvalidFormula",S.MidInvalidFormula="MidInvalidFormula",S.MaxInvalidFormula="MaxInvalidFormula",S.ValueUpperInvalidFormula="ValueUpperInvalidFormula",S.ValueLowerInvalidFormula="ValueLowerInvalidFormula",S.InvalidSortAnchor="InvalidSortAnchor",S.InvalidSortZone="InvalidSortZone",S.SortZoneWithArrayFormulas="SortZoneWithArrayFormulas",S.WaitingSessionConfirmation="WaitingSessionConfirmation",S.MergeOverlap="MergeOverlap",S.TooManyHiddenElements="TooManyHiddenElements",S.Readonly="Readonly",S.InvalidViewportSize="InvalidViewportSize",S.InvalidScrollingDirection="InvalidScrollingDirection",S.ViewportScrollLimitsReached="ViewportScrollLimitsReached",S.FigureDoesNotExist="FigureDoesNotExist",S.InvalidConditionalFormatId="InvalidConditionalFormatId",S.InvalidCellPopover="InvalidCellPopover",S.EmptyTarget="EmptyTarget",S.InvalidFreezeQuantity="InvalidFreezeQuantity",S.FrozenPaneOverlap="FrozenPaneOverlap",S.ValuesNotChanged="ValuesNotChanged",S.InvalidFilterZone="InvalidFilterZone",S.TableNotFound="TableNotFound",S.TableOverlap="TableOverlap",S.InvalidTableConfig="InvalidTableConfig",S.InvalidTableStyle="InvalidTableStyle",S.FilterNotFound="FilterNotFound",S.MergeInTable="MergeInTable",S.NonContinuousTargets="NonContinuousTargets",S.DuplicatedFigureId="DuplicatedFigureId",S.InvalidSelectionStep="InvalidSelectionStep",S.DuplicatedChartId="DuplicatedChartId",S.ChartDoesNotExist="ChartDoesNotExist",S.InvalidHeaderIndex="InvalidHeaderIndex",S.InvalidQuantity="InvalidQuantity",S.MoreThanOneColumnSelected="MoreThanOneColumnSelected",S.EmptySplitSeparator="EmptySplitSeparator",S.SplitWillOverwriteContent="SplitWillOverwriteContent",S.NoSplitSeparatorInSelection="NoSplitSeparatorInSelection",S.NoActiveSheet="NoActiveSheet",S.InvalidLocale="InvalidLocale",S.MoreThanOneRangeSelected="MoreThanOneRangeSelected",S.NoColumnsProvided="NoColumnsProvided",S.ColumnsNotIncludedInZone="ColumnsNotIncludedInZone",S.DuplicatesColumnsSelected="DuplicatesColumnsSelected",S.InvalidHeaderGroupStartEnd="InvalidHeaderGroupStartEnd",S.HeaderGroupAlreadyExists="HeaderGroupAlreadyExists",S.UnknownHeaderGroup="UnknownHeaderGroup",S.UnknownDataValidationRule="UnknownDataValidationRule",S.UnknownDataValidationCriterionType="UnknownDataValidationCriterionType",S.InvalidDataValidationCriterionValue="InvalidDataValidationCriterionValue",S.InvalidNumberOfCriterionValues="InvalidNumberOfCriterionValues",S.InvalidCopyPasteSelection="InvalidCopyPasteSelection",S.NoChanges="NoChanges",S.InvalidInputId="InvalidInputId",S.SheetIsHidden="SheetIsHidden",S.InvalidTableResize="InvalidTableResize",S.PivotIdNotFound="PivotIdNotFound",S.PivotInError="PivotInError",S.EmptyName="EmptyName",S.ValueCellIsInvalidFormula="ValueCellIsInvalidFormula",S.InvalidDefinition="InvalidDefinition",S.InvalidColor="InvalidColor",S.InvalidPivotDataSet="InvalidPivotDataSet",S.InvalidPivotCustomField="InvalidPivotCustomField",S.MissingFigureArguments="MissingFigureArguments",S.InvalidCarouselItem="InvalidCarouselItem";const C=new Set(["containsText","notContainsText","isGreaterThan","isGreaterOrEqualTo","isLessThan","isLessOrEqualTo","isBetween","isNotBetween","beginsWithText","endsWithText","isNotEmpty","isEmpty","isNotEqual","isEqual","customFormula"]),y=new Set(["containsText","notContainsText","isEqualText","isEmail","isLink","dateIs","dateIsBefore","dateIsOnOrBefore","dateIsAfter","dateIsOnOrAfter","dateIsBetween","dateIsNotBetween","dateIsValid","isEqual","isNotEqual","isGreaterThan","isGreaterOrEqualTo","isLessThan","isLessOrEqualTo","isBetween","isNotBetween","isBoolean","isValueInList","isValueInRange","customFormula"]),I=[{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:";"}],w=I[0],x=["thin","medium","thick","dashed","dotted"];function E(e){return Array.isArray(e)&&Array.isArray(e[0])}var R;!function(e){e.UP="up",e.DOWN="down",e.LEFT="left",e.RIGHT="right"}(R||(R={}));const T=.5,A="#017E84",D="#f5f5f5",_="#F8F9FA",F="#E8EAED",O="#595959",P="#666666",M="#c9ccd2",N="#3266ca",k="#FFFFFF",L="#CACACA",V=11982760,U=A,H="#188038",z="#E0E2E4",B="#4A4F59",$="#999",G="#E2E3E3",W="#BCBCBC",q="#9B359B",Z="#00000000",j="#4EA7F2",Y="#EA6175",X="#AAAAAA",K="#111827",J="#D8DADD",Q="#E7E9ED",ee="#F9FAFB",te="#374151",oe=te+"C2",se="#111827",ie="#714B67",ne=Q,re=J,ae="#111827",le="#e6f2f3",ce="#111827",he=A,de="#D44C591A",ue="#C34A41",ge="#98DBE2",pe="#E6F2F3",me=20,fe=10,ve=15,be=16,Se=12,Ce="#F28C28",ye=["#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"],Ie=26,we=48,xe=96,Ee=23,Re=15,Te=4,Ae=3,De=Te,_e=21,Fe=2*Ee,Oe={align:"left",verticalAlign:"bottom",wrapping:"overflow",bold:!1,italic:!1,strikethrough:!1,underline:!1,fontSize:10,fillColor:"",textColor:""},Pe=Oe.verticalAlign,Me=Oe.wrapping,Ne="400",ke=Oe.fontSize,Le="'Roboto', arial",Ve="thin",Ue="#000000",He="START_REVISION",ze=1,Be=20,$e="??",Ge="difference",We="#43C5B1",qe="#EA6175",Ze=.4,je=3,Ye=2,Xe=["'","*","?","/","\\","[","]"],Ke=/'|\*|\?|\/|\\|\[|\]/,Je="|";var Qe;!function(e){e[e.Grid=0]="Grid",e[e.Highlight=5]="Highlight",e[e.HeaderGroupingButton=6]="HeaderGroupingButton",e[e.Figure=10]="Figure",e[e.ScrollBar=15]="ScrollBar",e[e.GridPopover=19]="GridPopover",e[e.GridComposer=20]="GridComposer",e[e.IconPicker=25]="IconPicker",e[e.TopBarComposer=30]="TopBarComposer",e[e.Popover=35]="Popover",e[e.FigureAnchor=1e3]="FigureAnchor",e[e.FigureSnapLine=1001]="FigureSnapLine",e[e.FigureTooltip=1002]="FigureTooltip"}(Qe||(Qe={}));let et=0;function tt(){return et}const ot="\n",st=[6,7,8,9,10,11,12,14,18,24,36],it={hasFilters:!1,totalRow:!1,firstColumn:!0,lastColumn:!1,numberOfHeaders:1,bandedRows:!0,bandedColumns:!1,styleId:"TableStyleMedium5",automaticAutofill:!1},nt=1e5,rt={symbol:"$",position:"before",decimalPlaces:2,code:"",name:"Dollar"},at={fontSize:be,color:te},lt="#000000",ct="#3da4ab",ht={OPERATOR:ct,NUMBER:"#02c39a",STRING:"#00a82d",FUNCTION:lt,DEBUGGER:ct,LEFT_PAREN:lt,RIGHT_PAREN:lt,ARG_SEPARATOR:lt,ORPHAN_RIGHT_PAREN:"#ff0000"},dt=new RegExp(Ke,"g");function ut(e){return'"'===e[0]&&(e=e.slice(1)),'"'===e[e.length-1]&&"\\"!==e[e.length-2]?e.slice(0,e.length-1):e}function gt(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function pt(e){switch(typeof e){case"object":{if(null===e)return e;if(function(e){return"clone"in e&&e.clone instanceof Function}(e))return e.clone();if(!(function(e){return"object"==typeof e&&null!==e&&(e?.constructor===Object||void 0===e?.constructor)}(e)||e instanceof Array))throw new Error("Unsupported type: only objects and arrays are supported");const t=Array.isArray(e)?new Array(e.length):{};if(Array.isArray(e))for(let o=0,s=e.length;o<s;o++)o in e&&(t[o]=pt(e[o]));else for(const o in e)t[o]=pt(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 mt(e){return ft(e,"'")}function ft(e,t='"'){return e.startsWith(t)&&(e=e.slice(1)),e.endsWith(t)&&(e=e.slice(0,-1)),e}function vt(e){return e.match(/\w/g)?.length!==e.length&&(e=`'${e}'`),e}function bt(e,t=" "){return e.replace(dt,t)}function St(e,t,o){return e<t?t:e>o?o:e}function Ct(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 yt(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*It(e,t){t.next();for(const o of e){const e=t.next();yield{...o,next:e.done?void 0:e.value}}}function wt(e){const t=e.toUpperCase();return"TRUE"===t||"FALSE"===t}const xt=/^\[(.+)\]\((.+)\)$/,Et=/^https?:\/\/(www\.)?[-a-zA-Z0-9@:%._\+~#=]{2,256}\.[a-z]{2,4}\b([-a-zA-Z0-9@:%_\+.~#?&//=]*)$/;function Rt(e){return xt.test(e)}function Tt(e){return Et.test(e)}function At(e,t){return`[${e}](${t})`}function Dt(e){const t=e.match(xt)||[],o=t[1],s=t[2];if(!o||!s)throw new Error(`Could not parse markdown link ${e}.`);return{label:o,url:s}}const _t="o-spreadsheet://";function Ft(e){return e.startsWith(_t)}function Ot(e){return`${_t}${e}`}function Pt(e){if(e.startsWith(_t))return e.slice(_t.length);throw new Error(`${e} is not a valid sheet link`)}function Mt(e){return void 0!==e}function Nt(e){return void 0===e||Object.values(e).every((e=>"object"==typeof e?Nt(e):!e))}function kt(e,t,o){let s;const i=function(){const i=this,n=Array.from(arguments);const r=o&&!s;clearTimeout(s),s=setTimeout((function(){s=void 0,o||e.apply(i,n)}),t),r&&e.apply(i,n)};return i.isDebouncePending=()=>void 0!==s,i.stopDebounce=()=>{clearTimeout(s)},i}function Lt(e){let t="";for(let o=0,s=e.length;o<s;o++)t+=e[o];return t}function Vt(e){let t,o=!1;const s=()=>(o||(t=e instanceof Function?e():e,o=!0),t);return s.map=e=>Vt((()=>e(s()))),s}function Ut(e,t){let o=e.slice(t).find((e=>e));return o||(o=e.slice(0,t).reverse().find((e=>e))),o||""}function Ht(e,t){return"after"===e?t+1:t}function zt(...e){if(e.length<=1)return!0;for(let t=1;t<e.length;t++)if(!Bt(e[0],e[t]))return!1;return!0}function Bt(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(!Bt(e[o],t[o]))return!1}else if(e[o]!==t[o])return!1}return!0}function $t(e,t){if(e.length!==t.length)return!1;for(let o=0;o<e.length;o++)if(!zt(e[o],t[o]))return!1;return!0}function Gt(e,t){if(e.length<t.length)return!1;const o=new Set(e);return t.every((e=>o.has(e)))}function Wt(e){if(!e)return e;const t={...e};return Object.keys(t).forEach((e=>!t[e]&&delete t[e])),t}const qt=["\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))],Zt=new RegExp(qt.join("|"),"g"),jt=/(\r\n|\r)/g,Yt=qt.concat([" "]);function Xt(e){return e?e.replace(jt,ot):""}function Kt(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 Jt(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 Qt(e,t){const o=new Set(t),s=[];for(let t=0;t<e.length;t++)o.has(t)||s.push(e[t]);return s}function eo(e,t,o){return e.slice(0,o).concat(t).concat(e.slice(o))}function to(e,t,o){const s=[...e];return s[o]=t,s}function oo(e){return e.split("\n").map((e=>e.replace(/\s+/g," ").trim())).join("\n")}function so(e,t,o){return t>o?so(e,o,t):e>=t&&e<=o}function io(e,t){let o=gt(e);const s=t.matchCase?"":"i";return t.exactMatch&&(o=`^${o}$`),RegExp(o,s)}function no(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 ro(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 ao{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 lo(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 co(e){const t={};for(const o in e)for(const s in e[o])t[s]||(t[s]={}),t[s][o]=e[o][s];return t}function ho(e,t,o={}){const s=o.compute??((e,t)=>`${e} (${t})`),i=o.computeFirstOne??!1;let n=o.start??1,r=i?s(e,n):e;for(;t.includes(r);)r=s(e,n++);return r}function uo(e){return e.startsWith("=")||e.startsWith("+")}const go={Background:0,Highlights:1,Clipboard:2,Chart:4,Autofill:5,Selection:6,Headers:100},po=Jt((()=>Object.keys(go).sort(((e,t)=>go[e]-go[t]))));new Set(["containsText","notContainsText","isEqualText","dateIs","dateIsBefore","dateIsOnOrBefore","dateIsAfter","dateIsOnOrAfter","dateIsBetween","dateIsNotBetween","isEqual","isNotEqual","isGreaterThan","isGreaterOrEqualTo","isLessThan","isLessOrEqualTo","isBetween","isNotBetween","customFormula","beginsWithText","endsWithText","isNotEmpty","isEmpty"]);const mo=["containsText","notContainsText","isEqualText","isEmpty","isNotEmpty","beginsWithText","endsWithText"],fo=["isEqual","isNotEqual","isGreaterThan","isGreaterOrEqualTo","isLessThan","isLessOrEqualTo","isBetween","isNotBetween","isEmpty","isNotEmpty"],vo=["dateIs","dateIsBefore","dateIsOnOrBefore","dateIsAfter","dateIsOnOrAfter","dateIsBetween","dateIsNotBetween","isEmpty","isNotEmpty"],bo=["image/avif","image/bmp","image/gif","image/vnd.microsoft.icon","image/jpeg","image/png","image/tiff","image/webp"];function So(e){if(e<0)throw new Error(`number must be positive. Got ${e}`);return e<26?String.fromCharCode(65+e):So(Math.floor(e/26)-1)+So(e%26)}function Co(e){let t=0;const o=e.length;for(let s=0;s<o;s++){t=26*t+yo(e[s])}return t-1}function yo(e){const t=e.charCodeAt(0);return t>=65&&t<=90?t-64:t-96}function Io(e){return e>="A"&&e<="Z"||e>="a"&&e<="z"}function wo(e){return e>="0"&&e<="9"}const xo=Co("ZZZ"),Eo=9999998;function Ro(e){for(;" "===e.current;)e.advanceBy(1)}function To(e){if("$"===e.current&&e.advanceBy(1),!e.current||!Io(e.current))return-1;let t=0;for(;e.current&&Io(e.current);)t=26*t+yo(e.shift());return t}function Ao(e){if("$"===e.current&&e.advanceBy(1),!e.current||!wo(e.current))return-1;let t=0;for(;e.current&&wo(e.current);)t=10*t+Number(e.shift());return t}function Do(e){const t=new ao(e);Ro(t);const o=To(t);if(-1===o||!t.current)throw new Error(`Invalid cell description: ${e}`);const s=Ao(t);Ro(t);const i=o-1,n=s-1;if(!t.isOver()||i>xo||n>Eo)throw new Error(`Invalid cell description: ${e}`);return{col:i,row:n}}function _o(e,t,o={colFixed:!1,rowFixed:!1}){return(o.colFixed?"$":"")+So(e)+(o.rowFixed?"$":"")+String(t+1)}function Fo(e,t=[]){if(e.length<=1&&0===t.length)return e;const o=[0],s=new Map([[0,[]]]);return Oo(o,s,e,!1),Oo(o,s,t,!0),ko(o,s)}function Oo(e,t,o,s=!1){for(const i of o){const o=i.left,n=void 0===i.right?void 0:i.right+1,r=Po(e,t,o,!0,0),a=Po(e,t,n,!1,r);for(let o=r;o<=a;o++){Mo(t.get(e[o]),i,s)}No(e,t,r,a)}}function Po(e,t,o,s,i){if(void 0===o)return e.length-1;const n=Lo(e,o,i);return o!==e[n]?(e.splice(n+1,0,o),t.set(o,[...t.get(e[n])]),s?n+1:n):s?n:n-1}function Mo(e,t,o=!1){const s=t.top,i=void 0===t.bottom?void 0:t.bottom+1,n=[],r=Lo(e,s,0,!1);if((r%2!=0&&!o||r%2==0&&o)&&n.push(s),void 0===i)return e.splice(r+1),void e.push(...n);const a=Vo(e,i,0,!1);(a%2==0&&!o||a%2!=0&&o)&&n.push(i);const l=a-r-1,c=n.length,h=r+1;h===e.length-1&&1===l&&1===c?e[h]=n[0]??n[1]:e.splice(h,l,...n)}function No(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--)$t(t.get(e[o]),t.get(e[o-1]))&&(t.delete(e[o]),e.splice(o,1))}function ko(e,t){const o=[];let s=[];for(let i=0;i<e.length;i++){const n=e[i],r=t.get(n);if(!r||0===r.length){o.push(...s),s=[];continue}let a=e[i+1];void 0!==a&&a--;const l=[];for(let e=0;e<r.length;e+=2){const t=r[e];let o=r[e+1];void 0!==o&&o--;const i={top:t,left:n,bottom:o,right:a};(void 0===o&&0!==t||void 0===a&&0!==n)&&(i.hasHeader=!0);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}function Lo(e,t,o=0,s=!0){let i=e.length-1,n=-1;for(;o<=i;){const r=Math.floor((o+i)/2);if(e[r]===t&&s)return r;e[r]<t?(n=r,o=r+1):i=r-1}return n}function Vo(e,t,o=0,s=!0){let i=e.length-1,n=e.length;for(;o<=i;){const r=Math.floor((o+i)/2);if(e[r]===t&&s)return r;e[r]>t?(n=r,i=r-1):o=r+1}return n}function Uo(e){const t=function(e){const t=new ao(e);Ro(t);const o=e.indexOf("!");-1!==o&&t.advanceBy(o+1);const s=To(t),i=Ao(t);let n,r,a,l,c=!1,h=!1,d=!1;if(-1===i?(a=l=s-1,n=r=0,c=!0):-1===s?(n=r=i-1,a=l=0,h=!0):(a=l=s-1,n=r=i-1,d=!0),Ro(t),":"===t.current){t.advanceBy(1),Ro(t);const e=To(t),o=Ao(t);-1===o?(l=e-1,c=!0):-1===e?(r=o-1,h=!0):(l=e-1,r=o-1,n=c?r:n,a=h?l:a,d=!0)}const u={top:n,left:a,bottom:c?void 0:r,right:h?void 0:l};return d=d&&(h||c),d&&(u.hasHeader=d),u}(e),o=rs(t),s=o.bottom,i=o.right;if(void 0!==s&&s>Eo||void 0!==i&&i>xo)throw new Error(`Range string out of bounds: ${e}`);if(void 0===s&&void 0===i)throw new Error("Wrong zone xc. The zone cannot be at the same time a full column and a full row");return o}function Ho(e){const t=Uo(e);if(void 0===t.bottom||void 0===t.right)throw new Error("This does not support unbounded ranges");return t}function zo(e){try{return function(e){return Bo(Uo(e))}(e)}catch(e){return!1}}function Bo(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))&&($o(e)&&e.top>=0&&e.left>=0)}function $o(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 Go(e){const{top:t,bottom:o,left:s,right:i}=e,n="hasHeader"in e&&e.hasHeader,r=t===o&&s===i;if(void 0===o&&void 0!==i)return 0!==t||n?`${_o(s,t)}:${So(i)}`:`${So(s)}:${So(i)}`;if(void 0===i&&void 0!==o)return 0!==s||n?`${_o(s,t)}:${o+1}`:`${t+1}:${o+1}`;if(void 0!==o&&void 0!==i)return r?_o(s,t):`${_o(s,t)}:${_o(i,o)}`;throw new Error("Bad zone format")}function Wo(e,t,o,s,i){const n="left"===t?"columns":"rows",r="before"===s?o-1:o,a=e["left"===t?"right":"bottom"];return e[t]<=r&&a&&a>r?as(e,n,"RESIZE",i):r<e[t]?as(e,n,"MOVE",i):{...e}}function qo(e,t,o,s,i){const n="left"===t?"columns":"rows",r="before"===s?o-1:o,a="left"===t?"right":"bottom";return e[t]<=r&&e[a]>r?as(e,n,"RESIZE",i):r<e[t]?as(e,n,"MOVE",i):{...e}}function Zo(e,t,o){const s="left"===t?"right":"bottom";let i=e[t],n=e[s];for(const r of o.sort(((e,t)=>t-e)))e[t]>r&&(i--,n--),e[t]<r&&e[s]>=r&&n--;return{...e,[t]:i,[s]:n}}function jo(e,t,o){const s="left"===t?"right":"bottom";let i=e[t],n=e[s];const r=e[s];for(const s of o.sort(((e,t)=>t-e)))e[t]>s&&(i--,void 0!==n&&n--),void 0!==r&&void 0!==n&&e[t]<=s&&r>=s&&n--;if(!(void 0!==n&&i>n))return{...e,[t]:i,[s]:n}}function Yo(...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 Xo(e,t){if(Qo(e,t))return{top:Math.max(e.top,t.top),left:Math.max(e.left,t.left),bottom:void 0!==e.bottom?Math.min(e.bottom,t.bottom):e.bottom??t.bottom,right:void 0!==e.right?Math.min(e.right,t.right):e.right??t.right}}function Ko(e,t){return e.left===t.left&&e.right===t.right&&e.top===t.top&&e.bottom===t.bottom&&e.hasHeader===t.hasHeader}function Jo(e,t){if(Xo(e,t))return;let o;return e.left===t.right+1&&(o={position:"left",start:Math.max(e.top,t.top),stop:void 0!==e.bottom?Math.min(e.bottom,t.bottom):t.bottom}),void 0!==e.right&&e.right+1===t.left&&(o={position:"right",start:Math.max(e.top,t.top),stop:void 0!==e.bottom?Math.min(e.bottom,t.bottom):t.bottom}),e.top===t.bottom+1&&(o={position:"top",start:Math.max(e.left,t.left),stop:void 0!==e.right?Math.min(e.right,t.right):t.right}),void 0!==e.bottom&&e.bottom+1===t.top&&(o={position:"bottom",start:Math.max(e.left,t.left),stop:void 0!==e.right?Math.min(e.right,t.right):t.right}),o&&o.start<=o.stop?o:void 0}function Qo(e,t){return!(void 0!==e.bottom&&e.bottom<t.top||void 0!==t.bottom&&t.bottom<e.top)&&!(void 0!==e.right&&e.right<t.left||void 0!==t.right&&t.right<e.left)}function es(e,t,o){const{left:s,right:i,top:n,bottom:r}=o;return e>=s&&e<=i&&t>=n&&t<=r}function ts(e,t){return Ko(Yo(t,e),t)}function os(e){return{numberOfRows:e.bottom-e.top+1,numberOfCols:e.right-e.left+1}}function ss(e){const{numberOfCols:t,numberOfRows:o}=os(e);return 1===t||1===o}function is(e){const t=[],{left:o,right:s,top:i,bottom:n}=rs(e);for(const e of Ct(o,s+1))for(const o of Ct(i,n+1))t.push({col:e,row:o});return t}function ns(e,t){const o=[],{left:s,right:i,top:n,bottom:r}=rs(t);for(const t of Ct(s,i+1))for(const s of Ct(n,r+1))o.push({sheetId:e,col:t,row:s});return o}function rs(e){return void 0!==e.right&&e.left>e.right&&(e={...e,left:e.right,right:e.left}),void 0!==e.bottom&&e.top>e.bottom&&(e={...e,top:e.bottom,bottom:e.top}),e}function as(e,t,o,s){const i="both"===t?s[0]:"columns"===t?s:0,n="both"===t?s[1]:"rows"===t?s:0,r="hasHeader"in e&&e.hasHeader;let a;a=us(e)&&!r?"rows"!==t:!(ds(e)&&!r)||"columns"!==t;const l={...e};return a&&"MOVE"===o&&(l.left+=i,l.top+=n),void 0!==l.right&&(l.right+=i),void 0!==l.bottom&&(l.bottom+=n),l}function ls(e,t){let o,s;const{left:i,right:n,top:r,bottom:a}=e,{left:l,right:c,top:h,bottom:d}=t;return o=l!==i?l:c!==n?c:l,s=h!==r?h:d!==a?d:h,{col:o,row:s}}function cs(e){return{left:e.col,right:e.col,top:e.row,bottom:e.row}}function hs(e){return{...e,right:e.left,bottom:e.top}}function ds(e){return void 0===e.right}function us(e){return void 0===e.bottom}function gs(e){return(e.bottom-e.top+1)*(e.right-e.left+1)}function ps(e,t,o){return e.some((e=>function(e,t,o){return e.left<t&&t<=e.right||e.top<o&&o<=e.bottom}(e,t,o)))}function ms(e){return e.length<2||1===Fo(e).length}function fs(e){const t=[...e];let o=!0;for(;o;){o=!1;for(let e=0;e<t.length;e++){const s=t[e],i=t.findIndex(((t,o)=>{return e!==o&&(n=s,((i=t).right+1===n.left||i.left===n.right+1?i.top<=n.bottom&&i.top>=n.top||n.top<=i.bottom&&n.top>=i.top:(i.bottom+1===n.top||i.top===n.bottom+1)&&(i.left<=n.right&&i.left>=n.left||n.left<=i.right&&n.left>=i.left))||Qo(t,s));var i,n}));if(-1!==i){t[e]=Yo(t[i],s),t.splice(i,1),o=!0;break}}}return t}function vs(e,t){const o=Jo(e,t);if(!o)return[e];const s=[];switch(o.position){case"bottom":case"top":return s.push({top:e.top,bottom:e.bottom,left:o.start,right:o.stop}),o.start>e.left&&s.push({top:e.top,bottom:e.bottom,left:e.left,right:o.start-1}),(void 0===e.right||o.stop<e.right)&&s.push({top:e.top,bottom:e.bottom,left:o.stop+1,right:e.right}),s;case"left":case"right":return s.push({top:o.start,bottom:o.stop,left:e.left,right:e.right}),o.start>e.top&&s.push({top:e.top,bottom:o.start-1,left:e.left,right:e.right}),(void 0===e.bottom||o.stop<e.bottom)&&s.push({top:o.stop+1,bottom:e.bottom,left:e.left,right:e.right}),s}}function bs(e,t){const o=new Set(t.map((e=>e.left))),s=new Set(t.map((e=>e.right))),i=new Set(t.map((e=>e.top))),n=new Set(t.map((e=>e.bottom))),r=1===i.size&&1===n.size||1===o.size&&1===s.size?function(e){return e.reduce(((e,t)=>{const o=e.length;for(let s=0;s<o;s++)if(Qo(e[s],t))return e[s]=Yo(e[s],t),e;return e[o]=t,e}),[])}(t):[t[t.length-1]],a=r.map((e=>is(e))).flat();return{sheetId:e,zones:t,clippedZones:r,columnsIndexes:[...new Set(a.map((e=>e.col)))].sort(((e,t)=>e-t)),rowsIndexes:[...new Set(a.map((e=>e.row)))].sort(((e,t)=>e-t))}}function Ss(e,t,o){const s=Math.max(e.right-t+1,e.left),i=Math.max(e.bottom-o+1,e.top),n=[];for(let r=e.left;r<=s;r+=t)for(let s=e.top;s<=i;s+=o)n.push({left:r,top:s,bottom:s+o-1,right:r+t-1});return n}function Cs(e,t){if(!t.length||!t[0].length)return e;const o=t[0].length,s=t.length;return e.map((e=>Ss(e,o,s))).flat()}function ys(e){let t;if(e[a.Html]){t=function(e){const t=[...e.documentElement.attributes];if(t.some((e=>e.value.includes("microsoft"))))return;const o=e.querySelector("div")?.getAttribute("data-osheet-clipboard");return o&&JSON.parse(o)}((new DOMParser).parseFromString(e[a.Html],"text/html"))}const o=e[a.PlainText]||"";let s;if(!o.trim())for(const t of bo)if(e[t]){s=e[t];break}return{text:o,data:t,imageBlob:s}}const Is=(e,t,o,s)=>{e.forEach((({handlerName:e,handler:i})=>{const n=t[e];n&&i.paste(o,n,s)}))};function ws(e,t,o,s,i){let n;const r=[],a={sheetId:e,zones:t};for(const{handlerName:l,handler:c}of s){const s=o[l];if(!s)continue;const h=c.getPasteTarget(e,t,s,i);h.figureId&&(a.figureId=h.figureId);for(const e of h.zones)r.push(e),n=void 0!==n?Yo(n,e):e}return{target:a,zone:n,selectedZones:r}}const xs=(e,t,o)=>{const s={col:t[0].left,row:t[0].top};e.getBackToDefault(),e.selectZone({cell:s,zone:Yo(...o)},{scrollIntoView:!1})},Es=/rgba?\(|\s+|\)/gi,Rs=/^#([A-F\d]{2}){3,4}$/,Ts=["#eb6d00","#0074d9","#ad8e00","#169ed4","#b10dc9","#00a82d","#00a3a3","#f012be","#3d9970","#111111","#62A300","#ff4136","#949494","#85144b","#001f3f"];function As(e,t=1){const o=1!==t?Math.round(255*t).toString(16).padStart(2,"0"):"";return _s(e.toString(16).padStart(6,"0"))+o}function Ds(e){return"number"==typeof e?e:Number.parseInt(_s(e).slice(1,7),16)}function _s(e){let t=e;if(e.startsWith("rgb")?t=function(e){const t=e.replace(Es,"").split(",");let o=255;if(3!==t.length&&4!==t.length)throw new Error("invalid color");if(4===t.length){const e=parseFloat(t.pop()||"1");if(isNaN(e))throw new Error("invalid alpha value");o=Math.round(255*e)}const s=t.map((e=>parseInt(e,10)));255!==o&&s.push(o);return"#"+Lt(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}`),!Rs.test(t))throw new Error(`invalid color input: ${e}`);return t}function Fs(e){try{return _s(e),!0}catch(e){return!1}}const Os=e=>e>=0&&e<=255;function Ps(e,t,o,s=1){if(!Os(e)||!Os(t)||!Os(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 Ms(e){let{r:t,g:o,b:s}=ks(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 Ns(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 ks(e){let t,o,s,i;if(7===(e=_s(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 Ls(e){(e={...e}).s/=100,e.l/=100;const t=(1-Math.abs(2*e.l-1))*e.s,o=t*(1-Math.abs(e.h/60%2-1)),s=e.l-t/2;let i=0,n=0,r=0;return 0<=e.h&&e.h<60?(i=t,n=o,r=0):60<=e.h&&e.h<120?(i=o,n=t,r=0):120<=e.h&&e.h<180?(i=0,n=t,r=o):180<=e.h&&e.h<240?(i=0,n=o,r=t):240<=e.h&&e.h<300?(i=o,n=0,r=t):300<=e.h&&e.h<360&&(i=t,n=0,r=o),i=Math.round(255*(i+s)),n=Math.round(255*(n+s)),r=Math.round(255*(r+s)),{a:e.a,r:i,g:n,b:r}}function Vs(e){const t=e.r/255,o=e.g/255,s=e.b/255,i=Math.min(t,o,s),n=Math.max(t,o,s),r=n-i;let a=0,l=0,c=0;return a=0===r?0:n===t?(o-s)/r%6:n===o?(s-t)/r+2:(t-o)/r+4,a=Math.round(60*a),a<0&&(a+=360),c=(n+i)/2,l=0===r?0:r/(1-Math.abs(2*c-1)),l=+(100*l).toFixed(1),c=+(100*c).toFixed(1),{a:e.a,h:a,s:l,l:c}}function Us(e){return Ns(Ls(e))}function Hs(e){return Vs(ks(e))}function zs(e){return ks("number"==typeof e?As(e):e)}function Bs(e,t){return 1===t?_s(e).slice(0,7):Ns({...ks(e),a:t})}function $s(e,t){const o=Hs(e);return 1===t?"#fff":(o.l=t*(100-o.l)+o.l,Us(o))}function Gs(e,t){const o=Hs(e);return 1===t?"#000":(o.s=Math.min(100,t*o.s+o.s),o.l=o.l-t*o.l,Us(o))}function Ws(e){return Ms(e)<.6?$s(e,.9):Gs(e,.75)}const qs=["#4EA7F2","#EA6175","#43C5B1","#F4A261","#8481DD","#FFD86D"],Zs=["#4EA7F2","#3188E6","#43C5B1","#00A78D","#EA6175","#CE4257","#F4A261","#F48935","#8481DD","#5752D1","#FFD86D","#FFBC2C"],js=["#4EA7F2","#3188E6","#056BD9","#A76DBC","#7F4295","#6D2387","#EA6175","#CE4257","#982738","#43C5B1","#00A78D","#0E8270","#F4A261","#F48935","#BE5D10","#8481DD","#5752D1","#3A3580","#A4A8B6","#7E8290","#545B70","#FFD86D","#FFBC2C","#C08A16"],Ys=["#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"],Xs=["#4EA7F2","#43C5B1","#EA6175","#F4A261","#8481DD","#FFD86D","#3188E6","#00A78D","#CE4257","#F48935","#5752D1","#FFBC2C"],Ks=["#4EA7F2","#A76DBC","#EA6175","#43C5B1","#F4A261","#8481DD","#A4A8B6","#FFD86D","#3188E6","#7F4295","#CE4257","#00A78D","#F48935","#5752D1","#7E8290","#FFBC2C","#056BD9","#6D2387","#982738","#0E8270","#BE5D10","#3A3580","#545B70","#C08A16"],Js=["#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 Qs(e,t){return t[e%t.length]}function ei(e){return e<=6?qs:e<=12?Zs:e<=24?js:Ys}class ti{preferredColors;currentColorIndex=0;palette;constructor(e,t=[]){this.preferredColors=t,this.palette=ei(e).filter((e=>!t.includes(e)))}next(){return this.preferredColors?.[this.currentColorIndex]?this.preferredColors[this.currentColorIndex++]:Qs(this.currentColorIndex++,this.palette)}}class oi extends ti{constructor(e,t=[]){var o;super(e,t),this.palette=(o=e,o<=6?qs:o<=12?Xs:o<=24?Ks:Js).filter((e=>!t.includes(e)))}}class si{availableColors;colors={};constructor(e=12){this.availableColors=new oi(e)}get(e){return this.colors[e]||(this.colors[e]=this.availableColors.next()),this.colors[e]}}function ii(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=zs(t[e-1].color).a,i=zs(t[e].color).a,n=Ds(t[e-1].color),r=Ds(t[e].color);o.push({min:t[e-1].value,max:t[e].value,minColor:n,maxColor:r,minColorAlpha:s,maxColorAlpha:i,colorDiff:ni(t[e-1].value,t[e].value,n,r)})}return e=>{if(e<o[0].min)return As(o[0].minColor,o[0].minColorAlpha);for(const t of o)if(e>=t.min&&e<=t.max)return As(ri(e,t.min,t.minColor,t.colorDiff),t.maxColorAlpha);return As(o[o.length-1].maxColor,o[o.length-1].maxColorAlpha)}}function ni(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 ri(e,t,o,s){const[i,n,r]=s;return Math.round((o>>16)%256-i*(e-t))<<16|Math.round((o>>8)%256-n*(e-t))<<8|Math.round(o%256-r*(e-t))}const ai=e=>e,li=()=>!1;let ci=ai,hi=li;function di(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 ui=function(e,...t){return hi()?di(ci(e),...t):new gi(e,t)};class gi extends String{values;constructor(e,t){super(e),this.values=t}valueOf(){const e=super.valueOf();return hi()?di(ci(e),...this.values):di(e,...this.values)}toString(){return this.valueOf()}}function pi(e){return/^https?:\/\//i.test(e)?e:`https://${e}`}const mi=new n;function fi(e,t){return{url:e=pi(e),label:t||e,isExternal:!0,isUrlEditable:!0}}mi.add("sheet_URL",{match:e=>Ft(e),createLink:(e,t)=>({label:t,url:e,isExternal:!1,isUrlEditable:!1}),urlRepresentation(e,t){const o=Pt(e);return t.tryGetSheetName(o)||ui("Invalid sheet")},open(e,t){const o=Pt(e);t.model.dispatch("ACTIVATE_SHEET",{sheetIdFrom:t.model.getters.getActiveSheetId(),sheetIdTo:o}).isCancelledBecause("SheetIsHidden")&&t.notifyUser({type:"warning",sticky:!1,text:ui("Cannot open the link because the linked sheet is hidden.")})},sequence:0});const vi={createLink:fi,match:e=>Tt(e),open:e=>window.open(e,"_blank"),urlRepresentation:e=>e,sequence:0};function bi(e){return mi.getAll().sort(((e,t)=>e.sequence-t.sequence)).find((t=>t.match(e)))||vi}function Si(e,t){return bi(e.url).urlRepresentation(e.url,t)}function Ci(e,t,o){bi(e.url).open(e.url,t,o)}function yi(e){if("string"==typeof e){if(Rt(e)){const{label:t,url:o}=Dt(e);return bi(o).createLink(o,t)}return Tt(e)?fi(e):void 0}}class Ii{jsDate;constructor(e,t,o,s=0,i=0,n=0){this.jsDate=new Date(Date.UTC(e,t,o,s,i,n,0))}static fromTimestamp(e){const t=new Date(e);return new Ii(t.getUTCFullYear(),t.getUTCMonth(),t.getUTCDate(),t.getUTCHours(),t.getUTCMinutes(),t.getUTCSeconds())}static now(){const e=new Date;return new Ii(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 wi=new Ii(1899,11,30),xi=864e5,Ei=2e3,Ri=Ii.now().getFullYear(),Ti=Ii.now().getMonth(),Ai=Ii.fromTimestamp(0).getTime()-wi.getTime(),Di=/^\d{1,2}(\/|-|\s)\d{1,2}((\/|-|\s)\d{1,4})?$/,_i=/^\d{3,4}(\/|-|\s)\d{1,2}(\/|-|\s)\d{1,2}$/,Fi=Yt.join(""),Oi=new RegExp(`/|-|${Yt.join("|")}`),Pi=new RegExp(`^(\\d{1,4})[/${Fi}-](\\d{1,4})([/${Fi}-](\\d{1,4}))?$`),Mi=/((\d+(:\d+)?(:\d+)?\s*(AM|PM))|(\d+:\d+(:\d+)?))$/;function Ni(e,t){switch(typeof e){case"number":return e;case"string":return ki(e,t)?Vi(e,t)?.value:!e||isNaN(Number(e))?void 0:Number(e);default:return}}function ki(e,t){return null!==Vi(e,t)}const Li=new Map;function Vi(e,t){return Li.has(t)||Li.set(t,new Map),Li.get(t).has(e)||Li.get(t).set(e,function(e,t){e=e.trim();let o=null;const s=e.match(Mi);if(s){if(o=function(e){if(e=e.trim(),Mi.test(e)){const t=/AM/i.test(e),o=/PM/i.test(e),s=(t||o?e.substring(0,e.length-2).trim():e).split(/:/),i=s.length>=2,n=3===s.length;let r=Number(s[0]),a=i?Number(s[1]):0,l=n?Number(s[2]):0,c=n?"hh:mm:ss":"hh:mm";if(t||o)c+=" a";else if(!i)return null;r>=12&&t?r-=12:r<12&&o&&(r+=12),a+=Math.floor(l/60),l%=60,r+=Math.floor(a/60),a%=60,r>=24&&(c="hhhh:mm:ss");return{value:r/24+a/1440+l/86400,format:c,jsDate:new Ii(1899,11,30,r,a,l)}}return null}(s[0]),null===o)return null;e=e.replace(s[0],"").trim()}let i=null;const n=function(e,t){const o=e.match(Pi);if(!o)return null;const[,s,i,,n]=o;if(s.length>2&&n&&n.length>2)return null;if(s.length>2)return{year:s,month:i,day:n,dateString:e,type:"ymd"};const r=function(e){switch(e.dateFormat[0]){case"d":return"dmy";case"m":return"mdy";case"y":return"ymd"}throw new Error("Invalid date format in locale")}(t);if(!n)return i.length>2?{month:s,year:i,day:void 0,dateString:e,type:r}:"dmy"===r?{day:s,month:i,year:n,dateString:e,type:"dmy"}:{month:s,day:i,year:n,dateString:e,type:"mdy"};if(n.length>2)return"mdy"===r?{month:s,day:i,year:n,dateString:e,type:"mdy"}:{day:s,month:i,year:n,dateString:e,type:"dmy"};if("mdy"===r)return{month:s,day:i,year:n,dateString:e,type:"mdy"};if("ymd"===r)return{year:s,month:i,day:n,dateString:e,type:"ymd"};if("dmy"===r)return{day:s,month:i,year:n,dateString:e,type:"dmy"};return null}(e,t);if(n){const t=n.dateString.match(Oi)[0];if(i=function(e,t){const{year:o,month:s,day:i}=e,n=function(e){if(!e)return Ti;const t=Number(e);if(t>=1&&t<=12)return t-1;return null}(s),r=function(e){if(!e)return 1;const t=Number(e);if(t>=0&&t<=31)return t;return null}(i),a=function(e){if(!e)return Ri;const t=Number(e);switch(e.length){case 1:return Ei+t;case 2:return Ei+(Ei+t>Ri+10?-100:0)+t;case 3:case 4:return t}return null}(o);if(null===a||null===n||null===r)return null;const l=2===s?.length&&n+1<10||2===i?.length&&r<10,c=2!==o?.length,h=new Ii(a,n,r);if(h.getMonth()!==n||h.getDate()!==r)return null;const d=h.getTime()-wi.getTime(),u=function(e,t,o,s){const i=e.year?s?"yyyy":"yy":void 0,n=e.month?o?"mm":"m":void 0,r=e.day?o?"dd":"d":void 0;switch(e.type){case"mdy":return[n,r,i].filter(Mt).join(t);case"ymd":return[i,n,r].filter(Mt).join(t);case"dmy":return[r,n,i].filter(Mt).join(t)}}(e,t,l,c);return{value:Math.round(d/xi),format:u,jsDate:h}}(n,t),null===i)return null;e=e.replace(n.dateString,"").trim()}if(""!==e||!i&&!o)return null;if(i&&i.jsDate&&o&&o.jsDate)return{value:i.value+o.value,format:i.format+" "+("hhhh:mm:ss"===o.format?"hh:mm:ss":o.format),jsDate:new Ii(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)),Li.get(t).get(e)}function Ui(e){const t=Math.trunc(e),o=Ii.fromTimestamp(t*xi-Ai);let s=e-t;s=s<0?1+s:s;const i=Math.round(24*s),n=Math.round(24*(s-i/24)*60),r=Math.round(24*(s-i/24-n/24/60)*60*60);return o.setHours(i),o.setMinutes(n),o.setSeconds(r),o}function Hi(e){return Math.round(zi(e))}function zi(e){return(e.getTime()-wi.getTime())/xi}function Bi(e){return new Ii(e.getFullYear(),e.getMonth()+1,0).getDate()}function $i(e){return Bi(e)===e.getDate()}function Gi(e,t,o){const s=e.getFullYear(),i=e.getMonth(),n=e.getDate(),r=new Ii(s,i+t,1);return o&&n===Bi(e)||n>Bi(r)?r.setDate(Bi(r)):r.setDate(n),r}function Wi(e){const t=Math.trunc(e);return t%4==0&&t%100!=0||t%400==0}function qi(e,t,o){if(e===t)return 0;if(e>t){const o=t;t=e,e=o}const s=Ui(e),i=Ui(t);let n=s.getDate(),r=i.getDate();const a=s.getMonth(),l=i.getMonth(),c=s.getFullYear(),h=i.getFullYear();let d=0,u=0;switch(o){case 0:31===n&&(n=30),30===n&&31===r&&(r=30),1===a&&n===(Wi(c)?29:28)&&(n=30,1===l&&r===(Wi(h)?29:28)&&(r=30)),d=c+(30*a+n)/360,u=h+(30*l+r)/360;break;case 1:let o=365;const s=c===h;if(!s&&!(c+1===h)||!s&&a<l||!s&&a===l&&n<r){let e=0,t=0;for(let o=c;o<=h;o++)e++,t+=Wi(o)?366:365;o=t/e}else s?Wi(c)&&(o=366):(Wi(c)&&a<2&&(o=366),Wi(h)&&(l>1||1===l&&29===r)&&(o=366));d=e/o,u=t/o;break;case 2:d=e/360,u=t/360;break;case 3:d=e/365,u=t/365;break;case 4:31===n&&(n=30),31===r&&(r=30),d=c+(30*a+n)/360,u=h+(30*l+r)/360}return u-d}function Zi(e,t){const o=12*(t.getFullYear()-e.getFullYear())+t.getMonth()-e.getMonth();return e.getDate()>t.getDate()?o-1:o}function ji(e,t){const o=e.getTime(),s=t.getTime();return Math.floor((s-o)/xi)}function Yi(e,t){const o=t.getFullYear()-e.getFullYear(),s=e.getMonth(),i=t.getMonth(),n=e.getDate(),r=t.getDate();return i>s||i===s&&r>=n?o:o-1}function Xi(e,t,o){return t>o?Xi(e,o,t):(e=Math.trunc(e),t=Math.trunc(t),o=Math.trunc(o),e>=t&&e<=o)}const Ki=Jt((function(e){return e=gt(e),new RegExp(`(?:^-?\\d+(?:${e}?\\d*(?:e(\\+|-)?\\d+)?)?|^-?${e}\\d+)(?!\\w|!)`)})),Ji=Jt((function(e){const t=gt(e.decimalSeparator),o="(?:\\s*"+`(?:\\d+(?:${gt(e.thousandsSeparator||"")}\\d{3,})*(?:${t}\\d*)?)`+"|"+`(?:${t}\\d+)`+")(?:e(?:\\+|-)?\\d+)?(?:\\s*%)?",s="(?:\\s*-)?",i="(?:\\s*[\\$€])?",n="^(?:(?:"+[s+i+o,s+o+i,i+s+o].join(")|(?:")+"))$";return new RegExp(n,"i")}));function Qi(e,t){return!!e&&Ji(t).test(e.trim())}const en=Jt((function(e){return new RegExp(`[$€${gt(e.thousandsSeparator||"")}]`,"g")}));function tn(e,t){e=e.replace(en(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 on(e,t,o){const s=[...e].sort(((e,t)=>e-t));let i=(s.length+(o?-1:1))*t;if(o||i--,Number.isInteger(i))return s[i];const n=Math.ceil(i),r=Math.floor(i);return s[n]*(i-r)+s[r]*(n-i)}const sn={NotAvailable:"#N/A",InvalidReference:"#REF",BadExpression:"#BAD_EXPR",CircularDependency:"#CYCLE",UnknownFunction:"#NAME?",DivisionByZero:"#DIV/0!",SpilledBlocked:"#SPILL!",GenericError:"#ERROR",NullError:"#NULL!"},nn=new Set(Object.values(sn));class rn{message;value;constructor(e=ui("Error"),t=sn.GenericError){this.message=e,this.value=t,this.message=e.toString()}}class an extends rn{constructor(e=ui("Invalid expression")){super(e,sn.BadExpression)}}class ln extends rn{constructor(e=ui("Circular reference")){super(e,sn.CircularDependency)}}class cn extends rn{constructor(e=ui("Invalid reference")){super(e,sn.InvalidReference)}}class hn extends rn{constructor(e=ui("Data not available")){super(e,sn.NotAvailable)}}class dn extends rn{constructor(e=ui("Unknown function")){super(e,sn.UnknownFunction)}}class un extends rn{constructor(e=ui("Spill range is not empty")){super(e,sn.SpilledBlocked)}}class gn extends rn{constructor(e=ui("Division by zero")){super(e,sn.DivisionByZero)}}const pn=["number","string","boolean","undefined"];function mn(e){if(void 0!==e)return E(e)?e[0][0]?.format:e.format}function fn(e){return"string"==typeof e&&nn.has(e)}function vn(e){return{value:sn.NotAvailable,message:ui("Did not find value '%s' in [[FUNCTION_NAME]] evaluation.",En(e))}}const bn=e=>ui("The function [[FUNCTION_NAME]] expects a number value, but '%s' is a string, and cannot be coerced to a number.",e);function Sn(e,t){const o=_n(e);switch(typeof o){case"number":return o;case"boolean":return o?1:0;case"string":if(Qi(o,t)||""===o)return tn(o,t);const e=Vi(o,t);if(e)return e.value;throw new rn(bn(o));default:return 0}}function Cn(e,t){try{return Sn(e,t)}catch(e){return}}function yn(e,t){return Kn(e).map((e=>e.map((e=>{if("number"!=typeof e.value){let o="";throw"object"==typeof e?o=ui("Function [[FUNCTION_NAME]] expects number values for %s, but got an empty value.",t):"string"==typeof e?o=ui("Function [[FUNCTION_NAME]] expects number values for %s, but got a string.",t):"boolean"==typeof e&&(o=ui("Function [[FUNCTION_NAME]] expects number values for %s, but got a boolean.",t)),new rn(o)}return e.value}))))}function In(e,t){const o=_n(e);if(""===o)throw new rn(bn(o));return Sn(o,t)}function wn(e,t){return Math.trunc(Sn(e,t))}function xn(e,t){return Math.trunc(In(e,t))}function En(e){const t=_n(e);switch(typeof t){case"string":return t;case"number":return t.toString();case"boolean":return t?"TRUE":"FALSE";default:return""}}const Rn=Jt((function(e){return e.toLowerCase().normalize("NFD").replace(/[\u0300-\u036f]/g,"")})),Tn=e=>ui("The function [[FUNCTION_NAME]] expects a boolean value, but '%s' is a text, and cannot be coerced to a boolean.",e);function An(e){const t=_n(e);switch(typeof t){case"boolean":return t;case"string":if(t){const e=t.toUpperCase();if("TRUE"===e)return!0;if("FALSE"===e)return!1;throw new rn(Tn(t))}return!1;case"number":return!!t;default:return!1}}function Dn(e,t){return Ui(Sn(_n(e),t))}function _n(e){if("object"==typeof e&&null!==e&&"value"in e){if(fn(e.value))throw e;return e.value}if(fn(e))throw new rn("",e);return e}function Fn(e,t,o){for(const s of e)if(E(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 On(e,t){Fn(e,(e=>{if(fn(e.value))throw e;t(e)}),(e=>{if(fn(e?.value))throw e;t(e)}))}function Pn(e,t,o){Fn(e,(e=>{if("number"==typeof e?.value&&t(e),fn(e?.value))throw e}),(e=>{t({value:In(e,o),format:e?.format})}))}function Mn(e,t,o,s,i="rowFirst"){let n=s;for(const s of e)if(E(s)){const e=s.length,o=s[0].length;if("rowFirst"===i)for(let i=0;i<o;i++)for(let o=0;o<e;o++)n=t(n,s[o][i]);else for(let i=0;i<e;i++)for(let e=0;e<o;e++)n=t(n,s[i][e])}else n=o(n,s);return n}function Nn(e,t,o,s="rowFirst"){return Mn(e,t,t,o,s)}function kn(e,t,o,s){return Mn(e,((e,o)=>{const s=o?.value;if("number"==typeof s)return t(e,s);if(fn(s))throw o;return e}),((e,o)=>t(e,In(o,s))),o)}function Ln(e,t,o,s){return Mn(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,Sn(i,s));if(fn(i))throw o;return t(e,0)}return e}),((e,o)=>t(e,Sn(o,s))),o)}function Vn(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 Un(e,t){return 0===e.length?[]:Vn(e.length,e[0].length,((o,s)=>t(e[o][s])))}function Hn(e){return e.length?Vn(e[0].length,e.length,((t,o)=>e[o][t])):[]}function zn(e,t,o=void 0){let s,i=1,n=1,r=1/0,a=1/0;for(let e=0;e<t.length;e++){const l=t[e];if(E(l)&&(void 0===o||o[e])){const o=l.length,c=l[0].length;1!==o||1!==c?(s??=new Array(t.length),1!==o&&1!==c?(s[e]="matrix",i=Math.max(i,o),n=Math.max(n,c),r=Math.min(r,o),a=Math.min(a,c)):1!==o?(s[e]="horizontal",i=Math.max(i,o),r=Math.min(r,o)):1!==c&&(s[e]="vertical",n=Math.max(n,c),a=Math.min(a,c))):t[e]=l[0][0]}}if(1===i&&1===n)return e(...t);return Vn(i,n,((o,i)=>{if(o>r-1||i>a-1)return new hn(ui("Array arguments to [[FUNCTION_NAME]] are of different size."));const n=e(...(l=o,c=i,t.map(((e,t)=>{switch(s?.[t]){case"matrix":return e[l][c];case"horizontal":return e[l][0];case"vertical":return e[0][c];case void 0:return e}}))));var l,c;return E(n)?n[0][0]:n}))}function Bn(e,t){return function(e,t,o){for(const s of e)if(E(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(fn(o))throw e;return!0}),(e=>void 0===e||null===e.value||t(function(e){const t=_n(e);if(""===t)throw new rn(Tn(t));return An(t)}(e))))}function $n(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)),Qi(s,t)||ki(s,t)?s=Sn(s,t):"TRUE"!==s&&"FALSE"!==s||(s=An(s)),{operator:o,operand:s}}const Gn=Jt((function(e){if("*"===e)return/.+/;let t="",o="";for(const s of e)"?"===s&&"~"!==o?t+=".":"*"===s&&"~"!==o?t+=".*":("*"!==s&&"?"!==s||(t=t.slice(0,-1)),["^",".","[","]","$","(",")","*","+","?","|","{","}","\\"].includes(s)&&(t+="\\"),t+=s),o=s;return new RegExp("^"+t+"$","i")}));function Wn(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&&(Qi(e,o)||ki(e,o))?Sn(e,o)===i:e===i;if("<>"===s||"="===s){let t;return t=typeof e==typeof i&&("string"==typeof e&&"string"==typeof i?Gn(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 qn(e,t,o,s=!1){const i=e.length;if(i%2==1)throw new rn(ui("Function [[FUNCTION_NAME]] expects criteria_range and criterion to be in pairs."));const n=Kn(e[0]),r=n.length,a=n[0].length,l=[];for(let t=0;t<i-1;t+=2){const i=Kn(e[t]);if(i.length!==r||i[0].length!==a)throw new rn(ui("Function [[FUNCTION_NAME]] expects criteria_range to have the same dimension"));const n=$n(En(e[t+1]),o);s&&"string"==typeof n.operand&&(n.operand+="*"),l.push(n)}for(let s=0;s<r;s++)for(let n=0;n<a;n++){let r=!0;for(let t=0;t<i-1;t+=2){if(r=Wn(Kn(e[t])[s][n].value??void 0,l[t/2],o),!r)break}r&&t(s,n)}}function Zn(e,t,o,s,i,n){if(void 0===t||null===t.value)return-1;if(fn(t.value))throw t;const r=Yn(t.value),a=typeof r;let l,c,h,d,u,g,p=0,m=i-1;const f="desc"===s?t=>Yn(n(e,i-t-1)):t=>Yn(n(e,t));for(;m-p>=0;){for(h=Math.floor((p+m)/2),d=h,u=f(d),g=typeof u;p<d&&a!==g;)d--,u=f(d),g=typeof u;g===a&&null!=u?("strict"===o&&u===r?(l=u,c=d):"nextSmaller"===o&&u<=r?(null==l||l<u||l===u&&c<d)&&(l=u,c=d):"nextGreater"===o&&u>=r&&(void 0===l||l>u||l===u&&c<d)&&(l=u,c=d),u>r||"strict"===o&&u===r?m=d-1:p=h+1):p=h+1}return void 0===c?-1:"desc"===s?i-c-1:c}function jn(e,t,o,s,i,n,r=!1){if(void 0===t||null===t.value)return-1;if(fn(t.value))throw t;const a=Yn(t.value),l=r?(e,t)=>Yn(i(e,s-t-1)):(e,t)=>Yn(i(e,t)),c="wildcard"!==o||"string"!=typeof a||!(a.includes("*")||a.includes("?"));if(n&&c){const t=r?"reverseSearch":"forwardSearch";let i=n[t].get(e);if(void 0===i){i=new Map;for(let t=0;t<s;t++){const o=l(e,t)??null;i.has(o)||i.set(o,t)}n[t].set(e,i)}if(i.has(a)){const e=i.get(a);return r?s-e-1:e}if("strict"===o)return-1}const h=function(e,t,o,s,i){let n=o=>i(e,o)===t;if("wildcard"===o&&"string"==typeof t&&(t.includes("*")||t.includes("?"))){const o=Gn(t);n=t=>{const s=i(e,t);return"string"==typeof s&&o.test(s)}}let r,a=-1;"nextSmaller"===o&&(n=o=>{const s=i(e,o);return(!r&&Xn(t,s)>=0||Xn(t,s)>=0&&Xn(s,r)>0)&&(r=s,a=o),s===t});"nextGreater"===o&&(n=o=>{const s=i(e,o);return(!r&&Xn(t,s)<=0||Xn(t,s)<=0&&Xn(s,r)<0)&&(r=s,a=o),s===t});for(let e=0;e<s;e++)if(n(e))return e;return a}(e,a,o,s,l);return r&&-1!==h?s-h-1:h}function Yn(e){return"string"==typeof e?Rn(e):e}function Xn(e,t){let o=pn.indexOf(typeof e)-pn.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 Kn(e){return void 0===e?[[]]:E(e)?e:[[e]]}function Jn(e,t){return Nn(e,((e,o)=>(e.push(t(o)),e)),[],"rowFirst")}function Qn(e){if(void 0===e)return!1;const{value:t}=e;return null!==t&&""!==t}const er=ui("[[FUNCTION_NAME]] has no valid input data.");function tr(e){return ui("[[FUNCTION_NAME]] expects the provided values of %(argName)s to be a non-empty matrix.",{argName:e})}function or(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 sr=new Set("$+-/():!^&~{}<>= ");function ir(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 sr.has(e.current)?{type:"CHAR",value:e.shift()}:null}function nr(e){return","===e.current?(e.shift(),{type:"THOUSANDS_SEPARATOR",value:","}):null}function rr(e){return"@"===e.current?(e.shift(),{type:"TEXT_PLACEHOLDER",value:"@"}):null}function ar(e){return"."===e.current?(e.shift(),{type:"DECIMAL_POINT",value:"."}):null}function lr(e){return"%"===e.current?(e.shift(),{type:"PERCENT",value:"%"}):null}function cr(e){if("0"===e.current||"#"===e.current){const t=e.current;return e.shift(),{type:"DIGIT",value:t}}return null}const hr=new Set("dmqyhsa");function dr(e){if(!hr.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 ur(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 gr=20,pr={};function mr(e){let t=pr[e];return void 0===t&&(t=function(e){const t=function(e){const t=new ao(e),o=[];let s=[];for(o.push(s);!t.isOver();){if(";"===t.current){s=[],o.push(s),t.shift();continue}const e=cr(t)||or(t)||ir(t)||nr(t)||ar(t)||lr(t)||dr(t)||rr(t)||ur(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=vr(t[0])||fr(t[0])||br(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=vr(t[1])||fr(t[1]);if(t[1]?.length&&!s)throw new Error("Invalid second format part of: "+e);const i=vr(t[2])||fr(t[2]);if(t[2]?.length&&!i)throw new Error("Invalid third format part of: "+e);const n=br(t[3]);if(t[3]?.length&&!n)throw new Error("Invalid fourth format part of: "+e);return{positive:o,negative:s,zero:i,text:n}}(e),pr[e]=t),t}function fr(e){if(!e||!function(e){return e.every((e=>"DIGIT"===e.type||"DECIMAL_POINT"===e.type||"THOUSANDS_SEPARATOR"===e.type||"PERCENT"===e.type||"STRING"===e.type||"CHAR"===e.type||"REPEATED_CHAR"===e.type))}(e))return;const t=[];let o,s=t,i=0,n=0,r=e.findLastIndex((e=>"DIGIT"===e.type)),a=!1,l=0;for(let c=0;c<e.length;c++){const h=e[c];switch(h.type){case"DIGIT":s===t?s.push(h):l<gr&&(s.push(h),l++);break;case"DECIMAL_POINT":if(s!==t)throw new Error("Multiple decimal points in a number format");o=[],s=o;break;case"REPEATED_CHAR":case"CHAR":case"STRING":s.push(h);break;case"PERCENT":i++,s.push(h);break;case"THOUSANDS_SEPARATOR":c-1===r?(n+=1,r++,s.push(h)):"DIGIT"===e[c+1]?.type&&"DIGIT"===e[c-1]?.type?(s===t&&(a=!0),s.push(h)):s.push({type:"CHAR",value:","})}}return{type:"number",integerPart:t,decimalPart:o,percentSymbols:i,thousandsSeparator:a,magnitude:n}}function vr(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 br(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 Sr(e){return[Cr(e.positive),Cr(e.negative),Cr(e.zero),Cr(e.text)].filter(Mt).join(";")}function Cr(e){if(!e)return;let t="";const o="number"!==e.type?e.tokens:function(e){const t=[...e.integerPart];e.decimalPart&&(t.push({type:"DECIMAL_POINT",value:"."}),t.push(...e.decimalPart));return t}(e);for(const e of o)switch(e.type){case"STRING":t+=`[$${e.value}]`;break;case"CHAR":t+=(s=e.value,sr.has(s)?e.value:`\\${e.value}`);break;case"REPEATED_CHAR":t+="*"+e.value;break;case"DATE_PART":t+="MM"===e.value?"mm":e.value;break;default:t+=e.value}var s;return t}const yr=11,Ir="REPEATED_CHAR_PLACEHOLDER_",wr={0:ui("January"),1:ui("February"),2:ui("March"),3:ui("April"),4:ui("May"),5:ui("June"),6:ui("July"),7:ui("August"),8:ui("September"),9:ui("October"),10:ui("November"),11:ui("December")},xr={0:ui("Sunday"),1:ui("Monday"),2:ui("Tuesday"),3:ui("Wednesday"),4:ui("Thursday"),5:ui("Friday"),6:ui("Saturday")};function Er(e,t,o,s=!1){return s?Wr({value:e,format:t},o):Rr(e,{format:t,locale:o})}function Rr(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=mr(t),i=o.text||o.positive;return i&&"text"===i.type?Tr(e,i,s):e}case"number":t||(t=Lr(e));const i=mr(t);if("text"===i.positive.type)return Tr(e.toString(),i.positive,s);let n=i.positive;if(e<0&&i.negative?(n=i.negative,e=-e):0===e&&i.zero&&(n=i.zero),"date"===n.type)return Ar(function(e,t){const o=Ui(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+=Nr(o,e.value,s);break;case"REPEATED_CHAR":i+=Ir+e.value;break;default:i+=e.value}return i}(e,n),s);const r=e<0,a=Ar(function(e,t,o){if(e===1/0)return"∞"+(t.percentSymbols?"%":"");const s=2*t.percentSymbols-3*t.magnitude;e*=10**s;let i=0;void 0!==t.decimalPart&&(i=t.decimalPart.filter((e=>"DIGIT"===e.type)).length);const{integerDigits:n,decimalDigits:r}=_r(Math.abs(e),i);let a=function(e,t,o){let s=t.integerPart;s.some((e=>"DIGIT"===e.type))||(s=[...s,{type:"DIGIT",value:"#"}]);"0"===e&&(e="");let i="";const n=s.findIndex((e=>"DIGIT"===e.type));let r=e.length-1;function a(t,s){if("0"===s&&(t=t||"0"),!t)return;const n=e.length-1-r;i=o&&n>0&&n%3==0?t+o+i:t+i}for(let t=s.length-1;t>=0;t--){const o=s[t];switch(o.type){case"DIGIT":if(a(e[r],o.value),r--,n===t)for(;r>=0;)a(e[r],"0"),r--;break;case"THOUSANDS_SEPARATOR":break;case"REPEATED_CHAR":i=Ir+o.value+i;break;default:i=o.value+i}}return i}(n,t,t.thousandsSeparator?o.thousandsSeparator:void 0);void 0!==t.decimalPart&&(a+=o.decimalSeparator+function(e,t){if(!t.decimalPart)return"";let o="",s=0;for(const i of t.decimalPart)switch(i.type){case"DIGIT":o+="#"===i.value?e[s]||"":e[s]||"0",s++;break;case"THOUSANDS_SEPARATOR":break;case"REPEATED_CHAR":o+=Ir+i.value;break;default:o+=i.value}return o}(r||"",t));return a}(Math.abs(e),n,o),s);return r?"-"+a:a;case"object":return""}}function Tr(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+=Ir+o.value}return Ar(s,o)}function Ar(e,t){const o=e.indexOf(Ir);if(-1===o)return e;const s=e.slice(0,o),i=e.slice(o+Ir.length+1),n=e[o+Ir.length];const{timesToRepeat:r,padding:a}=function(){if(!t)return{timesToRepeat:0,padding:""};const e=t.measureText(s+i),o=t.measureText(n),r=t.availableWidth-e;if(r<=0)return{timesToRepeat:0,padding:""};const a=Math.floor(r/o),l=r-a*o,c=t.measureText(" ");return{timesToRepeat:a,padding:" ".repeat(Math.floor(l/c))}}();return s+n.repeat(r)+a+i}const Dr=[];function _r(e,t=gr){const o=e.toString();if(o.includes("e"))return function(e,t=gr){let o=Dr[t];o||(o=new Intl.NumberFormat("en-US",{maximumFractionDigits:t,useGrouping:!1}),Dr[t]=o);const[s,i]=o.format(e).split(".");return{integerDigits:s,decimalDigits:i}}(e,t);if(Number.isInteger(e))return{integerDigits:o,decimalDigits:void 0};const s=o.indexOf(".");let i=o.substring(0,s),n=o.substring(s+1);if(0===t)return Number(n[0])>=5&&(i=(Number(i)+1).toString()),{integerDigits:i,decimalDigits:void 0};if(n.length>t){const{integerDigits:e,decimalDigits:o}=function(e,t){let o="0",s=e;const i=e.slice(0,t),n=t;if(Number(e[n])<5)return{integerDigits:o,decimalDigits:i};const r=i.match(Or)?.[0]||"",a=(Number(i)+1).toString(),l=i.slice(r.length),c=a.length>l.length;c&&!r?(o="1",s=void 0):s=c?r.slice(0,-1)+a:r+a;return{integerDigits:o,decimalDigits:s}}(n,t);n=o,"0"!==e&&(i=(Number(i)+Number(e)).toString())}return{integerDigits:i,decimalDigits:Fr(n||"")}}function Fr(e){let t=e.length-1;for(;t>=0&&"0"===e[t];)t--;return e.slice(0,t+1)||void 0}const Or=/^0+/;function Pr(e,t){const{integerDigits:o,decimalDigits:s}=_r(e,20);return s?o+t+s:o}const Mr=Jt((function(e){if(!e)return!1;try{return"date"===mr(e).positive.type}catch(e){return!1}}));function Nr(e,t,o){switch(t){case"d":return e.getDate();case"dd":return e.getDate().toString().padStart(2,"0");case"ddd":return xr[e.getDay()].slice(0,3);case"dddd":return xr[e.getDay()].toString();case"m":return e.getMonth()+1;case"mm":return String(e.getMonth()+1).padStart(2,"0");case"mmm":return wr[e.getMonth()].slice(0,3);case"mmmm":return wr[e.getMonth()].toString();case"mmmmm":return wr[e.getMonth()].slice(0,1);case"qq":return ui("Q%(quarter)s",{quarter:e.getQuarter()}).toString();case"qqqq":return ui("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()-wi.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 kr=Jt((function(e){return new RegExp(`[0-9]+${gt(e.decimalSeparator)}[0-9]`)}));function Lr(e){let{integerDigits:t,decimalDigits:o}=_r(e);if(!o)return"0";const s=t.replace("-","").length;if(s+2>yr)return"0";const i=yr-s-1;return({decimalDigits:o}=_r(e,Math.min(i,o.length))),o?"0."+"0".repeat(o.length):"0"}function Vr(e,t){if(!ki(e,t))return;return Vi(e,t).format}function Ur(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 Hr(e){const t=e.decimalPlaces??2,o=e.position??"before",s=e.code??"",i=e.symbol??"",n="#,##0"+(t?"."+"0".repeat(t):"");let r=`${s} ${i}`.trim();return"after"===o&&s&&(r=" "+r),function(e,t,o){const s=`[$${e}]`;return"before"===t?s+o:o+s}(r,o,n)}function zr(e){const t=e.decimalPlaces??2,o=e.position??"before",s=e.code??"",i=e.symbol??"",n="#,##0"+(t?"."+"0".repeat(t):"");let r=`${s} ${i}`.trim();"after"===o&&s&&(r=" "+r);return[Br(r,o,` ${n} `),Br(r,o,`(${n})`),Br(r,o," - ")].join(";")}function Br(e,t,o){const s=`[$${e}]`;return"before"===t?s+"* "+o:o+"* "+s}function $r(e){const t=mr(e);return Sr({positive:Gr(t.positive),negative:t.negative?Gr(t.negative):void 0,zero:t.zero?Gr(t.zero):void 0,text:t.text})}function Gr(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 Wr({value:e,format:t},o){const s=Cn(e,o);if(void 0===s)return"";let i=t;if(Math.abs(s)<1e3){i=!t&&s%1!=0?"0.####":t}else i=qr({value:e,format:t},void 0,o);return Rr(e,{format:i,locale:o})}function qr(e,t,o){let s=0;try{s=Math.abs(Sn(e?.value,o))}catch(e){return""}const i=e?.format;if(void 0!==t){const e=t?.value;switch(e){case"k":return Zr(i,1,"k");case"m":return Zr(i,2,"m");case"b":return Zr(i,3,"b");default:throw new rn(ui("The formatting unit should be 'k', 'm' or 'b'."))}}return s<1e5?Zr(i,0,""):s<1e8?Zr(i,1,"k"):s<1e11?Zr(i,2,"m"):Zr(i,3,"b")}function Zr(e,t,o,s){const i=mr(e||"#,##0");return Sr({positive:jr(i.positive,t,o),negative:i.negative?jr(i.negative,t,o):void 0,zero:i.zero?jr(i.zero,t,o):void 0,text:i.text})}function jr(e,t,o){if("number"!==e.type)return e;const s={type:"STRING",value:o};let i=[...e.integerPart];const n=i.findLastIndex((e=>"DIGIT"===e.type));if(-1===n)throw new Error("Cannot create a large number format from a format with no digit.");for(;"THOUSANDS_SEPARATOR"===i[n+1]?.type;)i=Qt(i,[n+1]);const r=i[n+1];i="STRING"===r?.type&&["m","k","b"].includes(r.value)?to(i,s,n+1):eo(i,[s],n+1),t>0&&(i=eo(i,Array(t).fill({type:"THOUSANDS_SEPARATOR",value:","}),n+1));const a=e.percentSymbols-i.filter((e=>"PERCENT"===e.type)).length;return i.push(...new Array(a).fill({type:"PERCENT",value:"%"})),{...e,integerPart:i,decimalPart:void 0,magnitude:t}}function Yr(e,t){const o=mr(e);return Sr(mr(Sr({positive:Xr(o.positive,t),negative:o.negative?Xr(o.negative,t):void 0,zero:o.zero?Xr(o.zero,t):void 0,text:o.text})))}function Xr(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=Ct(0,t).map((()=>({type:"DIGIT",value:"0"}))),n=s.findLastIndex((e=>"DIGIT"===e.type));s=-1===n?[...i,...s]:eo(s,i,n+1);return{...e,decimalPart:s,integerPart:o}}(e,t):function(e,t){let o=e.decimalPart;if(!o)return e;const s=[];let i=0;for(let e=o.length-1;e>=0&&!(i>=Math.abs(t));e--)"DIGIT"===o[e].type&&(i++,s.push(e));if(o=Qt(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 Kr(e){const t=mr(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 Jr(e){if(!e)return!1;try{return"text"===mr(e).positive.type}catch{return!1}}function Qr(e,t,o){return ta({value:Jr(t.format)&&null!==e.parsedValue?e.content:e.parsedValue,format:t.format,origin:o},t.locale)}function ea(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(e.includes("\n"))return e;if(Qi(e,w))return tn(e,w);const o=Vi(e,t);return o?o.value:wt(e)?"TRUE"===e.toUpperCase():e}function ta(e,t=w,o,s){const i=yi(e.value);if(!i){return na(oa(e,t,o),e.origin??s)}const n=ea(i.label,t);return na({...oa({value:n,format:e.format||("number"==typeof n?Vr(i.label,t)||Ur(i.label):void 0)},t,o),link:i},e.origin??s)}function oa(e,t,o){let{value:s,format:i,message:n}=e;i=o?.format||i;const a=Rr(s,{format:i,locale:t});return fn(s)?function(e,t){return{value:e,formattedValue:e,message:t,type:r.error,isAutoSummable:!1,defaultAlign:"center"}}(s,n):null===s?ia(i):Jr(i)?sa(En(s),i,a):"number"==typeof s?Mr(i||"")?function(e,t,o){return{value:e,format:t,formattedValue:o,type:r.number,isAutoSummable:!1,defaultAlign:"right"}}(s,i,a):function(e,t,o){return{value:e||0,format:t,formattedValue:o,type:r.number,isAutoSummable:!0,defaultAlign:"right"}}(s,i,a):"boolean"==typeof s?function(e,t,o){return{value:e,format:t,formattedValue:o,type:r.boolean,isAutoSummable:!1,defaultAlign:"center"}}(s,i,a):sa(s,i,a)}function sa(e,t,o){return{value:e,format:t,formattedValue:o,type:r.text,isAutoSummable:!0,defaultAlign:"left"}}const ia=Jt((function(e){return{value:null,format:e,formattedValue:"",type:r.empty,isAutoSummable:!0,defaultAlign:"left"}}));function na(e,t){return null===e.value||"origin"in e||(e.origin=t),e}function ra(e){const t=Ii.now();switch(e){case"today":return zi(t);case"yesterday":return zi(Ii.fromTimestamp(t.setDate(t.getDate()-1)));case"tomorrow":return zi(Ii.fromTimestamp(t.setDate(t.getDate()+1)));case"lastWeek":return zi(Ii.fromTimestamp(t.setDate(t.getDate()-7)));case"lastMonth":return zi(Ii.fromTimestamp(t.setMonth(t.getMonth()-1)));case"lastYear":return zi(Ii.fromTimestamp(t.setFullYear(t.getFullYear()-1)))}}function aa(e,t){return"dateValue"in e&&"exactDate"!==e.dateValue?[ra(e.dateValue)]:e.values.map((e=>Ni(e,t)))}function la(e,t){return e.map((e=>{if(e.startsWith("="))return e;const o=ea(e,t);return"number"==typeof o?Rr(o,{format:t.dateFormat,locale:t}):""}))}const ca=new WeakMap,ha=new WeakMap;function da(e,t){ca.has(t)||(ca.set(t,new Map),ha.set(t,0));const o=ca.get(t),s=pa(e);if(o.has(s)){const i=o.get(s);return t[i]=e,i}const i=ha.get(t)+1;return o.set(s,i),ha.set(t,i),t[i]=e,i}function ua(e){const t={};for(const o in e){const s=Fo(e[o].map(cs));for(const e of s)t[Go(e)]=Number(o)}return t}function*ga(e,t){for(const o in t){const s=Ho(o),i=t[o];for(let t=s.top;t<=s.bottom;t++)for(let o=s.left;o<=s.right;o++){const s={sheetId:e,col:o,row:t};yield[s,i]}}}function pa(e){if(null===e)return"null";if(void 0===e)return"undefined";if("object"!=typeof e)return String(e);if(Array.isArray(e)){const t=e.length;let o="[";for(let s=0;s<t;s++)s>0&&(o+=","),o+=pa(e[s]);return o+"]"}const t=Object.keys(e).sort();let o="{";for(const s of t)void 0!==e[s]&&(o+=`"${s}":${pa(e[s])},`);return o+="}",o}function ma(e){return 20+120*Math.exp(-.035*(e-1))}const fa=new RegExp(/\$?([A-Z]{1,3})\$?([0-9]{1,7})/,"i"),va=new RegExp(/^\$?([A-Z]{1,3})\$?([0-9]{1,7})$/,"i"),ba=new RegExp(/^\$?([A-Z]{1,3})+$/,"i"),Sa=new RegExp(/^\$?([0-9]{1,7})+$/,"i"),Ca=new RegExp(/^\s*('.+'!|[^']+!)?\$?([A-Z]{1,3})$/,"i"),ya=new RegExp(/^\s*('.+'!|[^']+!)?\$?([0-9]{1,7})$/,"i"),Ia=new RegExp(/^\s*('.+'!|[^']+!)?/.source+"("+[fa.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 wa(e){return ya.test(e)}function xa(e){return ba.test(e)}function Ea(e){return Sa.test(e)}function Ra(e){return va.test(e)}function Ta(e){if(!e.includes("!"))return{xc:e};const t=e.split("!"),o=t.pop();return{sheetName:mt(t.join("!"))||void 0,xc:o}}function Aa(e,t){return void 0!==e?`${vt(e)}!${t}`:t}function Da(e){const t=[];for(let o=0;o<e;o++){const e={cells:{}};t.push(e)}return t}function _a(e,t,o){return o.map((o=>o>=e?o+t:o))}function Fa(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(Mt)}function Oa(e,t="Sheet"){let o=1,s=`${t}${o}`;for(;e.includes(s);)s=`${t}${o}`,o++;return s}function Pa(e,t){let o=1;const s=ui("Copy of %s",e);let i=s.toString();for(;t.includes(i);)i=`${s} (${o})`,o++;return i}function Ma(e,t){return void 0!==e&&void 0!==t&&mt(e.trim().toUpperCase())===mt(t.trim().toUpperCase())}function Na(e,t){const o=e.zone,s=function(e,t){const{left:o,top:s,bottom:i,right:n}=e;if(void 0!==n&&void 0!==i)return e;if(void 0===i&&void 0!==n)return{right:n,top:s,left:o,bottom:t.numberOfRows-1};if(void 0===n&&void 0!==i)return{bottom:i,left:o,top:s,right:t.numberOfCols-1};throw new Error("Bad zone format")}(o,t(e.sheetId));let i=e.parts;return 1===e.parts.length&&gs(s)>1?i=[e.parts[0],e.parts[0]]:2===e.parts.length&&1===gs(s)&&(i=[e.parts[0]]),{unboundedZone:o,zone:s,parts:i,prefixSheet:e.prefixSheet,invalidSheetName:e.invalidSheetName,sheetId:e.sheetId}}function ka(e,t){const o=e.xc,{xc:s,sheetName:i}=Ta(o),n=Uo(s),r=function(e,t){const o=e.split(":").map((e=>{const t=wa(e);return{colFixed:!t&&e.startsWith("$"),rowFixed:t?e.startsWith("$"):e.includes("$",1)}})),s=void 0===t.bottom,i=void 0===t.right;s&&(o[0].rowFixed=o[0].rowFixed||o[1].rowFixed,o[1].rowFixed=o[0].rowFixed||o[1].rowFixed);i&&(o[0].colFixed=o[0].colFixed||o[1].colFixed,o[1].colFixed=o[0].colFixed||o[1].colFixed);return o}(s,n);return Na({zone:n,parts:r,sheetId:e.sheetId,prefixSheet:Boolean(i),invalidSheetName:e.invalidSheetName},t)}function La(e){const t={left:-1,top:-1,right:-1,bottom:-1};return{sheetId:"",zone:t,unboundedZone:t,parts:[],invalidXc:e,prefixSheet:!1}}function Va(e){return us(e.unboundedZone)}function Ua(e){return ds(e.unboundedZone)}function Ha(e,t,o,s={useBoundedReference:!1,useFixedReference:!1}){if(e.invalidXc)return e.invalidXc;if(e.zone.bottom-e.zone.top<0||e.zone.right-e.zone.left<0)return sn.InvalidReference;if(e.zone.left<0||e.zone.top<0)return sn.InvalidReference;const i=e.sheetId!==t||e.invalidSheetName||e.prefixSheet;let n="";if(i&&(n=e.invalidSheetName?e.invalidSheetName:vt(o(e.sheetId))),i&&!n)return sn.InvalidReference;let r=Qa(e,0,s);return e.parts&&2===e.parts.length&&(e.zone.top!==e.zone.bottom||e.zone.left!==e.zone.right||e.parts[0].rowFixed||e.parts[0].colFixed||e.parts[1].rowFixed||e.parts[1].colFixed)&&(r+=":",r+=Qa(e,1,s)),`${i?n+"!":""}${r}`}function za(e,t,o){const s=o.sheetId===e?t:o.sheetId;return{...o,sheetId:s}}function Ba(e,t,o){if(!o)return;const s=e.getRangeFromSheetXC(t,o);return s.invalidSheetName||s.invalidXc?void 0:s}function $a(e){const t=[];for(const o of e)for(const e of is(o.zone))t.push({...e,sheetId:o.sheetId});return t}function Ga(e){const t={left:e.col,top:e.row,right:e.col,bottom:e.row};return{sheetId:e.sheetId,zone:t}}function Wa(e){return qa.get(e.type)?.(e)}const qa=new class extends n{add(e,t){return super.add(e,t),this}get(e){return this.content[e]}};function Za(e){const t="COL"===e.dimension?"left":"top",o="COL"===e.dimension?"right":"bottom",s="COL"===e.dimension?"columns":"rows",i=[...e.elements];i.sort(((e,t)=>t-e));const n=yt(i);return i=>{if(!Ma(i.sheetId,e.sheetId))return{changeType:"NONE"};let r=i,a="NONE";for(const e of n){const n=ro(e),l=no(e);if(i.zone[t]<=n&&n<=i.zone[o]){const e=Math.min(i.zone[o],l)-n+1;a="RESIZE",r=Ja(r,s,a,-e)}else if(i.zone[t]>=n&&i.zone[o]<=l)a="REMOVE",r=La(sn.InvalidReference);else if(i.zone[t]<=l&&i.zone[o]>=l){const e=l-i.zone[t]+1;a="RESIZE",r=Ja(r,s,a,-e),r=Ja(r,s,"MOVE",-(i.zone[t]-n))}else n<i.zone[t]&&(a="MOVE",r=Ja(r,s,a,-(l-n+1)))}return"NONE"!==a?{changeType:a,range:r}:{changeType:"NONE"}}}function ja(e){const t="COL"===e.dimension?"left":"top",o="COL"===e.dimension?"right":"bottom",s="COL"===e.dimension?"columns":"rows";return i=>{if(i.sheetId!==e.sheetId)return{changeType:"NONE"};if("after"===e.position){if(i.zone[t]<=e.base&&e.base<i.zone[o])return{changeType:"RESIZE",range:Ja(i,s,"RESIZE",e.quantity)};if(e.base<i.zone[t])return{changeType:"MOVE",range:Ja(i,s,"MOVE",e.quantity)}}else{if(i.zone[t]<e.base&&e.base<=i.zone[o])return{changeType:"RESIZE",range:Ja(i,s,"RESIZE",e.quantity)};if(e.base<=i.zone[t])return{changeType:"MOVE",range:Ja(i,s,"MOVE",e.quantity)}}return{changeType:"NONE"}}}function Ya(e){return t=>{if(t.sheetId!==e.sheetId&&t.invalidSheetName!==e.sheetName)return{changeType:"NONE"};const o=e.sheetName;return{changeType:"REMOVE",range:t={...La(sn.InvalidReference),invalidSheetName:o}}}}function Xa(e){return t=>{if(t.sheetId===e.sheetId)return{changeType:"CHANGE",range:t};if(e.newName&&t.invalidSheetName===e.newName){const o=void 0,s=e.sheetId;return{changeType:"CHANGE",range:{...t,sheetId:s,invalidSheetName:o}}}if(e.oldName&&t.invalidSheetName===e.oldName){const o=void 0,s=e.sheetId;return{changeType:"CHANGE",range:{...t,sheetId:s,invalidSheetName:o}}}return{changeType:"NONE"}}}function Ka(e){const t=e.target[0];return o=>{if(o.sheetId!==e.sheetId||!ts(o.zone,t))return{changeType:"NONE"};const s=e.targetSheetId,i=Ja(o,"both","MOVE",[e.col-t.left,e.row-t.top]),n=e.sheetId!==s||i.prefixSheet;return{changeType:"MOVE",range:{...i,sheetId:s,prefixSheet:n}}}}function Ja(e,t,o,s){return{...e,unboundedZone:as(e.unboundedZone,t,o,s),zone:as(e.zone,t,o,s)}}function Qa(e,t,o={useBoundedReference:!1,useFixedReference:!1}){const s=e.parts[t]?.colFixed||o.useFixedReference?"$":"",i=So(0===t?e.zone.left:e.zone.right),n=e.parts[t]?.rowFixed||o.useFixedReference?"$":"",r=String(0===t?e.zone.top+1:e.zone.bottom+1);let a="";return a=us(e.unboundedZone)&&!o.useBoundedReference?0===t&&e.unboundedZone.hasHeader?s+i+n+r:s+i:ds(e.unboundedZone)&&!o.useBoundedReference?0===t&&e.unboundedZone.hasHeader?s+i+n+r:n+r:s+i+n+r,a}function el(e,t,o){const s=[];return t.forEach((t=>{const i=function(e,t){e=e.toLocaleLowerCase();let o=0,s=0;const i=(t=t.toLocaleLowerCase()).length;let n=0;for(let r=0;r<i;r++)t[r]===e[n]?(n++,s+=100+s-r/200):s=0,o+=s;return n===e.length?o:0}(e,o(t));i>0&&s.push({score:i,elem:t})})),s.sort(((e,t)=>t.score-e.score)),s.map((e=>e.elem))}function tl(e,t=1){return t*(e+Te)-Te}function ol(e,t,o,s){const i=gl(e,t,o,"wrap"===o?.wrapping?s-2*Te:void 0).length;return tl(dl(o),i)+2*Ae}function sl(e,t=!1,o=!1){return`${o?"italic":""} ${t?"bold":""} ${e}px ${Le}`}qa.add("REMOVE_COLUMNS_ROWS",(e=>({applyChange:Za(e),sheetId:e.sheetId,sheetName:{old:e.sheetName,current:e.sheetName}}))).add("ADD_COLUMNS_ROWS",(e=>({applyChange:ja(e),sheetId:e.sheetId,sheetName:{old:e.sheetName,current:e.sheetName}}))).add("DELETE_SHEET",(e=>({applyChange:Ya(e),sheetId:e.sheetId,sheetName:{old:e.sheetName,current:e.sheetName}}))).add("RENAME_SHEET",(e=>({applyChange:Xa(e),sheetId:e.sheetId,sheetName:{old:e.oldName,current:e.newName}}))).add("MOVE_RANGES",(e=>({applyChange:Ka(e),sheetId:e.sheetId,sheetName:{old:e.sheetName,current:e.sheetName}})));const il={};function nl(e,t,o,s="pt"){return rl(e,t,hl(o,s))}function rl(e,t,o){if(il[o]||(il[o]={}),void 0===il[o][t]){const s=e.font;e.font=o,il[o][t]=e.measureText(t).width,e.font=s}return il[o][t]}const al={};function ll(e,t,o,s="pt"){const i=hl(o,s);e.save(),e.font=i;const n=function(e,t){const o=e.font;al[o]||(al[o]={});if(void 0===al[o][t]){const s=e.measureText(t),i=s.width,n=s.fontBoundingBoxAscent+s.fontBoundingBoxDescent;al[o][t]={width:i,height:n}}return al[o][t]}(e,t);return e.restore(),n}function cl(e){return Math.round(96*e/72)}function hl(e,t="pt"){return`${e.italic?"italic ":""}${e.bold?"bold":Ne} ${("pt"===t?dl(e):e.fontSize)??ke}px ${Le}`}function dl(e){return cl(e?.fontSize||ke)}function ul(e,t,o,s){if(nl(e,t,s)<=o)return[t];const i=[];let n="";for(const r of t){nl(e,n+r,s)>o?(i.push(n),n=r):n+=r}return i.push(n),i}function gl(e,t,o,s){o||(o={}),Rt(t)&&(t=Dt(t).label);const i=[],n=t.includes(ot)?t.split(ot):[t];for(const t of n){const n=t.includes(" ")?t.split(" "):[t];if(!s){i.push(t);continue}let r="",a=s;for(const t of n){const n=ul(e,t,s,o),l=n.pop(),c=nl(e,l,o);if(n.length)""!==r&&(i.push(r),r="",a=s),n.forEach((e=>{i.push(e)})),r=l,a=s-c;else{const t=""===r?l:" "+l,n=nl(e,t,o);n<=a?(r+=t,a-=n):(i.push(r),r=l,a=s-c)}}""!==r&&i.push(r)}return i}function pl(e){return e?e.toLowerCase():""}const ml=/([0-9\.]*)px/;function fl(e,t,o){let s=rl(e,t,e.font);if(s<=o)return t;const i=rl(e,"…",e.font);if(s<=i)return t;let n=t.length;for(;s>=o-i&&n-- >0;)s=rl(e,t=t.substring(0,n),e.font);return t+"…"}function vl(e,t,o,s=!1,i=!1,n=function(e){return Number(e.match(ml)?.[1])}(e.font)/10){if(e.fillText(t,o.x,o.y),!s&&!i)return;const r=e.measureText(t),a=r.width,l=r.actualBoundingBoxAscent+r.actualBoundingBoxDescent,c=r.fontBoundingBoxAscent+r.fontBoundingBoxDescent;let{x:h,y:d}=o,u=d,g=d;switch(e.textAlign){case"center":h-=a/2;break;case"right":h-=a}switch(e.textBaseline){case"top":g+=c-2*n,u+=c/2-n;break;case"middle":g+=c/2-n;break;case"alphabetic":g+=2*n,u-=3*n;break;case"bottom":g=d,u-=l/2-n/2}s&&(e.lineWidth=n,e.strokeStyle=e.fillStyle,e.beginPath(),e.moveTo(h,g),e.lineTo(h+a,g),e.stroke()),i&&(e.lineWidth=n,e.strokeStyle=e.fillStyle,e.beginPath(),e.moveTo(h,u),e.lineTo(h+a,u),e.stroke())}function bl(e,t,o,s,i="pt"){if(nl(e,o,s,i)<=t)return o;const n=nl(e,"...",s,i);if(n>=t)return"";let r,a=1,l=o.length;for(;a<=l;){const c=Math.floor((a+l)/2);r=nl(e,o.slice(0,c),s,i),r+n>t?l=c-1:a=c+1}const c=o.slice(0,Math.max(0,a-1));return c?c+"...":""}class Sl{smallUuid(){return window.crypto?"10000000-1000".replace(/[01]/g,(e=>{const t=Number(e);return(t^crypto.getRandomValues(new Uint8Array(1))[0]&15>>t/4).toString(16)})):"xxxxxxxx-xxxx".replace(/[xy]/g,(function(e){const t=16*Math.random()|0;return("x"===e?t:3&t|8).toString(16)}))}uuidv4(){return window.crypto?"10000000-1000-4000-8000-100000000000".replace(/[018]/g,(e=>{const t=Number(e);return(t^crypto.getRandomValues(new Uint8Array(1))[0]&15>>t/4).toString(16)})):"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,(function(e){const t=16*Math.random()|0;return("x"===e?t:3&t|8).toString(16)}))}}class Cl{getters;dispatch;constructor(e,t){this.getters=e,this.dispatch=t}copy(e,t,o="copyPaste"){}paste(e,t,o){}isPasteAllowed(e,t,o,s){return"Success"}isCutAllowed(e){return"Success"}getPasteTarget(e,t,o,s){return{zones:[],sheetId:e}}convertTextToClipboardData(e){}}class yl extends Cl{copy(e,t,o="copyPaste"){}pasteFromCopy(e,t,o,s){if(1===t.length)for(const i of Cs(t,o))this.pasteZone(e,i.left,i.top,o,s);else for(const i of Fo(t))for(let t=i.left;t<=i.right;t++)for(let n=i.top;n<=i.bottom;n++)this.pasteZone(e,t,n,o,s)}pasteZone(e,t,o,s,i){}}class Il extends Cl{copy(e){}}const wl=["%"],xl="+,-,*,/,:,=,<>,>=,>,<=,<,^,&".split(",").concat(wl);function El(e,t=w){e=Xt(e);const o=new ao(e),s=[],i=Zt.test(e)?Ll:Vl;for(;!o.isOver();){let e=Ul(o)||i(o)||Dl(o,t)||Al(o)||_l(o)||Pl(o)||Rl(o)||Hl(o)||Ol(o,t)||kl(o);e||(e={type:"UNKNOWN",value:o.shift()}),s.push(e)}return s}function Rl(e){return"?"===e.current?(e.shift(),{type:"DEBUGGER",value:"?"}):null}const Tl={"(":{type:"LEFT_PAREN",value:"("},")":{type:"RIGHT_PAREN",value:")"}};function Al(e){if("("===e.current||")"===e.current){const t=e.shift();return Tl[t]}return null}function Dl(e,t){if(e.current===t.formulaArgSeparator){return{type:"ARG_SEPARATOR",value:e.shift()}}return null}function _l(e){for(const t of xl)if(e.currentStartsWith(t))return e.advanceBy(t.length),{type:"OPERATOR",value:t};return null}const Fl=new Set("0123456789");function Ol(e,t){if(!Fl.has(e.current)&&e.current!==t.decimalSeparator)return null;const o=e.remaining().match(Ki(t.decimalSeparator));return o?(e.advanceBy(o[0].length),{type:"NUMBER",value:o[0]}):null}function Pl(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 Ml=/\p{L}|\p{N}|_|\.|!|\$/u,Nl=new Set("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789_.!$");function kl(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&&(Nl.has(e.current)||e.current.match(Ml));)t+=e.shift();if(t.length){const e=t;return Ia.test(e)?{type:"REFERENCE",value:e}:{type:"SYMBOL",value:e}}return null}function Ll(e){let t="";for(;" "===e.current||e.current&&e.current.match(Zt);)t+=e.shift();return t?{type:"SPACE",value:t}:null}function Vl(e){let t="";for(;" "===e.current;)t+=e.shift();return t?{type:"SPACE",value:t}:null}function Ul(e){let t=0;for(;e.current===ot;)t++,e.shift();return t?{type:"SPACE",value:ot.repeat(t)}:null}function Hl(e){return e.currentStartsWith(sn.InvalidReference)?(e.advanceBy(sn.InvalidReference.length),{type:"INVALID_REFERENCE",value:sn.InvalidReference}):null}function zl(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{Rr(1,{locale:e,format:"#,##0.00"}),Rr(1,{locale:e,format:e.dateFormat}),Rr(1,{locale:e,format:e.timeFormat})}catch{return!1}return!0}function Bl(e,t){return uo(e)?ql(e,t):Yl(e,t)}function $l(e,t){return uo(e)?ql(e,t):function(e,t){if(ki(e,t)){const o=Sn(e,t);let s=w.dateFormat;return Number.isInteger(o)||(s+=" "+w.timeFormat),Rr(o,{locale:w,format:s})}return Yl(e,t)}(e,t)}function Gl(e,t){return e.startsWith("=")?Zl(e,t):function(e,t){if(ki(e,w)){const o=Sn(e,w);let s=t.dateFormat;return Number.isInteger(o)||(s+=" "+t.timeFormat),Rr(o,{locale:t,format:s})}return function(e,t){if("."===t.decimalSeparator||!Qi(e,w))return e;const o=kr(w);return e.replace(o,(e=>e.replace(".",t.decimalSeparator)))}(e,t)}(e,t)}function Wl(e,t){return uo(e)?ql(e,t):Yl(e,t)}function ql(e,t){return jl(e.startsWith("+")?"="+e.slice(1):e,t,w)}function Zl(e,t){return jl(e,w,t)}function jl(e,t,o){if(t.formulaArgSeparator===o.formulaArgSeparator&&t.decimalSeparator===o.decimalSeparator)return e;const s=El(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 Yl(e,t){return"."!==t.decimalSeparator&&Qi(e,t)?(t.thousandsSeparator&&(e=e.replaceAll(t.thousandsSeparator,"")),e.replace(t.decimalSeparator,".")):e}function Xl(e,t){return Ql(e,(e=>$l(e,t)))}function Kl(e,t){return Ql(e,(e=>Gl(e,t)))}function Jl(e,t){const o=pt(e);return o.criterion.values=o.criterion.values.map((e=>Gl(e,t))),o}function Ql(e,t){switch((e=pt(e)).type){case"CellIsRule":switch(e.operator){case"isBetween":case"isNotBetween":case"isEqual":case"isNotEqual":case"isGreaterThan":case"isGreaterOrEqualTo":case"isLessThan":case"isLessOrEqualTo":case"customFormula":return e.values=e.values.map((e=>t(e))),e;case"beginsWithText":case"containsText":case"endsWithText":case"notContainsText":case"isEmpty":case"isNotEmpty":return e}case"DataBarRule":return e;case"ColorScaleRule":return e.minimum=ec(e.minimum,t),e.maximum=ec(e.maximum,t),e.midpoint&&(e.midpoint=ec(e.midpoint,t)),e;case"IconSetRule":return e.lowerInflectionPoint.value=t(e.lowerInflectionPoint.value),e.upperInflectionPoint.value=t(e.upperInflectionPoint.value),e}}function ec(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 tc(e){return e.dateFormat+" "+e.timeFormat}function oc(e){let t=!1,o=!0;return Bn(e,(e=>(t=!0,o=o&&e,o))),{foundBoolean:t,result:o}}function sc(e){let t=!1,o=!1;return Bn(e,(e=>(t=!0,o=o||e,!o))),{foundBoolean:t,result:o}}function ic(e,t){return kn(e,((e,t)=>e+t),0,t)}function nc(e){return Nn(e,((e,t)=>Qn(t)?e.add(t?.value):e),new Set).size}function rc(e,t){if(!e)throw new rn(t)}function ac(e,t=ui("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.")){if(0===e)throw new gn(t)}function lc(e){return 1===e.length||1===e[0].length}function cc(...e){if(e.every(E)){const t=e[0].length,o=e[0][0].length;for(const s of e)if(s.length!==t||s[0].length!==o)return!1;return!0}return!e.some((e=>Array.isArray(e)&&(1!==e.length||1!==e[0].length)))}function hc(e){return e.length===e[0].length}const dc=e=>ui("The function [[FUNCTION_NAME]] expects a number value to be greater than or equal to 1, but receives %s.",e);function uc(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 gc(e){if(e.length<1||e[0].length<1)throw new Error("invertMatrix: an empty matrix cannot be inverted.");if(e.length!==e[0].length)throw new Error("invertMatrix: only square matrices are invertible");let t=1;const o=e.length,s=uc(o),i=e.map((e=>e.slice()));for(let e=0;e<o;e++){let n=i[e][e];if(0===n){for(let n=e+1;n<o;n++)if(0!==i[e][n]){pc(i,e,n),pc(s,e,n),t*=-1;break}if(n=i[e][e],0===n)return{determinant:0}}for(let t=0;t<o;t++)i[t][e]=i[t][e]/n,s[t][e]=s[t][e]/n;t*=n;for(let t=0;t<o;t++){if(t===e)continue;const n=i[e][t];for(let r=0;r<o;r++)i[r][t]-=n*i[r][e],s[r][t]-=n*s[r][e]}}return{inverted:s,determinant:t}}function pc(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 mc(e,t){if(e.length<1||t.length<1)throw new Error("multiplyMatrices: empty matrices cannot be multiplied.");if(e.length!==t[0].length)throw new Error("multiplyMatrices: incompatible matrices size.");const o=e[0].length,s=t.length,i=e.length,n=Array(s);for(let r=0;r<s;r++){n[r]=Array(o);for(let s=0;s<o;s++){let o=0;for(let n=0;n<i;n++)o+=e[n][s]*t[r][n];n[r][s]=o}}return n}function fc(e){if(!E(e))return e;if(!vc(e))throw new Error("The value should be a scalar or a 1x1 matrix");return e[0][0]}function vc(e){return 1===e.length&&1===e[0].length}function bc(e){return E(e)&&!vc(e)}function Sc(...e){const t=e[0].length;e.forEach(((e,o)=>rc(e.length===t,ui("[[FUNCTION_NAME]] has mismatched dimensions for argument %s (%s vs %s).",o.toString(),t.toString(),e.length.toString()))))}function Cc(e,t){let o=0;const s=kn(e,((e,t)=>(o+=1,e+t)),0,t);return ac(o),s/o}function yc(e,t){let o=0;for(const s of e)if(E(s))for(const e of s)for(const t of e)"number"==typeof t.value&&(o+=1);else{const e=s?.value;fn(e)||"string"==typeof e&&!Qi(e,t)&&!Vi(e,t)||(o+=1)}return o}function Ic(e){return Nn(e,((e,t)=>void 0!==t&&null!==t.value?e+1:e),0)}function wc(e,t){let o={value:-1/0};return Pn(e,(e=>{e.value>=o.value&&(o=e)}),t),o.value===-1/0?{value:0}:o}function xc(e,t){let o={value:1/0};return Pn(e,(e=>{e.value<=o.value&&(o=e)}),t),o.value===1/0?{value:0}:o}function Ec(e,t,o){const s=e[0].length?e:[Ct(1,t.flat().length+1)],i=s.length;let n=o[0].length?o:s;return n=n.length===i?Hn(n):n,{_X:s,_newX:n}}function Rc(e,t,o=!0,s=!1){const i=t.flat(),n=i.length;let{_X:r}=Ec(e,t,[[]]);r=r.length===n?Hn(r):r.slice(),Sc(r[0],i);const a=r.length,l=n-a-(o?1:0),c=[i],h=Hn(r.reverse()),d=[];for(let e=0;e<a;e++)if(d.push(0),o){for(const t of r[e])d[e]+=t;d[e]/=n}let u=0;if(o){for(const e of i)u+=e;u/=n}const g=h.map((e=>e.map(((e,t)=>e-d[t]))));o&&h.forEach((e=>e.push(1)));const p=Ac(h,c);if(o||p.push([0]),!s)return p;const m=mc(g,Hn(g)),{inverted:f}=gc(m);if(void 0===f)throw new rn(ui("Matrix is not invertible"));let v=0,b=0;for(let e=0;e<n;e++){const t=i[e]-u;let o=0;for(let t=0;t<a;t++){o+=g[e][t]*p[t][0]}const s=t-o;v+=s*s,b+=o*o}const S=Math.sqrt(v/l),C=b/(b+v),y=b/a/(v/l),I=[];for(let e=0;e<a;e++)I.push(S*Math.sqrt(f[e][e]));if(o){const e=mc(f,[d]),t=mc(Hn([d]),e);I.push(S*Math.sqrt(t[0][0]+1/i.length))}const w=[[p[0][0],I[0],C,y,b],[p[1][0],I[1],S,l,v]];for(let e=2;e<a;e++)w.push([p[e][0],I[e],"","",""]);return o?w.push([p[a][0],I[a],"","",""]):w.push([0,"","","",""]),w}function Tc(e,t,o,s){Sc(t,e),rc(o>=1,ui("Function [[FUNCTION_NAME]] A regression of order less than 1 cannot be possible."));const i=[e],n=t.map((e=>Ct(0,o).map((t=>Math.pow(e,o-t)))));s&&n.forEach((e=>e.push(1)));const r=Ac(n,i);return s||r.push([0]),r}function Ac(e,t){const o=mc(e,Hn(e)),{inverted:s}=gc(o);if(void 0===s)throw new rn(ui("Matrix is not invertible"));const i=mc(e,t);return Hn(mc(s,i))}function Dc(e,t,o){return e.reduce(((e,s,i)=>e+s*Math.pow(t,o-i)),0)}function _c(e){return e.map((e=>e.map((e=>Math.exp(e)))))}function Fc(e){return e.map((e=>e.map((e=>Math.log(e)))))}function Oc(e,t,o,s){const{_X:i,_newX:n}=Ec(t,e,o),r=Rc(i,e,s,!1),a=r.length-1,l=n.map((e=>{let t=0;for(let o=0;o<a;o++)t+=r[o][0]*e[a-o-1];return t+=r[a][0],[t]}));return l.length===o.length?l:Hn(l)}const Pc=new n;function Mc(e){return Pc.get(e)}const Nc={normalizeFunctionValue:e=>Sn(e,w),toValueAndFormat:(e,t)=>({value:Sn(e,w),format:"dd mmm yyyy"}),toFunctionValue(e){const t=Dn(e,w);return`DATE(${t.getFullYear()},${t.getMonth()+1},${t.getDate()})`}},kc={normalizeFunctionValue(e){const t=Sn(e,w);if(t<1||t>31)throw new rn(ui("%s is not a valid day of month (it should be a number between 1 and 31)",t));return t},toValueAndFormat:e=>({value:Sn(e,w),format:"0"}),toFunctionValue:e=>`${e}`},Lc={normalizeFunctionValue(e){const t=Sn(e,w);if(t<1||t>7)throw new rn(ui("%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||w).weekStart)%7;return{value:xr[o].toString(),format:"@"}},toFunctionValue:e=>`${e}`},Vc={normalizeFunctionValue(e){const t=Sn(e,w);if(t<0||t>53)throw new rn(ui("%s is not a valid week (it should be a number between 0 and 53)",t));return t},toValueAndFormat:e=>({value:Sn(e,w),format:"0"}),toFunctionValue:e=>`${e}`},Uc={normalizeFunctionValue(e){const t=Sn(e,w);if(t<1||t>12)throw new rn(ui("%s is not a valid month (it should be a number between 1 and 12)",t));return t},toValueAndFormat:e=>({value:wr[Sn(e,w)-1].toString(),format:"@"}),toFunctionValue:e=>`${e}`},Hc={normalizeFunctionValue:e=>Rr(Sn(e,w),{locale:w,format:"mm/yyyy"}),toValueAndFormat:e=>({value:Sn(e,w),format:"mmmm yyyy"}),toFunctionValue(e){const t=Dn(e,w);return`DATE(${t.getFullYear()},${t.getMonth()+1},1)`}},zc={normalizeFunctionValue(e){const t=Sn(e,w);if(t<1||t>4)throw new rn(ui("%s is not a valid quarter (it should be a number between 1 and 4)",t));return t},toValueAndFormat:e=>({value:ui("Q%(quarter_number)s",{quarter_number:e}),format:"@"}),toFunctionValue:e=>`${e}`},Bc={normalizeFunctionValue(e){const t=Sn(e,w);return t>3e3?Dn(t,w).getFullYear():t},toValueAndFormat:e=>({value:Sn(e,w),format:"0"}),toFunctionValue:e=>`${e}`},$c={normalizeFunctionValue(e){const t=Sn(e,w);if(t<0||t>23)throw new rn(ui("%s is not a valid hour (it should be a number between 0 and 23)",t));return t},toValueAndFormat:e=>({value:ui("%(hour_number)sh",{hour_number:e}),format:"@"}),toFunctionValue:e=>`${e}`},Gc={normalizeFunctionValue(e){const t=Sn(e,w);if(t<0||t>59)throw new rn(ui("%s is not a valid minute (it should be a number between 0 and 59)",t));return t},toValueAndFormat:e=>({value:ui("%(minute_number)s'",{minute_number:e}),format:"@"}),toFunctionValue:e=>`${e}`},Wc={normalizeFunctionValue(e){const t=Sn(e,w);if(t<0||t>59)throw new rn(ui("%s is not a valid second (it should be a number between 0 and 59)",t));return t},toValueAndFormat:e=>({value:ui("%(second_number)s''",{second_number:e}),format:"@"}),toFunctionValue:e=>`${e}`};function qc(e){return{normalizeFunctionValue:t=>null===t?null:e.normalizeFunctionValue(t),toValueAndFormat:(t,o)=>null===t?{value:ui("(Undefined)")}:e.toValueAndFormat(t,o),toFunctionValue:t=>null===t?"false":e.toFunctionValue(t)}}Pc.add("day",qc(Nc)).add("year",qc(Bc)).add("day_of_month",qc(kc)).add("iso_week_number",qc(Vc)).add("month_number",qc(Uc)).add("month",qc(Hc)).add("quarter_number",qc(zc)).add("day_of_week",qc(Lc)).add("hour_number",qc($c)).add("minute_number",qc(Gc)).add("second_number",qc(Wc));const Zc={count:ui("Count"),count_distinct:ui("Count Distinct"),bool_and:ui("Boolean And"),bool_or:ui("Boolean Or"),max:ui("Maximum"),min:ui("Minimum"),avg:ui("Average"),sum:ui("Sum")},jc=["max","min","avg","sum","count_distinct","count"],Yc={integer:jc,char:jc,datetime:jc,boolean:["count_distinct","count","bool_and","bool_or"]},Xc={};for(const e in Yc){Xc[e]={};for(const t of Yc[e])Xc[e][t]=Zc[t]}const Kc={count:e=>({value:Ic([e]),format:"0"}),count_distinct:e=>({value:nc([e]),format:"0"}),bool_and:e=>({value:oc([e]).result}),bool_or:e=>({value:sc([e]).result}),max:(e,t)=>wc([e],t),min:(e,t)=>xc([e],t),avg:(e,t)=>({value:Cc([e],t),format:mn(e)}),sum:(e,t)=>({value:ic([e],t),format:mn(e)})};function Jc(e){const t=Object.keys(e);if(!t.length)return 0;const o=t.map((e=>parseInt(e,10)));return Math.max(...o)}const Qc={year:ui("Year"),quarter:ui("Quarter & Year"),month:ui("Month & Year"),week:ui("Week & Year"),day:ui("Day"),quarter_number:ui("Quarter"),month_number:ui("Month"),iso_week_number:ui("Week"),day_of_month:ui("Day of Month"),day_of_week:ui("Day of Week"),hour_number:ui("Hour"),minute_number:ui("Minute"),second_number:ui("Second")},eh=["date","datetime"];function th(e){const[t,o]=e.split(":");return o?{fieldName:t,granularity:o}:{fieldName:t}}function oh(e){return eh.includes(e.type)}function sh(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}=th(e),n=lh(o,{type:i,granularity:t});s.push(`"${e}"`,n)}return s}function ih(e,t){let o=0,s=0;const i=t.columns.map((e=>e.nameWithGranularity)),n=t.rows.map((e=>e.nameWithGranularity));for(;void 0!==e[o]&&e[o]===n[s];)o++,s++;for(s=0;void 0!==e[o]&&e[o]===i[s];)o++,s++;return e.length===o}function nh(e,t){switch(t.type){case"HEADER":return`=PIVOT.HEADER(${sh(e,t.domain).join(",")})`;case"VALUE":return`=PIVOT.VALUE(${sh(e,t.domain,t.measure).join(",")})`;case"MEASURE_HEADER":return`=PIVOT.HEADER(${sh(e,[...t.domain,{field:"measure",value:t.measure,type:"char"}]).join(",")})`}return""}function rh(e,t){if(null===t||"null"===t)return null;const o="object"==typeof t?t.value:t;if(fn(o))return o;if("custom"===e.type)return _n(t)??null;const s="boolean"==typeof t?En(t).toLocaleLowerCase():En(t);if("null"===s)return null;if(!hh.contains(e.type))throw new rn(ui("Field %(field)s is not supported because of its type (%(type)s)",{field:e.displayName,type:e.type}));if("false"===s.toLowerCase())return!1;return hh.get(e.type)(s,e.granularity)}function ah(e,t){return Mc(t??"month").normalizeFunctionValue(e)}function lh(e,t){return null===e?'"null"':dh.contains(t.type)?dh.get(t.type)(e,t.granularity):`"${e}"`}function ch(e,t){return Mc(t??"month").toFunctionValue(e)}const hh=new n;hh.add("date",ah).add("datetime",ah).add("integer",(e=>Sn(e,w))).add("boolean",(e=>An(e))).add("char",(e=>En(e))).add("custom",(e=>e));const dh=new n;function uh(e){return e.displayName+(e.granularity?` (${Qc[e.granularity]})`:"")}function gh(e,t){try{if(!t.getMeasure(e.measure))return!1;const o=t.definition.columns;for(let s=0;s<e.domain.length;s++){if(o[s].nameWithGranularity!==e.domain[s].field)return!1;const i=t.getPossibleFieldValues(o[s]).map((e=>e.value));if(!(i.includes(e.domain[s].value)||null===e.domain[s].value&&i.includes("")))return!1}return!0}catch(e){return!1}}function ph(e,t){return ho(e,t.groups.map((e=>e.name)),{compute:(e,t)=>`${e}${t}`,start:2})}function mh(e,t){return ho(e,Object.values(t).map((e=>[e?.name,e?.string])).flat().filter(Mt),{compute:(e,t)=>`${e}${t}`,start:2})}function fh(e,t){const o={};for(const s of Object.values(e.customFields||{})){t[s.parentField]&&(o[s.name]={type:"custom",isCustomField:!0,name:s.name,string:s.name,customGroups:s.groups,parentField:s.parentField})}return o}function vh(e,t){t.groups=t.groups.filter((t=>!t.values.some((t=>e.includes(t)))))}function bh(e,t,o){const s=e.rows.some((e=>e.fieldName===t))?e.rows:e.columns,i=s.findIndex((e=>e.fieldName===t));return-1===i||s.some((e=>e.fieldName===o))||s.splice(i,0,{fieldName:o}),e}function Sh(e,t,o){return Object.values(e.customFields||{}).find((e=>e.parentField===t.name))||{parentField:t.name,name:mh(t.string,o),groups:[]}}dh.add("date",ch).add("datetime",ch).add("integer",(e=>`${Sn(e,w)}`)).add("boolean",(e=>An(e)?"TRUE":"FALSE")).add("char",(e=>`"${En(e).replace(/"/g,'\\"')}"`)).add("custom",(e=>"string"==typeof e?`"${e}"`:String(e)));class Ch extends yl{isCutAllowed(e){return 1!==e.zones.length?"WrongCutSelection":"Success"}copy(e,t,o="copyPaste"){const s=e.sheetId,{clippedZones:i,rowsIndexes:n,columnsIndexes:r}=e,a=[],l=1===n.length&&1===r.length;for(const t of n){const i=[];for(const a of r){const c={col:a,row:t,sheetId:s};let h=this.getters.getCell(c);const d=this.getters.getEvaluatedCell(c),u=this.getters.getPivotIdFromPosition(c),g=this.getters.getArrayFormulaSpreadingOn(c);if("shiftCells"!==o&&u&&g){const t=this.getters.getSpreadZone(g);if((!zt(g,c)||!l)&&t&&!e.zones.some((e=>ts(t,e)))){const e=this.getters.getPivotCellFromPosition(c),t=nh(this.getters.getPivotFormulaId(u),e);h={id:h?.id||"",style:h?.style,format:h?.format,content:t,isFormula:!1,parsedValue:d.value}}}else if("shiftCells"!==o&&g&&!zt(g,c)){const e=n.includes(g.row)&&r.includes(g.col)?"":Rr(d.value,{locale:this.getters.getLocale()});h={id:h?.id||"",style:h?.style,format:d.format,content:e,isFormula:!1,parsedValue:d.value}}i.push({content:h?.content??"",style:h?.style,format:h?.format,tokens:h?.isFormula?h.compiledFormula.tokens.map((({value:e,type:t})=>({value:e,type:t}))):[],border:this.getters.getCellBorder(c)||void 0,evaluatedCell:d,position:c})}a.push(i)}return{cells:a,zones:i,sheetId:e.sheetId}}isPasteAllowed(e,t,o,s){if(!o.cells)return"Success";if(s?.isCutOperation&&void 0!==s?.pasteOption)return"WrongPasteOption";if(t.length>1&&(o.cells.length>1||o.cells[0].length>1))return"WrongPasteSelection";const i=o.cells.length,n=o.cells[0].length;for(const s of Cs(t,o.cells))if(this.getters.doesIntersectMerge(e,s)&&(t.length>1||!this.getters.isSingleCellOrMerge(e,t[0])||i*n!=1))return"WillRemoveExistingMerge";return"Success"}paste(e,t,o){const s=e.zones,i=e.sheetId;o.isCutOperation?this.pasteFromCut(i,s,t,o):this.pasteFromCopy(i,s,t.cells,o)}getPasteTarget(e,t,o,s){const i=o.cells[0].length,n=o.cells.length;return s?.isCutOperation?{sheetId:e,zones:[{left:t[0].left,top:t[0].top,right:t[0].left+i-1,bottom:t[0].top+n-1}]}:1===i&&1===n?{zones:[],sheetId:e}:{sheetId:e,zones:Cs(t,o.cells)}}pasteFromCut(e,t,o,s){this.clearClippedZones(o);const i=t[0];this.pasteZone(e,i.left,i.top,o.cells,s)}clearClippedZones(e){this.dispatch("CLEAR_CELLS",{sheetId:e.sheetId,target:e.zones}),this.dispatch("CLEAR_FORMATTING",{sheetId:e.sheetId,target:e.zones})}pasteZone(e,t,o,s,i){for(const[n,r]of s.entries())for(const[s,a]of r.entries()){if(!a)continue;const r={col:t+s,row:o+n,sheetId:e};this.pasteCell(a,r,i)}}pasteCell(e,t,o){const{sheetId:s,col:i,row:n}=t,r=this.getters.getEvaluatedCell(t),a=e?.format||e.evaluatedCell.format;if("asValue"===o?.pasteOption)return void this.dispatch("UPDATE_CELL",{...t,content:e.evaluatedCell.value?.toString()||"",format:a});if("onlyFormat"===o?.pasteOption)return void this.dispatch("UPDATE_CELL",{...t,style:e?.style??null,format:a??r.format});let l=e?.content;e?.tokens&&e.tokens.length>0&&!o?.isCutOperation?l=this.getters.getTranslatedCellFormula(s,i-e.position.col,n-e.position.row,e.tokens):e?.tokens&&e.tokens.length>0&&(l=this.getters.getFormulaMovedInSheet(e.position.sheetId,s,e.tokens)),""!==l||e?.format||e?.style?this.dispatch("UPDATE_CELL",{...t,content:l,style:e?.style||null,format:e?.format}):r&&this.dispatch("CLEAR_CELL",t)}convertTextToClipboardData(e){const t=this.getters.getLocale(),o={cells:[]},s=[];let i=0;for(const[t,o]of e.replace(/\r/g,"").split("\n").entries())s.push(o.split("\t")),s[t].length>i&&(i=s[t].length);for(const e of s){const s=[];for(let o=0;o<i;o++){const i=Wl(e[o]||"",t);s.push({content:i,evaluatedCell:{formattedValue:i}})}o.cells.push(s)}return o}}const yh={figureHandlers:new n,cellHandlers:new n};function Ih(e,t){return"REMOVE_COLUMNS_ROWS"===t.type?jo(e,"COL"===t.dimension?"left":"top",t.elements):"ADD_COLUMNS_ROWS"===t.type?Wo(e,"COL"===t.dimension?"left":"top",t.base,t.position,t.quantity):e}function wh(e,t){const o="DELETE_SHEET"===t.type&&t.sheetId;if("sheetId"in t&&e._sheetId!==t.sheetId)return e;{const s=Ih(e._zone,t);if(s&&o!==e._sheetId)return{...e,_zone:s}}}yh.figureHandlers.add("chart",class extends Il{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.getChartFromFigureId(e.figureId);if(!i)throw new Error(`No chart for the given id: ${e.figureId}`);const n=i.copyInSheetId(t);return{figureId:e.figureId,copiedFigure:s,copiedChart:n}}getPasteTarget(e,t,o,s){return{zones:[],figureId:(new Sl).smallUuid(),sheetId:e}}paste(e,t,o){if(!e.figureId)return;const{zones:s,figureId:i}=e,n=e.sheetId,{width:r,height:a}=t.copiedFigure,l=t.copiedChart.copyInSheetId(n),c=this.getters.getMaxAnchorOffset(n,a,r);let{left:h,top:d}=s[0];const u={x:0,y:0};h>c.col&&(h=c.col,u.x=c.offset.x),d>c.row&&(d=c.row,u.y=c.offset.y),this.dispatch("CREATE_CHART",{figureId:i,chartId:(new Sl).smallUuid(),sheetId:n,definition:l.getDefinition(),col:h,row:d,offset:u,size:{height:a,width:r}}),o.isCutOperation&&this.dispatch("DELETE_FIGURE",{sheetId:t.copiedChart.sheetId,figureId:t.copiedFigure.id}),this.dispatch("SELECT_FIGURE",{figureId:i})}isPasteAllowed(e,t,o,s){return 0===t.length?"EmptyTarget":void 0!==s?.pasteOption?"WrongFigurePasteOption":"Success"}}).add("image",class extends Il{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=pt(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 Sl).smallUuid()}}paste(e,t,o){if(!e.figureId)return;const{zones:s,figureId:i}=e,n=this.getters.getActiveSheetId(),{width:r,height:a}=t.copiedFigure,l=pt(t.copiedImage),c=this.getters.getMaxAnchorOffset(n,a,r);let{left:h,top:d}=s[0];const u={x:0,y:0};h>c.col&&(h=c.col,u.x=c.offset.x),d>c.row&&(d=c.row,u.y=c.offset.y),this.dispatch("CREATE_IMAGE",{figureId:i,sheetId:n,col:h,row:d,offset:u,size:{height:a,width:r},definition:l}),o.isCutOperation&&this.dispatch("DELETE_FIGURE",{sheetId:t.sheetId,figureId:t.copiedFigure.id}),this.dispatch("SELECT_FIGURE",{figureId:i})}isPasteAllowed(e,t,o,s){return 0===t.length?"EmptyTarget":void 0!==s?.pasteOption?"WrongFigurePasteOption":"Success"}}).add("carousel",class extends Il{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("carousel"!==o.tag)return;const s={...o},i=this.getters.getCarousel(e.figureId),n={};for(const e of i.items)if("chart"===e.type){const o=this.getters.getChart(e.chartId);if(!o)throw new Error(`No chart for the given id: ${e.chartId}`);n[e.chartId]=o.copyInSheetId(t)}return{figureId:e.figureId,copiedFigure:s,copiedCarousel:i,copiedCharts:n,copiedSheetId:t}}getPasteTarget(e){return{zones:[],figureId:(new Sl).smallUuid(),sheetId:e}}paste(e,t,o){if(!e.figureId)return;const{zones:s,figureId:i}=e,n=e.sheetId,{width:r,height:a}=t.copiedFigure,l=this.getters.getMaxAnchorOffset(n,a,r);let{left:c,top:h}=s[0];const d={x:0,y:0};c>l.col&&(c=l.col,d.x=l.offset.x),h>l.row&&(h=l.row,d.y=l.offset.y),this.dispatch("CREATE_CAROUSEL",{figureId:i,sheetId:n,definition:{items:[]},col:c,row:h,offset:d,size:{height:a,width:r}});const u=new Sl,g=pt(t.copiedCarousel.items);for(const e of g){if("chart"!==e.type)continue;const o=t.copiedCharts[e.chartId],s=u.smallUuid(),r=o.copyInSheetId(n).getDefinition();this.dispatch("CREATE_CHART",{figureId:i,chartId:s,sheetId:n,definition:r}),e.chartId=s}this.dispatch("UPDATE_CAROUSEL",{sheetId:n,figureId:i,definition:{...t.copiedCarousel,items:g}}),o.isCutOperation&&this.dispatch("DELETE_FIGURE",{sheetId:t.copiedSheetId,figureId:t.copiedFigure.id}),this.dispatch("SELECT_FIGURE",{figureId:i})}isPasteAllowed(e,t,o,s){return 0===t.length?"EmptyTarget":void 0!==s?.pasteOption?"WrongFigurePasteOption":"Success"}}),yh.cellHandlers.add("dataValidation",class extends yl{uuidGenerator=new Sl;queuedChanges={};copy(e){const{rowsIndexes:t,columnsIndexes:o}=e,s=e.sheetId,i=[];for(const e of t){const t=[];for(const i of o){const o={sheetId:s,col:i,row:e},n=this.getters.getValidationRuleForCell(o);t.push({position:o,rule:n})}i.push(t)}return{dvRules:i}}paste(e,t,o){if(this.queuedChanges={},o.pasteOption)return;const s=e.zones,i=e.sheetId;o.isCutOperation?this.pasteFromCut(i,s,t):this.pasteFromCopy(i,s,t.dvRules),this.executeQueuedChanges()}pasteFromCut(e,t,o){const s=t[0];this.pasteZone(e,s.left,s.top,o.dvRules,{isCutOperation:!0})}pasteZone(e,t,o,s,i){for(const[n,r]of s.entries())for(const[s,a]of r.entries()){const r={col:t+s,row:o+n,sheetId:e};this.pasteDataValidation(a,r,i?.isCutOperation)}}pasteDataValidation(e,t,o){if(e){const s=cs(t),i=cs(e.position),n=e.rule;if(!n){const e=this.getters.getValidationRuleForCell(t);return void(e&&this.adaptDataValidationRule(t.sheetId,e,[],[s]))}const r=[];if(o&&r.push(i),e.position.sheetId===t.sheetId){const o=this.getDataValidationRuleToCopyTo(t.sheetId,n,!1);this.adaptDataValidationRule(e.position.sheetId,o,[s],r)}else{const o=this.getters.getValidationRuleForCell(e.position);o&&this.adaptDataValidationRule(e.position.sheetId,o,[],r);const i=this.getDataValidationRuleToCopyTo(t.sheetId,n);this.adaptDataValidationRule(t.sheetId,i,[s],[])}}}getDataValidationRuleToCopyTo(e,t,o=!0){let s=this.getters.getDataValidationRules(e).find((e=>zt(t.criterion,e.criterion)&&t.isBlocking===e.isBlocking));const i=this.queuedChanges[e];return!s&&i&&(s=i.find((e=>zt(t.criterion,e.rule.criterion)&&t.isBlocking===e.rule.isBlocking))?.rule),s||{...t,id:o?this.uuidGenerator.smallUuid():t.id,ranges:[]}}adaptDataValidationRule(e,t,o,s){this.queuedChanges[e]||(this.queuedChanges[e]=[]);const i=this.queuedChanges[e].find((e=>e.rule.id===t.id));i?(i.toAdd.push(...o),i.toRemove.push(...s)):this.queuedChanges[e].push({toAdd:o,toRemove:s,rule:t})}executeQueuedChanges(){for(const e in this.queuedChanges)for(const{toAdd:t,toRemove:o,rule:s}of this.queuedChanges[e]){const i=s.ranges.map((e=>e.zone)),n=Fo(i,o),r=Fo([...n,...t],[]);0!==r.length?this.dispatch("ADD_DATA_VALIDATION_RULE",{rule:{id:s.id,criterion:s.criterion,isBlocking:s.isBlocking},ranges:r.map((t=>this.getters.getRangeDataFromZone(e,t))),sheetId:e}):this.dispatch("REMOVE_DATA_VALIDATION_RULE",{sheetId:e,id:s.id})}}}).add("cell",Ch).add("sheet",class extends yl{isPasteAllowed(e,t,o,s){if(!("cells"in o))return"Success";const{xSplit:i,ySplit:n}=this.getters.getPaneDivisions(e);return ps(Cs(t,o.cells),i,n)?"FrozenPaneOverlap":"Success"}}).add("merge",class extends yl{copy(e){const t=this.getters.getActiveSheetId(),{rowsIndexes:o,columnsIndexes:s}=e,i=[];for(const e of o){const o=[];for(const i of s){const s={col:i,row:e,sheetId:t};o.push(this.getters.getMerge(s))}i.push(o)}return{merges:i,sheetId:t}}paste(e,t,o){if(o.isCutOperation){const e=t.merges.flat().filter(Mt);this.dispatch("REMOVE_MERGE",{sheetId:t.sheetId,target:e})}this.pasteFromCopy(e.sheetId,e.zones,t.merges,o)}pasteZone(e,t,o,s){for(const[i,n]of s.entries())for(const[s,r]of n.entries()){const n={col:t+s,row:o+i,sheetId:e};this.pasteMerge(r,n)}}pasteMerge(e,t){if(!e)return;if(this.getters.isInMerge(t))return;const{sheetId:o,col:s,row:i}=t;this.dispatch("ADD_MERGE",{sheetId:o,force:!0,target:[{left:s,top:i,right:s+e.right-e.left,bottom:i+e.bottom-e.top}]})}}).add("table",class extends yl{copy(e,t,o="copyPaste"){const s=e.sheetId,{rowsIndexes:i,columnsIndexes:n,zones:r}=e,a=new Set,l=[];for(const e of i){const c=[];l.push(c);for(const l of n){const n={col:l,row:e,sheetId:s},h=this.getters.getTable(n);if(!h){c.push({});continue}const d=this.getters.getCoreTable(n),u=d?.range.zone;let g;if(!a.has(h.id)&&d&&u&&r.some((e=>ts(u,e)))){a.add(h.id);let{numberOfRows:e}=os(u);for(let o=u.top;o<=u.bottom;o++)t||i.includes(o)||e--;const o=d.range,s=this.getters.extendRange(d.range,"ROW",o.zone.top+e-1-o.zone.bottom);g={range:this.getters.getRangeData(s),config:d.config,type:d.type}}"shiftCells"!==o&&c.push({table:g,style:this.getTableStyleToCopy(n),isWholeTableCopied:a.has(h.id)})}}return{tableCells:l,sheetId:e.sheetId}}getTableStyleToCopy(e){const t=this.getters.getCellTableStyle(e),o=this.getters.getCellStyle(e),s=this.getters.getCellTableBorder(e),i=this.getters.getCellBorder(e);return{style:{...t,...Wt(o)},border:{...s,...Wt(i)}}}paste(e,t,o){const s=e.zones,i=e.sheetId;o.isCutOperation?this.pasteFromCut(i,s,t,o):this.pasteFromCopy(i,s,t.tableCells,o)}pasteFromCut(e,t,o,s){for(const e of o.tableCells)for(const t of e)t.table&&this.dispatch("REMOVE_TABLE",{sheetId:o.sheetId,target:[this.getters.getRangeFromRangeData(t.table.range).zone]});const i=t[0];this.pasteZone(e,i.left,i.top,o.tableCells,s)}pasteZone(e,t,o,s,i){for(let n=0;n<s.length;n++){const r=s[n];for(let s=0;s<r.length;s++){const a=r[s];if(!a)continue;const l={col:t+s,row:o+n,sheetId:e};this.pasteTableCell(e,a,l,i)}}if(1===s.length)for(let i=0;i<s[0].length;i++)this.dispatch("AUTOFILL_TABLE_COLUMN",{col:t+i,row:o,sheetId:e})}pasteTableCell(e,t,o,s){if(t.table&&!s?.pasteOption){const{range:s}=t.table,i=os(this.getters.getRangeFromRangeData(s).zone),n={left:o.col,top:o.row,right:o.col+i.numberOfCols-1,bottom:o.row+i.numberOfRows-1};this.dispatch("CREATE_TABLE",{sheetId:o.sheetId,ranges:[this.getters.getRangeDataFromZone(e,n)],config:t.table.config,tableType:t.table.type})}this.getters.getCoreTable(o)||"asValue"===s?.pasteOption||(s?.pasteOption||t.isWholeTableCopied)&&"onlyFormat"!==s?.pasteOption||(t.style?.style&&this.dispatch("UPDATE_CELL",{...o,style:t.style.style}),t.style?.border&&this.dispatch("SET_BORDER",{...o,border:t.style.border}))}}).add("conditionalFormat",class extends yl{uuidGenerator=new Sl;queuedChanges={};copy(e){if(!e.zones.length)return;const{rowsIndexes:t,columnsIndexes:o}=e,s=e.sheetId,i=[];for(const e of t){const t=[];for(const i of o){const o=Array.from(this.getters.getRulesByCell(s,i,e));t.push({position:{col:i,row:e,sheetId:s},rules:o})}i.push(t)}return{cfRules:i}}paste(e,t,o){if(this.queuedChanges={},"asValue"===o.pasteOption)return;const s=e.zones,i=e.sheetId;o.isCutOperation?this.pasteFromCut(i,s,t):this.pasteFromCopy(i,s,t.cfRules,o),this.executeQueuedChanges()}pasteFromCut(e,t,o){const s=t[0];this.pasteZone(e,s.left,s.top,o.cfRules,{isCutOperation:!0})}pasteZone(e,t,o,s,i){for(const[n,r]of s.entries())for(const[s,a]of r.entries()){const r={col:t+s,row:o+n,sheetId:e};this.pasteCf(a,r,i?.isCutOperation)}}pasteCf(e,t,o){if(e?.rules&&e.rules.length>0){const s=cs(e.position),i=cs(t);for(const n of e.rules){const r=[];if(o&&r.push(s),e.position.sheetId===t.sheetId)this.adaptCFRules(e.position.sheetId,n,[i],r);else{this.adaptCFRules(e.position.sheetId,n,[],r);const o=this.getCFToCopyTo(t.sheetId,n);this.adaptCFRules(t.sheetId,o,[i],[])}}}}adaptCFRules(e,t,o,s){this.queuedChanges[e]||(this.queuedChanges[e]=[]);const i=this.queuedChanges[e].find((e=>e.cf.id===t.id));i?(i.toAdd.push(...o),i.toRemove.push(...s)):this.queuedChanges[e].push({toAdd:o,toRemove:s,cf:t})}executeQueuedChanges(){for(const e in this.queuedChanges)for(const{toAdd:t,toRemove:o,cf:s}of this.queuedChanges[e]){const i=this.getters.getAdaptedCfRanges(e,s,t,o);i&&(0!==i.length?this.dispatch("ADD_CONDITIONAL_FORMAT",{cf:{id:s.id,rule:s.rule,stopIfTrue:s.stopIfTrue},ranges:i,sheetId:e}):this.dispatch("REMOVE_CONDITIONAL_FORMAT",{id:s.id,sheetId:e}))}}getCFToCopyTo(e,t){let o=this.getters.getConditionalFormats(e).find((e=>e.stopIfTrue===t.stopIfTrue&&zt(e.rule,t.rule)));const s=this.queuedChanges[e];return!o&&s&&(o=s.find((e=>e.cf.stopIfTrue===t.stopIfTrue&&zt(e.cf.rule,t.rule)))?.cf),o||{...t,id:this.uuidGenerator.smallUuid(),ranges:[]}}}).add("references",class extends yl{copy(e){return{zones:e.clippedZones,sheetId:e.sheetId}}paste(e,t,o){if(o.isCutOperation){const o=e.zones[0];this.dispatch("MOVE_RANGES",{target:t.zones,sheetId:t.sheetId,sheetName:this.getters.getSheetName(t.sheetId),targetSheetId:e.sheetId,col:o.left,row:o.top})}}}).add("border",class extends yl{copy(e){const t=e.sheetId;if(0===e.zones.length)return;const o=[];let s=0;for(const i of yt(e.columnsIndexes)){let n=0;for(const r of yt(e.rowsIndexes)){const e={left:i[0],right:i[i.length-1],top:r[0],bottom:r[r.length-1]};o.push(...this.getters.getBorders(t,e).map((({zone:t,style:o})=>({zone:{left:t.left-e.left+s,right:t.right&&t.right-e.left+s,top:t.top-e.top+n,bottom:t.bottom&&t.bottom-e.top+n},style:o})))),n+=r.length}s+=i.length}return{borders:o,width:e.columnsIndexes.length,height:e.rowsIndexes.length}}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.pasteBorderZone(s,e,o,t.borders)}else for(const e of i)for(const o of Ss(e,t.width,t.height))this.pasteBorderZone(s,o.left,o.top,t.borders)}pasteBorderZone(e,t,o,s){for(const i of s){const s={left:i.zone.left+t,right:i.zone.right&&i.zone.right+t||i.zone.left+t,top:i.zone.top+o,bottom:i.zone.bottom&&i.zone.bottom+o||i.zone.top+o};for(const[t,o]of this.getOptimalBorderCommands(i.style))o&&this.dispatch("SET_ZONE_BORDERS",{sheetId:e,target:[s],border:{position:t,...o}})}}getOptimalBorderCommands(e){const t=zt(e.horizontal,e.vertical),o=zt(e.left,e.right,e.top,e.bottom);return t&&o&&zt(e.horizontal,e.left)?[["all",e.top]]:t&&o?[["hv",e.horizontal],["external",e.top]]:o?[["h",e.horizontal],["v",e.vertical],["external",e.top]]:t?[["hv",e.horizontal],["top",e.top],["bottom",e.bottom],["left",e.left],["right",e.right]]:[["h",e.horizontal],["v",e.vertical],["top",e.top],["bottom",e.bottom],["left",e.left],["right",e.right]]}});class xh{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 Eh extends xh{dependencies=new Map;factory=new Rh(this.get.bind(this));inject(e,t){if(this.dependencies.has(e)&&this.dependencies.get(e)!==t)throw new Error(`Store ${e.name} already has an instance`);this.dependencies.set(e,t)}get(e){return this.dependencies.has(e)||this.dependencies.set(e,this.instantiate(e)),this.dependencies.get(e)}instantiate(e,...t){return this.factory.build(e,...t)}resetStores(){this.dependencies.clear()}dispose(){for(const e of this.dependencies.values())"dispose"in e&&"function"==typeof e.dispose&&e.dispose()}}class Rh{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 Th{get;disposeCallbacks=[];constructor(e){this.get=e}onDispose(e){this.disposeCallbacks.push(e)}dispose(){this.disposeCallbacks.forEach((e=>e()))}}function Ah(){const e=t.useEnv();if(e.__spreadsheet_stores__ instanceof Eh)return e.__spreadsheet_stores__;const o=new Eh;return t.useSubEnv({__spreadsheet_stores__:o,getStore:e=>Oh(o.get(e),(()=>o.trigger("store-updated")))}),t.onWillUnmount((()=>o.dispose())),o}function Dh(e){const o=Ph(t.useEnv()),s=o.get(e);return Fh(o,s)}function _h(e,...o){const s=Ph(t.useEnv()),i=s.instantiate(e,...o);return t.onWillUnmount((()=>i.dispose())),Fh(s,i)}function Fh(e,o){const s=t.useComponent();return Oh(o,(()=>{"mounted"===t.status(s)&&e.trigger("store-updated")}))}function Oh(e,t){return new Proxy(e,{get(o,s,i){const n=o,r=Reflect.get(o,s,n);if(e.mutators?.includes(s)){const e=new Proxy(r,{apply(e,o,s){"noStateChange"!==Reflect.apply(e,n,s)&&t()}});return e}return r}})}function Ph(e){const t=e.__spreadsheet_stores__;if(!(t instanceof Eh))throw new Error("No store provider found. Did you forget to call useStoreProvider()?");return t}const Mh=(Nh="Model",class{constructor(e){throw new Error(`This is a abstract store for ${Nh}, it cannot be instantiated.\nDid you forget to inject your store instance?\n\nconst stores = useStoreProvider();\nstores.inject(MyMetaStore, storeInstance);\n`)}});var Nh;class kh{mutators=["register","unRegister","draw","startAnimation","stopAnimation"];renderers={};model;context=void 0;animationFrameId=null;registeredAnimations=new Set;constructor(e){this.model=e(Mh)}register(e){if(e.renderingLayers.length)for(const t of e.renderingLayers)this.renderers[t]||(this.renderers[t]=[]),this.renderers[t].push(e)}unRegister(e){for(const t of Object.keys(this.renderers))this.renderers[t]=this.renderers[t].filter((t=>t!==e))}drawLayer(e,t,o){const s=this.renderers[t];if(s)for(const i of s)e.ctx.save(),i.drawLayer(e,t,o),e.ctx.restore();return"noStateChange"}draw(e,t){if(!(e=e||this.context))throw new Error("Rendering context is not defined");this.context=e;for(const o of po())this.model.drawLayer(e,o),this.drawLayer(e,o,t);return"noStateChange"}startAnimation(e){if(this.registeredAnimations.add(e),!this.animationFrameId){const e=t=>{this.animationFrameId=requestAnimationFrame(e),this.draw(void 0,t)};this.animationFrameId=requestAnimationFrame(e)}return"noStateChange"}stopAnimation(e){return this.registeredAnimations.delete(e),0===this.registeredAnimations.size&&null!==this.animationFrameId&&(cancelAnimationFrame(this.animationFrameId),this.animationFrameId=null),"noStateChange"}dispose(){this.animationFrameId&&(cancelAnimationFrame(this.animationFrameId),this.animationFrameId=null)}}class Lh extends Th{model=this.get(Mh);getters=this.model.getters;renderer=this.get(kh);constructor(e){super(e),this.model.on("command-dispatched",this,this.handle),this.model.on("command-finalized",this,this.finalize),this.renderer.register(this),this.onDispose((()=>{this.model.off("command-dispatched",this),this.model.off("command-finalized",this),this.renderer.unRegister(this)}))}get renderingLayers(){return[]}handle(e){}finalize(){}drawLayer(e,t,o){}}const Vh={id:"void-composer",get editionMode(){return"inactive"},startEdition:()=>{throw new Error("No composer is registered")},stopEdition:()=>{throw new Error("No composer is registered")},setCurrentContent:()=>{throw new Error("No composer is registered")}};class Uh extends Lh{mutators=["focusComposer","focusActiveComposer"];activeComposer=Vh;_focusMode="inactive";get focusMode(){return"inactive"===this.activeComposer.editionMode?"inactive":this._focusMode}focusComposer(e,t){if(this.activeComposer=e,this.getters.isReadonly())return"noStateChange";this._focusMode=t.focusMode||"contentFocus","inactive"!==this._focusMode&&this.setComposerContent(t)}focusActiveComposer(e){if(this.getters.isReadonly())return"noStateChange";if(!this.activeComposer)throw new Error("No composer is registered");this._focusMode=e.focusMode||"contentFocus","inactive"!==this._focusMode&&this.setComposerContent(e)}setComposerContent({content:e,selection:t}){"inactive"===this.activeComposer.editionMode?this.activeComposer.startEdition(e,t):e&&this.activeComposer.setCurrentContent(e,t)}}const Hh={};let zh=0;function Bh(e,...t){const o="__sheet__"+zh++;return function(e,t){const o=document.createElement("style");o.textContent=function(e){const t=e.split(/(\{|\}|;)/).map((e=>e.trim())),o=[],s=[];let i=[];function n(e,t){const s=[];for(const i of o[e]){let r=t&&t+" "+i||i;r.includes("&")&&(r=i.replace(/&/g,t||"")),e<o.length-1&&(r=n(e+1,r)),s.push(r)}return s.join(", ")}function r(){i.length&&(s.push(n(0)+" {"),s.push(...i),s.push("}"),i=[])}for(;t.length;){const e=t.shift();"}"===e?(r(),o.pop()):("{"===t[0]&&(r(),o.push(e.split(/\s*,\s*/)),t.shift()),";"===t[0]&&i.push(" "+e+";"))}return s.join("\n")}(t),Hh[e]=o}(o,String.raw(e,...t)),function(e){const t=Hh[e];t.setAttribute("component",e),document.head.appendChild(t)}(o),o}function $h({strikethrough:e,underline:t}){return e||t?`${e?"line-through":""} ${t?"underline":""}`:"none"}function Gh(e){const t=Wh(e);return e?(e.fillColor&&(t.background=e.fillColor),t):t}function Wh(e){const t={};if(!e)return t;if(e.bold&&(t["font-weight"]="bold"),e.italic&&(t["font-style"]="italic"),e.fontSize&&(t["font-size"]=`${e.fontSize}px`),e.strikethrough||e.underline){let o=e.strikethrough?"line-through":"";o=e.underline?o+" underline":o,t["text-decoration"]=o}return e.textColor&&(t.color=e.textColor),t}function qh(e){let t="";for(const o in e)e[o]&&(t+=`${o}:${e[o]}; `);return t}const Zh=new n;function jh(){if(window.Chart&&!window.Chart.registry.plugins.get("chartShowValuesPlugin"))for(const e of Zh.getAll())e.register(window.Chart)}class Yh extends Lh{mutators=["disableAnimationForChart","enableAnimationForChart"];animationPlayed={};disableAnimationForChart(e,t){return this.animationPlayed[e]=t,"noStateChange"}enableAnimationForChart(e){return this.animationPlayed[e]=void 0,"noStateChange"}}function Xh(){return class extends window.Chart.BarController{static id="funnel";static defaults={...window.Chart?.BarController.defaults,dataElementType:"funnel",animation:{duration:e=>{if("data"!==e.type)return 1e3;return e.raw[1]/Math.max(...e.dataset.data.map((e=>e[1])))*1e3}}};updateElements(e,t,o,s){super.updateElements(e,t,o,s);for(let i=t;i<t+o;i++){const t=e[i];this.updateElement(t,i,{nextElement:e[i+1]},s)}}}}function Kh(){return class extends window.Chart.BarElement{static id="funnel";draw(e){e.save();const{x:t,y:o,height:s,nextElement:i,base:n,options:r}=this.getProps(["x","y","width","height","nextElement","base","options"]),a=Jh(this),l=(a-(i?Jh(i):0))/2,c=Math.min(t,n),h=o-s/2;e.fillStyle=r.backgroundColor,e.beginPath(),e.moveTo(c,h),e.lineTo(c+a,h),e.lineTo(c+a-l,h+s),e.lineTo(c+l,h+s),e.closePath(),e.fill(),r.borderWidth&&(e.strokeStyle=r.borderColor,e.lineWidth=r.borderWidth,e.stroke()),e.restore()}inRange(e,t){const{x:o,y:s,height:i,nextElement:n,base:r}=this.getProps(["x","y","width","height","nextElement","base","options"]),a=Jh(this),l=n?Jh(n):0,c=Math.min(o,r),h=s-i/2;if(t<h||t>h+i)return!1;const d=(a-l)/2;return!(e<c+d*(t-h)/i||e>c+a-d*(t-h)/i)}}}function Jh(e){const{x:t,base:o}=e.getProps(["x","base"]),s=Math.min(t,o);return Math.max(t,o)-s}const Qh=function(e){if(!e.length)return{x:0,y:0};const t=e[0].element,{x:o,y:s,base:i,width:n,height:r}=t.getProps(["x","y","width","height","base"]);return{x:Math.min(o,i)+2*n/3,y:s-r/2+r/2}},ed="000000",td={arrows:"3Arrows",smiley:"3Symbols",dots:"3TrafficLights1"},od={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"},sd="http://schemas.openxmlformats.org/drawingml/2006/main",id="http://schemas.openxmlformats.org/drawingml/2006/chart",nd={workbook:"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.main+xml",macroEnabledWorkbook:"application/vnd.ms-excel.sheet.macroEnabled.main+xml",templateWorkbook:"application/vnd.openxmlformats-officedocument.spreadsheetml.template.main+xml",macroEnabledTemplateWorkbook:"application/vnd.ms-excel.template.macroEnabled.main+xml",excelAddInWorkbook:"application/vnd.ms-excel.addin.macroEnabled.main+xml",sheet:"application/vnd.openxmlformats-officedocument.spreadsheetml.worksheet+xml",metadata:"application/vnd.openxmlformats-officedocument.spreadsheetml.sheetMetadata+xml",sharedStrings:"application/vnd.openxmlformats-officedocument.spreadsheetml.sharedStrings+xml",styles:"application/vnd.openxmlformats-officedocument.spreadsheetml.styles+xml",drawing:"application/vnd.openxmlformats-officedocument.drawing+xml",chart:"application/vnd.openxmlformats-officedocument.drawingml.chart+xml",themes:"application/vnd.openxmlformats-officedocument.theme+xml",table:"application/vnd.openxmlformats-officedocument.spreadsheetml.table+xml",pivot:"application/vnd.openxmlformats-officedocument.spreadsheetml.pivotTable+xml",externalLink:"application/vnd.openxmlformats-officedocument.spreadsheetml.externalLink+xml"},rd={document:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument",sheet:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/worksheet",metadata:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/sheetMetadata",sharedStrings:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/sharedStrings",styles:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/styles",drawing:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/drawing",chart:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/chart",theme:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/theme",table:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/table",hyperlink:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/hyperlink",image:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/image"},ad="bdbb8cdc-fa1e-496e-a857-3c3f30c029c3",ld="http://schemas.openxmlformats.org/officeDocument/2006/relationships",cd=.75,hd=.143,dd=8.43,ud=12.75,gd=30,pd=100,md=164,fd=50,vd={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}]},bd=["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"],Sd="[Content_Types].xml",Cd=/(.*?)\((.*?)\)(.*)/,yd=["ANY","BOOLEAN","DATE","NUMBER","STRING","RANGE","RANGE<BOOLEAN>","RANGE<DATE>","RANGE<NUMBER>","RANGE<STRING>","META","RANGE<META>"];function Id(e,t="",o){return function(e,t,o){const s=e.match(Cd),i=s[1].trim();if(!i)throw new Error(`Function argument definition is missing a name: '${e}'.`);const n=[];let r,a=!1,l=!1;for(const e of s[2].split(",")){const t=e.trim().toUpperCase(),o=yd.find((e=>t===e));o?n.push(o):"RANGE<ANY>"===t?n.push("RANGE"):"OPTIONAL"===t?a=!0:"REPEATING"===t?l=!0:t.startsWith("DEFAULT=")&&(r=e.trim().slice(8))}const c={name:i,description:t,type:n};(n.includes("ANY")||n.includes("RANGE"))&&(c.acceptErrors=!0);a&&(c.optional=!0);l&&(c.repeating=!0);void 0!==r&&(c.default=!0,c.defaultValue=r);n.some((e=>e.startsWith("RANGE")))&&(c.acceptMatrix=!0);n.every((e=>e.startsWith("RANGE")))&&(c.acceptMatrixOnly=!0);o&&o.length>0&&(c.proposalValues=o);return c}(e,t,o)}const wd={};function xd(e,t){const o=e.name,s=wd[o]?.[t];return s||(wd[o]||(wd[o]={}),wd[o][t]||(wd[o][t]=function(e,t){const o={},s=e.nbrArgRepeating?Math.floor((t-e.minArgRequired)/e.nbrArgRepeating):0,i=e.nbrArgRepeating*s,n=t-e.minArgRequired-i;let r=0,a=0;for(let t=0;t<e.args.length;t++){const i=e.args[t];if(i.optional||i.default)a<n&&(o[r]=t,r++),a++;else if(i.repeating){for(let i=0;i<s;i++)for(let s=0;s<e.nbrArgRepeating;s++)o[r]=t+s,r++;t+=e.nbrArgRepeating-1}else o[r]=t,r++}return e=>o[e]}(e,t)),wd[o][t])}const Ed=["META","RANGE<META>"];const Rd=new n,Td={description:ui("Returns a result array constrained to a specific width and height."),args:[Id("input_range (any, range<any>)",ui("The range to constrain.")),Id("rows (number)",ui("The number of rows in the constrained array.")),Id("columns (number)",ui("The number of columns in the constrained array."))],compute:function(e,t,o){const s=Kn(e),i=wn(t?.value,this.locale),n=wn(o?.value,this.locale);if(i<=0)return new rn(ui("The rows argument (%s) must be strictly positive.",i.toString()));if(n<=0)return new rn(ui("The columns argument (%s) must be strictly positive.",n.toString()));const r=Math.min(i,s[0].length);return Vn(Math.min(n,s.length),r,((e,t)=>s[e][t]))},isExported:!1},Ad={description:ui("Creates a new array from the selected columns in the existing range."),args:[Id("array (any, range<any>)",ui("The array that contains the columns to be returned.")),Id("col_num (number, range<number>)",ui("The first column index of the columns to be returned.")),Id("col_num2 (number, range<number>, repeating)",ui("The columns indexes of the columns to be returned."))],compute:function(e,...t){const o=Kn(e),s=Jn(t,(e=>wn(e?.value,this.locale))),i=s.filter((e=>0===e||o.length<Math.abs(e)));if(0!==i.length)return new rn(ui("The columns arguments must be between -%s and %s (got %s), excluding 0.",o.length.toString(),o.length.toString(),i.join(",")));const n=Array(s.length);for(let e=0;e<s.length;e++)s[e]>0?n[e]=o[s[e]-1]:n[e]=o[o.length+s[e]];return n},isExported:!0},Dd={description:ui("Creates a new array from the selected rows in the existing range."),args:[Id("array (any, range<any>)",ui("The array that contains the rows to be returned.")),Id("row_num (number, range<number>)",ui("The first row index of the rows to be returned.")),Id("row_num2 (number, range<number>, repeating)",ui("The rows indexes of the rows to be returned."))],compute:function(e,...t){const o=Kn(e),s=Jn(t,(e=>wn(e?.value,this.locale))),i=o.length,n=s.filter((e=>0===e||o[0].length<Math.abs(e)));return 0!==n.length?new rn(ui("The rows arguments must be between -%s and %s (got %s), excluding 0.",o[0].length.toString(),o[0].length.toString(),n.join(","))):Vn(i,s.length,((e,t)=>s[t]>0?o[e][s[t]-1]:o[e][o[e].length+s[t]]))},isExported:!0},_d={description:ui("Expands or pads an array to specified row and column dimensions."),args:[Id("array (any, range<any>)",ui("The array to expand.")),Id("rows (number)",ui("The number of rows in the expanded array. If missing, rows will not be expanded.")),Id("columns (number, optional)",ui("The number of columns in the expanded array. If missing, columns will not be expanded.")),Id("pad_with (any, default=0)",ui("The value with which to pad."))],compute:function(e,t,o,s={value:0}){const i=Kn(e),n=wn(t?.value,this.locale),r=void 0!==o?wn(o.value,this.locale):i.length;return n<i[0].length?new rn(ui("The rows arguments (%s) must be greater or equal than the number of rows of the array.",n.toString())):r<i.length?new rn(ui("The columns arguments (%s) must be greater or equal than the number of columns of the array.",r.toString())):Vn(r,n,((e,t)=>e>=i.length||t>=i[e].length?s:i[e][t]))},isExported:!0},Fd={description:ui("Flattens all the values from one or more ranges into a single column."),args:[Id("range (any, range<any>)",ui("The first range to flatten.")),Id("range2 (any, range<any>, repeating)",ui("Additional ranges to flatten."))],compute:function(...e){return[Jn(e,(e=>void 0===e?{value:""}:e))]},isExported:!1},Od={description:ui("Calculates the frequency distribution of a range."),args:[Id("data (range<number>)",ui("The array of ranges containing the values to be counted.")),Id("classes (number, range<number>)",ui("The range containing the set of classes."))],compute:function(e,t){const o=Jn([e],(e=>e.value)).filter((e=>"number"==typeof e)),s=Jn([t],(e=>e.value)).filter((e=>"number"==typeof e)),i=s.map(((e,t)=>({initialIndex:t,value:e,count:0}))).sort(((e,t)=>e.value-t.value));i.push({initialIndex:i.length,value:1/0,count:0});const n=o.sort(((e,t)=>e-t));let r=0;for(const e of n){for(;e>i[r].value&&r<i.length-1;)r++;i[r].count++}return[i.sort(((e,t)=>e.initialIndex-t.initialIndex)).map((e=>e.count))]},isExported:!0},Pd={description:ui("Appends ranges horizontally and in sequence to return a larger array."),args:[Id("range1 (any, range<any>)",ui("The first range to be appended.")),Id("range2 (any, range<any>, repeating)",ui("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=Kn(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},Md={description:ui("Returns the matrix determinant of a square matrix."),args:[Id("square_matrix (number, range<number>)",ui("An range with an equal number of rows and columns representing a matrix whose determinant will be calculated."))],compute:function(e){const t=yn(e,"square_matrix");return hc(t)?gc(t).determinant:new rn(ui("The argument square_matrix must have the same number of columns and rows."))},isExported:!0},Nd={description:ui("Returns the multiplicative inverse of a square matrix."),args:[Id("square_matrix (number, range<number>)",ui("An range with an equal number of rows and columns representing a matrix whose multiplicative inverse will be calculated."))],compute:function(e){const t=yn(e,"square_matrix");if(!hc(t))return new rn(ui("The argument square_matrix must have the same number of columns and rows."));const{inverted:o}=gc(t);return o||new rn(ui("The matrix is not invertible."))},isExported:!0},kd={description:ui("Calculates the matrix product of two matrices."),args:[Id("matrix1 (number, range<number>)",ui("The first matrix in the matrix multiplication operation.")),Id("matrix2 (number, range<number>)",ui("The second matrix in the matrix multiplication operation."))],compute:function(e,t){const o=yn(e,"matrix1"),s=yn(t,"matrix2");return 0===o.length||0===s.length?new rn(ui("The first and second arguments of [[FUNCTION_NAME]] must be non-empty matrices.")):o.length!==s[0].length?new rn(ui("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())):mc(o,s)},isExported:!0},Ld={description:ui("Calculates the sum of the products of corresponding entries in equal-sized ranges."),args:[Id("range1 (number, range<number>)",ui("The first range whose entries will be multiplied with corresponding entries in the other ranges.")),Id("range2 (number, range<number>, repeating)",ui("The other range whose entries will be multiplied with corresponding entries in the other ranges."))],compute:function(...e){if(!cc(...e))return new rn(ui("All the ranges must have the same dimensions."));const t=e.map(Kn);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*=Sn(o[e][s],this.locale);o+=i}return o},isExported:!0};function Vd(e,t,o){if(!cc(e,t))return new rn(ui("The arguments array_x and array_y must have the same dimensions."));const s=Kn(e),i=Kn(t);let n=!1,r=0;for(const e in s)for(const t in s[e]){const a=s[e][t].value,l=i[e][t].value;"number"==typeof a&&"number"==typeof l&&(n=!0,r+=o(a,l))}return n?r:new rn(ui("The arguments array_x and array_y must contain at least one pair of numbers."))}const Ud={description:ui("Calculates the sum of the difference of the squares of the values in two array."),args:[Id("array_x (number, range<number>)",ui("The array or range of values whose squares will be reduced by the squares of corresponding entries in array_y and added together.")),Id("array_y (number, range<number>)",ui("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 Vd(e,t,((e,t)=>e**2-t**2))},isExported:!0},Hd={description:ui("Calculates the sum of the sum of the squares of the values in two array."),args:[Id("array_x (number, range<number>)",ui("The array or range of values whose squares will be added to the squares of corresponding entries in array_y and added together.")),Id("array_y (number, range<number>)",ui("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 Vd(e,t,((e,t)=>e**2+t**2))},isExported:!0},zd={description:ui("Calculates the sum of squares of the differences of values in two array."),args:[Id("array_x (number, range<number>)",ui("The array or range of values that will be reduced by corresponding entries in array_y, squared, and added together.")),Id("array_y (number, range<number>)",ui("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 Vd(e,t,((e,t)=>(e-t)**2))},isExported:!0},Bd=!1,$d=[Id("array (any, range<any>)",ui("The array which will be transformed.")),Id("ignore (number, default=0)",ui("Whether to ignore certain types of values. By default, no values are ignored."),[{value:0,label:ui("Keep all values (default)")},{value:1,label:ui("Ignore blanks")},{value:2,label:ui("Ignore errors")},{value:3,label:ui("Ignore blanks and errors")}]),Id("scan_by_column (number, default=false)",ui("Scan the array by column. By default, the array is scanned by row."),[{value:!1,label:ui("Scan by row (default)")},{value:!0,label:ui("Scan by column")}])];function Gd(e){const t=Math.trunc(e);if(0===t)return()=>!0;if(1===t)return e=>null!==e.value;if(2===t)return e=>!fn(e.value);if(3===t)return e=>null!==e.value&&!fn(e.value);throw new rn(ui("Argument ignore must be between 0 and 3"))}const Wd={description:ui("Transforms a range of cells into a single column."),args:$d,compute:function(e,t={value:0},o={value:Bd}){const s=Kn(e),i=Sn(t.value,this.locale),n=(An(o.value)?s:Hn(s)).flat().filter(Gd(i));return 0===n.length?new hn(ui("No results for the given arguments of TOCOL.")):[n]},isExported:!0},qd={description:ui("Transforms a range of cells into a single row."),args:$d,compute:function(e,t={value:0},o={value:Bd}){const s=Kn(e),i=Sn(t.value,this.locale),n=(An(o.value)?s:Hn(s)).flat().filter(Gd(i)).map((e=>[e]));return 0===n.length||0===n[0].length?new hn(ui("No results for the given arguments of TOROW.")):n},isExported:!0},Zd={description:ui("Transposes the rows and columns of a range."),args:[Id("range (any, range<any>)",ui("The range to be transposed."))],compute:function(e){const t=Kn(e);return Vn(t[0].length,t.length,((e,o)=>t[o][e]))},isExported:!0},jd={description:ui("Appends ranges vertically and in sequence to return a larger array."),args:[Id("range1 (any, range<any>)",ui("The first range to be appended.")),Id("range2 (any, range<any>, repeating)",ui("Additional ranges to add to range1."))],compute:function(...e){const t=Math.max(...e.map((e=>Kn(e).length))),o=e.reduce(((e,t)=>e+Kn(t)[0].length),0),s=Array(t).fill([]).map((()=>Array(o).fill({value:0})));let i=0;for(const t of e){const e=Kn(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},Yd={description:ui("Wraps the provided row or column of cells by columns after a specified number of elements to form a new array."),args:[Id("range (any, range<any>)",ui("The range to wrap.")),Id("wrap_count (number)",ui("The maximum number of cells for each column, rounded down to the nearest whole number.")),Id("pad_with (any, default=0)",ui("The value with which to fill the extra cells in the range."))],compute:function(e,t,o={value:0}){const s=Kn(e),i=wn(t?.value,this.locale);if(!lc(s))return new rn(ui("Argument range must be a single row or column."));const n=s.flat();return Vn(Math.ceil(n.length/i),i,((e,t)=>{const s=e*i+t;return s<n.length?n[s]:o}))},isExported:!0},Xd={description:ui("Wraps the provided row or column of cells by rows after a specified number of elements to form a new array."),args:[Id("range (any, range<any>)",ui("The range to wrap.")),Id("wrap_count (number)",ui("The maximum number of cells for each row, rounded down to the nearest whole number.")),Id("pad_with (any, default=0)",ui("The value with which to fill the extra cells in the range."))],compute:function(e,t,o={value:0}){const s=Kn(e),i=wn(t?.value,this.locale);if(!lc(s))return new rn(ui("Argument range must be a single row or column."));const n=s.flat(),r=Math.ceil(n.length/i);return Vn(i,r,((e,t)=>{const s=t*i+e;return s<n.length?n[s]:o}))},isExported:!0};var Kd=Object.freeze({__proto__:null,ARRAY_CONSTRAIN:Td,CHOOSECOLS:Ad,CHOOSEROWS:Dd,EXPAND:_d,FLATTEN:Fd,FREQUENCY:Od,HSTACK:Pd,MDETERM:Md,MINVERSE:Nd,MMULT:kd,SUMPRODUCT:Ld,SUMX2MY2:Ud,SUMX2PY2:Hd,SUMXMY2:zd,TOCOL:Wd,TOROW:qd,TRANSPOSE:Zd,VSTACK:jd,WRAPCOLS:Yd,WRAPROWS:Xd});const Jd={description:ui("Apply a large number format"),args:[Id("value (number)",ui("The number.")),Id("unit (string, optional)",ui("The formatting unit. Use 'k', 'm', or 'b' to force the unit"),[{value:"k",label:ui("Thousand")},{value:"m",label:ui("Million")},{value:"b",label:ui("Billion")}])],compute:function(e,t){return{value:Sn(e,this.locale),format:qr(e,t,this.locale)}}};var Qd=Object.freeze({__proto__:null,FORMAT_LARGE_NUMBER:Jd});class eu{static getters=[];history;constructor(e){this.history=Object.assign(Object.create(e),{update:e.addChange.bind(e,this),selectCell:()=>{}})}exportForExcel(e){}allowDispatch(e){return"Success"}beforeHandle(e){}handle(e){}finalize(){}batchValidations(...e){return t=>e.map((e=>e.call(this,t))).flat()}chainValidations(...e){return t=>{for(const o of e){let e=o.call(this,t);Array.isArray(e)||(e=[e]);const s=e.filter((e=>"Success"!==e));if(s.length)return s}return"Success"}}checkValidations(e,...t){return this.batchValidations(...t)(e)}}class tu extends eu{static layers=[];getters;ui;selection;dispatch;canDispatch;constructor({getters:e,stateObserver:t,dispatch:o,canDispatch:s,uiActions:i,selection:n}){super(t),this.getters=e,this.ui=i,this.selection=n,this.dispatch=o,this.canDispatch=s}drawLayer(e,t){}}function ou(e){return e.isFormula&&e.compiledFormula.tokens.some((e=>"SYMBOL"===e.type&&"SUBTOTAL"===e.value.toUpperCase()))}const su=/^-?[a-z0-9]+$/i,iu={description:ui("Absolute value of a number."),args:[Id("value (number)",ui("The number of which to return the absolute value."))],compute:function(e){return Math.abs(Sn(e,this.locale))},isExported:!0},nu={description:ui("Inverse cosine of a value, in radians."),args:[Id("value (number)",ui("The value for which to calculate the inverse cosine. Must be between -1 and 1, inclusive."))],compute:function(e){const t=Sn(e,this.locale);return Math.abs(t)>1?new rn(ui("The value (%s) must be between -1 and 1 inclusive.",t)):Math.acos(t)},isExported:!0},ru={description:ui("Inverse hyperbolic cosine of a number."),args:[Id("value (number)",ui("The value for which to calculate the inverse hyperbolic cosine. Must be greater than or equal to 1."))],compute:function(e){const t=Sn(e,this.locale);return t<1?new rn(ui("The value (%s) must be greater than or equal to 1.",t)):Math.acosh(t)},isExported:!0},au={description:ui("Inverse cotangent of a value."),args:[Id("value (number)",ui("The value for which to calculate the inverse cotangent."))],compute:function(e){const t=Sn(e,this.locale);return(Math.sign(t)||1)*Math.PI/2-Math.atan(t)},isExported:!0},lu={description:ui("Inverse hyperbolic cotangent of a value."),args:[Id("value (number)",ui("The value for which to calculate the inverse hyperbolic cotangent. Must not be between -1 and 1, inclusive."))],compute:function(e){const t=Sn(e,this.locale);return Math.abs(t)<=1?new rn(ui("The value (%s) cannot be between -1 and 1 inclusive.",t)):Math.log((t+1)/(t-1))/2},isExported:!0},cu={description:ui("Inverse sine of a value, in radians."),args:[Id("value (number)",ui("The value for which to calculate the inverse sine. Must be between -1 and 1, inclusive."))],compute:function(e){const t=Sn(e,this.locale);return Math.abs(t)>1?new rn(ui("The value (%s) must be between -1 and 1 inclusive.",t)):Math.asin(t)},isExported:!0},hu={description:ui("Inverse hyperbolic sine of a number."),args:[Id("value (number)",ui("The value for which to calculate the inverse hyperbolic sine."))],compute:function(e){return Math.asinh(Sn(e,this.locale))},isExported:!0},du={description:ui("Inverse tangent of a value, in radians."),args:[Id("value (number)",ui("The value for which to calculate the inverse tangent."))],compute:function(e){return Math.atan(Sn(e,this.locale))},isExported:!0},uu={description:ui("Angle from the X axis to a point (x,y), in radians."),args:[Id("x (number)",ui("The x coordinate of the endpoint of the line segment for which to calculate the angle from the x-axis.")),Id("y (number)",ui("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=Sn(e,this.locale),s=Sn(t,this.locale);return 0===o&&0===s?new gn(ui("Function [[FUNCTION_NAME]] caused a divide by zero error.")):Math.atan2(s,o)},isExported:!0},gu={description:ui("Inverse hyperbolic tangent of a number."),args:[Id("value (number)",ui("The value for which to calculate the inverse hyperbolic tangent. Must be between -1 and 1, exclusive."))],compute:function(e){const t=Sn(e,this.locale);return Math.abs(t)>=1?new rn(ui("The value (%s) must be between -1 and 1 exclusive.",t)):Math.atanh(t)},isExported:!0},pu={description:ui("Rounds number up to nearest multiple of factor."),args:[Id("value (number)",ui("The value to round up to the nearest integer multiple of factor.")),Id("factor (number, default=1)",ui("The number to whose multiples value will be rounded."))],compute:function(e,t={value:1}){const o=Sn(e,this.locale),s=Sn(t,this.locale);return s<0&&o>0?new rn(ui("The factor (%s) must be positive when the value (%s) is positive.",s,o)):{value:s?Math.ceil(o/s)*s:0,format:e?.format}},isExported:!0};function mu(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 fu={description:ui("Rounds number up to nearest multiple of factor."),args:[Id("number (number)",ui("The value to round up to the nearest integer multiple of significance.")),Id("significance (number, default=1)",ui("The number to whose multiples number will be rounded. The sign of significance will be ignored.")),Id("mode (number, default=0)",ui("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=Sn(t,this.locale);return{value:mu(Sn(e,this.locale),s,Sn(o,this.locale)),format:e?.format}},isExported:!0},vu={description:ui("Rounds number up to nearest multiple of factor."),args:[Id("number (number)",ui("The value to round up to the nearest integer multiple of significance.")),Id("significance (number, default=1)",ui("The number to whose multiples number will be rounded."))],compute:function(e,t={value:1}){const o=Sn(t,this.locale);return{value:mu(Sn(e,this.locale),o),format:e?.format}},isExported:!0},bu={description:ui("Cosine of an angle provided in radians."),args:[Id("angle (number)",ui("The angle to find the cosine of, in radians."))],compute:function(e){return Math.cos(Sn(e,this.locale))},isExported:!0},Su={description:ui("Hyperbolic cosine of any real number."),args:[Id("value (number)",ui("Any real value to calculate the hyperbolic cosine of."))],compute:function(e){return Math.cosh(Sn(e,this.locale))},isExported:!0},Cu={description:ui("Cotangent of an angle provided in radians."),args:[Id("angle (number)",ui("The angle to find the cotangent of, in radians."))],compute:function(e){const t=Sn(e,this.locale);return 0===t?new gn(ui("Function [[FUNCTION_NAME]] caused a divide by zero error.")):1/Math.tan(t)},isExported:!0},yu={description:ui("Hyperbolic cotangent of any real number."),args:[Id("value (number)",ui("Any real value to calculate the hyperbolic cotangent of."))],compute:function(e){const t=Sn(e,this.locale);return 0===t?new gn(ui("Function [[FUNCTION_NAME]] caused a divide by zero error.")):1/Math.tanh(t)},isExported:!0},Iu={description:ui("Number of empty values."),args:[Id("value1 (any, range)",ui("The first value or range in which to count the number of blanks.")),Id("value2 (any, range, repeating)",ui("Additional values or ranges in which to count the number of blanks."))],compute:function(...e){return Nn(e,((e,t)=>void 0===t||null===t.value||""===t.value?e+1:e),0)},isExported:!0},wu={description:ui("A conditional count across a range."),args:[Id("range (range)",ui("The range that is tested against criterion.")),Id("criterion (string)",ui("The pattern or test to apply to range."))],compute:function(...e){let t=0;return qn(e,((e,o)=>{t+=1}),this.locale),t},isExported:!0},xu={description:ui("Count values depending on multiple criteria."),args:[Id("criteria_range1 (range)",ui("The range to check against criterion1.")),Id("criterion1 (string)",ui("The pattern or test to apply to criteria_range1.")),Id("criteria_range2 (any, range, repeating)",ui("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.")),Id("criterion2 (string, repeating)",ui("Additional criteria to check."))],compute:function(...e){let t=0;return qn(e,((e,o)=>{t+=1}),this.locale),t},isExported:!0},Eu={description:ui("Counts number of unique values in a range."),args:[Id("value1 (any, range)",ui("The first value or range to consider for uniqueness.")),Id("value2 (any, range, repeating)",ui("Additional values or ranges to consider for uniqueness."))],compute:function(...e){return nc(e)}},Ru={description:ui("Counts number of unique values in a range, filtered by a set of criteria."),args:[Id("range (range)",ui("The range of cells from which the number of unique values will be counted.")),Id("criteria_range1 (range)",ui("The range of cells over which to evaluate criterion1.")),Id("criterion1 (string)",ui("The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.")),Id("criteria_range2 (any, range, repeating)",ui("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.")),Id("criterion2 (string, repeating)",ui("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){const o=new Set;return qn(t,((t,s)=>{const i=e[t]?.[s];Qn(i)&&o.add(i.value)}),this.locale),o.size}},Tu={description:ui("Cosecant of an angle provided in radians."),args:[Id("angle (number)",ui("The angle to find the cosecant of, in radians."))],compute:function(e){const t=Sn(e,this.locale);return 0===t?new gn(ui("Function [[FUNCTION_NAME]] caused a divide by zero error.")):1/Math.sin(t)},isExported:!0},Au={description:ui("Hyperbolic cosecant of any real number."),args:[Id("value (number)",ui("Any real value to calculate the hyperbolic cosecant of."))],compute:function(e){const t=Sn(e,this.locale);return 0===t?new gn(ui("Function [[FUNCTION_NAME]] caused a divide by zero error.")):1/Math.sinh(t)},isExported:!0},Du={description:ui("Converts from another base to decimal."),args:[Id("value (string)",ui("The number to convert.")),Id("base (number)",ui("The base to convert the value from."))],compute:function(e,t){let o=Sn(t,this.locale);if(o=Math.floor(o),2>o||o>36)return new rn(ui("The base (%s) must be between 2 and 36 inclusive.",o));const s=En(e);if(""===s)return 0;if(!su.test(s))return new rn(ui("The value (%s) must be a valid base %s representation.",s,o));const i=parseInt(s,o);return isNaN(i)?new rn(ui("The value (%s) must be a valid base %s representation.",s,o)):i},isExported:!0},_u={description:ui("Converts an angle value in radians to degrees."),args:[Id("angle (number)",ui("The angle to convert from radians to degrees."))],compute:function(e){return 180*Sn(e,this.locale)/Math.PI},isExported:!0},Fu={description:ui("Euler's number, e (~2.718) raised to a power."),args:[Id("value (number)",ui("The exponent to raise e."))],compute:function(e){return Math.exp(Sn(e,this.locale))},isExported:!0},Ou={description:ui("Rounds number down to nearest multiple of factor."),args:[Id("value (number)",ui("The value to round down to the nearest integer multiple of factor.")),Id("factor (number, default=1)",ui("The number to whose multiples value will be rounded."))],compute:function(e,t={value:1}){const o=Sn(e,this.locale),s=Sn(t,this.locale);return s<0&&o>0?new rn(ui("The factor (%s) must be positive when the value (%s) is positive.",s,o)):{value:s?Math.floor(o/s)*s:0,format:e?.format}},isExported:!0};function Pu(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 Mu={description:ui("Rounds number down to nearest multiple of factor."),args:[Id("number (number)",ui("The value to round down to the nearest integer multiple of significance.")),Id("significance (number, default=1)",ui("The number to whose multiples number will be rounded. The sign of significance will be ignored.")),Id("mode (number, default=0)",ui("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=Sn(t,this.locale);return{value:Pu(Sn(e,this.locale),s,Sn(o,this.locale)),format:e?.format}},isExported:!0},Nu={description:ui("Rounds number down to nearest multiple of factor."),args:[Id("number (number)",ui("The value to round down to the nearest integer multiple of significance.")),Id("significance (number, default=1)",ui("The number to whose multiples number will be rounded."))],compute:function(e,t={value:1}){const o=Sn(t,this.locale);return{value:Pu(Sn(e,this.locale),o),format:e?.format}},isExported:!0},ku={description:ui("Whether the provided value is even."),args:[Id("value (number)",ui("The value to be verified as even."))],compute:function(e){const t=In(e,this.locale);return!(1&Math.floor(Math.abs(t)))},isExported:!0},Lu={description:ui("Rounds number up to nearest multiple of factor."),args:[Id("number (number)",ui("The value to round up to the nearest integer multiple of significance.")),Id("significance (number, default=1)",ui("The number to whose multiples number will be rounded."))],compute:function(e,t={value:1}){return{value:mu(Sn(e,this.locale),Sn(t,this.locale)),format:e?.format}},isExported:!0},Vu={description:ui("Whether the provided value is even."),args:[Id("value (number)",ui("The value to be verified as even."))],compute:function(e){const t=In(e,this.locale);return!!(1&Math.floor(Math.abs(t)))},isExported:!0},Uu={description:ui("The logarithm of a number, base e (euler's number)."),args:[Id("value (number)",ui("The value for which to calculate the logarithm, base e."))],compute:function(e){const t=Sn(e,this.locale);return t<=0?new rn(ui("The value (%s) must be strictly positive.",t)):Math.log(t)},isExported:!0},Hu={description:ui("The logarithm of a number, for a given base."),args:[Id("value (number)",ui("The value for which to calculate the logarithm.")),Id("base (number, default=10)",ui("The base of the logarithm."))],compute:function(e,t={value:10}){const o=Sn(e,this.locale),s=Sn(t,this.locale);return o<=0?new rn(ui("The value (%s) must be strictly positive.",o)):s<=0?new rn(ui("The base (%s) must be strictly positive.",s)):1===s?new rn(ui("The base must be different from 1.")):Math.log10(o)/Math.log10(s)},isExported:!0};function zu(e,t){ac(t,ui("The divisor must be different from 0."));const o=e%t;return o>0&&t<0||o<0&&t>0?o+t:o}const Bu={description:ui("Modulo (remainder) operator."),args:[Id("dividend (number)",ui("The number to be divided to find the remainder.")),Id("divisor (number)",ui("The number to divide by."))],compute:function(e,t){const o=Sn(t,this.locale);return{value:zu(Sn(e,this.locale),o),format:e?.format}},isExported:!0},$u={description:ui("Returns a n x n unit matrix, where n is the input dimension."),args:[Id("dimension (number)",ui("An integer specifying the dimension size of the unit matrix. It must be positive."))],compute:function(e){const t=wn(e,this.locale);return t<1?new rn(ui("The argument dimension must be positive")):uc(t)},isExported:!0},Gu={description:ui("Rounds a number up to the nearest odd integer."),args:[Id("value (number)",ui("The value to round to the next greatest odd number."))],compute:function(e){const t=Sn(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},Wu={description:ui("The number pi."),args:[],compute:function(){return Math.PI},isExported:!0},qu={description:ui("A number raised to a power."),args:[Id("base (number)",ui("The number to raise to the exponent power.")),Id("exponent (number)",ui("The exponent to raise base to."))],compute:function(e,t){const o=Sn(e,this.locale),s=Sn(t,this.locale);return o<0&&!Number.isInteger(s)?new rn(ui("The exponent (%s) must be an integer when the base is negative.",s)):{value:Math.pow(o,s),format:e?.format}},isExported:!0},Zu={description:ui("Result of multiplying a series of numbers together."),args:[Id("factor1 (number, range<number>)",ui("The first number or range to calculate for the product.")),Id("factor2 (number, range<number>, repeating)",ui("More numbers or ranges to calculate for the product."))],compute:function(...e){let t=0,o=1;for(const s of e)if(E(s))for(const e of s)for(const s of e){const e=s.value;if("number"==typeof e&&(o*=e,t+=1),fn(e))return s}else void 0!==s&&null!==s.value&&(o*=In(s,this.locale),t+=1);return{value:0===t?0:o,format:mn(e[0])}},isExported:!0},ju={description:ui("A random number between 0 inclusive and 1 exclusive."),args:[],compute:function(){return Math.random()},isExported:!0},Yu={description:ui("Returns a grid of random numbers between 0 inclusive and 1 exclusive."),args:[Id("rows (number, default=1)",ui("The number of rows to be returned.")),Id("columns (number, default=1)",ui("The number of columns to be returned.")),Id("min (number, default=0)",ui("The minimum number you would like returned.")),Id("max (number, default=1)",ui("The maximum number you would like returned.")),Id("whole_number (boolean, default=FALSE)",ui("Return a whole number or a decimal value."),[{value:!1,label:ui("Decimal (default)")},{value:!0,label:ui("Integer")}])],compute:function(e={value:1},t={value:1},o={value:0},s={value:1},i={value:!1}){const n=wn(t,this.locale),r=wn(e,this.locale),a=Sn(o,this.locale),l=Sn(s,this.locale),c=An(i);if(n<1)return new rn(ui("The number of columns (%s) must be positive.",n));if(r<1)return new rn(ui("The number of rows (%s) must be positive.",r));if(a>l)return new rn(ui("The maximum (%s) must be greater than or equal to the minimum (%s).",l,a));if(c&&(!Number.isInteger(a)||!Number.isInteger(l)))return new rn(ui("The maximum (%s) and minimum (%s) must be integers when whole_number is TRUE.",l.toString(),a.toString()));const h=Array(n);for(let e=0;e<n;e++){h[e]=Array(r);for(let t=0;t<r;t++)h[e][t]=c?Math.floor(Math.random()*(l-a+1)+a):a+Math.random()*(l-a)}return h},isExported:!0},Xu={description:ui("Random integer between two values, inclusive."),args:[Id("low (number)",ui("The low end of the random range.")),Id("high (number)",ui("The high end of the random range."))],compute:function(e,t){let o=Sn(e,this.locale);Number.isInteger(o)||(o=Math.ceil(o));let s=Sn(t,this.locale);return Number.isInteger(s)||(s=Math.floor(s)),o>s?new rn(ui("The high (%s) must be greater than or equal to the low (%s).",s,o)):{value:o+Math.ceil((s-o+1)*Math.random())-1,format:e?.format}},isExported:!0},Ku={description:ui("Rounds a number according to standard rules."),args:[Id("value (number)",ui("The value to round to places number of places.")),Id("places (number, default=0)",ui("The number of decimal places to which to round."))],compute:function(e,t={value:0}){const o=Sn(e,this.locale);let s=Sn(t,this.locale);const i=Math.abs(o);let n;return 0===s?n=Math.round(i):(Number.isInteger(s)||(s=Math.trunc(s)),n=Math.round(i*Math.pow(10,s))/Math.pow(10,s)),{value:o>=0?n:-n,format:e?.format}},isExported:!0},Ju={description:ui("Rounds down a number."),args:[Id("value (number)",ui("The value to round to places number of places, always rounding down.")),Id("places (number, default=0)",ui("The number of decimal places to which to round."))],compute:function(e,t={value:0}){const o=Sn(e,this.locale);let s=Sn(t,this.locale);const i=Math.abs(o);let n;return 0===s?n=Math.floor(i):(Number.isInteger(s)||(s=Math.trunc(s)),n=Math.floor(i*Math.pow(10,s))/Math.pow(10,s)),{value:o>=0?n:-n,format:e?.format}},isExported:!0},Qu={description:ui("Rounds up a number."),args:[Id("value (number)",ui("The value to round to places number of places, always rounding up.")),Id("places (number, default=0)",ui("The number of decimal places to which to round."))],compute:function(e,t={value:0}){const o=Sn(e,this.locale);let s=Sn(t,this.locale);const i=Math.abs(o);let n;return 0===s?n=Math.ceil(i):(Number.isInteger(s)||(s=Math.trunc(s)),n=Math.ceil(i*Math.pow(10,s))/Math.pow(10,s)),{value:o>=0?n:-n,format:e?.format}},isExported:!0},eg={description:ui("Secant of an angle provided in radians."),args:[Id("angle (number)",ui("The angle to find the secant of, in radians."))],compute:function(e){return 1/Math.cos(Sn(e,this.locale))},isExported:!0},tg={description:ui("Hyperbolic secant of any real number."),args:[Id("value (number)",ui("Any real value to calculate the hyperbolic secant of."))],compute:function(e){return 1/Math.cosh(Sn(e,this.locale))},isExported:!0},og={description:ui("Returns a sequence of numbers."),args:[Id("rows (number)",ui("The number of rows to return")),Id("columns (number, optional, default=1)",ui("The number of columns to return")),Id("start (number, optional, default=1)",ui("The first number in the sequence")),Id("step (number, optional, default=1)",ui("The amount to increment each value in the sequence"))],compute:function(e,t={value:1},o={value:1},s={value:1}){const i=Sn(o,this.locale),n=Sn(s,this.locale),r=wn(e,this.locale),a=wn(t,this.locale);return a<1?new rn(ui("The number of columns (%s) must be positive.",a)):r<1?new rn(ui("The number of rows (%s) must be positive.",r)):Vn(a,r,((e,t)=>({value:i+t*a*n+e*n})))},isExported:!0},sg={description:ui("Sine of an angle provided in radians."),args:[Id("angle (number)",ui("The angle to find the sine of, in radians."))],compute:function(e){return Math.sin(Sn(e,this.locale))},isExported:!0},ig={description:ui("Hyperbolic sine of any real number."),args:[Id("value (number)",ui("Any real value to calculate the hyperbolic sine of."))],compute:function(e){return Math.sinh(Sn(e,this.locale))},isExported:!0},ng={description:ui("Positive square root of a positive number."),args:[Id("value (number)",ui("The number for which to calculate the positive square root."))],compute:function(e){const t=Sn(e,this.locale);return t<0?new rn(ui("The value (%s) must be positive or null.",t)):{value:Math.sqrt(t),format:e?.format}},isExported:!0},rg={1:"AVERAGE",2:"COUNT",3:"COUNTA",4:"MAX",5:"MIN",6:"PRODUCT",7:"STDEV",8:"STDEVP",9:"SUM",10:"VAR",11:"VARP"},ag=Object.entries(rg).map((([e,t])=>({value:parseInt(e),label:ui("%s (include manually-hidden rows)",t)}))),lg=Object.entries(rg).map((([e,t])=>({value:parseInt(e)+100,label:ui("%s (exclude manually-hidden rows)",t)}))),cg={description:ui("Returns a subtotal for a vertical range of cells using a specified aggregation function."),args:[Id("function_code (number)",ui("The function to use in subtotal aggregation."),[...ag,...lg]),Id("ref1 (meta, range<meta>)",ui("The range or reference for which you want the subtotal.")),Id("ref2 (meta, range<meta>, repeating)",ui("Additional ranges or references for which you want the subtotal."))],compute:function(e,...t){let o=wn(e,this.locale),s=!0;if(o>100&&(o-=100,s=!1),o<1||o>11)return new rn(ui("The function code (%s) must be between 1 to 11 or 101 to 111.",o));const i=[];for(const e of t){const t=e[0][0],o=Ta(t.value).sheetName,n=o?this.getters.getSheetIdByName(o):this.__originSheetId;if(!n)continue;const{top:r,left:a}=Ho(t.value),l=a+e.length-1,c=r+e[0].length-1;for(let e=r;e<=c;e++)if(!this.getters.isRowFiltered(n,e)&&(s||!this.getters.isRowHiddenByUser(n,e)))for(let t=a;t<=l;t++){const o=this.getters.getCell({sheetId:n,col:t,row:e});o&&ou(o)||i.push(this.getters.getEvaluatedCell({sheetId:n,col:t,row:e}))}}return this[rg[o]].apply(this,[[i]])},isExported:!0},hg={description:ui("Sum of a series of numbers and/or cells."),args:[Id("value1 (number, range<number>)",ui("The first number or range to add together.")),Id("value2 (number, range<number>, repeating)",ui("Additional numbers or ranges to add to value1."))],compute:function(...e){const t=e[0];return{value:ic(e,this.locale),format:mn(t)}},isExported:!0},dg={description:ui("A conditional sum across a range."),args:[Id("criteria_range (range)",ui("The range which is tested against criterion.")),Id("criterion (string)",ui("The pattern or test to apply to range.")),Id("sum_range (range, default=criteria_range)",ui("The range to be summed, if different from range."))],compute:function(e,t,o){void 0===o&&(o=e);let s=0;return qn([e,t],((e,t)=>{const i=o[e]?.[t]?.value;"number"==typeof i&&(s+=i)}),this.locale),s},isExported:!0},ug={description:ui("Sums a range depending on multiple criteria."),args:[Id("sum_range (range)",ui("The range to sum.")),Id("criteria_range1 (range)",ui("The range to check against criterion1.")),Id("criterion1 (string)",ui("The pattern or test to apply to criteria_range1.")),Id("criteria_range2 (any, range, repeating)",ui("Additional ranges to check.")),Id("criterion2 (string, repeating)",ui("Additional criteria to check."))],compute:function(e,...t){let o=0;return qn(t,((t,s)=>{const i=e[t]?.[s]?.value;"number"==typeof i&&(o+=i)}),this.locale),o},isExported:!0},gg={description:ui("Tangent of an angle provided in radians."),args:[Id("angle (number)",ui("The angle to find the tangent of, in radians."))],compute:function(e){return Math.tan(Sn(e,this.locale))},isExported:!0},pg={description:ui("Hyperbolic tangent of any real number."),args:[Id("value (number)",ui("Any real value to calculate the hyperbolic tangent of."))],compute:function(e){return Math.tanh(Sn(e,this.locale))},isExported:!0};function mg(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 fg={description:ui("Truncates a number."),args:[Id("value (number)",ui("The value to be truncated.")),Id("places (number, default=0)",ui("The number of significant digits to the right of the decimal point to retain."))],compute:function(e,t={value:0}){return{value:mg(Sn(e,this.locale),Sn(t,this.locale)),format:e?.format}},isExported:!0},vg={description:ui("Rounds a number down to the nearest integer that is less than or equal to it."),args:[Id("value (number)",ui("The number to round down to the nearest integer."))],compute:function(e){return Math.floor(Sn(e,this.locale))},isExported:!0};var bg=Object.freeze({__proto__:null,ABS:iu,ACOS:nu,ACOSH:ru,ACOT:au,ACOTH:lu,ASIN:cu,ASINH:hu,ATAN:du,ATAN2:uu,ATANH:gu,CEILING:pu,CEILING_MATH:fu,CEILING_PRECISE:vu,COS:bu,COSH:Su,COT:Cu,COTH:yu,COUNTBLANK:Iu,COUNTIF:wu,COUNTIFS:xu,COUNTUNIQUE:Eu,COUNTUNIQUEIFS:Ru,CSC:Tu,CSCH:Au,DECIMAL:Du,DEGREES:_u,EXP:Fu,FLOOR:Ou,FLOOR_MATH:Mu,FLOOR_PRECISE:Nu,INT:vg,ISEVEN:ku,ISODD:Vu,ISO_CEILING:Lu,LN:Uu,LOG:Hu,MOD:Bu,MUNIT:$u,ODD:Gu,PI:Wu,POWER:qu,PRODUCT:Zu,RAND:ju,RANDARRAY:Yu,RANDBETWEEN:Xu,ROUND:Ku,ROUNDDOWN:Ju,ROUNDUP:Qu,SEC:eg,SECH:tg,SEQUENCE:og,SIN:sg,SINH:ig,SQRT:ng,SUBTOTAL:cg,SUM:hg,SUMIF:dg,SUMIFS:ug,TAN:gg,TANH:pg,TRUNC:fg});const Sg=[{value:!0,label:ui("b is calculated normally")},{value:!1,label:ui("b is forced to 1")}],Cg=[{value:!1,label:ui("do not return additional regression statistics")},{value:!0,label:ui("return additional regression statistics")}],yg=[{value:1,label:ui("order 1 (Linear)")},{value:2,label:ui("order 2 (Quadratic)")},{value:3,label:ui("order 3 (Cubic)")},{value:4,label:ui("order 4 (Quartic)")},{value:5,label:ui("order 5 (Quintic)")},{value:6,label:ui("order 6 (Sextic)")}],Ig=[{value:!0,label:ui("Compute intercept")},{value:!1,label:ui("Force intercept to 0")}],wg=[{value:0,label:ui("Minimum value")},{value:1,label:ui("First quartile (25th percentile)")},{value:2,label:ui("Median value (50th percentile)")},{value:3,label:ui("Third quartile (75th percentile)")},{value:4,label:ui("Maximum value")}];function xg(e,t){const o=[],s=[];let i=0,n=0;On([e],(e=>{o.push(e),i+=1})),On([t],(e=>{s.push(e),n+=1})),rc(i===n,ui("[[FUNCTION_NAME]] has mismatched argument count %s vs %s.",i,n));const r=[],a=[];for(let e=0;e<i;e++){const t=o[e]?.value,i=s[e]?.value;"number"==typeof t&&"number"==typeof i&&(a.push(t),r.push(i))}return{flatDataX:r,flatDataY:a}}function Eg(e,t,o){const{flatDataX:s,flatDataY:i}=xg(e,t),n=i.length;ac(n),o&&ac(n-1);let r=0,a=0;for(let e=0;e<n;e++)r+=i[e],a+=s[e];const l=r/n,c=a/n;let h=0;for(let e=0;e<n;e++)h+=(i[e]-l)*(s[e]-c);return h/(n-(o?1:0))}function Rg(e,t,o,s){let i=0;const n=o?Ln:kn,r=n(e,((e,t)=>(i+=1,e+t)),0,s);ac(i),t&&ac(i-1);const a=r/i;return n(e,((e,t)=>e+Math.pow(t-a,2)),0,s)/(i-(t?1:0))}function Tg(e,t,o,s){const i=Sn(t,s);rc(o?0<=i&&i<=1:0<i&&i<1,ui("Function [[FUNCTION_NAME]] parameter 2 value is out of range."));const n=[];let r,a=0;return On(e,(e=>{const t=e?.value;"number"==typeof t&&(r=Zn(n,e,"nextSmaller","asc",n.length,((e,t)=>e[t])),n.splice(r+1,0,t),a++)})),rc(0!==a,er),o||rc(1/(a+1)<=i&&i<=a/(a+1),ui("Function [[FUNCTION_NAME]] parameter 2 value is out of range.")),on(n,i,o)}const Ag={description:ui("Average magnitude of deviations from mean."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the sample.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the sample."))],compute:function(...e){let t=0;const o=kn(e,((e,o)=>(t+=1,e+o)),0,this.locale);if(0===t)return new gn(ui("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error."));const s=o/t;return kn(e,((e,t)=>e+Math.abs(s-t)),0,this.locale)/t},isExported:!0},Dg={description:ui("Numerical average value in a dataset, ignoring text."),args:[Id("value1 (number, range<number>)",ui("The first value or range to consider when calculating the average value.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to consider when calculating the average value."))],compute:function(...e){return{value:Cc(e,this.locale),format:mn(e[0])}},isExported:!0},_g=ui("[[FUNCTION_NAME]] has mismatched range sizes."),Fg=ui("[[FUNCTION_NAME]] expects the weight to be positive or equal to 0."),Og={description:ui("Weighted average."),args:[Id("values (number, range<number>)",ui("Values to average.")),Id("weights (number, range<number>)",ui("Weights for each corresponding value.")),Id("additional_values (number, range<number>, repeating)",ui("Additional values to average.")),Id("additional_weights (number, range<number>, repeating)",ui("Additional weights."))],compute:function(...e){let t=0,o=0;for(let s=0;s<e.length-1;s+=2){const i=e[s],n=e[s+1];if(!cc(i,n))return new rn(_g);if(E(i))for(let e=0;e<i.length;e++)for(let s=0;s<i[0].length;s++){const r=i[e][s].value,a=E(n)?n?.[e][s].value:Sn(n,this.locale),l="number"==typeof r,c="number"==typeof a;if(l&&c){if(a<0)return new rn(Fg);t+=r*a,o+=a}else if(l!==c)return new rn(ui("[[FUNCTION_NAME]] expects number values."))}else{const e=Sn(i,this.locale),s=E(n)?n?.[0][0].value:Sn(n,this.locale);if("number"==typeof s){if(s<0)return new rn(Fg);t+=e*s,o+=s}}}return 0===o?new gn(ui("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.")):{value:t/o,format:mn(e[0])}}},Pg={description:ui("Numerical average value in a dataset."),args:[Id("value1 (number, range<number>)",ui("The first value or range to consider when calculating the average value.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to consider when calculating the average value."))],compute:function(...e){let t=0;const o=Ln(e,((e,o)=>(t+=1,e+o)),0,this.locale);return 0===t?new gn(ui("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.")):{value:o/t,format:mn(e[0])}},isExported:!0},Mg={description:ui("Average of values depending on criteria."),args:[Id("criteria_range (number, range<number>)",ui("The range to check against criterion.")),Id("criterion (string)",ui("The pattern or test to apply to criteria_range.")),Id("average_range (number, range<number>, default=criteria_range)",ui("The range to average. If not included, criteria_range is used for the average instead."))],compute:function(e,t,o){const s=Kn(void 0===o?e:o);let i=0,n=0;return qn([e,t],((e,t)=>{const o=s[e]?.[t]?.value;"number"==typeof o&&(i+=1,n+=o)}),this.locale),0===i?new gn(ui("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.")):n/i},isExported:!0},Ng={description:ui("Average of values depending on multiple criteria."),args:[Id("average_range (range)",ui("The range to average.")),Id("criteria_range1 (range)",ui("The range to check against criterion1.")),Id("criterion1 (string)",ui("The pattern or test to apply to criteria_range1.")),Id("criteria_range2 (any, range, repeating)",ui("Additional criteria_range and criterion to check.")),Id("criterion2 (string, repeating)",ui("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){const o=Kn(e);let s=0,i=0;return qn(t,((e,t)=>{const n=o[e]?.[t]?.value;"number"==typeof n&&(s+=1,i+=n)}),this.locale),0===s?new gn(ui("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.")):i/s},isExported:!0},kg={description:ui("The number of numeric values in dataset."),args:[Id("value1 (number, any, range<number>)",ui("The first value or range to consider when counting.")),Id("value2 (number, any, range<number>, repeating)",ui("Additional values or ranges to consider when counting."))],compute:function(...e){return yc(e,this.locale)},isExported:!0},Lg={description:ui("The number of values in a dataset."),args:[Id("value1 (any, range)",ui("The first value or range to consider when counting.")),Id("value2 (any, range, repeating)",ui("Additional values or ranges to consider when counting."))],compute:function(...e){return Ic(e)},isExported:!0},Vg={description:ui("The covariance of a dataset."),args:[Id("data_y (any, range)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (any, range)",ui("The range representing the array or matrix of independent data."))],compute:function(e,t){return Eg(e,t,!1)},isExported:!0},Ug={description:ui("The covariance of a dataset."),args:[Id("data_y (any, range)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (any, range)",ui("The range representing the array or matrix of independent data."))],compute:function(e,t){return Eg(e,t,!1)},isExported:!0},Hg={description:ui("The sample covariance of a dataset."),args:[Id("data_y (any, range)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (any, range)",ui("The range representing the array or matrix of independent data."))],compute:function(e,t){return Eg(e,t,!0)},isExported:!0},zg={description:ui("Calculates the expected y-value for a specified x based on a linear regression of a dataset."),args:[Id("x (number, range<number>)",ui("The value(s) on the x-axis to forecast.")),Id("data_y (range<number>)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (range<number>)",ui("The range representing the array or matrix of independent data."))],compute:function(e,t,o){const{flatDataX:s,flatDataY:i}=xg(t,o);return 0===s.length||0===i.length?new hn(er):Oc([i],[s],Un(Kn(e),(e=>Sn(e,this.locale))),!0)},isExported:!0},Bg={description:ui("Fits points to exponential growth trend."),args:[Id("known_data_y (range<number>)",ui("The array or range containing dependent (y) values that are already known, used to curve fit an ideal exponential growth curve.")),Id("known_data_x (range<number>, default={1;2;3;...})",ui("The values of the independent variable(s) corresponding with known_data_y.")),Id("new_data_x (any, range, default=known_data_x)",ui("The data points to return the y values for on the ideal curve fit.")),Id("b (boolean, default=TRUE)",ui("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."),Sg)],compute:function(e,t=[[]],o=[[]],s={value:!0}){return 0===e.length||0===e[0].length?new rn(tr("known_data_y")):_c(Oc(Fc(yn(e,"known_data_y")),yn(t,"known_data_x"),yn(o,"new_data_y"),An(s)))}},$g={description:ui("Compute the intercept of the linear regression."),args:[Id("data_y (range<number>)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (range<number>)",ui("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=xg(e,t);if(0===o.length||0===s.length)return new hn(er);const[[],[i]]=Rc([o],[s]);return i},isExported:!0},Gg={description:ui("Nth largest element from a data set."),args:[Id("data (any, range)",ui("Array or range containing the dataset to consider.")),Id("n (number)",ui("The rank from largest to smallest of the element to return."))],compute:function(e,t){const o=Math.trunc(Sn(t?.value,this.locale)),s=[];let i,n=0;On([e],(e=>{"number"==typeof e?.value&&(i=Zn(s,e,"nextSmaller","asc",s.length,((e,t)=>e[t].value)),s.splice(i+1,0,e),n++,n>o&&(s.shift(),n--))}));const r=s.shift();return void 0===r?new rn(er):n<o?new rn(ui("Function [[FUNCTION_NAME]] parameter 2 value (%s) is out of range.",o)):r},isExported:!0},Wg={description:ui("Given partial data about a linear trend, calculates various parameters about the ideal linear trend using the least-squares method."),args:[Id("data_y (range<number>)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (range<number>, default={1;2;3;...})",ui("The range representing the array or matrix of independent data.")),Id("calculate_b (boolean, default=TRUE)",ui("A flag specifying whether to compute the slope or not"),Sg),Id("verbose (boolean, default=FALSE)",ui("A flag specifying whether to return additional regression statistics or only the linear coefficients and the y-intercept"),Cg)],compute:function(e,t=[[]],o={value:!0},s={value:!1}){return 0===e.length||0===e[0].length?new rn(tr("data_y")):Rc(yn(t,"data_x"),yn(e,"data_y"),An(o),An(s))},isExported:!0},qg={description:ui("Given partial data about an exponential growth curve, calculates various parameters about the best fit ideal exponential growth curve."),args:[Id("data_y (range<number>)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (range<number>, optional, default={1;2;3;...})",ui("The range representing the array or matrix of independent data.")),Id("calculate_b (boolean, default=TRUE)",ui("A flag specifying whether to compute the slope or not"),Sg),Id("verbose (boolean, default=FALSE)",ui("A flag specifying whether to return additional regression statistics or only the linear coefficients and the y-intercept"),Cg)],compute:function(e,t=[[]],o={value:!0},s={value:!1}){if(0===e.length||0===e[0].length)return new rn(tr("data_y"));const i=Rc(yn(t,"data_x"),Fc(yn(e,"data_y")),An(o),An(s));for(let e=0;e<i.length;e++)i[e][0]=Math.exp(i[e][0]);return i},isExported:!0},Zg={description:ui("Compute the Matthews correlation coefficient of a dataset."),args:[Id("data_x (range)",ui("The range representing the array or matrix of observed data.")),Id("data_y (range)",ui("The range representing the array or matrix of predicted data."))],compute:function(e,t){const o=e.flat(),s=t.flat();if(Sc(o,s),0===o.length||0===s.length)return new hn(er);const i=o.length;let n=0,r=0,a=0,l=0;for(let e=0;e<i;++e){const t=An(o[e]);t===An(s[e])?t?r++:n++:t?l++:a++}return(r*n-a*l)/Math.sqrt((r+a)*(r+l)*(n+a)*(n+l))},isExported:!1},jg={description:ui("Maximum value in a numeric dataset."),args:[Id("value1 (number, range<number>)",ui("The first value or range to consider when calculating the maximum value.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to consider when calculating the maximum value."))],compute:function(...e){return wc(e,this.locale)},isExported:!0},Yg={description:ui("Maximum numeric value in a dataset."),args:[Id("value1 (any, range)",ui("The first value or range to consider when calculating the maximum value.")),Id("value2 (any, range, repeating)",ui("Additional values or ranges to consider when calculating the maximum value."))],compute:function(...e){const t=Ln(e,((e,t)=>Math.max(t,e)),-1/0,this.locale);return{value:t===-1/0?0:t,format:mn(e[0])}},isExported:!0},Xg={description:ui("Returns the maximum value in a range of cells, filtered by a set of criteria."),args:[Id("range (range)",ui("The range of cells from which the maximum will be determined.")),Id("criteria_range1 (range)",ui("The range of cells over which to evaluate criterion1.")),Id("criterion1 (string)",ui("The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.")),Id("criteria_range2 (any, range, repeating)",ui("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.")),Id("criterion2 (string, repeating)",ui("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){let o=-1/0;return qn(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},Kg={description:ui("Median value in a numeric dataset."),args:[Id("value1 (any, range)",ui("The first value or range to consider when calculating the median value.")),Id("value2 (any, range, repeating)",ui("Additional values or ranges to consider when calculating the median value."))],compute:function(...e){const t=[];return Pn(e,(e=>{t.push(e)}),this.locale),{value:Tg(t,{value:.5},!0,this.locale),format:mn(t[0])}},isExported:!0},Jg={description:ui("Minimum value in a numeric dataset."),args:[Id("value1 (number, range<number>)",ui("The first value or range to consider when calculating the minimum value.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to consider when calculating the minimum value."))],compute:function(...e){return xc(e,this.locale)},isExported:!0},Qg={description:ui("Minimum numeric value in a dataset."),args:[Id("value1 (number, range<number>)",ui("The first value or range to consider when calculating the minimum value.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to consider when calculating the minimum value."))],compute:function(...e){const t=Ln(e,((e,t)=>Math.min(t,e)),1/0,this.locale);return{value:t===1/0?0:t,format:mn(e[0])}},isExported:!0},ep={description:ui("Returns the minimum value in a range of cells, filtered by a set of criteria."),args:[Id("range (range)",ui("The range of cells from which the minimum will be determined.")),Id("criteria_range1 (range)",ui("The range of cells over which to evaluate criterion1.")),Id("criterion1 (string)",ui("The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.")),Id("criteria_range2 (any, range, repeating)",ui("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.")),Id("criterion2 (string, repeating)",ui("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){let o=1/0;return qn(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 tp(e,t){const{flatDataX:o,flatDataY:s}=xg(e,t);if(0===o.length||0===s.length)return new hn(er);const i=o.length;let n=0,r=0,a=0,l=0,c=0;for(let e=0;e<i;e++){const t=o[e],i=s[e];n+=t,r+=i,a+=t*i,l+=t*t,c+=i*i}return(i*a-n*r)/Math.sqrt((i*l-n*n)*(i*c-r*r))}const op={description:ui("Compute the Pearson product-moment correlation coefficient of a dataset."),args:[Id("data_y (range<number>)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (range<number>)",ui("The range representing the array or matrix of independent data."))],compute:function(e,t){return tp(e,t)},isExported:!0},sp=op,ip={description:ui("Value at a given percentile of a dataset."),args:[Id("data (any, range)",ui("The array or range containing the dataset to consider.")),Id("percentile (number)",ui("The percentile whose value within data will be calculated and returned."))],compute:function(e,t){return rp.compute.bind(this)(e,t)},isExported:!0},np={description:ui("Value at a given percentile of a dataset exclusive of 0 and 1."),args:[Id("data (any, range)",ui("The array or range containing the dataset to consider.")),Id("percentile (number)",ui("The percentile, exclusive of 0 and 1, whose value within 'data' will be calculated and returned."))],compute:function(e,t){return{value:Tg([e],t,!1,this.locale),format:mn(e)}},isExported:!0},rp={description:ui("Value at a given percentile of a dataset."),args:[Id("data (any, range)",ui("The array or range containing the dataset to consider.")),Id("percentile (number)",ui("The percentile whose value within data will be calculated and returned."))],compute:function(e,t){return{value:Tg([e],t,!0,this.locale),format:mn(e)}},isExported:!0},ap={description:ui("Compute the coefficients of polynomial regression of the dataset."),args:[Id("data_y (range<number>)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (range<number>)",ui("The range representing the array or matrix of independent data.")),Id("order (number)",ui("The order of the polynomial to fit the data, between 1 and 6."),yg),Id("intercept (boolean, default=TRUE)",ui("A flag specifying whether to compute the intercept or not."),Ig)],compute:function(e,t,o,s={value:!0}){const{flatDataX:i,flatDataY:n}=xg(e,t);return 0===i.length||0===n.length?new hn(er):Tc(n,i,Sn(o,this.locale),An(s))},isExported:!1},lp={description:ui("Predict value by computing a polynomial regression of the dataset."),args:[Id("x (number, range<number>)",ui("The value(s) on the x-axis to forecast.")),Id("data_y (range<number>)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (range<number>)",ui("The range representing the array or matrix of independent data.")),Id("order (number)",ui("The order of the polynomial to fit the data, between 1 and 6."),yg),Id("intercept (boolean, default=TRUE)",ui("A flag specifying whether to compute the intercept or not."),Ig)],compute:function(e,t,o,s,i={value:!0}){const n=Sn(s,this.locale),{flatDataX:r,flatDataY:a}=xg(t,o);if(0===r.length||0===a.length)return new hn(er);const l=Tc(a,r,n,An(i)).flat();return Un(Kn(e),(e=>Dc(l,Sn(e,this.locale),n)))},isExported:!1},cp={description:ui("Value nearest to a specific quartile of a dataset."),args:[Id("data (any, range)",ui("The array or range containing the dataset to consider.")),Id("quartile_number (number)",ui("Which quartile value to return."),wg)],compute:function(e,t){return dp.compute.bind(this)(e,t)},isExported:!0},hp={description:ui("Value nearest to a specific quartile of a dataset exclusive of 0 and 4."),args:[Id("data (any, range)",ui("The array or range containing the dataset to consider.")),Id("quartile_number (number)",ui("Which quartile value, exclusive of 0 and 4, to return."),[{value:1,label:ui("First quartile (25th percentile)")},{value:2,label:ui("Median value (50th percentile)")},{value:3,label:ui("Third quartile (75th percentile)")}])],compute:function(e,t){return{value:Tg([e],{value:.25*Math.trunc(Sn(t,this.locale))},!1,this.locale),format:mn(e)}},isExported:!0},dp={description:ui("Value nearest to a specific quartile of a dataset."),args:[Id("data (any, range)",ui("The array or range containing the dataset to consider.")),Id("quartile_number (number)",ui("Which quartile value to return."),wg)],compute:function(e,t){return{value:Tg([e],{value:.25*Math.trunc(Sn(t,this.locale))},!0,this.locale),format:mn(e)}},isExported:!0},up={description:ui("Returns the rank of a specified value in a dataset."),args:[Id("value (number)",ui("The value whose rank will be determined.")),Id("data (range)",ui("The range containing the dataset to consider.")),Id("is_ascending (boolean, default=FALSE)",ui("Whether to consider the values in data in descending or ascending order."),[{value:!1,label:ui("Descending")},{value:!0,label:ui("Ascending")}])],compute:function(e,t,o={value:!1}){const s=An(o),i=Sn(e,this.locale);let n=1,r=!1;for(const e of t)for(const t of e){if("number"!=typeof t.value)continue;const e=Sn(t,this.locale);e===i?r=!0:e>i!==s&&n++}return r?n:new hn(ui("Value not found in the given data."))},isExported:!0},gp={description:ui("Compute the square of r, the Pearson product-moment correlation coefficient of a dataset."),args:[Id("data_y (range<number>)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (range<number>)",ui("The range representing the array or matrix of independent data."))],compute:function(e,t){const o=tp(e,t);if(o instanceof Error)throw o;return Math.pow(o,2)},isExported:!0},pp={description:ui("Compute the slope of the linear regression."),args:[Id("data_y (range<number>)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (range<number>)",ui("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=xg(e,t);if(0===o.length||0===s.length)return new hn(er);const[[i]]=Rc([o],[s]);return i},isExported:!0},mp={description:ui("Nth smallest element in a data set."),args:[Id("data (any, range)",ui("The array or range containing the dataset to consider.")),Id("n (number)",ui("The rank from smallest to largest of the element to return."))],compute:function(e,t){const o=Math.trunc(Sn(t?.value,this.locale)),s=[];let i,n=0;On([e],(e=>{"number"==typeof e?.value&&(i=Zn(s,e,"nextSmaller","asc",s.length,((e,t)=>e[t].value)),s.splice(i+1,0,e),n++,n>o&&(s.pop(),n--))}));const r=s.pop();return void 0===r?new rn(er):n<o?new rn(ui("Function [[FUNCTION_NAME]] parameter 2 value (%s) is out of range.",o)):r},isExported:!0},fp={description:ui("Compute the Spearman rank correlation coefficient of a dataset."),args:[Id("data_y (range<number>)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (range<number>)",ui("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=xg(t,e);if(0===o.length||0===s.length)return new hn(er);const i=o.length,n=o.map(((e,t)=>[e,s[t]]));n.sort(((e,t)=>e[0]-t[0]));for(let e=0;e<i;++e)n[e][0]=e;n.sort(((e,t)=>e[1]-t[1]));let r=0;for(let e=0;e<i;++e)r+=(n[e][0]-e)**2;return 1-6*r/(i**3-i)},isExported:!1},vp={description:ui("Standard deviation."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the sample.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the sample."))],compute:function(...e){return Math.sqrt(Ep.compute.bind(this)(...e))},isExported:!0},bp={description:ui("Standard deviation of entire population."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the population.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the population."))],compute:function(...e){return Math.sqrt(Rp.compute.bind(this)(...e))},isExported:!0},Sp={description:ui("Standard deviation."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the sample.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the sample."))],compute:function(...e){return Math.sqrt(Tp.compute.bind(this)(...e))},isExported:!0},Cp={description:ui("Standard deviation of sample (text as 0)."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the sample.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the sample."))],compute:function(...e){return Math.sqrt(Ap.compute.bind(this)(...e))},isExported:!0},yp={description:ui("Standard deviation of entire population."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the population.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the population."))],compute:function(...e){return Math.sqrt(Dp.compute.bind(this)(...e))},isExported:!0},Ip={description:ui("Standard deviation of entire population (text as 0)."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the population.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the population."))],compute:function(...e){return Math.sqrt(_p.compute.bind(this)(...e))},isExported:!0},wp={description:ui("Calculates the standard error of the predicted y-value for each x in the regression of a dataset."),args:[Id("data_y (range<number>)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (range<number>)",ui("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=xg(e,t);if(0===o.length||0===s.length)return new hn(er);return Rc([o],[s],!0,!0)[1][2]},isExported:!0},xp={description:ui("Fits points to linear trend derived via least-squares."),args:[Id("known_data_y (number, range<number>)",ui("The array or range containing dependent (y) values that are already known, used to curve fit an ideal linear trend.")),Id("known_data_x (number, range<number>, optional, default={1;2;3;...})",ui("The values of the independent variable(s) corresponding with known_data_y.")),Id("new_data_x (number, range<number>, optional, default=known_data_x)",ui("The data points to return the y values for on the ideal curve fit.")),Id("b (boolean, optional, default=TRUE)",ui("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."),Sg)],compute:function(e,t=[[]],o=[[]],s={value:!0}){return 0===e.length||0===e[0].length?new rn(tr("known_data_y")):Oc(yn(e,"known_data_y"),yn(t,"known_data_x"),yn(o,"new_data_y"),An(s))}},Ep={description:ui("Variance."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the sample.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the sample."))],compute:function(...e){return Rg(e,!0,!1,this.locale)},isExported:!0},Rp={description:ui("Variance of entire population."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the population.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the population."))],compute:function(...e){return Rg(e,!1,!1,this.locale)},isExported:!0},Tp={description:ui("Variance."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the sample.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the sample."))],compute:function(...e){return Rg(e,!0,!1,this.locale)},isExported:!0},Ap={description:ui("Variance of sample (text as 0)."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the sample.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the sample."))],compute:function(...e){return Rg(e,!0,!0,this.locale)},isExported:!0},Dp={description:ui("Variance of entire population."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the population.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the population."))],compute:function(...e){return Rg(e,!1,!1,this.locale)},isExported:!0},_p={description:ui("Variance of entire population (text as 0)."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the population.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the population."))],compute:function(...e){return Rg(e,!1,!0,this.locale)},isExported:!0};var Fp=Object.freeze({__proto__:null,AVEDEV:Ag,AVERAGE:Dg,AVERAGEA:Pg,AVERAGEIF:Mg,AVERAGEIFS:Ng,AVERAGE_WEIGHTED:Og,CORREL:sp,COUNT:kg,COUNTA:Lg,COVAR:Vg,COVARIANCE_P:Ug,COVARIANCE_S:Hg,FORECAST:zg,GROWTH:Bg,INTERCEPT:$g,LARGE:Gg,LINEST:Wg,LOGEST:qg,MATTHEWS:Zg,MAX:jg,MAXA:Yg,MAXIFS:Xg,MEDIAN:Kg,MIN:Jg,MINA:Qg,MINIFS:ep,PEARSON:op,PERCENTILE:ip,PERCENTILE_EXC:np,PERCENTILE_INC:rp,POLYFIT_COEFFS:ap,POLYFIT_FORECAST:lp,QUARTILE:cp,QUARTILE_EXC:hp,QUARTILE_INC:dp,RANK:up,RSQ:gp,SLOPE:pp,SMALL:mp,SPEARMAN:fp,STDEV:vp,STDEVA:Cp,STDEVP:yp,STDEVPA:Ip,STDEV_P:bp,STDEV_S:Sp,STEYX:wp,TREND:xp,VAR:Ep,VARA:Ap,VARP:Dp,VARPA:_p,VAR_P:Rp,VAR_S:Tp});function Op(e,t,o,s){const i=new Map,n=e.length;for(let t=n-1;t>=0;t--)i.set(En(e[t][0]).toUpperCase(),t);const r=t?.value;if("number"!=typeof r&&"string"!=typeof r)throw new rn(ui("The field must be a number or a string"));let a;if("number"==typeof r){if(a=Math.trunc(r)-1,a<0||n-1<a)throw new rn(ui("The field (%(fieldValue)s) must be one of %(dimRowDB)s or must be a number between 1 and %s inclusive.",{fieldValue:r.toString(),dimRowDB:n.toString()}))}else{const e=En(t).toUpperCase();if(a=i.get(e)??-1,-1===a)throw new rn(ui("The field (%s) must be one of %s.",En(t),[...i.keys()].toString()))}const l=o[0].length;if(l<2)throw new rn(ui("The criteria range contains %s row, it must be at least 2 rows.",l.toString()));let c=new Set;const h=e[0].length;for(let t=1;t<l;t++){const n=[];let r=!0;for(let s=0;s<o.length;s++){const a=En(o[s][0]).toUpperCase(),l=i.get(a),c=o[s][t];if(null!==c.value){if(void 0===l){r=!1;break}n.push([e[l].slice(1,h)]),n.push(c)}}if(r){if(!(n.length>0)){c=new Set(Array(h-1).keys());break}qn(n,((e,t)=>{c.add(t)}),s,!0)}}const d=e[a];return[...c].map((e=>d[e+1]))}const Pp=[Id("database (range)",ui("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.")),Id("field (number, string)",ui("Indicates which column in database contains the values to be extracted and operated on.")),Id("criteria (range)",ui("An array or range containing zero or more criteria to filter the database values by before operating."))],Mp={description:ui("Average of a set of values from a table-like range."),args:Pp,compute:function(e,t,o){const s=Op(e,t,o,this.locale);return Dg.compute.bind(this)([s])},isExported:!0},Np={description:ui("Counts values from a table-like range."),args:Pp,compute:function(e,t,o){const s=Op(e,t,o,this.locale);return kg.compute.bind(this)([s])},isExported:!0},kp={description:ui("Counts values and text from a table-like range."),args:Pp,compute:function(e,t,o){const s=Op(e,t,o,this.locale);return Lg.compute.bind(this)([s])},isExported:!0},Lp={description:ui("Single value from a table-like range."),args:Pp,compute:function(e,t,o){const s=Op(e,t,o,this.locale);return 1!==s.length?new rn(ui("More than one match found in DGET evaluation.")):s[0]},isExported:!0},Vp={description:ui("Maximum of values from a table-like range."),args:Pp,compute:function(e,t,o){const s=Op(e,t,o,this.locale);return jg.compute.bind(this)([s])},isExported:!0},Up={description:ui("Minimum of values from a table-like range."),args:Pp,compute:function(e,t,o){const s=Op(e,t,o,this.locale);return Jg.compute.bind(this)([s])},isExported:!0},Hp={description:ui("Product of values from a table-like range."),args:Pp,compute:function(e,t,o){const s=Op(e,t,o,this.locale);return Zu.compute.bind(this)([s])},isExported:!0},zp={description:ui("Standard deviation of population sample from table."),args:Pp,compute:function(e,t,o){const s=Op(e,t,o,this.locale);return vp.compute.bind(this)([s])},isExported:!0},Bp={description:ui("Standard deviation of entire population from table."),args:Pp,compute:function(e,t,o){const s=Op(e,t,o,this.locale);return yp.compute.bind(this)([s])},isExported:!0},$p={description:ui("Sum of values from a table-like range."),args:Pp,compute:function(e,t,o){const s=Op(e,t,o,this.locale);return hg.compute.bind(this)([s])},isExported:!0},Gp={description:ui("Variance of population sample from table-like range."),args:Pp,compute:function(e,t,o){const s=Op(e,t,o,this.locale);return Ep.compute.bind(this)([s])},isExported:!0},Wp={description:ui("Variance of a population from a table-like range."),args:Pp,compute:function(e,t,o){const s=Op(e,t,o,this.locale);return Dp.compute.bind(this)([s])},isExported:!0};var qp=Object.freeze({__proto__:null,DAVERAGE:Mp,DCOUNT:Np,DCOUNTA:kp,DGET:Lp,DMAX:Vp,DMIN:Up,DPRODUCT:Hp,DSTDEV:zp,DSTDEVP:Bp,DSUM:$p,DVAR:Gp,DVARP:Wp});const Zp=ui("The cashflow_amounts and cashflow_dates ranges must have the same dimensions."),jp=ui("There must be both positive and negative values in cashflow_amounts."),Yp=e=>ui("The cost (%s) must be positive or null.",e),Xp=e=>ui("The frequency (%s) must be one of %s",e,[1,2,4].toString()),Kp=e=>ui("The day_count_convention (%s) must be between 0 and 4 inclusive.",e),Jp=e=>ui("The depreciation factor (%s) must be strictly positive.",e),Qp=e=>ui("The discount (%s) must be strictly positive.",e),em=e=>ui("The discount (%s) must be smaller than 1.",e),tm=e=>ui("All the dates should be greater or equal to the first date in cashflow_dates (%s).",e),om=(e,t)=>ui("The first_period (%(first)s) must be smaller or equal to the last_period (%(last)s).",{first:e,last:t}),sm=e=>ui("The first_period (%s) must be strictly positive.",e),im=e=>ui("The investment (%s) must be strictly positive.",e),nm=(e,t)=>ui("The last_period (%(last)s) must be smaller or equal to the number_of_periods (%(nPeriods)s).",{last:e,nPeriods:t}),rm=e=>ui("The last_period (%s) must be strictly positive.",e),am=e=>ui("The life (%s) must be strictly positive.",e),lm=(e,t)=>ui("The maturity (%(maturity)s) must be strictly greater than the settlement (%(settlement)s).",{maturity:t,settlement:e}),cm=e=>ui("The number_of_periods (%s) must be strictly positive.",e),hm=e=>ui("The period must be between 1 and number_of_periods (%s)",e),dm=e=>ui("The periods_by_year (%s) must be strictly positive.",e),um=(e,t)=>ui("The period (%(period)s) must be less than or equal life (%(life)s).",{period:e,life:t}),gm=e=>ui("The period (%s) must be strictly positive.",e),pm=e=>ui("The present_value (%s) must be strictly positive.",e),mm=e=>ui("The price (%s) must be strictly positive.",e),fm=e=>ui("The rate_guess (%s) must be strictly greater than -1.",e),vm=e=>ui("The rate (%s) must be positive or null.",e),bm=e=>ui("The rate (%s) must be strictly positive.",e),Sm=e=>ui("The redemption (%s) must be strictly positive.",e),Cm=e=>ui("The salvage (%s) must be positive or null.",e),ym=(e,t)=>ui("The settlement date (%(settlement)s) must at most one year after the maturity date (%(maturity)s).",{settlement:e,maturity:t}),Im=e=>ui("The unit (%s) must be strictly positive.",e),wm=e=>ui("The yield (%s) must be positive or null.",e);function xm(e){return e.some((e=>e>0))&&e.some((e=>e<0))}function Em(e){return![0,1,2,3,4].includes(e)}function Rm(e){return![1,2,4].includes(e)}function Tm(e,t,o){const s=Dn(e,o),i=Dn(t,o),n=Dn(e,o);return n.setFullYear(s.getFullYear()+1),i.getTime()<=n.getTime()}const Am=[{value:0,label:ui("US (NASD) 30/360")},{value:1,label:ui("Actual/Actual")},{value:2,label:ui("Actual/360")},{value:3,label:ui("Actual/365")},{value:4,label:ui("European 30/360")}];var Dm;!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"}(Dm||(Dm={}));const _m={description:ui("Converts year/month/day into a date."),args:[Id("year (number)",ui("The year component of the date.")),Id("month (number)",ui("The month component of the date.")),Id("day (number)",ui("The day component of the date."))],compute:function(e,t,o){let s=Math.trunc(Sn(e,this.locale));const i=Math.trunc(Sn(t,this.locale)),n=Math.trunc(Sn(o,this.locale));if(s<0||s>9999)return new rn(ui("The year (%s) must be between 0 and 9999 inclusive.",s.toString()));s<1900&&(s+=1900);const r=Hi(new Ii(s,i-1,n));return r<0?new rn(ui("The function [[FUNCTION_NAME]] result must be greater than or equal 01/01/1900.")):{value:r,format:this.locale.dateFormat}},isExported:!0},Fm={description:ui("Calculates the number of days, months, or years between two dates."),args:[Id("start_date (date)",ui("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.")),Id("end_date (date)",ui("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.")),Id("unit (string)",ui("A text abbreviation for unit of time."),[{value:"Y",label:ui("The number of whole years between start_date and end_date")},{value:"M",label:ui("The number of whole months between start_date and end_date")},{value:"D",label:ui("The number of days between start_date and end_date")},{value:"MD",label:ui("The number of days between start_date and end_date after subtracting whole months")},{value:"YM",label:ui("The number of whole months between start_date and end_date after subtracting whole years")},{value:"YD",label:ui("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=En(o).toUpperCase();if(!Object.values(Dm).includes(s))return new rn(((e,t)=>{const o=e.map((e=>`'${e}'`)).join(", ");return ui("The function [[FUNCTION_NAME]] has an argument with value '%s'. It should be one of: %s.",t,o)})(Object.values(Dm),En(o)));const i=Math.trunc(Sn(e,this.locale)),n=Math.trunc(Sn(t,this.locale)),r=Ui(i),a=Ui(n);if(n<i)return new rn(ui("start_date (%s) should be on or before end_date (%s).",r.toLocaleDateString(),a.toLocaleDateString()));switch(s){case Dm.WHOLE_YEARS:return Yi(r,a);case Dm.WHOLE_MONTHS:return Zi(r,a);case Dm.WHOLE_DAYS:return ji(r,a);case Dm.MONTH_WITHOUT_WHOLE_YEARS:return Zi(r,a)-12*Yi(r,a);case Dm.DAYS_WITHOUT_WHOLE_MONTHS:let e=a.getDate()-r.getDate();if(e<0){e=Bi(new Ii(a.getFullYear(),a.getMonth()-1,1))-Math.abs(e)}return e;case Dm.DAYS_BETWEEN_NO_MORE_THAN_ONE_YEAR:{if(function(e,t){return qi(e,t,1)<1}(i,n))return ji(r,a);const e=new Ii(r.getFullYear(),a.getMonth(),a.getDate());let t=ji(r,e);return t<0&&(e.setFullYear(r.getFullYear()+1),t=ji(r,e)),t}}},isExported:!0},Om={description:ui("Converts a date string to a date value."),args:[Id("date_string (string)",ui("The string representing the date."))],compute:function(e){const t=En(e),o=Vi(t,this.locale);return null===o?new rn(ui("The date_string (%s) cannot be parsed to date/time.",t.toString())):Math.trunc(o.value)},isExported:!0},Pm={description:ui("Day of the month that a specific date falls on."),args:[Id("date (string)",ui("The date from which to extract the day."))],compute:function(e){return Dn(e,this.locale).getDate()},isExported:!0},Mm={description:ui("Number of days between two dates."),args:[Id("end_date (date)",ui("The end of the date range.")),Id("start_date (date)",ui("The start of the date range."))],compute:function(e,t){const o=Dn(e,this.locale),s=Dn(t,this.locale),i=o.getTime()-s.getTime();return Math.round(i/xi)},isExported:!0},Nm={description:ui("Number of days between two dates on a 360-day year (months of 30 days)."),args:[Id("start_date (date)",ui("The start date to consider in the calculation.")),Id("end_date (date)",ui("The end date to consider in the calculation.")),Id("method (boolean, default=false)",ui("An indicator of what day count method to use."),[{value:!1,label:ui("U.S. NASD method (default)")},{value:!0,label:ui("European method")}])],compute:function(e,t,o={value:false}){const s=Math.trunc(Sn(e,this.locale)),i=Math.trunc(Sn(t,this.locale)),n=qi(s,i,An(o)?4:0);return Math.sign(i-s)*Math.round(360*n)},isExported:!0},km={description:ui("Date a number of months before/after another date."),args:[Id("start_date (date)",ui("The date from which to calculate the result.")),Id("months (number)",ui("The number of months before (negative) or after (positive) 'start_date' to calculate."))],compute:function(e,t){return{value:Hi(Gi(Dn(e,this.locale),Math.trunc(Sn(t,this.locale)),!1)),format:this.locale.dateFormat}},isExported:!0},Lm={description:ui("Last day of a month before or after a date."),args:[Id("start_date (date)",ui("The date from which to calculate the result.")),Id("months (number)",ui("The number of months before (negative) or after (positive) 'start_date' to consider."))],compute:function(e,t){const o=Dn(e,this.locale),s=Math.trunc(Sn(t,this.locale)),i=o.getFullYear(),n=o.getMonth();return{value:Hi(new Ii(i,n+s+1,0)),format:this.locale.dateFormat}},isExported:!0},Vm={description:ui("Hour component of a specific time."),args:[Id("time (date)",ui("The time from which to calculate the hour component."))],compute:function(e){return Dn(e,this.locale).getHours()},isExported:!0},Um={description:ui("ISO week number of the year."),args:[Id("date (date)",ui("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=Dn(e,this.locale),o=t.getFullYear();let s=1;for(;4!==new Ii(o,0,s).getDay();)s+=1;const i=new Ii(o,0,s-3);let n=31;for(;4!==new Ii(o,11,n).getDay();)n-=1;const r=new Ii(o,11,n+3);let a,l;switch(a=i.getTime()<=t.getTime()?t.getTime()<=r.getTime()?0:1:-1,a){case 0:l=i;break;case 1:l=new Ii(o,11,n+3+1);break;case-1:let e=1;for(;4!==new Ii(o-1,0,e).getDay();)e+=1;l=new Ii(o-1,0,e-3)}const c=(t.getTime()-l.getTime())/xi;return Math.floor(c/7)+1},isExported:!0},Hm={description:ui("Minute component of a specific time."),args:[Id("time (date)",ui("The time from which to calculate the minute component."))],compute:function(e){return Dn(e,this.locale).getMinutes()},isExported:!0},zm={description:ui("Month of the year a specific date falls in"),args:[Id("date (date)",ui("The date from which to extract the month."))],compute:function(e){return Dn(e,this.locale).getMonth()+1},isExported:!0},Bm={description:ui("Net working days between two provided days."),args:[Id("start_date (date)",ui("The start date of the period from which to calculate the number of net working days.")),Id("end_date (date)",ui("The end date of the period from which to calculate the number of net working days.")),Id("holidays (date, range<date>, optional)",ui("A range or array constant containing the date serial numbers to consider holidays."))],compute:function(e,t,o){return Wm.compute.bind(this)(e,t,{value:1},o)},isExported:!0};function $m(e){const t=e?.value;if("string"==typeof t){rc(7===t.length&&[...t].every((e=>"0"===e||"1"===e)),ui('When weekend is a string (%s) it must be composed of "0" or "1".',t));const e=[];for(let o=0;o<7;o++)"1"===t[o]&&e.push((o+1)%7);return e}if("number"==typeof t)return rc(1<=t&&t<=7||11<=t&&t<=17,ui("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 rn(ui("The weekend must be a number or a string."))}const Gm=[{value:1,label:ui("Saturday/Sunday are weekends")},{value:2,label:ui("Sunday/Monday are weekends")},{value:3,label:ui("Monday/Tuesday are weekends")},{value:4,label:ui("Tuesday/Wednesday are weekends")},{value:5,label:ui("Wednesday/Thursday are weekends")},{value:6,label:ui("Thursday/Friday are weekends")},{value:7,label:ui("Friday/Saturday are weekends")},{value:11,label:ui("Sunday is the only weekend")},{value:12,label:ui("Monday is the only weekend")},{value:13,label:ui("Tuesday is the only weekend")},{value:14,label:ui("Wednesday is the only weekend")},{value:15,label:ui("Thursday is the only weekend")},{value:16,label:ui("Friday is the only weekend")},{value:17,label:ui("Saturday is the only weekend")}],Wm={description:ui("Net working days between two dates (specifying weekends)."),args:[Id("start_date (date)",ui("The start date of the period from which to calculate the number of net working days.")),Id("end_date (date)",ui("The end date of the period from which to calculate the number of net working days.")),Id("weekend (any, default=1)",ui("A number or string representing which days of the week are considered weekends."),Gm),Id("holidays (date, range<date>, optional)",ui("A range or array constant containing the dates to consider as holidays."))],compute:function(e,t,o={value:1},s){const i=Dn(e,this.locale),n=Dn(t,this.locale),r=$m(o),a=new Set;void 0!==s&&On([s],(e=>{const t=Dn(e,this.locale);a.add(t.getTime())}));const l=i.getTime()>n.getTime(),c=Ii.fromTimestamp((l?i:n).getTime()),h=Ii.fromTimestamp((l?n:i).getTime()),d=c.getTime();let u=h.getTime(),g=0;for(;u<=d;)r.includes(h.getDay())||a.has(u)||(g+=1),h.setDate(h.getDate()+1),u=h.getTime();return l?-g:g},isExported:!0},qm={description:ui("Current date and time as a date value."),args:[],compute:function(){const e=Ii.now(),t=e.getTime()-wi.getTime(),o=e.getHours()/24+e.getMinutes()/1440+e.getSeconds()/86400;return{value:Math.floor(t/xi)+o,format:tc(this.locale)}},isExported:!0},Zm={description:ui("Minute component of a specific time."),args:[Id("time (date)",ui("The time from which to calculate the second component."))],compute:function(e){return Dn(e,this.locale).getSeconds()},isExported:!0},jm={description:ui("Converts hour/minute/second into a time."),args:[Id("hour (number)",ui("The hour component of the time.")),Id("minute (number)",ui("The minute component of the time.")),Id("second (number)",ui("The second component of the time."))],compute:function(e,t,o){let s=Math.trunc(Sn(e,this.locale)),i=Math.trunc(Sn(t,this.locale)),n=Math.trunc(Sn(o,this.locale));return i+=Math.floor(n/60),n=n%60+(n<0?60:0),s+=Math.floor(i/60),i=i%60+(i<0?60:0),s%=24,s<0?new rn(ui("The function [[FUNCTION_NAME]] result cannot be negative")):{value:s/24+i/1440+n/86400,format:this.locale.timeFormat}},isExported:!0},Ym={description:ui("Converts a time string into its serial number representation."),args:[Id("time_string (string)",ui("The string that holds the time representation."))],compute:function(e){const t=En(e),o=Vi(t,this.locale);if(null===o)return new rn(ui("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},Xm={description:ui("Current date as a date value."),args:[],compute:function(){const e=Ii.now();return{value:Hi(new Ii(e.getFullYear(),e.getMonth(),e.getDate())),format:this.locale.dateFormat}},isExported:!0},Km={description:ui("Day of the week of the date provided (as number)."),args:[Id("date (date)",ui("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.")),Id("type (number, default=1)",ui("A number indicating which numbering system to use to represent weekdays. By default, counts starting with Sunday = 1."),[{value:1,label:ui("Numbers 1 (Sunday) trough 7 (Saturday)")},{value:2,label:ui("Numbers 1 (Monday) trough 7 (Sunday)")},{value:3,label:ui("Numbers 0 (Monday) trough 6 (Sunday)")},{value:11,label:ui("Numbers 1 (Monday) trough 7 (Sunday)")},{value:12,label:ui("Numbers 1 (Tuesday) trough 7 (Monday)")},{value:13,label:ui("Numbers 1 (Wednesday) trough 7 (Tuesday)")},{value:14,label:ui("Numbers 1 (Thursday) trough 7 (Wednesday)")},{value:15,label:ui("Numbers 1 (Friday) trough 7 (Thursday)")},{value:16,label:ui("Numbers 1 (Saturday) trough 7 (Friday)")},{value:17,label:ui("Numbers 1 (Sunday) trough 7 (Saturday)")}])],compute:function(e,t={value:1}){const o=Dn(e,this.locale),s=Math.round(Sn(t,this.locale)),i=o.getDay();if(!(1<=s&&s<=3||11<=s&&s<=17))return new rn(ui("The type (%s) must be between 1 and 3 or between 11 and 17.",s));switch(s){case 1:return i+1;case 2:return 0===i?7:i;case 3:return 0===i?6:i-1}const n=(i+1-(s-10)+7)%7;return 0===n?7:n},isExported:!0},Jm={description:ui("Week number of the year."),args:[Id("date (date)",ui("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.")),Id("type (number, default=1)",ui("A number representing the day that a week starts on. Sunday = 1."),[{value:1,label:ui("Sunday")},{value:2,label:ui("Monday")},{value:11,label:ui("Monday")},{value:12,label:ui("Tuesday")},{value:13,label:ui("Wednesday")},{value:14,label:ui("Thursday")},{value:15,label:ui("Friday")},{value:16,label:ui("Saturday")},{value:17,label:ui("Sunday")},{value:21,label:ui("ISO week number (Monday as first day of the week)")}])],compute:function(e,t={value:1}){const o=Dn(e,this.locale),s=Math.round(Sn(t,this.locale));if(![1,2,11,12,13,14,15,16,17,21].includes(s))return new rn(ui("The type (%s) is out of range.",s.toString()));if(21===s)return Um.compute.bind(this)(e);let i;i=1===s||2===s?s-1:s-10==7?0:s-10;const n=o.getFullYear();let r=1,a=new Ii(n,0,r);for(;a.getDay()!==i;)r+=1,a=new Ii(n,0,r);const l=(o.getTime()-a.getTime())/xi;return l<0?1:Math.floor(l/7)+(1===r?1:2)},isExported:!0},Qm={description:ui("Date after a number of workdays."),args:[Id("start_date (date)",ui("The date from which to begin counting.")),Id("num_days (number)",ui("The number of working days to advance from start_date. If negative, counts backwards.")),Id("holidays (date, range<date>, optional)",ui("A range or array constant containing the dates to consider holidays."))],compute:function(e,t,o={value:null}){return ef.compute.bind(this)(e,t,{value:1},o)},isExported:!0},ef={description:ui("Date after a number of workdays (specifying weekends)."),args:[Id("start_date (date)",ui("The date from which to begin counting.")),Id("num_days (number)",ui("The number of working days to advance from start_date. If negative, counts backwards.")),Id("weekend (any, default=1)",ui("A number or string representing which days of the week are considered weekends."),Gm),Id("holidays (date, range<date>, optional)",ui("A range or array constant containing the dates to consider holidays."))],compute:function(e,t,o={value:1},s){const i=Dn(e,this.locale),n=Math.trunc(Sn(t,this.locale));if("1111111"===o.value)return new rn(ui("The weekend must be different from '1111111'."));const r=$m(o),a=new Set;void 0!==s&&On([s],(e=>{const t=Dn(e,this.locale);a.add(t.getTime())}));const l=Ii.fromTimestamp(i.getTime());let c=l.getTime();const h=Math.sign(n);let d=Math.abs(n);for(;d>0;)l.setDate(l.getDate()+h),c=l.getTime(),r.includes(l.getDay())||a.has(c)||(d-=1);const u=c-wi.getTime();return{value:Math.round(u/xi),format:this.locale.dateFormat}},isExported:!0},tf={description:ui("Year specified by a given date."),args:[Id("date (date)",ui("The date from which to extract the year."))],compute:function(e){return Dn(e,this.locale).getFullYear()},isExported:!0},of={description:ui("Exact number of years between two dates."),args:[Id("start_date (date)",ui("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.")),Id("end_date (date)",ui("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.")),Id("day_count_convention (number, default=0)",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o={value:0}){const s=Math.trunc(Sn(e,this.locale)),i=Math.trunc(Sn(t,this.locale)),n=Math.trunc(Sn(o,this.locale));return s<0?new rn(ui("The start_date (%s) must be positive or null.",s)):i<0?new rn(ui("The end_date (%s) must be positive or null.",i)):0>n||n>4?new rn(ui("The day_count_convention (%s) must be between 0 and 4 inclusive.",n)):qi(s,i,n)}},sf={description:ui("First day of the month preceding a date."),args:[Id("date (date)",ui("The date from which to calculate the result."))],compute:function(e){const t=Dn(e,this.locale),o=t.getFullYear(),s=t.getMonth();return{value:Hi(new Ii(o,s,1)),format:this.locale.dateFormat}}},nf={description:ui("Last day of the month following a date."),args:[Id("date (date)",ui("The date from which to calculate the result."))],compute:function(e){return Lm.compute.bind(this)(e,{value:0})}},rf={description:ui("Quarter of the year a specific date falls in"),args:[Id("date (date)",ui("The date from which to extract the quarter."))],compute:function(e){return Math.ceil((Dn(e,this.locale).getMonth()+1)/3)}},af={description:ui("First day of the quarter of the year a specific date falls in."),args:[Id("date (date)",ui("The date from which to calculate the start of quarter."))],compute:function(e){const t=rf.compute.bind(this)(e),o=tf.compute.bind(this)(e);return{value:Hi(new Ii(o,3*(t-1),1)),format:this.locale.dateFormat}}},lf={description:ui("Last day of the quarter of the year a specific date falls in."),args:[Id("date (date)",ui("The date from which to calculate the end of quarter."))],compute:function(e){const t=rf.compute.bind(this)(e),o=tf.compute.bind(this)(e);return{value:Hi(new Ii(o,3*t,0)),format:this.locale.dateFormat}}},cf={description:ui("First day of the year a specific date falls in."),args:[Id("date (date)",ui("The date from which to calculate the start of the year."))],compute:function(e){const t=tf.compute.bind(this)(e);return{value:Hi(new Ii(t,0,1)),format:this.locale.dateFormat}}},hf={description:ui("Last day of the year a specific date falls in."),args:[Id("date (date)",ui("The date from which to calculate the end of the year."))],compute:function(e){const t=tf.compute.bind(this)(e);return{value:Hi(new Ii(t+1,0,0)),format:this.locale.dateFormat}}};var df=Object.freeze({__proto__:null,DATE:_m,DATEDIF:Fm,DATEVALUE:Om,DAY:Pm,DAYS:Mm,DAYS360:Nm,EDATE:km,EOMONTH:Lm,HOUR:Vm,ISOWEEKNUM:Um,MINUTE:Hm,MONTH:zm,MONTH_END:nf,MONTH_START:sf,NETWORKDAYS:Bm,NETWORKDAYS_INTL:Wm,NOW:qm,QUARTER:rf,QUARTER_END:lf,QUARTER_START:af,SECOND:Zm,TIME:jm,TIMEVALUE:Ym,TODAY:Xm,WEEKDAY:Km,WEEKNUM:Jm,WORKDAY:Qm,WORKDAY_INTL:ef,YEAR:tf,YEARFRAC:of,YEAR_END:hf,YEAR_START:cf});const uf={description:ui("Compare two numeric values, returning 1 if they're equal."),args:[Id("number1 (number)",ui("The first number to compare.")),Id("number2 (number, default=0)",ui("The second number to compare."))],compute:function(e,t={value:0}){return Sn(e,this.locale)===Sn(t,this.locale)?1:0},isExported:!0};var gf=Object.freeze({__proto__:null,DELTA:uf});const pf=[r.number,r.error,r.text,r.boolean];function mf(e){const t="asc"===e?1:-1;return(e,o)=>{if(e.type===r.empty)return o.type===r.empty?0:1;if(o.type===r.empty)return-1;let s=pf.indexOf(e.type)-pf.indexOf(o.type);return 0===s&&(s=e.type===r.text||e.type===r.error?e.value.localeCompare(o.value):e.value-o.value),t*s}}function ff(e,t,o,s,i){let n=s.right>s.left;if(e.model.getters.doesIntersectMerge(t,s)){let o;n=!1;for(let i=s.top;i<=s.bottom;i++){o=[];for(let n=s.left;n<=s.right;n++){const s=e.model.getters.getMerge({sheetId:t,col:n,row:i});s&&!o.includes(s.id.toString())&&o.push(s.id.toString())}if(o.length>=2){n=!0;break}}}if(n)return void vf(e,t,o,s,i);const r=e.model.getters.getContiguousZone(t,s);Ko(r,s)?vf(e,t,o,s,i):e.askConfirmation(ui("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?"),(()=>vf(e,t,o,r,i)),(()=>vf(e,t,o,s,i)))}function vf(e,t,o,s,i,n){const r=e.model.dispatch("SORT_CELLS",{sheetId:t,col:o.col,row:o.row,zone:s,sortDirection:i,sortOptions:n});if(r.isCancelledBecause("InvalidSortZone")){const{col:t,row:i}=o;e.model.selection.selectZone({cell:{col:t,row:i},zone:s}),e.raiseError(ui("Cannot sort. To sort, select only cells or only merges that have the same size."))}if(r.isCancelledBecause("SortZoneWithArrayFormulas")){const{col:t,row:i}=o;e.model.selection.selectZone({cell:{col:t,row:i},zone:s}),e.raiseError(ui("Cannot sort a zone with array formulas."))}}function bf(e,t,...o){for(let e=0;e<o.length;e++){const t=e%2==0?"sort_column":"is_ascending";rc(void 0!==o[e],ui("Value for parameter %s is missing in [[FUNCTION_NAME]].",t))}const s=[],i=[],n=e.length;for(let r=0;r<o.length;r+=2){s.push(An(fc(o[r+1])?.value)?"asc":"desc");const a=o[r];if(E(a)&&(a.length>1||a[0].length>1))rc(1===a.length&&a[0].length===n,ui("Wrong size for %s. Expected a range of size 1x%s. Got %sx%s.",`sort_column${r+1}`,n,a.length,a[0].length)),i.push(a.flat().map((e=>e.value)));else{const o=Sn(fc(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 a={desc:mf("desc"),asc:mf("asc")},l=Ct(0,e.length);return l.sort(((e,t)=>{for(const[o,n]of i.entries()){const i=n[e],l=n[t],c={value:i,type:null===i?r.empty:"string"==typeof i?r.text:typeof i},h={value:l,type:null===l?r.empty:"string"==typeof l?r.text:typeof l},d=a[s[o]](c,h);if(0!==d)return d}return 0})),l.map((t=>e[t]))}const Sf={description:ui("Returns a filtered version of the source range, returning only rows or columns that meet the specified conditions."),args:[Id("range (any, range<any>)",ui("The data to be filtered.")),Id("condition1 (boolean, range<boolean>)",ui("A column or row containing true or false values corresponding to the first column or row of range.")),Id("condition2 (boolean, range<boolean>, repeating)",ui("Additional column or row containing true or false values."))],compute:function(e,...t){let o=Kn(e);const s=t.map((e=>Un(Kn(e),(e=>e.value))));for(const e of s)if(!lc(e))return new rn(ui("The arguments condition must be a single column or row."));if(!cc(...t))return new rn(ui("The arguments conditions must have the same dimensions."));const i=s.map((e=>e.flat())),n=1===s[0].length?"row":"col";if(o="row"===n?Hn(o):o,i.some((e=>e.length!==o.length)))return new rn(ui("FILTER has mismatched sizes on the range and conditions."));const r=[];for(let e=0;e<o.length;e++){const t=o[e];i.every((t=>("boolean"==typeof t[e]||"number"==typeof t[e])&&t[e]))&&r.push(t)}return r.length?"row"===n?Hn(r):r:new hn(ui("No match found in FILTER evaluation"))},isExported:!1},Cf={description:ui("Sorts the rows of a given array or range by the values in one or more columns."),args:[Id("range (range)",ui("The data to be sorted.")),Id("sort_column (any, range<number>, repeating)",ui("The index of the column in range or a range outside of range containing the values by which to sort.")),Id("is_ascending (boolean, repeating)",ui("TRUE or FALSE indicating whether to sort sort_column in ascending order."),[{value:!0,label:ui("Ascending")},{value:!1,label:ui("Descending")}])],compute:function(e,...t){const o=Hn(e);return Hn(bf(o,this.locale,...t))},isExported:!0},yf={description:ui("Returns the first n items in a data set after performing a sort."),args:[Id("range (range)",ui("The data to be sorted.")),Id("n (number)",ui("The number of items to return.")),Id("display_ties_mode (number, default=0)",ui("A number representing the way to display ties.")),Id("sort_column (number, range<number>, repeating)",ui("The index of the column in range or a range outside of range containing the values by which to sort.")),Id("is_ascending (boolean, repeating)",ui("TRUE or FALSE indicating whether to sort sort_column in ascending order."),[{value:!0,label:ui("Ascending")},{value:!1,label:ui("Descending")}])],compute:function(e,t,...o){const s=Sn(t?.value??1,this.locale),i=o.length%2==0?0:Sn(o[0]?.value,this.locale),n=o.length%2==0?o:o.slice(1);if(s<0)return new rn(ui("Wrong value of 'n'. Expected a positive number. Got %s.",s));if(i<0||i>3)return new rn(ui("Wrong value of 'display_ties_mode'. Expected a positive number between 0 and 3. Got %s.",i));const r=bf(Hn(e),this.locale,...n),a=(e,t)=>JSON.stringify(r[e].map((e=>e.value)))===JSON.stringify(r[t].map((e=>e.value)));switch(i){case 0:return Hn(r.slice(0,s));case 1:for(let e=s;e<r.length;e++)if(!a(e,s-1))return Hn(r.slice(0,e));return Hn(r);case 2:{const e=[r[0]];for(let t=1;t<r.length;t++)for(let o=0;o<t&&!a(t,o);o++)o===t-1&&e.push(r[t]);return Hn(e.slice(0,s))}case 3:{const e=[r[0]];let t=1;for(let o=1;o<r.length&&(a(o,o-1)||t++,!(t>s));o++)e.push(r[o]);return Hn(e)}}},isExported:!1},If={description:ui("Unique rows in the provided source range."),args:[Id("range (any, range<any>)",ui("The data to filter by unique entries.")),Id("by_column (boolean, default=FALSE)",ui("Whether to filter the data by columns or by rows."),[{value:!0,label:ui("Return unique columns")},{value:!1,label:ui("Return unique rows")}]),Id("exactly_once (boolean, default=FALSE)",ui("Whether to return only entries with no duplicates."),[{value:!0,label:ui("Return items that appear exactly once")},{value:!1,label:ui("Return every distinct item")}])],compute:function(e={value:""},t,o){if(!E(e))return[[e]];const s=An(t?.value)||!1,i=An(o?.value)||!1;s||(e=Hn(e));const n=new Map;for(const t of e){const e=JSON.stringify(t.map((e=>e.value))),o=n.get(e);o?o.count++:n.set(e,{data:t,count:1})}const r=[];for(const e of n.values())i&&e.count>1||r.push(e.data);return r.length?s?r:Hn(r):new rn(ui("No unique values found"))},isExported:!0};var wf=Object.freeze({__proto__:null,FILTER:Sf,SORT:Cf,SORTN:yf,UNIQUE:If});const xf=[{value:1,label:ui("Annual")},{value:2,label:ui("Semi-annual")},{value:4,label:ui("Quarterly")}],Ef=[{value:0,label:ui("End of period (default)")},{value:1,label:ui("Beginning of period")}],Rf=[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("frequency (number)",ui("The number of interest or coupon payments per year (1, 2, or 4)."),xf),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."),Am)];function Tf(e,t,o,s,i=1e-10,n){let r,a,l,c,h=o,d=!1,u=0;do{l=e(h),isNaN(l)?(rc(u<s&&void 0!==n,ui("Function [[FUNCTION_NAME]] didn't find any result.")),u++,h=n(c),c=h):(r=h-l/t(h),a=Math.abs(r-h),h=r,d=a<i||Math.abs(l)<i,rc(u<s,ui("Function [[FUNCTION_NAME]] didn't find any result.")),u++)}while(!d);return h}const Af={description:ui("Accrued interest of security paying at maturity."),args:[Id("issue (date)",ui("The date the security was initially issued.")),Id("maturity (date)",ui("The maturity date of the security.")),Id("rate (number)",ui("The annualized rate of interest.")),Id("redemption (number)",ui("The redemption amount per 100 face value, or par.")),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o,s,i={value:0}){const n=Math.trunc(Sn(e,this.locale)),r=Math.trunc(Sn(t,this.locale)),a=Sn(s,this.locale),l=Sn(o,this.locale),c=Math.trunc(Sn(i,this.locale));if(n<0)return new rn((e=>ui("The issue (%s) must be positive or null.",e))(n));if(n>=r)return new rn(lm(n,r));if(Em(c))return new rn(Kp(c));if(a<=0)return new rn(Sm(a));if(l<=0)return new rn(bm(l));return a*l*qi(n,r,c)},isExported:!0},Df={description:ui("Depreciation for an accounting period."),args:[Id("cost (number)",ui("The initial cost of the asset.")),Id("purchase_date (date)",ui("The date the asset was purchased.")),Id("first_period_end (date)",ui("The date the first period ended.")),Id("salvage (number)",ui("The value of the asset at the end of depreciation.")),Id("period (number)",ui("The single period within life for which to calculate depreciation.")),Id("rate (number)",ui("The deprecation rate.")),Id("day_count_convention (number, optional)",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o,s,i,n,r={value:0}){r=r||0;const a=Sn(e,this.locale),l=Math.trunc(Sn(t,this.locale)),c=Math.trunc(Sn(o,this.locale)),h=Sn(s,this.locale),d=Sn(i,this.locale),u=Sn(n,this.locale),g=Math.trunc(Sn(r,this.locale));if(a<=0)return new rn((e=>ui("The cost (%s) must be strictly positive.",e))(a));if(l<0)return new rn((e=>ui("The purchase_date (%s) must be positive or null.",e))(l));if(h<0)return new rn(Cm(h));if(h>a)return new rn(((e,t)=>ui("The salvage (%(salvage)s) must be smaller or equal than the cost (%(cost)s).",{salvage:e,cost:t}))(h,a));if(d<0)return new rn((e=>ui("The period (%s) must be positive or null.",e))(d));if(u<=0)return new rn(bm(u));if(Em(g))return new rn(Kp(g));if(l>c)return new rn(((e,t)=>ui("The purchase_date (%(purchaseDate)s) must be before the first_period_end (%(firstPeriodEnd)s).",{purchaseDate:e,firstPeriodEnd:t}))(l,c));const p=d<1&&d>0?1:Math.trunc(d),m=a*u,f=qi(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},_f={description:ui("Days in coupon period containing settlement date."),args:Rf,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Sn(e,this.locale)),n=Math.trunc(Sn(t,this.locale)),r=Math.trunc(Sn(o,this.locale)),a=Math.trunc(Sn(s,this.locale));if(i>=n)return new rn(lm(i,n));if(Rm(r))return new rn(Xp(r));if(Em(a))return new rn(Kp(a));if(1===a){const i=Nf.compute.bind(this)(e,t,o,s).value;return Sn(Pf.compute.bind(this)(e,t,o,s).value,this.locale)-Sn(i,this.locale)}return(3===a?365:360)/r},isExported:!0},Ff={description:ui("Days from settlement until next coupon."),args:Rf,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Sn(e,this.locale)),n=Math.trunc(Sn(t,this.locale)),r=Math.trunc(Sn(o,this.locale)),a=Math.trunc(Sn(s,this.locale));if(i>=n)return new rn(lm(i,n));if(Rm(r))return new rn(Xp(r));if(Em(a))return new rn(Kp(a));const l=Sn(Nf.compute.bind(this)(e,t,o,s).value,this.locale);if([1,2,3].includes(a))return i-l;if(4===a){const e=qi(l,i,a);return Math.round(360*e)}const c=Dn(i,this.locale),h=Dn(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&&$i(h)&&$i(c)&&(f=30),31!==f||30!==m&&31!==m||(f=30),2===g&&$i(h)&&(m=30),31===m&&(m=30),360*(u-d)+30*(p-g)+(f-m)},isExported:!0},Of={description:ui("Days from settlement until next coupon."),args:Rf,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Sn(e,this.locale)),n=Math.trunc(Sn(t,this.locale)),r=Math.trunc(Sn(o,this.locale)),a=Math.trunc(Sn(s,this.locale));if(i>=n)return new rn(lm(i,n));if(Rm(r))return new rn(Xp(r));if(Em(a))return new rn(Kp(a));const l=Sn(Pf.compute.bind(this)(e,t,o,s).value,this.locale);if([1,2,3].includes(a))return l-i;if(4===a){const e=qi(i,l,a);return Math.round(360*e)}const c=Ff.compute.bind(this)(e,t,o,s);return Sn(_f.compute.bind(this)(e,t,o,s),this.locale)-Sn(c,this.locale)},isExported:!0},Pf={description:ui("Next coupon date after the settlement date."),args:Rf,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Sn(e,this.locale)),n=Math.trunc(Sn(t,this.locale)),r=Math.trunc(Sn(o,this.locale)),a=Math.trunc(Sn(s,this.locale));if(i>=n)return new rn(lm(i,n));if(Rm(r))return new rn(Xp(r));if(Em(a))return new rn(Kp(a));const l=12/r,c=Mf.compute.bind(this)(e,t,o,s);return{value:Hi(Gi(Dn(n,this.locale),-(Sn(c,this.locale)-1)*l,!0)),format:this.locale.dateFormat}},isExported:!0},Mf={description:ui("Number of coupons between settlement and maturity."),args:Rf,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Sn(e,this.locale)),n=Math.trunc(Sn(t,this.locale)),r=Math.trunc(Sn(o,this.locale)),a=Math.trunc(Sn(s,this.locale));if(i>=n)return new rn(lm(i,n));if(Rm(r))return new rn(Xp(r));if(Em(a))return new rn(Kp(a));let l=1,c=n;const h=12/r;for(;c>i;)c=Hi(Gi(Dn(c,this.locale),-h,!1)),l++;return l-1},isExported:!0},Nf={description:ui("Last coupon date prior to or on the settlement date."),args:Rf,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Sn(e,this.locale)),n=Math.trunc(Sn(t,this.locale)),r=Math.trunc(Sn(o,this.locale)),a=Math.trunc(Sn(s,this.locale));if(i>=n)return new rn(lm(i,n));if(Rm(r))return new rn(Xp(r));if(Em(a))return new rn(Kp(a));const l=12/r,c=Mf.compute.bind(this)(e,t,o,s);return{value:Hi(Gi(Dn(n,this.locale),-c*l,!0)),format:this.locale.dateFormat}},isExported:!0},kf={description:ui("Cumulative interest paid over a set of periods."),args:[Id("rate (number)",ui("The interest rate.")),Id("number_of_periods (number)",ui("The number of payments to be made.")),Id("present_value (number)",ui("The current value of the annuity.")),Id("first_period (number)",ui("The number of the payment period to begin the cumulative calculation.")),Id("last_period (number)",ui("The number of the payment period to end the cumulative calculation.")),Id("end_or_beginning (number, default=0)",ui("The timing of the payment payments are due for each period."),Ef)],compute:function(e,t,o,s,i,n={value:0}){const r=Sn(s,this.locale),a=Sn(i,this.locale),l=Sn(e,this.locale),c=Sn(o,this.locale),h=Sn(t,this.locale),d=An(n)?1:0;if(h<=0)return new rn(cm(h));if(r<=0)return new rn(sm(r));if(a<=0)return new rn(rm(a));if(r>a)return new rn(om(r,a));if(a>h)return new rn(nm(a,h));if(l<=0)return new rn(bm(l));if(c<=0)return new rn(pm(c));let u=0;for(let e=r;e<=a;e++)u+=Xf(l,e,h,c,0,d);return u},isExported:!0},Lf={description:ui("Cumulative principal paid over a set of periods."),args:[Id("rate (number)",ui("The interest rate.")),Id("number_of_periods (number)",ui("The number of payments to be made.")),Id("present_value (number)",ui("The current value of the annuity.")),Id("first_period (number)",ui("The number of the payment period to begin the cumulative calculation.")),Id("last_period (number)",ui("The number of the payment period to end the cumulative calculation.")),Id("end_or_beginning (number, default=0)",ui("The timing of the payment payments are due for each period."),Ef)],compute:function(e,t,o,s,i,n={value:0}){const r=Sn(s,this.locale),a=Sn(i,this.locale),l=Sn(e,this.locale),c=Sn(o,this.locale),h=Sn(t,this.locale),d=An(n)?1:0;if(h<=0)return new rn(cm(h));if(r<=0)return new rn(sm(r));if(a<=0)return new rn(rm(a));if(r>a)return new rn(om(r,a));if(a>h)return new rn(nm(a,h));if(l<=0)return new rn(bm(l));if(c<=0)return new rn(pm(c));let u=0;for(let e=r;e<=a;e++)u+=cv(l,e,h,c,0,d);return u},isExported:!0},Vf={description:ui("Depreciation via declining balance method."),args:[Id("cost (number)",ui("The initial cost of the asset.")),Id("salvage (number)",ui("The value of the asset at the end of depreciation.")),Id("life (number)",ui("The number of periods over which the asset is depreciated.")),Id("period (number)",ui("The single period within life for which to calculate depreciation.")),Id("month (number, optional)",ui("The number of months in the first year of depreciation."))],compute:function(e,t,o,s,...i){const n=Sn(e,this.locale),r=Sn(t,this.locale),a=Sn(o,this.locale),l=Math.trunc(Sn(s,this.locale)),c=i.length?Math.trunc(Sn(i[0],this.locale)):12,h=a+(12===c?0:1);if(n<0)return new rn(Yp(n));if(r<0)return new rn(Cm(r));if(l<=0)return new rn(gm(l));if(a<=0)return new rn(am(a));if(1>c||c>12)return new rn(ui("The month (%s) must be between 1 and 12 inclusive.",c));if(l>h)return new rn(((e,t)=>ui("The period (%(period)s) must be less than or equal to %(lifeLimit)s.",{period:e,lifeLimit:t}))(l,h));const d=c/12;let u=1-Math.pow(r/n,1/a);u=Math.round(1e3*u)/1e3;let g=n,p=n*(1-u*d);for(let e=1;e<l;e++)g=p,p=g*(1-u),e===a&&(p=g*(1-u*(1-d)));return{value:g-p,format:"#,##0.00"}},isExported:!0},Uf="#,##0.00",Hf={description:ui("Depreciation via double-declining balance method."),args:[Id("cost (number)",ui("The initial cost of the asset.")),Id("salvage (number)",ui("The value of the asset at the end of depreciation.")),Id("life (number)",ui("The number of periods over which the asset is depreciated.")),Id("period (number)",ui("The single period within life for which to calculate depreciation.")),Id("factor (number, default=2)",ui("The factor by which depreciation decreases."))],compute:function(e,t,o,s,i={value:2}){const n=Sn(e,this.locale),r=Sn(t,this.locale),a=Sn(o,this.locale),l=Sn(s,this.locale),c=Sn(i,this.locale);if(n<0)return new rn(Yp(n));if(r<0)return new rn(Cm(r));if(l<=0)return new rn(gm(l));if(a<=0)return new rn(am(a));if(l>a)return new rn(um(l,a));if(c<=0)return new rn(Jp(c));if(0===n||r>=n)return{value:0,format:Uf};const h=c/a;if(h>1)return{value:1===l?n-r:0,format:Uf};if(l<=1)return{value:n*h,format:Uf};const d=n*Math.pow(1-h,l-1),u=n*Math.pow(1-h,l),g=u<r?d-r:d-u;return{value:Math.max(g,0),format:Uf}},isExported:!0},zf={description:ui("Discount rate of a security based on price."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("price (number)",ui("The price at which the security is bought per 100 face value.")),Id("redemption (number)",ui("The redemption amount per 100 face value, or par.")),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o,s,i={value:0}){i=i||0;const n=Math.trunc(Sn(e,this.locale)),r=Math.trunc(Sn(t,this.locale)),a=Sn(o,this.locale),l=Sn(s,this.locale),c=Math.trunc(Sn(i,this.locale));if(n>=r)return new rn(lm(n,r));if(Em(c))return new rn(Kp(c));if(a<=0)return new rn(mm(a));if(l<=0)return new rn(Sm(l));return(l-a)/l/qi(n,r,c)},isExported:!0},Bf={description:ui("Convert a decimal fraction to decimal value."),args:[Id("fractional_price (number)",ui("The price quotation given using fractional decimal conventions.")),Id("unit (number)",ui("The units of the fraction, e.g. 8 for 1/8ths or 32 for 1/32nds."))],compute:function(e,t){const o=Sn(e,this.locale),s=Math.trunc(Sn(t,this.locale));if(s<=0)return new rn(Im(s));const i=Math.trunc(o);return i+(o-i)*(10**Math.ceil(Math.log10(s))/s)},isExported:!0},$f={description:ui("Convert a decimal value to decimal fraction."),args:[Id("decimal_price (number)",ui("The price quotation given as a decimal value.")),Id("unit (number)",ui("The units of the desired fraction, e.g. 8 for 1/8ths or 32 for 1/32nds."))],compute:function(e,t){const o=Sn(e,this.locale),s=Math.trunc(Sn(t,this.locale));if(s<=0)return new rn(Im(s));const i=Math.trunc(o);return i+(o-i)*(s/10**Math.ceil(Math.log10(s)))},isExported:!0},Gf={description:ui("Number of periods for an investment to reach a value."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("rate (number)",ui("The annualized rate of interest.")),Id("yield (number)",ui("The expected annual yield of the security.")),Id("frequency (number)",ui("The number of interest or coupon payments per year (1, 2, or 4)."),xf),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o,s,i,n={value:0}){const r=Math.trunc(Sn(e,this.locale)),a=Math.trunc(Sn(t,this.locale)),l=Sn(o,this.locale),c=Sn(s,this.locale),h=Math.trunc(Sn(i,this.locale)),d=Math.trunc(Sn(n,this.locale));if(r>=a)return new rn(lm(r,a));if(Rm(h))return new rn(Xp(h));if(Em(d))return new rn(Kp(d));if(l<0)return new rn(vm(l));if(c<0)return new rn(wm(c));const u=qi(r,a,d),g=u-Math.trunc(u)||1/h,p=Math.ceil(u*h),m=l/h,f=c/h;let v=0,b=0;for(let e=1;e<=p;e++){const t=(m+(e===p?1:0))/(1+f)**e;b+=(g+(e-1)/h)*t,v+=t}return 0===v?0:b/v},isExported:!0},Wf={description:ui("Annual effective interest rate."),args:[Id("nominal_rate (number)",ui("The nominal interest rate per year.")),Id("periods_per_year (number)",ui("The number of compounding periods per year."))],compute:function(e,t){const o=Sn(e,this.locale),s=Math.trunc(Sn(t,this.locale));return o<=0?new rn(ui("The nominal_rate (%s) must be strictly positive.",o)):s<=0?new rn(dm(s)):Math.pow(1+o/s,s)-1},isExported:!0};function qf(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 Zf={description:ui("Future value of an annuity investment."),args:[Id("rate (number)",ui("The interest rate.")),Id("number_of_periods (number)",ui("The number of payments to be made.")),Id("payment_amount (number)",ui("The amount per period to be paid.")),Id("present_value (number, default=0)",ui("The current value of the annuity.")),Id("end_or_beginning (number, default=0)",ui("The timing of the payment payments are due for each period."),Ef)],compute:function(e,t,o,s={value:0},i={value:0}){s=s||0,i=i||0;return{value:qf(Sn(e,this.locale),Sn(t,this.locale),Sn(o,this.locale),Sn(s,this.locale),An(i)?1:0),format:"#,##0.00"}},isExported:!0},jf={description:ui("Future value of principal from series of rates."),args:[Id("principal (number)",ui("The amount of initial capital or value to compound against.")),Id("rate_schedule (number, range<number>)",ui("A series of interest rates to compound against the principal."))],compute:function(e,t){return Nn([t],((e,t)=>e*(1+Sn(t,this.locale))),Sn(e,this.locale))},isExported:!0},Yf={description:ui("Calculates effective interest rate."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("investment (number)",ui("The amount invested in the security.")),Id("redemption (number)",ui("The amount to be received at maturity.")),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o,s,i={value:0}){const n=Math.trunc(Sn(e,this.locale)),r=Math.trunc(Sn(t,this.locale)),a=Sn(s,this.locale),l=Sn(o,this.locale),c=Math.trunc(Sn(i,this.locale));if(n>=r)return new rn(lm(n,r));if(l<=0)return new rn(im(l));if(a<=0)return new rn(Sm(a));if(Em(c))return new rn(Kp(c));return(a-l)/l/qi(n,r,c)},isExported:!0};function Xf(e,t,o,s,i,n){return av(e,o,s,i,n)-cv(e,t,o,s,i,n)}const Kf={description:ui("Payment on the principal of an investment."),args:[Id("rate (number)",ui("The annualized rate of interest.")),Id("period (number)",ui("The amortization period, in terms of number of periods.")),Id("number_of_periods (number)",ui("The number of payments to be made.")),Id("present_value (number)",ui("The current value of the annuity.")),Id("future_value (number, default=0)",ui("The future value remaining after the final payment has been made.")),Id("end_or_beginning (number, default=0)",ui("The timing of the payment payments are due for each period."),Ef)],compute:function(e,t,o,s,i={value:0},n={value:0}){return{value:Xf(Sn(e,this.locale),Sn(t,this.locale),Sn(o,this.locale),Sn(s,this.locale),Sn(i,this.locale),An(n)?1:0),format:"#,##0.00"}},isExported:!0},Jf={description:ui("Internal rate of return given periodic cashflows."),args:[Id("cashflow_amounts (number, range<number>)",ui("An array or range containing the income or payments associated with the investment.")),Id("rate_guess (number, default=0.1)",ui("An estimate for what the internal rate of return will be."))],compute:function(e,t={value:.1}){const o=Sn(t,this.locale);if(o<=-1)return new rn(fm(o));let s=!1,i=!1;const n=[];if(Pn([e],(({value:e})=>{e>0&&(s=!0),e<0&&(i=!0),n.push(e)}),this.locale),!s||!i)return new rn(jp);const r=n.shift();return{value:Tf((function(e){return function(e,t,o){const s=o.length;let i=0;return o.reduce(((t,o)=>(i++,t+o*e**(s-i))),t*e**s)}(e,r,n)}),(function(e){return function(e,t,o){const s=o.length;let i=0;return o.reduce(((t,o)=>(i++,t+o*(s-i)*e**(s-i-1))),t*s*e**(s-1))}(e,r,n)}),o+1,20,1e-5)-1,format:"0%"}},isExported:!0},Qf={description:ui("Returns the interest paid at a particular period of an investment."),args:[Id("rate (number)",ui("The interest rate.")),Id("period (number)",ui("The period for which you want to view the interest payment.")),Id("number_of_periods (number)",ui("The number of payments to be made.")),Id("present_value (number)",ui("The current value of the annuity."))],compute:function(e,t,o,s){const i=Sn(e,this.locale),n=Sn(t,this.locale),r=Sn(o,this.locale),a=Sn(s,this.locale);if(0===r)return new rn(ui("The number_of_periods (%s) must be different from zero.",r));return-1*(a-a*(n/r))*i},isExported:!0},ev={description:ui("Modified Macaulay duration."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("rate (number)",ui("The annualized rate of interest.")),Id("yield (number)",ui("The expected annual yield of the security.")),Id("frequency (number)",ui("The number of interest or coupon payments per year (1, 2, or 4)."),xf),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,n={value:0}){const r=Gf.compute.bind(this)(e,t,o,s,i,n),a=Sn(s,this.locale),l=Math.trunc(Sn(i,this.locale));return Sn(r,this.locale)/(1+a/l)},isExported:!0},tv={description:ui("Modified internal rate of return."),args:[Id("cashflow_amounts (range<number>)",ui("A range containing the income or payments associated with the investment. The array should contain bot payments and incomes.")),Id("financing_rate (number)",ui("The interest rate paid on funds invested.")),Id("reinvestment_return_rate (number)",ui("The return (as a percentage) earned on reinvestment of income received from the investment."))],compute:function(e,t,o){const s=Sn(t,this.locale),i=Sn(o,this.locale),n=Hn(e).flat().filter((e=>null!==e.value)).map((e=>Sn(e,this.locale))),r=n.length;let a=0,l=0;for(const e of Ct(0,r)){const t=n[e];t>=0?a+=t*(i+1)**(r-e-1):l+=t/(s+1)**e}if(0===l||0===a)return new rn(jp);return(-a/l)**(1/(r-1))-1},isExported:!0},ov={description:ui("Annual nominal interest rate."),args:[Id("effective_rate (number)",ui("The effective interest rate per year.")),Id("periods_per_year (number)",ui("The number of compounding periods per year."))],compute:function(e,t){const o=Sn(e,this.locale),s=Math.trunc(Sn(t,this.locale));return o<=0?new rn(ui("The effective_rate (%s) must be strictly positive.",o)):s<=0?new rn(dm(s)):(Math.pow(o+1,1/s)-1)*s},isExported:!0},sv={description:ui("Number of payment periods for an investment."),args:[Id("rate (number)",ui("The interest rate.")),Id("payment_amount (number)",ui("The amount of each payment made.")),Id("present_value (number)",ui("The current value of the annuity.")),Id("future_value (number, default=0)",ui("The future value remaining after the final payment has been made.")),Id("end_or_beginning (number, default=0)",ui("The timing of the payment payments are due for each period."),Ef)],compute:function(e,t,o,s={value:0},i={value:0}){s=s||0,i=i||0;const n=Sn(e,this.locale),r=Sn(t,this.locale),a=Sn(o,this.locale),l=Sn(s,this.locale),c=An(i)?1:0;if(0===n)return-(l+a)/r;const h=r*(1+n*c)/n;return Math.log((h-l)/(a+h))/Math.log(1+n)},isExported:!0};function iv(e,t,o,s){let i=0;return kn(o,((t,o)=>(i++,t+o/(1+e)**i)),t,s)}const nv={description:ui("The net present value of an investment based on a series of periodic cash flows and a discount rate."),args:[Id("discount (number)",ui("The discount rate of the investment over one period.")),Id("cashflow1 (number, range<number>)",ui("The first future cash flow.")),Id("cashflow2 (number, range<number>, repeating)",ui("Additional future cash flows."))],compute:function(e,...t){const o=Sn(e,this.locale);return-1===o?new rn((e=>ui("The discount (%s) must be different from -1.",e))(o)):{value:iv(o,0,t,this.locale),format:"#,##0.00"}},isExported:!0},rv={description:ui("Computes the number of periods needed for an investment to reach a value."),args:[Id("rate (number)",ui("The rate at which the investment grows each period.")),Id("present_value (number)",ui("The investment's current value.")),Id("future_value (number)",ui("The investment's desired future value."))],compute:function(e,t,o){const s=Sn(e,this.locale),i=Sn(t,this.locale),n=Sn(o,this.locale);return s<=0?new rn(bm(s)):i<=0?new rn(pm(i)):n<=0?new rn(ui("The future_value (%s) must be strictly positive.",n)):(Math.log(n)-Math.log(i))/Math.log(1+s)},isExported:!0};function av(e,t,o,s,i){if(t<=0)throw new rn(cm(t));if(0===e)return-(s+o)/t;let n=-(o*(1+e)**t+s);return n=n*e/((1+e*i)*((1+e)**t-1)),n}const lv={description:ui("Periodic payment for an annuity investment."),args:[Id("rate (number)",ui("The annualized rate of interest.")),Id("number_of_periods (number)",ui("The number of payments to be made.")),Id("present_value (number)",ui("The current value of the annuity.")),Id("future_value (number, default=0)",ui("The future value remaining after the final payment has been made.")),Id("end_or_beginning (number, default=0)",ui("The timing of the payment payments are due for each period."),Ef)],compute:function(e,t,o,s={value:0},i={value:0}){const n=Sn(t,this.locale),r=Sn(e,this.locale),a=An(i)?1:0,l=Sn(s,this.locale);return{value:av(r,n,Sn(o,this.locale),l,a),format:"#,##0.00"}},isExported:!0};function cv(e,t,o,s,i,n){if(o<=0)throw new rn(cm(o));if(t<=0||t>o)throw new rn(hm(o));const r=av(e,o,s,i,n);if(1===n&&1===t)return r;return r+-qf(e,0===n?t-1:t-2,r,s+r*n,0)*e}const hv={description:ui("Payment on the principal of an investment."),args:[Id("rate (number)",ui("The annualized rate of interest.")),Id("period (number)",ui("The amortization period, in terms of number of periods.")),Id("number_of_periods (number)",ui("The number of payments to be made.")),Id("present_value (number)",ui("The current value of the annuity.")),Id("future_value (number, default=0)",ui("The future value remaining after the final payment has been made.")),Id("end_or_beginning (number, default=0)",ui("The timing of the payment payments are due for each period."),Ef)],compute:function(e,t,o,s,i={value:0},n={value:0}){const r=Sn(o,this.locale),a=Sn(e,this.locale),l=Sn(t,this.locale),c=An(n)?1:0,h=Sn(i,this.locale);return{value:cv(a,l,r,Sn(s,this.locale),h,c),format:"#,##0.00"}},isExported:!0},dv={description:ui("Present value of an annuity investment."),args:[Id("rate (number)",ui("The interest rate.")),Id("number_of_periods (number)",ui("The number of payments to be made.")),Id("payment_amount (number)",ui("The amount per period to be paid.")),Id("future_value (number, default=0)",ui("The future value remaining after the final payment has been made.")),Id("end_or_beginning (number, default=0)",ui("The timing of the payment payments are due for each period."),Ef)],compute:function(e,t,o,s={value:0},i={value:0}){s=s||0,i=i||0;const n=Sn(e,this.locale),r=Sn(t,this.locale),a=Sn(o,this.locale),l=Sn(s,this.locale),c=An(i)?1:0;return{value:n?-(a*(1+n*c)*((1+n)**r-1)/n+l)/(1+n)**r:-(l+a*r),format:"#,##0.00"}},isExported:!0},uv={description:ui("Price of a security paying periodic interest."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("rate (number)",ui("The annualized rate of interest.")),Id("yield (number)",ui("The expected annual yield of the security.")),Id("redemption (number)",ui("The redemption amount per 100 face value, or par.")),Id("frequency (number)",ui("The number of interest or coupon payments per year (1, 2, or 4)."),xf),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o,s,i,n,r={value:0}){r=r||0;const a=Math.trunc(Sn(e,this.locale)),l=Math.trunc(Sn(t,this.locale)),c=Sn(o,this.locale),h=Sn(s,this.locale),d=Sn(i,this.locale),u=Math.trunc(Sn(n,this.locale)),g=Math.trunc(Sn(r,this.locale));if(a>=l)return new rn(lm(a,l));if(Rm(u))return new rn(Xp(u));if(Em(g))return new rn(Kp(g));if(c<0)return new rn(vm(c));if(h<0)return new rn(wm(h));if(d<=0)return new rn(Sm(d));const p=qi(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},gv={description:ui("Price of a discount security."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("discount (number)",ui("The discount rate of the security at time of purchase.")),Id("redemption (number)",ui("The redemption amount per 100 face value, or par.")),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o,s,i={value:0}){i=i||0;const n=Math.trunc(Sn(e,this.locale)),r=Math.trunc(Sn(t,this.locale)),a=Sn(o,this.locale),l=Sn(s,this.locale),c=Math.trunc(Sn(i,this.locale));if(n>=r)return new rn(lm(n,r));if(Em(c))return new rn(Kp(c));if(a<=0)return new rn(Qp(a));if(l<=0)return new rn(Sm(l));return l-a*l*qi(n,r,c)},isExported:!0},pv={description:ui("Calculates the price of a security paying interest at maturity, based on expected yield."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("issue (date)",ui("The date the security was initially issued.")),Id("rate (number)",ui("The annualized rate of interest.")),Id("yield (number)",ui("The expected annual yield of the security.")),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o,s,i,n={value:0}){n=n||0;const r=Math.trunc(Sn(e,this.locale)),a=Math.trunc(Sn(t,this.locale)),l=Math.trunc(Sn(o,this.locale)),c=Sn(s,this.locale),h=Sn(i,this.locale),d=Math.trunc(Sn(n,this.locale));if(r<=l)return new rn(((e,t)=>ui("The settlement date (%(settlement)s) must be strictly greater than the issue date (%(issue)s).",{settlement:e,issue:t}))(r,l));if(r>=a)return new rn(lm(r,a));if(Em(d))return new rn(Kp(d));if(c<0)return new rn(vm(c));if(h<0)return new rn(wm(h));const u=qi(r,a,d),g=qi(r,l,d);return(100+qi(l,a,d)*c*100)/(1+u*h)-g*c*100},isExported:!0},mv=.1,fv={description:ui("Interest rate of an annuity investment."),args:[Id("number_of_periods (number)",ui("The number of payments to be made.")),Id("payment_per_period (number)",ui("The amount per period to be paid.")),Id("present_value (number)",ui("The current value of the annuity.")),Id("future_value (number, default=0)",ui("The future value remaining after the final payment has been made.")),Id("end_or_beginning (number, default=0)",ui("The timing of the payment payments are due for each period."),Ef),Id("rate_guess (number, default=0.1)",ui("An estimate for what the interest rate will be."))],compute:function(e,t,o,s={value:0},i={value:0},n={value:mv}){const r=Sn(e,this.locale),a=Sn(t,this.locale),l=An(i)?1:0,c=Sn(n,this.locale)||mv;let h=Sn(s,this.locale),d=Sn(o,this.locale);if(r<=0)return new rn(cm(r));if(!xm([a,d,h]))return new rn(ui("There must be both positive and negative values in [payment_amount, present_value, future_value]."));if(c<=-1)return new rn(fm(c));h-=a*l,d+=a*l;return{value:Tf((e=>{const t=Math.pow(1+e,r);return h+d*t+a*((t-1)/e)}),(e=>{const t=Math.pow(1+e,r-1),o=Math.pow(1+e,r);return d*r*t+a*(r*t/e-(o-1)/e/e)}),c,40,1e-5),format:"0%"}},isExported:!0},vv={description:ui("Amount received at maturity for a security."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("investment (number)",ui("The amount invested (irrespective of face value of each security).")),Id("discount (number)",ui("The discount rate of the security invested in.")),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o,s,i={value:0}){i=i||0;const n=Math.trunc(Sn(e,this.locale)),r=Math.trunc(Sn(t,this.locale)),a=Sn(o,this.locale),l=Sn(s,this.locale),c=Math.trunc(Sn(i,this.locale));if(n>=r)return new rn(lm(n,r));if(Em(c))return new rn(Kp(c));if(a<=0)return new rn(im(a));if(l<=0)return new rn(Qp(l));return a/(1-l*qi(n,r,c))},isExported:!0},bv={description:ui("Computes the rate needed for an investment to reach a specific value within a specific number of periods."),args:[Id("number_of_periods (number)",ui("The number of periods.")),Id("present_value (number)",ui("The present value of the investment.")),Id("future_value (number)",ui("The future value of the investment."))],compute:function(e,t,o){const s=Sn(e,this.locale),i=Sn(t,this.locale),n=Sn(o,this.locale);return s<=0?new rn(cm(s)):(n/i)**(1/s)-1},isExported:!0},Sv={description:ui("Depreciation of an asset using the straight-line method."),args:[Id("cost (number)",ui("The initial cost of the asset.")),Id("salvage (number)",ui("The value of the asset at the end of depreciation.")),Id("life (number)",ui("The number of periods over which the asset is depreciated."))],compute:function(e,t,o){return{value:(Sn(e,this.locale)-Sn(t,this.locale))/Sn(o,this.locale),format:"#,##0.00"}},isExported:!0},Cv={description:ui("Depreciation via sum of years digit method."),args:[Id("cost (number)",ui("The initial cost of the asset.")),Id("salvage (number)",ui("The value of the asset at the end of depreciation.")),Id("life (number)",ui("The number of periods over which the asset is depreciated.")),Id("period (number)",ui("The single period within life for which to calculate depreciation."))],compute:function(e,t,o,s){const i=Sn(e,this.locale),n=Sn(t,this.locale),r=Sn(o,this.locale),a=Sn(s,this.locale);if(a<=0)return new rn(gm(a));if(r<=0)return new rn(am(r));if(a>r)return new rn(um(a,r));return{value:(r-a+1)/(r*(r+1)/2)*(i-n),format:"#,##0.00"}},isExported:!0};function yv(e,t,o){return 100*(1-o*qi(e,t,2))}const Iv={description:ui("Price of a US Treasury bill."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("discount (number)",ui("The discount rate of the bill at time of purchase."))],compute:function(e,t,o){const s=Math.trunc(Sn(e,this.locale)),i=Math.trunc(Sn(t,this.locale)),n=Sn(o,this.locale);return s>=i?new rn(lm(s,i)):Tm(s,i,this.locale)?n<=0?new rn(Qp(n)):n>=1?new rn(em(n)):yv(s,i,n):new rn(ym(s,i))},isExported:!0},wv={description:ui("Equivalent rate of return for a US Treasury bill."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("discount (number)",ui("The discount rate of the bill at time of purchase."))],compute:function(e,t,o){const s=Math.trunc(Sn(e,this.locale)),i=Math.trunc(Sn(t,this.locale)),n=Sn(o,this.locale);if(s>=i)return new rn(lm(s,i));if(!Tm(s,i,this.locale))return new rn(ym(s,i));if(n<=0)return new rn(Qp(n));if(n>=1)return new rn(em(n));const r=Mm.compute.bind(this)({value:i},{value:s});if(r<=182)return 365*n/(360-n*r);const a=yv(s,i,n)/100,l=r/(366===r?366:365);return(-2*l+2*Math.sqrt(l**2-(2*l-1)*(1-1/a)))/(2*l-1)},isExported:!0},xv={description:ui("The yield of a US Treasury bill based on price."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("price (number)",ui("The price at which the security is bought per 100 face value."))],compute:function(e,t,o){const s=Math.trunc(Sn(e,this.locale)),i=Math.trunc(Sn(t,this.locale)),n=Sn(o,this.locale);if(s>=i)return new rn(lm(s,i));if(!Tm(s,i,this.locale))return new rn(ym(s,i));if(n<=0)return new rn(mm(n));return(100-n)/n*(1/qi(s,i,2))},isExported:!0},Ev={description:ui("Variable declining balance. WARNING : does not handle decimal periods."),args:[Id("cost (number)",ui("The initial cost of the asset.")),Id("salvage (number)",ui("The value of the asset at the end of depreciation.")),Id("life (number)",ui("The number of periods over which the asset is depreciated.")),Id("start (number)",ui("Starting period to calculate depreciation.")),Id("end (number)",ui("Ending period to calculate depreciation.")),Id("factor (number, default=2)",ui("The number of months in the first year of depreciation.")),Id("no_switch (number, default=false)",ui("Whether to switch to straight-line depreciation when the depreciation is greater than the declining balance calculation."),[{value:!1,label:ui("Switch to straight-line depreciation")},{value:!0,label:ui("Do not switch to straight-line depreciation")}])],compute:function(e,t,o,s,i,n={value:2},r={value:false}){n=n||0;const a=Sn(e,this.locale),l=Sn(t,this.locale),c=Sn(o,this.locale),h=Math.trunc(Sn(s,this.locale)),d=Math.trunc(Sn(i,this.locale)),u=Sn(n,this.locale),g=An(r);if(a<0)return new rn(Yp(a));if(l<0)return new rn(Cm(l));if(c<=0)return new rn(am(c));if(h<0)return new rn((e=>ui("The start_period (%s) must be positive or null.",e))(h));if(d<0)return new rn((e=>ui("The end_period (%s) must be positive or null.",e))(d));if(h>d)return new rn(ui("The start_period (%(start)s) must be smaller or equal to the end_period (%(end)s).",{start:h,end:d}));if(d>c)return new rn(((e,t)=>ui("The end_period (%(end)s) must be smaller or equal to the life (%(life)s).",{end:e,life:t}))(d,c));if(u<=0)return new rn(Jp(u));if(0===a)return 0;if(l>=a)return h<1?a-l:0;const p=u/c;if(p>=1)return h<1?a-l:0;let m=a,f=0,v=0,b=!1;for(let e=0;e<d;e++){if(!b||g){const t=m*p,o=(m-l)/(c-e);!g&&o>t?(b=!0,f=o):f=t}const t=Math.max(m-f,l);e>=h&&(v+=m-t),m=t}return v},isExported:!0},Rv={description:ui("Internal rate of return given non-periodic cash flows."),args:[Id("cashflow_amounts (range<number>)",ui("An range containing the income or payments associated with the investment.")),Id("cashflow_dates (range<number>)",ui("An range with dates corresponding to the cash flows in cashflow_amounts.")),Id("rate_guess (number, default=0.1)",ui("An estimate for what the internal rate of return will be."))],compute:function(e,t,o={value:mv}){const s=Sn(o,this.locale);if(!cc(e,t))return new rn(Zp);const i=e.flat().map((e=>Sn(e,this.locale))),n=t.flat().map((e=>Sn(e,this.locale)));if(!xm(i))return new rn(jp);if(n.some((e=>e<n[0])))return new rn(tm(n[0]));if(s<=-1)return new rn(fm(s));const r=new Map;for(const e of Ct(0,n.length)){const t=n[e];r.has(t)?r.set(t,r.get(t)+i[e]):r.set(t,i[e])}const a=Array.from(r.keys()),l=a.map((e=>r.get(e)));return Tf((e=>{let t=l[0];for(const o of Ct(1,l.length)){const s=(a[0]-a[o])/365;t+=l[o]*(1+e)**s}return t}),(e=>{let t=0;for(const o of Ct(1,l.length)){const s=(a[0]-a[o])/365;t+=s*l[o]*(1+e)**(s-1)}return t}),s,40,1e-5,(e=>e?e/10-.9:-.9))},isExported:!0},Tv={description:ui("Net present value given to non-periodic cash flows.."),args:[Id("discount (number)",ui("The discount rate of the investment over one period.")),Id("cashflow_amounts (number, range<number>)",ui("An range containing the income or payments associated with the investment.")),Id("cashflow_dates (number, range<number>)",ui("An range with dates corresponding to the cash flows in cashflow_amounts."))],compute:function(e,t,o){const s=Sn(e,this.locale);if(!cc(t,o))return new rn(Zp);const i=Kn(t).flat().map((e=>In(e,this.locale))),n=Kn(o).flat().map((e=>In(e,this.locale)));if(n.some((e=>e<n[0])))return new rn(tm(n[0]));if(s<=0)return new rn(bm(s));if(1===i.length)return i[0];const r=new Map;for(const e of Ct(0,n.length)){const t=n[e];r.has(t)?r.set(t,r.get(t)+i[e]):r.set(t,i[e])}const a=Array.from(r.keys()),l=a.map((e=>r.get(e)));let c=l[0];for(const e of Ct(1,l.length)){const t=(a[0]-a[e])/365;c+=l[e]*(1+s)**t}return c},isExported:!0},Av={description:ui("Annual yield of a security paying periodic interest."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("rate (number)",ui("The annualized rate of interest.")),Id("price (number)",ui("The price at which the security is bought per 100 face value.")),Id("redemption (number)",ui("The redemption amount per 100 face value, or par.")),Id("frequency (number)",ui("The number of interest or coupon payments per year (1, 2, or 4)."),xf),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o,s,i,n,r={value:0}){r=r||0;const a=Math.trunc(Sn(e,this.locale)),l=Math.trunc(Sn(t,this.locale)),c=Sn(o,this.locale),h=Sn(s,this.locale),d=Sn(i,this.locale),u=Math.trunc(Sn(n,this.locale)),g=Math.trunc(Sn(r,this.locale));if(a>=l)return new rn(lm(a,l));if(Rm(u))return new rn(Xp(u));if(Em(g))return new rn(Kp(g));if(c<0)return new rn(vm(c));if(h<=0)return new rn(mm(h));if(d<=0)return new rn(Sm(d));const p=qi(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=Tf((function(e){return function(e,t,o,s,i,n){let r=n-(e+i*(1-t))*s**(o-1+t);for(let e=1;e<=o;e++)r+=i*s**(e-1);return r}(h,f,m,e,v,d)}),(function(e){return function(e,t,o,s,i){let n=-(e+i*(1-t))*(o-1+t)*s**(o-2+t);for(let e=1;e<=o;e++)n+=i*(e-1)*s**(e-2);return n}(h,f,m,e,v)}),1+(c+1)/u,100,1e-5);return(b-1)*u},isExported:!0},Dv={description:ui("Annual yield of a discount security."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("price (number)",ui("The price at which the security is bought per 100 face value.")),Id("redemption (number)",ui("The redemption amount per 100 face value, or par.")),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o,s,i={value:0}){i=i||0;const n=Math.trunc(Sn(e,this.locale)),r=Math.trunc(Sn(t,this.locale)),a=Sn(o,this.locale),l=Sn(s,this.locale),c=Math.trunc(Sn(i,this.locale));if(n>=r)return new rn(lm(n,r));if(Em(c))return new rn(Kp(c));if(a<=0)return new rn(mm(a));if(l<=0)return new rn(Sm(l));return(l/a-1)/qi(n,r,c)},isExported:!0},_v={description:ui("Annual yield of a security paying interest at maturity."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("issue (date)",ui("The date the security was initially issued.")),Id("rate (number)",ui("The annualized rate of interest.")),Id("price (number)",ui("The price at which the security is bought.")),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o,s,i,n={value:0}){n=n||0;const r=Math.trunc(Sn(e,this.locale)),a=Math.trunc(Sn(t,this.locale)),l=Math.trunc(Sn(o,this.locale)),c=Sn(s,this.locale),h=Sn(i,this.locale),d=Math.trunc(Sn(n,this.locale));if(r>=a)return new rn(lm(r,a));if(Em(d))return new rn(Kp(d));if(r<l)return new rn(((e,t)=>ui("The settlement date (%(settlement)s) must be greater or equal to the issue date (%(issue)s).",{settlement:e,issue:t}))(r,l));if(c<0)return new rn(vm(c));if(h<=0)return new rn(mm(h));return(100*(1+c*qi(l,a,d))/(h+100*c*qi(l,r,d))-1)/qi(r,a,d)},isExported:!0};var Fv,Ov=Object.freeze({__proto__:null,ACCRINTM:Af,AMORLINC:Df,COUPDAYBS:Ff,COUPDAYS:_f,COUPDAYSNC:Of,COUPNCD:Pf,COUPNUM:Mf,COUPPCD:Nf,CUMIPMT:kf,CUMPRINC:Lf,DB:Vf,DDB:Hf,DISC:zf,DOLLARDE:Bf,DOLLARFR:$f,DURATION:Gf,EFFECT:Wf,FV:Zf,FVSCHEDULE:jf,INTRATE:Yf,IPMT:Kf,IRR:Jf,ISPMT:Qf,MDURATION:ev,MIRR:tv,NOMINAL:ov,NPER:sv,NPV:nv,PDURATION:rv,PMT:lv,PPMT:hv,PRICE:uv,PRICEDISC:gv,PRICEMAT:pv,PV:dv,RATE:fv,RECEIVED:vv,RRI:bv,SLN:Sv,SYD:Cv,TBILLEQ:wv,TBILLPRICE:Iv,TBILLYIELD:xv,VDB:Ev,XIRR:Rv,XNPV:Tv,YIELD:Av,YIELDDISC:Dv,YIELDMAT:_v});!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"}(Fv||(Fv={}));const Pv=(e,t=(()=>!0))=>[{goTo:e,guard:t}],Mv=(e,t=(()=>!0))=>({goTo:e,guard:t}),Nv={[Fv.LeftRef]:{REFERENCE:Pv(Fv.Separator),NUMBER:Pv(Fv.FullRowSeparator),SYMBOL:[Mv(Fv.FullColumnSeparator,(e=>{return t=e.value,Ca.test(t);var t})),Mv(Fv.FullRowSeparator,(e=>wa(e.value)))]},[Fv.FullColumnSeparator]:{SPACE:Pv(Fv.FullColumnSeparator),OPERATOR:Pv(Fv.RightColumnRef,(e=>":"===e.value))},[Fv.FullRowSeparator]:{SPACE:Pv(Fv.FullRowSeparator),OPERATOR:Pv(Fv.RightRowRef,(e=>":"===e.value))},[Fv.Separator]:{SPACE:Pv(Fv.Separator),OPERATOR:Pv(Fv.RightRef,(e=>":"===e.value))},[Fv.RightRef]:{SPACE:Pv(Fv.RightRef),NUMBER:Pv(Fv.Found),REFERENCE:Pv(Fv.Found,(e=>Ra(e.value))),SYMBOL:Pv(Fv.Found,(e=>xa(e.value)||Ea(e.value)))},[Fv.RightColumnRef]:{SPACE:Pv(Fv.RightColumnRef),SYMBOL:Pv(Fv.Found,(e=>xa(e.value))),REFERENCE:Pv(Fv.Found,(e=>Ra(e.value)))},[Fv.RightRowRef]:{SPACE:Pv(Fv.RightRowRef),NUMBER:Pv(Fv.Found),REFERENCE:Pv(Fv.Found,(e=>Ra(e.value))),SYMBOL:Pv(Fv.Found,(e=>Ea(e.value)))},[Fv.Found]:{}};function kv(e){let t=0,o=Nv[Fv.LeftRef],s="";for(;void 0!==o;){const i=e[t++];if(!i)return null;const n=o[i.type]?.find((e=>e.guard(i))),r=n?n.goTo:void 0;switch(r){case void 0:return null;case Fv.Found:return s+=i.value,e.splice(0,t),{type:"REFERENCE",value:s};default:o=Nv[r],s+=i.value}}return null}function Lv(e,t=w){const o=El(e,t),s=[];for(;o.length;)s.push(kv(o)||o.shift());return s}const Vv=/[a-zA-Z0-9\_]+(\.[a-zA-Z0-9\_]+)*/,Uv=["-","+"],Hv=["%"];class zv{tokens;currentIndex=0;current;length;constructor(e){this.tokens=e,this.current=e[0],this.length=e.length}shift(){const e=this.tokens[this.currentIndex];return this.current=this.tokens[++this.currentIndex],e}get next(){return this.tokens[this.currentIndex+1]}}const Bv={"%":40,"^":30,"*":20,"/":20,"+":15,"-":15,"&":13,">":10,"<>":10,">=":10,"<":10,"<=":10,"=":10};function $v(e){const t=e.shift();if(!t)throw new an;switch(t.type){case"DEBUGGER":const o=qv(e,1e3);return o.debug=!0,o;case"NUMBER":return{type:"NUMBER",value:tn(t.value,w),tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case"STRING":return{type:"STRING",value:ut(t.value),tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case"INVALID_REFERENCE":return{type:"REFERENCE",value:sn.InvalidReference,tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case"REFERENCE":if(":"===e.current?.value&&"REFERENCE"===e.next?.type){e.shift();const o=e.shift();return{type:"REFERENCE",value:`${t.value}:${o?.value}`,tokenStartIndex:t.tokenIndex,tokenEndIndex:o.tokenIndex}}return{type:"REFERENCE",value:t.value,tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case"SYMBOL":const s=t.value,i=e.current;if("LEFT_PAREN"===i?.type&&Vv.test(t.value)&&s===ft(s,"'")){const{args:o,rightParen:i}=function(e){Wv(e,"LEFT_PAREN",ui("Missing opening parenthesis"));const t=e.current;if("RIGHT_PAREN"===t?.type){return{args:[],rightParen:Wv(e,"RIGHT_PAREN")}}const o=[];o.push(Gv(e));for(;"RIGHT_PAREN"!==e.current?.type;)Wv(e,"ARG_SEPARATOR",ui("Wrong function call")),o.push(Gv(e));const s=Wv(e,"RIGHT_PAREN");return{args:o,rightParen:s}}(e);return{type:"FUNCALL",value:s,args:o,tokenStartIndex:t.tokenIndex,tokenEndIndex:i.tokenIndex}}const n=s.toUpperCase();return"TRUE"===n||"FALSE"===n?{type:"BOOLEAN",value:"TRUE"===n,tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex}:{type:"SYMBOL",value:ft(t.value,"'"),tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case"LEFT_PAREN":const r=qv(e),a=Wv(e,"RIGHT_PAREN",ui("Missing closing parenthesis"));return{...r,tokenStartIndex:t.tokenIndex,tokenEndIndex:a.tokenIndex};case"OPERATOR":const l=t.value;if(Uv.includes(l)){const o=qv(e,Bv[l]);return{type:"UNARY_OPERATION",value:l,operand:o,tokenStartIndex:t.tokenIndex,tokenEndIndex:o.tokenEndIndex}}throw new an(ui("Unexpected token: %s",t.value));default:throw new an(ui("Unexpected token: %s",t.value))}}function Gv(e){const t=e.current;return"ARG_SEPARATOR"===t?.type||"RIGHT_PAREN"===t?.type?{type:"EMPTY",value:"",tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex}:qv(e)}function Wv(e,t,o){const s=e.shift();if(!s||s.type!==t)throw new an(o);return s}function qv(e,t=0){if(0===e.length)throw new an;let o=$v(e);for(;"OPERATOR"===e.current?.type&&Bv[e.current.value]>t;){const t=e.shift(),s=t.value;if(Hv.includes(s))o={type:"UNARY_OPERATION",value:s,operand:o,postfix:!0,tokenStartIndex:o.tokenStartIndex,tokenEndIndex:t.tokenIndex};else{const t=qv(e,Bv[s]);o={type:"BIN_OPERATION",value:s,left:o,right:t,tokenStartIndex:o.tokenStartIndex,tokenEndIndex:t.tokenEndIndex}}}return o}function Zv(e){return jv(Lv(e))}function jv(e){const t=e.map(((e,t)=>({type:e.type,value:e.value,tokenIndex:t}))).filter((e=>"SPACE"!==e.type)),o=new zv(t);"="===o.current?.value&&o.shift();const s=qv(o);if(o.current)throw new an;return s}function Yv(e,t,o){return Jv(e,(e=>e.type===t?o(e):e))}function Xv(e){return Array.from(Kv(e))}function*Kv(e){switch(yield e,e.type){case"FUNCALL":for(const t of e.args)yield*Kv(t);break;case"UNARY_OPERATION":yield*Kv(e.operand);break;case"BIN_OPERATION":yield*Kv(e.left),yield*Kv(e.right)}}function Jv(e,t){switch((e=t(e)).type){case"FUNCALL":return{...e,args:e.args.map((e=>Jv(e,t)))};case"UNARY_OPERATION":return{...e,operand:Jv(e.operand,t)};case"BIN_OPERATION":return{...e,right:Jv(e.right,t),left:Jv(e.left,t)};default:return e}}function Qv(e,t){return function(e){for(const t of e)if(t.functionContext){const{argsTokens:e,args:o}=t.functionContext;if(delete t.functionContext.argsTokens,o.length||!e)continue;"LEFT_PAREN"===e[0]?.[0]?.type&&(e[0]=e[0].slice(1));for(const t of e){let e=t;"ARG_SEPARATOR"===e.at(0)?.type&&(e=e.slice(1));try{o.push(jv(e))}catch(e){o.push(void 0)}}}return e}(function(e){const t=[];let o="";function s(e){if(0===t.length)return;const o=t.at(-1);if(o&&o.argsTokens){const{argsTokens:t,argPosition:s}=o;t[s]||(t[s]=[]),t[s].push({value:e.value,type:e.type})}}return e.map(((e,i)=>{switch(["SPACE","LEFT_PAREN"].includes(e.type)||(o=""),e.type){case"SYMBOL":s(e),o=e.value;break;case"LEFT_PAREN":t.push({parent:o,argPosition:0,argsTokens:[],args:[]}),s(e),o="";break;case"RIGHT_PAREN":const i=t.pop();i?.argsTokens?.flat().forEach(s),s(e);break;case"ARG_SEPARATOR":t.length&&t[t.length-1].argPosition++,s(e);break;default:s(e)}if(t.length){const o=t[t.length-1];o.parent&&(e.functionContext=Object.assign({},o))}return e}))}(function(e){const t=[];let o=0;return e.map(((s,i)=>{if("LEFT_PAREN"===s.type){t.push(o+1),o=0;for(let o=i-1;o>=0;o--){if("SPACE"!==e[o].type){"SYMBOL"===e[o].type&&(e[o].parenthesesCode=t.join(":"));break}e[o].parenthesesCode=t.join(":")}}return s.parenthesesCode=t.join(":"),"RIGHT_PAREN"===s.type&&t.length&&(o=t.pop()),s}))}(function(e){let t=0;return e.map((e=>{const o=e.value.toString().length,s=Object.assign({},e,{start:t,end:t+o,length:o});return t=s.end,s}))}(Lv(e,t)))))}function eb(e){if("REFERENCE"!==e.type)return e;const{xc:t,sheetName:o}=Ta(e.value),[s,i]=t.split(":"),n=tb(s),r=i?`:${tb(i)}`:"";return{...e,value:Aa(o,n+r)}}function tb(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=ob(e,"colrow");break;case"colrow":e=ob(e,"row");break;case"row":e=ob(e,"col");break;case"col":e=ob(e,"none")}return e}function ob(e,t){let o;({sheetName:o,xc:e}=Ta(e)),o=o?o+"!":"";const s=(e=e.replace(/\$/g,"")).indexOf(":");return s>=0?`${o}${sb(e.slice(0,s),t)}:${sb(e.slice(s+1),t)}`:o+sb(e,t)}function sb(e,t){const o=e.search(/[0-9]/),s=0!==o,i=o>=0;switch(t){case"col":return s?"$"+e:e;case"row":return i?e.slice(0,o)+"$"+e.slice(o):e;case"colrow":return i&&s?"$"+e.slice(0,o)+"$"+e.slice(o):"$"+e;case"none":return e}}function ib(e,t,o){const s=(t.startsWith("=")?Qv(t,o):[]).filter((t=>t.start<=e.start&&t.end>=e.start||t.start>=e.start&&t.start<e.end)),i=s.filter((e=>"REFERENCE"===e.type));if(0===i.length)return;const n=s.map(eb).map((e=>e.value)).join(""),r=s[0].start,a=s[s.length-1].end,l=t.slice(0,r)+n+t.slice(a),c=l.length-t.length,h={start:i[0].start,end:i[i.length-1].end+c};return 1===i.length&&e.start===e.end&&(h.start=h.end),{content:l,selection:h}}const nb=[{value:"address",label:ui("Returns an absolute reference as plain text of the top left cell in reference.")},{value:"col",label:ui("Returns the column number of the cell in reference.")},{value:"contents",label:ui("Returns the value contained in the top left cell in reference.")},{value:"format",label:ui("Returns the format of the top left cell in reference.")},{value:"row",label:ui("Returns the row number of the top left cell in reference.")},{value:"type",label:ui('Returns the type of data in the cell in reference. The following values are returned: "b" for a blank cell, "l" (for label) if the cell contains plain text, and "v" (for value) if the cell contains any other type of data.')}],rb={description:ui("Gets information about a cell."),args:[Id("info_type (string)",ui("The type of information requested."),nb),Id("reference (meta, range<meta>)",ui("The reference to the cell."))],compute:function(e,t){const o=En(e).toLowerCase();if(!nb.map((e=>e.value)).includes(o))return new rn(ui("The info_type should be one of %s.",nb.join(", ")));const s=this.__originSheetId,i=t[0][0].value;let{sheetName:n,xc:a}=Ta(i);n=n===this.getters.getSheetName(s)?void 0:n;const l=Aa(n,ob(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===r.empty?"b":t===r.text?"l":"v"}}return""},isExported:!0},ab={description:ui("Whether a value is an error other than #N/A."),args:[Id("value (any)",ui("The value to be verified as an error type."))],compute:function(e){const t=e?.value;return fn(t)&&t!==sn.NotAvailable},isExported:!0},lb={description:ui("Whether a value is an error."),args:[Id("value (any)",ui("The value to be verified as an error type."))],compute:function(e){const t=e?.value;return fn(t)},isExported:!0},cb={description:ui("Whether a value is `true` or `false`."),args:[Id("value (any)",ui("The value to be verified as a logical TRUE or FALSE."))],compute:function(e){return"boolean"==typeof e?.value},isExported:!0},hb={description:ui("Whether a value is the error #N/A."),args:[Id("value (any)",ui("The value to be verified as an error type."))],compute:function(e){return e?.value===sn.NotAvailable},isExported:!0},db={description:ui("Whether a value is non-textual."),args:[Id("value (any)",ui("The value to be checked."))],compute:function(e){return!gb.compute.bind(this)(e)},isExported:!0},ub={description:ui("Whether a value is a number."),args:[Id("value (any)",ui("The value to be verified as a number."))],compute:function(e){return"number"==typeof e?.value},isExported:!0},gb={description:ui("Whether a value is text."),args:[Id("value (any)",ui("The value to be verified as text."))],compute:function(e){return"string"==typeof e?.value&&!1===fn(e?.value)},isExported:!0},pb={description:ui("Whether the referenced cell is empty"),args:[Id("value (any)",ui("Reference to the cell that will be checked for emptiness."))],compute:function(e){return null===e?.value},isExported:!0},mb={description:ui("Returns the error value #N/A."),args:[],compute:function(){return{value:sn.NotAvailable}},isExported:!0};var fb=Object.freeze({__proto__:null,CELL:rb,ISBLANK:pb,ISERR:ab,ISERROR:lb,ISLOGICAL:cb,ISNA:hb,ISNONTEXT:db,ISNUMBER:ub,ISTEXT:gb,NA:mb});const vb={description:ui("Logical `and` operator."),args:[Id("logical_expression1 (boolean, range<boolean>)",ui("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.")),Id("logical_expression2 (boolean, range<boolean>, repeating)",ui("More expressions that represent logical values."))],compute:function(...e){const{result:t,foundBoolean:o}=oc(e);return o?t:new rn(er)},isExported:!0},bb={description:ui("Logical value `false`."),args:[],compute:function(){return!1},isExported:!0},Sb={description:ui("Returns value depending on logical expression."),args:[Id("logical_expression (boolean, range<boolean>)",ui("An expression or reference to a cell containing an expression that represents some logical value, i.e. TRUE or FALSE.")),Id("value_if_true (any, range)",ui("The value the function returns if logical_expression is TRUE.")),Id("value_if_false (any, range, default=FALSE)",ui("The value the function returns if logical_expression is FALSE."))],compute:function(e,t,o){if(bc(e))return zn(Sb.compute,[e,t,o]);return(An(fc(e))?t:o)??{value:0}},isExported:!0},Cb={description:ui("Value if it is not an error, otherwise 2nd argument."),args:[Id("value (any, range)",ui("The value to return if value itself is not an error.")),Id('value_if_error (any, range, default="empty")',ui("The value the function returns if value is an error."))],compute:function(e,t){if(bc(e))return zn(Cb.compute,[e,t]);return(fn(fc(e)?.value)?t:e)??{value:0}},isExported:!0},yb={description:ui("Value if it is not an #N/A error, otherwise 2nd argument."),args:[Id("value (any, range)",ui("The value to return if value itself is not #N/A an error.")),Id('value_if_error (any, range, default="empty")',ui("The value the function returns if value is an #N/A error."))],compute:function(e,t){if(bc(e))return zn(yb.compute,[e,t]);return(fc(e)?.value===sn.NotAvailable?t:e)??{value:0}},isExported:!0},Ib={description:ui("Returns a value depending on multiple logical expressions."),args:[Id("condition1 (boolean, range<boolean>)",ui("The first condition to be evaluated. This can be a boolean, a number, an array, or a reference to any of those.")),Id("value1 (any, range)",ui("The returned value if condition1 is TRUE.")),Id("condition2 (boolean, any, range, repeating)",ui("Additional conditions to be evaluated if the previous ones are FALSE.")),Id("value2 (any, range, repeating)",ui("Additional values to be returned if their corresponding conditions are TRUE."))],compute:function(...e){if(e.length%2!=0)return new rn(ui("Wrong number of arguments. Expected an even number of arguments."));for(;e.length>0;){if(bc(e[0]))return zn(Ib.compute,e);const t=An(fc(e.shift())),o=e.shift();if(t)return o??{value:0}}return new rn(ui("No match."))},isExported:!0},wb={description:ui("Returns opposite of provided logical value."),args:[Id("logical_expression (boolean)",ui("An expression or reference to a cell holding an expression that represents some logical value."))],compute:function(e){return!An(e)},isExported:!0},xb={description:ui("Logical `or` operator."),args:[Id("logical_expression1 (boolean, range<boolean>)",ui("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.")),Id("logical_expression2 (boolean, range<boolean>, repeating)",ui("More expressions that evaluate to logical values."))],compute:function(...e){const{result:t,foundBoolean:o}=sc(e);return o?t:new rn(er)},isExported:!0},Eb={description:ui("Returns a value by comparing cases to an expression."),args:[Id("expression (number, boolean, string)",ui("The value to be checked.")),Id("case1 (number, boolean, string)",ui("The first case to be checked against expression.")),Id("value1 (any)",ui("The corresponding value to be returned if case1 matches expression.")),Id("case2 (any, repeating)",ui("Additional cases to try if the previous ones don't match expression.")),Id("value2 (any, repeating)",ui("Additional values to be returned if their corresponding cases match expression.")),Id('default (any, default="empty")',ui("An optional default value to be returned if none of the cases match expression."))],compute:function(e,...t){const o=t.length%2==0?vn(e):t.pop();for(let o=0;o<t.length;o+=2){const s=t[o];if(s&&fn(s.value))return s;if(e?.value===s?.value)return t[o+1]||{value:0}}return o||{value:0}},isExported:!0},Rb={description:ui("Logical value `true`."),args:[],compute:function(){return!0},isExported:!0},Tb={description:ui("Logical `xor` operator."),args:[Id("logical_expression1 (boolean, range<boolean>)",ui("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.")),Id("logical_expression2 (boolean, range<boolean>, repeating)",ui("More expressions that evaluate to logical values."))],compute:function(...e){let t=!1,o=!1;return Bn(e,(e=>(t=!0,o=o?!e:e,!0))),t?o:new rn(er)},isExported:!0};var Ab=Object.freeze({__proto__:null,AND:vb,FALSE:bb,IF:Sb,IFERROR:Cb,IFNA:yb,IFS:Ib,NOT:wb,OR:xb,SWITCH:Eb,TRUE:Rb,XOR:Tb});const Db={Errors:{InvalidRange:ui("The range is invalid"),FirstArgMissing:ui("The argument is missing. Please provide a value"),SecondArgMissing:ui("The second argument is missing. Please provide a value"),MinNaN:ui("The minpoint must be a number"),MidNaN:ui("The midpoint must be a number"),MaxNaN:ui("The maxpoint must be a number"),ValueUpperInflectionNaN:ui("The first value must be a number"),ValueLowerInflectionNaN:ui("The second value must be a number"),MinBiggerThanMax:ui("Minimum must be smaller then Maximum"),MinBiggerThanMid:ui("Minimum must be smaller then Midpoint"),MidBiggerThanMax:ui("Midpoint must be smaller then Maximum"),LowerBiggerThanUpper:ui("Lower inflection point must be smaller than upper inflection point"),MinInvalidFormula:ui("Invalid Minpoint formula"),MaxInvalidFormula:ui("Invalid Maxpoint formula"),MidInvalidFormula:ui("Invalid Midpoint formula"),ValueUpperInvalidFormula:ui("Invalid upper inflection point formula"),ValueLowerInvalidFormula:ui("Invalid lower inflection point formula"),EmptyRange:ui("A range needs to be defined"),ValueCellIsInvalidFormula:ui("At least one of the provided values is an invalid formula"),Unexpected:ui("The rule is invalid for an unknown reason")},ColorScale:ui("Color scale"),IconSet:ui("Icon set"),DataBar:ui("Data bar")},_b={Series:ui("Series"),BackgroundColor:ui("Background color"),StackedBarChart:ui("Stacked bar chart"),StackedLineChart:ui("Stacked line chart"),StackedAreaChart:ui("Stacked area chart"),StackedColumnChart:ui("Stacked column chart"),CumulativeData:ui("Cumulative data"),TreatLabelsAsText:ui("Treat labels as text"),AggregatedChart:ui("Aggregate"),Errors:{Unexpected:ui("The chart definition is invalid for an unknown reason"),InvalidDataSet:ui("The dataset is invalid"),InvalidLabelRange:ui("Labels are invalid"),InvalidScorecardKeyValue:ui("The key value is invalid"),InvalidScorecardBaseline:ui("The baseline value is invalid"),InvalidGaugeDataRange:ui("The data range is invalid"),EmptyGaugeRangeMin:ui("A minimum range limit value is needed"),GaugeRangeMinNaN:ui("The minimum range limit value must be a number"),EmptyGaugeRangeMax:ui("A maximum range limit value is needed"),GaugeRangeMaxNaN:ui("The maximum range limit value must be a number"),GaugeLowerInflectionPointNaN:ui("The lower inflection point value must be a number"),GaugeUpperInflectionPointNaN:ui("The upper inflection point value must be a number")},GeoChart:{ColorScales:{blues:ui("Blues"),cividis:ui("Cividis"),greens:ui("Greens"),greys:ui("Greys"),oranges:ui("Oranges"),purples:ui("Purples"),rainbow:ui("Rainbow"),reds:ui("Reds"),viridis:ui("Viridis")}}},Fb={Custom:ui("Custom")},Ob=ui("Merged cells are preventing this operation. Unmerge those cells and try again."),Pb=ui("The header row of a table can't be moved."),Mb={Errors:{Unexpected:ui("Cannot split the selection for an unknown reason"),NoSplitSeparatorInSelection:ui("There is no match for the selected separator in the selection"),MoreThanOneColumnSelected:ui("Only a selection from a single column can be split"),SplitWillOverwriteContent:ui("Splitting will overwrite existing content")}},Nb={Errors:{Unexpected:ui("Cannot remove duplicates for an unknown reason"),MoreThanOneRangeSelected:ui("Please select only one range of cells"),EmptyTarget:ui("Please select a range of cells containing values."),NoColumnsProvided:ui("Please select at latest one column to analyze."),WillRemoveExistingMerge:ui("This operation is not possible due to a merge. Please remove the merges first than try again.")}},kb={DateIs:{today:ui("today"),yesterday:ui("yesterday"),tomorrow:ui("tomorrow"),lastWeek:ui("in the past week"),lastMonth:ui("in the past month"),lastYear:ui("in the past year")},DateIsBefore:{today:ui("today"),yesterday:ui("yesterday"),tomorrow:ui("tomorrow"),lastWeek:ui("one week ago"),lastMonth:ui("one month ago"),lastYear:ui("one year ago")},CriterionError:{notEmptyValue:ui("The value must not be empty"),numberValue:ui("The value must be a number"),dateValue:ui("The value must be a date"),validRange:ui("The value must be a valid range"),validFormula:ui("The formula must be valid")},Errors:{InvalidRange:ui("The range is invalid."),InvalidDataValidationCriterionValue:ui("One or more of the provided criteria values are invalid. Please review and correct them."),InvalidNumberOfCriterionValues:ui("One or more of the provided criteria values are missing."),Unexpected:ui("The rule is invalid for an unknown reason.")}},Lb={Errors:{Unexpected:ui("The table zone is invalid for an unknown reason"),TableOverlap:ui("You cannot create overlapping tables."),NonContinuousTargets:ui("A table can only be created on a continuous selection."),InvalidRange:ui("The range is invalid"),TargetOutOfSheet:ui("The range is out of the sheet")},Checkboxes:{hasFilters:ui("Filter button"),headerRow:ui("Header row(s)"),bandedRows:ui("Banded rows"),firstColumn:ui("First column"),lastColumn:ui("Last column"),bandedColumns:ui("Banded columns"),automaticAutofill:ui("Automatically autofill formulas"),totalRow:ui("Total row"),isDynamic:ui("Auto-adjust to formula result")},Tooltips:{filterWithoutHeader:ui("Cannot have filters without a header row"),isDynamic:ui("For tables based on array formulas only")}},Vb={labels:{no_calculations:ui("No calculations"),"%_of_grand_total":ui("% of grand total"),"%_of_col_total":ui("% of column total"),"%_of_row_total":ui("% of row total"),"%_of":ui("% of"),"%_of_parent_row_total":ui("% of parent row total"),"%_of_parent_col_total":ui("% of parent column total"),"%_of_parent_total":ui("% of parent total"),difference_from:ui("Difference from"),"%_difference_from":ui("% difference from"),running_total:ui("Running total"),"%_running_total":ui("% Running total"),rank_asc:ui("Rank smallest to largest"),rank_desc:ui("Rank largest to smallest"),index:ui("Index")},descriptions:{"%_of_grand_total":()=>ui("Displayed as % of grand total"),"%_of_col_total":()=>ui("Displayed as % of column total"),"%_of_row_total":()=>ui("Displayed as % of row total"),"%_of":e=>ui('Displayed as % of "%s"',e),"%_of_parent_row_total":e=>ui('Displayed as % of parent row total of "%s"',e),"%_of_parent_col_total":()=>ui("Displayed as % of parent column total"),"%_of_parent_total":e=>ui('Displayed as % of parent "%s" total',e),difference_from:e=>ui('Displayed as difference from "%s"',e),"%_difference_from":e=>ui('Displayed as % difference from "%s"',e),running_total:e=>ui('Displayed as running total based on "%s"',e),"%_running_total":e=>ui('Displayed as % running total based on "%s"',e),rank_asc:e=>ui('Displayed as rank from smallest to largest based on "%s"',e),rank_desc:e=>ui('Displayed as rank largest to smallest based on "%s"',e),index:()=>ui("Displayed as index")},documentation:{no_calculations:ui("Displays the value that is entered in the field."),"%_of_grand_total":ui("Displays values as a percentage of the grand total of all the values or data points in the report."),"%_of_col_total":ui("Displays all the values in each column or series as a percentage of the total for the column or series."),"%_of_row_total":ui("Displays the value in each row or category as a percentage of the total for the row or category."),"%_of":ui("Displays values as a percentage of the value of the Base item in the Base field."),"%_of_parent_row_total":ui("Calculates values as follows:\n(value for the item) / (value for the parent item on rows)"),"%_of_parent_col_total":ui("Calculates values as follows:\n(value for the item) / (value for the parent item on columns)"),"%_of_parent_total":ui("Calculates values as follows:\n(value for the item) / (value for the parent item of the selected Base field)"),difference_from:ui("Displays values as the difference from the value of the Base item in the Base field."),"%_difference_from":ui("Displays values as the percentage difference from the value of the Base item in the Base field."),running_total:ui("Displays the value for successive items in the Base field as a running total."),"%_running_total":ui("Calculates the value as a percentage for successive items in the Base field that are displayed as a running total."),rank_asc:ui("Displays the rank of selected values in a specific field, listing the smallest item in the field as 1, and each larger value with a higher rank value."),rank_desc:ui("Displays the rank of selected values in a specific field, listing the largest item in the field as 1, and each smaller value with a higher rank value."),index:ui("Calculates values as follows:\n((value in cell) x (Grand Total of Grand Totals)) / ((Grand Row Total) x (Grand Column Total))")}};function Ub(e,t){const o=Rr(e,{format:"0,00",locale:t});return ui("Oops—this pivot table is quite large (%s cells). Try simplifying it using the side panel.",o)}function Hb(e,t){const o=t.getPivotId(e);if(!o)throw new rn(ui('There is no pivot with id "%s"',e));return o}function zb(e){if(e.length%2!=0)throw new rn(ui("Function PIVOT takes an even number of arguments."))}function Bb(e,t,o){const s=[];if("SPREADSHEET"===t.type&&t.dataSet){const{sheetId:o,zone:i}=t.dataSet,n=Go(i),r=e.getters.getRangeFromSheetXC(o,n);if(void 0===r||r.invalidXc||r.invalidSheetName)throw new cn;if(e.__originCellPosition&&r.sheetId===e.__originSheetId&&ts(cs(e.__originCellPosition),i))throw new ln;s.push(r)}for(const t of o)if(t.computedBy){const o=e.getters.getMeasureCompiledFormula(t);s.push(...o.dependencies.filter((e=>!e.invalidXc)))}const i=e.__originCellPosition;i&&s.length&&(e.updateDependencies?.(i),e.addDependencies?.(i,s))}const $b=!0,Gb=[{value:!0,label:ui("A1 style (default)")},{value:!1,label:ui("R1C1 style")}],Wb=[{value:!0,label:ui("Approximate match (default)")},{value:!1,label:ui("Exact match")}],qb={description:ui("Returns a cell reference as a string. "),args:[Id("row (number)",ui("The row number of the cell reference. ")),Id("column (number)",ui("The column number (not name) of the cell reference. A is column number 1. ")),Id("absolute_relative_mode (number, default=1)",ui("An indicator of whether the reference is row/column absolute."),[{value:1,label:ui("Absolute row and column (e.g. $A$1)")},{value:2,label:ui("Absolute row, relative column (e.g. A$1)")},{value:3,label:ui("Relative row, absolute column (e.g. $A1)")},{value:4,label:ui("Relative row and column (e.g. A1)")}]),Id("use_a1_notation (boolean, default=TRUE)",ui("A boolean indicating whether to use A1 style notation or R1C1 style notation."),Gb),Id("sheet (string, optional)",ui("A string indicating the name of the sheet into which the address points."))],compute:function(e,t,o={value:1},s={value:!0},i){const n=xn(e,this.locale),r=xn(t,this.locale);if(n<1)return new rn(dc(n));if(r<1)return new rn(dc(r));const a=xn(o,this.locale);if(![1,2,3,4].includes(a))return new rn((l=4,c=a,ui("The function [[FUNCTION_NAME]] expects a number value between %s and %s inclusive, but receives %s.",1..toString(),l.toString(),c.toString())));var l,c;let h;if(An(s)){h=_o(r-1,n-1,{rowFixed:[1,2].includes(a),colFixed:[1,3].includes(a)})}else{h=([1,2].includes(a)?`R${n}`:`R[${n}]`)+([1,3].includes(a)?`C${r}`:`C[${r}]`)}return void 0!==i?Aa(En(i),h):h},isExported:!0},Zb={description:ui("Column number of a specified cell."),args:[Id("cell_reference (meta, range<meta>, default='this cell')",ui("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(void 0===e)return void 0===this.__originCellPosition?.col?new rn(ui("In this context, the function [[FUNCTION_NAME]] needs to have a cell or range in parameter.")):this.__originCellPosition.col+1;if(void 0===e[0][0])return new rn(ui("The range is out of bounds."));if(e[0][0].value===sn.InvalidReference)return e[0][0];const t=this.getters.getRangeFromSheetXC(this.getters.getActiveSheetId(),e[0][0].value).zone.left;return 1===e.length?t+1:Vn(e.length,1,((e,o)=>({value:t+e+1})))},isExported:!0},jb={description:ui("Number of columns in a specified array or range."),args:[Id("range (any, range<any>)",ui("The range whose column count will be returned."))],compute:function(e){const t=Kn(e);return void 0===t[0][0]?new rn(ui("The range is out of bounds.")):t[0][0].value===sn.InvalidReference?t[0][0]:t.length},isExported:!0},Yb={description:ui("Horizontal lookup"),args:[Id("search_key (string, number, boolean)",ui("The value to search for. For example, 42, 'Cats', or I24.")),Id("range (any, range)",ui("The range to consider for the search. The first row in the range is searched for the key specified in search_key.")),Id("index (number)",ui("The row index of the value to be returned, where the first row in range is numbered 1.")),Id("is_sorted (boolean, default=true)",ui("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."),Wb)],compute:function(e,t,o,s={value:$b}){const i=Math.trunc(Sn(o?.value,this.locale)),n=Kn(t);if(1>i||i>n[0].length)return new rn(ui("[[FUNCTION_NAME]] evaluates to an out of bounds range."));const r=(e,t)=>e[t][0].value,a=n[An(s.value)?Zn(n,e,"nextSmaller","asc",n.length,r):jn(n,e,"wildcard",n.length,r,this.lookupCaches)];return void 0===a?vn(e):a[i-1]},isExported:!0},Xb={description:ui("Returns the content of a cell, specified by row and column offset."),args:[Id("reference (any, range)",ui("The range of cells from which the values are returned.")),Id("row (number, default=0)",ui("The index of the row to be returned from within the reference range of cells.")),Id("column (number, default=0)",ui("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=Kn(e),i=Sn(t.value,this.locale),n=Sn(o.value,this.locale);return n<0||n-1>=s.length||i<0||i-1>=s[0].length?new rn(ui("Index out of range.")):0===i&&0===n?s:0===i?[s[n-1]]:0===n?s.map((e=>[e[i-1]])):s[n-1][i-1]},isExported:!0},Kb={description:ui("Returns the content of a cell, specified by a string."),args:[Id("reference (string)",ui("The range of cells from which the values are returned.")),Id("use_a1_notation (boolean, default=TRUE)",ui("A boolean indicating whether to use A1 style notation (TRUE) or R1C1 style notation (FALSE)."),Gb)],compute:function(e,t={value:!0}){const o=e?.value?.toString();if(!o)return new cn(ui("Reference should be defined."));if(!An(t))return new rn(ui("R1C1 notation is not supported."));const s=this.__originSheetId,i=this.__originCellPosition;i&&this.updateDependencies?.(i);const n=this.getters.getRangeFromSheetXC(s,o);if(void 0===n||n.invalidXc||n.invalidSheetName)return new cn;i&&this.addDependencies?.(i,[n]);const r=[];for(let e=n.zone.left;e<=n.zone.right;e++){const t=[];for(let o=n.zone.top;o<=n.zone.bottom;o++){const s={sheetId:n.sheetId,col:e,row:o};t.push(this.getters.getEvaluatedCell(s))}r.push(t)}return 1===r.length&&1===r[0].length?r[0][0]:r},isExported:!0},Jb={description:ui("Look up a value."),args:[Id("search_key (string, number, boolean)",ui("The value to search for. For example, 42, 'Cats', or I24.")),Id("search_array (any, range)",ui("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.")),Id("result_range (any, range, optional)",ui("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=Kn(t),i=Kn(o);let n=s.length,r=s[0].length;const a=r>=n,l=a?(e,t)=>e[0][t].value:(e,t)=>e[t][0].value,c=Zn(s,e,"nextSmaller","asc",a?r:n,l);return-1===c||a&&void 0===s[0][c]||!a&&void 0===s[c][r-1]?vn(e):0===i[0].length?a?s[n-1][c]:s[c][r-1]:(n=i.length,r=i[0].length,1!==n&&1!==r?new rn(ui("The result_range must be a single row or a single column.")):n>1?c>n-1?new rn(ui("[[FUNCTION_NAME]] evaluates to an out of range row value %s.",c+1)):i[c][0]:c>r-1?new rn(ui("[[FUNCTION_NAME]] evaluates to an out of range column value %s.",c+1)):i[0][c])},isExported:!0},Qb={description:ui("Position of item in range that matches value."),args:[Id("search_key (string, number, boolean)",ui("The value to search for. For example, 42, 'Cats', or I24.")),Id("range (any, range)",ui("The one-dimensional array to be searched.")),Id("search_type (number, default=1)",ui("The search method is a number 1, 0 or -1 indicating which value to return. 1 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."),[{value:1,label:ui("Ascending order (default)")},{value:0,label:ui("Exact match")},{value:-1,label:ui("Descending order")}])],compute:function(e,t,o={value:1}){let s=Sn(o,this.locale);const i=Kn(t),n=i.length,r=i[0].length;if(1!==n&&1!==r)return new rn(ui("The range must be a single row or a single column."));let a=-1;const l=1===n?(e,t)=>e[0][t].value:(e,t)=>e[t][0].value,c=1===n?i[0].length:i.length;switch(s=Math.sign(s),s){case 1:a=Zn(i,e,"nextSmaller","asc",c,l);break;case 0:a=jn(i,e,"wildcard",c,l,this.lookupCaches);break;case-1:a=Zn(i,e,"nextGreater","desc",c,l)}return 1===n&&void 0===i[0][a]||1!==n&&void 0===i[a]?vn(e):a+1},isExported:!0},eS={description:ui("Row number of a specified cell."),args:[Id("cell_reference (meta, range<meta>, default='this cell')",ui("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(void 0===e)return void 0===this.__originCellPosition?.row?new rn(ui("In this context, the function [[FUNCTION_NAME]] needs to have a cell or range in parameter.")):this.__originCellPosition.row+1;if(void 0===e[0][0])return new rn(ui("The range is out of bounds."));if(e[0][0].value===sn.InvalidReference)return e[0][0];const t=this.getters.getRangeFromSheetXC(this.getters.getActiveSheetId(),e[0][0].value).zone.top;return 1===e[0].length?t+1:Vn(1,e[0].length,((e,o)=>({value:t+o+1})))},isExported:!0},tS={description:ui("Number of rows in a specified array or range."),args:[Id("range (any, range<any>)",ui("The range whose row count will be returned."))],compute:function(e){const t=Kn(e);return void 0===t[0][0]?new rn(ui("The range is out of bounds.")):t[0][0].value===sn.InvalidReference?t[0][0]:t[0].length},isExported:!0},oS={description:ui("Vertical lookup."),args:[Id("search_key (string, number, boolean)",ui("The value to search for. For example, 42, 'Cats', or I24.")),Id("range (any, range)",ui("The range to consider for the search. The first column in the range is searched for the key specified in search_key.")),Id("index (number)",ui("The column index of the value to be returned, where the first column in range is numbered 1.")),Id("is_sorted (boolean, default=true)",ui("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."),Wb)],compute:function(e,t,o,s={value:$b}){const i=Math.trunc(Sn(o?.value,this.locale)),n=Kn(t);if(1>i||i>n.length)return new rn(ui("[[FUNCTION_NAME]] evaluates to an out of bounds range."));const r=(e,t)=>e[0][t].value,a=An(s.value)?Zn(n,e,"nextSmaller","asc",n[0].length,r):jn(n,e,"wildcard",n[0].length,r,this.lookupCaches),l=n[i-1][a];return void 0===l?vn(e):l},isExported:!0},sS={0:"strict",1:"nextGreater","-1":"nextSmaller",2:"wildcard"},iS={description:ui("Search a range for a match and return the corresponding item from a second range."),args:[Id("search_key (string,number,boolean)",ui("The value to search for.")),Id("lookup_range (any, range)",ui("The range to consider for the search. Should be a single column or a single row.")),Id("return_range (any, range)",ui("The range containing the return value. Should have the same dimensions as lookup_range.")),Id("if_not_found (any, optional)",ui("If a valid match is not found, return this value.")),Id("match_mode (any, default=0)",ui("Specifies how to match search_key with the items in lookup_range. "),[{value:0,label:ui("Exact match (default)")},{value:-1,label:ui("Exact match or next smaller item")},{value:1,label:ui("Exact match or next larger item")},{value:2,label:ui("Wildcard character match")}]),Id("search_mode (any, default=1)",ui("Specifies the search mode to use. By default, a first to last search will be used."),[{value:1,label:ui("Search first to last (default)")},{value:-1,label:ui("Search last to first")},{value:2,label:ui("Binary search (sorted ascending order)")},{value:-2,label:ui("Binary search (sorted descending order)")}])],compute:function(e,t,o,s,i={value:0},n={value:1}){const r=Math.trunc(Sn(i.value,this.locale)),a=Math.trunc(Sn(n.value,this.locale)),l=Kn(t),c=Kn(o);if(1!==l.length&&1!==l[0].length)return new rn(ui("lookup_range should be either a single row or single column."));if(![1,-1,2,-2].includes(a))return new rn(ui("search_mode should be a value in [-1, 1, -2, 2]."));if(![-1,0,1,2].includes(r))return new rn(ui("match_mode should be a value in [-1, 0, 1, 2]."));const h=1===l.length?"col":"row";if(2===r&&[-2,2].includes(a))return new rn(ui("The search and match mode combination is not supported for XLOOKUP evaluation."));if("col"===h?c[0].length!==l[0].length:c.length!==l.length)return new rn(ui("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=sS[r],p=-1===a,m=2===a||-2===a?Zn(l,e,g,2===a?"asc":"desc",u,d):jn(l,e,g,u,d,this.lookupCaches,p);return-1!==m?"col"===h?c.map((e=>[e[m]])):[c[m]]:void 0===s?vn(e):[[s]]},isExported:!0},nS={description:ui("Get the value from a pivot."),args:[Id("pivot_id (number,string)",ui("ID of the pivot.")),Id("measure_name (string)",ui("Name of the measure.")),Id("domain_field_name (string,repeating)",ui("Field name.")),Id("domain_value (number,string,boolean,repeating)",ui("Value."))],compute:function(e,t,...o){const s=En(e),i=En(t),n=Hb(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 rn(ui("The argument %s is not a valid measure. Here are the measures: %s",t,e))}}(n,i,this.getters),zb(o);const r=this.getters.getPivot(n),a=this.getters.getPivotCoreDefinition(n);Bb(this,a,a.measures.filter((e=>e.id===i))),r.init({reload:r.needsReevaluation});const l=r.assertIsValid({throwOnError:!1});if(l)return l;if(!r.areDomainArgsFieldsValid(o)){const e=ui("Consider using a dynamic pivot formula: %s. Or re-insert the static pivot from the Data menu.",`=PIVOT(${s})`);return{value:sn.GenericError,message:ui("Dimensions don't match the pivot definition")+". "+e}}const c=r.parseArgsToPivotDomain(o);return this.getters.getActiveSheetId()===this.__originSheetId&&this.getters.getPivotPresenceTracker(n)?.trackValue(i,c),r.getPivotCellValueAndFormat(i,c)}},rS={description:ui("Get the header of a pivot."),args:[Id("pivot_id (number,string)",ui("ID of the pivot.")),Id("domain_field_name (string,repeating)",ui("Field name.")),Id("domain_value (number,string,value,repeating)",ui("Value."))],compute:function(e,...t){const o=En(e),s=Hb(o,this.getters);zb(t);const i=this.getters.getPivot(s);Bb(this,this.getters.getPivotCoreDefinition(s),[]),i.init({reload:i.needsReevaluation});const n=i.assertIsValid({throwOnError:!1});if(n)return n;if(!i.areDomainArgsFieldsValid(t)){const e=ui("Consider using a dynamic pivot formula: %s. Or re-insert the static pivot from the Data menu.",`=PIVOT(${o})`);return{value:sn.GenericError,message:ui("Dimensions don't match the pivot definition")+". "+e}}const r=i.parseArgsToPivotDomain(t);this.getters.getActiveSheetId()===this.__originSheetId&&this.getters.getPivotPresenceTracker(s)?.trackHeader(r);const a=r.at(-1);if("measure"===a?.field)return i.getPivotMeasureValue(En(a.value),r);const{value:l,format:c}=i.getPivotHeaderValueAndFormat(r);return{value:l,format:a&&"measure"!==a.field&&"false"!==a.value?c:void 0}}},aS={description:ui("Get a pivot table."),args:[Id("pivot_id (string)",ui("ID of the pivot.")),Id("row_count (number, optional)",ui("number of rows")),Id("include_total (boolean, default=TRUE)",ui("Whether to include total/sub-totals or not.")),Id("include_column_titles (boolean, default=TRUE)",ui("Whether to include the column titles or not.")),Id("column_count (number, optional)",ui("number of columns")),Id("include_measure_titles (boolean, default=TRUE)",ui("Whether to include the measure titles row or not."))],compute:function(e,t={value:1e4},o={value:!0},s={value:!0},i={value:Number.MAX_VALUE},n={value:!0}){const r=En(e),a=Sn(t,this.locale);if(a<0)return new rn(ui("The number of rows must be positive."));const l=Sn(i,this.locale);if(l<0)return new rn(ui("The number of columns must be positive."));const c={displayColumnHeaders:An(s),displayTotals:An(o),displayMeasuresRow:An(n)},h=Hb(r,this.getters),d=this.getters.getPivot(h),u=this.getters.getPivotCoreDefinition(h);Bb(this,u,u.measures),d.init({reload:d.needsReevaluation});const g=d.assertIsValid({throwOnError:!1});if(g)return g;const p=d.getCollapsedTableStructure();if(p.numberOfCells>nt)return new rn(Ub(p.numberOfCells,this.locale));const m=p.getPivotCells(c);let f=0;c.displayColumnHeaders&&(f=p.columns.length-1),c.displayMeasuresRow&&f++;const v=this.getters.getPivotName(h),b=Math.min(f+a,m[0].length);if(0===b)return[[{value:v}]];const S=Math.min(1+l,m.length),C=[];for(const e of Ct(0,S)){C[e]=[];for(const t of Ct(0,b)){const o=m[e][t];switch(o.type){case"EMPTY":C[e].push({value:""});break;case"HEADER":const t=d.getPivotHeaderValueAndFormat(o.domain);C[e].push((y=o.domain,I=t,0===y.length?I:{...I,format:(I.format||"@")+"* "}));break;case"MEASURE_HEADER":C[e].push(d.getPivotMeasureValue(o.measure,o.domain));break;case"VALUE":C[e].push(d.getPivotCellValueAndFormat(o.measure,o.domain))}}}var y,I;return(c.displayColumnHeaders||c.displayMeasuresRow)&&(C[0][0]={value:v}),C}},lS={description:ui("Returns a range reference shifted by a specified number of rows and columns from a starting cell reference."),args:[Id("cell_reference (meta, range<meta>)",ui("The starting point from which to count the offset rows and columns.")),Id("offset_rows (number)",ui("The number of rows to offset by.")),Id("offset_columns (number)",ui("The number of columns to offset by.")),Id("height (number, default='height of cell_reference')",ui("The number of rows of the range to return starting at the offset target.")),Id("width (number, default='width of cell_reference')",ui("The number of columns of the range to return starting at the offset target."))],compute:function(e,t,o,s,i){if(fn(e[0][0].value))return e[0][0];const n=e[0][0].value;if(!n)return new rn("In this context, the function OFFSET needs to have a cell or range in parameter.");const r=Ho(n);let a=e[0].length,l=e.length;if(s){const e=Sn(s,this.locale);if(e<1)return new rn(ui("Height value is %(_height)s. It should be greater than or equal to 1.",{_height:e}));a=e}if(i){const e=Sn(i,this.locale);if(e<1)return new rn(ui("Width value is %(_width)s. It should be greater than or equal to 1.",{_width:e}));l=e}const{sheetName:c}=Ta(n),h=c&&this.getters.getSheetIdByName(c)||this.getters.getActiveSheetId(),d=Sn(t,this.locale),u=Sn(o,this.locale),g=this.__originCellPosition;g&&this.updateDependencies?.(g);const p=r.left+u,m=r.top+d;if(p<0||m<0)return new cn(ui("OFFSET evaluates to an out of bounds range."));const f={left:p,top:m,right:p+l-1,bottom:m+a-1},v=this.getters.getRangeFromZone(h,f);return v.invalidXc||v.invalidSheetName?new cn:(g&&this.addDependencies?.(g,[v]),Vn(l,a,((e,t)=>this.getters.getEvaluatedCell({sheetId:h,col:p+e,row:m+t}))))}};var cS=Object.freeze({__proto__:null,ADDRESS:qb,COLUMN:Zb,COLUMNS:jb,HLOOKUP:Yb,INDEX:Xb,INDIRECT:Kb,LOOKUP:Jb,MATCH:Qb,OFFSET:lS,PIVOT:aS,PIVOT_HEADER:rS,PIVOT_VALUE:nS,ROW:eS,ROWS:tS,VLOOKUP:oS,XLOOKUP:iS});const hS={description:ui("Sum of two numbers."),args:[Id("value1 (number)",ui("The first addend.")),Id("value2 (number)",ui("The second addend."))],compute:function(e,t){return{value:Sn(e,this.locale)+Sn(t,this.locale),format:e?.format||t?.format}}},dS={description:ui("Concatenation of two values."),args:[Id("value1 (string)",ui("The value to which value2 will be appended.")),Id("value2 (string)",ui("The value to append to value1."))],compute:function(e,t){return En(e)+En(t)},isExported:!0},uS={description:ui("One number divided by another."),args:[Id("dividend (number)",ui("The number to be divided.")),Id("divisor (number)",ui("The number to divide by."))],compute:function(e,t){const o=Sn(t,this.locale);return 0===o?new gn(ui("The divisor must be different from zero.")):{value:Sn(e,this.locale)/o,format:e?.format||t?.format}}};function gS(e){return void 0===e||null===e.value}const pS={number:0,string:"",boolean:!1};function mS(e,t,o=2e-16){return Math.abs(e-t)<o}const fS={description:ui("Equal."),args:[Id("value1 (string, number, boolean)",ui("The first value.")),Id("value2 (string, number, boolean)",ui("The value to test against value1 for equality."))],compute:function(e,t){if(fn(e?.value))return e;if(fn(t?.value))return t;let o=gS(e)?pS[typeof t?.value]:e?.value,s=gS(t)?pS[typeof e?.value]:t?.value;return"string"==typeof o&&(o=o.toUpperCase()),"string"==typeof s&&(s=s.toUpperCase()),"number"==typeof o&&"number"==typeof s?{value:mS(o,s)}:{value:o===s}}};function vS(e,t,o){if(fn(e?.value))return e;if(fn(t?.value))return t;let s=gS(e)?pS[typeof t?.value]:e?.value,i=gS(t)?pS[typeof e?.value]:t?.value;"number"!=typeof s&&(s=En(s).toUpperCase()),"number"!=typeof i&&(i=En(i).toUpperCase());const n=typeof s,r=typeof i;return"string"===n&&"number"===r?{value:!0}:"string"===r&&"number"===n?{value:!1}:{value:o(s,i)}}const bS={description:ui("Strictly greater than."),args:[Id("value1 (number, string, boolean)",ui("The value to test as being greater than value2.")),Id("value2 (number, string, boolean)",ui("The second value."))],compute:function(e,t){return vS(e,t,((e,t)=>"number"==typeof e&&"number"==typeof t?!mS(e,t)&&e>t:e>t))}},SS={description:ui("Greater than or equal to."),args:[Id("value1 (number, string, boolean)",ui("The value to test as being greater than or equal to value2.")),Id("value2 (number, string, boolean)",ui("The second value."))],compute:function(e,t){return vS(e,t,((e,t)=>"number"==typeof e&&"number"==typeof t?mS(e,t)||e>t:e>=t))}},CS={description:ui("Less than."),args:[Id("value1 (number, string, boolean)",ui("The value to test as being less than value2.")),Id("value2 (number, string, boolean)",ui("The second value."))],compute:function(e,t){const o=SS.compute.bind(this)(e,t);return fn(o.value)?o:{value:!o.value}}},yS={description:ui("Less than or equal to."),args:[Id("value1 (number, string, boolean)",ui("The value to test as being less than or equal to value2.")),Id("value2 (number, string, boolean)",ui("The second value."))],compute:function(e,t){const o=bS.compute.bind(this)(e,t);return fn(o.value)?o:{value:!o.value}}},IS={description:ui("Difference of two numbers."),args:[Id("value1 (number)",ui("The minuend, or number to be subtracted from.")),Id("value2 (number)",ui("The subtrahend, or number to subtract from value1."))],compute:function(e,t){return{value:Sn(e,this.locale)-Sn(t,this.locale),format:e?.format||t?.format}}},wS={description:ui("Product of two numbers"),args:[Id("factor1 (number)",ui("The first multiplicand.")),Id("factor2 (number)",ui("The second multiplicand."))],compute:function(e,t){return{value:Sn(e,this.locale)*Sn(t,this.locale),format:e?.format||t?.format}}},xS={description:ui("Not equal."),args:[Id("value1 (string, number, boolean)",ui("The first value.")),Id("value2 (string, number, boolean)",ui("The value to test against value1 for inequality."))],compute:function(e,t){const o=fS.compute.bind(this)(e,t);return fn(o.value)?o:{value:!o.value}}},ES={description:ui("A number raised to a power."),args:[Id("base (number)",ui("The number to raise to the exponent power.")),Id("exponent (number)",ui("The exponent to raise base to."))],compute:function(e,t){return qu.compute.bind(this)(e,t)}},RS={description:ui("A number with the sign reversed."),args:[Id("value (number)",ui("The number to have its sign reversed. Equivalently, the number to multiply by -1."))],compute:function(e){return{value:-Sn(e,this.locale),format:e?.format}}},TS={description:ui("Value interpreted as a percentage."),args:[Id("percentage (number)",ui("The value to interpret as a percentage."))],compute:function(e){return Sn(e,this.locale)/100}},AS={description:ui("A specified number, unchanged."),args:[Id("value (any)",ui("The number to return."))],compute:function(e={value:null}){return e}};var DS=Object.freeze({__proto__:null,ADD:hS,CONCAT:dS,DIVIDE:uS,EQ:fS,GT:bS,GTE:SS,LT:CS,LTE:yS,MINUS:IS,MULTIPLY:wS,NE:xS,POW:ES,UMINUS:RS,UNARY_PERCENT:TS,UPLUS:AS});const _S=e=>({transform:t=>t*e,inverseTransform:t=>t/e}),FS={transform:e=>e,inverseTransform:e=>e},OS=1e-10,PS=.0254,MS=PS/72,NS=.3048,kS=.9144,LS=1609.34,VS=1852,US=946073047258e4,HS={g:{...FS,category:"weight"},u:{..._S(166053e-29),category:"weight"},grain:{..._S(.0647989),category:"weight"},ozm:{..._S(28.3495),category:"weight"},lbm:{..._S(453.592),category:"weight"},stone:{..._S(6350.29),category:"weight"},sg:{..._S(14593.90294),category:"weight"},cwt:{..._S(45359.237),category:"weight"},uk_cwt:{..._S(50802.3),category:"weight"},ton:{..._S(907184.74),category:"weight"},uk_ton:{..._S(1016046.9),category:"weight"},m:{...FS,category:"distance"},km:{..._S(1e3),category:"distance"},ang:{..._S(OS),category:"distance"},Picapt:{..._S(MS),category:"distance"},pica:{..._S(PS/6),category:"distance"},in:{..._S(PS),category:"distance"},ft:{..._S(NS),category:"distance"},yd:{..._S(kS),category:"distance"},ell:{..._S(1.143),category:"distance"},mi:{..._S(LS),category:"distance"},survey_mi:{..._S(1609.34),category:"distance"},Nmi:{..._S(VS),category:"distance"},ly:{..._S(US),category:"distance"},parsec:{..._S(0x6da012f95c9fd0),category:"distance"},sec:{...FS,category:"time"},min:{..._S(60),category:"time"},hr:{..._S(3600),category:"time"},day:{..._S(86400),category:"time"},yr:{..._S(31556952),category:"time"},Pa:{...FS,category:"pressure"},bar:{..._S(1e5),category:"pressure"},mmHg:{..._S(133.322),category:"pressure"},Torr:{..._S(133.322),category:"pressure"},psi:{..._S(6894.76),category:"pressure"},atm:{..._S(101325),category:"pressure"},N:{...FS,category:"force"},dyn:{..._S(1e-5),category:"force"},pond:{..._S(.00980665),category:"force"},lbf:{..._S(4.44822),category:"force"},J:{...FS,category:"energy"},eV:{..._S(160218e-24),category:"energy"},e:{..._S(1e-7),category:"energy"},flb:{..._S(1.3558179483),category:"energy"},c:{..._S(4.184),category:"energy"},cal:{..._S(4.1868),category:"energy"},BTU:{..._S(1055.06),category:"energy"},Wh:{..._S(3600),category:"energy"},HPh:{..._S(2684520),category:"energy"},W:{...FS,category:"power"},PS:{..._S(735.499),category:"power"},HP:{..._S(745.7),category:"power"},T:{...FS,category:"magnetism"},ga:{..._S(1e-4),category:"magnetism"},K:{...FS,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:{..._S(5/9),category:"temperature"},Reau:{transform:e=>1.25*e+273.15,inverseTransform:e=>(e-273.15)/1.25,category:"temperature"},"m^3":{...FS,category:"volume",order:3},"ang^3":{..._S(Math.pow(OS,3)),category:"volume",order:3},"Picapt^3":{..._S(Math.pow(MS,3)),category:"volume",order:3},tsp:{..._S(492892e-11),category:"volume"},tspm:{..._S(5e-6),category:"volume"},tbs:{..._S(14786764825785619e-21),category:"volume"},"in^3":{..._S(Math.pow(PS,3)),category:"volume",order:3},oz:{..._S(295735295625e-16),category:"volume"},cup:{..._S(237e-6),category:"volume"},pt:{..._S(.0004731765),category:"volume"},uk_pt:{..._S(568261e-9),category:"volume"},qt:{..._S(.0009463529),category:"volume"},l:{..._S(.001),category:"volume"},uk_qt:{..._S(.0011365225),category:"volume"},gal:{..._S(.0037854118),category:"volume"},uk_gal:{..._S(.00454609),category:"volume"},"ft^3":{..._S(Math.pow(NS,3)),category:"volume",order:3},bushel:{..._S(.0352390704),category:"volume"},barrel:{..._S(.158987295),category:"volume"},"yd^3":{..._S(Math.pow(kS,3)),category:"volume",order:3},MTON:{..._S(1.13267386368),category:"volume"},GRT:{..._S(2.83168),category:"volume"},"mi^3":{..._S(Math.pow(LS,3)),category:"volume",order:3},"Nmi^3":{..._S(Math.pow(VS,3)),category:"volume",order:3},"ly^3":{..._S(Math.pow(US,3)),category:"volume",order:3},"m^2":{...FS,category:"area",order:2},"ang^2":{..._S(Math.pow(OS,2)),category:"area",order:2},"Picapt^2":{..._S(Math.pow(MS,2)),category:"area",order:2},"in^2":{..._S(Math.pow(PS,2)),category:"area",order:2},"ft^2":{..._S(Math.pow(NS,2)),category:"area",order:2},"yd^2":{..._S(Math.pow(kS,2)),category:"area",order:2},ar:{..._S(100),category:"area"},Morgen:{..._S(2500),category:"area"},uk_acre:{..._S(4046.8564224),category:"area"},us_acre:{..._S(4046.8726098743),category:"area"},ha:{..._S(1e4),category:"area"},"mi^2":{..._S(Math.pow(LS,2)),category:"area",order:2},"Nmi^2":{..._S(Math.pow(VS,2)),category:"area",order:2},"ly^2":{..._S(Math.pow(US,2)),category:"area",order:2},bit:{...FS,category:"information"},byte:{..._S(8),category:"information"},"m/s":{...FS,category:"speed"},"m/hr":{..._S(1/3600),category:"speed"},"km/hr":{..._S(1/3.6),category:"speed"},mph:{..._S(.44704),category:"speed"},kn:{..._S(.5144444444),category:"speed"},admkn:{..._S(.5147733333),category:"speed"}},zS={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"},BS={"":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)},$S={weight:ui("Weight"),distance:ui("Distance"),time:ui("Time"),pressure:ui("Pressure"),force:ui("Force"),energy:ui("Energy"),power:ui("Power"),magnetism:ui("Magnetism"),temperature:ui("Temperature"),volume:ui("Volume"),area:ui("Area"),information:ui("Information"),speed:ui("Speed")},GS=Object.entries(HS).map((([e,t])=>({value:e,label:WS(t.category)})));function WS(e){return $S[e]??""}function qS(e){for(const[t,o]of Object.entries(BS)){if(t&&!e.startsWith(t))continue;const s=e.slice(t.length);let i=HS[s];if(!i&&zS[s]&&(i=HS[zS[s]]),i)return{...i,factor:i.order?Math.pow(o,i.order):o}}}const ZS={description:ui("Converts a numeric value to a different unit of measure."),args:[Id("value (number)",ui("the numeric value in start_unit to convert to end_unit")),Id("start_unit (string)",ui("The starting unit, the unit currently assigned to value"),GS),Id("end_unit (string)",ui("The unit of measure into which to convert value"),GS)],compute:function(e,t,o){const s=Sn(e,this.locale),i=En(t),n=En(o),r=qS(i),a=qS(n);return r?a?r.category!==a.category?{value:sn.GenericError,message:ui("Incompatible units of measure ('%s' vs '%s')",WS(r.category),WS(a.category))}:{value:a.inverseTransform(r.factor*r.transform(s))/a.factor,format:e?.format}:{value:sn.GenericError,message:ui("Invalid units of measure ('%s')",n)}:{value:sn.GenericError,message:ui("Invalid units of measure ('%s')",i)}},isExported:!0};var jS=Object.freeze({__proto__:null,CONVERT:ZS});const YS=/[A-Za-zÀ-ÖØ-öø-ÿ]+/g,XS=[{value:0,label:ui("Case-sensitive (default)")},{value:1,label:ui("Case-insensitive")}],KS=[{value:0,label:ui("Don't match to end (default)")},{value:1,label:ui("Match to end")}],JS={description:ui("Gets character associated with number."),args:[Id("table_number (number)",ui("The number of the character to look up from the current Unicode table in decimal format."))],compute:function(e){const t=Math.trunc(Sn(e,this.locale));return t<1?new rn(ui("The table_number (%s) is out of range.",t)):String.fromCharCode(t)},isExported:!0},QS={description:ui("Remove non-printable characters from a piece of text."),args:[Id("text (string)",ui("The text whose non-printable characters are to be removed."))],compute:function(e){const t=En(e);let o="";for(const e of t)e&&e.charCodeAt(0)>31&&(o+=e);return o},isExported:!0},eC={description:ui("Appends strings to one another."),args:[Id("string1 (string, range<string>)",ui("The initial string.")),Id("string2 (string, range<string>, repeating)",ui("More strings to append in sequence."))],compute:function(...e){return Nn(e,((e,t)=>e+En(t)),"")},isExported:!0},tC={description:ui("Tests whether two strings are identical."),args:[Id("string1 (string)",ui("The first string to compare.")),Id("string2 (string)",ui("The second string to compare."))],compute:function(e,t){return En(e)===En(t)},isExported:!0},oC={description:ui("First position of string found in text, case-sensitive."),args:[Id("search_for (string)",ui("The string to look for within text_to_search.")),Id("text_to_search (string)",ui("The text to search for the first occurrence of search_for.")),Id("starting_at (number, default=1)",ui("The character within text_to_search at which to start the search."))],compute:function(e,t,o={value:1}){const s=En(e),i=En(t),n=Sn(o,this.locale);if(""===i)return new rn(ui("The text_to_search must be non-empty."));if(n<1)return new rn(ui("The starting_at (%s) must be greater than or equal to 1.",n));const r=i.indexOf(s,n-1);return-1===r?new rn(ui("In [[FUNCTION_NAME]] evaluation, cannot find '%s' within '%s'.",s,i)):r+1},isExported:!0},sC={description:ui("Concatenates elements of arrays with delimiter."),args:[Id("delimiter (string)",ui("The character or string to place between each concatenated value.")),Id("value_or_array1 (string, range<string>)",ui("The value or values to be appended using delimiter.")),Id("value_or_array2 (string, range<string>, repeating)",ui("More values to be appended using delimiter."))],compute:function(e,...t){const o=En(e);return Nn(t,((e,t)=>(e?e+o:"")+En(t)),"")}},iC={description:ui("Substring from beginning of specified string."),args:[Id("text (string)",ui("The string from which the left portion will be returned.")),Id("number_of_characters (number, optional)",ui("The number of characters to return from the left side of string."))],compute:function(e,...t){const o=t.length?Sn(t[0],this.locale):1;return o<0?new rn(ui("The number_of_characters (%s) must be positive or null.",o)):En(e).substring(0,o)},isExported:!0},nC={description:ui("Length of a string."),args:[Id("text (string)",ui("The string whose length will be returned."))],compute:function(e){return En(e).length},isExported:!0},rC={description:ui("Converts a specified string to lowercase."),args:[Id("text (string)",ui("The string to convert to lowercase."))],compute:function(e){return En(e).toLowerCase()},isExported:!0},aC={description:ui("A segment of a string."),args:[Id("text (string)",ui("The string to extract a segment from.")),Id("starting_at (number)",ui("The index from the left of string from which to begin extracting. The first character in string has the index 1.")),Id("extract_length (number)",ui("The length of the segment to extract."))],compute:function(e,t,o){const s=En(e),i=Sn(t,this.locale),n=Sn(o,this.locale);return i<1?new rn(ui("The starting_at argument (%s) must be positive greater than one.",i.toString())):n<0?new rn(ui("The extract_length argument (%s) must be positive or null.",n)):s.slice(i-1,i+n-1)},isExported:!0},lC={description:ui("Capitalizes each word in a specified string."),args:[Id("text_to_capitalize (string)",ui("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 En(e).replace(YS,(e=>e.charAt(0).toUpperCase()+e.slice(1).toLowerCase()))},isExported:!0},cC={description:ui("Extract text from a string based on the supplied regular expression."),args:[Id("text (string)",ui("The string on which you want to extract text.")),Id("pattern (string)",ui("The regular expression pattern to match against the text.")),Id("return_mode (number, default=0)",ui("0 = first match, 1 = all matches as an array, 2 = capturing groups from the first match as an array."),[{value:0,label:ui("First match")},{value:1,label:ui("All matches")},{value:2,label:ui("Capture groups of first match")}]),Id("case_sensitivity (number, default=0)",ui("Whether the match is case-sensitive."),[{value:0,label:ui("Case-sensitive")},{value:1,label:ui("Case-insensitive")}])],compute:function(e,t,o={value:0},s={value:0}){const i=En(e),n=En(t),r=Sn(o,this.locale),a=Sn(s,this.locale);if(""===i||""===n)return{value:""};if(r<0||r>2)return new rn(ui("The return_mode (%s) must be 0, 1 or 2.",r));if(0!==a&&1!==a)return new rn(ui("The case_sensitivity (%s) must be 0 or 1.",a));const l=new RegExp(n,1===a?"gi":"g"),c=[...i.matchAll(l)];return 0===c.length?{value:sn.NotAvailable,message:ui("No matches found.")}:0===r?c[0][0]:1===r?c.map((e=>[e[0]])):c[0].length<2?new rn(ui("No capturing groups found.")):c[0].slice(1).map((e=>[e]))},isExported:!0},hC={description:ui("Replaces part of a text string with different text."),args:[Id("text (string)",ui("The text, a part of which will be replaced.")),Id("position (number)",ui("The position where the replacement will begin (starting from 1).")),Id("length (number)",ui("The number of characters in the text to be replaced.")),Id("new_text (string)",ui("The text which will be inserted into the original text."))],compute:function(e,t,o,s){const i=Sn(t,this.locale);if(i<1)return new rn(ui("The position (%s) must be greater than or equal to 1.",i));const n=En(e),r=Sn(o,this.locale),a=En(s);return n.substring(0,i-1)+a+n.substring(i-1+r)},isExported:!0},dC={description:ui("A substring from the end of a specified string."),args:[Id("text (string)",ui("The string from which the right portion will be returned.")),Id("number_of_characters (number, optional)",ui("The number of characters to return from the right side of string."))],compute:function(e,...t){const o=t.length?Sn(t[0],this.locale):1;if(o<0)return new rn(ui("The number_of_characters (%s) must be positive or null.",o));const s=En(e),i=s.length;return s.substring(i-o,i)},isExported:!0},uC={description:ui("First position of string found in text, ignoring case."),args:[Id("search_for (string)",ui("The string to look for within text_to_search.")),Id("text_to_search (string)",ui("The text to search for the first occurrence of search_for.")),Id("starting_at (number, default=1)",ui("The character within text_to_search at which to start the search."))],compute:function(e,t,o={value:1}){const s=En(e).toLowerCase(),i=En(t).toLowerCase(),n=Sn(o,this.locale);if(""===i)return{value:sn.GenericError,message:ui("The text_to_search must be non-empty.")};if(n<1)return{value:sn.GenericError,message:ui("The starting_at (%s) must be greater than or equal to 1.",n)};const r=i.indexOf(s,n-1);return-1===r?{value:sn.GenericError,message:ui("In [[FUNCTION_NAME]] evaluation, cannot find '%s' within '%s'.",s,i)}:{value:r+1}},isExported:!0},gC={description:ui("Split text by specific character delimiter(s)."),args:[Id("text (string)",ui("The text to divide.")),Id("delimiter (string)",ui("The character or characters to use to split text.")),Id("split_by_each (boolean, default=true})",ui("Whether or not to divide text around each character contained in delimiter.")),Id("remove_empty_text (boolean, default=true)",ui("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=En(e),n=gt(En(t)),r=An(o),a=An(s);if(n.length<=0)return new rn(ui("The delimiter (%s) must be not be empty.",n));const l=r?new RegExp(`[${n}]`,"g"):new RegExp(n,"g");let c=i.split(l);return a&&(c=c.filter((e=>""!==e))),Hn([c])},isExported:!1},pC={description:ui("Replaces existing text with new text in a string."),args:[Id("text_to_search (string)",ui("The text within which to search and replace.")),Id("search_for (string)",ui("The string to search for within text_to_search.")),Id("replace_with (string)",ui("The string that will replace search_for.")),Id("occurrence_number (number, optional)",ui("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=Sn(s,this.locale);if(i<0)return new rn(ui("The occurrenceNumber (%s) must be positive or null.",i));const n=En(e),r=En(t);if(""===r)return n;const a=En(o),l=new RegExp(gt(r),"g");if(0===i)return n.replace(l,a);let c=0;return n.replace(l,(e=>++c===i?a:e))},isExported:!0},mC={description:ui("Combines text from multiple strings and/or arrays."),args:[Id("delimiter (string)",ui(" A string, possible empty, or a reference to a valid string. If empty, the text will be simply concatenated.")),Id("ignore_empty (boolean)",ui("A boolean; if TRUE, empty cells selected in the text arguments won't be included in the result."),[{value:!0,label:ui("Ignore empty cells")},{value:!1,label:ui("Include empty cells (default)")}]),Id("text1 (string, range<string>)",ui("Any text item. This could be a string, or an array of strings in a range.")),Id("text2 (string, range<string>, repeating)",ui("Additional text item(s)."))],compute:function(e,t={value:true},...o){const s=En(e),i=An(t);let n=0;return Nn(o,((e,t)=>i&&""===En(t)?e:(n++?e+s:"")+En(t)),"")},isExported:!0},fC={description:ui("Splits text into rows or columns using specified column and row delimiters."),args:[Id("text (string)",ui("The text to split.")),Id("col_delimiter (string, range<string>)",ui("Character or string to split columns by.")),Id("row_delimiter (string, range<string>, optional)",ui("Character or string to split rows by.")),Id("ignore_empty (boolean, default=false)",ui("Whether to ignore empty cells."),[{value:!1,label:ui("Include empty cells (default)")},{value:!0,label:ui("Ignore empty cells")}]),Id("match_mode (number, default=0)",ui("Searches the text for a delimiter match. By default, a case-sensitive match is done."),XS),Id(`pad_with (string, default="${sn.NotAvailable}")`,ui("The value to use for padding empty cells."))],compute:function(e,t,o,s={value:false},i={value:0},n=new hn){const r=En(e);if(r.length<=0)return new rn(ui("No text to split."));if(void 0===t&&void 0===o)return new rn(ui("At least one delimiter must be provided."));const a=Kn(t).flat().map((e=>gt(En(e)))),l=Kn(o).flat().map((e=>gt(En(e))));if(a.some((e=>""===e))||l.some((e=>""===e)))return new rn(ui("The delimiters cannot be empty values."));const c=An(s),h=Sn(i,this.locale);if(![0,1].includes(h))return new rn(ui("match_mode should be a value of 0 or 1."));const d=[],u=1===h?"gi":"g",g=l.filter((e=>!a.includes(e)));let p=g.length?r.split(new RegExp(g.join("|"),u)):[r];c&&(p=p.filter((e=>""!==e)));const m=new RegExp(a.join("|"),u);for(const e of p){let t=a.length?e.split(m):[e];c&&(t=t.filter((e=>""!==e))),d.push(t.map((e=>({value:e}))))}const f=Math.max(...d.map((e=>e.length)));for(const e of d)for(;e.length<f;)e.push(n);return Hn(d)},isExported:!0},vC={description:ui("Removes space characters."),args:[Id("text (string)",ui("The text or reference to a cell containing text to be trimmed."))],compute:function(e){return oo(En(e))},isExported:!0},bC={description:ui("Converts a specified string to uppercase."),args:[Id("text (string)",ui("The string to convert to uppercase."))],compute:function(e){return En(e).toUpperCase()},isExported:!0},SC={description:ui("Converts a number to text according to a specified format."),args:[Id("number (number)",ui("The number, date or time to format.")),Id("format (string)",ui('The case-sensitive format of the result, enclosed in quotation marks. Examples: "0.00" rounded to 2 decimal places, "hh:mm:ss" for hour:minutes:seconds.'))],compute:function(e,t){return Rr(Sn(e,this.locale),{format:En(t),locale:this.locale})},isExported:!0},CC={description:ui("Converts a string to a numeric value."),args:[Id("value (number)",ui("the string to be converted"))],compute:function(e){return Sn(e,this.locale)},isExported:!0},yC={description:ui("Returns text that occurs after a given substring or delimiter."),args:[Id("text (string)",ui("The source text.")),Id("delimiter (string)",ui("The substring after which text will be returned.")),Id("instance_num (number, default=1)",ui("The desired instance of the delimiter after which we extract the text. A negative number searches from the end.")),Id("match_mode (number, default=0)",ui("Searches the text for a delimiter match. By default, a case-sensitive match is done."),XS),Id("match_end (number, default=0))",ui("Whether to treat the end of text as a delimiter."),KS),Id(`if_not_found (string, default="${sn.NotAvailable}")`,ui("Value to return if the delimiter is not found."))],compute:function(e,t,o={value:1},s={value:0},i={value:0},n=new hn){const r=En(e),a=Sn(o,this.locale),l=Sn(s,this.locale),c=Sn(i,this.locale);if(0===a)return new rn(ui("The instance_num (%s) must not be zero.",a));if(0!==l&&1!==l)return new rn(ui("match_mode should have a value of 0 or 1."));if(0!==c&&1!==c)return new rn(ui("match_end should have a value of 0 or 1."));const h=En(t);if(""===h)return Math.sign(a)>0?{value:r}:{value:""};const d=1===l?"gi":"g",u=gt(h),g=new RegExp(u,d);let p=[...r.matchAll(g)].map((e=>e.index+u.length));if(a<0&&(p=p.reverse()),c&&Math.abs(a)===p.length+1)return Math.sign(a)>0?{value:""}:{value:r};const m=p[Math.abs(a)-1];return void 0===m?n:{value:r.substring(m)}},isExported:!0},IC={description:ui("Returns text that occurs before a given substring or delimiter."),args:[Id("text (string)",ui("The source text.")),Id("delimiter (string)",ui("The substring after which text will be returned.")),Id("instance_num (number, default=1)",ui("The desired instance of the delimiter before which we extract the text. A negative number searches from the end.")),Id("match_mode (number, default=0)",ui("Searches the text for a delimiter match. By default, a case-sensitive match is done."),XS),Id("match_end (number, default=0))",ui("Whether to match a delimiter against the end of the text."),KS),Id(`if_not_found (string, default="${sn.NotAvailable}")`,ui("Value to return if the delimiter is not found."))],compute:function(e,t,o={value:1},s={value:0},i={value:0},n=new hn){const r=En(e),a=Sn(o,this.locale),l=Sn(s,this.locale),c=Sn(i,this.locale);if(0===a)return new rn(ui("The instance_num (%s) must not be zero.",a));if(0!==l&&1!==l)return new rn(ui("match_mode should have a value of 0 or 1."));if(0!==c&&1!==c)return new rn(ui("match_end should have a value of 0 or 1."));const h=En(t);if(""===h)return Math.sign(a)>0?{value:""}:{value:r};const d=1===l?"gi":"g",u=gt(h),g=new RegExp(u,d);let p=[...r.matchAll(g)].map((e=>e.index+u.length));if(a<0&&(p=p.reverse()),c&&Math.abs(a)===p.length+1)return Math.sign(a)>0?{value:r}:{value:""};const m=p[Math.abs(a)-1];return void 0===m?n:{value:r.substring(0,m-h.length)}},isExported:!0};var wC=Object.freeze({__proto__:null,CHAR:JS,CLEAN:QS,CONCATENATE:eC,EXACT:tC,FIND:oC,JOIN:sC,LEFT:iC,LEN:nC,LOWER:rC,MID:aC,PROPER:lC,REGEXEXTRACT:cC,REPLACE:hC,RIGHT:dC,SEARCH:uC,SPLIT:gC,SUBSTITUTE:pC,TEXT:SC,TEXTAFTER:yC,TEXTBEFORE:IC,TEXTJOIN:mC,TEXTSPLIT:fC,TRIM:vC,UPPER:bC,VALUE:CC});const xC={description:ui("Creates a hyperlink in a cell."),args:[Id("url (string)",ui("The full URL of the link enclosed in quotation marks.")),Id("link_label (string, optional)",ui("The text to display in the cell, enclosed in quotation marks."))],compute:function(e,t){const o=En(e).trim(),s=En(t)||o;return""===o?s:At(s,o)},isExported:!0};var EC=Object.freeze({__proto__:null,HYPERLINK:xC});const RC=[{name:ui("Array"),functions:Kd},{name:ui("Database"),functions:qp},{name:ui("Date"),functions:df},{name:ui("Filter"),functions:wf},{name:ui("Financial"),functions:Ov},{name:ui("Info"),functions:fb},{name:ui("Lookup"),functions:cS},{name:ui("Logical"),functions:Ab},{name:ui("Math"),functions:bg},{name:ui("Misc"),functions:Qd},{name:ui("Operator"),functions:DS},{name:ui("Statistical"),functions:Fp},{name:ui("Text"),functions:wC},{name:ui("Engineering"),functions:gf},{name:ui("Web"),functions:EC},{name:ui("Parser"),functions:jS}],TC=/^[A-Z0-9\_\.]+$/;const AC=new class extends n{mapping={};add(e,t){if((e=e.toUpperCase())in this.content)throw new Error(`${e} is already present in this registry!`);return this.replace(e,t)}replace(e,t){if(e=e.toUpperCase(),!TC.test(e))throw new Error(ui("Invalid function name %s. Function names can exclusively contain alphanumerical values separated by dots (.) or underscore (_)",e));const o=function(e,t){let o=0,s=0,i=0,n=0;for(const e of t.args)o++,e.optional||e.repeating||e.default||s++,e.repeating&&i++,(e.optional||e.default)&&n++;const r=t;return r.minArgRequired=s,r.maxArgPossible=i?1/0:o,r.nbrArgRepeating=i,r.nbrArgOptional=n,r.hidden=t.hidden||!1,r.name=e,r}(e,t);return function(e){if(e.nbrArgRepeating&&e.nbrArgOptional>=e.nbrArgRepeating)throw new Error(`Function ${e.name} has more optional arguments than repeatable ones.`);let t=!1,o=!1;for(const s of e.args){if(s.type.some((e=>Ed.includes(e)))&&s.type.some((e=>!Ed.includes(e))))throw new Error(`Function ${e.name} has a mix of META and non-META types in the same argument: ${s.type}.`);if(s.repeating){if(!o&&t)throw new Error(`Function ${e.name} has non-consecutive repeating arguments. All repeating arguments must be declared consecutively.`);t=!0,o=!0}else o=!1}}(o),this.mapping[e]=function(e){function t(...t){const s=[],i=xd(e,t.length);for(let o=0;o<t.length;o++){const n=i(o)??-1,r=e.args[n];if(!E(t[o])&&r.acceptMatrixOnly)throw new an(ui("Function %s expects the parameter '%s' to be reference to a cell or range.",e.name,(o+1).toString()));s.push(!r.acceptMatrix)}return zn(o.bind(this),t,s)}function o(...t){for(let o=0;o<t.length;o++){const s=t[o],i=xd(e,t.length);if(!e.args[i(o)||o].acceptErrors&&!E(s)&&fn(s?.value))return s}try{return s.apply(this,t)}catch(t){return DC(t,e.name)}}function s(...t){this.debug;const o=e.compute.apply(this,t);return E(o)?"object"==typeof o[0][0]&&null!==o[0][0]&&"value"in o[0][0]?(function(e,t){const o=e.length,s=e[0]?.length??0;for(let i=0;i<o;i++)for(let o=0;o<s;o++)t(e[i][o])}(o,(t=>_C(t,e.name))),o):Un(o,(e=>({value:e}))):"object"==typeof o&&null!==o&&"value"in o?(_C(o,e.name),o):{value:o}}return t}(o),super.replace(e,o),this}};for(const e of RC){const t=e.functions;for(let o in t){const s=t[o];s.category=s.category||e.name,o=o.replace(/_/g,"."),AC.add(o,{isExported:!1,...s}),PC(o,s.args)}}function DC(e,t){return o=e,void 0!==o?.value&&"string"==typeof o.value&&fn(e.value)?(OC(e)&&_C(e,t),e):(console.error(e),new rn(FC+(OC(e)?" "+e.message:"")));var o}function _C(e,t){e.message?.includes("[[FUNCTION_NAME]]")&&(e.message=e.message.replace("[[FUNCTION_NAME]]",t))}const FC=ui("An unexpected error occurred. Submit a support ticket at odoo.com/help.");function OC(e){return void 0!==e?.message&&"string"==typeof e.message}function PC(e,t){for(let o=0;o<t.length;o++){const s=t[o].proposalValues;if(void 0===s||0===s.length)continue;const i=t=>{const i=t.functionContext;if(!i||i.parent.toUpperCase()!==e.toUpperCase()||i.argPosition!==o)return;const n=[];let r="";for(const{value:e,label:t}of s){switch(typeof e){case"string":r=`"${e}"`;break;case"number":r=e.toString();break;case"boolean":r=e?"TRUE":"FALSE"}n.push({text:r,description:t,htmlContent:[{value:r,color:"string"==typeof e?ht.STRING:ht.NUMBER}],fuzzySearchKey:r,alwaysExpanded:!0})}return n};Rd.add(`${e}_function_${t[o].name}_argument_proposals`,{sequence:50,autoSelectFirstProposal:!0,selectProposal:MC,getProposals:i})}}function MC(e,t){let o=e.end;const s=e.end;["LEFT_PAREN","ARG_SEPARATOR"].includes(e.type)||(o=e.start),this.composer.stopComposerRangeSelection(),this.composer.changeComposerCursorSelection(o,s),this.composer.replaceComposerCursorSelection(t)}class NC{scope;code="";constructor(e=new LC){this.scope=e}append(...e){this.code+=e.map((e=>e.toString())).join("\n")+"\n"}return(e){return new kC(this.scope,this.code,e)}toString(){return VC(this.code)}}class kC{scope;returnExpression;code;constructor(e,t,o){this.scope=e,this.returnExpression=o,this.code=VC(t)}toString(){return this.code}assignResultToVariable(){if(this.scope.isAlreadyDeclared(this.returnExpression))return this;const e=this.scope.nextVariableName(),t=new NC(this.scope);return t.append(this.code),t.append(`const ${e} = ${this.returnExpression};`),t.return(e)}}class LC{nextId=1;declaredVariables=new Set;nextVariableName(){const e="_"+this.nextId++;return this.declaredVariables.add(e),e}isAlreadyDeclared(e){return this.declaredVariables.has(e)}}function VC(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 UC=AC.content,HC={"=":"EQ","+":"ADD","-":"MINUS","*":"MULTIPLY","/":"DIVIDE",">=":"GTE","<>":"NE",">":"GT","<=":"LTE","<":"LT","^":"POWER","&":"CONCATENATE"},zC={"-":"UMINUS","+":"UPLUS","%":"UNARY.PERCENT"},BC={};function $C(e){return GC(Lv(e))}function GC(e){try{return function(e){const{dependencies:t,literalValues:o,symbols:s}=function(e){const t={numbers:[],strings:[]},o=[],s=[];for(const i of e)switch(i.type){case"INVALID_REFERENCE":case"REFERENCE":o.push(i.value);break;case"STRING":const e=ut(i.value);t.strings.push({value:e});break;case"NUMBER":{const e=tn(i.value,w);t.numbers.push({value:e});break}case"SYMBOL":s.push(ft(i.value,"'"))}return{dependencies:o,literalValues:t,symbols:s}}(e),i=function(e){let t="";for(const o of e)switch(o.type){case"STRING":t+="|S|";break;case"NUMBER":t+="|N|";break;case"REFERENCE":case"INVALID_REFERENCE":o.value.includes(":")?t+="|R|":t+="|C|";break;case"SPACE":break;default:t+=o.value}return t}(e);if(!BC[i]){const r=jv([...e]),a=new LC;let l=0,c=0,h=0;if("BIN_OPERATION"===r.type&&":"===r.value)throw new an(ui("Invalid formula"));if("EMPTY"===r.type)throw new an(ui("Invalid formula"));const d=m(r),u=new NC;u.append(`// ${i}`),u.append(d),u.append(`return ${d.returnExpression};`);const g=new Function("deps","ref","range","getSymbolValue","ctx",u.toString());function p(e){const{args:t}=e,o=e.value.toUpperCase(),s=UC[o];if(!s)throw new dn(ui('Unknown function: "%s"',e.value));!function(e){const t=e.args.length,o=e.value.toUpperCase(),s=UC[o],{nbrArgRepeating:i,minArgRequired:n}=s;if(t<n)throw new an(ui("Invalid number of arguments for the %(functionName)s function. Expected %(minArgRequired)s minimum, but got %(nbrArgSupplied)s instead.",{functionName:o,minArgRequired:n,nbrArgSupplied:t}));if(t>s.maxArgPossible)throw new an(ui("Invalid number of arguments for the %(functionName)s function. Expected %(maxArgPossible)s maximum, but got %(nbrArgSupplied)s instead.",{functionName:o,maxArgPossible:s.maxArgPossible,nbrArgSupplied:t}));if(i>1){const e=t-n-i*Math.floor((t-n)/i)-s.nbrArgOptional;if(e>0)throw new an(ui("Invalid number of arguments for the %(functionName)s function. Repeatable arguments should be supplied in groups of %(nbrArgRepeating)s, with up to %(nbrArgOptional)s optional. Got %(nbrValueRemaining)s too many.",{functionName:o,nbrArgRepeating:i,nbrArgOptional:s.nbrArgOptional,nbrValueRemaining:e}))}}(e);const i=[],n=xd(s,t.length);for(let e=0;e<t.length;e++){const o=s.args[n(e)??-1],r=t[e],a=o.type||[],l=a.includes("META")||a.includes("RANGE<META>"),c=a.some((e=>WC(e)));i.push(m(r,l,c))}return i}function m(e,t=!1,o=!1){const i=new NC(a);if("REFERENCE"!==e.type&&("BIN_OPERATION"!==e.type||":"!==e.value)&&t)throw new an(ui("Argument must be a reference to a cell or range."));switch(e.debug&&(i.append("debugger;"),i.append('ctx["debug"] = true;')),e.type){case"BOOLEAN":return i.return(`{ value: ${e.value} }`);case"NUMBER":return i.return(`this.literalValues.numbers[${c++}]`);case"STRING":return i.return(`this.literalValues.strings[${l++}]`);case"REFERENCE":return i.return(`${e.value.includes(":")||o?"range":"ref"}(deps[${h++}], ${t?"true":"false"})`);case"FUNCALL":const n=p(e).map((e=>e.assignResultToVariable()));i.append(...n);const r=e.value.toUpperCase();return i.return(`ctx['${r}'](${n.map((e=>e.returnExpression))})`);case"UNARY_OPERATION":{const t=zC[e.value],o=m(e.operand,!1,!1).assignResultToVariable();return i.append(o),i.return(`ctx['${t}'](${o.returnExpression})`)}case"BIN_OPERATION":{const t=HC[e.value],o=m(e.left,!1,!1).assignResultToVariable(),s=m(e.right,!1,!1).assignResultToVariable();return i.append(o),i.append(s),i.return(`ctx['${t}'](${o.returnExpression}, ${s.returnExpression})`)}case"SYMBOL":const a=s.indexOf(e.value);return i.return(`getSymbolValue(this.symbols[${a}])`);case"EMPTY":return i.return("undefined")}}BC[i]=g}const n={execute:BC[i],dependencies:t,literalValues:o,symbols:s,tokens:e,isBadExpression:!1,normalizedFormula:i};return n}(e)}catch(t){return{tokens:e,dependencies:[],execute:function(){return t},isBadExpression:!0,normalizedFormula:e.map((e=>e.value)).join("")}}}function WC(e){return e.startsWith("RANGE")}const qC=AC.content;function ZC(e){try{return 0===Xv(jv(e)).filter((e=>"FUNCALL"===e.type&&!qC[e.value.toUpperCase()]?.isExported)).length}catch(e){return!1}}function jC(e,t){if(!e.some((e=>"SYMBOL"===e.type&&t.includes(e.value.toUpperCase()))))return[];let o;try{o=jv(e)}catch{return[]}return function(e,t){return Xv(e).filter((e=>"FUNCALL"===e.type&&t.includes(e.value.toUpperCase()))).map((e=>({functionName:e.value.toUpperCase(),args:e.args})))}(o,t)}function YC(e,t,o){if(!t.startsWith("="))return t;const s=Lv(t);for(let t=1;t<s.length;t++){if("REFERENCE"!==s[t].type)continue;const i=s[t].value,n=XC(e,i,o);i!==n&&(s[t]={value:n,type:"REFERENCE"})}return Lt(s.map((e=>e.value)))}function XC(e,t,o){const s=Ta(t).sheetName;if(s?!Ma(s,o.sheetName.old):e!==o.sheetId)return t;const i=function(e,t){if(!Ia.test(e))return La(e);return ka({xc:e,sheetId:t},KC)}(t,s?o.sheetId:e);if(i.invalidXc)return t;const n=o.applyChange(i);return"NONE"===n.changeType||"REMOVE"===n.changeType?t:Ha(n.range,e,function(e){return t=>t===e.sheetId?e.sheetName.current:""}(o))}function KC(e){return{numberOfRows:Number.MAX_SAFE_INTEGER,numberOfCols:Number.MAX_SAFE_INTEGER}}const JC="x1",QC="xMovingAverage",ey={exponential:"exp",logarithmic:"log",polynomial:"poly",trailingMovingAverage:"movingAvg"};function ty(e,t,o,s){let i=!1;const n=[];for(const s in o){let r=o[s];if(r.labelCell){const e=iy(r.labelCell,t);r.labelCell!==e&&(i=!0,r={...r,labelCell:e})}const a=iy(r.dataRange,t);void 0===a||e.getRangeString(a,a.sheetId)===sn.InvalidReference?(i=!0,r=void 0):a!==r.dataRange&&(i=!0,r={...r,dataRange:a}),n[s]=r}let r=s;const a=iy(r,t);a!==r&&(i=!0,r=a);return{isStale:i,dataSets:n.filter(Mt),labelRange:r}}function oy(e,t,o){return o.map((o=>({dataRange:za(e,t,o.dataRange),labelCell:o.labelCell?za(e,t,o.labelCell):void 0})))}function sy(e,t,o){return o?za(e,t,o):void 0}function iy(e,t){if(!e)return;const o=t(e);switch(o.changeType){case"NONE":return e;case"REMOVE":return;default:return o.range}}function ny(e,t,o,s){const i=[];for(const n of t){const t=e.getRangeFromSheetXC(o,n.dataRange),{unboundedZone:r,sheetId:a,invalidSheetName:l,invalidXc:c}=t;if(!l&&!c)if(r.left!==r.right&&r.top!==r.bottom){if(void 0===r.right)continue;for(let t=r.left;t<=r.right;t++){const o={...r,left:t,right:t};i.push({...ry(e,a,o,s?{top:o.top,bottom:o.top,left:o.left,right:o.left}:void 0),backgroundColor:n.backgroundColor,rightYAxis:"y1"===n.yAxisId,customLabel:n.label,trend:n.trend})}}else i.push({...ry(e,a,r,s?{top:r.top,bottom:r.top,left:r.left,right:r.left}:void 0),backgroundColor:n.backgroundColor,rightYAxis:"y1"===n.yAxisId,customLabel:n.label,trend:n.trend})}return i}function ry(e,t,o,s){if(o.left!==o.right&&o.top!==o.bottom)throw new Error(`Zone should be a single column or row: ${Go(o)}`);if(s){const i=Go(o),n=Go(s);return{labelCell:e.getRangeFromSheetXC(t,n),dataRange:e.getRangeFromSheetXC(t,i)}}return{labelCell:void 0,dataRange:e.getRangeFromSheetXC(t,Go(o))}}function ay(e,t){const o=t.labelCell?.zone;let s=t.dataRange.zone;if(o){const{numberOfRows:e,numberOfCols:t}=os(s);1===e?s={...s,left:s.left+1}:1===t&&(s={...s,top:s.top+1})}const i=Na({...t.dataRange,zone:s},e.getSheetSize);let n,r={};return t.customLabel?r={text:t.customLabel}:t.labelCell&&(r={reference:e.getRangeString(t.labelCell,"forceSheetReference",{useBoundedReference:!0})}),t.trend?.type&&(n={type:"polynomial"===t.trend.type&&1===t.trend.order?"linear":ey[t.trend.type],color:t.trend.color,order:t.trend.order?Math.min(t.trend.order,6):void 0,window:t.trend.window||Ye}),{label:r,range:e.getRangeString(i,"forceSheetReference",{useBoundedReference:!0}),backgroundColor:t.backgroundColor,rightYAxis:t.rightYAxis,trend:n}}function ly(e,t,o){if(!t)return;const s={...t.zone};o&&t.zone.bottom>t.zone.top&&(s.top=s.top+1);const i=Na({...t,zone:s},e.getSheetSize);return e.getRangeString(i,"forceSheetReference",{useBoundedReference:!0})}function cy(e,t,o){let s;if(t.labelRange){const i=XC(e,t.labelRange,o);i!==sn.InvalidReference&&(s=i)}const i=[];for(const s of t.dataSets){const t={...s},n=XC(e,s.dataRange,o);n!==sn.InvalidReference&&(t.dataRange=n,i.push(t))}return{...t,dataSets:i,labelRange:s}}function hy(e){return e&&Ms(e)<.3?"#FFFFFF":"#000000"}function dy(e){return e&&Ms(e)<.3?"#C8C8C8":"#666666"}function uy(e){if(e.dataSets){const t=void 0!==e.dataSets.find((e=>!Ia.test(e.dataRange)));if(t)return"InvalidDataSet";if(e.dataSets.map((e=>Uo(e.dataRange))).some((e=>e.top!==e.bottom&&ds(e))))return"InvalidDataSet"}return"Success"}function gy(e){if(e.labelRange){if(!Ia.test(e.labelRange||""))return"InvalidLabelRange"}return"Success"}function py(e,t,o){if(!o)return!1;if(!e)return!1;if(!t)return!0;const s=gs(t.dataRange.zone);return!(gs(e.zone)<s)}function my(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 fy(e,t,o=!1){return(s,i)=>{const n=e?.[i];return vy({format:n,locale:t},o)(s)}}function vy(e,t=!1){return o=>{if(o=Number(o),isNaN(o))return o;const{locale:s,format:i}=e;return Cy(t?Wr({value:o,format:i},s):Rr(o,{locale:s,format:!i&&Math.abs(o)>=1e3?"#,##":i}))}}const by=[{value:"left",label:ui("Left")},{value:"right",label:ui("Right")}];function Sy(e,t){const o=[],s=no(t.map((e=>e.data.length)));for(let t=0;t<=s;t++)o.push(e.next());return o}function Cy(e,t=Be){return e?e.length>t?e.substring(0,t)+"…":e:""}function yy(e){return e===JC||e===QC}const Iy={id:"chartShowValuesPlugin",afterDatasetsDraw(e,t,o){if(!o.showValues)return;const s=e._metasets?.[0]?.data;if(!s)return;const i=e.ctx;i.save();const{left:n,top:r,height:a,width:l}=e.chartArea;switch(i.beginPath(),i.rect(n,r,l,a),i.clip(),i.textAlign="center",i.textBaseline="middle",i.miterLimit=1,e.config.type){case"pie":case"doughnut":!function(e,t,o){for(const s of e._metasets)for(let e=0;e<s._parsed.length;e++){const i=Number(s._parsed[e]);if(isNaN(i)||0===i)continue;const n=s.data[e],{startAngle:r,endAngle:a,innerRadius:l,outerRadius:c}=n,h=(r+a)/2,d=(l+c)/2,u=n.x+d*Math.cos(h),g=n.y+d*Math.sin(h),p=t.callback(i,s,e),m=12,f=nl(o,p,{fontSize:m},"px"),v=c-l;if(f>=v||v<m)continue;const b=a-r,S=2*d*Math.tan(b/2);b<Math.PI/2&&(f>=S||S<m)||(o.fillStyle=hy(t.background),o.strokeStyle=t.background||"#ffffff",wy(p,u,g,o))}}(e,o,i);break;case"bar":case"line":case"radar":o.horizontal?xy(e,o,i):function(e,t,o){const s=e.chartArea.bottom,i=e.chartArea.top,n={};for(const r of e._metasets){if(yy(r.xAxisID)||r.hidden)continue;const a=e.scales[r.yAxisID];for(let l=0;l<r._parsed.length;l++){const c=r._parsed[l],h=Number("radar"===e.config.type?c.r:c.y);if(isNaN(h))continue;const d=r.data[l],u=d.x;let g=0;if("line"===e.config.type||"radar"===e.config.type)g=h<0?d.y+10:d.y-10;else{const e=a.getPixelForValue(0),t=12;g=Math.abs(e-d.y)<t?h<0?e+t/2:e-t/2:h<0?d.y-d.height/2:d.y+d.height/2}g=Math.min(g,s),g=Math.max(g,i),n[u]||(n[u]=[]);for(const e of n[u]||[])Math.abs(e-g)<13&&(g=h<0?e+13:e-13);n[u].push(g),o.fillStyle=d.options.backgroundColor,o.strokeStyle=t.background||"#ffffff";wy(t.callback(Number(h),r,l),u,g,o)}}}(e,o,i);break;case"funnel":xy(e,o,i)}i.restore()}};function wy(e,t,o,s){s.lineWidth=3,s.strokeText(e,t,o),s.lineWidth=1,s.fillText(e,t,o)}function xy(e,t,o){const s=e.chartArea.right,i=e.chartArea.left,n={};for(const r of e._metasets){if(yy(r.xAxisID))return;const a=e.scales[r.xAxisID].getPixelForValue(0);for(let e=0;e<r._parsed.length;e++){const l=Number(r._parsed[e].x);if(isNaN(l))continue;const c=t.callback(l,r,e),h=r.data[e],d=h.y,u=nl(o,c,{fontSize:12},"px"),g=3;let p;Math.abs(h.x-a)<u?p=l<0?a-u/2-g:a+u/2+g:(p=l<0?h.x+h.width/2:h.x-h.width/2,p=Math.min(p,s),p=Math.max(p,i)),n[d]||(n[d]=[]);for(const e of n[d])Math.abs(e-p)<u&&(p=l<0?e-u-g:e+u+g);n[d].push(p),o.fillStyle=h.options.backgroundColor,o.strokeStyle=t.background||"#ffffff",wy(c,p,d,o)}}}const Ey={showHeaders:!0,headerDesign:{align:"center",fillColor:"#808080",bold:!0,fontSize:15},showValues:!0,showLabels:!0,valuesDesign:{align:"left",verticalAlign:"bottom",fontSize:12},coloringOptions:{type:"categoryColor",colors:[],useValueBasedGradient:!0}},Ry="nullValue";function Ty(e,t){const{dataSetsValues:o}=t,s=[],i=Wy(e,o.length),n=[];for(const r in o){let{label:a,data:l,hidden:c}=o[r];a=e.dataSets?.[r].label||a;const h=i.next(),d={label:a,data:l,hidden:c,borderColor:e.background||k,borderWidth:e.stacked?1:0,backgroundColor:h,yAxisID:e.horizontal?"y":e.dataSets?.[r].yAxisId||"y",xAxisID:"x"};s.push(d);const u=e.dataSets?.[r].trend,g=t.trendDataSetsValues?.[r];u?.display&&!e.horizontal&&g&&n.push($y(d,u,g))}return s.push(...n),s}function Ay(e,t){const{dataSetsValues:o,labels:s}=t,i=e.negativeValuesColor||Y,n=e.positiveValuesColor||j,r=e.subTotalValuesColor||X,a=[],l=[],c={label:"",data:l,backgroundColor:a},h=[];let d=0;for(const t of o)if(!t.hidden){for(let c=0;c<t.data.length;c++){const u=t.data[c];if(h.push(s[c]),isNaN(Number(u))){l.push([d,d]),a.push("");continue}l.push([d,u+d]);let g=u>=0?n:i;0===c&&t===o[0]&&e.firstValueAsSubtotal&&(g=r),a.push(g),d+=u}e.showSubTotals&&(h.push(ui("Subtotal")),l.push([0,d]),a.push(r))}return{datasets:[c],labels:h}}function Dy(e,t){const{dataSetsValues:o,axisType:s,labels:i}=t,n=[],r=!!e.fillArea,a=!!e.stacked,l=[],c=Wy(e,o.length);for(let h=0;h<o.length;h++){let{label:d,data:u,hidden:g}=o[h];d=e.dataSets?.[h].label||d;const p=c.next();s&&["linear","time"].includes(s)&&(u=u.map(((e,t)=>({x:i[t]||void 0,y:e}))));const m={label:d,data:u,hidden:g,tension:0,borderColor:p,backgroundColor:r?Bs(p,Ze):p,pointBackgroundColor:p,fill:!!r&&Gy(h,a),pointRadius:e.hideDataMarkers?0:je,yAxisID:e.dataSets?.[h].yAxisId||"y"};n.push(m);const f=e.dataSets?.[h].trend,v=t.trendDataSetsValues?.[h];f?.display&&v&&l.push($y(m,f,v))}return n.push(...l),n}function _y(e,t){const o=Dy(e,t);for(const e of o)yy(e.xAxisID)||(e.showLine=!1);return o}function Fy(e,t){const{dataSetsValues:o}=t,s=[],i=Math.max(0,...o.map((e=>e?.data?.length??0))),n=Sy(new ti(i),o);for(const{label:t,data:i,hidden:r}of o){if(r)continue;const o={label:t,data:i,borderColor:e.background||"#FFFFFF",backgroundColor:n,hoverOffset:10};s.push(o)}return s}function Oy(e,t){const{dataSetsValues:o}=t,s=[],i=Wy(e,o.length),n=[];for(let r=0;r<o.length;r++){let{label:a,data:l,hidden:c}=o[r];a=e.dataSets?.[r].label||a;const h=e.dataSets?.[r],d=i.next(),u=h?.type??"line",g={label:a,data:l,hidden:c,borderColor:d,backgroundColor:d,yAxisID:e.dataSets?.[r].yAxisId||"y",xAxisID:"x",type:u,order:"bar"===u?o.length+r:r,pointRadius:e.hideDataMarkers?0:je};s.push(g);const p=e.dataSets?.[r].trend,m=t.trendDataSetsValues?.[r];p?.display&&m&&n.push($y(g,p,m))}return s.push(...n),s}function Py(e,t){const{dataSetsValues:o}=t,s=[],i=e.fillArea??!1,n=Wy(e,o.length);for(let t=0;t<o.length;t++){let{label:r,data:a,hidden:l}=o[t];e.dataSets?.[t]?.label&&(r=e.dataSets[t].label);const c=n.next(),h={label:r,data:a,hidden:l,borderColor:c,backgroundColor:c,pointRadius:e.hideDataMarkers?0:je};i&&(h.backgroundColor=Bs(c,Ze),h.fill="start"),s.push(h)}return s}function My(e,t){const{availableRegions:o,dataSetsValues:s,labels:i}=t,n=e.region||o[0]?.id,r=n?t.getGeoJsonFeatures(n):void 0,a={outline:r,showOutline:!!r,data:[]};if(r&&n){const e={};if(s[0])for(let o=0;o<s[0].data.length;o++){if(!i[o]||void 0===s[0].data[o])continue;const r=t.geoFeatureNameToId(n,i[o]);r&&(e[r]={value:s[0].data[o],label:i[o]})}for(const t of r)t.id&&a.data.push({feature:{...t,properties:{name:e[t.id]?.label}},value:e[t.id]?.value})}return[a]}function Ny(e,t){const o=t.dataSetsValues[0],s=t.labels;if(!o)return[];let{label:i,data:n}=o;i=e.dataSets?.[0].label||i;return[{label:i,data:n.map((e=>e<=0?[0,0]:[-e,e])),backgroundColor:ky(s,e.funnelColors),yAxisID:"y",xAxisID:"x",barPercentage:1,categoryPercentage:1,borderColor:e.background||k,borderWidth:3}]}function ky(e,t){const o=new ti(e.length,t);return e.map((()=>o.next()))}function Ly(e,t){const{dataSetsValues:o,labels:s}=t,i=Hy(Vy(o,s)),n=i[0]||[],r=new ti(n.length,e.groupColors||[]),a=n.map((e=>({label:e.label,color:r.next()}))),l=[];for(let t=i.length-1;t>=0;t--){const o={groupColors:a,parsing:{key:"value"},data:i[t],borderColor:t=>{const o="data"===t.type?t.raw:void 0;return o&&o.label!==Ry?e.background||k:Z},backgroundColor:e=>{const t="data"===e.type?e.raw:void 0;if(!t||t.label===Ry)return Z;const o=t.groups[0];return a.find((e=>e.label===o))?.color},hoverOffset:10};l.push(o)}return l}function Vy(e,t){const o=function(e,t){const o=[],s=Math.max(...e.map((e=>e.data.length)));for(let i=0;i<s;i++){o[i]={};for(let t=0;t<e.length;t++){const s=null===e[t].data[i]?Ry:String(e[t].data[i]);o[i][t]=s}o[i].value=Number(t[i])}return o}(e,t);return Uy(o,0,e.length,[])}function Uy(e,t,o,s){if(t>=o)return[];const i=Object.groupBy(e,(e=>e[t]));return Object.keys(i).map((e=>{const n=i[e]?.reduce(((e,t)=>e+Number(t.value)),0)||0,r=[...s,e];return{label:e,value:n,children:Uy(i[e]||[],t+1,o,[...s,e]),groups:r,depth:t}})).sort(((e,t)=>t.value-e.value))}function Hy(e){const t=[],o=[...e];for(;o.length>0;){const e=o.shift();e&&(t[e.depth]||(t[e.depth]=[]),t[e.depth].push(e),e.children&&o.push(...e.children))}return t}function zy(e,t){const{dataSetsValues:o,labels:s,locale:i,axisFormats:n}=t,r={locale:i,format:n?.y};if(0===o.length)return[];const a=Vy(o,s).sort(((e,t)=>t.value-e.value)),l=function(e,t){const o="categoryColor"===e.coloringOptions?.type?e.coloringOptions.colors:[],s=new ti(t.length,o);return t.map((e=>({label:e.label,color:s.next()})))}(e,a),c=[],h=Math.max(...o.map((e=>e.data.length)));for(let e=0;e<h;e++){c[e]={};for(let t=0;t<o.length;t++)c[e][t]=o[t].data[e]?String(o[t].data[e]):void 0;c[e].value=Number(s[e])}const d=e.showLabels??Ey.showLabels,u=e.showValues??Ey.showValues,g=e.coloringOptions||Ey.coloringOptions;let p;"colorScale"===g?.type&&(p=function(e,t){const o=Hy(e),s=o[o.length-1],i=Math.min(...s.map((e=>e.value))),n=Math.max(...s.map((e=>e.value)));if(Number.isFinite(i)&&Number.isFinite(n)){const e=[{value:i,color:t.minColor}];if(t.midColor){const o=(i+n)/2;e.push({value:o,color:t.midColor})}return e.push({value:n,color:t.maxColor}),ii(e)}return}(a,g));const m=[{data:[],tree:c,labels:{display:d||u,overflow:"hidden",...By(e.valuesDesign,Ey.valuesDesign),formatter:e=>[d?e.raw.g:void 0,u?Rr(e.raw.v,r):void 0].filter(Mt)},captions:{display:e.showHeaders??Ey.showHeaders,padding:6,...By(e.headerDesign,Ey.headerDesign)},key:"value",groups:Ct(0,o.length).map((e=>String(e))),borderWidth:0,spacing:1,displayMode:"headerBoxes",groupColors:l,backgroundColor:t=>{if("data"!==t.type)return"transparent";if(!t.raw.isLeaf)return e.headerDesign?.fillColor||Ey.headerDesign?.fillColor;if("colorScale"===g.type)return p?.(t.raw.v)||"#FF0000";if("categoryColor"===g.type)return function(e,t,o,s){const i=e.raw._data.children[0][0],n=s.find((e=>e.label===i))?.color;if(!n||!o.useValueBasedGradient)return n||"#FF0000";const r=t.find((e=>e.label===i));if(!r||!r.children.length)return n;const a=Hy(r.children),l=a[a.length-1],c=Math.max(...l.map((e=>e.value))),h=Math.min(...l.map((e=>e.value)));if(h===c||!isFinite(h)||!isFinite(c))return n;const d=Number(e.raw.v)||0,u=(d-c)/(h-c)*.5;return $s(n,u)}(t,a,g,l);throw new Error("Unsupported coloring option type}")}}];return m}function By(e,t){const o=e=>Ms(e.element.options.backgroundColor)>.7?"#666666":"#FFFFFF";return{align:e?.align??t?.align,position:e?.verticalAlign??t?.verticalAlign,color:e?.color||o,hoverColor:e?.color||o,font:{weight:e?.bold??t?.bold?"bold":"normal",style:e?.italic??t?.italic?"italic":"normal",size:e?.fontSize??t?.fontSize}}}function $y(e,t,o){const s=ks(e.backgroundColor);s.a=1;const i=t.color||$s(Ns(s),.5);return{type:"line",xAxisID:"trailingMovingAverage"===t.type?QC:JC,yAxisID:e.yAxisID,label:e.label?ui("Trend line for %s",e.label):"",data:o,order:-1,showLine:!0,pointRadius:0,backgroundColor:i,borderColor:i,borderDash:[5,5],borderWidth:void 0,fill:!1,pointBackgroundColor:i}}function Gy(e,t){return t?0===e?"origin":"-1":"origin"}function Wy(e,t){return new ti(t,e.dataSets?.map((e=>e.backgroundColor))||[])}const qy={id:"sunburstHoverPlugin",afterEvent(e,t,o){if(!o.enabled)return;const s=e.getActiveElements();let i=s.map((e=>({datasetIndex:e.datasetIndex,index:e.index})));for(const t of s){const o=e.data.datasets[t.datasetIndex].data[t.index];for(let t=0;t<e.data.datasets.length;t++){const s=e.data.datasets[t];for(let e=0;e<s.data.length;e++){const n=s.data[e];Zy(o.groups,n.groups)&&i.push({datasetIndex:t,index:e})}}}i=i.filter((t=>{const{datasetIndex:o,index:s}=t;return e.data.datasets[o].data[s].label!==Ry})),e.setActiveElements(i);for(const t of e.getSortedVisibleDatasetMetas())for(const e of t.data){const t=e.$context,{datasetIndex:o,index:s,dataset:n,raw:r}=t;if(r.label===Ry)continue;const a="function"==typeof n.backgroundColor?n.backgroundColor(t):n.backgroundColor;i.length&&!i.some((e=>e.datasetIndex===o&&e.index===s))?e.options.backgroundColor=$s(a,.5):e.options.backgroundColor=a}}};function Zy(e,t){return t.length>e.length&&e.every(((e,o)=>e===t[o]))}const jy={id:"sunburstLabelsPlugin",afterDatasetsDraw(e,t,o){if(!o.showValues&&!o.showLabels||"doughnut"!==e.config.type)return;!function(e,t,o){const s=t.style,i=s.fontSize||13,n=i+3;for(const r of e._metasets)for(let a=0;a<r._dataset.data.length;a++){const l=r._dataset.data[a];if(l.label===Ry)continue;const c=[t.showLabels?l.label:void 0,t.showValues?t.callback(l.value,"y"):void 0].filter(Mt),h=r.data[a];let{startAngle:d,endAngle:u,innerRadius:g,outerRadius:p,circumference:m}=h;const f=h.options.offset/4,v=f*(1-Math.sin(Math.min(Math.PI,m||0)));g+=v,p+=v;const b=(d+u)/2,S=(g+p)/2,C=.9*(p-g),y=u-d;if((y>=Math.PI?p:Math.sin(y/2)*g*2)<c.length*n)continue;o.save();const I={x:Math.cos(b)*f,y:Math.sin(b)*f},w=e.chartArea.left+e.chartArea.width/2+I.x,x=e.chartArea.top+e.chartArea.height/2+I.y;let E;o.translate(w,x),b>Math.PI/2?(o.rotate(b-Math.PI),E=-S):(E=S,o.rotate(b));const R=Ms(h.options.backgroundColor)>.7?"#666666":"#FFFFFF";o.fillStyle=s.textColor||R,o.textAlign="center",o.textBaseline="middle",o.font=sl(i,s.bold,s.italic);const T=-(c.length-1)*n/2;for(let e=0;e<c.length;e++){const t=bl(o,C,c[e],s,"px");o.fillText(t,E,T+e*n)}o.restore()}}(e,o,e.ctx)}};const Yy={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=Ky(s,e);if(!o)break;const n=Xy(t),r=Xy(o),a=t.$context.raw,l=a[1]-a[0],c=Math.round(l<0?n.bottom-1:n.top),h=Math.round(n.right),d=Math.round(r.left);i.strokeStyle="#999",i.beginPath(),i.moveTo(h+1,c+.5),i.lineTo(d,c+.5),i.stroke()}i.restore()}};function Xy(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 Ky(e,t){return e.find(((e,o)=>o>t&&0!==e.height))}Bh`
1
+ !function(e,t){"use strict";function o(e){return e.map(i).sort(((e,t)=>e.sequence-t.sequence))}let s=1;function i(e){const t=e.name,o=e.children,n=e.description,r=e.icon,a=e.secondaryIcon,l=e.id||s++,c=e.isEnabled?e.isEnabled:()=>!0;return{id:l.toString(),name:"function"==typeof t?t:()=>t,isVisible:e.isVisible?e.isVisible:()=>!0,isEnabled:c,isActive:e.isActive,execute:e.execute?(t,o)=>{if(c(t))return e.execute(t,o)}:void 0,children:o?e=>o.map((t=>"function"==typeof t?t(e):t)).flat().map(i):()=>[],isReadonlyAllowed:e.isReadonlyAllowed||!1,separator:e.separator||!1,icon:"function"==typeof r?r:()=>r||"",iconColor:e.iconColor,secondaryIcon:"function"==typeof a?a:()=>a||"",description:"function"==typeof n?n:()=>n||"",textColor:e.textColor,sequence:e.sequence||0,onStartHover:e.onStartHover,onStopHover:e.onStopHover}}class n{content={};add(e,t){if(e in this.content)throw new Error(`${e} is already present in this registry!`);return this.replace(e,t)}replace(e,t){return this.content[e]=t,this}get(e){const t=this.content[e];if(!t&&!(e in this.content))throw new Error(`Cannot find ${e} in this registry!`);return t}contains(e){return e in this.content}getAll(){return Object.values(this.content)}getKeys(){return Object.keys(this.content)}remove(e){delete this.content[e]}}var r,a;!function(e){e.boolean="boolean",e.number="number",e.text="text",e.empty="empty",e.error="error"}(r||(r={})),function(e){e.PlainText="text/plain",e.Html="text/html",e.Image="image"}(a||(a={}));const l=new Set(["RENAME_SHEET","DELETE_SHEET","CREATE_SHEET","DUPLICATE_SHEET","ADD_COLUMNS_ROWS","REMOVE_COLUMNS_ROWS","UNDO","REDO","ADD_MERGE","REMOVE_MERGE","DUPLICATE_SHEET","UPDATE_LOCALE","ADD_PIVOT","UPDATE_PIVOT","INSERT_PIVOT","RENAME_PIVOT","REMOVE_PIVOT","DUPLICATE_PIVOT"]),c=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"]),h=new Set(["MOVE_RANGES"]),d=new Set(["EVALUATE_CELLS","ADD_CONDITIONAL_FORMAT","REMOVE_CONDITIONAL_FORMAT","CHANGE_CONDITIONAL_FORMAT_PRIORITY"]),u=new Set(["AUTOFILL_CELL","SET_BORDER","SET_ZONE_BORDERS","SET_BORDERS_ON_TARGET"]),g=new Set(["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"]),p=new Set(["START","ACTIVATE_SHEET","COPY","RESIZE_SHEETVIEW","SET_VIEWPORT_OFFSET","EVALUATE_CELLS","EVALUATE_CHARTS","SET_FORMULA_VISIBILITY","UPDATE_FILTER","UPDATE_CHART","UPDATE_CAROUSEL_ACTIVE_ITEM","UPDATE_PIVOT"]),m=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","CREATE_CAROUSEL","UPDATE_CAROUSEL","SET_FORMATTING","CLEAR_FORMATTING","SET_BORDER","SET_ZONE_BORDERS","SET_BORDERS_ON_TARGET","CREATE_CHART","UPDATE_CHART","DELETE_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 f(e){return m.has(e.type)}class v{reasons;constructor(e=[]){Array.isArray(e)||(e=[e]),e=[...new Set(e)],this.reasons=e.filter((e=>"Success"!==e))}static get Success(){return b}get isSuccessful(){return 0===this.reasons.length}isCancelledBecause(e){return this.reasons.includes(e)}}const b=new v;var S;e.CommandResult=void 0,(S=e.CommandResult||(e.CommandResult={})).Success="Success",S.CancelledForUnknownReason="CancelledForUnknownReason",S.WillRemoveExistingMerge="WillRemoveExistingMerge",S.CannotMoveTableHeader="CannotMoveTableHeader",S.MergeIsDestructive="MergeIsDestructive",S.CellIsMerged="CellIsMerged",S.InvalidTarget="InvalidTarget",S.EmptyUndoStack="EmptyUndoStack",S.EmptyRedoStack="EmptyRedoStack",S.NotEnoughElements="NotEnoughElements",S.NotEnoughSheets="NotEnoughSheets",S.MissingSheetName="MissingSheetName",S.UnchangedSheetName="UnchangedSheetName",S.DuplicatedSheetName="DuplicatedSheetName",S.DuplicatedSheetId="DuplicatedSheetId",S.ForbiddenCharactersInSheetName="ForbiddenCharactersInSheetName",S.WrongSheetMove="WrongSheetMove",S.WrongSheetPosition="WrongSheetPosition",S.InvalidAnchorZone="InvalidAnchorZone",S.SelectionOutOfBound="SelectionOutOfBound",S.TargetOutOfSheet="TargetOutOfSheet",S.WrongCutSelection="WrongCutSelection",S.WrongPasteSelection="WrongPasteSelection",S.WrongPasteOption="WrongPasteOption",S.WrongFigurePasteOption="WrongFigurePasteOption",S.EmptyClipboard="EmptyClipboard",S.EmptyRange="EmptyRange",S.InvalidRange="InvalidRange",S.InvalidZones="InvalidZones",S.InvalidSheetId="InvalidSheetId",S.InvalidCellId="InvalidCellId",S.InvalidFigureId="InvalidFigureId",S.InputAlreadyFocused="InputAlreadyFocused",S.MaximumRangesReached="MaximumRangesReached",S.MinimumRangesReached="MinimumRangesReached",S.InvalidChartDefinition="InvalidChartDefinition",S.InvalidDataSet="InvalidDataSet",S.InvalidLabelRange="InvalidLabelRange",S.InvalidScorecardKeyValue="InvalidScorecardKeyValue",S.InvalidScorecardBaseline="InvalidScorecardBaseline",S.InvalidGaugeDataRange="InvalidGaugeDataRange",S.EmptyGaugeRangeMin="EmptyGaugeRangeMin",S.GaugeRangeMinNaN="GaugeRangeMinNaN",S.EmptyGaugeRangeMax="EmptyGaugeRangeMax",S.GaugeRangeMaxNaN="GaugeRangeMaxNaN",S.GaugeLowerInflectionPointNaN="GaugeLowerInflectionPointNaN",S.GaugeUpperInflectionPointNaN="GaugeUpperInflectionPointNaN",S.InvalidAutofillSelection="InvalidAutofillSelection",S.MinBiggerThanMax="MinBiggerThanMax",S.LowerBiggerThanUpper="LowerBiggerThanUpper",S.MidBiggerThanMax="MidBiggerThanMax",S.MinBiggerThanMid="MinBiggerThanMid",S.FirstArgMissing="FirstArgMissing",S.SecondArgMissing="SecondArgMissing",S.MinNaN="MinNaN",S.MidNaN="MidNaN",S.MaxNaN="MaxNaN",S.ValueUpperInflectionNaN="ValueUpperInflectionNaN",S.ValueLowerInflectionNaN="ValueLowerInflectionNaN",S.MinInvalidFormula="MinInvalidFormula",S.MidInvalidFormula="MidInvalidFormula",S.MaxInvalidFormula="MaxInvalidFormula",S.ValueUpperInvalidFormula="ValueUpperInvalidFormula",S.ValueLowerInvalidFormula="ValueLowerInvalidFormula",S.InvalidSortAnchor="InvalidSortAnchor",S.InvalidSortZone="InvalidSortZone",S.SortZoneWithArrayFormulas="SortZoneWithArrayFormulas",S.WaitingSessionConfirmation="WaitingSessionConfirmation",S.MergeOverlap="MergeOverlap",S.TooManyHiddenElements="TooManyHiddenElements",S.Readonly="Readonly",S.InvalidViewportSize="InvalidViewportSize",S.InvalidScrollingDirection="InvalidScrollingDirection",S.ViewportScrollLimitsReached="ViewportScrollLimitsReached",S.FigureDoesNotExist="FigureDoesNotExist",S.InvalidConditionalFormatId="InvalidConditionalFormatId",S.InvalidCellPopover="InvalidCellPopover",S.EmptyTarget="EmptyTarget",S.InvalidFreezeQuantity="InvalidFreezeQuantity",S.FrozenPaneOverlap="FrozenPaneOverlap",S.ValuesNotChanged="ValuesNotChanged",S.InvalidFilterZone="InvalidFilterZone",S.TableNotFound="TableNotFound",S.TableOverlap="TableOverlap",S.InvalidTableConfig="InvalidTableConfig",S.InvalidTableStyle="InvalidTableStyle",S.FilterNotFound="FilterNotFound",S.MergeInTable="MergeInTable",S.NonContinuousTargets="NonContinuousTargets",S.DuplicatedFigureId="DuplicatedFigureId",S.InvalidSelectionStep="InvalidSelectionStep",S.DuplicatedChartId="DuplicatedChartId",S.ChartDoesNotExist="ChartDoesNotExist",S.InvalidHeaderIndex="InvalidHeaderIndex",S.InvalidQuantity="InvalidQuantity",S.MoreThanOneColumnSelected="MoreThanOneColumnSelected",S.EmptySplitSeparator="EmptySplitSeparator",S.SplitWillOverwriteContent="SplitWillOverwriteContent",S.NoSplitSeparatorInSelection="NoSplitSeparatorInSelection",S.NoActiveSheet="NoActiveSheet",S.InvalidLocale="InvalidLocale",S.MoreThanOneRangeSelected="MoreThanOneRangeSelected",S.NoColumnsProvided="NoColumnsProvided",S.ColumnsNotIncludedInZone="ColumnsNotIncludedInZone",S.DuplicatesColumnsSelected="DuplicatesColumnsSelected",S.InvalidHeaderGroupStartEnd="InvalidHeaderGroupStartEnd",S.HeaderGroupAlreadyExists="HeaderGroupAlreadyExists",S.UnknownHeaderGroup="UnknownHeaderGroup",S.UnknownDataValidationRule="UnknownDataValidationRule",S.UnknownDataValidationCriterionType="UnknownDataValidationCriterionType",S.InvalidDataValidationCriterionValue="InvalidDataValidationCriterionValue",S.InvalidNumberOfCriterionValues="InvalidNumberOfCriterionValues",S.InvalidCopyPasteSelection="InvalidCopyPasteSelection",S.NoChanges="NoChanges",S.InvalidInputId="InvalidInputId",S.SheetIsHidden="SheetIsHidden",S.InvalidTableResize="InvalidTableResize",S.PivotIdNotFound="PivotIdNotFound",S.PivotInError="PivotInError",S.EmptyName="EmptyName",S.ValueCellIsInvalidFormula="ValueCellIsInvalidFormula",S.InvalidDefinition="InvalidDefinition",S.InvalidColor="InvalidColor",S.InvalidPivotDataSet="InvalidPivotDataSet",S.InvalidPivotCustomField="InvalidPivotCustomField",S.MissingFigureArguments="MissingFigureArguments",S.InvalidCarouselItem="InvalidCarouselItem";const C=new Set(["containsText","notContainsText","isGreaterThan","isGreaterOrEqualTo","isLessThan","isLessOrEqualTo","isBetween","isNotBetween","beginsWithText","endsWithText","isNotEmpty","isEmpty","isNotEqual","isEqual","customFormula"]),y=new Set(["containsText","notContainsText","isEqualText","isEmail","isLink","dateIs","dateIsBefore","dateIsOnOrBefore","dateIsAfter","dateIsOnOrAfter","dateIsBetween","dateIsNotBetween","dateIsValid","isEqual","isNotEqual","isGreaterThan","isGreaterOrEqualTo","isLessThan","isLessOrEqualTo","isBetween","isNotBetween","isBoolean","isValueInList","isValueInRange","customFormula"]),I=[{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:";"}],w=I[0],x=["thin","medium","thick","dashed","dotted"];function E(e){return Array.isArray(e)&&Array.isArray(e[0])}var R;!function(e){e.UP="up",e.DOWN="down",e.LEFT="left",e.RIGHT="right"}(R||(R={}));const T=.5,A="#017E84",D="#f5f5f5",_="#F8F9FA",F="#E8EAED",O="#595959",P="#666666",M="#c9ccd2",N="#3266ca",k="#FFFFFF",L="#CACACA",V=11982760,U=A,H="#188038",z="#E0E2E4",B="#4A4F59",$="#999",G="#E2E3E3",W="#BCBCBC",q="#9B359B",Z="#00000000",j="#4EA7F2",Y="#EA6175",X="#AAAAAA",K="#111827",J="#D8DADD",Q="#E7E9ED",ee="#F9FAFB",te="#374151",oe=te+"C2",se="#111827",ie="#714B67",ne=Q,re=J,ae="#111827",le="#e6f2f3",ce="#111827",he=A,de="#D44C591A",ue="#C34A41",ge="#98DBE2",pe="#E6F2F3",me=20,fe=10,ve=15,be=16,Se=12,Ce="#F28C28",ye=["#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"],Ie=26,we=48,xe=96,Ee=23,Re=15,Te=4,Ae=3,De=Te,_e=21,Fe=2*Ee,Oe={align:"left",verticalAlign:"bottom",wrapping:"overflow",bold:!1,italic:!1,strikethrough:!1,underline:!1,fontSize:10,fillColor:"",textColor:""},Pe=Oe.verticalAlign,Me=Oe.wrapping,Ne="400",ke=Oe.fontSize,Le="'Roboto', arial",Ve="thin",Ue="#000000",He="START_REVISION",ze=1,Be=20,$e="??",Ge="difference",We="#43C5B1",qe="#EA6175",Ze=.4,je=3,Ye=2,Xe=["'","*","?","/","\\","[","]"],Ke=/'|\*|\?|\/|\\|\[|\]/,Je="|";var Qe;!function(e){e[e.Grid=0]="Grid",e[e.Highlight=5]="Highlight",e[e.HeaderGroupingButton=6]="HeaderGroupingButton",e[e.Figure=10]="Figure",e[e.ScrollBar=15]="ScrollBar",e[e.GridPopover=19]="GridPopover",e[e.GridComposer=20]="GridComposer",e[e.IconPicker=25]="IconPicker",e[e.TopBarComposer=30]="TopBarComposer",e[e.Popover=35]="Popover",e[e.FigureAnchor=1e3]="FigureAnchor",e[e.FigureSnapLine=1001]="FigureSnapLine",e[e.FigureTooltip=1002]="FigureTooltip"}(Qe||(Qe={}));let et=0;function tt(){return et}const ot="\n",st=[6,7,8,9,10,11,12,14,18,24,36],it={hasFilters:!1,totalRow:!1,firstColumn:!0,lastColumn:!1,numberOfHeaders:1,bandedRows:!0,bandedColumns:!1,styleId:"TableStyleMedium5",automaticAutofill:!1},nt=1e5,rt={symbol:"$",position:"before",decimalPlaces:2,code:"",name:"Dollar"},at={fontSize:be,color:te},lt="#000000",ct="#3da4ab",ht={OPERATOR:ct,NUMBER:"#02c39a",STRING:"#00a82d",FUNCTION:lt,DEBUGGER:ct,LEFT_PAREN:lt,RIGHT_PAREN:lt,ARG_SEPARATOR:lt,ORPHAN_RIGHT_PAREN:"#ff0000"},dt=new RegExp(Ke,"g");function ut(e){return'"'===e[0]&&(e=e.slice(1)),'"'===e[e.length-1]&&"\\"!==e[e.length-2]?e.slice(0,e.length-1):e}function gt(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function pt(e){switch(typeof e){case"object":{if(null===e)return e;if(function(e){return"clone"in e&&e.clone instanceof Function}(e))return e.clone();if(!(function(e){return"object"==typeof e&&null!==e&&(e?.constructor===Object||void 0===e?.constructor)}(e)||e instanceof Array))throw new Error("Unsupported type: only objects and arrays are supported");const t=Array.isArray(e)?new Array(e.length):{};if(Array.isArray(e))for(let o=0,s=e.length;o<s;o++)o in e&&(t[o]=pt(e[o]));else for(const o in e)t[o]=pt(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 mt(e){return ft(e,"'")}function ft(e,t='"'){return e.startsWith(t)&&(e=e.slice(1)),e.endsWith(t)&&(e=e.slice(0,-1)),e}function vt(e){return e.match(/\w/g)?.length!==e.length&&(e=`'${e}'`),e}function bt(e,t=" "){return e.replace(dt,t)}function St(e,t,o){return e<t?t:e>o?o:e}function Ct(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 yt(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*It(e,t){t.next();for(const o of e){const e=t.next();yield{...o,next:e.done?void 0:e.value}}}function wt(e){const t=e.toUpperCase();return"TRUE"===t||"FALSE"===t}const xt=/^\[(.+)\]\((.+)\)$/,Et=/^https?:\/\/(www\.)?[-a-zA-Z0-9@:%._\+~#=]{2,256}\.[a-z]{2,4}\b([-a-zA-Z0-9@:%_\+.~#?&//=]*)$/;function Rt(e){return xt.test(e)}function Tt(e){return Et.test(e)}function At(e,t){return`[${e}](${t})`}function Dt(e){const t=e.match(xt)||[],o=t[1],s=t[2];if(!o||!s)throw new Error(`Could not parse markdown link ${e}.`);return{label:o,url:s}}const _t="o-spreadsheet://";function Ft(e){return e.startsWith(_t)}function Ot(e){return`${_t}${e}`}function Pt(e){if(e.startsWith(_t))return e.slice(_t.length);throw new Error(`${e} is not a valid sheet link`)}function Mt(e){return void 0!==e}function Nt(e){return void 0===e||Object.values(e).every((e=>"object"==typeof e?Nt(e):!e))}function kt(e,t,o){let s;const i=function(){const i=this,n=Array.from(arguments);const r=o&&!s;clearTimeout(s),s=setTimeout((function(){s=void 0,o||e.apply(i,n)}),t),r&&e.apply(i,n)};return i.isDebouncePending=()=>void 0!==s,i.stopDebounce=()=>{clearTimeout(s)},i}function Lt(e){let t="";for(let o=0,s=e.length;o<s;o++)t+=e[o];return t}function Vt(e){let t,o=!1;const s=()=>(o||(t=e instanceof Function?e():e,o=!0),t);return s.map=e=>Vt((()=>e(s()))),s}function Ut(e,t){let o=e.slice(t).find((e=>e));return o||(o=e.slice(0,t).reverse().find((e=>e))),o||""}function Ht(e,t){return"after"===e?t+1:t}function zt(...e){if(e.length<=1)return!0;for(let t=1;t<e.length;t++)if(!Bt(e[0],e[t]))return!1;return!0}function Bt(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(!Bt(e[o],t[o]))return!1}else if(e[o]!==t[o])return!1}return!0}function $t(e,t){if(e.length!==t.length)return!1;for(let o=0;o<e.length;o++)if(!zt(e[o],t[o]))return!1;return!0}function Gt(e,t){if(e.length<t.length)return!1;const o=new Set(e);return t.every((e=>o.has(e)))}function Wt(e){if(!e)return e;const t={...e};return Object.keys(t).forEach((e=>!t[e]&&delete t[e])),t}const qt=["\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))],Zt=new RegExp(qt.join("|"),"g"),jt=/(\r\n|\r)/g,Yt=qt.concat([" "]);function Xt(e){return e?e.replace(jt,ot):""}function Kt(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 Jt(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 Qt(e,t){const o=new Set(t),s=[];for(let t=0;t<e.length;t++)o.has(t)||s.push(e[t]);return s}function eo(e,t,o){return e.slice(0,o).concat(t).concat(e.slice(o))}function to(e,t,o){const s=[...e];return s[o]=t,s}function oo(e){return e.split("\n").map((e=>e.replace(/\s+/g," ").trim())).join("\n")}function so(e,t,o){return t>o?so(e,o,t):e>=t&&e<=o}function io(e,t){let o=gt(e);const s=t.matchCase?"":"i";return t.exactMatch&&(o=`^${o}$`),RegExp(o,s)}function no(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 ro(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 ao{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 lo(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 co(e){const t={};for(const o in e)for(const s in e[o])t[s]||(t[s]={}),t[s][o]=e[o][s];return t}function ho(e,t,o={}){const s=o.compute??((e,t)=>`${e} (${t})`),i=o.computeFirstOne??!1;let n=o.start??1,r=i?s(e,n):e;for(;t.includes(r);)r=s(e,n++);return r}function uo(e){return e.startsWith("=")||e.startsWith("+")}const go={Background:0,Highlights:1,Clipboard:2,Chart:4,Autofill:5,Selection:6,Headers:100},po=Jt((()=>Object.keys(go).sort(((e,t)=>go[e]-go[t]))));new Set(["containsText","notContainsText","isEqualText","dateIs","dateIsBefore","dateIsOnOrBefore","dateIsAfter","dateIsOnOrAfter","dateIsBetween","dateIsNotBetween","isEqual","isNotEqual","isGreaterThan","isGreaterOrEqualTo","isLessThan","isLessOrEqualTo","isBetween","isNotBetween","customFormula","beginsWithText","endsWithText","isNotEmpty","isEmpty"]);const mo=["containsText","notContainsText","isEqualText","isEmpty","isNotEmpty","beginsWithText","endsWithText"],fo=["isEqual","isNotEqual","isGreaterThan","isGreaterOrEqualTo","isLessThan","isLessOrEqualTo","isBetween","isNotBetween","isEmpty","isNotEmpty"],vo=["dateIs","dateIsBefore","dateIsOnOrBefore","dateIsAfter","dateIsOnOrAfter","dateIsBetween","dateIsNotBetween","isEmpty","isNotEmpty"],bo=["image/avif","image/bmp","image/gif","image/vnd.microsoft.icon","image/jpeg","image/png","image/tiff","image/webp"];function So(e){if(e<0)throw new Error(`number must be positive. Got ${e}`);return e<26?String.fromCharCode(65+e):So(Math.floor(e/26)-1)+So(e%26)}function Co(e){let t=0;const o=e.length;for(let s=0;s<o;s++){t=26*t+yo(e[s])}return t-1}function yo(e){const t=e.charCodeAt(0);return t>=65&&t<=90?t-64:t-96}function Io(e){return e>="A"&&e<="Z"||e>="a"&&e<="z"}function wo(e){return e>="0"&&e<="9"}const xo=Co("ZZZ"),Eo=9999998;function Ro(e){for(;" "===e.current;)e.advanceBy(1)}function To(e){if("$"===e.current&&e.advanceBy(1),!e.current||!Io(e.current))return-1;let t=0;for(;e.current&&Io(e.current);)t=26*t+yo(e.shift());return t}function Ao(e){if("$"===e.current&&e.advanceBy(1),!e.current||!wo(e.current))return-1;let t=0;for(;e.current&&wo(e.current);)t=10*t+Number(e.shift());return t}function Do(e){const t=new ao(e);Ro(t);const o=To(t);if(-1===o||!t.current)throw new Error(`Invalid cell description: ${e}`);const s=Ao(t);Ro(t);const i=o-1,n=s-1;if(!t.isOver()||i>xo||n>Eo)throw new Error(`Invalid cell description: ${e}`);return{col:i,row:n}}function _o(e,t,o={colFixed:!1,rowFixed:!1}){return(o.colFixed?"$":"")+So(e)+(o.rowFixed?"$":"")+String(t+1)}function Fo(e,t=[]){if(e.length<=1&&0===t.length)return e;const o=[0],s=new Map([[0,[]]]);return Oo(o,s,e,!1),Oo(o,s,t,!0),ko(o,s)}function Oo(e,t,o,s=!1){for(const i of o){const o=i.left,n=void 0===i.right?void 0:i.right+1,r=Po(e,t,o,!0,0),a=Po(e,t,n,!1,r);for(let o=r;o<=a;o++){Mo(t.get(e[o]),i,s)}No(e,t,r,a)}}function Po(e,t,o,s,i){if(void 0===o)return e.length-1;const n=Lo(e,o,i);return o!==e[n]?(e.splice(n+1,0,o),t.set(o,[...t.get(e[n])]),s?n+1:n):s?n:n-1}function Mo(e,t,o=!1){const s=t.top,i=void 0===t.bottom?void 0:t.bottom+1,n=[],r=Lo(e,s,0,!1);if((r%2!=0&&!o||r%2==0&&o)&&n.push(s),void 0===i)return e.splice(r+1),void e.push(...n);const a=Vo(e,i,0,!1);(a%2==0&&!o||a%2!=0&&o)&&n.push(i);const l=a-r-1,c=n.length,h=r+1;h===e.length-1&&1===l&&1===c?e[h]=n[0]??n[1]:e.splice(h,l,...n)}function No(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--)$t(t.get(e[o]),t.get(e[o-1]))&&(t.delete(e[o]),e.splice(o,1))}function ko(e,t){const o=[];let s=[];for(let i=0;i<e.length;i++){const n=e[i],r=t.get(n);if(!r||0===r.length){o.push(...s),s=[];continue}let a=e[i+1];void 0!==a&&a--;const l=[];for(let e=0;e<r.length;e+=2){const t=r[e];let o=r[e+1];void 0!==o&&o--;const i={top:t,left:n,bottom:o,right:a};(void 0===o&&0!==t||void 0===a&&0!==n)&&(i.hasHeader=!0);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}function Lo(e,t,o=0,s=!0){let i=e.length-1,n=-1;for(;o<=i;){const r=Math.floor((o+i)/2);if(e[r]===t&&s)return r;e[r]<t?(n=r,o=r+1):i=r-1}return n}function Vo(e,t,o=0,s=!0){let i=e.length-1,n=e.length;for(;o<=i;){const r=Math.floor((o+i)/2);if(e[r]===t&&s)return r;e[r]>t?(n=r,i=r-1):o=r+1}return n}function Uo(e){const t=function(e){const t=new ao(e);Ro(t);const o=e.indexOf("!");-1!==o&&t.advanceBy(o+1);const s=To(t),i=Ao(t);let n,r,a,l,c=!1,h=!1,d=!1;if(-1===i?(a=l=s-1,n=r=0,c=!0):-1===s?(n=r=i-1,a=l=0,h=!0):(a=l=s-1,n=r=i-1,d=!0),Ro(t),":"===t.current){t.advanceBy(1),Ro(t);const e=To(t),o=Ao(t);-1===o?(l=e-1,c=!0):-1===e?(r=o-1,h=!0):(l=e-1,r=o-1,n=c?r:n,a=h?l:a,d=!0)}const u={top:n,left:a,bottom:c?void 0:r,right:h?void 0:l};return d=d&&(h||c),d&&(u.hasHeader=d),u}(e),o=rs(t),s=o.bottom,i=o.right;if(void 0!==s&&s>Eo||void 0!==i&&i>xo)throw new Error(`Range string out of bounds: ${e}`);if(void 0===s&&void 0===i)throw new Error("Wrong zone xc. The zone cannot be at the same time a full column and a full row");return o}function Ho(e){const t=Uo(e);if(void 0===t.bottom||void 0===t.right)throw new Error("This does not support unbounded ranges");return t}function zo(e){try{return function(e){return Bo(Uo(e))}(e)}catch(e){return!1}}function Bo(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))&&($o(e)&&e.top>=0&&e.left>=0)}function $o(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 Go(e){const{top:t,bottom:o,left:s,right:i}=e,n="hasHeader"in e&&e.hasHeader,r=t===o&&s===i;if(void 0===o&&void 0!==i)return 0!==t||n?`${_o(s,t)}:${So(i)}`:`${So(s)}:${So(i)}`;if(void 0===i&&void 0!==o)return 0!==s||n?`${_o(s,t)}:${o+1}`:`${t+1}:${o+1}`;if(void 0!==o&&void 0!==i)return r?_o(s,t):`${_o(s,t)}:${_o(i,o)}`;throw new Error("Bad zone format")}function Wo(e,t,o,s,i){const n="left"===t?"columns":"rows",r="before"===s?o-1:o,a=e["left"===t?"right":"bottom"];return e[t]<=r&&a&&a>r?as(e,n,"RESIZE",i):r<e[t]?as(e,n,"MOVE",i):{...e}}function qo(e,t,o,s,i){const n="left"===t?"columns":"rows",r="before"===s?o-1:o,a="left"===t?"right":"bottom";return e[t]<=r&&e[a]>r?as(e,n,"RESIZE",i):r<e[t]?as(e,n,"MOVE",i):{...e}}function Zo(e,t,o){const s="left"===t?"right":"bottom";let i=e[t],n=e[s];for(const r of o.sort(((e,t)=>t-e)))e[t]>r&&(i--,n--),e[t]<r&&e[s]>=r&&n--;return{...e,[t]:i,[s]:n}}function jo(e,t,o){const s="left"===t?"right":"bottom";let i=e[t],n=e[s];const r=e[s];for(const s of o.sort(((e,t)=>t-e)))e[t]>s&&(i--,void 0!==n&&n--),void 0!==r&&void 0!==n&&e[t]<=s&&r>=s&&n--;if(!(void 0!==n&&i>n))return{...e,[t]:i,[s]:n}}function Yo(...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 Xo(e,t){if(Qo(e,t))return{top:Math.max(e.top,t.top),left:Math.max(e.left,t.left),bottom:void 0!==e.bottom?Math.min(e.bottom,t.bottom):e.bottom??t.bottom,right:void 0!==e.right?Math.min(e.right,t.right):e.right??t.right}}function Ko(e,t){return e.left===t.left&&e.right===t.right&&e.top===t.top&&e.bottom===t.bottom&&e.hasHeader===t.hasHeader}function Jo(e,t){if(Xo(e,t))return;let o;return e.left===t.right+1&&(o={position:"left",start:Math.max(e.top,t.top),stop:void 0!==e.bottom?Math.min(e.bottom,t.bottom):t.bottom}),void 0!==e.right&&e.right+1===t.left&&(o={position:"right",start:Math.max(e.top,t.top),stop:void 0!==e.bottom?Math.min(e.bottom,t.bottom):t.bottom}),e.top===t.bottom+1&&(o={position:"top",start:Math.max(e.left,t.left),stop:void 0!==e.right?Math.min(e.right,t.right):t.right}),void 0!==e.bottom&&e.bottom+1===t.top&&(o={position:"bottom",start:Math.max(e.left,t.left),stop:void 0!==e.right?Math.min(e.right,t.right):t.right}),o&&o.start<=o.stop?o:void 0}function Qo(e,t){return!(void 0!==e.bottom&&e.bottom<t.top||void 0!==t.bottom&&t.bottom<e.top)&&!(void 0!==e.right&&e.right<t.left||void 0!==t.right&&t.right<e.left)}function es(e,t,o){const{left:s,right:i,top:n,bottom:r}=o;return e>=s&&e<=i&&t>=n&&t<=r}function ts(e,t){return e.left>=t.left&&e.right<=t.right&&e.top>=t.top&&e.bottom<=t.bottom}function os(e){return{numberOfRows:e.bottom-e.top+1,numberOfCols:e.right-e.left+1}}function ss(e){const{numberOfCols:t,numberOfRows:o}=os(e);return 1===t||1===o}function is(e){const t=[],{left:o,right:s,top:i,bottom:n}=rs(e);for(const e of Ct(o,s+1))for(const o of Ct(i,n+1))t.push({col:e,row:o});return t}function ns(e,t){const o=[],{left:s,right:i,top:n,bottom:r}=rs(t);for(const t of Ct(s,i+1))for(const s of Ct(n,r+1))o.push({sheetId:e,col:t,row:s});return o}function rs(e){return void 0!==e.right&&e.left>e.right&&(e={...e,left:e.right,right:e.left}),void 0!==e.bottom&&e.top>e.bottom&&(e={...e,top:e.bottom,bottom:e.top}),e}function as(e,t,o,s){const i="both"===t?s[0]:"columns"===t?s:0,n="both"===t?s[1]:"rows"===t?s:0,r="hasHeader"in e&&e.hasHeader;let a;a=us(e)&&!r?"rows"!==t:!(ds(e)&&!r)||"columns"!==t;const l={...e};return a&&"MOVE"===o&&(l.left+=i,l.top+=n),void 0!==l.right&&(l.right+=i),void 0!==l.bottom&&(l.bottom+=n),l}function ls(e,t){let o,s;const{left:i,right:n,top:r,bottom:a}=e,{left:l,right:c,top:h,bottom:d}=t;return o=l!==i?l:c!==n?c:l,s=h!==r?h:d!==a?d:h,{col:o,row:s}}function cs(e){return{left:e.col,right:e.col,top:e.row,bottom:e.row}}function hs(e){return{...e,right:e.left,bottom:e.top}}function ds(e){return void 0===e.right}function us(e){return void 0===e.bottom}function gs(e){return(e.bottom-e.top+1)*(e.right-e.left+1)}function ps(e,t,o){return e.some((e=>function(e,t,o){return e.left<t&&t<=e.right||e.top<o&&o<=e.bottom}(e,t,o)))}function ms(e){return e.length<2||1===Fo(e).length}function fs(e){const t=[...e];let o=!0;for(;o;){o=!1;for(let e=0;e<t.length;e++){const s=t[e],i=t.findIndex(((t,o)=>{return e!==o&&(n=s,((i=t).right+1===n.left||i.left===n.right+1?i.top<=n.bottom&&i.top>=n.top||n.top<=i.bottom&&n.top>=i.top:(i.bottom+1===n.top||i.top===n.bottom+1)&&(i.left<=n.right&&i.left>=n.left||n.left<=i.right&&n.left>=i.left))||Qo(t,s));var i,n}));if(-1!==i){t[e]=Yo(t[i],s),t.splice(i,1),o=!0;break}}}return t}function vs(e,t){const o=Jo(e,t);if(!o)return[e];const s=[];switch(o.position){case"bottom":case"top":return s.push({top:e.top,bottom:e.bottom,left:o.start,right:o.stop}),o.start>e.left&&s.push({top:e.top,bottom:e.bottom,left:e.left,right:o.start-1}),(void 0===e.right||o.stop<e.right)&&s.push({top:e.top,bottom:e.bottom,left:o.stop+1,right:e.right}),s;case"left":case"right":return s.push({top:o.start,bottom:o.stop,left:e.left,right:e.right}),o.start>e.top&&s.push({top:e.top,bottom:o.start-1,left:e.left,right:e.right}),(void 0===e.bottom||o.stop<e.bottom)&&s.push({top:o.stop+1,bottom:e.bottom,left:e.left,right:e.right}),s}}function bs(e,t){const o=new Set(t.map((e=>e.left))),s=new Set(t.map((e=>e.right))),i=new Set(t.map((e=>e.top))),n=new Set(t.map((e=>e.bottom))),r=1===i.size&&1===n.size||1===o.size&&1===s.size?function(e){return e.reduce(((e,t)=>{const o=e.length;for(let s=0;s<o;s++)if(Qo(e[s],t))return e[s]=Yo(e[s],t),e;return e[o]=t,e}),[])}(t):[t[t.length-1]],a=r.map((e=>is(e))).flat();return{sheetId:e,zones:t,clippedZones:r,columnsIndexes:[...new Set(a.map((e=>e.col)))].sort(((e,t)=>e-t)),rowsIndexes:[...new Set(a.map((e=>e.row)))].sort(((e,t)=>e-t))}}function Ss(e,t,o){const s=Math.max(e.right-t+1,e.left),i=Math.max(e.bottom-o+1,e.top),n=[];for(let r=e.left;r<=s;r+=t)for(let s=e.top;s<=i;s+=o)n.push({left:r,top:s,bottom:s+o-1,right:r+t-1});return n}function Cs(e,t){if(!t.length||!t[0].length)return e;const o=t[0].length,s=t.length;return e.map((e=>Ss(e,o,s))).flat()}function ys(e){let t;if(e[a.Html]){t=function(e){const t=[...e.documentElement.attributes];if(t.some((e=>e.value.includes("microsoft"))))return;const o=e.querySelector("div")?.getAttribute("data-osheet-clipboard");return o&&JSON.parse(o)}((new DOMParser).parseFromString(e[a.Html],"text/html"))}const o=e[a.PlainText]||"";let s;if(!o.trim())for(const t of bo)if(e[t]){s=e[t];break}return{text:o,data:t,imageBlob:s}}const Is=(e,t,o,s)=>{e.forEach((({handlerName:e,handler:i})=>{const n=t[e];n&&i.paste(o,n,s)}))};function ws(e,t,o,s,i){let n;const r=[],a={sheetId:e,zones:t};for(const{handlerName:l,handler:c}of s){const s=o[l];if(!s)continue;const h=c.getPasteTarget(e,t,s,i);h.figureId&&(a.figureId=h.figureId);for(const e of h.zones)r.push(e),n=void 0!==n?Yo(n,e):e}return{target:a,zone:n,selectedZones:r}}const xs=(e,t,o)=>{const s={col:t[0].left,row:t[0].top};e.getBackToDefault(),e.selectZone({cell:s,zone:Yo(...o)},{scrollIntoView:!1})},Es=/rgba?\(|\s+|\)/gi,Rs=/^#([A-F\d]{2}){3,4}$/,Ts=["#eb6d00","#0074d9","#ad8e00","#169ed4","#b10dc9","#00a82d","#00a3a3","#f012be","#3d9970","#111111","#62A300","#ff4136","#949494","#85144b","#001f3f"];function As(e,t=1){const o=1!==t?Math.round(255*t).toString(16).padStart(2,"0"):"";return _s(e.toString(16).padStart(6,"0"))+o}function Ds(e){return"number"==typeof e?e:Number.parseInt(_s(e).slice(1,7),16)}function _s(e){let t=e;if(e.startsWith("rgb")?t=function(e){const t=e.replace(Es,"").split(",");let o=255;if(3!==t.length&&4!==t.length)throw new Error("invalid color");if(4===t.length){const e=parseFloat(t.pop()||"1");if(isNaN(e))throw new Error("invalid alpha value");o=Math.round(255*e)}const s=t.map((e=>parseInt(e,10)));255!==o&&s.push(o);return"#"+Lt(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}`),!Rs.test(t))throw new Error(`invalid color input: ${e}`);return t}function Fs(e){try{return _s(e),!0}catch(e){return!1}}const Os=e=>e>=0&&e<=255;function Ps(e,t,o,s=1){if(!Os(e)||!Os(t)||!Os(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 Ms(e){let{r:t,g:o,b:s}=ks(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 Ns(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 ks(e){let t,o,s,i;if(7===(e=_s(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 Ls(e){(e={...e}).s/=100,e.l/=100;const t=(1-Math.abs(2*e.l-1))*e.s,o=t*(1-Math.abs(e.h/60%2-1)),s=e.l-t/2;let i=0,n=0,r=0;return 0<=e.h&&e.h<60?(i=t,n=o,r=0):60<=e.h&&e.h<120?(i=o,n=t,r=0):120<=e.h&&e.h<180?(i=0,n=t,r=o):180<=e.h&&e.h<240?(i=0,n=o,r=t):240<=e.h&&e.h<300?(i=o,n=0,r=t):300<=e.h&&e.h<360&&(i=t,n=0,r=o),i=Math.round(255*(i+s)),n=Math.round(255*(n+s)),r=Math.round(255*(r+s)),{a:e.a,r:i,g:n,b:r}}function Vs(e){const t=e.r/255,o=e.g/255,s=e.b/255,i=Math.min(t,o,s),n=Math.max(t,o,s),r=n-i;let a=0,l=0,c=0;return a=0===r?0:n===t?(o-s)/r%6:n===o?(s-t)/r+2:(t-o)/r+4,a=Math.round(60*a),a<0&&(a+=360),c=(n+i)/2,l=0===r?0:r/(1-Math.abs(2*c-1)),l=+(100*l).toFixed(1),c=+(100*c).toFixed(1),{a:e.a,h:a,s:l,l:c}}function Us(e){return Ns(Ls(e))}function Hs(e){return Vs(ks(e))}function zs(e){return ks("number"==typeof e?As(e):e)}function Bs(e,t){return 1===t?_s(e).slice(0,7):Ns({...ks(e),a:t})}function $s(e,t){const o=Hs(e);return 1===t?"#fff":(o.l=t*(100-o.l)+o.l,Us(o))}function Gs(e,t){const o=Hs(e);return 1===t?"#000":(o.s=Math.min(100,t*o.s+o.s),o.l=o.l-t*o.l,Us(o))}function Ws(e){return Ms(e)<.6?$s(e,.9):Gs(e,.75)}const qs=["#4EA7F2","#EA6175","#43C5B1","#F4A261","#8481DD","#FFD86D"],Zs=["#4EA7F2","#3188E6","#43C5B1","#00A78D","#EA6175","#CE4257","#F4A261","#F48935","#8481DD","#5752D1","#FFD86D","#FFBC2C"],js=["#4EA7F2","#3188E6","#056BD9","#A76DBC","#7F4295","#6D2387","#EA6175","#CE4257","#982738","#43C5B1","#00A78D","#0E8270","#F4A261","#F48935","#BE5D10","#8481DD","#5752D1","#3A3580","#A4A8B6","#7E8290","#545B70","#FFD86D","#FFBC2C","#C08A16"],Ys=["#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"],Xs=["#4EA7F2","#43C5B1","#EA6175","#F4A261","#8481DD","#FFD86D","#3188E6","#00A78D","#CE4257","#F48935","#5752D1","#FFBC2C"],Ks=["#4EA7F2","#A76DBC","#EA6175","#43C5B1","#F4A261","#8481DD","#A4A8B6","#FFD86D","#3188E6","#7F4295","#CE4257","#00A78D","#F48935","#5752D1","#7E8290","#FFBC2C","#056BD9","#6D2387","#982738","#0E8270","#BE5D10","#3A3580","#545B70","#C08A16"],Js=["#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 Qs(e,t){return t[e%t.length]}function ei(e){return e<=6?qs:e<=12?Zs:e<=24?js:Ys}class ti{preferredColors;currentColorIndex=0;palette;constructor(e,t=[]){this.preferredColors=t,this.palette=ei(e).filter((e=>!t.includes(e)))}next(){return this.preferredColors?.[this.currentColorIndex]?this.preferredColors[this.currentColorIndex++]:Qs(this.currentColorIndex++,this.palette)}}class oi extends ti{constructor(e,t=[]){var o;super(e,t),this.palette=(o=e,o<=6?qs:o<=12?Xs:o<=24?Ks:Js).filter((e=>!t.includes(e)))}}class si{availableColors;colors={};constructor(e=12){this.availableColors=new oi(e)}get(e){return this.colors[e]||(this.colors[e]=this.availableColors.next()),this.colors[e]}}function ii(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=zs(t[e-1].color).a,i=zs(t[e].color).a,n=Ds(t[e-1].color),r=Ds(t[e].color);o.push({min:t[e-1].value,max:t[e].value,minColor:n,maxColor:r,minColorAlpha:s,maxColorAlpha:i,colorDiff:ni(t[e-1].value,t[e].value,n,r)})}return e=>{if(e<o[0].min)return As(o[0].minColor,o[0].minColorAlpha);for(const t of o)if(e>=t.min&&e<=t.max)return As(ri(e,t.min,t.minColor,t.colorDiff),t.maxColorAlpha);return As(o[o.length-1].maxColor,o[o.length-1].maxColorAlpha)}}function ni(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 ri(e,t,o,s){const[i,n,r]=s;return Math.round((o>>16)%256-i*(e-t))<<16|Math.round((o>>8)%256-n*(e-t))<<8|Math.round(o%256-r*(e-t))}const ai=e=>e,li=()=>!1;let ci=ai,hi=li;function di(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 ui=function(e,...t){return hi()?di(ci(e),...t):new gi(e,t)};class gi extends String{values;constructor(e,t){super(e),this.values=t}valueOf(){const e=super.valueOf();return hi()?di(ci(e),...this.values):di(e,...this.values)}toString(){return this.valueOf()}}function pi(e){return/^https?:\/\//i.test(e)?e:`https://${e}`}const mi=new n;function fi(e,t){return{url:e=pi(e),label:t||e,isExternal:!0,isUrlEditable:!0}}mi.add("sheet_URL",{match:e=>Ft(e),createLink:(e,t)=>({label:t,url:e,isExternal:!1,isUrlEditable:!1}),urlRepresentation(e,t){const o=Pt(e);return t.tryGetSheetName(o)||ui("Invalid sheet")},open(e,t){const o=Pt(e);t.model.dispatch("ACTIVATE_SHEET",{sheetIdFrom:t.model.getters.getActiveSheetId(),sheetIdTo:o}).isCancelledBecause("SheetIsHidden")&&t.notifyUser({type:"warning",sticky:!1,text:ui("Cannot open the link because the linked sheet is hidden.")})},sequence:0});const vi={createLink:fi,match:e=>Tt(e),open:e=>window.open(e,"_blank"),urlRepresentation:e=>e,sequence:0};function bi(e){return mi.getAll().sort(((e,t)=>e.sequence-t.sequence)).find((t=>t.match(e)))||vi}function Si(e,t){return bi(e.url).urlRepresentation(e.url,t)}function Ci(e,t,o){bi(e.url).open(e.url,t,o)}function yi(e){if("string"==typeof e){if(Rt(e)){const{label:t,url:o}=Dt(e);return bi(o).createLink(o,t)}return Tt(e)?fi(e):void 0}}class Ii{jsDate;constructor(e,t,o,s=0,i=0,n=0){this.jsDate=new Date(Date.UTC(e,t,o,s,i,n,0))}static fromTimestamp(e){const t=new Date(e);return new Ii(t.getUTCFullYear(),t.getUTCMonth(),t.getUTCDate(),t.getUTCHours(),t.getUTCMinutes(),t.getUTCSeconds())}static now(){const e=new Date;return new Ii(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 wi=new Ii(1899,11,30),xi=864e5,Ei=2e3,Ri=Ii.now().getFullYear(),Ti=Ii.now().getMonth(),Ai=Ii.fromTimestamp(0).getTime()-wi.getTime(),Di=/^\d{1,2}(\/|-|\s)\d{1,2}((\/|-|\s)\d{1,4})?$/,_i=/^\d{3,4}(\/|-|\s)\d{1,2}(\/|-|\s)\d{1,2}$/,Fi=Yt.join(""),Oi=new RegExp(`/|-|${Yt.join("|")}`),Pi=new RegExp(`^(\\d{1,4})[/${Fi}-](\\d{1,4})([/${Fi}-](\\d{1,4}))?$`),Mi=/((\d+(:\d+)?(:\d+)?\s*(AM|PM))|(\d+:\d+(:\d+)?))$/;function Ni(e,t){switch(typeof e){case"number":return e;case"string":return ki(e,t)?Vi(e,t)?.value:!e||isNaN(Number(e))?void 0:Number(e);default:return}}function ki(e,t){return null!==Vi(e,t)}const Li=new Map;function Vi(e,t){return Li.has(t)||Li.set(t,new Map),Li.get(t).has(e)||Li.get(t).set(e,function(e,t){e=e.trim();let o=null;const s=e.match(Mi);if(s){if(o=function(e){if(e=e.trim(),Mi.test(e)){const t=/AM/i.test(e),o=/PM/i.test(e),s=(t||o?e.substring(0,e.length-2).trim():e).split(/:/),i=s.length>=2,n=3===s.length;let r=Number(s[0]),a=i?Number(s[1]):0,l=n?Number(s[2]):0,c=n?"hh:mm:ss":"hh:mm";if(t||o)c+=" a";else if(!i)return null;r>=12&&t?r-=12:r<12&&o&&(r+=12),a+=Math.floor(l/60),l%=60,r+=Math.floor(a/60),a%=60,r>=24&&(c="hhhh:mm:ss");return{value:r/24+a/1440+l/86400,format:c,jsDate:new Ii(1899,11,30,r,a,l)}}return null}(s[0]),null===o)return null;e=e.replace(s[0],"").trim()}let i=null;const n=function(e,t){const o=e.match(Pi);if(!o)return null;const[,s,i,,n]=o;if(s.length>2&&n&&n.length>2)return null;if(s.length>2)return{year:s,month:i,day:n,dateString:e,type:"ymd"};const r=function(e){switch(e.dateFormat[0]){case"d":return"dmy";case"m":return"mdy";case"y":return"ymd"}throw new Error("Invalid date format in locale")}(t);if(!n)return i.length>2?{month:s,year:i,day:void 0,dateString:e,type:r}:"dmy"===r?{day:s,month:i,year:n,dateString:e,type:"dmy"}:{month:s,day:i,year:n,dateString:e,type:"mdy"};if(n.length>2)return"mdy"===r?{month:s,day:i,year:n,dateString:e,type:"mdy"}:{day:s,month:i,year:n,dateString:e,type:"dmy"};if("mdy"===r)return{month:s,day:i,year:n,dateString:e,type:"mdy"};if("ymd"===r)return{year:s,month:i,day:n,dateString:e,type:"ymd"};if("dmy"===r)return{day:s,month:i,year:n,dateString:e,type:"dmy"};return null}(e,t);if(n){const t=n.dateString.match(Oi)[0];if(i=function(e,t){const{year:o,month:s,day:i}=e,n=function(e){if(!e)return Ti;const t=Number(e);if(t>=1&&t<=12)return t-1;return null}(s),r=function(e){if(!e)return 1;const t=Number(e);if(t>=0&&t<=31)return t;return null}(i),a=function(e){if(!e)return Ri;const t=Number(e);switch(e.length){case 1:return Ei+t;case 2:return Ei+(Ei+t>Ri+10?-100:0)+t;case 3:case 4:return t}return null}(o);if(null===a||null===n||null===r)return null;const l=2===s?.length&&n+1<10||2===i?.length&&r<10,c=2!==o?.length,h=new Ii(a,n,r);if(h.getMonth()!==n||h.getDate()!==r)return null;const d=h.getTime()-wi.getTime(),u=function(e,t,o,s){const i=e.year?s?"yyyy":"yy":void 0,n=e.month?o?"mm":"m":void 0,r=e.day?o?"dd":"d":void 0;switch(e.type){case"mdy":return[n,r,i].filter(Mt).join(t);case"ymd":return[i,n,r].filter(Mt).join(t);case"dmy":return[r,n,i].filter(Mt).join(t)}}(e,t,l,c);return{value:Math.round(d/xi),format:u,jsDate:h}}(n,t),null===i)return null;e=e.replace(n.dateString,"").trim()}if(""!==e||!i&&!o)return null;if(i&&i.jsDate&&o&&o.jsDate)return{value:i.value+o.value,format:i.format+" "+("hhhh:mm:ss"===o.format?"hh:mm:ss":o.format),jsDate:new Ii(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)),Li.get(t).get(e)}function Ui(e){const t=Math.trunc(e),o=Ii.fromTimestamp(t*xi-Ai);let s=e-t;s=s<0?1+s:s;const i=Math.round(24*s),n=Math.round(24*(s-i/24)*60),r=Math.round(24*(s-i/24-n/24/60)*60*60);return o.setHours(i),o.setMinutes(n),o.setSeconds(r),o}function Hi(e){return Math.round(zi(e))}function zi(e){return(e.getTime()-wi.getTime())/xi}function Bi(e){return new Ii(e.getFullYear(),e.getMonth()+1,0).getDate()}function $i(e){return Bi(e)===e.getDate()}function Gi(e,t,o){const s=e.getFullYear(),i=e.getMonth(),n=e.getDate(),r=new Ii(s,i+t,1);return o&&n===Bi(e)||n>Bi(r)?r.setDate(Bi(r)):r.setDate(n),r}function Wi(e){const t=Math.trunc(e);return t%4==0&&t%100!=0||t%400==0}function qi(e,t,o){if(e===t)return 0;if(e>t){const o=t;t=e,e=o}const s=Ui(e),i=Ui(t);let n=s.getDate(),r=i.getDate();const a=s.getMonth(),l=i.getMonth(),c=s.getFullYear(),h=i.getFullYear();let d=0,u=0;switch(o){case 0:31===n&&(n=30),30===n&&31===r&&(r=30),1===a&&n===(Wi(c)?29:28)&&(n=30,1===l&&r===(Wi(h)?29:28)&&(r=30)),d=c+(30*a+n)/360,u=h+(30*l+r)/360;break;case 1:let o=365;const s=c===h;if(!s&&!(c+1===h)||!s&&a<l||!s&&a===l&&n<r){let e=0,t=0;for(let o=c;o<=h;o++)e++,t+=Wi(o)?366:365;o=t/e}else s?Wi(c)&&(o=366):(Wi(c)&&a<2&&(o=366),Wi(h)&&(l>1||1===l&&29===r)&&(o=366));d=e/o,u=t/o;break;case 2:d=e/360,u=t/360;break;case 3:d=e/365,u=t/365;break;case 4:31===n&&(n=30),31===r&&(r=30),d=c+(30*a+n)/360,u=h+(30*l+r)/360}return u-d}function Zi(e,t){const o=12*(t.getFullYear()-e.getFullYear())+t.getMonth()-e.getMonth();return e.getDate()>t.getDate()?o-1:o}function ji(e,t){const o=e.getTime(),s=t.getTime();return Math.floor((s-o)/xi)}function Yi(e,t){const o=t.getFullYear()-e.getFullYear(),s=e.getMonth(),i=t.getMonth(),n=e.getDate(),r=t.getDate();return i>s||i===s&&r>=n?o:o-1}function Xi(e,t,o){return t>o?Xi(e,o,t):(e=Math.trunc(e),t=Math.trunc(t),o=Math.trunc(o),e>=t&&e<=o)}const Ki=Jt((function(e){return e=gt(e),new RegExp(`(?:^-?\\d+(?:${e}?\\d*(?:e(\\+|-)?\\d+)?)?|^-?${e}\\d+)(?!\\w|!)`)})),Ji=Jt((function(e){const t=gt(e.decimalSeparator),o="(?:\\s*"+`(?:\\d+(?:${gt(e.thousandsSeparator||"")}\\d{3,})*(?:${t}\\d*)?)`+"|"+`(?:${t}\\d+)`+")(?:e(?:\\+|-)?\\d+)?(?:\\s*%)?",s="(?:\\s*-)?",i="(?:\\s*[\\$€])?",n="^(?:(?:"+[s+i+o,s+o+i,i+s+o].join(")|(?:")+"))$";return new RegExp(n,"i")}));function Qi(e,t){return!!e&&Ji(t).test(e.trim())}const en=Jt((function(e){return new RegExp(`[$€${gt(e.thousandsSeparator||"")}]`,"g")}));function tn(e,t){e=e.replace(en(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 on(e,t,o){const s=[...e].sort(((e,t)=>e-t));let i=(s.length+(o?-1:1))*t;if(o||i--,Number.isInteger(i))return s[i];const n=Math.ceil(i),r=Math.floor(i);return s[n]*(i-r)+s[r]*(n-i)}const sn={NotAvailable:"#N/A",InvalidReference:"#REF",BadExpression:"#BAD_EXPR",CircularDependency:"#CYCLE",UnknownFunction:"#NAME?",DivisionByZero:"#DIV/0!",SpilledBlocked:"#SPILL!",GenericError:"#ERROR",NullError:"#NULL!"},nn=new Set(Object.values(sn));class rn{message;value;constructor(e=ui("Error"),t=sn.GenericError){this.message=e,this.value=t,this.message=e.toString()}}class an extends rn{constructor(e=ui("Invalid expression")){super(e,sn.BadExpression)}}class ln extends rn{constructor(e=ui("Circular reference")){super(e,sn.CircularDependency)}}class cn extends rn{constructor(e=ui("Invalid reference")){super(e,sn.InvalidReference)}}class hn extends rn{constructor(e=ui("Data not available")){super(e,sn.NotAvailable)}}class dn extends rn{constructor(e=ui("Unknown function")){super(e,sn.UnknownFunction)}}class un extends rn{constructor(e=ui("Spill range is not empty")){super(e,sn.SpilledBlocked)}}class gn extends rn{constructor(e=ui("Division by zero")){super(e,sn.DivisionByZero)}}const pn=["number","string","boolean","undefined"];function mn(e){if(void 0!==e)return E(e)?e[0][0]?.format:e.format}function fn(e){return"string"==typeof e&&nn.has(e)}function vn(e){return{value:sn.NotAvailable,message:ui("Did not find value '%s' in [[FUNCTION_NAME]] evaluation.",En(e))}}const bn=e=>ui("The function [[FUNCTION_NAME]] expects a number value, but '%s' is a string, and cannot be coerced to a number.",e);function Sn(e,t){const o=_n(e);switch(typeof o){case"number":return o;case"boolean":return o?1:0;case"string":if(Qi(o,t)||""===o)return tn(o,t);const e=Vi(o,t);if(e)return e.value;throw new rn(bn(o));default:return 0}}function Cn(e,t){try{return Sn(e,t)}catch(e){return}}function yn(e,t){return Kn(e).map((e=>e.map((e=>{if("number"!=typeof e.value){let o="";throw"object"==typeof e?o=ui("Function [[FUNCTION_NAME]] expects number values for %s, but got an empty value.",t):"string"==typeof e?o=ui("Function [[FUNCTION_NAME]] expects number values for %s, but got a string.",t):"boolean"==typeof e&&(o=ui("Function [[FUNCTION_NAME]] expects number values for %s, but got a boolean.",t)),new rn(o)}return e.value}))))}function In(e,t){const o=_n(e);if(""===o)throw new rn(bn(o));return Sn(o,t)}function wn(e,t){return Math.trunc(Sn(e,t))}function xn(e,t){return Math.trunc(In(e,t))}function En(e){const t=_n(e);switch(typeof t){case"string":return t;case"number":return t.toString();case"boolean":return t?"TRUE":"FALSE";default:return""}}const Rn=Jt((function(e){return e.toLowerCase().normalize("NFD").replace(/[\u0300-\u036f]/g,"")})),Tn=e=>ui("The function [[FUNCTION_NAME]] expects a boolean value, but '%s' is a text, and cannot be coerced to a boolean.",e);function An(e){const t=_n(e);switch(typeof t){case"boolean":return t;case"string":if(t){const e=t.toUpperCase();if("TRUE"===e)return!0;if("FALSE"===e)return!1;throw new rn(Tn(t))}return!1;case"number":return!!t;default:return!1}}function Dn(e,t){return Ui(Sn(_n(e),t))}function _n(e){if("object"==typeof e&&null!==e&&"value"in e){if(fn(e.value))throw e;return e.value}if(fn(e))throw new rn("",e);return e}function Fn(e,t,o){for(const s of e)if(E(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 On(e,t){Fn(e,(e=>{if(fn(e.value))throw e;t(e)}),(e=>{if(fn(e?.value))throw e;t(e)}))}function Pn(e,t,o){Fn(e,(e=>{if("number"==typeof e?.value&&t(e),fn(e?.value))throw e}),(e=>{t({value:In(e,o),format:e?.format})}))}function Mn(e,t,o,s,i="rowFirst"){let n=s;for(const s of e)if(E(s)){const e=s.length,o=s[0].length;if("rowFirst"===i)for(let i=0;i<o;i++)for(let o=0;o<e;o++)n=t(n,s[o][i]);else for(let i=0;i<e;i++)for(let e=0;e<o;e++)n=t(n,s[i][e])}else n=o(n,s);return n}function Nn(e,t,o,s="rowFirst"){return Mn(e,t,t,o,s)}function kn(e,t,o,s){return Mn(e,((e,o)=>{const s=o?.value;if("number"==typeof s)return t(e,s);if(fn(s))throw o;return e}),((e,o)=>t(e,In(o,s))),o)}function Ln(e,t,o,s){return Mn(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,Sn(i,s));if(fn(i))throw o;return t(e,0)}return e}),((e,o)=>t(e,Sn(o,s))),o)}function Vn(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 Un(e,t){return 0===e.length?[]:Vn(e.length,e[0].length,((o,s)=>t(e[o][s])))}function Hn(e){return e.length?Vn(e[0].length,e.length,((t,o)=>e[o][t])):[]}function zn(e,t,o=void 0){let s,i=1,n=1,r=1/0,a=1/0;for(let e=0;e<t.length;e++){const l=t[e];if(E(l)&&(void 0===o||o[e])){const o=l.length,c=l[0].length;1!==o||1!==c?(s??=new Array(t.length),1!==o&&1!==c?(s[e]="matrix",i=Math.max(i,o),n=Math.max(n,c),r=Math.min(r,o),a=Math.min(a,c)):1!==o?(s[e]="horizontal",i=Math.max(i,o),r=Math.min(r,o)):1!==c&&(s[e]="vertical",n=Math.max(n,c),a=Math.min(a,c))):t[e]=l[0][0]}}if(1===i&&1===n)return e(...t);return Vn(i,n,((o,i)=>{if(o>r-1||i>a-1)return new hn(ui("Array arguments to [[FUNCTION_NAME]] are of different size."));const n=e(...(l=o,c=i,t.map(((e,t)=>{switch(s?.[t]){case"matrix":return e[l][c];case"horizontal":return e[l][0];case"vertical":return e[0][c];case void 0:return e}}))));var l,c;return E(n)?n[0][0]:n}))}function Bn(e,t){return function(e,t,o){for(const s of e)if(E(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(fn(o))throw e;return!0}),(e=>void 0===e||null===e.value||t(function(e){const t=_n(e);if(""===t)throw new rn(Tn(t));return An(t)}(e))))}function $n(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)),Qi(s,t)||ki(s,t)?s=Sn(s,t):"TRUE"!==s&&"FALSE"!==s||(s=An(s)),{operator:o,operand:s}}const Gn=Jt((function(e){if("*"===e)return/.+/;let t="",o="";for(const s of e)"?"===s&&"~"!==o?t+=".":"*"===s&&"~"!==o?t+=".*":("*"!==s&&"?"!==s||(t=t.slice(0,-1)),["^",".","[","]","$","(",")","*","+","?","|","{","}","\\"].includes(s)&&(t+="\\"),t+=s),o=s;return new RegExp("^"+t+"$","i")}));function Wn(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&&(Qi(e,o)||ki(e,o))?Sn(e,o)===i:e===i;if("<>"===s||"="===s){let t;return t=typeof e==typeof i&&("string"==typeof e&&"string"==typeof i?Gn(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 qn(e,t,o,s=!1){const i=e.length;if(i%2==1)throw new rn(ui("Function [[FUNCTION_NAME]] expects criteria_range and criterion to be in pairs."));const n=Kn(e[0]),r=n.length,a=n[0].length,l=[];for(let t=0;t<i-1;t+=2){const i=Kn(e[t]);if(i.length!==r||i[0].length!==a)throw new rn(ui("Function [[FUNCTION_NAME]] expects criteria_range to have the same dimension"));const n=$n(En(e[t+1]),o);s&&"string"==typeof n.operand&&(n.operand+="*"),l.push(n)}for(let s=0;s<r;s++)for(let n=0;n<a;n++){let r=!0;for(let t=0;t<i-1;t+=2){if(r=Wn(Kn(e[t])[s][n].value??void 0,l[t/2],o),!r)break}r&&t(s,n)}}function Zn(e,t,o,s,i,n){if(void 0===t||null===t.value)return-1;if(fn(t.value))throw t;const r=Yn(t.value),a=typeof r;let l,c,h,d,u,g,p=0,m=i-1;const f="desc"===s?t=>Yn(n(e,i-t-1)):t=>Yn(n(e,t));for(;m-p>=0;){for(h=Math.floor((p+m)/2),d=h,u=f(d),g=typeof u;p<d&&a!==g;)d--,u=f(d),g=typeof u;g===a&&null!=u?("strict"===o&&u===r?(l=u,c=d):"nextSmaller"===o&&u<=r?(null==l||l<u||l===u&&c<d)&&(l=u,c=d):"nextGreater"===o&&u>=r&&(void 0===l||l>u||l===u&&c<d)&&(l=u,c=d),u>r||"strict"===o&&u===r?m=d-1:p=h+1):p=h+1}return void 0===c?-1:"desc"===s?i-c-1:c}function jn(e,t,o,s,i,n,r=!1){if(void 0===t||null===t.value)return-1;if(fn(t.value))throw t;const a=Yn(t.value),l=r?(e,t)=>Yn(i(e,s-t-1)):(e,t)=>Yn(i(e,t)),c="wildcard"!==o||"string"!=typeof a||!(a.includes("*")||a.includes("?"));if(n&&c){const t=r?"reverseSearch":"forwardSearch";let i=n[t].get(e);if(void 0===i){i=new Map;for(let t=0;t<s;t++){const o=l(e,t)??null;i.has(o)||i.set(o,t)}n[t].set(e,i)}if(i.has(a)){const e=i.get(a);return r?s-e-1:e}if("strict"===o)return-1}const h=function(e,t,o,s,i){let n=o=>i(e,o)===t;if("wildcard"===o&&"string"==typeof t&&(t.includes("*")||t.includes("?"))){const o=Gn(t);n=t=>{const s=i(e,t);return"string"==typeof s&&o.test(s)}}let r,a=-1;"nextSmaller"===o&&(n=o=>{const s=i(e,o);return(!r&&Xn(t,s)>=0||Xn(t,s)>=0&&Xn(s,r)>0)&&(r=s,a=o),s===t});"nextGreater"===o&&(n=o=>{const s=i(e,o);return(!r&&Xn(t,s)<=0||Xn(t,s)<=0&&Xn(s,r)<0)&&(r=s,a=o),s===t});for(let e=0;e<s;e++)if(n(e))return e;return a}(e,a,o,s,l);return r&&-1!==h?s-h-1:h}function Yn(e){return"string"==typeof e?Rn(e):e}function Xn(e,t){let o=pn.indexOf(typeof e)-pn.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 Kn(e){return void 0===e?[[]]:E(e)?e:[[e]]}function Jn(e,t){return Nn(e,((e,o)=>(e.push(t(o)),e)),[],"rowFirst")}function Qn(e){if(void 0===e)return!1;const{value:t}=e;return null!==t&&""!==t}const er=ui("[[FUNCTION_NAME]] has no valid input data.");function tr(e){return ui("[[FUNCTION_NAME]] expects the provided values of %(argName)s to be a non-empty matrix.",{argName:e})}function or(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 sr=new Set("$+-/():!^&~{}<>= ");function ir(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 sr.has(e.current)?{type:"CHAR",value:e.shift()}:null}function nr(e){return","===e.current?(e.shift(),{type:"THOUSANDS_SEPARATOR",value:","}):null}function rr(e){return"@"===e.current?(e.shift(),{type:"TEXT_PLACEHOLDER",value:"@"}):null}function ar(e){return"."===e.current?(e.shift(),{type:"DECIMAL_POINT",value:"."}):null}function lr(e){return"%"===e.current?(e.shift(),{type:"PERCENT",value:"%"}):null}function cr(e){if("0"===e.current||"#"===e.current){const t=e.current;return e.shift(),{type:"DIGIT",value:t}}return null}const hr=new Set("dmqyhsa");function dr(e){if(!hr.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 ur(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 gr=20,pr={};function mr(e){let t=pr[e];return void 0===t&&(t=function(e){const t=function(e){const t=new ao(e),o=[];let s=[];for(o.push(s);!t.isOver();){if(";"===t.current){s=[],o.push(s),t.shift();continue}const e=cr(t)||or(t)||ir(t)||nr(t)||ar(t)||lr(t)||dr(t)||rr(t)||ur(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=vr(t[0])||fr(t[0])||br(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=vr(t[1])||fr(t[1]);if(t[1]?.length&&!s)throw new Error("Invalid second format part of: "+e);const i=vr(t[2])||fr(t[2]);if(t[2]?.length&&!i)throw new Error("Invalid third format part of: "+e);const n=br(t[3]);if(t[3]?.length&&!n)throw new Error("Invalid fourth format part of: "+e);return{positive:o,negative:s,zero:i,text:n}}(e),pr[e]=t),t}function fr(e){if(!e||!function(e){return e.every((e=>"DIGIT"===e.type||"DECIMAL_POINT"===e.type||"THOUSANDS_SEPARATOR"===e.type||"PERCENT"===e.type||"STRING"===e.type||"CHAR"===e.type||"REPEATED_CHAR"===e.type))}(e))return;const t=[];let o,s=t,i=0,n=0,r=e.findLastIndex((e=>"DIGIT"===e.type)),a=!1,l=0;for(let c=0;c<e.length;c++){const h=e[c];switch(h.type){case"DIGIT":s===t?s.push(h):l<gr&&(s.push(h),l++);break;case"DECIMAL_POINT":if(s!==t)throw new Error("Multiple decimal points in a number format");o=[],s=o;break;case"REPEATED_CHAR":case"CHAR":case"STRING":s.push(h);break;case"PERCENT":i++,s.push(h);break;case"THOUSANDS_SEPARATOR":c-1===r?(n+=1,r++,s.push(h)):"DIGIT"===e[c+1]?.type&&"DIGIT"===e[c-1]?.type?(s===t&&(a=!0),s.push(h)):s.push({type:"CHAR",value:","})}}return{type:"number",integerPart:t,decimalPart:o,percentSymbols:i,thousandsSeparator:a,magnitude:n}}function vr(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 br(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 Sr(e){return[Cr(e.positive),Cr(e.negative),Cr(e.zero),Cr(e.text)].filter(Mt).join(";")}function Cr(e){if(!e)return;let t="";const o="number"!==e.type?e.tokens:function(e){const t=[...e.integerPart];e.decimalPart&&(t.push({type:"DECIMAL_POINT",value:"."}),t.push(...e.decimalPart));return t}(e);for(const e of o)switch(e.type){case"STRING":t+=`[$${e.value}]`;break;case"CHAR":t+=(s=e.value,sr.has(s)?e.value:`\\${e.value}`);break;case"REPEATED_CHAR":t+="*"+e.value;break;case"DATE_PART":t+="MM"===e.value?"mm":e.value;break;default:t+=e.value}var s;return t}const yr=11,Ir="REPEATED_CHAR_PLACEHOLDER_",wr={0:ui("January"),1:ui("February"),2:ui("March"),3:ui("April"),4:ui("May"),5:ui("June"),6:ui("July"),7:ui("August"),8:ui("September"),9:ui("October"),10:ui("November"),11:ui("December")},xr={0:ui("Sunday"),1:ui("Monday"),2:ui("Tuesday"),3:ui("Wednesday"),4:ui("Thursday"),5:ui("Friday"),6:ui("Saturday")};function Er(e,t,o,s=!1){return s?Wr({value:e,format:t},o):Rr(e,{format:t,locale:o})}function Rr(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=mr(t),i=o.text||o.positive;return i&&"text"===i.type?Tr(e,i,s):e}case"number":t||(t=Lr(e));const i=mr(t);if("text"===i.positive.type)return Tr(e.toString(),i.positive,s);let n=i.positive;if(e<0&&i.negative?(n=i.negative,e=-e):0===e&&i.zero&&(n=i.zero),"date"===n.type)return Ar(function(e,t){const o=Ui(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+=Nr(o,e.value,s);break;case"REPEATED_CHAR":i+=Ir+e.value;break;default:i+=e.value}return i}(e,n),s);const r=e<0,a=Ar(function(e,t,o){if(e===1/0)return"∞"+(t.percentSymbols?"%":"");const s=2*t.percentSymbols-3*t.magnitude;e*=10**s;let i=0;void 0!==t.decimalPart&&(i=t.decimalPart.filter((e=>"DIGIT"===e.type)).length);const{integerDigits:n,decimalDigits:r}=_r(Math.abs(e),i);let a=function(e,t,o){let s=t.integerPart;s.some((e=>"DIGIT"===e.type))||(s=[...s,{type:"DIGIT",value:"#"}]);"0"===e&&(e="");let i="";const n=s.findIndex((e=>"DIGIT"===e.type));let r=e.length-1;function a(t,s){if("0"===s&&(t=t||"0"),!t)return;const n=e.length-1-r;i=o&&n>0&&n%3==0?t+o+i:t+i}for(let t=s.length-1;t>=0;t--){const o=s[t];switch(o.type){case"DIGIT":if(a(e[r],o.value),r--,n===t)for(;r>=0;)a(e[r],"0"),r--;break;case"THOUSANDS_SEPARATOR":break;case"REPEATED_CHAR":i=Ir+o.value+i;break;default:i=o.value+i}}return i}(n,t,t.thousandsSeparator?o.thousandsSeparator:void 0);void 0!==t.decimalPart&&(a+=o.decimalSeparator+function(e,t){if(!t.decimalPart)return"";let o="",s=0;for(const i of t.decimalPart)switch(i.type){case"DIGIT":o+="#"===i.value?e[s]||"":e[s]||"0",s++;break;case"THOUSANDS_SEPARATOR":break;case"REPEATED_CHAR":o+=Ir+i.value;break;default:o+=i.value}return o}(r||"",t));return a}(Math.abs(e),n,o),s);return r?"-"+a:a;case"object":return""}}function Tr(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+=Ir+o.value}return Ar(s,o)}function Ar(e,t){const o=e.indexOf(Ir);if(-1===o)return e;const s=e.slice(0,o),i=e.slice(o+Ir.length+1),n=e[o+Ir.length];const{timesToRepeat:r,padding:a}=function(){if(!t)return{timesToRepeat:0,padding:""};const e=t.measureText(s+i),o=t.measureText(n),r=t.availableWidth-e;if(r<=0)return{timesToRepeat:0,padding:""};const a=Math.floor(r/o),l=r-a*o,c=t.measureText(" ");return{timesToRepeat:a,padding:" ".repeat(Math.floor(l/c))}}();return s+n.repeat(r)+a+i}const Dr=[];function _r(e,t=gr){const o=e.toString();if(o.includes("e"))return function(e,t=gr){let o=Dr[t];o||(o=new Intl.NumberFormat("en-US",{maximumFractionDigits:t,useGrouping:!1}),Dr[t]=o);const[s,i]=o.format(e).split(".");return{integerDigits:s,decimalDigits:i}}(e,t);if(Number.isInteger(e))return{integerDigits:o,decimalDigits:void 0};const s=o.indexOf(".");let i=o.substring(0,s),n=o.substring(s+1);if(0===t)return Number(n[0])>=5&&(i=(Number(i)+1).toString()),{integerDigits:i,decimalDigits:void 0};if(n.length>t){const{integerDigits:e,decimalDigits:o}=function(e,t){let o="0",s=e;const i=e.slice(0,t),n=t;if(Number(e[n])<5)return{integerDigits:o,decimalDigits:i};const r=i.match(Or)?.[0]||"",a=(Number(i)+1).toString(),l=i.slice(r.length),c=a.length>l.length;c&&!r?(o="1",s=void 0):s=c?r.slice(0,-1)+a:r+a;return{integerDigits:o,decimalDigits:s}}(n,t);n=o,"0"!==e&&(i=(Number(i)+Number(e)).toString())}return{integerDigits:i,decimalDigits:Fr(n||"")}}function Fr(e){let t=e.length-1;for(;t>=0&&"0"===e[t];)t--;return e.slice(0,t+1)||void 0}const Or=/^0+/;function Pr(e,t){const{integerDigits:o,decimalDigits:s}=_r(e,20);return s?o+t+s:o}const Mr=Jt((function(e){if(!e)return!1;try{return"date"===mr(e).positive.type}catch(e){return!1}}));function Nr(e,t,o){switch(t){case"d":return e.getDate();case"dd":return e.getDate().toString().padStart(2,"0");case"ddd":return xr[e.getDay()].slice(0,3);case"dddd":return xr[e.getDay()].toString();case"m":return e.getMonth()+1;case"mm":return String(e.getMonth()+1).padStart(2,"0");case"mmm":return wr[e.getMonth()].slice(0,3);case"mmmm":return wr[e.getMonth()].toString();case"mmmmm":return wr[e.getMonth()].slice(0,1);case"qq":return ui("Q%(quarter)s",{quarter:e.getQuarter()}).toString();case"qqqq":return ui("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()-wi.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 kr=Jt((function(e){return new RegExp(`[0-9]+${gt(e.decimalSeparator)}[0-9]`)}));function Lr(e){let{integerDigits:t,decimalDigits:o}=_r(e);if(!o)return"0";const s=t.replace("-","").length;if(s+2>yr)return"0";const i=yr-s-1;return({decimalDigits:o}=_r(e,Math.min(i,o.length))),o?"0."+"0".repeat(o.length):"0"}function Vr(e,t){if(!ki(e,t))return;return Vi(e,t).format}function Ur(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 Hr(e){const t=e.decimalPlaces??2,o=e.position??"before",s=e.code??"",i=e.symbol??"",n="#,##0"+(t?"."+"0".repeat(t):"");let r=`${s} ${i}`.trim();return"after"===o&&s&&(r=" "+r),function(e,t,o){const s=`[$${e}]`;return"before"===t?s+o:o+s}(r,o,n)}function zr(e){const t=e.decimalPlaces??2,o=e.position??"before",s=e.code??"",i=e.symbol??"",n="#,##0"+(t?"."+"0".repeat(t):"");let r=`${s} ${i}`.trim();"after"===o&&s&&(r=" "+r);return[Br(r,o,` ${n} `),Br(r,o,`(${n})`),Br(r,o," - ")].join(";")}function Br(e,t,o){const s=`[$${e}]`;return"before"===t?s+"* "+o:o+"* "+s}function $r(e){const t=mr(e);return Sr({positive:Gr(t.positive),negative:t.negative?Gr(t.negative):void 0,zero:t.zero?Gr(t.zero):void 0,text:t.text})}function Gr(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 Wr({value:e,format:t},o){const s=Cn(e,o);if(void 0===s)return"";let i=t;if(Math.abs(s)<1e3){i=!t&&s%1!=0?"0.####":t}else i=qr({value:e,format:t},void 0,o);return Rr(e,{format:i,locale:o})}function qr(e,t,o){let s=0;try{s=Math.abs(Sn(e?.value,o))}catch(e){return""}const i=e?.format;if(void 0!==t){const e=t?.value;switch(e){case"k":return Zr(i,1,"k");case"m":return Zr(i,2,"m");case"b":return Zr(i,3,"b");default:throw new rn(ui("The formatting unit should be 'k', 'm' or 'b'."))}}return s<1e5?Zr(i,0,""):s<1e8?Zr(i,1,"k"):s<1e11?Zr(i,2,"m"):Zr(i,3,"b")}function Zr(e,t,o,s){const i=mr(e||"#,##0");return Sr({positive:jr(i.positive,t,o),negative:i.negative?jr(i.negative,t,o):void 0,zero:i.zero?jr(i.zero,t,o):void 0,text:i.text})}function jr(e,t,o){if("number"!==e.type)return e;const s={type:"STRING",value:o};let i=[...e.integerPart];const n=i.findLastIndex((e=>"DIGIT"===e.type));if(-1===n)throw new Error("Cannot create a large number format from a format with no digit.");for(;"THOUSANDS_SEPARATOR"===i[n+1]?.type;)i=Qt(i,[n+1]);const r=i[n+1];i="STRING"===r?.type&&["m","k","b"].includes(r.value)?to(i,s,n+1):eo(i,[s],n+1),t>0&&(i=eo(i,Array(t).fill({type:"THOUSANDS_SEPARATOR",value:","}),n+1));const a=e.percentSymbols-i.filter((e=>"PERCENT"===e.type)).length;return i.push(...new Array(a).fill({type:"PERCENT",value:"%"})),{...e,integerPart:i,decimalPart:void 0,magnitude:t}}function Yr(e,t){const o=mr(e);return Sr(mr(Sr({positive:Xr(o.positive,t),negative:o.negative?Xr(o.negative,t):void 0,zero:o.zero?Xr(o.zero,t):void 0,text:o.text})))}function Xr(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=Ct(0,t).map((()=>({type:"DIGIT",value:"0"}))),n=s.findLastIndex((e=>"DIGIT"===e.type));s=-1===n?[...i,...s]:eo(s,i,n+1);return{...e,decimalPart:s,integerPart:o}}(e,t):function(e,t){let o=e.decimalPart;if(!o)return e;const s=[];let i=0;for(let e=o.length-1;e>=0&&!(i>=Math.abs(t));e--)"DIGIT"===o[e].type&&(i++,s.push(e));if(o=Qt(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 Kr(e){const t=mr(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 Jr(e){if(!e)return!1;try{return"text"===mr(e).positive.type}catch{return!1}}function Qr(e,t,o){return ta({value:Jr(t.format)&&null!==e.parsedValue?e.content:e.parsedValue,format:t.format,origin:o},t.locale)}function ea(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(e.includes("\n"))return e;if(Qi(e,w))return tn(e,w);const o=Vi(e,t);return o?o.value:wt(e)?"TRUE"===e.toUpperCase():e}function ta(e,t=w,o,s){const i=yi(e.value);if(!i){return na(oa(e,t,o),e.origin??s)}const n=ea(i.label,t);return na({...oa({value:n,format:e.format||("number"==typeof n?Vr(i.label,t)||Ur(i.label):void 0)},t,o),link:i},e.origin??s)}function oa(e,t,o){let{value:s,format:i,message:n}=e;i=o?.format||i;const a=Rr(s,{format:i,locale:t});return fn(s)?function(e,t){return{value:e,formattedValue:e,message:t,type:r.error,isAutoSummable:!1,defaultAlign:"center"}}(s,n):null===s?ia(i):Jr(i)?sa(En(s),i,a):"number"==typeof s?Mr(i||"")?function(e,t,o){return{value:e,format:t,formattedValue:o,type:r.number,isAutoSummable:!1,defaultAlign:"right"}}(s,i,a):function(e,t,o){return{value:e||0,format:t,formattedValue:o,type:r.number,isAutoSummable:!0,defaultAlign:"right"}}(s,i,a):"boolean"==typeof s?function(e,t,o){return{value:e,format:t,formattedValue:o,type:r.boolean,isAutoSummable:!1,defaultAlign:"center"}}(s,i,a):sa(s,i,a)}function sa(e,t,o){return{value:e,format:t,formattedValue:o,type:r.text,isAutoSummable:!0,defaultAlign:"left"}}const ia=Jt((function(e){return{value:null,format:e,formattedValue:"",type:r.empty,isAutoSummable:!0,defaultAlign:"left"}}));function na(e,t){return null===e.value||"origin"in e||(e.origin=t),e}function ra(e){const t=Ii.now();switch(e){case"today":return zi(t);case"yesterday":return zi(Ii.fromTimestamp(t.setDate(t.getDate()-1)));case"tomorrow":return zi(Ii.fromTimestamp(t.setDate(t.getDate()+1)));case"lastWeek":return zi(Ii.fromTimestamp(t.setDate(t.getDate()-7)));case"lastMonth":return zi(Ii.fromTimestamp(t.setMonth(t.getMonth()-1)));case"lastYear":return zi(Ii.fromTimestamp(t.setFullYear(t.getFullYear()-1)))}}function aa(e,t){return"dateValue"in e&&"exactDate"!==e.dateValue?[ra(e.dateValue)]:e.values.map((e=>Ni(e,t)))}function la(e,t){return e.map((e=>{if(e.startsWith("="))return e;const o=ea(e,t);return"number"==typeof o?Rr(o,{format:t.dateFormat,locale:t}):""}))}const ca=new WeakMap,ha=new WeakMap;function da(e,t){ca.has(t)||(ca.set(t,new Map),ha.set(t,0));const o=ca.get(t),s=pa(e);if(o.has(s)){const i=o.get(s);return t[i]=e,i}const i=ha.get(t)+1;return o.set(s,i),ha.set(t,i),t[i]=e,i}function ua(e){const t={};for(const o in e){const s=Fo(e[o].map(cs));for(const e of s)t[Go(e)]=Number(o)}return t}function*ga(e,t){for(const o in t){const s=Ho(o),i=t[o];for(let t=s.top;t<=s.bottom;t++)for(let o=s.left;o<=s.right;o++){const s={sheetId:e,col:o,row:t};yield[s,i]}}}function pa(e){if(null===e)return"null";if(void 0===e)return"undefined";if("object"!=typeof e)return String(e);if(Array.isArray(e)){const t=e.length;let o="[";for(let s=0;s<t;s++)s>0&&(o+=","),o+=pa(e[s]);return o+"]"}const t=Object.keys(e).sort();let o="{";for(const s of t)void 0!==e[s]&&(o+=`"${s}":${pa(e[s])},`);return o+="}",o}function ma(e){return 20+120*Math.exp(-.035*(e-1))}const fa=new RegExp(/\$?([A-Z]{1,3})\$?([0-9]{1,7})/,"i"),va=new RegExp(/^\$?([A-Z]{1,3})\$?([0-9]{1,7})$/,"i"),ba=new RegExp(/^\$?([A-Z]{1,3})+$/,"i"),Sa=new RegExp(/^\$?([0-9]{1,7})+$/,"i"),Ca=new RegExp(/^\s*('.+'!|[^']+!)?\$?([A-Z]{1,3})$/,"i"),ya=new RegExp(/^\s*('.+'!|[^']+!)?\$?([0-9]{1,7})$/,"i"),Ia=new RegExp(/^\s*('.+'!|[^']+!)?/.source+"("+[fa.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 wa(e){return ya.test(e)}function xa(e){return ba.test(e)}function Ea(e){return Sa.test(e)}function Ra(e){return va.test(e)}function Ta(e){if(!e.includes("!"))return{xc:e};const t=e.split("!"),o=t.pop();return{sheetName:mt(t.join("!"))||void 0,xc:o}}function Aa(e,t){return void 0!==e?`${vt(e)}!${t}`:t}function Da(e){const t=[];for(let o=0;o<e;o++){const e={cells:{}};t.push(e)}return t}function _a(e,t,o){return o.map((o=>o>=e?o+t:o))}function Fa(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(Mt)}function Oa(e,t="Sheet"){let o=1,s=`${t}${o}`;for(;e.includes(s);)s=`${t}${o}`,o++;return s}function Pa(e,t){let o=1;const s=ui("Copy of %s",e);let i=s.toString();for(;t.includes(i);)i=`${s} (${o})`,o++;return i}function Ma(e,t){return void 0!==e&&void 0!==t&&mt(e.trim().toUpperCase())===mt(t.trim().toUpperCase())}function Na(e,t){const o=e.zone,s=function(e,t){const{left:o,top:s,bottom:i,right:n}=e;if(void 0!==n&&void 0!==i)return e;if(void 0===i&&void 0!==n)return{right:n,top:s,left:o,bottom:t.numberOfRows-1};if(void 0===n&&void 0!==i)return{bottom:i,left:o,top:s,right:t.numberOfCols-1};throw new Error("Bad zone format")}(o,t(e.sheetId));let i=e.parts;return 1===e.parts.length&&gs(s)>1?i=[e.parts[0],e.parts[0]]:2===e.parts.length&&1===gs(s)&&(i=[e.parts[0]]),{unboundedZone:o,zone:s,parts:i,prefixSheet:e.prefixSheet,invalidSheetName:e.invalidSheetName,sheetId:e.sheetId}}function ka(e,t){const o=e.xc,{xc:s,sheetName:i}=Ta(o),n=Uo(s),r=function(e,t){const o=e.split(":").map((e=>{const t=wa(e);return{colFixed:!t&&e.startsWith("$"),rowFixed:t?e.startsWith("$"):e.includes("$",1)}})),s=void 0===t.bottom,i=void 0===t.right;s&&(o[0].rowFixed=o[0].rowFixed||o[1].rowFixed,o[1].rowFixed=o[0].rowFixed||o[1].rowFixed);i&&(o[0].colFixed=o[0].colFixed||o[1].colFixed,o[1].colFixed=o[0].colFixed||o[1].colFixed);return o}(s,n);return Na({zone:n,parts:r,sheetId:e.sheetId,prefixSheet:Boolean(i),invalidSheetName:e.invalidSheetName},t)}function La(e){const t={left:-1,top:-1,right:-1,bottom:-1};return{sheetId:"",zone:t,unboundedZone:t,parts:[],invalidXc:e,prefixSheet:!1}}function Va(e){return us(e.unboundedZone)}function Ua(e){return ds(e.unboundedZone)}function Ha(e,t,o,s={useBoundedReference:!1,useFixedReference:!1}){if(e.invalidXc)return e.invalidXc;if(e.zone.bottom-e.zone.top<0||e.zone.right-e.zone.left<0)return sn.InvalidReference;if(e.zone.left<0||e.zone.top<0)return sn.InvalidReference;const i=e.sheetId!==t||e.invalidSheetName||e.prefixSheet;let n="";if(i&&(n=e.invalidSheetName?vt(e.invalidSheetName):vt(o(e.sheetId))),i&&!n)return sn.InvalidReference;let r=Qa(e,0,s);return e.parts&&2===e.parts.length&&(e.zone.top!==e.zone.bottom||e.zone.left!==e.zone.right||e.parts[0].rowFixed||e.parts[0].colFixed||e.parts[1].rowFixed||e.parts[1].colFixed)&&(r+=":",r+=Qa(e,1,s)),`${i?n+"!":""}${r}`}function za(e,t,o){const s=o.sheetId===e?t:o.sheetId;return{...o,sheetId:s}}function Ba(e,t,o){if(!o)return;const s=e.getRangeFromSheetXC(t,o);return s.invalidSheetName||s.invalidXc?void 0:s}function $a(e){const t=[];for(const o of e)for(const e of is(o.zone))t.push({...e,sheetId:o.sheetId});return t}function Ga(e){const t={left:e.col,top:e.row,right:e.col,bottom:e.row};return{sheetId:e.sheetId,zone:t}}function Wa(e){return qa.get(e.type)?.(e)}const qa=new class extends n{add(e,t){return super.add(e,t),this}get(e){return this.content[e]}};function Za(e){const t="COL"===e.dimension?"left":"top",o="COL"===e.dimension?"right":"bottom",s="COL"===e.dimension?"columns":"rows",i=[...e.elements];i.sort(((e,t)=>t-e));const n=yt(i);return i=>{if(!Ma(i.sheetId,e.sheetId))return{changeType:"NONE"};let r=i,a="NONE";for(const e of n){const n=ro(e),l=no(e);if(i.zone[t]<=n&&n<=i.zone[o]){const e=Math.min(i.zone[o],l)-n+1;a="RESIZE",r=Ja(r,s,a,-e)}else if(i.zone[t]>=n&&i.zone[o]<=l)a="REMOVE",r=La(sn.InvalidReference);else if(i.zone[t]<=l&&i.zone[o]>=l){const e=l-i.zone[t]+1;a="RESIZE",r=Ja(r,s,a,-e),r=Ja(r,s,"MOVE",-(i.zone[t]-n))}else n<i.zone[t]&&(a="MOVE",r=Ja(r,s,a,-(l-n+1)))}return"NONE"!==a?{changeType:a,range:r}:{changeType:"NONE"}}}function ja(e){const t="COL"===e.dimension?"left":"top",o="COL"===e.dimension?"right":"bottom",s="COL"===e.dimension?"columns":"rows";return i=>{if(i.sheetId!==e.sheetId)return{changeType:"NONE"};if("after"===e.position){if(i.zone[t]<=e.base&&e.base<i.zone[o])return{changeType:"RESIZE",range:Ja(i,s,"RESIZE",e.quantity)};if(e.base<i.zone[t])return{changeType:"MOVE",range:Ja(i,s,"MOVE",e.quantity)}}else{if(i.zone[t]<e.base&&e.base<=i.zone[o])return{changeType:"RESIZE",range:Ja(i,s,"RESIZE",e.quantity)};if(e.base<=i.zone[t])return{changeType:"MOVE",range:Ja(i,s,"MOVE",e.quantity)}}return{changeType:"NONE"}}}function Ya(e){return t=>{if(t.sheetId!==e.sheetId&&t.invalidSheetName!==e.sheetName)return{changeType:"NONE"};const o=e.sheetName;return{changeType:"REMOVE",range:t={...La(sn.InvalidReference),invalidSheetName:o}}}}function Xa(e){return t=>{if(t.sheetId===e.sheetId)return{changeType:"CHANGE",range:t};if(e.newName&&t.invalidSheetName===e.newName){const o=void 0,s=e.sheetId;return{changeType:"CHANGE",range:{...t,sheetId:s,invalidSheetName:o}}}if(e.oldName&&t.invalidSheetName===e.oldName){const o=void 0,s=e.sheetId;return{changeType:"CHANGE",range:{...t,sheetId:s,invalidSheetName:o}}}return{changeType:"NONE"}}}function Ka(e){const t=e.target[0];return o=>{if(o.sheetId!==e.sheetId||!ts(o.zone,t))return{changeType:"NONE"};const s=e.targetSheetId,i=Ja(o,"both","MOVE",[e.col-t.left,e.row-t.top]),n=e.sheetId!==s||i.prefixSheet;return{changeType:"MOVE",range:{...i,sheetId:s,prefixSheet:n}}}}function Ja(e,t,o,s){return{...e,unboundedZone:as(e.unboundedZone,t,o,s),zone:as(e.zone,t,o,s)}}function Qa(e,t,o={useBoundedReference:!1,useFixedReference:!1}){const s=e.parts[t]?.colFixed||o.useFixedReference?"$":"",i=So(0===t?e.zone.left:e.zone.right),n=e.parts[t]?.rowFixed||o.useFixedReference?"$":"",r=String(0===t?e.zone.top+1:e.zone.bottom+1);let a="";return a=us(e.unboundedZone)&&!o.useBoundedReference?0===t&&e.unboundedZone.hasHeader?s+i+n+r:s+i:ds(e.unboundedZone)&&!o.useBoundedReference?0===t&&e.unboundedZone.hasHeader?s+i+n+r:n+r:s+i+n+r,a}function el(e,t,o){const s=[];return t.forEach((t=>{const i=function(e,t){e=e.toLocaleLowerCase();let o=0,s=0;const i=(t=t.toLocaleLowerCase()).length;let n=0;for(let r=0;r<i;r++)t[r]===e[n]?(n++,s+=100+s-r/200):s=0,o+=s;return n===e.length?o:0}(e,o(t));i>0&&s.push({score:i,elem:t})})),s.sort(((e,t)=>t.score-e.score)),s.map((e=>e.elem))}function tl(e,t=1){return t*(e+Te)-Te}function ol(e,t,o,s){const i=gl(e,t,o,"wrap"===o?.wrapping?s-2*Te:void 0).length;return tl(dl(o),i)+2*Ae}function sl(e,t=!1,o=!1){return`${o?"italic":""} ${t?"bold":""} ${e}px ${Le}`}qa.add("REMOVE_COLUMNS_ROWS",(e=>({applyChange:Za(e),sheetId:e.sheetId,sheetName:{old:e.sheetName,current:e.sheetName}}))).add("ADD_COLUMNS_ROWS",(e=>({applyChange:ja(e),sheetId:e.sheetId,sheetName:{old:e.sheetName,current:e.sheetName}}))).add("DELETE_SHEET",(e=>({applyChange:Ya(e),sheetId:e.sheetId,sheetName:{old:e.sheetName,current:e.sheetName}}))).add("RENAME_SHEET",(e=>({applyChange:Xa(e),sheetId:e.sheetId,sheetName:{old:e.oldName,current:e.newName}}))).add("MOVE_RANGES",(e=>({applyChange:Ka(e),sheetId:e.sheetId,sheetName:{old:e.sheetName,current:e.sheetName}})));const il={};function nl(e,t,o,s="pt"){return rl(e,t,hl(o,s))}function rl(e,t,o){if(il[o]||(il[o]={}),void 0===il[o][t]){const s=e.font;e.font=o,il[o][t]=e.measureText(t).width,e.font=s}return il[o][t]}const al={};function ll(e,t,o,s="pt"){const i=hl(o,s);e.save(),e.font=i;const n=function(e,t){const o=e.font;al[o]||(al[o]={});if(void 0===al[o][t]){const s=e.measureText(t),i=s.width,n=s.fontBoundingBoxAscent+s.fontBoundingBoxDescent;al[o][t]={width:i,height:n}}return al[o][t]}(e,t);return e.restore(),n}function cl(e){return Math.round(96*e/72)}function hl(e,t="pt"){return`${e.italic?"italic ":""}${e.bold?"bold":Ne} ${("pt"===t?dl(e):e.fontSize)??ke}px ${Le}`}function dl(e){return cl(e?.fontSize||ke)}function ul(e,t,o,s){if(nl(e,t,s)<=o)return[t];const i=[];let n="";for(const r of t){nl(e,n+r,s)>o?(i.push(n),n=r):n+=r}return i.push(n),i}function gl(e,t,o,s){o||(o={}),Rt(t)&&(t=Dt(t).label);const i=[],n=t.includes(ot)?t.split(ot):[t];for(const t of n){const n=t.includes(" ")?t.split(" "):[t];if(!s){i.push(t);continue}let r="",a=s;for(const t of n){const n=ul(e,t,s,o),l=n.pop(),c=nl(e,l,o);if(n.length)""!==r&&(i.push(r),r="",a=s),n.forEach((e=>{i.push(e)})),r=l,a=s-c;else{const t=""===r?l:" "+l,n=nl(e,t,o);n<=a?(r+=t,a-=n):(i.push(r),r=l,a=s-c)}}""!==r&&i.push(r)}return i}function pl(e){return e?e.toLowerCase():""}const ml=/([0-9\.]*)px/;function fl(e,t,o){let s=rl(e,t,e.font);if(s<=o)return t;const i=rl(e,"…",e.font);if(s<=i)return t;let n=t.length;for(;s>=o-i&&n-- >0;)s=rl(e,t=t.substring(0,n),e.font);return t+"…"}function vl(e,t,o,s=!1,i=!1,n=function(e){return Number(e.match(ml)?.[1])}(e.font)/10){if(e.fillText(t,o.x,o.y),!s&&!i)return;const r=e.measureText(t),a=r.width,l=r.actualBoundingBoxAscent+r.actualBoundingBoxDescent,c=r.fontBoundingBoxAscent+r.fontBoundingBoxDescent;let{x:h,y:d}=o,u=d,g=d;switch(e.textAlign){case"center":h-=a/2;break;case"right":h-=a}switch(e.textBaseline){case"top":g+=c-2*n,u+=c/2-n;break;case"middle":g+=c/2-n;break;case"alphabetic":g+=2*n,u-=3*n;break;case"bottom":g=d,u-=l/2-n/2}s&&(e.lineWidth=n,e.strokeStyle=e.fillStyle,e.beginPath(),e.moveTo(h,g),e.lineTo(h+a,g),e.stroke()),i&&(e.lineWidth=n,e.strokeStyle=e.fillStyle,e.beginPath(),e.moveTo(h,u),e.lineTo(h+a,u),e.stroke())}function bl(e,t,o,s,i="pt"){if(nl(e,o,s,i)<=t)return o;const n=nl(e,"...",s,i);if(n>=t)return"";let r,a=1,l=o.length;for(;a<=l;){const c=Math.floor((a+l)/2);r=nl(e,o.slice(0,c),s,i),r+n>t?l=c-1:a=c+1}const c=o.slice(0,Math.max(0,a-1));return c?c+"...":""}class Sl{smallUuid(){return window.crypto?"10000000-1000".replace(/[01]/g,(e=>{const t=Number(e);return(t^crypto.getRandomValues(new Uint8Array(1))[0]&15>>t/4).toString(16)})):"xxxxxxxx-xxxx".replace(/[xy]/g,(function(e){const t=16*Math.random()|0;return("x"===e?t:3&t|8).toString(16)}))}uuidv4(){return window.crypto?"10000000-1000-4000-8000-100000000000".replace(/[018]/g,(e=>{const t=Number(e);return(t^crypto.getRandomValues(new Uint8Array(1))[0]&15>>t/4).toString(16)})):"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,(function(e){const t=16*Math.random()|0;return("x"===e?t:3&t|8).toString(16)}))}}class Cl{getters;dispatch;constructor(e,t){this.getters=e,this.dispatch=t}copy(e,t,o="copyPaste"){}paste(e,t,o){}isPasteAllowed(e,t,o,s){return"Success"}isCutAllowed(e){return"Success"}getPasteTarget(e,t,o,s){return{zones:[],sheetId:e}}convertTextToClipboardData(e){}}class yl extends Cl{copy(e,t,o="copyPaste"){}pasteFromCopy(e,t,o,s){if(1===t.length)for(const i of Cs(t,o))this.pasteZone(e,i.left,i.top,o,s);else for(const i of Fo(t))for(let t=i.left;t<=i.right;t++)for(let n=i.top;n<=i.bottom;n++)this.pasteZone(e,t,n,o,s)}pasteZone(e,t,o,s,i){}}class Il extends Cl{copy(e){}}const wl=["%"],xl="+,-,*,/,:,=,<>,>=,>,<=,<,^,&".split(",").concat(wl);function El(e,t=w){e=Xt(e);const o=new ao(e),s=[],i=Zt.test(e)?Ll:Vl;for(;!o.isOver();){let e=Ul(o)||i(o)||Dl(o,t)||Al(o)||_l(o)||Pl(o)||Rl(o)||Hl(o)||Ol(o,t)||kl(o);e||(e={type:"UNKNOWN",value:o.shift()}),s.push(e)}return s}function Rl(e){return"?"===e.current?(e.shift(),{type:"DEBUGGER",value:"?"}):null}const Tl={"(":{type:"LEFT_PAREN",value:"("},")":{type:"RIGHT_PAREN",value:")"}};function Al(e){if("("===e.current||")"===e.current){const t=e.shift();return Tl[t]}return null}function Dl(e,t){if(e.current===t.formulaArgSeparator){return{type:"ARG_SEPARATOR",value:e.shift()}}return null}function _l(e){for(const t of xl)if(e.currentStartsWith(t))return e.advanceBy(t.length),{type:"OPERATOR",value:t};return null}const Fl=new Set("0123456789");function Ol(e,t){if(!Fl.has(e.current)&&e.current!==t.decimalSeparator)return null;const o=e.remaining().match(Ki(t.decimalSeparator));return o?(e.advanceBy(o[0].length),{type:"NUMBER",value:o[0]}):null}function Pl(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 Ml=/\p{L}|\p{N}|_|\.|!|\$/u,Nl=new Set("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789_.!$");function kl(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&&(Nl.has(e.current)||e.current.match(Ml));)t+=e.shift();if(t.length){const e=t;return Ia.test(e)?{type:"REFERENCE",value:e}:{type:"SYMBOL",value:e}}return null}function Ll(e){let t="";for(;" "===e.current||e.current&&e.current.match(Zt);)t+=e.shift();return t?{type:"SPACE",value:t}:null}function Vl(e){let t="";for(;" "===e.current;)t+=e.shift();return t?{type:"SPACE",value:t}:null}function Ul(e){let t=0;for(;e.current===ot;)t++,e.shift();return t?{type:"SPACE",value:ot.repeat(t)}:null}function Hl(e){return e.currentStartsWith(sn.InvalidReference)?(e.advanceBy(sn.InvalidReference.length),{type:"INVALID_REFERENCE",value:sn.InvalidReference}):null}function zl(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{Rr(1,{locale:e,format:"#,##0.00"}),Rr(1,{locale:e,format:e.dateFormat}),Rr(1,{locale:e,format:e.timeFormat})}catch{return!1}return!0}function Bl(e,t){return uo(e)?ql(e,t):Yl(e,t)}function $l(e,t){return uo(e)?ql(e,t):function(e,t){if(ki(e,t)){const o=Sn(e,t);let s=w.dateFormat;return Number.isInteger(o)||(s+=" "+w.timeFormat),Rr(o,{locale:w,format:s})}return Yl(e,t)}(e,t)}function Gl(e,t){return e.startsWith("=")?Zl(e,t):function(e,t){if(ki(e,w)){const o=Sn(e,w);let s=t.dateFormat;return Number.isInteger(o)||(s+=" "+t.timeFormat),Rr(o,{locale:t,format:s})}return function(e,t){if("."===t.decimalSeparator||!Qi(e,w))return e;const o=kr(w);return e.replace(o,(e=>e.replace(".",t.decimalSeparator)))}(e,t)}(e,t)}function Wl(e,t){return uo(e)?ql(e,t):Yl(e,t)}function ql(e,t){return jl(e.startsWith("+")?"="+e.slice(1):e,t,w)}function Zl(e,t){return jl(e,w,t)}function jl(e,t,o){if(t.formulaArgSeparator===o.formulaArgSeparator&&t.decimalSeparator===o.decimalSeparator)return e;const s=El(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 Yl(e,t){return"."!==t.decimalSeparator&&Qi(e,t)?(t.thousandsSeparator&&(e=e.replaceAll(t.thousandsSeparator,"")),e.replace(t.decimalSeparator,".")):e}function Xl(e,t){return Ql(e,(e=>$l(e,t)))}function Kl(e,t){return Ql(e,(e=>Gl(e,t)))}function Jl(e,t){const o=pt(e);return o.criterion.values=o.criterion.values.map((e=>Gl(e,t))),o}function Ql(e,t){switch((e=pt(e)).type){case"CellIsRule":switch(e.operator){case"isBetween":case"isNotBetween":case"isEqual":case"isNotEqual":case"isGreaterThan":case"isGreaterOrEqualTo":case"isLessThan":case"isLessOrEqualTo":case"customFormula":return e.values=e.values.map((e=>t(e))),e;case"beginsWithText":case"containsText":case"endsWithText":case"notContainsText":case"isEmpty":case"isNotEmpty":return e}case"DataBarRule":return e;case"ColorScaleRule":return e.minimum=ec(e.minimum,t),e.maximum=ec(e.maximum,t),e.midpoint&&(e.midpoint=ec(e.midpoint,t)),e;case"IconSetRule":return e.lowerInflectionPoint.value=t(e.lowerInflectionPoint.value),e.upperInflectionPoint.value=t(e.upperInflectionPoint.value),e}}function ec(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 tc(e){return e.dateFormat+" "+e.timeFormat}function oc(e){let t=!1,o=!0;return Bn(e,(e=>(t=!0,o=o&&e,o))),{foundBoolean:t,result:o}}function sc(e){let t=!1,o=!1;return Bn(e,(e=>(t=!0,o=o||e,!o))),{foundBoolean:t,result:o}}function ic(e,t){return kn(e,((e,t)=>e+t),0,t)}function nc(e){return Nn(e,((e,t)=>Qn(t)?e.add(t?.value):e),new Set).size}function rc(e,t){if(!e)throw new rn(t)}function ac(e,t=ui("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.")){if(0===e)throw new gn(t)}function lc(e){return 1===e.length||1===e[0].length}function cc(...e){if(e.every(E)){const t=e[0].length,o=e[0][0].length;for(const s of e)if(s.length!==t||s[0].length!==o)return!1;return!0}return!e.some((e=>Array.isArray(e)&&(1!==e.length||1!==e[0].length)))}function hc(e){return e.length===e[0].length}const dc=e=>ui("The function [[FUNCTION_NAME]] expects a number value to be greater than or equal to 1, but receives %s.",e);function uc(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 gc(e){if(e.length<1||e[0].length<1)throw new Error("invertMatrix: an empty matrix cannot be inverted.");if(e.length!==e[0].length)throw new Error("invertMatrix: only square matrices are invertible");let t=1;const o=e.length,s=uc(o),i=e.map((e=>e.slice()));for(let e=0;e<o;e++){let n=i[e][e];if(0===n){for(let n=e+1;n<o;n++)if(0!==i[e][n]){pc(i,e,n),pc(s,e,n),t*=-1;break}if(n=i[e][e],0===n)return{determinant:0}}for(let t=0;t<o;t++)i[t][e]=i[t][e]/n,s[t][e]=s[t][e]/n;t*=n;for(let t=0;t<o;t++){if(t===e)continue;const n=i[e][t];for(let r=0;r<o;r++)i[r][t]-=n*i[r][e],s[r][t]-=n*s[r][e]}}return{inverted:s,determinant:t}}function pc(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 mc(e,t){if(e.length<1||t.length<1)throw new Error("multiplyMatrices: empty matrices cannot be multiplied.");if(e.length!==t[0].length)throw new Error("multiplyMatrices: incompatible matrices size.");const o=e[0].length,s=t.length,i=e.length,n=Array(s);for(let r=0;r<s;r++){n[r]=Array(o);for(let s=0;s<o;s++){let o=0;for(let n=0;n<i;n++)o+=e[n][s]*t[r][n];n[r][s]=o}}return n}function fc(e){if(!E(e))return e;if(!vc(e))throw new Error("The value should be a scalar or a 1x1 matrix");return e[0][0]}function vc(e){return 1===e.length&&1===e[0].length}function bc(e){return E(e)&&!vc(e)}function Sc(...e){const t=e[0].length;e.forEach(((e,o)=>rc(e.length===t,ui("[[FUNCTION_NAME]] has mismatched dimensions for argument %s (%s vs %s).",o.toString(),t.toString(),e.length.toString()))))}function Cc(e,t){let o=0;const s=kn(e,((e,t)=>(o+=1,e+t)),0,t);return ac(o),s/o}function yc(e,t){let o=0;for(const s of e)if(E(s))for(const e of s)for(const t of e)"number"==typeof t.value&&(o+=1);else{const e=s?.value;fn(e)||"string"==typeof e&&!Qi(e,t)&&!Vi(e,t)||(o+=1)}return o}function Ic(e){return Nn(e,((e,t)=>void 0!==t&&null!==t.value?e+1:e),0)}function wc(e,t){let o={value:-1/0};return Pn(e,(e=>{e.value>=o.value&&(o=e)}),t),o.value===-1/0?{value:0}:o}function xc(e,t){let o={value:1/0};return Pn(e,(e=>{e.value<=o.value&&(o=e)}),t),o.value===1/0?{value:0}:o}function Ec(e,t,o){const s=e[0].length?e:[Ct(1,t.flat().length+1)],i=s.length;let n=o[0].length?o:s;return n=n.length===i?Hn(n):n,{_X:s,_newX:n}}function Rc(e,t,o=!0,s=!1){const i=t.flat(),n=i.length;let{_X:r}=Ec(e,t,[[]]);r=r.length===n?Hn(r):r.slice(),Sc(r[0],i);const a=r.length,l=n-a-(o?1:0),c=[i],h=Hn(r.reverse()),d=[];for(let e=0;e<a;e++)if(d.push(0),o){for(const t of r[e])d[e]+=t;d[e]/=n}let u=0;if(o){for(const e of i)u+=e;u/=n}const g=h.map((e=>e.map(((e,t)=>e-d[t]))));o&&h.forEach((e=>e.push(1)));const p=Ac(h,c);if(o||p.push([0]),!s)return p;const m=mc(g,Hn(g)),{inverted:f}=gc(m);if(void 0===f)throw new rn(ui("Matrix is not invertible"));let v=0,b=0;for(let e=0;e<n;e++){const t=i[e]-u;let o=0;for(let t=0;t<a;t++){o+=g[e][t]*p[t][0]}const s=t-o;v+=s*s,b+=o*o}const S=Math.sqrt(v/l),C=b/(b+v),y=b/a/(v/l),I=[];for(let e=0;e<a;e++)I.push(S*Math.sqrt(f[e][e]));if(o){const e=mc(f,[d]),t=mc(Hn([d]),e);I.push(S*Math.sqrt(t[0][0]+1/i.length))}const w=[[p[0][0],I[0],C,y,b],[p[1][0],I[1],S,l,v]];for(let e=2;e<a;e++)w.push([p[e][0],I[e],"","",""]);return o?w.push([p[a][0],I[a],"","",""]):w.push([0,"","","",""]),w}function Tc(e,t,o,s){Sc(t,e),rc(o>=1,ui("Function [[FUNCTION_NAME]] A regression of order less than 1 cannot be possible."));const i=[e],n=t.map((e=>Ct(0,o).map((t=>Math.pow(e,o-t)))));s&&n.forEach((e=>e.push(1)));const r=Ac(n,i);return s||r.push([0]),r}function Ac(e,t){const o=mc(e,Hn(e)),{inverted:s}=gc(o);if(void 0===s)throw new rn(ui("Matrix is not invertible"));const i=mc(e,t);return Hn(mc(s,i))}function Dc(e,t,o){return e.reduce(((e,s,i)=>e+s*Math.pow(t,o-i)),0)}function _c(e){return e.map((e=>e.map((e=>Math.exp(e)))))}function Fc(e){return e.map((e=>e.map((e=>Math.log(e)))))}function Oc(e,t,o,s){const{_X:i,_newX:n}=Ec(t,e,o),r=Rc(i,e,s,!1),a=r.length-1,l=n.map((e=>{let t=0;for(let o=0;o<a;o++)t+=r[o][0]*e[a-o-1];return t+=r[a][0],[t]}));return l.length===o.length?l:Hn(l)}const Pc=new n;function Mc(e){return Pc.get(e)}const Nc={normalizeFunctionValue:e=>Sn(e,w),toValueAndFormat:(e,t)=>({value:Sn(e,w),format:"dd mmm yyyy"}),toFunctionValue(e){const t=Dn(e,w);return`DATE(${t.getFullYear()},${t.getMonth()+1},${t.getDate()})`}},kc={normalizeFunctionValue(e){const t=Sn(e,w);if(t<1||t>31)throw new rn(ui("%s is not a valid day of month (it should be a number between 1 and 31)",t));return t},toValueAndFormat:e=>({value:Sn(e,w),format:"0"}),toFunctionValue:e=>`${e}`},Lc={normalizeFunctionValue(e){const t=Sn(e,w);if(t<1||t>7)throw new rn(ui("%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||w).weekStart)%7;return{value:xr[o].toString(),format:"@"}},toFunctionValue:e=>`${e}`},Vc={normalizeFunctionValue(e){const t=Sn(e,w);if(t<0||t>53)throw new rn(ui("%s is not a valid week (it should be a number between 0 and 53)",t));return t},toValueAndFormat:e=>({value:Sn(e,w),format:"0"}),toFunctionValue:e=>`${e}`},Uc={normalizeFunctionValue(e){const t=Sn(e,w);if(t<1||t>12)throw new rn(ui("%s is not a valid month (it should be a number between 1 and 12)",t));return t},toValueAndFormat:e=>({value:wr[Sn(e,w)-1].toString(),format:"@"}),toFunctionValue:e=>`${e}`},Hc={normalizeFunctionValue:e=>Rr(Sn(e,w),{locale:w,format:"mm/yyyy"}),toValueAndFormat:e=>({value:Sn(e,w),format:"mmmm yyyy"}),toFunctionValue(e){const t=Dn(e,w);return`DATE(${t.getFullYear()},${t.getMonth()+1},1)`}},zc={normalizeFunctionValue(e){const t=Sn(e,w);if(t<1||t>4)throw new rn(ui("%s is not a valid quarter (it should be a number between 1 and 4)",t));return t},toValueAndFormat:e=>({value:ui("Q%(quarter_number)s",{quarter_number:e}),format:"@"}),toFunctionValue:e=>`${e}`},Bc={normalizeFunctionValue(e){const t=Sn(e,w);return t>3e3?Dn(t,w).getFullYear():t},toValueAndFormat:e=>({value:Sn(e,w),format:"0"}),toFunctionValue:e=>`${e}`},$c={normalizeFunctionValue(e){const t=Sn(e,w);if(t<0||t>23)throw new rn(ui("%s is not a valid hour (it should be a number between 0 and 23)",t));return t},toValueAndFormat:e=>({value:ui("%(hour_number)sh",{hour_number:e}),format:"@"}),toFunctionValue:e=>`${e}`},Gc={normalizeFunctionValue(e){const t=Sn(e,w);if(t<0||t>59)throw new rn(ui("%s is not a valid minute (it should be a number between 0 and 59)",t));return t},toValueAndFormat:e=>({value:ui("%(minute_number)s'",{minute_number:e}),format:"@"}),toFunctionValue:e=>`${e}`},Wc={normalizeFunctionValue(e){const t=Sn(e,w);if(t<0||t>59)throw new rn(ui("%s is not a valid second (it should be a number between 0 and 59)",t));return t},toValueAndFormat:e=>({value:ui("%(second_number)s''",{second_number:e}),format:"@"}),toFunctionValue:e=>`${e}`};function qc(e){return{normalizeFunctionValue:t=>null===t?null:e.normalizeFunctionValue(t),toValueAndFormat:(t,o)=>null===t?{value:ui("(Undefined)")}:e.toValueAndFormat(t,o),toFunctionValue:t=>null===t?"false":e.toFunctionValue(t)}}Pc.add("day",qc(Nc)).add("year",qc(Bc)).add("day_of_month",qc(kc)).add("iso_week_number",qc(Vc)).add("month_number",qc(Uc)).add("month",qc(Hc)).add("quarter_number",qc(zc)).add("day_of_week",qc(Lc)).add("hour_number",qc($c)).add("minute_number",qc(Gc)).add("second_number",qc(Wc));const Zc={count:ui("Count"),count_distinct:ui("Count Distinct"),bool_and:ui("Boolean And"),bool_or:ui("Boolean Or"),max:ui("Maximum"),min:ui("Minimum"),avg:ui("Average"),sum:ui("Sum")},jc=["max","min","avg","sum","count_distinct","count"],Yc={integer:jc,char:jc,datetime:jc,boolean:["count_distinct","count","bool_and","bool_or"]},Xc={};for(const e in Yc){Xc[e]={};for(const t of Yc[e])Xc[e][t]=Zc[t]}const Kc={count:e=>({value:Ic([e]),format:"0"}),count_distinct:e=>({value:nc([e]),format:"0"}),bool_and:e=>({value:oc([e]).result}),bool_or:e=>({value:sc([e]).result}),max:(e,t)=>wc([e],t),min:(e,t)=>xc([e],t),avg:(e,t)=>({value:Cc([e],t),format:mn(e)}),sum:(e,t)=>({value:ic([e],t),format:mn(e)})};function Jc(e){const t=Object.keys(e);if(!t.length)return 0;const o=t.map((e=>parseInt(e,10)));return Math.max(...o)}const Qc={year:ui("Year"),quarter:ui("Quarter & Year"),month:ui("Month & Year"),week:ui("Week & Year"),day:ui("Day"),quarter_number:ui("Quarter"),month_number:ui("Month"),iso_week_number:ui("Week"),day_of_month:ui("Day of Month"),day_of_week:ui("Day of Week"),hour_number:ui("Hour"),minute_number:ui("Minute"),second_number:ui("Second")},eh=["date","datetime"];function th(e){const[t,o]=e.split(":");return o?{fieldName:t,granularity:o}:{fieldName:t}}function oh(e){return eh.includes(e.type)}function sh(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}=th(e),n=lh(o,{type:i,granularity:t});s.push(`"${e}"`,n)}return s}function ih(e,t){let o=0,s=0;const i=t.columns.map((e=>e.nameWithGranularity)),n=t.rows.map((e=>e.nameWithGranularity));for(;void 0!==e[o]&&e[o]===n[s];)o++,s++;for(s=0;void 0!==e[o]&&e[o]===i[s];)o++,s++;return e.length===o}function nh(e,t){switch(t.type){case"HEADER":return`=PIVOT.HEADER(${sh(e,t.domain).join(",")})`;case"VALUE":return`=PIVOT.VALUE(${sh(e,t.domain,t.measure).join(",")})`;case"MEASURE_HEADER":return`=PIVOT.HEADER(${sh(e,[...t.domain,{field:"measure",value:t.measure,type:"char"}]).join(",")})`}return""}function rh(e,t){if(null===t||"null"===t)return null;const o="object"==typeof t?t.value:t;if(fn(o))return o;if("custom"===e.type)return _n(t)??null;const s="boolean"==typeof t?En(t).toLocaleLowerCase():En(t);if("null"===s)return null;if(!hh.contains(e.type))throw new rn(ui("Field %(field)s is not supported because of its type (%(type)s)",{field:e.displayName,type:e.type}));if("false"===s.toLowerCase())return!1;return hh.get(e.type)(s,e.granularity)}function ah(e,t){return Mc(t??"month").normalizeFunctionValue(e)}function lh(e,t){return null===e?'"null"':dh.contains(t.type)?dh.get(t.type)(e,t.granularity):`"${e}"`}function ch(e,t){return Mc(t??"month").toFunctionValue(e)}const hh=new n;hh.add("date",ah).add("datetime",ah).add("integer",(e=>Sn(e,w))).add("boolean",(e=>An(e))).add("char",(e=>En(e))).add("custom",(e=>e));const dh=new n;function uh(e){return e.displayName+(e.granularity?` (${Qc[e.granularity]})`:"")}function gh(e,t){try{if(!t.getMeasure(e.measure))return!1;const o=t.definition.columns;for(let s=0;s<e.domain.length;s++){if(o[s].nameWithGranularity!==e.domain[s].field)return!1;const i=t.getPossibleFieldValues(o[s]).map((e=>e.value));if(!(i.includes(e.domain[s].value)||null===e.domain[s].value&&i.includes("")))return!1}return!0}catch(e){return!1}}function ph(e,t){return ho(e,t.groups.map((e=>e.name)),{compute:(e,t)=>`${e}${t}`,start:2})}function mh(e,t){return ho(e,Object.values(t).map((e=>[e?.name,e?.string])).flat().filter(Mt),{compute:(e,t)=>`${e}${t}`,start:2})}function fh(e,t){const o={};for(const s of Object.values(e.customFields||{})){t[s.parentField]&&(o[s.name]={type:"custom",isCustomField:!0,name:s.name,string:s.name,customGroups:s.groups,parentField:s.parentField})}return o}function vh(e,t){t.groups=t.groups.filter((t=>!t.values.some((t=>e.includes(t)))))}function bh(e,t,o){const s=e.rows.some((e=>e.fieldName===t))?e.rows:e.columns,i=s.findIndex((e=>e.fieldName===t));return-1===i||s.some((e=>e.fieldName===o))||s.splice(i,0,{fieldName:o}),e}function Sh(e,t,o){return Object.values(e.customFields||{}).find((e=>e.parentField===t.name))||{parentField:t.name,name:mh(t.string,o),groups:[]}}dh.add("date",ch).add("datetime",ch).add("integer",(e=>`${Sn(e,w)}`)).add("boolean",(e=>An(e)?"TRUE":"FALSE")).add("char",(e=>`"${En(e).replace(/"/g,'\\"')}"`)).add("custom",(e=>"string"==typeof e?`"${e}"`:String(e)));class Ch extends yl{isCutAllowed(e){return 1!==e.zones.length?"WrongCutSelection":"Success"}copy(e,t,o="copyPaste"){const s=e.sheetId,{clippedZones:i,rowsIndexes:n,columnsIndexes:r}=e,a=[],l=1===n.length&&1===r.length;for(const t of n){const i=[];for(const a of r){const c={col:a,row:t,sheetId:s};let h=this.getters.getCell(c);const d=this.getters.getEvaluatedCell(c),u=this.getters.getPivotIdFromPosition(c),g=this.getters.getArrayFormulaSpreadingOn(c);if("shiftCells"!==o&&u&&g){const t=this.getters.getSpreadZone(g);if((!zt(g,c)||!l)&&t&&!e.zones.some((e=>ts(t,e)))){const e=this.getters.getPivotCellFromPosition(c),t=nh(this.getters.getPivotFormulaId(u),e);h={id:h?.id||"",style:h?.style,format:h?.format,content:t,isFormula:!1,parsedValue:d.value}}}else if("shiftCells"!==o&&g&&!zt(g,c)){const e=n.includes(g.row)&&r.includes(g.col)?"":Rr(d.value,{locale:this.getters.getLocale()});h={id:h?.id||"",style:h?.style,format:d.format,content:e,isFormula:!1,parsedValue:d.value}}i.push({content:h?.content??"",style:h?.style,format:h?.format,tokens:h?.isFormula?h.compiledFormula.tokens.map((({value:e,type:t})=>({value:e,type:t}))):[],border:this.getters.getCellBorder(c)||void 0,evaluatedCell:d,position:c})}a.push(i)}return{cells:a,zones:i,sheetId:e.sheetId}}isPasteAllowed(e,t,o,s){if(!o.cells)return"Success";if(s?.isCutOperation&&void 0!==s?.pasteOption)return"WrongPasteOption";if(t.length>1&&(o.cells.length>1||o.cells[0].length>1))return"WrongPasteSelection";const i=o.cells.length,n=o.cells[0].length;for(const s of Cs(t,o.cells))if(this.getters.doesIntersectMerge(e,s)&&(t.length>1||!this.getters.isSingleCellOrMerge(e,t[0])||i*n!=1))return"WillRemoveExistingMerge";return"Success"}paste(e,t,o){const s=e.zones,i=e.sheetId;o.isCutOperation?this.pasteFromCut(i,s,t,o):this.pasteFromCopy(i,s,t.cells,o)}getPasteTarget(e,t,o,s){const i=o.cells[0].length,n=o.cells.length;return s?.isCutOperation?{sheetId:e,zones:[{left:t[0].left,top:t[0].top,right:t[0].left+i-1,bottom:t[0].top+n-1}]}:1===i&&1===n?{zones:[],sheetId:e}:{sheetId:e,zones:Cs(t,o.cells)}}pasteFromCut(e,t,o,s){this.clearClippedZones(o);const i=t[0];this.pasteZone(e,i.left,i.top,o.cells,s)}clearClippedZones(e){this.dispatch("CLEAR_CELLS",{sheetId:e.sheetId,target:e.zones}),this.dispatch("CLEAR_FORMATTING",{sheetId:e.sheetId,target:e.zones})}pasteZone(e,t,o,s,i){for(const[n,r]of s.entries())for(const[s,a]of r.entries()){if(!a)continue;const r={col:t+s,row:o+n,sheetId:e};this.pasteCell(a,r,i)}}pasteCell(e,t,o){const{sheetId:s,col:i,row:n}=t,r=this.getters.getEvaluatedCell(t),a=e?.format||e.evaluatedCell.format;if("asValue"===o?.pasteOption)return void this.dispatch("UPDATE_CELL",{...t,content:e.evaluatedCell.value?.toString()||"",format:a});if("onlyFormat"===o?.pasteOption)return void this.dispatch("UPDATE_CELL",{...t,style:e?.style??null,format:a??r.format});let l=e?.content;e?.tokens&&e.tokens.length>0&&!o?.isCutOperation?l=this.getters.getTranslatedCellFormula(s,i-e.position.col,n-e.position.row,e.tokens):e?.tokens&&e.tokens.length>0&&(l=this.getters.getFormulaMovedInSheet(e.position.sheetId,s,e.tokens)),""!==l||e?.format||e?.style?this.dispatch("UPDATE_CELL",{...t,content:l,style:e?.style||null,format:e?.format}):r&&this.dispatch("CLEAR_CELL",t)}convertTextToClipboardData(e){const t=this.getters.getLocale(),o={cells:[]},s=[];let i=0;for(const[t,o]of e.replace(/\r/g,"").split("\n").entries())s.push(o.split("\t")),s[t].length>i&&(i=s[t].length);for(const e of s){const s=[];for(let o=0;o<i;o++){const i=Wl(e[o]||"",t);s.push({content:i,evaluatedCell:{formattedValue:i}})}o.cells.push(s)}return o}}const yh={figureHandlers:new n,cellHandlers:new n};function Ih(e,t){return"REMOVE_COLUMNS_ROWS"===t.type?jo(e,"COL"===t.dimension?"left":"top",t.elements):"ADD_COLUMNS_ROWS"===t.type?Wo(e,"COL"===t.dimension?"left":"top",t.base,t.position,t.quantity):e}function wh(e,t){const o="DELETE_SHEET"===t.type&&t.sheetId;if("sheetId"in t&&e._sheetId!==t.sheetId)return e;{const s=Ih(e._zone,t);if(s&&o!==e._sheetId)return{...e,_zone:s}}}yh.figureHandlers.add("chart",class extends Il{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.getChartFromFigureId(e.figureId);if(!i)throw new Error(`No chart for the given id: ${e.figureId}`);const n=i.copyInSheetId(t);return{figureId:e.figureId,copiedFigure:s,copiedChart:n}}getPasteTarget(e,t,o,s){return{zones:[],figureId:(new Sl).smallUuid(),sheetId:e}}paste(e,t,o){if(!e.figureId)return;const{zones:s,figureId:i}=e,n=e.sheetId,{width:r,height:a}=t.copiedFigure,l=t.copiedChart.copyInSheetId(n),c=this.getters.getMaxAnchorOffset(n,a,r);let{left:h,top:d}=s[0];const u={x:0,y:0};h>c.col&&(h=c.col,u.x=c.offset.x),d>c.row&&(d=c.row,u.y=c.offset.y),this.dispatch("CREATE_CHART",{figureId:i,chartId:(new Sl).smallUuid(),sheetId:n,definition:l.getDefinition(),col:h,row:d,offset:u,size:{height:a,width:r}}),o.isCutOperation&&this.dispatch("DELETE_FIGURE",{sheetId:t.copiedChart.sheetId,figureId:t.copiedFigure.id}),this.dispatch("SELECT_FIGURE",{figureId:i})}isPasteAllowed(e,t,o,s){return 0===t.length?"EmptyTarget":void 0!==s?.pasteOption?"WrongFigurePasteOption":"Success"}}).add("image",class extends Il{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=pt(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 Sl).smallUuid()}}paste(e,t,o){if(!e.figureId)return;const{zones:s,figureId:i}=e,n=this.getters.getActiveSheetId(),{width:r,height:a}=t.copiedFigure,l=pt(t.copiedImage),c=this.getters.getMaxAnchorOffset(n,a,r);let{left:h,top:d}=s[0];const u={x:0,y:0};h>c.col&&(h=c.col,u.x=c.offset.x),d>c.row&&(d=c.row,u.y=c.offset.y),this.dispatch("CREATE_IMAGE",{figureId:i,sheetId:n,col:h,row:d,offset:u,size:{height:a,width:r},definition:l}),o.isCutOperation&&this.dispatch("DELETE_FIGURE",{sheetId:t.sheetId,figureId:t.copiedFigure.id}),this.dispatch("SELECT_FIGURE",{figureId:i})}isPasteAllowed(e,t,o,s){return 0===t.length?"EmptyTarget":void 0!==s?.pasteOption?"WrongFigurePasteOption":"Success"}}).add("carousel",class extends Il{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("carousel"!==o.tag)return;const s={...o},i=this.getters.getCarousel(e.figureId),n={};for(const e of i.items)if("chart"===e.type){const o=this.getters.getChart(e.chartId);if(!o)throw new Error(`No chart for the given id: ${e.chartId}`);n[e.chartId]=o.copyInSheetId(t)}return{figureId:e.figureId,copiedFigure:s,copiedCarousel:i,copiedCharts:n,copiedSheetId:t}}getPasteTarget(e){return{zones:[],figureId:(new Sl).smallUuid(),sheetId:e}}paste(e,t,o){if(!e.figureId)return;const{zones:s,figureId:i}=e,n=e.sheetId,{width:r,height:a}=t.copiedFigure,l=this.getters.getMaxAnchorOffset(n,a,r);let{left:c,top:h}=s[0];const d={x:0,y:0};c>l.col&&(c=l.col,d.x=l.offset.x),h>l.row&&(h=l.row,d.y=l.offset.y),this.dispatch("CREATE_CAROUSEL",{figureId:i,sheetId:n,definition:{items:[]},col:c,row:h,offset:d,size:{height:a,width:r}});const u=new Sl,g=pt(t.copiedCarousel.items);for(const e of g){if("chart"!==e.type)continue;const o=t.copiedCharts[e.chartId],s=u.smallUuid(),r=o.copyInSheetId(n).getDefinition();this.dispatch("CREATE_CHART",{figureId:i,chartId:s,sheetId:n,definition:r}),e.chartId=s}this.dispatch("UPDATE_CAROUSEL",{sheetId:n,figureId:i,definition:{...t.copiedCarousel,items:g}}),o.isCutOperation&&this.dispatch("DELETE_FIGURE",{sheetId:t.copiedSheetId,figureId:t.copiedFigure.id}),this.dispatch("SELECT_FIGURE",{figureId:i})}isPasteAllowed(e,t,o,s){return 0===t.length?"EmptyTarget":void 0!==s?.pasteOption?"WrongFigurePasteOption":"Success"}}),yh.cellHandlers.add("dataValidation",class extends yl{uuidGenerator=new Sl;queuedChanges={};copy(e){const{rowsIndexes:t,columnsIndexes:o}=e,s=e.sheetId,i=[];for(const e of t){const t=[];for(const i of o){const o={sheetId:s,col:i,row:e},n=this.getters.getValidationRuleForCell(o);t.push({position:o,rule:n})}i.push(t)}return{dvRules:i}}paste(e,t,o){if(this.queuedChanges={},o.pasteOption)return;const s=e.zones,i=e.sheetId;o.isCutOperation?this.pasteFromCut(i,s,t):this.pasteFromCopy(i,s,t.dvRules),this.executeQueuedChanges()}pasteFromCut(e,t,o){const s=t[0];this.pasteZone(e,s.left,s.top,o.dvRules,{isCutOperation:!0})}pasteZone(e,t,o,s,i){for(const[n,r]of s.entries())for(const[s,a]of r.entries()){const r={col:t+s,row:o+n,sheetId:e};this.pasteDataValidation(a,r,i?.isCutOperation)}}pasteDataValidation(e,t,o){if(e){const s=cs(t),i=cs(e.position),n=e.rule;if(!n){const e=this.getters.getValidationRuleForCell(t);return void(e&&this.adaptDataValidationRule(t.sheetId,e,[],[s]))}const r=[];if(o&&r.push(i),e.position.sheetId===t.sheetId){const o=this.getDataValidationRuleToCopyTo(t.sheetId,n,!1);this.adaptDataValidationRule(e.position.sheetId,o,[s],r)}else{const o=this.getters.getValidationRuleForCell(e.position);o&&this.adaptDataValidationRule(e.position.sheetId,o,[],r);const i=this.getDataValidationRuleToCopyTo(t.sheetId,n);this.adaptDataValidationRule(t.sheetId,i,[s],[])}}}getDataValidationRuleToCopyTo(e,t,o=!0){let s=this.getters.getDataValidationRules(e).find((e=>zt(t.criterion,e.criterion)&&t.isBlocking===e.isBlocking));const i=this.queuedChanges[e];return!s&&i&&(s=i.find((e=>zt(t.criterion,e.rule.criterion)&&t.isBlocking===e.rule.isBlocking))?.rule),s||{...t,id:o?this.uuidGenerator.smallUuid():t.id,ranges:[]}}adaptDataValidationRule(e,t,o,s){this.queuedChanges[e]||(this.queuedChanges[e]=[]);const i=this.queuedChanges[e].find((e=>e.rule.id===t.id));i?(i.toAdd.push(...o),i.toRemove.push(...s)):this.queuedChanges[e].push({toAdd:o,toRemove:s,rule:t})}executeQueuedChanges(){for(const e in this.queuedChanges)for(const{toAdd:t,toRemove:o,rule:s}of this.queuedChanges[e]){const i=s.ranges.map((e=>e.zone)),n=Fo(i,o),r=Fo([...n,...t],[]);0!==r.length?this.dispatch("ADD_DATA_VALIDATION_RULE",{rule:{id:s.id,criterion:s.criterion,isBlocking:s.isBlocking},ranges:r.map((t=>this.getters.getRangeDataFromZone(e,t))),sheetId:e}):this.dispatch("REMOVE_DATA_VALIDATION_RULE",{sheetId:e,id:s.id})}}}).add("cell",Ch).add("sheet",class extends yl{isPasteAllowed(e,t,o,s){if(!("cells"in o))return"Success";const{xSplit:i,ySplit:n}=this.getters.getPaneDivisions(e);return ps(Cs(t,o.cells),i,n)?"FrozenPaneOverlap":"Success"}}).add("merge",class extends yl{copy(e){const t=this.getters.getActiveSheetId(),{rowsIndexes:o,columnsIndexes:s}=e,i=[];for(const e of o){const o=[];for(const i of s){const s={col:i,row:e,sheetId:t};o.push(this.getters.getMerge(s))}i.push(o)}return{merges:i,sheetId:t}}paste(e,t,o){if(o.isCutOperation){const e=t.merges.flat().filter(Mt);this.dispatch("REMOVE_MERGE",{sheetId:t.sheetId,target:e})}this.pasteFromCopy(e.sheetId,e.zones,t.merges,o)}pasteZone(e,t,o,s){for(const[i,n]of s.entries())for(const[s,r]of n.entries()){const n={col:t+s,row:o+i,sheetId:e};this.pasteMerge(r,n)}}pasteMerge(e,t){if(!e)return;if(this.getters.isInMerge(t))return;const{sheetId:o,col:s,row:i}=t;this.dispatch("ADD_MERGE",{sheetId:o,force:!0,target:[{left:s,top:i,right:s+e.right-e.left,bottom:i+e.bottom-e.top}]})}}).add("table",class extends yl{copy(e,t,o="copyPaste"){const s=e.sheetId,{rowsIndexes:i,columnsIndexes:n,zones:r}=e,a=new Set,l=[];for(const e of i){const c=[];l.push(c);for(const l of n){const n={col:l,row:e,sheetId:s},h=this.getters.getTable(n);if(!h){c.push({});continue}const d=this.getters.getCoreTable(n),u=d?.range.zone;let g;if(!a.has(h.id)&&d&&u&&r.some((e=>ts(u,e)))){a.add(h.id);let{numberOfRows:e}=os(u);for(let o=u.top;o<=u.bottom;o++)t||i.includes(o)||e--;const o=d.range,s=this.getters.extendRange(d.range,"ROW",o.zone.top+e-1-o.zone.bottom);g={range:this.getters.getRangeData(s),config:d.config,type:d.type}}"shiftCells"!==o&&c.push({table:g,style:this.getTableStyleToCopy(n),isWholeTableCopied:a.has(h.id)})}}return{tableCells:l,sheetId:e.sheetId}}getTableStyleToCopy(e){const t=this.getters.getCellTableStyle(e),o=this.getters.getCellStyle(e),s=this.getters.getCellTableBorder(e),i=this.getters.getCellBorder(e);return{style:{...t,...Wt(o)},border:{...s,...Wt(i)}}}paste(e,t,o){const s=e.zones,i=e.sheetId;o.isCutOperation?this.pasteFromCut(i,s,t,o):this.pasteFromCopy(i,s,t.tableCells,o)}pasteFromCut(e,t,o,s){for(const e of o.tableCells)for(const t of e)t.table&&this.dispatch("REMOVE_TABLE",{sheetId:o.sheetId,target:[this.getters.getRangeFromRangeData(t.table.range).zone]});const i=t[0];this.pasteZone(e,i.left,i.top,o.tableCells,s)}pasteZone(e,t,o,s,i){for(let n=0;n<s.length;n++){const r=s[n];for(let s=0;s<r.length;s++){const a=r[s];if(!a)continue;const l={col:t+s,row:o+n,sheetId:e};this.pasteTableCell(e,a,l,i)}}if(1===s.length)for(let i=0;i<s[0].length;i++)this.dispatch("AUTOFILL_TABLE_COLUMN",{col:t+i,row:o,sheetId:e})}pasteTableCell(e,t,o,s){if(t.table&&!s?.pasteOption){const{range:s}=t.table,i=os(this.getters.getRangeFromRangeData(s).zone),n={left:o.col,top:o.row,right:o.col+i.numberOfCols-1,bottom:o.row+i.numberOfRows-1};this.dispatch("CREATE_TABLE",{sheetId:o.sheetId,ranges:[this.getters.getRangeDataFromZone(e,n)],config:t.table.config,tableType:t.table.type})}this.getters.getCoreTable(o)||"asValue"===s?.pasteOption||(s?.pasteOption||t.isWholeTableCopied)&&"onlyFormat"!==s?.pasteOption||(t.style?.style&&this.dispatch("UPDATE_CELL",{...o,style:t.style.style}),t.style?.border&&this.dispatch("SET_BORDER",{...o,border:t.style.border}))}}).add("conditionalFormat",class extends yl{uuidGenerator=new Sl;queuedChanges={};copy(e){if(!e.zones.length)return;const{rowsIndexes:t,columnsIndexes:o}=e,s=e.sheetId,i=[];for(const e of t){const t=[];for(const i of o){const o=Array.from(this.getters.getRulesByCell(s,i,e));t.push({position:{col:i,row:e,sheetId:s},rules:o})}i.push(t)}return{cfRules:i}}paste(e,t,o){if(this.queuedChanges={},"asValue"===o.pasteOption)return;const s=e.zones,i=e.sheetId;o.isCutOperation?this.pasteFromCut(i,s,t):this.pasteFromCopy(i,s,t.cfRules,o),this.executeQueuedChanges()}pasteFromCut(e,t,o){const s=t[0];this.pasteZone(e,s.left,s.top,o.cfRules,{isCutOperation:!0})}pasteZone(e,t,o,s,i){for(const[n,r]of s.entries())for(const[s,a]of r.entries()){const r={col:t+s,row:o+n,sheetId:e};this.pasteCf(a,r,i?.isCutOperation)}}pasteCf(e,t,o){if(e?.rules&&e.rules.length>0){const s=cs(e.position),i=cs(t);for(const n of e.rules){const r=[];if(o&&r.push(s),e.position.sheetId===t.sheetId)this.adaptCFRules(e.position.sheetId,n,[i],r);else{this.adaptCFRules(e.position.sheetId,n,[],r);const o=this.getCFToCopyTo(t.sheetId,n);this.adaptCFRules(t.sheetId,o,[i],[])}}}}adaptCFRules(e,t,o,s){this.queuedChanges[e]||(this.queuedChanges[e]=[]);const i=this.queuedChanges[e].find((e=>e.cf.id===t.id));i?(i.toAdd.push(...o),i.toRemove.push(...s)):this.queuedChanges[e].push({toAdd:o,toRemove:s,cf:t})}executeQueuedChanges(){for(const e in this.queuedChanges)for(const{toAdd:t,toRemove:o,cf:s}of this.queuedChanges[e]){const i=this.getters.getAdaptedCfRanges(e,s,t,o);i&&(0!==i.length?this.dispatch("ADD_CONDITIONAL_FORMAT",{cf:{id:s.id,rule:s.rule,stopIfTrue:s.stopIfTrue},ranges:i,sheetId:e}):this.dispatch("REMOVE_CONDITIONAL_FORMAT",{id:s.id,sheetId:e}))}}getCFToCopyTo(e,t){let o=this.getters.getConditionalFormats(e).find((e=>e.stopIfTrue===t.stopIfTrue&&zt(e.rule,t.rule)));const s=this.queuedChanges[e];return!o&&s&&(o=s.find((e=>e.cf.stopIfTrue===t.stopIfTrue&&zt(e.cf.rule,t.rule)))?.cf),o||{...t,id:this.uuidGenerator.smallUuid(),ranges:[]}}}).add("references",class extends yl{copy(e){return{zones:e.clippedZones,sheetId:e.sheetId}}paste(e,t,o){if(o.isCutOperation){const o=e.zones[0];this.dispatch("MOVE_RANGES",{target:t.zones,sheetId:t.sheetId,sheetName:this.getters.getSheetName(t.sheetId),targetSheetId:e.sheetId,col:o.left,row:o.top})}}}).add("border",class extends yl{copy(e){const t=e.sheetId;if(0===e.zones.length)return;const o=[];let s=0;for(const i of yt(e.columnsIndexes)){let n=0;for(const r of yt(e.rowsIndexes)){const e={left:i[0],right:i[i.length-1],top:r[0],bottom:r[r.length-1]};o.push(...this.getters.getBorders(t,e).map((({zone:t,style:o})=>({zone:{left:t.left-e.left+s,right:t.right&&t.right-e.left+s,top:t.top-e.top+n,bottom:t.bottom&&t.bottom-e.top+n},style:o})))),n+=r.length}s+=i.length}return{borders:o,width:e.columnsIndexes.length,height:e.rowsIndexes.length}}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.pasteBorderZone(s,e,o,t.borders)}else for(const e of i)for(const o of Ss(e,t.width,t.height))this.pasteBorderZone(s,o.left,o.top,t.borders)}pasteBorderZone(e,t,o,s){for(const i of s){const s={left:i.zone.left+t,right:i.zone.right&&i.zone.right+t||i.zone.left+t,top:i.zone.top+o,bottom:i.zone.bottom&&i.zone.bottom+o||i.zone.top+o};for(const[t,o]of this.getOptimalBorderCommands(i.style))o&&this.dispatch("SET_ZONE_BORDERS",{sheetId:e,target:[s],border:{position:t,...o}})}}getOptimalBorderCommands(e){const t=zt(e.horizontal,e.vertical),o=zt(e.left,e.right,e.top,e.bottom);return t&&o&&zt(e.horizontal,e.left)?[["all",e.top]]:t&&o?[["hv",e.horizontal],["external",e.top]]:o?[["h",e.horizontal],["v",e.vertical],["external",e.top]]:t?[["hv",e.horizontal],["top",e.top],["bottom",e.bottom],["left",e.left],["right",e.right]]:[["h",e.horizontal],["v",e.vertical],["top",e.top],["bottom",e.bottom],["left",e.left],["right",e.right]]}});class xh{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 Eh extends xh{dependencies=new Map;factory=new Rh(this.get.bind(this));inject(e,t){if(this.dependencies.has(e)&&this.dependencies.get(e)!==t)throw new Error(`Store ${e.name} already has an instance`);this.dependencies.set(e,t)}get(e){return this.dependencies.has(e)||this.dependencies.set(e,this.instantiate(e)),this.dependencies.get(e)}instantiate(e,...t){return this.factory.build(e,...t)}resetStores(){this.dependencies.clear()}dispose(){for(const e of this.dependencies.values())"dispose"in e&&"function"==typeof e.dispose&&e.dispose()}}class Rh{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 Th{get;disposeCallbacks=[];constructor(e){this.get=e}onDispose(e){this.disposeCallbacks.push(e)}dispose(){this.disposeCallbacks.forEach((e=>e()))}}function Ah(){const e=t.useEnv();if(e.__spreadsheet_stores__ instanceof Eh)return e.__spreadsheet_stores__;const o=new Eh;return t.useSubEnv({__spreadsheet_stores__:o,getStore:e=>Oh(o.get(e),(()=>o.trigger("store-updated")))}),t.onWillUnmount((()=>o.dispose())),o}function Dh(e){const o=Ph(t.useEnv()),s=o.get(e);return Fh(o,s)}function _h(e,...o){const s=Ph(t.useEnv()),i=s.instantiate(e,...o);return t.onWillUnmount((()=>i.dispose())),Fh(s,i)}function Fh(e,o){const s=t.useComponent();return Oh(o,(()=>{"mounted"===t.status(s)&&e.trigger("store-updated")}))}function Oh(e,t){return new Proxy(e,{get(o,s,i){const n=o,r=Reflect.get(o,s,n);if(e.mutators?.includes(s)){const e=new Proxy(r,{apply(e,o,s){"noStateChange"!==Reflect.apply(e,n,s)&&t()}});return e}return r}})}function Ph(e){const t=e.__spreadsheet_stores__;if(!(t instanceof Eh))throw new Error("No store provider found. Did you forget to call useStoreProvider()?");return t}const Mh=(Nh="Model",class{constructor(e){throw new Error(`This is a abstract store for ${Nh}, it cannot be instantiated.\nDid you forget to inject your store instance?\n\nconst stores = useStoreProvider();\nstores.inject(MyMetaStore, storeInstance);\n`)}});var Nh;class kh{mutators=["register","unRegister","draw","startAnimation","stopAnimation"];renderers={};model;context=void 0;animationFrameId=null;registeredAnimations=new Set;constructor(e){this.model=e(Mh)}register(e){if(e.renderingLayers.length)for(const t of e.renderingLayers)this.renderers[t]||(this.renderers[t]=[]),this.renderers[t].push(e)}unRegister(e){for(const t of Object.keys(this.renderers))this.renderers[t]=this.renderers[t].filter((t=>t!==e))}drawLayer(e,t,o){const s=this.renderers[t];if(s)for(const i of s)e.ctx.save(),i.drawLayer(e,t,o),e.ctx.restore();return"noStateChange"}draw(e,t){if(!(e=e||this.context))throw new Error("Rendering context is not defined");this.context=e;for(const o of po())this.model.drawLayer(e,o),this.drawLayer(e,o,t);return"noStateChange"}startAnimation(e){if(this.registeredAnimations.add(e),!this.animationFrameId){const e=t=>{this.animationFrameId=requestAnimationFrame(e),this.draw(void 0,t)};this.animationFrameId=requestAnimationFrame(e)}return"noStateChange"}stopAnimation(e){return this.registeredAnimations.delete(e),0===this.registeredAnimations.size&&null!==this.animationFrameId&&(cancelAnimationFrame(this.animationFrameId),this.animationFrameId=null),"noStateChange"}dispose(){this.animationFrameId&&(cancelAnimationFrame(this.animationFrameId),this.animationFrameId=null)}}class Lh extends Th{model=this.get(Mh);getters=this.model.getters;renderer=this.get(kh);constructor(e){super(e),this.model.on("command-dispatched",this,this.handle),this.model.on("command-finalized",this,this.finalize),this.renderer.register(this),this.onDispose((()=>{this.model.off("command-dispatched",this),this.model.off("command-finalized",this),this.renderer.unRegister(this)}))}get renderingLayers(){return[]}handle(e){}finalize(){}drawLayer(e,t,o){}}const Vh={id:"void-composer",get editionMode(){return"inactive"},startEdition:()=>{throw new Error("No composer is registered")},stopEdition:()=>{throw new Error("No composer is registered")},setCurrentContent:()=>{throw new Error("No composer is registered")}};class Uh extends Lh{mutators=["focusComposer","focusActiveComposer"];activeComposer=Vh;_focusMode="inactive";get focusMode(){return"inactive"===this.activeComposer.editionMode?"inactive":this._focusMode}focusComposer(e,t){if(this.activeComposer=e,this.getters.isReadonly())return"noStateChange";this._focusMode=t.focusMode||"contentFocus","inactive"!==this._focusMode&&this.setComposerContent(t)}focusActiveComposer(e){if(this.getters.isReadonly())return"noStateChange";if(!this.activeComposer)throw new Error("No composer is registered");this._focusMode=e.focusMode||"contentFocus","inactive"!==this._focusMode&&this.setComposerContent(e)}setComposerContent({content:e,selection:t}){"inactive"===this.activeComposer.editionMode?this.activeComposer.startEdition(e,t):e&&this.activeComposer.setCurrentContent(e,t)}}const Hh={};let zh=0;function Bh(e,...t){const o="__sheet__"+zh++;return function(e,t){const o=document.createElement("style");o.textContent=function(e){const t=e.split(/(\{|\}|;)/).map((e=>e.trim())),o=[],s=[];let i=[];function n(e,t){const s=[];for(const i of o[e]){let r=t&&t+" "+i||i;r.includes("&")&&(r=i.replace(/&/g,t||"")),e<o.length-1&&(r=n(e+1,r)),s.push(r)}return s.join(", ")}function r(){i.length&&(s.push(n(0)+" {"),s.push(...i),s.push("}"),i=[])}for(;t.length;){const e=t.shift();"}"===e?(r(),o.pop()):("{"===t[0]&&(r(),o.push(e.split(/\s*,\s*/)),t.shift()),";"===t[0]&&i.push(" "+e+";"))}return s.join("\n")}(t),Hh[e]=o}(o,String.raw(e,...t)),function(e){const t=Hh[e];t.setAttribute("component",e),document.head.appendChild(t)}(o),o}function $h({strikethrough:e,underline:t}){return e||t?`${e?"line-through":""} ${t?"underline":""}`:"none"}function Gh(e){const t=Wh(e);return e?(e.fillColor&&(t.background=e.fillColor),t):t}function Wh(e){const t={};if(!e)return t;if(e.bold&&(t["font-weight"]="bold"),e.italic&&(t["font-style"]="italic"),e.fontSize&&(t["font-size"]=`${e.fontSize}px`),e.strikethrough||e.underline){let o=e.strikethrough?"line-through":"";o=e.underline?o+" underline":o,t["text-decoration"]=o}return e.textColor&&(t.color=e.textColor),t}function qh(e){let t="";for(const o in e)e[o]&&(t+=`${o}:${e[o]}; `);return t}const Zh=new n;function jh(){if(window.Chart&&!window.Chart.registry.plugins.get("chartShowValuesPlugin"))for(const e of Zh.getAll())e.register(window.Chart)}class Yh extends Lh{mutators=["disableAnimationForChart","enableAnimationForChart"];animationPlayed={};disableAnimationForChart(e,t){return this.animationPlayed[e]=t,"noStateChange"}enableAnimationForChart(e){return this.animationPlayed[e]=void 0,"noStateChange"}}function Xh(){return class extends window.Chart.BarController{static id="funnel";static defaults={...window.Chart?.BarController.defaults,dataElementType:"funnel",animation:{duration:e=>{if("data"!==e.type)return 1e3;return e.raw[1]/Math.max(...e.dataset.data.map((e=>e[1])))*1e3}}};updateElements(e,t,o,s){super.updateElements(e,t,o,s);for(let i=t;i<t+o;i++){const t=e[i];this.updateElement(t,i,{nextElement:e[i+1]},s)}}}}function Kh(){return class extends window.Chart.BarElement{static id="funnel";draw(e){e.save();const{x:t,y:o,height:s,nextElement:i,base:n,options:r}=this.getProps(["x","y","width","height","nextElement","base","options"]),a=Jh(this),l=(a-(i?Jh(i):0))/2,c=Math.min(t,n),h=o-s/2;e.fillStyle=r.backgroundColor,e.beginPath(),e.moveTo(c,h),e.lineTo(c+a,h),e.lineTo(c+a-l,h+s),e.lineTo(c+l,h+s),e.closePath(),e.fill(),r.borderWidth&&(e.strokeStyle=r.borderColor,e.lineWidth=r.borderWidth,e.stroke()),e.restore()}inRange(e,t){const{x:o,y:s,height:i,nextElement:n,base:r}=this.getProps(["x","y","width","height","nextElement","base","options"]),a=Jh(this),l=n?Jh(n):0,c=Math.min(o,r),h=s-i/2;if(t<h||t>h+i)return!1;const d=(a-l)/2;return!(e<c+d*(t-h)/i||e>c+a-d*(t-h)/i)}}}function Jh(e){const{x:t,base:o}=e.getProps(["x","base"]),s=Math.min(t,o);return Math.max(t,o)-s}const Qh=function(e){if(!e.length)return{x:0,y:0};const t=e[0].element,{x:o,y:s,base:i,width:n,height:r}=t.getProps(["x","y","width","height","base"]);return{x:Math.min(o,i)+2*n/3,y:s-r/2+r/2}},ed="000000",td={arrows:"3Arrows",smiley:"3Symbols",dots:"3TrafficLights1"},od={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"},sd="http://schemas.openxmlformats.org/drawingml/2006/main",id="http://schemas.openxmlformats.org/drawingml/2006/chart",nd={workbook:"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.main+xml",macroEnabledWorkbook:"application/vnd.ms-excel.sheet.macroEnabled.main+xml",templateWorkbook:"application/vnd.openxmlformats-officedocument.spreadsheetml.template.main+xml",macroEnabledTemplateWorkbook:"application/vnd.ms-excel.template.macroEnabled.main+xml",excelAddInWorkbook:"application/vnd.ms-excel.addin.macroEnabled.main+xml",sheet:"application/vnd.openxmlformats-officedocument.spreadsheetml.worksheet+xml",metadata:"application/vnd.openxmlformats-officedocument.spreadsheetml.sheetMetadata+xml",sharedStrings:"application/vnd.openxmlformats-officedocument.spreadsheetml.sharedStrings+xml",styles:"application/vnd.openxmlformats-officedocument.spreadsheetml.styles+xml",drawing:"application/vnd.openxmlformats-officedocument.drawing+xml",chart:"application/vnd.openxmlformats-officedocument.drawingml.chart+xml",themes:"application/vnd.openxmlformats-officedocument.theme+xml",table:"application/vnd.openxmlformats-officedocument.spreadsheetml.table+xml",pivot:"application/vnd.openxmlformats-officedocument.spreadsheetml.pivotTable+xml",externalLink:"application/vnd.openxmlformats-officedocument.spreadsheetml.externalLink+xml"},rd={document:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument",sheet:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/worksheet",metadata:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/sheetMetadata",sharedStrings:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/sharedStrings",styles:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/styles",drawing:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/drawing",chart:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/chart",theme:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/theme",table:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/table",hyperlink:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/hyperlink",image:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/image"},ad="bdbb8cdc-fa1e-496e-a857-3c3f30c029c3",ld="http://schemas.openxmlformats.org/officeDocument/2006/relationships",cd=.75,hd=.143,dd=8.43,ud=12.75,gd=30,pd=100,md=164,fd=50,vd={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}]},bd=["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"],Sd="[Content_Types].xml",Cd=/(.*?)\((.*?)\)(.*)/,yd=["ANY","BOOLEAN","DATE","NUMBER","STRING","RANGE","RANGE<BOOLEAN>","RANGE<DATE>","RANGE<NUMBER>","RANGE<STRING>","META","RANGE<META>"];function Id(e,t="",o){return function(e,t,o){const s=e.match(Cd),i=s[1].trim();if(!i)throw new Error(`Function argument definition is missing a name: '${e}'.`);const n=[];let r,a=!1,l=!1;for(const e of s[2].split(",")){const t=e.trim().toUpperCase(),o=yd.find((e=>t===e));o?n.push(o):"RANGE<ANY>"===t?n.push("RANGE"):"OPTIONAL"===t?a=!0:"REPEATING"===t?l=!0:t.startsWith("DEFAULT=")&&(r=e.trim().slice(8))}const c={name:i,description:t,type:n};(n.includes("ANY")||n.includes("RANGE"))&&(c.acceptErrors=!0);a&&(c.optional=!0);l&&(c.repeating=!0);void 0!==r&&(c.default=!0,c.defaultValue=r);n.some((e=>e.startsWith("RANGE")))&&(c.acceptMatrix=!0);n.every((e=>e.startsWith("RANGE")))&&(c.acceptMatrixOnly=!0);o&&o.length>0&&(c.proposalValues=o);return c}(e,t,o)}const wd={};function xd(e,t){const o=e.name,s=wd[o]?.[t];return s||(wd[o]||(wd[o]={}),wd[o][t]||(wd[o][t]=function(e,t){const o={},s=e.nbrArgRepeating?Math.floor((t-e.minArgRequired)/e.nbrArgRepeating):0,i=e.nbrArgRepeating*s,n=t-e.minArgRequired-i;let r=0,a=0;for(let t=0;t<e.args.length;t++){const i=e.args[t];if(i.optional||i.default)a<n&&(o[r]=t,r++),a++;else if(i.repeating){for(let i=0;i<s;i++)for(let s=0;s<e.nbrArgRepeating;s++)o[r]=t+s,r++;t+=e.nbrArgRepeating-1}else o[r]=t,r++}return e=>o[e]}(e,t)),wd[o][t])}const Ed=["META","RANGE<META>"];const Rd=new n,Td={description:ui("Returns a result array constrained to a specific width and height."),args:[Id("input_range (any, range<any>)",ui("The range to constrain.")),Id("rows (number)",ui("The number of rows in the constrained array.")),Id("columns (number)",ui("The number of columns in the constrained array."))],compute:function(e,t,o){const s=Kn(e),i=wn(t?.value,this.locale),n=wn(o?.value,this.locale);if(i<=0)return new rn(ui("The rows argument (%s) must be strictly positive.",i.toString()));if(n<=0)return new rn(ui("The columns argument (%s) must be strictly positive.",n.toString()));const r=Math.min(i,s[0].length);return Vn(Math.min(n,s.length),r,((e,t)=>s[e][t]))},isExported:!1},Ad={description:ui("Creates a new array from the selected columns in the existing range."),args:[Id("array (any, range<any>)",ui("The array that contains the columns to be returned.")),Id("col_num (number, range<number>)",ui("The first column index of the columns to be returned.")),Id("col_num2 (number, range<number>, repeating)",ui("The columns indexes of the columns to be returned."))],compute:function(e,...t){const o=Kn(e),s=Jn(t,(e=>wn(e?.value,this.locale))),i=s.filter((e=>0===e||o.length<Math.abs(e)));if(0!==i.length)return new rn(ui("The columns arguments must be between -%s and %s (got %s), excluding 0.",o.length.toString(),o.length.toString(),i.join(",")));const n=Array(s.length);for(let e=0;e<s.length;e++)s[e]>0?n[e]=o[s[e]-1]:n[e]=o[o.length+s[e]];return n},isExported:!0},Dd={description:ui("Creates a new array from the selected rows in the existing range."),args:[Id("array (any, range<any>)",ui("The array that contains the rows to be returned.")),Id("row_num (number, range<number>)",ui("The first row index of the rows to be returned.")),Id("row_num2 (number, range<number>, repeating)",ui("The rows indexes of the rows to be returned."))],compute:function(e,...t){const o=Kn(e),s=Jn(t,(e=>wn(e?.value,this.locale))),i=o.length,n=s.filter((e=>0===e||o[0].length<Math.abs(e)));return 0!==n.length?new rn(ui("The rows arguments must be between -%s and %s (got %s), excluding 0.",o[0].length.toString(),o[0].length.toString(),n.join(","))):Vn(i,s.length,((e,t)=>s[t]>0?o[e][s[t]-1]:o[e][o[e].length+s[t]]))},isExported:!0},_d={description:ui("Expands or pads an array to specified row and column dimensions."),args:[Id("array (any, range<any>)",ui("The array to expand.")),Id("rows (number)",ui("The number of rows in the expanded array. If missing, rows will not be expanded.")),Id("columns (number, optional)",ui("The number of columns in the expanded array. If missing, columns will not be expanded.")),Id("pad_with (any, default=0)",ui("The value with which to pad."))],compute:function(e,t,o,s={value:0}){const i=Kn(e),n=wn(t?.value,this.locale),r=void 0!==o?wn(o.value,this.locale):i.length;return n<i[0].length?new rn(ui("The rows arguments (%s) must be greater or equal than the number of rows of the array.",n.toString())):r<i.length?new rn(ui("The columns arguments (%s) must be greater or equal than the number of columns of the array.",r.toString())):Vn(r,n,((e,t)=>e>=i.length||t>=i[e].length?s:i[e][t]))},isExported:!0},Fd={description:ui("Flattens all the values from one or more ranges into a single column."),args:[Id("range (any, range<any>)",ui("The first range to flatten.")),Id("range2 (any, range<any>, repeating)",ui("Additional ranges to flatten."))],compute:function(...e){return[Jn(e,(e=>void 0===e?{value:""}:e))]},isExported:!1},Od={description:ui("Calculates the frequency distribution of a range."),args:[Id("data (range<number>)",ui("The array of ranges containing the values to be counted.")),Id("classes (number, range<number>)",ui("The range containing the set of classes."))],compute:function(e,t){const o=Jn([e],(e=>e.value)).filter((e=>"number"==typeof e)),s=Jn([t],(e=>e.value)).filter((e=>"number"==typeof e)),i=s.map(((e,t)=>({initialIndex:t,value:e,count:0}))).sort(((e,t)=>e.value-t.value));i.push({initialIndex:i.length,value:1/0,count:0});const n=o.sort(((e,t)=>e-t));let r=0;for(const e of n){for(;e>i[r].value&&r<i.length-1;)r++;i[r].count++}return[i.sort(((e,t)=>e.initialIndex-t.initialIndex)).map((e=>e.count))]},isExported:!0},Pd={description:ui("Appends ranges horizontally and in sequence to return a larger array."),args:[Id("range1 (any, range<any>)",ui("The first range to be appended.")),Id("range2 (any, range<any>, repeating)",ui("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=Kn(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},Md={description:ui("Returns the matrix determinant of a square matrix."),args:[Id("square_matrix (number, range<number>)",ui("An range with an equal number of rows and columns representing a matrix whose determinant will be calculated."))],compute:function(e){const t=yn(e,"square_matrix");return hc(t)?gc(t).determinant:new rn(ui("The argument square_matrix must have the same number of columns and rows."))},isExported:!0},Nd={description:ui("Returns the multiplicative inverse of a square matrix."),args:[Id("square_matrix (number, range<number>)",ui("An range with an equal number of rows and columns representing a matrix whose multiplicative inverse will be calculated."))],compute:function(e){const t=yn(e,"square_matrix");if(!hc(t))return new rn(ui("The argument square_matrix must have the same number of columns and rows."));const{inverted:o}=gc(t);return o||new rn(ui("The matrix is not invertible."))},isExported:!0},kd={description:ui("Calculates the matrix product of two matrices."),args:[Id("matrix1 (number, range<number>)",ui("The first matrix in the matrix multiplication operation.")),Id("matrix2 (number, range<number>)",ui("The second matrix in the matrix multiplication operation."))],compute:function(e,t){const o=yn(e,"matrix1"),s=yn(t,"matrix2");return 0===o.length||0===s.length?new rn(ui("The first and second arguments of [[FUNCTION_NAME]] must be non-empty matrices.")):o.length!==s[0].length?new rn(ui("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())):mc(o,s)},isExported:!0},Ld={description:ui("Calculates the sum of the products of corresponding entries in equal-sized ranges."),args:[Id("range1 (number, range<number>)",ui("The first range whose entries will be multiplied with corresponding entries in the other ranges.")),Id("range2 (number, range<number>, repeating)",ui("The other range whose entries will be multiplied with corresponding entries in the other ranges."))],compute:function(...e){if(!cc(...e))return new rn(ui("All the ranges must have the same dimensions."));const t=e.map(Kn);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*=Sn(o[e][s],this.locale);o+=i}return o},isExported:!0};function Vd(e,t,o){if(!cc(e,t))return new rn(ui("The arguments array_x and array_y must have the same dimensions."));const s=Kn(e),i=Kn(t);let n=!1,r=0;for(const e in s)for(const t in s[e]){const a=s[e][t].value,l=i[e][t].value;"number"==typeof a&&"number"==typeof l&&(n=!0,r+=o(a,l))}return n?r:new rn(ui("The arguments array_x and array_y must contain at least one pair of numbers."))}const Ud={description:ui("Calculates the sum of the difference of the squares of the values in two array."),args:[Id("array_x (number, range<number>)",ui("The array or range of values whose squares will be reduced by the squares of corresponding entries in array_y and added together.")),Id("array_y (number, range<number>)",ui("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 Vd(e,t,((e,t)=>e**2-t**2))},isExported:!0},Hd={description:ui("Calculates the sum of the sum of the squares of the values in two array."),args:[Id("array_x (number, range<number>)",ui("The array or range of values whose squares will be added to the squares of corresponding entries in array_y and added together.")),Id("array_y (number, range<number>)",ui("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 Vd(e,t,((e,t)=>e**2+t**2))},isExported:!0},zd={description:ui("Calculates the sum of squares of the differences of values in two array."),args:[Id("array_x (number, range<number>)",ui("The array or range of values that will be reduced by corresponding entries in array_y, squared, and added together.")),Id("array_y (number, range<number>)",ui("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 Vd(e,t,((e,t)=>(e-t)**2))},isExported:!0},Bd=!1,$d=[Id("array (any, range<any>)",ui("The array which will be transformed.")),Id("ignore (number, default=0)",ui("Whether to ignore certain types of values. By default, no values are ignored."),[{value:0,label:ui("Keep all values (default)")},{value:1,label:ui("Ignore blanks")},{value:2,label:ui("Ignore errors")},{value:3,label:ui("Ignore blanks and errors")}]),Id("scan_by_column (number, default=false)",ui("Scan the array by column. By default, the array is scanned by row."),[{value:!1,label:ui("Scan by row (default)")},{value:!0,label:ui("Scan by column")}])];function Gd(e){const t=Math.trunc(e);if(0===t)return()=>!0;if(1===t)return e=>null!==e.value;if(2===t)return e=>!fn(e.value);if(3===t)return e=>null!==e.value&&!fn(e.value);throw new rn(ui("Argument ignore must be between 0 and 3"))}const Wd={description:ui("Transforms a range of cells into a single column."),args:$d,compute:function(e,t={value:0},o={value:Bd}){const s=Kn(e),i=Sn(t.value,this.locale),n=(An(o.value)?s:Hn(s)).flat().filter(Gd(i));return 0===n.length?new hn(ui("No results for the given arguments of TOCOL.")):[n]},isExported:!0},qd={description:ui("Transforms a range of cells into a single row."),args:$d,compute:function(e,t={value:0},o={value:Bd}){const s=Kn(e),i=Sn(t.value,this.locale),n=(An(o.value)?s:Hn(s)).flat().filter(Gd(i)).map((e=>[e]));return 0===n.length||0===n[0].length?new hn(ui("No results for the given arguments of TOROW.")):n},isExported:!0},Zd={description:ui("Transposes the rows and columns of a range."),args:[Id("range (any, range<any>)",ui("The range to be transposed."))],compute:function(e){const t=Kn(e);return Vn(t[0].length,t.length,((e,o)=>t[o][e]))},isExported:!0},jd={description:ui("Appends ranges vertically and in sequence to return a larger array."),args:[Id("range1 (any, range<any>)",ui("The first range to be appended.")),Id("range2 (any, range<any>, repeating)",ui("Additional ranges to add to range1."))],compute:function(...e){const t=Math.max(...e.map((e=>Kn(e).length))),o=e.reduce(((e,t)=>e+Kn(t)[0].length),0),s=Array(t).fill([]).map((()=>Array(o).fill({value:0})));let i=0;for(const t of e){const e=Kn(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},Yd={description:ui("Wraps the provided row or column of cells by columns after a specified number of elements to form a new array."),args:[Id("range (any, range<any>)",ui("The range to wrap.")),Id("wrap_count (number)",ui("The maximum number of cells for each column, rounded down to the nearest whole number.")),Id("pad_with (any, default=0)",ui("The value with which to fill the extra cells in the range."))],compute:function(e,t,o={value:0}){const s=Kn(e),i=wn(t?.value,this.locale);if(!lc(s))return new rn(ui("Argument range must be a single row or column."));const n=s.flat();return Vn(Math.ceil(n.length/i),i,((e,t)=>{const s=e*i+t;return s<n.length?n[s]:o}))},isExported:!0},Xd={description:ui("Wraps the provided row or column of cells by rows after a specified number of elements to form a new array."),args:[Id("range (any, range<any>)",ui("The range to wrap.")),Id("wrap_count (number)",ui("The maximum number of cells for each row, rounded down to the nearest whole number.")),Id("pad_with (any, default=0)",ui("The value with which to fill the extra cells in the range."))],compute:function(e,t,o={value:0}){const s=Kn(e),i=wn(t?.value,this.locale);if(!lc(s))return new rn(ui("Argument range must be a single row or column."));const n=s.flat(),r=Math.ceil(n.length/i);return Vn(i,r,((e,t)=>{const s=t*i+e;return s<n.length?n[s]:o}))},isExported:!0};var Kd=Object.freeze({__proto__:null,ARRAY_CONSTRAIN:Td,CHOOSECOLS:Ad,CHOOSEROWS:Dd,EXPAND:_d,FLATTEN:Fd,FREQUENCY:Od,HSTACK:Pd,MDETERM:Md,MINVERSE:Nd,MMULT:kd,SUMPRODUCT:Ld,SUMX2MY2:Ud,SUMX2PY2:Hd,SUMXMY2:zd,TOCOL:Wd,TOROW:qd,TRANSPOSE:Zd,VSTACK:jd,WRAPCOLS:Yd,WRAPROWS:Xd});const Jd={description:ui("Apply a large number format"),args:[Id("value (number)",ui("The number.")),Id("unit (string, optional)",ui("The formatting unit. Use 'k', 'm', or 'b' to force the unit"),[{value:"k",label:ui("Thousand")},{value:"m",label:ui("Million")},{value:"b",label:ui("Billion")}])],compute:function(e,t){return{value:Sn(e,this.locale),format:qr(e,t,this.locale)}}};var Qd=Object.freeze({__proto__:null,FORMAT_LARGE_NUMBER:Jd});class eu{static getters=[];history;constructor(e){this.history=Object.assign(Object.create(e),{update:e.addChange.bind(e,this),selectCell:()=>{}})}exportForExcel(e){}allowDispatch(e){return"Success"}beforeHandle(e){}handle(e){}finalize(){}batchValidations(...e){return t=>e.map((e=>e.call(this,t))).flat()}chainValidations(...e){return t=>{for(const o of e){let e=o.call(this,t);Array.isArray(e)||(e=[e]);const s=e.filter((e=>"Success"!==e));if(s.length)return s}return"Success"}}checkValidations(e,...t){return this.batchValidations(...t)(e)}}class tu extends eu{static layers=[];getters;ui;selection;dispatch;canDispatch;constructor({getters:e,stateObserver:t,dispatch:o,canDispatch:s,uiActions:i,selection:n}){super(t),this.getters=e,this.ui=i,this.selection=n,this.dispatch=o,this.canDispatch=s}drawLayer(e,t){}}function ou(e){return e.isFormula&&e.compiledFormula.tokens.some((e=>"SYMBOL"===e.type&&"SUBTOTAL"===e.value.toUpperCase()))}const su=/^-?[a-z0-9]+$/i,iu={description:ui("Absolute value of a number."),args:[Id("value (number)",ui("The number of which to return the absolute value."))],compute:function(e){return Math.abs(Sn(e,this.locale))},isExported:!0},nu={description:ui("Inverse cosine of a value, in radians."),args:[Id("value (number)",ui("The value for which to calculate the inverse cosine. Must be between -1 and 1, inclusive."))],compute:function(e){const t=Sn(e,this.locale);return Math.abs(t)>1?new rn(ui("The value (%s) must be between -1 and 1 inclusive.",t)):Math.acos(t)},isExported:!0},ru={description:ui("Inverse hyperbolic cosine of a number."),args:[Id("value (number)",ui("The value for which to calculate the inverse hyperbolic cosine. Must be greater than or equal to 1."))],compute:function(e){const t=Sn(e,this.locale);return t<1?new rn(ui("The value (%s) must be greater than or equal to 1.",t)):Math.acosh(t)},isExported:!0},au={description:ui("Inverse cotangent of a value."),args:[Id("value (number)",ui("The value for which to calculate the inverse cotangent."))],compute:function(e){const t=Sn(e,this.locale);return(Math.sign(t)||1)*Math.PI/2-Math.atan(t)},isExported:!0},lu={description:ui("Inverse hyperbolic cotangent of a value."),args:[Id("value (number)",ui("The value for which to calculate the inverse hyperbolic cotangent. Must not be between -1 and 1, inclusive."))],compute:function(e){const t=Sn(e,this.locale);return Math.abs(t)<=1?new rn(ui("The value (%s) cannot be between -1 and 1 inclusive.",t)):Math.log((t+1)/(t-1))/2},isExported:!0},cu={description:ui("Inverse sine of a value, in radians."),args:[Id("value (number)",ui("The value for which to calculate the inverse sine. Must be between -1 and 1, inclusive."))],compute:function(e){const t=Sn(e,this.locale);return Math.abs(t)>1?new rn(ui("The value (%s) must be between -1 and 1 inclusive.",t)):Math.asin(t)},isExported:!0},hu={description:ui("Inverse hyperbolic sine of a number."),args:[Id("value (number)",ui("The value for which to calculate the inverse hyperbolic sine."))],compute:function(e){return Math.asinh(Sn(e,this.locale))},isExported:!0},du={description:ui("Inverse tangent of a value, in radians."),args:[Id("value (number)",ui("The value for which to calculate the inverse tangent."))],compute:function(e){return Math.atan(Sn(e,this.locale))},isExported:!0},uu={description:ui("Angle from the X axis to a point (x,y), in radians."),args:[Id("x (number)",ui("The x coordinate of the endpoint of the line segment for which to calculate the angle from the x-axis.")),Id("y (number)",ui("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=Sn(e,this.locale),s=Sn(t,this.locale);return 0===o&&0===s?new gn(ui("Function [[FUNCTION_NAME]] caused a divide by zero error.")):Math.atan2(s,o)},isExported:!0},gu={description:ui("Inverse hyperbolic tangent of a number."),args:[Id("value (number)",ui("The value for which to calculate the inverse hyperbolic tangent. Must be between -1 and 1, exclusive."))],compute:function(e){const t=Sn(e,this.locale);return Math.abs(t)>=1?new rn(ui("The value (%s) must be between -1 and 1 exclusive.",t)):Math.atanh(t)},isExported:!0},pu={description:ui("Rounds number up to nearest multiple of factor."),args:[Id("value (number)",ui("The value to round up to the nearest integer multiple of factor.")),Id("factor (number, default=1)",ui("The number to whose multiples value will be rounded."))],compute:function(e,t={value:1}){const o=Sn(e,this.locale),s=Sn(t,this.locale);return s<0&&o>0?new rn(ui("The factor (%s) must be positive when the value (%s) is positive.",s,o)):{value:s?Math.ceil(o/s)*s:0,format:e?.format}},isExported:!0};function mu(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 fu={description:ui("Rounds number up to nearest multiple of factor."),args:[Id("number (number)",ui("The value to round up to the nearest integer multiple of significance.")),Id("significance (number, default=1)",ui("The number to whose multiples number will be rounded. The sign of significance will be ignored.")),Id("mode (number, default=0)",ui("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=Sn(t,this.locale);return{value:mu(Sn(e,this.locale),s,Sn(o,this.locale)),format:e?.format}},isExported:!0},vu={description:ui("Rounds number up to nearest multiple of factor."),args:[Id("number (number)",ui("The value to round up to the nearest integer multiple of significance.")),Id("significance (number, default=1)",ui("The number to whose multiples number will be rounded."))],compute:function(e,t={value:1}){const o=Sn(t,this.locale);return{value:mu(Sn(e,this.locale),o),format:e?.format}},isExported:!0},bu={description:ui("Cosine of an angle provided in radians."),args:[Id("angle (number)",ui("The angle to find the cosine of, in radians."))],compute:function(e){return Math.cos(Sn(e,this.locale))},isExported:!0},Su={description:ui("Hyperbolic cosine of any real number."),args:[Id("value (number)",ui("Any real value to calculate the hyperbolic cosine of."))],compute:function(e){return Math.cosh(Sn(e,this.locale))},isExported:!0},Cu={description:ui("Cotangent of an angle provided in radians."),args:[Id("angle (number)",ui("The angle to find the cotangent of, in radians."))],compute:function(e){const t=Sn(e,this.locale);return 0===t?new gn(ui("Function [[FUNCTION_NAME]] caused a divide by zero error.")):1/Math.tan(t)},isExported:!0},yu={description:ui("Hyperbolic cotangent of any real number."),args:[Id("value (number)",ui("Any real value to calculate the hyperbolic cotangent of."))],compute:function(e){const t=Sn(e,this.locale);return 0===t?new gn(ui("Function [[FUNCTION_NAME]] caused a divide by zero error.")):1/Math.tanh(t)},isExported:!0},Iu={description:ui("Number of empty values."),args:[Id("value1 (any, range)",ui("The first value or range in which to count the number of blanks.")),Id("value2 (any, range, repeating)",ui("Additional values or ranges in which to count the number of blanks."))],compute:function(...e){return Nn(e,((e,t)=>void 0===t||null===t.value||""===t.value?e+1:e),0)},isExported:!0},wu={description:ui("A conditional count across a range."),args:[Id("range (range)",ui("The range that is tested against criterion.")),Id("criterion (string)",ui("The pattern or test to apply to range."))],compute:function(...e){let t=0;return qn(e,((e,o)=>{t+=1}),this.locale),t},isExported:!0},xu={description:ui("Count values depending on multiple criteria."),args:[Id("criteria_range1 (range)",ui("The range to check against criterion1.")),Id("criterion1 (string)",ui("The pattern or test to apply to criteria_range1.")),Id("criteria_range2 (any, range, repeating)",ui("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.")),Id("criterion2 (string, repeating)",ui("Additional criteria to check."))],compute:function(...e){let t=0;return qn(e,((e,o)=>{t+=1}),this.locale),t},isExported:!0},Eu={description:ui("Counts number of unique values in a range."),args:[Id("value1 (any, range)",ui("The first value or range to consider for uniqueness.")),Id("value2 (any, range, repeating)",ui("Additional values or ranges to consider for uniqueness."))],compute:function(...e){return nc(e)}},Ru={description:ui("Counts number of unique values in a range, filtered by a set of criteria."),args:[Id("range (range)",ui("The range of cells from which the number of unique values will be counted.")),Id("criteria_range1 (range)",ui("The range of cells over which to evaluate criterion1.")),Id("criterion1 (string)",ui("The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.")),Id("criteria_range2 (any, range, repeating)",ui("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.")),Id("criterion2 (string, repeating)",ui("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){const o=new Set;return qn(t,((t,s)=>{const i=e[t]?.[s];Qn(i)&&o.add(i.value)}),this.locale),o.size}},Tu={description:ui("Cosecant of an angle provided in radians."),args:[Id("angle (number)",ui("The angle to find the cosecant of, in radians."))],compute:function(e){const t=Sn(e,this.locale);return 0===t?new gn(ui("Function [[FUNCTION_NAME]] caused a divide by zero error.")):1/Math.sin(t)},isExported:!0},Au={description:ui("Hyperbolic cosecant of any real number."),args:[Id("value (number)",ui("Any real value to calculate the hyperbolic cosecant of."))],compute:function(e){const t=Sn(e,this.locale);return 0===t?new gn(ui("Function [[FUNCTION_NAME]] caused a divide by zero error.")):1/Math.sinh(t)},isExported:!0},Du={description:ui("Converts from another base to decimal."),args:[Id("value (string)",ui("The number to convert.")),Id("base (number)",ui("The base to convert the value from."))],compute:function(e,t){let o=Sn(t,this.locale);if(o=Math.floor(o),2>o||o>36)return new rn(ui("The base (%s) must be between 2 and 36 inclusive.",o));const s=En(e);if(""===s)return 0;if(!su.test(s))return new rn(ui("The value (%s) must be a valid base %s representation.",s,o));const i=parseInt(s,o);return isNaN(i)?new rn(ui("The value (%s) must be a valid base %s representation.",s,o)):i},isExported:!0},_u={description:ui("Converts an angle value in radians to degrees."),args:[Id("angle (number)",ui("The angle to convert from radians to degrees."))],compute:function(e){return 180*Sn(e,this.locale)/Math.PI},isExported:!0},Fu={description:ui("Euler's number, e (~2.718) raised to a power."),args:[Id("value (number)",ui("The exponent to raise e."))],compute:function(e){return Math.exp(Sn(e,this.locale))},isExported:!0},Ou={description:ui("Rounds number down to nearest multiple of factor."),args:[Id("value (number)",ui("The value to round down to the nearest integer multiple of factor.")),Id("factor (number, default=1)",ui("The number to whose multiples value will be rounded."))],compute:function(e,t={value:1}){const o=Sn(e,this.locale),s=Sn(t,this.locale);return s<0&&o>0?new rn(ui("The factor (%s) must be positive when the value (%s) is positive.",s,o)):{value:s?Math.floor(o/s)*s:0,format:e?.format}},isExported:!0};function Pu(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 Mu={description:ui("Rounds number down to nearest multiple of factor."),args:[Id("number (number)",ui("The value to round down to the nearest integer multiple of significance.")),Id("significance (number, default=1)",ui("The number to whose multiples number will be rounded. The sign of significance will be ignored.")),Id("mode (number, default=0)",ui("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=Sn(t,this.locale);return{value:Pu(Sn(e,this.locale),s,Sn(o,this.locale)),format:e?.format}},isExported:!0},Nu={description:ui("Rounds number down to nearest multiple of factor."),args:[Id("number (number)",ui("The value to round down to the nearest integer multiple of significance.")),Id("significance (number, default=1)",ui("The number to whose multiples number will be rounded."))],compute:function(e,t={value:1}){const o=Sn(t,this.locale);return{value:Pu(Sn(e,this.locale),o),format:e?.format}},isExported:!0},ku={description:ui("Whether the provided value is even."),args:[Id("value (number)",ui("The value to be verified as even."))],compute:function(e){const t=In(e,this.locale);return!(1&Math.floor(Math.abs(t)))},isExported:!0},Lu={description:ui("Rounds number up to nearest multiple of factor."),args:[Id("number (number)",ui("The value to round up to the nearest integer multiple of significance.")),Id("significance (number, default=1)",ui("The number to whose multiples number will be rounded."))],compute:function(e,t={value:1}){return{value:mu(Sn(e,this.locale),Sn(t,this.locale)),format:e?.format}},isExported:!0},Vu={description:ui("Whether the provided value is even."),args:[Id("value (number)",ui("The value to be verified as even."))],compute:function(e){const t=In(e,this.locale);return!!(1&Math.floor(Math.abs(t)))},isExported:!0},Uu={description:ui("The logarithm of a number, base e (euler's number)."),args:[Id("value (number)",ui("The value for which to calculate the logarithm, base e."))],compute:function(e){const t=Sn(e,this.locale);return t<=0?new rn(ui("The value (%s) must be strictly positive.",t)):Math.log(t)},isExported:!0},Hu={description:ui("The logarithm of a number, for a given base."),args:[Id("value (number)",ui("The value for which to calculate the logarithm.")),Id("base (number, default=10)",ui("The base of the logarithm."))],compute:function(e,t={value:10}){const o=Sn(e,this.locale),s=Sn(t,this.locale);return o<=0?new rn(ui("The value (%s) must be strictly positive.",o)):s<=0?new rn(ui("The base (%s) must be strictly positive.",s)):1===s?new rn(ui("The base must be different from 1.")):Math.log10(o)/Math.log10(s)},isExported:!0};function zu(e,t){ac(t,ui("The divisor must be different from 0."));const o=e%t;return o>0&&t<0||o<0&&t>0?o+t:o}const Bu={description:ui("Modulo (remainder) operator."),args:[Id("dividend (number)",ui("The number to be divided to find the remainder.")),Id("divisor (number)",ui("The number to divide by."))],compute:function(e,t){const o=Sn(t,this.locale);return{value:zu(Sn(e,this.locale),o),format:e?.format}},isExported:!0},$u={description:ui("Returns a n x n unit matrix, where n is the input dimension."),args:[Id("dimension (number)",ui("An integer specifying the dimension size of the unit matrix. It must be positive."))],compute:function(e){const t=wn(e,this.locale);return t<1?new rn(ui("The argument dimension must be positive")):uc(t)},isExported:!0},Gu={description:ui("Rounds a number up to the nearest odd integer."),args:[Id("value (number)",ui("The value to round to the next greatest odd number."))],compute:function(e){const t=Sn(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},Wu={description:ui("The number pi."),args:[],compute:function(){return Math.PI},isExported:!0},qu={description:ui("A number raised to a power."),args:[Id("base (number)",ui("The number to raise to the exponent power.")),Id("exponent (number)",ui("The exponent to raise base to."))],compute:function(e,t){const o=Sn(e,this.locale),s=Sn(t,this.locale);return o<0&&!Number.isInteger(s)?new rn(ui("The exponent (%s) must be an integer when the base is negative.",s)):{value:Math.pow(o,s),format:e?.format}},isExported:!0},Zu={description:ui("Result of multiplying a series of numbers together."),args:[Id("factor1 (number, range<number>)",ui("The first number or range to calculate for the product.")),Id("factor2 (number, range<number>, repeating)",ui("More numbers or ranges to calculate for the product."))],compute:function(...e){let t=0,o=1;for(const s of e)if(E(s))for(const e of s)for(const s of e){const e=s.value;if("number"==typeof e&&(o*=e,t+=1),fn(e))return s}else void 0!==s&&null!==s.value&&(o*=In(s,this.locale),t+=1);return{value:0===t?0:o,format:mn(e[0])}},isExported:!0},ju={description:ui("A random number between 0 inclusive and 1 exclusive."),args:[],compute:function(){return Math.random()},isExported:!0},Yu={description:ui("Returns a grid of random numbers between 0 inclusive and 1 exclusive."),args:[Id("rows (number, default=1)",ui("The number of rows to be returned.")),Id("columns (number, default=1)",ui("The number of columns to be returned.")),Id("min (number, default=0)",ui("The minimum number you would like returned.")),Id("max (number, default=1)",ui("The maximum number you would like returned.")),Id("whole_number (boolean, default=FALSE)",ui("Return a whole number or a decimal value."),[{value:!1,label:ui("Decimal (default)")},{value:!0,label:ui("Integer")}])],compute:function(e={value:1},t={value:1},o={value:0},s={value:1},i={value:!1}){const n=wn(t,this.locale),r=wn(e,this.locale),a=Sn(o,this.locale),l=Sn(s,this.locale),c=An(i);if(n<1)return new rn(ui("The number of columns (%s) must be positive.",n));if(r<1)return new rn(ui("The number of rows (%s) must be positive.",r));if(a>l)return new rn(ui("The maximum (%s) must be greater than or equal to the minimum (%s).",l,a));if(c&&(!Number.isInteger(a)||!Number.isInteger(l)))return new rn(ui("The maximum (%s) and minimum (%s) must be integers when whole_number is TRUE.",l.toString(),a.toString()));const h=Array(n);for(let e=0;e<n;e++){h[e]=Array(r);for(let t=0;t<r;t++)h[e][t]=c?Math.floor(Math.random()*(l-a+1)+a):a+Math.random()*(l-a)}return h},isExported:!0},Xu={description:ui("Random integer between two values, inclusive."),args:[Id("low (number)",ui("The low end of the random range.")),Id("high (number)",ui("The high end of the random range."))],compute:function(e,t){let o=Sn(e,this.locale);Number.isInteger(o)||(o=Math.ceil(o));let s=Sn(t,this.locale);return Number.isInteger(s)||(s=Math.floor(s)),o>s?new rn(ui("The high (%s) must be greater than or equal to the low (%s).",s,o)):{value:o+Math.ceil((s-o+1)*Math.random())-1,format:e?.format}},isExported:!0},Ku={description:ui("Rounds a number according to standard rules."),args:[Id("value (number)",ui("The value to round to places number of places.")),Id("places (number, default=0)",ui("The number of decimal places to which to round."))],compute:function(e,t={value:0}){const o=Sn(e,this.locale);let s=Sn(t,this.locale);const i=Math.abs(o);let n;return 0===s?n=Math.round(i):(Number.isInteger(s)||(s=Math.trunc(s)),n=Math.round(i*Math.pow(10,s))/Math.pow(10,s)),{value:o>=0?n:-n,format:e?.format}},isExported:!0},Ju={description:ui("Rounds down a number."),args:[Id("value (number)",ui("The value to round to places number of places, always rounding down.")),Id("places (number, default=0)",ui("The number of decimal places to which to round."))],compute:function(e,t={value:0}){const o=Sn(e,this.locale);let s=Sn(t,this.locale);const i=Math.abs(o);let n;return 0===s?n=Math.floor(i):(Number.isInteger(s)||(s=Math.trunc(s)),n=Math.floor(i*Math.pow(10,s))/Math.pow(10,s)),{value:o>=0?n:-n,format:e?.format}},isExported:!0},Qu={description:ui("Rounds up a number."),args:[Id("value (number)",ui("The value to round to places number of places, always rounding up.")),Id("places (number, default=0)",ui("The number of decimal places to which to round."))],compute:function(e,t={value:0}){const o=Sn(e,this.locale);let s=Sn(t,this.locale);const i=Math.abs(o);let n;return 0===s?n=Math.ceil(i):(Number.isInteger(s)||(s=Math.trunc(s)),n=Math.ceil(i*Math.pow(10,s))/Math.pow(10,s)),{value:o>=0?n:-n,format:e?.format}},isExported:!0},eg={description:ui("Secant of an angle provided in radians."),args:[Id("angle (number)",ui("The angle to find the secant of, in radians."))],compute:function(e){return 1/Math.cos(Sn(e,this.locale))},isExported:!0},tg={description:ui("Hyperbolic secant of any real number."),args:[Id("value (number)",ui("Any real value to calculate the hyperbolic secant of."))],compute:function(e){return 1/Math.cosh(Sn(e,this.locale))},isExported:!0},og={description:ui("Returns a sequence of numbers."),args:[Id("rows (number)",ui("The number of rows to return")),Id("columns (number, optional, default=1)",ui("The number of columns to return")),Id("start (number, optional, default=1)",ui("The first number in the sequence")),Id("step (number, optional, default=1)",ui("The amount to increment each value in the sequence"))],compute:function(e,t={value:1},o={value:1},s={value:1}){const i=Sn(o,this.locale),n=Sn(s,this.locale),r=wn(e,this.locale),a=wn(t,this.locale);return a<1?new rn(ui("The number of columns (%s) must be positive.",a)):r<1?new rn(ui("The number of rows (%s) must be positive.",r)):Vn(a,r,((e,t)=>({value:i+t*a*n+e*n})))},isExported:!0},sg={description:ui("Sine of an angle provided in radians."),args:[Id("angle (number)",ui("The angle to find the sine of, in radians."))],compute:function(e){return Math.sin(Sn(e,this.locale))},isExported:!0},ig={description:ui("Hyperbolic sine of any real number."),args:[Id("value (number)",ui("Any real value to calculate the hyperbolic sine of."))],compute:function(e){return Math.sinh(Sn(e,this.locale))},isExported:!0},ng={description:ui("Positive square root of a positive number."),args:[Id("value (number)",ui("The number for which to calculate the positive square root."))],compute:function(e){const t=Sn(e,this.locale);return t<0?new rn(ui("The value (%s) must be positive or null.",t)):{value:Math.sqrt(t),format:e?.format}},isExported:!0},rg={1:"AVERAGE",2:"COUNT",3:"COUNTA",4:"MAX",5:"MIN",6:"PRODUCT",7:"STDEV",8:"STDEVP",9:"SUM",10:"VAR",11:"VARP"},ag=Object.entries(rg).map((([e,t])=>({value:parseInt(e),label:ui("%s (include manually-hidden rows)",t)}))),lg=Object.entries(rg).map((([e,t])=>({value:parseInt(e)+100,label:ui("%s (exclude manually-hidden rows)",t)}))),cg={description:ui("Returns a subtotal for a vertical range of cells using a specified aggregation function."),args:[Id("function_code (number)",ui("The function to use in subtotal aggregation."),[...ag,...lg]),Id("ref1 (meta, range<meta>)",ui("The range or reference for which you want the subtotal.")),Id("ref2 (meta, range<meta>, repeating)",ui("Additional ranges or references for which you want the subtotal."))],compute:function(e,...t){let o=wn(e,this.locale),s=!0;if(o>100&&(o-=100,s=!1),o<1||o>11)return new rn(ui("The function code (%s) must be between 1 to 11 or 101 to 111.",o));const i=[];for(const e of t){const t=e[0][0],o=Ta(t.value).sheetName,n=o?this.getters.getSheetIdByName(o):this.__originSheetId;if(!n)continue;const{top:r,left:a}=Ho(t.value),l=a+e.length-1,c=r+e[0].length-1;for(let e=r;e<=c;e++)if(!this.getters.isRowFiltered(n,e)&&(s||!this.getters.isRowHiddenByUser(n,e)))for(let t=a;t<=l;t++){const o=this.getters.getCell({sheetId:n,col:t,row:e});o&&ou(o)||i.push(this.getters.getEvaluatedCell({sheetId:n,col:t,row:e}))}}return this[rg[o]].apply(this,[[i]])},isExported:!0},hg={description:ui("Sum of a series of numbers and/or cells."),args:[Id("value1 (number, range<number>)",ui("The first number or range to add together.")),Id("value2 (number, range<number>, repeating)",ui("Additional numbers or ranges to add to value1."))],compute:function(...e){const t=e[0];return{value:ic(e,this.locale),format:mn(t)}},isExported:!0},dg={description:ui("A conditional sum across a range."),args:[Id("criteria_range (range)",ui("The range which is tested against criterion.")),Id("criterion (string)",ui("The pattern or test to apply to range.")),Id("sum_range (range, default=criteria_range)",ui("The range to be summed, if different from range."))],compute:function(e,t,o){void 0===o&&(o=e);let s=0;return qn([e,t],((e,t)=>{const i=o[e]?.[t]?.value;"number"==typeof i&&(s+=i)}),this.locale),s},isExported:!0},ug={description:ui("Sums a range depending on multiple criteria."),args:[Id("sum_range (range)",ui("The range to sum.")),Id("criteria_range1 (range)",ui("The range to check against criterion1.")),Id("criterion1 (string)",ui("The pattern or test to apply to criteria_range1.")),Id("criteria_range2 (any, range, repeating)",ui("Additional ranges to check.")),Id("criterion2 (string, repeating)",ui("Additional criteria to check."))],compute:function(e,...t){let o=0;return qn(t,((t,s)=>{const i=e[t]?.[s]?.value;"number"==typeof i&&(o+=i)}),this.locale),o},isExported:!0},gg={description:ui("Tangent of an angle provided in radians."),args:[Id("angle (number)",ui("The angle to find the tangent of, in radians."))],compute:function(e){return Math.tan(Sn(e,this.locale))},isExported:!0},pg={description:ui("Hyperbolic tangent of any real number."),args:[Id("value (number)",ui("Any real value to calculate the hyperbolic tangent of."))],compute:function(e){return Math.tanh(Sn(e,this.locale))},isExported:!0};function mg(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 fg={description:ui("Truncates a number."),args:[Id("value (number)",ui("The value to be truncated.")),Id("places (number, default=0)",ui("The number of significant digits to the right of the decimal point to retain."))],compute:function(e,t={value:0}){return{value:mg(Sn(e,this.locale),Sn(t,this.locale)),format:e?.format}},isExported:!0},vg={description:ui("Rounds a number down to the nearest integer that is less than or equal to it."),args:[Id("value (number)",ui("The number to round down to the nearest integer."))],compute:function(e){return Math.floor(Sn(e,this.locale))},isExported:!0};var bg=Object.freeze({__proto__:null,ABS:iu,ACOS:nu,ACOSH:ru,ACOT:au,ACOTH:lu,ASIN:cu,ASINH:hu,ATAN:du,ATAN2:uu,ATANH:gu,CEILING:pu,CEILING_MATH:fu,CEILING_PRECISE:vu,COS:bu,COSH:Su,COT:Cu,COTH:yu,COUNTBLANK:Iu,COUNTIF:wu,COUNTIFS:xu,COUNTUNIQUE:Eu,COUNTUNIQUEIFS:Ru,CSC:Tu,CSCH:Au,DECIMAL:Du,DEGREES:_u,EXP:Fu,FLOOR:Ou,FLOOR_MATH:Mu,FLOOR_PRECISE:Nu,INT:vg,ISEVEN:ku,ISODD:Vu,ISO_CEILING:Lu,LN:Uu,LOG:Hu,MOD:Bu,MUNIT:$u,ODD:Gu,PI:Wu,POWER:qu,PRODUCT:Zu,RAND:ju,RANDARRAY:Yu,RANDBETWEEN:Xu,ROUND:Ku,ROUNDDOWN:Ju,ROUNDUP:Qu,SEC:eg,SECH:tg,SEQUENCE:og,SIN:sg,SINH:ig,SQRT:ng,SUBTOTAL:cg,SUM:hg,SUMIF:dg,SUMIFS:ug,TAN:gg,TANH:pg,TRUNC:fg});const Sg=[{value:!0,label:ui("b is calculated normally")},{value:!1,label:ui("b is forced to 1")}],Cg=[{value:!1,label:ui("do not return additional regression statistics")},{value:!0,label:ui("return additional regression statistics")}],yg=[{value:1,label:ui("order 1 (Linear)")},{value:2,label:ui("order 2 (Quadratic)")},{value:3,label:ui("order 3 (Cubic)")},{value:4,label:ui("order 4 (Quartic)")},{value:5,label:ui("order 5 (Quintic)")},{value:6,label:ui("order 6 (Sextic)")}],Ig=[{value:!0,label:ui("Compute intercept")},{value:!1,label:ui("Force intercept to 0")}],wg=[{value:0,label:ui("Minimum value")},{value:1,label:ui("First quartile (25th percentile)")},{value:2,label:ui("Median value (50th percentile)")},{value:3,label:ui("Third quartile (75th percentile)")},{value:4,label:ui("Maximum value")}];function xg(e,t){const o=[],s=[];let i=0,n=0;On([e],(e=>{o.push(e),i+=1})),On([t],(e=>{s.push(e),n+=1})),rc(i===n,ui("[[FUNCTION_NAME]] has mismatched argument count %s vs %s.",i,n));const r=[],a=[];for(let e=0;e<i;e++){const t=o[e]?.value,i=s[e]?.value;"number"==typeof t&&"number"==typeof i&&(a.push(t),r.push(i))}return{flatDataX:r,flatDataY:a}}function Eg(e,t,o){const{flatDataX:s,flatDataY:i}=xg(e,t),n=i.length;ac(n),o&&ac(n-1);let r=0,a=0;for(let e=0;e<n;e++)r+=i[e],a+=s[e];const l=r/n,c=a/n;let h=0;for(let e=0;e<n;e++)h+=(i[e]-l)*(s[e]-c);return h/(n-(o?1:0))}function Rg(e,t,o,s){let i=0;const n=o?Ln:kn,r=n(e,((e,t)=>(i+=1,e+t)),0,s);ac(i),t&&ac(i-1);const a=r/i;return n(e,((e,t)=>e+Math.pow(t-a,2)),0,s)/(i-(t?1:0))}function Tg(e,t,o,s){const i=Sn(t,s);rc(o?0<=i&&i<=1:0<i&&i<1,ui("Function [[FUNCTION_NAME]] parameter 2 value is out of range."));const n=[];let r,a=0;return On(e,(e=>{const t=e?.value;"number"==typeof t&&(r=Zn(n,e,"nextSmaller","asc",n.length,((e,t)=>e[t])),n.splice(r+1,0,t),a++)})),rc(0!==a,er),o||rc(1/(a+1)<=i&&i<=a/(a+1),ui("Function [[FUNCTION_NAME]] parameter 2 value is out of range.")),on(n,i,o)}const Ag={description:ui("Average magnitude of deviations from mean."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the sample.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the sample."))],compute:function(...e){let t=0;const o=kn(e,((e,o)=>(t+=1,e+o)),0,this.locale);if(0===t)return new gn(ui("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error."));const s=o/t;return kn(e,((e,t)=>e+Math.abs(s-t)),0,this.locale)/t},isExported:!0},Dg={description:ui("Numerical average value in a dataset, ignoring text."),args:[Id("value1 (number, range<number>)",ui("The first value or range to consider when calculating the average value.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to consider when calculating the average value."))],compute:function(...e){return{value:Cc(e,this.locale),format:mn(e[0])}},isExported:!0},_g=ui("[[FUNCTION_NAME]] has mismatched range sizes."),Fg=ui("[[FUNCTION_NAME]] expects the weight to be positive or equal to 0."),Og={description:ui("Weighted average."),args:[Id("values (number, range<number>)",ui("Values to average.")),Id("weights (number, range<number>)",ui("Weights for each corresponding value.")),Id("additional_values (number, range<number>, repeating)",ui("Additional values to average.")),Id("additional_weights (number, range<number>, repeating)",ui("Additional weights."))],compute:function(...e){let t=0,o=0;for(let s=0;s<e.length-1;s+=2){const i=e[s],n=e[s+1];if(!cc(i,n))return new rn(_g);if(E(i))for(let e=0;e<i.length;e++)for(let s=0;s<i[0].length;s++){const r=i[e][s].value,a=E(n)?n?.[e][s].value:Sn(n,this.locale),l="number"==typeof r,c="number"==typeof a;if(l&&c){if(a<0)return new rn(Fg);t+=r*a,o+=a}else if(l!==c)return new rn(ui("[[FUNCTION_NAME]] expects number values."))}else{const e=Sn(i,this.locale),s=E(n)?n?.[0][0].value:Sn(n,this.locale);if("number"==typeof s){if(s<0)return new rn(Fg);t+=e*s,o+=s}}}return 0===o?new gn(ui("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.")):{value:t/o,format:mn(e[0])}}},Pg={description:ui("Numerical average value in a dataset."),args:[Id("value1 (number, range<number>)",ui("The first value or range to consider when calculating the average value.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to consider when calculating the average value."))],compute:function(...e){let t=0;const o=Ln(e,((e,o)=>(t+=1,e+o)),0,this.locale);return 0===t?new gn(ui("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.")):{value:o/t,format:mn(e[0])}},isExported:!0},Mg={description:ui("Average of values depending on criteria."),args:[Id("criteria_range (number, range<number>)",ui("The range to check against criterion.")),Id("criterion (string)",ui("The pattern or test to apply to criteria_range.")),Id("average_range (number, range<number>, default=criteria_range)",ui("The range to average. If not included, criteria_range is used for the average instead."))],compute:function(e,t,o){const s=Kn(void 0===o?e:o);let i=0,n=0;return qn([e,t],((e,t)=>{const o=s[e]?.[t]?.value;"number"==typeof o&&(i+=1,n+=o)}),this.locale),0===i?new gn(ui("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.")):n/i},isExported:!0},Ng={description:ui("Average of values depending on multiple criteria."),args:[Id("average_range (range)",ui("The range to average.")),Id("criteria_range1 (range)",ui("The range to check against criterion1.")),Id("criterion1 (string)",ui("The pattern or test to apply to criteria_range1.")),Id("criteria_range2 (any, range, repeating)",ui("Additional criteria_range and criterion to check.")),Id("criterion2 (string, repeating)",ui("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){const o=Kn(e);let s=0,i=0;return qn(t,((e,t)=>{const n=o[e]?.[t]?.value;"number"==typeof n&&(s+=1,i+=n)}),this.locale),0===s?new gn(ui("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.")):i/s},isExported:!0},kg={description:ui("The number of numeric values in dataset."),args:[Id("value1 (number, any, range<number>)",ui("The first value or range to consider when counting.")),Id("value2 (number, any, range<number>, repeating)",ui("Additional values or ranges to consider when counting."))],compute:function(...e){return yc(e,this.locale)},isExported:!0},Lg={description:ui("The number of values in a dataset."),args:[Id("value1 (any, range)",ui("The first value or range to consider when counting.")),Id("value2 (any, range, repeating)",ui("Additional values or ranges to consider when counting."))],compute:function(...e){return Ic(e)},isExported:!0},Vg={description:ui("The covariance of a dataset."),args:[Id("data_y (any, range)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (any, range)",ui("The range representing the array or matrix of independent data."))],compute:function(e,t){return Eg(e,t,!1)},isExported:!0},Ug={description:ui("The covariance of a dataset."),args:[Id("data_y (any, range)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (any, range)",ui("The range representing the array or matrix of independent data."))],compute:function(e,t){return Eg(e,t,!1)},isExported:!0},Hg={description:ui("The sample covariance of a dataset."),args:[Id("data_y (any, range)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (any, range)",ui("The range representing the array or matrix of independent data."))],compute:function(e,t){return Eg(e,t,!0)},isExported:!0},zg={description:ui("Calculates the expected y-value for a specified x based on a linear regression of a dataset."),args:[Id("x (number, range<number>)",ui("The value(s) on the x-axis to forecast.")),Id("data_y (range<number>)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (range<number>)",ui("The range representing the array or matrix of independent data."))],compute:function(e,t,o){const{flatDataX:s,flatDataY:i}=xg(t,o);return 0===s.length||0===i.length?new hn(er):Oc([i],[s],Un(Kn(e),(e=>Sn(e,this.locale))),!0)},isExported:!0},Bg={description:ui("Fits points to exponential growth trend."),args:[Id("known_data_y (range<number>)",ui("The array or range containing dependent (y) values that are already known, used to curve fit an ideal exponential growth curve.")),Id("known_data_x (range<number>, default={1;2;3;...})",ui("The values of the independent variable(s) corresponding with known_data_y.")),Id("new_data_x (any, range, default=known_data_x)",ui("The data points to return the y values for on the ideal curve fit.")),Id("b (boolean, default=TRUE)",ui("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."),Sg)],compute:function(e,t=[[]],o=[[]],s={value:!0}){return 0===e.length||0===e[0].length?new rn(tr("known_data_y")):_c(Oc(Fc(yn(e,"known_data_y")),yn(t,"known_data_x"),yn(o,"new_data_y"),An(s)))}},$g={description:ui("Compute the intercept of the linear regression."),args:[Id("data_y (range<number>)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (range<number>)",ui("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=xg(e,t);if(0===o.length||0===s.length)return new hn(er);const[[],[i]]=Rc([o],[s]);return i},isExported:!0},Gg={description:ui("Nth largest element from a data set."),args:[Id("data (any, range)",ui("Array or range containing the dataset to consider.")),Id("n (number)",ui("The rank from largest to smallest of the element to return."))],compute:function(e,t){const o=Math.trunc(Sn(t?.value,this.locale)),s=[];let i,n=0;On([e],(e=>{"number"==typeof e?.value&&(i=Zn(s,e,"nextSmaller","asc",s.length,((e,t)=>e[t].value)),s.splice(i+1,0,e),n++,n>o&&(s.shift(),n--))}));const r=s.shift();return void 0===r?new rn(er):n<o?new rn(ui("Function [[FUNCTION_NAME]] parameter 2 value (%s) is out of range.",o)):r},isExported:!0},Wg={description:ui("Given partial data about a linear trend, calculates various parameters about the ideal linear trend using the least-squares method."),args:[Id("data_y (range<number>)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (range<number>, default={1;2;3;...})",ui("The range representing the array or matrix of independent data.")),Id("calculate_b (boolean, default=TRUE)",ui("A flag specifying whether to compute the slope or not"),Sg),Id("verbose (boolean, default=FALSE)",ui("A flag specifying whether to return additional regression statistics or only the linear coefficients and the y-intercept"),Cg)],compute:function(e,t=[[]],o={value:!0},s={value:!1}){return 0===e.length||0===e[0].length?new rn(tr("data_y")):Rc(yn(t,"data_x"),yn(e,"data_y"),An(o),An(s))},isExported:!0},qg={description:ui("Given partial data about an exponential growth curve, calculates various parameters about the best fit ideal exponential growth curve."),args:[Id("data_y (range<number>)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (range<number>, optional, default={1;2;3;...})",ui("The range representing the array or matrix of independent data.")),Id("calculate_b (boolean, default=TRUE)",ui("A flag specifying whether to compute the slope or not"),Sg),Id("verbose (boolean, default=FALSE)",ui("A flag specifying whether to return additional regression statistics or only the linear coefficients and the y-intercept"),Cg)],compute:function(e,t=[[]],o={value:!0},s={value:!1}){if(0===e.length||0===e[0].length)return new rn(tr("data_y"));const i=Rc(yn(t,"data_x"),Fc(yn(e,"data_y")),An(o),An(s));for(let e=0;e<i.length;e++)i[e][0]=Math.exp(i[e][0]);return i},isExported:!0},Zg={description:ui("Compute the Matthews correlation coefficient of a dataset."),args:[Id("data_x (range)",ui("The range representing the array or matrix of observed data.")),Id("data_y (range)",ui("The range representing the array or matrix of predicted data."))],compute:function(e,t){const o=e.flat(),s=t.flat();if(Sc(o,s),0===o.length||0===s.length)return new hn(er);const i=o.length;let n=0,r=0,a=0,l=0;for(let e=0;e<i;++e){const t=An(o[e]);t===An(s[e])?t?r++:n++:t?l++:a++}return(r*n-a*l)/Math.sqrt((r+a)*(r+l)*(n+a)*(n+l))},isExported:!1},jg={description:ui("Maximum value in a numeric dataset."),args:[Id("value1 (number, range<number>)",ui("The first value or range to consider when calculating the maximum value.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to consider when calculating the maximum value."))],compute:function(...e){return wc(e,this.locale)},isExported:!0},Yg={description:ui("Maximum numeric value in a dataset."),args:[Id("value1 (any, range)",ui("The first value or range to consider when calculating the maximum value.")),Id("value2 (any, range, repeating)",ui("Additional values or ranges to consider when calculating the maximum value."))],compute:function(...e){const t=Ln(e,((e,t)=>Math.max(t,e)),-1/0,this.locale);return{value:t===-1/0?0:t,format:mn(e[0])}},isExported:!0},Xg={description:ui("Returns the maximum value in a range of cells, filtered by a set of criteria."),args:[Id("range (range)",ui("The range of cells from which the maximum will be determined.")),Id("criteria_range1 (range)",ui("The range of cells over which to evaluate criterion1.")),Id("criterion1 (string)",ui("The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.")),Id("criteria_range2 (any, range, repeating)",ui("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.")),Id("criterion2 (string, repeating)",ui("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){let o=-1/0;return qn(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},Kg={description:ui("Median value in a numeric dataset."),args:[Id("value1 (any, range)",ui("The first value or range to consider when calculating the median value.")),Id("value2 (any, range, repeating)",ui("Additional values or ranges to consider when calculating the median value."))],compute:function(...e){const t=[];return Pn(e,(e=>{t.push(e)}),this.locale),{value:Tg(t,{value:.5},!0,this.locale),format:mn(t[0])}},isExported:!0},Jg={description:ui("Minimum value in a numeric dataset."),args:[Id("value1 (number, range<number>)",ui("The first value or range to consider when calculating the minimum value.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to consider when calculating the minimum value."))],compute:function(...e){return xc(e,this.locale)},isExported:!0},Qg={description:ui("Minimum numeric value in a dataset."),args:[Id("value1 (number, range<number>)",ui("The first value or range to consider when calculating the minimum value.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to consider when calculating the minimum value."))],compute:function(...e){const t=Ln(e,((e,t)=>Math.min(t,e)),1/0,this.locale);return{value:t===1/0?0:t,format:mn(e[0])}},isExported:!0},ep={description:ui("Returns the minimum value in a range of cells, filtered by a set of criteria."),args:[Id("range (range)",ui("The range of cells from which the minimum will be determined.")),Id("criteria_range1 (range)",ui("The range of cells over which to evaluate criterion1.")),Id("criterion1 (string)",ui("The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.")),Id("criteria_range2 (any, range, repeating)",ui("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.")),Id("criterion2 (string, repeating)",ui("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){let o=1/0;return qn(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 tp(e,t){const{flatDataX:o,flatDataY:s}=xg(e,t);if(0===o.length||0===s.length)return new hn(er);const i=o.length;let n=0,r=0,a=0,l=0,c=0;for(let e=0;e<i;e++){const t=o[e],i=s[e];n+=t,r+=i,a+=t*i,l+=t*t,c+=i*i}return(i*a-n*r)/Math.sqrt((i*l-n*n)*(i*c-r*r))}const op={description:ui("Compute the Pearson product-moment correlation coefficient of a dataset."),args:[Id("data_y (range<number>)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (range<number>)",ui("The range representing the array or matrix of independent data."))],compute:function(e,t){return tp(e,t)},isExported:!0},sp=op,ip={description:ui("Value at a given percentile of a dataset."),args:[Id("data (any, range)",ui("The array or range containing the dataset to consider.")),Id("percentile (number)",ui("The percentile whose value within data will be calculated and returned."))],compute:function(e,t){return rp.compute.bind(this)(e,t)},isExported:!0},np={description:ui("Value at a given percentile of a dataset exclusive of 0 and 1."),args:[Id("data (any, range)",ui("The array or range containing the dataset to consider.")),Id("percentile (number)",ui("The percentile, exclusive of 0 and 1, whose value within 'data' will be calculated and returned."))],compute:function(e,t){return{value:Tg([e],t,!1,this.locale),format:mn(e)}},isExported:!0},rp={description:ui("Value at a given percentile of a dataset."),args:[Id("data (any, range)",ui("The array or range containing the dataset to consider.")),Id("percentile (number)",ui("The percentile whose value within data will be calculated and returned."))],compute:function(e,t){return{value:Tg([e],t,!0,this.locale),format:mn(e)}},isExported:!0},ap={description:ui("Compute the coefficients of polynomial regression of the dataset."),args:[Id("data_y (range<number>)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (range<number>)",ui("The range representing the array or matrix of independent data.")),Id("order (number)",ui("The order of the polynomial to fit the data, between 1 and 6."),yg),Id("intercept (boolean, default=TRUE)",ui("A flag specifying whether to compute the intercept or not."),Ig)],compute:function(e,t,o,s={value:!0}){const{flatDataX:i,flatDataY:n}=xg(e,t);return 0===i.length||0===n.length?new hn(er):Tc(n,i,Sn(o,this.locale),An(s))},isExported:!1},lp={description:ui("Predict value by computing a polynomial regression of the dataset."),args:[Id("x (number, range<number>)",ui("The value(s) on the x-axis to forecast.")),Id("data_y (range<number>)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (range<number>)",ui("The range representing the array or matrix of independent data.")),Id("order (number)",ui("The order of the polynomial to fit the data, between 1 and 6."),yg),Id("intercept (boolean, default=TRUE)",ui("A flag specifying whether to compute the intercept or not."),Ig)],compute:function(e,t,o,s,i={value:!0}){const n=Sn(s,this.locale),{flatDataX:r,flatDataY:a}=xg(t,o);if(0===r.length||0===a.length)return new hn(er);const l=Tc(a,r,n,An(i)).flat();return Un(Kn(e),(e=>Dc(l,Sn(e,this.locale),n)))},isExported:!1},cp={description:ui("Value nearest to a specific quartile of a dataset."),args:[Id("data (any, range)",ui("The array or range containing the dataset to consider.")),Id("quartile_number (number)",ui("Which quartile value to return."),wg)],compute:function(e,t){return dp.compute.bind(this)(e,t)},isExported:!0},hp={description:ui("Value nearest to a specific quartile of a dataset exclusive of 0 and 4."),args:[Id("data (any, range)",ui("The array or range containing the dataset to consider.")),Id("quartile_number (number)",ui("Which quartile value, exclusive of 0 and 4, to return."),[{value:1,label:ui("First quartile (25th percentile)")},{value:2,label:ui("Median value (50th percentile)")},{value:3,label:ui("Third quartile (75th percentile)")}])],compute:function(e,t){return{value:Tg([e],{value:.25*Math.trunc(Sn(t,this.locale))},!1,this.locale),format:mn(e)}},isExported:!0},dp={description:ui("Value nearest to a specific quartile of a dataset."),args:[Id("data (any, range)",ui("The array or range containing the dataset to consider.")),Id("quartile_number (number)",ui("Which quartile value to return."),wg)],compute:function(e,t){return{value:Tg([e],{value:.25*Math.trunc(Sn(t,this.locale))},!0,this.locale),format:mn(e)}},isExported:!0},up={description:ui("Returns the rank of a specified value in a dataset."),args:[Id("value (number)",ui("The value whose rank will be determined.")),Id("data (range)",ui("The range containing the dataset to consider.")),Id("is_ascending (boolean, default=FALSE)",ui("Whether to consider the values in data in descending or ascending order."),[{value:!1,label:ui("Descending")},{value:!0,label:ui("Ascending")}])],compute:function(e,t,o={value:!1}){const s=An(o),i=Sn(e,this.locale);let n=1,r=!1;for(const e of t)for(const t of e){if("number"!=typeof t.value)continue;const e=Sn(t,this.locale);e===i?r=!0:e>i!==s&&n++}return r?n:new hn(ui("Value not found in the given data."))},isExported:!0},gp={description:ui("Compute the square of r, the Pearson product-moment correlation coefficient of a dataset."),args:[Id("data_y (range<number>)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (range<number>)",ui("The range representing the array or matrix of independent data."))],compute:function(e,t){const o=tp(e,t);if(o instanceof Error)throw o;return Math.pow(o,2)},isExported:!0},pp={description:ui("Compute the slope of the linear regression."),args:[Id("data_y (range<number>)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (range<number>)",ui("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=xg(e,t);if(0===o.length||0===s.length)return new hn(er);const[[i]]=Rc([o],[s]);return i},isExported:!0},mp={description:ui("Nth smallest element in a data set."),args:[Id("data (any, range)",ui("The array or range containing the dataset to consider.")),Id("n (number)",ui("The rank from smallest to largest of the element to return."))],compute:function(e,t){const o=Math.trunc(Sn(t?.value,this.locale)),s=[];let i,n=0;On([e],(e=>{"number"==typeof e?.value&&(i=Zn(s,e,"nextSmaller","asc",s.length,((e,t)=>e[t].value)),s.splice(i+1,0,e),n++,n>o&&(s.pop(),n--))}));const r=s.pop();return void 0===r?new rn(er):n<o?new rn(ui("Function [[FUNCTION_NAME]] parameter 2 value (%s) is out of range.",o)):r},isExported:!0},fp={description:ui("Compute the Spearman rank correlation coefficient of a dataset."),args:[Id("data_y (range<number>)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (range<number>)",ui("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=xg(t,e);if(0===o.length||0===s.length)return new hn(er);const i=o.length,n=o.map(((e,t)=>[e,s[t]]));n.sort(((e,t)=>e[0]-t[0]));for(let e=0;e<i;++e)n[e][0]=e;n.sort(((e,t)=>e[1]-t[1]));let r=0;for(let e=0;e<i;++e)r+=(n[e][0]-e)**2;return 1-6*r/(i**3-i)},isExported:!1},vp={description:ui("Standard deviation."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the sample.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the sample."))],compute:function(...e){return Math.sqrt(Ep.compute.bind(this)(...e))},isExported:!0},bp={description:ui("Standard deviation of entire population."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the population.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the population."))],compute:function(...e){return Math.sqrt(Rp.compute.bind(this)(...e))},isExported:!0},Sp={description:ui("Standard deviation."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the sample.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the sample."))],compute:function(...e){return Math.sqrt(Tp.compute.bind(this)(...e))},isExported:!0},Cp={description:ui("Standard deviation of sample (text as 0)."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the sample.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the sample."))],compute:function(...e){return Math.sqrt(Ap.compute.bind(this)(...e))},isExported:!0},yp={description:ui("Standard deviation of entire population."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the population.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the population."))],compute:function(...e){return Math.sqrt(Dp.compute.bind(this)(...e))},isExported:!0},Ip={description:ui("Standard deviation of entire population (text as 0)."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the population.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the population."))],compute:function(...e){return Math.sqrt(_p.compute.bind(this)(...e))},isExported:!0},wp={description:ui("Calculates the standard error of the predicted y-value for each x in the regression of a dataset."),args:[Id("data_y (range<number>)",ui("The range representing the array or matrix of dependent data.")),Id("data_x (range<number>)",ui("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=xg(e,t);if(0===o.length||0===s.length)return new hn(er);return Rc([o],[s],!0,!0)[1][2]},isExported:!0},xp={description:ui("Fits points to linear trend derived via least-squares."),args:[Id("known_data_y (number, range<number>)",ui("The array or range containing dependent (y) values that are already known, used to curve fit an ideal linear trend.")),Id("known_data_x (number, range<number>, optional, default={1;2;3;...})",ui("The values of the independent variable(s) corresponding with known_data_y.")),Id("new_data_x (number, range<number>, optional, default=known_data_x)",ui("The data points to return the y values for on the ideal curve fit.")),Id("b (boolean, optional, default=TRUE)",ui("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."),Sg)],compute:function(e,t=[[]],o=[[]],s={value:!0}){return 0===e.length||0===e[0].length?new rn(tr("known_data_y")):Oc(yn(e,"known_data_y"),yn(t,"known_data_x"),yn(o,"new_data_y"),An(s))}},Ep={description:ui("Variance."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the sample.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the sample."))],compute:function(...e){return Rg(e,!0,!1,this.locale)},isExported:!0},Rp={description:ui("Variance of entire population."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the population.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the population."))],compute:function(...e){return Rg(e,!1,!1,this.locale)},isExported:!0},Tp={description:ui("Variance."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the sample.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the sample."))],compute:function(...e){return Rg(e,!0,!1,this.locale)},isExported:!0},Ap={description:ui("Variance of sample (text as 0)."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the sample.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the sample."))],compute:function(...e){return Rg(e,!0,!0,this.locale)},isExported:!0},Dp={description:ui("Variance of entire population."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the population.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the population."))],compute:function(...e){return Rg(e,!1,!1,this.locale)},isExported:!0},_p={description:ui("Variance of entire population (text as 0)."),args:[Id("value1 (number, range<number>)",ui("The first value or range of the population.")),Id("value2 (number, range<number>, repeating)",ui("Additional values or ranges to include in the population."))],compute:function(...e){return Rg(e,!1,!0,this.locale)},isExported:!0};var Fp=Object.freeze({__proto__:null,AVEDEV:Ag,AVERAGE:Dg,AVERAGEA:Pg,AVERAGEIF:Mg,AVERAGEIFS:Ng,AVERAGE_WEIGHTED:Og,CORREL:sp,COUNT:kg,COUNTA:Lg,COVAR:Vg,COVARIANCE_P:Ug,COVARIANCE_S:Hg,FORECAST:zg,GROWTH:Bg,INTERCEPT:$g,LARGE:Gg,LINEST:Wg,LOGEST:qg,MATTHEWS:Zg,MAX:jg,MAXA:Yg,MAXIFS:Xg,MEDIAN:Kg,MIN:Jg,MINA:Qg,MINIFS:ep,PEARSON:op,PERCENTILE:ip,PERCENTILE_EXC:np,PERCENTILE_INC:rp,POLYFIT_COEFFS:ap,POLYFIT_FORECAST:lp,QUARTILE:cp,QUARTILE_EXC:hp,QUARTILE_INC:dp,RANK:up,RSQ:gp,SLOPE:pp,SMALL:mp,SPEARMAN:fp,STDEV:vp,STDEVA:Cp,STDEVP:yp,STDEVPA:Ip,STDEV_P:bp,STDEV_S:Sp,STEYX:wp,TREND:xp,VAR:Ep,VARA:Ap,VARP:Dp,VARPA:_p,VAR_P:Rp,VAR_S:Tp});function Op(e,t,o,s){const i=new Map,n=e.length;for(let t=n-1;t>=0;t--)i.set(En(e[t][0]).toUpperCase(),t);const r=t?.value;if("number"!=typeof r&&"string"!=typeof r)throw new rn(ui("The field must be a number or a string"));let a;if("number"==typeof r){if(a=Math.trunc(r)-1,a<0||n-1<a)throw new rn(ui("The field (%(fieldValue)s) must be one of %(dimRowDB)s or must be a number between 1 and %s inclusive.",{fieldValue:r.toString(),dimRowDB:n.toString()}))}else{const e=En(t).toUpperCase();if(a=i.get(e)??-1,-1===a)throw new rn(ui("The field (%s) must be one of %s.",En(t),[...i.keys()].toString()))}const l=o[0].length;if(l<2)throw new rn(ui("The criteria range contains %s row, it must be at least 2 rows.",l.toString()));let c=new Set;const h=e[0].length;for(let t=1;t<l;t++){const n=[];let r=!0;for(let s=0;s<o.length;s++){const a=En(o[s][0]).toUpperCase(),l=i.get(a),c=o[s][t];if(null!==c.value){if(void 0===l){r=!1;break}n.push([e[l].slice(1,h)]),n.push(c)}}if(r){if(!(n.length>0)){c=new Set(Array(h-1).keys());break}qn(n,((e,t)=>{c.add(t)}),s,!0)}}const d=e[a];return[...c].map((e=>d[e+1]))}const Pp=[Id("database (range)",ui("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.")),Id("field (number, string)",ui("Indicates which column in database contains the values to be extracted and operated on.")),Id("criteria (range)",ui("An array or range containing zero or more criteria to filter the database values by before operating."))],Mp={description:ui("Average of a set of values from a table-like range."),args:Pp,compute:function(e,t,o){const s=Op(e,t,o,this.locale);return Dg.compute.bind(this)([s])},isExported:!0},Np={description:ui("Counts values from a table-like range."),args:Pp,compute:function(e,t,o){const s=Op(e,t,o,this.locale);return kg.compute.bind(this)([s])},isExported:!0},kp={description:ui("Counts values and text from a table-like range."),args:Pp,compute:function(e,t,o){const s=Op(e,t,o,this.locale);return Lg.compute.bind(this)([s])},isExported:!0},Lp={description:ui("Single value from a table-like range."),args:Pp,compute:function(e,t,o){const s=Op(e,t,o,this.locale);return 1!==s.length?new rn(ui("More than one match found in DGET evaluation.")):s[0]},isExported:!0},Vp={description:ui("Maximum of values from a table-like range."),args:Pp,compute:function(e,t,o){const s=Op(e,t,o,this.locale);return jg.compute.bind(this)([s])},isExported:!0},Up={description:ui("Minimum of values from a table-like range."),args:Pp,compute:function(e,t,o){const s=Op(e,t,o,this.locale);return Jg.compute.bind(this)([s])},isExported:!0},Hp={description:ui("Product of values from a table-like range."),args:Pp,compute:function(e,t,o){const s=Op(e,t,o,this.locale);return Zu.compute.bind(this)([s])},isExported:!0},zp={description:ui("Standard deviation of population sample from table."),args:Pp,compute:function(e,t,o){const s=Op(e,t,o,this.locale);return vp.compute.bind(this)([s])},isExported:!0},Bp={description:ui("Standard deviation of entire population from table."),args:Pp,compute:function(e,t,o){const s=Op(e,t,o,this.locale);return yp.compute.bind(this)([s])},isExported:!0},$p={description:ui("Sum of values from a table-like range."),args:Pp,compute:function(e,t,o){const s=Op(e,t,o,this.locale);return hg.compute.bind(this)([s])},isExported:!0},Gp={description:ui("Variance of population sample from table-like range."),args:Pp,compute:function(e,t,o){const s=Op(e,t,o,this.locale);return Ep.compute.bind(this)([s])},isExported:!0},Wp={description:ui("Variance of a population from a table-like range."),args:Pp,compute:function(e,t,o){const s=Op(e,t,o,this.locale);return Dp.compute.bind(this)([s])},isExported:!0};var qp=Object.freeze({__proto__:null,DAVERAGE:Mp,DCOUNT:Np,DCOUNTA:kp,DGET:Lp,DMAX:Vp,DMIN:Up,DPRODUCT:Hp,DSTDEV:zp,DSTDEVP:Bp,DSUM:$p,DVAR:Gp,DVARP:Wp});const Zp=ui("The cashflow_amounts and cashflow_dates ranges must have the same dimensions."),jp=ui("There must be both positive and negative values in cashflow_amounts."),Yp=e=>ui("The cost (%s) must be positive or null.",e),Xp=e=>ui("The frequency (%s) must be one of %s",e,[1,2,4].toString()),Kp=e=>ui("The day_count_convention (%s) must be between 0 and 4 inclusive.",e),Jp=e=>ui("The depreciation factor (%s) must be strictly positive.",e),Qp=e=>ui("The discount (%s) must be strictly positive.",e),em=e=>ui("The discount (%s) must be smaller than 1.",e),tm=e=>ui("All the dates should be greater or equal to the first date in cashflow_dates (%s).",e),om=(e,t)=>ui("The first_period (%(first)s) must be smaller or equal to the last_period (%(last)s).",{first:e,last:t}),sm=e=>ui("The first_period (%s) must be strictly positive.",e),im=e=>ui("The investment (%s) must be strictly positive.",e),nm=(e,t)=>ui("The last_period (%(last)s) must be smaller or equal to the number_of_periods (%(nPeriods)s).",{last:e,nPeriods:t}),rm=e=>ui("The last_period (%s) must be strictly positive.",e),am=e=>ui("The life (%s) must be strictly positive.",e),lm=(e,t)=>ui("The maturity (%(maturity)s) must be strictly greater than the settlement (%(settlement)s).",{maturity:t,settlement:e}),cm=e=>ui("The number_of_periods (%s) must be strictly positive.",e),hm=e=>ui("The period must be between 1 and number_of_periods (%s)",e),dm=e=>ui("The periods_by_year (%s) must be strictly positive.",e),um=(e,t)=>ui("The period (%(period)s) must be less than or equal life (%(life)s).",{period:e,life:t}),gm=e=>ui("The period (%s) must be strictly positive.",e),pm=e=>ui("The present_value (%s) must be strictly positive.",e),mm=e=>ui("The price (%s) must be strictly positive.",e),fm=e=>ui("The rate_guess (%s) must be strictly greater than -1.",e),vm=e=>ui("The rate (%s) must be positive or null.",e),bm=e=>ui("The rate (%s) must be strictly positive.",e),Sm=e=>ui("The redemption (%s) must be strictly positive.",e),Cm=e=>ui("The salvage (%s) must be positive or null.",e),ym=(e,t)=>ui("The settlement date (%(settlement)s) must at most one year after the maturity date (%(maturity)s).",{settlement:e,maturity:t}),Im=e=>ui("The unit (%s) must be strictly positive.",e),wm=e=>ui("The yield (%s) must be positive or null.",e);function xm(e){return e.some((e=>e>0))&&e.some((e=>e<0))}function Em(e){return![0,1,2,3,4].includes(e)}function Rm(e){return![1,2,4].includes(e)}function Tm(e,t,o){const s=Dn(e,o),i=Dn(t,o),n=Dn(e,o);return n.setFullYear(s.getFullYear()+1),i.getTime()<=n.getTime()}const Am=[{value:0,label:ui("US (NASD) 30/360")},{value:1,label:ui("Actual/Actual")},{value:2,label:ui("Actual/360")},{value:3,label:ui("Actual/365")},{value:4,label:ui("European 30/360")}];var Dm;!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"}(Dm||(Dm={}));const _m={description:ui("Converts year/month/day into a date."),args:[Id("year (number)",ui("The year component of the date.")),Id("month (number)",ui("The month component of the date.")),Id("day (number)",ui("The day component of the date."))],compute:function(e,t,o){let s=Math.trunc(Sn(e,this.locale));const i=Math.trunc(Sn(t,this.locale)),n=Math.trunc(Sn(o,this.locale));if(s<0||s>9999)return new rn(ui("The year (%s) must be between 0 and 9999 inclusive.",s.toString()));s<1900&&(s+=1900);const r=Hi(new Ii(s,i-1,n));return r<0?new rn(ui("The function [[FUNCTION_NAME]] result must be greater than or equal 01/01/1900.")):{value:r,format:this.locale.dateFormat}},isExported:!0},Fm={description:ui("Calculates the number of days, months, or years between two dates."),args:[Id("start_date (date)",ui("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.")),Id("end_date (date)",ui("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.")),Id("unit (string)",ui("A text abbreviation for unit of time."),[{value:"Y",label:ui("The number of whole years between start_date and end_date")},{value:"M",label:ui("The number of whole months between start_date and end_date")},{value:"D",label:ui("The number of days between start_date and end_date")},{value:"MD",label:ui("The number of days between start_date and end_date after subtracting whole months")},{value:"YM",label:ui("The number of whole months between start_date and end_date after subtracting whole years")},{value:"YD",label:ui("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=En(o).toUpperCase();if(!Object.values(Dm).includes(s))return new rn(((e,t)=>{const o=e.map((e=>`'${e}'`)).join(", ");return ui("The function [[FUNCTION_NAME]] has an argument with value '%s'. It should be one of: %s.",t,o)})(Object.values(Dm),En(o)));const i=Math.trunc(Sn(e,this.locale)),n=Math.trunc(Sn(t,this.locale)),r=Ui(i),a=Ui(n);if(n<i)return new rn(ui("start_date (%s) should be on or before end_date (%s).",r.toLocaleDateString(),a.toLocaleDateString()));switch(s){case Dm.WHOLE_YEARS:return Yi(r,a);case Dm.WHOLE_MONTHS:return Zi(r,a);case Dm.WHOLE_DAYS:return ji(r,a);case Dm.MONTH_WITHOUT_WHOLE_YEARS:return Zi(r,a)-12*Yi(r,a);case Dm.DAYS_WITHOUT_WHOLE_MONTHS:let e=a.getDate()-r.getDate();if(e<0){e=Bi(new Ii(a.getFullYear(),a.getMonth()-1,1))-Math.abs(e)}return e;case Dm.DAYS_BETWEEN_NO_MORE_THAN_ONE_YEAR:{if(function(e,t){return qi(e,t,1)<1}(i,n))return ji(r,a);const e=new Ii(r.getFullYear(),a.getMonth(),a.getDate());let t=ji(r,e);return t<0&&(e.setFullYear(r.getFullYear()+1),t=ji(r,e)),t}}},isExported:!0},Om={description:ui("Converts a date string to a date value."),args:[Id("date_string (string)",ui("The string representing the date."))],compute:function(e){const t=En(e),o=Vi(t,this.locale);return null===o?new rn(ui("The date_string (%s) cannot be parsed to date/time.",t.toString())):Math.trunc(o.value)},isExported:!0},Pm={description:ui("Day of the month that a specific date falls on."),args:[Id("date (string)",ui("The date from which to extract the day."))],compute:function(e){return Dn(e,this.locale).getDate()},isExported:!0},Mm={description:ui("Number of days between two dates."),args:[Id("end_date (date)",ui("The end of the date range.")),Id("start_date (date)",ui("The start of the date range."))],compute:function(e,t){const o=Dn(e,this.locale),s=Dn(t,this.locale),i=o.getTime()-s.getTime();return Math.round(i/xi)},isExported:!0},Nm={description:ui("Number of days between two dates on a 360-day year (months of 30 days)."),args:[Id("start_date (date)",ui("The start date to consider in the calculation.")),Id("end_date (date)",ui("The end date to consider in the calculation.")),Id("method (boolean, default=false)",ui("An indicator of what day count method to use."),[{value:!1,label:ui("U.S. NASD method (default)")},{value:!0,label:ui("European method")}])],compute:function(e,t,o={value:false}){const s=Math.trunc(Sn(e,this.locale)),i=Math.trunc(Sn(t,this.locale)),n=qi(s,i,An(o)?4:0);return Math.sign(i-s)*Math.round(360*n)},isExported:!0},km={description:ui("Date a number of months before/after another date."),args:[Id("start_date (date)",ui("The date from which to calculate the result.")),Id("months (number)",ui("The number of months before (negative) or after (positive) 'start_date' to calculate."))],compute:function(e,t){return{value:Hi(Gi(Dn(e,this.locale),Math.trunc(Sn(t,this.locale)),!1)),format:this.locale.dateFormat}},isExported:!0},Lm={description:ui("Last day of a month before or after a date."),args:[Id("start_date (date)",ui("The date from which to calculate the result.")),Id("months (number)",ui("The number of months before (negative) or after (positive) 'start_date' to consider."))],compute:function(e,t){const o=Dn(e,this.locale),s=Math.trunc(Sn(t,this.locale)),i=o.getFullYear(),n=o.getMonth();return{value:Hi(new Ii(i,n+s+1,0)),format:this.locale.dateFormat}},isExported:!0},Vm={description:ui("Hour component of a specific time."),args:[Id("time (date)",ui("The time from which to calculate the hour component."))],compute:function(e){return Dn(e,this.locale).getHours()},isExported:!0},Um={description:ui("ISO week number of the year."),args:[Id("date (date)",ui("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=Dn(e,this.locale),o=t.getFullYear();let s=1;for(;4!==new Ii(o,0,s).getDay();)s+=1;const i=new Ii(o,0,s-3);let n=31;for(;4!==new Ii(o,11,n).getDay();)n-=1;const r=new Ii(o,11,n+3);let a,l;switch(a=i.getTime()<=t.getTime()?t.getTime()<=r.getTime()?0:1:-1,a){case 0:l=i;break;case 1:l=new Ii(o,11,n+3+1);break;case-1:let e=1;for(;4!==new Ii(o-1,0,e).getDay();)e+=1;l=new Ii(o-1,0,e-3)}const c=(t.getTime()-l.getTime())/xi;return Math.floor(c/7)+1},isExported:!0},Hm={description:ui("Minute component of a specific time."),args:[Id("time (date)",ui("The time from which to calculate the minute component."))],compute:function(e){return Dn(e,this.locale).getMinutes()},isExported:!0},zm={description:ui("Month of the year a specific date falls in"),args:[Id("date (date)",ui("The date from which to extract the month."))],compute:function(e){return Dn(e,this.locale).getMonth()+1},isExported:!0},Bm={description:ui("Net working days between two provided days."),args:[Id("start_date (date)",ui("The start date of the period from which to calculate the number of net working days.")),Id("end_date (date)",ui("The end date of the period from which to calculate the number of net working days.")),Id("holidays (date, range<date>, optional)",ui("A range or array constant containing the date serial numbers to consider holidays."))],compute:function(e,t,o){return Wm.compute.bind(this)(e,t,{value:1},o)},isExported:!0};function $m(e){const t=e?.value;if("string"==typeof t){rc(7===t.length&&[...t].every((e=>"0"===e||"1"===e)),ui('When weekend is a string (%s) it must be composed of "0" or "1".',t));const e=[];for(let o=0;o<7;o++)"1"===t[o]&&e.push((o+1)%7);return e}if("number"==typeof t)return rc(1<=t&&t<=7||11<=t&&t<=17,ui("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 rn(ui("The weekend must be a number or a string."))}const Gm=[{value:1,label:ui("Saturday/Sunday are weekends")},{value:2,label:ui("Sunday/Monday are weekends")},{value:3,label:ui("Monday/Tuesday are weekends")},{value:4,label:ui("Tuesday/Wednesday are weekends")},{value:5,label:ui("Wednesday/Thursday are weekends")},{value:6,label:ui("Thursday/Friday are weekends")},{value:7,label:ui("Friday/Saturday are weekends")},{value:11,label:ui("Sunday is the only weekend")},{value:12,label:ui("Monday is the only weekend")},{value:13,label:ui("Tuesday is the only weekend")},{value:14,label:ui("Wednesday is the only weekend")},{value:15,label:ui("Thursday is the only weekend")},{value:16,label:ui("Friday is the only weekend")},{value:17,label:ui("Saturday is the only weekend")}],Wm={description:ui("Net working days between two dates (specifying weekends)."),args:[Id("start_date (date)",ui("The start date of the period from which to calculate the number of net working days.")),Id("end_date (date)",ui("The end date of the period from which to calculate the number of net working days.")),Id("weekend (any, default=1)",ui("A number or string representing which days of the week are considered weekends."),Gm),Id("holidays (date, range<date>, optional)",ui("A range or array constant containing the dates to consider as holidays."))],compute:function(e,t,o={value:1},s){const i=Dn(e,this.locale),n=Dn(t,this.locale),r=$m(o),a=new Set;void 0!==s&&On([s],(e=>{const t=Dn(e,this.locale);a.add(t.getTime())}));const l=i.getTime()>n.getTime(),c=Ii.fromTimestamp((l?i:n).getTime()),h=Ii.fromTimestamp((l?n:i).getTime()),d=c.getTime();let u=h.getTime(),g=0;for(;u<=d;)r.includes(h.getDay())||a.has(u)||(g+=1),h.setDate(h.getDate()+1),u=h.getTime();return l?-g:g},isExported:!0},qm={description:ui("Current date and time as a date value."),args:[],compute:function(){const e=Ii.now(),t=e.getTime()-wi.getTime(),o=e.getHours()/24+e.getMinutes()/1440+e.getSeconds()/86400;return{value:Math.floor(t/xi)+o,format:tc(this.locale)}},isExported:!0},Zm={description:ui("Minute component of a specific time."),args:[Id("time (date)",ui("The time from which to calculate the second component."))],compute:function(e){return Dn(e,this.locale).getSeconds()},isExported:!0},jm={description:ui("Converts hour/minute/second into a time."),args:[Id("hour (number)",ui("The hour component of the time.")),Id("minute (number)",ui("The minute component of the time.")),Id("second (number)",ui("The second component of the time."))],compute:function(e,t,o){let s=Math.trunc(Sn(e,this.locale)),i=Math.trunc(Sn(t,this.locale)),n=Math.trunc(Sn(o,this.locale));return i+=Math.floor(n/60),n=n%60+(n<0?60:0),s+=Math.floor(i/60),i=i%60+(i<0?60:0),s%=24,s<0?new rn(ui("The function [[FUNCTION_NAME]] result cannot be negative")):{value:s/24+i/1440+n/86400,format:this.locale.timeFormat}},isExported:!0},Ym={description:ui("Converts a time string into its serial number representation."),args:[Id("time_string (string)",ui("The string that holds the time representation."))],compute:function(e){const t=En(e),o=Vi(t,this.locale);if(null===o)return new rn(ui("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},Xm={description:ui("Current date as a date value."),args:[],compute:function(){const e=Ii.now();return{value:Hi(new Ii(e.getFullYear(),e.getMonth(),e.getDate())),format:this.locale.dateFormat}},isExported:!0},Km={description:ui("Day of the week of the date provided (as number)."),args:[Id("date (date)",ui("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.")),Id("type (number, default=1)",ui("A number indicating which numbering system to use to represent weekdays. By default, counts starting with Sunday = 1."),[{value:1,label:ui("Numbers 1 (Sunday) trough 7 (Saturday)")},{value:2,label:ui("Numbers 1 (Monday) trough 7 (Sunday)")},{value:3,label:ui("Numbers 0 (Monday) trough 6 (Sunday)")},{value:11,label:ui("Numbers 1 (Monday) trough 7 (Sunday)")},{value:12,label:ui("Numbers 1 (Tuesday) trough 7 (Monday)")},{value:13,label:ui("Numbers 1 (Wednesday) trough 7 (Tuesday)")},{value:14,label:ui("Numbers 1 (Thursday) trough 7 (Wednesday)")},{value:15,label:ui("Numbers 1 (Friday) trough 7 (Thursday)")},{value:16,label:ui("Numbers 1 (Saturday) trough 7 (Friday)")},{value:17,label:ui("Numbers 1 (Sunday) trough 7 (Saturday)")}])],compute:function(e,t={value:1}){const o=Dn(e,this.locale),s=Math.round(Sn(t,this.locale)),i=o.getDay();if(!(1<=s&&s<=3||11<=s&&s<=17))return new rn(ui("The type (%s) must be between 1 and 3 or between 11 and 17.",s));switch(s){case 1:return i+1;case 2:return 0===i?7:i;case 3:return 0===i?6:i-1}const n=(i+1-(s-10)+7)%7;return 0===n?7:n},isExported:!0},Jm={description:ui("Week number of the year."),args:[Id("date (date)",ui("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.")),Id("type (number, default=1)",ui("A number representing the day that a week starts on. Sunday = 1."),[{value:1,label:ui("Sunday")},{value:2,label:ui("Monday")},{value:11,label:ui("Monday")},{value:12,label:ui("Tuesday")},{value:13,label:ui("Wednesday")},{value:14,label:ui("Thursday")},{value:15,label:ui("Friday")},{value:16,label:ui("Saturday")},{value:17,label:ui("Sunday")},{value:21,label:ui("ISO week number (Monday as first day of the week)")}])],compute:function(e,t={value:1}){const o=Dn(e,this.locale),s=Math.round(Sn(t,this.locale));if(![1,2,11,12,13,14,15,16,17,21].includes(s))return new rn(ui("The type (%s) is out of range.",s.toString()));if(21===s)return Um.compute.bind(this)(e);let i;i=1===s||2===s?s-1:s-10==7?0:s-10;const n=o.getFullYear();let r=1,a=new Ii(n,0,r);for(;a.getDay()!==i;)r+=1,a=new Ii(n,0,r);const l=(o.getTime()-a.getTime())/xi;return l<0?1:Math.floor(l/7)+(1===r?1:2)},isExported:!0},Qm={description:ui("Date after a number of workdays."),args:[Id("start_date (date)",ui("The date from which to begin counting.")),Id("num_days (number)",ui("The number of working days to advance from start_date. If negative, counts backwards.")),Id("holidays (date, range<date>, optional)",ui("A range or array constant containing the dates to consider holidays."))],compute:function(e,t,o={value:null}){return ef.compute.bind(this)(e,t,{value:1},o)},isExported:!0},ef={description:ui("Date after a number of workdays (specifying weekends)."),args:[Id("start_date (date)",ui("The date from which to begin counting.")),Id("num_days (number)",ui("The number of working days to advance from start_date. If negative, counts backwards.")),Id("weekend (any, default=1)",ui("A number or string representing which days of the week are considered weekends."),Gm),Id("holidays (date, range<date>, optional)",ui("A range or array constant containing the dates to consider holidays."))],compute:function(e,t,o={value:1},s){const i=Dn(e,this.locale),n=Math.trunc(Sn(t,this.locale));if("1111111"===o.value)return new rn(ui("The weekend must be different from '1111111'."));const r=$m(o),a=new Set;void 0!==s&&On([s],(e=>{const t=Dn(e,this.locale);a.add(t.getTime())}));const l=Ii.fromTimestamp(i.getTime());let c=l.getTime();const h=Math.sign(n);let d=Math.abs(n);for(;d>0;)l.setDate(l.getDate()+h),c=l.getTime(),r.includes(l.getDay())||a.has(c)||(d-=1);const u=c-wi.getTime();return{value:Math.round(u/xi),format:this.locale.dateFormat}},isExported:!0},tf={description:ui("Year specified by a given date."),args:[Id("date (date)",ui("The date from which to extract the year."))],compute:function(e){return Dn(e,this.locale).getFullYear()},isExported:!0},of={description:ui("Exact number of years between two dates."),args:[Id("start_date (date)",ui("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.")),Id("end_date (date)",ui("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.")),Id("day_count_convention (number, default=0)",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o={value:0}){const s=Math.trunc(Sn(e,this.locale)),i=Math.trunc(Sn(t,this.locale)),n=Math.trunc(Sn(o,this.locale));return s<0?new rn(ui("The start_date (%s) must be positive or null.",s)):i<0?new rn(ui("The end_date (%s) must be positive or null.",i)):0>n||n>4?new rn(ui("The day_count_convention (%s) must be between 0 and 4 inclusive.",n)):qi(s,i,n)}},sf={description:ui("First day of the month preceding a date."),args:[Id("date (date)",ui("The date from which to calculate the result."))],compute:function(e){const t=Dn(e,this.locale),o=t.getFullYear(),s=t.getMonth();return{value:Hi(new Ii(o,s,1)),format:this.locale.dateFormat}}},nf={description:ui("Last day of the month following a date."),args:[Id("date (date)",ui("The date from which to calculate the result."))],compute:function(e){return Lm.compute.bind(this)(e,{value:0})}},rf={description:ui("Quarter of the year a specific date falls in"),args:[Id("date (date)",ui("The date from which to extract the quarter."))],compute:function(e){return Math.ceil((Dn(e,this.locale).getMonth()+1)/3)}},af={description:ui("First day of the quarter of the year a specific date falls in."),args:[Id("date (date)",ui("The date from which to calculate the start of quarter."))],compute:function(e){const t=rf.compute.bind(this)(e),o=tf.compute.bind(this)(e);return{value:Hi(new Ii(o,3*(t-1),1)),format:this.locale.dateFormat}}},lf={description:ui("Last day of the quarter of the year a specific date falls in."),args:[Id("date (date)",ui("The date from which to calculate the end of quarter."))],compute:function(e){const t=rf.compute.bind(this)(e),o=tf.compute.bind(this)(e);return{value:Hi(new Ii(o,3*t,0)),format:this.locale.dateFormat}}},cf={description:ui("First day of the year a specific date falls in."),args:[Id("date (date)",ui("The date from which to calculate the start of the year."))],compute:function(e){const t=tf.compute.bind(this)(e);return{value:Hi(new Ii(t,0,1)),format:this.locale.dateFormat}}},hf={description:ui("Last day of the year a specific date falls in."),args:[Id("date (date)",ui("The date from which to calculate the end of the year."))],compute:function(e){const t=tf.compute.bind(this)(e);return{value:Hi(new Ii(t+1,0,0)),format:this.locale.dateFormat}}};var df=Object.freeze({__proto__:null,DATE:_m,DATEDIF:Fm,DATEVALUE:Om,DAY:Pm,DAYS:Mm,DAYS360:Nm,EDATE:km,EOMONTH:Lm,HOUR:Vm,ISOWEEKNUM:Um,MINUTE:Hm,MONTH:zm,MONTH_END:nf,MONTH_START:sf,NETWORKDAYS:Bm,NETWORKDAYS_INTL:Wm,NOW:qm,QUARTER:rf,QUARTER_END:lf,QUARTER_START:af,SECOND:Zm,TIME:jm,TIMEVALUE:Ym,TODAY:Xm,WEEKDAY:Km,WEEKNUM:Jm,WORKDAY:Qm,WORKDAY_INTL:ef,YEAR:tf,YEARFRAC:of,YEAR_END:hf,YEAR_START:cf});const uf={description:ui("Compare two numeric values, returning 1 if they're equal."),args:[Id("number1 (number)",ui("The first number to compare.")),Id("number2 (number, default=0)",ui("The second number to compare."))],compute:function(e,t={value:0}){return Sn(e,this.locale)===Sn(t,this.locale)?1:0},isExported:!0};var gf=Object.freeze({__proto__:null,DELTA:uf});const pf=[r.number,r.error,r.text,r.boolean];function mf(e){const t="asc"===e?1:-1;return(e,o)=>{if(e.type===r.empty)return o.type===r.empty?0:1;if(o.type===r.empty)return-1;let s=pf.indexOf(e.type)-pf.indexOf(o.type);return 0===s&&(s=e.type===r.text||e.type===r.error?e.value.localeCompare(o.value):e.value-o.value),t*s}}function ff(e,t,o,s,i){let n=s.right>s.left;if(e.model.getters.doesIntersectMerge(t,s)){let o;n=!1;for(let i=s.top;i<=s.bottom;i++){o=[];for(let n=s.left;n<=s.right;n++){const s=e.model.getters.getMerge({sheetId:t,col:n,row:i});s&&!o.includes(s.id.toString())&&o.push(s.id.toString())}if(o.length>=2){n=!0;break}}}if(n)return void vf(e,t,o,s,i);const r=e.model.getters.getContiguousZone(t,s);Ko(r,s)?vf(e,t,o,s,i):e.askConfirmation(ui("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?"),(()=>vf(e,t,o,r,i)),(()=>vf(e,t,o,s,i)))}function vf(e,t,o,s,i,n){const r=e.model.dispatch("SORT_CELLS",{sheetId:t,col:o.col,row:o.row,zone:s,sortDirection:i,sortOptions:n});if(r.isCancelledBecause("InvalidSortZone")){const{col:t,row:i}=o;e.model.selection.selectZone({cell:{col:t,row:i},zone:s}),e.raiseError(ui("Cannot sort. To sort, select only cells or only merges that have the same size."))}if(r.isCancelledBecause("SortZoneWithArrayFormulas")){const{col:t,row:i}=o;e.model.selection.selectZone({cell:{col:t,row:i},zone:s}),e.raiseError(ui("Cannot sort a zone with array formulas."))}}function bf(e,t,...o){for(let e=0;e<o.length;e++){const t=e%2==0?"sort_column":"is_ascending";rc(void 0!==o[e],ui("Value for parameter %s is missing in [[FUNCTION_NAME]].",t))}const s=[],i=[],n=e.length;for(let r=0;r<o.length;r+=2){s.push(An(fc(o[r+1])?.value)?"asc":"desc");const a=o[r];if(E(a)&&(a.length>1||a[0].length>1))rc(1===a.length&&a[0].length===n,ui("Wrong size for %s. Expected a range of size 1x%s. Got %sx%s.",`sort_column${r+1}`,n,a.length,a[0].length)),i.push(a.flat().map((e=>e.value)));else{const o=Sn(fc(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 a={desc:mf("desc"),asc:mf("asc")},l=Ct(0,e.length);return l.sort(((e,t)=>{for(const[o,n]of i.entries()){const i=n[e],l=n[t],c={value:i,type:null===i?r.empty:"string"==typeof i?r.text:typeof i},h={value:l,type:null===l?r.empty:"string"==typeof l?r.text:typeof l},d=a[s[o]](c,h);if(0!==d)return d}return 0})),l.map((t=>e[t]))}const Sf={description:ui("Returns a filtered version of the source range, returning only rows or columns that meet the specified conditions."),args:[Id("range (any, range<any>)",ui("The data to be filtered.")),Id("condition1 (boolean, range<boolean>)",ui("A column or row containing true or false values corresponding to the first column or row of range.")),Id("condition2 (boolean, range<boolean>, repeating)",ui("Additional column or row containing true or false values."))],compute:function(e,...t){let o=Kn(e);const s=t.map((e=>Un(Kn(e),(e=>e.value))));for(const e of s)if(!lc(e))return new rn(ui("The arguments condition must be a single column or row."));if(!cc(...t))return new rn(ui("The arguments conditions must have the same dimensions."));const i=s.map((e=>e.flat())),n=1===s[0].length?"row":"col";if(o="row"===n?Hn(o):o,i.some((e=>e.length!==o.length)))return new rn(ui("FILTER has mismatched sizes on the range and conditions."));const r=[];for(let e=0;e<o.length;e++){const t=o[e];i.every((t=>("boolean"==typeof t[e]||"number"==typeof t[e])&&t[e]))&&r.push(t)}return r.length?"row"===n?Hn(r):r:new hn(ui("No match found in FILTER evaluation"))},isExported:!1},Cf={description:ui("Sorts the rows of a given array or range by the values in one or more columns."),args:[Id("range (range)",ui("The data to be sorted.")),Id("sort_column (any, range<number>, repeating)",ui("The index of the column in range or a range outside of range containing the values by which to sort.")),Id("is_ascending (boolean, repeating)",ui("TRUE or FALSE indicating whether to sort sort_column in ascending order."),[{value:!0,label:ui("Ascending")},{value:!1,label:ui("Descending")}])],compute:function(e,...t){const o=Hn(e);return Hn(bf(o,this.locale,...t))},isExported:!0},yf={description:ui("Returns the first n items in a data set after performing a sort."),args:[Id("range (range)",ui("The data to be sorted.")),Id("n (number)",ui("The number of items to return.")),Id("display_ties_mode (number, default=0)",ui("A number representing the way to display ties.")),Id("sort_column (number, range<number>, repeating)",ui("The index of the column in range or a range outside of range containing the values by which to sort.")),Id("is_ascending (boolean, repeating)",ui("TRUE or FALSE indicating whether to sort sort_column in ascending order."),[{value:!0,label:ui("Ascending")},{value:!1,label:ui("Descending")}])],compute:function(e,t,...o){const s=Sn(t?.value??1,this.locale),i=o.length%2==0?0:Sn(o[0]?.value,this.locale),n=o.length%2==0?o:o.slice(1);if(s<0)return new rn(ui("Wrong value of 'n'. Expected a positive number. Got %s.",s));if(i<0||i>3)return new rn(ui("Wrong value of 'display_ties_mode'. Expected a positive number between 0 and 3. Got %s.",i));const r=bf(Hn(e),this.locale,...n),a=(e,t)=>JSON.stringify(r[e].map((e=>e.value)))===JSON.stringify(r[t].map((e=>e.value)));switch(i){case 0:return Hn(r.slice(0,s));case 1:for(let e=s;e<r.length;e++)if(!a(e,s-1))return Hn(r.slice(0,e));return Hn(r);case 2:{const e=[r[0]];for(let t=1;t<r.length;t++)for(let o=0;o<t&&!a(t,o);o++)o===t-1&&e.push(r[t]);return Hn(e.slice(0,s))}case 3:{const e=[r[0]];let t=1;for(let o=1;o<r.length&&(a(o,o-1)||t++,!(t>s));o++)e.push(r[o]);return Hn(e)}}},isExported:!1},If={description:ui("Unique rows in the provided source range."),args:[Id("range (any, range<any>)",ui("The data to filter by unique entries.")),Id("by_column (boolean, default=FALSE)",ui("Whether to filter the data by columns or by rows."),[{value:!0,label:ui("Return unique columns")},{value:!1,label:ui("Return unique rows")}]),Id("exactly_once (boolean, default=FALSE)",ui("Whether to return only entries with no duplicates."),[{value:!0,label:ui("Return items that appear exactly once")},{value:!1,label:ui("Return every distinct item")}])],compute:function(e={value:""},t,o){if(!E(e))return[[e]];const s=An(t?.value)||!1,i=An(o?.value)||!1;s||(e=Hn(e));const n=new Map;for(const t of e){const e=JSON.stringify(t.map((e=>e.value))),o=n.get(e);o?o.count++:n.set(e,{data:t,count:1})}const r=[];for(const e of n.values())i&&e.count>1||r.push(e.data);return r.length?s?r:Hn(r):new rn(ui("No unique values found"))},isExported:!0};var wf=Object.freeze({__proto__:null,FILTER:Sf,SORT:Cf,SORTN:yf,UNIQUE:If});const xf=[{value:1,label:ui("Annual")},{value:2,label:ui("Semi-annual")},{value:4,label:ui("Quarterly")}],Ef=[{value:0,label:ui("End of period (default)")},{value:1,label:ui("Beginning of period")}],Rf=[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("frequency (number)",ui("The number of interest or coupon payments per year (1, 2, or 4)."),xf),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."),Am)];function Tf(e,t,o,s,i=1e-10,n){let r,a,l,c,h=o,d=!1,u=0;do{l=e(h),isNaN(l)?(rc(u<s&&void 0!==n,ui("Function [[FUNCTION_NAME]] didn't find any result.")),u++,h=n(c),c=h):(r=h-l/t(h),a=Math.abs(r-h),h=r,d=a<i||Math.abs(l)<i,rc(u<s,ui("Function [[FUNCTION_NAME]] didn't find any result.")),u++)}while(!d);return h}const Af={description:ui("Accrued interest of security paying at maturity."),args:[Id("issue (date)",ui("The date the security was initially issued.")),Id("maturity (date)",ui("The maturity date of the security.")),Id("rate (number)",ui("The annualized rate of interest.")),Id("redemption (number)",ui("The redemption amount per 100 face value, or par.")),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o,s,i={value:0}){const n=Math.trunc(Sn(e,this.locale)),r=Math.trunc(Sn(t,this.locale)),a=Sn(s,this.locale),l=Sn(o,this.locale),c=Math.trunc(Sn(i,this.locale));if(n<0)return new rn((e=>ui("The issue (%s) must be positive or null.",e))(n));if(n>=r)return new rn(lm(n,r));if(Em(c))return new rn(Kp(c));if(a<=0)return new rn(Sm(a));if(l<=0)return new rn(bm(l));return a*l*qi(n,r,c)},isExported:!0},Df={description:ui("Depreciation for an accounting period."),args:[Id("cost (number)",ui("The initial cost of the asset.")),Id("purchase_date (date)",ui("The date the asset was purchased.")),Id("first_period_end (date)",ui("The date the first period ended.")),Id("salvage (number)",ui("The value of the asset at the end of depreciation.")),Id("period (number)",ui("The single period within life for which to calculate depreciation.")),Id("rate (number)",ui("The deprecation rate.")),Id("day_count_convention (number, optional)",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o,s,i,n,r={value:0}){r=r||0;const a=Sn(e,this.locale),l=Math.trunc(Sn(t,this.locale)),c=Math.trunc(Sn(o,this.locale)),h=Sn(s,this.locale),d=Sn(i,this.locale),u=Sn(n,this.locale),g=Math.trunc(Sn(r,this.locale));if(a<=0)return new rn((e=>ui("The cost (%s) must be strictly positive.",e))(a));if(l<0)return new rn((e=>ui("The purchase_date (%s) must be positive or null.",e))(l));if(h<0)return new rn(Cm(h));if(h>a)return new rn(((e,t)=>ui("The salvage (%(salvage)s) must be smaller or equal than the cost (%(cost)s).",{salvage:e,cost:t}))(h,a));if(d<0)return new rn((e=>ui("The period (%s) must be positive or null.",e))(d));if(u<=0)return new rn(bm(u));if(Em(g))return new rn(Kp(g));if(l>c)return new rn(((e,t)=>ui("The purchase_date (%(purchaseDate)s) must be before the first_period_end (%(firstPeriodEnd)s).",{purchaseDate:e,firstPeriodEnd:t}))(l,c));const p=d<1&&d>0?1:Math.trunc(d),m=a*u,f=qi(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},_f={description:ui("Days in coupon period containing settlement date."),args:Rf,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Sn(e,this.locale)),n=Math.trunc(Sn(t,this.locale)),r=Math.trunc(Sn(o,this.locale)),a=Math.trunc(Sn(s,this.locale));if(i>=n)return new rn(lm(i,n));if(Rm(r))return new rn(Xp(r));if(Em(a))return new rn(Kp(a));if(1===a){const i=Nf.compute.bind(this)(e,t,o,s).value;return Sn(Pf.compute.bind(this)(e,t,o,s).value,this.locale)-Sn(i,this.locale)}return(3===a?365:360)/r},isExported:!0},Ff={description:ui("Days from settlement until next coupon."),args:Rf,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Sn(e,this.locale)),n=Math.trunc(Sn(t,this.locale)),r=Math.trunc(Sn(o,this.locale)),a=Math.trunc(Sn(s,this.locale));if(i>=n)return new rn(lm(i,n));if(Rm(r))return new rn(Xp(r));if(Em(a))return new rn(Kp(a));const l=Sn(Nf.compute.bind(this)(e,t,o,s).value,this.locale);if([1,2,3].includes(a))return i-l;if(4===a){const e=qi(l,i,a);return Math.round(360*e)}const c=Dn(i,this.locale),h=Dn(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&&$i(h)&&$i(c)&&(f=30),31!==f||30!==m&&31!==m||(f=30),2===g&&$i(h)&&(m=30),31===m&&(m=30),360*(u-d)+30*(p-g)+(f-m)},isExported:!0},Of={description:ui("Days from settlement until next coupon."),args:Rf,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Sn(e,this.locale)),n=Math.trunc(Sn(t,this.locale)),r=Math.trunc(Sn(o,this.locale)),a=Math.trunc(Sn(s,this.locale));if(i>=n)return new rn(lm(i,n));if(Rm(r))return new rn(Xp(r));if(Em(a))return new rn(Kp(a));const l=Sn(Pf.compute.bind(this)(e,t,o,s).value,this.locale);if([1,2,3].includes(a))return l-i;if(4===a){const e=qi(i,l,a);return Math.round(360*e)}const c=Ff.compute.bind(this)(e,t,o,s);return Sn(_f.compute.bind(this)(e,t,o,s),this.locale)-Sn(c,this.locale)},isExported:!0},Pf={description:ui("Next coupon date after the settlement date."),args:Rf,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Sn(e,this.locale)),n=Math.trunc(Sn(t,this.locale)),r=Math.trunc(Sn(o,this.locale)),a=Math.trunc(Sn(s,this.locale));if(i>=n)return new rn(lm(i,n));if(Rm(r))return new rn(Xp(r));if(Em(a))return new rn(Kp(a));const l=12/r,c=Mf.compute.bind(this)(e,t,o,s);return{value:Hi(Gi(Dn(n,this.locale),-(Sn(c,this.locale)-1)*l,!0)),format:this.locale.dateFormat}},isExported:!0},Mf={description:ui("Number of coupons between settlement and maturity."),args:Rf,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Sn(e,this.locale)),n=Math.trunc(Sn(t,this.locale)),r=Math.trunc(Sn(o,this.locale)),a=Math.trunc(Sn(s,this.locale));if(i>=n)return new rn(lm(i,n));if(Rm(r))return new rn(Xp(r));if(Em(a))return new rn(Kp(a));let l=1,c=n;const h=12/r;for(;c>i;)c=Hi(Gi(Dn(c,this.locale),-h,!1)),l++;return l-1},isExported:!0},Nf={description:ui("Last coupon date prior to or on the settlement date."),args:Rf,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Sn(e,this.locale)),n=Math.trunc(Sn(t,this.locale)),r=Math.trunc(Sn(o,this.locale)),a=Math.trunc(Sn(s,this.locale));if(i>=n)return new rn(lm(i,n));if(Rm(r))return new rn(Xp(r));if(Em(a))return new rn(Kp(a));const l=12/r,c=Mf.compute.bind(this)(e,t,o,s);return{value:Hi(Gi(Dn(n,this.locale),-c*l,!0)),format:this.locale.dateFormat}},isExported:!0},kf={description:ui("Cumulative interest paid over a set of periods."),args:[Id("rate (number)",ui("The interest rate.")),Id("number_of_periods (number)",ui("The number of payments to be made.")),Id("present_value (number)",ui("The current value of the annuity.")),Id("first_period (number)",ui("The number of the payment period to begin the cumulative calculation.")),Id("last_period (number)",ui("The number of the payment period to end the cumulative calculation.")),Id("end_or_beginning (number, default=0)",ui("The timing of the payment payments are due for each period."),Ef)],compute:function(e,t,o,s,i,n={value:0}){const r=Sn(s,this.locale),a=Sn(i,this.locale),l=Sn(e,this.locale),c=Sn(o,this.locale),h=Sn(t,this.locale),d=An(n)?1:0;if(h<=0)return new rn(cm(h));if(r<=0)return new rn(sm(r));if(a<=0)return new rn(rm(a));if(r>a)return new rn(om(r,a));if(a>h)return new rn(nm(a,h));if(l<=0)return new rn(bm(l));if(c<=0)return new rn(pm(c));let u=0;for(let e=r;e<=a;e++)u+=Xf(l,e,h,c,0,d);return u},isExported:!0},Lf={description:ui("Cumulative principal paid over a set of periods."),args:[Id("rate (number)",ui("The interest rate.")),Id("number_of_periods (number)",ui("The number of payments to be made.")),Id("present_value (number)",ui("The current value of the annuity.")),Id("first_period (number)",ui("The number of the payment period to begin the cumulative calculation.")),Id("last_period (number)",ui("The number of the payment period to end the cumulative calculation.")),Id("end_or_beginning (number, default=0)",ui("The timing of the payment payments are due for each period."),Ef)],compute:function(e,t,o,s,i,n={value:0}){const r=Sn(s,this.locale),a=Sn(i,this.locale),l=Sn(e,this.locale),c=Sn(o,this.locale),h=Sn(t,this.locale),d=An(n)?1:0;if(h<=0)return new rn(cm(h));if(r<=0)return new rn(sm(r));if(a<=0)return new rn(rm(a));if(r>a)return new rn(om(r,a));if(a>h)return new rn(nm(a,h));if(l<=0)return new rn(bm(l));if(c<=0)return new rn(pm(c));let u=0;for(let e=r;e<=a;e++)u+=cv(l,e,h,c,0,d);return u},isExported:!0},Vf={description:ui("Depreciation via declining balance method."),args:[Id("cost (number)",ui("The initial cost of the asset.")),Id("salvage (number)",ui("The value of the asset at the end of depreciation.")),Id("life (number)",ui("The number of periods over which the asset is depreciated.")),Id("period (number)",ui("The single period within life for which to calculate depreciation.")),Id("month (number, optional)",ui("The number of months in the first year of depreciation."))],compute:function(e,t,o,s,...i){const n=Sn(e,this.locale),r=Sn(t,this.locale),a=Sn(o,this.locale),l=Math.trunc(Sn(s,this.locale)),c=i.length?Math.trunc(Sn(i[0],this.locale)):12,h=a+(12===c?0:1);if(n<0)return new rn(Yp(n));if(r<0)return new rn(Cm(r));if(l<=0)return new rn(gm(l));if(a<=0)return new rn(am(a));if(1>c||c>12)return new rn(ui("The month (%s) must be between 1 and 12 inclusive.",c));if(l>h)return new rn(((e,t)=>ui("The period (%(period)s) must be less than or equal to %(lifeLimit)s.",{period:e,lifeLimit:t}))(l,h));const d=c/12;let u=1-Math.pow(r/n,1/a);u=Math.round(1e3*u)/1e3;let g=n,p=n*(1-u*d);for(let e=1;e<l;e++)g=p,p=g*(1-u),e===a&&(p=g*(1-u*(1-d)));return{value:g-p,format:"#,##0.00"}},isExported:!0},Uf="#,##0.00",Hf={description:ui("Depreciation via double-declining balance method."),args:[Id("cost (number)",ui("The initial cost of the asset.")),Id("salvage (number)",ui("The value of the asset at the end of depreciation.")),Id("life (number)",ui("The number of periods over which the asset is depreciated.")),Id("period (number)",ui("The single period within life for which to calculate depreciation.")),Id("factor (number, default=2)",ui("The factor by which depreciation decreases."))],compute:function(e,t,o,s,i={value:2}){const n=Sn(e,this.locale),r=Sn(t,this.locale),a=Sn(o,this.locale),l=Sn(s,this.locale),c=Sn(i,this.locale);if(n<0)return new rn(Yp(n));if(r<0)return new rn(Cm(r));if(l<=0)return new rn(gm(l));if(a<=0)return new rn(am(a));if(l>a)return new rn(um(l,a));if(c<=0)return new rn(Jp(c));if(0===n||r>=n)return{value:0,format:Uf};const h=c/a;if(h>1)return{value:1===l?n-r:0,format:Uf};if(l<=1)return{value:n*h,format:Uf};const d=n*Math.pow(1-h,l-1),u=n*Math.pow(1-h,l),g=u<r?d-r:d-u;return{value:Math.max(g,0),format:Uf}},isExported:!0},zf={description:ui("Discount rate of a security based on price."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("price (number)",ui("The price at which the security is bought per 100 face value.")),Id("redemption (number)",ui("The redemption amount per 100 face value, or par.")),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o,s,i={value:0}){i=i||0;const n=Math.trunc(Sn(e,this.locale)),r=Math.trunc(Sn(t,this.locale)),a=Sn(o,this.locale),l=Sn(s,this.locale),c=Math.trunc(Sn(i,this.locale));if(n>=r)return new rn(lm(n,r));if(Em(c))return new rn(Kp(c));if(a<=0)return new rn(mm(a));if(l<=0)return new rn(Sm(l));return(l-a)/l/qi(n,r,c)},isExported:!0},Bf={description:ui("Convert a decimal fraction to decimal value."),args:[Id("fractional_price (number)",ui("The price quotation given using fractional decimal conventions.")),Id("unit (number)",ui("The units of the fraction, e.g. 8 for 1/8ths or 32 for 1/32nds."))],compute:function(e,t){const o=Sn(e,this.locale),s=Math.trunc(Sn(t,this.locale));if(s<=0)return new rn(Im(s));const i=Math.trunc(o);return i+(o-i)*(10**Math.ceil(Math.log10(s))/s)},isExported:!0},$f={description:ui("Convert a decimal value to decimal fraction."),args:[Id("decimal_price (number)",ui("The price quotation given as a decimal value.")),Id("unit (number)",ui("The units of the desired fraction, e.g. 8 for 1/8ths or 32 for 1/32nds."))],compute:function(e,t){const o=Sn(e,this.locale),s=Math.trunc(Sn(t,this.locale));if(s<=0)return new rn(Im(s));const i=Math.trunc(o);return i+(o-i)*(s/10**Math.ceil(Math.log10(s)))},isExported:!0},Gf={description:ui("Number of periods for an investment to reach a value."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("rate (number)",ui("The annualized rate of interest.")),Id("yield (number)",ui("The expected annual yield of the security.")),Id("frequency (number)",ui("The number of interest or coupon payments per year (1, 2, or 4)."),xf),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o,s,i,n={value:0}){const r=Math.trunc(Sn(e,this.locale)),a=Math.trunc(Sn(t,this.locale)),l=Sn(o,this.locale),c=Sn(s,this.locale),h=Math.trunc(Sn(i,this.locale)),d=Math.trunc(Sn(n,this.locale));if(r>=a)return new rn(lm(r,a));if(Rm(h))return new rn(Xp(h));if(Em(d))return new rn(Kp(d));if(l<0)return new rn(vm(l));if(c<0)return new rn(wm(c));const u=qi(r,a,d),g=u-Math.trunc(u)||1/h,p=Math.ceil(u*h),m=l/h,f=c/h;let v=0,b=0;for(let e=1;e<=p;e++){const t=(m+(e===p?1:0))/(1+f)**e;b+=(g+(e-1)/h)*t,v+=t}return 0===v?0:b/v},isExported:!0},Wf={description:ui("Annual effective interest rate."),args:[Id("nominal_rate (number)",ui("The nominal interest rate per year.")),Id("periods_per_year (number)",ui("The number of compounding periods per year."))],compute:function(e,t){const o=Sn(e,this.locale),s=Math.trunc(Sn(t,this.locale));return o<=0?new rn(ui("The nominal_rate (%s) must be strictly positive.",o)):s<=0?new rn(dm(s)):Math.pow(1+o/s,s)-1},isExported:!0};function qf(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 Zf={description:ui("Future value of an annuity investment."),args:[Id("rate (number)",ui("The interest rate.")),Id("number_of_periods (number)",ui("The number of payments to be made.")),Id("payment_amount (number)",ui("The amount per period to be paid.")),Id("present_value (number, default=0)",ui("The current value of the annuity.")),Id("end_or_beginning (number, default=0)",ui("The timing of the payment payments are due for each period."),Ef)],compute:function(e,t,o,s={value:0},i={value:0}){s=s||0,i=i||0;return{value:qf(Sn(e,this.locale),Sn(t,this.locale),Sn(o,this.locale),Sn(s,this.locale),An(i)?1:0),format:"#,##0.00"}},isExported:!0},jf={description:ui("Future value of principal from series of rates."),args:[Id("principal (number)",ui("The amount of initial capital or value to compound against.")),Id("rate_schedule (number, range<number>)",ui("A series of interest rates to compound against the principal."))],compute:function(e,t){return Nn([t],((e,t)=>e*(1+Sn(t,this.locale))),Sn(e,this.locale))},isExported:!0},Yf={description:ui("Calculates effective interest rate."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("investment (number)",ui("The amount invested in the security.")),Id("redemption (number)",ui("The amount to be received at maturity.")),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o,s,i={value:0}){const n=Math.trunc(Sn(e,this.locale)),r=Math.trunc(Sn(t,this.locale)),a=Sn(s,this.locale),l=Sn(o,this.locale),c=Math.trunc(Sn(i,this.locale));if(n>=r)return new rn(lm(n,r));if(l<=0)return new rn(im(l));if(a<=0)return new rn(Sm(a));if(Em(c))return new rn(Kp(c));return(a-l)/l/qi(n,r,c)},isExported:!0};function Xf(e,t,o,s,i,n){return av(e,o,s,i,n)-cv(e,t,o,s,i,n)}const Kf={description:ui("Payment on the principal of an investment."),args:[Id("rate (number)",ui("The annualized rate of interest.")),Id("period (number)",ui("The amortization period, in terms of number of periods.")),Id("number_of_periods (number)",ui("The number of payments to be made.")),Id("present_value (number)",ui("The current value of the annuity.")),Id("future_value (number, default=0)",ui("The future value remaining after the final payment has been made.")),Id("end_or_beginning (number, default=0)",ui("The timing of the payment payments are due for each period."),Ef)],compute:function(e,t,o,s,i={value:0},n={value:0}){return{value:Xf(Sn(e,this.locale),Sn(t,this.locale),Sn(o,this.locale),Sn(s,this.locale),Sn(i,this.locale),An(n)?1:0),format:"#,##0.00"}},isExported:!0},Jf={description:ui("Internal rate of return given periodic cashflows."),args:[Id("cashflow_amounts (number, range<number>)",ui("An array or range containing the income or payments associated with the investment.")),Id("rate_guess (number, default=0.1)",ui("An estimate for what the internal rate of return will be."))],compute:function(e,t={value:.1}){const o=Sn(t,this.locale);if(o<=-1)return new rn(fm(o));let s=!1,i=!1;const n=[];if(Pn([e],(({value:e})=>{e>0&&(s=!0),e<0&&(i=!0),n.push(e)}),this.locale),!s||!i)return new rn(jp);const r=n.shift();return{value:Tf((function(e){return function(e,t,o){const s=o.length;let i=0;return o.reduce(((t,o)=>(i++,t+o*e**(s-i))),t*e**s)}(e,r,n)}),(function(e){return function(e,t,o){const s=o.length;let i=0;return o.reduce(((t,o)=>(i++,t+o*(s-i)*e**(s-i-1))),t*s*e**(s-1))}(e,r,n)}),o+1,20,1e-5)-1,format:"0%"}},isExported:!0},Qf={description:ui("Returns the interest paid at a particular period of an investment."),args:[Id("rate (number)",ui("The interest rate.")),Id("period (number)",ui("The period for which you want to view the interest payment.")),Id("number_of_periods (number)",ui("The number of payments to be made.")),Id("present_value (number)",ui("The current value of the annuity."))],compute:function(e,t,o,s){const i=Sn(e,this.locale),n=Sn(t,this.locale),r=Sn(o,this.locale),a=Sn(s,this.locale);if(0===r)return new rn(ui("The number_of_periods (%s) must be different from zero.",r));return-1*(a-a*(n/r))*i},isExported:!0},ev={description:ui("Modified Macaulay duration."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("rate (number)",ui("The annualized rate of interest.")),Id("yield (number)",ui("The expected annual yield of the security.")),Id("frequency (number)",ui("The number of interest or coupon payments per year (1, 2, or 4)."),xf),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,n={value:0}){const r=Gf.compute.bind(this)(e,t,o,s,i,n),a=Sn(s,this.locale),l=Math.trunc(Sn(i,this.locale));return Sn(r,this.locale)/(1+a/l)},isExported:!0},tv={description:ui("Modified internal rate of return."),args:[Id("cashflow_amounts (range<number>)",ui("A range containing the income or payments associated with the investment. The array should contain bot payments and incomes.")),Id("financing_rate (number)",ui("The interest rate paid on funds invested.")),Id("reinvestment_return_rate (number)",ui("The return (as a percentage) earned on reinvestment of income received from the investment."))],compute:function(e,t,o){const s=Sn(t,this.locale),i=Sn(o,this.locale),n=Hn(e).flat().filter((e=>null!==e.value)).map((e=>Sn(e,this.locale))),r=n.length;let a=0,l=0;for(const e of Ct(0,r)){const t=n[e];t>=0?a+=t*(i+1)**(r-e-1):l+=t/(s+1)**e}if(0===l||0===a)return new rn(jp);return(-a/l)**(1/(r-1))-1},isExported:!0},ov={description:ui("Annual nominal interest rate."),args:[Id("effective_rate (number)",ui("The effective interest rate per year.")),Id("periods_per_year (number)",ui("The number of compounding periods per year."))],compute:function(e,t){const o=Sn(e,this.locale),s=Math.trunc(Sn(t,this.locale));return o<=0?new rn(ui("The effective_rate (%s) must be strictly positive.",o)):s<=0?new rn(dm(s)):(Math.pow(o+1,1/s)-1)*s},isExported:!0},sv={description:ui("Number of payment periods for an investment."),args:[Id("rate (number)",ui("The interest rate.")),Id("payment_amount (number)",ui("The amount of each payment made.")),Id("present_value (number)",ui("The current value of the annuity.")),Id("future_value (number, default=0)",ui("The future value remaining after the final payment has been made.")),Id("end_or_beginning (number, default=0)",ui("The timing of the payment payments are due for each period."),Ef)],compute:function(e,t,o,s={value:0},i={value:0}){s=s||0,i=i||0;const n=Sn(e,this.locale),r=Sn(t,this.locale),a=Sn(o,this.locale),l=Sn(s,this.locale),c=An(i)?1:0;if(0===n)return-(l+a)/r;const h=r*(1+n*c)/n;return Math.log((h-l)/(a+h))/Math.log(1+n)},isExported:!0};function iv(e,t,o,s){let i=0;return kn(o,((t,o)=>(i++,t+o/(1+e)**i)),t,s)}const nv={description:ui("The net present value of an investment based on a series of periodic cash flows and a discount rate."),args:[Id("discount (number)",ui("The discount rate of the investment over one period.")),Id("cashflow1 (number, range<number>)",ui("The first future cash flow.")),Id("cashflow2 (number, range<number>, repeating)",ui("Additional future cash flows."))],compute:function(e,...t){const o=Sn(e,this.locale);return-1===o?new rn((e=>ui("The discount (%s) must be different from -1.",e))(o)):{value:iv(o,0,t,this.locale),format:"#,##0.00"}},isExported:!0},rv={description:ui("Computes the number of periods needed for an investment to reach a value."),args:[Id("rate (number)",ui("The rate at which the investment grows each period.")),Id("present_value (number)",ui("The investment's current value.")),Id("future_value (number)",ui("The investment's desired future value."))],compute:function(e,t,o){const s=Sn(e,this.locale),i=Sn(t,this.locale),n=Sn(o,this.locale);return s<=0?new rn(bm(s)):i<=0?new rn(pm(i)):n<=0?new rn(ui("The future_value (%s) must be strictly positive.",n)):(Math.log(n)-Math.log(i))/Math.log(1+s)},isExported:!0};function av(e,t,o,s,i){if(t<=0)throw new rn(cm(t));if(0===e)return-(s+o)/t;let n=-(o*(1+e)**t+s);return n=n*e/((1+e*i)*((1+e)**t-1)),n}const lv={description:ui("Periodic payment for an annuity investment."),args:[Id("rate (number)",ui("The annualized rate of interest.")),Id("number_of_periods (number)",ui("The number of payments to be made.")),Id("present_value (number)",ui("The current value of the annuity.")),Id("future_value (number, default=0)",ui("The future value remaining after the final payment has been made.")),Id("end_or_beginning (number, default=0)",ui("The timing of the payment payments are due for each period."),Ef)],compute:function(e,t,o,s={value:0},i={value:0}){const n=Sn(t,this.locale),r=Sn(e,this.locale),a=An(i)?1:0,l=Sn(s,this.locale);return{value:av(r,n,Sn(o,this.locale),l,a),format:"#,##0.00"}},isExported:!0};function cv(e,t,o,s,i,n){if(o<=0)throw new rn(cm(o));if(t<=0||t>o)throw new rn(hm(o));const r=av(e,o,s,i,n);if(1===n&&1===t)return r;return r+-qf(e,0===n?t-1:t-2,r,s+r*n,0)*e}const hv={description:ui("Payment on the principal of an investment."),args:[Id("rate (number)",ui("The annualized rate of interest.")),Id("period (number)",ui("The amortization period, in terms of number of periods.")),Id("number_of_periods (number)",ui("The number of payments to be made.")),Id("present_value (number)",ui("The current value of the annuity.")),Id("future_value (number, default=0)",ui("The future value remaining after the final payment has been made.")),Id("end_or_beginning (number, default=0)",ui("The timing of the payment payments are due for each period."),Ef)],compute:function(e,t,o,s,i={value:0},n={value:0}){const r=Sn(o,this.locale),a=Sn(e,this.locale),l=Sn(t,this.locale),c=An(n)?1:0,h=Sn(i,this.locale);return{value:cv(a,l,r,Sn(s,this.locale),h,c),format:"#,##0.00"}},isExported:!0},dv={description:ui("Present value of an annuity investment."),args:[Id("rate (number)",ui("The interest rate.")),Id("number_of_periods (number)",ui("The number of payments to be made.")),Id("payment_amount (number)",ui("The amount per period to be paid.")),Id("future_value (number, default=0)",ui("The future value remaining after the final payment has been made.")),Id("end_or_beginning (number, default=0)",ui("The timing of the payment payments are due for each period."),Ef)],compute:function(e,t,o,s={value:0},i={value:0}){s=s||0,i=i||0;const n=Sn(e,this.locale),r=Sn(t,this.locale),a=Sn(o,this.locale),l=Sn(s,this.locale),c=An(i)?1:0;return{value:n?-(a*(1+n*c)*((1+n)**r-1)/n+l)/(1+n)**r:-(l+a*r),format:"#,##0.00"}},isExported:!0},uv={description:ui("Price of a security paying periodic interest."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("rate (number)",ui("The annualized rate of interest.")),Id("yield (number)",ui("The expected annual yield of the security.")),Id("redemption (number)",ui("The redemption amount per 100 face value, or par.")),Id("frequency (number)",ui("The number of interest or coupon payments per year (1, 2, or 4)."),xf),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o,s,i,n,r={value:0}){r=r||0;const a=Math.trunc(Sn(e,this.locale)),l=Math.trunc(Sn(t,this.locale)),c=Sn(o,this.locale),h=Sn(s,this.locale),d=Sn(i,this.locale),u=Math.trunc(Sn(n,this.locale)),g=Math.trunc(Sn(r,this.locale));if(a>=l)return new rn(lm(a,l));if(Rm(u))return new rn(Xp(u));if(Em(g))return new rn(Kp(g));if(c<0)return new rn(vm(c));if(h<0)return new rn(wm(h));if(d<=0)return new rn(Sm(d));const p=qi(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},gv={description:ui("Price of a discount security."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("discount (number)",ui("The discount rate of the security at time of purchase.")),Id("redemption (number)",ui("The redemption amount per 100 face value, or par.")),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o,s,i={value:0}){i=i||0;const n=Math.trunc(Sn(e,this.locale)),r=Math.trunc(Sn(t,this.locale)),a=Sn(o,this.locale),l=Sn(s,this.locale),c=Math.trunc(Sn(i,this.locale));if(n>=r)return new rn(lm(n,r));if(Em(c))return new rn(Kp(c));if(a<=0)return new rn(Qp(a));if(l<=0)return new rn(Sm(l));return l-a*l*qi(n,r,c)},isExported:!0},pv={description:ui("Calculates the price of a security paying interest at maturity, based on expected yield."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("issue (date)",ui("The date the security was initially issued.")),Id("rate (number)",ui("The annualized rate of interest.")),Id("yield (number)",ui("The expected annual yield of the security.")),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o,s,i,n={value:0}){n=n||0;const r=Math.trunc(Sn(e,this.locale)),a=Math.trunc(Sn(t,this.locale)),l=Math.trunc(Sn(o,this.locale)),c=Sn(s,this.locale),h=Sn(i,this.locale),d=Math.trunc(Sn(n,this.locale));if(r<=l)return new rn(((e,t)=>ui("The settlement date (%(settlement)s) must be strictly greater than the issue date (%(issue)s).",{settlement:e,issue:t}))(r,l));if(r>=a)return new rn(lm(r,a));if(Em(d))return new rn(Kp(d));if(c<0)return new rn(vm(c));if(h<0)return new rn(wm(h));const u=qi(r,a,d),g=qi(r,l,d);return(100+qi(l,a,d)*c*100)/(1+u*h)-g*c*100},isExported:!0},mv=.1,fv={description:ui("Interest rate of an annuity investment."),args:[Id("number_of_periods (number)",ui("The number of payments to be made.")),Id("payment_per_period (number)",ui("The amount per period to be paid.")),Id("present_value (number)",ui("The current value of the annuity.")),Id("future_value (number, default=0)",ui("The future value remaining after the final payment has been made.")),Id("end_or_beginning (number, default=0)",ui("The timing of the payment payments are due for each period."),Ef),Id("rate_guess (number, default=0.1)",ui("An estimate for what the interest rate will be."))],compute:function(e,t,o,s={value:0},i={value:0},n={value:mv}){const r=Sn(e,this.locale),a=Sn(t,this.locale),l=An(i)?1:0,c=Sn(n,this.locale)||mv;let h=Sn(s,this.locale),d=Sn(o,this.locale);if(r<=0)return new rn(cm(r));if(!xm([a,d,h]))return new rn(ui("There must be both positive and negative values in [payment_amount, present_value, future_value]."));if(c<=-1)return new rn(fm(c));h-=a*l,d+=a*l;return{value:Tf((e=>{const t=Math.pow(1+e,r);return h+d*t+a*((t-1)/e)}),(e=>{const t=Math.pow(1+e,r-1),o=Math.pow(1+e,r);return d*r*t+a*(r*t/e-(o-1)/e/e)}),c,40,1e-5),format:"0%"}},isExported:!0},vv={description:ui("Amount received at maturity for a security."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("investment (number)",ui("The amount invested (irrespective of face value of each security).")),Id("discount (number)",ui("The discount rate of the security invested in.")),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o,s,i={value:0}){i=i||0;const n=Math.trunc(Sn(e,this.locale)),r=Math.trunc(Sn(t,this.locale)),a=Sn(o,this.locale),l=Sn(s,this.locale),c=Math.trunc(Sn(i,this.locale));if(n>=r)return new rn(lm(n,r));if(Em(c))return new rn(Kp(c));if(a<=0)return new rn(im(a));if(l<=0)return new rn(Qp(l));return a/(1-l*qi(n,r,c))},isExported:!0},bv={description:ui("Computes the rate needed for an investment to reach a specific value within a specific number of periods."),args:[Id("number_of_periods (number)",ui("The number of periods.")),Id("present_value (number)",ui("The present value of the investment.")),Id("future_value (number)",ui("The future value of the investment."))],compute:function(e,t,o){const s=Sn(e,this.locale),i=Sn(t,this.locale),n=Sn(o,this.locale);return s<=0?new rn(cm(s)):(n/i)**(1/s)-1},isExported:!0},Sv={description:ui("Depreciation of an asset using the straight-line method."),args:[Id("cost (number)",ui("The initial cost of the asset.")),Id("salvage (number)",ui("The value of the asset at the end of depreciation.")),Id("life (number)",ui("The number of periods over which the asset is depreciated."))],compute:function(e,t,o){return{value:(Sn(e,this.locale)-Sn(t,this.locale))/Sn(o,this.locale),format:"#,##0.00"}},isExported:!0},Cv={description:ui("Depreciation via sum of years digit method."),args:[Id("cost (number)",ui("The initial cost of the asset.")),Id("salvage (number)",ui("The value of the asset at the end of depreciation.")),Id("life (number)",ui("The number of periods over which the asset is depreciated.")),Id("period (number)",ui("The single period within life for which to calculate depreciation."))],compute:function(e,t,o,s){const i=Sn(e,this.locale),n=Sn(t,this.locale),r=Sn(o,this.locale),a=Sn(s,this.locale);if(a<=0)return new rn(gm(a));if(r<=0)return new rn(am(r));if(a>r)return new rn(um(a,r));return{value:(r-a+1)/(r*(r+1)/2)*(i-n),format:"#,##0.00"}},isExported:!0};function yv(e,t,o){return 100*(1-o*qi(e,t,2))}const Iv={description:ui("Price of a US Treasury bill."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("discount (number)",ui("The discount rate of the bill at time of purchase."))],compute:function(e,t,o){const s=Math.trunc(Sn(e,this.locale)),i=Math.trunc(Sn(t,this.locale)),n=Sn(o,this.locale);return s>=i?new rn(lm(s,i)):Tm(s,i,this.locale)?n<=0?new rn(Qp(n)):n>=1?new rn(em(n)):yv(s,i,n):new rn(ym(s,i))},isExported:!0},wv={description:ui("Equivalent rate of return for a US Treasury bill."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("discount (number)",ui("The discount rate of the bill at time of purchase."))],compute:function(e,t,o){const s=Math.trunc(Sn(e,this.locale)),i=Math.trunc(Sn(t,this.locale)),n=Sn(o,this.locale);if(s>=i)return new rn(lm(s,i));if(!Tm(s,i,this.locale))return new rn(ym(s,i));if(n<=0)return new rn(Qp(n));if(n>=1)return new rn(em(n));const r=Mm.compute.bind(this)({value:i},{value:s});if(r<=182)return 365*n/(360-n*r);const a=yv(s,i,n)/100,l=r/(366===r?366:365);return(-2*l+2*Math.sqrt(l**2-(2*l-1)*(1-1/a)))/(2*l-1)},isExported:!0},xv={description:ui("The yield of a US Treasury bill based on price."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("price (number)",ui("The price at which the security is bought per 100 face value."))],compute:function(e,t,o){const s=Math.trunc(Sn(e,this.locale)),i=Math.trunc(Sn(t,this.locale)),n=Sn(o,this.locale);if(s>=i)return new rn(lm(s,i));if(!Tm(s,i,this.locale))return new rn(ym(s,i));if(n<=0)return new rn(mm(n));return(100-n)/n*(1/qi(s,i,2))},isExported:!0},Ev={description:ui("Variable declining balance. WARNING : does not handle decimal periods."),args:[Id("cost (number)",ui("The initial cost of the asset.")),Id("salvage (number)",ui("The value of the asset at the end of depreciation.")),Id("life (number)",ui("The number of periods over which the asset is depreciated.")),Id("start (number)",ui("Starting period to calculate depreciation.")),Id("end (number)",ui("Ending period to calculate depreciation.")),Id("factor (number, default=2)",ui("The number of months in the first year of depreciation.")),Id("no_switch (number, default=false)",ui("Whether to switch to straight-line depreciation when the depreciation is greater than the declining balance calculation."),[{value:!1,label:ui("Switch to straight-line depreciation")},{value:!0,label:ui("Do not switch to straight-line depreciation")}])],compute:function(e,t,o,s,i,n={value:2},r={value:false}){n=n||0;const a=Sn(e,this.locale),l=Sn(t,this.locale),c=Sn(o,this.locale),h=Math.trunc(Sn(s,this.locale)),d=Math.trunc(Sn(i,this.locale)),u=Sn(n,this.locale),g=An(r);if(a<0)return new rn(Yp(a));if(l<0)return new rn(Cm(l));if(c<=0)return new rn(am(c));if(h<0)return new rn((e=>ui("The start_period (%s) must be positive or null.",e))(h));if(d<0)return new rn((e=>ui("The end_period (%s) must be positive or null.",e))(d));if(h>d)return new rn(ui("The start_period (%(start)s) must be smaller or equal to the end_period (%(end)s).",{start:h,end:d}));if(d>c)return new rn(((e,t)=>ui("The end_period (%(end)s) must be smaller or equal to the life (%(life)s).",{end:e,life:t}))(d,c));if(u<=0)return new rn(Jp(u));if(0===a)return 0;if(l>=a)return h<1?a-l:0;const p=u/c;if(p>=1)return h<1?a-l:0;let m=a,f=0,v=0,b=!1;for(let e=0;e<d;e++){if(!b||g){const t=m*p,o=(m-l)/(c-e);!g&&o>t?(b=!0,f=o):f=t}const t=Math.max(m-f,l);e>=h&&(v+=m-t),m=t}return v},isExported:!0},Rv={description:ui("Internal rate of return given non-periodic cash flows."),args:[Id("cashflow_amounts (range<number>)",ui("An range containing the income or payments associated with the investment.")),Id("cashflow_dates (range<number>)",ui("An range with dates corresponding to the cash flows in cashflow_amounts.")),Id("rate_guess (number, default=0.1)",ui("An estimate for what the internal rate of return will be."))],compute:function(e,t,o={value:mv}){const s=Sn(o,this.locale);if(!cc(e,t))return new rn(Zp);const i=e.flat().map((e=>Sn(e,this.locale))),n=t.flat().map((e=>Sn(e,this.locale)));if(!xm(i))return new rn(jp);if(n.some((e=>e<n[0])))return new rn(tm(n[0]));if(s<=-1)return new rn(fm(s));const r=new Map;for(const e of Ct(0,n.length)){const t=n[e];r.has(t)?r.set(t,r.get(t)+i[e]):r.set(t,i[e])}const a=Array.from(r.keys()),l=a.map((e=>r.get(e)));return Tf((e=>{let t=l[0];for(const o of Ct(1,l.length)){const s=(a[0]-a[o])/365;t+=l[o]*(1+e)**s}return t}),(e=>{let t=0;for(const o of Ct(1,l.length)){const s=(a[0]-a[o])/365;t+=s*l[o]*(1+e)**(s-1)}return t}),s,40,1e-5,(e=>e?e/10-.9:-.9))},isExported:!0},Tv={description:ui("Net present value given to non-periodic cash flows.."),args:[Id("discount (number)",ui("The discount rate of the investment over one period.")),Id("cashflow_amounts (number, range<number>)",ui("An range containing the income or payments associated with the investment.")),Id("cashflow_dates (number, range<number>)",ui("An range with dates corresponding to the cash flows in cashflow_amounts."))],compute:function(e,t,o){const s=Sn(e,this.locale);if(!cc(t,o))return new rn(Zp);const i=Kn(t).flat().map((e=>In(e,this.locale))),n=Kn(o).flat().map((e=>In(e,this.locale)));if(n.some((e=>e<n[0])))return new rn(tm(n[0]));if(s<=0)return new rn(bm(s));if(1===i.length)return i[0];const r=new Map;for(const e of Ct(0,n.length)){const t=n[e];r.has(t)?r.set(t,r.get(t)+i[e]):r.set(t,i[e])}const a=Array.from(r.keys()),l=a.map((e=>r.get(e)));let c=l[0];for(const e of Ct(1,l.length)){const t=(a[0]-a[e])/365;c+=l[e]*(1+s)**t}return c},isExported:!0},Av={description:ui("Annual yield of a security paying periodic interest."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("rate (number)",ui("The annualized rate of interest.")),Id("price (number)",ui("The price at which the security is bought per 100 face value.")),Id("redemption (number)",ui("The redemption amount per 100 face value, or par.")),Id("frequency (number)",ui("The number of interest or coupon payments per year (1, 2, or 4)."),xf),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o,s,i,n,r={value:0}){r=r||0;const a=Math.trunc(Sn(e,this.locale)),l=Math.trunc(Sn(t,this.locale)),c=Sn(o,this.locale),h=Sn(s,this.locale),d=Sn(i,this.locale),u=Math.trunc(Sn(n,this.locale)),g=Math.trunc(Sn(r,this.locale));if(a>=l)return new rn(lm(a,l));if(Rm(u))return new rn(Xp(u));if(Em(g))return new rn(Kp(g));if(c<0)return new rn(vm(c));if(h<=0)return new rn(mm(h));if(d<=0)return new rn(Sm(d));const p=qi(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=Tf((function(e){return function(e,t,o,s,i,n){let r=n-(e+i*(1-t))*s**(o-1+t);for(let e=1;e<=o;e++)r+=i*s**(e-1);return r}(h,f,m,e,v,d)}),(function(e){return function(e,t,o,s,i){let n=-(e+i*(1-t))*(o-1+t)*s**(o-2+t);for(let e=1;e<=o;e++)n+=i*(e-1)*s**(e-2);return n}(h,f,m,e,v)}),1+(c+1)/u,100,1e-5);return(b-1)*u},isExported:!0},Dv={description:ui("Annual yield of a discount security."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("price (number)",ui("The price at which the security is bought per 100 face value.")),Id("redemption (number)",ui("The redemption amount per 100 face value, or par.")),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o,s,i={value:0}){i=i||0;const n=Math.trunc(Sn(e,this.locale)),r=Math.trunc(Sn(t,this.locale)),a=Sn(o,this.locale),l=Sn(s,this.locale),c=Math.trunc(Sn(i,this.locale));if(n>=r)return new rn(lm(n,r));if(Em(c))return new rn(Kp(c));if(a<=0)return new rn(mm(a));if(l<=0)return new rn(Sm(l));return(l/a-1)/qi(n,r,c)},isExported:!0},_v={description:ui("Annual yield of a security paying interest at maturity."),args:[Id("settlement (date)",ui("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Id("maturity (date)",ui("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Id("issue (date)",ui("The date the security was initially issued.")),Id("rate (number)",ui("The annualized rate of interest.")),Id("price (number)",ui("The price at which the security is bought.")),Id("day_count_convention (number, default=0 )",ui("An indicator of what day count method to use."),Am)],compute:function(e,t,o,s,i,n={value:0}){n=n||0;const r=Math.trunc(Sn(e,this.locale)),a=Math.trunc(Sn(t,this.locale)),l=Math.trunc(Sn(o,this.locale)),c=Sn(s,this.locale),h=Sn(i,this.locale),d=Math.trunc(Sn(n,this.locale));if(r>=a)return new rn(lm(r,a));if(Em(d))return new rn(Kp(d));if(r<l)return new rn(((e,t)=>ui("The settlement date (%(settlement)s) must be greater or equal to the issue date (%(issue)s).",{settlement:e,issue:t}))(r,l));if(c<0)return new rn(vm(c));if(h<=0)return new rn(mm(h));return(100*(1+c*qi(l,a,d))/(h+100*c*qi(l,r,d))-1)/qi(r,a,d)},isExported:!0};var Fv,Ov=Object.freeze({__proto__:null,ACCRINTM:Af,AMORLINC:Df,COUPDAYBS:Ff,COUPDAYS:_f,COUPDAYSNC:Of,COUPNCD:Pf,COUPNUM:Mf,COUPPCD:Nf,CUMIPMT:kf,CUMPRINC:Lf,DB:Vf,DDB:Hf,DISC:zf,DOLLARDE:Bf,DOLLARFR:$f,DURATION:Gf,EFFECT:Wf,FV:Zf,FVSCHEDULE:jf,INTRATE:Yf,IPMT:Kf,IRR:Jf,ISPMT:Qf,MDURATION:ev,MIRR:tv,NOMINAL:ov,NPER:sv,NPV:nv,PDURATION:rv,PMT:lv,PPMT:hv,PRICE:uv,PRICEDISC:gv,PRICEMAT:pv,PV:dv,RATE:fv,RECEIVED:vv,RRI:bv,SLN:Sv,SYD:Cv,TBILLEQ:wv,TBILLPRICE:Iv,TBILLYIELD:xv,VDB:Ev,XIRR:Rv,XNPV:Tv,YIELD:Av,YIELDDISC:Dv,YIELDMAT:_v});!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"}(Fv||(Fv={}));const Pv=(e,t=(()=>!0))=>[{goTo:e,guard:t}],Mv=(e,t=(()=>!0))=>({goTo:e,guard:t}),Nv={[Fv.LeftRef]:{REFERENCE:Pv(Fv.Separator),NUMBER:Pv(Fv.FullRowSeparator),SYMBOL:[Mv(Fv.FullColumnSeparator,(e=>{return t=e.value,Ca.test(t);var t})),Mv(Fv.FullRowSeparator,(e=>wa(e.value)))]},[Fv.FullColumnSeparator]:{SPACE:Pv(Fv.FullColumnSeparator),OPERATOR:Pv(Fv.RightColumnRef,(e=>":"===e.value))},[Fv.FullRowSeparator]:{SPACE:Pv(Fv.FullRowSeparator),OPERATOR:Pv(Fv.RightRowRef,(e=>":"===e.value))},[Fv.Separator]:{SPACE:Pv(Fv.Separator),OPERATOR:Pv(Fv.RightRef,(e=>":"===e.value))},[Fv.RightRef]:{SPACE:Pv(Fv.RightRef),NUMBER:Pv(Fv.Found),REFERENCE:Pv(Fv.Found,(e=>Ra(e.value))),SYMBOL:Pv(Fv.Found,(e=>xa(e.value)||Ea(e.value)))},[Fv.RightColumnRef]:{SPACE:Pv(Fv.RightColumnRef),SYMBOL:Pv(Fv.Found,(e=>xa(e.value))),REFERENCE:Pv(Fv.Found,(e=>Ra(e.value)))},[Fv.RightRowRef]:{SPACE:Pv(Fv.RightRowRef),NUMBER:Pv(Fv.Found),REFERENCE:Pv(Fv.Found,(e=>Ra(e.value))),SYMBOL:Pv(Fv.Found,(e=>Ea(e.value)))},[Fv.Found]:{}};function kv(e){let t=0,o=Nv[Fv.LeftRef],s="";for(;void 0!==o;){const i=e[t++];if(!i)return null;const n=o[i.type]?.find((e=>e.guard(i))),r=n?n.goTo:void 0;switch(r){case void 0:return null;case Fv.Found:return s+=i.value,e.splice(0,t),{type:"REFERENCE",value:s};default:o=Nv[r],s+=i.value}}return null}function Lv(e,t=w){const o=El(e,t),s=[];for(;o.length;)s.push(kv(o)||o.shift());return s}const Vv=/[a-zA-Z0-9\_]+(\.[a-zA-Z0-9\_]+)*/,Uv=["-","+"],Hv=["%"];class zv{tokens;currentIndex=0;current;length;constructor(e){this.tokens=e,this.current=e[0],this.length=e.length}shift(){const e=this.tokens[this.currentIndex];return this.current=this.tokens[++this.currentIndex],e}get next(){return this.tokens[this.currentIndex+1]}}const Bv={"%":40,"^":30,"*":20,"/":20,"+":15,"-":15,"&":13,">":10,"<>":10,">=":10,"<":10,"<=":10,"=":10};function $v(e){const t=e.shift();if(!t)throw new an;switch(t.type){case"DEBUGGER":const o=qv(e,1e3);return o.debug=!0,o;case"NUMBER":return{type:"NUMBER",value:tn(t.value,w),tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case"STRING":return{type:"STRING",value:ut(t.value),tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case"INVALID_REFERENCE":return{type:"REFERENCE",value:sn.InvalidReference,tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case"REFERENCE":if(":"===e.current?.value&&"REFERENCE"===e.next?.type){e.shift();const o=e.shift();return{type:"REFERENCE",value:`${t.value}:${o?.value}`,tokenStartIndex:t.tokenIndex,tokenEndIndex:o.tokenIndex}}return{type:"REFERENCE",value:t.value,tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case"SYMBOL":const s=t.value,i=e.current;if("LEFT_PAREN"===i?.type&&Vv.test(t.value)&&s===ft(s,"'")){const{args:o,rightParen:i}=function(e){Wv(e,"LEFT_PAREN",ui("Missing opening parenthesis"));const t=e.current;if("RIGHT_PAREN"===t?.type){return{args:[],rightParen:Wv(e,"RIGHT_PAREN")}}const o=[];o.push(Gv(e));for(;"RIGHT_PAREN"!==e.current?.type;)Wv(e,"ARG_SEPARATOR",ui("Wrong function call")),o.push(Gv(e));const s=Wv(e,"RIGHT_PAREN");return{args:o,rightParen:s}}(e);return{type:"FUNCALL",value:s,args:o,tokenStartIndex:t.tokenIndex,tokenEndIndex:i.tokenIndex}}const n=s.toUpperCase();return"TRUE"===n||"FALSE"===n?{type:"BOOLEAN",value:"TRUE"===n,tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex}:{type:"SYMBOL",value:ft(t.value,"'"),tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case"LEFT_PAREN":const r=qv(e),a=Wv(e,"RIGHT_PAREN",ui("Missing closing parenthesis"));return{...r,tokenStartIndex:t.tokenIndex,tokenEndIndex:a.tokenIndex};case"OPERATOR":const l=t.value;if(Uv.includes(l)){const o=qv(e,Bv[l]);return{type:"UNARY_OPERATION",value:l,operand:o,tokenStartIndex:t.tokenIndex,tokenEndIndex:o.tokenEndIndex}}throw new an(ui("Unexpected token: %s",t.value));default:throw new an(ui("Unexpected token: %s",t.value))}}function Gv(e){const t=e.current;return"ARG_SEPARATOR"===t?.type||"RIGHT_PAREN"===t?.type?{type:"EMPTY",value:"",tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex}:qv(e)}function Wv(e,t,o){const s=e.shift();if(!s||s.type!==t)throw new an(o);return s}function qv(e,t=0){if(0===e.length)throw new an;let o=$v(e);for(;"OPERATOR"===e.current?.type&&Bv[e.current.value]>t;){const t=e.shift(),s=t.value;if(Hv.includes(s))o={type:"UNARY_OPERATION",value:s,operand:o,postfix:!0,tokenStartIndex:o.tokenStartIndex,tokenEndIndex:t.tokenIndex};else{const t=qv(e,Bv[s]);o={type:"BIN_OPERATION",value:s,left:o,right:t,tokenStartIndex:o.tokenStartIndex,tokenEndIndex:t.tokenEndIndex}}}return o}function Zv(e){return jv(Lv(e))}function jv(e){const t=e.map(((e,t)=>({type:e.type,value:e.value,tokenIndex:t}))).filter((e=>"SPACE"!==e.type)),o=new zv(t);"="===o.current?.value&&o.shift();const s=qv(o);if(o.current)throw new an;return s}function Yv(e,t,o){return Jv(e,(e=>e.type===t?o(e):e))}function Xv(e){return Array.from(Kv(e))}function*Kv(e){switch(yield e,e.type){case"FUNCALL":for(const t of e.args)yield*Kv(t);break;case"UNARY_OPERATION":yield*Kv(e.operand);break;case"BIN_OPERATION":yield*Kv(e.left),yield*Kv(e.right)}}function Jv(e,t){switch((e=t(e)).type){case"FUNCALL":return{...e,args:e.args.map((e=>Jv(e,t)))};case"UNARY_OPERATION":return{...e,operand:Jv(e.operand,t)};case"BIN_OPERATION":return{...e,right:Jv(e.right,t),left:Jv(e.left,t)};default:return e}}function Qv(e,t){return function(e){for(const t of e)if(t.functionContext){const{argsTokens:e,args:o}=t.functionContext;if(delete t.functionContext.argsTokens,o.length||!e)continue;"LEFT_PAREN"===e[0]?.[0]?.type&&(e[0]=e[0].slice(1));for(const t of e){let e=t;"ARG_SEPARATOR"===e.at(0)?.type&&(e=e.slice(1));try{o.push(jv(e))}catch(e){o.push(void 0)}}}return e}(function(e){const t=[];let o="";function s(e){if(0===t.length)return;const o=t.at(-1);if(o&&o.argsTokens){const{argsTokens:t,argPosition:s}=o;t[s]||(t[s]=[]),t[s].push({value:e.value,type:e.type})}}return e.map(((e,i)=>{switch(["SPACE","LEFT_PAREN"].includes(e.type)||(o=""),e.type){case"SYMBOL":s(e),o=e.value;break;case"LEFT_PAREN":t.push({parent:o,argPosition:0,argsTokens:[],args:[]}),s(e),o="";break;case"RIGHT_PAREN":const i=t.pop();i?.argsTokens?.flat().forEach(s),s(e);break;case"ARG_SEPARATOR":t.length&&t[t.length-1].argPosition++,s(e);break;default:s(e)}if(t.length){const o=t[t.length-1];o.parent&&(e.functionContext=Object.assign({},o))}return e}))}(function(e){const t=[];let o=0;return e.map(((s,i)=>{if("LEFT_PAREN"===s.type){t.push(o+1),o=0;for(let o=i-1;o>=0;o--){if("SPACE"!==e[o].type){"SYMBOL"===e[o].type&&(e[o].parenthesesCode=t.join(":"));break}e[o].parenthesesCode=t.join(":")}}return s.parenthesesCode=t.join(":"),"RIGHT_PAREN"===s.type&&t.length&&(o=t.pop()),s}))}(function(e){let t=0;return e.map((e=>{const o=e.value.toString().length,s=Object.assign({},e,{start:t,end:t+o,length:o});return t=s.end,s}))}(Lv(e,t)))))}function eb(e){if("REFERENCE"!==e.type)return e;const{xc:t,sheetName:o}=Ta(e.value),[s,i]=t.split(":"),n=tb(s),r=i?`:${tb(i)}`:"";return{...e,value:Aa(o,n+r)}}function tb(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=ob(e,"colrow");break;case"colrow":e=ob(e,"row");break;case"row":e=ob(e,"col");break;case"col":e=ob(e,"none")}return e}function ob(e,t){let o;({sheetName:o,xc:e}=Ta(e)),o=o?o+"!":"";const s=(e=e.replace(/\$/g,"")).indexOf(":");return s>=0?`${o}${sb(e.slice(0,s),t)}:${sb(e.slice(s+1),t)}`:o+sb(e,t)}function sb(e,t){const o=e.search(/[0-9]/),s=0!==o,i=o>=0;switch(t){case"col":return s?"$"+e:e;case"row":return i?e.slice(0,o)+"$"+e.slice(o):e;case"colrow":return i&&s?"$"+e.slice(0,o)+"$"+e.slice(o):"$"+e;case"none":return e}}function ib(e,t,o){const s=(t.startsWith("=")?Qv(t,o):[]).filter((t=>t.start<=e.start&&t.end>=e.start||t.start>=e.start&&t.start<e.end)),i=s.filter((e=>"REFERENCE"===e.type));if(0===i.length)return;const n=s.map(eb).map((e=>e.value)).join(""),r=s[0].start,a=s[s.length-1].end,l=t.slice(0,r)+n+t.slice(a),c=l.length-t.length,h={start:i[0].start,end:i[i.length-1].end+c};return 1===i.length&&e.start===e.end&&(h.start=h.end),{content:l,selection:h}}const nb=[{value:"address",label:ui("Returns an absolute reference as plain text of the top left cell in reference.")},{value:"col",label:ui("Returns the column number of the cell in reference.")},{value:"contents",label:ui("Returns the value contained in the top left cell in reference.")},{value:"format",label:ui("Returns the format of the top left cell in reference.")},{value:"row",label:ui("Returns the row number of the top left cell in reference.")},{value:"type",label:ui('Returns the type of data in the cell in reference. The following values are returned: "b" for a blank cell, "l" (for label) if the cell contains plain text, and "v" (for value) if the cell contains any other type of data.')}],rb={description:ui("Gets information about a cell."),args:[Id("info_type (string)",ui("The type of information requested."),nb),Id("reference (meta, range<meta>)",ui("The reference to the cell."))],compute:function(e,t){const o=En(e).toLowerCase();if(!nb.map((e=>e.value)).includes(o))return new rn(ui("The info_type should be one of %s.",nb.join(", ")));const s=this.__originSheetId,i=t[0][0].value;let{sheetName:n,xc:a}=Ta(i);n=n===this.getters.getSheetName(s)?void 0:n;const l=Aa(n,ob(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===r.empty?"b":t===r.text?"l":"v"}}return""},isExported:!0},ab={description:ui("Whether a value is an error other than #N/A."),args:[Id("value (any)",ui("The value to be verified as an error type."))],compute:function(e){const t=e?.value;return fn(t)&&t!==sn.NotAvailable},isExported:!0},lb={description:ui("Whether a value is an error."),args:[Id("value (any)",ui("The value to be verified as an error type."))],compute:function(e){const t=e?.value;return fn(t)},isExported:!0},cb={description:ui("Whether a value is `true` or `false`."),args:[Id("value (any)",ui("The value to be verified as a logical TRUE or FALSE."))],compute:function(e){return"boolean"==typeof e?.value},isExported:!0},hb={description:ui("Whether a value is the error #N/A."),args:[Id("value (any)",ui("The value to be verified as an error type."))],compute:function(e){return e?.value===sn.NotAvailable},isExported:!0},db={description:ui("Whether a value is non-textual."),args:[Id("value (any)",ui("The value to be checked."))],compute:function(e){return!gb.compute.bind(this)(e)},isExported:!0},ub={description:ui("Whether a value is a number."),args:[Id("value (any)",ui("The value to be verified as a number."))],compute:function(e){return"number"==typeof e?.value},isExported:!0},gb={description:ui("Whether a value is text."),args:[Id("value (any)",ui("The value to be verified as text."))],compute:function(e){return"string"==typeof e?.value&&!1===fn(e?.value)},isExported:!0},pb={description:ui("Whether the referenced cell is empty"),args:[Id("value (any)",ui("Reference to the cell that will be checked for emptiness."))],compute:function(e){return null===e?.value},isExported:!0},mb={description:ui("Returns the error value #N/A."),args:[],compute:function(){return{value:sn.NotAvailable}},isExported:!0};var fb=Object.freeze({__proto__:null,CELL:rb,ISBLANK:pb,ISERR:ab,ISERROR:lb,ISLOGICAL:cb,ISNA:hb,ISNONTEXT:db,ISNUMBER:ub,ISTEXT:gb,NA:mb});const vb={description:ui("Logical `and` operator."),args:[Id("logical_expression1 (boolean, range<boolean>)",ui("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.")),Id("logical_expression2 (boolean, range<boolean>, repeating)",ui("More expressions that represent logical values."))],compute:function(...e){const{result:t,foundBoolean:o}=oc(e);return o?t:new rn(er)},isExported:!0},bb={description:ui("Logical value `false`."),args:[],compute:function(){return!1},isExported:!0},Sb={description:ui("Returns value depending on logical expression."),args:[Id("logical_expression (boolean, range<boolean>)",ui("An expression or reference to a cell containing an expression that represents some logical value, i.e. TRUE or FALSE.")),Id("value_if_true (any, range)",ui("The value the function returns if logical_expression is TRUE.")),Id("value_if_false (any, range, default=FALSE)",ui("The value the function returns if logical_expression is FALSE."))],compute:function(e,t,o){if(bc(e))return zn(Sb.compute,[e,t,o]);return(An(fc(e))?t:o)??{value:0}},isExported:!0},Cb={description:ui("Value if it is not an error, otherwise 2nd argument."),args:[Id("value (any, range)",ui("The value to return if value itself is not an error.")),Id('value_if_error (any, range, default="empty")',ui("The value the function returns if value is an error."))],compute:function(e,t){if(bc(e))return zn(Cb.compute,[e,t]);return(fn(fc(e)?.value)?t:e)??{value:0}},isExported:!0},yb={description:ui("Value if it is not an #N/A error, otherwise 2nd argument."),args:[Id("value (any, range)",ui("The value to return if value itself is not #N/A an error.")),Id('value_if_error (any, range, default="empty")',ui("The value the function returns if value is an #N/A error."))],compute:function(e,t){if(bc(e))return zn(yb.compute,[e,t]);return(fc(e)?.value===sn.NotAvailable?t:e)??{value:0}},isExported:!0},Ib={description:ui("Returns a value depending on multiple logical expressions."),args:[Id("condition1 (boolean, range<boolean>)",ui("The first condition to be evaluated. This can be a boolean, a number, an array, or a reference to any of those.")),Id("value1 (any, range)",ui("The returned value if condition1 is TRUE.")),Id("condition2 (boolean, any, range, repeating)",ui("Additional conditions to be evaluated if the previous ones are FALSE.")),Id("value2 (any, range, repeating)",ui("Additional values to be returned if their corresponding conditions are TRUE."))],compute:function(...e){if(e.length%2!=0)return new rn(ui("Wrong number of arguments. Expected an even number of arguments."));for(;e.length>0;){if(bc(e[0]))return zn(Ib.compute,e);const t=An(fc(e.shift())),o=e.shift();if(t)return o??{value:0}}return new rn(ui("No match."))},isExported:!0},wb={description:ui("Returns opposite of provided logical value."),args:[Id("logical_expression (boolean)",ui("An expression or reference to a cell holding an expression that represents some logical value."))],compute:function(e){return!An(e)},isExported:!0},xb={description:ui("Logical `or` operator."),args:[Id("logical_expression1 (boolean, range<boolean>)",ui("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.")),Id("logical_expression2 (boolean, range<boolean>, repeating)",ui("More expressions that evaluate to logical values."))],compute:function(...e){const{result:t,foundBoolean:o}=sc(e);return o?t:new rn(er)},isExported:!0},Eb={description:ui("Returns a value by comparing cases to an expression."),args:[Id("expression (number, boolean, string)",ui("The value to be checked.")),Id("case1 (number, boolean, string)",ui("The first case to be checked against expression.")),Id("value1 (any)",ui("The corresponding value to be returned if case1 matches expression.")),Id("case2 (any, repeating)",ui("Additional cases to try if the previous ones don't match expression.")),Id("value2 (any, repeating)",ui("Additional values to be returned if their corresponding cases match expression.")),Id('default (any, default="empty")',ui("An optional default value to be returned if none of the cases match expression."))],compute:function(e,...t){const o=t.length%2==0?vn(e):t.pop();for(let o=0;o<t.length;o+=2){const s=t[o];if(s&&fn(s.value))return s;if(e?.value===s?.value)return t[o+1]||{value:0}}return o||{value:0}},isExported:!0},Rb={description:ui("Logical value `true`."),args:[],compute:function(){return!0},isExported:!0},Tb={description:ui("Logical `xor` operator."),args:[Id("logical_expression1 (boolean, range<boolean>)",ui("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.")),Id("logical_expression2 (boolean, range<boolean>, repeating)",ui("More expressions that evaluate to logical values."))],compute:function(...e){let t=!1,o=!1;return Bn(e,(e=>(t=!0,o=o?!e:e,!0))),t?o:new rn(er)},isExported:!0};var Ab=Object.freeze({__proto__:null,AND:vb,FALSE:bb,IF:Sb,IFERROR:Cb,IFNA:yb,IFS:Ib,NOT:wb,OR:xb,SWITCH:Eb,TRUE:Rb,XOR:Tb});const Db={Errors:{InvalidRange:ui("The range is invalid"),FirstArgMissing:ui("The argument is missing. Please provide a value"),SecondArgMissing:ui("The second argument is missing. Please provide a value"),MinNaN:ui("The minpoint must be a number"),MidNaN:ui("The midpoint must be a number"),MaxNaN:ui("The maxpoint must be a number"),ValueUpperInflectionNaN:ui("The first value must be a number"),ValueLowerInflectionNaN:ui("The second value must be a number"),MinBiggerThanMax:ui("Minimum must be smaller then Maximum"),MinBiggerThanMid:ui("Minimum must be smaller then Midpoint"),MidBiggerThanMax:ui("Midpoint must be smaller then Maximum"),LowerBiggerThanUpper:ui("Lower inflection point must be smaller than upper inflection point"),MinInvalidFormula:ui("Invalid Minpoint formula"),MaxInvalidFormula:ui("Invalid Maxpoint formula"),MidInvalidFormula:ui("Invalid Midpoint formula"),ValueUpperInvalidFormula:ui("Invalid upper inflection point formula"),ValueLowerInvalidFormula:ui("Invalid lower inflection point formula"),EmptyRange:ui("A range needs to be defined"),ValueCellIsInvalidFormula:ui("At least one of the provided values is an invalid formula"),Unexpected:ui("The rule is invalid for an unknown reason")},ColorScale:ui("Color scale"),IconSet:ui("Icon set"),DataBar:ui("Data bar")},_b={Series:ui("Series"),BackgroundColor:ui("Background color"),StackedBarChart:ui("Stacked bar chart"),StackedLineChart:ui("Stacked line chart"),StackedAreaChart:ui("Stacked area chart"),StackedColumnChart:ui("Stacked column chart"),CumulativeData:ui("Cumulative data"),TreatLabelsAsText:ui("Treat labels as text"),AggregatedChart:ui("Aggregate"),Errors:{Unexpected:ui("The chart definition is invalid for an unknown reason"),InvalidDataSet:ui("The dataset is invalid"),InvalidLabelRange:ui("Labels are invalid"),InvalidScorecardKeyValue:ui("The key value is invalid"),InvalidScorecardBaseline:ui("The baseline value is invalid"),InvalidGaugeDataRange:ui("The data range is invalid"),EmptyGaugeRangeMin:ui("A minimum range limit value is needed"),GaugeRangeMinNaN:ui("The minimum range limit value must be a number"),EmptyGaugeRangeMax:ui("A maximum range limit value is needed"),GaugeRangeMaxNaN:ui("The maximum range limit value must be a number"),GaugeLowerInflectionPointNaN:ui("The lower inflection point value must be a number"),GaugeUpperInflectionPointNaN:ui("The upper inflection point value must be a number")},GeoChart:{ColorScales:{blues:ui("Blues"),cividis:ui("Cividis"),greens:ui("Greens"),greys:ui("Greys"),oranges:ui("Oranges"),purples:ui("Purples"),rainbow:ui("Rainbow"),reds:ui("Reds"),viridis:ui("Viridis")}}},Fb={Custom:ui("Custom")},Ob=ui("Merged cells are preventing this operation. Unmerge those cells and try again."),Pb=ui("The header row of a table can't be moved."),Mb={Errors:{Unexpected:ui("Cannot split the selection for an unknown reason"),NoSplitSeparatorInSelection:ui("There is no match for the selected separator in the selection"),MoreThanOneColumnSelected:ui("Only a selection from a single column can be split"),SplitWillOverwriteContent:ui("Splitting will overwrite existing content")}},Nb={Errors:{Unexpected:ui("Cannot remove duplicates for an unknown reason"),MoreThanOneRangeSelected:ui("Please select only one range of cells"),EmptyTarget:ui("Please select a range of cells containing values."),NoColumnsProvided:ui("Please select at latest one column to analyze."),WillRemoveExistingMerge:ui("This operation is not possible due to a merge. Please remove the merges first than try again.")}},kb={DateIs:{today:ui("today"),yesterday:ui("yesterday"),tomorrow:ui("tomorrow"),lastWeek:ui("in the past week"),lastMonth:ui("in the past month"),lastYear:ui("in the past year")},DateIsBefore:{today:ui("today"),yesterday:ui("yesterday"),tomorrow:ui("tomorrow"),lastWeek:ui("one week ago"),lastMonth:ui("one month ago"),lastYear:ui("one year ago")},CriterionError:{notEmptyValue:ui("The value must not be empty"),numberValue:ui("The value must be a number"),dateValue:ui("The value must be a date"),validRange:ui("The value must be a valid range"),validFormula:ui("The formula must be valid")},Errors:{InvalidRange:ui("The range is invalid."),InvalidDataValidationCriterionValue:ui("One or more of the provided criteria values are invalid. Please review and correct them."),InvalidNumberOfCriterionValues:ui("One or more of the provided criteria values are missing."),Unexpected:ui("The rule is invalid for an unknown reason.")}},Lb={Errors:{Unexpected:ui("The table zone is invalid for an unknown reason"),TableOverlap:ui("You cannot create overlapping tables."),NonContinuousTargets:ui("A table can only be created on a continuous selection."),InvalidRange:ui("The range is invalid"),TargetOutOfSheet:ui("The range is out of the sheet")},Checkboxes:{hasFilters:ui("Filter button"),headerRow:ui("Header row(s)"),bandedRows:ui("Banded rows"),firstColumn:ui("First column"),lastColumn:ui("Last column"),bandedColumns:ui("Banded columns"),automaticAutofill:ui("Automatically autofill formulas"),totalRow:ui("Total row"),isDynamic:ui("Auto-adjust to formula result")},Tooltips:{filterWithoutHeader:ui("Cannot have filters without a header row"),isDynamic:ui("For tables based on array formulas only")}},Vb={labels:{no_calculations:ui("No calculations"),"%_of_grand_total":ui("% of grand total"),"%_of_col_total":ui("% of column total"),"%_of_row_total":ui("% of row total"),"%_of":ui("% of"),"%_of_parent_row_total":ui("% of parent row total"),"%_of_parent_col_total":ui("% of parent column total"),"%_of_parent_total":ui("% of parent total"),difference_from:ui("Difference from"),"%_difference_from":ui("% difference from"),running_total:ui("Running total"),"%_running_total":ui("% Running total"),rank_asc:ui("Rank smallest to largest"),rank_desc:ui("Rank largest to smallest"),index:ui("Index")},descriptions:{"%_of_grand_total":()=>ui("Displayed as % of grand total"),"%_of_col_total":()=>ui("Displayed as % of column total"),"%_of_row_total":()=>ui("Displayed as % of row total"),"%_of":e=>ui('Displayed as % of "%s"',e),"%_of_parent_row_total":e=>ui('Displayed as % of parent row total of "%s"',e),"%_of_parent_col_total":()=>ui("Displayed as % of parent column total"),"%_of_parent_total":e=>ui('Displayed as % of parent "%s" total',e),difference_from:e=>ui('Displayed as difference from "%s"',e),"%_difference_from":e=>ui('Displayed as % difference from "%s"',e),running_total:e=>ui('Displayed as running total based on "%s"',e),"%_running_total":e=>ui('Displayed as % running total based on "%s"',e),rank_asc:e=>ui('Displayed as rank from smallest to largest based on "%s"',e),rank_desc:e=>ui('Displayed as rank largest to smallest based on "%s"',e),index:()=>ui("Displayed as index")},documentation:{no_calculations:ui("Displays the value that is entered in the field."),"%_of_grand_total":ui("Displays values as a percentage of the grand total of all the values or data points in the report."),"%_of_col_total":ui("Displays all the values in each column or series as a percentage of the total for the column or series."),"%_of_row_total":ui("Displays the value in each row or category as a percentage of the total for the row or category."),"%_of":ui("Displays values as a percentage of the value of the Base item in the Base field."),"%_of_parent_row_total":ui("Calculates values as follows:\n(value for the item) / (value for the parent item on rows)"),"%_of_parent_col_total":ui("Calculates values as follows:\n(value for the item) / (value for the parent item on columns)"),"%_of_parent_total":ui("Calculates values as follows:\n(value for the item) / (value for the parent item of the selected Base field)"),difference_from:ui("Displays values as the difference from the value of the Base item in the Base field."),"%_difference_from":ui("Displays values as the percentage difference from the value of the Base item in the Base field."),running_total:ui("Displays the value for successive items in the Base field as a running total."),"%_running_total":ui("Calculates the value as a percentage for successive items in the Base field that are displayed as a running total."),rank_asc:ui("Displays the rank of selected values in a specific field, listing the smallest item in the field as 1, and each larger value with a higher rank value."),rank_desc:ui("Displays the rank of selected values in a specific field, listing the largest item in the field as 1, and each smaller value with a higher rank value."),index:ui("Calculates values as follows:\n((value in cell) x (Grand Total of Grand Totals)) / ((Grand Row Total) x (Grand Column Total))")}};function Ub(e,t){const o=Rr(e,{format:"0,00",locale:t});return ui("Oops—this pivot table is quite large (%s cells). Try simplifying it using the side panel.",o)}function Hb(e,t){const o=t.getPivotId(e);if(!o)throw new rn(ui('There is no pivot with id "%s"',e));return o}function zb(e){if(e.length%2!=0)throw new rn(ui("Function PIVOT takes an even number of arguments."))}function Bb(e,t,o){const s=[];if("SPREADSHEET"===t.type&&t.dataSet){const{sheetId:o,zone:i}=t.dataSet,n=Go(i),r=e.getters.getRangeFromSheetXC(o,n);if(void 0===r||r.invalidXc||r.invalidSheetName)throw new cn;if(e.__originCellPosition&&r.sheetId===e.__originSheetId&&ts(cs(e.__originCellPosition),i))throw new ln;s.push(r)}for(const t of o)if(t.computedBy){const o=e.getters.getMeasureCompiledFormula(t);s.push(...o.dependencies.filter((e=>!e.invalidXc)))}const i=e.__originCellPosition;i&&s.length&&(e.updateDependencies?.(i),e.addDependencies?.(i,s))}const $b=!0,Gb=[{value:!0,label:ui("A1 style (default)")},{value:!1,label:ui("R1C1 style")}],Wb=[{value:!0,label:ui("Approximate match (default)")},{value:!1,label:ui("Exact match")}],qb={description:ui("Returns a cell reference as a string. "),args:[Id("row (number)",ui("The row number of the cell reference. ")),Id("column (number)",ui("The column number (not name) of the cell reference. A is column number 1. ")),Id("absolute_relative_mode (number, default=1)",ui("An indicator of whether the reference is row/column absolute."),[{value:1,label:ui("Absolute row and column (e.g. $A$1)")},{value:2,label:ui("Absolute row, relative column (e.g. A$1)")},{value:3,label:ui("Relative row, absolute column (e.g. $A1)")},{value:4,label:ui("Relative row and column (e.g. A1)")}]),Id("use_a1_notation (boolean, default=TRUE)",ui("A boolean indicating whether to use A1 style notation or R1C1 style notation."),Gb),Id("sheet (string, optional)",ui("A string indicating the name of the sheet into which the address points."))],compute:function(e,t,o={value:1},s={value:!0},i){const n=xn(e,this.locale),r=xn(t,this.locale);if(n<1)return new rn(dc(n));if(r<1)return new rn(dc(r));const a=xn(o,this.locale);if(![1,2,3,4].includes(a))return new rn((l=4,c=a,ui("The function [[FUNCTION_NAME]] expects a number value between %s and %s inclusive, but receives %s.",1..toString(),l.toString(),c.toString())));var l,c;let h;if(An(s)){h=_o(r-1,n-1,{rowFixed:[1,2].includes(a),colFixed:[1,3].includes(a)})}else{h=([1,2].includes(a)?`R${n}`:`R[${n}]`)+([1,3].includes(a)?`C${r}`:`C[${r}]`)}return void 0!==i?Aa(En(i),h):h},isExported:!0},Zb={description:ui("Column number of a specified cell."),args:[Id("cell_reference (meta, range<meta>, default='this cell')",ui("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(void 0===e)return void 0===this.__originCellPosition?.col?new rn(ui("In this context, the function [[FUNCTION_NAME]] needs to have a cell or range in parameter.")):this.__originCellPosition.col+1;if(void 0===e[0][0])return new rn(ui("The range is out of bounds."));if(e[0][0].value===sn.InvalidReference)return e[0][0];const t=this.getters.getRangeFromSheetXC(this.getters.getActiveSheetId(),e[0][0].value).zone.left;return 1===e.length?t+1:Vn(e.length,1,((e,o)=>({value:t+e+1})))},isExported:!0},jb={description:ui("Number of columns in a specified array or range."),args:[Id("range (any, range<any>)",ui("The range whose column count will be returned."))],compute:function(e){const t=Kn(e);return void 0===t[0][0]?new rn(ui("The range is out of bounds.")):t[0][0].value===sn.InvalidReference?t[0][0]:t.length},isExported:!0},Yb={description:ui("Horizontal lookup"),args:[Id("search_key (string, number, boolean)",ui("The value to search for. For example, 42, 'Cats', or I24.")),Id("range (any, range)",ui("The range to consider for the search. The first row in the range is searched for the key specified in search_key.")),Id("index (number)",ui("The row index of the value to be returned, where the first row in range is numbered 1.")),Id("is_sorted (boolean, default=true)",ui("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."),Wb)],compute:function(e,t,o,s={value:$b}){const i=Math.trunc(Sn(o?.value,this.locale)),n=Kn(t);if(1>i||i>n[0].length)return new rn(ui("[[FUNCTION_NAME]] evaluates to an out of bounds range."));const r=(e,t)=>e[t][0].value,a=n[An(s.value)?Zn(n,e,"nextSmaller","asc",n.length,r):jn(n,e,"wildcard",n.length,r,this.lookupCaches)];return void 0===a?vn(e):a[i-1]},isExported:!0},Xb={description:ui("Returns the content of a cell, specified by row and column offset."),args:[Id("reference (any, range)",ui("The range of cells from which the values are returned.")),Id("row (number, default=0)",ui("The index of the row to be returned from within the reference range of cells.")),Id("column (number, default=0)",ui("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=Kn(e),i=Sn(t.value,this.locale),n=Sn(o.value,this.locale);return n<0||n-1>=s.length||i<0||i-1>=s[0].length?new rn(ui("Index out of range.")):0===i&&0===n?s:0===i?[s[n-1]]:0===n?s.map((e=>[e[i-1]])):s[n-1][i-1]},isExported:!0},Kb={description:ui("Returns the content of a cell, specified by a string."),args:[Id("reference (string)",ui("The range of cells from which the values are returned.")),Id("use_a1_notation (boolean, default=TRUE)",ui("A boolean indicating whether to use A1 style notation (TRUE) or R1C1 style notation (FALSE)."),Gb)],compute:function(e,t={value:!0}){const o=e?.value?.toString();if(!o)return new cn(ui("Reference should be defined."));if(!An(t))return new rn(ui("R1C1 notation is not supported."));const s=this.__originSheetId,i=this.__originCellPosition;i&&this.updateDependencies?.(i);const n=this.getters.getRangeFromSheetXC(s,o);if(void 0===n||n.invalidXc||n.invalidSheetName)return new cn;i&&this.addDependencies?.(i,[n]);const r=[];for(let e=n.zone.left;e<=n.zone.right;e++){const t=[];for(let o=n.zone.top;o<=n.zone.bottom;o++){const s={sheetId:n.sheetId,col:e,row:o};t.push(this.getters.getEvaluatedCell(s))}r.push(t)}return 1===r.length&&1===r[0].length?r[0][0]:r},isExported:!0},Jb={description:ui("Look up a value."),args:[Id("search_key (string, number, boolean)",ui("The value to search for. For example, 42, 'Cats', or I24.")),Id("search_array (any, range)",ui("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.")),Id("result_range (any, range, optional)",ui("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=Kn(t),i=Kn(o);let n=s.length,r=s[0].length;const a=r>=n,l=a?(e,t)=>e[0][t].value:(e,t)=>e[t][0].value,c=Zn(s,e,"nextSmaller","asc",a?r:n,l);return-1===c||a&&void 0===s[0][c]||!a&&void 0===s[c][r-1]?vn(e):0===i[0].length?a?s[n-1][c]:s[c][r-1]:(n=i.length,r=i[0].length,1!==n&&1!==r?new rn(ui("The result_range must be a single row or a single column.")):n>1?c>n-1?new rn(ui("[[FUNCTION_NAME]] evaluates to an out of range row value %s.",c+1)):i[c][0]:c>r-1?new rn(ui("[[FUNCTION_NAME]] evaluates to an out of range column value %s.",c+1)):i[0][c])},isExported:!0},Qb={description:ui("Position of item in range that matches value."),args:[Id("search_key (string, number, boolean)",ui("The value to search for. For example, 42, 'Cats', or I24.")),Id("range (any, range)",ui("The one-dimensional array to be searched.")),Id("search_type (number, default=1)",ui("The search method is a number 1, 0 or -1 indicating which value to return. 1 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."),[{value:1,label:ui("Ascending order (default)")},{value:0,label:ui("Exact match")},{value:-1,label:ui("Descending order")}])],compute:function(e,t,o={value:1}){let s=Sn(o,this.locale);const i=Kn(t),n=i.length,r=i[0].length;if(1!==n&&1!==r)return new rn(ui("The range must be a single row or a single column."));let a=-1;const l=1===n?(e,t)=>e[0][t].value:(e,t)=>e[t][0].value,c=1===n?i[0].length:i.length;switch(s=Math.sign(s),s){case 1:a=Zn(i,e,"nextSmaller","asc",c,l);break;case 0:a=jn(i,e,"wildcard",c,l,this.lookupCaches);break;case-1:a=Zn(i,e,"nextGreater","desc",c,l)}return 1===n&&void 0===i[0][a]||1!==n&&void 0===i[a]?vn(e):a+1},isExported:!0},eS={description:ui("Row number of a specified cell."),args:[Id("cell_reference (meta, range<meta>, default='this cell')",ui("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(void 0===e)return void 0===this.__originCellPosition?.row?new rn(ui("In this context, the function [[FUNCTION_NAME]] needs to have a cell or range in parameter.")):this.__originCellPosition.row+1;if(void 0===e[0][0])return new rn(ui("The range is out of bounds."));if(e[0][0].value===sn.InvalidReference)return e[0][0];const t=this.getters.getRangeFromSheetXC(this.getters.getActiveSheetId(),e[0][0].value).zone.top;return 1===e[0].length?t+1:Vn(1,e[0].length,((e,o)=>({value:t+o+1})))},isExported:!0},tS={description:ui("Number of rows in a specified array or range."),args:[Id("range (any, range<any>)",ui("The range whose row count will be returned."))],compute:function(e){const t=Kn(e);return void 0===t[0][0]?new rn(ui("The range is out of bounds.")):t[0][0].value===sn.InvalidReference?t[0][0]:t[0].length},isExported:!0},oS={description:ui("Vertical lookup."),args:[Id("search_key (string, number, boolean)",ui("The value to search for. For example, 42, 'Cats', or I24.")),Id("range (any, range)",ui("The range to consider for the search. The first column in the range is searched for the key specified in search_key.")),Id("index (number)",ui("The column index of the value to be returned, where the first column in range is numbered 1.")),Id("is_sorted (boolean, default=true)",ui("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."),Wb)],compute:function(e,t,o,s={value:$b}){const i=Math.trunc(Sn(o?.value,this.locale)),n=Kn(t);if(1>i||i>n.length)return new rn(ui("[[FUNCTION_NAME]] evaluates to an out of bounds range."));const r=(e,t)=>e[0][t].value,a=An(s.value)?Zn(n,e,"nextSmaller","asc",n[0].length,r):jn(n,e,"wildcard",n[0].length,r,this.lookupCaches),l=n[i-1][a];return void 0===l?vn(e):l},isExported:!0},sS={0:"strict",1:"nextGreater","-1":"nextSmaller",2:"wildcard"},iS={description:ui("Search a range for a match and return the corresponding item from a second range."),args:[Id("search_key (string,number,boolean)",ui("The value to search for.")),Id("lookup_range (any, range)",ui("The range to consider for the search. Should be a single column or a single row.")),Id("return_range (any, range)",ui("The range containing the return value. Should have the same dimensions as lookup_range.")),Id("if_not_found (any, optional)",ui("If a valid match is not found, return this value.")),Id("match_mode (any, default=0)",ui("Specifies how to match search_key with the items in lookup_range. "),[{value:0,label:ui("Exact match (default)")},{value:-1,label:ui("Exact match or next smaller item")},{value:1,label:ui("Exact match or next larger item")},{value:2,label:ui("Wildcard character match")}]),Id("search_mode (any, default=1)",ui("Specifies the search mode to use. By default, a first to last search will be used."),[{value:1,label:ui("Search first to last (default)")},{value:-1,label:ui("Search last to first")},{value:2,label:ui("Binary search (sorted ascending order)")},{value:-2,label:ui("Binary search (sorted descending order)")}])],compute:function(e,t,o,s,i={value:0},n={value:1}){const r=Math.trunc(Sn(i.value,this.locale)),a=Math.trunc(Sn(n.value,this.locale)),l=Kn(t),c=Kn(o);if(1!==l.length&&1!==l[0].length)return new rn(ui("lookup_range should be either a single row or single column."));if(![1,-1,2,-2].includes(a))return new rn(ui("search_mode should be a value in [-1, 1, -2, 2]."));if(![-1,0,1,2].includes(r))return new rn(ui("match_mode should be a value in [-1, 0, 1, 2]."));const h=1===l.length?"col":"row";if(2===r&&[-2,2].includes(a))return new rn(ui("The search and match mode combination is not supported for XLOOKUP evaluation."));if("col"===h?c[0].length!==l[0].length:c.length!==l.length)return new rn(ui("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=sS[r],p=-1===a,m=2===a||-2===a?Zn(l,e,g,2===a?"asc":"desc",u,d):jn(l,e,g,u,d,this.lookupCaches,p);return-1!==m?"col"===h?c.map((e=>[e[m]])):[c[m]]:void 0===s?vn(e):[[s]]},isExported:!0},nS={description:ui("Get the value from a pivot."),args:[Id("pivot_id (number,string)",ui("ID of the pivot.")),Id("measure_name (string)",ui("Name of the measure.")),Id("domain_field_name (string,repeating)",ui("Field name.")),Id("domain_value (number,string,boolean,repeating)",ui("Value."))],compute:function(e,t,...o){const s=En(e),i=En(t),n=Hb(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 rn(ui("The argument %s is not a valid measure. Here are the measures: %s",t,e))}}(n,i,this.getters),zb(o);const r=this.getters.getPivot(n),a=this.getters.getPivotCoreDefinition(n);Bb(this,a,a.measures.filter((e=>e.id===i))),r.init({reload:r.needsReevaluation});const l=r.assertIsValid({throwOnError:!1});if(l)return l;if(!r.areDomainArgsFieldsValid(o)){const e=ui("Consider using a dynamic pivot formula: %s. Or re-insert the static pivot from the Data menu.",`=PIVOT(${s})`);return{value:sn.GenericError,message:ui("Dimensions don't match the pivot definition")+". "+e}}const c=r.parseArgsToPivotDomain(o);return this.getters.getActiveSheetId()===this.__originSheetId&&this.getters.getPivotPresenceTracker(n)?.trackValue(i,c),r.getPivotCellValueAndFormat(i,c)}},rS={description:ui("Get the header of a pivot."),args:[Id("pivot_id (number,string)",ui("ID of the pivot.")),Id("domain_field_name (string,repeating)",ui("Field name.")),Id("domain_value (number,string,value,repeating)",ui("Value."))],compute:function(e,...t){const o=En(e),s=Hb(o,this.getters);zb(t);const i=this.getters.getPivot(s);Bb(this,this.getters.getPivotCoreDefinition(s),[]),i.init({reload:i.needsReevaluation});const n=i.assertIsValid({throwOnError:!1});if(n)return n;if(!i.areDomainArgsFieldsValid(t)){const e=ui("Consider using a dynamic pivot formula: %s. Or re-insert the static pivot from the Data menu.",`=PIVOT(${o})`);return{value:sn.GenericError,message:ui("Dimensions don't match the pivot definition")+". "+e}}const r=i.parseArgsToPivotDomain(t);this.getters.getActiveSheetId()===this.__originSheetId&&this.getters.getPivotPresenceTracker(s)?.trackHeader(r);const a=r.at(-1);if("measure"===a?.field)return i.getPivotMeasureValue(En(a.value),r);const{value:l,format:c}=i.getPivotHeaderValueAndFormat(r);return{value:l,format:a&&"measure"!==a.field&&"false"!==a.value?c:void 0}}},aS={description:ui("Get a pivot table."),args:[Id("pivot_id (string)",ui("ID of the pivot.")),Id("row_count (number, optional)",ui("number of rows")),Id("include_total (boolean, default=TRUE)",ui("Whether to include total/sub-totals or not.")),Id("include_column_titles (boolean, default=TRUE)",ui("Whether to include the column titles or not.")),Id("column_count (number, optional)",ui("number of columns")),Id("include_measure_titles (boolean, default=TRUE)",ui("Whether to include the measure titles row or not."))],compute:function(e,t={value:1e4},o={value:!0},s={value:!0},i={value:Number.MAX_VALUE},n={value:!0}){const r=En(e),a=Sn(t,this.locale);if(a<0)return new rn(ui("The number of rows must be positive."));const l=Sn(i,this.locale);if(l<0)return new rn(ui("The number of columns must be positive."));const c={displayColumnHeaders:An(s),displayTotals:An(o),displayMeasuresRow:An(n)},h=Hb(r,this.getters),d=this.getters.getPivot(h),u=this.getters.getPivotCoreDefinition(h);Bb(this,u,u.measures),d.init({reload:d.needsReevaluation});const g=d.assertIsValid({throwOnError:!1});if(g)return g;const p=d.getCollapsedTableStructure();if(p.numberOfCells>nt)return new rn(Ub(p.numberOfCells,this.locale));const m=p.getPivotCells(c);let f=0;c.displayColumnHeaders&&(f=p.columns.length-1),c.displayMeasuresRow&&f++;const v=this.getters.getPivotName(h),b=Math.min(f+a,m[0].length);if(0===b)return[[{value:v}]];const S=Math.min(1+l,m.length),C=[];for(const e of Ct(0,S)){C[e]=[];for(const t of Ct(0,b)){const o=m[e][t];switch(o.type){case"EMPTY":C[e].push({value:""});break;case"HEADER":const t=d.getPivotHeaderValueAndFormat(o.domain);C[e].push((y=o.domain,I=t,0===y.length?I:{...I,format:(I.format||"@")+"* "}));break;case"MEASURE_HEADER":C[e].push(d.getPivotMeasureValue(o.measure,o.domain));break;case"VALUE":C[e].push(d.getPivotCellValueAndFormat(o.measure,o.domain))}}}var y,I;return(c.displayColumnHeaders||c.displayMeasuresRow)&&(C[0][0]={value:v}),C}},lS={description:ui("Returns a range reference shifted by a specified number of rows and columns from a starting cell reference."),args:[Id("cell_reference (meta, range<meta>)",ui("The starting point from which to count the offset rows and columns.")),Id("offset_rows (number)",ui("The number of rows to offset by.")),Id("offset_columns (number)",ui("The number of columns to offset by.")),Id("height (number, default='height of cell_reference')",ui("The number of rows of the range to return starting at the offset target.")),Id("width (number, default='width of cell_reference')",ui("The number of columns of the range to return starting at the offset target."))],compute:function(e,t,o,s,i){if(fn(e[0][0].value))return e[0][0];const n=e[0][0].value;if(!n)return new rn("In this context, the function OFFSET needs to have a cell or range in parameter.");const r=Ho(n);let a=e[0].length,l=e.length;if(s){const e=Sn(s,this.locale);if(e<1)return new rn(ui("Height value is %(_height)s. It should be greater than or equal to 1.",{_height:e}));a=e}if(i){const e=Sn(i,this.locale);if(e<1)return new rn(ui("Width value is %(_width)s. It should be greater than or equal to 1.",{_width:e}));l=e}const{sheetName:c}=Ta(n),h=c&&this.getters.getSheetIdByName(c)||this.getters.getActiveSheetId(),d=Sn(t,this.locale),u=Sn(o,this.locale),g=this.__originCellPosition;g&&this.updateDependencies?.(g);const p=r.left+u,m=r.top+d;if(p<0||m<0)return new cn(ui("OFFSET evaluates to an out of bounds range."));const f={left:p,top:m,right:p+l-1,bottom:m+a-1},v=this.getters.getRangeFromZone(h,f);return v.invalidXc||v.invalidSheetName?new cn:(g&&this.addDependencies?.(g,[v]),Vn(l,a,((e,t)=>this.getters.getEvaluatedCell({sheetId:h,col:p+e,row:m+t}))))}};var cS=Object.freeze({__proto__:null,ADDRESS:qb,COLUMN:Zb,COLUMNS:jb,HLOOKUP:Yb,INDEX:Xb,INDIRECT:Kb,LOOKUP:Jb,MATCH:Qb,OFFSET:lS,PIVOT:aS,PIVOT_HEADER:rS,PIVOT_VALUE:nS,ROW:eS,ROWS:tS,VLOOKUP:oS,XLOOKUP:iS});const hS={description:ui("Sum of two numbers."),args:[Id("value1 (number)",ui("The first addend.")),Id("value2 (number)",ui("The second addend."))],compute:function(e,t){return{value:Sn(e,this.locale)+Sn(t,this.locale),format:e?.format||t?.format}}},dS={description:ui("Concatenation of two values."),args:[Id("value1 (string)",ui("The value to which value2 will be appended.")),Id("value2 (string)",ui("The value to append to value1."))],compute:function(e,t){return En(e)+En(t)},isExported:!0},uS={description:ui("One number divided by another."),args:[Id("dividend (number)",ui("The number to be divided.")),Id("divisor (number)",ui("The number to divide by."))],compute:function(e,t){const o=Sn(t,this.locale);return 0===o?new gn(ui("The divisor must be different from zero.")):{value:Sn(e,this.locale)/o,format:e?.format||t?.format}}};function gS(e){return void 0===e||null===e.value}const pS={number:0,string:"",boolean:!1};function mS(e,t,o=2e-16){return Math.abs(e-t)<o}const fS={description:ui("Equal."),args:[Id("value1 (string, number, boolean)",ui("The first value.")),Id("value2 (string, number, boolean)",ui("The value to test against value1 for equality."))],compute:function(e,t){if(fn(e?.value))return e;if(fn(t?.value))return t;let o=gS(e)?pS[typeof t?.value]:e?.value,s=gS(t)?pS[typeof e?.value]:t?.value;return"string"==typeof o&&(o=o.toUpperCase()),"string"==typeof s&&(s=s.toUpperCase()),"number"==typeof o&&"number"==typeof s?{value:mS(o,s)}:{value:o===s}}};function vS(e,t,o){if(fn(e?.value))return e;if(fn(t?.value))return t;let s=gS(e)?pS[typeof t?.value]:e?.value,i=gS(t)?pS[typeof e?.value]:t?.value;"number"!=typeof s&&(s=En(s).toUpperCase()),"number"!=typeof i&&(i=En(i).toUpperCase());const n=typeof s,r=typeof i;return"string"===n&&"number"===r?{value:!0}:"string"===r&&"number"===n?{value:!1}:{value:o(s,i)}}const bS={description:ui("Strictly greater than."),args:[Id("value1 (number, string, boolean)",ui("The value to test as being greater than value2.")),Id("value2 (number, string, boolean)",ui("The second value."))],compute:function(e,t){return vS(e,t,((e,t)=>"number"==typeof e&&"number"==typeof t?!mS(e,t)&&e>t:e>t))}},SS={description:ui("Greater than or equal to."),args:[Id("value1 (number, string, boolean)",ui("The value to test as being greater than or equal to value2.")),Id("value2 (number, string, boolean)",ui("The second value."))],compute:function(e,t){return vS(e,t,((e,t)=>"number"==typeof e&&"number"==typeof t?mS(e,t)||e>t:e>=t))}},CS={description:ui("Less than."),args:[Id("value1 (number, string, boolean)",ui("The value to test as being less than value2.")),Id("value2 (number, string, boolean)",ui("The second value."))],compute:function(e,t){const o=SS.compute.bind(this)(e,t);return fn(o.value)?o:{value:!o.value}}},yS={description:ui("Less than or equal to."),args:[Id("value1 (number, string, boolean)",ui("The value to test as being less than or equal to value2.")),Id("value2 (number, string, boolean)",ui("The second value."))],compute:function(e,t){const o=bS.compute.bind(this)(e,t);return fn(o.value)?o:{value:!o.value}}},IS={description:ui("Difference of two numbers."),args:[Id("value1 (number)",ui("The minuend, or number to be subtracted from.")),Id("value2 (number)",ui("The subtrahend, or number to subtract from value1."))],compute:function(e,t){return{value:Sn(e,this.locale)-Sn(t,this.locale),format:e?.format||t?.format}}},wS={description:ui("Product of two numbers"),args:[Id("factor1 (number)",ui("The first multiplicand.")),Id("factor2 (number)",ui("The second multiplicand."))],compute:function(e,t){return{value:Sn(e,this.locale)*Sn(t,this.locale),format:e?.format||t?.format}}},xS={description:ui("Not equal."),args:[Id("value1 (string, number, boolean)",ui("The first value.")),Id("value2 (string, number, boolean)",ui("The value to test against value1 for inequality."))],compute:function(e,t){const o=fS.compute.bind(this)(e,t);return fn(o.value)?o:{value:!o.value}}},ES={description:ui("A number raised to a power."),args:[Id("base (number)",ui("The number to raise to the exponent power.")),Id("exponent (number)",ui("The exponent to raise base to."))],compute:function(e,t){return qu.compute.bind(this)(e,t)}},RS={description:ui("A number with the sign reversed."),args:[Id("value (number)",ui("The number to have its sign reversed. Equivalently, the number to multiply by -1."))],compute:function(e){return{value:-Sn(e,this.locale),format:e?.format}}},TS={description:ui("Value interpreted as a percentage."),args:[Id("percentage (number)",ui("The value to interpret as a percentage."))],compute:function(e){return Sn(e,this.locale)/100}},AS={description:ui("A specified number, unchanged."),args:[Id("value (any)",ui("The number to return."))],compute:function(e={value:null}){return e}};var DS=Object.freeze({__proto__:null,ADD:hS,CONCAT:dS,DIVIDE:uS,EQ:fS,GT:bS,GTE:SS,LT:CS,LTE:yS,MINUS:IS,MULTIPLY:wS,NE:xS,POW:ES,UMINUS:RS,UNARY_PERCENT:TS,UPLUS:AS});const _S=e=>({transform:t=>t*e,inverseTransform:t=>t/e}),FS={transform:e=>e,inverseTransform:e=>e},OS=1e-10,PS=.0254,MS=PS/72,NS=.3048,kS=.9144,LS=1609.34,VS=1852,US=946073047258e4,HS={g:{...FS,category:"weight"},u:{..._S(166053e-29),category:"weight"},grain:{..._S(.0647989),category:"weight"},ozm:{..._S(28.3495),category:"weight"},lbm:{..._S(453.592),category:"weight"},stone:{..._S(6350.29),category:"weight"},sg:{..._S(14593.90294),category:"weight"},cwt:{..._S(45359.237),category:"weight"},uk_cwt:{..._S(50802.3),category:"weight"},ton:{..._S(907184.74),category:"weight"},uk_ton:{..._S(1016046.9),category:"weight"},m:{...FS,category:"distance"},km:{..._S(1e3),category:"distance"},ang:{..._S(OS),category:"distance"},Picapt:{..._S(MS),category:"distance"},pica:{..._S(PS/6),category:"distance"},in:{..._S(PS),category:"distance"},ft:{..._S(NS),category:"distance"},yd:{..._S(kS),category:"distance"},ell:{..._S(1.143),category:"distance"},mi:{..._S(LS),category:"distance"},survey_mi:{..._S(1609.34),category:"distance"},Nmi:{..._S(VS),category:"distance"},ly:{..._S(US),category:"distance"},parsec:{..._S(0x6da012f95c9fd0),category:"distance"},sec:{...FS,category:"time"},min:{..._S(60),category:"time"},hr:{..._S(3600),category:"time"},day:{..._S(86400),category:"time"},yr:{..._S(31556952),category:"time"},Pa:{...FS,category:"pressure"},bar:{..._S(1e5),category:"pressure"},mmHg:{..._S(133.322),category:"pressure"},Torr:{..._S(133.322),category:"pressure"},psi:{..._S(6894.76),category:"pressure"},atm:{..._S(101325),category:"pressure"},N:{...FS,category:"force"},dyn:{..._S(1e-5),category:"force"},pond:{..._S(.00980665),category:"force"},lbf:{..._S(4.44822),category:"force"},J:{...FS,category:"energy"},eV:{..._S(160218e-24),category:"energy"},e:{..._S(1e-7),category:"energy"},flb:{..._S(1.3558179483),category:"energy"},c:{..._S(4.184),category:"energy"},cal:{..._S(4.1868),category:"energy"},BTU:{..._S(1055.06),category:"energy"},Wh:{..._S(3600),category:"energy"},HPh:{..._S(2684520),category:"energy"},W:{...FS,category:"power"},PS:{..._S(735.499),category:"power"},HP:{..._S(745.7),category:"power"},T:{...FS,category:"magnetism"},ga:{..._S(1e-4),category:"magnetism"},K:{...FS,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:{..._S(5/9),category:"temperature"},Reau:{transform:e=>1.25*e+273.15,inverseTransform:e=>(e-273.15)/1.25,category:"temperature"},"m^3":{...FS,category:"volume",order:3},"ang^3":{..._S(Math.pow(OS,3)),category:"volume",order:3},"Picapt^3":{..._S(Math.pow(MS,3)),category:"volume",order:3},tsp:{..._S(492892e-11),category:"volume"},tspm:{..._S(5e-6),category:"volume"},tbs:{..._S(14786764825785619e-21),category:"volume"},"in^3":{..._S(Math.pow(PS,3)),category:"volume",order:3},oz:{..._S(295735295625e-16),category:"volume"},cup:{..._S(237e-6),category:"volume"},pt:{..._S(.0004731765),category:"volume"},uk_pt:{..._S(568261e-9),category:"volume"},qt:{..._S(.0009463529),category:"volume"},l:{..._S(.001),category:"volume"},uk_qt:{..._S(.0011365225),category:"volume"},gal:{..._S(.0037854118),category:"volume"},uk_gal:{..._S(.00454609),category:"volume"},"ft^3":{..._S(Math.pow(NS,3)),category:"volume",order:3},bushel:{..._S(.0352390704),category:"volume"},barrel:{..._S(.158987295),category:"volume"},"yd^3":{..._S(Math.pow(kS,3)),category:"volume",order:3},MTON:{..._S(1.13267386368),category:"volume"},GRT:{..._S(2.83168),category:"volume"},"mi^3":{..._S(Math.pow(LS,3)),category:"volume",order:3},"Nmi^3":{..._S(Math.pow(VS,3)),category:"volume",order:3},"ly^3":{..._S(Math.pow(US,3)),category:"volume",order:3},"m^2":{...FS,category:"area",order:2},"ang^2":{..._S(Math.pow(OS,2)),category:"area",order:2},"Picapt^2":{..._S(Math.pow(MS,2)),category:"area",order:2},"in^2":{..._S(Math.pow(PS,2)),category:"area",order:2},"ft^2":{..._S(Math.pow(NS,2)),category:"area",order:2},"yd^2":{..._S(Math.pow(kS,2)),category:"area",order:2},ar:{..._S(100),category:"area"},Morgen:{..._S(2500),category:"area"},uk_acre:{..._S(4046.8564224),category:"area"},us_acre:{..._S(4046.8726098743),category:"area"},ha:{..._S(1e4),category:"area"},"mi^2":{..._S(Math.pow(LS,2)),category:"area",order:2},"Nmi^2":{..._S(Math.pow(VS,2)),category:"area",order:2},"ly^2":{..._S(Math.pow(US,2)),category:"area",order:2},bit:{...FS,category:"information"},byte:{..._S(8),category:"information"},"m/s":{...FS,category:"speed"},"m/hr":{..._S(1/3600),category:"speed"},"km/hr":{..._S(1/3.6),category:"speed"},mph:{..._S(.44704),category:"speed"},kn:{..._S(.5144444444),category:"speed"},admkn:{..._S(.5147733333),category:"speed"}},zS={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"},BS={"":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)},$S={weight:ui("Weight"),distance:ui("Distance"),time:ui("Time"),pressure:ui("Pressure"),force:ui("Force"),energy:ui("Energy"),power:ui("Power"),magnetism:ui("Magnetism"),temperature:ui("Temperature"),volume:ui("Volume"),area:ui("Area"),information:ui("Information"),speed:ui("Speed")},GS=Object.entries(HS).map((([e,t])=>({value:e,label:WS(t.category)})));function WS(e){return $S[e]??""}function qS(e){for(const[t,o]of Object.entries(BS)){if(t&&!e.startsWith(t))continue;const s=e.slice(t.length);let i=HS[s];if(!i&&zS[s]&&(i=HS[zS[s]]),i)return{...i,factor:i.order?Math.pow(o,i.order):o}}}const ZS={description:ui("Converts a numeric value to a different unit of measure."),args:[Id("value (number)",ui("the numeric value in start_unit to convert to end_unit")),Id("start_unit (string)",ui("The starting unit, the unit currently assigned to value"),GS),Id("end_unit (string)",ui("The unit of measure into which to convert value"),GS)],compute:function(e,t,o){const s=Sn(e,this.locale),i=En(t),n=En(o),r=qS(i),a=qS(n);return r?a?r.category!==a.category?{value:sn.GenericError,message:ui("Incompatible units of measure ('%s' vs '%s')",WS(r.category),WS(a.category))}:{value:a.inverseTransform(r.factor*r.transform(s))/a.factor,format:e?.format}:{value:sn.GenericError,message:ui("Invalid units of measure ('%s')",n)}:{value:sn.GenericError,message:ui("Invalid units of measure ('%s')",i)}},isExported:!0};var jS=Object.freeze({__proto__:null,CONVERT:ZS});const YS=/[A-Za-zÀ-ÖØ-öø-ÿ]+/g,XS=[{value:0,label:ui("Case-sensitive (default)")},{value:1,label:ui("Case-insensitive")}],KS=[{value:0,label:ui("Don't match to end (default)")},{value:1,label:ui("Match to end")}],JS={description:ui("Gets character associated with number."),args:[Id("table_number (number)",ui("The number of the character to look up from the current Unicode table in decimal format."))],compute:function(e){const t=Math.trunc(Sn(e,this.locale));return t<1?new rn(ui("The table_number (%s) is out of range.",t)):String.fromCharCode(t)},isExported:!0},QS={description:ui("Remove non-printable characters from a piece of text."),args:[Id("text (string)",ui("The text whose non-printable characters are to be removed."))],compute:function(e){const t=En(e);let o="";for(const e of t)e&&e.charCodeAt(0)>31&&(o+=e);return o},isExported:!0},eC={description:ui("Appends strings to one another."),args:[Id("string1 (string, range<string>)",ui("The initial string.")),Id("string2 (string, range<string>, repeating)",ui("More strings to append in sequence."))],compute:function(...e){return Nn(e,((e,t)=>e+En(t)),"")},isExported:!0},tC={description:ui("Tests whether two strings are identical."),args:[Id("string1 (string)",ui("The first string to compare.")),Id("string2 (string)",ui("The second string to compare."))],compute:function(e,t){return En(e)===En(t)},isExported:!0},oC={description:ui("First position of string found in text, case-sensitive."),args:[Id("search_for (string)",ui("The string to look for within text_to_search.")),Id("text_to_search (string)",ui("The text to search for the first occurrence of search_for.")),Id("starting_at (number, default=1)",ui("The character within text_to_search at which to start the search."))],compute:function(e,t,o={value:1}){const s=En(e),i=En(t),n=Sn(o,this.locale);if(""===i)return new rn(ui("The text_to_search must be non-empty."));if(n<1)return new rn(ui("The starting_at (%s) must be greater than or equal to 1.",n));const r=i.indexOf(s,n-1);return-1===r?new rn(ui("In [[FUNCTION_NAME]] evaluation, cannot find '%s' within '%s'.",s,i)):r+1},isExported:!0},sC={description:ui("Concatenates elements of arrays with delimiter."),args:[Id("delimiter (string)",ui("The character or string to place between each concatenated value.")),Id("value_or_array1 (string, range<string>)",ui("The value or values to be appended using delimiter.")),Id("value_or_array2 (string, range<string>, repeating)",ui("More values to be appended using delimiter."))],compute:function(e,...t){const o=En(e);return Nn(t,((e,t)=>(e?e+o:"")+En(t)),"")}},iC={description:ui("Substring from beginning of specified string."),args:[Id("text (string)",ui("The string from which the left portion will be returned.")),Id("number_of_characters (number, optional)",ui("The number of characters to return from the left side of string."))],compute:function(e,...t){const o=t.length?Sn(t[0],this.locale):1;return o<0?new rn(ui("The number_of_characters (%s) must be positive or null.",o)):En(e).substring(0,o)},isExported:!0},nC={description:ui("Length of a string."),args:[Id("text (string)",ui("The string whose length will be returned."))],compute:function(e){return En(e).length},isExported:!0},rC={description:ui("Converts a specified string to lowercase."),args:[Id("text (string)",ui("The string to convert to lowercase."))],compute:function(e){return En(e).toLowerCase()},isExported:!0},aC={description:ui("A segment of a string."),args:[Id("text (string)",ui("The string to extract a segment from.")),Id("starting_at (number)",ui("The index from the left of string from which to begin extracting. The first character in string has the index 1.")),Id("extract_length (number)",ui("The length of the segment to extract."))],compute:function(e,t,o){const s=En(e),i=Sn(t,this.locale),n=Sn(o,this.locale);return i<1?new rn(ui("The starting_at argument (%s) must be positive greater than one.",i.toString())):n<0?new rn(ui("The extract_length argument (%s) must be positive or null.",n)):s.slice(i-1,i+n-1)},isExported:!0},lC={description:ui("Capitalizes each word in a specified string."),args:[Id("text_to_capitalize (string)",ui("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 En(e).replace(YS,(e=>e.charAt(0).toUpperCase()+e.slice(1).toLowerCase()))},isExported:!0},cC={description:ui("Extract text from a string based on the supplied regular expression."),args:[Id("text (string)",ui("The string on which you want to extract text.")),Id("pattern (string)",ui("The regular expression pattern to match against the text.")),Id("return_mode (number, default=0)",ui("0 = first match, 1 = all matches as an array, 2 = capturing groups from the first match as an array."),[{value:0,label:ui("First match")},{value:1,label:ui("All matches")},{value:2,label:ui("Capture groups of first match")}]),Id("case_sensitivity (number, default=0)",ui("Whether the match is case-sensitive."),[{value:0,label:ui("Case-sensitive")},{value:1,label:ui("Case-insensitive")}])],compute:function(e,t,o={value:0},s={value:0}){const i=En(e),n=En(t),r=Sn(o,this.locale),a=Sn(s,this.locale);if(""===i||""===n)return{value:""};if(r<0||r>2)return new rn(ui("The return_mode (%s) must be 0, 1 or 2.",r));if(0!==a&&1!==a)return new rn(ui("The case_sensitivity (%s) must be 0 or 1.",a));const l=new RegExp(n,1===a?"gi":"g"),c=[...i.matchAll(l)];return 0===c.length?{value:sn.NotAvailable,message:ui("No matches found.")}:0===r?c[0][0]:1===r?c.map((e=>[e[0]])):c[0].length<2?new rn(ui("No capturing groups found.")):c[0].slice(1).map((e=>[e]))},isExported:!0},hC={description:ui("Replaces part of a text string with different text."),args:[Id("text (string)",ui("The text, a part of which will be replaced.")),Id("position (number)",ui("The position where the replacement will begin (starting from 1).")),Id("length (number)",ui("The number of characters in the text to be replaced.")),Id("new_text (string)",ui("The text which will be inserted into the original text."))],compute:function(e,t,o,s){const i=Sn(t,this.locale);if(i<1)return new rn(ui("The position (%s) must be greater than or equal to 1.",i));const n=En(e),r=Sn(o,this.locale),a=En(s);return n.substring(0,i-1)+a+n.substring(i-1+r)},isExported:!0},dC={description:ui("A substring from the end of a specified string."),args:[Id("text (string)",ui("The string from which the right portion will be returned.")),Id("number_of_characters (number, optional)",ui("The number of characters to return from the right side of string."))],compute:function(e,...t){const o=t.length?Sn(t[0],this.locale):1;if(o<0)return new rn(ui("The number_of_characters (%s) must be positive or null.",o));const s=En(e),i=s.length;return s.substring(i-o,i)},isExported:!0},uC={description:ui("First position of string found in text, ignoring case."),args:[Id("search_for (string)",ui("The string to look for within text_to_search.")),Id("text_to_search (string)",ui("The text to search for the first occurrence of search_for.")),Id("starting_at (number, default=1)",ui("The character within text_to_search at which to start the search."))],compute:function(e,t,o={value:1}){const s=En(e).toLowerCase(),i=En(t).toLowerCase(),n=Sn(o,this.locale);if(""===i)return{value:sn.GenericError,message:ui("The text_to_search must be non-empty.")};if(n<1)return{value:sn.GenericError,message:ui("The starting_at (%s) must be greater than or equal to 1.",n)};const r=i.indexOf(s,n-1);return-1===r?{value:sn.GenericError,message:ui("In [[FUNCTION_NAME]] evaluation, cannot find '%s' within '%s'.",s,i)}:{value:r+1}},isExported:!0},gC={description:ui("Split text by specific character delimiter(s)."),args:[Id("text (string)",ui("The text to divide.")),Id("delimiter (string)",ui("The character or characters to use to split text.")),Id("split_by_each (boolean, default=true})",ui("Whether or not to divide text around each character contained in delimiter.")),Id("remove_empty_text (boolean, default=true)",ui("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=En(e),n=gt(En(t)),r=An(o),a=An(s);if(n.length<=0)return new rn(ui("The delimiter (%s) must be not be empty.",n));const l=r?new RegExp(`[${n}]`,"g"):new RegExp(n,"g");let c=i.split(l);return a&&(c=c.filter((e=>""!==e))),Hn([c])},isExported:!1},pC={description:ui("Replaces existing text with new text in a string."),args:[Id("text_to_search (string)",ui("The text within which to search and replace.")),Id("search_for (string)",ui("The string to search for within text_to_search.")),Id("replace_with (string)",ui("The string that will replace search_for.")),Id("occurrence_number (number, optional)",ui("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=Sn(s,this.locale);if(i<0)return new rn(ui("The occurrenceNumber (%s) must be positive or null.",i));const n=En(e),r=En(t);if(""===r)return n;const a=En(o),l=new RegExp(gt(r),"g");if(0===i)return n.replace(l,a);let c=0;return n.replace(l,(e=>++c===i?a:e))},isExported:!0},mC={description:ui("Combines text from multiple strings and/or arrays."),args:[Id("delimiter (string)",ui(" A string, possible empty, or a reference to a valid string. If empty, the text will be simply concatenated.")),Id("ignore_empty (boolean)",ui("A boolean; if TRUE, empty cells selected in the text arguments won't be included in the result."),[{value:!0,label:ui("Ignore empty cells")},{value:!1,label:ui("Include empty cells (default)")}]),Id("text1 (string, range<string>)",ui("Any text item. This could be a string, or an array of strings in a range.")),Id("text2 (string, range<string>, repeating)",ui("Additional text item(s)."))],compute:function(e,t={value:true},...o){const s=En(e),i=An(t);let n=0;return Nn(o,((e,t)=>i&&""===En(t)?e:(n++?e+s:"")+En(t)),"")},isExported:!0},fC={description:ui("Splits text into rows or columns using specified column and row delimiters."),args:[Id("text (string)",ui("The text to split.")),Id("col_delimiter (string, range<string>)",ui("Character or string to split columns by.")),Id("row_delimiter (string, range<string>, optional)",ui("Character or string to split rows by.")),Id("ignore_empty (boolean, default=false)",ui("Whether to ignore empty cells."),[{value:!1,label:ui("Include empty cells (default)")},{value:!0,label:ui("Ignore empty cells")}]),Id("match_mode (number, default=0)",ui("Searches the text for a delimiter match. By default, a case-sensitive match is done."),XS),Id(`pad_with (string, default="${sn.NotAvailable}")`,ui("The value to use for padding empty cells."))],compute:function(e,t,o,s={value:false},i={value:0},n=new hn){const r=En(e);if(r.length<=0)return new rn(ui("No text to split."));if(void 0===t&&void 0===o)return new rn(ui("At least one delimiter must be provided."));const a=Kn(t).flat().map((e=>gt(En(e)))),l=Kn(o).flat().map((e=>gt(En(e))));if(a.some((e=>""===e))||l.some((e=>""===e)))return new rn(ui("The delimiters cannot be empty values."));const c=An(s),h=Sn(i,this.locale);if(![0,1].includes(h))return new rn(ui("match_mode should be a value of 0 or 1."));const d=[],u=1===h?"gi":"g",g=l.filter((e=>!a.includes(e)));let p=g.length?r.split(new RegExp(g.join("|"),u)):[r];c&&(p=p.filter((e=>""!==e)));const m=new RegExp(a.join("|"),u);for(const e of p){let t=a.length?e.split(m):[e];c&&(t=t.filter((e=>""!==e))),d.push(t.map((e=>({value:e}))))}const f=Math.max(...d.map((e=>e.length)));for(const e of d)for(;e.length<f;)e.push(n);return Hn(d)},isExported:!0},vC={description:ui("Removes space characters."),args:[Id("text (string)",ui("The text or reference to a cell containing text to be trimmed."))],compute:function(e){return oo(En(e))},isExported:!0},bC={description:ui("Converts a specified string to uppercase."),args:[Id("text (string)",ui("The string to convert to uppercase."))],compute:function(e){return En(e).toUpperCase()},isExported:!0},SC={description:ui("Converts a number to text according to a specified format."),args:[Id("number (number)",ui("The number, date or time to format.")),Id("format (string)",ui('The case-sensitive format of the result, enclosed in quotation marks. Examples: "0.00" rounded to 2 decimal places, "hh:mm:ss" for hour:minutes:seconds.'))],compute:function(e,t){return Rr(Sn(e,this.locale),{format:En(t),locale:this.locale})},isExported:!0},CC={description:ui("Converts a string to a numeric value."),args:[Id("value (number)",ui("the string to be converted"))],compute:function(e){return Sn(e,this.locale)},isExported:!0},yC={description:ui("Returns text that occurs after a given substring or delimiter."),args:[Id("text (string)",ui("The source text.")),Id("delimiter (string)",ui("The substring after which text will be returned.")),Id("instance_num (number, default=1)",ui("The desired instance of the delimiter after which we extract the text. A negative number searches from the end.")),Id("match_mode (number, default=0)",ui("Searches the text for a delimiter match. By default, a case-sensitive match is done."),XS),Id("match_end (number, default=0))",ui("Whether to treat the end of text as a delimiter."),KS),Id(`if_not_found (string, default="${sn.NotAvailable}")`,ui("Value to return if the delimiter is not found."))],compute:function(e,t,o={value:1},s={value:0},i={value:0},n=new hn){const r=En(e),a=Sn(o,this.locale),l=Sn(s,this.locale),c=Sn(i,this.locale);if(0===a)return new rn(ui("The instance_num (%s) must not be zero.",a));if(0!==l&&1!==l)return new rn(ui("match_mode should have a value of 0 or 1."));if(0!==c&&1!==c)return new rn(ui("match_end should have a value of 0 or 1."));const h=En(t);if(""===h)return Math.sign(a)>0?{value:r}:{value:""};const d=1===l?"gi":"g",u=gt(h),g=new RegExp(u,d);let p=[...r.matchAll(g)].map((e=>e.index+u.length));if(a<0&&(p=p.reverse()),c&&Math.abs(a)===p.length+1)return Math.sign(a)>0?{value:""}:{value:r};const m=p[Math.abs(a)-1];return void 0===m?n:{value:r.substring(m)}},isExported:!0},IC={description:ui("Returns text that occurs before a given substring or delimiter."),args:[Id("text (string)",ui("The source text.")),Id("delimiter (string)",ui("The substring after which text will be returned.")),Id("instance_num (number, default=1)",ui("The desired instance of the delimiter before which we extract the text. A negative number searches from the end.")),Id("match_mode (number, default=0)",ui("Searches the text for a delimiter match. By default, a case-sensitive match is done."),XS),Id("match_end (number, default=0))",ui("Whether to match a delimiter against the end of the text."),KS),Id(`if_not_found (string, default="${sn.NotAvailable}")`,ui("Value to return if the delimiter is not found."))],compute:function(e,t,o={value:1},s={value:0},i={value:0},n=new hn){const r=En(e),a=Sn(o,this.locale),l=Sn(s,this.locale),c=Sn(i,this.locale);if(0===a)return new rn(ui("The instance_num (%s) must not be zero.",a));if(0!==l&&1!==l)return new rn(ui("match_mode should have a value of 0 or 1."));if(0!==c&&1!==c)return new rn(ui("match_end should have a value of 0 or 1."));const h=En(t);if(""===h)return Math.sign(a)>0?{value:""}:{value:r};const d=1===l?"gi":"g",u=gt(h),g=new RegExp(u,d);let p=[...r.matchAll(g)].map((e=>e.index+u.length));if(a<0&&(p=p.reverse()),c&&Math.abs(a)===p.length+1)return Math.sign(a)>0?{value:r}:{value:""};const m=p[Math.abs(a)-1];return void 0===m?n:{value:r.substring(0,m-h.length)}},isExported:!0};var wC=Object.freeze({__proto__:null,CHAR:JS,CLEAN:QS,CONCATENATE:eC,EXACT:tC,FIND:oC,JOIN:sC,LEFT:iC,LEN:nC,LOWER:rC,MID:aC,PROPER:lC,REGEXEXTRACT:cC,REPLACE:hC,RIGHT:dC,SEARCH:uC,SPLIT:gC,SUBSTITUTE:pC,TEXT:SC,TEXTAFTER:yC,TEXTBEFORE:IC,TEXTJOIN:mC,TEXTSPLIT:fC,TRIM:vC,UPPER:bC,VALUE:CC});const xC={description:ui("Creates a hyperlink in a cell."),args:[Id("url (string)",ui("The full URL of the link enclosed in quotation marks.")),Id("link_label (string, optional)",ui("The text to display in the cell, enclosed in quotation marks."))],compute:function(e,t){const o=En(e).trim(),s=En(t)||o;return""===o?s:At(s,o)},isExported:!0};var EC=Object.freeze({__proto__:null,HYPERLINK:xC});const RC=[{name:ui("Array"),functions:Kd},{name:ui("Database"),functions:qp},{name:ui("Date"),functions:df},{name:ui("Filter"),functions:wf},{name:ui("Financial"),functions:Ov},{name:ui("Info"),functions:fb},{name:ui("Lookup"),functions:cS},{name:ui("Logical"),functions:Ab},{name:ui("Math"),functions:bg},{name:ui("Misc"),functions:Qd},{name:ui("Operator"),functions:DS},{name:ui("Statistical"),functions:Fp},{name:ui("Text"),functions:wC},{name:ui("Engineering"),functions:gf},{name:ui("Web"),functions:EC},{name:ui("Parser"),functions:jS}],TC=/^[A-Z0-9\_\.]+$/;const AC=new class extends n{mapping={};add(e,t){if((e=e.toUpperCase())in this.content)throw new Error(`${e} is already present in this registry!`);return this.replace(e,t)}replace(e,t){if(e=e.toUpperCase(),!TC.test(e))throw new Error(ui("Invalid function name %s. Function names can exclusively contain alphanumerical values separated by dots (.) or underscore (_)",e));const o=function(e,t){let o=0,s=0,i=0,n=0;for(const e of t.args)o++,e.optional||e.repeating||e.default||s++,e.repeating&&i++,(e.optional||e.default)&&n++;const r=t;return r.minArgRequired=s,r.maxArgPossible=i?1/0:o,r.nbrArgRepeating=i,r.nbrArgOptional=n,r.hidden=t.hidden||!1,r.name=e,r}(e,t);return function(e){if(e.nbrArgRepeating&&e.nbrArgOptional>=e.nbrArgRepeating)throw new Error(`Function ${e.name} has more optional arguments than repeatable ones.`);let t=!1,o=!1;for(const s of e.args){if(s.type.some((e=>Ed.includes(e)))&&s.type.some((e=>!Ed.includes(e))))throw new Error(`Function ${e.name} has a mix of META and non-META types in the same argument: ${s.type}.`);if(s.repeating){if(!o&&t)throw new Error(`Function ${e.name} has non-consecutive repeating arguments. All repeating arguments must be declared consecutively.`);t=!0,o=!0}else o=!1}}(o),this.mapping[e]=function(e){function t(...t){const s=[],i=xd(e,t.length);for(let o=0;o<t.length;o++){const n=i(o)??-1,r=e.args[n];if(!E(t[o])&&r.acceptMatrixOnly)throw new an(ui("Function %s expects the parameter '%s' to be reference to a cell or range.",e.name,(o+1).toString()));s.push(!r.acceptMatrix)}return zn(o.bind(this),t,s)}function o(...t){for(let o=0;o<t.length;o++){const s=t[o],i=xd(e,t.length);if(!e.args[i(o)||o].acceptErrors&&!E(s)&&fn(s?.value))return s}try{return s.apply(this,t)}catch(t){return DC(t,e.name)}}function s(...t){this.debug;const o=e.compute.apply(this,t);return E(o)?"object"==typeof o[0][0]&&null!==o[0][0]&&"value"in o[0][0]?(function(e,t){const o=e.length,s=e[0]?.length??0;for(let i=0;i<o;i++)for(let o=0;o<s;o++)t(e[i][o])}(o,(t=>_C(t,e.name))),o):Un(o,(e=>({value:e}))):"object"==typeof o&&null!==o&&"value"in o?(_C(o,e.name),o):{value:o}}return t}(o),super.replace(e,o),this}};for(const e of RC){const t=e.functions;for(let o in t){const s=t[o];s.category=s.category||e.name,o=o.replace(/_/g,"."),AC.add(o,{isExported:!1,...s}),PC(o,s.args)}}function DC(e,t){return o=e,void 0!==o?.value&&"string"==typeof o.value&&fn(e.value)?(OC(e)&&_C(e,t),e):(console.error(e),new rn(FC+(OC(e)?" "+e.message:"")));var o}function _C(e,t){e.message?.includes("[[FUNCTION_NAME]]")&&(e.message=e.message.replace("[[FUNCTION_NAME]]",t))}const FC=ui("An unexpected error occurred. Submit a support ticket at odoo.com/help.");function OC(e){return void 0!==e?.message&&"string"==typeof e.message}function PC(e,t){for(let o=0;o<t.length;o++){const s=t[o].proposalValues;if(void 0===s||0===s.length)continue;const i=t=>{const i=t.functionContext;if(!i||i.parent.toUpperCase()!==e.toUpperCase()||i.argPosition!==o)return;const n=[];let r="";for(const{value:e,label:t}of s){switch(typeof e){case"string":r=`"${e}"`;break;case"number":r=e.toString();break;case"boolean":r=e?"TRUE":"FALSE"}n.push({text:r,description:t,htmlContent:[{value:r,color:"string"==typeof e?ht.STRING:ht.NUMBER}],fuzzySearchKey:r,alwaysExpanded:!0})}return n};Rd.add(`${e}_function_${t[o].name}_argument_proposals`,{sequence:50,autoSelectFirstProposal:!0,selectProposal:MC,getProposals:i})}}function MC(e,t){let o=e.end;const s=e.end;["LEFT_PAREN","ARG_SEPARATOR"].includes(e.type)||(o=e.start),this.composer.stopComposerRangeSelection(),this.composer.changeComposerCursorSelection(o,s),this.composer.replaceComposerCursorSelection(t)}class NC{scope;code="";constructor(e=new LC){this.scope=e}append(...e){this.code+=e.map((e=>e.toString())).join("\n")+"\n"}return(e){return new kC(this.scope,this.code,e)}toString(){return VC(this.code)}}class kC{scope;returnExpression;code;constructor(e,t,o){this.scope=e,this.returnExpression=o,this.code=VC(t)}toString(){return this.code}assignResultToVariable(){if(this.scope.isAlreadyDeclared(this.returnExpression))return this;const e=this.scope.nextVariableName(),t=new NC(this.scope);return t.append(this.code),t.append(`const ${e} = ${this.returnExpression};`),t.return(e)}}class LC{nextId=1;declaredVariables=new Set;nextVariableName(){const e="_"+this.nextId++;return this.declaredVariables.add(e),e}isAlreadyDeclared(e){return this.declaredVariables.has(e)}}function VC(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 UC=AC.content,HC={"=":"EQ","+":"ADD","-":"MINUS","*":"MULTIPLY","/":"DIVIDE",">=":"GTE","<>":"NE",">":"GT","<=":"LTE","<":"LT","^":"POWER","&":"CONCATENATE"},zC={"-":"UMINUS","+":"UPLUS","%":"UNARY.PERCENT"},BC={};function $C(e){return GC(Lv(e))}function GC(e){try{return function(e){const{dependencies:t,literalValues:o,symbols:s}=function(e){const t={numbers:[],strings:[]},o=[],s=[];for(const i of e)switch(i.type){case"INVALID_REFERENCE":case"REFERENCE":o.push(i.value);break;case"STRING":const e=ut(i.value);t.strings.push({value:e});break;case"NUMBER":{const e=tn(i.value,w);t.numbers.push({value:e});break}case"SYMBOL":s.push(ft(i.value,"'"))}return{dependencies:o,literalValues:t,symbols:s}}(e),i=function(e){let t="";for(const o of e)switch(o.type){case"STRING":t+="|S|";break;case"NUMBER":t+="|N|";break;case"REFERENCE":case"INVALID_REFERENCE":o.value.includes(":")?t+="|R|":t+="|C|";break;case"SPACE":break;default:t+=o.value}return t}(e);if(!BC[i]){const r=jv([...e]),a=new LC;let l=0,c=0,h=0;if("BIN_OPERATION"===r.type&&":"===r.value)throw new an(ui("Invalid formula"));if("EMPTY"===r.type)throw new an(ui("Invalid formula"));const d=m(r),u=new NC;u.append(`// ${i}`),u.append(d),u.append(`return ${d.returnExpression};`);const g=new Function("deps","ref","range","getSymbolValue","ctx",u.toString());function p(e){const{args:t}=e,o=e.value.toUpperCase(),s=UC[o];if(!s)throw new dn(ui('Unknown function: "%s"',e.value));!function(e){const t=e.args.length,o=e.value.toUpperCase(),s=UC[o],{nbrArgRepeating:i,minArgRequired:n}=s;if(t<n)throw new an(ui("Invalid number of arguments for the %(functionName)s function. Expected %(minArgRequired)s minimum, but got %(nbrArgSupplied)s instead.",{functionName:o,minArgRequired:n,nbrArgSupplied:t}));if(t>s.maxArgPossible)throw new an(ui("Invalid number of arguments for the %(functionName)s function. Expected %(maxArgPossible)s maximum, but got %(nbrArgSupplied)s instead.",{functionName:o,maxArgPossible:s.maxArgPossible,nbrArgSupplied:t}));if(i>1){const e=t-n-i*Math.floor((t-n)/i)-s.nbrArgOptional;if(e>0)throw new an(ui("Invalid number of arguments for the %(functionName)s function. Repeatable arguments should be supplied in groups of %(nbrArgRepeating)s, with up to %(nbrArgOptional)s optional. Got %(nbrValueRemaining)s too many.",{functionName:o,nbrArgRepeating:i,nbrArgOptional:s.nbrArgOptional,nbrValueRemaining:e}))}}(e);const i=[],n=xd(s,t.length);for(let e=0;e<t.length;e++){const o=s.args[n(e)??-1],r=t[e],a=o.type||[],l=a.includes("META")||a.includes("RANGE<META>"),c=a.some((e=>WC(e)));i.push(m(r,l,c))}return i}function m(e,t=!1,o=!1){const i=new NC(a);if("REFERENCE"!==e.type&&("BIN_OPERATION"!==e.type||":"!==e.value)&&t)throw new an(ui("Argument must be a reference to a cell or range."));switch(e.debug&&(i.append("debugger;"),i.append('ctx["debug"] = true;')),e.type){case"BOOLEAN":return i.return(`{ value: ${e.value} }`);case"NUMBER":return i.return(`this.literalValues.numbers[${c++}]`);case"STRING":return i.return(`this.literalValues.strings[${l++}]`);case"REFERENCE":return i.return(`${e.value.includes(":")||o?"range":"ref"}(deps[${h++}], ${t?"true":"false"})`);case"FUNCALL":const n=p(e).map((e=>e.assignResultToVariable()));i.append(...n);const r=e.value.toUpperCase();return i.return(`ctx['${r}'](${n.map((e=>e.returnExpression))})`);case"UNARY_OPERATION":{const t=zC[e.value],o=m(e.operand,!1,!1).assignResultToVariable();return i.append(o),i.return(`ctx['${t}'](${o.returnExpression})`)}case"BIN_OPERATION":{const t=HC[e.value],o=m(e.left,!1,!1).assignResultToVariable(),s=m(e.right,!1,!1).assignResultToVariable();return i.append(o),i.append(s),i.return(`ctx['${t}'](${o.returnExpression}, ${s.returnExpression})`)}case"SYMBOL":const a=s.indexOf(e.value);return i.return(`getSymbolValue(this.symbols[${a}])`);case"EMPTY":return i.return("undefined")}}BC[i]=g}const n={execute:BC[i],dependencies:t,literalValues:o,symbols:s,tokens:e,isBadExpression:!1,normalizedFormula:i};return n}(e)}catch(t){return{tokens:e,dependencies:[],execute:function(){return t},isBadExpression:!0,normalizedFormula:e.map((e=>e.value)).join("")}}}function WC(e){return e.startsWith("RANGE")}const qC=AC.content;function ZC(e){try{return 0===Xv(jv(e)).filter((e=>"FUNCALL"===e.type&&!qC[e.value.toUpperCase()]?.isExported)).length}catch(e){return!1}}function jC(e,t){if(!e.some((e=>"SYMBOL"===e.type&&t.includes(e.value.toUpperCase()))))return[];let o;try{o=jv(e)}catch{return[]}return function(e,t){return Xv(e).filter((e=>"FUNCALL"===e.type&&t.includes(e.value.toUpperCase()))).map((e=>({functionName:e.value.toUpperCase(),args:e.args})))}(o,t)}function YC(e,t,o){if(!t.startsWith("="))return t;const s=Lv(t);for(let t=1;t<s.length;t++){if("REFERENCE"!==s[t].type)continue;const i=s[t].value,n=XC(e,i,o);i!==n&&(s[t]={value:n,type:"REFERENCE"})}return Lt(s.map((e=>e.value)))}function XC(e,t,o){const s=Ta(t).sheetName;if(s?!Ma(s,o.sheetName.old):e!==o.sheetId)return t;const i=function(e,t){if(!Ia.test(e))return La(e);return ka({xc:e,sheetId:t},KC)}(t,s?o.sheetId:e);if(i.invalidXc)return t;const n=o.applyChange(i);return"NONE"===n.changeType||"REMOVE"===n.changeType?t:Ha(n.range,e,function(e){return t=>t===e.sheetId?e.sheetName.current:""}(o))}function KC(e){return{numberOfRows:Number.MAX_SAFE_INTEGER,numberOfCols:Number.MAX_SAFE_INTEGER}}const JC="x1",QC="xMovingAverage",ey={exponential:"exp",logarithmic:"log",polynomial:"poly",trailingMovingAverage:"movingAvg"};function ty(e,t,o,s){let i=!1;const n=[];for(const s in o){let r=o[s];if(r.labelCell){const e=iy(r.labelCell,t);r.labelCell!==e&&(i=!0,r={...r,labelCell:e})}const a=iy(r.dataRange,t);void 0===a||e.getRangeString(a,a.sheetId)===sn.InvalidReference?(i=!0,r=void 0):a!==r.dataRange&&(i=!0,r={...r,dataRange:a}),n[s]=r}let r=s;const a=iy(r,t);a!==r&&(i=!0,r=a);return{isStale:i,dataSets:n.filter(Mt),labelRange:r}}function oy(e,t,o){return o.map((o=>({dataRange:za(e,t,o.dataRange),labelCell:o.labelCell?za(e,t,o.labelCell):void 0})))}function sy(e,t,o){return o?za(e,t,o):void 0}function iy(e,t){if(!e)return;const o=t(e);switch(o.changeType){case"NONE":return e;case"REMOVE":return;default:return o.range}}function ny(e,t,o,s){const i=[];for(const n of t){const t=e.getRangeFromSheetXC(o,n.dataRange),{unboundedZone:r,sheetId:a,invalidSheetName:l,invalidXc:c}=t;if(!l&&!c)if(r.left!==r.right&&r.top!==r.bottom){if(void 0===r.right)continue;for(let t=r.left;t<=r.right;t++){const o={...r,left:t,right:t};i.push({...ry(e,a,o,s?{top:o.top,bottom:o.top,left:o.left,right:o.left}:void 0),backgroundColor:n.backgroundColor,rightYAxis:"y1"===n.yAxisId,customLabel:n.label,trend:n.trend})}}else i.push({...ry(e,a,r,s?{top:r.top,bottom:r.top,left:r.left,right:r.left}:void 0),backgroundColor:n.backgroundColor,rightYAxis:"y1"===n.yAxisId,customLabel:n.label,trend:n.trend})}return i}function ry(e,t,o,s){if(o.left!==o.right&&o.top!==o.bottom)throw new Error(`Zone should be a single column or row: ${Go(o)}`);if(s){const i=Go(o),n=Go(s);return{labelCell:e.getRangeFromSheetXC(t,n),dataRange:e.getRangeFromSheetXC(t,i)}}return{labelCell:void 0,dataRange:e.getRangeFromSheetXC(t,Go(o))}}function ay(e,t){const o=t.labelCell?.zone;let s=t.dataRange.zone;if(o){const{numberOfRows:e,numberOfCols:t}=os(s);1===e?s={...s,left:s.left+1}:1===t&&(s={...s,top:s.top+1})}const i=Na({...t.dataRange,zone:s},e.getSheetSize);let n,r={};return t.customLabel?r={text:t.customLabel}:t.labelCell&&(r={reference:e.getRangeString(t.labelCell,"forceSheetReference",{useBoundedReference:!0})}),t.trend?.type&&(n={type:"polynomial"===t.trend.type&&1===t.trend.order?"linear":ey[t.trend.type],color:t.trend.color,order:t.trend.order?Math.min(t.trend.order,6):void 0,window:t.trend.window||Ye}),{label:r,range:e.getRangeString(i,"forceSheetReference",{useBoundedReference:!0}),backgroundColor:t.backgroundColor,rightYAxis:t.rightYAxis,trend:n}}function ly(e,t,o){if(!t)return;const s={...t.zone};o&&t.zone.bottom>t.zone.top&&(s.top=s.top+1);const i=Na({...t,zone:s},e.getSheetSize);return e.getRangeString(i,"forceSheetReference",{useBoundedReference:!0})}function cy(e,t,o){let s;if(t.labelRange){const i=XC(e,t.labelRange,o);i!==sn.InvalidReference&&(s=i)}const i=[];for(const s of t.dataSets){const t={...s},n=XC(e,s.dataRange,o);n!==sn.InvalidReference&&(t.dataRange=n,i.push(t))}return{...t,dataSets:i,labelRange:s}}function hy(e){return e&&Ms(e)<.3?"#FFFFFF":"#000000"}function dy(e){return e&&Ms(e)<.3?"#C8C8C8":"#666666"}function uy(e){if(e.dataSets){const t=void 0!==e.dataSets.find((e=>!Ia.test(e.dataRange)));if(t)return"InvalidDataSet";if(e.dataSets.map((e=>Uo(e.dataRange))).some((e=>e.top!==e.bottom&&ds(e))))return"InvalidDataSet"}return"Success"}function gy(e){if(e.labelRange){if(!Ia.test(e.labelRange||""))return"InvalidLabelRange"}return"Success"}function py(e,t,o){if(!o)return!1;if(!e)return!1;if(!t)return!0;const s=gs(t.dataRange.zone);return!(gs(e.zone)<s)}function my(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 fy(e,t,o=!1){return(s,i)=>{const n=e?.[i];return vy({format:n,locale:t},o)(s)}}function vy(e,t=!1){return o=>{if(o=Number(o),isNaN(o))return o;const{locale:s,format:i}=e;return Cy(t?Wr({value:o,format:i},s):Rr(o,{locale:s,format:!i&&Math.abs(o)>=1e3?"#,##":i}))}}const by=[{value:"left",label:ui("Left")},{value:"right",label:ui("Right")}];function Sy(e,t){const o=[],s=no(t.map((e=>e.data.length)));for(let t=0;t<=s;t++)o.push(e.next());return o}function Cy(e,t=Be){return e?e.length>t?e.substring(0,t)+"…":e:""}function yy(e){return e===JC||e===QC}const Iy={id:"chartShowValuesPlugin",afterDatasetsDraw(e,t,o){if(!o.showValues)return;const s=e._metasets?.[0]?.data;if(!s)return;const i=e.ctx;i.save();const{left:n,top:r,height:a,width:l}=e.chartArea;switch(i.beginPath(),i.rect(n,r,l,a),i.clip(),i.textAlign="center",i.textBaseline="middle",i.miterLimit=1,e.config.type){case"pie":case"doughnut":!function(e,t,o){for(const s of e._metasets)for(let e=0;e<s._parsed.length;e++){const i=Number(s._parsed[e]);if(isNaN(i)||0===i)continue;const n=s.data[e],{startAngle:r,endAngle:a,innerRadius:l,outerRadius:c}=n,h=(r+a)/2,d=(l+c)/2,u=n.x+d*Math.cos(h),g=n.y+d*Math.sin(h),p=t.callback(i,s,e),m=12,f=nl(o,p,{fontSize:m},"px"),v=c-l;if(f>=v||v<m)continue;const b=a-r,S=2*d*Math.tan(b/2);b<Math.PI/2&&(f>=S||S<m)||(o.fillStyle=hy(t.background),o.strokeStyle=t.background||"#ffffff",wy(p,u,g,o))}}(e,o,i);break;case"bar":case"line":case"radar":o.horizontal?xy(e,o,i):function(e,t,o){const s=e.chartArea.bottom,i=e.chartArea.top,n={};for(const r of e._metasets){if(yy(r.xAxisID)||r.hidden)continue;const a=e.scales[r.yAxisID];for(let l=0;l<r._parsed.length;l++){const c=r._parsed[l],h=Number("radar"===e.config.type?c.r:c.y);if(isNaN(h))continue;const d=r.data[l],u=d.x;let g=0;if("line"===e.config.type||"radar"===e.config.type)g=h<0?d.y+10:d.y-10;else{const e=a.getPixelForValue(0),t=12;g=Math.abs(e-d.y)<t?h<0?e+t/2:e-t/2:h<0?d.y-d.height/2:d.y+d.height/2}g=Math.min(g,s),g=Math.max(g,i),n[u]||(n[u]=[]);for(const e of n[u]||[])Math.abs(e-g)<13&&(g=h<0?e+13:e-13);n[u].push(g),o.fillStyle=d.options.backgroundColor,o.strokeStyle=t.background||"#ffffff";wy(t.callback(Number(h),r,l),u,g,o)}}}(e,o,i);break;case"funnel":xy(e,o,i)}i.restore()}};function wy(e,t,o,s){s.lineWidth=3,s.strokeText(e,t,o),s.lineWidth=1,s.fillText(e,t,o)}function xy(e,t,o){const s=e.chartArea.right,i=e.chartArea.left,n={};for(const r of e._metasets){if(yy(r.xAxisID))return;const a=e.scales[r.xAxisID].getPixelForValue(0);for(let e=0;e<r._parsed.length;e++){const l=Number(r._parsed[e].x);if(isNaN(l))continue;const c=t.callback(l,r,e),h=r.data[e],d=h.y,u=nl(o,c,{fontSize:12},"px"),g=3;let p;Math.abs(h.x-a)<u?p=l<0?a-u/2-g:a+u/2+g:(p=l<0?h.x+h.width/2:h.x-h.width/2,p=Math.min(p,s),p=Math.max(p,i)),n[d]||(n[d]=[]);for(const e of n[d])Math.abs(e-p)<u&&(p=l<0?e-u-g:e+u+g);n[d].push(p),o.fillStyle=h.options.backgroundColor,o.strokeStyle=t.background||"#ffffff",wy(c,p,d,o)}}}const Ey={showHeaders:!0,headerDesign:{align:"center",fillColor:"#808080",bold:!0,fontSize:15},showValues:!0,showLabels:!0,valuesDesign:{align:"left",verticalAlign:"bottom",fontSize:12},coloringOptions:{type:"categoryColor",colors:[],useValueBasedGradient:!0}},Ry="nullValue";function Ty(e,t){const{dataSetsValues:o}=t,s=[],i=Wy(e,o.length),n=[];for(const r in o){let{label:a,data:l,hidden:c}=o[r];a=e.dataSets?.[r].label||a;const h=i.next(),d={label:a,data:l,hidden:c,borderColor:e.background||k,borderWidth:e.stacked?1:0,backgroundColor:h,yAxisID:e.horizontal?"y":e.dataSets?.[r].yAxisId||"y",xAxisID:"x"};s.push(d);const u=e.dataSets?.[r].trend,g=t.trendDataSetsValues?.[r];u?.display&&!e.horizontal&&g&&n.push($y(d,u,g))}return s.push(...n),s}function Ay(e,t){const{dataSetsValues:o,labels:s}=t,i=e.negativeValuesColor||Y,n=e.positiveValuesColor||j,r=e.subTotalValuesColor||X,a=[],l=[],c={label:"",data:l,backgroundColor:a},h=[];let d=0;for(const t of o)if(!t.hidden){for(let c=0;c<t.data.length;c++){const u=t.data[c];if(h.push(s[c]),isNaN(Number(u))){l.push([d,d]),a.push("");continue}l.push([d,u+d]);let g=u>=0?n:i;0===c&&t===o[0]&&e.firstValueAsSubtotal&&(g=r),a.push(g),d+=u}e.showSubTotals&&(h.push(ui("Subtotal")),l.push([0,d]),a.push(r))}return{datasets:[c],labels:h}}function Dy(e,t){const{dataSetsValues:o,axisType:s,labels:i}=t,n=[],r=!!e.fillArea,a=!!e.stacked,l=[],c=Wy(e,o.length);for(let h=0;h<o.length;h++){let{label:d,data:u,hidden:g}=o[h];d=e.dataSets?.[h].label||d;const p=c.next();s&&["linear","time"].includes(s)&&(u=u.map(((e,t)=>({x:i[t]||void 0,y:e}))));const m={label:d,data:u,hidden:g,tension:0,borderColor:p,backgroundColor:r?Bs(p,Ze):p,pointBackgroundColor:p,fill:!!r&&Gy(h,a),pointRadius:e.hideDataMarkers?0:je,yAxisID:e.dataSets?.[h].yAxisId||"y"};n.push(m);const f=e.dataSets?.[h].trend,v=t.trendDataSetsValues?.[h];f?.display&&v&&l.push($y(m,f,v))}return n.push(...l),n}function _y(e,t){const o=Dy(e,t);for(const e of o)yy(e.xAxisID)||(e.showLine=!1);return o}function Fy(e,t){const{dataSetsValues:o}=t,s=[],i=Math.max(0,...o.map((e=>e?.data?.length??0))),n=Sy(new ti(i),o);for(const{label:t,data:i,hidden:r}of o){if(r)continue;const o={label:t,data:i,borderColor:e.background||"#FFFFFF",backgroundColor:n,hoverOffset:10};s.push(o)}return s}function Oy(e,t){const{dataSetsValues:o}=t,s=[],i=Wy(e,o.length),n=[];for(let r=0;r<o.length;r++){let{label:a,data:l,hidden:c}=o[r];a=e.dataSets?.[r].label||a;const h=e.dataSets?.[r],d=i.next(),u=h?.type??"line",g={label:a,data:l,hidden:c,borderColor:d,backgroundColor:d,yAxisID:e.dataSets?.[r].yAxisId||"y",xAxisID:"x",type:u,order:"bar"===u?o.length+r:r,pointRadius:e.hideDataMarkers?0:je};s.push(g);const p=e.dataSets?.[r].trend,m=t.trendDataSetsValues?.[r];p?.display&&m&&n.push($y(g,p,m))}return s.push(...n),s}function Py(e,t){const{dataSetsValues:o}=t,s=[],i=e.fillArea??!1,n=Wy(e,o.length);for(let t=0;t<o.length;t++){let{label:r,data:a,hidden:l}=o[t];e.dataSets?.[t]?.label&&(r=e.dataSets[t].label);const c=n.next(),h={label:r,data:a,hidden:l,borderColor:c,backgroundColor:c,pointRadius:e.hideDataMarkers?0:je};i&&(h.backgroundColor=Bs(c,Ze),h.fill="start"),s.push(h)}return s}function My(e,t){const{availableRegions:o,dataSetsValues:s,labels:i}=t,n=e.region||o[0]?.id,r=n?t.getGeoJsonFeatures(n):void 0,a={outline:r,showOutline:!!r,data:[]};if(r&&n){const e={};if(s[0])for(let o=0;o<s[0].data.length;o++){if(!i[o]||void 0===s[0].data[o])continue;const r=t.geoFeatureNameToId(n,i[o]);r&&(e[r]={value:s[0].data[o],label:i[o]})}for(const t of r)t.id&&a.data.push({feature:{...t,properties:{name:e[t.id]?.label}},value:e[t.id]?.value})}return[a]}function Ny(e,t){const o=t.dataSetsValues[0],s=t.labels;if(!o)return[];let{label:i,data:n}=o;i=e.dataSets?.[0].label||i;return[{label:i,data:n.map((e=>e<=0?[0,0]:[-e,e])),backgroundColor:ky(s,e.funnelColors),yAxisID:"y",xAxisID:"x",barPercentage:1,categoryPercentage:1,borderColor:e.background||k,borderWidth:3}]}function ky(e,t){const o=new ti(e.length,t);return e.map((()=>o.next()))}function Ly(e,t){const{dataSetsValues:o,labels:s}=t,i=Hy(Vy(o,s)),n=i[0]||[],r=new ti(n.length,e.groupColors||[]),a=n.map((e=>({label:e.label,color:r.next()}))),l=[];for(let t=i.length-1;t>=0;t--){const o={groupColors:a,parsing:{key:"value"},data:i[t],borderColor:t=>{const o="data"===t.type?t.raw:void 0;return o&&o.label!==Ry?e.background||k:Z},backgroundColor:e=>{const t="data"===e.type?e.raw:void 0;if(!t||t.label===Ry)return Z;const o=t.groups[0];return a.find((e=>e.label===o))?.color},hoverOffset:10};l.push(o)}return l}function Vy(e,t){const o=function(e,t){const o=[],s=Math.max(...e.map((e=>e.data.length)));for(let i=0;i<s;i++){o[i]={};for(let t=0;t<e.length;t++){const s=null===e[t].data[i]?Ry:String(e[t].data[i]);o[i][t]=s}o[i].value=Number(t[i])}return o}(e,t);return Uy(o,0,e.length,[])}function Uy(e,t,o,s){if(t>=o)return[];const i=Object.groupBy(e,(e=>e[t]));return Object.keys(i).map((e=>{const n=i[e]?.reduce(((e,t)=>e+Number(t.value)),0)||0,r=[...s,e];return{label:e,value:n,children:Uy(i[e]||[],t+1,o,[...s,e]),groups:r,depth:t}})).sort(((e,t)=>t.value-e.value))}function Hy(e){const t=[],o=[...e];for(;o.length>0;){const e=o.shift();e&&(t[e.depth]||(t[e.depth]=[]),t[e.depth].push(e),e.children&&o.push(...e.children))}return t}function zy(e,t){const{dataSetsValues:o,labels:s,locale:i,axisFormats:n}=t,r={locale:i,format:n?.y};if(0===o.length)return[];const a=Vy(o,s).sort(((e,t)=>t.value-e.value)),l=function(e,t){const o="categoryColor"===e.coloringOptions?.type?e.coloringOptions.colors:[],s=new ti(t.length,o);return t.map((e=>({label:e.label,color:s.next()})))}(e,a),c=[],h=Math.max(...o.map((e=>e.data.length)));for(let e=0;e<h;e++){c[e]={};for(let t=0;t<o.length;t++)c[e][t]=o[t].data[e]?String(o[t].data[e]):void 0;c[e].value=Number(s[e])}const d=e.showLabels??Ey.showLabels,u=e.showValues??Ey.showValues,g=e.coloringOptions||Ey.coloringOptions;let p;"colorScale"===g?.type&&(p=function(e,t){const o=Hy(e),s=o[o.length-1],i=Math.min(...s.map((e=>e.value))),n=Math.max(...s.map((e=>e.value)));if(Number.isFinite(i)&&Number.isFinite(n)){const e=[{value:i,color:t.minColor}];if(t.midColor){const o=(i+n)/2;e.push({value:o,color:t.midColor})}return e.push({value:n,color:t.maxColor}),ii(e)}return}(a,g));const m=[{data:[],tree:c,labels:{display:d||u,overflow:"hidden",...By(e.valuesDesign,Ey.valuesDesign),formatter:e=>[d?e.raw.g:void 0,u?Rr(e.raw.v,r):void 0].filter(Mt)},captions:{display:e.showHeaders??Ey.showHeaders,padding:6,...By(e.headerDesign,Ey.headerDesign)},key:"value",groups:Ct(0,o.length).map((e=>String(e))),borderWidth:0,spacing:1,displayMode:"headerBoxes",groupColors:l,backgroundColor:t=>{if("data"!==t.type)return"transparent";if(!t.raw.isLeaf)return e.headerDesign?.fillColor||Ey.headerDesign?.fillColor;if("colorScale"===g.type)return p?.(t.raw.v)||"#FF0000";if("categoryColor"===g.type)return function(e,t,o,s){const i=e.raw._data.children[0][0],n=s.find((e=>e.label===i))?.color;if(!n||!o.useValueBasedGradient)return n||"#FF0000";const r=t.find((e=>e.label===i));if(!r||!r.children.length)return n;const a=Hy(r.children),l=a[a.length-1],c=Math.max(...l.map((e=>e.value))),h=Math.min(...l.map((e=>e.value)));if(h===c||!isFinite(h)||!isFinite(c))return n;const d=Number(e.raw.v)||0,u=(d-c)/(h-c)*.5;return $s(n,u)}(t,a,g,l);throw new Error("Unsupported coloring option type}")}}];return m}function By(e,t){const o=e=>Ms(e.element.options.backgroundColor)>.7?"#666666":"#FFFFFF";return{align:e?.align??t?.align,position:e?.verticalAlign??t?.verticalAlign,color:e?.color||o,hoverColor:e?.color||o,font:{weight:e?.bold??t?.bold?"bold":"normal",style:e?.italic??t?.italic?"italic":"normal",size:e?.fontSize??t?.fontSize}}}function $y(e,t,o){const s=ks(e.backgroundColor);s.a=1;const i=t.color||$s(Ns(s),.5);return{type:"line",xAxisID:"trailingMovingAverage"===t.type?QC:JC,yAxisID:e.yAxisID,label:e.label?ui("Trend line for %s",e.label):"",data:o,order:-1,showLine:!0,pointRadius:0,backgroundColor:i,borderColor:i,borderDash:[5,5],borderWidth:void 0,fill:!1,pointBackgroundColor:i}}function Gy(e,t){return t?0===e?"origin":"-1":"origin"}function Wy(e,t){return new ti(t,e.dataSets?.map((e=>e.backgroundColor))||[])}const qy={id:"sunburstHoverPlugin",afterEvent(e,t,o){if(!o.enabled)return;const s=e.getActiveElements();let i=s.map((e=>({datasetIndex:e.datasetIndex,index:e.index})));for(const t of s){const o=e.data.datasets[t.datasetIndex].data[t.index];for(let t=0;t<e.data.datasets.length;t++){const s=e.data.datasets[t];for(let e=0;e<s.data.length;e++){const n=s.data[e];Zy(o.groups,n.groups)&&i.push({datasetIndex:t,index:e})}}}i=i.filter((t=>{const{datasetIndex:o,index:s}=t;return e.data.datasets[o].data[s].label!==Ry})),e.setActiveElements(i);for(const t of e.getSortedVisibleDatasetMetas())for(const e of t.data){const t=e.$context,{datasetIndex:o,index:s,dataset:n,raw:r}=t;if(r.label===Ry)continue;const a="function"==typeof n.backgroundColor?n.backgroundColor(t):n.backgroundColor;i.length&&!i.some((e=>e.datasetIndex===o&&e.index===s))?e.options.backgroundColor=$s(a,.5):e.options.backgroundColor=a}}};function Zy(e,t){return t.length>e.length&&e.every(((e,o)=>e===t[o]))}const jy={id:"sunburstLabelsPlugin",afterDatasetsDraw(e,t,o){if(!o.showValues&&!o.showLabels||"doughnut"!==e.config.type)return;!function(e,t,o){const s=t.style,i=s.fontSize||13,n=i+3;for(const r of e._metasets)for(let a=0;a<r._dataset.data.length;a++){const l=r._dataset.data[a];if(l.label===Ry)continue;const c=[t.showLabels?l.label:void 0,t.showValues?t.callback(l.value,"y"):void 0].filter(Mt),h=r.data[a];let{startAngle:d,endAngle:u,innerRadius:g,outerRadius:p,circumference:m}=h;const f=h.options.offset/4,v=f*(1-Math.sin(Math.min(Math.PI,m||0)));g+=v,p+=v;const b=(d+u)/2,S=(g+p)/2,C=.9*(p-g),y=u-d;if((y>=Math.PI?p:Math.sin(y/2)*g*2)<c.length*n)continue;o.save();const I={x:Math.cos(b)*f,y:Math.sin(b)*f},w=e.chartArea.left+e.chartArea.width/2+I.x,x=e.chartArea.top+e.chartArea.height/2+I.y;let E;o.translate(w,x),b>Math.PI/2?(o.rotate(b-Math.PI),E=-S):(E=S,o.rotate(b));const R=Ms(h.options.backgroundColor)>.7?"#666666":"#FFFFFF";o.fillStyle=s.textColor||R,o.textAlign="center",o.textBaseline="middle",o.font=sl(i,s.bold,s.italic);const T=-(c.length-1)*n/2;for(let e=0;e<c.length;e++){const t=bl(o,C,c[e],s,"px");o.fillText(t,E,T+e*n)}o.restore()}}(e,o,e.ctx)}};const Yy={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=Ky(s,e);if(!o)break;const n=Xy(t),r=Xy(o),a=t.$context.raw,l=a[1]-a[0],c=Math.round(l<0?n.bottom-1:n.top),h=Math.round(n.right),d=Math.round(r.left);i.strokeStyle="#999",i.beginPath(),i.moveTo(h+1,c+.5),i.lineTo(d,c+.5),i.stroke()}i.restore()}};function Xy(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 Ky(e,t){return e.find(((e,o)=>o>t&&0!==e.height))}Bh`
2
2
  .o-spreadsheet {
3
3
  .o-chart-custom-tooltip {
4
4
  font-size: 12px;
@@ -6,13 +6,13 @@
6
6
  z-index: ${Qe.FigureTooltip};
7
7
  }
8
8
  }
9
- `,Zh.add("chartShowValuesPlugin",{register:e=>e.register(Iy),unregister:e=>e.unregister(Iy)}),Zh.add("waterfallLinesPlugin",{register:e=>e.register(Yy),unregister:e=>e.unregister(Yy)}),Zh.add("funnelController",{register:e=>e.register(Xh()),unregister:e=>e.unregister(Xh())}),Zh.add("funnelElement",{register:e=>e.register(Kh()),unregister:e=>e.unregister(Kh())}),Zh.add("funnelTooltipPositioner",{register:e=>e.Tooltip.positioners.funnelTooltipPositioner=Qh,unregister:e=>e.Tooltip.positioners.funnelTooltipPositioner=void 0}),Zh.add("sunburstLabelsPlugin",{register:e=>e.register(jy),unregister:e=>e.unregister(jy)}),Zh.add("sunburstHoverPlugin",{register:e=>e.register(qy),unregister:e=>e.unregister(qy)});class Jy extends t.Component{static template="o-spreadsheet-ChartJsComponent";static props={chartId:String,isFullScreen:{type:Boolean,optional:!0}};canvas=t.useRef("graphContainer");chart;currentRuntime;animationStore;currentDevicePixelRatio=window.devicePixelRatio;get background(){return this.chartRuntime.background}get canvasStyle(){return`background-color: ${this.background}`}get chartRuntime(){const e=this.env.model.getters.getChartRuntime(this.props.chartId);if(!("chartJsConfig"in e))throw new Error("Unsupported chart runtime");return e}setup(){this.shouldAnimate&&(this.animationStore=Dh(Yh)),t.onMounted((()=>{jh();const e=this.chartRuntime;this.currentRuntime=e,this.createChart(pt(e))})),t.onWillUnmount(this.unmount.bind(this)),t.useEffect((()=>{const e=this.chartRuntime;e!==this.currentRuntime?(e.chartJsConfig.type!==this.currentRuntime.chartJsConfig.type?(this.chart?.destroy(),this.createChart(pt(e))):this.updateChartJs(pt(e)),this.currentRuntime=e):this.currentDevicePixelRatio!==window.devicePixelRatio&&(this.currentDevicePixelRatio=window.devicePixelRatio,this.updateChartJs(pt(this.currentRuntime)))}))}unmount(){this.chart?.destroy()}get shouldAnimate(){return this.env.model.getters.isDashboard()}createChart(e){let t=e.chartJsConfig;if(this.shouldAnimate&&this.animationStore){const e=this.env.model.getters.getChart(this.props.chartId)?.type;e&&this.animationStore.animationPlayed[this.animationChartId]!==e&&(t=this.enableAnimationInChartData(t),this.animationStore.disableAnimationForChart(this.animationChartId,e))}const o=this.canvas.el.getContext("2d");this.chart=new window.Chart(o,t)}updateChartJs(e){let t=e.chartJsConfig;if(this.shouldAnimate){const e=this.env.model.getters.getChart(this.props.chartId)?.type;e&&this.hasChartDataChanged()&&this.animationStore&&(t=this.enableAnimationInChartData(t),this.animationStore.disableAnimationForChart(this.animationChartId,e))}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()}hasChartDataChanged(){return!zt(this.getChartDataInRuntime(this.currentRuntime),this.getChartDataInRuntime(this.chartRuntime))}enableAnimationInChartData(e){return{...e,options:{...e.options,animation:{animateRotate:!0}}}}getChartDataInRuntime(e){const t=e.chartJsConfig.data;return{labels:t.labels,dataset:t.datasets.map((e=>({data:e.data,label:e.label,tree:e.tree})))}}get animationChartId(){return this.props.isFullScreen?this.props.chartId+"-fullscreen":this.props.chartId}}class Qy{sheetId;title;getters;humanize;constructor(e,t,o){this.title=e.title,this.sheetId=t,this.getters=o,this.humanize=e.humanize??!0}static validateChartDefinition(e,t){throw new Error("This method should be implemented by sub class")}static transformDefinition(e,t,o){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")}getCommonDataSetAttributesForExcel(e,t,o){return{dataSets:t.map((e=>ay(this.getters,e))).filter((e=>""!==e.range&&e.range!==sn.InvalidReference)),labelRange:ly(this.getters,e,o)}}}function eI(e,t,o,s,i){if("text"===t||"progress"===t||e?.type!==r.number||o?.type!==r.number)return;const n=o.value-e.value;return n>0?s:n<0?i:void 0}function tI(e,t,o){if("text"===o||e?.type!==r.number||t?.type!==r.number)return"neutral";const s=t.value-e.value;return s>0?"up":s<0?"down":"neutral"}function oI(e){return e.keyValue&&!Ia.test(e.keyValue)?"InvalidScorecardKeyValue":"Success"}function sI(e){return e.baseline&&!Ia.test(e.baseline)?"InvalidScorecardBaseline":"Success"}const iI=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"),nI=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 rI=class e extends Qy{keyValue;keyDescr;baseline;baselineMode;baselineDescr;progressBar=!1;background;baselineColorUp;baselineColorDown;fontColor;humanize;type="scorecard";constructor(e,t,o){super(e,t,o),this.keyValue=Ba(o,t,e.keyValue),this.keyDescr=e.keyDescr,this.baseline=Ba(o,t,e.baseline),this.baselineMode=e.baselineMode,this.baselineDescr=e.baselineDescr,this.background=e.background,this.baselineColorUp=e.baselineColorUp??We,this.baselineColorDown=e.baselineColorDown??qe,this.humanize=e.humanize??!0}static validateChartDefinition(e,t){return e.checkValidations(t,oI,sI)}static getDefinitionFromContextCreation(e){return{background:e.background,type:"scorecard",keyValue:e.range?e.range[0].dataRange:void 0,title:e.title||{text:""},baselineMode:Ge,baselineColorUp:We,baselineColorDown:qe,baseline:e.auxiliaryRange||"",humanize:e.humanize}}static transformDefinition(e,t,o){let s,i;if(t.baseline){const i=XC(e,t.baseline,o);i!==sn.InvalidReference&&(s=i)}if(t.keyValue){const s=XC(e,t.keyValue,o);s!==sn.InvalidReference&&(i=s)}return{...t,baseline:s,keyValue:i}}duplicateInDuplicatedSheet(t){const o=sy(this.sheetId,t,this.baseline),s=sy(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,keyDescr:this.keyDescr,humanize:this.humanize}}getDefinitionForExcel(){}updateRanges(t){const o=iy(this.baseline,t),s=iy(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 aI(e,t){const o=t.getContext("2d"),s=window.devicePixelRatio||1;t.width=s*e.canvas.width,t.height=s*e.canvas.height,o.scale(s,s);const i=e.canvas.width-me;if(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(fl(o,e.title.text,i-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,vl(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(iI);break;case"up":o.fill(nI)}o.restore()}if(e.baselineDescr){const t=e.baselineDescr;o.font=t.style.font,o.fillStyle=t.style.color,o.fillText(fl(o,t.text,i-t.position.x),t.position.x,t.position.y)}if(e.key&&(o.font=e.key.style.font,o.fillStyle=e.key.style.color,vl(o,fl(o,e.key.text,i-e.key.position.x),e.key.position,e.key.style.underline,e.key.style.strikethrough)),e.keyDescr){const t=e.keyDescr;o.font=e.keyDescr?.style.font??t.style.font,o.fillStyle=t.style.color,o.fillText(fl(o,t.text,i-t.position.x),t.position.x,t.position.y)}if(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 lI(e,t){let o,s="";const i=t.getLocale();if(e.keyValue){const n={sheetId:e.keyValue.sheetId,col:e.keyValue.zone.left,row:e.keyValue.zone.top};o=t.getEvaluatedCell(n),s=function(e,t,o){return e?t?Wr(e,o):e.formattedValue??String(e.value??""):""}(o,e.humanize??!0,i)}let n;const a=e.baseline;if(a){const e={sheetId:a.sheetId,col:a.zone.left,row:a.zone.top};n=t.getEvaluatedCell(e)}const{background:l,fontColor:c}=t.getStyleOfSingleCellChart(e.background,e.keyValue),h=function(e,t,o,s,i){if(!e)return"";if("text"===o||t?.type!==r.number||e.type!==r.number)return s?Wr(e,i):e.formattedValue;let{value:n,format:a}=e;return"progress"===o?(n=t.value/n,a="0.0%"):(n=Math.abs(t.value-n),"percentage"===o&&0!==n&&(n/=e.value),"percentage"===o&&(a="0.0%"),a||(n=Math.round(100*n)/100)),s?Wr({value:n,format:a},i):Rr(n,{format:a,locale:i})}(n,o,e.baselineMode,e.humanize??!0,i),d="progress"===e.baselineMode&&Qi(h,i)?Sn(h,i):0;return{title:{...e.title,text:e.title.text?t.dynamicTranslate(e.title.text):""},keyValue:s,keyDescr:e.keyDescr?.text?t.dynamicTranslate(e.keyDescr.text):"",baselineDisplay:h,baselineArrow:tI(n,o,e.baselineMode),baselineColor:eI(n,e.baselineMode,o,e.baselineColorUp,e.baselineColorDown),baselineDescr:"progress"!==e.baselineMode&&e.baselineDescr?.text?t.dynamicTranslate(e.baselineDescr.text):"",fontColor:c,background:l,baselineStyle:{..."percentage"!==e.baselineMode&&"progress"!==e.baselineMode&&a?t.getCellComputedStyle({sheetId:a.sheetId,col:a.zone.left,row:a.zone.top}):void 0,fontSize:e.baselineDescr?.fontSize,align:e.baselineDescr?.align},baselineDescrStyle:{textColor:e.baselineDescr?.color,...e.baselineDescr},keyValueStyle:{...e.keyValue?t.getCellComputedStyle({sheetId:e.keyValue.sheetId,col:e.keyValue.zone.left,row:e.keyValue.zone.top}):void 0,fontSize:e.keyDescr?.fontSize,align:e.keyDescr?.align},keyValueDescrStyle:{textColor:e.keyDescr?.color,...e.keyDescr},progressBar:"progress"===e.baselineMode?{value:d,color:d>0?e.baselineColorUp:e.baselineColorDown}:void 0}}const cI=.05;function hI(e,t){const o=e||"";return t&&o?" "+o:o}function dI({width:e,height:t},o){return new uI({width:e,height:t},o).computeDesign()}class uI{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-me;break;default:s=me}e.title={text:this.title,style:t.title,position:{x:s,y:fe+o/2}}}const s=t.baselineArrow?.size??0;let{height:i,width:n}=this.getTextDimensions(this.baseline,t.baselineValue.font);this.baseline||(i=this.getTextDimensions(this.baselineDescr,t.baselineDescr.font).height);const r=this.getTextDimensions(this.baselineDescr,t.baselineDescr.font).width;let a;switch(this.runtime.baselineStyle?.align){case"right":a=this.width-me-r-n;break;case"left":a=me+s;break;default:a=(this.width-n-r+s)/2}if(this.baseline&&(e.baseline={text:this.baseline,style:t.baselineValue,position:{x:a,y:this.keyValue?this.height*(1-cI*(this.runtime.progressBar?1:2)):this.height-(this.height-o-i)/2-fe}},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}})),e.baseline&&this.baselineDescr){const o={x:e.baseline.position.x+n,y:e.baseline.position.y};e.baselineDescr={text:this.baselineDescr,style:t.baselineDescr,position:o}}let l=0;this.runtime.progressBar&&(l=.05*this.height,e.progressBar={position:{x:2*me,y:.9*this.height-i-l},dimension:{height:l,width:this.width-4*me},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),d=this.getTextDimensions(this.keyDescr,t.keyDescr.font).width;let u;switch(this.runtime.keyValueStyle?.align){case"right":u=this.width-me-d-c;break;case"left":u=me;break;default:u=(this.width-c-d)/2}if(this.keyValue&&(e.key={text:this.keyValue,style:t.keyValue,position:{x:Math.max(me,u),y:.4*this.height+fe/2+(o+h/2)/2}}),e.key&&this.keyDescr){const o={x:e.key.position.x+c,y:e.key.position.y};e.keyDescr={text:this.keyDescr,style:t.keyDescr,position:o}}return e}get title(){return this.runtime.title.text??""}get keyValue(){return this.runtime.keyValue}get keyDescr(){return hI(this.runtime.keyDescr,this.keyValue)}get baseline(){return this.runtime.baselineDisplay}get baselineDescr(){return hI(this.runtime.baselineDescr,this.baseline)}get baselineArrow(){return this.runtime.baselineArrow}get backgroundColor(){return this.runtime.background}get secondaryFontColor(){return dy(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(){const e=this.runtime.keyValueStyle?.fontSize??32,t=Math.floor(.9*e);let o=this.runtime.baselineStyle?.fontSize??16;const s=Math.floor(.9*o);return this.runtime.progressBar&&(o/=1.5),{title:{font:sl(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:sl(e,this.runtime.keyValueStyle?.bold,this.runtime.keyValueStyle?.italic),strikethrough:this.runtime.keyValueStyle?.strikethrough,underline:this.runtime.keyValueStyle?.underline},keyDescr:{color:this.runtime.keyValueDescrStyle?.textColor||this.runtime.fontColor,font:sl(t,this.runtime.keyValueDescrStyle?.bold,this.runtime.keyValueDescrStyle?.italic),strikethrough:this.runtime.keyValueDescrStyle?.strikethrough,underline:this.runtime.keyValueDescrStyle?.underline},baselineValue:{font:sl(o,this.runtime.baselineStyle?.bold,this.runtime.baselineStyle?.italic),strikethrough:this.runtime.baselineStyle?.strikethrough,underline:this.runtime.baselineStyle?.underline,color:this.runtime.baselineColor||this.runtime.baselineStyle?.textColor||this.secondaryFontColor},baselineDescr:{font:sl(s,this.runtime.baselineDescrStyle?.bold,this.runtime.baselineDescrStyle?.italic),strikethrough:this.runtime.baselineDescrStyle?.strikethrough,underline:this.runtime.baselineDescrStyle?.underline,color:this.runtime.baselineDescrStyle?.textColor??this.secondaryFontColor},baselineArrow:"neutral"===this.baselineArrow||this.runtime.progressBar?void 0:{size:this.keyValue?.8*o:0,color:this.runtime.baselineColor||this.runtime.baselineStyle?.textColor||this.secondaryFontColor}}}}class gI extends t.Component{static template="o-spreadsheet-ScorecardChart";static props={chartId:String,isFullScreen:{type:Boolean,optional:!0}};canvas=t.useRef("chartContainer");get runtime(){return this.env.model.getters.getChartRuntime(this.props.chartId)}get title(){const e=this.env.model.getters.getChartDefinition(this.props.chartId).title.text;return e?this.env.model.getters.dynamicTranslate(e):""}setup(){t.useEffect(this.createChart.bind(this),(()=>{const e=this.canvas.el.getBoundingClientRect();return[e.width,e.height,this.runtime,this.canvas.el,window.devicePixelRatio]}))}createChart(){const e=this.canvas.el;aI(dI(e.getBoundingClientRect(),this.runtime),e)}}const pI=/Mac/i,mI=["Shift","Control","Alt","Meta"];function fI(e,t){return!!e&&(!!t.target&&e.contains(t.target))}function vI(){const e=document.querySelector(".o-grid-overlay");if(e){const{top:t,left:o}=e.getBoundingClientRect();return{top:t,left:o}}throw new Error("Can't find spreadsheet position")}function bI(e){return e.el?SI(e.el):{x:0,y:0,width:0,height:0}}function SI(e){const t=e.getBoundingClientRect();return{x:t.x,y:t.y,width:t.width,height:t.height}}function*CI(e){if(yield e,e.hasChildNodes())for(const t of e.childNodes)yield*CI(t)}function yI(e){const{startElement:t,endElement:o,startSelectionOffset:s,endSelectionOffset:i}=function(e){const t=document.getSelection();return{startElement:t.anchorNode||e,startSelectionOffset:t.anchorOffset,endElement:t.focusNode||e,endSelectionOffset:t.focusOffset}}(e);return{start:II(e,t,s),end:II(e,o,i)}}function II(e,t,o){let s=0;const i=CI(e);let n=i.next(),r=!0;for(;!n.done&&n.value!==t;)n.value.hasChildNodes()||n.value.textContent&&(s+=n.value.textContent.length),("P"===n.value.nodeName||"DIV"===n.value.nodeName&&n.value!==e)&&(r?r=!1:s++),n=i.next();if(n.value!==t)return 0;if(n.value.hasChildNodes()){const e=[...n.value.childNodes].slice(0,o);s+=e.reduce(((t,o,s)=>{if(null!==o.textContent){let i=o.textContent.length;return"P"===o.nodeName&&s!==e.length-1&&i++,t+i}return t}),0)}else s+=o;return"P"!==t.nodeName||r||""!==t.textContent||s++,s}const wI=/^[a-zA-Z]$/;function xI(e,t="key"){let o="";mI.includes(e.key)||(RI(e)&&(o+="Ctrl+"),e.altKey&&(o+="Alt+"),e.shiftKey&&(o+="Shift+"));const s="key"===t?e.key:e.code;return o+=wI.test(s)?s.toUpperCase():s,o}function EI(){return Boolean(pI.test(navigator.userAgent))}function RI(e){return EI()||_I()?e.metaKey:e.ctrlKey}function TI(e){return 1===e.button||RI(e)&&0===e.button}function AI(e,t){const o=document.createElement("a");o.href=e,o.download=t,document.body.appendChild(o),o.click(),document.body.removeChild(o)}function DI(){return/Firefox/i.test(navigator.userAgent)}function _I(){return/(iPad|iPhone|iPod)/i.test(navigator.userAgent)||"MacIntel"===navigator.platform&&(navigator.maxTouchPoints||1)>1}function FI(){return/Android/i.test(navigator.userAgent)||_I()||/(webOS|BlackBerry|Windows Phone)/i.test(navigator.userAgent)}function OI(e){return 8===(e=_s(e).replace("#","")).length?e.slice(6)+e.slice(0,6):e}const PI=30,MI=10,NI=20,kI=12,LI=80,VI="#F3F2F1",UI=6,HI=25;function zI(e,t){const o=e.getBoundingClientRect(),s=window.devicePixelRatio||1;e.width=s*o.width,e.height=s*o.height;const i=e.getContext("2d");i.scale(s,s);const n=function(e,t,o){const s=t.maxValue,i=t.minValue,n=ZI(t,"animated"),r=function(e,t){const o=t?HI:0,s=e.height-NI-o-MI,i=e.width-2*PI;let n,r;i>2*s?(n=2*s,r=s):(n=i,r=i/2);const a=o+MI+(s-r)/2;return{x:PI+(i-n)/2,y:a,width:n,height:r}}(e,t.title.text),a=r.width/6,l=n?(n-i.value)/(s.value-i.value):0,c={x:e.width/2,y:r.y+r.height-r.height/12};let h=LI;r.height<300&&(h*=r.height/300);const d=r.width/2,u=t.gaugeValue?.label||"-";nl(o,u,{fontSize:h},"px")>d&&(h=function(e,t,o,s=.25){let i=1;if(o(i)>e)return i;if(o(t)<e)return t;let n=(i+t)/2,r=o(n),a=0;for(;Math.abs(r-e)>s&&a<20;)r>=e?t=(i+t)/2:i=(i+t)/2,n=(i+t)/2,r=o(n),a++;return n}(d,h,(e=>nl(o,u,{fontSize:e},"px"))));const g={x:r.x+a/2,y:r.y+r.height+kI},p={x:r.x+r.width-a/2,y:r.y+r.height+kI},m=dy(t.background),f=function(e,t,o,s){const i=e.maxValue,n=e.minValue,r={x:t.x+t.width/2,y:t.y+t.height},a={fontSize:kI},l=[],c=[];for(const h of e.inflectionValues){const e=(h.value-n.value)/(i.value-n.value),d=nl(s,h.label,a,"px"),u=Math.PI-Math.PI*e,g=qI(u,t.height+UI,r.x,r.y,d+2,kI),p=c.some((e=>WI(e,g)))?kI:0;c.push(g),l.push({rotation:u,label:h.label,fontSize:kI,color:o,offset:p})}return l}(t,r,m,o);let v=0,b=0,S=0;t.title.text&&({width:b,height:S}=ll(o,t.title.text,{fontSize:be,...t.title},"px"));switch(t.title.align){case"right":v=e.width-b-me;break;case"center":v=(e.width-b)/2;break;default:v=me}return{width:e.width,height:e.height,title:{label:t.title.text??"",fontSize:t.title.fontSize??be,textPosition:{x:v,y:ve+S/2},color:t.title.color??m,bold:t.title.bold,italic:t.title.italic},backgroundColor:t.background,gauge:{rect:r,arcWidth:a,percentage:St(l,0,1),color:BI(t)},inflectionValues:f,gaugeValue:{label:u,textPosition:c,fontSize:h,color:m},minLabel:{label:t.minValue.label,textPosition:g,fontSize:kI,color:m},maxLabel:{label:t.maxValue.label,textPosition:p,fontSize:kI,color:m}}}(o,t,i);!function(e,t){e.save(),e.fillStyle=t.backgroundColor,e.fillRect(0,0,t.width,t.height),e.restore()}(i,n),function(e,t){e.save();const o=t.gauge,s=o.rect.x+o.rect.width/2,i=o.rect.y+o.rect.height,n=o.rect.height-o.arcWidth/2;if(n<0)return;const r=1===o.percentage?0:Math.PI*(1+o.percentage);e.strokeStyle=VI,e.beginPath(),e.lineWidth=o.arcWidth,e.arc(s,i,n,r,0),e.stroke(),e.strokeStyle=o.color,e.beginPath(),e.arc(s,i,n,Math.PI,r),e.stroke(),e.restore()}(i,n),function(e,t){const{x:o,y:s,width:i,height:n}=t.gauge.rect;for(const r of t.inflectionValues){e.save(),e.translate(o+i/2-.5,s+n-.5),e.rotate(Math.PI/2-r.rotation),e.lineWidth=2,e.strokeStyle=dy(t.backgroundColor)+"aa",e.beginPath(),e.moveTo(0,-(n-t.gauge.arcWidth)),e.lineTo(0,-n-3),e.stroke(),e.textAlign="center",e.font=`${r.fontSize}px ${Le}`,e.fillStyle=r.color;const a=-n-UI-r.offset;e.fillText(r.label,0,a),e.restore()}}(i,n),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 ${Le}`,e.fillText(o.label,o.textPosition.x,o.textPosition.y),e.restore()}(i,n),function(e,t){e.save();const o=t.title;e.font=sl(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()}(i,n)}function BI(e){const t=ZI(e,"final");if(void 0===t)return VI;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 $I(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 GI(e,t){const o=e.start,s=e.end,i=t.start,n=t.end;function r(e,t,o){return(o.y-e.y)*(t.x-e.x)>(t.y-e.y)*(o.x-e.x)}return r(o,i,n)!==r(s,i,n)&&r(o,s,i)!==r(o,s,n)}function WI(e,t){const o=$I(e),s=$I(t);for(const e of o)for(const t of s)if(GI(e,t))return!0;return!1}function qI(e,t,o,s,i,n){const r=Math.cos(e),a=Math.sin(e),l=r*t,c=a*t,h=a*(i/2),d=r*(i/2),u=r*(t+n),g=a*(t+n);return{bottomLeft:{x:l-h+o,y:s-(c+d)},bottomRight:{x:l+h+o,y:s-(c-d)},topRight:{x:u+h+o,y:s-(g-d)},topLeft:{x:u-h+o,y:s-(g+d)}}}function ZI(e,t){return"animated"===t&&void 0!==e.animationValue?e.animationValue:e.gaugeValue?.value}const jI={responsive:!0,maintainAspectRatio:!1,elements:{line:{fill:!1},point:{hitRadius:15}},animation:!1,events:["mousemove","mouseout","click","touchstart","touchmove","mouseup"]};function YI(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");let n;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=pt(e.chartJsConfig);t.plugins=[KI];const o=new window.Chart(i,t);n=o.toBase64Image(),o.destroy()}else if("scorecard"===o){aI(dI(t,e),i),n=i.toDataURL()}else"gauge"===o&&(zI(i,e),n=i.toDataURL());return s.remove(),n}async function XI(e,t,o){const s=document.createElement("div");s.style.width=`${t.width}px`,s.style.height=`${t.height}px`,s.style.position="fixed",s.style.opacity="0";const i=document.createElement("canvas");s.append(i),i.setAttribute("width",t.width.toString()),i.setAttribute("height",t.height.toString()),document.body.append(s);let n=null;if("chartJsConfig"in e){const t=pt(e.chartJsConfig);t.plugins=[KI];const o=new window.Chart(i,t);n=await new Promise((e=>i.toBlob(e,"image/png"))),o.destroy()}else if("scorecard"===o){aI(dI(t,e),i),n=await new Promise((e=>i.toBlob(e,"image/png")))}else"gauge"===o&&(zI(i,e),n=await new Promise((e=>i.toBlob(e,"image/png"))));return s.remove(),n?new File([n],"chart.png",{type:"image/png"}):void 0}const KI={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()}},JI={second:1e3,minute:6e4,hour:36e5,day:864e5,month:2592e6,year:31536e6},QI={inSeconds:function(e){return Math.floor(e/JI.second)},inMinutes:function(e){return Math.floor(e/JI.minute)},inHours:function(e){return Math.floor(e/JI.hour)},inDays:function(e){return Math.floor(e/JI.day)},inMonths:function(e){return Math.floor(e/JI.month)},inYears:function(e){return Math.floor(e/JI.year)}},ew=/^((d|dd|m|mm|yyyy|yy|hh|h|ss|a)(-|:|\s|\/))*(d|dd|m|mm|yyyy|yy|hh|h|ss|a)$/i;function tw(e,t,o){const s=function(e){const t=e.indexOf("h");e=t>=0?e.slice(0,t).replace(/m/g,"M")+e.slice(t):e.replace(/m/g,"M");e.includes("a")||(e=e.replace(/h/g,"H"));return e}(t),i=function(e,t,o){const s=e.map((e=>Vi(e,o)?.jsDate));if(s.some((e=>void 0===e))||e.length<2)return;const i=s.map((e=>e.getTime())),n=no(i)-ro(i),r=function(e){if(e.includes("s"))return"second";if(e.includes("m"))return"minute";if(e.includes("h")||e.includes("H"))return"hour";if(e.includes("d"))return"day";if(e.includes("M"))return"month";return"year"}(t);if(JI.second>=JI[r]&&QI.inSeconds(n)<180)return"second";if(JI.minute>=JI[r]&&QI.inMinutes(n)<180)return"minute";if(JI.hour>=JI[r]&&QI.inHours(n)<96)return"hour";if(JI.day>=JI[r]&&QI.inDays(n)<90)return"day";if(JI.month>=JI[r]&&QI.inMonths(n)<36)return"month";return"year"}(e,s,o),n={};return i&&(n[i]=s),{parser:s,displayFormats:n,unit:i??!1,tooltipFormat:s}}function ow(e,t,o,s){let i=yw(s,t,o).formattedValues,n=ww(s,t);py(o,t[0],e.dataSetsHaveTitle||!1)&&i.shift(),({labels:i,dataSetsValues:n}=bw(i,n)),e.aggregated&&({labels:i,dataSetsValues:n}=Sw(i,n));const r=Iw(s,t,"left"),a=Iw(s,t,"right"),l=e.horizontal?{x:r||a}:{y:r,y1:a},c=[];for(const t in n){const{data:o}=n[t],s=e.dataSets?.[t].trend;if(!s?.display||e.horizontal){c.push(void 0);continue}const i=hw(s,o);c.push(i)}return{dataSetsValues:n,trendDataSetsValues:c,axisFormats:l,labels:i,locale:s.getLocale(),topPadding:Ew(e,s)}}function sw(e,t,o,s){const i=ow(e,t.slice(0,2),o,s),n=i.dataSetsValues.filter((e=>!e.hidden)),r=[];if(n[0]){const e=n[0].data.map((e=>e>0?e:0));r.push({...n[0],data:e})}if(n[1]){const e=n[1].data.map((e=>e>0?-e:0));r.push({...n[1],data:e})}return{...i,dataSetsValues:r}}function iw(e,t,o,s){const i=function(e,t,o,s){if(function(e,t,o,s){return!e.labelsAsText&&pw(e,t,o,s)}(e,t,o,s)&&function(){if(!window.Chart)return!1;const e="luxon"===new window.Chart._adapters._date({})._id;e||fw||(fw=!0,console.warn("'chartjs-adapter-luxon' time adapter is not installed. Time scale axes are disabled."));return e}())return"time";if(function(e,t,o,s){return!e.labelsAsText&&mw(e,t,o,s)}(e,t,o,s))return"linear";return"category"}(e,t,o,s),n=yw(s,t,o);let r="linear"===i?n.values:n.formattedValues,a=ww(s,t);const l=py(o,t[0],e.dataSetsHaveTitle||!1);l&&r.shift(),({labels:r,dataSetsValues:a}=bw(r,a)),"time"===i&&({labels:r,dataSetsValues:a}=function(e,t){if(0===e.length||e.every((e=>!e)))return{labels:e,dataSetsValues:t};const o=[...e],s=pt(t);for(let e=0;e<o.length;e++)if(!o[e]){o[e]=Ut(o,e);for(const t of s)t.data[e]=void 0}return{labels:o,dataSetsValues:s}}(r,a)),e.aggregated&&({labels:r,dataSetsValues:a}=Sw(r,a)),e.cumulative&&(a=xw(a,"asc"));const c={y:Iw(s,t,"left"),y1:Iw(s,t,"right"),x:Cw(s,o,l)},h=[];for(const t in a){const o=e.dataSets?.[t].trend;if(!o?.display){h.push(void 0);continue}const{data:n}=a[t];h.push(dw(o,n,r,i,s.getLocale()))}return{dataSetsValues:a,axisFormats:c,labels:r,locale:s.getLocale(),trendDataSetsValues:h,axisType:i,topPadding:Ew(e,s)}}function nw(e,t,o,s){let i=yw(s,t,o).formattedValues,n=ww(s,t);py(o,t[0],e.dataSetsHaveTitle||!1)&&i.shift(),({labels:i,dataSetsValues:n}=bw(i,n)),e.aggregated&&({labels:i,dataSetsValues:n}=Sw(i,n)),({dataSetsValues:n,labels:i}=function(e,t){const o=Math.max(e.length,...t.map((e=>e.data?.length||0))),s=Ct(0,o).filter((e=>t.some((t=>"number"==typeof t.data[e]&&t.data[e]>0))));return{labels:s.map((t=>e[t]||"")),dataSetsValues:t.map((e=>({...e,data:s.map((t=>"number"==typeof e.data[t]&&e.data[t]>0?e.data[t]:null))})))}}(i,n));return{dataSetsValues:n,axisFormats:{y:Iw(s,t,"left")},labels:i,locale:s.getLocale(),topPadding:Ew(e,s)}}function rw(e,t,o,s){let i=yw(s,t,o).formattedValues,n=ww(s,t);py(o,t[0],e.dataSetsHaveTitle||!1)&&i.shift(),({labels:i,dataSetsValues:n}=bw(i,n)),e.aggregated&&({labels:i,dataSetsValues:n}=Sw(i,n));return{dataSetsValues:n,axisFormats:{r:Iw(s,t,"left")||Iw(s,t,"right")},labels:i,locale:s.getLocale()}}function aw(e,t,o,s){const i=t.slice(0,1);let n=yw(s,i,o).formattedValues;py(o,i[0],e.dataSetsHaveTitle||!1)&&n.shift();let r=ww(s,i);({labels:n,dataSetsValues:r}=Sw(n,r));return{dataSetsValues:r,axisFormats:{y:Iw(s,i,"left")||Iw(s,i,"right")},labels:n,locale:s.getLocale(),availableRegions:s.getGeoChartAvailableRegions(),geoFeatureNameToId:s.geoFeatureNameToId,getGeoJsonFeatures:s.getGeoJsonFeatures}}function lw(e,t,o,s){let i=yw(s,t,o).formattedValues,n=ww(s,t);py(o,t[0],e.dataSetsHaveTitle||!1)&&i.shift(),({labels:i,dataSetsValues:n}=bw(i,n)),e.aggregated&&({labels:i,dataSetsValues:n}=Sw(i,n)),e.cumulative&&(n=xw(n,"desc"));return{dataSetsValues:n,axisFormats:{x:Iw(s,t,"left")||Iw(s,t,"right")},labels:i,locale:s.getLocale()}}function cw(e,t,o,s){let i=yw(s,t,o).values,n=function(e,t){t=t.filter((t=>!e.isColHidden(t.dataRange.sheetId,t.dataRange.zone.left)));const o=t.map((()=>({data:[],label:""}))),s=t.map((t=>vw(e,t)));if(!s.length)return o;const i=Math.min(...s.map((e=>e.length)));let n=[];const r=t.length-1;for(let e=0;e<i;e++)for(let t=0;t<s.length;t++){let i=s[t][e];null==i&&t!==r&&(i=n[t]),i!==n[t]&&(n=n.slice(0,t),n[t]=i),o[t].data.push(i??null)}return o.filter((e=>e.data.some((e=>null!==e))))}(s,t);const r=py(o,t[0],e.dataSetsHaveTitle||!1);return r&&i.shift(),({labels:i,dataSetsValues:n}=function(e,t){const o=[],s=[];for(let t=0;t<e.length;t++)Number(e[t])<=0?s.push(t):Number(e[t])>0&&o.push(t);const i=o.length?o:s;return{labels:i.map((t=>e[t])),dataSetsValues:t.map((e=>({...e,data:i.map((t=>e.data[t]))})))}}(i,n)),({labels:i,dataSetsValues:n}=function(e,t){const o=Math.max(e.length,...t.map((e=>e.data?.length||0))),s=e=>null==e||""===e,i=Ct(0,o).filter((o=>{const i=t.map((e=>e.data?.[o]));if(s(i[0]))return!1;let n=!1;for(const e of i)if(n||=s(e),n&&!s(e))return!1;return e[o]&&!isNaN(Number(e[o]))}));return{labels:i.map((t=>e[t])),dataSetsValues:t.map((e=>({...e,data:i.map((t=>e.data[t]))})))}}(i,n)),{dataSetsValues:n,axisFormats:{y:Cw(s,o,r)},labels:i,locale:s.getLocale()}}function hw(e,t){const o=[],s=[],i=[];for(let e=0;e<t.length;e++)"number"==typeof t[e]&&(o.push(t[e]),s.push(e+1)),i.push(e+1);const n=uw(e,o,s,Ct(.5,i.length+.55,.2));return n.length?n:void 0}function dw(e,t,o,s,i){const n=[],r=[],a=[],l=t.length;if(l<2)return;switch(s){case"category":for(let e=0;e<l;e++)"number"==typeof t[e]&&(n.push(t[e]),r.push(e+1)),a.push(e+1);break;case"linear":for(let e=0;e<t.length;e++){const s=Number(o[e]);isNaN(s)||("number"==typeof t[e]&&(n.push(t[e]),r.push(s)),a.push(s))}break;case"time":for(let e=0;e<t.length;e++){const s=Sn({value:o[e]},i);null!==t[e]&&(n.push(t[e]),r.push(s)),a.push(s)}}const c=Math.min(...a),h=Math.max(...a);if(h===c)return;const d=(h-c)/(5*a.length),u=uw(e,n,r,Ct(c,h+d/2,d));return u.length?u:void 0}function uw(e,t,o,s){if(t.length<2||o.length<2||0===s.length)return[];const{normalizedLabels:i,normalizedNewLabels:n}=function(e,t,o){let s=[],i=[];if("logarithmic"===o.type){const o=Math.max(...e.map(Math.abs));s=e.map((e=>e/o)),i=t.map((e=>e/o))}else{const o=Math.max(...e),n=Math.min(...e),r=o-n;s=e.map((e=>(e-o)/r)),i=t.map((e=>(e-o)/r))}return{normalizedLabels:s,normalizedNewLabels:i}}(o,s,e);try{switch(e.type){case"polynomial":{const o=e.order;if(!o)return s.map((e=>({x:e,y:NaN})));if(1===o)return Oc([t],[i],[n],!0)[0].map(((e,t)=>({x:s[t],y:e})));const r=Tc(t,i,o,!0).flat();return n.map(((e,t)=>({x:s[t],y:Dc(r,e,o)})))}case"exponential":{const e=[],o=[];for(let s=0;s<t.length;s++)t[s]>0&&(e.push(Math.log(t[s])),o.push(i[s]));return o.length?_c(Oc([e],[o],[n],!0))[0].map(((e,t)=>({x:s[t],y:e}))):s.map((e=>({x:e,y:NaN})))}case"logarithmic":return Oc([t],Fc([i]),Fc([n]),!0)[0].map(((e,t)=>({x:s[t],y:e})));case"trailingMovingAverage":return function(e,t,o=Ye){const s=[];for(let e=0;e<o-1;e++)s.push({x:t[e],y:NaN});for(let i=0;i<=e.length-o;i++){let n=0;for(let t=i;t<i+o;t++)n+=e[t];s.push({x:t[i+o-1],y:n/o})}return s}(t,o,e.window);default:return s.map((e=>({x:e,y:NaN})))}}catch(e){return s.map((e=>({x:e,y:NaN})))}}function gw(e,t,o,s){return pw(e,t,o,s)||mw(e,t,o,s)}function pw(e,t,o,s){if(!o||!mw(e,t,o,s))return!1;const i=Cw(s,o,py(o,t[0],e.dataSetsHaveTitle||!1));return Boolean(i&&ew.test(i))}function mw(e,t,o,s){if(!o)return!1;const i=s.getRangeValues(o);return py(o,t[0],e.dataSetsHaveTitle||!1)&&i.shift(),!i.some((e=>isNaN(Number(e))&&e))&&!i.every((e=>!e))}let fw=!1;function vw(e,t){if(t.dataRange){const o=t.labelCell?[t.labelCell.zone]:[],s=Fo([t.dataRange.zone],o)[0];if(void 0===s)return[];const i=e.getRangeFromZone(t.dataRange.sheetId,s);return e.getRangeValues(i).map((e=>""===e?void 0:e))}return[]}function bw(e,t){const o=Ct(0,Math.max(e.length,...t.map((e=>e.data?.length||0)))).filter((o=>{const s=e[o],i=t.map((e=>e.data?.[o]));return s||i.some((e=>"number"==typeof e))}));return{labels:o.map((t=>e[t]||"")),dataSetsValues:t.map((e=>({...e,data:o.map((t=>"number"==typeof e.data[t]?e.data[t]:null))})))}}function Sw(e,t){const o=new Set(e),s={};o.forEach((e=>{s[e]=new Array(t.length).fill(0)}));for(const o of Ct(0,e.length)){const n=e[o];for(const e of Ct(0,t.length))s[n][e]+="number"==typeof(i=t[e].data[o])?i:0}var i;return{labels:Array.from(o),dataSetsValues:t.map(((e,t)=>({...e,data:Array.from(o).map((e=>s[e][t]))})))}}function Cw(e,t,o){if(!t)return;const{sheetId:s,zone:i}=t,n=is(i).map((t=>e.getEvaluatedCell({sheetId:s,...t}).format));return o&&n.shift(),n.find((e=>void 0!==e))}function yw(e,t,o){let s={values:[],formattedValues:[]};if(o){const{left:i}=o.zone;if(o.invalidXc||o.invalidSheetName||e.isColHidden(o.sheetId,i)){if(t[0]){s={formattedValues:Ct(0,vw(e,t[0]).length).map((e=>e.toString())),values:s.formattedValues}}}else s={formattedValues:e.getRangeFormattedValues(o),values:e.getRangeValues(o).map((e=>String(e??"")))}}else if(1===t.length){const o=vw(e,t[0]).length;for(let e=0;e<o;e++)s.formattedValues.push(""),s.values.push("")}else if(t[0]){s={formattedValues:Ct(0,vw(e,t[0]).length).map((e=>e.toString())),values:s.formattedValues}}return s}function Iw(e,t,o){const s=t.filter((e=>"right"===o==!!e.rightYAxis));for(const t of s){const o=e.getRangeFormats(t.dataRange).find((e=>void 0!==e&&!Mr(e)));if(o)return o}}function ww(e,t){const o=[];for(const[s,i]of Object.entries(t)){let t=`${_b.Series} ${parseInt(s)+1}`,n=e.isColHidden(i.dataRange.sheetId,i.dataRange.zone.left);if(i.labelCell){const{sheetId:o,zone:s}=i.labelCell,n=e.getEvaluatedCell({sheetId:o,col:s.left,row:s.top});n&&(t=n.formattedValue)}let r=i.dataRange?vw(e,i):[];r.every((e=>!e||"string"==typeof e&&!fn(e)))&&r.filter((e=>"string"==typeof e)).length>1?r=r.map((e=>e&&!fn(e)?1:null)):r.every((e=>null==e||!Qi(e.toString(),w)))&&(n=!0),o.push({data:r,label:t,hidden:n})}return o}function xw(e,t){return e.map((e=>{const o=[];let s=0;const i="asc"===t?Object.keys(e.data):Object.keys(e.data).reverse();for(const t of i)isNaN(parseFloat(e.data[t]))?o[t]=e.data[t]:(s+=parseFloat(e.data[t]),o[t]=s);return{...e,data:o}}))}function Ew(e,t){const{title:o,legendPosition:s}=e,i=o&&o.text||"top"===s;return t.isDashboard()&&!i?30:0}function Rw(e,t){return{padding:{left:me,right:me,top:Math.max(ve,t.topPadding||0),bottom:fe}}}function Tw(e,t){return{display:"none"!==e.legendPosition,position:"none"!==e.legendPosition?e.legendPosition:void 0}}function Aw(e,t){return{...kw,...Tw(e),...Lw(hy(e.background),{pointStyle:"rect",lineWidth:3})}}function Dw(e,t){const o=e.fillArea,s=o?"rect":"line",i=o?2:3;return{...kw,...Tw(e),...Lw(hy(e.background),{pointStyle:s,lineWidth:i})}}function _w(e,t){const{dataSetsValues:o}=t,s=Math.max(0,...o.map((e=>e?.data?.length??0))),i=Sy(new ti(s),o),n=hy(e.background);return{...Tw(e),labels:{usePointStyle:!0,generateLabels:e=>(e.data.labels?.map(((e,t)=>({text:Cy(String(e)),strokeStyle:i[t],fillStyle:i[t],pointStyle:"rect",lineWidth:2,fontColor:n})))||[]).filter((e=>e.text)),filter:(e,t)=>!("datasetIndex"in e)||!t.datasets[e.datasetIndex].hidden}}}function Fw(e,t){return{...kw,...Tw(e),...Lw(hy(e.background),{pointStyle:"circle",strokeStyle:e.background||"#ffffff",lineWidth:8})}}function Ow(e,t){return{...kw,...Tw(e),...Lw(hy(e.background),{lineWidth:3})}}function Pw(e,t){const o=hy(e.background),s=e.negativeValuesColor||Y,i=e.positiveValuesColor||j,n=e.subTotalValuesColor||X;return{...Tw(e),labels:{usePointStyle:!0,generateLabels:()=>{const t=[{text:ui("Positive values"),fontColor:o,fillStyle:i,strokeStyle:i,pointStyle:"rect"},{text:ui("Negative values"),fontColor:o,fillStyle:s,strokeStyle:s,pointStyle:"rect"}];return(e.showSubTotals||e.firstValueAsSubtotal)&&t.push({text:ui("Subtotals"),fontColor:o,fillStyle:n,strokeStyle:n,pointStyle:"rect"}),t},filter:(e,t)=>!("datasetIndex"in e)||!t.datasets[e.datasetIndex].hidden},onClick:()=>{}}}function Mw(e,t){const o=e.fillArea??!1,s=o?"rect":"line",i=o?2:3;return{...kw,...Tw(e),...Lw(hy(e.background),{pointStyle:s,lineWidth:i})}}function Nw(e,t){const o=hy(e.background);return{...Tw(e),labels:{usePointStyle:!0,generateLabels:e=>{const t=e.data.datasets.at(-1);if(!t)return[];return t.groupColors.map((({color:e,label:t})=>({text:Cy(t),fontColor:o,fillStyle:e,strokeStyle:e,pointStyle:"rect"})))}}}}const kw={onHover:e=>{const t=e.native?.target;t&&(t.style.cursor="pointer")},onLeave:e=>{const t=e.native?.target;t&&(t.style.cursor="default")},onClick:(e,t,o)=>{if("click"!==e.type)return;const s=t.datasetIndex;o.legendItems&&void 0!==s&&(o.chart.isDatasetVisible(s)?o.chart.hide(s):o.chart.show(s),e.native.preventDefault(),e.native.stopPropagation())}};function Lw(e,t){return{labels:{color:e,usePointStyle:!0,generateLabels:o=>o.data.datasets.map(((s,i)=>yy(s.xAxisID)?{text:Cy(s.label),fontColor:e,strokeStyle:s.borderColor,hidden:!o.isDatasetVisible(i),pointStyle:"line",datasetIndex:i,lineWidth:3}:{text:Cy(s.label),fontColor:e,strokeStyle:s.borderColor,fillStyle:s.backgroundColor,hidden:!o.isDatasetVisible(i),pointStyle:"line"===s.type?"line":"rect",datasetIndex:i,...t})).filter((e=>e.text)),filter:(e,t)=>!("datasetIndex"in e)||!t.datasets[e.datasetIndex].hidden}}}function Vw(e,t){let o={};const{trendDataSetsValues:s,locale:i,axisFormats:n}=t,r={stacked:e.stacked,locale:i};if(e.horizontal)o.x=jw(e,"bottom","values",{...r,format:n?.x}),o.y=jw(e,"left","labels",r);else{o.x=jw(e,"bottom","labels",r);const t={...r,format:n?.y};o.y=jw(e,"left","values",t);const s={...r,format:n?.y1};o.y1=jw(e,"right","values",s)}if(o=Wt(o),s&&s.length&&s.some(Mt)){const e=Math.max(...s.map((e=>e?.length||0)));o[JC]={...o.x,labels:Array(e).fill(""),offset:!1,display:!1},o[QC]={...o.x,offset:!0,display:!1}}return o}function Uw(e,t){const{locale:o,axisType:s,trendDataSetsValues:i,labels:n,axisFormats:r}=t,a=r?.x,l=e.stacked;let c={x:jw(e,"bottom","labels",{locale:o}),y:jw(e,"left","values",{locale:o,stacked:l,format:r?.y}),y1:jw(e,"right","values",{locale:o,stacked:l,format:r?.y1})};if(c=Wt(c),"time"===s&&n&&a){const e={type:"time",time:tw(n,a,o)};Object.assign(c.x,e),c.x.ticks.maxTicksLimit=15,delete c?.x?.ticks?.callback}else"linear"===s&&(c.x.type="linear",c.x.ticks.callback=e.humanize?e=>Wr({value:e,format:a},o):e=>Rr(e,{format:a,locale:o}));if(i&&i.length&&i.some(Mt)&&(c[JC]={...c.x,display:!1},c[QC]={...c.x,display:!1},"category"===s||"time"===s)){const e=Math.max(...i.map((e=>e?.length||0)));c[JC].type="category",c[JC].labels=Ct(0,e).map((e=>e.toString())),c[JC].offset=!1,c[QC].type="category",c[QC].offset=!1}return c}function Hw(e,t){const o=Uw(e,t);return{...o,x:{...o.x,grid:{display:!0}}}}function zw(e,t){const{locale:o,axisFormats:s}=t,i=s?.y||s?.y1;e.dataSets;const n={x:{...jw(e,"bottom","labels",{locale:o}),grid:{display:!1}},y:{position:e.verticalAxisPosition,ticks:{color:hy(e.background),callback:vy({locale:o,format:i},e.humanize)},grid:{lineWidth:e=>0===e.tick.value?2:1},title:Zw(e.axesDesign?.y)}},r=n?.y||n?.y1;return r&&(r.grid={lineWidth:e=>0===e.tick.value?2:1}),n}function Bw(e,t){const{dataSetsValues:o}=t,s=Vw(e,t),i=s.x.ticks.callback;s.x.ticks.callback=e=>i(Math.abs(e));const n=Math.max(...o.map((e=>Math.max(...e.data.map(Math.abs)))));return s.x.suggestedMin=-n,s.x.suggestedMax=n,s}function $w(e,t){const{locale:o,axisFormats:s,dataSetsValues:i}=t,n=Math.min(...i.map((e=>Math.min(...e.data.filter((e=>!isNaN(e)))))));return{r:{beginAtZero:!0,ticks:{callback:vy({format:s?.r,locale:o},e.humanize),backdropColor:e.background||"#FFFFFF"},pointLabels:{color:hy(e.background),callback:e=>Cy(e)},suggestedMin:n<0?n-1:0}}}function Gw(e,t){const{locale:o,axisFormats:s,availableRegions:i}=t,n=function(e){switch(e){case"top":return"top-left";case"right":return"top-right";case"bottom":return"bottom-right";case"left":case"none":return"bottom-left"}}(e.legendPosition),r=e.region?i.find((t=>t.id===e.region)):i[0],a=s?.y||s?.y1;return{projection:{projection:qw(r?.defaultProjection||"mercator"),axis:"x"},color:{axis:"x",display:"none"!==e.legendPosition,border:{color:J},grid:{color:J},ticks:{color:hy(e.background),callback:vy({locale:o,format:a},e.humanize)},legend:{position:n,align:n.includes("right")?"left":"right",margin:Xw(e)},interpolate:Yw(e),missing:e.missingValueColor||"#ffffff"}}}function Ww(e,t){const o=t.dataSetsValues[0];return{x:{display:!1},y:{grid:{offset:!1},ticks:{callback:function(e){return Cy(this.getLabelForValue(e))}},border:{display:!1}},percentages:{position:"right",border:{display:!1},ticks:{callback:function(e,s,i){const n=o.data?.[s],r=o.data?.[0];return r&&void 0!==n?Rr(n/r,{format:"0%",locale:t.locale}):""}},grid:{display:!1}}}}function qw(e){return"conicConformal"===e?window.ChartGeo.geoConicConformal().rotate([100,0]):e}function Zw(e){if(e?.title?.text){const{text:t,color:o,align:s,italic:i,bold:n}=e.title;return{display:!0,text:t,color:o,font:{style:i?"italic":"normal",weight:n?"bold":"normal",size:e.title.fontSize??Se},align:"left"===s?"start":"right"===s?"end":"center"}}}function jw(e,t,o,s){const{useLeftAxis:i,useRightAxis:n}=my(e);if("left"===t&&!i||"right"===t&&!n)return;const r=hy(e.background);let a;if(a="bottom"===t?e.axesDesign?.x:"left"===t?e.axesDesign?.y:e.axesDesign?.y1,"values"===o){const o=!("right"===t&&i);return{position:t,title:Zw(a),grid:{display:o},beginAtZero:!0,stacked:s?.stacked,ticks:{color:r,callback:vy(s,e.humanize)}}}return{ticks:{padding:5,color:r,callback:function(e,t,o){return Cy(this.getLabelForValue(e))}},grid:{display:!1},stacked:s?.stacked,title:Zw(a)}}function Yw(e){if(!e.colorScale||"string"==typeof e.colorScale)return e.colorScale||"oranges";const t=[{value:0,color:e.colorScale.minColor}];return e.colorScale.midColor&&t.push({value:.5,color:e.colorScale.midColor}),t.push({value:1,color:e.colorScale.maxColor}),ii(t)}function Xw(e){switch(e.legendPosition){case"top":case"right":return{top:!!e.title.text?ve+30:ve,left:me,right:me};case"bottom":case"left":case"none":return{left:me,right:me,bottom:fe}}}const Kw={showValues:!1,showLabels:!0,valuesDesign:{align:"center",fontSize:13}};function Jw(e,t){const{axisFormats:o,locale:s}=t;return{horizontal:"horizontal"in e&&e.horizontal,showValues:"showValues"in e&&!!e.showValues,background:e.background,callback:(t,i)=>{const n=function(e,t){if(t.rAxisID)return t.rAxisID;const o="horizontal"in e&&e.horizontal?t.xAxisID:t.yAxisID;return o||"y"}(e,i);return fy(o,s,e.humanize)(t,n)}}}function Qw(e,t){const{axisFormats:o,locale:s}=t;return{callback:fy(o,s,e.humanize),showLabels:e.showLabels??Kw.showLabels,showValues:e.showValues??Kw.showValues,style:{fontSize:e.valuesDesign?.fontSize??Kw.valuesDesign.fontSize,align:e.valuesDesign?.align??Kw.valuesDesign.align,bold:e.valuesDesign?.bold??Kw.valuesDesign.bold,italic:e.valuesDesign?.italic??Kw.valuesDesign.italic,textColor:e.valuesDesign?.color??Kw.valuesDesign.color}}}function ex(e,t){const{axisFormats:o,locale:s}=t;return{horizontal:!0,showValues:"showValues"in e&&!!e.showValues,background:e.background,callback:(e,t)=>0===(e=Math.abs(Number(e)))?"":fy(o,s)(e,t.xAxisID||"x")}}function tx(e,t){const{axisFormats:o,locale:s,dataSetsValues:i}=t,n=i.reduce(((e,t)=>(e.push((e.at(-1)||-1)+t.data.length+1),e)),[]);return{showValues:"showValues"in e&&!!e.showValues,background:e.background,callback:(t,i,r)=>{const a=i._dataset.data[r],l=a[1]-a[0];let c=l>=0?"+":"";return e.showSubTotals&&n.includes(r)&&"+"===c&&(c=""),`${c}${fy(o,s,e.humanize)(l,i.yAxisID)}`}}}function ox(e,t){const o=e.title,s=dy(e.background);return{display:!!o.text,text:o.text?t.dynamicTranslate(o.text):"",color:o?.color??s,align:"center"===o.align?"center":"right"===o.align?"end":"start",font:{size:e.title.fontSize??be,weight:o.bold?"bold":"normal",style:o.italic?"italic":"normal"},padding:{bottom:"top"===e.legendPosition?0:me}}}const sx='\n<templates>\n <t t-name="o-spreadsheet-CustomTooltip">\n <div\n class="o-chart-custom-tooltip border rounded px-2 py-1 pe-none mw-100 position-absolute text-nowrap shadow opacity-100">\n <table class="overflow-hidden m-0">\n <thead t-if="title">\n <tr>\n <th class="o-tooltip-title align-baseline border-0 text-truncate" t-esc="title" t-attf-style="max-width: {{ labelsMaxWidth }}"/>\n </tr>\n </thead>\n <tbody>\n <tr t-foreach="tooltipItems" t-as="tooltipItem" t-key="tooltipItem_index">\n <td>\n <span\n class="badge ps-2 py-2 rounded-0 align-middle"\n t-attf-style="background-color: {{ tooltipItem.boxColor }}"\n > </span>\n <small\n t-if="tooltipItem.label"\n class="o-tooltip-label d-inline-block text-truncate align-middle smaller ms-2"\n t-esc="tooltipItem.label"\n t-attf-style="max-width: {{ labelsMaxWidth }}"\n />\n </td>\n <td class="o-tooltip-value ps-2 fw-bolder text-end">\n <small class="smaller d-inline-block text-truncate align-middle" t-attf-style="max-width: {{ valuesMaxWidth }}">\n <t t-esc="tooltipItem.value"/>\n <t t-if="tooltipItem.percentage">\n (\n <t t-esc="tooltipItem.percentage"/>\n %)\n </t>\n </small>\n </td>\n </tr>\n </tbody>\n </table>\n </div>\n </t>\n</templates>\n';let ix;function nx(e,o={}){return function(e,o={}){ix||(ix=new t.App(t.Component,{templates:sx,translateFn:ui}));const s=ix.getTemplate(e),i=s(o,{}),n=document.createElement("div");return t.blockDom.mount(i,n),n}(e,o).innerHTML}function rx(e,t){return{enabled:!1,external:fx,callbacks:{title:function(e){return e.some((e=>!yy(e.dataset.xAxisID)))?void 0:""},beforeLabel:e=>e.dataset?.label||e.label,label:function(o){const s=e.horizontal;let i=s?o.parsed.x:o.parsed.y;null==i&&(i=o.parsed);const n=s?o.dataset.xAxisID:o.dataset.yAxisID;return fy(t.axisFormats,t.locale,e.humanize)(i,n)}}}}function ax(e,t){const{axisType:o,locale:s,axisFormats:i}=t,n=i?.x,r={enabled:!1,external:fx,callbacks:{}};return r.callbacks.label="linear"===o?t=>{const o=t.parsed.y;let r=yy(t.dataset.xAxisID)?"":t.parsed.x;"string"==typeof r&&Qi(r,s)&&(r=Sn(r,s));const a=Er(r,n,s,e.humanize),l=t.dataset.yAxisID||"y",c=Er(o,i?.[l],s,e.humanize);return a?`(${a}, ${c})`:`${c}`}:function(t){const o=t.parsed.y,n=t.dataset.yAxisID;return fy(i,s,e.humanize)(o,n)},r.callbacks.beforeLabel=e=>e.dataset?.label||e.label,r.callbacks.title=function(e){return"linear"!==o&&e.some((e=>!yy(e.dataset.xAxisID)))?void 0:""},r}function lx(e,t){const{locale:o,axisFormats:s}=t,i=s?.y||s?.y1;return{enabled:!1,external:fx,callbacks:{title:function(e){return e[0].dataset.label},beforeLabel:e=>e.label||e.dataset.label,label:function(t){const s=function(e,t){const o=e.filter((e=>"number"==typeof e)).reduce(((e,t)=>e+t),0);if(!o)return"";const s=e[t]/o*100;return s.toFixed(2)}(t.dataset.data,t.dataIndex),n=t.parsed.y??t.parsed;return`${Er(n,!i&&n>=1e3?"#,##":i,o,e.humanize)} (${s}%)`}}}}function cx(e,t){const{dataSetsValues:o,locale:s,axisFormats:i,labels:n}=t,r=i?.y||i?.y1,a=o.map((e=>e.label));return{enabled:!1,external:fx,callbacks:{beforeLabel:function(e){const t=n.length?Math.floor(e.dataIndex/n.length):0;return a[t]},label:function(t){const[o,i]=t.raw,n=i-o;return Er(n,!r&&Math.abs(n)>1e3?"#,##":r,s,e.humanize)}}}}function hx(e,t){const o=rx(e,t);return{...o,callbacks:{...o.callbacks,label:e=>{const t={...e,parsed:{y:e.parsed.y,x:Math.abs(e.parsed.x)}};return(o?.callbacks?.label)(t)}}}}function dx(e,t){const{locale:o,axisFormats:s}=t;return{enabled:!1,external:fx,callbacks:{beforeLabel:e=>e.dataset?.label||e.label,label:function(t){return Er(t.parsed.r,s?.r,o,e.humanize)}}}}function ux(e,t){const{locale:o,axisFormats:s}=t,i=s?.y||s?.y1;return{enabled:!1,external:fx,filter:function(e){return void 0!==e.raw.value},callbacks:{beforeLabel:e=>e.raw.feature.properties.name,label:function(t){const s=t.raw.value;return Er(s,!i&&Math.abs(s)>=1e3?"#,##":i,o,e.humanize)}}}}function gx(e,t){return{enabled:!1,external:fx,position:"funnelTooltipPositioner",callbacks:{title:()=>"",beforeLabel:e=>e.label,label:function(o){const s=o.parsed.x,i=o.dataset.xAxisID;return fy(t.axisFormats,t.locale,e.humanize)(s,i)}}}}function px(e,t){const{locale:o,axisFormats:s}=t,i=s?.y||s?.y1;return{enabled:!1,external:fx,filter:function(e){const t=e.raw;return t?.label!==Ry},callbacks:{title:()=>"",beforeLabel:e=>e.raw.groups.join(" / "),label:function(t){const s=t.raw.value;return Er(s,!i&&s>=1e3?"#,##":i,o,e.humanize)}}}}function mx(e,t){const{locale:o,axisFormats:s}=t,i=s?.y;return{enabled:!1,external:fx,filter:(e,t,o)=>t===o.length-1,callbacks:{title:()=>"",beforeLabel:e=>{const t=e.raw._data.children[0];if(!t)return"";const o=[];for(let s=0;s<=e.raw.l;s++)o.push(t[s]);return o.join(" / ")},label:t=>{const s=t.raw.v;return Er(s,!i&&s>=1e3?"#,##":i,o,e.humanize)}}}}function fx({chart:e,tooltip:t}){if(e.canvas.parentNode.querySelector("div.o-chart-custom-tooltip")?.remove(),0===t.opacity||0===t.dataPoints.length)return;const o=t.body.map(((e,o)=>{let s=e.before[0],i=e.lines[0];i||(i=s,s="");const n=t.labelColors[o].backgroundColor;return{label:s,value:i,boxColor:"string"==typeof n?Bs(n,1):n}})),s=nx("o-spreadsheet-CustomTooltip",{labelsMaxWidth:Math.floor(.5*e.canvas.clientWidth)+"px",valuesMaxWidth:Math.floor(.25*e.canvas.clientWidth)+"px",title:t.title[0],tooltipItems:o}),i=Object.assign(document.createElement("template"),{innerHTML:s}).content.firstChild;e.canvas.parentNode?.appendChild(i),Object.assign(i.style,{left:vx(e,t,i.clientWidth)+"px",top:Math.floor(t.caretY-i.clientHeight/2)+"px"})}function vx(e,t,o){const s=t.caretX;return s+o>e.chartArea.right?Math.max(0,s-o):s}var bx=Object.freeze({__proto__:null,GHOST_SUNBURST_VALUE:Ry,INTERACTIVE_LEGEND_CONFIG:kw,canChartParseLabels:gw,getBarChartData:ow,getBarChartDatasets:Ty,getBarChartLegend:Aw,getBarChartScales:Vw,getBarChartTooltip:rx,getChartColorsGenerator:Wy,getChartLabelFormat:Cw,getChartLayout:Rw,getChartShowValues:Jw,getChartTitle:ox,getComboChartDatasets:Oy,getComboChartLegend:Ow,getData:vw,getFunnelChartData:lw,getFunnelChartDatasets:Ny,getFunnelChartScales:Ww,getFunnelChartTooltip:gx,getFunnelLabelColors:ky,getGeoChartData:aw,getGeoChartDatasets:My,getGeoChartScales:Gw,getGeoChartTooltip:ux,getHierarchalChartData:cw,getLineChartData:iw,getLineChartDatasets:Dy,getLineChartLegend:Dw,getLineChartScales:Uw,getLineChartTooltip:ax,getPieChartData:nw,getPieChartDatasets:Fy,getPieChartLegend:_w,getPieChartTooltip:lx,getPyramidChartData:sw,getPyramidChartScales:Bw,getPyramidChartShowValues:ex,getPyramidChartTooltip:hx,getRadarChartData:rw,getRadarChartDatasets:Py,getRadarChartLegend:Mw,getRadarChartScales:$w,getRadarChartTooltip:dx,getScatterChartDatasets:_y,getScatterChartLegend:Fw,getScatterChartScales:Hw,getSunburstChartDatasets:Ly,getSunburstChartLegend:Nw,getSunburstChartTooltip:px,getSunburstShowValues:Qw,getTopPaddingForDashboard:Ew,getTreeMapChartDatasets:zy,getTreeMapChartTooltip:mx,getTrendDatasetForBarChart:hw,getTrendDatasetForLineChart:dw,getWaterfallChartLegend:Pw,getWaterfallChartScales:zw,getWaterfallChartShowValues:tx,getWaterfallChartTooltip:cx,getWaterfallDatasetAndLabels:Ay,makeDatasetsCumulative:xw});class Sx extends Qy{dataSets;labelRange;background;legendPosition;stacked;aggregated;type="bar";dataSetsHaveTitle;dataSetDesign;axesDesign;horizontal;showValues;zoomable;constructor(e,t,o){super(e,t,o),this.dataSets=ny(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Ba(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.stacked=e.stacked,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.horizontal=e.horizontal,this.showValues=e.showValues,this.zoomable=e.zoomable}static transformDefinition(e,t,o){return cy(e,t,o)}static validateChartDefinition(e,t){return e.checkValidations(t,uy,gy)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,stacked:e.stacked??!1,aggregated:e.aggregated??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"bar",labelRange:e.auxiliaryRange||void 0,axesDesign:e.axesDesign,showValues:e.showValues,horizontal:e.horizontal,zoomable:e.zoomable,humanize:e.humanize}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}duplicateInDuplicatedSheet(e){const t=oy(this.sheetId,e,this.dataSets),o=sy(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new Sx(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new Sx(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"bar",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,stacked:this.stacked,aggregated:this.aggregated,axesDesign:this.axesDesign,horizontal:this.horizontal,showValues:this.showValues,zoomable:this.horizontal?void 0:this.zoomable,humanize:this.humanize}}getDefinitionForExcel(){const{dataSets:e,labelRange:t}=this.getCommonDataSetAttributesForExcel(this.labelRange,this.dataSets,py(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle)),o=this.getDefinition();return{...o,backgroundColor:OI(this.background||k),fontColor:OI(hy(this.background)),dataSets:e,labelRange:t,verticalAxis:my(o)}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=ty(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new Sx(i,this.sheetId,this.getters)}}function Cx(e,t){const o=e.getDefinition(),s=ow(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"bar",data:{labels:s.labels,datasets:Ty(o,s)},options:{...jI,indexAxis:e.horizontal?"y":"x",layout:Rw(0,s),scales:Vw(o,s),plugins:{title:ox(o,t),legend:Aw(o),tooltip:rx(o,s),chartShowValuesPlugin:Jw(o,s)}}},background:e.background||k}}const yx=[JC,QC],Ix=["x",...yx];class wx extends Lh{mutators=["resetAxisLimits","updateAxisLimits","updateTrendLineConfiguration","clearAxisLimits"];originalAxisLimits={};currentAxesLimits={};idConversion={};handle(e){switch(e.type){case"DELETE_FIGURE":if(e.figureId&&this.idConversion[e.figureId])for(const t of this.idConversion[e.figureId])delete this.originalAxisLimits[t],delete this.currentAxesLimits[t];break;case"UPDATE_CHART":const t=`${e.definition.type}-${e.figureId}`;this.idConversion[e.figureId]||(this.idConversion[e.figureId]=new Set),this.idConversion[e.figureId].add(t),"zoomable"in e.definition&&e.definition.zoomable||this.clearAxisLimits(t)}}clearAxisLimits(e){return delete this.originalAxisLimits[e],delete this.currentAxesLimits[e],"noStateChange"}resetAxisLimits(e,t){for(const o of Ix)t?.[o]?(this.originalAxisLimits[e]?.[o]||(this.originalAxisLimits[e]={...this.originalAxisLimits[e],[o]:{}}),this.originalAxisLimits[e][o].min=t[o].min,this.originalAxisLimits[e][o].max=t[o].max):this.originalAxisLimits[e]?.[o]&&delete this.originalAxisLimits[e][o];return"noStateChange"}updateAxisLimits(e,t){if(void 0===t)return delete this.currentAxesLimits[e],"noStateChange";let{min:o,max:s}=t;return o>s&&([o,s]=[s,o]),this.currentAxesLimits[e]={x:{min:o,max:s}},"noStateChange"}updateTrendLineConfiguration(e){if(!this.originalAxisLimits[e])return"noStateChange";const t=this.originalAxisLimits[e].x;if(void 0===t)return"noStateChange";for(const o of yx){if(!this.originalAxisLimits[e][o])continue;if(this.currentAxesLimits[e]?.[o]||(this.currentAxesLimits[e]={...this.currentAxesLimits[e],[o]:{}}),void 0===this.currentAxesLimits[e]?.x)return"noStateChange";const s=t.max-t.min,i=this.originalAxisLimits[e][o],n=(i.max-i.min)/s,r=i.min-t.min*n,a=this.currentAxesLimits[e].x.min,l=this.currentAxesLimits[e].x.max;this.currentAxesLimits[e][o].min=a*n+r,this.currentAxesLimits[e][o].max=l*n+r}return"noStateChange"}}const xx={id:"zoomWindowPlugin",afterDatasetsDraw:function(e,t,o){if(!o.getLowerBound||!o.getUpperBound)return;const{ctx:s,chartArea:{left:i,right:n,top:r,bottom:a}}=e;let l=o.getLowerBound()??i,c=o.getUpperBound()??n;l>c&&([l,c]=[c,l]),l=Math.max(i,l),c=Math.min(n,c),l===i&&(l-=1),c===n&&(c+=1),s.save(),s.fillStyle="rgba(255,255,255,0.5)",s.beginPath(),s.rect(i,a,l-i,r-a),s.rect(c,a,n-c,r-a),s.fill(),s.beginPath(),s.strokeStyle="#bbb",s.rect(l,a,c-l,r-a),s.stroke(),s.lineWidth=2,s.beginPath(),s.moveTo(l-3,(r+a)/2-7),s.lineTo(l-3,(r+a)/2+7),s.stroke(),s.beginPath(),s.moveTo(c+3,(r+a)/2-7),s.lineTo(c+3,(r+a)/2+7),s.stroke(),s.restore()}};Bh`
9
+ `,Zh.add("chartShowValuesPlugin",{register:e=>e.register(Iy),unregister:e=>e.unregister(Iy)}),Zh.add("waterfallLinesPlugin",{register:e=>e.register(Yy),unregister:e=>e.unregister(Yy)}),Zh.add("funnelController",{register:e=>e.register(Xh()),unregister:e=>e.unregister(Xh())}),Zh.add("funnelElement",{register:e=>e.register(Kh()),unregister:e=>e.unregister(Kh())}),Zh.add("funnelTooltipPositioner",{register:e=>e.Tooltip.positioners.funnelTooltipPositioner=Qh,unregister:e=>e.Tooltip.positioners.funnelTooltipPositioner=void 0}),Zh.add("sunburstLabelsPlugin",{register:e=>e.register(jy),unregister:e=>e.unregister(jy)}),Zh.add("sunburstHoverPlugin",{register:e=>e.register(qy),unregister:e=>e.unregister(qy)});class Jy extends t.Component{static template="o-spreadsheet-ChartJsComponent";static props={chartId:String,isFullScreen:{type:Boolean,optional:!0}};canvas=t.useRef("graphContainer");chart;currentRuntime;animationStore;currentDevicePixelRatio=window.devicePixelRatio;get background(){return this.chartRuntime.background}get canvasStyle(){return`background-color: ${this.background}`}get chartRuntime(){const e=this.env.model.getters.getChartRuntime(this.props.chartId);if(!("chartJsConfig"in e))throw new Error("Unsupported chart runtime");return e}setup(){this.shouldAnimate&&(this.animationStore=Dh(Yh)),t.onMounted((()=>{jh();const e=this.chartRuntime;this.currentRuntime=e,this.createChart(pt(e))})),t.onWillUnmount(this.unmount.bind(this)),t.useEffect((()=>{const e=this.chartRuntime;e!==this.currentRuntime?(e.chartJsConfig.type!==this.currentRuntime.chartJsConfig.type?(this.chart?.destroy(),this.createChart(pt(e))):this.updateChartJs(pt(e)),this.currentRuntime=e):this.currentDevicePixelRatio!==window.devicePixelRatio&&(this.currentDevicePixelRatio=window.devicePixelRatio,this.updateChartJs(pt(this.currentRuntime)))}))}unmount(){this.chart?.destroy()}get shouldAnimate(){return this.env.model.getters.isDashboard()}createChart(e){let t=e.chartJsConfig;if(this.shouldAnimate&&this.animationStore){const e=this.env.model.getters.getChart(this.props.chartId)?.type;e&&this.animationStore.animationPlayed[this.animationChartId]!==e&&(t=this.enableAnimationInChartData(t),this.animationStore.disableAnimationForChart(this.animationChartId,e))}const o=this.canvas.el.getContext("2d");this.chart=new window.Chart(o,t)}updateChartJs(e){let t=e.chartJsConfig;if(this.shouldAnimate){const e=this.env.model.getters.getChart(this.props.chartId)?.type;e&&this.hasChartDataChanged()&&this.animationStore&&(t=this.enableAnimationInChartData(t),this.animationStore.disableAnimationForChart(this.animationChartId,e))}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()}hasChartDataChanged(){return!zt(this.getChartDataInRuntime(this.currentRuntime),this.getChartDataInRuntime(this.chartRuntime))}enableAnimationInChartData(e){return{...e,options:{...e.options,animation:{animateRotate:!0}}}}getChartDataInRuntime(e){const t=e.chartJsConfig.data;return{labels:t.labels,dataset:t.datasets.map((e=>({data:e.data,label:e.label,tree:e.tree})))}}get animationChartId(){return this.props.isFullScreen?this.props.chartId+"-fullscreen":this.props.chartId}}class Qy{sheetId;title;getters;humanize;constructor(e,t,o){this.title=e.title,this.sheetId=t,this.getters=o,this.humanize=e.humanize??!0}static validateChartDefinition(e,t){throw new Error("This method should be implemented by sub class")}static transformDefinition(e,t,o){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")}getCommonDataSetAttributesForExcel(e,t,o){return{dataSets:t.map((e=>ay(this.getters,e))).filter((e=>""!==e.range&&e.range!==sn.InvalidReference)),labelRange:ly(this.getters,e,o)}}}function eI(e,t,o,s,i){if("text"===t||"progress"===t||e?.type!==r.number||o?.type!==r.number)return;const n=o.value-e.value;return n>0?s:n<0?i:void 0}function tI(e,t,o){if("text"===o||e?.type!==r.number||t?.type!==r.number)return"neutral";const s=t.value-e.value;return s>0?"up":s<0?"down":"neutral"}function oI(e){return e.keyValue&&!Ia.test(e.keyValue)?"InvalidScorecardKeyValue":"Success"}function sI(e){return e.baseline&&!Ia.test(e.baseline)?"InvalidScorecardBaseline":"Success"}const iI=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"),nI=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 rI=class e extends Qy{keyValue;keyDescr;baseline;baselineMode;baselineDescr;progressBar=!1;background;baselineColorUp;baselineColorDown;fontColor;humanize;type="scorecard";constructor(e,t,o){super(e,t,o),this.keyValue=Ba(o,t,e.keyValue),this.keyDescr=e.keyDescr,this.baseline=Ba(o,t,e.baseline),this.baselineMode=e.baselineMode,this.baselineDescr=e.baselineDescr,this.background=e.background,this.baselineColorUp=e.baselineColorUp??We,this.baselineColorDown=e.baselineColorDown??qe,this.humanize=e.humanize??!0}static validateChartDefinition(e,t){return e.checkValidations(t,oI,sI)}static getDefinitionFromContextCreation(e){return{background:e.background,type:"scorecard",keyValue:e.range?.[0]?.dataRange,title:e.title||{text:""},baselineMode:Ge,baselineColorUp:We,baselineColorDown:qe,baseline:e.auxiliaryRange||"",humanize:e.humanize}}static transformDefinition(e,t,o){let s,i;if(t.baseline){const i=XC(e,t.baseline,o);i!==sn.InvalidReference&&(s=i)}if(t.keyValue){const s=XC(e,t.keyValue,o);s!==sn.InvalidReference&&(i=s)}return{...t,baseline:s,keyValue:i}}duplicateInDuplicatedSheet(t){const o=sy(this.sheetId,t,this.baseline),s=sy(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,keyDescr:this.keyDescr,humanize:this.humanize}}getDefinitionForExcel(){}updateRanges(t){const o=iy(this.baseline,t),s=iy(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 aI(e,t){const o=t.getContext("2d"),s=window.devicePixelRatio||1;t.width=s*e.canvas.width,t.height=s*e.canvas.height,o.scale(s,s);const i=e.canvas.width-me;if(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(fl(o,e.title.text,i-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,vl(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(iI);break;case"up":o.fill(nI)}o.restore()}if(e.baselineDescr){const t=e.baselineDescr;o.font=t.style.font,o.fillStyle=t.style.color,o.fillText(fl(o,t.text,i-t.position.x),t.position.x,t.position.y)}if(e.key&&(o.font=e.key.style.font,o.fillStyle=e.key.style.color,vl(o,fl(o,e.key.text,i-e.key.position.x),e.key.position,e.key.style.underline,e.key.style.strikethrough)),e.keyDescr){const t=e.keyDescr;o.font=e.keyDescr?.style.font??t.style.font,o.fillStyle=t.style.color,o.fillText(fl(o,t.text,i-t.position.x),t.position.x,t.position.y)}if(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 lI(e,t){let o,s="";const i=t.getLocale();if(e.keyValue){const n={sheetId:e.keyValue.sheetId,col:e.keyValue.zone.left,row:e.keyValue.zone.top};o=t.getEvaluatedCell(n),s=function(e,t,o){return e?t?Wr(e,o):e.formattedValue??String(e.value??""):""}(o,e.humanize??!0,i)}let n;const a=e.baseline;if(a){const e={sheetId:a.sheetId,col:a.zone.left,row:a.zone.top};n=t.getEvaluatedCell(e)}const{background:l,fontColor:c}=t.getStyleOfSingleCellChart(e.background,e.keyValue),h=function(e,t,o,s,i){if(!e)return"";if("text"===o||t?.type!==r.number||e.type!==r.number)return s?Wr(e,i):e.formattedValue;let{value:n,format:a}=e;return"progress"===o?(n=t.value/n,a="0.0%"):(n=Math.abs(t.value-n),"percentage"===o&&0!==n&&(n/=e.value),"percentage"===o&&(a="0.0%"),a||(n=Math.round(100*n)/100)),s?Wr({value:n,format:a},i):Rr(n,{format:a,locale:i})}(n,o,e.baselineMode,e.humanize??!0,i),d="progress"===e.baselineMode&&Qi(h,i)?Sn(h,i):0;return{title:{...e.title,text:e.title.text?t.dynamicTranslate(e.title.text):""},keyValue:s,keyDescr:e.keyDescr?.text?t.dynamicTranslate(e.keyDescr.text):"",baselineDisplay:h,baselineArrow:tI(n,o,e.baselineMode),baselineColor:eI(n,e.baselineMode,o,e.baselineColorUp,e.baselineColorDown),baselineDescr:"progress"!==e.baselineMode&&e.baselineDescr?.text?t.dynamicTranslate(e.baselineDescr.text):"",fontColor:c,background:l,baselineStyle:{..."percentage"!==e.baselineMode&&"progress"!==e.baselineMode&&a?t.getCellComputedStyle({sheetId:a.sheetId,col:a.zone.left,row:a.zone.top}):void 0,fontSize:e.baselineDescr?.fontSize,align:e.baselineDescr?.align},baselineDescrStyle:{textColor:e.baselineDescr?.color,...e.baselineDescr},keyValueStyle:{...e.keyValue?t.getCellComputedStyle({sheetId:e.keyValue.sheetId,col:e.keyValue.zone.left,row:e.keyValue.zone.top}):void 0,fontSize:e.keyDescr?.fontSize,align:e.keyDescr?.align},keyValueDescrStyle:{textColor:e.keyDescr?.color,...e.keyDescr},progressBar:"progress"===e.baselineMode?{value:d,color:d>0?e.baselineColorUp:e.baselineColorDown}:void 0}}const cI=.05;function hI(e,t){const o=e||"";return t&&o?" "+o:o}function dI({width:e,height:t},o){return new uI({width:e,height:t},o).computeDesign()}class uI{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-me;break;default:s=me}e.title={text:this.title,style:t.title,position:{x:s,y:fe+o/2}}}const s=t.baselineArrow?.size??0;let{height:i,width:n}=this.getTextDimensions(this.baseline,t.baselineValue.font);this.baseline||(i=this.getTextDimensions(this.baselineDescr,t.baselineDescr.font).height);const r=this.getTextDimensions(this.baselineDescr,t.baselineDescr.font).width;let a;switch(this.runtime.baselineStyle?.align){case"right":a=this.width-me-r-n;break;case"left":a=me+s;break;default:a=(this.width-n-r+s)/2}if(this.baseline&&(e.baseline={text:this.baseline,style:t.baselineValue,position:{x:a,y:this.keyValue?this.height*(1-cI*(this.runtime.progressBar?1:2)):this.height-(this.height-o-i)/2-fe}},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}})),e.baseline&&this.baselineDescr){const o={x:e.baseline.position.x+n,y:e.baseline.position.y};e.baselineDescr={text:this.baselineDescr,style:t.baselineDescr,position:o}}let l=0;this.runtime.progressBar&&(l=.05*this.height,e.progressBar={position:{x:2*me,y:.9*this.height-i-l},dimension:{height:l,width:this.width-4*me},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),d=this.getTextDimensions(this.keyDescr,t.keyDescr.font).width;let u;switch(this.runtime.keyValueStyle?.align){case"right":u=this.width-me-d-c;break;case"left":u=me;break;default:u=(this.width-c-d)/2}if(this.keyValue&&(e.key={text:this.keyValue,style:t.keyValue,position:{x:Math.max(me,u),y:.4*this.height+fe/2+(o+h/2)/2}}),e.key&&this.keyDescr){const o={x:e.key.position.x+c,y:e.key.position.y};e.keyDescr={text:this.keyDescr,style:t.keyDescr,position:o}}return e}get title(){return this.runtime.title.text??""}get keyValue(){return this.runtime.keyValue}get keyDescr(){return hI(this.runtime.keyDescr,this.keyValue)}get baseline(){return this.runtime.baselineDisplay}get baselineDescr(){return hI(this.runtime.baselineDescr,this.baseline)}get baselineArrow(){return this.runtime.baselineArrow}get backgroundColor(){return this.runtime.background}get secondaryFontColor(){return dy(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(){const e=this.runtime.keyValueStyle?.fontSize??32,t=Math.floor(.9*e);let o=this.runtime.baselineStyle?.fontSize??16;const s=Math.floor(.9*o);return this.runtime.progressBar&&(o/=1.5),{title:{font:sl(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:sl(e,this.runtime.keyValueStyle?.bold,this.runtime.keyValueStyle?.italic),strikethrough:this.runtime.keyValueStyle?.strikethrough,underline:this.runtime.keyValueStyle?.underline},keyDescr:{color:this.runtime.keyValueDescrStyle?.textColor||this.runtime.fontColor,font:sl(t,this.runtime.keyValueDescrStyle?.bold,this.runtime.keyValueDescrStyle?.italic),strikethrough:this.runtime.keyValueDescrStyle?.strikethrough,underline:this.runtime.keyValueDescrStyle?.underline},baselineValue:{font:sl(o,this.runtime.baselineStyle?.bold,this.runtime.baselineStyle?.italic),strikethrough:this.runtime.baselineStyle?.strikethrough,underline:this.runtime.baselineStyle?.underline,color:this.runtime.baselineColor||this.runtime.baselineStyle?.textColor||this.secondaryFontColor},baselineDescr:{font:sl(s,this.runtime.baselineDescrStyle?.bold,this.runtime.baselineDescrStyle?.italic),strikethrough:this.runtime.baselineDescrStyle?.strikethrough,underline:this.runtime.baselineDescrStyle?.underline,color:this.runtime.baselineDescrStyle?.textColor??this.secondaryFontColor},baselineArrow:"neutral"===this.baselineArrow||this.runtime.progressBar?void 0:{size:this.keyValue?.8*o:0,color:this.runtime.baselineColor||this.runtime.baselineStyle?.textColor||this.secondaryFontColor}}}}class gI extends t.Component{static template="o-spreadsheet-ScorecardChart";static props={chartId:String,isFullScreen:{type:Boolean,optional:!0}};canvas=t.useRef("chartContainer");get runtime(){return this.env.model.getters.getChartRuntime(this.props.chartId)}get title(){const e=this.env.model.getters.getChartDefinition(this.props.chartId).title.text;return e?this.env.model.getters.dynamicTranslate(e):""}setup(){t.useEffect(this.createChart.bind(this),(()=>{const e=this.canvas.el.getBoundingClientRect();return[e.width,e.height,this.runtime,this.canvas.el,window.devicePixelRatio]}))}createChart(){const e=this.canvas.el;aI(dI(e.getBoundingClientRect(),this.runtime),e)}}const pI=/Mac/i,mI=["Shift","Control","Alt","Meta"];function fI(e,t){return!!e&&(!!t.target&&e.contains(t.target))}function vI(){const e=document.querySelector(".o-grid-overlay");if(e){const{top:t,left:o}=e.getBoundingClientRect();return{top:t,left:o}}throw new Error("Can't find spreadsheet position")}function bI(e){return e.el?SI(e.el):{x:0,y:0,width:0,height:0}}function SI(e){const t=e.getBoundingClientRect();return{x:t.x,y:t.y,width:t.width,height:t.height}}function*CI(e){if(yield e,e.hasChildNodes())for(const t of e.childNodes)yield*CI(t)}function yI(e){const{startElement:t,endElement:o,startSelectionOffset:s,endSelectionOffset:i}=function(e){const t=document.getSelection();return{startElement:t.anchorNode||e,startSelectionOffset:t.anchorOffset,endElement:t.focusNode||e,endSelectionOffset:t.focusOffset}}(e);return{start:II(e,t,s),end:II(e,o,i)}}function II(e,t,o){let s=0;const i=CI(e);let n=i.next(),r=!0;for(;!n.done&&n.value!==t;)n.value.hasChildNodes()||n.value.textContent&&(s+=n.value.textContent.length),("P"===n.value.nodeName||"DIV"===n.value.nodeName&&n.value!==e)&&(r?r=!1:s++),n=i.next();if(n.value!==t)return 0;if(n.value.hasChildNodes()){const e=[...n.value.childNodes].slice(0,o);s+=e.reduce(((t,o,s)=>{if(null!==o.textContent){let i=o.textContent.length;return"P"===o.nodeName&&s!==e.length-1&&i++,t+i}return t}),0)}else s+=o;return"P"!==t.nodeName||r||""!==t.textContent||s++,s}const wI=/^[a-zA-Z]$/;function xI(e,t="key"){let o="";mI.includes(e.key)||(RI(e)&&(o+="Ctrl+"),e.altKey&&(o+="Alt+"),e.shiftKey&&(o+="Shift+"));const s="key"===t?e.key:e.code;return o+=wI.test(s)?s.toUpperCase():s,o}function EI(){return Boolean(pI.test(navigator.userAgent))}function RI(e){return EI()||_I()?e.metaKey:e.ctrlKey}function TI(e){return 1===e.button||RI(e)&&0===e.button}function AI(e,t){const o=document.createElement("a");o.href=e,o.download=t,document.body.appendChild(o),o.click(),document.body.removeChild(o)}function DI(){return/Firefox/i.test(navigator.userAgent)}function _I(){return/(iPad|iPhone|iPod)/i.test(navigator.userAgent)||"MacIntel"===navigator.platform&&(navigator.maxTouchPoints||1)>1}function FI(){return/Android/i.test(navigator.userAgent)||_I()||/(webOS|BlackBerry|Windows Phone)/i.test(navigator.userAgent)}function OI(e){return 8===(e=_s(e).replace("#","")).length?e.slice(6)+e.slice(0,6):e}const PI=30,MI=10,NI=20,kI=12,LI=80,VI="#F3F2F1",UI=6,HI=25;function zI(e,t){const o=e.getBoundingClientRect(),s=window.devicePixelRatio||1;e.width=s*o.width,e.height=s*o.height;const i=e.getContext("2d");i.scale(s,s);const n=function(e,t,o){const s=t.maxValue,i=t.minValue,n=ZI(t,"animated"),r=function(e,t){const o=t?HI:0,s=e.height-NI-o-MI,i=e.width-2*PI;let n,r;i>2*s?(n=2*s,r=s):(n=i,r=i/2);const a=o+MI+(s-r)/2;return{x:PI+(i-n)/2,y:a,width:n,height:r}}(e,t.title.text),a=r.width/6,l=n?(n-i.value)/(s.value-i.value):0,c={x:e.width/2,y:r.y+r.height-r.height/12};let h=LI;r.height<300&&(h*=r.height/300);const d=r.width/2,u=t.gaugeValue?.label||"-";nl(o,u,{fontSize:h},"px")>d&&(h=function(e,t,o,s=.25){let i=1;if(o(i)>e)return i;if(o(t)<e)return t;let n=(i+t)/2,r=o(n),a=0;for(;Math.abs(r-e)>s&&a<20;)r>=e?t=(i+t)/2:i=(i+t)/2,n=(i+t)/2,r=o(n),a++;return n}(d,h,(e=>nl(o,u,{fontSize:e},"px"))));const g={x:r.x+a/2,y:r.y+r.height+kI},p={x:r.x+r.width-a/2,y:r.y+r.height+kI},m=dy(t.background),f=function(e,t,o,s){const i=e.maxValue,n=e.minValue,r={x:t.x+t.width/2,y:t.y+t.height},a={fontSize:kI},l=[],c=[];for(const h of e.inflectionValues){const e=(h.value-n.value)/(i.value-n.value),d=nl(s,h.label,a,"px"),u=Math.PI-Math.PI*e,g=qI(u,t.height+UI,r.x,r.y,d+2,kI),p=c.some((e=>WI(e,g)))?kI:0;c.push(g),l.push({rotation:u,label:h.label,fontSize:kI,color:o,offset:p})}return l}(t,r,m,o);let v=0,b=0,S=0;t.title.text&&({width:b,height:S}=ll(o,t.title.text,{fontSize:be,...t.title},"px"));switch(t.title.align){case"right":v=e.width-b-me;break;case"center":v=(e.width-b)/2;break;default:v=me}return{width:e.width,height:e.height,title:{label:t.title.text??"",fontSize:t.title.fontSize??be,textPosition:{x:v,y:ve+S/2},color:t.title.color??m,bold:t.title.bold,italic:t.title.italic},backgroundColor:t.background,gauge:{rect:r,arcWidth:a,percentage:St(l,0,1),color:BI(t)},inflectionValues:f,gaugeValue:{label:u,textPosition:c,fontSize:h,color:m},minLabel:{label:t.minValue.label,textPosition:g,fontSize:kI,color:m},maxLabel:{label:t.maxValue.label,textPosition:p,fontSize:kI,color:m}}}(o,t,i);!function(e,t){e.save(),e.fillStyle=t.backgroundColor,e.fillRect(0,0,t.width,t.height),e.restore()}(i,n),function(e,t){e.save();const o=t.gauge,s=o.rect.x+o.rect.width/2,i=o.rect.y+o.rect.height,n=o.rect.height-o.arcWidth/2;if(n<0)return;const r=1===o.percentage?0:Math.PI*(1+o.percentage);e.strokeStyle=VI,e.beginPath(),e.lineWidth=o.arcWidth,e.arc(s,i,n,r,0),e.stroke(),e.strokeStyle=o.color,e.beginPath(),e.arc(s,i,n,Math.PI,r),e.stroke(),e.restore()}(i,n),function(e,t){const{x:o,y:s,width:i,height:n}=t.gauge.rect;for(const r of t.inflectionValues){e.save(),e.translate(o+i/2-.5,s+n-.5),e.rotate(Math.PI/2-r.rotation),e.lineWidth=2,e.strokeStyle=dy(t.backgroundColor)+"aa",e.beginPath(),e.moveTo(0,-(n-t.gauge.arcWidth)),e.lineTo(0,-n-3),e.stroke(),e.textAlign="center",e.font=`${r.fontSize}px ${Le}`,e.fillStyle=r.color;const a=-n-UI-r.offset;e.fillText(r.label,0,a),e.restore()}}(i,n),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 ${Le}`,e.fillText(o.label,o.textPosition.x,o.textPosition.y),e.restore()}(i,n),function(e,t){e.save();const o=t.title;e.font=sl(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()}(i,n)}function BI(e){const t=ZI(e,"final");if(void 0===t)return VI;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 $I(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 GI(e,t){const o=e.start,s=e.end,i=t.start,n=t.end;function r(e,t,o){return(o.y-e.y)*(t.x-e.x)>(t.y-e.y)*(o.x-e.x)}return r(o,i,n)!==r(s,i,n)&&r(o,s,i)!==r(o,s,n)}function WI(e,t){const o=$I(e),s=$I(t);for(const e of o)for(const t of s)if(GI(e,t))return!0;return!1}function qI(e,t,o,s,i,n){const r=Math.cos(e),a=Math.sin(e),l=r*t,c=a*t,h=a*(i/2),d=r*(i/2),u=r*(t+n),g=a*(t+n);return{bottomLeft:{x:l-h+o,y:s-(c+d)},bottomRight:{x:l+h+o,y:s-(c-d)},topRight:{x:u+h+o,y:s-(g-d)},topLeft:{x:u-h+o,y:s-(g+d)}}}function ZI(e,t){return"animated"===t&&void 0!==e.animationValue?e.animationValue:e.gaugeValue?.value}const jI={responsive:!0,maintainAspectRatio:!1,elements:{line:{fill:!1},point:{hitRadius:15}},animation:!1,events:["mousemove","mouseout","click","touchstart","touchmove","mouseup"]};function YI(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");let n;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=pt(e.chartJsConfig);t.plugins=[KI];const o=new window.Chart(i,t);n=o.toBase64Image(),o.destroy()}else if("scorecard"===o){aI(dI(t,e),i),n=i.toDataURL()}else"gauge"===o&&(zI(i,e),n=i.toDataURL());return s.remove(),n}async function XI(e,t,o){const s=document.createElement("div");s.style.width=`${t.width}px`,s.style.height=`${t.height}px`,s.style.position="fixed",s.style.opacity="0";const i=document.createElement("canvas");s.append(i),i.setAttribute("width",t.width.toString()),i.setAttribute("height",t.height.toString()),document.body.append(s);let n=null;if("chartJsConfig"in e){const t=pt(e.chartJsConfig);t.plugins=[KI];const o=new window.Chart(i,t);n=await new Promise((e=>i.toBlob(e,"image/png"))),o.destroy()}else if("scorecard"===o){aI(dI(t,e),i),n=await new Promise((e=>i.toBlob(e,"image/png")))}else"gauge"===o&&(zI(i,e),n=await new Promise((e=>i.toBlob(e,"image/png"))));return s.remove(),n?new File([n],"chart.png",{type:"image/png"}):void 0}const KI={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()}},JI={second:1e3,minute:6e4,hour:36e5,day:864e5,month:2592e6,year:31536e6},QI={inSeconds:function(e){return Math.floor(e/JI.second)},inMinutes:function(e){return Math.floor(e/JI.minute)},inHours:function(e){return Math.floor(e/JI.hour)},inDays:function(e){return Math.floor(e/JI.day)},inMonths:function(e){return Math.floor(e/JI.month)},inYears:function(e){return Math.floor(e/JI.year)}},ew=/^((d|dd|m|mm|yyyy|yy|hh|h|ss|a)(-|:|\s|\/))*(d|dd|m|mm|yyyy|yy|hh|h|ss|a)$/i;function tw(e,t,o){const s=function(e){const t=e.indexOf("h");e=t>=0?e.slice(0,t).replace(/m/g,"M")+e.slice(t):e.replace(/m/g,"M");e.includes("a")||(e=e.replace(/h/g,"H"));return e}(t),i=function(e,t,o){const s=e.map((e=>Vi(e,o)?.jsDate));if(s.some((e=>void 0===e))||e.length<2)return;const i=s.map((e=>e.getTime())),n=no(i)-ro(i),r=function(e){if(e.includes("s"))return"second";if(e.includes("m"))return"minute";if(e.includes("h")||e.includes("H"))return"hour";if(e.includes("d"))return"day";if(e.includes("M"))return"month";return"year"}(t);if(JI.second>=JI[r]&&QI.inSeconds(n)<180)return"second";if(JI.minute>=JI[r]&&QI.inMinutes(n)<180)return"minute";if(JI.hour>=JI[r]&&QI.inHours(n)<96)return"hour";if(JI.day>=JI[r]&&QI.inDays(n)<90)return"day";if(JI.month>=JI[r]&&QI.inMonths(n)<36)return"month";return"year"}(e,s,o),n={};return i&&(n[i]=s),{parser:s,displayFormats:n,unit:i??!1,tooltipFormat:s}}function ow(e,t,o,s){let i=yw(s,t,o).formattedValues,n=ww(s,t);py(o,t[0],e.dataSetsHaveTitle||!1)&&i.shift(),({labels:i,dataSetsValues:n}=bw(i,n)),e.aggregated&&({labels:i,dataSetsValues:n}=Sw(i,n));const r=Iw(s,t,"left"),a=Iw(s,t,"right"),l=e.horizontal?{x:r||a}:{y:r,y1:a},c=[];for(const t in n){const{data:o}=n[t],s=e.dataSets?.[t].trend;if(!s?.display||e.horizontal){c.push(void 0);continue}const i=hw(s,o);c.push(i)}return{dataSetsValues:n,trendDataSetsValues:c,axisFormats:l,labels:i,locale:s.getLocale(),topPadding:Ew(e,s)}}function sw(e,t,o,s){const i=ow(e,t.slice(0,2),o,s),n=i.dataSetsValues.filter((e=>!e.hidden)),r=[];if(n[0]){const e=n[0].data.map((e=>e>0?e:0));r.push({...n[0],data:e})}if(n[1]){const e=n[1].data.map((e=>e>0?-e:0));r.push({...n[1],data:e})}return{...i,dataSetsValues:r}}function iw(e,t,o,s){const i=function(e,t,o,s){if(function(e,t,o,s){return!e.labelsAsText&&pw(e,t,o,s)}(e,t,o,s)&&function(){if(!window.Chart)return!1;const e="luxon"===new window.Chart._adapters._date({})._id;e||fw||(fw=!0,console.warn("'chartjs-adapter-luxon' time adapter is not installed. Time scale axes are disabled."));return e}())return"time";if(function(e,t,o,s){return!e.labelsAsText&&mw(e,t,o,s)}(e,t,o,s))return"linear";return"category"}(e,t,o,s),n=yw(s,t,o);let r="linear"===i?n.values:n.formattedValues,a=ww(s,t);const l=py(o,t[0],e.dataSetsHaveTitle||!1);l&&r.shift(),({labels:r,dataSetsValues:a}=bw(r,a)),"time"===i&&({labels:r,dataSetsValues:a}=function(e,t){if(0===e.length||e.every((e=>!e)))return{labels:e,dataSetsValues:t};const o=[...e],s=pt(t);for(let e=0;e<o.length;e++)if(!o[e]){o[e]=Ut(o,e);for(const t of s)t.data[e]=void 0}return{labels:o,dataSetsValues:s}}(r,a)),e.aggregated&&({labels:r,dataSetsValues:a}=Sw(r,a)),e.cumulative&&(a=xw(a,"asc"));const c={y:Iw(s,t,"left"),y1:Iw(s,t,"right"),x:Cw(s,o,l)},h=[];for(const t in a){const o=e.dataSets?.[t].trend;if(!o?.display){h.push(void 0);continue}const{data:n}=a[t];h.push(dw(o,n,r,i,s.getLocale()))}return{dataSetsValues:a,axisFormats:c,labels:r,locale:s.getLocale(),trendDataSetsValues:h,axisType:i,topPadding:Ew(e,s)}}function nw(e,t,o,s){let i=yw(s,t,o).formattedValues,n=ww(s,t);py(o,t[0],e.dataSetsHaveTitle||!1)&&i.shift(),({labels:i,dataSetsValues:n}=bw(i,n)),e.aggregated&&({labels:i,dataSetsValues:n}=Sw(i,n)),({dataSetsValues:n,labels:i}=function(e,t){const o=Math.max(e.length,...t.map((e=>e.data?.length||0))),s=Ct(0,o).filter((e=>t.some((t=>"number"==typeof t.data[e]&&t.data[e]>0))));return{labels:s.map((t=>e[t]||"")),dataSetsValues:t.map((e=>({...e,data:s.map((t=>"number"==typeof e.data[t]&&e.data[t]>0?e.data[t]:null))})))}}(i,n));return{dataSetsValues:n,axisFormats:{y:Iw(s,t,"left")},labels:i,locale:s.getLocale(),topPadding:Ew(e,s)}}function rw(e,t,o,s){let i=yw(s,t,o).formattedValues,n=ww(s,t);py(o,t[0],e.dataSetsHaveTitle||!1)&&i.shift(),({labels:i,dataSetsValues:n}=bw(i,n)),e.aggregated&&({labels:i,dataSetsValues:n}=Sw(i,n));return{dataSetsValues:n,axisFormats:{r:Iw(s,t,"left")||Iw(s,t,"right")},labels:i,locale:s.getLocale()}}function aw(e,t,o,s){const i=t.slice(0,1);let n=yw(s,i,o).formattedValues;py(o,i[0],e.dataSetsHaveTitle||!1)&&n.shift();let r=ww(s,i);({labels:n,dataSetsValues:r}=Sw(n,r));return{dataSetsValues:r,axisFormats:{y:Iw(s,i,"left")||Iw(s,i,"right")},labels:n,locale:s.getLocale(),availableRegions:s.getGeoChartAvailableRegions(),geoFeatureNameToId:s.geoFeatureNameToId,getGeoJsonFeatures:s.getGeoJsonFeatures}}function lw(e,t,o,s){let i=yw(s,t,o).formattedValues,n=ww(s,t);py(o,t[0],e.dataSetsHaveTitle||!1)&&i.shift(),({labels:i,dataSetsValues:n}=bw(i,n)),e.aggregated&&({labels:i,dataSetsValues:n}=Sw(i,n)),e.cumulative&&(n=xw(n,"desc"));return{dataSetsValues:n,axisFormats:{x:Iw(s,t,"left")||Iw(s,t,"right")},labels:i,locale:s.getLocale()}}function cw(e,t,o,s){let i=yw(s,t,o).values,n=function(e,t){t=t.filter((t=>!e.isColHidden(t.dataRange.sheetId,t.dataRange.zone.left)));const o=t.map((()=>({data:[],label:""}))),s=t.map((t=>vw(e,t)));if(!s.length)return o;const i=Math.min(...s.map((e=>e.length)));let n=[];const r=t.length-1;for(let e=0;e<i;e++)for(let t=0;t<s.length;t++){let i=s[t][e];null==i&&t!==r&&(i=n[t]),i!==n[t]&&(n=n.slice(0,t),n[t]=i),o[t].data.push(i??null)}return o.filter((e=>e.data.some((e=>null!==e))))}(s,t);const r=py(o,t[0],e.dataSetsHaveTitle||!1);return r&&i.shift(),({labels:i,dataSetsValues:n}=function(e,t){const o=[],s=[];for(let t=0;t<e.length;t++)Number(e[t])<=0?s.push(t):Number(e[t])>0&&o.push(t);const i=o.length?o:s;return{labels:i.map((t=>e[t])),dataSetsValues:t.map((e=>({...e,data:i.map((t=>e.data[t]))})))}}(i,n)),({labels:i,dataSetsValues:n}=function(e,t){const o=Math.max(e.length,...t.map((e=>e.data?.length||0))),s=e=>null==e||""===e,i=Ct(0,o).filter((o=>{const i=t.map((e=>e.data?.[o]));if(s(i[0]))return!1;let n=!1;for(const e of i)if(n||=s(e),n&&!s(e))return!1;return e[o]&&!isNaN(Number(e[o]))}));return{labels:i.map((t=>e[t])),dataSetsValues:t.map((e=>({...e,data:i.map((t=>e.data[t]))})))}}(i,n)),{dataSetsValues:n,axisFormats:{y:Cw(s,o,r)},labels:i,locale:s.getLocale()}}function hw(e,t){const o=[],s=[],i=[];for(let e=0;e<t.length;e++)"number"==typeof t[e]&&(o.push(t[e]),s.push(e+1)),i.push(e+1);const n=uw(e,o,s,Ct(.5,i.length+.55,.2));return n.length?n:void 0}function dw(e,t,o,s,i){const n=[],r=[],a=[],l=t.length;if(l<2)return;switch(s){case"category":for(let e=0;e<l;e++)"number"==typeof t[e]&&(n.push(t[e]),r.push(e+1)),a.push(e+1);break;case"linear":for(let e=0;e<t.length;e++){const s=Number(o[e]);isNaN(s)||("number"==typeof t[e]&&(n.push(t[e]),r.push(s)),a.push(s))}break;case"time":for(let e=0;e<t.length;e++){const s=Sn({value:o[e]},i);null!==t[e]&&(n.push(t[e]),r.push(s)),a.push(s)}}const c=Math.min(...a),h=Math.max(...a);if(h===c)return;const d=(h-c)/(5*a.length),u=uw(e,n,r,Ct(c,h+d/2,d));return u.length?u:void 0}function uw(e,t,o,s){if(t.length<2||o.length<2||0===s.length)return[];const{normalizedLabels:i,normalizedNewLabels:n}=function(e,t,o){let s=[],i=[];if("logarithmic"===o.type){const o=Math.max(...e.map(Math.abs));s=e.map((e=>e/o)),i=t.map((e=>e/o))}else{const o=Math.max(...e),n=Math.min(...e),r=o-n;s=e.map((e=>(e-o)/r)),i=t.map((e=>(e-o)/r))}return{normalizedLabels:s,normalizedNewLabels:i}}(o,s,e);try{switch(e.type){case"polynomial":{const o=e.order;if(!o)return s.map((e=>({x:e,y:NaN})));if(1===o)return Oc([t],[i],[n],!0)[0].map(((e,t)=>({x:s[t],y:e})));const r=Tc(t,i,o,!0).flat();return n.map(((e,t)=>({x:s[t],y:Dc(r,e,o)})))}case"exponential":{const e=[],o=[];for(let s=0;s<t.length;s++)t[s]>0&&(e.push(Math.log(t[s])),o.push(i[s]));return o.length?_c(Oc([e],[o],[n],!0))[0].map(((e,t)=>({x:s[t],y:e}))):s.map((e=>({x:e,y:NaN})))}case"logarithmic":return Oc([t],Fc([i]),Fc([n]),!0)[0].map(((e,t)=>({x:s[t],y:e})));case"trailingMovingAverage":return function(e,t,o=Ye){const s=[];for(let e=0;e<o-1;e++)s.push({x:t[e],y:NaN});for(let i=0;i<=e.length-o;i++){let n=0;for(let t=i;t<i+o;t++)n+=e[t];s.push({x:t[i+o-1],y:n/o})}return s}(t,o,e.window);default:return s.map((e=>({x:e,y:NaN})))}}catch(e){return s.map((e=>({x:e,y:NaN})))}}function gw(e,t,o,s){return pw(e,t,o,s)||mw(e,t,o,s)}function pw(e,t,o,s){if(!o||!mw(e,t,o,s))return!1;const i=Cw(s,o,py(o,t[0],e.dataSetsHaveTitle||!1));return Boolean(i&&ew.test(i))}function mw(e,t,o,s){if(!o)return!1;const i=s.getRangeValues(o);return py(o,t[0],e.dataSetsHaveTitle||!1)&&i.shift(),!i.some((e=>isNaN(Number(e))&&e))&&!i.every((e=>!e))}let fw=!1;function vw(e,t){if(t.dataRange){const o=t.labelCell?[t.labelCell.zone]:[],s=Fo([t.dataRange.zone],o)[0];if(void 0===s)return[];const i=e.getRangeFromZone(t.dataRange.sheetId,s);return e.getRangeValues(i).map((e=>""===e?void 0:e))}return[]}function bw(e,t){const o=Ct(0,Math.max(e.length,...t.map((e=>e.data?.length||0)))).filter((o=>{const s=e[o],i=t.map((e=>e.data?.[o]));return s||i.some((e=>"number"==typeof e))}));return{labels:o.map((t=>e[t]||"")),dataSetsValues:t.map((e=>({...e,data:o.map((t=>"number"==typeof e.data[t]?e.data[t]:null))})))}}function Sw(e,t){const o=new Set(e),s={};o.forEach((e=>{s[e]=new Array(t.length).fill(0)}));for(const o of Ct(0,e.length)){const n=e[o];for(const e of Ct(0,t.length))s[n][e]+="number"==typeof(i=t[e].data[o])?i:0}var i;return{labels:Array.from(o),dataSetsValues:t.map(((e,t)=>({...e,data:Array.from(o).map((e=>s[e][t]))})))}}function Cw(e,t,o){if(!t)return;const{sheetId:s,zone:i}=t,n=is(i).map((t=>e.getEvaluatedCell({sheetId:s,...t}).format));return o&&n.shift(),n.find((e=>void 0!==e))}function yw(e,t,o){let s={values:[],formattedValues:[]};if(o){const{left:i}=o.zone;if(o.invalidXc||o.invalidSheetName||e.isColHidden(o.sheetId,i)){if(t[0]){s={formattedValues:Ct(0,vw(e,t[0]).length).map((e=>e.toString())),values:s.formattedValues}}}else s={formattedValues:e.getRangeFormattedValues(o),values:e.getRangeValues(o).map((e=>String(e??"")))}}else if(1===t.length){const o=vw(e,t[0]).length;for(let e=0;e<o;e++)s.formattedValues.push(""),s.values.push("")}else if(t[0]){s={formattedValues:Ct(0,vw(e,t[0]).length).map((e=>e.toString())),values:s.formattedValues}}return s}function Iw(e,t,o){const s=t.filter((e=>"right"===o==!!e.rightYAxis));for(const t of s){const o=e.getRangeFormats(t.dataRange).find((e=>void 0!==e&&!Mr(e)));if(o)return o}}function ww(e,t){const o=[];for(const[s,i]of Object.entries(t)){let t=`${_b.Series} ${parseInt(s)+1}`,n=e.isColHidden(i.dataRange.sheetId,i.dataRange.zone.left);if(i.labelCell){const{sheetId:o,zone:s}=i.labelCell,n=e.getEvaluatedCell({sheetId:o,col:s.left,row:s.top});n&&(t=n.formattedValue)}let r=i.dataRange?vw(e,i):[];r.every((e=>!e||"string"==typeof e&&!fn(e)))&&r.filter((e=>"string"==typeof e)).length>1?r=r.map((e=>e&&!fn(e)?1:null)):r.every((e=>null==e||!Qi(e.toString(),w)))&&(n=!0),o.push({data:r,label:t,hidden:n})}return o}function xw(e,t){return e.map((e=>{const o=[];let s=0;const i="asc"===t?Object.keys(e.data):Object.keys(e.data).reverse();for(const t of i)isNaN(parseFloat(e.data[t]))?o[t]=e.data[t]:(s+=parseFloat(e.data[t]),o[t]=s);return{...e,data:o}}))}function Ew(e,t){const{title:o,legendPosition:s}=e,i=o&&o.text||"top"===s;return t.isDashboard()&&!i?30:0}function Rw(e,t){return{padding:{left:me,right:me,top:Math.max(ve,t.topPadding||0),bottom:fe}}}function Tw(e,t){return{display:"none"!==e.legendPosition,position:"none"!==e.legendPosition?e.legendPosition:void 0}}function Aw(e,t){return{...kw,...Tw(e),...Lw(hy(e.background),{pointStyle:"rect",lineWidth:3})}}function Dw(e,t){const o=e.fillArea,s=o?"rect":"line",i=o?2:3;return{...kw,...Tw(e),...Lw(hy(e.background),{pointStyle:s,lineWidth:i})}}function _w(e,t){const{dataSetsValues:o}=t,s=Math.max(0,...o.map((e=>e?.data?.length??0))),i=Sy(new ti(s),o),n=hy(e.background);return{...Tw(e),labels:{usePointStyle:!0,generateLabels:e=>(e.data.labels?.map(((e,t)=>({text:Cy(String(e)),strokeStyle:i[t],fillStyle:i[t],pointStyle:"rect",lineWidth:2,fontColor:n})))||[]).filter((e=>e.text)),filter:(e,t)=>!("datasetIndex"in e)||!t.datasets[e.datasetIndex].hidden}}}function Fw(e,t){return{...kw,...Tw(e),...Lw(hy(e.background),{pointStyle:"circle",strokeStyle:e.background||"#ffffff",lineWidth:8})}}function Ow(e,t){return{...kw,...Tw(e),...Lw(hy(e.background),{lineWidth:3})}}function Pw(e,t){const o=hy(e.background),s=e.negativeValuesColor||Y,i=e.positiveValuesColor||j,n=e.subTotalValuesColor||X;return{...Tw(e),labels:{usePointStyle:!0,generateLabels:()=>{const t=[{text:ui("Positive values"),fontColor:o,fillStyle:i,strokeStyle:i,pointStyle:"rect"},{text:ui("Negative values"),fontColor:o,fillStyle:s,strokeStyle:s,pointStyle:"rect"}];return(e.showSubTotals||e.firstValueAsSubtotal)&&t.push({text:ui("Subtotals"),fontColor:o,fillStyle:n,strokeStyle:n,pointStyle:"rect"}),t},filter:(e,t)=>!("datasetIndex"in e)||!t.datasets[e.datasetIndex].hidden},onClick:()=>{}}}function Mw(e,t){const o=e.fillArea??!1,s=o?"rect":"line",i=o?2:3;return{...kw,...Tw(e),...Lw(hy(e.background),{pointStyle:s,lineWidth:i})}}function Nw(e,t){const o=hy(e.background);return{...Tw(e),labels:{usePointStyle:!0,generateLabels:e=>{const t=e.data.datasets.at(-1);if(!t)return[];return t.groupColors.map((({color:e,label:t})=>({text:Cy(t),fontColor:o,fillStyle:e,strokeStyle:e,pointStyle:"rect"})))}}}}const kw={onHover:e=>{const t=e.native?.target;t&&(t.style.cursor="pointer")},onLeave:e=>{const t=e.native?.target;t&&(t.style.cursor="default")},onClick:(e,t,o)=>{if("click"!==e.type)return;const s=t.datasetIndex;o.legendItems&&void 0!==s&&(o.chart.isDatasetVisible(s)?o.chart.hide(s):o.chart.show(s),e.native.preventDefault(),e.native.stopPropagation())}};function Lw(e,t){return{labels:{color:e,usePointStyle:!0,generateLabels:o=>o.data.datasets.map(((s,i)=>yy(s.xAxisID)?{text:Cy(s.label),fontColor:e,strokeStyle:s.borderColor,hidden:!o.isDatasetVisible(i),pointStyle:"line",datasetIndex:i,lineWidth:3}:{text:Cy(s.label),fontColor:e,strokeStyle:s.borderColor,fillStyle:s.backgroundColor,hidden:!o.isDatasetVisible(i),pointStyle:"line"===s.type?"line":"rect",datasetIndex:i,...t})).filter((e=>e.text)),filter:(e,t)=>!("datasetIndex"in e)||!t.datasets[e.datasetIndex].hidden}}}function Vw(e,t){let o={};const{trendDataSetsValues:s,locale:i,axisFormats:n}=t,r={stacked:e.stacked,locale:i};if(e.horizontal)o.x=jw(e,"bottom","values",{...r,format:n?.x}),o.y=jw(e,"left","labels",r);else{o.x=jw(e,"bottom","labels",r);const t={...r,format:n?.y};o.y=jw(e,"left","values",t);const s={...r,format:n?.y1};o.y1=jw(e,"right","values",s)}if(o=Wt(o),s&&s.length&&s.some(Mt)){const e=Math.max(...s.map((e=>e?.length||0)));o[JC]={...o.x,labels:Array(e).fill(""),offset:!1,display:!1},o[QC]={...o.x,offset:!0,display:!1}}return o}function Uw(e,t){const{locale:o,axisType:s,trendDataSetsValues:i,labels:n,axisFormats:r}=t,a=r?.x,l=e.stacked;let c={x:jw(e,"bottom","labels",{locale:o}),y:jw(e,"left","values",{locale:o,stacked:l,format:r?.y}),y1:jw(e,"right","values",{locale:o,stacked:l,format:r?.y1})};if(c=Wt(c),"time"===s&&n&&a){const e={type:"time",time:tw(n,a,o)};Object.assign(c.x,e),c.x.ticks.maxTicksLimit=15,delete c?.x?.ticks?.callback}else"linear"===s&&(c.x.type="linear",c.x.ticks.callback=e.humanize?e=>Wr({value:e,format:a},o):e=>Rr(e,{format:a,locale:o}));if(i&&i.length&&i.some(Mt)&&(c[JC]={...c.x,display:!1},c[QC]={...c.x,display:!1},"category"===s||"time"===s)){const e=Math.max(...i.map((e=>e?.length||0)));c[JC].type="category",c[JC].labels=Ct(0,e).map((e=>e.toString())),c[JC].offset=!1,c[QC].type="category",c[QC].offset=!1}return c}function Hw(e,t){const o=Uw(e,t);return{...o,x:{...o.x,grid:{display:!0}}}}function zw(e,t){const{locale:o,axisFormats:s}=t,i=s?.y||s?.y1;e.dataSets;const n={x:{...jw(e,"bottom","labels",{locale:o}),grid:{display:!1}},y:{position:e.verticalAxisPosition,ticks:{color:hy(e.background),callback:vy({locale:o,format:i},e.humanize)},grid:{lineWidth:e=>0===e.tick.value?2:1},title:Zw(e.axesDesign?.y)}},r=n?.y||n?.y1;return r&&(r.grid={lineWidth:e=>0===e.tick.value?2:1}),n}function Bw(e,t){const{dataSetsValues:o}=t,s=Vw(e,t),i=s.x.ticks.callback;s.x.ticks.callback=e=>i(Math.abs(e));const n=Math.max(...o.map((e=>Math.max(...e.data.map(Math.abs)))));return s.x.suggestedMin=-n,s.x.suggestedMax=n,s}function $w(e,t){const{locale:o,axisFormats:s,dataSetsValues:i}=t,n=Math.min(...i.map((e=>Math.min(...e.data.filter((e=>!isNaN(e)))))));return{r:{beginAtZero:!0,ticks:{callback:vy({format:s?.r,locale:o},e.humanize),backdropColor:e.background||"#FFFFFF"},pointLabels:{color:hy(e.background),callback:e=>Cy(e)},suggestedMin:n<0?n-1:0}}}function Gw(e,t){const{locale:o,axisFormats:s,availableRegions:i}=t,n=function(e){switch(e){case"top":return"top-left";case"right":return"top-right";case"bottom":return"bottom-right";case"left":case"none":return"bottom-left"}}(e.legendPosition),r=e.region?i.find((t=>t.id===e.region)):i[0],a=s?.y||s?.y1;return{projection:{projection:qw(r?.defaultProjection||"mercator"),axis:"x"},color:{axis:"x",display:"none"!==e.legendPosition,border:{color:J},grid:{color:J},ticks:{color:hy(e.background),callback:vy({locale:o,format:a},e.humanize)},legend:{position:n,align:n.includes("right")?"left":"right",margin:Xw(e)},interpolate:Yw(e),missing:e.missingValueColor||"#ffffff"}}}function Ww(e,t){const o=t.dataSetsValues[0];return{x:{display:!1},y:{grid:{offset:!1},ticks:{callback:function(e){return Cy(this.getLabelForValue(e))}},border:{display:!1}},percentages:{position:"right",border:{display:!1},ticks:{callback:function(e,s,i){const n=o.data?.[s],r=o.data?.[0];return r&&void 0!==n?Rr(n/r,{format:"0%",locale:t.locale}):""}},grid:{display:!1}}}}function qw(e){return"conicConformal"===e?window.ChartGeo.geoConicConformal().rotate([100,0]):e}function Zw(e){if(e?.title?.text){const{text:t,color:o,align:s,italic:i,bold:n}=e.title;return{display:!0,text:t,color:o,font:{style:i?"italic":"normal",weight:n?"bold":"normal",size:e.title.fontSize??Se},align:"left"===s?"start":"right"===s?"end":"center"}}}function jw(e,t,o,s){const{useLeftAxis:i,useRightAxis:n}=my(e);if("left"===t&&!i||"right"===t&&!n)return;const r=hy(e.background);let a;if(a="bottom"===t?e.axesDesign?.x:"left"===t?e.axesDesign?.y:e.axesDesign?.y1,"values"===o){const o=!("right"===t&&i);return{position:t,title:Zw(a),grid:{display:o},beginAtZero:!0,stacked:s?.stacked,ticks:{color:r,callback:vy(s,e.humanize)}}}return{ticks:{padding:5,color:r,callback:function(e,t,o){return Cy(this.getLabelForValue(e))}},grid:{display:!1},stacked:s?.stacked,title:Zw(a)}}function Yw(e){if(!e.colorScale||"string"==typeof e.colorScale)return e.colorScale||"oranges";const t=[{value:0,color:e.colorScale.minColor}];return e.colorScale.midColor&&t.push({value:.5,color:e.colorScale.midColor}),t.push({value:1,color:e.colorScale.maxColor}),ii(t)}function Xw(e){switch(e.legendPosition){case"top":case"right":return{top:!!e.title.text?ve+30:ve,left:me,right:me};case"bottom":case"left":case"none":return{left:me,right:me,bottom:fe}}}const Kw={showValues:!1,showLabels:!0,valuesDesign:{align:"center",fontSize:13}};function Jw(e,t){const{axisFormats:o,locale:s}=t;return{horizontal:"horizontal"in e&&e.horizontal,showValues:"showValues"in e&&!!e.showValues,background:e.background,callback:(t,i)=>{const n=function(e,t){if(t.rAxisID)return t.rAxisID;const o="horizontal"in e&&e.horizontal?t.xAxisID:t.yAxisID;return o||"y"}(e,i);return fy(o,s,e.humanize)(t,n)}}}function Qw(e,t){const{axisFormats:o,locale:s}=t;return{callback:fy(o,s,e.humanize),showLabels:e.showLabels??Kw.showLabels,showValues:e.showValues??Kw.showValues,style:{fontSize:e.valuesDesign?.fontSize??Kw.valuesDesign.fontSize,align:e.valuesDesign?.align??Kw.valuesDesign.align,bold:e.valuesDesign?.bold??Kw.valuesDesign.bold,italic:e.valuesDesign?.italic??Kw.valuesDesign.italic,textColor:e.valuesDesign?.color??Kw.valuesDesign.color}}}function ex(e,t){const{axisFormats:o,locale:s}=t;return{horizontal:!0,showValues:"showValues"in e&&!!e.showValues,background:e.background,callback:(e,t)=>0===(e=Math.abs(Number(e)))?"":fy(o,s)(e,t.xAxisID||"x")}}function tx(e,t){const{axisFormats:o,locale:s,dataSetsValues:i}=t,n=i.reduce(((e,t)=>(e.push((e.at(-1)||-1)+t.data.length+1),e)),[]);return{showValues:"showValues"in e&&!!e.showValues,background:e.background,callback:(t,i,r)=>{const a=i._dataset.data[r],l=a[1]-a[0];let c=l>=0?"+":"";return e.showSubTotals&&n.includes(r)&&"+"===c&&(c=""),`${c}${fy(o,s,e.humanize)(l,i.yAxisID)}`}}}function ox(e,t){const o=e.title,s=dy(e.background);return{display:!!o.text,text:o.text?t.dynamicTranslate(o.text):"",color:o?.color??s,align:"center"===o.align?"center":"right"===o.align?"end":"start",font:{size:e.title.fontSize??be,weight:o.bold?"bold":"normal",style:o.italic?"italic":"normal"},padding:{bottom:"top"===e.legendPosition?0:me}}}const sx='\n<templates>\n <t t-name="o-spreadsheet-CustomTooltip">\n <div\n class="o-chart-custom-tooltip border rounded px-2 py-1 pe-none mw-100 position-absolute text-nowrap shadow opacity-100">\n <table class="overflow-hidden m-0">\n <thead t-if="title">\n <tr>\n <th class="o-tooltip-title align-baseline border-0 text-truncate" t-esc="title" t-attf-style="max-width: {{ labelsMaxWidth }}"/>\n </tr>\n </thead>\n <tbody>\n <tr t-foreach="tooltipItems" t-as="tooltipItem" t-key="tooltipItem_index">\n <td>\n <span\n class="badge ps-2 py-2 rounded-0 align-middle"\n t-attf-style="background-color: {{ tooltipItem.boxColor }}"\n > </span>\n <small\n t-if="tooltipItem.label"\n class="o-tooltip-label d-inline-block text-truncate align-middle smaller ms-2"\n t-esc="tooltipItem.label"\n t-attf-style="max-width: {{ labelsMaxWidth }}"\n />\n </td>\n <td class="o-tooltip-value ps-2 fw-bolder text-end">\n <small class="smaller d-inline-block text-truncate align-middle" t-attf-style="max-width: {{ valuesMaxWidth }}">\n <t t-esc="tooltipItem.value"/>\n <t t-if="tooltipItem.percentage">\n (\n <t t-esc="tooltipItem.percentage"/>\n %)\n </t>\n </small>\n </td>\n </tr>\n </tbody>\n </table>\n </div>\n </t>\n</templates>\n';let ix;function nx(e,o={}){return function(e,o={}){ix||(ix=new t.App(t.Component,{templates:sx,translateFn:ui}));const s=ix.getTemplate(e),i=s(o,{}),n=document.createElement("div");return t.blockDom.mount(i,n),n}(e,o).innerHTML}function rx(e,t){return{enabled:!1,external:fx,callbacks:{title:function(e){return e.some((e=>!yy(e.dataset.xAxisID)))?void 0:""},beforeLabel:e=>e.dataset?.label||e.label,label:function(o){const s=e.horizontal;let i=s?o.parsed.x:o.parsed.y;null==i&&(i=o.parsed);const n=s?o.dataset.xAxisID:o.dataset.yAxisID;return fy(t.axisFormats,t.locale,e.humanize)(i,n)}}}}function ax(e,t){const{axisType:o,locale:s,axisFormats:i}=t,n=i?.x,r={enabled:!1,external:fx,callbacks:{}};return r.callbacks.label="linear"===o?t=>{const o=t.parsed.y;let r=yy(t.dataset.xAxisID)?"":t.parsed.x;"string"==typeof r&&Qi(r,s)&&(r=Sn(r,s));const a=Er(r,n,s,e.humanize),l=t.dataset.yAxisID||"y",c=Er(o,i?.[l],s,e.humanize);return a?`(${a}, ${c})`:`${c}`}:function(t){const o=t.parsed.y,n=t.dataset.yAxisID;return fy(i,s,e.humanize)(o,n)},r.callbacks.beforeLabel=e=>e.dataset?.label||e.label,r.callbacks.title=function(e){return"linear"!==o&&e.some((e=>!yy(e.dataset.xAxisID)))?void 0:""},r}function lx(e,t){const{locale:o,axisFormats:s}=t,i=s?.y||s?.y1;return{enabled:!1,external:fx,callbacks:{title:function(e){return e[0].dataset.label},beforeLabel:e=>e.label||e.dataset.label,label:function(t){const s=function(e,t){const o=e.filter((e=>"number"==typeof e)).reduce(((e,t)=>e+t),0);if(!o)return"";const s=e[t]/o*100;return s.toFixed(2)}(t.dataset.data,t.dataIndex),n=t.parsed.y??t.parsed;return`${Er(n,!i&&n>=1e3?"#,##":i,o,e.humanize)} (${s}%)`}}}}function cx(e,t){const{dataSetsValues:o,locale:s,axisFormats:i,labels:n}=t,r=i?.y||i?.y1,a=o.map((e=>e.label));return{enabled:!1,external:fx,callbacks:{beforeLabel:function(e){const t=n.length?Math.floor(e.dataIndex/n.length):0;return a[t]},label:function(t){const[o,i]=t.raw,n=i-o;return Er(n,!r&&Math.abs(n)>1e3?"#,##":r,s,e.humanize)}}}}function hx(e,t){const o=rx(e,t);return{...o,callbacks:{...o.callbacks,label:e=>{const t={...e,parsed:{y:e.parsed.y,x:Math.abs(e.parsed.x)}};return(o?.callbacks?.label)(t)}}}}function dx(e,t){const{locale:o,axisFormats:s}=t;return{enabled:!1,external:fx,callbacks:{beforeLabel:e=>e.dataset?.label||e.label,label:function(t){return Er(t.parsed.r,s?.r,o,e.humanize)}}}}function ux(e,t){const{locale:o,axisFormats:s}=t,i=s?.y||s?.y1;return{enabled:!1,external:fx,filter:function(e){return void 0!==e.raw.value},callbacks:{beforeLabel:e=>e.raw.feature.properties.name,label:function(t){const s=t.raw.value;return Er(s,!i&&Math.abs(s)>=1e3?"#,##":i,o,e.humanize)}}}}function gx(e,t){return{enabled:!1,external:fx,position:"funnelTooltipPositioner",callbacks:{title:()=>"",beforeLabel:e=>e.label,label:function(o){const s=o.parsed.x,i=o.dataset.xAxisID;return fy(t.axisFormats,t.locale,e.humanize)(s,i)}}}}function px(e,t){const{locale:o,axisFormats:s}=t,i=s?.y||s?.y1;return{enabled:!1,external:fx,filter:function(e){const t=e.raw;return t?.label!==Ry},callbacks:{title:()=>"",beforeLabel:e=>e.raw.groups.join(" / "),label:function(t){const s=t.raw.value;return Er(s,!i&&s>=1e3?"#,##":i,o,e.humanize)}}}}function mx(e,t){const{locale:o,axisFormats:s}=t,i=s?.y;return{enabled:!1,external:fx,filter:(e,t,o)=>t===o.length-1,callbacks:{title:()=>"",beforeLabel:e=>{const t=e.raw._data.children[0];if(!t)return"";const o=[];for(let s=0;s<=e.raw.l;s++)o.push(t[s]);return o.join(" / ")},label:t=>{const s=t.raw.v;return Er(s,!i&&s>=1e3?"#,##":i,o,e.humanize)}}}}function fx({chart:e,tooltip:t}){if(e.canvas.parentNode.querySelector("div.o-chart-custom-tooltip")?.remove(),0===t.opacity||0===t.dataPoints.length)return;const o=t.body.map(((e,o)=>{let s=e.before[0],i=e.lines[0];i||(i=s,s="");const n=t.labelColors[o].backgroundColor;return{label:s,value:i,boxColor:"string"==typeof n?Bs(n,1):n}})),s=nx("o-spreadsheet-CustomTooltip",{labelsMaxWidth:Math.floor(.5*e.canvas.clientWidth)+"px",valuesMaxWidth:Math.floor(.25*e.canvas.clientWidth)+"px",title:t.title[0],tooltipItems:o}),i=Object.assign(document.createElement("template"),{innerHTML:s}).content.firstChild;e.canvas.parentNode?.appendChild(i),Object.assign(i.style,{left:vx(e,t,i.clientWidth)+"px",top:Math.floor(t.caretY-i.clientHeight/2)+"px"})}function vx(e,t,o){const s=t.caretX;return s+o>e.chartArea.right?Math.max(0,s-o):s}var bx=Object.freeze({__proto__:null,GHOST_SUNBURST_VALUE:Ry,INTERACTIVE_LEGEND_CONFIG:kw,canChartParseLabels:gw,getBarChartData:ow,getBarChartDatasets:Ty,getBarChartLegend:Aw,getBarChartScales:Vw,getBarChartTooltip:rx,getChartColorsGenerator:Wy,getChartLabelFormat:Cw,getChartLayout:Rw,getChartShowValues:Jw,getChartTitle:ox,getComboChartDatasets:Oy,getComboChartLegend:Ow,getData:vw,getFunnelChartData:lw,getFunnelChartDatasets:Ny,getFunnelChartScales:Ww,getFunnelChartTooltip:gx,getFunnelLabelColors:ky,getGeoChartData:aw,getGeoChartDatasets:My,getGeoChartScales:Gw,getGeoChartTooltip:ux,getHierarchalChartData:cw,getLineChartData:iw,getLineChartDatasets:Dy,getLineChartLegend:Dw,getLineChartScales:Uw,getLineChartTooltip:ax,getPieChartData:nw,getPieChartDatasets:Fy,getPieChartLegend:_w,getPieChartTooltip:lx,getPyramidChartData:sw,getPyramidChartScales:Bw,getPyramidChartShowValues:ex,getPyramidChartTooltip:hx,getRadarChartData:rw,getRadarChartDatasets:Py,getRadarChartLegend:Mw,getRadarChartScales:$w,getRadarChartTooltip:dx,getScatterChartDatasets:_y,getScatterChartLegend:Fw,getScatterChartScales:Hw,getSunburstChartDatasets:Ly,getSunburstChartLegend:Nw,getSunburstChartTooltip:px,getSunburstShowValues:Qw,getTopPaddingForDashboard:Ew,getTreeMapChartDatasets:zy,getTreeMapChartTooltip:mx,getTrendDatasetForBarChart:hw,getTrendDatasetForLineChart:dw,getWaterfallChartLegend:Pw,getWaterfallChartScales:zw,getWaterfallChartShowValues:tx,getWaterfallChartTooltip:cx,getWaterfallDatasetAndLabels:Ay,makeDatasetsCumulative:xw});class Sx extends Qy{dataSets;labelRange;background;legendPosition;stacked;aggregated;type="bar";dataSetsHaveTitle;dataSetDesign;axesDesign;horizontal;showValues;zoomable;constructor(e,t,o){super(e,t,o),this.dataSets=ny(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Ba(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.stacked=e.stacked,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.horizontal=e.horizontal,this.showValues=e.showValues,this.zoomable=e.zoomable}static transformDefinition(e,t,o){return cy(e,t,o)}static validateChartDefinition(e,t){return e.checkValidations(t,uy,gy)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,stacked:e.stacked??!1,aggregated:e.aggregated??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"bar",labelRange:e.auxiliaryRange||void 0,axesDesign:e.axesDesign,showValues:e.showValues,horizontal:e.horizontal,zoomable:e.zoomable,humanize:e.humanize}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}duplicateInDuplicatedSheet(e){const t=oy(this.sheetId,e,this.dataSets),o=sy(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new Sx(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new Sx(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"bar",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,stacked:this.stacked,aggregated:this.aggregated,axesDesign:this.axesDesign,horizontal:this.horizontal,showValues:this.showValues,zoomable:this.horizontal?void 0:this.zoomable,humanize:this.humanize}}getDefinitionForExcel(){const{dataSets:e,labelRange:t}=this.getCommonDataSetAttributesForExcel(this.labelRange,this.dataSets,py(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle)),o=this.getDefinition();return{...o,backgroundColor:OI(this.background||k),fontColor:OI(hy(this.background)),dataSets:e,labelRange:t,verticalAxis:my(o)}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=ty(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new Sx(i,this.sheetId,this.getters)}}function Cx(e,t){const o=e.getDefinition(),s=ow(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"bar",data:{labels:s.labels,datasets:Ty(o,s)},options:{...jI,indexAxis:e.horizontal?"y":"x",layout:Rw(0,s),scales:Vw(o,s),plugins:{title:ox(o,t),legend:Aw(o),tooltip:rx(o,s),chartShowValuesPlugin:Jw(o,s)}}},background:e.background||k}}const yx=[JC,QC],Ix=["x",...yx];class wx extends Lh{mutators=["resetAxisLimits","updateAxisLimits","updateTrendLineConfiguration","clearAxisLimits"];originalAxisLimits={};currentAxesLimits={};idConversion={};handle(e){switch(e.type){case"DELETE_FIGURE":if(e.figureId&&this.idConversion[e.figureId])for(const t of this.idConversion[e.figureId])delete this.originalAxisLimits[t],delete this.currentAxesLimits[t];break;case"UPDATE_CHART":const t=`${e.definition.type}-${e.figureId}`;this.idConversion[e.figureId]||(this.idConversion[e.figureId]=new Set),this.idConversion[e.figureId].add(t),"zoomable"in e.definition&&e.definition.zoomable||this.clearAxisLimits(t)}}clearAxisLimits(e){return delete this.originalAxisLimits[e],delete this.currentAxesLimits[e],"noStateChange"}resetAxisLimits(e,t){for(const o of Ix)t?.[o]?(this.originalAxisLimits[e]?.[o]||(this.originalAxisLimits[e]={...this.originalAxisLimits[e],[o]:{}}),this.originalAxisLimits[e][o].min=t[o].min,this.originalAxisLimits[e][o].max=t[o].max):this.originalAxisLimits[e]?.[o]&&delete this.originalAxisLimits[e][o];return"noStateChange"}updateAxisLimits(e,t){if(void 0===t)return delete this.currentAxesLimits[e],"noStateChange";let{min:o,max:s}=t;return o>s&&([o,s]=[s,o]),this.currentAxesLimits[e]={x:{min:o,max:s}},"noStateChange"}updateTrendLineConfiguration(e){if(!this.originalAxisLimits[e])return"noStateChange";const t=this.originalAxisLimits[e].x;if(void 0===t)return"noStateChange";for(const o of yx){if(!this.originalAxisLimits[e][o])continue;if(this.currentAxesLimits[e]?.[o]||(this.currentAxesLimits[e]={...this.currentAxesLimits[e],[o]:{}}),void 0===this.currentAxesLimits[e]?.x)return"noStateChange";const s=t.max-t.min,i=this.originalAxisLimits[e][o],n=(i.max-i.min)/s,r=i.min-t.min*n,a=this.currentAxesLimits[e].x.min,l=this.currentAxesLimits[e].x.max;this.currentAxesLimits[e][o].min=a*n+r,this.currentAxesLimits[e][o].max=l*n+r}return"noStateChange"}}const xx={id:"zoomWindowPlugin",afterDatasetsDraw:function(e,t,o){if(!o.getLowerBound||!o.getUpperBound)return;const{ctx:s,chartArea:{left:i,right:n,top:r,bottom:a}}=e;let l=o.getLowerBound()??i,c=o.getUpperBound()??n;l>c&&([l,c]=[c,l]),l=Math.max(i,l),c=Math.min(n,c),l===i&&(l-=1),c===n&&(c+=1),s.save(),s.fillStyle="rgba(255,255,255,0.5)",s.beginPath(),s.rect(i,a,l-i,r-a),s.rect(c,a,n-c,r-a),s.fill(),s.beginPath(),s.strokeStyle="#bbb",s.rect(l,a,c-l,r-a),s.stroke(),s.lineWidth=2,s.beginPath(),s.moveTo(l-3,(r+a)/2-7),s.lineTo(l-3,(r+a)/2+7),s.stroke(),s.beginPath(),s.moveTo(c+3,(r+a)/2-7),s.lineTo(c+3,(r+a)/2+7),s.stroke(),s.restore()}};Bh`
10
10
  .o-spreadsheet {
11
11
  .o-master-chart-container {
12
12
  height: ${60}px;
13
13
  }
14
14
  }
15
- `,Zh.add("zoomWindowPlugin",{register:e=>e.register(xx),unregister:e=>e.unregister(xx)});class Ex extends Jy{static template="o-spreadsheet-ZoomableChartJsComponent";store;masterChartCanvas=t.useRef("masterChartCanvas");masterChart;mode;hasLinearScale;isBarChart;chartId="";datasetBoundaries={xMin:0,xMax:0};removeEventListeners=()=>{};setup(){this.store=Dh(wx),super.setup()}unmount(){super.unmount(),this.masterChart?.destroy(),this.removeEventListeners()}get containerStyle(){return`\n height:${this.sliceable?"calc(100% - 60px)":"100%"};\n `}get sliceable(){if(this.props.isFullScreen)return!0;const e=this.env.model.getters.getChartDefinition(this.props.chartId);return("zoomable"in e&&e?.zoomable)??!1}get axisOffset(){return!this.hasLinearScale&&this.isBarChart?.5:0}getMasterChartConfiguration(e){const t=e;return{...t,options:{...t.options,plugins:{...t.options.plugins,zoomWindowPlugin:{getLowerBound:()=>this.lowerBound,getUpperBound:()=>this.upperBound}}}}}getDetailChartConfiguration(e){if(!this.sliceable)return e;const t=this.store.currentAxesLimits[this.chartId]?.x,o={...e.options.scales?.x};return void 0!==t?.min&&(o.min=this.hasLinearScale?t.min:Math.ceil(t.min)-this.axisOffset),void 0!==t?.max&&(o.max=this.hasLinearScale?t.max:Math.floor(t.max)-this.axisOffset),{...e,options:{...e.options,scales:{...e.options.scales,x:o},layout:{...e.options.layout,padding:{...e.options.layout?.padding,bottom:5}}}}}getAxisLimitsFromDataset(e){const t=e.data.datasets.map((e=>e.data)).flat().map(((e,t)=>"object"==typeof e&&null!==e?e.x:t));return{xMin:Math.min(...t),xMax:Math.max(...t)}}createChart(e){const t=e.chartJsConfig;if(this.isBarChart="bar"===t.type,this.chartId=`${t.type}-${this.props.chartId}`,this.datasetBoundaries=this.getAxisLimitsFromDataset(t),this.sliceable){const o=this.getDetailChartConfiguration(t);e.chartJsConfig=o}if(super.createChart(e),this.hasLinearScale="linear"===this.chart?.scales?.x.type,!this.sliceable||!("masterChartConfig"in e))return;this.masterChart?.destroy();const o=this.masterChartCanvas.el.getContext("2d");this.masterChart=new window.Chart(o,this.getMasterChartConfiguration(e.masterChartConfig)),this.resetAxesLimits(),this.chart?.options&&(this.chart.options.animation=!1)}updateChartJs(e){const t=e.chartJsConfig,o=this.getAxisLimitsFromDataset(t);if(this.datasetBoundaries.xMin===o.xMin&&this.datasetBoundaries.xMax===o.xMax||(this.store.clearAxisLimits(this.chartId),this.datasetBoundaries=o),this.isBarChart="bar"===t?.type,this.chartId=`${t.type}-${this.props.chartId}`,this.sliceable){const o=this.getDetailChartConfiguration(t);e.chartJsConfig=o}if(super.updateChartJs(e),this.hasLinearScale="linear"===this.chart?.scales?.x.type,this.sliceable&&"masterChartConfig"in e){const t=this.getMasterChartConfiguration(e.masterChartConfig);if(this.masterChart)this.masterChart.data=t.data,this.masterChart.config.options=t.options,this.masterChart.update();else{const e=this.masterChartCanvas.el.getContext("2d");this.masterChart=new window.Chart(e,t)}}else this.masterChart=void 0;this.resetAxesLimits(),this.chart?.options&&(this.chart.options.animation=!1)}resetAxesLimits(){if(!this.chart)return;const e=this.store.originalAxisLimits[this.chartId];if(void 0===e?.x?.min&&void 0===e?.x?.max){let e=this.masterChart?this.masterChart.scales:this.chart.scales;return!this.hasLinearScale&&e?.x&&(e={...e,x:{min:Math.ceil(e.x.min)-this.axisOffset,max:Math.floor(e.x.max)+this.axisOffset}}),void this.store.resetAxisLimits(this.chartId,e)}this.updateTrendingLineAxes(),this.chart.update(),this.masterChart&&this.masterChart.update()}updateTrendingLineAxes(){this.store.updateTrendLineConfiguration(this.chartId);const e=this.store.currentAxesLimits[this.chartId];for(const t of[JC,QC])this.chart?.config.options?.scales?.[t]&&e?.[t]&&(this.chart.config.options.scales[t].min=e[t].min,this.chart.config.options.scales[t].max=e[t].max)}get upperBound(){return this.computePosition(this.store.currentAxesLimits[this.chartId]?.x?.max)}get lowerBound(){return this.computePosition(this.store.currentAxesLimits[this.chartId]?.x?.min)}computePosition(e){if(void 0===e||!this.masterChart?.scales?.x)return;const t=this.masterChart.scales.x;if(this.hasLinearScale)return t.getPixelForValue(e);if(!this.masterChart.chartArea)return;const{left:o,right:s}=this.masterChart.chartArea,{min:i,max:n}=t,r=this.axisOffset;return o+(s-o)*(r+e-i)/(2*r+n-i)}computeCoordinate(e){if(!this.masterChart)return;const t=this.masterChart.scales.x;if(this.hasLinearScale){const o=t.getValueForPixel(e);if(void 0===o)return;return Math.round(100*o)/100}const{left:o,right:s}=this.masterChart.chartArea,i=this.axisOffset;return t.min-i+(t.max+2*i-t.min)*(e-o)/(s-o)}updateAxisLimits(e,t){this.hasLinearScale?(this.chart.config.options.scales.x.min=e,this.chart.config.options.scales.x.max=t):(this.chart.config.options.scales.x.min=Math.ceil(e),this.chart.config.options.scales.x.max=Math.floor(t)),this.store.updateAxisLimits(this.chartId,{min:e,max:t}),this.updateTrendingLineAxes(),this.masterChart?.update(),this.chart?.update()}onPointerDownInMasterChart(e){this.removeEventListeners();const t=e.offsetX;if(!this.masterChart?.chartArea||!this.chart?.scales?.x)return;const{left:o,right:s,top:i,bottom:n}=this.masterChart.chartArea,r=this.upperBound??s,a=this.lowerBound??o;if(t<o-5||t>s+5||e.offsetY<i||e.offsetY>n)return;let l,c,h;e.preventDefault(),e.stopPropagation();const d=e.clientX-(this.masterChartCanvas.el?.getBoundingClientRect().left??0);if((a!==o||r!==s)&&t>a+5&&t<r-5){l=e.offsetX-a,this.mode="moveInMaster";const t=this.store.currentAxesLimits[this.chartId]?.x;c=(t?.max??this.chart.scales.x.max)-(t?.min??this.chart.scales.x.min)}else this.mode="selectInMaster",l=Math.abs(t-a)<5?r:Math.abs(t-r)<5?a:St(t,o,s),h=this.computeCoordinate(l);const u=this.store.originalAxisLimits[this.chartId].x.min,g=this.store.originalAxisLimits[this.chartId].x.max,p=e=>{let t,o;const{left:s,right:i}=this.masterChart.chartArea;if("moveInMaster"===this.mode)t=this.computeCoordinate(e-l),t<u?t=u:t>g-c&&(t=g-c),o=t+c;else if("selectInMaster"===this.mode){const n=St(e,s,i);if(Math.abs(l-n)>5){const e=this.computeCoordinate(n);if(void 0===h||void 0===e)return{};t=Math.min(h,e),o=Math.max(h,e)}}return{min:t,max:o}},m=e=>{const t=e.clientX-(this.masterChartCanvas.el?.getBoundingClientRect().left??0);if(Math.abs(t-d)<5)return;const{min:o,max:s}=p(t);void 0!==o&&void 0!==s&&this.updateAxisLimits(o,s)},f=e=>{this.removeEventListeners();const t=e.clientX-(this.masterChartCanvas.el?.getBoundingClientRect().left??0);if(Math.abs(t-d)>5){let{min:e,max:o}=p(t);void 0!==e&&void 0!==o&&(this.hasLinearScale||("moveInMaster"===this.mode&&c&&!this.isBarChart?(e=Math.round(e)-this.axisOffset,o=e+c):(e=Math.ceil(e)-this.axisOffset,o=Math.floor(o)+this.axisOffset)),this.updateAxisLimits(e,o))}this.mode=void 0};this.removeEventListeners=()=>{window.removeEventListener("pointermove",m,!0),window.removeEventListener("pointerup",f,!0)},window.addEventListener("pointermove",m,!0),window.addEventListener("pointerup",f,!0)}onPointerMoveInMasterChart(e){const{offsetX:t,offsetY:o}=e;if(void 0===this.mode){const s=e.target;if(!this.masterChart?.chartArea)return void(s.style.cursor="default");const{left:i,right:n,top:r,bottom:a}=this.masterChart.chartArea,l=this.lowerBound??i,c=this.upperBound??n;o<r||o>a?s.style.cursor="default":Math.abs(l-t)<5||Math.abs(c-t)<5?s.style.cursor="ew-resize":s.style.cursor=l<t&&t<c&&(l!==i||c!==n)?"grab":"crosshair"}}onMouseLeaveMasterChart(e){const t=e.target;t&&(t.style.cursor="default")}onDoubleClickInMasterChart(e){this.mode=void 0;const t=e.offsetX;if(!this.masterChart?.chartArea||!this.chart?.scales.x)return;const{left:o,right:s,top:i,bottom:n}=this.masterChart.chartArea;let r=this.upperBound??s,a=this.lowerBound??o;if(r<a&&([r,a]=[a,r]),t<o-5||t>s+5||e.offsetY<i||e.offsetY>n)return;e.preventDefault(),e.stopPropagation();let{min:l,max:c}=this.store.currentAxesLimits[this.chartId]?.x??this.chart.scales.x;const h=this.store.originalAxisLimits[this.chartId].x;if(!h)return;let d=h.min,u=h.max;if(this.hasLinearScale&&(d=Math.ceil(d)-this.axisOffset,u=Math.floor(u)+this.axisOffset),Math.abs(t-a)<5)l=d;else if(Math.abs(t-r)<5)c=u;else{if(!(a<t&&t<r))return;l=d,c=u}this.updateAxisLimits(l,c)}}const Rx=new n;Rx.add("animatedBackgroundColorChange",{id:"animatedBackgroundColorChange",easingFn:"easeOutCubic",hasAnimation:(e,t)=>e?.style?.fillColor!==t?.style?.fillColor,updateAnimation:function(e,t,o,s){const i=ii([{value:0,color:o.style.fillColor||"#ffffff"},{value:1,color:s.style.fillColor||"#ffffff"}]);t.style.fillColor=i(Tx[this.easingFn](e))}}),Rx.add("animatedTextColorChange",{id:"animatedTextColorChange",easingFn:"easeOutCubic",hasAnimation:(e,t)=>e?.style?.textColor!==t?.style?.textColor,updateAnimation:function(e,t,o,s){const i=ii([{value:0,color:o.style.textColor||"#000000"},{value:1,color:s.style.textColor||"#000000"}]);t.style.textColor=i(Tx[this.easingFn](e))}}),Rx.add("animatedDataBar",{id:"animatedDataBar",easingFn:"easeOutCubic",hasAnimation:(e,t)=>e?.dataBarFill?.percentage!==t?.dataBarFill?.percentage,updateAnimation:function(e,t,o,s){const i=o?.dataBarFill?.percentage||0,n=i+((s?.dataBarFill?.percentage||0)-i)*Tx[this.easingFn](e);t.dataBarFill={color:s.dataBarFill?.color||o.dataBarFill?.color||"#ffffff",percentage:n}}}),Rx.add("textFadeIn",{id:"textFadeIn",easingFn:"easeInCubic",hasAnimation:(e,t)=>{const o=e?.content?.textLines?.join("\n"),s=t?.content?.textLines?.join("\n");return Boolean(!o&&s)},updateAnimation:function(e,t,o,s){t.textOpacity=Tx[this.easingFn](e)}}),Rx.add("textFadeOut",{id:"textFadeOut",easingFn:"easeOutCubic",hasAnimation:(e,t)=>{const o=e?.content?.textLines?.join("\n"),s=t?.content?.textLines?.join("\n");return Boolean(o&&!s)},updateAnimation:function(e,t,o,s){const i=1-Tx[this.easingFn](e),n={...o.style};delete n.fillColor,t.textOpacity=i,t.content=o.content,t.clipRect=o.clipRect,Object.assign(t.style,n)}}),Rx.add("iconFadeIn",{id:"iconFadeIn",easingFn:"easeInCubic",hasAnimation:(e,t)=>Boolean(!e?.icons?.left&&t?.icons?.left||!e?.icons?.right&&t?.icons?.right||!e?.icons?.center&&t?.icons?.center),updateAnimation:function(e,t,o,s){const i=Tx[this.easingFn](e);t.icons.left&&s.icons.left&&!o.icons.left&&(t.icons.left.opacity=i),t.icons.right&&s.icons.right&&!o.icons.right&&(t.icons.right.opacity=i),t.icons.center&&s.icons.center&&!o.icons.center&&(t.icons.center.opacity=i)}}),Rx.add("iconFadeOut",{id:"iconFadeOut",easingFn:"easeOutCubic",hasAnimation:(e,t)=>Boolean(e?.icons?.left&&!t?.icons?.left||e?.icons?.right&&!t?.icons?.right||e?.icons?.center&&!t?.icons?.center),updateAnimation:function(e,t,o,s){const i=1-Tx[this.easingFn](e);t.icons||(t.icons={}),o.icons.left&&!s.icons.left&&(t.icons.left={...o.icons.left,opacity:i}),o.icons.right&&!s.icons.right&&(t.icons.right={...o.icons.right,opacity:i}),o.icons.center&&!s.icons.center&&(t.icons.center={...o.icons.center,opacity:i})}}),Rx.add("textChange",{id:"textChange",easingFn:"easeOutCubic",hasAnimation:(e,t)=>{const o=e?.content?.textLines?.join("\n"),s=t?.content?.textLines?.join("\n");return Boolean(o&&s&&(o!==s||_x(t,e)))},updateAnimation:function(e,t,o,s){const i=Tx[this.easingFn](e),n=s.y+(i-1)*s.height,r=s.y+i*s.height,a=_x(s,o),l={id:s.id+"-text-slide-in",x:s.x,y:n,width:s.width,height:s.height,style:{...s.style},skipCellGridLines:!0,content:s.content?{...s.content}:void 0,clipRect:s.clipRect||{...s,x:Math.max(0,s.x-(s.content?.width||0)),width:s.width+2*(s.content?.width||0)},icons:a?Dx(s.icons,s):Ax(s.icons)},c={id:o.id+"-text-slide-out",x:s.x,y:r,width:s.width,height:s.height,style:{...o.style},skipCellGridLines:!0,content:o.content?{...o.content}:void 0,clipRect:o.clipRect||{...s,x:Math.max(0,s.x-(o.content?.width||0)),width:s.width+2*(o.content?.width||0)},icons:a?Dx(o.icons,s):Ax(o.icons)};if(s.content&&o.content&&l.content&&c.content){const e=s.content.y+(i-1)*s.height,t=s.content.y+i*s.height;l.content.y=e,c.content.y=t}return c.style.fillColor=l.style.fillColor=void 0,t.content=void 0,t.icons=a?{}:t.icons,{newBoxes:[l,c]}}}),Rx.add("borderFadeIn",{id:"borderFadeIn",easingFn:"easeInCubic",hasAnimation:(e,t)=>Boolean(!e?.border?.bottom&&t?.border?.bottom||!e?.border?.top&&t?.border?.top||!e?.border?.left&&t?.border?.left||!e?.border?.right&&t?.border?.right),updateAnimation:function(e,t,o,s){const i=Tx[this.easingFn](e);t.border?.top&&s.border?.top&&!o.border?.top&&(t.border.top.opacity=i),t.border?.bottom&&s.border?.bottom&&!o.border?.bottom&&(t.border.bottom.opacity=i),t.border?.left&&s.border?.left&&!o.border?.left&&(t.border.left.opacity=i),t.border?.right&&s.border?.right&&!o.border?.right&&(t.border.right.opacity=i)}}),Rx.add("borderFadeOut",{id:"borderFadeOut",easingFn:"easeOutCubic",hasAnimation:(e,t)=>Boolean(e?.border?.bottom&&!t?.border?.bottom||e?.border?.top&&!t?.border?.top||e?.border?.left&&!t?.border?.left||e?.border?.right&&!t?.border?.right),updateAnimation:function(e,t,o,s){const i=1-Tx[this.easingFn](e);t.border||(t.border={}),o.border?.top&&!s.border?.top&&(t.border.top={...o.border.top,opacity:i}),o.border?.bottom&&!s.border?.bottom&&(t.border.bottom={...o.border.bottom,opacity:i}),o.border?.left&&!s.border?.left&&(t.border.left={...o.border.left,opacity:i}),o.border?.right&&!s.border?.right&&(t.border.right={...o.border.right,opacity:i})}}),Rx.add("borderColorChange",{id:"borderColorChange",easingFn:"easeOutCubic",hasAnimation:(e,t)=>{const o=e?.border,s=t?.border;return!(!o||!s)&&Boolean(o.bottom?.color!==s.bottom?.color||o.top?.color!==s.top?.color||o.left?.color!==s.left?.color||o.right?.color!==s.right?.color)},updateAnimation:function(e,t,o,s){const i=i=>{const n=o?.border?.[i],r=s?.border?.[i],a=t.border?.[i];if(n&&r&&a){const t=ii([{value:0,color:n.color||"#000000"},{value:1,color:r.color||"#000000"}]);a.color=t(Tx[this.easingFn](e))}};i("top"),i("bottom"),i("left"),i("right")}}),Rx.add("iconChange",{id:"iconChange",easingFn:"easeOutCubic",hasAnimation:(e,t)=>!_x(t,e)&&Boolean(e?.icons?.center?.svg?.name!==t?.icons?.center?.svg?.name||e?.icons?.left?.svg?.name!==t?.icons?.left?.svg?.name||e?.icons?.right?.svg?.name!==t?.icons?.right?.svg?.name),updateAnimation:function(e,t,o,s){const i=Tx[this.easingFn](e),n=s.y+(i-1)*s.height,r=s.y+i*s.height,a=[],l=e=>{const i=o.icons?.[e],l=s.icons?.[e],c={id:`${s.id}-icon-${e}-slide-in`,style:{verticalAlign:s.style.verticalAlign},x:s.x,y:n,width:s.width,height:s.height,skipCellGridLines:!0,icons:{[e]:{...l,clipRect:s}}},h={id:`${s.id}-icon-${e}-slide-out`,style:{verticalAlign:o.style.verticalAlign},x:s.x,y:r,width:s.width,height:s.height,skipCellGridLines:!0,icons:{[e]:{...i,clipRect:s}}};t.icons[e]=Ax(s.icons)[e],a.push(c,h)};return l("left"),l("right"),l("center"),{newBoxes:a}}});const Tx={linear:e=>e,easeInCubic:e=>e*e*e,easeOutCubic:e=>(e-=1)*e*e+1,easeInOutCubic:e=>(e/=.5)<1?.5*e*e*e:.5*((e-=2)*e*e+2),easeOutQuart:e=>-((e-=1)*e*e*e-1)};function Ax(e){return{left:e.left?{...e.left,svg:void 0}:void 0,right:e.right?{...e.right,svg:void 0}:void 0,center:e.center?{...e.center,svg:void 0}:void 0}}function Dx(e,t){return{left:e.left?{...e.left,clipRect:t}:void 0,right:e.right?{...e.right,clipRect:t}:void 0,center:e.center?{...e.center,clipRect:t}:void 0}}function _x(e,t){const o=(e,t)=>t&&e?!!(e.horizontalAlign!==t.horizontalAlign||e.size!==t.size||e.margin!==t.margin||e.svg&&!t.svg||!e.svg&&t.svg):!!(e&&!t||!e&&t);return o(e?.icons.left,t?.icons.left)||o(e?.icons.right,t?.icons.right)||o(e?.icons.center,t?.icons.center)}class Fx extends t.Component{static template="o-spreadsheet-GaugeChartComponent";static props={chartId:String,isFullScreen:{type:Boolean,optional:!0}};canvas=t.useRef("chartContainer");animationStore;get runtime(){return this.env.model.getters.getChartRuntime(this.props.chartId)}setup(){this.env.model.getters.isDashboard()&&(this.animationStore=Dh(Yh));let e,o=null;t.useEffect((()=>(this.env.isDashboard()&&void 0===e&&"gauge"!==this.animationStore?.animationPlayed[this.animationChartId]||this.env.isDashboard()&&void 0!==e&&!zt(this.runtime,e)?(o=this.drawGaugeWithAnimation(),this.animationStore?.disableAnimationForChart(this.animationChartId,"gauge")):zI(this.canvasEl,this.runtime),e=this.runtime,()=>o?.stop())),(()=>{const e=this.canvasEl.getBoundingClientRect();return[e.width,e.height,this.runtime,this.canvas.el,window.devicePixelRatio]}))}drawGaugeWithAnimation(){zI(this.canvasEl,{...this.runtime,animationValue:0});const e=this.runtime.gaugeValue?.value||0,t=this.runtime.maxValue.value,o=Math.sign(e)*Math.min(Math.abs(e),Math.abs(t));if(0===o)return null;const s=this.runtime.minValue.value,i=new Ox(s,o,1e3,(e=>zI(this.canvasEl,{...this.runtime,animationValue:e})));return i.start(),i}get canvasEl(){return this.canvas.el}get animationChartId(){return this.props.isFullScreen?this.props.chartId+"-fullscreen":this.props.chartId}}class Ox{startValue;endValue;duration;callback;startTime=void 0;animationFrameId=null;constructor(e,t,o,s){this.startValue=e,this.endValue=t,this.duration=o,this.callback=s}start(){this.animationFrameId=requestAnimationFrame(this.animate.bind(this))}stop(){this.animationFrameId&&(cancelAnimationFrame(this.animationFrameId),this.animationFrameId=null)}animate(e){this.startTime||(this.startTime=e);const t=e-this.startTime,o=Math.min(t/this.duration,1),s=this.startValue+(this.endValue-this.startValue)*Tx.easeOutQuart(o);this.callback(s),o<1?this.animationFrameId=requestAnimationFrame(this.animate.bind(this)):this.stop()}}class Px extends Qy{dataSets;labelRange;background;legendPosition;aggregated;dataSetsHaveTitle;dataSetDesign;axesDesign;type="combo";showValues;hideDataMarkers;zoomable;constructor(e,t,o){super(e,t,o),this.dataSets=ny(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Ba(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.showValues=e.showValues,this.hideDataMarkers=e.hideDataMarkers,this.zoomable=e.zoomable}static transformDefinition(e,t,o){return cy(e,t,o)}static validateChartDefinition(e,t){return e.checkValidations(t,uy,gy)}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId),type:this.dataSetDesign?.[t]?.type??(t?"line":"bar")});return{type:"combo",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,aggregated:this.aggregated,axesDesign:this.axesDesign,showValues:this.showValues,hideDataMarkers:this.hideDataMarkers,zoomable:this.zoomable,humanize:this.humanize}}getDefinitionForExcel(){const{dataSets:e,labelRange:t}=this.getCommonDataSetAttributesForExcel(this.labelRange,this.dataSets,py(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle)),o=this.getDefinition();return{...o,backgroundColor:OI(this.background||k),fontColor:OI(hy(this.background)),dataSets:e,labelRange:t,verticalAxis:my(o)}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=ty(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new Px(i,this.sheetId,this.getters)}static getDefinitionFromContextCreation(e){const t=(e.range??[]).map(((e,t)=>({...e,type:t?"line":"bar"})));return{background:e.background,dataSets:t,dataSetsHaveTitle:e.dataSetsHaveTitle??!1,aggregated:e.aggregated,legendPosition:e.legendPosition??"top",title:e.title||{text:""},labelRange:e.auxiliaryRange||void 0,type:"combo",axesDesign:e.axesDesign,showValues:e.showValues,hideDataMarkers:e.hideDataMarkers,zoomable:e.zoomable,humanize:e.humanize}}duplicateInDuplicatedSheet(e){const t=oy(this.sheetId,e,this.dataSets),o=sy(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new Px(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new Px(t,e,this.getters)}}class Mx extends Qy{dataSets;labelRange;background;legendPosition;aggregated;type="funnel";dataSetsHaveTitle;dataSetDesign;axesDesign;horizontal=!0;showValues;funnelColors;cumulative;constructor(e,t,o){super(e,t,o),this.dataSets=ny(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Ba(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.showValues=e.showValues,this.horizontal=!0,this.funnelColors=e.funnelColors,this.cumulative=e.cumulative}static transformDefinition(e,t,o){return cy(e,t,o)}static validateChartDefinition(e,t){return e.checkValidations(t,uy,gy)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,aggregated:e.aggregated??!1,legendPosition:"none",title:e.title||{text:""},type:"funnel",labelRange:e.auxiliaryRange||void 0,showValues:e.showValues,axesDesign:e.axesDesign,funnelColors:e.funnelColors,horizontal:!0,cumulative:e.cumulative,humanize:e.humanize}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}duplicateInDuplicatedSheet(e){const t=oy(this.sheetId,e,this.dataSets),o=sy(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new Mx(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new Mx(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"funnel",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,aggregated:this.aggregated,horizontal:this.horizontal,axesDesign:this.axesDesign,showValues:this.showValues,funnelColors:this.funnelColors,cumulative:this.cumulative,humanize:this.humanize}}getDefinitionForExcel(){}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=ty(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new Mx(i,this.sheetId,this.getters)}}function Nx(e){return e.dataRange&&!Ia.test(e.dataRange)?"InvalidGaugeDataRange":"Success"}function kx(e,t){return t((t=>t.sectionRule?e(t.sectionRule.rangeMin,"rangeMin"):"Success"),(t=>t.sectionRule?e(t.sectionRule.rangeMax,"rangeMax"):"Success"))}function Lx(e,t){if(""===e)switch(t){case"rangeMin":return"EmptyGaugeRangeMin";case"rangeMax":return"EmptyGaugeRangeMax"}return"Success"}function Vx(e,t){if(e.startsWith("="))return"Success";if(isNaN(e))switch(t){case"rangeMin":return"GaugeRangeMinNaN";case"rangeMax":return"GaugeRangeMaxNaN";case"lowerInflectionPointValue":return"GaugeLowerInflectionPointNaN";case"upperInflectionPointValue":return"GaugeUpperInflectionPointNaN"}return"Success"}class Ux extends Qy{dataRange;sectionRule;background;type="gauge";constructor(e,t,o){super(e,t,o),this.dataRange=Ba(this.getters,this.sheetId,e.dataRange),this.sectionRule=e.sectionRule,this.background=e.background}static validateChartDefinition(e,t){return e.checkValidations(t,Nx,e.chainValidations(kx(Lx,e.batchValidations),kx(Vx,e.batchValidations)),e.chainValidations((o=Vx,(0,e.batchValidations)((e=>e.sectionRule?o(e.sectionRule.lowerInflectionPoint.value,"lowerInflectionPointValue"):"Success"),(e=>e.sectionRule?o(e.sectionRule.upperInflectionPoint.value,"upperInflectionPointValue"):"Success")))));var o}static transformDefinition(e,t,o){let s;if(t.dataRange){const i=XC(e,t.dataRange,o);i!==sn.InvalidReference&&(s=i)}return{...t,dataRange:s}}static getDefinitionFromContextCreation(e){return{background:e.background,title:e.title||{text:""},type:"gauge",dataRange:e.range?e.range[0].dataRange:void 0,sectionRule:{colors:{lowerColor:"#EA6175",middleColor:"#FFD86D",upperColor:"#43C5B1"},rangeMin:"0",rangeMax:"100",lowerInflectionPoint:{type:"percentage",value:"15",operator:"<="},upperInflectionPoint:{type:"percentage",value:"40",operator:"<="}},humanize:e.humanize}}duplicateInDuplicatedSheet(e){const t=sy(this.sheetId,e,this.dataRange),o=$x(this.sectionRule,(t=>this.getters.copyFormulaStringForSheet(this.sheetId,e,t,"moveReference"))),s=this.getDefinitionWithSpecificRanges(t,o,e);return new Ux(s,e,this.getters)}copyInSheetId(e){const t=$x(this.sectionRule,(t=>this.getters.copyFormulaStringForSheet(this.sheetId,e,t,"keepSameReference"))),o=this.getDefinitionWithSpecificRanges(this.dataRange,t,e);return new Ux(o,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificRanges(this.dataRange,this.sectionRule)}getDefinitionWithSpecificRanges(e,t,o){return{background:this.background,sectionRule:t,title:this.title,type:"gauge",dataRange:e?this.getters.getRangeString(e,o||this.sheetId):void 0,humanize:this.humanize}}getDefinitionForExcel(){}getContextCreation(){return{...this,range:this.dataRange?[{dataRange:this.getters.getRangeString(this.dataRange,this.sheetId)}]:void 0}}updateRanges(e,t,o){const s=iy(this.dataRange,e),i=$x(this.sectionRule,(s=>YC(this.sheetId,s,{applyChange:e,sheetId:t,sheetName:o}))),n=this.getDefinitionWithSpecificRanges(s,i);return new Ux(n,this.sheetId,this.getters)}}function Hx(e,t){const o=t.getLocale(),s=e.sectionRule.colors;let i,n,a;const l=e.dataRange;if(void 0!==l){const e=t.getEvaluatedCell({sheetId:l.sheetId,col:l.zone.left,row:l.zone.top});e.type===r.number&&(i=e.value,n=e.formattedValue,a=e.format)}let c=Bx(e.sheetId,e.sectionRule.rangeMin,t),h=Bx(e.sheetId,e.sectionRule.rangeMax,t);if(void 0===c||void 0===h)return function(e,t){return{background:t.getStyleOfSingleCellChart(e.background,e.dataRange).background,title:e.title??{text:""},minValue:{value:0,label:""},maxValue:{value:100,label:""},gaugeValue:{value:0,label:sn.GenericError},inflectionValues:[],colors:[]}}(e,t);h<c&&([c,h]=[h,c]);const d=e.sectionRule.lowerInflectionPoint,u=e.sectionRule.upperInflectionPoint,g=zx(e.sheetId,e.sectionRule.lowerInflectionPoint,c,h,t),p=zx(e.sheetId,e.sectionRule.upperInflectionPoint,c,h,t),m=[],f=[];return void 0!==g&&(m.push({value:g,label:Er(g,a,o,e.humanize),operator:d.operator}),f.push(s.lowerColor)),void 0!==p&&p!==g&&(m.push({value:p,label:Er(p,a,o,e.humanize),operator:u.operator}),f.push(s.middleColor)),void 0!==p&&void 0!==g&&g>p&&(m.reverse(),f.reverse()),f.push(s.upperColor),{background:t.getStyleOfSingleCellChart(e.background,l).background,title:{...e.title,text:e.title.text?t.dynamicTranslate(e.title.text):""},minValue:{value:c,label:Er(c,a,o,e.humanize)},maxValue:{value:h,label:Er(h,a,o,e.humanize)},gaugeValue:void 0!==i&&n?{value:i,label:e.humanize?Wr({value:i,format:a},o):n}:void 0,inflectionValues:m,colors:f}}function zx(e,t,o,s,i){const n=Bx(e,t.value,i);if(void 0===n)return;return St("number"===t.type?n:o+(s-o)*n/100,o,s)}function Bx(e,t,o){const s=o.evaluateFormula(e,t);return bc(s)?void 0:Cn(fc(s),o.getLocale())}function $x(e,t){return{...e,rangeMin:t(e.rangeMin),rangeMax:t(e.rangeMax),lowerInflectionPoint:{...e.lowerInflectionPoint,value:t(e.lowerInflectionPoint.value)},upperInflectionPoint:{...e.upperInflectionPoint,value:t(e.upperInflectionPoint.value)}}}class Gx extends Qy{dataSets;labelRange;background;legendPosition;type="geo";dataSetsHaveTitle;dataSetDesign;colorScale;missingValueColor;region;constructor(e,t,o){super(e,t,o),this.dataSets=ny(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Ba(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.colorScale=e.colorScale,this.missingValueColor=e.missingValueColor,this.region=e.region}static transformDefinition(e,t,o){return cy(e,t,o)}static validateChartDefinition(e,t){return e.checkValidations(t,uy,gy)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"geo",labelRange:e.auxiliaryRange||void 0,humanize:e.humanize}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}duplicateInDuplicatedSheet(e){const t=oy(this.sheetId,e,this.dataSets),o=sy(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new Gx(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new Gx(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"geo",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,colorScale:this.colorScale,missingValueColor:this.missingValueColor,region:this.region,humanize:this.humanize}}getDefinitionForExcel(){}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=ty(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new Gx(i,this.sheetId,this.getters)}}class Wx extends Qy{dataSets;labelRange;background;legendPosition;labelsAsText;stacked;aggregated;type="line";dataSetsHaveTitle;cumulative;dataSetDesign;axesDesign;fillArea;showValues;hideDataMarkers;zoomable;constructor(e,t,o){super(e,t,o),this.dataSets=ny(this.getters,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Ba(this.getters,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.labelsAsText=e.labelsAsText,this.stacked=e.stacked,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.cumulative=e.cumulative,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.fillArea=e.fillArea,this.showValues=e.showValues,this.hideDataMarkers=e.hideDataMarkers,this.zoomable=e.zoomable}static validateChartDefinition(e,t){return e.checkValidations(t,uy,gy)}static transformDefinition(e,t,o){return cy(e,t,o)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,labelsAsText:e.labelsAsText??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"line",labelRange:e.auxiliaryRange||void 0,stacked:e.stacked??!1,aggregated:e.aggregated??!1,cumulative:e.cumulative??!1,axesDesign:e.axesDesign,fillArea:e.fillArea,showValues:e.showValues,hideDataMarkers:e.hideDataMarkers,zoomable:e.zoomable,humanize:e.humanize}}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"line",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,labelsAsText:this.labelsAsText,stacked:this.stacked,aggregated:this.aggregated,cumulative:this.cumulative,axesDesign:this.axesDesign,fillArea:this.fillArea,showValues:this.showValues,hideDataMarkers:this.hideDataMarkers,zoomable:this.zoomable,humanize:this.humanize}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=ty(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new Wx(i,this.sheetId,this.getters)}getDefinitionForExcel(){const{dataSets:e,labelRange:t}=this.getCommonDataSetAttributesForExcel(this.labelRange,this.dataSets,py(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle)),o=this.getDefinition();return{...o,backgroundColor:OI(this.background||k),fontColor:OI(hy(this.background)),dataSets:e,labelRange:t,verticalAxis:my(o)}}duplicateInDuplicatedSheet(e){const t=oy(this.sheetId,e,this.dataSets),o=sy(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new Wx(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new Wx(t,e,this.getters)}}function qx(e,t){const o=e.getDefinition(),s=iw(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"line",data:{labels:s.labels,datasets:Dy(o,s)},options:{...jI,layout:Rw(0,s),scales:Uw(o,s),plugins:{title:ox(o,t),legend:Dw(o),tooltip:ax(o,s),chartShowValuesPlugin:Jw(o,s)}}},background:e.background||k}}class Zx extends Qy{dataSets;labelRange;background;legendPosition;type="pie";aggregated;dataSetsHaveTitle;isDoughnut;showValues;pieHolePercentage;constructor(e,t,o){super(e,t,o),this.dataSets=ny(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Ba(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.isDoughnut=e.isDoughnut,this.showValues=e.showValues,this.pieHolePercentage=e.pieHolePercentage}static transformDefinition(e,t,o){return cy(e,t,o)}static validateChartDefinition(e,t){return e.checkValidations(t,uy,gy)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"pie",labelRange:e.auxiliaryRange||void 0,aggregated:e.aggregated??!1,isDoughnut:e.isDoughnut,pieHolePercentage:e.pieHolePercentage,showValues:e.showValues,humanize:e.humanize}}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getContextCreation(){return{...this,range:this.dataSets.map((e=>({dataRange:this.getters.getRangeString(e.dataRange,this.sheetId)}))),auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}getDefinitionWithSpecificDataSets(e,t,o){return{type:"pie",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:e.map((e=>({dataRange:this.getters.getRangeString(e.dataRange,o||this.sheetId)}))),legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,aggregated:this.aggregated,isDoughnut:this.isDoughnut,showValues:this.showValues,pieHolePercentage:this.pieHolePercentage,humanize:this.humanize}}duplicateInDuplicatedSheet(e){const t=oy(this.sheetId,e,this.dataSets),o=sy(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new Zx(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new Zx(t,e,this.getters)}getDefinitionForExcel(){const{dataSets:e,labelRange:t}=this.getCommonDataSetAttributesForExcel(this.labelRange,this.dataSets,py(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle));return{...this.getDefinition(),backgroundColor:OI(this.background||k),fontColor:OI(hy(this.background)),dataSets:e,labelRange:t}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=ty(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new Zx(i,this.sheetId,this.getters)}}function jx(e,t){const o=e.getDefinition(),s=nw(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:e.isDoughnut?"doughnut":"pie",data:{labels:s.labels,datasets:Fy(o,s)},options:{...jI,cutout:e.isDoughnut&&void 0!==o.pieHolePercentage?o.pieHolePercentage+"%":void 0,layout:Rw(0,s),plugins:{title:ox(o,t),legend:_w(o,s),tooltip:lx(o,s),chartShowValuesPlugin:Jw(o,s)}}},background:e.background||k}}class Yx extends Qy{dataSets;labelRange;background;legendPosition;aggregated;type="pyramid";dataSetsHaveTitle;dataSetDesign;axesDesign;horizontal=!0;stacked=!0;showValues;constructor(e,t,o){super(e,t,o),this.dataSets=ny(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Ba(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.showValues=e.showValues}static transformDefinition(e,t,o){return cy(e,t,o)}static validateChartDefinition(e,t){return e.checkValidations(t,uy,gy)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,aggregated:e.aggregated??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"pyramid",labelRange:e.auxiliaryRange||void 0,axesDesign:e.axesDesign,horizontal:!0,stacked:!0,showValues:e.showValues,humanize:e.humanize}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}duplicateInDuplicatedSheet(e){const t=oy(this.sheetId,e,this.dataSets),o=sy(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new Yx(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new Yx(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"pyramid",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,aggregated:this.aggregated,axesDesign:this.axesDesign,horizontal:!0,stacked:!0,showValues:this.showValues,humanize:this.humanize}}getDefinitionForExcel(e){const{dataSets:t,labelRange:o}=this.getCommonDataSetAttributesForExcel(this.labelRange,this.dataSets,py(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle)),s=this.getDefinition(),i=sw(s,this.dataSets,this.labelRange,e),{dataSetsValues:n}=i,r=Math.max(...n.map((e=>Math.max(...e.data.map(Math.abs)))));return{...s,horizontal:!0,backgroundColor:OI(this.background||k),fontColor:OI(hy(this.background)),dataSets:t,labelRange:o,verticalAxis:my(s),maxValue:r}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=ty(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new Yx(i,this.sheetId,this.getters)}}class Xx extends Qy{dataSets;labelRange;background;legendPosition;stacked;aggregated;type="radar";dataSetsHaveTitle;dataSetDesign;fillArea;showValues;hideDataMarkers;constructor(e,t,o){super(e,t,o),this.dataSets=ny(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Ba(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.stacked=e.stacked,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.fillArea=e.fillArea,this.showValues=e.showValues,this.hideDataMarkers=e.hideDataMarkers}static transformDefinition(e,t,o){return cy(e,t,o)}static validateChartDefinition(e,t){return e.checkValidations(t,uy,gy)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,stacked:e.stacked??!1,aggregated:e.aggregated??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"radar",labelRange:e.auxiliaryRange||void 0,fillArea:e.fillArea??!1,showValues:e.showValues??!1,hideDataMarkers:e.hideDataMarkers,humanize:e.humanize}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}duplicateInDuplicatedSheet(e){const t=oy(this.sheetId,e,this.dataSets),o=sy(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new Xx(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new Xx(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"radar",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,stacked:this.stacked,aggregated:this.aggregated,fillArea:this.fillArea,showValues:this.showValues,hideDataMarkers:this.hideDataMarkers,humanize:this.humanize}}getDefinitionForExcel(){const{dataSets:e,labelRange:t}=this.getCommonDataSetAttributesForExcel(this.labelRange,this.dataSets,py(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle));return{...this.getDefinition(),backgroundColor:OI(this.background||k),fontColor:OI(hy(this.background)),dataSets:e,labelRange:t}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=ty(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new Xx(i,this.sheetId,this.getters)}}class Kx extends Qy{dataSets;labelRange;background;legendPosition;labelsAsText;aggregated;type="scatter";dataSetsHaveTitle;dataSetDesign;axesDesign;showValues;zoomable;constructor(e,t,o){super(e,t,o),this.dataSets=ny(this.getters,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Ba(this.getters,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.labelsAsText=e.labelsAsText,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.showValues=e.showValues,this.zoomable=e.zoomable}static validateChartDefinition(e,t){return e.checkValidations(t,uy,gy)}static transformDefinition(e,t,o){return cy(e,t,o)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,labelsAsText:e.labelsAsText??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"scatter",labelRange:e.auxiliaryRange||void 0,aggregated:e.aggregated??!1,axesDesign:e.axesDesign,showValues:e.showValues,zoomable:e.zoomable,humanize:e.humanize}}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"scatter",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,labelsAsText:this.labelsAsText,aggregated:this.aggregated,axesDesign:this.axesDesign,showValues:this.showValues,zoomable:this.zoomable,humanize:this.humanize}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=ty(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new Kx(i,this.sheetId,this.getters)}getDefinitionForExcel(){const e=this.dataSets.map((e=>ay(this.getters,e))).filter((e=>""!==e.range)),t=ly(this.getters,this.labelRange,py(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle)),o=this.getDefinition();return{...o,backgroundColor:OI(this.background||k),fontColor:OI(hy(this.background)),dataSets:e,labelRange:t,verticalAxis:my(o)}}duplicateInDuplicatedSheet(e){const t=oy(this.sheetId,e,this.dataSets),o=sy(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new Kx(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new Kx(t,e,this.getters)}}class Jx extends Qy{dataSets;labelRange;background;legendPosition;type="sunburst";dataSetsHaveTitle;showValues;showLabels;valuesDesign;groupColors;pieHolePercentage;constructor(e,t,o){super(e,t,o),this.dataSets=ny(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Ba(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.showValues=e.showValues,this.showLabels=e.showLabels,this.valuesDesign=e.valuesDesign,this.groupColors=e.groupColors,this.pieHolePercentage=e.pieHolePercentage}static transformDefinition(e,t,o){return cy(e,t,o)}static validateChartDefinition(e,t){return e.checkValidations(t,uy,gy)}static getDefinitionFromContextCreation(e){const t=[];return e.hierarchicalRanges?.length?t.push(...e.hierarchicalRanges):e.auxiliaryRange&&t.push({...e.range?.[0],dataRange:e.auxiliaryRange}),{background:e.background,dataSets:t,dataSetsHaveTitle:e.dataSetsHaveTitle??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"sunburst",labelRange:e.range?.[0]?.dataRange,showValues:e.showValues,showLabels:e.showLabels,valuesDesign:e.valuesDesign,groupColors:e.groupColors,humanize:e.humanize}}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getContextCreation(){const e=this.dataSets.at(-1)?.dataRange;return{...this,range:this.labelRange?[{dataRange:this.getters.getRangeString(this.labelRange,this.sheetId)}]:[],auxiliaryRange:e?this.getters.getRangeString(e,this.sheetId):void 0,hierarchicalRanges:this.dataSets.map((e=>({dataRange:this.getters.getRangeString(e.dataRange,this.sheetId)})))}}getDefinitionWithSpecificDataSets(e,t,o){return{type:"sunburst",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:e.map((e=>({dataRange:this.getters.getRangeString(e.dataRange,o||this.sheetId)}))),legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,showValues:this.showValues,showLabels:this.showLabels,valuesDesign:this.valuesDesign,groupColors:this.groupColors,pieHolePercentage:this.pieHolePercentage,humanize:this.humanize}}duplicateInDuplicatedSheet(e){const t=oy(this.sheetId,e,this.dataSets),o=sy(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new Jx(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new Jx(t,e,this.getters)}getDefinitionForExcel(){}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=ty(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new Jx(i,this.sheetId,this.getters)}}class Qx extends Qy{static defaults={background:k,legendPosition:"top",dataSetsHaveTitle:!1,showHeaders:!0,headersColor:"#000000"};dataSets;labelRange;background;legendPosition;type="treemap";dataSetsHaveTitle;showHeaders;headerDesign;showValues;showLabels;valuesDesign;coloringOptions;constructor(e,t,o){super(e,t,o),this.dataSets=ny(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Ba(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.showHeaders=e.showHeaders,this.headerDesign=e.headerDesign,this.showValues=e.showValues,this.showLabels=e.showLabels,this.valuesDesign=e.valuesDesign,this.coloringOptions=e.coloringOptions}static transformDefinition(e,t,o){return cy(e,t,o)}static validateChartDefinition(e,t){return e.checkValidations(t,uy,gy)}static getDefinitionFromContextCreation(e){const t=[];return e.hierarchicalRanges?.length?t.push(...e.hierarchicalRanges):e.auxiliaryRange&&t.push({...e.range?.[0],dataRange:e.auxiliaryRange}),{background:e.background,dataSets:t,dataSetsHaveTitle:e.dataSetsHaveTitle??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"treemap",labelRange:e.range?.[0]?.dataRange,showValues:e.showValues,showHeaders:e.showHeaders,headerDesign:e.headerDesign,showLabels:e.showLabels,valuesDesign:e.valuesDesign,coloringOptions:e.treemapColoringOptions,humanize:e.humanize}}getContextCreation(){const e=this.dataSets.at(-1)?.dataRange;return{...this,range:this.labelRange?[{dataRange:this.getters.getRangeString(this.labelRange,this.sheetId)}]:[],auxiliaryRange:e?this.getters.getRangeString(e,this.sheetId):void 0,hierarchicalRanges:this.dataSets.map((e=>({dataRange:this.getters.getRangeString(e.dataRange,this.sheetId)})))}}duplicateInDuplicatedSheet(e){const t=oy(this.sheetId,e,this.dataSets),o=sy(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new Qx(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new Qx(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=e.map((e=>({dataRange:this.getters.getRangeString(e.dataRange,o||this.sheetId)})));return{type:"treemap",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,showValues:this.showValues,showHeaders:this.showHeaders,headerDesign:this.headerDesign,showLabels:this.showLabels,valuesDesign:this.valuesDesign,coloringOptions:this.coloringOptions,humanize:this.humanize}}getDefinitionForExcel(){}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=ty(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new Qx(i,this.sheetId,this.getters)}}class eE extends Qy{dataSets;labelRange;background;verticalAxisPosition;legendPosition;aggregated;type="waterfall";dataSetsHaveTitle;showSubTotals;firstValueAsSubtotal;showConnectorLines;positiveValuesColor;negativeValuesColor;subTotalValuesColor;dataSetDesign;axesDesign;showValues;zoomable;constructor(e,t,o){super(e,t,o),this.dataSets=ny(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Ba(o,t,e.labelRange),this.background=e.background,this.verticalAxisPosition=e.verticalAxisPosition,this.legendPosition=e.legendPosition,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.showSubTotals=e.showSubTotals,this.showConnectorLines=e.showConnectorLines,this.positiveValuesColor=e.positiveValuesColor,this.negativeValuesColor=e.negativeValuesColor,this.subTotalValuesColor=e.subTotalValuesColor,this.firstValueAsSubtotal=e.firstValueAsSubtotal,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.showValues=e.showValues,this.zoomable=e.zoomable}static transformDefinition(e,t,o){return cy(e,t,o)}static validateChartDefinition(e,t){return e.checkValidations(t,uy,gy)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range?e.range:[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,aggregated:e.aggregated??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"waterfall",verticalAxisPosition:"left",labelRange:e.auxiliaryRange||void 0,showSubTotals:e.showSubTotals??!1,showConnectorLines:e.showConnectorLines??!0,firstValueAsSubtotal:e.firstValueAsSubtotal??!1,axesDesign:e.axesDesign,showValues:e.showValues,zoomable:e.zoomable??!1,humanize:e.humanize}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}duplicateInDuplicatedSheet(e){const t=oy(this.sheetId,e,this.dataSets),o=sy(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new eE(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new eE(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"waterfall",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,verticalAxisPosition:this.verticalAxisPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,aggregated:this.aggregated,showSubTotals:this.showSubTotals,showConnectorLines:this.showConnectorLines,positiveValuesColor:this.positiveValuesColor,negativeValuesColor:this.negativeValuesColor,subTotalValuesColor:this.subTotalValuesColor,firstValueAsSubtotal:this.firstValueAsSubtotal,axesDesign:this.axesDesign,showValues:this.showValues,zoomable:this.zoomable,humanize:this.humanize}}getDefinitionForExcel(){}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=ty(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new eE(i,this.sheetId,this.getters)}}function tE(e,t){const o=e.getDefinition(),s=ow(o,e.dataSets,e.labelRange,t),{labels:i,datasets:n}=Ay(o,s);return{chartJsConfig:{type:"bar",data:{labels:i,datasets:n},options:{...jI,layout:Rw(0,s),scales:zw(o,s),plugins:{title:ox(o,t),legend:Pw(o),tooltip:cx(o,s),chartShowValuesPlugin:tx(o,s),waterfallLinesPlugin:{showConnectorLines:o.showConnectorLines}}}},background:e.background||k}}const oE=new n;oE.add("bar",{match:e=>"bar"===e,createChart:(e,t,o)=>new Sx(e,t,o),getChartRuntime:Cx,validateChartDefinition:Sx.validateChartDefinition,transformDefinition:Sx.transformDefinition,getChartDefinitionFromContextCreation:Sx.getDefinitionFromContextCreation,sequence:10}),oE.add("combo",{match:e=>"combo"===e,createChart:(e,t,o)=>new Px(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=ow(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"bar",data:{labels:s.labels,datasets:Oy(o,s)},options:{...jI,layout:Rw(0,s),scales:Vw(o,s),plugins:{title:ox(o,t),legend:Ow(o),tooltip:rx(o,s),chartShowValuesPlugin:Jw(o,s)}}},background:e.background||k}},validateChartDefinition:Px.validateChartDefinition,transformDefinition:Px.transformDefinition,getChartDefinitionFromContextCreation:Px.getDefinitionFromContextCreation,sequence:15}),oE.add("line",{match:e=>"line"===e,createChart:(e,t,o)=>new Wx(e,t,o),getChartRuntime:qx,validateChartDefinition:Wx.validateChartDefinition,transformDefinition:Wx.transformDefinition,getChartDefinitionFromContextCreation:Wx.getDefinitionFromContextCreation,sequence:20}),oE.add("pie",{match:e=>"pie"===e,createChart:(e,t,o)=>new Zx(e,t,o),getChartRuntime:jx,validateChartDefinition:Zx.validateChartDefinition,transformDefinition:Zx.transformDefinition,getChartDefinitionFromContextCreation:Zx.getDefinitionFromContextCreation,sequence:30}),oE.add("scorecard",{match:e=>"scorecard"===e,createChart:(e,t,o)=>new rI(e,t,o),getChartRuntime:lI,validateChartDefinition:rI.validateChartDefinition,transformDefinition:rI.transformDefinition,getChartDefinitionFromContextCreation:rI.getDefinitionFromContextCreation,sequence:40}),oE.add("gauge",{match:e=>"gauge"===e,createChart:(e,t,o)=>new Ux(e,t,o),getChartRuntime:Hx,validateChartDefinition:Ux.validateChartDefinition,transformDefinition:Ux.transformDefinition,getChartDefinitionFromContextCreation:Ux.getDefinitionFromContextCreation,sequence:50}),oE.add("scatter",{match:e=>"scatter"===e,createChart:(e,t,o)=>new Kx(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=iw(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"line",data:{labels:s.labels,datasets:_y(o,s)},options:{...jI,layout:Rw(0,s),scales:Hw(o,s),plugins:{title:ox(o,t),legend:Fw(o),tooltip:ax(o,s),chartShowValuesPlugin:Jw(o,s)}}},background:e.background||k}},validateChartDefinition:Kx.validateChartDefinition,transformDefinition:Kx.transformDefinition,getChartDefinitionFromContextCreation:Kx.getDefinitionFromContextCreation,sequence:60}),oE.add("waterfall",{match:e=>"waterfall"===e,createChart:(e,t,o)=>new eE(e,t,o),getChartRuntime:tE,validateChartDefinition:eE.validateChartDefinition,transformDefinition:eE.transformDefinition,getChartDefinitionFromContextCreation:eE.getDefinitionFromContextCreation,sequence:70}),oE.add("pyramid",{match:e=>"pyramid"===e,createChart:(e,t,o)=>new Yx(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=sw(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"bar",data:{labels:s.labels,datasets:Ty(o,s)},options:{...jI,indexAxis:"y",layout:Rw(0,s),scales:Bw(o,s),plugins:{title:ox(o,t),legend:Aw(o),tooltip:hx(o,s),chartShowValuesPlugin:ex(o,s)}}},background:e.background||k}},validateChartDefinition:Yx.validateChartDefinition,transformDefinition:Yx.transformDefinition,getChartDefinitionFromContextCreation:Yx.getDefinitionFromContextCreation,sequence:80,dataSeriesLimit:2}),oE.add("radar",{match:e=>"radar"===e,createChart:(e,t,o)=>new Xx(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=rw(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"radar",data:{labels:s.labels,datasets:Py(o,s)},options:{...jI,layout:Rw(0,s),scales:$w(o,s),plugins:{title:ox(o,t),legend:Mw(o),tooltip:dx(o,s),chartShowValuesPlugin:Jw(o,s)}}},background:e.background||k}},validateChartDefinition:Xx.validateChartDefinition,transformDefinition:Xx.transformDefinition,getChartDefinitionFromContextCreation:Xx.getDefinitionFromContextCreation,sequence:80}),oE.add("geo",{match:e=>"geo"===e,createChart:(e,t,o)=>new Gx(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=aw(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"choropleth",data:{datasets:My(o,s)},options:{...jI,layout:Rw(0,s),scales:Gw(o,s),plugins:{title:ox(o,t),tooltip:ux(o,s),legend:{display:!1}}}},background:e.background||k}},validateChartDefinition:Gx.validateChartDefinition,transformDefinition:Gx.transformDefinition,getChartDefinitionFromContextCreation:Gx.getDefinitionFromContextCreation,sequence:90,dataSeriesLimit:1}),oE.add("funnel",{match:e=>"funnel"===e,createChart:(e,t,o)=>new Mx(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=lw(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"funnel",data:{labels:s.labels,datasets:Ny(o,s)},options:{...jI,indexAxis:"y",layout:Rw(0,s),scales:Ww(0,s),plugins:{title:ox(o,t),legend:{display:!1},tooltip:gx(o,s),chartShowValuesPlugin:Jw(o,s)}}},background:e.background||k}},validateChartDefinition:Mx.validateChartDefinition,transformDefinition:Mx.transformDefinition,getChartDefinitionFromContextCreation:Mx.getDefinitionFromContextCreation,sequence:100,dataSeriesLimit:1}),oE.add("sunburst",{match:e=>"sunburst"===e,createChart:(e,t,o)=>new Jx(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=cw(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"doughnut",data:{datasets:Ly(o,s)},options:{cutout:void 0===e.pieHolePercentage?"25%":`${e.pieHolePercentage}%`,...jI,layout:Rw(0,s),plugins:{title:ox(o,t),legend:Nw(o),tooltip:px(o,s),sunburstLabelsPlugin:Qw(o,s),sunburstHoverPlugin:{enabled:!0}}}},background:e.background||k}},validateChartDefinition:Jx.validateChartDefinition,transformDefinition:Jx.transformDefinition,getChartDefinitionFromContextCreation:Jx.getDefinitionFromContextCreation,sequence:30}),oE.add("treemap",{match:e=>"treemap"===e,createChart:(e,t,o)=>new Qx(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=cw(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"treemap",data:{labels:s.labels,datasets:zy(o,s)},options:{...jI,layout:Rw(0,s),plugins:{title:ox(o,t),legend:{display:!1},tooltip:mx(o,s)}}},background:e.background||k}},validateChartDefinition:Qx.validateChartDefinition,transformDefinition:Qx.transformDefinition,getChartDefinitionFromContextCreation:Qx.getDefinitionFromContextCreation,sequence:100});const sE=new n;sE.add("line",Ex),sE.add("bar",Ex),sE.add("combo",Ex),sE.add("pie",Jy),sE.add("gauge",Fx),sE.add("scatter",Ex),sE.add("scorecard",gI),sE.add("waterfall",Ex),sE.add("pyramid",Jy),sE.add("radar",Jy),sE.add("geo",Jy),sE.add("funnel",Jy),sE.add("sunburst",Jy),sE.add("treemap",Jy);const iE={line:ui("Line"),column:ui("Column"),bar:ui("Bar"),area:ui("Area"),pie:ui("Pie"),hierarchical:ui("Hierarchical"),misc:ui("Miscellaneous")},nE=new n;function rE(e){const t=oE.getAll().sort(((e,t)=>e.sequence-t.sequence));return function(o,s,i){const n=t.find((e=>e.match(s.type)));if(!n)throw new Error(`No builder for this chart: ${s.type}`);return n.createChart(s,i,e)}}function aE(e){const t=oE.getAll().sort(((e,t)=>e.sequence-t.sequence));return function(o){const s=t.find((e=>e.match(o.type)));if(!s)throw new Error("No runtime builder for this chart.");const i=s.getChartRuntime(o,e),n=o.getDefinition();if("chartJsConfig"in i&&/line|combo|bar|scatter|waterfall/.test(n.type)){const e=i.chartJsConfig;i.masterChartConfig=function(e){return{...e,data:{...e.data,datasets:e.data.datasets.filter((e=>!yy(e.xAxisID))).map((e=>({...e,pointRadius:0,showLine:!0})))},options:{...e.options,hover:{mode:null},plugins:{...e.options.plugins,title:{display:!1},legend:{display:!1},tooltip:{enabled:!1},chartShowValuesPlugin:void 0},layout:{padding:{...e.options.layout?.padding,top:5,bottom:10}},scales:{y:{...e.options.scales?.y,display:!1},y1:{...e.options.scales?.y1,display:!1},x:{...e.options.scales?.x,title:void 0,ticks:{...e.options.scales?.x?.ticks,callback:function(t){return Cy(e.options.scales?.x?.ticks?.callback?.call(this,t),5)},padding:0,font:{size:9}}}}}}}(e)}return i}}function lE(e,t){const o=oE.getAll().find((e=>e.match(t.type)));if(!o)throw new Error("Unknown chart type.");return o.validateChartDefinition(e,t)}function cE(e,t,o){const s=oE.getAll().find((e=>e.match(t.type)));if(!s)throw new Error("Unknown chart type.");return s.transformDefinition(e,t,o)}nE.add("line",{matcher:e=>"line"===e.type&&!e.stacked&&!e.fillArea,displayName:ui("Line"),chartType:"line",chartSubtype:"line",subtypeDefinition:{stacked:!1,fillArea:!1},category:"line",preview:"o-spreadsheet-ChartPreview.LINE_CHART"}).add("stacked_line",{matcher:e=>"line"===e.type&&!e.fillArea&&!!e.stacked,displayName:ui("Stacked Line"),chartType:"line",chartSubtype:"stacked_line",subtypeDefinition:{stacked:!0,fillArea:!1},category:"line",preview:"o-spreadsheet-ChartPreview.STACKED_LINE_CHART"}).add("area",{matcher:e=>"line"===e.type&&!e.stacked&&!!e.fillArea,displayName:ui("Area"),chartType:"line",chartSubtype:"area",subtypeDefinition:{stacked:!1,fillArea:!0},category:"area",preview:"o-spreadsheet-ChartPreview.AREA_CHART"}).add("stacked_area",{matcher:e=>"line"===e.type&&e.stacked&&!!e.fillArea,displayName:ui("Stacked Area"),chartType:"line",chartSubtype:"stacked_area",subtypeDefinition:{stacked:!0,fillArea:!0},category:"area",preview:"o-spreadsheet-ChartPreview.STACKED_AREA_CHART"}).add("scatter",{displayName:ui("Scatter"),chartType:"scatter",chartSubtype:"scatter",category:"misc",preview:"o-spreadsheet-ChartPreview.SCATTER_CHART"}).add("column",{matcher:e=>"bar"===e.type&&!e.stacked&&!e.horizontal,displayName:ui("Column"),chartType:"bar",chartSubtype:"column",subtypeDefinition:{stacked:!1,horizontal:!1},category:"column",preview:"o-spreadsheet-ChartPreview.COLUMN_CHART"}).add("stacked_column",{matcher:e=>"bar"===e.type&&e.stacked&&!e.horizontal,displayName:ui("Stacked Column"),chartType:"bar",chartSubtype:"stacked_column",subtypeDefinition:{stacked:!0,horizontal:!1},category:"column",preview:"o-spreadsheet-ChartPreview.STACKED_COLUMN_CHART"}).add("bar",{matcher:e=>"bar"===e.type&&!e.stacked&&!!e.horizontal,displayName:ui("Bar"),chartType:"bar",chartSubtype:"bar",subtypeDefinition:{horizontal:!0,stacked:!1},category:"bar",preview:"o-spreadsheet-ChartPreview.BAR_CHART"}).add("stacked_bar",{matcher:e=>"bar"===e.type&&e.stacked&&!!e.horizontal,displayName:ui("Stacked Bar"),chartType:"bar",chartSubtype:"stacked_bar",subtypeDefinition:{horizontal:!0,stacked:!0},category:"bar",preview:"o-spreadsheet-ChartPreview.STACKED_BAR_CHART"}).add("combo",{displayName:ui("Combo"),chartSubtype:"combo",chartType:"combo",category:"line",preview:"o-spreadsheet-ChartPreview.COMBO_CHART"}).add("pie",{matcher:e=>"pie"===e.type&&!e.isDoughnut,displayName:ui("Pie"),chartSubtype:"pie",chartType:"pie",subtypeDefinition:{isDoughnut:!1},category:"pie",preview:"o-spreadsheet-ChartPreview.PIE_CHART"}).add("doughnut",{matcher:e=>"pie"===e.type&&!!e.isDoughnut,displayName:ui("Doughnut"),chartSubtype:"doughnut",chartType:"pie",subtypeDefinition:{isDoughnut:!0},category:"pie",preview:"o-spreadsheet-ChartPreview.DOUGHNUT_CHART"}).add("gauge",{displayName:ui("Gauge"),chartSubtype:"gauge",chartType:"gauge",category:"misc",preview:"o-spreadsheet-ChartPreview.GAUGE_CHART"}).add("scorecard",{displayName:ui("Scorecard"),chartSubtype:"scorecard",chartType:"scorecard",category:"misc",preview:"o-spreadsheet-ChartPreview.SCORECARD_CHART"}).add("waterfall",{displayName:ui("Waterfall"),chartSubtype:"waterfall",chartType:"waterfall",category:"misc",preview:"o-spreadsheet-ChartPreview.WATERFALL_CHART"}).add("pyramid",{displayName:ui("Population Pyramid"),chartSubtype:"pyramid",chartType:"pyramid",category:"misc",preview:"o-spreadsheet-ChartPreview.POPULATION_PYRAMID_CHART"}).add("radar",{matcher:e=>"radar"===e.type&&!e.fillArea,displayName:ui("Radar"),chartSubtype:"radar",chartType:"radar",subtypeDefinition:{fillArea:!1},category:"misc",preview:"o-spreadsheet-ChartPreview.RADAR_CHART"}).add("filled_radar",{matcher:e=>"radar"===e.type&&!!e.fillArea,displayName:ui("Filled Radar"),chartType:"radar",chartSubtype:"filled_radar",subtypeDefinition:{fillArea:!0},category:"misc",preview:"o-spreadsheet-ChartPreview.FILLED_RADAR_CHART"}).add("geo",{displayName:ui("Geo Chart"),chartSubtype:"geo",chartType:"geo",category:"misc",preview:"o-spreadsheet-ChartPreview.GEO_CHART"}).add("funnel",{displayName:ui("Funnel"),chartSubtype:"funnel",chartType:"funnel",category:"misc",preview:"o-spreadsheet-ChartPreview.FUNNEL_CHART"}).add("sunburst",{matcher:e=>"sunburst"===e.type,displayName:ui("Sunburst"),chartSubtype:"sunburst",chartType:"sunburst",category:"hierarchical",preview:"o-spreadsheet-ChartPreview.SUNBURST_CHART"}).add("treemap",{matcher:e=>"treemap"===e.type,displayName:ui("Tree Map"),chartType:"treemap",chartSubtype:"treemap",category:"hierarchical",preview:"o-spreadsheet-ChartPreview.TREE_MAP_CHART"});var hE=Object.freeze({__proto__:null,AbstractChart:Qy,BarChart:Sx,CHART_AXIS_CHOICES:by,CHART_COMMON_OPTIONS:jI,GaugeChart:Ux,LineChart:Wx,MOVING_AVERAGE_TREND_LINE_XAXIS_ID:QC,PieChart:Zx,SPREADSHEET_TO_EXCEL_TRENDLINE_TYPE_MAPPING:ey,ScorecardChart:rI,TREND_LINE_XAXIS_ID:JC,WaterfallChart:eE,adaptChartRange:iy,chartFactory:rE,chartFontColor:hy,chartMutedFontColor:dy,chartRuntimeFactory:aE,chartToImageFile:XI,chartToImageUrl:YI,checkDataset:uy,checkLabelRange:gy,createBarChartRuntime:Cx,createDataSets:ny,createGaugeChartRuntime:Hx,createLineChartRuntime:qx,createPieChartRuntime:jx,createScorecardChartRuntime:lI,createWaterfallChartRuntime:tE,drawScoreChart:aI,duplicateDataSetsInDuplicatedSheet:oy,duplicateLabelRangeInDuplicatedSheet:sy,formatChartDatasetValue:fy,formatTickValue:vy,getChartPositionAtCenterOfViewport:function(e,t){const{x:o,y:s}=e.getMainViewportCoordinates(),{scrollX:i,scrollY:n}=e.getActiveSheetScrollInfo(),{width:r,height:a}=e.getVisibleRect(e.getActiveMainViewport());return{x:o+i+Math.max(0,(r-t.width)/2),y:s+n+Math.max(0,(a-t.height)/2)}},getDefinedAxis:my,getPieColors:Sy,isTrendLineAxis:yy,shouldRemoveFirstLabel:py,toExcelDataset:ay,toExcelLabelRange:ly,transformChartDefinitionWithDataSetsWithZone:cy,transformDefinition:cE,truncateLabel:Cy,updateChartRangesWithDataSets:ty,validateChartDefinition:lE});function dE(e,t){const{scrollX:o,scrollY:s}=e.getActiveSheetScrollInfo(),i=e.getSheetViewDimension(),n=o+Math.max(0,(i.width-t.width)/2),r=s+Math.max(0,(i.height-t.height)/2);return e.getPositionAnchorOffset({x:n,y:r})}function uE(e,t){const o=pt(t),s=e.getSheetViewDimension(),i=s.width,n=s.height;if(o.width>i){const e=i/o.width;o.width=i,o.height=o.height*e}if(o.height>n){const e=n/o.height;o.height=n,o.width=o.width*e}return o}class gE{xmlString;constructor(e){this.xmlString=e}toString(){return this.xmlString}}const pE=["areaChart","area3DChart","lineChart","line3DChart","stockChart","radarChart","scatterChart","pieChart","pie3DChart","doughnutChart","barChart","bar3DChart","ofPieChart","surfaceChart","surface3DChart","bubbleChart","comboChart","radarChart"];function mE(e,t,o){return{content:(new XMLSerializer).serializeToString(e),path:t,contentType:o}}function fE(e){return String(e).replace(/\&/g,"&amp;").replace(/\</g,"&lt;").replace(/\>/g,"&gt;").replace(/\"/g,"&quot;").replace(/\'/g,"&apos;").replace(/[\x00-\x08\x0B\x0C\x0E-\x1F]/g,"")}function vE(e){return new gE(e.map((([e,t])=>`${e}="${fE(t)}"`)).join(" "))}function bE(e,t="text/xml"){const o=(new DOMParser).parseFromString(e.toString(),t),s=o.querySelector("parsererror");if(s){const t=s.innerHTML,o=parseInt(t.split(":")[0],10),i=e.toString().trim().split("\n"),n=i.slice(Math.max(o-3,0),Math.min(o+2,i.length)).join("\n");throw new Error(`XML string could not be parsed: ${t}\n${n}`)}return o}function SE(e){if(e)return{style:e.style,color:{rgb:e.color}}}function CE(e,t){return IE`
15
+ `,Zh.add("zoomWindowPlugin",{register:e=>e.register(xx),unregister:e=>e.unregister(xx)});class Ex extends Jy{static template="o-spreadsheet-ZoomableChartJsComponent";store;masterChartCanvas=t.useRef("masterChartCanvas");masterChart;mode;hasLinearScale;isBarChart;chartId="";datasetBoundaries={xMin:0,xMax:0};removeEventListeners=()=>{};setup(){this.store=Dh(wx),super.setup()}unmount(){super.unmount(),this.masterChart?.destroy(),this.removeEventListeners()}get containerStyle(){return`\n height:${this.sliceable?"calc(100% - 60px)":"100%"};\n `}get sliceable(){if(this.props.isFullScreen)return!0;const e=this.env.model.getters.getChartDefinition(this.props.chartId);return("zoomable"in e&&e?.zoomable)??!1}get axisOffset(){return!this.hasLinearScale&&this.isBarChart?.5:0}getMasterChartConfiguration(e){const t=e;return{...t,options:{...t.options,plugins:{...t.options.plugins,zoomWindowPlugin:{getLowerBound:()=>this.lowerBound,getUpperBound:()=>this.upperBound}}}}}getDetailChartConfiguration(e){if(!this.sliceable)return e;const t=this.store.currentAxesLimits[this.chartId]?.x,o={...e.options.scales?.x};return void 0!==t?.min&&(o.min=this.hasLinearScale?t.min:Math.ceil(t.min)-this.axisOffset),void 0!==t?.max&&(o.max=this.hasLinearScale?t.max:Math.floor(t.max)-this.axisOffset),{...e,options:{...e.options,scales:{...e.options.scales,x:o},layout:{...e.options.layout,padding:{...e.options.layout?.padding,bottom:5}}}}}getAxisLimitsFromDataset(e){const t=e.data.datasets.map((e=>e.data)).flat().map(((e,t)=>"object"==typeof e&&null!==e?e.x:t));return{xMin:Math.min(...t),xMax:Math.max(...t)}}createChart(e){const t=e.chartJsConfig;if(this.isBarChart="bar"===t.type,this.chartId=`${t.type}-${this.props.chartId}`,this.datasetBoundaries=this.getAxisLimitsFromDataset(t),this.sliceable){const o=this.getDetailChartConfiguration(t);e.chartJsConfig=o}if(super.createChart(e),this.hasLinearScale="linear"===this.chart?.scales?.x.type,!this.sliceable||!("masterChartConfig"in e))return;this.masterChart?.destroy();const o=this.masterChartCanvas.el.getContext("2d");this.masterChart=new window.Chart(o,this.getMasterChartConfiguration(e.masterChartConfig)),this.resetAxesLimits(),this.chart?.options&&(this.chart.options.animation=!1)}updateChartJs(e){const t=e.chartJsConfig,o=this.getAxisLimitsFromDataset(t);if(this.datasetBoundaries.xMin===o.xMin&&this.datasetBoundaries.xMax===o.xMax||(this.store.clearAxisLimits(this.chartId),this.datasetBoundaries=o),this.isBarChart="bar"===t?.type,this.chartId=`${t.type}-${this.props.chartId}`,this.sliceable){const o=this.getDetailChartConfiguration(t);e.chartJsConfig=o}if(super.updateChartJs(e),this.hasLinearScale="linear"===this.chart?.scales?.x.type,this.sliceable&&"masterChartConfig"in e){const t=this.getMasterChartConfiguration(e.masterChartConfig);if(this.masterChart)this.masterChart.data=t.data,this.masterChart.config.options=t.options,this.masterChart.update();else{const e=this.masterChartCanvas.el.getContext("2d");this.masterChart=new window.Chart(e,t)}}else this.masterChart=void 0;this.resetAxesLimits(),this.chart?.options&&(this.chart.options.animation=!1)}resetAxesLimits(){if(!this.chart)return;const e=this.store.originalAxisLimits[this.chartId];if(void 0===e?.x?.min&&void 0===e?.x?.max){let e=this.masterChart?this.masterChart.scales:this.chart.scales;return!this.hasLinearScale&&e?.x&&(e={...e,x:{min:Math.ceil(e.x.min)-this.axisOffset,max:Math.floor(e.x.max)+this.axisOffset}}),void this.store.resetAxisLimits(this.chartId,e)}this.updateTrendingLineAxes(),this.chart.update(),this.masterChart&&this.masterChart.update()}updateTrendingLineAxes(){this.store.updateTrendLineConfiguration(this.chartId);const e=this.store.currentAxesLimits[this.chartId];for(const t of[JC,QC])this.chart?.config.options?.scales?.[t]&&e?.[t]&&(this.chart.config.options.scales[t].min=e[t].min,this.chart.config.options.scales[t].max=e[t].max)}get upperBound(){return this.computePosition(this.store.currentAxesLimits[this.chartId]?.x?.max)}get lowerBound(){return this.computePosition(this.store.currentAxesLimits[this.chartId]?.x?.min)}computePosition(e){if(void 0===e||!this.masterChart?.scales?.x)return;const t=this.masterChart.scales.x;if(this.hasLinearScale)return t.getPixelForValue(e);if(!this.masterChart.chartArea)return;const{left:o,right:s}=this.masterChart.chartArea,{min:i,max:n}=t,r=this.axisOffset;return o+(s-o)*(r+e-i)/(2*r+n-i)}computeCoordinate(e){if(!this.masterChart)return;const t=this.masterChart.scales.x;if(this.hasLinearScale){const o=t.getValueForPixel(e);if(void 0===o)return;return Math.round(100*o)/100}const{left:o,right:s}=this.masterChart.chartArea,i=this.axisOffset;return t.min-i+(t.max+2*i-t.min)*(e-o)/(s-o)}updateAxisLimits(e,t){this.hasLinearScale?(this.chart.config.options.scales.x.min=e,this.chart.config.options.scales.x.max=t):(this.chart.config.options.scales.x.min=Math.ceil(e),this.chart.config.options.scales.x.max=Math.floor(t)),this.store.updateAxisLimits(this.chartId,{min:e,max:t}),this.updateTrendingLineAxes(),this.masterChart?.update(),this.chart?.update()}onPointerDownInMasterChart(e){this.removeEventListeners();const t=e.offsetX;if(!this.masterChart?.chartArea||!this.chart?.scales?.x)return;const{left:o,right:s,top:i,bottom:n}=this.masterChart.chartArea,r=this.upperBound??s,a=this.lowerBound??o;if(t<o-5||t>s+5||e.offsetY<i||e.offsetY>n)return;let l,c,h;e.preventDefault(),e.stopPropagation();const d=e.clientX-(this.masterChartCanvas.el?.getBoundingClientRect().left??0);if((a!==o||r!==s)&&t>a+5&&t<r-5){l=e.offsetX-a,this.mode="moveInMaster";const t=this.store.currentAxesLimits[this.chartId]?.x;c=(t?.max??this.chart.scales.x.max)-(t?.min??this.chart.scales.x.min)}else this.mode="selectInMaster",l=Math.abs(t-a)<5?r:Math.abs(t-r)<5?a:St(t,o,s),h=this.computeCoordinate(l);const u=this.store.originalAxisLimits[this.chartId].x.min,g=this.store.originalAxisLimits[this.chartId].x.max,p=e=>{let t,o;const{left:s,right:i}=this.masterChart.chartArea;if("moveInMaster"===this.mode)t=this.computeCoordinate(e-l),t<u?t=u:t>g-c&&(t=g-c),o=t+c;else if("selectInMaster"===this.mode){const n=St(e,s,i);if(Math.abs(l-n)>5){const e=this.computeCoordinate(n);if(void 0===h||void 0===e)return{};t=Math.min(h,e),o=Math.max(h,e)}}return{min:t,max:o}},m=e=>{const t=e.clientX-(this.masterChartCanvas.el?.getBoundingClientRect().left??0);if(Math.abs(t-d)<5)return;const{min:o,max:s}=p(t);void 0!==o&&void 0!==s&&this.updateAxisLimits(o,s)},f=e=>{this.removeEventListeners();const t=e.clientX-(this.masterChartCanvas.el?.getBoundingClientRect().left??0);if(Math.abs(t-d)>5){let{min:e,max:o}=p(t);void 0!==e&&void 0!==o&&(this.hasLinearScale||("moveInMaster"===this.mode&&c&&!this.isBarChart?(e=Math.round(e)-this.axisOffset,o=e+c):(e=Math.ceil(e)-this.axisOffset,o=Math.floor(o)+this.axisOffset)),this.updateAxisLimits(e,o))}this.mode=void 0};this.removeEventListeners=()=>{window.removeEventListener("pointermove",m,!0),window.removeEventListener("pointerup",f,!0)},window.addEventListener("pointermove",m,!0),window.addEventListener("pointerup",f,!0)}onPointerMoveInMasterChart(e){const{offsetX:t,offsetY:o}=e;if(void 0===this.mode){const s=e.target;if(!this.masterChart?.chartArea)return void(s.style.cursor="default");const{left:i,right:n,top:r,bottom:a}=this.masterChart.chartArea,l=this.lowerBound??i,c=this.upperBound??n;o<r||o>a?s.style.cursor="default":Math.abs(l-t)<5||Math.abs(c-t)<5?s.style.cursor="ew-resize":s.style.cursor=l<t&&t<c&&(l!==i||c!==n)?"grab":"crosshair"}}onMouseLeaveMasterChart(e){const t=e.target;t&&(t.style.cursor="default")}onDoubleClickInMasterChart(e){this.mode=void 0;const t=e.offsetX;if(!this.masterChart?.chartArea||!this.chart?.scales.x)return;const{left:o,right:s,top:i,bottom:n}=this.masterChart.chartArea;let r=this.upperBound??s,a=this.lowerBound??o;if(r<a&&([r,a]=[a,r]),t<o-5||t>s+5||e.offsetY<i||e.offsetY>n)return;e.preventDefault(),e.stopPropagation();let{min:l,max:c}=this.store.currentAxesLimits[this.chartId]?.x??this.chart.scales.x;const h=this.store.originalAxisLimits[this.chartId].x;if(!h)return;let d=h.min,u=h.max;if(this.hasLinearScale&&(d=Math.ceil(d)-this.axisOffset,u=Math.floor(u)+this.axisOffset),Math.abs(t-a)<5)l=d;else if(Math.abs(t-r)<5)c=u;else{if(!(a<t&&t<r))return;l=d,c=u}this.updateAxisLimits(l,c)}}const Rx=new n;Rx.add("animatedBackgroundColorChange",{id:"animatedBackgroundColorChange",easingFn:"easeOutCubic",hasAnimation:(e,t)=>e?.style?.fillColor!==t?.style?.fillColor,updateAnimation:function(e,t,o,s){const i=ii([{value:0,color:o.style.fillColor||"#ffffff"},{value:1,color:s.style.fillColor||"#ffffff"}]);t.style.fillColor=i(Tx[this.easingFn](e))}}),Rx.add("animatedTextColorChange",{id:"animatedTextColorChange",easingFn:"easeOutCubic",hasAnimation:(e,t)=>e?.style?.textColor!==t?.style?.textColor,updateAnimation:function(e,t,o,s){const i=ii([{value:0,color:o.style.textColor||"#000000"},{value:1,color:s.style.textColor||"#000000"}]);t.style.textColor=i(Tx[this.easingFn](e))}}),Rx.add("animatedDataBar",{id:"animatedDataBar",easingFn:"easeOutCubic",hasAnimation:(e,t)=>e?.dataBarFill?.percentage!==t?.dataBarFill?.percentage,updateAnimation:function(e,t,o,s){const i=o?.dataBarFill?.percentage||0,n=i+((s?.dataBarFill?.percentage||0)-i)*Tx[this.easingFn](e);t.dataBarFill={color:s.dataBarFill?.color||o.dataBarFill?.color||"#ffffff",percentage:n}}}),Rx.add("textFadeIn",{id:"textFadeIn",easingFn:"easeInCubic",hasAnimation:(e,t)=>{const o=e?.content?.textLines?.join("\n"),s=t?.content?.textLines?.join("\n");return Boolean(!o&&s)},updateAnimation:function(e,t,o,s){t.textOpacity=Tx[this.easingFn](e)}}),Rx.add("textFadeOut",{id:"textFadeOut",easingFn:"easeOutCubic",hasAnimation:(e,t)=>{const o=e?.content?.textLines?.join("\n"),s=t?.content?.textLines?.join("\n");return Boolean(o&&!s)},updateAnimation:function(e,t,o,s){const i=1-Tx[this.easingFn](e),n={...o.style};delete n.fillColor,t.textOpacity=i,t.content=o.content,t.clipRect=o.clipRect,Object.assign(t.style,n)}}),Rx.add("iconFadeIn",{id:"iconFadeIn",easingFn:"easeInCubic",hasAnimation:(e,t)=>Boolean(!e?.icons?.left&&t?.icons?.left||!e?.icons?.right&&t?.icons?.right||!e?.icons?.center&&t?.icons?.center),updateAnimation:function(e,t,o,s){const i=Tx[this.easingFn](e);t.icons.left&&s.icons.left&&!o.icons.left&&(t.icons.left.opacity=i),t.icons.right&&s.icons.right&&!o.icons.right&&(t.icons.right.opacity=i),t.icons.center&&s.icons.center&&!o.icons.center&&(t.icons.center.opacity=i)}}),Rx.add("iconFadeOut",{id:"iconFadeOut",easingFn:"easeOutCubic",hasAnimation:(e,t)=>Boolean(e?.icons?.left&&!t?.icons?.left||e?.icons?.right&&!t?.icons?.right||e?.icons?.center&&!t?.icons?.center),updateAnimation:function(e,t,o,s){const i=1-Tx[this.easingFn](e);t.icons||(t.icons={}),o.icons.left&&!s.icons.left&&(t.icons.left={...o.icons.left,opacity:i}),o.icons.right&&!s.icons.right&&(t.icons.right={...o.icons.right,opacity:i}),o.icons.center&&!s.icons.center&&(t.icons.center={...o.icons.center,opacity:i})}}),Rx.add("textChange",{id:"textChange",easingFn:"easeOutCubic",hasAnimation:(e,t)=>{const o=e?.content?.textLines?.join("\n"),s=t?.content?.textLines?.join("\n");return Boolean(o&&s&&(o!==s||_x(t,e)))},updateAnimation:function(e,t,o,s){const i=Tx[this.easingFn](e),n=s.y+(i-1)*s.height,r=s.y+i*s.height,a=_x(s,o),l={id:s.id+"-text-slide-in",x:s.x,y:n,width:s.width,height:s.height,style:{...s.style},skipCellGridLines:!0,content:s.content?{...s.content}:void 0,clipRect:s.clipRect||{...s,x:Math.max(0,s.x-(s.content?.width||0)),width:s.width+2*(s.content?.width||0)},icons:a?Dx(s.icons,s):Ax(s.icons)},c={id:o.id+"-text-slide-out",x:s.x,y:r,width:s.width,height:s.height,style:{...o.style},skipCellGridLines:!0,content:o.content?{...o.content}:void 0,clipRect:o.clipRect||{...s,x:Math.max(0,s.x-(o.content?.width||0)),width:s.width+2*(o.content?.width||0)},icons:a?Dx(o.icons,s):Ax(o.icons)};if(s.content&&o.content&&l.content&&c.content){const e=s.content.y+(i-1)*s.height,t=s.content.y+i*s.height;l.content.y=e,c.content.y=t}return c.style.fillColor=l.style.fillColor=void 0,t.content=void 0,t.icons=a?{}:t.icons,{newBoxes:[l,c]}}}),Rx.add("borderFadeIn",{id:"borderFadeIn",easingFn:"easeInCubic",hasAnimation:(e,t)=>Boolean(!e?.border?.bottom&&t?.border?.bottom||!e?.border?.top&&t?.border?.top||!e?.border?.left&&t?.border?.left||!e?.border?.right&&t?.border?.right),updateAnimation:function(e,t,o,s){const i=Tx[this.easingFn](e);t.border?.top&&s.border?.top&&!o.border?.top&&(t.border.top.opacity=i),t.border?.bottom&&s.border?.bottom&&!o.border?.bottom&&(t.border.bottom.opacity=i),t.border?.left&&s.border?.left&&!o.border?.left&&(t.border.left.opacity=i),t.border?.right&&s.border?.right&&!o.border?.right&&(t.border.right.opacity=i)}}),Rx.add("borderFadeOut",{id:"borderFadeOut",easingFn:"easeOutCubic",hasAnimation:(e,t)=>Boolean(e?.border?.bottom&&!t?.border?.bottom||e?.border?.top&&!t?.border?.top||e?.border?.left&&!t?.border?.left||e?.border?.right&&!t?.border?.right),updateAnimation:function(e,t,o,s){const i=1-Tx[this.easingFn](e);t.border||(t.border={}),o.border?.top&&!s.border?.top&&(t.border.top={...o.border.top,opacity:i}),o.border?.bottom&&!s.border?.bottom&&(t.border.bottom={...o.border.bottom,opacity:i}),o.border?.left&&!s.border?.left&&(t.border.left={...o.border.left,opacity:i}),o.border?.right&&!s.border?.right&&(t.border.right={...o.border.right,opacity:i})}}),Rx.add("borderColorChange",{id:"borderColorChange",easingFn:"easeOutCubic",hasAnimation:(e,t)=>{const o=e?.border,s=t?.border;return!(!o||!s)&&Boolean(o.bottom?.color!==s.bottom?.color||o.top?.color!==s.top?.color||o.left?.color!==s.left?.color||o.right?.color!==s.right?.color)},updateAnimation:function(e,t,o,s){const i=i=>{const n=o?.border?.[i],r=s?.border?.[i],a=t.border?.[i];if(n&&r&&a){const t=ii([{value:0,color:n.color||"#000000"},{value:1,color:r.color||"#000000"}]);a.color=t(Tx[this.easingFn](e))}};i("top"),i("bottom"),i("left"),i("right")}}),Rx.add("iconChange",{id:"iconChange",easingFn:"easeOutCubic",hasAnimation:(e,t)=>!_x(t,e)&&Boolean(e?.icons?.center?.svg?.name!==t?.icons?.center?.svg?.name||e?.icons?.left?.svg?.name!==t?.icons?.left?.svg?.name||e?.icons?.right?.svg?.name!==t?.icons?.right?.svg?.name),updateAnimation:function(e,t,o,s){const i=Tx[this.easingFn](e),n=s.y+(i-1)*s.height,r=s.y+i*s.height,a=[],l=e=>{const i=o.icons?.[e],l=s.icons?.[e],c={id:`${s.id}-icon-${e}-slide-in`,style:{verticalAlign:s.style.verticalAlign},x:s.x,y:n,width:s.width,height:s.height,skipCellGridLines:!0,icons:{[e]:{...l,clipRect:s}}},h={id:`${s.id}-icon-${e}-slide-out`,style:{verticalAlign:o.style.verticalAlign},x:s.x,y:r,width:s.width,height:s.height,skipCellGridLines:!0,icons:{[e]:{...i,clipRect:s}}};t.icons[e]=Ax(s.icons)[e],a.push(c,h)};return l("left"),l("right"),l("center"),{newBoxes:a}}});const Tx={linear:e=>e,easeInCubic:e=>e*e*e,easeOutCubic:e=>(e-=1)*e*e+1,easeInOutCubic:e=>(e/=.5)<1?.5*e*e*e:.5*((e-=2)*e*e+2),easeOutQuart:e=>-((e-=1)*e*e*e-1)};function Ax(e){return{left:e.left?{...e.left,svg:void 0}:void 0,right:e.right?{...e.right,svg:void 0}:void 0,center:e.center?{...e.center,svg:void 0}:void 0}}function Dx(e,t){return{left:e.left?{...e.left,clipRect:t}:void 0,right:e.right?{...e.right,clipRect:t}:void 0,center:e.center?{...e.center,clipRect:t}:void 0}}function _x(e,t){const o=(e,t)=>t&&e?!!(e.horizontalAlign!==t.horizontalAlign||e.size!==t.size||e.margin!==t.margin||e.svg&&!t.svg||!e.svg&&t.svg):!!(e&&!t||!e&&t);return o(e?.icons.left,t?.icons.left)||o(e?.icons.right,t?.icons.right)||o(e?.icons.center,t?.icons.center)}class Fx extends t.Component{static template="o-spreadsheet-GaugeChartComponent";static props={chartId:String,isFullScreen:{type:Boolean,optional:!0}};canvas=t.useRef("chartContainer");animationStore;get runtime(){return this.env.model.getters.getChartRuntime(this.props.chartId)}setup(){this.env.model.getters.isDashboard()&&(this.animationStore=Dh(Yh));let e,o=null;t.useEffect((()=>(this.env.isDashboard()&&void 0===e&&"gauge"!==this.animationStore?.animationPlayed[this.animationChartId]||this.env.isDashboard()&&void 0!==e&&!zt(this.runtime,e)?(o=this.drawGaugeWithAnimation(),this.animationStore?.disableAnimationForChart(this.animationChartId,"gauge")):zI(this.canvasEl,this.runtime),e=this.runtime,()=>o?.stop())),(()=>{const e=this.canvasEl.getBoundingClientRect();return[e.width,e.height,this.runtime,this.canvas.el,window.devicePixelRatio]}))}drawGaugeWithAnimation(){zI(this.canvasEl,{...this.runtime,animationValue:0});const e=this.runtime.gaugeValue?.value||0,t=this.runtime.maxValue.value,o=Math.sign(e)*Math.min(Math.abs(e),Math.abs(t));if(0===o)return null;const s=this.runtime.minValue.value,i=new Ox(s,o,1e3,(e=>zI(this.canvasEl,{...this.runtime,animationValue:e})));return i.start(),i}get canvasEl(){return this.canvas.el}get animationChartId(){return this.props.isFullScreen?this.props.chartId+"-fullscreen":this.props.chartId}}class Ox{startValue;endValue;duration;callback;startTime=void 0;animationFrameId=null;constructor(e,t,o,s){this.startValue=e,this.endValue=t,this.duration=o,this.callback=s}start(){this.animationFrameId=requestAnimationFrame(this.animate.bind(this))}stop(){this.animationFrameId&&(cancelAnimationFrame(this.animationFrameId),this.animationFrameId=null)}animate(e){this.startTime||(this.startTime=e);const t=e-this.startTime,o=Math.min(t/this.duration,1),s=this.startValue+(this.endValue-this.startValue)*Tx.easeOutQuart(o);this.callback(s),o<1?this.animationFrameId=requestAnimationFrame(this.animate.bind(this)):this.stop()}}class Px extends Qy{dataSets;labelRange;background;legendPosition;aggregated;dataSetsHaveTitle;dataSetDesign;axesDesign;type="combo";showValues;hideDataMarkers;zoomable;constructor(e,t,o){super(e,t,o),this.dataSets=ny(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Ba(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.showValues=e.showValues,this.hideDataMarkers=e.hideDataMarkers,this.zoomable=e.zoomable}static transformDefinition(e,t,o){return cy(e,t,o)}static validateChartDefinition(e,t){return e.checkValidations(t,uy,gy)}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId),type:this.dataSetDesign?.[t]?.type??(t?"line":"bar")});return{type:"combo",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,aggregated:this.aggregated,axesDesign:this.axesDesign,showValues:this.showValues,hideDataMarkers:this.hideDataMarkers,zoomable:this.zoomable,humanize:this.humanize}}getDefinitionForExcel(){const{dataSets:e,labelRange:t}=this.getCommonDataSetAttributesForExcel(this.labelRange,this.dataSets,py(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle)),o=this.getDefinition();return{...o,backgroundColor:OI(this.background||k),fontColor:OI(hy(this.background)),dataSets:e,labelRange:t,verticalAxis:my(o)}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=ty(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new Px(i,this.sheetId,this.getters)}static getDefinitionFromContextCreation(e){const t=(e.range??[]).map(((e,t)=>({...e,type:t?"line":"bar"})));return{background:e.background,dataSets:t,dataSetsHaveTitle:e.dataSetsHaveTitle??!1,aggregated:e.aggregated,legendPosition:e.legendPosition??"top",title:e.title||{text:""},labelRange:e.auxiliaryRange||void 0,type:"combo",axesDesign:e.axesDesign,showValues:e.showValues,hideDataMarkers:e.hideDataMarkers,zoomable:e.zoomable,humanize:e.humanize}}duplicateInDuplicatedSheet(e){const t=oy(this.sheetId,e,this.dataSets),o=sy(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new Px(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new Px(t,e,this.getters)}}class Mx extends Qy{dataSets;labelRange;background;legendPosition;aggregated;type="funnel";dataSetsHaveTitle;dataSetDesign;axesDesign;horizontal=!0;showValues;funnelColors;cumulative;constructor(e,t,o){super(e,t,o),this.dataSets=ny(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Ba(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.showValues=e.showValues,this.horizontal=!0,this.funnelColors=e.funnelColors,this.cumulative=e.cumulative}static transformDefinition(e,t,o){return cy(e,t,o)}static validateChartDefinition(e,t){return e.checkValidations(t,uy,gy)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,aggregated:e.aggregated??!1,legendPosition:"none",title:e.title||{text:""},type:"funnel",labelRange:e.auxiliaryRange||void 0,showValues:e.showValues,axesDesign:e.axesDesign,funnelColors:e.funnelColors,horizontal:!0,cumulative:e.cumulative,humanize:e.humanize}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}duplicateInDuplicatedSheet(e){const t=oy(this.sheetId,e,this.dataSets),o=sy(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new Mx(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new Mx(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"funnel",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,aggregated:this.aggregated,horizontal:this.horizontal,axesDesign:this.axesDesign,showValues:this.showValues,funnelColors:this.funnelColors,cumulative:this.cumulative,humanize:this.humanize}}getDefinitionForExcel(){}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=ty(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new Mx(i,this.sheetId,this.getters)}}function Nx(e){return e.dataRange&&!Ia.test(e.dataRange)?"InvalidGaugeDataRange":"Success"}function kx(e,t){return t((t=>t.sectionRule?e(t.sectionRule.rangeMin,"rangeMin"):"Success"),(t=>t.sectionRule?e(t.sectionRule.rangeMax,"rangeMax"):"Success"))}function Lx(e,t){if(""===e)switch(t){case"rangeMin":return"EmptyGaugeRangeMin";case"rangeMax":return"EmptyGaugeRangeMax"}return"Success"}function Vx(e,t){if(e.startsWith("="))return"Success";if(isNaN(e))switch(t){case"rangeMin":return"GaugeRangeMinNaN";case"rangeMax":return"GaugeRangeMaxNaN";case"lowerInflectionPointValue":return"GaugeLowerInflectionPointNaN";case"upperInflectionPointValue":return"GaugeUpperInflectionPointNaN"}return"Success"}class Ux extends Qy{dataRange;sectionRule;background;type="gauge";constructor(e,t,o){super(e,t,o),this.dataRange=Ba(this.getters,this.sheetId,e.dataRange),this.sectionRule=e.sectionRule,this.background=e.background}static validateChartDefinition(e,t){return e.checkValidations(t,Nx,e.chainValidations(kx(Lx,e.batchValidations),kx(Vx,e.batchValidations)),e.chainValidations((o=Vx,(0,e.batchValidations)((e=>e.sectionRule?o(e.sectionRule.lowerInflectionPoint.value,"lowerInflectionPointValue"):"Success"),(e=>e.sectionRule?o(e.sectionRule.upperInflectionPoint.value,"upperInflectionPointValue"):"Success")))));var o}static transformDefinition(e,t,o){let s;if(t.dataRange){const i=XC(e,t.dataRange,o);i!==sn.InvalidReference&&(s=i)}return{...t,dataRange:s}}static getDefinitionFromContextCreation(e){return{background:e.background,title:e.title||{text:""},type:"gauge",dataRange:e.range?.[0]?.dataRange,sectionRule:{colors:{lowerColor:"#EA6175",middleColor:"#FFD86D",upperColor:"#43C5B1"},rangeMin:"0",rangeMax:"100",lowerInflectionPoint:{type:"percentage",value:"15",operator:"<="},upperInflectionPoint:{type:"percentage",value:"40",operator:"<="}},humanize:e.humanize}}duplicateInDuplicatedSheet(e){const t=sy(this.sheetId,e,this.dataRange),o=$x(this.sectionRule,(t=>this.getters.copyFormulaStringForSheet(this.sheetId,e,t,"moveReference"))),s=this.getDefinitionWithSpecificRanges(t,o,e);return new Ux(s,e,this.getters)}copyInSheetId(e){const t=$x(this.sectionRule,(t=>this.getters.copyFormulaStringForSheet(this.sheetId,e,t,"keepSameReference"))),o=this.getDefinitionWithSpecificRanges(this.dataRange,t,e);return new Ux(o,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificRanges(this.dataRange,this.sectionRule)}getDefinitionWithSpecificRanges(e,t,o){return{background:this.background,sectionRule:t,title:this.title,type:"gauge",dataRange:e?this.getters.getRangeString(e,o||this.sheetId):void 0,humanize:this.humanize}}getDefinitionForExcel(){}getContextCreation(){return{...this,range:this.dataRange?[{dataRange:this.getters.getRangeString(this.dataRange,this.sheetId)}]:void 0}}updateRanges(e,t,o){const s=iy(this.dataRange,e),i=$x(this.sectionRule,(s=>YC(this.sheetId,s,{applyChange:e,sheetId:t,sheetName:o}))),n=this.getDefinitionWithSpecificRanges(s,i);return new Ux(n,this.sheetId,this.getters)}}function Hx(e,t){const o=t.getLocale(),s=e.sectionRule.colors;let i,n,a;const l=e.dataRange;if(void 0!==l){const e=t.getEvaluatedCell({sheetId:l.sheetId,col:l.zone.left,row:l.zone.top});e.type===r.number&&(i=e.value,n=e.formattedValue,a=e.format)}let c=Bx(e.sheetId,e.sectionRule.rangeMin,t),h=Bx(e.sheetId,e.sectionRule.rangeMax,t);if(void 0===c||void 0===h)return function(e,t){return{background:t.getStyleOfSingleCellChart(e.background,e.dataRange).background,title:e.title??{text:""},minValue:{value:0,label:""},maxValue:{value:100,label:""},gaugeValue:{value:0,label:sn.GenericError},inflectionValues:[],colors:[]}}(e,t);h<c&&([c,h]=[h,c]);const d=e.sectionRule.lowerInflectionPoint,u=e.sectionRule.upperInflectionPoint,g=zx(e.sheetId,e.sectionRule.lowerInflectionPoint,c,h,t),p=zx(e.sheetId,e.sectionRule.upperInflectionPoint,c,h,t),m=[],f=[];return void 0!==g&&(m.push({value:g,label:Er(g,a,o,e.humanize),operator:d.operator}),f.push(s.lowerColor)),void 0!==p&&p!==g&&(m.push({value:p,label:Er(p,a,o,e.humanize),operator:u.operator}),f.push(s.middleColor)),void 0!==p&&void 0!==g&&g>p&&(m.reverse(),f.reverse()),f.push(s.upperColor),{background:t.getStyleOfSingleCellChart(e.background,l).background,title:{...e.title,text:e.title.text?t.dynamicTranslate(e.title.text):""},minValue:{value:c,label:Er(c,a,o,e.humanize)},maxValue:{value:h,label:Er(h,a,o,e.humanize)},gaugeValue:void 0!==i&&n?{value:i,label:e.humanize?Wr({value:i,format:a},o):n}:void 0,inflectionValues:m,colors:f}}function zx(e,t,o,s,i){const n=Bx(e,t.value,i);if(void 0===n)return;return St("number"===t.type?n:o+(s-o)*n/100,o,s)}function Bx(e,t,o){const s=o.evaluateFormula(e,t);return bc(s)?void 0:Cn(fc(s),o.getLocale())}function $x(e,t){return{...e,rangeMin:t(e.rangeMin),rangeMax:t(e.rangeMax),lowerInflectionPoint:{...e.lowerInflectionPoint,value:t(e.lowerInflectionPoint.value)},upperInflectionPoint:{...e.upperInflectionPoint,value:t(e.upperInflectionPoint.value)}}}class Gx extends Qy{dataSets;labelRange;background;legendPosition;type="geo";dataSetsHaveTitle;dataSetDesign;colorScale;missingValueColor;region;constructor(e,t,o){super(e,t,o),this.dataSets=ny(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Ba(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.colorScale=e.colorScale,this.missingValueColor=e.missingValueColor,this.region=e.region}static transformDefinition(e,t,o){return cy(e,t,o)}static validateChartDefinition(e,t){return e.checkValidations(t,uy,gy)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"geo",labelRange:e.auxiliaryRange||void 0,humanize:e.humanize}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}duplicateInDuplicatedSheet(e){const t=oy(this.sheetId,e,this.dataSets),o=sy(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new Gx(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new Gx(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"geo",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,colorScale:this.colorScale,missingValueColor:this.missingValueColor,region:this.region,humanize:this.humanize}}getDefinitionForExcel(){}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=ty(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new Gx(i,this.sheetId,this.getters)}}class Wx extends Qy{dataSets;labelRange;background;legendPosition;labelsAsText;stacked;aggregated;type="line";dataSetsHaveTitle;cumulative;dataSetDesign;axesDesign;fillArea;showValues;hideDataMarkers;zoomable;constructor(e,t,o){super(e,t,o),this.dataSets=ny(this.getters,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Ba(this.getters,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.labelsAsText=e.labelsAsText,this.stacked=e.stacked,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.cumulative=e.cumulative,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.fillArea=e.fillArea,this.showValues=e.showValues,this.hideDataMarkers=e.hideDataMarkers,this.zoomable=e.zoomable}static validateChartDefinition(e,t){return e.checkValidations(t,uy,gy)}static transformDefinition(e,t,o){return cy(e,t,o)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,labelsAsText:e.labelsAsText??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"line",labelRange:e.auxiliaryRange||void 0,stacked:e.stacked??!1,aggregated:e.aggregated??!1,cumulative:e.cumulative??!1,axesDesign:e.axesDesign,fillArea:e.fillArea,showValues:e.showValues,hideDataMarkers:e.hideDataMarkers,zoomable:e.zoomable,humanize:e.humanize}}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"line",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,labelsAsText:this.labelsAsText,stacked:this.stacked,aggregated:this.aggregated,cumulative:this.cumulative,axesDesign:this.axesDesign,fillArea:this.fillArea,showValues:this.showValues,hideDataMarkers:this.hideDataMarkers,zoomable:this.zoomable,humanize:this.humanize}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=ty(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new Wx(i,this.sheetId,this.getters)}getDefinitionForExcel(){const{dataSets:e,labelRange:t}=this.getCommonDataSetAttributesForExcel(this.labelRange,this.dataSets,py(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle)),o=this.getDefinition();return{...o,backgroundColor:OI(this.background||k),fontColor:OI(hy(this.background)),dataSets:e,labelRange:t,verticalAxis:my(o)}}duplicateInDuplicatedSheet(e){const t=oy(this.sheetId,e,this.dataSets),o=sy(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new Wx(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new Wx(t,e,this.getters)}}function qx(e,t){const o=e.getDefinition(),s=iw(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"line",data:{labels:s.labels,datasets:Dy(o,s)},options:{...jI,layout:Rw(0,s),scales:Uw(o,s),plugins:{title:ox(o,t),legend:Dw(o),tooltip:ax(o,s),chartShowValuesPlugin:Jw(o,s)}}},background:e.background||k}}class Zx extends Qy{dataSets;labelRange;background;legendPosition;type="pie";aggregated;dataSetsHaveTitle;isDoughnut;showValues;pieHolePercentage;constructor(e,t,o){super(e,t,o),this.dataSets=ny(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Ba(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.isDoughnut=e.isDoughnut,this.showValues=e.showValues,this.pieHolePercentage=e.pieHolePercentage}static transformDefinition(e,t,o){return cy(e,t,o)}static validateChartDefinition(e,t){return e.checkValidations(t,uy,gy)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"pie",labelRange:e.auxiliaryRange||void 0,aggregated:e.aggregated??!1,isDoughnut:e.isDoughnut,pieHolePercentage:e.pieHolePercentage,showValues:e.showValues,humanize:e.humanize}}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getContextCreation(){return{...this,range:this.dataSets.map((e=>({dataRange:this.getters.getRangeString(e.dataRange,this.sheetId)}))),auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}getDefinitionWithSpecificDataSets(e,t,o){return{type:"pie",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:e.map((e=>({dataRange:this.getters.getRangeString(e.dataRange,o||this.sheetId)}))),legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,aggregated:this.aggregated,isDoughnut:this.isDoughnut,showValues:this.showValues,pieHolePercentage:this.pieHolePercentage,humanize:this.humanize}}duplicateInDuplicatedSheet(e){const t=oy(this.sheetId,e,this.dataSets),o=sy(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new Zx(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new Zx(t,e,this.getters)}getDefinitionForExcel(){const{dataSets:e,labelRange:t}=this.getCommonDataSetAttributesForExcel(this.labelRange,this.dataSets,py(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle));return{...this.getDefinition(),backgroundColor:OI(this.background||k),fontColor:OI(hy(this.background)),dataSets:e,labelRange:t}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=ty(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new Zx(i,this.sheetId,this.getters)}}function jx(e,t){const o=e.getDefinition(),s=nw(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:e.isDoughnut?"doughnut":"pie",data:{labels:s.labels,datasets:Fy(o,s)},options:{...jI,cutout:e.isDoughnut&&void 0!==o.pieHolePercentage?o.pieHolePercentage+"%":void 0,layout:Rw(0,s),plugins:{title:ox(o,t),legend:_w(o,s),tooltip:lx(o,s),chartShowValuesPlugin:Jw(o,s)}}},background:e.background||k}}class Yx extends Qy{dataSets;labelRange;background;legendPosition;aggregated;type="pyramid";dataSetsHaveTitle;dataSetDesign;axesDesign;horizontal=!0;stacked=!0;showValues;constructor(e,t,o){super(e,t,o),this.dataSets=ny(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Ba(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.showValues=e.showValues}static transformDefinition(e,t,o){return cy(e,t,o)}static validateChartDefinition(e,t){return e.checkValidations(t,uy,gy)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,aggregated:e.aggregated??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"pyramid",labelRange:e.auxiliaryRange||void 0,axesDesign:e.axesDesign,horizontal:!0,stacked:!0,showValues:e.showValues,humanize:e.humanize}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}duplicateInDuplicatedSheet(e){const t=oy(this.sheetId,e,this.dataSets),o=sy(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new Yx(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new Yx(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"pyramid",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,aggregated:this.aggregated,axesDesign:this.axesDesign,horizontal:!0,stacked:!0,showValues:this.showValues,humanize:this.humanize}}getDefinitionForExcel(e){const{dataSets:t,labelRange:o}=this.getCommonDataSetAttributesForExcel(this.labelRange,this.dataSets,py(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle)),s=this.getDefinition(),i=sw(s,this.dataSets,this.labelRange,e),{dataSetsValues:n}=i,r=Math.max(...n.map((e=>Math.max(...e.data.map(Math.abs)))));return{...s,horizontal:!0,backgroundColor:OI(this.background||k),fontColor:OI(hy(this.background)),dataSets:t,labelRange:o,verticalAxis:my(s),maxValue:r}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=ty(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new Yx(i,this.sheetId,this.getters)}}class Xx extends Qy{dataSets;labelRange;background;legendPosition;stacked;aggregated;type="radar";dataSetsHaveTitle;dataSetDesign;fillArea;showValues;hideDataMarkers;constructor(e,t,o){super(e,t,o),this.dataSets=ny(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Ba(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.stacked=e.stacked,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.fillArea=e.fillArea,this.showValues=e.showValues,this.hideDataMarkers=e.hideDataMarkers}static transformDefinition(e,t,o){return cy(e,t,o)}static validateChartDefinition(e,t){return e.checkValidations(t,uy,gy)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,stacked:e.stacked??!1,aggregated:e.aggregated??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"radar",labelRange:e.auxiliaryRange||void 0,fillArea:e.fillArea??!1,showValues:e.showValues??!1,hideDataMarkers:e.hideDataMarkers,humanize:e.humanize}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}duplicateInDuplicatedSheet(e){const t=oy(this.sheetId,e,this.dataSets),o=sy(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new Xx(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new Xx(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"radar",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,stacked:this.stacked,aggregated:this.aggregated,fillArea:this.fillArea,showValues:this.showValues,hideDataMarkers:this.hideDataMarkers,humanize:this.humanize}}getDefinitionForExcel(){const{dataSets:e,labelRange:t}=this.getCommonDataSetAttributesForExcel(this.labelRange,this.dataSets,py(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle));return{...this.getDefinition(),backgroundColor:OI(this.background||k),fontColor:OI(hy(this.background)),dataSets:e,labelRange:t}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=ty(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new Xx(i,this.sheetId,this.getters)}}class Kx extends Qy{dataSets;labelRange;background;legendPosition;labelsAsText;aggregated;type="scatter";dataSetsHaveTitle;dataSetDesign;axesDesign;showValues;zoomable;constructor(e,t,o){super(e,t,o),this.dataSets=ny(this.getters,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Ba(this.getters,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.labelsAsText=e.labelsAsText,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.showValues=e.showValues,this.zoomable=e.zoomable}static validateChartDefinition(e,t){return e.checkValidations(t,uy,gy)}static transformDefinition(e,t,o){return cy(e,t,o)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,labelsAsText:e.labelsAsText??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"scatter",labelRange:e.auxiliaryRange||void 0,aggregated:e.aggregated??!1,axesDesign:e.axesDesign,showValues:e.showValues,zoomable:e.zoomable,humanize:e.humanize}}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"scatter",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,labelsAsText:this.labelsAsText,aggregated:this.aggregated,axesDesign:this.axesDesign,showValues:this.showValues,zoomable:this.zoomable,humanize:this.humanize}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=ty(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new Kx(i,this.sheetId,this.getters)}getDefinitionForExcel(){const e=this.dataSets.map((e=>ay(this.getters,e))).filter((e=>""!==e.range)),t=ly(this.getters,this.labelRange,py(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle)),o=this.getDefinition();return{...o,backgroundColor:OI(this.background||k),fontColor:OI(hy(this.background)),dataSets:e,labelRange:t,verticalAxis:my(o)}}duplicateInDuplicatedSheet(e){const t=oy(this.sheetId,e,this.dataSets),o=sy(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new Kx(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new Kx(t,e,this.getters)}}class Jx extends Qy{dataSets;labelRange;background;legendPosition;type="sunburst";dataSetsHaveTitle;showValues;showLabels;valuesDesign;groupColors;pieHolePercentage;constructor(e,t,o){super(e,t,o),this.dataSets=ny(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Ba(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.showValues=e.showValues,this.showLabels=e.showLabels,this.valuesDesign=e.valuesDesign,this.groupColors=e.groupColors,this.pieHolePercentage=e.pieHolePercentage}static transformDefinition(e,t,o){return cy(e,t,o)}static validateChartDefinition(e,t){return e.checkValidations(t,uy,gy)}static getDefinitionFromContextCreation(e){const t=[];return e.hierarchicalRanges?.length?t.push(...e.hierarchicalRanges):e.auxiliaryRange&&t.push({...e.range?.[0],dataRange:e.auxiliaryRange}),{background:e.background,dataSets:t,dataSetsHaveTitle:e.dataSetsHaveTitle??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"sunburst",labelRange:e.range?.[0]?.dataRange,showValues:e.showValues,showLabels:e.showLabels,valuesDesign:e.valuesDesign,groupColors:e.groupColors,humanize:e.humanize}}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getContextCreation(){const e=this.dataSets.at(-1)?.dataRange;return{...this,range:this.labelRange?[{dataRange:this.getters.getRangeString(this.labelRange,this.sheetId)}]:[],auxiliaryRange:e?this.getters.getRangeString(e,this.sheetId):void 0,hierarchicalRanges:this.dataSets.map((e=>({dataRange:this.getters.getRangeString(e.dataRange,this.sheetId)})))}}getDefinitionWithSpecificDataSets(e,t,o){return{type:"sunburst",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:e.map((e=>({dataRange:this.getters.getRangeString(e.dataRange,o||this.sheetId)}))),legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,showValues:this.showValues,showLabels:this.showLabels,valuesDesign:this.valuesDesign,groupColors:this.groupColors,pieHolePercentage:this.pieHolePercentage,humanize:this.humanize}}duplicateInDuplicatedSheet(e){const t=oy(this.sheetId,e,this.dataSets),o=sy(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new Jx(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new Jx(t,e,this.getters)}getDefinitionForExcel(){}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=ty(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new Jx(i,this.sheetId,this.getters)}}class Qx extends Qy{static defaults={background:k,legendPosition:"top",dataSetsHaveTitle:!1,showHeaders:!0,headersColor:"#000000"};dataSets;labelRange;background;legendPosition;type="treemap";dataSetsHaveTitle;showHeaders;headerDesign;showValues;showLabels;valuesDesign;coloringOptions;constructor(e,t,o){super(e,t,o),this.dataSets=ny(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Ba(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.showHeaders=e.showHeaders,this.headerDesign=e.headerDesign,this.showValues=e.showValues,this.showLabels=e.showLabels,this.valuesDesign=e.valuesDesign,this.coloringOptions=e.coloringOptions}static transformDefinition(e,t,o){return cy(e,t,o)}static validateChartDefinition(e,t){return e.checkValidations(t,uy,gy)}static getDefinitionFromContextCreation(e){const t=[];return e.hierarchicalRanges?.length?t.push(...e.hierarchicalRanges):e.auxiliaryRange&&t.push({...e.range?.[0],dataRange:e.auxiliaryRange}),{background:e.background,dataSets:t,dataSetsHaveTitle:e.dataSetsHaveTitle??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"treemap",labelRange:e.range?.[0]?.dataRange,showValues:e.showValues,showHeaders:e.showHeaders,headerDesign:e.headerDesign,showLabels:e.showLabels,valuesDesign:e.valuesDesign,coloringOptions:e.treemapColoringOptions,humanize:e.humanize}}getContextCreation(){const e=this.dataSets.at(-1)?.dataRange;return{...this,range:this.labelRange?[{dataRange:this.getters.getRangeString(this.labelRange,this.sheetId)}]:[],auxiliaryRange:e?this.getters.getRangeString(e,this.sheetId):void 0,hierarchicalRanges:this.dataSets.map((e=>({dataRange:this.getters.getRangeString(e.dataRange,this.sheetId)})))}}duplicateInDuplicatedSheet(e){const t=oy(this.sheetId,e,this.dataSets),o=sy(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new Qx(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new Qx(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=e.map((e=>({dataRange:this.getters.getRangeString(e.dataRange,o||this.sheetId)})));return{type:"treemap",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,showValues:this.showValues,showHeaders:this.showHeaders,headerDesign:this.headerDesign,showLabels:this.showLabels,valuesDesign:this.valuesDesign,coloringOptions:this.coloringOptions,humanize:this.humanize}}getDefinitionForExcel(){}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=ty(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new Qx(i,this.sheetId,this.getters)}}class eE extends Qy{dataSets;labelRange;background;verticalAxisPosition;legendPosition;aggregated;type="waterfall";dataSetsHaveTitle;showSubTotals;firstValueAsSubtotal;showConnectorLines;positiveValuesColor;negativeValuesColor;subTotalValuesColor;dataSetDesign;axesDesign;showValues;zoomable;constructor(e,t,o){super(e,t,o),this.dataSets=ny(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Ba(o,t,e.labelRange),this.background=e.background,this.verticalAxisPosition=e.verticalAxisPosition,this.legendPosition=e.legendPosition,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.showSubTotals=e.showSubTotals,this.showConnectorLines=e.showConnectorLines,this.positiveValuesColor=e.positiveValuesColor,this.negativeValuesColor=e.negativeValuesColor,this.subTotalValuesColor=e.subTotalValuesColor,this.firstValueAsSubtotal=e.firstValueAsSubtotal,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.showValues=e.showValues,this.zoomable=e.zoomable}static transformDefinition(e,t,o){return cy(e,t,o)}static validateChartDefinition(e,t){return e.checkValidations(t,uy,gy)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range?e.range:[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,aggregated:e.aggregated??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"waterfall",verticalAxisPosition:"left",labelRange:e.auxiliaryRange||void 0,showSubTotals:e.showSubTotals??!1,showConnectorLines:e.showConnectorLines??!0,firstValueAsSubtotal:e.firstValueAsSubtotal??!1,axesDesign:e.axesDesign,showValues:e.showValues,zoomable:e.zoomable??!1,humanize:e.humanize}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}duplicateInDuplicatedSheet(e){const t=oy(this.sheetId,e,this.dataSets),o=sy(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new eE(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new eE(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"waterfall",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,verticalAxisPosition:this.verticalAxisPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,aggregated:this.aggregated,showSubTotals:this.showSubTotals,showConnectorLines:this.showConnectorLines,positiveValuesColor:this.positiveValuesColor,negativeValuesColor:this.negativeValuesColor,subTotalValuesColor:this.subTotalValuesColor,firstValueAsSubtotal:this.firstValueAsSubtotal,axesDesign:this.axesDesign,showValues:this.showValues,zoomable:this.zoomable,humanize:this.humanize}}getDefinitionForExcel(){}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=ty(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new eE(i,this.sheetId,this.getters)}}function tE(e,t){const o=e.getDefinition(),s=ow(o,e.dataSets,e.labelRange,t),{labels:i,datasets:n}=Ay(o,s);return{chartJsConfig:{type:"bar",data:{labels:i,datasets:n},options:{...jI,layout:Rw(0,s),scales:zw(o,s),plugins:{title:ox(o,t),legend:Pw(o),tooltip:cx(o,s),chartShowValuesPlugin:tx(o,s),waterfallLinesPlugin:{showConnectorLines:o.showConnectorLines}}}},background:e.background||k}}const oE=new n;oE.add("bar",{match:e=>"bar"===e,createChart:(e,t,o)=>new Sx(e,t,o),getChartRuntime:Cx,validateChartDefinition:Sx.validateChartDefinition,transformDefinition:Sx.transformDefinition,getChartDefinitionFromContextCreation:Sx.getDefinitionFromContextCreation,sequence:10}),oE.add("combo",{match:e=>"combo"===e,createChart:(e,t,o)=>new Px(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=ow(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"bar",data:{labels:s.labels,datasets:Oy(o,s)},options:{...jI,layout:Rw(0,s),scales:Vw(o,s),plugins:{title:ox(o,t),legend:Ow(o),tooltip:rx(o,s),chartShowValuesPlugin:Jw(o,s)}}},background:e.background||k}},validateChartDefinition:Px.validateChartDefinition,transformDefinition:Px.transformDefinition,getChartDefinitionFromContextCreation:Px.getDefinitionFromContextCreation,sequence:15}),oE.add("line",{match:e=>"line"===e,createChart:(e,t,o)=>new Wx(e,t,o),getChartRuntime:qx,validateChartDefinition:Wx.validateChartDefinition,transformDefinition:Wx.transformDefinition,getChartDefinitionFromContextCreation:Wx.getDefinitionFromContextCreation,sequence:20}),oE.add("pie",{match:e=>"pie"===e,createChart:(e,t,o)=>new Zx(e,t,o),getChartRuntime:jx,validateChartDefinition:Zx.validateChartDefinition,transformDefinition:Zx.transformDefinition,getChartDefinitionFromContextCreation:Zx.getDefinitionFromContextCreation,sequence:30}),oE.add("scorecard",{match:e=>"scorecard"===e,createChart:(e,t,o)=>new rI(e,t,o),getChartRuntime:lI,validateChartDefinition:rI.validateChartDefinition,transformDefinition:rI.transformDefinition,getChartDefinitionFromContextCreation:rI.getDefinitionFromContextCreation,sequence:40}),oE.add("gauge",{match:e=>"gauge"===e,createChart:(e,t,o)=>new Ux(e,t,o),getChartRuntime:Hx,validateChartDefinition:Ux.validateChartDefinition,transformDefinition:Ux.transformDefinition,getChartDefinitionFromContextCreation:Ux.getDefinitionFromContextCreation,sequence:50}),oE.add("scatter",{match:e=>"scatter"===e,createChart:(e,t,o)=>new Kx(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=iw(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"line",data:{labels:s.labels,datasets:_y(o,s)},options:{...jI,layout:Rw(0,s),scales:Hw(o,s),plugins:{title:ox(o,t),legend:Fw(o),tooltip:ax(o,s),chartShowValuesPlugin:Jw(o,s)}}},background:e.background||k}},validateChartDefinition:Kx.validateChartDefinition,transformDefinition:Kx.transformDefinition,getChartDefinitionFromContextCreation:Kx.getDefinitionFromContextCreation,sequence:60}),oE.add("waterfall",{match:e=>"waterfall"===e,createChart:(e,t,o)=>new eE(e,t,o),getChartRuntime:tE,validateChartDefinition:eE.validateChartDefinition,transformDefinition:eE.transformDefinition,getChartDefinitionFromContextCreation:eE.getDefinitionFromContextCreation,sequence:70}),oE.add("pyramid",{match:e=>"pyramid"===e,createChart:(e,t,o)=>new Yx(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=sw(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"bar",data:{labels:s.labels,datasets:Ty(o,s)},options:{...jI,indexAxis:"y",layout:Rw(0,s),scales:Bw(o,s),plugins:{title:ox(o,t),legend:Aw(o),tooltip:hx(o,s),chartShowValuesPlugin:ex(o,s)}}},background:e.background||k}},validateChartDefinition:Yx.validateChartDefinition,transformDefinition:Yx.transformDefinition,getChartDefinitionFromContextCreation:Yx.getDefinitionFromContextCreation,sequence:80,dataSeriesLimit:2}),oE.add("radar",{match:e=>"radar"===e,createChart:(e,t,o)=>new Xx(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=rw(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"radar",data:{labels:s.labels,datasets:Py(o,s)},options:{...jI,layout:Rw(0,s),scales:$w(o,s),plugins:{title:ox(o,t),legend:Mw(o),tooltip:dx(o,s),chartShowValuesPlugin:Jw(o,s)}}},background:e.background||k}},validateChartDefinition:Xx.validateChartDefinition,transformDefinition:Xx.transformDefinition,getChartDefinitionFromContextCreation:Xx.getDefinitionFromContextCreation,sequence:80}),oE.add("geo",{match:e=>"geo"===e,createChart:(e,t,o)=>new Gx(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=aw(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"choropleth",data:{datasets:My(o,s)},options:{...jI,layout:Rw(0,s),scales:Gw(o,s),plugins:{title:ox(o,t),tooltip:ux(o,s),legend:{display:!1}}}},background:e.background||k}},validateChartDefinition:Gx.validateChartDefinition,transformDefinition:Gx.transformDefinition,getChartDefinitionFromContextCreation:Gx.getDefinitionFromContextCreation,sequence:90,dataSeriesLimit:1}),oE.add("funnel",{match:e=>"funnel"===e,createChart:(e,t,o)=>new Mx(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=lw(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"funnel",data:{labels:s.labels,datasets:Ny(o,s)},options:{...jI,indexAxis:"y",layout:Rw(0,s),scales:Ww(0,s),plugins:{title:ox(o,t),legend:{display:!1},tooltip:gx(o,s),chartShowValuesPlugin:Jw(o,s)}}},background:e.background||k}},validateChartDefinition:Mx.validateChartDefinition,transformDefinition:Mx.transformDefinition,getChartDefinitionFromContextCreation:Mx.getDefinitionFromContextCreation,sequence:100,dataSeriesLimit:1}),oE.add("sunburst",{match:e=>"sunburst"===e,createChart:(e,t,o)=>new Jx(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=cw(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"doughnut",data:{datasets:Ly(o,s)},options:{cutout:void 0===e.pieHolePercentage?"25%":`${e.pieHolePercentage}%`,...jI,layout:Rw(0,s),plugins:{title:ox(o,t),legend:Nw(o),tooltip:px(o,s),sunburstLabelsPlugin:Qw(o,s),sunburstHoverPlugin:{enabled:!0}}}},background:e.background||k}},validateChartDefinition:Jx.validateChartDefinition,transformDefinition:Jx.transformDefinition,getChartDefinitionFromContextCreation:Jx.getDefinitionFromContextCreation,sequence:30}),oE.add("treemap",{match:e=>"treemap"===e,createChart:(e,t,o)=>new Qx(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=cw(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"treemap",data:{labels:s.labels,datasets:zy(o,s)},options:{...jI,layout:Rw(0,s),plugins:{title:ox(o,t),legend:{display:!1},tooltip:mx(o,s)}}},background:e.background||k}},validateChartDefinition:Qx.validateChartDefinition,transformDefinition:Qx.transformDefinition,getChartDefinitionFromContextCreation:Qx.getDefinitionFromContextCreation,sequence:100});const sE=new n;sE.add("line",Ex),sE.add("bar",Ex),sE.add("combo",Ex),sE.add("pie",Jy),sE.add("gauge",Fx),sE.add("scatter",Ex),sE.add("scorecard",gI),sE.add("waterfall",Ex),sE.add("pyramid",Jy),sE.add("radar",Jy),sE.add("geo",Jy),sE.add("funnel",Jy),sE.add("sunburst",Jy),sE.add("treemap",Jy);const iE={line:ui("Line"),column:ui("Column"),bar:ui("Bar"),area:ui("Area"),pie:ui("Pie"),hierarchical:ui("Hierarchical"),misc:ui("Miscellaneous")},nE=new n;function rE(e){const t=oE.getAll().sort(((e,t)=>e.sequence-t.sequence));return function(o,s,i){const n=t.find((e=>e.match(s.type)));if(!n)throw new Error(`No builder for this chart: ${s.type}`);return n.createChart(s,i,e)}}function aE(e){const t=oE.getAll().sort(((e,t)=>e.sequence-t.sequence));return function(o){const s=t.find((e=>e.match(o.type)));if(!s)throw new Error("No runtime builder for this chart.");const i=s.getChartRuntime(o,e),n=o.getDefinition();if("chartJsConfig"in i&&/line|combo|bar|scatter|waterfall/.test(n.type)){const e=i.chartJsConfig;i.masterChartConfig=function(e){return{...e,data:{...e.data,datasets:e.data.datasets.filter((e=>!yy(e.xAxisID))).map((e=>({...e,pointRadius:!1===e.showLine?2:0})))},options:{...e.options,hover:{mode:null},plugins:{...e.options.plugins,title:{display:!1},legend:{display:!1},tooltip:{enabled:!1},chartShowValuesPlugin:void 0},layout:{padding:{...e.options.layout?.padding,top:5,bottom:10}},scales:{y:{...e.options.scales?.y,display:!1},y1:{...e.options.scales?.y1,display:!1},x:{...e.options.scales?.x,title:void 0,ticks:{...e.options.scales?.x?.ticks,callback:function(t){return Cy(e.options.scales?.x?.ticks?.callback?.call(this,t),5)},padding:0,font:{size:9}}}}}}}(e)}return i}}function lE(e,t){const o=oE.getAll().find((e=>e.match(t.type)));if(!o)throw new Error("Unknown chart type.");return o.validateChartDefinition(e,t)}function cE(e,t,o){const s=oE.getAll().find((e=>e.match(t.type)));if(!s)throw new Error("Unknown chart type.");return s.transformDefinition(e,t,o)}nE.add("line",{matcher:e=>"line"===e.type&&!e.stacked&&!e.fillArea,displayName:ui("Line"),chartType:"line",chartSubtype:"line",subtypeDefinition:{stacked:!1,fillArea:!1},category:"line",preview:"o-spreadsheet-ChartPreview.LINE_CHART"}).add("stacked_line",{matcher:e=>"line"===e.type&&!e.fillArea&&!!e.stacked,displayName:ui("Stacked Line"),chartType:"line",chartSubtype:"stacked_line",subtypeDefinition:{stacked:!0,fillArea:!1},category:"line",preview:"o-spreadsheet-ChartPreview.STACKED_LINE_CHART"}).add("area",{matcher:e=>"line"===e.type&&!e.stacked&&!!e.fillArea,displayName:ui("Area"),chartType:"line",chartSubtype:"area",subtypeDefinition:{stacked:!1,fillArea:!0},category:"area",preview:"o-spreadsheet-ChartPreview.AREA_CHART"}).add("stacked_area",{matcher:e=>"line"===e.type&&e.stacked&&!!e.fillArea,displayName:ui("Stacked Area"),chartType:"line",chartSubtype:"stacked_area",subtypeDefinition:{stacked:!0,fillArea:!0},category:"area",preview:"o-spreadsheet-ChartPreview.STACKED_AREA_CHART"}).add("scatter",{displayName:ui("Scatter"),chartType:"scatter",chartSubtype:"scatter",category:"misc",preview:"o-spreadsheet-ChartPreview.SCATTER_CHART"}).add("column",{matcher:e=>"bar"===e.type&&!e.stacked&&!e.horizontal,displayName:ui("Column"),chartType:"bar",chartSubtype:"column",subtypeDefinition:{stacked:!1,horizontal:!1},category:"column",preview:"o-spreadsheet-ChartPreview.COLUMN_CHART"}).add("stacked_column",{matcher:e=>"bar"===e.type&&e.stacked&&!e.horizontal,displayName:ui("Stacked Column"),chartType:"bar",chartSubtype:"stacked_column",subtypeDefinition:{stacked:!0,horizontal:!1},category:"column",preview:"o-spreadsheet-ChartPreview.STACKED_COLUMN_CHART"}).add("bar",{matcher:e=>"bar"===e.type&&!e.stacked&&!!e.horizontal,displayName:ui("Bar"),chartType:"bar",chartSubtype:"bar",subtypeDefinition:{horizontal:!0,stacked:!1},category:"bar",preview:"o-spreadsheet-ChartPreview.BAR_CHART"}).add("stacked_bar",{matcher:e=>"bar"===e.type&&e.stacked&&!!e.horizontal,displayName:ui("Stacked Bar"),chartType:"bar",chartSubtype:"stacked_bar",subtypeDefinition:{horizontal:!0,stacked:!0},category:"bar",preview:"o-spreadsheet-ChartPreview.STACKED_BAR_CHART"}).add("combo",{displayName:ui("Combo"),chartSubtype:"combo",chartType:"combo",category:"line",preview:"o-spreadsheet-ChartPreview.COMBO_CHART"}).add("pie",{matcher:e=>"pie"===e.type&&!e.isDoughnut,displayName:ui("Pie"),chartSubtype:"pie",chartType:"pie",subtypeDefinition:{isDoughnut:!1},category:"pie",preview:"o-spreadsheet-ChartPreview.PIE_CHART"}).add("doughnut",{matcher:e=>"pie"===e.type&&!!e.isDoughnut,displayName:ui("Doughnut"),chartSubtype:"doughnut",chartType:"pie",subtypeDefinition:{isDoughnut:!0},category:"pie",preview:"o-spreadsheet-ChartPreview.DOUGHNUT_CHART"}).add("gauge",{displayName:ui("Gauge"),chartSubtype:"gauge",chartType:"gauge",category:"misc",preview:"o-spreadsheet-ChartPreview.GAUGE_CHART"}).add("scorecard",{displayName:ui("Scorecard"),chartSubtype:"scorecard",chartType:"scorecard",category:"misc",preview:"o-spreadsheet-ChartPreview.SCORECARD_CHART"}).add("waterfall",{displayName:ui("Waterfall"),chartSubtype:"waterfall",chartType:"waterfall",category:"misc",preview:"o-spreadsheet-ChartPreview.WATERFALL_CHART"}).add("pyramid",{displayName:ui("Population Pyramid"),chartSubtype:"pyramid",chartType:"pyramid",category:"misc",preview:"o-spreadsheet-ChartPreview.POPULATION_PYRAMID_CHART"}).add("radar",{matcher:e=>"radar"===e.type&&!e.fillArea,displayName:ui("Radar"),chartSubtype:"radar",chartType:"radar",subtypeDefinition:{fillArea:!1},category:"misc",preview:"o-spreadsheet-ChartPreview.RADAR_CHART"}).add("filled_radar",{matcher:e=>"radar"===e.type&&!!e.fillArea,displayName:ui("Filled Radar"),chartType:"radar",chartSubtype:"filled_radar",subtypeDefinition:{fillArea:!0},category:"misc",preview:"o-spreadsheet-ChartPreview.FILLED_RADAR_CHART"}).add("geo",{displayName:ui("Geo Chart"),chartSubtype:"geo",chartType:"geo",category:"misc",preview:"o-spreadsheet-ChartPreview.GEO_CHART"}).add("funnel",{displayName:ui("Funnel"),chartSubtype:"funnel",chartType:"funnel",category:"misc",preview:"o-spreadsheet-ChartPreview.FUNNEL_CHART"}).add("sunburst",{matcher:e=>"sunburst"===e.type,displayName:ui("Sunburst"),chartSubtype:"sunburst",chartType:"sunburst",category:"hierarchical",preview:"o-spreadsheet-ChartPreview.SUNBURST_CHART"}).add("treemap",{matcher:e=>"treemap"===e.type,displayName:ui("Tree Map"),chartType:"treemap",chartSubtype:"treemap",category:"hierarchical",preview:"o-spreadsheet-ChartPreview.TREE_MAP_CHART"});var hE=Object.freeze({__proto__:null,AbstractChart:Qy,BarChart:Sx,CHART_AXIS_CHOICES:by,CHART_COMMON_OPTIONS:jI,GaugeChart:Ux,LineChart:Wx,MOVING_AVERAGE_TREND_LINE_XAXIS_ID:QC,PieChart:Zx,SPREADSHEET_TO_EXCEL_TRENDLINE_TYPE_MAPPING:ey,ScorecardChart:rI,TREND_LINE_XAXIS_ID:JC,WaterfallChart:eE,adaptChartRange:iy,chartFactory:rE,chartFontColor:hy,chartMutedFontColor:dy,chartRuntimeFactory:aE,chartToImageFile:XI,chartToImageUrl:YI,checkDataset:uy,checkLabelRange:gy,createBarChartRuntime:Cx,createDataSets:ny,createGaugeChartRuntime:Hx,createLineChartRuntime:qx,createPieChartRuntime:jx,createScorecardChartRuntime:lI,createWaterfallChartRuntime:tE,drawScoreChart:aI,duplicateDataSetsInDuplicatedSheet:oy,duplicateLabelRangeInDuplicatedSheet:sy,formatChartDatasetValue:fy,formatTickValue:vy,getChartPositionAtCenterOfViewport:function(e,t){const{x:o,y:s}=e.getMainViewportCoordinates(),{scrollX:i,scrollY:n}=e.getActiveSheetScrollInfo(),{width:r,height:a}=e.getVisibleRect(e.getActiveMainViewport());return{x:o+i+Math.max(0,(r-t.width)/2),y:s+n+Math.max(0,(a-t.height)/2)}},getDefinedAxis:my,getPieColors:Sy,isTrendLineAxis:yy,shouldRemoveFirstLabel:py,toExcelDataset:ay,toExcelLabelRange:ly,transformChartDefinitionWithDataSetsWithZone:cy,transformDefinition:cE,truncateLabel:Cy,updateChartRangesWithDataSets:ty,validateChartDefinition:lE});function dE(e,t){const{scrollX:o,scrollY:s}=e.getActiveSheetScrollInfo(),i=e.getSheetViewDimension(),n=o+Math.max(0,(i.width-t.width)/2),r=s+Math.max(0,(i.height-t.height)/2);return e.getPositionAnchorOffset({x:n,y:r})}function uE(e,t){const o=pt(t),s=e.getSheetViewDimension(),i=s.width,n=s.height;if(o.width>i){const e=i/o.width;o.width=i,o.height=o.height*e}if(o.height>n){const e=n/o.height;o.height=n,o.width=o.width*e}return o}class gE{xmlString;constructor(e){this.xmlString=e}toString(){return this.xmlString}}const pE=["areaChart","area3DChart","lineChart","line3DChart","stockChart","radarChart","scatterChart","pieChart","pie3DChart","doughnutChart","barChart","bar3DChart","ofPieChart","surfaceChart","surface3DChart","bubbleChart","comboChart","radarChart"];function mE(e,t,o){return{content:(new XMLSerializer).serializeToString(e),path:t,contentType:o}}function fE(e){return String(e).replace(/\&/g,"&amp;").replace(/\</g,"&lt;").replace(/\>/g,"&gt;").replace(/\"/g,"&quot;").replace(/\'/g,"&apos;").replace(/[\x00-\x08\x0B\x0C\x0E-\x1F]/g,"")}function vE(e){return new gE(e.map((([e,t])=>`${e}="${fE(t)}"`)).join(" "))}function bE(e,t="text/xml"){const o=(new DOMParser).parseFromString(e.toString(),t),s=o.querySelector("parsererror");if(s){const t=s.innerHTML,o=parseInt(t.split(":")[0],10),i=e.toString().trim().split("\n"),n=i.slice(Math.max(o-3,0),Math.min(o+2,i.length)).join("\n");throw new Error(`XML string could not be parsed: ${t}\n${n}`)}return o}function SE(e){if(e)return{style:e.style,color:{rgb:e.color}}}function CE(e,t){return IE`
16
16
  <Override ContentType="${t}" PartName="${e}" />
17
17
  `}function yE(e){return new gE(e.join("\n"))}function IE(e,...t){const o=[e[0]];for(let s=0;s<t.length;s++){const i=t[s]instanceof gE?t[s]:fE(t[s]);o.push(i+e[s+1])}return new gE(Lt(o))}function wE(e){return e.replace(/NAMESPACE.*NAMESPACE(.*)/,"$1")}function xE(e){return e.replaceAll(/([a-zA-Z0-9]+):([a-zA-Z0-9]+)/g,"NAMESPACE$1NAMESPACE$2")}function EE(e,t,s){if(!s.model.getters.getChartIdFromFigureId(e))return[];return o([{id:"edit",name:ui("Edit"),execute:()=>{s.model.dispatch("SELECT_FIGURE",{figureId:e}),s.openSidePanel("ChartPanel")},icon:"o-spreadsheet-Icon.EDIT",isEnabled:e=>!e.isSmall},RE(e,s),TE(e,s),AE(e,s),DE(e,s),_E(e,t,s)]).filter((e=>!s.model.getters.isReadonly()||e.isReadonlyAllowed))}function RE(e,t,o){return{id:"copy",name:ui("Copy"),description:"Ctrl+C",execute:async()=>{t.model.dispatch("SELECT_FIGURE",{figureId:e}),t.model.dispatch("COPY");const s=await t.model.getters.getClipboardTextAndImageContent();await t.clipboard.write(s),o&&t.notifyUser({sticky:!1,type:"success",text:o})},icon:"o-spreadsheet-Icon.CLIPBOARD"}}function TE(e,t){return{id:"cut",name:ui("Cut"),description:"Ctrl+X",execute:async()=>{t.model.dispatch("SELECT_FIGURE",{figureId:e}),t.model.dispatch("CUT"),await t.clipboard.write(await t.model.getters.getClipboardTextAndImageContent())},icon:"o-spreadsheet-Icon.CUT"}}function AE(e,t){return{id:"copy_as_image",name:ui("Copy as image"),icon:"o-spreadsheet-Icon.COPY_AS_IMAGE",execute:async()=>{const o=t.model.getters.getFigureSheetId(e),s=t.model.getters.getFigure(o,e),i=t.model.getters.getChartIdFromFigureId(e);if(!i)return;const n=t.model.getters.getChartType(i),r=t.model.getters.getChartRuntime(i),a=`<img src="${fE(YI(r,s,n))}" />`,l=await XI(r,s,n);t.clipboard.write({"text/html":a,"image/png":l}),t.notifyUser({sticky:!1,type:"success",text:ui("Chart copied to clipboard")})},isReadonlyAllowed:!0}}function DE(e,t){return{id:"download",name:ui("Download"),icon:"o-spreadsheet-Icon.DOWNLOAD",execute:async()=>{const o=t.model.getters.getFigureSheetId(e),s=t.model.getters.getFigure(o,e),i=t.model.getters.getChartIdFromFigureId(e);if(!i)return;const n=t.model.getters.getChartType(i);AI(YI(t.model.getters.getChartRuntime(i),s,n),"chart")},isReadonlyAllowed:!0}}function _E(e,t,o){return{id:"delete",name:ui("Delete"),execute:()=>{o.model.dispatch("DELETE_FIGURE",{sheetId:o.model.getters.getActiveSheetId(),figureId:e}),t()},icon:"o-spreadsheet-Icon.TRASH"}}const FE={type:"bar",title:{},stacked:!1,dataSetsHaveTitle:!1,dataSets:[],legendPosition:"top",humanize:!0};function OE(e,t){if(t.title)return t.title;if("carouselDataView"===t.type)return ui("Data");const o=e.getChartDefinition(t.chartId);return(nE.getAll().find((e=>e.matcher?.(o)))||nE.get(o.type)).displayName}class PE extends Lh{mutators=["toggleFullScreenFigure"];fullScreenFigure=void 0;toggleFullScreenFigure(e){this.fullScreenFigure?.id===e?this.fullScreenFigure=void 0:this.makeFullScreen(e)}makeFullScreen(e){const t=this.getters.getActiveSheetId(),o=this.getters.getFigure(t,e);o&&(this.fullScreenFigure={...o,x:0,y:0,width:0,height:0})}}Bh`
18
18
  .o-menu {
@@ -314,7 +314,7 @@
314
314
  }
315
315
  }
316
316
  }
317
- `;class RR extends t.Component{static template="o-spreadsheet-Composer";static props={focus:{validate:e=>["inactive","cellFocus","contentFocus"].includes(e)},inputStyle:{type:String,optional:!0},rect:{type:Object,optional:!0},delimitation:{type:Object,optional:!0},onComposerCellFocused:{type:Function,optional:!0},onComposerContentFocused:Function,isDefaultFocus:{type:Boolean,optional:!0},onInputContextMenu:{type:Function,optional:!0},composerStore:Object,placeholder:{type:String,optional:!0},inputMode:{type:String,optional:!0},showAssistant:{type:Boolean,optional:!0}};static components={TextValueProvider:uR,FunctionDescriptionProvider:SR,SpeechBubble:CR};static defaultProps={inputStyle:"",isDefaultFocus:!1,inputMode:"text",showAssistant:!0};DOMFocusableElementStore;composerRef=t.useRef("o_composer");contentHelper=new gR(this.composerRef.el);composerState=t.useState({positionStart:0,positionEnd:0,hoveredRect:void 0});functionDescriptionState=t.useState({showDescription:!1,functionDescription:{},argsToFocus:[]});assistant=t.useState({forcedClosed:!1});compositionActive=!1;spreadsheetRect=LE();lastHoveredTokenIndex=void 0;debouncedHover=kt(((e,t)=>{const o=this.contentHelper.getCurrentSelection();if(o.start!==o.end)return;const s=this.props.composerStore.hoveredTokens;this.props.composerStore.hoverToken(e),zt(s,this.props.composerStore.hoveredTokens)||(this.composerState.hoveredRect=t)}),120);get assistantStyleProperties(){const e=this.composerRef.el.getBoundingClientRect(),t={},o=Math.min(this.props.rect?.width||1/0,IR);t["min-width"]=`${o}px`;const s=this.props.composerStore.autoCompleteProposals,i=s?.some((e=>e.description));if((this.functionDescriptionState.showDescription||i)&&(t.width="300px"),this.props.delimitation&&this.props.rect){const{x:e,y:o,height:s}=this.props.rect,i=this.props.delimitation.height-(o+s);if(t["max-height"]=`${i}px`,o>i){const e=o;t["max-height"]=e-9+"px",t.transform=`translate(0, calc(-100% - ${s+3}px))`}e+IR>this.props.delimitation.width&&(t.right="0px")}else t["max-height"]=this.spreadsheetRect.height-e.bottom-1+"px",e.left+IR+Re+9>this.spreadsheetRect.width&&(t.right="9px");return t}get assistantStyle(){const e=this.assistantStyleProperties;return qh({"max-height":e["max-height"],width:e.width,"min-width":e["min-width"]})}get assistantContainerStyle(){const e=this.assistantStyleProperties;return qh({top:e.top,right:e.right,transform:e.transform})}shouldProcessInputEvents=!1;tokens=[];keyMapping={Enter:e=>this.processEnterKey(e,"down"),"Shift+Enter":e=>this.processEnterKey(e,"up"),"Alt+Enter":this.processNewLineEvent,"Ctrl+Enter":this.processNewLineEvent,Escape:this.processEscapeKey,F2:e=>this.toggleEditionMode(e),F4:e=>this.processF4Key(e),Tab:e=>this.processTabKey(e,"right"),"Shift+Tab":e=>this.processTabKey(e,"left")};keyCodeMapping={NumpadDecimal:this.processNumpadDecimal};setup(){this.DOMFocusableElementStore=Dh(cR),t.onMounted((()=>{const e=this.composerRef.el;this.props.isDefaultFocus&&this.DOMFocusableElementStore.setFocusableElement(e),this.contentHelper.updateEl(e)})),t.onWillUnmount((()=>{this.debouncedHover.stopDebounce()})),t.useEffect((()=>{this.processContent(),document.activeElement!==this.contentHelper.el||"inactive"!==this.props.composerStore.editionMode||this.props.isDefaultFocus||this.DOMFocusableElementStore.focus()})),t.useEffect((()=>{this.processTokenAtCursor()}),(()=>["inactive"!==this.props.composerStore.editionMode])),t.useEffect((()=>{this.contentHelper.scrollSelectionIntoView()}),(()=>[this.props.composerStore.composerSelection.start,this.props.composerStore.composerSelection.end]))}processArrowKeys(e){const t=this.props.composerStore.tokenAtCursor;if((this.props.composerStore.isSelectingRange||"inactive"===this.props.composerStore.editionMode)&&(!["ArrowUp","ArrowDown"].includes(e.key)||!this.props.composerStore.isAutoCompleteDisplayed||"REFERENCE"===t?.type))return this.functionDescriptionState.showDescription=!1,this.props.composerStore.hideHelp(),e.preventDefault(),e.stopPropagation(),void dR(e,this.env.model.selection);const o=this.props.composerStore.currentContent;"cellFocus"!==this.props.focus||this.props.composerStore.isAutoCompleteDisplayed||uo(o)?(e.stopPropagation(),this.handleArrowKeysForAutocomplete(e)):this.props.composerStore.stopEdition()}handleArrowKeysForAutocomplete(e){["ArrowUp","ArrowDown"].includes(e.key)&&this.props.composerStore.isAutoCompleteDisplayed&&(e.preventDefault(),this.props.composerStore.moveAutoCompleteSelection("ArrowDown"===e.key?"next":"previous"))}processTabKey(e,t){e.preventDefault(),e.stopPropagation(),this.assistant.forcedClosed||this.props.composerStore.autoCompleteOrStop(t)}processEnterKey(e,t){e.preventDefault(),e.stopPropagation(),this.assistant.forcedClosed||this.props.composerStore.autoCompleteOrStop(t)}processNewLineEvent(e){e.preventDefault(),e.stopPropagation();const t=this.contentHelper.getText(),o=this.contentHelper.getCurrentSelection(),s=Math.min(o.start,o.end),i=Math.max(o.start,o.end);this.props.composerStore.stopComposerRangeSelection(),this.props.composerStore.setCurrentContent(t.slice(0,s)+ot+t.slice(i),{start:s+1,end:s+1}),this.processContent()}processEscapeKey(e){this.props.composerStore.cancelEdition(),e.stopPropagation(),e.preventDefault()}processF4Key(e){e.stopPropagation(),this.props.composerStore.cycleReferences(),this.processContent()}toggleEditionMode(e){e.stopPropagation(),this.props.composerStore.toggleEditionMode(),this.processContent()}processNumpadDecimal(e){e.stopPropagation(),e.preventDefault();const t=this.env.model.getters.getLocale(),o=this.contentHelper.getCurrentSelection(),s=this.props.composerStore.currentContent,i=s.slice(0,o.start)+t.decimalSeparator+s.slice(o.end);this.props.composerStore.setCurrentContent(i,{start:o.start+1,end:o.start+1}),this.processContent()}onCompositionStart(){this.compositionActive=!0}onCompositionEnd(){this.compositionActive=!1}onKeydown(e){if("inactive"===this.props.composerStore.editionMode)return;if(e.key.startsWith("Arrow"))return void this.processArrowKeys(e);const t=this.keyMapping[xI(e)]||this.keyCodeMapping[xI(e,"code")];t?t.call(this,e):e.stopPropagation()}onPaste(e){"inactive"!==this.props.composerStore.editionMode?e.stopPropagation():e.preventDefault()}onInput(e){if(!this.shouldProcessInputEvents)return;let t;if(e.stopPropagation(),t="inactive"===this.props.composerStore.editionMode?e.data||"":this.contentHelper.getText(),"inactive"===this.props.focus)return this.props.onComposerCellFocused?.(t);const o=this.contentHelper.getCurrentSelection();this.props.composerStore.stopComposerRangeSelection(),this.props.composerStore.setCurrentContent(t,o),this.processTokenAtCursor()}onKeyup(e){if(this.contentHelper.el===document.activeElement){if(this.props.composerStore.isAutoCompleteDisplayed&&["ArrowUp","ArrowDown"].includes(e.key))return;if(this.props.composerStore.isSelectingRange&&e.key?.startsWith("Arrow"))return;const{start:t,end:o}=this.props.composerStore.composerSelection,{start:s,end:i}=this.contentHelper.getCurrentSelection();s===t&&i===o||this.props.composerStore.changeComposerCursorSelection(s,i),this.processTokenAtCursor()}}onBlur(e){if("inactive"===this.props.composerStore.editionMode)return;const t=e.relatedTarget;t&&t instanceof HTMLElement?t.attributes.getNamedItem("composerFocusableElement")?this.contentHelper.el.focus():t.classList.contains("o-composer")||this.props.composerStore.stopEdition():this.props.composerStore.stopEdition()}onMousedown(e){e.button>0||this.env.isMobile()&&!_I()||(this.debouncedHover.stopDebounce(),this.contentHelper.removeSelection())}onMouseup(){if(this.env.model.getters.isReadonly())return;const e=this.contentHelper.getCurrentSelection();e.start!==e.end&&this.props.composerStore.hoverToken(void 0)}onClick(){if(this.env.model.getters.isReadonly())return;const e=this.contentHelper.getCurrentSelection();this.props.composerStore.stopComposerRangeSelection();const t="inactive"===this.props.composerStore.editionMode;this.props.onComposerContentFocused(e),t||this.props.composerStore.changeComposerCursorSelection(e.start,e.end),this.processTokenAtCursor()}onDblClick(){if(this.env.model.getters.isReadonly())return;const e=this.props.composerStore.currentContent;if(uo(e)){const t=this.props.composerStore.currentTokens,o=this.contentHelper.getCurrentSelection();if(o.start===o.end)return;const s=e.substring(o.start,o.end),i=t.filter((e=>e.value.includes(s)&&e.start<=o.start&&e.end>=o.end))[0];if(!i)return;"REFERENCE"===i.type&&this.props.composerStore.changeComposerCursorSelection(i.start,i.end)}}onContextMenu(e){"inactive"===this.props.composerStore.editionMode&&this.props.onInputContextMenu?.(e)}closeAssistant(){this.props.composerStore.canBeToggled&&(this.assistant.forcedClosed=!0)}openAssistant(){this.props.composerStore.canBeToggled&&(this.assistant.forcedClosed=!1)}onWheel(e){this.composerRef.el&&this.composerRef.el.scrollHeight>this.composerRef.el.clientHeight&&e.stopPropagation()}processContent(){if(this.compositionActive)return;this.shouldProcessInputEvents=!1,"inactive"!==this.props.focus&&document.activeElement!==this.contentHelper.el&&this.contentHelper.el.focus();const e=this.getContentLines();if(this.contentHelper.setText(e),0!==e.length&&0!==e.length[0]&&"inactive"!==this.props.focus){const{start:e,end:t}=this.props.composerStore.composerSelection;this.contentHelper.selectRange(e,t)}this.shouldProcessInputEvents=!0}getContentLines(){const e=this.props.composerStore.currentContent,t=uo(e);return""===e?[]:t&&"inactive"!==this.props.focus?this.splitHtmlContentIntoLines(this.getHtmlContentFromTokens()):this.splitHtmlContentIntoLines([{value:e,classes:[]}])}getHtmlContentFromTokens(){const e=this.props.composerStore.currentTokens,t=[],{end:o,start:s}=this.props.composerStore.composerSelection;for(let i=0;i<e.length;i++){const n=e[i];let r=n.color||lt;n.isBlurred&&(r=Bs(r,.5));const a=[];"REFERENCE"===n.type&&this.props.composerStore.tokenAtCursor===n&&"selecting"===this.props.composerStore.editionMode&&a.push("text-decoration-underline"),o===s&&n.isParenthesisLinkedToCursor&&a.push(xR),n.isInHoverContext&&a.push(ER),this.props.composerStore.showSelectionIndicator&&o===s&&o===n.end&&a.push(wR),t.push({value:n.value,color:r,classes:a,onHover:e=>this.onTokenHover(i,e),onStopHover:()=>this.onTokenHover(void 0)})}return t}onTokenHover(e,t){this.lastHoveredTokenIndex!==e&&(this.lastHoveredTokenIndex=e,this.debouncedHover(e,t))}splitHtmlContentIntoLines(e){const t=[];let o=[];for(const s of e)if(s.value.includes(ot)){const e=s.value.split(ot),i=e.pop();for(const i of e)o.push({color:s.color,value:i}),t.push(o),o=[];o.push({...s,value:i})}else o.push(s);o.length&&t.push(o);const s=[];for(const e of t)e.every(this.isContentEmpty)?s.push([e[0]]):s.push(e.filter((e=>!this.isContentEmpty(e))));return s}isContentEmpty(e){return!(e.value||e.classes?.length)}processTokenAtCursor(){const e=this.props.composerStore;this.functionDescriptionState.showDescription=!1;const t=this.props.composerStore.tokenAtCursor;if(uo(e.currentContent)&&t&&"SYMBOL"!==t.type){const e=t.functionContext,o=e?.parent.toUpperCase();if(e&&o&&o in yR&&"UNKNOWN"!==t.type){const s=yR[o],i=e.argPosition,n=e.args.length;this.functionDescriptionState.functionDescription=s;const r=this.props.composerStore.currentTokens.some((e=>"RIGHT_PAREN"===e.type&&e.parenthesesCode===t.parenthesesCode));this.functionDescriptionState.argsToFocus=this.getArgsToFocus(r,s,n,i),this.functionDescriptionState.showDescription=!0}}}getArgsToFocus(e,t,o,s){const{nbrArgRepeating:i,minArgRequired:n,nbrArgOptional:r,maxArgPossible:a}=t;if(e){const e=xd(t,Math.max(Math.min(a,o),n))(s);return void 0!==e?[e]:[]}const l=Math.max(o,n),c=i?n+Math.ceil((l-n)/i)*i+r:a,h=[];for(let e=l;e<=c;e++){const o=xd(t,e)(s);void 0!==o&&h.push(o)}return[...new Set(h)]}autoComplete(e){!e||this.assistant.forcedClosed&&this.props.composerStore.canBeToggled||(this.props.composerStore.insertAutoCompleteValue(e),this.processTokenAtCursor())}get displaySpeechBubble(){return!("inactive"===this.props.focus||!this.composerState.hoveredRect||!this.props.composerStore.hoveredContentEvaluation)}}class TR{lastId=0;add(e){this.lastId++;const t=this.lastId;return new Promise(((o,s)=>{e.then((e=>{this.lastId===t&&o(e)})).catch((e=>{this.lastId===t&&s(e)}))}))}}function AR(e,t,o){const{x:s,y:i,width:n,height:r}=o;if(n<0||r<0)return;const a=t.color||A,{ctx:l}=e;l.save(),t.noBorder||(t.dashed&&l.setLineDash([5,3]),l.strokeStyle=a,t.thinLine?(l.lineWidth=1,l.strokeRect(s,i,n,r)):(l.lineWidth=2,l.strokeRect(s+.5,i+.5,n,r))),t.noFill||(l.fillStyle=Bs(_s(a),t.fillAlpha??.12),l.fillRect(s,i,n,r)),l.restore()}class DR extends Lh{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.range.sheetId===e)).map((e=>{const{numberOfRows:t,numberOfCols:o}=os(e.range.zone),s=t*o==1?this.getters.expandZone(e.range.sheetId,e.range.zone):e.range.unboundedZone;return{...e,range:this.model.getters.getRangeFromZone(e.range.sheetId,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){AR(e,t,this.getters.getVisibleRect(t.range.zone))}}}class _R{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}}class FR extends Lh{mutators=["useProvider","moveSelection","hide","selectIndex"];selectedIndex=void 0;provider;get selectedProposal(){if(void 0!==this.selectedIndex&&void 0!==this.provider)return this.provider.proposals[this.selectedIndex]}useProvider(e){this.provider=e,this.selectedIndex=e.autoSelectFirstProposal?0:void 0}hide(){this.provider=void 0,this.selectedIndex=void 0}selectIndex(e){this.selectedIndex=e}moveSelection(e){this.provider&&(void 0!==this.selectedIndex?"previous"===e?(this.selectedIndex--,this.selectedIndex<0&&(this.selectedIndex=this.provider.proposals.length-1)):this.selectedIndex=(this.selectedIndex+1)%this.provider.proposals.length:this.selectedIndex=0)}}class OR extends Lh{mutators=["startEdition","setCurrentContent","stopEdition","stopComposerRangeSelection","cancelEdition","cycleReferences","hideHelp","autoCompleteOrStop","insertAutoCompleteValue","moveAutoCompleteSelection","selectAutoCompleteIndex","toggleEditionMode","changeComposerCursorSelection","replaceComposerCursorSelection","hoverToken"];col=0;row=0;editionMode="inactive";sheetId="";_currentContent="";currentTokens=[];selectionStart=0;selectionEnd=0;initialContent="";colorIndexByRange={};autoComplete=new FR(this.get);hoveredTokens=[];hoveredContentEvaluation="";autoCompleteKeepLast=new TR;notificationStore=this.get(_R);highlightStore=this.get(DR);constructor(e){super(e),this.highlightStore.register(this),this.onDispose((()=>{this.highlightStore.unRegister(this)}))}handleEvent(e){this.hideHelp();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(),this.updateAutoCompleteProvider())}stopComposerRangeSelection(){this.isSelectingRange&&(this.editionMode="editing")}startEdition(e,t){const{col:o,row:s}=this.getters.getActivePosition();this.model.dispatch("SELECT_FIGURE",{figureId: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(),this.updateAutoCompleteProvider()}cancelEdition(){this.resetContent(),this.cancelEditionAndActivateSheet()}setCurrentContent(e,t){t&&!this.isSelectionValid(e.length,t.start,t.end)||(this.setContent(e,t,!0),this.updateTokenColor(),this.computeFormulaCursorContext(),this.computeParenthesisRelatedToCursor())}replaceComposerCursorSelection(e){this.replaceSelection(e)}handle(e){switch(e.type){case"SELECT_FIGURE":e.figureId&&(this.resetContent(),this.cancelEditionAndActivateSheet());break;case"START_CHANGE_HIGHLIGHT":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()).text: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))}get autoCompleteProposals(){return this.autoComplete.provider?.proposals||[]}get autoCompleteSelectedIndex(){return this.autoComplete.selectedIndex}get isAutoCompleteDisplayed(){return!!this.autoComplete.provider}get canBeToggled(){return this.autoComplete.provider?.canBeToggled??!0}cycleReferences(){const e=this.getters.getLocale(),t=ib(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}=Ta(o.value),i=this.getters.getSheetIdByName(t);i&&i!==e&&this.model.dispatch("ACTIVATE_SHEET",{sheetIdFrom:e,sheetIdTo:i}),this.selectionStart=this.selectionEnd=o.end;const n=this.getters.getRangeFromSheetXC(this.sheetId,s).zone;this.captureSelection(n),this.editionMode="selecting"}else this.editionMode="editing"}hoverToken(e){this.currentTokens.forEach((e=>e.isInHoverContext=void 0));const t=[...this.currentTokens];if(void 0===e||["ARG_SEPARATOR","SPACE"].includes(t[e].type))return this.hoveredContentEvaluation="",void(this.hoveredTokens=[]);const o=this.getNumberOfMissingParenthesis(t);o>0&&t.push(...Array(o).fill({value:")",type:"RIGHT_PAREN"}));let s=t;if(0!==e){const o=this.getRelatedTokens(t,e),i=t.filter((e=>!o.includes(e)&&"SPACE"!==e.type));s=1===i.length&&i[0]===t[0]?t:o}s.forEach((e=>e.isInHoverContext=!0));let i=s.map((e=>e.value)).join("");uo(i)||(i=`=${i}`);const n=Bl(i,this.getters.getLocale()),r=this.getters.evaluateFormulaResult(this.sheetId,n);this.hoveredTokens=s,this.hoveredContentEvaluation=this.evaluationResultToDisplayString(r)}getRelatedTokens(e,t){try{const o=jv(e);let s;for(const e of Xv(o))if(t>=e.tokenStartIndex&&t<=e.tokenEndIndex)s=e;else if(t<e.tokenStartIndex)break;return s?e.slice(s.tokenStartIndex,s.tokenEndIndex+1):e}catch(t){if(t instanceof rn)return e;throw t}}evaluationResultToDisplayString(e){const t=this.getters.getLocale();if(E(e)){const o=","===t.decimalSeparator?"/":",";return`{${Hn(e).map((e=>e.map((e=>this.cellValueToDisplayString(e))).join(o))).join(";")}}`}return this.cellValueToDisplayString(e)}cellValueToDisplayString(e){const t=e.value;switch(typeof t){case"number":return Rr(t,{locale:this.getters.getLocale(),format:e.format});case"string":return fn(t)?t:`"${t}"`;case"boolean":return t?"TRUE":"FALSE"}return"0"}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=cs({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("%")&&Qi(e,s)&&(t=t||{start:e.length,end:e.length},e=`${e}%`);const{col:i,row:n,sheetId:r}=this.getters.getActivePosition();this.col=i,this.sheetId=r,this.row=n,this.editionMode="editing";const{text:a,adjustedSelection:l}=this.getComposerContent({sheetId:r,col:i,row:n},t);this.initialContent=a,this.setContent(e||this.initialContent,l??t),this.colorIndexByRange={};const c=cs({col:this.col,row:this.row});this.captureSelection(c,i,n)}_stopEdition(){if("inactive"!==this.editionMode){this.cancelEditionAndActivateSheet();let e=this.getCurrentCanonicalContent();if(!(this.initialContent!==e))return;if(e&&uo(e)){const t=this.getNumberOfMissingParenthesis(this.currentTokens);t>0&&(e+=Lt(new Array(t).fill(")")))}this.confirmEdition(e)}}getCurrentCanonicalContent(){return Bl(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={},this.hoveredTokens=[],this.hoveredContentEvaluation="")}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=uo(e)?Qv(e,t):[];this.currentTokens.filter((e=>"SPACE"!==e.type)).length>1e3&&o&&this.notificationStore.raiseError(ui("This formula has over 1000 parts. It can't be processed properly, consider splitting it into multiple cells"))}this.canStartComposerRangeSelection()&&this.startComposerRangeSelection(),this.updateAutoCompleteProvider()}getAutoCompleteProviders(){return Rd.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}=Ta(t.value),n=i||this.getters.getSheetName(this.sheetId);if(!Ma(this.getters.getSheetName(o),n))return!1;const r=this.getters.getRangeFromSheetXC(o,s);return Ko(this.getters.expandZone(o,r.zone),e)}));if(!i)return;const n=this.getters.getRangeFromSheetXC(o,i.value);this.selectionStart=i.start,this.selectionEnd=this.selectionStart+i.value.length;const r=this.getters.getRangeFromZone(o,t),a=this.getRangeReference(r,n.parts);this.replaceSelection(a)}getZoneReference(e){const t=this.sheetId,o=this.getters.getActiveSheetId(),s=this.getters.getRangeFromZone(o,e);return this.getters.getSelectionRangeString(s,t)}getRangeReference(e,t){const o={...e,parts:[...t]};return this.getters.getSelectionRangeString(o,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}=Ta(e.value);return this.rangeColor(t,o)||lt}if("SYMBOL"===e.type){const t=e.value.toUpperCase();if("TRUE"===t||"FALSE"===t)return ht.NUMBER;if(t in AC.content)return ht.FUNCTION}return["LEFT_PAREN","RIGHT_PAREN"].includes(e.type)&&""===e.parenthesesCode?ht.ORPHAN_RIGHT_PAREN:ht[e.type]||lt}rangeColor(e,t){const o=t?this.model.getters.getSheetIdByName(t):this.sheetId,s=this.highlights.find((t=>{if(t.range.sheetId!==o)return!1;let s=this.model.getters.getRangeFromSheetXC(o,e).zone;return s=1===gs(s)?this.model.getters.expandZone(o,s):s,Ko(s,t.range.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(!uo(this._currentContent)||"inactive"===this.editionMode)return;const e=this.sheetId,t=this.getReferencedRanges().map((t=>this.getters.getRangeString(t,e))),o={};for(const e of t)void 0!==this.colorIndexByRange[e]&&(o[e]=this.colorIndexByRange[e]);const s=new Set(Object.values(o));let i=0;const n=()=>{for(;s.has(i);)i++;return s.add(i),i};for(const e of t){const t=e in o?o[e]:n();o[e]=t}this.colorIndexByRange=o}get highlights(){if(!uo(this.currentContent)||"inactive"===this.editionMode)return[];const e=this.sheetId,t=e=>{const t=this.colorIndexByRange[e];return Ts[t%Ts.length]};return this.getReferencedRanges().map((o=>{const s=this.getters.getRangeString(o,e),{numberOfRows:i,numberOfCols:n}=os(o.zone),r=i*n==1?this.getters.expandZone(o.sheetId,o.zone):o.unboundedZone;return{range:this.model.getters.getRangeFromZone(o.sheetId,r),color:t(s),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))}async updateAutoCompleteProvider(){this.autoComplete.hide();const e=await this.autoCompleteKeepLast.add(this.findAutocompleteProvider());e&&(this.autoComplete.useProvider(e),this.model.trigger("update"))}async findAutocompleteProvider(){const e=this.currentContent,t=uo(e)?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=await e.getProposals();const s=o?.find((e=>e.text===t.value)),i=t.value.replace(/[ ,\(\)]/g,"");if(this._currentContent===this.initialContent&&e.displayAllOnInitialContent&&o?.length)return{proposals:o,selectProposal:e.selectProposal,autoSelectFirstProposal:e.autoSelectFirstProposal??!1,canBeToggled:e.canBeToggled};if(s&&this._currentContent!==this.initialContent)return;if(i&&o&&!["ARG_SEPARATOR","LEFT_PAREN","OPERATOR"].includes(t.type)){const e=el(i,o,(e=>e.fuzzySearchKey||e.text));s&&!e.length||(o=e)}if(e.maxDisplayedProposals&&(o=o?.slice(0,e.maxDisplayedProposals)),o?.length)return{proposals:o,selectProposal:e.selectProposal,autoSelectFirstProposal:e.autoSelectFirstProposal??!1,canBeToggled:e.canBeToggled}}}hideHelp(){this.autoComplete.hide()}autoCompleteOrStop(e){if("inactive"!==this.editionMode){const t=this.autoComplete;if(t.provider&&void 0!==t.selectedIndex){const e=t.provider.proposals[t.selectedIndex]?.text;if(e)return void this.autoComplete.provider?.selectProposal(e)}this.stopEdition(e)}}insertAutoCompleteValue(e){this.autoComplete.provider?.selectProposal(e)}selectAutoCompleteIndex(e){this.autoComplete.selectIndex(St(0,e,10))}moveAutoCompleteSelection(e){this.autoComplete.moveSelection(e)}canStartComposerRangeSelection(){if(uo(this._currentContent)){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)||wl.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}getNumberOfMissingParenthesis(e){return e.filter((e=>"LEFT_PAREN"===e.type)).length-e.filter((e=>"RIGHT_PAREN"===e.type)).length}}class PR extends OR{args;constructor(e,t){super(e),this.args=t,this._currentContent=this.getComposerContent().text}getAutoCompleteProviders(){const e=super.getAutoCompleteProviders(),t=this.args().contextualAutocomplete;return t&&e.push(t),e}getZoneReference(e){const t=super.getZoneReference(e);return this.args().defaultStatic?ob(t,"colrow"):t}getComposerContent(){let e=this._currentContent;if("inactive"===this.editionMode){const t=this.args().defaultRangeSheetId;e=Lv(this.args().content).map((e=>{if("REFERENCE"===e.type){const o=this.getters.getRangeFromSheetXC(t,e.value);return this.getters.getRangeString(o,this.getters.getActiveSheetId())}return e.value})).join("")}return{text:Gl(e,this.getters.getLocale())}}stopEdition(){this._stopEdition()}confirmEdition(e){this.args().onConfirm(e)}getTokenColor(e){if("SYMBOL"===e.type){const t=this.args().getContextualColoredSymbolToken?.(e);if(t)return t}return super.getTokenColor(e)}}Bh`
317
+ `;class RR extends t.Component{static template="o-spreadsheet-Composer";static props={focus:{validate:e=>["inactive","cellFocus","contentFocus"].includes(e)},inputStyle:{type:String,optional:!0},rect:{type:Object,optional:!0},delimitation:{type:Object,optional:!0},onComposerCellFocused:{type:Function,optional:!0},onComposerContentFocused:Function,isDefaultFocus:{type:Boolean,optional:!0},onInputContextMenu:{type:Function,optional:!0},composerStore:Object,placeholder:{type:String,optional:!0},inputMode:{type:String,optional:!0},showAssistant:{type:Boolean,optional:!0}};static components={TextValueProvider:uR,FunctionDescriptionProvider:SR,SpeechBubble:CR};static defaultProps={inputStyle:"",isDefaultFocus:!1,inputMode:"text",showAssistant:!0};DOMFocusableElementStore;composerRef=t.useRef("o_composer");contentHelper=new gR(this.composerRef.el);composerState=t.useState({positionStart:0,positionEnd:0,hoveredRect:void 0});functionDescriptionState=t.useState({showDescription:!1,functionDescription:{},argsToFocus:[]});assistant=t.useState({forcedClosed:!1});compositionActive=!1;spreadsheetRect=LE();lastHoveredTokenIndex=void 0;debouncedHover=kt(((e,t)=>{const o=this.contentHelper.getCurrentSelection();if(o.start!==o.end)return;const s=this.props.composerStore.hoveredTokens;this.props.composerStore.hoverToken(e),zt(s,this.props.composerStore.hoveredTokens)||(this.composerState.hoveredRect=t)}),120);get assistantStyleProperties(){const e=this.composerRef.el.getBoundingClientRect(),t={},o=Math.min(this.props.rect?.width||1/0,IR);t["min-width"]=`${o}px`;const s=this.props.composerStore.autoCompleteProposals,i=s?.some((e=>e.description));if((this.functionDescriptionState.showDescription||i)&&(t.width="300px"),this.props.delimitation&&this.props.rect){const{x:e,y:o,height:s}=this.props.rect,i=this.props.delimitation.height-(o+s);if(t["max-height"]=`${i}px`,o>i){const e=o;t["max-height"]=e-9+"px",t.transform=`translate(0, calc(-100% - ${s+3}px))`}e+IR>this.props.delimitation.width&&(t.right="0px")}else t["max-height"]=this.spreadsheetRect.height-e.bottom-1+"px",e.left+IR+Re+9>this.spreadsheetRect.width&&(t.right="9px");return t}get assistantStyle(){const e=this.assistantStyleProperties;return qh({"max-height":e["max-height"],width:e.width,"min-width":e["min-width"]})}get assistantContainerStyle(){const e=this.assistantStyleProperties;return qh({top:e.top,right:e.right,transform:e.transform})}shouldProcessInputEvents=!1;tokens=[];keyMapping={Enter:e=>this.processEnterKey(e,"down"),"Shift+Enter":e=>this.processEnterKey(e,"up"),"Alt+Enter":this.processNewLineEvent,"Ctrl+Enter":this.processNewLineEvent,Escape:this.processEscapeKey,F2:e=>this.toggleEditionMode(e),F4:e=>this.processF4Key(e),Tab:e=>this.processTabKey(e,"right"),"Shift+Tab":e=>this.processTabKey(e,"left")};keyCodeMapping={NumpadDecimal:this.processNumpadDecimal};setup(){this.DOMFocusableElementStore=Dh(cR),t.onMounted((()=>{const e=this.composerRef.el;this.props.isDefaultFocus&&this.DOMFocusableElementStore.setFocusableElement(e),this.contentHelper.updateEl(e)})),t.onWillUnmount((()=>{this.debouncedHover.stopDebounce()})),t.useEffect((()=>{this.processContent(),document.activeElement!==this.contentHelper.el||"inactive"!==this.props.composerStore.editionMode||this.props.isDefaultFocus||this.DOMFocusableElementStore.focus()})),t.useEffect((()=>{this.processTokenAtCursor()}),(()=>["inactive"!==this.props.composerStore.editionMode])),t.useEffect((()=>{this.contentHelper.scrollSelectionIntoView()}),(()=>[this.props.composerStore.composerSelection.start,this.props.composerStore.composerSelection.end]))}processArrowKeys(e){const t=this.props.composerStore.tokenAtCursor;if((this.props.composerStore.isSelectingRange||"inactive"===this.props.composerStore.editionMode)&&(!["ArrowUp","ArrowDown"].includes(e.key)||!this.props.composerStore.isAutoCompleteDisplayed||"REFERENCE"===t?.type))return this.functionDescriptionState.showDescription=!1,this.props.composerStore.hideHelp(),e.preventDefault(),e.stopPropagation(),void dR(e,this.env.model.selection);const o=this.props.composerStore.currentContent;"cellFocus"!==this.props.focus||this.props.composerStore.isAutoCompleteDisplayed||uo(o)?(e.stopPropagation(),this.handleArrowKeysForAutocomplete(e)):this.props.composerStore.stopEdition()}handleArrowKeysForAutocomplete(e){["ArrowUp","ArrowDown"].includes(e.key)&&this.props.composerStore.isAutoCompleteDisplayed&&(e.preventDefault(),this.props.composerStore.moveAutoCompleteSelection("ArrowDown"===e.key?"next":"previous"))}processTabKey(e,t){e.preventDefault(),e.stopPropagation(),this.assistant.forcedClosed||this.props.composerStore.autoCompleteOrStop(t)}processEnterKey(e,t){e.preventDefault(),e.stopPropagation(),this.assistant.forcedClosed||this.props.composerStore.autoCompleteOrStop(t)}processNewLineEvent(e){e.preventDefault(),e.stopPropagation();const t=this.contentHelper.getText(),o=this.contentHelper.getCurrentSelection(),s=Math.min(o.start,o.end),i=Math.max(o.start,o.end);this.props.composerStore.stopComposerRangeSelection(),this.props.composerStore.setCurrentContent(t.slice(0,s)+ot+t.slice(i),{start:s+1,end:s+1}),this.processContent()}processEscapeKey(e){this.props.composerStore.cancelEdition(),e.stopPropagation(),e.preventDefault()}processF4Key(e){e.stopPropagation(),this.props.composerStore.cycleReferences(),this.processContent()}toggleEditionMode(e){e.stopPropagation(),this.props.composerStore.toggleEditionMode(),this.processContent()}processNumpadDecimal(e){e.stopPropagation(),e.preventDefault();const t=this.env.model.getters.getLocale(),o=this.contentHelper.getCurrentSelection(),s=this.props.composerStore.currentContent,i=s.slice(0,o.start)+t.decimalSeparator+s.slice(o.end);this.props.composerStore.setCurrentContent(i,{start:o.start+1,end:o.start+1}),this.processContent()}onCompositionStart(){this.compositionActive=!0}onCompositionEnd(){this.compositionActive=!1}onKeydown(e){if("inactive"===this.props.composerStore.editionMode)return;if(e.key.startsWith("Arrow"))return void this.processArrowKeys(e);const t=this.keyMapping[xI(e)]||this.keyCodeMapping[xI(e,"code")];t?t.call(this,e):e.stopPropagation()}onPaste(e){"inactive"!==this.props.composerStore.editionMode?e.stopPropagation():e.preventDefault()}onInput(e){if(!this.shouldProcessInputEvents)return;let t;if(e.stopPropagation(),t="inactive"===this.props.composerStore.editionMode?e.data||"":this.contentHelper.getText(),"inactive"===this.props.focus)return this.props.onComposerCellFocused?.(t);const o=this.contentHelper.getCurrentSelection();this.props.composerStore.stopComposerRangeSelection(),this.props.composerStore.setCurrentContent(t,o),this.processTokenAtCursor()}onKeyup(e){if(this.contentHelper.el===document.activeElement){if(this.props.composerStore.isAutoCompleteDisplayed&&["ArrowUp","ArrowDown"].includes(e.key))return;if(this.props.composerStore.isSelectingRange&&e.key?.startsWith("Arrow"))return;const{start:t,end:o}=this.props.composerStore.composerSelection,{start:s,end:i}=this.contentHelper.getCurrentSelection();s===t&&i===o||this.props.composerStore.changeComposerCursorSelection(s,i),this.processTokenAtCursor()}}onBlur(e){if("inactive"===this.props.composerStore.editionMode)return;const t=e.relatedTarget;t&&t instanceof HTMLElement?t.attributes.getNamedItem("composerFocusableElement")?this.contentHelper.el.focus():t.classList.contains("o-composer")||this.props.composerStore.stopEdition():this.props.composerStore.stopEdition()}onMousedown(e){e.button>0||this.env.isMobile()&&!_I()||(this.debouncedHover.stopDebounce(),this.contentHelper.removeSelection())}onMouseup(){if(this.env.model.getters.isReadonly())return;const e=this.contentHelper.getCurrentSelection();e.start!==e.end&&this.props.composerStore.hoverToken(void 0)}onClick(){if(this.env.model.getters.isReadonly())return;const e=this.contentHelper.getCurrentSelection();this.props.composerStore.stopComposerRangeSelection();const t="inactive"===this.props.composerStore.editionMode;this.props.onComposerContentFocused(e),t||this.props.composerStore.changeComposerCursorSelection(e.start,e.end),this.processTokenAtCursor()}onDblClick(){if(this.env.model.getters.isReadonly())return;const e=this.props.composerStore.currentContent;if(uo(e)){const t=this.props.composerStore.currentTokens,o=this.contentHelper.getCurrentSelection();if(o.start===o.end)return;const s=e.substring(o.start,o.end),i=t.filter((e=>e.value.includes(s)&&e.start<=o.start&&e.end>=o.end))[0];if(!i)return;"REFERENCE"===i.type&&this.props.composerStore.changeComposerCursorSelection(i.start,i.end)}}onContextMenu(e){"inactive"===this.props.composerStore.editionMode&&this.props.onInputContextMenu?.(e)}closeAssistant(){this.props.composerStore.canBeToggled&&(this.assistant.forcedClosed=!0)}openAssistant(){this.props.composerStore.canBeToggled&&(this.assistant.forcedClosed=!1)}onWheel(e){this.composerRef.el&&this.composerRef.el.scrollHeight>this.composerRef.el.clientHeight&&e.stopPropagation()}processContent(){if(this.compositionActive)return;this.shouldProcessInputEvents=!1,"inactive"!==this.props.focus&&document.activeElement!==this.contentHelper.el&&this.contentHelper.el.focus();const e=this.getContentLines();if(this.contentHelper.setText(e),0!==e.length&&0!==e.length[0]&&"inactive"!==this.props.focus){const{start:e,end:t}=this.props.composerStore.composerSelection;this.contentHelper.selectRange(e,t)}this.shouldProcessInputEvents=!0}getContentLines(){const e=this.props.composerStore.currentContent,t=uo(e);return""===e?[]:t&&"inactive"!==this.props.focus?this.splitHtmlContentIntoLines(this.getHtmlContentFromTokens()):this.splitHtmlContentIntoLines([{value:e,classes:[]}])}getHtmlContentFromTokens(){const e=this.props.composerStore.currentTokens,t=[],{end:o,start:s}=this.props.composerStore.composerSelection;for(let i=0;i<e.length;i++){const n=e[i];let r=n.color||lt;n.isBlurred&&(r=Bs(r,.5));const a=[];"REFERENCE"===n.type&&this.props.composerStore.tokenAtCursor===n&&"selecting"===this.props.composerStore.editionMode&&a.push("text-decoration-underline"),o===s&&n.isParenthesisLinkedToCursor&&a.push(xR),n.isInHoverContext&&a.push(ER),this.props.composerStore.showSelectionIndicator&&o===s&&o===n.end&&a.push(wR),t.push({value:n.value,color:r,classes:a,onHover:e=>this.onTokenHover(i,e),onStopHover:()=>this.onTokenHover(void 0)})}return t}onTokenHover(e,t){this.lastHoveredTokenIndex!==e&&(this.lastHoveredTokenIndex=e,this.debouncedHover(e,t))}splitHtmlContentIntoLines(e){const t=[];let o=[];for(const s of e)if(s.value.includes(ot)){const e=s.value.split(ot),i=e.pop();for(const i of e)o.push({color:s.color,value:i}),t.push(o),o=[];o.push({...s,value:i})}else o.push(s);o.length&&t.push(o);const s=[];for(const e of t)e.every(this.isContentEmpty)?s.push([e[0]]):s.push(e.filter((e=>!this.isContentEmpty(e))));return s}isContentEmpty(e){return!(e.value||e.classes?.length)}processTokenAtCursor(){const e=this.props.composerStore;this.functionDescriptionState.showDescription=!1;const t=this.props.composerStore.tokenAtCursor;if(uo(e.currentContent)&&t&&"SYMBOL"!==t.type){const e=t.functionContext,o=e?.parent.toUpperCase();if(e&&o&&o in yR&&"UNKNOWN"!==t.type){const s=yR[o],i=e.argPosition,n=e.args.length;this.functionDescriptionState.functionDescription=s;const r=this.props.composerStore.currentTokens.some((e=>"RIGHT_PAREN"===e.type&&e.parenthesesCode===t.parenthesesCode));this.functionDescriptionState.argsToFocus=this.getArgsToFocus(r,s,n,i),this.functionDescriptionState.showDescription=!0}}}getArgsToFocus(e,t,o,s){const{nbrArgRepeating:i,minArgRequired:n,nbrArgOptional:r,maxArgPossible:a}=t;if(e){const e=xd(t,Math.max(Math.min(a,o),n))(s);return void 0!==e?[e]:[]}const l=Math.max(o,n),c=i?n+Math.ceil((l-n)/i)*i+r:a,h=[];for(let e=l;e<=c;e++){const o=xd(t,e)(s);void 0!==o&&h.push(o)}return[...new Set(h)]}autoComplete(e){!e||this.assistant.forcedClosed&&this.props.composerStore.canBeToggled||(this.props.composerStore.insertAutoCompleteValue(e),this.processTokenAtCursor())}get displaySpeechBubble(){return!("inactive"===this.props.focus||!this.composerState.hoveredRect||!this.props.composerStore.hoveredContentEvaluation)}}class TR{lastId=0;add(e){this.lastId++;const t=this.lastId;return new Promise(((o,s)=>{e.then((e=>{this.lastId===t&&o(e)})).catch((e=>{this.lastId===t&&s(e)}))}))}}function AR(e,t,o){const{x:s,y:i,width:n,height:r}=o;if(n<0||r<0)return;const a=t.color||A,{ctx:l}=e;l.save(),t.noBorder||(t.dashed&&l.setLineDash([5,3]),l.strokeStyle=a,t.thinLine?(l.lineWidth=1,l.strokeRect(s,i,n,r)):(l.lineWidth=2,l.strokeRect(s+.5,i+.5,n,r))),t.noFill||(l.fillStyle=Bs(_s(a),t.fillAlpha??.12),l.fillRect(s,i,n,r)),l.restore()}class DR extends Lh{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.range.sheetId===e)).map((e=>{const{numberOfRows:t,numberOfCols:o}=os(e.range.zone),s=t*o==1?this.getters.expandZone(e.range.sheetId,e.range.zone):e.range.unboundedZone;return{...e,range:this.model.getters.getRangeFromZone(e.range.sheetId,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){AR(e,t,this.getters.getVisibleRect(t.range.zone))}}}class _R{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}}class FR extends Lh{mutators=["useProvider","moveSelection","hide","selectIndex"];selectedIndex=void 0;provider;get selectedProposal(){if(void 0!==this.selectedIndex&&void 0!==this.provider)return this.provider.proposals[this.selectedIndex]}useProvider(e){this.provider=e,this.selectedIndex=e.autoSelectFirstProposal?0:void 0}hide(){this.provider=void 0,this.selectedIndex=void 0}selectIndex(e){this.selectedIndex=e}moveSelection(e){this.provider&&(void 0!==this.selectedIndex?"previous"===e?(this.selectedIndex--,this.selectedIndex<0&&(this.selectedIndex=this.provider.proposals.length-1)):this.selectedIndex=(this.selectedIndex+1)%this.provider.proposals.length:this.selectedIndex=0)}}class OR extends Lh{mutators=["startEdition","setCurrentContent","stopEdition","stopComposerRangeSelection","cancelEdition","cycleReferences","hideHelp","autoCompleteOrStop","insertAutoCompleteValue","moveAutoCompleteSelection","selectAutoCompleteIndex","toggleEditionMode","changeComposerCursorSelection","replaceComposerCursorSelection","hoverToken"];col=0;row=0;editionMode="inactive";sheetId="";_currentContent="";currentTokens=[];selectionStart=0;selectionEnd=0;initialContent="";colorIndexByRange={};autoComplete=new FR(this.get);hoveredTokens=[];hoveredContentEvaluation="";autoCompleteKeepLast=new TR;notificationStore=this.get(_R);highlightStore=this.get(DR);constructor(e){super(e),this.highlightStore.register(this),this.onDispose((()=>{this.highlightStore.unRegister(this),this._cancelEdition()}))}handleEvent(e){this.hideHelp();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(),this.updateAutoCompleteProvider())}stopComposerRangeSelection(){this.isSelectingRange&&(this.editionMode="editing")}startEdition(e,t){const{col:o,row:s}=this.getters.getActivePosition();this.model.dispatch("SELECT_FIGURE",{figureId: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(),this.updateAutoCompleteProvider()}cancelEdition(){this.resetContent(),this.cancelEditionAndActivateSheet()}setCurrentContent(e,t){t&&!this.isSelectionValid(e.length,t.start,t.end)||(this.setContent(e,t,!0),this.updateTokenColor(),this.computeFormulaCursorContext(),this.computeParenthesisRelatedToCursor())}replaceComposerCursorSelection(e){this.replaceSelection(e)}handle(e){switch(e.type){case"SELECT_FIGURE":e.figureId&&(this.resetContent(),this.cancelEditionAndActivateSheet());break;case"START_CHANGE_HIGHLIGHT":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()).text: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))}get autoCompleteProposals(){return this.autoComplete.provider?.proposals||[]}get autoCompleteSelectedIndex(){return this.autoComplete.selectedIndex}get isAutoCompleteDisplayed(){return!!this.autoComplete.provider}get canBeToggled(){return this.autoComplete.provider?.canBeToggled??!0}cycleReferences(){const e=this.getters.getLocale(),t=ib(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}=Ta(o.value),i=this.getters.getSheetIdByName(t);i&&i!==e&&this.model.dispatch("ACTIVATE_SHEET",{sheetIdFrom:e,sheetIdTo:i}),this.selectionStart=this.selectionEnd=o.end;const n=this.getters.getRangeFromSheetXC(this.sheetId,s).zone;this.captureSelection(n),this.editionMode="selecting"}else this.editionMode="editing"}hoverToken(e){this.currentTokens.forEach((e=>e.isInHoverContext=void 0));const t=[...this.currentTokens];if(void 0===e||["ARG_SEPARATOR","SPACE"].includes(t[e].type))return this.hoveredContentEvaluation="",void(this.hoveredTokens=[]);const o=this.getNumberOfMissingParenthesis(t);o>0&&t.push(...Array(o).fill({value:")",type:"RIGHT_PAREN"}));let s=t;if(0!==e){const o=this.getRelatedTokens(t,e),i=t.filter((e=>!o.includes(e)&&"SPACE"!==e.type));s=1===i.length&&i[0]===t[0]?t:o}s.forEach((e=>e.isInHoverContext=!0));let i=s.map((e=>e.value)).join("");uo(i)||(i=`=${i}`);const n=Bl(i,this.getters.getLocale()),r=this.getters.evaluateFormulaResult(this.sheetId,n);this.hoveredTokens=s,this.hoveredContentEvaluation=this.evaluationResultToDisplayString(r)}getRelatedTokens(e,t){try{const o=jv(e);let s;for(const e of Xv(o))if(t>=e.tokenStartIndex&&t<=e.tokenEndIndex)s=e;else if(t<e.tokenStartIndex)break;return s?e.slice(s.tokenStartIndex,s.tokenEndIndex+1):e}catch(t){if(t instanceof rn)return e;throw t}}evaluationResultToDisplayString(e){const t=this.getters.getLocale();if(E(e)){const o=","===t.decimalSeparator?"/":",";return`{${Hn(e).map((e=>e.map((e=>this.cellValueToDisplayString(e))).join(o))).join(";")}}`}return this.cellValueToDisplayString(e)}cellValueToDisplayString(e){const t=e.value;switch(typeof t){case"number":return Rr(t,{locale:this.getters.getLocale(),format:e.format});case"string":return fn(t)?t:`"${t}"`;case"boolean":return t?"TRUE":"FALSE"}return"0"}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=cs({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("%")&&Qi(e,s)&&(t=t||{start:e.length,end:e.length},e=`${e}%`);const{col:i,row:n,sheetId:r}=this.getters.getActivePosition();this.col=i,this.sheetId=r,this.row=n,this.editionMode="editing";const{text:a,adjustedSelection:l}=this.getComposerContent({sheetId:r,col:i,row:n},t);this.initialContent=a,this.setContent(e||this.initialContent,l??t),this.colorIndexByRange={};const c=cs({col:this.col,row:this.row});this.captureSelection(c,i,n)}_stopEdition(){if("inactive"!==this.editionMode){this.cancelEditionAndActivateSheet();let e=this.getCurrentCanonicalContent();if(!(this.initialContent!==e))return;if(e&&uo(e)){const t=this.getNumberOfMissingParenthesis(this.currentTokens);t>0&&(e+=Lt(new Array(t).fill(")")))}this.confirmEdition(e)}}getCurrentCanonicalContent(){return Bl(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={},this.hoveredTokens=[],this.hoveredContentEvaluation="")}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=uo(e)?Qv(e,t):[];this.currentTokens.filter((e=>"SPACE"!==e.type)).length>1e3&&o&&this.notificationStore.raiseError(ui("This formula has over 1000 parts. It can't be processed properly, consider splitting it into multiple cells"))}this.canStartComposerRangeSelection()&&this.startComposerRangeSelection(),this.updateAutoCompleteProvider()}getAutoCompleteProviders(){return Rd.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}=Ta(t.value),n=i||this.getters.getSheetName(this.sheetId);if(!Ma(this.getters.getSheetName(o),n))return!1;const r=this.getters.getRangeFromSheetXC(o,s);return Ko(this.getters.expandZone(o,r.zone),e)}));if(!i)return;const n=this.getters.getRangeFromSheetXC(o,i.value);this.selectionStart=i.start,this.selectionEnd=this.selectionStart+i.value.length;const r=this.getters.getRangeFromZone(o,t),a=this.getRangeReference(r,n.parts);this.replaceSelection(a)}getZoneReference(e){const t=this.sheetId,o=this.getters.getActiveSheetId(),s=this.getters.getRangeFromZone(o,e);return this.getters.getSelectionRangeString(s,t)}getRangeReference(e,t){const o={...e,parts:[...t]};return this.getters.getSelectionRangeString(o,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}=Ta(e.value);return this.rangeColor(t,o)||lt}if("SYMBOL"===e.type){const t=e.value.toUpperCase();if("TRUE"===t||"FALSE"===t)return ht.NUMBER;if(t in AC.content)return ht.FUNCTION}return["LEFT_PAREN","RIGHT_PAREN"].includes(e.type)&&""===e.parenthesesCode?ht.ORPHAN_RIGHT_PAREN:ht[e.type]||lt}rangeColor(e,t){const o=t?this.model.getters.getSheetIdByName(t):this.sheetId,s=this.highlights.find((t=>{if(t.range.sheetId!==o)return!1;let s=this.model.getters.getRangeFromSheetXC(o,e).zone;return s=1===gs(s)?this.model.getters.expandZone(o,s):s,Ko(s,t.range.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(!uo(this._currentContent)||"inactive"===this.editionMode)return;const e=this.sheetId,t=this.getReferencedRanges().map((t=>this.getters.getRangeString(t,e))),o={};for(const e of t)void 0!==this.colorIndexByRange[e]&&(o[e]=this.colorIndexByRange[e]);const s=new Set(Object.values(o));let i=0;const n=()=>{for(;s.has(i);)i++;return s.add(i),i};for(const e of t){const t=e in o?o[e]:n();o[e]=t}this.colorIndexByRange=o}get highlights(){if(!uo(this.currentContent)||"inactive"===this.editionMode)return[];const e=this.sheetId,t=e=>{const t=this.colorIndexByRange[e];return Ts[t%Ts.length]};return this.getReferencedRanges().map((o=>{const s=this.getters.getRangeString(o,e),{numberOfRows:i,numberOfCols:n}=os(o.zone),r=i*n==1?this.getters.expandZone(o.sheetId,o.zone):o.unboundedZone;return{range:this.model.getters.getRangeFromZone(o.sheetId,r),color:t(s),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))}async updateAutoCompleteProvider(){this.autoComplete.hide();const e=await this.autoCompleteKeepLast.add(this.findAutocompleteProvider());e&&(this.autoComplete.useProvider(e),this.model.trigger("update"))}async findAutocompleteProvider(){const e=this.currentContent,t=uo(e)?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=await e.getProposals();const s=o?.find((e=>e.text===t.value)),i=t.value.replace(/[ ,\(\)]/g,"");if(this._currentContent===this.initialContent&&e.displayAllOnInitialContent&&o?.length)return{proposals:o,selectProposal:e.selectProposal,autoSelectFirstProposal:e.autoSelectFirstProposal??!1,canBeToggled:e.canBeToggled};if(s&&this._currentContent!==this.initialContent)return;if(i&&o&&!["ARG_SEPARATOR","LEFT_PAREN","OPERATOR"].includes(t.type)){const e=el(i,o,(e=>e.fuzzySearchKey||e.text));s&&!e.length||(o=e)}if(e.maxDisplayedProposals&&(o=o?.slice(0,e.maxDisplayedProposals)),o?.length)return{proposals:o,selectProposal:e.selectProposal,autoSelectFirstProposal:e.autoSelectFirstProposal??!1,canBeToggled:e.canBeToggled}}}hideHelp(){this.autoComplete.hide()}autoCompleteOrStop(e){if("inactive"!==this.editionMode){const t=this.autoComplete;if(t.provider&&void 0!==t.selectedIndex){const e=t.provider.proposals[t.selectedIndex]?.text;if(e)return void this.autoComplete.provider?.selectProposal(e)}this.stopEdition(e)}}insertAutoCompleteValue(e){this.autoComplete.provider?.selectProposal(e)}selectAutoCompleteIndex(e){this.autoComplete.selectIndex(St(0,e,10))}moveAutoCompleteSelection(e){this.autoComplete.moveSelection(e)}canStartComposerRangeSelection(){if(uo(this._currentContent)){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)||wl.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}getNumberOfMissingParenthesis(e){return e.filter((e=>"LEFT_PAREN"===e.type)).length-e.filter((e=>"RIGHT_PAREN"===e.type)).length}}class PR extends OR{args;constructor(e,t){super(e),this.args=t,this._currentContent=this.getComposerContent().text}getAutoCompleteProviders(){const e=super.getAutoCompleteProviders(),t=this.args().contextualAutocomplete;return t&&e.push(t),e}getZoneReference(e){const t=super.getZoneReference(e);return this.args().defaultStatic?ob(t,"colrow"):t}getComposerContent(){let e=this._currentContent;if("inactive"===this.editionMode){const t=this.args().defaultRangeSheetId;e=Lv(this.args().content).map((e=>{if("REFERENCE"===e.type){const o=this.getters.getRangeFromSheetXC(t,e.value);return this.getters.getRangeString(o,this.getters.getActiveSheetId())}return e.value})).join("")}return{text:Gl(e,this.getters.getLocale())}}stopEdition(){this._stopEdition()}confirmEdition(e){this.args().onConfirm(e)}getTokenColor(e){if("SYMBOL"===e.type){const t=this.args().getContextualColoredSymbolToken?.(e);if(t)return t}return super.getTokenColor(e)}}Bh`
318
318
  .o-spreadsheet {
319
319
  .o-standalone-composer {
320
320
  min-height: 24px;
@@ -985,7 +985,7 @@
985
985
  height: ${Ie}px;
986
986
  }
987
987
  }
988
- `;class GN extends t.Component{static props={onOpenContextMenu:Function};static template="o-spreadsheet-HeadersOverlay";static components={ColResizer:BN,RowResizer:$N};selectAll(){this.env.model.selection.selectAll()}}class WN extends Lh{fingerprints;hoveredTables;hoveredIcon;lastRenderBoxes=new Map;preventNewAnimationsInNextFrame=!1;zonesWithPreventedAnimationsInNextFrame=[];animations=new Map;constructor(e){super(e),this.getters=e(Mh).getters,this.fingerprints=e(oF),this.hoveredTables=e(MN),this.hoveredIcon=e(NN)}handle(e){switch(e.type){case"START":case"ACTIVATE_SHEET":case"ADD_COLUMNS_ROWS":case"REMOVE_COLUMNS_ROWS":this.animations.clear(),this.preventNewAnimationsInNextFrame=!0;break;case"RESIZE_COLUMNS_ROWS":this.preventNewAnimationsInNextFrame=!0;break;case"REDO":this.zonesWithPreventedAnimationsInNextFrame=[];break;case"UNDO":for(const t of e.commands)if("ADD_COLUMNS_ROWS"===t.type||"REMOVE_COLUMNS_ROWS"===t.type||"RESIZE_COLUMNS_ROWS"===t.type){this.animations.clear(),this.preventNewAnimationsInNextFrame=!0;break}break;case"PASTE":this.zonesWithPreventedAnimationsInNextFrame.push(...this.getters.getSelectedZones());break;case"UPDATE_CELL":const t=this.getters.getCommandZones(e);this.zonesWithPreventedAnimationsInNextFrame.push(...t)}}get renderingLayers(){return["Background","Headers"]}drawLayer(e,t,o){switch(t){case"Background":this.drawGlobalBackground(e);const t=this.lastRenderBoxes;this.lastRenderBoxes=new Map;for(const{zone:s,rect:i}of this.getters.getAllActiveViewportsZonesAndRect()){const{ctx:n}=e;n.save(),n.beginPath(),n.rect(i.x,i.y,i.width,i.height),n.clip();const r=this.getGridBoxes(s),a=this.getBoxesWithAnimations(r,t,o);this.drawBackground(e,a),this.drawOverflowingCellBackground(e,a),this.drawCellBackground(e,a),this.drawBorders(e,a),this.drawTexts(e,a),this.drawIcon(e,a),n.restore()}this.drawFrozenPanes(e),this.preventNewAnimationsInNextFrame=!1,this.zonesWithPreventedAnimationsInNextFrame=[];break;case"Headers":this.getters.isDashboard()||(this.drawHeaders(e),this.drawFrozenPanesHeaders(e))}}drawGlobalBackground(e){const{ctx:t}=e,{width:o,height:s}=this.getters.getSheetViewDimensionWithHeaders();t.fillStyle="#ffffff",t.fillRect(0,0,o+T,s+T)}drawBackground(e,t){const{ctx:o,thinLineWidth:s}=e,i=!this.getters.isDashboard()&&this.getters.getGridLinesVisibility(this.getters.getActiveSheetId()),n=i?.1*s:0;if(i)for(const e of t)e.skipCellGridLines||(o.strokeStyle="#E2E3E3",o.lineWidth=s,o.strokeRect(e.x+n,e.y+n,e.width-2*n,e.height-2*n))}drawCellBackground(e,t){const{ctx:o}=e;for(const e of t){const t=e.style;if(t.fillColor&&"#ffffff"!==t.fillColor&&(o.fillStyle=t.fillColor||"#ffffff",o.fillRect(e.x,e.y,e.width,e.height)),e.dataBarFill){o.fillStyle=e.dataBarFill.color;const t=e.dataBarFill.percentage,s=e.width*(t/100);o.fillRect(e.x,e.y,s,e.height)}if(e?.chip){o.save(),o.beginPath(),o.rect(e.x,e.y,e.width,e.height),o.clip();const t=e.chip;o.fillStyle=t.color;const s=10;o.beginPath(),o.roundRect(t.x,t.y,t.width,t.height,s),o.fill(),o.restore()}e.overlayColor&&(o.fillStyle=e.overlayColor,o.fillRect(e.x,e.y,e.width,e.height)),e.isError&&(o.fillStyle="red",o.beginPath(),o.moveTo(e.x+e.width-5,e.y),o.lineTo(e.x+e.width,e.y),o.lineTo(e.x+e.width,e.y+5),o.fill())}}drawOverflowingCellBackground(e,t){const{ctx:o,thinLineWidth:s}=e;for(const e of t)if(e.content&&e.isOverflow){const t=e.content.align||"left";let i,n;const r=e.y+s/2,a=e.height-s,l=Math.min(e.clipRect?.width||1/0,e.content.width);"left"===t?(i=e.x+s/2,n=l-2*s):"right"===t?(i=e.x+e.width-s/2,n=2*s-l):(i=(e.clipRect?.x||e.x+e.width/2-e.content.width/2)+s/2,n=l-2*s),o.fillStyle="#ffffff",o.fillRect(i,r,n,a)}}drawBorders(e,t){const{ctx:o}=e;for(const e of t){const t=e.border;if(t){const{x:o,y:i,width:n,height:r}=e;t.left&&s(t.left,o,i,o,i+r),t.top&&s(t.top,o,i,o+n,i),t.right&&s(t.right,o+n,i,o+n,i+r),t.bottom&&s(t.bottom,o,i+r,o+n,i+r)}}function s({color:e,style:t,opacity:s},i,n,r,a){switch(o.globalAlpha=s??1,o.strokeStyle=e,t){case"medium":o.lineWidth=2,n+=(i+=n===a?-.5:.5)===(r+=n===a?1.5:.5)?-.5:.5,a+=i===r?1.5:.5;break;case"thick":o.lineWidth=3,n===a&&(i--,r++),i===r&&(n--,a++);break;case"dashed":o.lineWidth=1,o.setLineDash([1,3]);break;case"dotted":o.lineWidth=1,n===a&&(i+=.5,r+=.5),i===r&&(n+=.5,a+=.5),o.setLineDash([1,1]);break;default:o.lineWidth=1}o.beginPath(),o.moveTo(i,n),o.lineTo(r,a),o.stroke(),o.lineWidth=1,o.setLineDash([]),o.globalAlpha=1}}drawTexts(e,t){const{ctx:o}=e;let s;o.textBaseline="top";for(const e of t)if(e.content){o.globalAlpha=e.textOpacity??1;const t=e.style||{},i=e.content.align||"left",n=hl(t);if(n!==s&&(s=n,o.font=n),o.fillStyle=t.textColor||"#000",o.textAlign=i,e.clipRect){o.save(),o.beginPath();const{x:t,y:s,width:i,height:n}=e.clipRect;o.rect(t,s,i,n),o.clip()}const r=e.content.x;let a=e.content.y;for(const s of e.content.textLines)vl(o,s,{x:r,y:a},t.underline,t.strikethrough),a+=Te+e.content.fontSizePx;e.clipRect&&o.restore(),o.globalAlpha=1}}drawIcon(e,t){const{ctx:o}=e;for(const e of t)for(const t of Object.values(e.icons)){if(!t)continue;const s=zt({id:t.type,position:t.position},this.hoveredIcon.hoveredIcon)&&t.hoverSvg||t.svg;if(!s)continue;o.save(),o.globalAlpha=t.opacity??1,o.beginPath();const i=t.clipRect||e;o.rect(i.x,i.y,i.width,i.height),o.clip();const n=t.size,{x:r,y:a}=this.getters.getCellIconRect(t,e);o.translate(r,a),o.scale(n/s.width,n/s.height);for(const e of s.paths)o.fillStyle=e.fillColor,o.fill(gA(e.path));o.restore()}}drawHeaders(e){const{ctx:t,thinLineWidth:o}=e,s=this.getters.getSheetViewVisibleCols(),i=s[0],n=this.getters.getSheetViewVisibleRows(),r=n[0],{width:a,height:l}=this.getters.getSheetViewDimensionWithHeaders(),c=this.getters.getSelectedZones(),h=function(e){const t=new Set;for(const o of Fo(e))for(const e of Ct(o.left,o.right+1))t.add(e);return t}(c),d=function(e){const t=new Set;for(const o of Fo(e))for(const e of Ct(o.top,o.bottom+1))t.add(e);return t}(c),u=this.getters.getActiveSheetId(),g=this.getters.getNumberCols(u),p=this.getters.getNumberRows(u),m=this.getters.getActiveCols(),f=this.getters.getActiveRows();t.font=`400 11px ${Le}`,t.textAlign="center",t.textBaseline="middle",t.lineWidth=o,t.strokeStyle="#333";for(const e of s){const o={left:e,right:e,top:0,bottom:p-1},{x:s,width:i}=this.getters.getVisibleRect(o),n=m.has(e),r=h.has(e);t.fillStyle=n?O:r?F:_,t.fillRect(s,0,i,Ie)}for(const e of n){const o={top:e,bottom:e,left:0,right:g-1},{y:s,height:i}=this.getters.getVisibleRect(o),n=f.has(e),r=d.has(e);t.fillStyle=n?O:r?F:_,t.fillRect(0,s,we,i)}t.beginPath(),t.moveTo(we,0),t.lineTo(we,l),t.moveTo(0,Ie),t.lineTo(a,Ie),t.strokeStyle="#C0C0C0",t.stroke();for(const e of s){const o=So(e);t.fillStyle=m.has(e)?"#fff":P;const s={left:e,right:e,top:r,bottom:r},{x:i,width:n}=this.getters.getRect(s),{x:a,width:l}=this.getters.getVisibleRect(s);t.save(),t.beginPath(),t.rect(a,0,l,Ie),t.clip(),t.fillText(o,i+n/2,13),t.restore(),t.beginPath(),t.moveTo(i+n,0),t.lineTo(i+n,Ie),t.stroke()}for(const e of n){t.fillStyle=f.has(e)?"#fff":P;const o={top:e,bottom:e,left:i,right:i},{y:s,height:n}=this.getters.getRect(o),{y:r,height:a}=this.getters.getVisibleRect(o);t.save(),t.beginPath(),t.rect(0,r,we,a),t.clip(),t.fillText(String(e+1),24,s+n/2),t.restore(),t.beginPath(),t.moveTo(0,s+n),t.lineTo(we,s+n),t.stroke()}}drawFrozenPanesHeaders(e){const{ctx:t,thinLineWidth:o}=e,{x:s,y:i}=this.getters.getMainViewportCoordinates(),n=this.getters.isDashboard()?0:we,r=this.getters.isDashboard()?0:Ie;t.lineWidth=6*o,t.strokeStyle=W,t.beginPath(),s&&(t.moveTo(n+s,0),t.lineTo(n+s,r)),i&&(t.moveTo(0,r+i),t.lineTo(n,r+i)),t.stroke()}drawFrozenPanes(e){const{ctx:t,thinLineWidth:o}=e,{x:s,y:i}=this.getters.getMainViewportCoordinates(),n=this.getters.getSheetViewVisibleCols(),r=n[0],a=n[n.length-1],l=this.getters.getSheetViewVisibleRows(),c={left:r,right:a,top:l[0],bottom:l[l.length-1]},h=this.getters.getVisibleRect(c),d=this.getters.isDashboard()?0:we,u=this.getters.isDashboard()?0:Ie;t.lineWidth=6*o,t.strokeStyle="#DADFE8",t.beginPath(),s&&(t.moveTo(d+s,u),t.lineTo(d+s,h.height+u)),i&&(t.moveTo(d,u+i),t.lineTo(h.width+d,u+i)),t.stroke()}findNextEmptyCol(e,t,o){const s=this.getters.getActiveSheetId();let i=e;for(;i<t;){const e={sheetId:s,col:i+1,row:o},t=this.getters.getEvaluatedCell(e),n=this.getters.getCellComputedBorder(e),a=this.getters.doesCellHaveGridIcon(e);if(t.type!==r.empty||this.getters.isInMerge(e)||n?.left||a)return i;i++}return i}findPreviousEmptyCol(e,t,o){const s=this.getters.getActiveSheetId();let i=e;for(;i>t;){const e={sheetId:s,col:i-1,row:o},t=this.getters.getEvaluatedCell(e),n=this.getters.getCellComputedBorder(e),a=this.getters.doesCellHaveGridIcon(e);if(t.type!==r.empty||this.getters.isInMerge(e)||n?.right||a)return i;i--}return i}computeCellAlignment(e,t){const o=this.getters.getCell(e);if(o?.isFormula&&this.getters.shouldShowFormulas())return"left";const{align:s}=this.getters.getCellStyle(e),i=this.getters.getEvaluatedCell(e);return t&&i.type===r.number?"center"!==s?"left":s:s||i.defaultAlign}createZoneBox(e,t,o,s){const{left:i,right:n}=o,a=t.left,l=t.top,c={sheetId:e,col:a,row:l},h=this.getters.getEvaluatedCell(c),d=this.getters.shouldShowFormulas(),{x:u,y:g,width:p,height:m}=this.getters.getRect(t),f=this.getters.getDataValidationChipStyle(c),v=this.getters.getCellComputedBorder(c,s);let b=this.getters.getCellComputedStyle(c);if(this.fingerprints.isEnabled){const e=this.fingerprints.colors.get(c);b={...b,fillColor:e}}f?.textColor&&(b={...b,textColor:f.textColor});const S=this.fingerprints.isEnabled?void 0:this.getters.getConditionalDataBar(c),C=this.getters.getCellIcons(c),y={left:C.find((e=>"left"===e?.horizontalAlign)),right:C.find((e=>"right"===e?.horizontalAlign)),center:C.find((e=>"center"===e?.horizontalAlign))},I={id:Go(t),x:u,y:g,width:p,height:m,border:v||void 0,style:b,dataBarFill:S,overlayColor:this.hoveredTables.overlayColors.get(c),isError:h.type===r.error&&!!h.message||this.getters.isDataValidationInvalid(c),icons:y,disabledAnimation:this.zonesWithPreventedAnimationsInNextFrame.some((e=>ts(t,e)||Qo(t,e)))},w=dl(I.style);if(h.type===r.empty||I.icons.center)return I;const x=b.wrapping||"overflow",E="wrap"===x&&!d,R=p-2*Te,T=this.getters.getCellMultiLineText(c,{maxWidth:R,wrapText:E}),A=Math.max(...T.map((e=>this.getters.getTextWidth(e,b)+Te))),D=f?5:0,_=(I.icons.left?I.icons.left.size+I.icons.left.margin:0)+D,F=(I.icons.right?I.icons.right.size+I.icons.right.margin:0)+D,O=_+A+F,P=this.computeCellAlignment(c,O>p),M=T.length,N=Math.round(this.getters.computeTextYCoordinate(I,w,b.verticalAlign,M));let k=I.x;k+="left"===P?Te+_:"right"===P?I.width-Te-F:I.width/2,k=Math.round(k);const L=tl(w,M);if(I.content={textLines:T,width:"overflow"===x?A:p,align:P,x:k,y:N,fontSizePx:w},f?.fillColor){const e=_,t=5;I.chip={color:f.fillColor,width:I.width-e-t,height:L+2,x:I.x+e,y:N-2}}const V=O>p||w>m;if(I.icons.left||I.icons.right||I.chip)I.clipRect={x:I.x+_,y:I.y,width:Math.max(0,p-_-F),height:m};else if(V&&"overflow"===x){let e,o;switch(this.getters.isInMerge(c)?(e=this.getters.getMerge(c).right,o=a):(e=I.border?.right?t.right:this.findNextEmptyCol(a,n,l),o=I.border?.left?t.left:this.findPreviousEmptyCol(a,i,l),I.isOverflow=!0),P){case"left":{const o=cs({col:e,row:l}),{x:s,y:i,width:n,height:r}=this.getters.getVisibleRect(Yo(t,o));(n<O||w>r||T.length>1)&&(I.clipRect={x:s,y:i,width:n,height:r});break}case"right":{const e=cs({col:o,row:l}),{x:s,y:i,width:n,height:r}=this.getters.getVisibleRect(Yo(t,e));(n<O||w>r||T.length>1)&&(I.clipRect={x:s,y:i,width:n,height:r});break}case"center":{const s={...t,left:o,right:e},{x:i,y:n,height:r,width:a}=this.getters.getVisibleRect(s),l=O/2,c=I.x+I.width/2;if(i+a<c+l||i>c-l||w>r||T.length>1){const e=i>c-l?i:c-l,t=i+a-e;I.clipRect={x:e,y:n,width:t,height:r}}break}}}else("clip"===x||"wrap"===x||T.length>1)&&(I.clipRect={x:I.x,y:I.y,width:p,height:m});return I}getGridBoxes(e){const t=[],o=this.getters.getSheetViewVisibleCols().filter((t=>t>=e.left&&t<=e.right)),s=o[0],i=o[o.length-1],n=this.getters.getSheetViewVisibleRows().filter((t=>t>=e.top&&t<=e.bottom)),r={left:s,right:i,top:n[0],bottom:n[n.length-1]},a=this.getters.getActiveSheetId();for(const s of n)for(const i of o){const o={sheetId:a,col:i,row:s};this.getters.isInMerge(o)||t.push(this.createZoneBox(a,cs(o),r,e))}for(const o of this.getters.getMerges(a))if(!this.getters.isMergeHidden(a,o)&&Qo(o,r)){const s=this.createZoneBox(a,o,r,e),i=this.getters.getCellComputedBorder({sheetId:a,col:o.right,row:o.bottom},e);s.border={...s.border,bottom:i?i.bottom:void 0,right:i?i.right:void 0},s.isMerge=!0,t.push(s)}return t}getBoxesWithAnimations(e,t,o){return this.updateAnimationsProgress(o),this.addNewAnimations(e,t,o),this.animations.size>0?(this.renderer.startAnimation("grid_renderer_animation"),this.updateBoxesWithAnimations(e)):(this.renderer.stopAnimation("grid_renderer_animation"),e)}updateBoxesWithAnimations(e){const t=[];for(const o of e){const e=this.animations.get(o.id);if(!e){t.push(o);continue}const s=pt(o);t.push(s);for(const i of e.animationTypes){const n=Rx.get(i).updateAnimation(e.progress,s,e.oldBox,o);n&&t.push(...n.newBoxes)}}return t}updateAnimationsProgress(e){if(void 0!==e)for(const t of this.animations.keys()){const o=this.animations.get(t);if(void 0===o.startTime){o.startTime=e;continue}const s=e-o.startTime,i=Math.min(1,s/200);i>=1&&this.animations.delete(t),o.progress=i}}addNewAnimations(e,t,o){for(const s of e){this.lastRenderBoxes.set(s.id,s);const e=t.get(s.id);if(this.preventNewAnimationsInNextFrame||!e||s.disabledAnimation)continue;const i=[];for(const t of Rx.getAll())t.hasAnimation(e,s)&&i.push(t.id);const n=i.length>0?{animationTypes:i,oldBox:e,progress:0,startTime:o}:void 0;n&&this.animations.set(s.id,n)}}}function qN(e,o,s){const i=t.useRef(e);t.useEffect((function(){const e=i.el,t=window.devicePixelRatio||1,o=e.getContext("2d",{alpha:!1}),r={ctx:o,dpr:t,thinLineWidth:.4*t},{width:a,height:l}=s();if(e.style.width=`${a}px`,e.style.height=`${l}px`,e.width=a*t,e.height=l*t,e.setAttribute("style",`width:${a}px;height:${l}px;`),0===a||0===l)return;o.translate(-.5,-.5),o.scale(t,t),n.draw(r)}));const n=Dh(kh);Dh(WN)}function ZN(e,t,o){let s=0,i=0,n=0,r=0,a=!1,l=0,c=null;function h(){if(Math.abs(n)<.05&&(n=0),Math.abs(r)<.05&&(r=0),!n&&!r)return;const e=Date.now(),o=Math.abs(e-l);t(1*(n*o),1*(r*o)),l=e,n*=.95,r*=.95,requestAnimationFrame(h)}FN(e,"touchstart",(function(e){a=!0,({clientX:s,clientY:i}=e.touches[0]),n=0,r=0}),{capture:!1}),FN(e,"touchmove",(function(e){if(!a)return;c&&(clearTimeout(c),c=null);const h=Date.now(),{clientX:d,clientY:u}=e.touches[0],g=s-d,p=i-u,m=h-l;if(!m)return;n=g/m,r=p/m,s=d,i=u,l=h,o()&&(e.cancelable&&e.preventDefault(),e.stopPropagation());c=setTimeout((()=>{n=0,r=0}),100),t(1*g,1*p)}),{capture:!1}),FN(e,"touchend",(function(e){a=!1,s=i=0,c&&clearTimeout(c);n*=1.2,r*=1.2,requestAnimationFrame(h)}),{capture:!1})}function jN(e){function t(e,t){return e*(0===t?1:Ee)}return o=>{const s=t(o.shiftKey&&!EI()?o.deltaY:o.deltaX,o.deltaMode),i=t(o.shiftKey&&!EI()?o.deltaX:o.deltaY,o.deltaMode);e(s,i)}}Bh`
988
+ `;class GN extends t.Component{static props={onOpenContextMenu:Function};static template="o-spreadsheet-HeadersOverlay";static components={ColResizer:BN,RowResizer:$N};selectAll(){this.env.model.selection.selectAll()}}class WN extends Lh{fingerprints;hoveredTables;hoveredIcon;lastRenderBoxes=new Map;preventNewAnimationsInNextFrame=!1;zonesWithPreventedAnimationsInNextFrame=[];animations=new Map;constructor(e){super(e),this.getters=e(Mh).getters,this.fingerprints=e(oF),this.hoveredTables=e(MN),this.hoveredIcon=e(NN)}handle(e){switch(e.type){case"START":case"ACTIVATE_SHEET":case"ADD_COLUMNS_ROWS":case"REMOVE_COLUMNS_ROWS":this.animations.clear(),this.preventNewAnimationsInNextFrame=!0;break;case"RESIZE_COLUMNS_ROWS":this.preventNewAnimationsInNextFrame=!0;break;case"REDO":this.zonesWithPreventedAnimationsInNextFrame=[];break;case"UNDO":for(const t of e.commands)if("ADD_COLUMNS_ROWS"===t.type||"REMOVE_COLUMNS_ROWS"===t.type||"RESIZE_COLUMNS_ROWS"===t.type){this.animations.clear(),this.preventNewAnimationsInNextFrame=!0;break}break;case"PASTE":this.zonesWithPreventedAnimationsInNextFrame.push(...this.getters.getSelectedZones());break;case"UPDATE_CELL":const t=this.getters.getCommandZones(e);this.zonesWithPreventedAnimationsInNextFrame.push(...t)}}finalize(){this.zonesWithPreventedAnimationsInNextFrame=Fo(this.zonesWithPreventedAnimationsInNextFrame)}get renderingLayers(){return["Background","Headers"]}drawLayer(e,t,o){switch(t){case"Background":this.drawGlobalBackground(e);const t=this.lastRenderBoxes;this.lastRenderBoxes=new Map;for(const{zone:s,rect:i}of this.getters.getAllActiveViewportsZonesAndRect()){const{ctx:n}=e;n.save(),n.beginPath(),n.rect(i.x,i.y,i.width,i.height),n.clip();const r=this.getGridBoxes(s),a=this.getBoxesWithAnimations(r,t,o);this.drawBackground(e,a),this.drawOverflowingCellBackground(e,a),this.drawCellBackground(e,a),this.drawBorders(e,a),this.drawTexts(e,a),this.drawIcon(e,a),n.restore()}this.drawFrozenPanes(e),this.preventNewAnimationsInNextFrame=!1,this.zonesWithPreventedAnimationsInNextFrame=[];break;case"Headers":this.getters.isDashboard()||(this.drawHeaders(e),this.drawFrozenPanesHeaders(e))}}drawGlobalBackground(e){const{ctx:t}=e,{width:o,height:s}=this.getters.getSheetViewDimensionWithHeaders();t.fillStyle="#ffffff",t.fillRect(0,0,o+T,s+T)}drawBackground(e,t){const{ctx:o,thinLineWidth:s}=e,i=!this.getters.isDashboard()&&this.getters.getGridLinesVisibility(this.getters.getActiveSheetId()),n=i?.1*s:0;if(i)for(const e of t)e.skipCellGridLines||(o.strokeStyle="#E2E3E3",o.lineWidth=s,o.strokeRect(e.x+n,e.y+n,e.width-2*n,e.height-2*n))}drawCellBackground(e,t){const{ctx:o}=e;for(const e of t){const t=e.style;if(t.fillColor&&"#ffffff"!==t.fillColor&&(o.fillStyle=t.fillColor||"#ffffff",o.fillRect(e.x,e.y,e.width,e.height)),e.dataBarFill){o.fillStyle=e.dataBarFill.color;const t=e.dataBarFill.percentage,s=e.width*(t/100);o.fillRect(e.x,e.y,s,e.height)}if(e?.chip){o.save(),o.beginPath(),o.rect(e.x,e.y,e.width,e.height),o.clip();const t=e.chip;o.fillStyle=t.color;const s=10;o.beginPath(),o.roundRect(t.x,t.y,t.width,t.height,s),o.fill(),o.restore()}e.overlayColor&&(o.fillStyle=e.overlayColor,o.fillRect(e.x,e.y,e.width,e.height)),e.isError&&(o.fillStyle="red",o.beginPath(),o.moveTo(e.x+e.width-5,e.y),o.lineTo(e.x+e.width,e.y),o.lineTo(e.x+e.width,e.y+5),o.fill())}}drawOverflowingCellBackground(e,t){const{ctx:o,thinLineWidth:s}=e;for(const e of t)if(e.content&&e.isOverflow){const t=e.content.align||"left";let i,n;const r=e.y+s/2,a=e.height-s,l=Math.min(e.clipRect?.width||1/0,e.content.width);"left"===t?(i=e.x+s/2,n=l-2*s):"right"===t?(i=e.x+e.width-s/2,n=2*s-l):(i=(e.clipRect?.x||e.x+e.width/2-e.content.width/2)+s/2,n=l-2*s),o.fillStyle="#ffffff",o.fillRect(i,r,n,a)}}drawBorders(e,t){const{ctx:o}=e;for(const e of t){const t=e.border;if(t){const{x:o,y:i,width:n,height:r}=e;t.left&&s(t.left,o,i,o,i+r),t.top&&s(t.top,o,i,o+n,i),t.right&&s(t.right,o+n,i,o+n,i+r),t.bottom&&s(t.bottom,o,i+r,o+n,i+r)}}function s({color:e,style:t,opacity:s},i,n,r,a){switch(o.globalAlpha=s??1,o.strokeStyle=e,t){case"medium":o.lineWidth=2,n+=(i+=n===a?-.5:.5)===(r+=n===a?1.5:.5)?-.5:.5,a+=i===r?1.5:.5;break;case"thick":o.lineWidth=3,n===a&&(i--,r++),i===r&&(n--,a++);break;case"dashed":o.lineWidth=1,o.setLineDash([1,3]);break;case"dotted":o.lineWidth=1,n===a&&(i+=.5,r+=.5),i===r&&(n+=.5,a+=.5),o.setLineDash([1,1]);break;default:o.lineWidth=1}o.beginPath(),o.moveTo(i,n),o.lineTo(r,a),o.stroke(),o.lineWidth=1,o.setLineDash([]),o.globalAlpha=1}}drawTexts(e,t){const{ctx:o}=e;let s;o.textBaseline="top";for(const e of t)if(e.content){o.globalAlpha=e.textOpacity??1;const t=e.style||{},i=e.content.align||"left",n=hl(t);if(n!==s&&(s=n,o.font=n),o.fillStyle=t.textColor||"#000",o.textAlign=i,e.clipRect){o.save(),o.beginPath();const{x:t,y:s,width:i,height:n}=e.clipRect;o.rect(t,s,i,n),o.clip()}const r=e.content.x;let a=e.content.y;for(const s of e.content.textLines)vl(o,s,{x:r,y:a},t.underline,t.strikethrough),a+=Te+e.content.fontSizePx;e.clipRect&&o.restore(),o.globalAlpha=1}}drawIcon(e,t){const{ctx:o}=e;for(const e of t)for(const t of Object.values(e.icons)){if(!t)continue;const s=zt({id:t.type,position:t.position},this.hoveredIcon.hoveredIcon)&&t.hoverSvg||t.svg;if(!s)continue;o.save(),o.globalAlpha=t.opacity??1,o.beginPath();const i=t.clipRect||e;o.rect(i.x,i.y,i.width,i.height),o.clip();const n=t.size,{x:r,y:a}=this.getters.getCellIconRect(t,e);o.translate(r,a),o.scale(n/s.width,n/s.height);for(const e of s.paths)o.fillStyle=e.fillColor,o.fill(gA(e.path));o.restore()}}drawHeaders(e){const{ctx:t,thinLineWidth:o}=e,s=this.getters.getSheetViewVisibleCols(),i=s[0],n=this.getters.getSheetViewVisibleRows(),r=n[0],{width:a,height:l}=this.getters.getSheetViewDimensionWithHeaders(),c=this.getters.getSelectedZones(),h=function(e){const t=new Set;for(const o of Fo(e))for(const e of Ct(o.left,o.right+1))t.add(e);return t}(c),d=function(e){const t=new Set;for(const o of Fo(e))for(const e of Ct(o.top,o.bottom+1))t.add(e);return t}(c),u=this.getters.getActiveSheetId(),g=this.getters.getNumberCols(u),p=this.getters.getNumberRows(u),m=this.getters.getActiveCols(),f=this.getters.getActiveRows();t.font=`400 11px ${Le}`,t.textAlign="center",t.textBaseline="middle",t.lineWidth=o,t.strokeStyle="#333";for(const e of s){const o={left:e,right:e,top:0,bottom:p-1},{x:s,width:i}=this.getters.getVisibleRect(o),n=m.has(e),r=h.has(e);t.fillStyle=n?O:r?F:_,t.fillRect(s,0,i,Ie)}for(const e of n){const o={top:e,bottom:e,left:0,right:g-1},{y:s,height:i}=this.getters.getVisibleRect(o),n=f.has(e),r=d.has(e);t.fillStyle=n?O:r?F:_,t.fillRect(0,s,we,i)}t.beginPath(),t.moveTo(we,0),t.lineTo(we,l),t.moveTo(0,Ie),t.lineTo(a,Ie),t.strokeStyle="#C0C0C0",t.stroke();for(const e of s){const o=So(e);t.fillStyle=m.has(e)?"#fff":P;const s={left:e,right:e,top:r,bottom:r},{x:i,width:n}=this.getters.getRect(s),{x:a,width:l}=this.getters.getVisibleRect(s);t.save(),t.beginPath(),t.rect(a,0,l,Ie),t.clip(),t.fillText(o,i+n/2,13),t.restore(),t.beginPath(),t.moveTo(i+n,0),t.lineTo(i+n,Ie),t.stroke()}for(const e of n){t.fillStyle=f.has(e)?"#fff":P;const o={top:e,bottom:e,left:i,right:i},{y:s,height:n}=this.getters.getRect(o),{y:r,height:a}=this.getters.getVisibleRect(o);t.save(),t.beginPath(),t.rect(0,r,we,a),t.clip(),t.fillText(String(e+1),24,s+n/2),t.restore(),t.beginPath(),t.moveTo(0,s+n),t.lineTo(we,s+n),t.stroke()}}drawFrozenPanesHeaders(e){const{ctx:t,thinLineWidth:o}=e,{x:s,y:i}=this.getters.getMainViewportCoordinates(),n=this.getters.isDashboard()?0:we,r=this.getters.isDashboard()?0:Ie;t.lineWidth=6*o,t.strokeStyle=W,t.beginPath(),s&&(t.moveTo(n+s,0),t.lineTo(n+s,r)),i&&(t.moveTo(0,r+i),t.lineTo(n,r+i)),t.stroke()}drawFrozenPanes(e){const{ctx:t,thinLineWidth:o}=e,{x:s,y:i}=this.getters.getMainViewportCoordinates(),n=this.getters.getSheetViewVisibleCols(),r=n[0],a=n[n.length-1],l=this.getters.getSheetViewVisibleRows(),c={left:r,right:a,top:l[0],bottom:l[l.length-1]},h=this.getters.getVisibleRect(c),d=this.getters.isDashboard()?0:we,u=this.getters.isDashboard()?0:Ie;t.lineWidth=6*o,t.strokeStyle="#DADFE8",t.beginPath(),s&&(t.moveTo(d+s,u),t.lineTo(d+s,h.height+u)),i&&(t.moveTo(d,u+i),t.lineTo(h.width+d,u+i)),t.stroke()}findNextEmptyCol(e,t,o){const s=this.getters.getActiveSheetId();let i=e;for(;i<t;){const e={sheetId:s,col:i+1,row:o},t=this.getters.getEvaluatedCell(e),n=this.getters.getCellComputedBorder(e),a=this.getters.doesCellHaveGridIcon(e);if(t.type!==r.empty||this.getters.isInMerge(e)||n?.left||a)return i;i++}return i}findPreviousEmptyCol(e,t,o){const s=this.getters.getActiveSheetId();let i=e;for(;i>t;){const e={sheetId:s,col:i-1,row:o},t=this.getters.getEvaluatedCell(e),n=this.getters.getCellComputedBorder(e),a=this.getters.doesCellHaveGridIcon(e);if(t.type!==r.empty||this.getters.isInMerge(e)||n?.right||a)return i;i--}return i}computeCellAlignment(e,t){const o=this.getters.getCell(e);if(o?.isFormula&&this.getters.shouldShowFormulas())return"left";const{align:s}=this.getters.getCellStyle(e),i=this.getters.getEvaluatedCell(e);return t&&i.type===r.number?"center"!==s?"left":s:s||i.defaultAlign}createZoneBox(e,t,o,s){const{left:i,right:n}=o,a=t.left,l=t.top,c={sheetId:e,col:a,row:l},h=this.getters.getEvaluatedCell(c),d=this.getters.shouldShowFormulas(),{x:u,y:g,width:p,height:m}=this.getters.getRect(t),f=this.getters.getDataValidationChipStyle(c),v=this.getters.getCellComputedBorder(c,s);let b=this.getters.getCellComputedStyle(c);if(this.fingerprints.isEnabled){const e=this.fingerprints.colors.get(c);b={...b,fillColor:e}}f?.textColor&&(b={...b,textColor:f.textColor});const S=this.fingerprints.isEnabled?void 0:this.getters.getConditionalDataBar(c),C=this.getters.getCellIcons(c),y={left:C.find((e=>"left"===e?.horizontalAlign)),right:C.find((e=>"right"===e?.horizontalAlign)),center:C.find((e=>"center"===e?.horizontalAlign))},I={id:Go(t),x:u,y:g,width:p,height:m,border:v||void 0,style:b,dataBarFill:S,overlayColor:this.hoveredTables.overlayColors.get(c),isError:h.type===r.error&&!!h.message||this.getters.isDataValidationInvalid(c),icons:y,disabledAnimation:this.zonesWithPreventedAnimationsInNextFrame.some((e=>ts(t,e)||Qo(t,e)))},w=dl(I.style);if(h.type===r.empty||I.icons.center)return I;const x=b.wrapping||"overflow",E="wrap"===x&&!d,R=p-2*Te,T=this.getters.getCellMultiLineText(c,{maxWidth:R,wrapText:E}),A=Math.max(...T.map((e=>this.getters.getTextWidth(e,b)+Te))),D=f?5:0,_=(I.icons.left?I.icons.left.size+I.icons.left.margin:0)+D,F=(I.icons.right?I.icons.right.size+I.icons.right.margin:0)+D,O=_+A+F,P=this.computeCellAlignment(c,O>p),M=T.length,N=Math.round(this.getters.computeTextYCoordinate(I,w,b.verticalAlign,M));let k=I.x;k+="left"===P?Te+_:"right"===P?I.width-Te-F:I.width/2,k=Math.round(k);const L=tl(w,M);if(I.content={textLines:T,width:"overflow"===x?A:p,align:P,x:k,y:N,fontSizePx:w},f?.fillColor){const e=_,t=5;I.chip={color:f.fillColor,width:I.width-e-t,height:L+2,x:I.x+e,y:N-2}}const V=O>p||w>m;if(I.icons.left||I.icons.right||I.chip)I.clipRect={x:I.x+_,y:I.y,width:Math.max(0,p-_-F),height:m};else if(V&&"overflow"===x){let e,o;switch(this.getters.isInMerge(c)?(e=this.getters.getMerge(c).right,o=a):(e=I.border?.right?t.right:this.findNextEmptyCol(a,n,l),o=I.border?.left?t.left:this.findPreviousEmptyCol(a,i,l),I.isOverflow=!0),P){case"left":{const o=cs({col:e,row:l}),{x:s,y:i,width:n,height:r}=this.getters.getVisibleRect(Yo(t,o));(n<O||w>r||T.length>1)&&(I.clipRect={x:s,y:i,width:n,height:r});break}case"right":{const e=cs({col:o,row:l}),{x:s,y:i,width:n,height:r}=this.getters.getVisibleRect(Yo(t,e));(n<O||w>r||T.length>1)&&(I.clipRect={x:s,y:i,width:n,height:r});break}case"center":{const s={...t,left:o,right:e},{x:i,y:n,height:r,width:a}=this.getters.getVisibleRect(s),l=O/2,c=I.x+I.width/2;if(i+a<c+l||i>c-l||w>r||T.length>1){const e=i>c-l?i:c-l,t=i+a-e;I.clipRect={x:e,y:n,width:t,height:r}}break}}}else("clip"===x||"wrap"===x||T.length>1)&&(I.clipRect={x:I.x,y:I.y,width:p,height:m});return I}getGridBoxes(e){const t=[],o=this.getters.getSheetViewVisibleCols().filter((t=>t>=e.left&&t<=e.right)),s=o[0],i=o[o.length-1],n=this.getters.getSheetViewVisibleRows().filter((t=>t>=e.top&&t<=e.bottom)),r={left:s,right:i,top:n[0],bottom:n[n.length-1]},a=this.getters.getActiveSheetId();for(const s of n)for(const i of o){const o={sheetId:a,col:i,row:s};this.getters.isInMerge(o)||t.push(this.createZoneBox(a,cs(o),r,e))}for(const o of this.getters.getMerges(a))if(!this.getters.isMergeHidden(a,o)&&Qo(o,r)){const s=this.createZoneBox(a,o,r,e),i=this.getters.getCellComputedBorder({sheetId:a,col:o.right,row:o.bottom},e);s.border={...s.border,bottom:i?i.bottom:void 0,right:i?i.right:void 0},s.isMerge=!0,t.push(s)}return t}getBoxesWithAnimations(e,t,o){return this.updateAnimationsProgress(o),this.addNewAnimations(e,t,o),this.animations.size>0?(this.renderer.startAnimation("grid_renderer_animation"),this.updateBoxesWithAnimations(e)):(this.renderer.stopAnimation("grid_renderer_animation"),e)}updateBoxesWithAnimations(e){const t=[];for(const o of e){const e=this.animations.get(o.id);if(!e){t.push(o);continue}const s=pt(o);t.push(s);for(const i of e.animationTypes){const n=Rx.get(i).updateAnimation(e.progress,s,e.oldBox,o);n&&t.push(...n.newBoxes)}}return t}updateAnimationsProgress(e){if(void 0!==e)for(const t of this.animations.keys()){const o=this.animations.get(t);if(void 0===o.startTime){o.startTime=e;continue}const s=e-o.startTime,i=Math.min(1,s/200);i>=1&&this.animations.delete(t),o.progress=i}}addNewAnimations(e,t,o){for(const s of e){this.lastRenderBoxes.set(s.id,s);const e=t.get(s.id);if(this.preventNewAnimationsInNextFrame||!e||s.disabledAnimation)continue;const i=[];for(const t of Rx.getAll())t.hasAnimation(e,s)&&i.push(t.id);const n=i.length>0?{animationTypes:i,oldBox:e,progress:0,startTime:o}:void 0;n&&this.animations.set(s.id,n)}}}function qN(e,o,s){const i=t.useRef(e);t.useEffect((function(){const e=i.el,t=window.devicePixelRatio||1,o=e.getContext("2d",{alpha:!1}),r={ctx:o,dpr:t,thinLineWidth:.4*t},{width:a,height:l}=s();if(e.style.width=`${a}px`,e.style.height=`${l}px`,e.width=a*t,e.height=l*t,e.setAttribute("style",`width:${a}px;height:${l}px;`),0===a||0===l)return;o.translate(-.5,-.5),o.scale(t,t),n.draw(r)}));const n=Dh(kh);Dh(WN)}function ZN(e,t,o){let s=0,i=0,n=0,r=0,a=!1,l=0,c=null;function h(){if(Math.abs(n)<.05&&(n=0),Math.abs(r)<.05&&(r=0),!n&&!r)return;const e=Date.now(),o=Math.abs(e-l);t(1*(n*o),1*(r*o)),l=e,n*=.95,r*=.95,requestAnimationFrame(h)}FN(e,"touchstart",(function(e){a=!0,({clientX:s,clientY:i}=e.touches[0]),n=0,r=0}),{capture:!1}),FN(e,"touchmove",(function(e){if(!a)return;c&&(clearTimeout(c),c=null);const h=Date.now(),{clientX:d,clientY:u}=e.touches[0],g=s-d,p=i-u,m=h-l;if(!m)return;n=g/m,r=p/m,s=d,i=u,l=h,o()&&(e.cancelable&&e.preventDefault(),e.stopPropagation());c=setTimeout((()=>{n=0,r=0}),100),t(1*g,1*p)}),{capture:!1}),FN(e,"touchend",(function(e){a=!1,s=i=0,c&&clearTimeout(c);n*=1.2,r*=1.2,requestAnimationFrame(h)}),{capture:!1})}function jN(e){function t(e,t){return e*(0===t?1:Ee)}return o=>{const s=t(o.shiftKey&&!EI()?o.deltaY:o.deltaX,o.deltaMode),i=t(o.shiftKey&&!EI()?o.deltaX:o.deltaY,o.deltaMode);e(s,i)}}Bh`
989
989
  .o-border {
990
990
  position: absolute;
991
991
  &:hover {
@@ -1848,7 +1848,7 @@
1848
1848
  background: #e7f2f6;
1849
1849
  }
1850
1850
  }
1851
- `;class uV extends t.Component{static template="o_spreadsheet.PivotHTMLRenderer";static components={Checkbox:nT};static props={pivotId:String,onCellClicked:Function};pivot=this.env.model.getters.getPivot(this.props.pivotId);data={columns:[],rows:[],values:[]};state=t.useState({showMissingValuesOnly:!1});setup(){const e=this.pivot.getExpandedTableStructure(),t=this.env.model.getters.getPivotFormulaId(this.props.pivotId);this.data={columns:this._buildColHeaders(t,e),rows:this._buildRowHeaders(t,e),values:this._buildValues(t,e)}}get tracker(){return this.env.model.getters.getPivotPresenceTracker(this.props.pivotId)}getTableData(){if(!this.state.showMissingValuesOnly)return this.data;const e=this.getColumnsIndexes(),t=this.getRowsIndexes();return{columns:this.buildColumnsMissing(e),rows:this.buildRowsMissing(t),values:this.buildValuesMissing(e,t)}}addRecursiveRow(e){const t=this.pivot.getExpandedTableStructure().rows,o=[...t[e].values];if(o.length<=1)return[e];o.pop();const s=t.findIndex((e=>JSON.stringify(e.values)===JSON.stringify(o)));return[e].concat(this.addRecursiveRow(s))}buildColumnsMissing(e){const t=[];for(const e of this.data.columns){const o=[];for(const t in e)for(let s=0;s<e[t].span;s++)o.push(parseInt(t,10));t.push(o)}for(let o=t[t.length-1].length;o>=0;o--)if(!e.includes(o))for(const e of t)e.splice(o,1);const o=[];for(const e in t){const s=[];let i,n=1;for(let o=0;o<t[e].length;o++)i!==t[e][o]?(void 0!==i&&s.push(Object.assign({},this.data.columns[e][i],{span:n})),i=t[e][o],n=1):n++;void 0!==i&&s.push(Object.assign({},this.data.columns[e][i],{span:n})),o.push(s)}return o}buildRowsMissing(e){return e.map((e=>this.data.rows[e]))}buildValuesMissing(e,t){const o=e.map((()=>[]));for(const s of t)for(const t in e)o[t].push(this.data.values[e[t]][s]);return o}getColumnsIndexes(){const e=new Set;for(let t=0;t<this.data.columns.length;t++){const o=[];for(let e=0;e<this.data.columns[t].length;e++)for(let s=0;s<this.data.columns[t][e].span;s++)o.push(this.data.columns[t][e]);for(let t=0;t<o.length;t++)o[t].isMissing&&e.add(t)}for(let t=0;t<this.data.columns[this.data.columns.length-1].length;t++){this.data.values[t].find((e=>e.isMissing))&&e.add(t)}return Array.from(e).sort(((e,t)=>e-t))}getRowsIndexes(){const e=new Set;for(let t=0;t<this.data.rows.length;t++){this.data.rows[t].isMissing&&e.add(t);for(const o of this.data.values)o[t].isMissing&&this.addRecursiveRow(t).forEach((t=>e.add(t)))}return Array.from(e).sort(((e,t)=>e-t))}_buildColHeaders(e,t){const o=[];for(const s of t.columns){const t=[];for(const o of s){const s=[];for(let e=0;e<o.fields.length;e++)s.push({value:o.fields[e]},{value:o.values[e]});const i=this.pivot.parseArgsToPivotDomain(s),n=this.env.model.getters.getLocale();if("measure"===i.at(-1)?.field){const{value:s,format:r}=this.pivot.getPivotMeasureValue(En(i.at(-1).value),i);t.push({formula:`=PIVOT.HEADER(${sh(e,i).join(",")})`,value:Rr(s,{format:r,locale:n}),span:o.width,isMissing:!this.tracker?.isHeaderPresent(i)})}else{const{value:s,format:r}=this.pivot.getPivotHeaderValueAndFormat(i);t.push({formula:`=PIVOT.HEADER(${sh(e,i).join(",")})`,value:Rr(s,{format:r,locale:n}),span:o.width,isMissing:!this.tracker?.isHeaderPresent(i)})}}o.push(t)}const s=o[o.length-1];return o[o.length-1]=s.map((e=>(e.isMissing||(e.style="color: #756f6f;"),e))),o}_buildRowHeaders(e,t){const o=[];for(const s of t.rows){const t=[];for(let e=0;e<s.fields.length;e++)t.push({value:s.fields[e]},{value:s.values[e]});const i=this.pivot.parseArgsToPivotDomain(t),{value:n,format:r}=this.pivot.getPivotHeaderValueAndFormat(i),a=this.env.model.getters.getLocale(),l={formula:`=PIVOT.HEADER(${sh(e,i).join(",")})`,value:Rr(n,{format:r,locale:a}),isMissing:!this.tracker?.isHeaderPresent(i)};s.indent>1&&(l.style=`padding-left: ${s.indent-10}px`),o.push(l)}return o}_buildValues(e,t){const o=[];for(const s of t.columns.at(-1)||[]){const i=[],n=En(s.values[s.values.length-1]);for(const o of t.rows){const t=[];for(let e=0;e<o.fields.length;e++)t.push({value:o.fields[e]},{value:o.values[e]});for(let e=0;e<s.fields.length-1;e++)t.push({value:s.fields[e]},{value:s.values[e]});const r=this.pivot.parseArgsToPivotDomain(t),{value:a,format:l}=this.pivot.getPivotCellValueAndFormat(n,r),c=this.env.model.getters.getLocale();i.push({formula:`=PIVOT.VALUE(${sh(e,r,n).join(",")})`,value:Rr(a,{format:l,locale:c}),isMissing:!this.tracker?.isValuePresent(n,r)})}o.push(i)}return o}}class gV extends eu{getters;dispatch;canDispatch;constructor({getters:e,stateObserver:t,range:o,dispatch:s,canDispatch:i}){super(t),o.addRangeProvider(this.adaptRanges.bind(this)),this.getters=e,this.dispatch=s,this.canDispatch=i}import(e){}export(e){}adaptRanges(e,t,o){}garbageCollectExternalResources(){}}class pV{id;format;style;sheetId;getRangeString;isFormula=!0;compiledFormula;constructor(e,t,o,s,i,n,r){this.id=e,this.format=o,this.style=s,this.sheetId=n,this.getRangeString=r;let a=0;const l=t.tokens.map((e=>{if("REFERENCE"===e.type){const e=a++;return new mV(i,e,this.sheetId,this.getRangeString)}return e}));this.compiledFormula={...t,dependencies:i,tokens:l}}get content(){return Lt(this.compiledFormula.tokens.map((e=>e.value)))}get contentWithFixedReferences(){let e=0;return Lt(this.compiledFormula.tokens.map((t=>{if("REFERENCE"===t.type){const t=e++;return this.getRangeString(this.compiledFormula.dependencies[t],this.sheetId,{useBoundedReference:!0})}return t.value})))}}class mV{ranges;rangeIndex;sheetId;getRangeString;type="REFERENCE";constructor(e,t,o,s){this.ranges=e,this.rangeIndex=t,this.sheetId=o,this.getRangeString=s}get value(){const e=this.ranges[this.rangeIndex];return this.getRangeString(e,this.sheetId)}}function fV(e){return""===e?NaN:Number(e)}function vV(e){return Object.entries(e).map((([e,t])=>t?bV(parseInt(e,10),t):void 0)).filter(Mt).map((e=>_o(e.left,e.top)+":"+_o(e.right,e.bottom)))}function bV(e,t){return{...t.zone,id:e}}class SV{getters;providers=[];constructor(e){this.getters=e}static getters=["adaptFormulaStringDependencies","copyFormulaStringForSheet","extendRange","getRangeString","getRangeFromSheetXC","createAdaptedRanges","getRangeData","getRangeDataFromXc","getRangeDataFromZone","getRangeFromRangeData","getRangeFromZone","getRangesUnion","recomputeRanges","isRangeValid","removeRangesSheetPrefix"];allowDispatch(e){return"MOVE_RANGES"===e.type?1===e.target.length?"Success":"InvalidZones":"Success"}beforeHandle(e){}handle(e){const t=Wa(e);t?.applyChange&&this.executeOnAllRanges(t.applyChange,t.sheetId,t.sheetName)}finalize(){}verifyRangeRemoved(e){return t=>{const o=e(t);return"NONE"===o.changeType||Bo(o.range.zone)?o:{range:o.range,changeType:"REMOVE"}}}executeOnAllRanges(e,t,o){const s=this.verifyRangeRemoved(e);for(const e of this.providers)e(s,t,o)}addRangeProvider(e){this.providers.push(e)}createAdaptedRanges(e,t,o,s){return e.map((e=>{if(!Bo(e.zone))return e;const i=e.prefixSheet?e.sheetId:s,n=Ua(e),r=Va(e),a={...e.unboundedZone,left:n&&!e.unboundedZone.hasHeader?e.unboundedZone.left:e.unboundedZone.left+(e.parts[0].colFixed?0:t),right:n?e.unboundedZone.right:e.unboundedZone.right+((e.parts[1]||e.parts[0]).colFixed?0:t),top:r&&!e.unboundedZone.hasHeader?e.unboundedZone.top:e.unboundedZone.top+(e.parts[0].rowFixed?0:o),bottom:r?e.unboundedZone.bottom:e.unboundedZone.bottom+((e.parts[1]||e.parts[0]).rowFixed?0:o)};return function(e){if($o(e.zone))return e;const t={...e.unboundedZone},o={...e.zone};let s=e.parts;if(void 0!==t.right&&t.right<t.left){const e=t.right;t.right=t.left,t.left=e,o.right=o.left,o.left=e,s=[{colFixed:s[1]?.colFixed||!1,rowFixed:s[0]?.rowFixed||!1},{colFixed:s[0]?.colFixed||!1,rowFixed:s[1]?.rowFixed||!1}]}if(void 0!==t.bottom&&t.bottom<t.top){const e=t.bottom;t.bottom=t.top,t.top=e,o.bottom=o.top,o.top=e,s=[{colFixed:s[0]?.colFixed||!1,rowFixed:s[1]?.rowFixed||!1},{colFixed:s[1]?.colFixed||!1,rowFixed:s[0]?.rowFixed||!1}]}return{unboundedZone:t,zone:o,parts:s,invalidXc:e.invalidXc,prefixSheet:e.prefixSheet,invalidSheetName:e.invalidSheetName,sheetId:e.sheetId}}(Na({...e,sheetId:i,zone:a},this.getters.getSheetSize))}))}removeRangesSheetPrefix(e,t){return t.map((t=>t.prefixSheet&&t.sheetId===e?{...t,prefixSheet:!1}:t))}extendRange(e,t,o){const s="COL"===t?e.zone.right+o:e.zone.right,i="ROW"===t?e.zone.bottom+o:e.zone.bottom,n={left:e.zone.left,top:e.zone.top,right:Ua(e)?void 0:s,bottom:Va(e)?void 0:i};return Na({...e,zone:n},this.getters.getSheetSize)}getRangeFromSheetXC(e,t){if(!Ia.test(t)||!this.getters.tryGetSheet(e))return La(t);const{sheetName:o}=Ta(t);return ka({xc:t,sheetId:this.getters.getSheetIdByName(o)||e,invalidSheetName:o&&!this.getters.getSheetIdByName(o)?o:void 0},this.getters.getSheetSize)}getRangeString(e,t,o={useBoundedReference:!1,useFixedReference:!1}){return e?e.invalidXc?e.invalidXc:this.getters.tryGetSheet(e.sheetId)?Ha(e,t,this.getters.getSheetName,o):sn.InvalidReference:sn.InvalidReference}getRangeDataFromXc(e,t){const o=this.getters.getRangeFromSheetXC(e,t);return this.getRangeDataFromZone(o.sheetId,o.unboundedZone)}getRangeDataFromZone(e,t){return{_sheetId:e,_zone:t=this.getters.getUnboundedZone(e,t)}}getRangeData(e){return this.getRangeDataFromZone(e.sheetId,e.unboundedZone)}getRangeFromZone(e,t){return Na({sheetId:e,zone:t,parts:[{colFixed:!1,rowFixed:!1},{colFixed:!1,rowFixed:!1}],prefixSheet:!1},this.getters.getSheetSize)}recomputeRanges(e,t){const o=e.map((e=>e.unboundedZone)),s=t.map((e=>e.unboundedZone));return Fo(o,s).map((t=>this.getRangeFromZone(e[0].sheetId,t)))}getRangeFromRangeData(e){if(!this.getters.tryGetSheet(e._sheetId))return La(sn.InvalidReference);return Na({prefixSheet:!1,zone:e._zone,sheetId:e._sheetId,invalidSheetName:void 0,parts:[{colFixed:!1,rowFixed:!1},{colFixed:!1,rowFixed:!1}]},this.getters.getSheetSize)}isRangeValid(e){if(!e)return!1;const{xc:t,sheetName:o}=Ta(e);return null!==t.match(Ia)&&(!o||void 0!==this.getters.getSheetIdByName(o))}getRangesUnion(e){const t=e.map((e=>e.unboundedZone)),o=function(...e){return{top:Math.min(...e.map((e=>e.top))),left:Math.min(...e.map((e=>e.left))),bottom:e.some((e=>void 0===e.bottom))?void 0:Math.max(...e.map((e=>e.bottom))),right:e.some((e=>void 0===e.right))?void 0:Math.max(...e.map((e=>e.right)))}}(...t);return this.getRangeFromZone(e[0].sheetId,o)}adaptFormulaStringDependencies(e,t,o){if(!t.startsWith("="))return t;const s=$C(t),i=s.dependencies.map((t=>{const s=this.getters.getRangeFromSheetXC(e,t),i=o(s);return"NONE"===i.changeType?s:i.range}));return this.getters.getFormulaString(e,s.tokens,i)}copyFormulaStringForSheet(e,t,o,s){if(!o.startsWith("="))return o;const i=$C(o),n=i.dependencies.map((o=>{const i=this.getters.getRangeFromSheetXC(e,o);return"keepSameReference"===s?i:za(e,t,i)}));return this.getters.getFormulaString(t,i.tokens,n)}}function CV(e,t){if(!e)return;const o=t(e);switch(o.changeType){case"NONE":return e;case"REMOVE":return;default:return o.range}}class yV extends eu{getters;constructor({getters:e,stateObserver:t}){super(t),this.getters=e}}const IV=new n;IV.add("pivots",(e=>{for(const t of e.getPivotIds()){const o=e.getPivot(t);o.markAsDirtyForEvaluation?.()}}));const wV=AC.mapping;function xV(e,t,o){return new EV(e,t,o).getParameters()}class EV{getters;computeCell;evalContext;rangeCache={};constructor(e,t,o){this.getters=t,this.computeCell=o,this.evalContext=Object.assign(Object.create(wV),e,{getters:this.getters,locale:this.getters.getLocale()})}getParameters(){return{referenceDenormalizer:this.refFn.bind(this),ensureRange:this.range.bind(this),evalContext:this.evalContext}}refFn(e,t){const o=this.getRangeError(e);if(o)return o;const s={sheetId:e.sheetId,col:e.zone.left,row:e.zone.top};if(t){this.computeCell(s);return{value:Aa(this.getters.getSheetName(e.sheetId),Go(e.zone))}}return this.computeCell(s)}range(e,t){const o=this.getRangeError(e);if(o)return[[o]];const s=e.sheetId,i=e.zone,n=Xo(i,this.getters.getSheetZone(s));if(!n)return[[]];const{top:r,left:a,bottom:l,right:c}=i,h=`${s}-${r}-${a}-${l}-${c}-${t}`;if(h in this.rangeCache)return this.rangeCache[h];const d=n.bottom-n.top+1,u=n.right-n.left+1,g=new Array(u),p=this.getters.getSheetName(e.sheetId);for(let e=n.left;e<=n.right;e++){const o=e-n.left;g[o]=new Array(d);for(let i=n.top;i<=n.bottom;i++){const r=i-n.top,a=this.computeCell({sheetId:s,col:e,row:i});g[o][r]=t?{value:Aa(p,_o(e,i))}:a}}return this.rangeCache[h]=g,g}getRangeError(e){return Bo(e.zone)?e.invalidSheetName?new cn(ui("Invalid sheet name: %s",e.invalidSheetName)):void 0:new cn}}function RV(e,t,o,s,i){TV(e,t,o||0,s||e.length-1,i||DV)}function TV(e,t,o,s,i){for(;s>o;){if(s-o>600){var n=s-o+1,r=t-o+1,a=Math.log(n),l=.5*Math.exp(2*a/3),c=.5*Math.sqrt(a*l*(n-l)/n)*(r-n/2<0?-1:1);TV(e,t,Math.max(o,Math.floor(t-r*l/n+c)),Math.min(s,Math.floor(t+(n-r)*l/n+c)),i)}var h=e[t],d=o,u=s;for(AV(e,o,t),i(e[s],h)>0&&AV(e,o,s);d<u;){for(AV(e,d,u),d++,u--;i(e[d],h)<0;)d++;for(;i(e[u],h)>0;)u--}0===i(e[o],h)?AV(e,o,u):AV(e,++u,s),u<=t&&(o=u+1),t<=u&&(s=u-1)}}function AV(e,t,o){var s=e[t];e[t]=e[o],e[o]=s}function DV(e,t){return e<t?-1:e>t?1:0}class _V{constructor(e=9){this._maxEntries=Math.max(4,e),this._minEntries=Math.max(2,Math.ceil(.4*this._maxEntries)),this.clear()}all(){return this._all(this.data,[])}search(e){let t=this.data;const o=[];if(!zV(e,t))return o;const s=this.toBBox,i=[];for(;t;){for(let n=0;n<t.children.length;n++){const r=t.children[n],a=t.leaf?s(r):r;zV(e,a)&&(t.leaf?o.push(r):HV(e,a)?this._all(r,o):i.push(r))}t=i.pop()}return o}collides(e){let t=this.data;if(!zV(e,t))return!1;const o=[];for(;t;){for(let s=0;s<t.children.length;s++){const i=t.children[s],n=t.leaf?this.toBBox(i):i;if(zV(e,n)){if(t.leaf||HV(e,n))return!0;o.push(i)}}t=o.pop()}return!1}load(e){if(!e||!e.length)return this;if(e.length<this._minEntries){for(let t=0;t<e.length;t++)this.insert(e[t]);return this}let t=this._build(e.slice(),0,e.length-1,0);if(this.data.children.length)if(this.data.height===t.height)this._splitRoot(this.data,t);else{if(this.data.height<t.height){const e=this.data;this.data=t,t=e}this._insert(t,this.data.height-t.height-1,!0)}else this.data=t;return this}insert(e){return e&&this._insert(e,this.data.height-1),this}clear(){return this.data=BV([]),this}remove(e,t){if(!e)return this;let o=this.data;const s=this.toBBox(e),i=[],n=[];let r,a,l;for(;o||i.length;){if(o||(o=i.pop(),a=i[i.length-1],r=n.pop(),l=!0),o.leaf){const s=FV(e,o.children,t);if(-1!==s)return o.children.splice(s,1),i.push(o),this._condense(i),this}l||o.leaf||!HV(o,s)?a?(r++,o=a.children[r],l=!1):o=null:(i.push(o),n.push(r),r=0,a=o,o=o.children[0])}return this}toBBox(e){return e}compareMinX(e,t){return e.minX-t.minX}compareMinY(e,t){return e.minY-t.minY}toJSON(){return this.data}fromJSON(e){return this.data=e,this}_all(e,t){const o=[];for(;e;)e.leaf?t.push(...e.children):o.push(...e.children),e=o.pop();return t}_build(e,t,o,s){const i=o-t+1;let n,r=this._maxEntries;if(i<=r)return n=BV(e.slice(t,o+1)),OV(n,this.toBBox),n;s||(s=Math.ceil(Math.log(i)/Math.log(r)),r=Math.ceil(i/Math.pow(r,s-1))),n=BV([]),n.leaf=!1,n.height=s;const a=Math.ceil(i/r),l=a*Math.ceil(Math.sqrt(r));$V(e,t,o,l,this.compareMinX);for(let i=t;i<=o;i+=l){const t=Math.min(i+l-1,o);$V(e,i,t,a,this.compareMinY);for(let o=i;o<=t;o+=a){const i=Math.min(o+a-1,t);n.children.push(this._build(e,o,i,s-1))}}return OV(n,this.toBBox),n}_chooseSubtree(e,t,o,s){for(;s.push(t),!t.leaf&&s.length-1!==o;){let o,s=1/0,r=1/0;for(let a=0;a<t.children.length;a++){const l=t.children[a],c=LV(l),h=(i=e,n=l,(Math.max(n.maxX,i.maxX)-Math.min(n.minX,i.minX))*(Math.max(n.maxY,i.maxY)-Math.min(n.minY,i.minY))-c);h<r?(r=h,s=c<s?c:s,o=l):h===r&&c<s&&(s=c,o=l)}t=o||t.children[0]}var i,n;return t}_insert(e,t,o){const s=o?e:this.toBBox(e),i=[],n=this._chooseSubtree(s,this.data,t,i);for(n.children.push(e),MV(n,s);t>=0&&i[t].children.length>this._maxEntries;)this._split(i,t),t--;this._adjustParentBBoxes(s,i,t)}_split(e,t){const o=e[t],s=o.children.length,i=this._minEntries;this._chooseSplitAxis(o,i,s);const n=this._chooseSplitIndex(o,i,s),r=BV(o.children.splice(n,o.children.length-n));r.height=o.height,r.leaf=o.leaf,OV(o,this.toBBox),OV(r,this.toBBox),t?e[t-1].children.push(r):this._splitRoot(o,r)}_splitRoot(e,t){this.data=BV([e,t]),this.data.height=e.height+1,this.data.leaf=!1,OV(this.data,this.toBBox)}_chooseSplitIndex(e,t,o){let s,i=1/0,n=1/0;for(let r=t;r<=o-t;r++){const t=PV(e,0,r,this.toBBox),a=PV(e,r,o,this.toBBox),l=UV(t,a),c=LV(t)+LV(a);l<i?(i=l,s=r,n=c<n?c:n):l===i&&c<n&&(n=c,s=r)}return s||o-t}_chooseSplitAxis(e,t,o){const s=e.leaf?this.compareMinX:NV,i=e.leaf?this.compareMinY:kV;this._allDistMargin(e,t,o,s)<this._allDistMargin(e,t,o,i)&&e.children.sort(s)}_allDistMargin(e,t,o,s){e.children.sort(s);const i=this.toBBox,n=PV(e,0,t,i),r=PV(e,o-t,o,i);let a=VV(n)+VV(r);for(let s=t;s<o-t;s++){const t=e.children[s];MV(n,e.leaf?i(t):t),a+=VV(n)}for(let s=o-t-1;s>=t;s--){const t=e.children[s];MV(r,e.leaf?i(t):t),a+=VV(r)}return a}_adjustParentBBoxes(e,t,o){for(let s=o;s>=0;s--)MV(t[s],e)}_condense(e){for(let t,o=e.length-1;o>=0;o--)0===e[o].children.length?o>0?(t=e[o-1].children,t.splice(t.indexOf(e[o]),1)):this.clear():OV(e[o],this.toBBox)}}function FV(e,t,o){if(!o)return t.indexOf(e);for(let s=0;s<t.length;s++)if(o(e,t[s]))return s;return-1}function OV(e,t){PV(e,0,e.children.length,t,e)}function PV(e,t,o,s,i){i||(i=BV(null)),i.minX=1/0,i.minY=1/0,i.maxX=-1/0,i.maxY=-1/0;for(let n=t;n<o;n++){const t=e.children[n];MV(i,e.leaf?s(t):t)}return i}function MV(e,t){return e.minX=Math.min(e.minX,t.minX),e.minY=Math.min(e.minY,t.minY),e.maxX=Math.max(e.maxX,t.maxX),e.maxY=Math.max(e.maxY,t.maxY),e}function NV(e,t){return e.minX-t.minX}function kV(e,t){return e.minY-t.minY}function LV(e){return(e.maxX-e.minX)*(e.maxY-e.minY)}function VV(e){return e.maxX-e.minX+(e.maxY-e.minY)}function UV(e,t){const o=Math.max(e.minX,t.minX),s=Math.max(e.minY,t.minY),i=Math.min(e.maxX,t.maxX),n=Math.min(e.maxY,t.maxY);return Math.max(0,i-o)*Math.max(0,n-s)}function HV(e,t){return e.minX<=t.minX&&e.minY<=t.minY&&t.maxX<=e.maxX&&t.maxY<=e.maxY}function zV(e,t){return t.minX<=e.maxX&&t.minY<=e.maxY&&t.maxX>=e.minX&&t.maxY>=e.minY}function BV(e){return{children:e,height:1,leaf:!0,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0}}function $V(e,t,o,s,i){const n=[t,o];for(;n.length;){if((o=n.pop())-(t=n.pop())<=s)continue;const r=t+Math.ceil((o-t)/s/2)*s;RV(e,r,t,o,i),n.push(t,r,r,o)}}class GV{rTrees={};constructor(e=[]){const t={};for(const o of e){const e=o.boundingBox.sheetId;t[e]||(t[e]=[]),t[e].push(o)}for(const e in t)this.rTrees[e]=new WV,this.rTrees[e].load(t[e])}insert(e){const t=e.boundingBox.sheetId;this.rTrees[t]||(this.rTrees[t]=new WV),this.rTrees[t].insert(e)}search({zone:e,sheetId:t}){return this.rTrees[t]?this.rTrees[t].search({minX:e.left,minY:e.top,maxX:e.right,maxY:e.bottom}):[]}remove(e){const t=e.boundingBox.sheetId;this.rTrees[t]&&this.rTrees[t].remove(e,this.rtreeItemComparer)}rtreeItemComparer(e,t){return e.boundingBox.sheetId===t.boundingBox.sheetId&&e.boundingBox?.zone.left===t.boundingBox.zone.left&&e.boundingBox?.zone.top===t.boundingBox.zone.top&&e.boundingBox?.zone.right===t.boundingBox.zone.right&&e.boundingBox?.zone.bottom===t.boundingBox.zone.bottom&&zt(e.data,t.data)}}class WV extends _V{toBBox({boundingBox:e}){const t=e.zone;return{minX:t.left,minY:t.top,maxX:t.right,maxY:t.bottom}}compareMinX(e,t){return e.boundingBox.zone.left-t.boundingBox.zone.left}compareMinY(e,t){return e.boundingBox.zone.top-t.boundingBox.zone.top}}class qV{profilesStartingPosition=[0];profiles=new Map([[0,[]]]);constructor(e=[]){for(const t of e)this.add(t)}isEmpty(){return 1===this.profiles.size&&0===this.profiles.get(0)?.length}add(e){Oo(this.profilesStartingPosition,this.profiles,[e])}delete(e){Oo(this.profilesStartingPosition,this.profiles,[e],!0)}has(e){return function(e,t,o){const s=o.left,i=o.right,n=o.top,r=o.bottom+1,a=Lo(e,s,0),l=Lo(e,i,a);if(-1===a||-1===l)return!1;for(let o=a;o<=l;o++){const s=t.get(e[o]),i=Lo(s,n,0,!0),a=Vo(s,r,0,!0);if(-1===i||i%2!=0)return!1;if(n<s[i]||r>s[a])return!1}return!0}(this.profilesStartingPosition,this.profiles,e)}difference(e){const t=this.copy();for(const o of e)t.delete(o);return t}copy(){const e=new qV;e.profilesStartingPosition=[...this.profilesStartingPosition],e.profiles=new Map;for(const[t,o]of this.profiles)e.profiles.set(t,[...o]);return e}size(){let e=0;for(const t of this.profiles.values())e+=t.length;return e/2}[Symbol.iterator](){return ko(this.profilesStartingPosition,this.profiles)[Symbol.iterator]()}}class ZV{setsBySheetId={};constructor(e=[]){for(const t of e)this.add(t)}add(e){this.setsBySheetId[e.sheetId]||(this.setsBySheetId[e.sheetId]=new qV),this.setsBySheetId[e.sheetId].add(e.zone)}addMany(e){for(const t of e)this.add(t)}addPosition(e){this.add(Ga(e))}addManyPositions(e){for(const t of e)this.addPosition(t)}has(e){return!!this.setsBySheetId[e.sheetId]&&this.setsBySheetId[e.sheetId].has(e.zone)}hasPosition(e){return this.has(Ga(e))}delete(e){this.setsBySheetId[e.sheetId]&&this.setsBySheetId[e.sheetId].delete(e.zone)}deleteMany(e){for(const t of e)this.delete(t)}deleteManyPositions(e){for(const t of e)this.delete(Ga(t))}difference(e){const t=new ZV;for(const e in this.setsBySheetId)t.setsBySheetId[e]=this.setsBySheetId[e];for(const o in e.setsBySheetId)t.setsBySheetId[o]&&(t.setsBySheetId[o]=t.setsBySheetId[o].difference(e.setsBySheetId[o]));return t}copy(){const e=new ZV;for(const t in this.setsBySheetId)e.setsBySheetId[t]=this.setsBySheetId[t].copy();return e}clear(){this.setsBySheetId={}}size(){let e=0;for(const t in this.setsBySheetId)e+=this.setsBySheetId[t].size();return e}isEmpty(){for(const e in this.setsBySheetId)if(!this.setsBySheetId[e].isEmpty())return!1;return!0}[Symbol.iterator](){const e=[];for(const t in this.setsBySheetId)for(const o of this.setsBySheetId[t])e.push({sheetId:t,zone:o});return e[Symbol.iterator]()}}class jV{rTree;constructor(e=[]){const t=function(e){let t=0,o=0;for(let s=0;s<e.length;s++){const i=e[s].boundingBox.zone;i.right>t&&(t=i.right),i.bottom>o&&(o=i.bottom)}t+=1,o+=1;const s=(((o+1)*t+1)*o+1)*t<=Number.MAX_SAFE_INTEGER;s||console.warn("Max col/row size exceeded, using slow zone key");const i={};for(const n of e){const e=n.boundingBox.sheetId;i[e]||(i[e]={});const r=n.boundingBox.zone;let a=0;if(a=s?r.left+r.top*t+r.right*t*o+r.bottom*t*o*t:`${r.left},${r.top},${r.right},${r.bottom}`,i[e][a]){i[e][a].data.add(n.data)}else i[e][a]={boundingBox:n.boundingBox,data:new ZV([n.data])}}const n=[];for(const e in i){const t=i[e];for(const e in t)n.push(t[e])}return n}(e);this.rTree=new GV(t)}insert(e){const t=this.rTree.search(e.boundingBox),o=e.boundingBox,s=t.find((({boundingBox:e})=>e.sheetId===o.sheetId&&e.zone.left===o.zone.left&&e.zone.top===o.zone.top&&e.zone.right===o.zone.right&&e.zone.bottom===o.zone.bottom));s?s.data.add(e.data):this.rTree.insert({...e,data:new ZV([e.data])})}search({zone:e,sheetId:t}){const o=new ZV;for(const{data:s}of this.rTree.search({zone:e,sheetId:t}))o.addMany(s);return o}remove(e){const t=this.rTree.search(e.boundingBox),o=e.boundingBox,s=t.find((({boundingBox:e})=>e.sheetId===o.sheetId&&e.zone.left===o.zone.left&&e.zone.top===o.zone.top&&e.zone.right===o.zone.right&&e.zone.bottom===o.zone.bottom));s?s.data.delete(e.data):this.rTree.remove({...e,data:new ZV([e.data])})}}class YV{dependencies=new tF;rTree;constructor(e=[]){this.rTree=new jV(e)}removeAllDependencies(e){const t=this.dependencies.get(e);if(t){for(const e of t)this.rTree.remove(e);this.dependencies.delete(e)}}addDependencies(e,t){const o=t.map((({sheetId:t,zone:o})=>({data:{sheetId:e.sheetId,zone:cs(e)},boundingBox:{zone:o,sheetId:t}})));for(const e of o)this.rTree.insert(e);const s=this.dependencies.get(e);s?s.push(...o):this.dependencies.set(e,o)}getCellsDependingOn(e,t=new ZV){t=t.copy();const o=Array.from(e).reverse();for(;o.length>0;){const e=o.pop();t.add(e);const s=this.rTree.search(e);o.push(...s.difference(t))}for(const o of e)t.delete(o);return t}}class XV extends Uint32Array{columnOffset=0;cols=0;rows=0;static create(e,t){const o=function(e){if(0===e)return-1/0;if(e<0)return NaN;return 32-Math.clz32(--e)}(t),s=new this((e<<o>>5)+1);return s.columnOffset=o,s.cols=t,s.rows=e,s}getValue(e){const[t,o]=this.getCoordinates(e);return this[t]>>o&1}setValue(e,t){const[o,s]=this.getCoordinates(e),i=0===(this[o]>>s&1)&&1===t;return this[o]=this[o]&~(1<<s)|t<<s,i}isEmpty(){return!this.some((e=>0!==e))}fillAllPositions(){this.fill(-1>>>0)}clear(){this.fill(0)}getCoordinates(e){const{row:t,col:o}=e,s=(t<<this.columnOffset)+o,i=s>>5;return[i,s-(i<<5)]}}class KV{sheets={};insertions=[];maxSize=0;constructor(e){for(const t in e){const o=e[t].cols,s=e[t].rows;this.maxSize+=o*s,this.sheets[t]=XV.create(s,o)}}add(e){this.sheets[e.sheetId].setValue(e,1)&&this.insertions.push(e)}addMany(e){for(const t of e)this.add(t)}delete(e){this.sheets[e.sheetId].setValue(e,0)}deleteMany(e){for(const t of e)this.delete(t)}has(e){return 1===this.sheets[e.sheetId].getValue(e)}clear(){const e=[...this];this.insertions=[];for(const e in this.sheets)this.sheets[e].clear();return e}isEmpty(){if(0===this.insertions.length)return!0;for(const e in this.sheets)if(!this.sheets[e].isEmpty())return!1;return!0}fillAllPositions(){this.insertions=new Array(this.maxSize);let e=0;for(const t in this.sheets){const o=this.sheets[t];o.fillAllPositions();for(let s=0;s<o.rows;s++)for(let i=0;i<o.cols;i++)this.insertions[e++]={sheetId:t,row:s,col:i}}}*[Symbol.iterator](){for(const e of this.insertions)1===this.sheets[e.sheetId].getValue(e)&&(yield e)}}class JV{resultsToArrayFormulas=new GV;arrayFormulasToResults=new tF;searchFormulaPositionsSpreadingOn(e,t){return this.resultsToArrayFormulas.search({sheetId:e,zone:t}).map((e=>e.data))||QV}getArrayResultZone(e){return this.arrayFormulasToResults.get(e)}removeNode(e){this.resultsToArrayFormulas.remove({boundingBox:{sheetId:e.sheetId,zone:cs(e)},data:e}),this.arrayFormulasToResults.delete(e)}addRelation({arrayFormulaPosition:e,resultZone:t}){this.resultsToArrayFormulas.insert({boundingBox:{sheetId:e.sheetId,zone:t},data:e}),this.arrayFormulasToResults.set(e,t)}isArrayFormula(e){return this.arrayFormulasToResults.has(e)}}const QV=[],eU=Object.freeze(ta({...new ln,origin:void 0})),tU=Object.freeze(ta({value:null}));class oU{context;getters;compilationParams;evaluatedCells=new tF;formulaDependencies=Vt(new YV);blockedArrayFormulas=new KV({});spreadingRelations=new JV;constructor(e,t){this.context=e,this.getters=t,this.compilationParams=xV(this.context,this.getters,this.computeAndSave.bind(this))}getEvaluatedCell(e){return this.evaluatedCells.get(e)||tU}getSpreadZone(e,t={ignoreSpillError:!1}){const o=this.spreadingRelations.getArrayResultZone(e);if(!o)return;const s=this.evaluatedCells.get(e);return s?.type!==r.error||t.ignoreSpillError&&s?.value===sn.SpilledBlocked?Yo(cs(e),o):cs(e)}getEvaluatedPositions(){return this.evaluatedCells.keys()}getEvaluatedPositionsInSheet(e){return this.evaluatedCells.keysForSheet(e)}getArrayFormulaSpreadingOn(e){if(this.getEvaluatedCell(e).type===r.empty)return;return this.spreadingRelations.searchFormulaPositionsSpreadingOn(e.sheetId,cs(e)).find((e=>!this.blockedArrayFormulas.has(e)))}updateDependencies(e){this.formulaDependencies().removeAllDependencies(e);const t=this.getDirectDependencies(e);this.formulaDependencies().addDependencies(e,t)}addDependencies(e,t){this.formulaDependencies().addDependencies(e,t);for(const e of t){const t=e.sheetId,{left:o,bottom:s,right:i,top:n}=e.zone;for(let e=o;e<=i;e++)for(let o=n;o<=s;o++)this.computeAndSave({sheetId:t,col:e,row:o})}}updateCompilationParameters(){this.compilationParams=xV(this.context,this.getters,this.computeAndSave.bind(this)),this.compilationParams.evalContext.updateDependencies=this.updateDependencies.bind(this),this.compilationParams.evalContext.addDependencies=this.addDependencies.bind(this),this.compilationParams.evalContext.lookupCaches={forwardSearch:new Map,reverseSearch:new Map}}createEmptyPositionSet(){const e={};for(const t of this.getters.getSheetIds())e[t]={rows:this.getters.getNumberRows(t),cols:this.getters.getNumberCols(t)};return new KV(e)}evaluateCells(e){const t=performance.now(),o=new ZV;o.addManyPositions(e);const s=this.getArrayFormulasImpactedByChangesOf(e);o.addMany(this.getCellsDependingOn(o)),o.addMany(s),o.addMany(this.getCellsDependingOn(s)),this.evaluate(o),console.debug("evaluate Cells",performance.now()-t,"ms")}getArrayFormulasImpactedByChangesOf(e){const t=new ZV;for(const o of e){const e=this.getters.getCell(o)?.content,s=this.getArrayFormulaSpreadingOn(o);void 0!==s&&t.addPosition(s),e||t.addPosition(o)}for(const e of[...t])t.addMany(this.getArrayFormulasBlockedBy(e.sheetId,e.zone));return t}buildDependencyGraph(){this.blockedArrayFormulas=this.createEmptyPositionSet(),this.spreadingRelations=new JV,this.formulaDependencies=Vt((()=>{const e=[];for(const t of this.getters.getSheetIds()){const o=this.getters.getCells(t);for(const s in o){const i=o[s];if(i.isFormula){const o=i.compiledFormula.dependencies;for(const i of o)i.invalidSheetName||i.invalidXc||e.push({data:{sheetId:t,zone:cs(this.getters.getCellPosition(s))},boundingBox:{sheetId:i.sheetId,zone:i.zone}})}}}return new YV(e)}))}evaluateAllCells(){const e=performance.now();this.evaluatedCells=new tF;const t=[];for(const e of this.getters.getSheetIds()){const o=this.getters.getSheetZone(e);t.push({sheetId:e,zone:o})}this.evaluate(t),console.debug("evaluate all cells",performance.now()-e,"ms")}evaluateFormulaResult(e,t){const o=$C(t),s=o.dependencies.map((t=>this.getters.getRangeFromSheetXC(e,t)));return this.updateCompilationParameters(),this.evaluateCompiledFormula(e,{...o,dependencies:s})}evaluateCompiledFormula(e,t,o){try{const s=nU(t,this.compilationParams,e,this.buildSafeGetSymbolValue(o),this.compilationParams.evalContext.__originCellPosition);return E(s)?Un(s,iU):iU(s)}catch(e){return DC(e,"")}}getArrayFormulasBlockedBy(e,t){const o=new ZV,s=this.spreadingRelations.searchFormulaPositionsSpreadingOn(e,t);o.addManyPositions(s);const i=[...s].filter((e=>!this.blockedArrayFormulas.has(e)));return i.length&&o.deleteManyPositions(i),o.addMany(this.getCellsDependingOn(o)),o}nextRangesToUpdate=new ZV;cellsBeingComputed=new Set;symbolsBeingComputed=new Set;evaluate(e){this.cellsBeingComputed=new Set,this.nextRangesToUpdate=new ZV(e);let t=0;for(;!this.nextRangesToUpdate.isEmpty()&&t++<30;){this.updateCompilationParameters();const e=[...this.nextRangesToUpdate];this.nextRangesToUpdate.clear(),this.clearEvaluatedRanges(e);for(const t of e){const{left:e,bottom:o,right:s,top:i}=t.zone;for(let n=e;n<=s;n++)for(let e=i;e<=o;e++){const o={sheetId:t.sheetId,col:n,row:e};if(this.nextRangesToUpdate.hasPosition(o))continue;const s=this.computeCell(o);s!==tU&&this.evaluatedCells.set(o,s)}}IV.getAll().forEach((e=>e(this.getters)))}t>=30&&console.warn("Maximum iteration reached while evaluating cells")}clearEvaluatedRanges(e){for(const t of e){const{left:e,bottom:o,right:s,top:i}=t.zone;for(let n=e;n<=s;n++)for(let e=i;e<=o;e++)this.evaluatedCells.delete({sheetId:t.sheetId,col:n,row:e})}}computeCell(e){const t=this.evaluatedCells.get(e);if(t)return t;this.blockedArrayFormulas.has(e)||this.invalidateSpreading(e),this.spreadingRelations.isArrayFormula(e)&&this.spreadingRelations.removeNode(e);const o=this.getters.getCell(e);if(void 0===o)return tU;const s=o.id,i={format:o.format,locale:this.getters.getLocale()};try{return this.cellsBeingComputed.has(s)?eU:(this.cellsBeingComputed.add(s),o.isFormula?this.computeFormulaCell(e,o):Qr(o,i,e))}catch(t){return t.value=t?.value||sn.GenericError,t.message=t?.message||FC,t.origin=e,ta(t)}finally{this.cellsBeingComputed.delete(s)}}computeAndSave(e){const t=this.computeCell(e);return this.evaluatedCells.has(e)||this.evaluatedCells.set(e,t),t}computeFormulaCell(e,t){const o=nU(t.compiledFormula,this.compilationParams,e.sheetId,this.buildSafeGetSymbolValue(),e);if(!E(o)){const s=ta(iU(o),this.getters.getLocale(),t,e);return s.type===r.error&&(s.errorOriginPosition=o.errorOriginPosition??e),s}this.assertSheetHasEnoughSpaceToSpreadFormulaResult(e,o);const s=o.length,i=o[0].length,n={top:e.row,bottom:e.row+i-1,left:e.col,right:e.col+s-1};return this.spreadingRelations.addRelation({resultZone:n,arrayFormulaPosition:e}),this.assertNoMergedCellsInSpreadZone(e,o),sU(s,i,this.checkCollision(e)),sU(s,i,this.spreadValues(e,o)),this.invalidatePositionsDependingOnSpread(e.sheetId,n),ta(iU(o[0][0]),this.getters.getLocale(),t)}invalidatePositionsDependingOnSpread(e,t){const o=this.getCellsDependingOn(function(e){const{top:t,left:o,bottom:s,right:i}=e;if(1===gs(e))return[];const n={top:t+1,bottom:s,left:o,right:o};if(i===o)return[n];const r={top:t,bottom:s,left:o+1,right:i};return t===s?[r]:[n,r]}(t).map((t=>({sheetId:e,zone:t}))));o.delete({sheetId:e,zone:t}),this.nextRangesToUpdate.addMany(o)}assertSheetHasEnoughSpaceToSpreadFormulaResult({sheetId:e,col:t,row:o},s){const i=this.getters.getNumberCols(e),n=this.getters.getNumberRows(e),r=t+s.length<=i,a=o+s[0].length<=n;if(!r||!a){if(r)throw new un(ui("Result couldn't be automatically expanded. Please insert more rows."));if(a)throw new un(ui("Result couldn't be automatically expanded. Please insert more columns."));throw new un(ui("Result couldn't be automatically expanded. Please insert more columns and rows."))}}assertNoMergedCellsInSpreadZone({sheetId:e,col:t,row:o},s){if(0!==this.getters.getMergesInZone(e,{top:o,bottom:o+s[0].length-1,left:t,right:t+s.length-1}).length)throw new un(ui("Merged cells found in the spill zone. Please unmerge cells before using array formulas."))}checkCollision(e){const{sheetId:t,col:o,row:s}=e;return(i,n)=>{const a={sheetId:t,col:i+o,row:n+s},l=this.getters.getCell(a);if(l?.content||this.getters.getEvaluatedCell(a).type!==r.empty)throw this.blockedArrayFormulas.add(e),new un(ui("Array result was not expanded because it would overwrite data in %s.",_o(a.col,a.row)));this.blockedArrayFormulas.delete(e)}}spreadValues({sheetId:e,col:t,row:o},s){return(i,n)=>{const a={sheetId:e,col:i+t,row:n+o},l=this.getters.getCell(a),c=ta(iU(s[i][n]),this.getters.getLocale(),l,a);c.type===r.error&&(c.errorOriginPosition=s[i][n].errorOriginPosition??a),this.evaluatedCells.set(a,c)}}invalidateSpreading(e){const t=this.spreadingRelations.getArrayResultZone(e);if(!t)return;for(let o=t.left;o<=t.right;o++)for(let s=t.top;s<=t.bottom;s++){const t={sheetId:e.sheetId,col:o,row:s},i=this.getters.getCell(t)?.content;i||this.evaluatedCells.delete(t)}const o=e.sheetId;this.invalidatePositionsDependingOnSpread(o,t),this.nextRangesToUpdate.addMany(this.getArrayFormulasBlockedBy(o,t))}buildSafeGetSymbolValue(e){return t=>{if(this.symbolsBeingComputed.has(t))return eU;this.symbolsBeingComputed.add(t);try{const o=e?.(t);return o||new an(ui("Invalid formula"))}finally{this.symbolsBeingComputed.delete(t)}}}getDirectDependencies(e){const t=this.getters.getCell(e);return t?.isFormula?t.compiledFormula.dependencies:[]}getCellsDependingOn(e){return this.formulaDependencies().getCellsDependingOn(e,this.nextRangesToUpdate)}}function sU(e,t,o){for(let s=0;s<e;++s)for(let e=0;e<t;++e)0===s&&0===e||o(s,e)}function iU(e){return null===e.value||void 0===e.value?{...e,value:0}:e}function nU(e,t,o,s,i){return t.evalContext.__originCellPosition=i,t.evalContext.__originSheetId=o,e.execute(e.dependencies,t.referenceDenormalizer,t.ensureRange,s,t.evalContext)}const rU=/"(#[0-9a-fA-F]{6})"/g;const aU={isValid:!0};const lU=new n;function cU(e,t){const o=t.model.getters.getPivotCellFromPosition(e),s=t.model.getters.getPivotIdFromPosition(e);if(!s||"HEADER"!==o.type)return;const i=t.model.getters.getPivotCoreDefinition(s),n=i.collapsedDomains?.[o.dimension]?[...i.collapsedDomains[o.dimension]]:[],r=n.findIndex((e=>zt(e,o.domain)));-1!==r?n.splice(r,1):n.push(o.domain);const a=i.collapsedDomains?{...i.collapsedDomains}:{COL:[],ROW:[]};a[o.dimension]=n,t.model.dispatch("UPDATE_PIVOT",{pivotId:s,pivot:{...i,collapsedDomains:a}})}lU.add("data_validation_checkbox",((e,t)=>{if(e.isCellValidCheckbox(t)){const o=!!e.getEvaluatedCell(t).value;return{svg:o?aA:nA,hoverSvg:o?aA:rA,priority:2,horizontalAlign:"center",size:17,margin:2,position:t,type:"data_validation_checkbox",onClick:(e,t)=>{const s=t.model.getters.getCell(e);if(t.model.getters.isReadonly()||!!s?.isFormula)return;const i=o?"FALSE":"TRUE";t.model.dispatch("UPDATE_CELL",{...e,content:i})}}}})),lU.add("data_validation_chip_icon",((e,t)=>{const o=e.getDataValidationChipStyle(t);if(o){const s=e.getCellComputedStyle(t);return{svg:sA(o),hoverSvg:iA(o),priority:10,horizontalAlign:"right",size:dl(s),margin:4,position:t,onClick:(e,t)=>{const{col:o,row:s}=e;t.model.selection.selectCell(o,s),t.startCellEdition()},type:"data_validation_chip_icon"}}})),lU.add("data_validation_list_icon",((e,t)=>{if(!e.isReadonly()&&e.cellHasListDataValidationIcon(t)){const s=e.getCellComputedStyle(t);return{svg:eA(s),hoverSvg:(o=s,{name:"CARET_DOWN",width:512,height:512,paths:[{fillColor:o.textColor||oe,path:"M15 15 h482 v482 h-482"},{fillColor:o.fillColor||"#fff",path:"M120 195 h270 l-135 130"}]}),priority:2,horizontalAlign:"right",size:17,margin:2,position:t,onClick:(e,t)=>{const{col:o,row:s}=e;t.model.selection.selectCell(o,s),t.startCellEdition()},type:"data_validation_list_icon"}}var o})),lU.add("filter_icon",((e,t)=>{if(e.isFilterHeader(t)){const o=e.isFilterActive(t),s=Ms(e.getCellComputedStyle(t).fillColor||"#fff")<.45;return{type:"filter_icon",svg:cA(o,s,!1),hoverSvg:cA(o,s,!0),priority:3,horizontalAlign:"right",size:17,margin:2,position:t,onClick:(e,t)=>{const o=t.getStore(KE),s=o.persistentCellPopover;s.isOpen&&s.col===e.col&&s.row===e.row&&"FilterMenu"===s.type?o.close():o.open(e,"FilterMenu")}}}})),lU.add("conditional_formatting",((e,t)=>{const o=e.getConditionalIcon(t);if(o){const s=e.getCellStyle(t);return{type:"conditional_formatting",svg:hA[o].svg,priority:1,horizontalAlign:"left",size:dl(s),margin:4,position:t}}})),lU.add("pivot_collapse",((e,t)=>{if(!e.isSpillPivotFormula(t))return;const o=e.getPivotCellFromPosition(t),s=e.getPivotIdFromPosition(t);if("HEADER"===o.type&&s&&o.domain.length){const i=e.getPivotCoreDefinition(s),n=e.isDashboard(),r="COL"===o.dimension?i.columns:i.rows,a=!n&&o.domain.length!==r.length,l=(i.collapsedDomains?.[o.dimension]??[]).some((e=>zt(e,o.domain))),c="ROW"===o.dimension?15*(o.domain.length-1):0;return{type:"pivot_collapse",priority:4,horizontalAlign:"left",size:a||!n&&"ROW"===o.dimension&&i.rows.length>1?12:0,margin:a?4+c:c,svg:a?lA(l,!1):void 0,hoverSvg:a?lA(l,!0):void 0,position:t,onClick:cU}}})),lU.add("pivot_dashboard_sorting",((e,t)=>{if(!e.isDashboard())return;if("MEASURE_HEADER"!==e.getPivotCellFromPosition(t).type)return;const o=e.getPivotCellSortDirection(t);if("asc"!==o&&"desc"!==o)return;const s=e.getCellComputedStyle(t);return{type:`pivot_dashboard_sorting_${o}`,priority:5,horizontalAlign:"right",size:17,margin:2,svg:"asc"===o?tA(s):eA(s),position:t,onClick:void 0}}));const hU="0.00%";function dU(e){return class extends e{getters;cache={};rankAsc={};rankDesc={};runningTotal={};runningTotalInPercent={};constructor(e,t){super(e,t),this.getters=t.getters}markAsDirtyForEvaluation(){this.cache={},this.rankAsc={},this.rankDesc={},this.runningTotal={},this.runningTotalInPercent={},super.markAsDirtyForEvaluation?.()}getPivotCellValueAndFormat(e,t){return this.getMeasureDisplayValue(e,t)}_getPivotCellValueAndFormat(e,t){const o=`${e}-${t.map((e=>e.field+"="+e.value)).join(",")}`;if(this.cache[o])return this.cache[o];const s=this.getMeasure(e),i=s.computedBy?this.computeMeasure(s,t):super.getPivotCellValueAndFormat(e,t);return s.format?this.cache[o]={...i,format:s.format}:this.cache[o]=i,this.cache[o]}computeMeasure(e,t){if(!e.computedBy)return{value:0};const{columns:o,rows:s}=super.definition;if(e.aggregator&&o.length+s.length!==t.length){const o=this.getValuesToAggregate(e,t),s=Kc[e.aggregator];if(!s)return{value:0};try{return s([o],this.getters.getLocale())}catch(t){return DC(t,e.aggregator.toUpperCase())}}const i=this.getters.getMeasureCompiledFormula(e),n=this.getters.evaluateCompiledFormula(e.computedBy.sheetId,i,(e=>{const{columns:o,rows:s}=this.definition;if(o.find((t=>t.nameWithGranularity===e))){const{colDomain:o}=jO(this,t),s=o.findIndex((t=>t.field===e));return-1===s?new hn:this.getPivotHeaderValueAndFormat(o.slice(0,s+1))}if(s.find((t=>t.nameWithGranularity===e))){const{rowDomain:o}=jO(this,t),s=o.findIndex((t=>t.field===e));return-1===s?new hn:this.getPivotHeaderValueAndFormat(o.slice(0,s+1))}return this.getPivotCellValueAndFormat(e,t)}));return E(n)?n[0][0]:n}getValuesToAggregate(e,t){const{rowDomain:o,colDomain:s}=jO(this,t),i=super.getExpandedTableStructure(),n=[];if(0===s.length&&o.length<this.definition.rows.length&&this.definition.rows.length&&this.definition.columns.length){const t=this.treeToLeafDomains(i.getColTree()),s=this.getSubTreeMatchingDomain(i.getRowTree(),o),r=this.treeToLeafDomains(s);for(const s of t)for(const t of r)n.push(this._getPivotCellValueAndFormat(e.id,o.concat(t).concat(s)));return n}if(o.length===this.definition.rows.length&&0===s.length){const t=i.getColTree(),r=this.getSubTreeMatchingDomain(t,s),a=this.treeToLeafDomains(r,s);for(const t of a)n.push(this._getPivotCellValueAndFormat(e.id,o.concat(t)));return n}if(o.length===this.definition.rows.length&&s.length&&s.length<this.definition.columns.length){const t=this.getSubTreeMatchingDomain(i.getColTree(),s),r=this.treeToLeafDomains(t,s);for(const t of r)n.push(this._getPivotCellValueAndFormat(e.id,o.concat(t)));return n}{const t=i.getRowTree(),r=this.getSubTreeMatchingDomain(t,o),a=this.treeToLeafDomains(r,o);for(const t of a)n.push(this._getPivotCellValueAndFormat(e.id,t.concat(s)));return n}}getSubTreeMatchingDomain(e,t,o=0){if(o>t.length)return[];if(t.length===o)return e;for(const s of e){const e=rh(this.definition.getDimension(s.field),t[o]?.value);if(s.field===t[o]?.field&&s.value===e)return this.getSubTreeMatchingDomain(s.children,t,o+1)}return[]}treeToLeafDomains(e,t=[]){const o=[];for(const s of e){const e=this.definition.getDimension(s.field),i=[...t,{field:s.field,value:s.value,type:e.type}];0===s.children.length?o.push(i):o.push(...this.treeToLeafDomains(s.children,i))}return o}getMeasureDisplayValue(e,t){const o=this.getMeasure(e),s=this._getPivotCellValueAndFormat(e,t);if(!o.display||"no_calculations"===o.display.type||s.message)return s;const i=o.display.fieldNameWithGranularity;if(i&&!this.isFieldInPivot(i))return{value:sn.NotAvailable,message:ui('Field "%s" not found in pivot for measure display calculation',i)};try{const e=o.display;switch(e.type){case"%_of_grand_total":return this.asPercentOfGrandTotal(s,o);case"%_of_col_total":return this.asPercentOfColumnTotal(s,o,t);case"%_of_row_total":return this.asPercentOfRowTotal(s,o,t);case"%_of_parent_row_total":return this.asPercentOfParentRowTotal(s,o,t);case"%_of_parent_col_total":return this.asPercentOfParentColumnTotal(s,o,t);case"index":return this.asIndex(s,o,t);case"%_of_parent_total":return this.asPercentOfParentTotal(s,o,t,e);case"running_total":return this.asRunningTotal(s,o,t,e,"running_total");case"%_running_total":return this.asRunningTotal(s,o,t,e,"%_running_total");case"rank_asc":return this.asRank(s,o,t,e,"asc");case"rank_desc":return this.asRank(s,o,t,e,"desc");case"%_of":return this.asPercentOf(s,o,t,e);case"difference_from":return this.asDifferenceFrom(s,o,t,e);case"%_difference_from":return this.asDifferenceFromInPercent(s,o,t,e)}return s}catch(e){return DC(e,"COMPUTE_MEASURE_DISPLAY_VALUE")}}asPercentOfGrandTotal(e,t){const o=this.getGrandTotal(t.id);return 0===o?{value:sn.DivisionByZero}:{value:this.measureValueToNumber(e)/o,format:hU}}asPercentOfRowTotal(e,t,o){const s=this.getRowTotal(t.id,o);return 0===s?{value:sn.DivisionByZero}:{value:this.measureValueToNumber(e)/s,format:hU}}asPercentOfColumnTotal(e,t,o){const s=this.getColumnTotal(t.id,o);return 0===s?{value:sn.DivisionByZero}:{value:this.measureValueToNumber(e)/s,format:hU}}asPercentOfParentRowTotal(e,t,o){const s=function(e,t){const{colDomain:o,rowDomain:s}=jO(e,t);return[...o,...s.slice(0,s.length-1)]}(this,o),i=this.measureValueToNumber(this._getPivotCellValueAndFormat(t.id,s));return 0===i?{value:""}:{value:this.measureValueToNumber(e)/i,format:hU}}asPercentOfParentColumnTotal(e,t,o){const s=function(e,t){const{colDomain:o,rowDomain:s}=jO(e,t);return[...o.slice(0,o.length-1),...s]}(this,o),i=this.measureValueToNumber(this._getPivotCellValueAndFormat(t.id,s));return 0===i?{value:""}:{value:this.measureValueToNumber(e)/i,format:hU}}asPercentOfParentTotal(e,t,o,s){const{fieldNameWithGranularity:i}=s;if(!i)return e;if(!QO(i,o))return{value:""};const n=function(e,t,o){let{rowDomain:s,colDomain:i}=jO(e,o);if("row"===eP(e,t)){const e=s.findIndex((e=>e.field===t));if(-1===e)return o;s=s.slice(0,e+1)}else{const e=i.findIndex((e=>e.field===t));if(-1===e)return o;i=i.slice(0,e+1)}return[...s,...i]}(this,i,o),r=this._getPivotCellValueAndFormat(t.id,n),a=this.measureValueToNumber(r);return 0===a?{value:""}:{value:this.measureValueToNumber(e)/a,format:hU}}asIndex(e,t,o){const s=this.measureValueToNumber(e),i=this.getRowTotal(t.id,o),n=this.getColumnTotal(t.id,o),r=this.getGrandTotal(t.id);return 0===i||0===n?{value:sn.DivisionByZero}:{value:s*r/(n*i),format:void 0}}asRunningTotal(e,t,o,s,i){const{fieldNameWithGranularity:n}=s;if(!n)return e;const r="running_total"===i?this.runningTotal:this.runningTotalInPercent;let a=r[t.id]?.[n];a||(a=this.computeRunningTotal(t,n,i),r[t.id]||(r[t.id]={}),r[t.id][n]=a);const{rowDomain:l,colDomain:c}=jO(this,o),h=tP(c),d=tP(l),u=a[h]?.[d];return{value:u??"",format:"running_total"===i?e.format:hU}}asPercentOf(e,t,o,s){const{fieldNameWithGranularity:i,value:n}=s;if(void 0===n||!i)return e;if(!QO(i,o))return{value:""};const r=this.getComparisonValue(t,o,i,n),a=this.strictMeasureValueToNumber(e);return 0===r||"sameValue"===r&&0===a?{value:sn.DivisionByZero}:!r||"sameValue"===r&&!a?{value:""}:"sameValue"===r?{value:1,format:hU}:void 0===a?{value:sn.NullError}:{value:a/r,format:hU}}asDifferenceFrom(e,t,o,s){const{fieldNameWithGranularity:i,value:n}=s;if(void 0===n||!i)return e;if(!QO(i,o))return{value:""};const r=this.getComparisonValue(t,o,i,n)||0;return"sameValue"===r?{value:""}:{value:this.measureValueToNumber(e)-r,format:e.format}}asDifferenceFromInPercent(e,t,o,s){const{fieldNameWithGranularity:i,value:n}=s;if(void 0===n||!i)return e;if(!QO(i,o))return{value:""};const r=this.getComparisonValue(t,o,i,n),a=this.strictMeasureValueToNumber(e);return 0===r?{value:sn.DivisionByZero}:r&&"sameValue"!==r?void 0===a?{value:sn.NullError}:{value:(a-r)/r,format:hU}:{value:""}}asRank(e,t,o,s,i){const{fieldNameWithGranularity:n}=s;if(!n)return e;if(!QO(n,o))return{value:""};const r="asc"===i?this.rankAsc:this.rankDesc;let a=r[t.id]?.[n];a||(a=this.computeRank(t,n,i),r[t.id]||(r[t.id]={}),r[t.id][n]=a);const{rowDomain:l,colDomain:c}=jO(this,o),h=tP(c),d=tP(l),u=a[h]?.[d];return{value:u??""}}computeRank(e,t,o){const s={},i=eP(this,t),n="row"===i?"column":"row";let r=this.getPivotValueCells(e.id);"column"===i&&(r=Hn(r));for(const a of r){const r=tP(YO(this,n,a[0].domain)),l=a.map((t=>({...t,value:this.strictMeasureValueToNumber(this._getPivotCellValueAndFormat(e.id,t.domain)),rowDomain:YO(this,i,t.domain)}))).filter((e=>QO(t,e.rowDomain))),c=Object.groupBy(l,(e=>sP(e.rowDomain,t)));for(const e in c)c[e]=lo(c[e]||[],(e=>e.value)).filter((e=>void 0!==e.value)).sort(((e,t)=>"asc"===o?e.value-t.value:t.value-e.value));s[r]={};for(const e of l){const o=tP(YO(this,i,e.domain)),n=c[sP(e.rowDomain,t)];if(!n)continue;const a=n.findIndex((t=>t.value===e.value));-1!==a&&(s[r][o]=a+1)}}return"row"===i?s:co(s)}computeRunningTotal(e,t,o){const s={},i=eP(this,t),n="row"===i?"column":"row";let r=this.getPivotValueCells(e.id);"column"===i&&(r=Hn(r));for(const a of r){const r=tP(YO(this,n,a[0].domain));s[r]={};const l={},c=a.map((t=>({...t,rowDomain:YO(this,i,t.domain),value:this.measureValueToNumber(this._getPivotCellValueAndFormat(e.id,t.domain))}))).filter((e=>QO(t,e.rowDomain)));for(const e of c){const o=tP(e.rowDomain),i=iP(e.rowDomain,t),n=(l[i]||0)+e.value;l[i]=n,s[r][o]=n}if("%_running_total"===o)for(const e of c){const o=e.rowDomain,i=tP(o),n=iP(o,t),a=s[r][i]||0,c=l[n];s[r][i]=c?a/c:void 0}}return"row"===i?s:co(s)}getGrandTotal(e){const t=this._getPivotCellValueAndFormat(e,[]);return this.measureValueToNumber(t)}getRowTotal(e,t){const o=jO(this,t).rowDomain,s=this._getPivotCellValueAndFormat(e,o);return this.measureValueToNumber(s)}getColumnTotal(e,t){const o=jO(this,t).colDomain,s=this._getPivotCellValueAndFormat(e,o);return this.measureValueToNumber(s)}isFieldInPivot(e){return this.definition.columns.some((t=>t.nameWithGranularity===e))||this.definition.rows.some((t=>t.nameWithGranularity===e))}getComparisonValue(e,t,o,s){const i=s===qO||s===ZO?function(e,t,o,s){const i=eP(e,o),n="row"===i?e.getExpandedTableStructure().getRowTree():e.getExpandedTableStructure().getColTree(),r=KO(YO(e,i,t),n,o),a=r?.map((e=>e.value))??[],l=function(e,t){const o=t.find((t=>t.field===e));return o?.value}(o,t);if(void 0===l)return;const c=a.indexOf(l);if(void 0===l||-1===c)return;return JO(t,o,a[St(c+(s===qO?-1:1),0,a.length-1)])}(this,t,o,s):JO(t,o,s);if(zt(i,t))return"sameValue";if(!i||!function(e,t){for(const o of t)if(void 0===e.definition.rows.find((e=>e.nameWithGranularity===o.field))&&void 0===e.definition.columns.find((e=>e.nameWithGranularity===o.field)))return!1;const{rowDomain:o,colDomain:s}=jO(e,t);return XO(o,e.getExpandedTableStructure().getRowTree())&&XO(s,e.getExpandedTableStructure().getColTree())}(this,i))throw new hn;const n=this._getPivotCellValueAndFormat(e.id,i);return this.strictMeasureValueToNumber(n)}getPivotValueCells(e){return this.getCollapsedTableStructure().getPivotCells().map((t=>t.filter((t=>"VALUE"===t.type&&t.measure===e)))).filter((e=>e.length>0))}measureValueToNumber(e){if("number"==typeof e.value)return e.value;if(!e.value)return 0;throw new Error(`Value ${e.value} is not a number`)}strictMeasureValueToNumber(e){if("number"==typeof e.value)return e.value;if(e.value)throw new Error(`Value ${e.value} is not a number`)}getCollapsedTableStructure(){const e=super.getCollapsedTableStructure();return this.sortTableStructure(e),e}getExpandedTableStructure(){const e=super.getExpandedTableStructure();return this.sortTableStructure(e),e}sortTableStructure(e){if(!this.definition.sortedColumn||e.isSorted)return;const t=this.definition.sortedColumn.measure;gh(this.definition.sortedColumn,this)&&e.sort(t,this.definition.sortedColumn,((e,t)=>this._getPivotCellValueAndFormat(e,t)))}}}const uU=["ADD_PIVOT","UPDATE_PIVOT","REMOVE_PIVOT"];function gU(e){return uU.includes(e.type)}const pU=new n;pU.add("ALPHANUMERIC_INCREMENT_MODIFIER",{apply:(e,t)=>{e.current+=e.increment;let o=Math.abs(e.current).toString();o="0".repeat(Math.max(e.numberPostfixLength-o.length,0))+o;const s=`${e.prefix}${o}`;return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:s},tooltip:{props:{content:s}}}}}).add("INCREMENT_MODIFIER",{apply:(e,t,o)=>{e.current+=e.increment;const s=e.current.toString(),i=o.getLocale(),n=Rr(e.current,{format:t.cell?.format,locale:i});return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:s},tooltip:s?{props:{content:n}}:void 0}}}).add("DATE_INCREMENT_MODIFIER",{apply:(e,t,o)=>{const s=Dn(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=zi(s);e.current=i;const n=o.getLocale(),r=Rr(i,{format:t.cell?.format,locale:n});return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:i.toString()},tooltip:i?{props:{content:r}}:void 0}}}).add("COPY_MODIFIER",{apply:(e,t,o)=>{const s=t.cell?.content||"",i={locale:o.getLocale(),format:t.cell?.format};return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:s},tooltip:s?{props:{content:t.cell?Qr(t.cell,i).formattedValue:""}}:void 0}}}).add("FORMULA_MODIFIER",{apply:(e,t,o,s)=>{e.current+=e.increment;let i=0,n=0;switch(s){case"up":i=0,n=-e.current;break;case"down":i=0,n=e.current;break;case"left":i=-e.current,n=0;break;case"right":i=e.current,n=0}const r=t.cell;if(!r||!r.isFormula)return{cellData:{}};const a=t.sheetId,l=o.getTranslatedCellFormula(a,i,n,r.compiledFormula.tokens);return{cellData:{border:t.border,style:r.style,format:r.format,content:l},tooltip:l?{props:{content:l}}:void 0}}});const mU=new n,fU=/(\d+)$/,vU=/^(.*\D+)/,bU=/^(.*\D+)(\d+)$/,SU=/^0*/;function CU(e,t,o){let s=[],i=!1;for(const n of t){n===e&&(i=!0);const t=void 0===n||n.isFormula?void 0:Qr(n,{locale:w,format:n.format});if(t&&o(t))s.push(t);else{if(i)return s;s=[]}}return s}function yU(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 IU(e){if(e.length<2)return 1;const t=e.map((e=>Dn(e,w))),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=Ii.fromTimestamp(e[o-1].getTime()),i=Yi(s,t),n=Zi(s,t)%12;s.setFullYear(s.getFullYear()+i),s.setMonth(s.getMonth()+n);return{years:i,months:n,days:ji(s,t)}}));return t.slice(1)}(t),s=(i=o).length<2?i[0]||{years:0,months:0,days:0}:i.every((e=>e.years===i[0].years&&e.months===i[0].months&&e.days===i[0].days))?i[0]:void 0;var i;if(void 0===s)return;const n=1===Object.values(s).filter((e=>0!==e)).length,r=Object.values(s).every((e=>0===e));if(!n||r){const o=t.map(((e,o)=>{if(0===o)return 0;const s=t[o-1];return Math.floor(e.getTime())-Math.floor(s.getTime())})).slice(1);if(o.every((e=>e===o[0])))return e.length*(e[1]-e[0])}return{years:s.years*e.length,months:s.months*e.length,days:s.days*e.length}}mU.add("simple_value_copy",{condition:(e,t)=>!(1!==t.length||e.isFormula||e.format&&Mr(e.format)),generateRule:()=>({type:"COPY_MODIFIER"}),sequence:10}).add("increment_alphanumeric_value",{condition:e=>!e.isFormula&&Qr(e,{locale:w}).type===r.text&&bU.test(e.content),generateRule:(e,t,o)=>{const s=parseInt(e.content.match(fU)[0]),i=e.content.match(vU)[0],n=CU(e,t,(e=>e.type===r.text&&bU.test(e.value))).filter((e=>i===(e.value??"").toString().match(vU)[0])).map((e=>(e.value??"").toString().match(fU)[0])),a=n.reduce(((e,t)=>{const o=t.match(SU)[0].length;return o>e[1]?[t,o]:e}),[n[0],0]),l=a[1]?a[0].length:0;let c=yU(n.map((e=>parseInt(e))));return["up","left"].includes(o)&&1===n.length&&(c=-c),{type:"ALPHANUMERIC_INCREMENT_MODIFIER",prefix:i,current:s,increment:c,numberPostfixLength:l}},sequence:15}).add("copy_text",{condition:e=>!e.isFormula&&Qr(e,{locale:w}).type===r.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&&Qr(e,{locale:w}).type===r.number&&!!e.format&&Mr(e.format),generateRule:(e,t)=>{const o=IU(CU(e,t,(e=>e.type===r.number&&!!e.format&&Mr(e.format))).map((e=>Number(e.value))));if(void 0===o)return{type:"COPY_MODIFIER"};const s=Qr(e,{locale:w});return"object"==typeof o?{type:"DATE_INCREMENT_MODIFIER",increment:o,current:s.type===r.number?s.value:0}:{type:"INCREMENT_MODIFIER",increment:o,current:s.type===r.number?s.value:0}},sequence:25}).add("increment_number",{condition:e=>!e.isFormula&&Qr(e,{locale:w}).type===r.number,generateRule:(e,t,o)=>{const s=CU(e,t,(e=>e.type===r.number&&!Mr(e.format||""))).map((e=>Number(e.value)));let i=yU(s);["up","left"].includes(o)&&1===s.length&&(i=-i);const n=Qr(e,{locale:w});return{type:"INCREMENT_MODIFIER",increment:i,current:n.type===r.number?n.value:0}},sequence:40});class wU{cells;getters;index=0;direction;constructor(e,t,o){this.cells=e,this.getters=t,this.direction=o}next(){const e=this.cells[this.index++%this.cells.length],t=e.rule,{cellData:o,tooltip:s}=pU.get(t.type).apply(t,e.data,this.getters,this.direction);return{cellData:o,tooltip:s,origin:{col:e.data.col,row:e.data.row}}}}const xU=new class extends n{addTransformation(e,t,o){this.content[e]||(this.content[e]=new Map);for(const s of t)this.content[e].set(s,o);return this}getTransformation(e,t){return this.content[t]&&this.content[t].get(e)}};const EU=new class extends n{add(e,t){return super.add(e,t),this}replace(e,t){return super.replace(e,t),this}get(e){return this.content[e]}};function RU(e,t){if("SPREADSHEET"!==e.pivot.type)return e;if(e.pivot.dataSet?.sheetId!==t.sheetId)return e;const o=Ih(e.pivot.dataSet.zone,t),s=o?{...e.pivot.dataSet,zone:o}:void 0;return{...e,pivot:{...e.pivot,dataSet:s}}}function TU(e,t){if(e.sheetId!==t.sheetId)return e;if(("FREEZE_COLUMNS"===e.type?"COL":"ROW")!==t.dimension)return e;let o=e.quantity;if("REMOVE_COLUMNS_ROWS"===t.type){const e=[...t.elements].sort(((e,t)=>t-e));for(const t of e)o>t&&o--}if("ADD_COLUMNS_ROWS"===t.type){o=o>("before"===t.position?t.base-1:t.base)?o+t.quantity:o}return o>0?{...e,quantity:o}:void 0}function AU(e,t){if(e.sheetId!==t.sheetId)return e;const o=Ih(e.zone,t);if(!o)return;const s=e.newTableRange?wh(e.newTableRange,t):void 0;return{...e,newTableRange:s,zone:o}}function DU(e,t){if(e.sheetId!==t.sheetId||e.dimension!==t.dimension)return e;let o;if("REMOVE_COLUMNS_ROWS"===t.type)o=Fa(t.elements,[e.base])[0];else if("ADD_COLUMNS_ROWS"===t.type){o=_a(Ht(t.position,t.base),t.quantity,[e.base])[0]}return void 0!==o?{...e,base:o}:void 0}function _U(e,t){if(e.sheetId!==t.sheetId||e.dimension!==t.dimension)return e;const o=Ct(e.start,e.end+1);let s=[];if("REMOVE_COLUMNS_ROWS"===t.type)s=Fa(t.elements,o);else if("ADD_COLUMNS_ROWS"===t.type){s=_a(Ht(t.position,t.base),t.quantity,o)}return 0!==s.length?{...e,start:Math.min(...s),end:Math.max(...s)}:void 0}function FU(e,t){return(e=pt(e)).pivot.measures.map((e=>{e.computedBy&&(e.computedBy.formula=YC(e.computedBy.sheetId,e.computedBy.formula,t))})),e}function OU(e,t){return{...e,definition:cE(e.sheetId,e.definition,t)}}xU.addTransformation("ADD_COLUMNS_ROWS",["ADD_COLUMNS_ROWS"],DU),xU.addTransformation("REMOVE_COLUMNS_ROWS",["ADD_COLUMNS_ROWS"],DU),xU.addTransformation("DELETE_SHEET",["MOVE_RANGES"],(function(e,t){const o=t.sheetId;if(e.targetSheetId===o||e.sheetId===o)return;return e})),xU.addTransformation("DELETE_FIGURE",["UPDATE_FIGURE","UPDATE_CHART","UPDATE_CAROUSEL"],(function(e,t){if(e.figureId===t.figureId)return;return e})),xU.addTransformation("DELETE_CHART",["UPDATE_CHART"],(function(e,t){if(e.chartId===t.chartId)return;return e})),xU.addTransformation("DELETE_CHART",["UPDATE_CAROUSEL"],(function(e,t){return{...e,definition:{...e.definition,items:e.definition.items.filter((e=>!("chart"===e.type&&e.chartId===t.chartId)))}}})),xU.addTransformation("CREATE_SHEET",["CREATE_SHEET"],(function(e,t){e.sheetId===t.sheetId&&(e={...e,sheetId:`${e.sheetId}~`});if(e.name===t.name)return{...e,name:e.name?.match(/\d+/)?e.name.replace(/\d+/,(e=>(parseInt(e)+1).toString())):`${e.name}~`,position:e.position+1};return e})),xU.addTransformation("ADD_MERGE",["ADD_MERGE","REMOVE_MERGE"],(function(e,t){if(e.sheetId!==t.sheetId)return e;const o=[];for(const s of e.target)t.target.every((e=>!Qo(s,e)))&&o.push(s);if(o.length)return{...e,target:o};return})),xU.addTransformation("ADD_COLUMNS_ROWS",["FREEZE_COLUMNS","FREEZE_ROWS"],TU),xU.addTransformation("REMOVE_COLUMNS_ROWS",["FREEZE_COLUMNS","FREEZE_ROWS"],TU),xU.addTransformation("ADD_COLUMNS_ROWS",["UPDATE_TABLE"],AU),xU.addTransformation("REMOVE_COLUMNS_ROWS",["UPDATE_TABLE"],AU),xU.addTransformation("REMOVE_TABLE_STYLE",["CREATE_TABLE","UPDATE_TABLE"],(function(e,t){if(e.config?.styleId!==t.tableStyleId)return e;return{...e,config:{...e.config,styleId:MT.styleId}}})),xU.addTransformation("ADD_COLUMNS_ROWS",["GROUP_HEADERS","UNGROUP_HEADERS","FOLD_HEADER_GROUP","UNFOLD_HEADER_GROUP"],_U),xU.addTransformation("REMOVE_COLUMNS_ROWS",["GROUP_HEADERS","UNGROUP_HEADERS","FOLD_HEADER_GROUP","UNFOLD_HEADER_GROUP"],_U),xU.addTransformation("REMOVE_PIVOT",["RENAME_PIVOT","DUPLICATE_PIVOT","INSERT_PIVOT","UPDATE_PIVOT"],(function(e,t){if(e.pivotId===t.pivotId)return;return e})),xU.addTransformation("DELETE_SHEET",["ADD_PIVOT","UPDATE_PIVOT"],(function(e,t){if("SPREADSHEET"!==e.pivot.type)return e;if(e.pivot.dataSet?.sheetId===t.sheetId)return{...e,pivot:{...e.pivot,dataSet:void 0}};return e})),xU.addTransformation("ADD_COLUMNS_ROWS",["ADD_PIVOT","UPDATE_PIVOT"],RU),xU.addTransformation("REMOVE_COLUMNS_ROWS",["ADD_PIVOT","UPDATE_PIVOT"],RU),EU.add("UPDATE_CELL",(function(e,t){const o=e.content&&YC(e.sheetId,e.content,t);return{...e,content:o}})),EU.add("ADD_CONDITIONAL_FORMAT",(function(e,t){const o=e.cf.rule;if(e={...e,cf:{...e.cf}},"CellIsRule"===o.type)e.cf.rule={...o,values:o.values.map((o=>YC(e.sheetId,o,t)))};else if("ColorScaleRule"===o.type){const{minimum:s,maximum:i,midpoint:n}=o;e.cf.rule={...o,minimum:{...s,value:s.value&&YC(e.sheetId,s.value,t)},maximum:{...i,value:i.value&&YC(e.sheetId,i.value,t)},midpoint:n?{...n,value:YC(e.sheetId,n.value,t)}:void 0}}else if("IconSetRule"===o.type){const{upperInflectionPoint:s,lowerInflectionPoint:i}=o;e.cf.rule={...o,upperInflectionPoint:{...s,value:YC(e.sheetId,s.value,t)},lowerInflectionPoint:{...i,value:YC(e.sheetId,i.value,t)}}}else"DataBarRule"===o.type&&(e.cf.rule={...o,rangeValues:o.rangeValues?XC(e.sheetId,o.rangeValues,t):void 0});return e})),EU.add("ADD_DATA_VALIDATION_RULE",(function(e,t){return(e={...e,rule:{...e.rule,criterion:{...e.rule.criterion}}}).rule.criterion.values=e.rule.criterion.values.map((o=>YC(e.sheetId,o,t))),e})),EU.add("ADD_PIVOT",FU),EU.add("UPDATE_PIVOT",FU),EU.add("CREATE_CHART",OU),EU.add("UPDATE_CHART",OU);const PU=[{match:function(e){return"sheetId"in e},fn:kU},{match:function(e){return"target"in e&&"sheetId"in e},fn:function(e,t){const o=kU(e,t);if("SKIP_TRANSFORMATION"!==o)return"IGNORE_COMMAND"===o?"IGNORE_COMMAND":e;const s=[];for(const o of e.target){const e=Ih(o,t);e&&s.push(e)}if(!s.length)return"IGNORE_COMMAND";return{...e,target:s}}},{match:function(e){return"sheetId"in e&&"zone"in e},fn:function(e,t){const o=kU(e,t);if("SKIP_TRANSFORMATION"!==o)return"IGNORE_COMMAND"===o?"IGNORE_COMMAND":e;const s=Ih(e.zone,t);if(s)return{...e,zone:s};return"IGNORE_COMMAND"}},{match:function(e){return"col"in e&&"row"in e&&"sheetId"in e},fn:function(e,t){const o=kU(e,t);if("SKIP_TRANSFORMATION"!==o)return"IGNORE_COMMAND"===o?"IGNORE_COMMAND":e;if("ADD_COLUMNS_ROWS"===t.type||"REMOVE_COLUMNS_ROWS"===t.type)return function(e,t){const o="COL"===t.dimension?"col":"row";let s=e[o];if("REMOVE_COLUMNS_ROWS"===t.type){const e=[...t.elements].sort(((e,t)=>t-e));if(e.includes(s))return"IGNORE_COMMAND";for(const t of e)s>=t&&s--}"ADD_COLUMNS_ROWS"===t.type&&(s>t.base||s===t.base&&"before"===t.position)&&(s+=t.quantity);return{...e,[o]:s}}(e,t);if("ADD_MERGE"===t.type)return function(e,t){for(const o of t.target){if(!(e.col===o.left&&e.row===o.top)&&es(e.col,e.row,o))return"IGNORE_COMMAND"}return e}(e,t);return"SKIP_TRANSFORMATION"}},{match:function(e){return"dimension"in e&&"sheetId"in e&&"elements"in e},fn:function(e,t){const o=kU(e,t);if("SKIP_TRANSFORMATION"!==o)return"IGNORE_COMMAND"===o?"IGNORE_COMMAND":e;if("ADD_COLUMNS_ROWS"!==t.type&&"REMOVE_COLUMNS_ROWS"!==t.type)return"SKIP_TRANSFORMATION";if(t.dimension!==e.dimension)return e;let s=[];if("REMOVE_COLUMNS_ROWS"===t.type)s=Fa(t.elements,e.elements);else if("ADD_COLUMNS_ROWS"===t.type){s=_a(Ht(t.position,t.base),t.quantity,e.elements)}if(0===s.length)return"IGNORE_COMMAND";return{...e,elements:s}}},{match:function(e){return"ranges"in e},fn:function(e,t){if(!("sheetId"in t))return e;const o=e.ranges.map((e=>wh(e,t))).filter(Mt);if(!o.length)return"IGNORE_COMMAND";return{...e,ranges:o}}}];function MU(e,t){const o=xU.getTransformation(e.type,t.type),s=o?o(e,t):function(e,t){for(const{match:o,fn:s}of PU)if(o(e)){const o=s(e,t);if("SKIP_TRANSFORMATION"===o)continue;if("IGNORE_COMMAND"===o)return;e=o}return e}(e,t);return s?function(e,t){const o=EU.get(e.type);if(!o)return e;const s=Wa(t);if(s)return o(e,s);return e}(s,t):s}function NU(e,t){let o=[...e];const s=new Set(xU.getKeys());for(const e of t)(s.has(e.type)||qa.contains(e.type))&&(o=o.reduce(((t,o)=>{const s=MU(o,e);return s&&t.push(s),t}),[]));return o}function kU(e,t){if(!("sheetId"in t))return e;const o="DELETE_SHEET"===t.type&&t.sheetId;return e.sheetId===o?"IGNORE_COMMAND":"CREATE_SHEET"===e.type||"CREATE_SHEET"===t.type||e.sheetId!==t.sheetId?e:"SKIP_TRANSFORMATION"}class LU{rootCommand;timestamp;id;clientId;_commands=[];_changes=[];constructor(e,t,o,s,i,n){this.rootCommand=s,this.timestamp=n,this.id=e,this.clientId=t,this._commands=[...o],this._changes=i?[...i]:[]}setChanges(e){this._changes=e}get commands(){return this._commands}get changes(){return this._changes}}class VU extends Error{}class UU extends xh{revisions;transportService;serverRevisionId;clients={};clientId="local";debouncedMove;pendingMessages=[];awaitingClientPosition;waitingAck=!1;waitingUndoRedoAck=!1;isReplayingInitialRevisions=!1;processedRevisions=new Set;lastRevisionMessage=void 0;uuidGenerator=new Sl;lastLocalOperation;constructor(e,t,o=He){super(),this.revisions=e,this.transportService=t,this.serverRevisionId=o,this.debouncedMove=kt(this._move.bind(this),200)}canApplyOptimisticUpdate(){return!this.waitingUndoRedoAck}save(e,t,o){if(!t.length||!o.length||!this.canApplyOptimisticUpdate())return;const s=new LU(this.uuidGenerator.uuidv4(),this.clientId,t,e,o,Date.now());this.revisions.append(s.id,s),"REQUEST_REDO"!==e.type&&(this.lastLocalOperation=s),this.trigger("new-local-state-update",{id:s.id}),this.sendUpdateMessage({type:"REMOTE_REVISION",version:1,serverRevisionId:this.serverRevisionId,nextRevisionId:s.id,clientId:s.clientId,commands:s.commands})}undo(e){this.waitingUndoRedoAck=!0,this.sendUpdateMessage({type:"REVISION_UNDONE",version:1,serverRevisionId:this.serverRevisionId,nextRevisionId:this.uuidGenerator.uuidv4(),undoneRevisionId:e})}redo(e){this.waitingUndoRedoAck=!0,this.sendUpdateMessage({type:"REVISION_REDONE",version:1,serverRevisionId:this.serverRevisionId,nextRevisionId:this.uuidGenerator.uuidv4(),redoneRevisionId:e})}move(e){this.debouncedMove(e)}join(e){e?(this.clients[e.id]=e,this.clientId=e.id):(this.clients.local={id:"local",name:"local"},this.clientId="local"),this.transportService.onNewMessage(this.clientId,this.onMessageReceived.bind(this)),this.awaitingClientPosition&&(this._move(this.awaitingClientPosition),this.awaitingClientPosition=void 0)}loadInitialMessages(e){const t=performance.now(),o=e.reduce(((e,t)=>e+("REMOTE_REVISION"===t.type?t.commands.length:1)),0);this.isReplayingInitialRevisions=!0;for(const t of e)this.onMessageReceived(t);this.isReplayingInitialRevisions=!1,console.debug("Replayed",o,"commands in",performance.now()-t,"ms")}async leave(e){e&&1===Object.keys(this.clients).length&&this.lastRevisionMessage&&"SNAPSHOT_CREATED"!==this.lastRevisionMessage?.type&&await this.snapshot(e()),delete this.clients[this.clientId],this.transportService.leave(this.clientId),this.transportService.sendMessage({type:"CLIENT_LEFT",clientId:this.clientId,version:1})}async snapshot(e){if(0!==this.pendingMessages.length)return;const t=this.uuidGenerator.uuidv4();await this.transportService.sendMessage({type:"SNAPSHOT",nextRevisionId:t,serverRevisionId:this.serverRevisionId,data:{...e,revisionId:t},version:1})}getCurrentClient(){return this.getClient(this.clientId)}getClient(e){const t=this.clients[e];if(!t)throw new VU("The client left the session");return t}getConnectedClients(){return new Set(Object.values(this.clients).filter(Mt))}getRevisionId(){return this.serverRevisionId}isFullySynchronized(){return 0===this.pendingMessages.length}getLastLocalNonEmptyRevision(){return this.lastLocalOperation}_move(e){if(!this.clients[this.clientId])return void(this.awaitingClientPosition=e);const t=this.clients[this.clientId]?.position;if(t?.col===e.col&&t.row===e.row&&t.sheetId===e.sheetId)return;const o=t?"CLIENT_MOVED":"CLIENT_JOINED",s=this.getCurrentClient();this.clients[this.clientId]={...s,position:e},this.transportService.sendMessage({type:o,version:1,client:{...s,position:e}})}onMessageReceived(e){if(!this.isAlreadyProcessed(e))if(this.isWrongServerRevisionId(e))this.trigger("unexpected-revision-id");else{switch(e.type){case"CLIENT_MOVED":this.onClientMoved(e);break;case"CLIENT_JOINED":this.onClientJoined(e);break;case"CLIENT_LEFT":this.onClientLeft(e);break;case"REVISION_REDONE":this.revisions.redo(e.redoneRevisionId,e.nextRevisionId,e.serverRevisionId),this.trigger("revision-redone",{revisionId:e.redoneRevisionId,commands:this.revisions.get(e.redoneRevisionId).commands});break;case"REVISION_UNDONE":this.revisions.undo(e.undoneRevisionId,e.nextRevisionId,e.serverRevisionId),this.trigger("revision-undone",{revisionId:e.undoneRevisionId,commands:this.revisions.get(e.undoneRevisionId).commands});break;case"REMOTE_REVISION":const{clientId:t,commands:o,timestamp:s}=e,i=new LU(e.nextRevisionId,t,o,void 0,void 0,s);if(i.clientId!==this.clientId){this.revisions.insert(i.id,i,e.serverRevisionId);const t=this.pendingMessages.filter((e=>"REMOTE_REVISION"===e.type)).map((e=>e.commands)).flat();this.trigger("remote-revision-received",{commands:NU(o,t)})}break;case"SNAPSHOT_CREATED":{const t=new LU(e.nextRevisionId,"server",[],void 0,void 0,Date.now());this.revisions.insert(t.id,t,e.serverRevisionId),this.dropPendingHistoryMessages(),this.trigger("snapshot"),this.lastLocalOperation=void 0;break}}this.acknowledge(e),this.trigger("collaborative-event-received")}}onClientMoved(e){e.client.id!==this.clientId&&(this.clients[e.client.id]=e.client)}onClientJoined(e){if(e.client.id!==this.clientId){this.clients[e.client.id]=e.client;const t=this.clients[this.clientId];if(t){const{position:e}=t;e&&this.transportService.sendMessage({type:"CLIENT_MOVED",version:1,client:{...t,position:e}})}}}onClientLeft(e){e.clientId!==this.clientId&&delete this.clients[e.clientId]}sendUpdateMessage(e){this.pendingMessages.push(e),this.waitingAck||this.sendPendingMessage()}sendPendingMessage(){let e=this.pendingMessages[0];if(e){if("REMOTE_REVISION"===e.type){let t=this.revisions.get(e.nextRevisionId);0===t.commands.length&&(this.revisions.rebase(t.id),t=this.revisions.get(e.nextRevisionId)),e={...e,clientId:t.clientId,commands:t.commands}}if(this.isReplayingInitialRevisions)throw new Error(`Trying to send a new revision while replaying initial revision. This can lead to endless dispatches every time the spreadsheet is open.\n ${JSON.stringify(e)}`);this.waitingAck=!0,this.transportService.sendMessage({...e,serverRevisionId:this.serverRevisionId})}}acknowledge(e){switch("REVISION_UNDONE"!==e.type&&"REVISION_REDONE"!==e.type||(this.waitingUndoRedoAck=!1),e.type){case"REMOTE_REVISION":case"REVISION_REDONE":case"SNAPSHOT_CREATED":this.waitingAck=!1,this.pendingMessages=this.pendingMessages.filter((t=>t.nextRevisionId!==e.nextRevisionId)),this.serverRevisionId=e.nextRevisionId,this.processedRevisions.add(e.nextRevisionId),this.lastRevisionMessage=e,this.sendPendingMessage();break;case"REVISION_UNDONE":{this.waitingAck=!1,this.pendingMessages=this.pendingMessages.filter((t=>t.nextRevisionId!==e.nextRevisionId));const t=this.pendingMessages.findIndex((e=>"REMOTE_REVISION"===e.type));-1!==t&&this.revisions.rebase(this.pendingMessages[t].nextRevisionId),this.serverRevisionId=e.nextRevisionId,this.processedRevisions.add(e.nextRevisionId),this.sendPendingMessage();break}}}isAlreadyProcessed(e){if("CLIENT_MOVED"===e.type&&e.client.id===this.clientId)return!0;switch(e.type){case"REMOTE_REVISION":case"REVISION_REDONE":case"REVISION_UNDONE":case"SNAPSHOT_CREATED":return this.processedRevisions.has(e.nextRevisionId);default:return!1}}isWrongServerRevisionId(e){switch(e.type){case"REMOTE_REVISION":case"REVISION_REDONE":case"REVISION_UNDONE":case"SNAPSHOT_CREATED":return e.serverRevisionId!==this.serverRevisionId;default:return!1}}dropPendingHistoryMessages(){this.waitingUndoRedoAck=!1,this.pendingMessages=this.pendingMessages.filter((({type:e})=>"REVISION_REDONE"!==e&&"REVISION_UNDONE"!==e))}}const HU=new Set(["HIDE_COLUMNS_ROWS","UNHIDE_COLUMNS_ROWS","UNFOLD_HEADER_GROUP","UNGROUP_HEADERS","FOLD_HEADER_GROUP","FOLD_ALL_HEADER_GROUPS","UNFOLD_ALL_HEADER_GROUPS","FOLD_HEADER_GROUPS_IN_ZONE","UNFOLD_HEADER_GROUPS_IN_ZONE","CREATE_TABLE","UPDATE_TABLE","UPDATE_FILTER","REMOVE_TABLE","RESIZE_TABLE","CREATE_TABLE_STYLE","REMOVE_TABLE_STYLE"]);function zU(e){return HU.has(e.type)}const BU=[$U,function(e,t){return"target"in t&&Array.isArray(t.target)?{...pt(t),target:e.getSelectedZones()}:t},WU,function(e,t){return"ranges"in t?{...pt(t),ranges:e.getSelectedZones().map((t=>e.getRangeDataFromZone(e.getActiveSheetId(),t)))}:t}];function $U(e,t){return"sheetId"in t?{...pt(t),sheetId:e.getActiveSheetId()}:t}function GU(e,t){return"zone"in t?{...pt(t),zone:e.getSelectedZone()}:t}function WU(e,t){if(!("row"in t)||!("col"in t))return t;const{col:o,row:s}=e.getActivePosition();return{...pt(t),col:o,row:s}}const qU=new Sl;function ZU(e,t){const o=e.getSelectedZone();return{...$U(e,t),elements:"COL"===t.dimension?Ct(o.left,o.right+1):Ct(o.top,o.bottom+1)}}function jU(e,t){const o=e.getSelectedZone();return{...pt(t),zone:o}}function YU(e,t){const o=pt(t),s=e.getSelectedZone(),{top:i,bottom:n,left:r,right:a}=s;return"cols"in o?o.cols=Ct(r,a+1):"rows"in o&&(o.rows=Ct(i,n+1)),o}function XU(e,t){const o=e.getSelectedZone();return{...$U(e,t),start:"COL"===t.dimension?o.left:o.top,end:"COL"===t.dimension?o.right:o.bottom}}const KU=new n;KU.add("UPDATE_CELL",QU),KU.add("CLEAR_CELL",QU),KU.add("CLEAR_CELLS",QU),KU.add("DELETE_CONTENT",QU),KU.add("ADD_MERGE",QU),KU.add("REMOVE_MERGE",QU),KU.add("SET_FORMATTING",QU),KU.add("CLEAR_FORMATTING",QU),KU.add("SET_BORDER",QU),KU.add("CREATE_TABLE",QU),KU.add("REMOVE_TABLE",QU),KU.add("HIDE_SHEET",QU),KU.add("ADD_COLUMNS_ROWS",(function(e,t){const o=e.getActivePosition();return{...$U(e,t),base:"COL"===t.dimension?o.col:o.row}})),KU.add("REMOVE_COLUMNS_ROWS",ZU),KU.add("HIDE_COLUMNS_ROWS",ZU),KU.add("RESIZE_COLUMNS_ROWS",ZU),KU.add("CREATE_SHEET",(function(e,t){const o=pt(t);o.sheetId=qU.smallUuid();const s=t.name||e.getSheet(e.getActiveSheetId()).name,i=s.match(/(.+?)\d*$/)?.[1]||s;return o.name=e.getNextSheetName(i),o})),KU.add("CREATE_FIGURE",(function(e,t){const o=WU(e,$U(e,t));return o.figureId=qU.smallUuid(),o})),KU.add("CREATE_CHART",(function(e,t){const o=qU.smallUuid();return{...$U(e,t),figureId:o,chartId:o}})),KU.add("CREATE_IMAGE",(function(e,t){return{...$U(e,t),figureId:qU.smallUuid()}})),KU.add("GROUP_HEADERS",XU),KU.add("UNGROUP_HEADERS",XU),KU.add("UNFOLD_HEADER_GROUPS_IN_ZONE",GU),KU.add("FOLD_HEADER_GROUPS_IN_ZONE",GU);const JU=new n;function QU(e,t){let o=pt(t);for(const t of BU)o=t(e,o);return o}function eH(e,t){if(e.rootCommand&&"object"==typeof e.rootCommand)return f(e.rootCommand)?function(e,t){if(!t)return;if(!KU.contains(t.type))return;return KU.get(t.type)(e,t)}(t,e.rootCommand):function(e,t,o){if(!JU.contains(t.type))return;return JU.get(t.type)(e,t,o)}(t,e.rootCommand,e.commands)}JU.add("PASTE",(function(e,t){return{type:"REPEAT_PASTE",pasteOption:pt(t.pasteOption),target:e.getSelectedZones()}})),JU.add("INSERT_CELL",jU),JU.add("DELETE_CELL",jU),JU.add("AUTORESIZE_COLUMNS",YU),JU.add("AUTORESIZE_ROWS",YU),JU.add("SORT_CELLS",(function(e,t){const o=e.getSelectedZone();return{...$U(e,t),col:o.left,row:o.top,zone:o}})),JU.add("SUM_SELECTION",QU),JU.add("SET_DECIMAL",QU),JU.add("DELETE_UNFILTERED_CONTENT",QU);class tH{trackedValues=new Set;domainToArray(e){return e.flatMap((e=>[e.field,En(e.value)]))}isValuePresent(e,t){const o=JSON.stringify({measure:e,domain:this.domainToArray(t)});return this.trackedValues.has(o)}isHeaderPresent(e){const t=JSON.stringify({domain:this.domainToArray(e)});return this.trackedValues.has(t)}trackValue(e,t){const o=JSON.stringify({measure:e,domain:this.domainToArray(t)});this.trackedValues.add(o)}trackHeader(e){const t=JSON.stringify({domain:this.domainToArray(e)});this.trackedValues.add(t)}}const oH=5242880;const sH={filterType:"criterion",type:"none",values:[]};class iH{getters;sheetId;boundaries;top;bottom;left;right;offsetX;offsetY;canScrollVertically;canScrollHorizontally;viewportWidth;viewportHeight;offsetCorrectionX;offsetCorrectionY;constructor(e,t,o,s,i,n){if(this.getters=e,this.sheetId=t,this.boundaries=o,s.width<0||s.height<0)throw new Error("Viewport size cannot be negative");this.viewportWidth=s.height&&s.width,this.viewportHeight=s.width&&s.height,this.top=o.top,this.bottom=o.bottom,this.left=o.left,this.right=o.right,this.offsetX=n.x,this.offsetY=n.y,this.canScrollVertically=i.canScrollVertically,this.canScrollHorizontally=i.canScrollHorizontally,this.offsetCorrectionX=this.getters.getColDimensions(this.sheetId,this.boundaries.left).start,this.offsetCorrectionY=this.getters.getRowDimensions(this.sheetId,this.boundaries.top).start,this.adjustViewportOffsetX(),this.adjustViewportOffsetY()}getMaxSize(){const e=this.getters.findLastVisibleColRowIndex(this.sheetId,"COL",{first:this.boundaries.left,last:this.boundaries.right}),t=this.getters.findLastVisibleColRowIndex(this.sheetId,"ROW",{first:this.boundaries.top,last:this.boundaries.bottom}),{end:o}=this.getters.getColDimensions(this.sheetId,e),{end:s}=this.getters.getRowDimensions(this.sheetId,t);let i=o-this.offsetCorrectionX;this.canScrollHorizontally&&(i=Math.max(i,this.viewportWidth));let n=s-this.offsetCorrectionY;return this.canScrollVertically&&(n=Math.max(n,this.viewportHeight),s+Fe>n&&!this.getters.isReadonly()&&(n+=Fe)),{width:i,height:n}}getColIndex(e){return e<this.offsetCorrectionX||e>this.offsetCorrectionX+this.viewportWidth?-1:this.searchHeaderIndex("COL",e-this.offsetCorrectionX+this.snapCorrection.x,this.left)}getRowIndex(e){return e<this.offsetCorrectionY||e>this.offsetCorrectionY+this.viewportHeight?-1:this.searchHeaderIndex("ROW",e-this.offsetCorrectionY+this.snapCorrection.y,this.top)}adjustPosition(e){const t=this.sheetId,o=this.getters.getMainCellPosition({sheetId:t,...e}),{col:s,row:i}=this.getters.getNextVisibleCellPosition(o);es(s,this.boundaries.top,this.boundaries)&&this.adjustPositionX(s),es(this.boundaries.left,i,this.boundaries)&&this.adjustPositionY(i)}adjustPositionX(e){const t=this.sheetId,{start:o,end:s}=this.getters.getColDimensions(t,e);this.offsetX+this.viewportWidth+this.offsetCorrectionX<s?this.offsetX=s-this.viewportWidth:this.offsetX+this.offsetCorrectionX>o&&(this.offsetX=o-this.offsetCorrectionX),this.adjustViewportZoneX()}adjustPositionY(e){const t=this.sheetId,{start:o,end:s}=this.getters.getRowDimensions(t,e);this.offsetY+this.viewportHeight+this.offsetCorrectionY<s?this.offsetY=s-this.viewportHeight:this.offsetY+this.offsetCorrectionY>o&&(this.offsetY=o-this.offsetCorrectionY),this.adjustViewportZoneY()}willNewOffsetScrollViewport(e,t){return this.canScrollHorizontally&&this.offsetX!==e||this.canScrollVertically&&this.offsetY!==t}setViewportOffset(e,t){this.setViewportOffsetX(e),this.setViewportOffsetY(t)}adjustViewportZone(){this.adjustViewportZoneX(),this.adjustViewportZoneY()}getVisibleRect(e){const t=Xo(e,this),o=this.snapCorrection.x,s=this.snapCorrection.y;if(t){return{x:this.getters.getColRowOffset("COL",this.left,t.left)+this.offsetCorrectionX-(this.left!==t.left?o:0),y:this.getters.getColRowOffset("ROW",this.top,t.top)+this.offsetCorrectionY-(this.top!==t.top?s:0),width:Math.min(this.getters.getColRowOffset("COL",t.left,t.right+1)-(this.left===t.left?o:0),this.viewportWidth),height:Math.min(this.getters.getColRowOffset("ROW",t.top,t.bottom+1)-(this.top===t.top?s:0),this.viewportHeight)}}}getFullRect(e){const t=Xo(e,this.boundaries),o=this.snapCorrection.x,s=this.snapCorrection.y;if(t){return{x:this.getters.getColRowOffset("COL",this.left,e.left)+this.offsetCorrectionX-o,y:this.getters.getColRowOffset("ROW",this.top,e.top)+this.offsetCorrectionY-s,width:this.getters.getColRowOffset("COL",e.left,e.right+1),height:this.getters.getColRowOffset("ROW",e.top,e.bottom+1)}}}isVisible(e,t){return t<=this.bottom&&t>=this.top&&e>=this.left&&e<=this.right&&!this.getters.isColHidden(this.sheetId,e)&&!this.getters.isRowHidden(this.sheetId,t)}searchHeaderIndex(e,t,o=0){if(this.viewportWidth<=0||this.viewportHeight<=0)return-1;const s=this.sheetId,i=this.getters.getNumberHeaders(s,e);let n=o,r=i;for(;n<=r&&n!==i&&-1!==r;){const i=Math.floor((n+r)/2),a=this.getters.getColRowOffset(e,o,i),l=this.getters.getHeaderSize(s,e,i);if(t>=a&&t<a+l)return i;t>=a+l?n=i+1:r=i-1}return-1}setViewportOffsetX(e){this.canScrollHorizontally&&(this.offsetX=e,this.adjustViewportZoneX())}setViewportOffsetY(e){this.canScrollVertically&&(this.offsetY=e,this.adjustViewportZoneY())}adjustViewportOffsetX(){if(this.canScrollHorizontally){const{width:e}=this.getMaxSize();this.viewportWidth+this.offsetX>e&&(this.offsetX=Math.max(0,e-this.viewportWidth))}this.adjustViewportZoneX()}adjustViewportOffsetY(){if(this.canScrollVertically){const{height:e}=this.getMaxSize();this.viewportHeight+this.offsetY>e&&(this.offsetY=Math.max(0,e-this.viewportHeight))}this.adjustViewportZoneY()}adjustViewportZoneX(){this.left=this.searchHeaderIndex("COL",this.offsetX,this.boundaries.left),this.right=Math.min(this.boundaries.right,this.searchHeaderIndex("COL",Math.max(this.viewportWidth+this.snapCorrection.x-.1),this.left)),this.viewportWidth&&(-1===this.left&&(this.left=this.boundaries.left),-1===this.right&&(this.right=this.boundaries.right))}adjustViewportZoneY(){this.top=this.searchHeaderIndex("ROW",this.offsetY,this.boundaries.top),this.bottom=Math.min(this.boundaries.bottom,this.searchHeaderIndex("ROW",Math.max(this.viewportHeight+this.snapCorrection.y-.1,0),this.top)),this.viewportHeight&&(-1===this.top&&(this.top=this.boundaries.top),-1===this.bottom&&(this.bottom=this.boundaries.bottom))}get snapCorrection(){return{x:Math.abs(this.offsetX-this.getters.getColRowOffset("COL",this.boundaries.left,Math.max(0,this.left))),y:Math.abs(this.offsetY-this.getters.getColRowOffset("ROW",this.boundaries.top,Math.max(0,this.top)))}}}const nH=(new n).add("settings",class extends gV{static getters=["getLocale"];locale=w;allowDispatch(e){return"UPDATE_LOCALE"===e.type?zl(e.locale)?"Success":"InvalidLocale":"Success"}handle(e){if("UPDATE_LOCALE"===e.type){const t=this.locale,o=e.locale;this.history.update("locale",o),this.changeCellsDateFormatWithLocale(t,o)}}getLocale(){return this.locale}changeCellsDateFormatWithLocale(e,t){for(const o of this.getters.getSheetIds())for(const[s,i]of Object.entries(this.getters.getCells(o))){let o;if(i.format===e.dateFormat&&(o=t.dateFormat),i.format===e.timeFormat&&(o=t.timeFormat),i.format===tc(e)&&(o=tc(t)),o){const{col:e,row:t,sheetId:i}=this.getters.getCellPosition(s);this.dispatch("UPDATE_CELL",{col:e,row:t,sheetId:i,format:o})}}}import(e){this.locale=e.settings?.locale??w}export(e){e.settings={locale:this.locale}}}).add("sheet",class extends gV{static getters=["getSheetName","tryGetSheetName","getSheet","tryGetSheet","getSheetIdByName","getSheetIds","getVisibleSheetIds","isSheetVisible","doesHeaderExist","doesHeadersExist","getCell","getCellPosition","getColsZone","getRowCells","getRowsZone","getNumberCols","getNumberRows","getNumberHeaders","getGridLinesVisibility","getNextSheetName","getSheetSize","getSheetZone","getPaneDivisions","checkZonesExistInSheet","getCommandZones","getUnboundedZone","checkElementsIncludeAllNonFrozenHeaders","getDuplicateSheetName"];sheetIdsMapName={};orderedSheetIds=[];sheets={};cellPosition={};allowDispatch(e){const t=this.chainValidations(this.checkSheetExists,this.checkZonesAreInSheet)(e);if("Success"!==t)return t;switch(e.type){case"HIDE_SHEET":return 1===this.getVisibleSheetIds().length?"NotEnoughSheets":"Success";case"CREATE_SHEET":return this.checkValidations(e,this.checkSheetName,this.checkSheetPosition);case"DUPLICATE_SHEET":return this.sheets[e.sheetIdTo]?"DuplicatedSheetId":this.orderedSheetIds.map(this.getSheetName.bind(this)).includes(e.sheetNameTo)?"DuplicatedSheetName":"Success";case"MOVE_SHEET":try{const t=this.orderedSheetIds.findIndex((t=>t===e.sheetId));return this.findIndexOfTargetSheet(t,e.delta),"Success"}catch(e){return"WrongSheetMove"}case"RENAME_SHEET":return this.isRenameAllowed(e);case"COLOR_SHEET":return!e.color||Fs(e.color)?"Success":"InvalidColor";case"DELETE_SHEET":return this.getVisibleSheetIds().length>1?"Success":"NotEnoughSheets";case"ADD_COLUMNS_ROWS":return this.doesHeaderExist(e.sheetId,e.dimension,e.base)?e.quantity<=0?"InvalidQuantity":"Success":"InvalidHeaderIndex";case"REMOVE_COLUMNS_ROWS":{const t=ro(e.elements),o=no(e.elements);return t<0||!this.doesHeaderExist(e.sheetId,e.dimension,o)?"InvalidHeaderIndex":this.checkElementsIncludeAllNonFrozenHeaders(e.sheetId,e.dimension,e.elements)?"NotEnoughElements":"Success"}case"FREEZE_ROWS":return this.checkValidations(e,this.checkRowFreezeQuantity,this.checkRowFreezeOverlapMerge);case"FREEZE_COLUMNS":return this.checkValidations(e,this.checkColFreezeQuantity,this.checkColFreezeOverlapMerge);default:return"Success"}}handle(e){switch(e.type){case"SET_GRID_LINES_VISIBILITY":this.setGridLinesVisibility(e.sheetId,e.areGridLinesVisible);break;case"CREATE_SHEET":const t=this.createSheet(e.sheetId,e.name||this.getNextSheetName(),e.cols||26,e.rows||100,e.position);this.history.update("sheetIdsMapName",t.name,t.id);break;case"MOVE_SHEET":this.moveSheet(e.sheetId,e.delta);break;case"RENAME_SHEET":this.renameSheet(this.sheets[e.sheetId],e.newName);break;case"COLOR_SHEET":this.history.update("sheets",e.sheetId,"color",e.color);break;case"HIDE_SHEET":this.hideSheet(e.sheetId);break;case"SHOW_SHEET":this.showSheet(e.sheetId);break;case"DUPLICATE_SHEET":this.duplicateSheet(e.sheetId,e.sheetIdTo,e.sheetNameTo);break;case"DELETE_SHEET":this.deleteSheet(this.sheets[e.sheetId]);break;case"REMOVE_COLUMNS_ROWS":"COL"===e.dimension?this.removeColumns(this.sheets[e.sheetId],[...e.elements]):this.removeRows(this.sheets[e.sheetId],[...e.elements]);break;case"ADD_COLUMNS_ROWS":"COL"===e.dimension?this.addColumns(this.sheets[e.sheetId],e.base,e.position,e.quantity):this.addRows(this.sheets[e.sheetId],e.base,e.position,e.quantity);break;case"UPDATE_CELL_POSITION":this.updateCellPosition(e);break;case"FREEZE_COLUMNS":this.setPaneDivisions(e.sheetId,e.quantity,"COL");break;case"FREEZE_ROWS":this.setPaneDivisions(e.sheetId,e.quantity,"ROW");break;case"UNFREEZE_ROWS":this.setPaneDivisions(e.sheetId,0,"ROW");break;case"UNFREEZE_COLUMNS":this.setPaneDivisions(e.sheetId,0,"COL");break;case"UNFREEZE_COLUMNS_ROWS":this.setPaneDivisions(e.sheetId,0,"COL"),this.setPaneDivisions(e.sheetId,0,"ROW")}}import(e){for(const t of e.sheets)this.sheetIdsMapName[t.name]=t.id;for(const t of e.sheets){const e=t.name||"Sheet"+(Object.keys(this.sheets).length+1),{colNumber:o,rowNumber:s}=this.getImportedSheetSize(t),i={id:t.id,name:e,numberOfCols:o,rows:Da(s),areGridLinesVisible:void 0===t.areGridLinesVisible||t.areGridLinesVisible,isVisible:t.isVisible,panes:{xSplit:t.panes?.xSplit||0,ySplit:t.panes?.ySplit||0},color:t.color};this.orderedSheetIds.push(i.id),this.sheets[i.id]=i}}exportSheets(e){e.sheets=this.orderedSheetIds.filter(Mt).map((e=>{const t=this.sheets[e],o={id:t.id,name:t.name,colNumber:t.numberOfCols,rowNumber:this.getters.getNumberRows(t.id),rows:{},cols:{},merges:[],cells:{},styles:{},formats:{},borders:{},conditionalFormats:[],dataValidationRules:[],figures:[],tables:[],areGridLinesVisible:void 0===t.areGridLinesVisible||t.areGridLinesVisible,isVisible:t.isVisible,color:t.color};return(t.panes.xSplit||t.panes.ySplit)&&(o.panes=t.panes),o}))}export(e){this.exportSheets(e)}exportForExcel(e){this.exportSheets(e)}getGridLinesVisibility(e){return this.getSheet(e).areGridLinesVisible}tryGetSheet(e){return this.sheets[e]}getSheet(e){const t=this.sheets[e];if(!t)throw new Error(`Sheet ${e} not found.`);return t}isSheetVisible(e){return this.getSheet(e).isVisible}getSheetName(e){return this.getSheet(e).name}tryGetSheetName(e){return this.tryGetSheet(e)?.name}getSheetIdByName(e){if(e){const t=mt(e);for(const e in this.sheetIdsMapName)if(Ma(e,t))return this.sheetIdsMapName[e]}}getSheetIds(){return this.orderedSheetIds}getVisibleSheetIds(){return this.orderedSheetIds.filter(this.isSheetVisible.bind(this))}doesHeaderExist(e,t,o){return"COL"===t?o>=0&&o<this.getNumberCols(e):o>=0&&o<this.getNumberRows(e)}doesHeadersExist(e,t,o){return o.every((o=>this.doesHeaderExist(e,t,o)))}getCell({sheetId:e,col:t,row:o}){const s=this.tryGetSheet(e),i=s?.rows[o]?.cells[t];if(void 0!==i)return this.getters.getCellById(i)}getColsZone(e,t,o){return{top:0,bottom:this.getNumberRows(e)-1,left:t,right:o}}getRowCells(e,t){return Object.values(this.getSheet(e).rows[t]?.cells).filter(Mt)}getRowsZone(e,t,o){return{top:t,bottom:o,left:0,right:this.getSheet(e).numberOfCols-1}}getCellPosition(e){const t=this.cellPosition[e];if(!t)throw new Error(`asking for a cell position that doesn't exist, cell id: ${e}`);return t}getNumberCols(e){return this.getSheet(e).numberOfCols}getNumberRows(e){return this.getSheet(e).rows.length}getNumberHeaders(e,t){return"COL"===t?this.getNumberCols(e):this.getNumberRows(e)}getNextSheetName(e="Sheet"){return Oa(this.orderedSheetIds.map(this.getSheetName.bind(this)),e)}getSheetSize(e){return{numberOfRows:this.getNumberRows(e),numberOfCols:this.getNumberCols(e)}}getSheetZone(e){return{top:0,left:0,bottom:this.getNumberRows(e)-1,right:this.getNumberCols(e)-1}}getUnboundedZone(e,t){if(void 0===t.bottom||void 0===t.right)return t;const o=0===t.left&&t.right===this.getNumberCols(e)-1,s=0===t.top&&t.bottom===this.getNumberRows(e)-1;return{...t,bottom:s?void 0:t.bottom,right:o&&!s?void 0:t.right}}getPaneDivisions(e){return this.getSheet(e).panes}setPaneDivisions(e,t,o){const s={...this.getPaneDivisions(e)};"COL"===o?s.xSplit=t:"ROW"===o&&(s.ySplit=t),this.history.update("sheets",e,"panes",s)}checkElementsIncludeAllNonFrozenHeaders(e,t,o){const s=this.getters.getPaneDivisions(e),i="ROW"===t?s.ySplit:s.xSplit,n=this.getters.getNumberHeaders(e,t);if(!i)return!1;return Gt(o,Ct(i,n))}getCommandZones(e){const t=[];return"zone"in e&&t.push(e.zone),"target"in e&&t.push(...e.target),"ranges"in e&&t.push(...e.ranges.map((e=>this.getters.getRangeFromRangeData(e).zone))),"col"in e&&void 0!==e.col&&"row"in e&&void 0!==e.row&&t.push({top:e.row,left:e.col,bottom:e.row,right:e.col}),t}checkZonesExistInSheet(e,t){if(!t.every(Bo))return"InvalidRange";if(t.length){const o=this.getSheetZone(e);return t.every((e=>ts(e,o)))?"Success":"TargetOutOfSheet"}return"Success"}updateCellPosition(e){const{sheetId:t,cellId:o,col:s,row:i}=e;o?this.setNewPosition(o,t,s,i):this.clearPosition(t,s,i)}setNewPosition(e,t,o,s){const i=this.cellPosition[e];i&&this.clearPosition(t,i.col,i.row),this.history.update("cellPosition",e,{row:s,col:o,sheetId:t}),this.history.update("sheets",t,"rows",s,"cells",o,e)}clearPosition(e,t,o){const s=this.sheets[e]?.rows[o].cells[t];s&&(this.history.update("cellPosition",s,void 0),this.history.update("sheets",e,"rows",o,"cells",t,void 0))}setGridLinesVisibility(e,t){this.history.update("sheets",e,"areGridLinesVisible",t)}createSheet(e,t,o,s,i){const n={id:e,name:t,numberOfCols:o,rows:Da(s),areGridLinesVisible:!0,isVisible:!0,panes:{xSplit:0,ySplit:0}},r=this.orderedSheetIds.slice();r.splice(i,0,n.id);const a=this.sheets;return this.history.update("orderedSheetIds",r),this.history.update("sheets",Object.assign({},a,{[n.id]:n})),n}moveSheet(e,t){const o=this.orderedSheetIds.slice(),s=o.findIndex((t=>t===e)),i=o.splice(s,1),n=this.findIndexOfTargetSheet(s,t);o.splice(n,0,i[0]),this.history.update("orderedSheetIds",o)}findIndexOfTargetSheet(e,t){for(;0!==t&&0<=e&&e<=this.orderedSheetIds.length;)t>0?(e++,this.isSheetVisible(this.orderedSheetIds[e])&&t--):t<0&&(e--,this.isSheetVisible(this.orderedSheetIds[e])&&t++);if(0===t)return e;throw new Error("There is not enough visible sheets")}checkSheetName(e){const t=this.getters.tryGetSheetName(e.sheetId),o="RENAME_SHEET"===e.type?e.newName:e.name;if(void 0!==t&&o===t)return"UnchangedSheetName";const{orderedSheetIds:s,sheets:i}=this,n=o&&o.trim().toLowerCase();return s.find((t=>Ma(i[t]?.name,n)&&t!==e.sheetId))?"DuplicatedSheetName":Ke.test(n)?"ForbiddenCharactersInSheetName":"Success"}checkSheetPosition(e){const{orderedSheetIds:t}=this;return e.position>t.length||e.position<0?"WrongSheetPosition":"Success"}checkRowFreezeQuantity(e){return e.quantity>=1&&e.quantity<this.getNumberRows(e.sheetId)?"Success":"InvalidFreezeQuantity"}checkColFreezeQuantity(e){return e.quantity>=1&&e.quantity<this.getNumberCols(e.sheetId)?"Success":"InvalidFreezeQuantity"}checkRowFreezeOverlapMerge(e){const t=this.getters.getMerges(e.sheetId);for(const o of t)if(o.top<e.quantity&&e.quantity<=o.bottom)return"MergeOverlap";return"Success"}checkColFreezeOverlapMerge(e){const t=this.getters.getMerges(e.sheetId);for(const o of t)if(o.left<e.quantity&&e.quantity<=o.right)return"MergeOverlap";return"Success"}isRenameAllowed(e){return e.newName&&e.newName.trim().toLowerCase()?this.checkSheetName(e):"MissingSheetName"}renameSheet(e,t){const o=e.name;this.history.update("sheets",e.id,"name",t.trim());const s=Object.assign({},this.sheetIdsMapName);delete s[o],s[t]=e.id,this.history.update("sheetIdsMapName",s)}hideSheet(e){this.history.update("sheets",e,"isVisible",!1)}showSheet(e){this.history.update("sheets",e,"isVisible",!0)}duplicateSheet(e,t,o){const s=pt(this.getSheet(e));s.id=t,s.name=o;for(let e=0;e<=s.numberOfCols;e++)for(let t=0;t<=s.rows.length;t++)s.rows[t]&&(s.rows[t].cells[e]=void 0);const i=this.orderedSheetIds.slice(),n=i.indexOf(e);i.splice(n+1,0,s.id),this.history.update("orderedSheetIds",i),this.history.update("sheets",Object.assign({},this.sheets,{[s.id]:s}));for(const t of Object.values(this.getters.getCells(e))){const{col:e,row:o}=this.getCellPosition(t.id);this.dispatch("UPDATE_CELL",{sheetId:s.id,col:e,row:o,content:t.content,format:t.format,style:t.style})}const r=Object.assign({},this.sheetIdsMapName);r[s.name]=s.id,this.history.update("sheetIdsMapName",r)}getDuplicateSheetName(e){return Pa(e,this.orderedSheetIds.map(this.getSheetName.bind(this)))}deleteSheet(e){const t=e.name,o=Object.assign({},this.sheets);delete o[e.id],this.history.update("sheets",o);const s=this.orderedSheetIds.slice(),i=s.indexOf(e.id);s.splice(i,1),this.history.update("orderedSheetIds",s);const n=Object.assign({},this.sheetIdsMapName);delete n[t],this.history.update("sheetIdsMapName",n)}removeColumns(e,t){t.sort(((e,t)=>t-e));for(const o of t)this.moveCellOnColumnsDeletion(e,o);const o=this.sheets[e.id].numberOfCols;this.history.update("sheets",e.id,"numberOfCols",o-t.length);const s=t.filter((t=>t<e.panes.xSplit)).length;s&&this.setPaneDivisions(e.id,e.panes.xSplit-s,"COL")}removeRows(e,t){t.sort(((e,t)=>t-e));for(const o of yt(t)){const t=o[o.length-1],s=o[0];this.moveCellOnRowsDeletion(e,t,s),this.updateRowsStructureOnDeletion(e,t,s)}const o=t.filter((t=>t<e.panes.ySplit)).length;o&&this.setPaneDivisions(e.id,e.panes.ySplit-o,"ROW")}addColumns(e,t,o,s){const i="before"===o?t:t+1;this.moveCellsOnAddition(e,i,s,"columns");const n=this.sheets[e.id].numberOfCols;this.history.update("sheets",e.id,"numberOfCols",n+s),i<e.panes.xSplit&&this.setPaneDivisions(e.id,e.panes.xSplit+s,"COL")}addRows(e,t,o,s){const i="before"===o?t:t+1;this.addEmptyRows(e,s),this.moveCellsOnAddition(e,i,s,"rows"),i<e.panes.ySplit&&this.setPaneDivisions(e.id,e.panes.ySplit+s,"ROW")}moveCellOnColumnsDeletion(e,t){this.dispatch("CLEAR_CELLS",{sheetId:e.id,target:[{left:t,top:0,right:t,bottom:e.rows.length-1}]});for(let o=0;o<e.rows.length;o++){const s=e.rows[o];for(const i in s.cells){const n=Number(i),r=s.cells[i];r&&n>t&&this.setNewPosition(r,e.id,n-1,o)}}}moveCellsOnAddition(e,t,o,s){const i=[];for(let n=0;n<e.rows.length;n++){const r=e.rows[n];if("rows"!==s||n>=t)for(const a in r.cells){const l=Number(a),c=r.cells[a];c&&("rows"===s||l>=t)&&i.push({sheetId:e.id,cellId:c,col:l+("columns"===s?o:0),row:n+("rows"===s?o:0),type:"UPDATE_CELL_POSITION"})}}for(const e of i.reverse())this.updateCellPosition(e)}moveCellOnRowsDeletion(e,t,o){this.dispatch("CLEAR_CELLS",{sheetId:e.id,target:[{left:0,top:t,right:this.getters.getNumberCols(e.id),bottom:o}]});const s=o-t+1;for(let t=0;t<e.rows.length;t++){const i=e.rows[t];if(t>o)for(const o in i.cells){const n=Number(o),r=i.cells[o];r&&this.setNewPosition(r,e.id,n,t-s)}}}updateRowsStructureOnDeletion(e,t,o){const s=[],i=e.rows.map((e=>e.cells)).reverse();for(const n in e.rows){const e=Number(n);e>=t&&e<=o||s.push({cells:i.pop()})}this.history.update("sheets",e.id,"rows",s)}addEmptyRows(e,t){const o=e.rows.slice();for(let e=0;e<t;e++)o.push({cells:{}});this.history.update("sheets",e.id,"rows",o)}getImportedSheetSize(e){const t=Object.keys(e.cells).map(Do);let o=e.rowNumber,s=e.colNumber;for(const{col:e,row:i}of t)o=Math.max(o,i+1),s=Math.max(s,e+1);return{rowNumber:o,colNumber:s}}checkSheetExists(e){return"CREATE_SHEET"!==e.type&&"sheetId"in e&&void 0===this.sheets[e.sheetId]?"InvalidSheetId":"CREATE_SHEET"===e.type&&void 0!==this.sheets[e.sheetId]?"DuplicatedSheetId":"Success"}checkZonesAreInSheet(e){return"sheetId"in e?"ranges"in e&&e.ranges.some((e=>""!==e._sheetId&&!this.getters.tryGetSheet(e._sheetId)))?"InvalidSheetId":this.checkZonesExistInSheet(e.sheetId,this.getCommandZones(e)):"Success"}}).add("header grouping",class extends gV{static getters=["getHeaderGroups","getGroupsLayers","getVisibleGroupLayers","getHeaderGroup","getHeaderGroupsInZone","isGroupFolded","isRowFolded","isColFolded"];groups={};allowDispatch(e){switch(e.type){case"GROUP_HEADERS":{const{start:t,end:o,sheetId:s}=e;if(!this.getters.tryGetSheet(s))return"InvalidSheetId";if(!this.getters.doesHeadersExist(e.sheetId,e.dimension,[t,o]))return"InvalidHeaderGroupStartEnd";if(t>o)return"InvalidHeaderGroupStartEnd";if(this.findGroupWithStartEnd(e.sheetId,e.dimension,t,o))return"HeaderGroupAlreadyExists";break}case"UNGROUP_HEADERS":{const{start:t,end:o,sheetId:s}=e;if(!this.getters.tryGetSheet(s))return"InvalidSheetId";if(!this.getters.doesHeadersExist(e.sheetId,e.dimension,[t,o]))return"InvalidHeaderGroupStartEnd";if(t>o)return"InvalidHeaderGroupStartEnd";break}case"UNFOLD_HEADER_GROUP":case"FOLD_HEADER_GROUP":if(!this.getters.tryGetSheet(e.sheetId))return"InvalidSheetId";const t=this.findGroupWithStartEnd(e.sheetId,e.dimension,e.start,e.end);if(!t)return"UnknownHeaderGroup";if(Ct(0,this.getters.getNumberHeaders(e.sheetId,e.dimension)).every((o=>o>=t.start&&o<=t.end||this.getters.isHeaderHiddenByUser(e.sheetId,e.dimension,o))))return"NotEnoughElements"}return"Success"}handle(e){switch(e.type){case"CREATE_SHEET":this.history.update("groups",e.sheetId,{ROW:[],COL:[]});break;case"GROUP_HEADERS":this.groupHeaders(e.sheetId,e.dimension,e.start,e.end);break;case"UNGROUP_HEADERS":this.unGroupHeaders(e.sheetId,e.dimension,e.start,e.end);break;case"DUPLICATE_SHEET":{const t=pt(this.groups[e.sheetId]);this.history.update("groups",e.sheetIdTo,t);break}case"DELETE_SHEET":{const t={...this.groups};delete t[e.sheetId],this.history.update("groups",t);break}case"ADD_COLUMNS_ROWS":const t=Ht(e.position,e.base);this.moveGroupsOnHeaderInsertion(e.sheetId,e.dimension,t,e.quantity);break;case"REMOVE_COLUMNS_ROWS":this.moveGroupsOnHeaderDeletion(e.sheetId,e.dimension,e.elements);break;case"UNFOLD_HEADER_GROUP":{const t=this.findGroupWithStartEnd(e.sheetId,e.dimension,e.start,e.end);t&&this.unfoldHeaderGroup(e.sheetId,e.dimension,t);break}case"FOLD_HEADER_GROUP":{const t=this.findGroupWithStartEnd(e.sheetId,e.dimension,e.start,e.end);t&&this.foldHeaderGroup(e.sheetId,e.dimension,t);break}case"UNFOLD_ALL_HEADER_GROUPS":{const t=this.getters.getHeaderGroups(e.sheetId,e.dimension);for(const o of t)this.unfoldHeaderGroup(e.sheetId,e.dimension,o);break}case"FOLD_ALL_HEADER_GROUPS":{const t=this.getters.getHeaderGroups(e.sheetId,e.dimension);for(const o of t)this.foldHeaderGroup(e.sheetId,e.dimension,o);break}case"FOLD_HEADER_GROUPS_IN_ZONE":case"UNFOLD_HEADER_GROUPS_IN_ZONE":{const t="UNFOLD_HEADER_GROUPS_IN_ZONE"===e.type?"unfold":"fold",o=this.getGroupsLayers(e.sheetId,e.dimension);"fold"===t&&o.reverse();const s=o.flat(),i="ROW"===e.dimension?e.zone.top:e.zone.left,n="ROW"===e.dimension?e.zone.bottom:e.zone.right,r=new Set;for(let e=i;e<=n;e++){const o=s.filter((t=>t.start-1<=e&&e<=t.end));for(const e of o)if(!("fold"===t&&e.isFolded||"unfold"===t&&!e.isFolded)){r.add(e);break}}for(const o of r)"unfold"===t?this.unfoldHeaderGroup(e.sheetId,e.dimension,o):this.foldHeaderGroup(e.sheetId,e.dimension,o);break}}}getHeaderGroups(e,t){return this.groups[e][t]}getHeaderGroup(e,t,o,s){return this.getHeaderGroups(e,t).find((e=>e.start===o&&e.end===s))}getHeaderGroupsInZone(e,t,o){return this.getHeaderGroups(e,t).filter((e=>{const s="ROW"===t?o.top:o.left,i="ROW"===t?o.bottom:o.right;return this.doGroupOverlap(e,s,i)}))}getGroupsLayers(e,t){const o=this.getHeaderGroups(e,t);return this.bricksFallingAlgorithm(o,0,0)}getVisibleGroupLayers(e,t){const o=this.getGroupsLayers(e,t);for(const s of o)for(let o=s.length-1;o>=0;o--){const i=s[o];if(0===i.start)continue;Ct(i.start-1,i.end+1).every((o=>this.getters.isHeaderHiddenByUser(e,t,o)))&&s.splice(o,1)}return o.filter((e=>e.length>0))}isGroupFolded(e,t,o,s){return this.getHeaderGroup(e,t,o,s)?.isFolded||!1}isRowFolded(e,t){return this.getters.getHeaderGroups(e,"ROW").some((e=>e.start<=t&&t<=e.end&&e.isFolded))}isColFolded(e,t){return this.getters.getHeaderGroups(e,"COL").some((e=>e.start<=t&&t<=e.end&&e.isFolded))}getGroupId(e){return`${e.start}-${e.end}}`}bricksFallingAlgorithm(e,t,o,s=0){const i={};for(const t of e)i[this.getGroupId(t)]=t.isFolded;const n={};for(const t of e)for(let e=t.start;e<=t.end;e++)n[e]=n[e]?n[e]+1:1;for(let e=t;e<=o;e++)n[e]=n[e]?n[e]+s:s;const r=Math.max(...Object.values(n),0),a=Array.from({length:r},(()=>[])),l=Math.max(o,...e.map((e=>e.end))),c=Math.min(t,...e.map((e=>e.start)));for(let e=c;e<=l;e++){const t=n[e]||0;for(let o=0;o<t;o++){const t=a[o].at(-1);if(t&&Kt([t.end,e]))t.end++;else{const t={start:e,end:e};a[o].push(t)}}}for(const e of a)for(const t of e)t.isFolded=i[this.getGroupId(t)];return a}groupHeaders(e,t,o,s){const i=this.getHeaderGroups(e,t),n=this.bricksFallingAlgorithm(i,o,s,1).flat();this.history.update("groups",e,t,this.removeDuplicateGroups(n))}unGroupHeaders(e,t,o,s){const i=this.getHeaderGroups(e,t),n=this.bricksFallingAlgorithm(i,o,s,-1).flat();this.history.update("groups",e,t,this.removeDuplicateGroups(n))}moveGroupsOnHeaderInsertion(e,t,o,s){const i=this.groups[e][t];for(let n=0;n<i.length;n++){const r=i[n],[a,l]=_a(o,s,[r.start,r.end]);a===r.start&&l===r.end||this.history.update("groups",e,t,n,{...r,start:a,end:l})}}moveGroupsOnHeaderDeletion(e,t,o){const s=this.getHeaderGroups(e,t),i=[];for(const e of s){const t=Fa(o,Ct(e.start,e.end+1));0!==t.length&&i.push({...e,start:Math.min(...t),end:Math.max(...t)})}this.history.update("groups",e,t,this.bricksFallingAlgorithm(i,0,0).flat())}doGroupOverlap(e,t,o){return e.start<=o&&e.end>=t}removeDuplicateGroups(e){const t={};for(const o of e)t[this.getGroupId(o)]=o;return Object.values(t)}findGroupWithStartEnd(e,t,o,s){return this.getHeaderGroups(e,t).find((e=>e.start===o&&e.end===s))}foldHeaderGroup(e,t,o){const s=this.getGroupIndex(e,t,o.start,o.end);if(void 0===s)return;this.history.update("groups",e,t,s,"isFolded",!0);const i=this.getters.getHeaderGroups(e,t);for(let s=0;s<i.length;s++){const n=i[s];n.start===o.start&&n.end<=o.end&&this.history.update("groups",e,t,s,"isFolded",!0)}}unfoldHeaderGroup(e,t,o){const s=this.getGroupIndex(e,t,o.start,o.end);if(void 0===s)return;this.history.update("groups",e,t,s,"isFolded",!1);const i=this.getters.getHeaderGroups(e,t);for(let s=0;s<i.length;s++){const n=i[s];n.start===o.start&&n.end>=o.end&&this.history.update("groups",e,t,s,"isFolded",!1)}}getGroupIndex(e,t,o,s){const i=this.groups[e][t].findIndex((e=>e.start===o&&e.end===s));return-1===i?void 0:i}import(e){for(const t of e.sheets)if(this.groups[t.id]={ROW:[],COL:[]},t.headerGroups)for(const e of["ROW","COL"])for(const o of t.headerGroups[e]||[])this.groups[t.id][e].push({...o})}export(e){for(const t of e.sheets)t.headerGroups=this.groups[t.id]}exportForExcel(e){for(const t of e.sheets)for(const e of["ROW","COL"]){const o=this.getGroupsLayers(t.id,e);for(let s=0;s<o.length;s++){const i=o[s];for(const o of i){for(let i=o.start;i<=o.end;i++){const n=vA(t,e,i);n.outlineLevel=s+1,o.isFolded&&(n.isHidden=!0)}if(o.isFolded){vA(t,e,o.end+1).collapsed=!0}}}}}}).add("header visibility",class extends gV{static getters=["checkElementsIncludeAllVisibleHeaders","getHiddenColsGroups","getHiddenRowsGroups","isHeaderHiddenByUser","isRowHiddenByUser","isColHiddenByUser"];hiddenHeaders={};allowDispatch(e){switch(e.type){case"HIDE_COLUMNS_ROWS":{if(!this.getters.tryGetSheet(e.sheetId))return"InvalidSheetId";const t="COL"===e.dimension?this.getHiddenColsGroups(e.sheetId):this.getHiddenRowsGroups(e.sheetId),o="COL"===e.dimension?this.getters.getNumberCols(e.sheetId):this.getters.getNumberRows(e.sheetId);return new Set((t||[]).flat().concat(e.elements)).size>=o?"TooManyHiddenElements":ro(e.elements)<0||no(e.elements)>o?"InvalidHeaderIndex":"Success"}case"REMOVE_COLUMNS_ROWS":return this.getters.tryGetSheet(e.sheetId)?this.checkElementsIncludeAllVisibleHeaders(e.sheetId,e.dimension,e.elements)?"NotEnoughElements":"Success":"InvalidSheetId"}return"Success"}handle(e){switch(e.type){case"CREATE_SHEET":const t={COL:Array(this.getters.getNumberCols(e.sheetId)).fill(!1),ROW:Array(this.getters.getNumberRows(e.sheetId)).fill(!1)};this.history.update("hiddenHeaders",e.sheetId,t);break;case"DUPLICATE_SHEET":this.history.update("hiddenHeaders",e.sheetIdTo,pt(this.hiddenHeaders[e.sheetId]));break;case"DELETE_SHEET":this.history.update("hiddenHeaders",e.sheetId,void 0);break;case"REMOVE_COLUMNS_ROWS":{const t=[...this.hiddenHeaders[e.sheetId][e.dimension]];for(const o of[...e.elements].sort(((e,t)=>t-e)))t.splice(o,1);this.history.update("hiddenHeaders",e.sheetId,e.dimension,t);break}case"ADD_COLUMNS_ROWS":{const t=Ht(e.position,e.base),o=eo([...this.hiddenHeaders[e.sheetId][e.dimension]],Array(e.quantity).fill(!1),t);this.history.update("hiddenHeaders",e.sheetId,e.dimension,o);break}case"HIDE_COLUMNS_ROWS":for(const t of e.elements)this.history.update("hiddenHeaders",e.sheetId,e.dimension,t,!0);break;case"UNHIDE_COLUMNS_ROWS":for(const t of e.elements)this.history.update("hiddenHeaders",e.sheetId,e.dimension,t,!1)}}checkElementsIncludeAllVisibleHeaders(e,t,o){return Gt(o,this.getAllVisibleHeaders(e,t))}isHeaderHiddenByUser(e,t,o){return"COL"===t?this.isColHiddenByUser(e,o):this.isRowHiddenByUser(e,o)}isRowHiddenByUser(e,t){return this.hiddenHeaders[e].ROW[t]||this.getters.isRowFolded(e,t)}isColHiddenByUser(e,t){return this.hiddenHeaders[e].COL[t]||this.getters.isColFolded(e,t)}getHiddenColsGroups(e){const t=[[]],o=this.hiddenHeaders[e].COL;for(let e=0;e<o.length;e++){o[e]?t[t.length-1].push(e):0!==t[t.length-1].length&&t.push([])}return 0===t[t.length-1].length&&t.pop(),t}getHiddenRowsGroups(e){const t=[[]],o=this.hiddenHeaders[e].ROW;for(let e=0;e<o.length;e++){o[e]?t[t.length-1].push(e):0!==t[t.length-1].length&&t.push([])}return 0===t[t.length-1].length&&t.pop(),t}getAllVisibleHeaders(e,t){const o=Ct(0,this.getters.getNumberHeaders(e,t)),s=[];return this.getters.getHeaderGroups(e,t).forEach((e=>{e.isFolded&&s.push(...Ct(e.start,e.end+1))})),o.filter((o=>!this.hiddenHeaders[e][t][o]&&!s.includes(o)))}import(e){for(const t of e.sheets){this.hiddenHeaders[t.id]={COL:[],ROW:[]};for(let e=0;e<t.rowNumber;e++)this.hiddenHeaders[t.id].ROW[e]=Boolean(t.rows[e]?.isHidden);for(let e=0;e<t.colNumber;e++)this.hiddenHeaders[t.id].COL[e]=Boolean(t.cols[e]?.isHidden)}}exportForExcel(e){this.exportData(e,!0)}export(e){this.exportData(e)}exportData(e,t=!1){for(const o of e.sheets){void 0===o.rows&&(o.rows={});for(let e=0;e<this.getters.getNumberRows(o.id);e++)(t||this.hiddenHeaders[o.id].ROW[e])&&(void 0===o.rows[e]&&(o.rows[e]={}),o.rows[e].isHidden||=this.hiddenHeaders[o.id].ROW[e]);void 0===o.cols&&(o.cols={});for(let e=0;e<this.getters.getNumberCols(o.id);e++)(t||this.hiddenHeaders[o.id].COL[e])&&(void 0===o.cols[e]&&(o.cols[e]={}),o.cols[e].isHidden||=this.hiddenHeaders[o.id].COL[e])}}}).add("tables",class extends gV{static getters=["getCoreTable","getCoreTables","getCoreTableMatchingTopLeft"];tables={};nextTableId=1;adaptRanges(e,t){for(const o of this.getCoreTables(t))this.applyRangeChangeOnTable(t,o,e)}allowDispatch(e){switch(e.type){case"CREATE_TABLE":if(e.ranges.some((t=>!this.getters.tryGetSheet(t._sheetId)||t._sheetId!==e.sheetId)))return"InvalidSheetId";const t=e.ranges.map((e=>this.getters.getRangeFromRangeData(e).zone));return ms(t)?this.checkValidations(e,(e=>this.getTablesOverlappingZones(e.sheetId,t).length?"TableOverlap":"Success"),(e=>this.checkTableConfigUpdateIsValid(e.config))):"NonContinuousTargets";case"UPDATE_TABLE":return this.getCoreTableMatchingTopLeft(e.sheetId,e.zone)?this.checkValidations(e,this.checkUpdatedTableZoneIsValid,(e=>this.checkTableConfigUpdateIsValid(e.config))):"TableNotFound";case"ADD_MERGE":for(const t of this.getCoreTables(e.sheetId)){const o=t.range.zone;for(const t of e.target)if(Qo(o,t))return"MergeInTable"}}return"Success"}handle(e){switch(e.type){case"CREATE_SHEET":this.history.update("tables",e.sheetId,{});break;case"DELETE_SHEET":{const t={...this.tables};delete t[e.sheetId],this.history.update("tables",t);break}case"DUPLICATE_SHEET":{const t={};for(const o of this.getCoreTables(e.sheetId))t[o.id]="dynamic"===o.type?this.copyDynamicTableForSheet(e.sheetIdTo,o):this.copyStaticTableForSheet(e.sheetIdTo,o);this.history.update("tables",e.sheetIdTo,t);break}case"CREATE_TABLE":{const t=e.ranges.map((e=>this.getters.getRangeFromRangeData(e))),o=this.getters.getRangesUnion(t),s=this.getters.getMergesInZone(e.sheetId,o.zone);s.length&&this.dispatch("REMOVE_MERGE",{sheetId:e.sheetId,target:s});const i=this.consumeNextId(),n=e.config||MT,r="dynamic"===e.tableType?this.createDynamicTable(i,o,n):this.createStaticTable(i,e.tableType,o,n);this.history.update("tables",e.sheetId,r.id,r);break}case"REMOVE_TABLE":{const t={};for(const o of this.getCoreTables(e.sheetId))e.target.every((e=>!Xo(o.range.zone,e)))&&(t[o.id]=o);this.history.update("tables",e.sheetId,t);break}case"UPDATE_TABLE":this.updateTable(e);break;case"UPDATE_CELL":{const t=e.sheetId;for(const o of this.getCoreTables(t)){if("dynamic"===o.type)continue;const s=this.canUpdateCellCmdExtendTable(e,o);"down"===s?this.extendTableDown(t,o):"right"===s&&this.extendTableRight(t,o)}break}case"DELETE_CONTENT":{const t={...this.tables[e.sheetId]};for(const o in t){const s=t[o];s&&e.target.some((e=>ts(s.range.zone,e)))&&this.dispatch("REMOVE_TABLE",{sheetId:e.sheetId,target:[s.range.zone]})}break}}}getCoreTables(e){return this.tables[e]?Object.values(this.tables[e]).filter(Mt):[]}getCoreTable({sheetId:e,col:t,row:o}){return this.getCoreTables(e).find((e=>es(t,o,e.range.zone)))}getTablesOverlappingZones(e,t){return this.getCoreTables(e).filter((e=>t.some((t=>Qo(e.range.zone,t)))))}extendTableDown(e,t){const o=this.getters.extendRange(t.range,"ROW",1);this.history.update("tables",e,t.id,this.updateStaticTable(t,o))}extendTableRight(e,t){const o=this.getters.extendRange(t.range,"COL",1);this.history.update("tables",e,t.id,this.updateStaticTable(t,o))}canUpdateCellCmdExtendTable({content:e,sheetId:t,col:o,row:s},i){if(!e)return"none";const n=i.range.zone;let r="none";if(n.bottom+1===s&&o>=n.left&&o<=n.right?r="down":n.right+1===o&&s>=n.top&&s<=n.bottom&&(r="right"),"none"===r)return"none";const a="down"===r?{...n,bottom:n.bottom+1,top:n.bottom+1}:{...n,right:n.right+1,left:n.right+1};for(let e=a.top;e<=a.bottom;e++)for(let o=a.left;o<=a.right;o++){const s={sheetId:t,col:o,row:e},i=this.getters.getCell(s)?.content;if(i||this.getters.isInMerge(s)||this.getTablesOverlappingZones(t,[cs(s)]).length)return"none"}return r}getCoreTableMatchingTopLeft(e,t){for(const o of this.getCoreTables(e)){const e=o.range.zone;if(e.left===t.left&&e.top===t.top)return o}}checkUpdatedTableZoneIsValid(e){if(!e.newTableRange)return"Success";const t=this.getters.getRangeFromRangeData(e.newTableRange).zone,o=this.getters.checkZonesExistInSheet(e.sheetId,[t]);if("Success"!==o)return o;const s=this.getCoreTableMatchingTopLeft(e.sheetId,e.zone);if(!s)return"TableNotFound";return this.getTablesOverlappingZones(e.sheetId,[t]).filter((e=>e.id!==s.id)).length?"TableOverlap":"Success"}checkTableConfigUpdateIsValid(e){return e&&(void 0!==e.numberOfHeaders&&e.numberOfHeaders<0||e.hasFilters&&0===e.numberOfHeaders)?"InvalidTableConfig":"Success"}createStaticTable(e,t,o,s,i){const n=o.zone;if(!i){i=[];for(const e of Ct(n.left,n.right+1)){const t={...n,left:e,right:e},r=this.consumeNextId();i.push(this.createFilterFromZone(r,o.sheetId,t,s))}}return{id:e,range:o,filters:i,config:s,type:t}}createDynamicTable(e,t,o){const s=hs(t.zone);return{id:e,range:this.getters.getRangeFromZone(t.sheetId,s),config:o,type:"dynamic"}}updateTable(e){const t=this.getCoreTableMatchingTopLeft(e.sheetId,e.zone);if(!t)return;const o=e.newTableRange?this.getters.getRangeFromRangeData(e.newTableRange):void 0;if(o){const t=this.getters.getMergesInZone(e.sheetId,o.zone);this.dispatch("REMOVE_MERGE",{sheetId:e.sheetId,target:t})}const s=o||t.range,i=this.updateTableConfig(e.config,t.config),n=e.tableType??t.type;if("dynamic"===n&&"dynamic"!==t.type||"dynamic"!==n&&"dynamic"===t.type){const o="dynamic"===n?this.createDynamicTable(t.id,s,i):this.createStaticTable(t.id,n,s,i);this.history.update("tables",e.sheetId,t.id,o)}else{const o="dynamic"===t.type?this.updateDynamicTable(t,s,i):this.updateStaticTable(t,s,i,n);this.history.update("tables",e.sheetId,t.id,o)}}updateStaticTable(e,t,o,s=e.type){if("dynamic"===s)throw new Error("Cannot use updateStaticTable to update a dynamic table");const i=t||e.range,n=i.zone,r=this.updateTableConfig(o,e.config),a=r||e.config,l=[];if(t||r&&"numberOfHeaders"in r)for(const t of Ct(n.left,n.right+1)){const o=n.top===e.range.zone.top?e.filters.find((e=>e.col===t)):void 0,s={...n,left:t,right:t},r=o?.id||this.consumeNextId();l.push(this.createFilterFromZone(r,i.sheetId,s,a))}return{...e,range:i,config:a,filters:l.length?l:e.filters,type:s}}updateDynamicTable(e,t,o){const s=t?this.getters.getRangeFromZone(t.sheetId,hs(t.zone)):e.range,i=o||e.config;return{...e,range:s,config:i}}updateTableConfig(e,t){if(!e)return t;const o={...t,...e};return 0===e.numberOfHeaders?o.hasFilters=!1:!0===e.hasFilters&&(o.numberOfHeaders||=1),o}createFilterFromZone(e,t,o,s){return OF(e,this.getters.getRangeFromZone(t,o),s,this.getters.getRangeFromZone)}copyStaticTableForSheet(e,t){const o=this.getters.getRangeFromZone(e,t.range.zone),s=t.filters.map((o=>{const s=this.getters.getRangeFromZone(e,o.rangeWithHeaders.zone);return OF(o.id,s,t.config,this.getters.getRangeFromZone)}));return{id:t.id,range:o,filters:s,config:pt(t.config),type:t.type}}copyDynamicTableForSheet(e,t){const o=this.getters.getRangeFromZone(e,t.range.zone);return{id:t.id,range:o,config:pt(t.config),type:"dynamic"}}applyRangeChangeOnTable(e,t,o){const s=o(t.range);let i;switch(s.changeType){case"REMOVE":return void this.history.update("tables",e,t.id,void 0);case"NONE":return;default:i=s.range}if("dynamic"===t.type){const o=this.updateDynamicTable(t,i);return void this.history.update("tables",e,t.id,o)}const n=[];for(const e of t.filters){const s=o(e.rangeWithHeaders);switch(s.changeType){case"REMOVE":continue;case"NONE":n.push(e);break;default:const o=s.range,i=OF(e.id,o,t.config,this.getters.getRangeFromZone);n.push(i)}}const r=i.zone;if(n.length<os(r).numberOfCols){for(let o=r.left;o<=r.right;o++)if(!n.find((e=>e.col===o))){const s=this.consumeNextId(),i={...r,left:o,right:o};n.push(this.createFilterFromZone(s,e,i,t.config))}n.sort(((e,t)=>e.col-t.col))}const a=this.createStaticTable(t.id,t.type,i,t.config,n);this.history.update("tables",e,t.id,a)}consumeNextId(){const e=`${this.nextTableId}`;return this.history.update("nextTableId",this.nextTableId+1),e}import(e){for(const t of e.sheets)for(const e of t.tables||[]){const o=this.consumeNextId(),s=e.config||MT,i=this.getters.getRangeFromSheetXC(t.id,e.range),n=e.type||"static",r="dynamic"===n?this.createDynamicTable(o,i,s):this.createStaticTable(o,n,i,s);this.history.update("tables",t.id,r.id,r)}}export(e){for(const t of e.sheets)for(const e of this.getCoreTables(t.id)){const o={range:Go(e.range.zone),type:e.type};zt(e.config,MT)||(o.config=e.config),t.tables.push(o)}}exportForExcel(e){for(const t of e.sheets)for(const e of this.getCoreTables(t.id)){const o=Go(e.range.zone);t.tables.push({range:o,filters:[],config:e.config})}}}).add("dataValidation",class extends gV{static getters=["cellHasListDataValidationIcon","getDataValidationRule","getDataValidationRules","getValidationRuleForCell"];rules={};adaptRanges(e,t){this.adaptDVRanges(t,e),this.adaptDVFormulas(e)}adaptDVFormulas(e){for(const t in this.rules){for(let o=this.rules[t].length-1;o>=0;o--){const s=this.rules[t][o];for(let i=0;i<s.criterion.values.length;i++){const n=this.getters.adaptFormulaStringDependencies(t,s.criterion.values[i],e);this.history.update("rules",t,o,"criterion","values",i,n)}}}}adaptDVRanges(e,t){for(let o=this.rules[e].length-1;o>=0;o--){const s=this.rules[e][o];for(let i=s.ranges.length-1;i>=0;i--){const n=t(s.ranges[i]);switch(n.changeType){case"REMOVE":if(1===s.ranges.length)this.removeDataValidationRule(e,s.id);else{const t=s.ranges.slice();t.splice(i,1),this.history.update("rules",e,o,"ranges",t)}break;case"RESIZE":case"MOVE":case"CHANGE":this.history.update("rules",e,o,"ranges",i,n.range)}}}}allowDispatch(e){switch(e.type){case"ADD_DATA_VALIDATION_RULE":return this.getters.tryGetSheet(e.sheetId)?e.ranges.some((e=>!this.getters.tryGetSheet(e._sheetId)))?"InvalidSheetId":this.checkValidations(e,this.chainValidations(this.checkEmptyRange,this.checkValidRange,this.checkCriterionTypeIsValid,this.checkCriterionHasValidNumberOfValues,this.checkCriterionValuesAreValid)):"InvalidSheetId";case"REMOVE_DATA_VALIDATION_RULE":if(!this.getters.tryGetSheet(e.sheetId))return"InvalidSheetId";if(!this.rules[e.sheetId].find((t=>t.id===e.id)))return"UnknownDataValidationRule"}return"Success"}handle(e){switch(e.type){case"CREATE_SHEET":this.history.update("rules",e.sheetId,[]);break;case"DUPLICATE_SHEET":{const t=pt(this.rules[e.sheetId]).map((t=>({...t,ranges:t.ranges.map((t=>za(e.sheetId,e.sheetIdTo,t)))})));this.history.update("rules",e.sheetIdTo,t);break}case"DELETE_SHEET":{const t={...this.rules};delete t[e.sheetId],this.history.update("rules",t);break}case"REMOVE_DATA_VALIDATION_RULE":this.removeDataValidationRule(e.sheetId,e.id);break;case"ADD_DATA_VALIDATION_RULE":{const t=e.ranges.map((e=>this.getters.getRangeFromRangeData(e)));this.addDataValidationRule(e.sheetId,{...e.rule,ranges:t});break}case"DELETE_CONTENT":{const t=Fo(e.target),o=e.sheetId;for(const e of t)for(let t=e.top;t<=e.bottom;t++)for(let s=e.left;s<=e.right;s++){const e=this.getValidationRuleForCell({sheetId:o,col:s,row:t});if(e&&("isBoolean"===e.criterion.type||"isValueInList"===e.criterion.type&&!this.getters.getCell({sheetId:o,col:s,row:t})?.content)){const e=this.rules[o],i=[this.getters.getRangeFromSheetXC(o,_o(s,t))],n=this.removeRangesFromRules(o,i,e);this.history.update("rules",o,n)}}}}}getDataValidationRules(e){return this.rules[e]}getDataValidationRule(e,t){return this.rules[e].find((e=>e.id===t))}getValidationRuleForCell({sheetId:e,col:t,row:o}){if(this.rules[e])for(const s of this.rules[e])for(const e of s.ranges)if(es(t,o,e.zone))return s}cellHasListDataValidationIcon(e){const t=this.getValidationRuleForCell(e);return!!t&&!("isValueInList"!==t.criterion.type&&"isValueInRange"!==t.criterion.type||"arrow"!==t.criterion.displayStyle&&"chip"!==t.criterion.displayStyle)}addDataValidationRule(e,t){const o=this.rules[e];"isBoolean"===t.criterion.type?this.setCenterStyleToBooleanCells(t):"isValueInList"===t.criterion.type&&(t.criterion.values=Array.from(new Set(t.criterion.values)));const s=this.removeRangesFromRules(e,t.ranges,o,t.id),i=s.findIndex((e=>e.id===t.id));-1!==i?(s[i]=t,this.history.update("rules",e,s)):this.history.update("rules",e,[...s,t])}removeRangesFromRules(e,t,o,s){o=pt(o);for(const e of o)e.id!==s&&(e.ranges=this.getters.recomputeRanges(e.ranges,t));return o.filter((e=>e.ranges.length>0))}removeDataValidationRule(e,t){const o=this.rules[e].filter((e=>e.id!==t));this.history.update("rules",e,o)}setCenterStyleToBooleanCells(e){for(const t of $a(e.ranges)){const e=this.getters.getCell(t),o={...e?.style,align:e?.style?.align??"center",verticalAlign:e?.style?.verticalAlign??"middle"};this.dispatch("UPDATE_CELL",{...t,style:o})}}checkEmptyRange(e){return e.ranges.length?"Success":"EmptyRange"}import(e){for(const t of e.sheets)if(this.rules[t.id]=[],t.dataValidationRules)for(const e of t.dataValidationRules)this.rules[t.id].push({...e,ranges:e.ranges.map((e=>this.getters.getRangeFromSheetXC(t.id,e)))})}export(e){if(e.sheets)for(const t of e.sheets){t.dataValidationRules=[];for(const e of this.rules[t.id])t.dataValidationRules.push({...e,ranges:e.ranges.map((e=>this.getters.getRangeString(e,t.id)))})}}exportForExcel(e){if(e.sheets)for(const t of e.sheets){t.dataValidationRules=[];for(const e of this.rules[t.id]){const o={...pt(e),ranges:e.ranges.map((e=>this.getters.getRangeString(e,t.id,{useBoundedReference:!0})))};"isValueInRange"===e.criterion.type&&(o.criterion.values=e.criterion.values.map((e=>{const o=this.getters.getRangeFromSheetXC(t.id,e);return this.getters.getRangeString(o,t.id,{useBoundedReference:!0,useFixedReference:!0})}))),t.dataValidationRules.push(o)}}}checkCriterionTypeIsValid(e){return sR.contains(e.rule.criterion.type)?"Success":"UnknownDataValidationCriterionType"}checkCriterionHasValidNumberOfValues(e){const t=e.rule.criterion,o=sR.get(t.type).numberOfValues(t);return void 0!==o&&t.values.length!==o?"InvalidNumberOfCriterionValues":"Success"}checkCriterionValuesAreValid(e){const t=e.rule.criterion,o=sR.get(t.type);return t.values.some((e=>"onlyFormulas"===o.allowedValues&&!e.startsWith("=")||(e.startsWith("=")?"onlyLiterals"===o.allowedValues||$C(e).isBadExpression:!o.isCriterionValueValid(e))))?"InvalidDataValidationCriterionValue":"Success"}checkValidRange(e){const t=e.ranges.map((e=>this.getters.getRangeFromRangeData(e))),o=t.map((t=>this.getters.getRangeString(t,e.sheetId)));return o.some((e=>!this.getters.isRangeValid(e)))?"InvalidRange":"Success"}}).add("cell",class extends gV{static getters=["zoneToXC","getCells","getTranslatedCellFormula","getCellStyle","getCellById","getFormulaString","getFormulaMovedInSheet"];nextId=1;cells={};adaptRanges(e,t,o){for(const s of Object.keys(this.cells))for(const i of Object.values(this.cells[s]||{}))if(i.isFormula)for(const n of i.compiledFormula.dependencies)if(n.sheetId===t||n.invalidSheetName===o.old){const t=e(n);"NONE"!==t.changeType&&this.history.update("cells",s,i.id,"compiledFormula","dependencies",i.compiledFormula.dependencies.indexOf(n),t.range)}}allowDispatch(e){switch(e.type){case"UPDATE_CELL":return this.checkValidations(e,this.checkCellOutOfSheet,this.checkUselessUpdateCell);case"CLEAR_CELL":return this.checkValidations(e,this.checkCellOutOfSheet,this.checkUselessClearCell);case"UPDATE_CELL_POSITION":return!e.cellId||this.cells[e.sheetId]?.[e.cellId]?"Success":"InvalidCellId";default:return"Success"}}handle(e){switch(e.type){case"SET_FORMATTING":"style"in e&&this.setStyle(e.sheetId,e.target,e.style),"format"in e&&void 0!==e.format&&this.setFormatter(e.sheetId,e.target,e.format);break;case"CLEAR_FORMATTING":this.clearFormatting(e.sheetId,e.target);break;case"ADD_COLUMNS_ROWS":"COL"===e.dimension?this.handleAddColumnsRows(e,this.copyColumnStyle.bind(this)):this.handleAddColumnsRows(e,this.copyRowStyle.bind(this));break;case"UPDATE_CELL":this.updateCell(e.sheetId,e.col,e.row,e);break;case"CLEAR_CELL":this.dispatch("UPDATE_CELL",{sheetId:e.sheetId,col:e.col,row:e.row,content:"",style:null,format:""});break;case"CLEAR_CELLS":this.clearCells(e.sheetId,e.target);break;case"DELETE_CONTENT":this.clearZones(e.sheetId,e.target);break;case"DELETE_SHEET":this.history.update("cells",e.sheetId,void 0)}}clearZones(e,t){for(const o of Fo(t))for(let t=o.left;t<=o.right;t++)for(let s=o.top;s<=o.bottom;s++){const o=this.getters.getCell({sheetId:e,col:t,row:s});(o?.isFormula||o?.content)&&this.dispatch("UPDATE_CELL",{sheetId:e,content:"",col:t,row:s})}}setFormatter(e,t,o){for(const s of Fo(t))for(let t=s.top;t<=s.bottom;t++)for(let i=s.left;i<=s.right;i++)this.dispatch("UPDATE_CELL",{sheetId:e,col:i,row:t,format:o})}clearFormatting(e,t){for(const o of Fo(t))for(let t=o.left;t<=o.right;t++)for(let s=o.top;s<=o.bottom;s++)this.dispatch("UPDATE_CELL",{sheetId:e,col:t,row:s,style:null,format:""})}clearCells(e,t){for(const o of t)for(let t=o.left;t<=o.right;t++)for(let s=o.top;s<=o.bottom;s++)this.dispatch("UPDATE_CELL",{sheetId:e,col:t,row:s,content:"",style:null,format:""})}handleAddColumnsRows(e,t){let o,s;"before"===e.position?(o=Ct(e.base,e.base+e.quantity),s=e.base+e.quantity):(o=Ct(e.base+1,e.base+e.quantity+1),s=e.base),t(e.sheetId,s,o)}import(e){for(const t of e.sheets){const o=t.id,s=new tF;for(const e in t.cells)if(t.cells[e]){const{col:o,row:i}=Do(e),n={sheetId:t.id,col:o,row:i};s.set(n,{content:t.cells[e]})}for(const[e,o]of[["style",t.styles],["format",t.formats]])for(const[i,n]of ga(t.id,o)){const t=s.get(i);t?t[e]=n:s.set(i,{[e]:n})}for(const i of s.keysForSheet(o)){const o=s.get(i);if(o?.content||o?.format||o?.style){const s=this.importCell(t.id,o?.content,o?.style?e.styles[o?.style]:void 0,o?.format?e.formats[o?.format]:void 0);this.history.update("cells",t.id,s.id,s),this.dispatch("UPDATE_CELL_POSITION",{cellId:s.id,...i})}}}}export(e){const t={},o={};for(const s of e.sheets){const e=[],i=[],n={},r=Object.keys(this.cells[s.id]||{}).map((e=>this.getters.getCellPosition(e))).sort(((e,t)=>e.col===t.col?e.row-t.row:e.col-t.col));for(const s of r){const r=this.getters.getCell(s),a=_o(s.col,s.row),l=this.removeDefaultStyleValues(r.style);if(Object.keys(l).length){const o=da(l,t);e[o]??=[],e[o].push(s)}if(r.format){const e=da(r.format,o);i[e]??=[],i[e].push(s)}r.content&&(n[a]=r.content)}s.styles=ua(e),s.formats=ua(i),s.cells=n}e.styles=t,e.formats=o}importCell(e,t,o,s){const i=this.getNextUid();return this.createCell(i,t||"",s,o,e)}exportForExcel(e){this.export(e);const t=[];for(const o in e.formats||[])Kr(e.formats[o])||(t.push(Number(o)),delete e.formats[o]);if(t.length)for(const o of e.sheets)for(const e in o.formats){const s=o.formats[e];s&&t.includes(s)&&delete o.formats[e]}}removeDefaultStyleValues(e){const t={...e};for(const e in Oe)t[e]===Oe[e]&&delete t[e];return t}getCells(e){return this.cells[e]||{}}getCellById(e){const t=this.getters.getCellPosition(e);return this.cells[t.sheetId][e]}getFormulaString(e,t,o,s=!1){if(!o.length)return Lt(t.map((e=>e.value)));let i=0;return Lt(t.map((t=>{if("REFERENCE"===t.type){const t=o[i++];return this.getters.getRangeString(t,e,{useBoundedReference:s})}return t.value})))}getTranslatedCellFormula(e,t,o,s){const i=this.getters.createAdaptedRanges(GC(s).dependencies.map((t=>this.getters.getRangeFromSheetXC(e,t))),t,o,e);return this.getFormulaString(e,s,i)}getFormulaMovedInSheet(e,t,o){const s=GC(o).dependencies.map((t=>this.getters.getRangeFromSheetXC(e,t))),i=this.getters.removeRangesSheetPrefix(t,s);return this.getFormulaString(t,o,i)}getCellStyle(e){return this.getters.getCell(e)?.style||{}}zoneToXC(e,t,o=[{colFixed:!1,rowFixed:!1}]){const s=_o((t=this.getters.expandZone(e,t)).left,t.top,o[0]),i=_o(t.right,t.bottom,o.length>1?o[1]:o[0]),n=this.getters.getMainCellPosition({sheetId:e,col:t.left,row:t.top}),r=this.getters.getMainCellPosition({sheetId:e,col:t.right,row:t.bottom}),a=n.col===r.col&&n.row===r.row;return s===i||a?s:s+":"+i}setStyle(e,t,o){for(const s of Fo(t))for(let t=s.left;t<=s.right;t++)for(let i=s.top;i<=s.bottom;i++){const s=this.getters.getCell({sheetId:e,col:t,row:i});this.dispatch("UPDATE_CELL",{sheetId:e,col:t,row:i,style:o?{...s?.style,...o}:void 0})}}copyColumnStyle(e,t,o){for(let s=0;s<this.getters.getNumberRows(e);s++){const i=this.getFormat(e,t,s);if(i.style||i.format)for(const t of o)this.dispatch("UPDATE_CELL",{sheetId:e,col:t,row:s,...i})}}copyRowStyle(e,t,o){for(let s=0;s<this.getters.getNumberCols(e);s++){const i=this.getFormat(e,s,t);if(i.style||i.format)for(const t of o)this.dispatch("UPDATE_CELL",{sheetId:e,col:s,row:t,...i})}}getFormat(e,t,o){const s={},i=this.getters.getMainCellPosition({sheetId:e,col:t,row:o}),n=this.getters.getCell(i);return n&&(n.style&&(s.style=n.style),n.format&&(s.format=n.format)),s}getNextUid(){const e=this.nextId.toString();return this.history.update("nextId",this.nextId+1),e}updateCell(e,t,o,s){const i=this.getters.getCell({sheetId:e,col:t,row:o}),n="content"in s||"formula"in s,r=n?Xt(s?.content):i?.content||"";let a;a=void 0!==s.style?s.style||void 0:i?i.style:void 0;const l="format"in s?s.format:i&&i.format;if((n&&!r&&!s.formula||!n&&(!i||""===i.content))&&!a&&!l)return void(i&&(this.history.update("cells",e,i.id,void 0),this.dispatch("UPDATE_CELL_POSITION",{cellId:void 0,col:t,row:o,sheetId:e})));const c=i?.id||this.getNextUid(),h=this.createCell(c,r,l,a,e);this.history.update("cells",e,h.id,h),this.dispatch("UPDATE_CELL_POSITION",{cellId:h.id,col:t,row:o,sheetId:e})}createCell(e,t,o,s,i){return t.startsWith("=")?this.createFormulaCell(e,t,o,s,i):this.createLiteralCell(e,t,o,s)}createLiteralCell(e,t,o,s){const i=this.getters.getLocale(),n=ea(t,i);return Jr(o=o||("number"==typeof n?Vr(t,i)||Ur(t):void 0))||fn(t)||(t=En(n)),{id:e,content:t,style:s,format:o,isFormula:!1,parsedValue:n}}createFormulaCell(e,t,o,s,i){const n=$C(t);return n.dependencies.length?this.createFormulaCellWithDependencies(e,n,o,s,i):{id:e,content:t,style:s,format:o,isFormula:!0,compiledFormula:{...n,dependencies:[]}}}createFormulaCellWithDependencies(e,t,o,s,i){const n=[];for(const e of t.dependencies)n.push(this.getters.getRangeFromSheetXC(i,e));return new pV(e,t,o,s,n,i,this.getters.getRangeString)}checkCellOutOfSheet(e){const{sheetId:t,col:o,row:s}=e;if(!this.getters.tryGetSheet(t))return"InvalidSheetId";return es(o,s,this.getters.getSheetZone(t))?"Success":"TargetOutOfSheet"}checkUselessClearCell(e){const t=this.getters.getCell(e);return t&&(t.content||t.style||t.format)?"Success":"NoChanges"}checkUselessUpdateCell(e){const t=this.getters.getCell(e),o="style"in e,s="format"in e;return("content"in e||"formula"in e)&&t?.content!==e.content||o&&!zt(t?.style,e.style)||s&&t?.format!==e.format?"Success":"NoChanges"}}).add("merge",class extends gV{static getters=["isInMerge","isInSameMerge","isMergeHidden","getMainCellPosition","expandZone","doesIntersectMerge","doesColumnsHaveCommonMerges","doesRowsHaveCommonMerges","getMerges","getMerge","getMergesInZone","isSingleCellOrMerge","getSelectionRangeString","isMainCellPosition"];nextId=1;merges={};mergeCellMap={};allowDispatch(e){const t="force"in e&&!!e.force;switch(e.type){case"ADD_MERGE":return t?this.checkValidations(e,this.checkFrozenPanes):this.checkValidations(e,this.checkDestructiveMerge,this.checkOverlap,this.checkFrozenPanes);case"UPDATE_CELL":return this.checkMergedContentUpdate(e);case"REMOVE_MERGE":return this.checkMergeExists(e);default:return"Success"}}handle(e){switch(e.type){case"CREATE_SHEET":case"DELETE_SHEET":this.history.update("merges",e.sheetId,{}),this.history.update("mergeCellMap",e.sheetId,{});break;case"DUPLICATE_SHEET":const t=this.merges[e.sheetId];if(!t)break;for(const o of Object.values(t).filter(Mt))this.addMerge(e.sheetIdTo,o.zone);break;case"ADD_MERGE":for(const t of e.target)this.addMerge(e.sheetId,t);break;case"REMOVE_MERGE":for(const t of e.target)this.removeMerge(e.sheetId,t)}}adaptRanges(e,t){this.applyRangeChangeOnSheet(t,e)}getMerges(e){return Object.keys(this.merges[e]||{}).map((t=>this.getMergeById(e,parseInt(t,10)))).filter(Mt)}getMerge({sheetId:e,col:t,row:o}){const s=this.mergeCellMap[e],i=s?t in s&&s[t]?.[o]:void 0;return i?this.getMergeById(e,i):void 0}getMergesInZone(e,t){const o=this.mergeCellMap[e];if(!o)return[];const s=new Set;for(let e=t.left;e<=t.right;e++)for(let i=t.top;i<=t.bottom;i++){const t=o[e]?.[i];t&&s.add(t)}return Array.from(s).map((t=>this.getMergeById(e,t))).filter(Mt)}getSelectionRangeString(e,t){const o=this.getters.expandZone(e.sheetId,e.zone),s=Na({...e,zone:{...o,bottom:Va(e)?void 0:o.bottom,right:Ua(e)?void 0:o.right}},this.getters.getSheetSize),i=this.getters.getRangeString(s,t);if(this.isSingleCellOrMerge(e.sheetId,e.zone)){const{sheetName:e,xc:t}=Ta(i);return Aa(e,t.split(":")[0])}return i}doesIntersectMerge(e,t){for(const o of this.getMerges(e))if(Qo(t,o))return!0;return!1}doesColumnsHaveCommonMerges(e,t,o){const s=this.getters.getSheet(e);for(let i=0;i<this.getters.getNumberRows(e);i++)if(this.isInSameMerge(s.id,t,i,o,i))return!0;return!1}doesRowsHaveCommonMerges(e,t,o){const s=this.getters.getSheet(e);for(let i=0;i<=this.getters.getNumberCols(e);i++)if(this.isInSameMerge(s.id,i,t,i,o))return!0;return!1}expandZone(e,t){const{left:o,right:s,top:i,bottom:n}=t;let r={left:o,right:s,top:i,bottom:n};for(const t in this.merges[e]){const o=this.getMergeById(e,parseInt(t));o&&Qo(o,r)&&(r=Yo(o,r))}return Ko(r,t)?r:this.expandZone(e,r)}isInSameMerge(e,t,o,s,i){const n=this.getMerge({sheetId:e,col:t,row:o}),r=this.getMerge({sheetId:e,col:s,row:i});return!(!n||!r)&&Ko(n,r)}isInMerge({sheetId:e,col:t,row:o}){const s=this.mergeCellMap[e];return!!s&&(t in s&&Boolean(s[t]?.[o]))}getMainCellPosition(e){const t=this.getMerge(e);return t?{sheetId:e.sheetId,col:t.left,row:t.top}:e}isMergeHidden(e,t){const o=this.getters.getHiddenColsGroups(e),s=this.getters.getHiddenRowsGroups(e);for(const e of o)if(t.left>=e[0]&&t.right<=e[e.length-1])return!0;for(const e of s)if(t.top>=e[0]&&t.bottom<=e[e.length-1])return!0;return!1}isSingleCellOrMerge(e,t){const o=this.getMerge({sheetId:e,col:t.left,row:t.top});if(o)return Ko(t,o);const{numberOfCols:s,numberOfRows:i}=os(t);return 1===s&&1===i}isMainCellPosition(e){return zt(this.getMainCellPosition(e),e)}isMergeDestructive(e,t){let{left:o,right:s,top:i,bottom:n}=t;s=St(s,0,this.getters.getNumberCols(e)-1),n=St(n,0,this.getters.getNumberRows(e)-1);for(let t=i;t<=n;t++)for(let n=o;n<=s;n++)if(n!==o||t!==i){const o=this.getters.getCell({sheetId:e,col:n,row:t});if(o&&""!==o.content)return!0}return!1}getMergeById(e,t){const o=this.merges[e]?.[t];return void 0!==o?bV(t,o):void 0}checkDestructiveMerge({sheetId:e,target:t}){if(!this.getters.tryGetSheet(e))return"Success";return t.some((t=>this.isMergeDestructive(e,t)))?"MergeIsDestructive":"Success"}checkOverlap({target:e}){for(const t of e)for(const o of e)if(t!==o&&Qo(t,o))return"MergeOverlap";return"Success"}checkFrozenPanes({sheetId:e,target:t}){if(!this.getters.tryGetSheet(e))return"Success";const{xSplit:o,ySplit:s}=this.getters.getPaneDivisions(e);return ps(t,o,s)?"FrozenPaneOverlap":"Success"}checkMergedContentUpdate(e){const{col:t,row:o,content:s}=e;if(void 0===s)return"Success";const{col:i,row:n}=this.getMainCellPosition(e);return i===t&&n===o?"Success":"CellIsMerged"}checkMergeExists(e){const{sheetId:t,target:o}=e;for(const e of o){const{left:o,top:s}=e,i=this.getMerge({sheetId:t,col:o,row:s});if(void 0===i||!Ko(e,i))return"InvalidTarget"}return"Success"}addMerge(e,t){let{left:o,right:s,top:i,bottom:n}=t;s=St(s,0,this.getters.getNumberCols(e)-1),n=St(n,0,this.getters.getNumberRows(e)-1);if(_o(o,i)===_o(s,n))return;const r=this.getters.getCell({sheetId:e,col:o,row:i}),a=this.nextId++;this.history.update("merges",e,a,this.getters.getRangeFromSheetXC(e,Go({left:o,top:i,right:s,bottom:n})));const l=new Set;for(let t=i;t<=n;t++)for(let n=o;n<=s;n++){n===o&&t===i||this.dispatch("UPDATE_CELL",{sheetId:e,col:n,row:t,style:r?r.style:null,content:""});const s=this.getMerge({sheetId:e,col:n,row:t});s&&l.add(s.id),this.history.update("mergeCellMap",e,n,t,a)}for(const t of l){const{top:o,bottom:s,left:i,right:n}=this.getMergeById(e,t);for(let t=o;t<=s;t++)for(let o=i;o<=n;o++){const s={sheetId:e,col:o,row:t},i=this.getMerge(s);i&&i.id===a||(this.history.update("mergeCellMap",e,o,t,void 0),this.dispatch("CLEAR_CELL",s))}this.history.update("merges",e,t,void 0)}}removeMerge(e,t){const{left:o,top:s,bottom:i,right:n}=t,r=this.getMerge({sheetId:e,col:o,row:s});if(void 0!==r&&Ko(t,r)){this.history.update("merges",e,r.id,void 0);for(let t=s;t<=i;t++)for(let s=o;s<=n;s++)this.history.update("mergeCellMap",e,s,t,void 0)}}applyRangeChangeOnSheet(e,t){const o=Object.entries(this.merges[e]||{});for(const[s,i]of o)if(i){const o=i.zone,n=t(i);switch(n.changeType){case"NONE":break;case"REMOVE":this.removeMerge(e,o);break;default:const{numberOfCols:t,numberOfRows:i}=os(n.range.zone);1===t&&1===i?this.removeMerge(e,o):this.history.update("merges",e,parseInt(s,10),n.range)}}this.history.update("mergeCellMap",e,{});for(const t of this.getMerges(e))for(const{col:o,row:s}of is(t))this.history.update("mergeCellMap",e,o,s,t.id)}import(e){const t=e.sheets||[];for(const e of t)this.history.update("merges",e.id,{}),this.history.update("mergeCellMap",e.id,{}),e.merges&&this.importMerges(e.id,e.merges)}importMerges(e,t){for(const o of t)this.addMerge(e,Ho(o))}export(e){for(const t of e.sheets){const e=this.merges[t.id];e&&t.merges.push(...vV(e))}}exportForExcel(e){this.export(e)}}).add("headerSize",class extends gV{static getters=["getUserRowSize","getColSize"];sizes={};handle(e){switch(e.type){case"CREATE_SHEET":this.history.update("sizes",e.sheetId,{COL:Array(this.getters.getNumberCols(e.sheetId)).fill(void 0),ROW:Array(this.getters.getNumberRows(e.sheetId)).fill(void 0)});break;case"DUPLICATE_SHEET":this.history.update("sizes",e.sheetIdTo,pt(this.sizes[e.sheetId]));break;case"DELETE_SHEET":const t={...this.sizes};delete t[e.sheetId],this.history.update("sizes",t);break;case"REMOVE_COLUMNS_ROWS":{const t=Qt(this.sizes[e.sheetId][e.dimension],e.elements);this.history.update("sizes",e.sheetId,e.dimension,t);break}case"ADD_COLUMNS_ROWS":{const t=this.sizes[e.sheetId][e.dimension],o=Ht(e.position,e.base),s=t[e.base],i=eo(t,Array(e.quantity).fill(s),o);this.history.update("sizes",e.sheetId,e.dimension,i);break}case"RESIZE_COLUMNS_ROWS":if("ROW"===e.dimension)for(const t of e.elements)this.history.update("sizes",e.sheetId,e.dimension,t,e.size||void 0);else for(const t of e.elements)this.history.update("sizes",e.sheetId,e.dimension,t,e.size||void 0)}}getColSize(e,t){return Math.round(this.sizes[e]?.COL[t]||xe)}getUserRowSize(e,t){const o=this.sizes[e]?.ROW[t];return o?Math.round(o):void 0}import(e){for(const t of e.sheets){const e={COL:Array(t.colNumber).fill(void 0),ROW:Array(t.rowNumber).fill(void 0)};for(const[o,s]of Object.entries(t.rows))s.size&&(e.ROW[o]=s.size);for(const[o,s]of Object.entries(t.cols))s.size&&(e.COL[o]=s.size);this.sizes[t.id]=e}}exportForExcel(e){this.exportData(e,!0)}export(e){this.exportData(e)}exportData(e,t=!1){for(const o of e.sheets){void 0===o.rows&&(o.rows={});for(const e of Ct(0,this.getters.getNumberRows(o.id)))(t||this.sizes[o.id].ROW[e])&&(o.rows[e]={...o.rows[e],size:this.getUserRowSize(o.id,e)??Ee});void 0===o.cols&&(o.cols={});for(const e of Ct(0,this.getters.getNumberCols(o.id)))(t||this.sizes[o.id].COL[e])&&(o.cols[e]={...o.cols[e],size:this.getColSize(o.id,e)})}}}).add("borders",class extends gV{static getters=["getCellBorder","getBorders","getBordersColors","getCellBordersInZone"];borders={};allowDispatch(e){return"SET_BORDER"===e.type?this.checkValidations(e,this.checkBordersUnchanged,this.ensureHasBorder):"Success"}handle(e){switch(e.type){case"ADD_MERGE":for(const t of e.target)this.addBordersToMerge(e.sheetId,t);break;case"DUPLICATE_SHEET":this.history.update("borders",e.sheetIdTo,pt(this.borders[e.sheetId]));break;case"DELETE_SHEET":const t={...this.borders};delete t[e.sheetId],this.history.update("borders",t);break;case"SET_BORDER":e.border&&this.addBorders(e.sheetId,[cs(e)],e.border);break;case"SET_BORDERS_ON_TARGET":for(const t of e.target)for(let o=t.left;o<=t.right;o++)for(let s=t.top;s<=t.bottom;s++)this.addBorder(e.sheetId,{left:o,right:o,top:s,bottom:s},e.border&&Object.keys(e.border).length?e.border:void 0);break;case"SET_ZONE_BORDERS":const o=e.target.map((t=>this.getters.expandZone(e.sheetId,t)));"clear"===e.border.position?this.clearBorders(e.sheetId,o):this.addBorders(e.sheetId,o,this.borderDataToNewBorderData(e.border));break;case"CLEAR_FORMATTING":this.clearBorders(e.sheetId,e.target)}}beforeHandle(e){"REMOVE_COLUMNS_ROWS"===e.type&&("ROW"===e.dimension?this.onRowRemove(e.sheetId,e.elements):this.onColRemove(e.sheetId,e.elements))}adaptRanges(e,t){const o=[];for(const s of this.borders[t]??[]){const i=e(this.getters.getRangeFromZone(t,s.zone));switch(i.changeType){case"RESIZE":case"CHANGE":case"MOVE":o.push({...s,zone:i.range.unboundedZone});break;case"NONE":o.push(s)}}this.history.update("borders",t,o.filter((e=>!this.borderIsClear(e))))}onRowRemove(e,t){const o=new Set(t),s=[];for(const t of this.borders[e]??[]){let e=t;o.has(t.zone.top)&&(e=pt(t),e.style.top=t.style.horizontal),void 0!==t.zone.bottom&&o.has(t.zone.bottom)&&(e=e===t?pt(t):e,e.style.bottom=t.style.horizontal),s.push(e)}this.history.update("borders",e,s)}onColRemove(e,t){const o=new Set(t),s=[];for(const t of this.borders[e]??[]){let e=t;o.has(t.zone.left)&&(e=pt(t),e.style.left=t.style.vertical),void 0!==t.zone.right&&o.has(t.zone.right)&&(e=e===t?pt(t):e,e.style.right=t.style.vertical),s.push(e)}this.history.update("borders",e,s.filter((e=>!this.borderIsClear(e))))}getCellBorder(e){return this.getZoneExternalBorders(e.sheetId,cs(e))}getZoneExternalBorders(e,t){const o={};for(const s of this.borders[e]??[])Qo(s.zone,t)&&(o.right=(t.right===s.zone.right?s.style.right:s.style.vertical)??o.right,o.left=(t.left===s.zone.left?s.style.left:s.style.vertical)??o.left,o.bottom=(t.bottom===s.zone.bottom?s.style.bottom:s.style.horizontal)??o.bottom,o.top=(t.top===s.zone.top?s.style.top:s.style.horizontal)??o.top);return o}getCellBordersInZone(e,t){const o=new tF;for(const s of this.borders[e]??[]){const{zone:i,style:n}=s,r=Xo(i,t);if(r)for(let t=r.left;t<=r.right;t++)for(let s=r.top;s<=r.bottom;s++){const r=o.get({sheetId:e,col:t,row:s})??{};r.right=(t===i.right?n.right:n.vertical)??r.right,r.left=(t===i.left?n.left:n.vertical)??r.left,r.bottom=(s===i.bottom?n.bottom:n.horizontal)??r.bottom,r.top=(s===i.top?n.top:n.horizontal)??r.top,o.set({sheetId:e,col:t,row:s},r)}}return o}getBordersColors(e){const t=new Set;for(const o of this.borders[e]??[])for(const e of Object.values(o.style))e?.color&&t.add(e.color);return[...t]}getBorders(e,t){const o=[];for(const s of this.borders[e]??[]){const e=Xo(s.zone,t);e&&o.push(this.computeBorderFromZone(e,s))}return o}computeBorderFromZone(e,t){const o=t.style,s=t.zone,i=e.top===s.top,n=e.bottom===s.bottom,r=e.left===s.left,a=e.right===s.right;return{zone:e,style:{top:i?o.top:o.horizontal,bottom:n?o.bottom:o.horizontal,left:r?o.left:o.vertical,right:a?o.right:o.vertical,vertical:o.vertical,horizontal:o.horizontal}}}borderIsClear(e){const t=e.style;if(t.left||t.right||t.bottom||t.top)return!1;const o=e.zone;return(!(void 0===o.bottom||o.top<o.bottom)||!t.horizontal)&&(!(void 0===o.right||o.left<o.right)||!t.vertical)}clearBorders(e,t){for(const o of t)this.removeAndClearAdjacent(e,o)}removeAndClearAdjacent(e,t){const o=[];for(const s of this.borders[e]??[])for(const e of Fo([s.zone],[t]))for(const i of vs(e,t)){const e=this.computeBorderFromZone(i,s),n=Jo(i,t);switch(n?.position){case"left":e.style.left=void 0;break;case"right":e.style.right=void 0;break;case"top":e.style.top=void 0;break;case"bottom":e.style.bottom=void 0}o.push(e)}this.history.update("borders",e,o)}addBorders(e,t,o){for(const s of t)this.addBorder(e,s,o)}addBorder(e,t,o,s=!1){const i=[],n=o?{zone:t,style:o}:void 0,r={left:s||!!o?.left,right:s||!!o?.right,top:s||!!o?.top,bottom:s||!!o?.bottom};let a=[t];for(const o of this.borders[e]??[]){const e=Xo(o.zone,t);if(e){if(n){let t=this.computeBorderFromZone(e,n).style;s||(t={...this.computeBorderFromZone(e,o).style,...Wt(t)}),i.push({zone:e,style:t})}a=Fo(a,[e]);for(const t of Fo([o.zone],[e]))i.push(this.computeBorderFromZone(t,o))}else{const e=Jo(o.zone,t);if(e&&r[e.position])for(const e of vs(o.zone,t)){const s=this.computeBorderFromZone(e,o),n=Jo(e,t);switch(n?.position){case"left":s.style.left=void 0;break;case"right":s.style.right=void 0;break;case"top":s.style.top=void 0;break;case"bottom":s.style.bottom=void 0}i.push(s)}else i.push(o)}}n&&i.push(...a.map((e=>this.computeBorderFromZone(e,n)))),this.history.update("borders",e,i.filter((e=>!this.borderIsClear(e))))}borderDataToNewBorderData(e){const t={},o={color:e.color??"#000000",style:e.style??"thin"};return["all","external","top"].includes(e.position)&&(t.top={...o}),["all","external","bottom"].includes(e.position)&&(t.bottom={...o}),["all","external","left"].includes(e.position)&&(t.left={...o}),["all","external","right"].includes(e.position)&&(t.right={...o}),["all","hv","v"].includes(e.position)&&(t.vertical={...o}),["all","hv","h"].includes(e.position)&&(t.horizontal={...o}),t}checkBordersUnchanged(e){const t=this.getCellBorder(e),o=!(e.border?.bottom||e.border?.left||e.border?.right||e.border?.top);return!t&&o||zt(t,e.border)?"NoChanges":"Success"}ensureHasBorder(e){return e.border?"Success":"NoChanges"}addBordersToMerge(e,t){const o={...this.getZoneExternalBorders(e,t),...Wt(this.getCellBorder({sheetId:e,col:t.left,row:t.top}))};this.addBorder(e,t,o,!0)}import(e){if(Object.keys(e.borders||{}).length)for(const t of e.sheets)for(const o in t.borders){const s=t.borders[o];this.addBorder(t.id,Ho(o),e.borders[s])}for(const t of e.sheets)if(t.merges)for(const e of t.merges)this.addBordersToMerge(t.id,Ho(e))}export(e){const t={};for(const o of e.sheets){o.borders={};for(const e of this.borders[o.id]??[])o.borders[Go(e.zone)]=da(e.style,t)}e.borders=t}exportForExcel(e){this.export(e)}}).add("conditional formatting",class extends gV{static getters=["getConditionalFormats","getRulesSelection","getRulesByCell","getAdaptedCfRanges"];cfRules={};adaptCFFormulas(e){for(const t in this.cfRules)for(const o of this.cfRules[t])if("DataBarRule"===o.rule.type&&o.rule.rangeValues){const s=e(o.rule.rangeValues);switch(s.changeType){case"REMOVE":this.history.update("cfRules",t,this.cfRules[t].indexOf(o),"rule","rangeValues",void 0);break;case"RESIZE":case"MOVE":case"CHANGE":this.history.update("cfRules",t,this.cfRules[t].indexOf(o),"rule","rangeValues",s.range)}}else if("CellIsRule"===o.rule.type)for(let s=0;s<o.rule.values.length;s++)this.history.update("cfRules",t,this.cfRules[t].indexOf(o),"rule","values",s,this.getters.adaptFormulaStringDependencies(t,o.rule.values[s],e));else if("IconSetRule"===o.rule.type)for(const s of["lowerInflectionPoint","upperInflectionPoint"])"formula"===o.rule[s].type&&this.history.update("cfRules",t,this.cfRules[t].indexOf(o),"rule",s,"value",this.getters.adaptFormulaStringDependencies(t,o.rule[s].value,e));else if("ColorScaleRule"===o.rule.type)for(const s of["minimum","maximum","midpoint"]){const i=o.rule[s];"formula"===i?.type&&i?.value&&this.history.update("cfRules",t,this.cfRules[t].indexOf(o),"rule",s,"value",this.getters.adaptFormulaStringDependencies(t,i.value,e))}}adaptCFRanges(e,t){for(const o of this.cfRules[e])for(const s of o.ranges){const i=t(s);switch(i.changeType){case"REMOVE":const t=o.ranges.slice();t.splice(o.ranges.indexOf(s),1),t.length>=1?this.history.update("cfRules",e,this.cfRules[e].indexOf(o),"ranges",t):this.removeConditionalFormatting(o.id,e);break;case"RESIZE":case"MOVE":case"CHANGE":this.history.update("cfRules",e,this.cfRules[e].indexOf(o),"ranges",o.ranges.indexOf(s),i.range)}}}adaptRanges(e,t){const o=t?[t]:Object.keys(this.cfRules);for(const t of o)this.adaptCFRanges(t,e);this.adaptCFFormulas(e)}allowDispatch(e){switch(e.type){case"ADD_CONDITIONAL_FORMAT":return e.ranges.some((e=>!this.getters.tryGetSheet(e._sheetId)))?"InvalidSheetId":this.checkValidations(e,this.checkCFRule,this.checkEmptyRange,this.checkCFHasChanged);case"CHANGE_CONDITIONAL_FORMAT_PRIORITY":return this.checkValidPriorityChange(e.cfId,e.delta,e.sheetId)}return"Success"}handle(e){switch(e.type){case"CREATE_SHEET":this.cfRules[e.sheetId]=[];break;case"DUPLICATE_SHEET":this.history.update("cfRules",e.sheetIdTo,[]);for(const t of this.getConditionalFormats(e.sheetId))this.addConditionalFormatting(t,e.sheetIdTo);break;case"DELETE_SHEET":const t=Object.assign({},this.cfRules);delete t[e.sheetId],this.history.update("cfRules",t);break;case"ADD_CONDITIONAL_FORMAT":const o={...e.cf,ranges:e.ranges.map((t=>this.getters.getRangeString(this.getters.getRangeFromRangeData(t),e.sheetId)))};this.addConditionalFormatting(o,e.sheetId);break;case"REMOVE_CONDITIONAL_FORMAT":this.removeConditionalFormatting(e.id,e.sheetId);break;case"CHANGE_CONDITIONAL_FORMAT_PRIORITY":this.changeCFPriority(e.cfId,e.delta,e.sheetId)}}import(e){for(const t of e.sheets)this.cfRules[t.id]=t.conditionalFormats.map((e=>this.mapToConditionalFormatInternal(t.id,e)))}export(e){if(e.sheets)for(const t of e.sheets)this.cfRules[t.id]&&(t.conditionalFormats=this.cfRules[t.id].map((e=>this.mapToConditionalFormat(t.id,e))))}exportForExcel(e){if(e.sheets)for(const t of e.sheets)this.cfRules[t.id]&&(t.conditionalFormats=this.cfRules[t.id].map((e=>this.mapToConditionalFormat(t.id,e,{useBoundedReference:!0}))))}getConditionalFormats(e){return this.cfRules[e]?.map((t=>this.mapToConditionalFormat(e,t)))||[]}getRulesSelection(e,t){const o=new Set;return t.forEach((t=>{this.getRulesByZone(e,t).forEach((e=>{o.add(e)}))})),Array.from(o)}getRulesByZone(e,t){const o=new Set;for(let s=t.top;s<=t.bottom;s++)for(let i=t.left;i<=t.right;i++){this.getRulesByCell(e,i,s).forEach((e=>{o.add(e.id)}))}return o}getRulesByCell(e,t,o){const s=[];for(const i of this.cfRules[e])for(const e of i.ranges)es(t,o,e.zone)&&s.push(i);return new Set(s.map((t=>this.mapToConditionalFormat(e,t))))}getAdaptedCfRanges(e,t,o,s){if(0===o.length&&0===s.length)return;const i=this.getters.getConditionalFormats(e),n=i.findIndex((e=>e.id===t.id));let r=[];n>-1&&(r=i[n].ranges.map(Uo));const a=Fo(r,s);return Fo([...o,...a],[]).map((t=>this.getters.getRangeDataFromZone(e,t)))}mapToConditionalFormat(e,t,{useBoundedReference:o}={useBoundedReference:!1}){const s=t.ranges.map((t=>this.getters.getRangeString(t,e,{useBoundedReference:o})));return"DataBarRule"!==t.rule.type?{...t,rule:{...t.rule},ranges:s}:{...t,rule:{...t.rule,rangeValues:t.rule.rangeValues&&this.getters.getRangeString(t.rule.rangeValues,e,{useBoundedReference:o})},ranges:s}}mapToConditionalFormatInternal(e,t){const o=t.ranges.map((t=>this.getters.getRangeFromSheetXC(e,t)));return"DataBarRule"!==t.rule.type?{...t,rule:{...t.rule},ranges:o}:{...t,rule:{...t.rule,rangeValues:t.rule.rangeValues?this.getters.getRangeFromSheetXC(e,t.rule.rangeValues):void 0},ranges:o}}addConditionalFormatting(e,t){const o=this.cfRules[t].slice(),s=o.findIndex((t=>t.id===e.id)),i=this.mapToConditionalFormatInternal(t,e);s>-1?o.splice(s,1,i):o.push(i),this.history.update("cfRules",t,o)}checkValidPriorityChange(e,t,o){if(!this.cfRules[o])return"InvalidSheetId";const s=this.cfRules[o].findIndex((t=>t.id===e));if(-1===s)return"InvalidConditionalFormatId";const i=s-t;return i<0||i>=this.cfRules[o].length?"InvalidConditionalFormatId":"Success"}checkEmptyRange(e){return e.ranges.length?"Success":"EmptyRange"}checkCFRule(e){const t=e.cf.rule;switch(t.type){case"CellIsRule":return this.checkValidations(t,this.checkOperatorArgsNumber,this.checkCFValues);case"ColorScaleRule":return this.checkValidations(t,this.chainValidations(this.checkThresholds(this.checkFormulaCompilation)),this.chainValidations(this.checkThresholds(this.checkNaN),this.batchValidations(this.checkMinBiggerThanMax,this.checkMinBiggerThanMid,this.checkMidBiggerThanMax)));case"IconSetRule":return this.checkValidations(t,this.chainValidations(this.checkInflectionPoints(this.checkNaN),this.checkLowerBiggerThanUpper),this.chainValidations(this.checkInflectionPoints(this.checkFormulaCompilation)))}return"Success"}checkCFHasChanged(e){const t=this.mapToConditionalFormatInternal(e.sheetId,{...e.cf,ranges:e.ranges.map((t=>this.getters.getRangeString(this.getters.getRangeFromRangeData(t),e.sheetId)))}),o=this.cfRules[e.sheetId]?.find((t=>t.id===e.cf.id));return o&&zt(t,o)?"NoChanges":"Success"}checkOperatorArgsNumber(e){const t=sR.get(e.operator).numberOfValues({type:e.operator,values:e.values});if(void 0===t||t>2)throw new Error("Checking more than 2 arguments is currently not supported. Add the appropriate CommandResult if you want to.");const o=[],s=e=>void 0===e||""===e;return t>=1&&s(e.values[0])&&o.push("FirstArgMissing"),t>=2&&s(e.values[1])&&o.push("SecondArgMissing"),o.length?o:"Success"}checkNaN(e,t){if(["number","percentage","percentile"].includes(e.type)&&(""===e.value||isNaN(e.value)))switch(t){case"min":return"MinNaN";case"max":return"MaxNaN";case"mid":return"MidNaN";case"upperInflectionPoint":return"ValueUpperInflectionNaN";case"lowerInflectionPoint":return"ValueLowerInflectionNaN"}return"Success"}checkFormulaCompilation(e,t){if("formula"!==e.type)return"Success";if($C(e.value||"").isBadExpression)switch(t){case"min":return"MinInvalidFormula";case"max":return"MaxInvalidFormula";case"mid":return"MidInvalidFormula";case"upperInflectionPoint":return"ValueUpperInvalidFormula";case"lowerInflectionPoint":return"ValueLowerInvalidFormula"}return"Success"}checkThresholds(e){return this.batchValidations((t=>e(t.minimum,"min")),(t=>e(t.maximum,"max")),(t=>t.midpoint?e(t.midpoint,"mid"):"Success"))}checkInflectionPoints(e){return this.batchValidations((t=>e(t.lowerInflectionPoint,"lowerInflectionPoint")),(t=>e(t.upperInflectionPoint,"upperInflectionPoint")))}checkLowerBiggerThanUpper(e){const t=e.lowerInflectionPoint.value,o=e.upperInflectionPoint.value;return["number","percentage","percentile"].includes(e.lowerInflectionPoint.type)&&e.lowerInflectionPoint.type===e.upperInflectionPoint.type&&Number(t)>Number(o)?"LowerBiggerThanUpper":"Success"}checkMinBiggerThanMax(e){const t=e.minimum.value,o=e.maximum.value;return["number","percentage","percentile"].includes(e.minimum.type)&&e.minimum.type===e.maximum.type&&fV(t)>=fV(o)?"MinBiggerThanMax":"Success"}checkMidBiggerThanMax(e){const t=e.midpoint?.value,o=e.maximum.value;return e.midpoint&&["number","percentage","percentile"].includes(e.midpoint.type)&&e.midpoint.type===e.maximum.type&&fV(t)>=fV(o)?"MidBiggerThanMax":"Success"}checkMinBiggerThanMid(e){const t=e.minimum.value,o=e.midpoint?.value;return e.midpoint&&["number","percentage","percentile"].includes(e.midpoint.type)&&e.minimum.type===e.midpoint.type&&fV(t)>=fV(o)?"MinBiggerThanMid":"Success"}checkCFValues(e){for(const t of e.values){if(!t.startsWith("="))continue;if($C(t||"").isBadExpression)return"ValueCellIsInvalidFormula"}return"Success"}removeConditionalFormatting(e,t){const o=this.cfRules[t].findIndex((t=>t.id===e));if(-1!==o){const e=this.cfRules[t].slice();e.splice(o,1),this.history.update("cfRules",t,e)}}changeCFPriority(e,t,o){const s=this.cfRules[o].findIndex((t=>t.id===e)),i=this.cfRules[o][s],n=s-t,r=[...this.cfRules[o]];r.splice(s,1),r.splice(n,0,i),this.history.update("cfRules",o,r)}}).add("figures",class extends gV{static getters=["getFigures","getFigure","getFigureSheetId"];figures={};insertionOrders=[];adaptRanges(e,t){for(const o of this.getFigures(t)){const s=e(this.getters.getRangeFromZone(t,{left:o.col,right:o.col,top:o.row,bottom:o.row}));if("MOVE"===s.changeType)this.history.update("figures",t,o.id,"col",s.range.zone.right),this.history.update("figures",t,o.id,"row",s.range.zone.bottom);else if("REMOVE"===s.changeType){const s=e(this.getters.getRangeFromZone(t,{left:0,right:o.col-1,top:0,bottom:o.row-1}));let{offset:i,col:n,row:r}=o;"NONE"!==s.changeType&&(n=s.range.zone.right+1,r=s.range.zone.bottom+1),({offset:i,col:n,row:r}=this.getPositionInSheet(t,{...o,col:n,row:r})),this.history.update("figures",t,o.id,"offset",i),this.history.update("figures",t,o.id,"col",n),this.history.update("figures",t,o.id,"row",r)}}}allowDispatch(e){switch(e.type){case"CREATE_FIGURE":return this.checkValidations(e,this.checkFigureDuplicate,this.checkFigureAnchorOffset);case"UPDATE_FIGURE":return this.checkValidations(e,this.checkFigureExists,this.checkFigureAnchorOffset);case"DELETE_FIGURE":return this.checkFigureExists(e);default:return"Success"}}beforeHandle(e){if("DELETE_SHEET"===e.type)this.getters.getFigures(e.sheetId).forEach((t=>{this.dispatch("DELETE_FIGURE",{figureId:t.id,sheetId:e.sheetId})}))}handle(e){switch(e.type){case"CREATE_SHEET":this.figures[e.sheetId]={};break;case"DELETE_SHEET":this.deleteSheet(e.sheetId);break;case"CREATE_FIGURE":const t={id:e.figureId,col:e.col,row:e.row,offset:e.offset,width:e.size.width,height:e.size.height,tag:e.tag};this.addFigure(t,e.sheetId);break;case"UPDATE_FIGURE":this.updateFigure(e);break;case"DELETE_FIGURE":this.removeFigure(e.figureId,e.sheetId);break;case"REMOVE_COLUMNS_ROWS":"COL"===e.dimension?this.onColRemove(e.sheetId):this.onRowRemove(e.sheetId);break;case"DUPLICATE_SHEET":for(const t in this.figures[e.sheetId]){const o=this.figures[e.sheetId]?.[t];if(!o)continue;const s=t.split($e).pop(),i=`${e.sheetIdTo}${$e}${s}`;this.dispatch("CREATE_FIGURE",{figureId:i,...o,size:{width:o.width,height:o.height},sheetId:e.sheetIdTo})}}}onColRemove(e){const t=this.getters.getNumberCols(e),o=new Array(t+1);o[t]=0;for(let s=t-1;s>=0;s--)o[s]=o[s+1]+this.getters.getColSize(e,s);for(const t of this.getFigures(e))if(t.offset.x+t.width>o[t.col]){let s=t.offset.x,i=t.col;for(s=Math.min(s,o[i]-t.width);s<0&&i>0;)i--,s=o[i]-t.width;s!==t.offset.x&&this.history.update("figures",e,t.id,"offset",{x:Math.max(s,0),y:t.offset.y}),i!==t.col&&this.history.update("figures",e,t.id,"col",i)}}onRowRemove(e){const t=this.getters.getNumberRows(e),o=new Array(t+1);o[t]=0;for(let s=t-1;s>=0;s--)o[s]=o[s+1]+(this.getters.getUserRowSize(e,s)??Ee);for(const t of this.getFigures(e))if(t.offset.y+t.height>o[t.row]){let s=t.offset.y,i=t.row;for(let t=this.getters.getUserRowSize(e,i)??Ee;t<s;t=this.getters.getUserRowSize(e,i)??Ee)i+=1,s-=t;for(s=Math.min(s,o[i]-t.height);s<0&&i>0;)i--,s=o[i]-t.height;s!==t.offset.y&&this.history.update("figures",e,t.id,"offset",{x:t.offset.x,y:Math.max(0,s)}),i!==t.row&&this.history.update("figures",e,t.id,"row",i)}else t.offset.y+t.height>o[0]&&this.history.update("figures",e,t.id,"offset",{x:t.offset.x,y:Math.max(o[0]-t.height,0)})}getPositionInSheet(e,t){const{numberOfRows:o,numberOfCols:s}=this.getters.getSheetSize(e);let i,n,r=0,a=0,{col:l,row:c}=t;const h={...t.offset};for(i=o;r<t.height&&i>0;i--)r+=this.getters.getUserRowSize(e,i-1)??Ee;for(c>i?(c=i,h.y=Math.max(r-t.height,0)):c===i&&(h.y=St(h.y,0,Math.max(r-t.height,0))),n=s;a<t.width&&n>0;n--)a+=this.getters.getColSize(e,n-1);return l>n?(l=n,h.x=Math.max(a-t.width,0)):n===l&&(h.x=St(h.x,0,Math.max(a-t.width,0))),{col:l,row:c,offset:h}}updateFigure(e){if(!("figureId"in e)||!("sheetId"in e))return;const{figureId:t,sheetId:o,...s}=e,i={...this.getFigure(o,t),...s};for(const[e,t]of Object.entries(s))switch(e){case"tag":case"offset":this.history.update("figures",o,i.id,e,t);break;case"col":case"row":case"width":case"height":void 0!==t&&this.history.update("figures",o,i.id,e,t)}}addFigure(e,t){this.history.update("figures",t,e.id,e),this.history.update("insertionOrders",this.insertionOrders.length,e.id)}deleteSheet(e){this.history.update("insertionOrders",this.insertionOrders.filter((t=>!this.figures[e]?.[t]))),this.history.update("figures",e,void 0)}removeFigure(e,t){this.history.update("insertionOrders",this.insertionOrders.filter((t=>t!==e))),this.history.update("figures",t,e,void 0)}checkFigureExists(e){return void 0===this.figures[e.sheetId]?.[e.figureId]?"FigureDoesNotExist":"Success"}checkFigureDuplicate(e){return Object.values(this.figures).find((t=>t?.[e.figureId]))?"DuplicatedFigureId":"Success"}checkFigureAnchorOffset(e){return e.col<0||e.row<0||e.offset&&(e.offset.x<0||e.offset.y<0)?"WrongSheetPosition":"Success"}getFigures(e){const t=[];for(const o of this.insertionOrders){const s=this.figures[e]?.[o];s&&t.push(s)}return t}getFigure(e,t){return this.figures[e]?.[t]}getFigureSheetId(e){return Object.keys(this.figures).find((t=>void 0!==this.figures[t]?.[e]))}import(e){for(const t of e.sheets)for(const e of t.figures)this.addFigure(e,t.id)}export(e){for(const t of e.sheets)for(const e of this.getFigures(t.id)){const o=void 0;t.figures.push({...e,data:o})}}exportForExcel(e){return this.export(e)}}).add("chart",class extends gV{static getters=["isChartDefined","getChartDefinition","getChartType","getChartIds","getChart","getFigureIdFromChartId","getContextCreationChart"];charts={};createChart=rE(this.getters);validateChartDefinition=e=>lE(this,e.definition);adaptRanges(e,t,o){for(const[s,i]of Object.entries(this.charts)){if(!i)continue;const n=i.chart.updateRanges(e,t,o);this.history.update("charts",s,n?{figureId:i.figureId,chart:n}:void 0)}}allowDispatch(e){switch(e.type){case"CREATE_CHART":return this.checkValidations(e,this.chainValidations(this.checkFigureArguments,this.validateChartDefinition,this.checkChartDuplicate));case"UPDATE_CHART":return this.checkValidations(e,this.chainValidations(this.validateChartDefinition,this.checkChartExists,this.checkChartChanged));case"DELETE_CHART":return this.checkChartExists(e);default:return"Success"}}handle(e){switch(e.type){case"CREATE_CHART":const{col:t,row:o,offset:s,size:i,sheetId:n,figureId:r}=e;this.getters.getFigure(n,r)||void 0===s||void 0===t||void 0===o||this.addFigure(r,n,t,o,s,i),this.addChart(e.figureId,e.chartId,e.definition);break;case"UPDATE_CHART":this.addChart(e.figureId,e.chartId,e.definition);break;case"DUPLICATE_SHEET":for(const t of this.getChartIds(e.sheetId)){const{chart:o,figureId:s}=this.charts[t]||{};if(!o||!s)continue;const i=this.getters.getFigure(e.sheetId,s);if(!i)continue;const n=s.split($e).pop(),r=`${e.sheetIdTo}${$e}${n}`,a=t.split($e).pop(),l=`${e.sheetIdTo}${$e}${a}`,c=o.duplicateInDuplicatedSheet(e.sheetIdTo);c&&this.dispatch("CREATE_CHART",{figureId:r,chartId:l,col:i.col,row:i.row,offset:i.offset,size:{width:i.width,height:i.height},definition:c.getDefinition(),sheetId:e.sheetIdTo})}break;case"DELETE_FIGURE":for(const t in this.charts)this.charts[t]?.figureId===e.figureId&&this.dispatch("DELETE_CHART",{chartId:t,sheetId:e.sheetId});break;case"DELETE_CHART":this.isChartDefined(e.chartId)&&this.history.update("charts",e.chartId,void 0);break;case"DELETE_SHEET":for(const t of this.getChartIds(e.sheetId))this.history.update("charts",t,void 0)}}getContextCreationChart(e){return this.charts[e]?.chart.getContextCreation()}getChart(e){return this.charts[e]?.chart}getFigureIdFromChartId(e){if(!this.charts[e])throw new Error(`Chart with id ${e} does not exist.`);return this.charts[e].figureId}getChartType(e){const t=this.charts[e]?.chart.type;if(!t)throw new Error("Chart not defined.");return t}isChartDefined(e){return e in this.charts&&void 0!==this.charts}getChartIds(e){return Object.entries(this.charts).filter((([,t])=>t?.chart.sheetId===e)).map((([e])=>e))}getChartDefinition(e){const t=this.charts[e]?.chart.getDefinition();if(!t)throw new Error(`There is no chart with the given id: ${e}`);return t}import(e){for(const t of e.sheets)if(t.figures)for(const e of t.figures)if("chart"===e.tag){const o=e.data.chartId,s=this.createChart(e.id,e.data,t.id);this.charts[o]={chart:s,figureId:e.id}}else if("carousel"===e.tag)for(const o in e.data.chartDefinitions||{}){const s=e.data.chartDefinitions[o],i=this.createChart(e.id,s,t.id);this.charts[o]={chart:i,figureId:e.id}}}export(e){if(e.sheets)for(const t of e.sheets){const e=this.getters.getFigures(t.id),o=[];for(const t of e){const e=t,s=Object.keys(this.charts).find((e=>this.charts[e]?.figureId===t.id));if(e&&"chart"===e.tag&&s){const t=this.charts[s]?.chart.getDefinition();t&&(e.data={...t,chartId:s},o.push(e))}else if(e&&"carousel"===e.tag){const s=Object.keys(this.charts).filter((e=>this.charts[e]?.figureId===t.id)),i={};for(const e of s)i[e]=this.charts[e]?.chart.getDefinition();e.data={chartDefinitions:i},o.push(e)}else o.push(e)}t.figures=o}}addFigure(e,t,o,s,i,n={width:536,height:335}){this.dispatch("CREATE_FIGURE",{sheetId:t,figureId:e,col:o,row:s,offset:i,size:n,tag:"chart"})}addChart(e,t,o){const s=this.getters.getFigureSheetId(e);if(s){const i=this.createChart(e,o,s);this.history.update("charts",t,{figureId:e,chart:i})}}checkChartDuplicate(e){return this.isChartDefined(e.chartId)?"DuplicatedChartId":"Success"}checkChartExists(e){return this.isChartDefined(e.chartId)?"Success":"ChartDoesNotExist"}checkChartChanged(e){return e.figureId!==this.charts[e.chartId]?.figureId?"Success":zt(this.getChartDefinition(e.chartId),e.definition)?"NoChanges":"Success"}checkFigureArguments(e){return this.getters.getFigure(e.sheetId,e.figureId)||void 0!==e.offset&&void 0!==e.col&&void 0!==e.row?"Success":"MissingFigureArguments"}}).add("carousel",class extends gV{static getters=["getCarousel","doesCarouselExist"];carousels={};allowDispatch(e){switch(e.type){case"CREATE_CAROUSEL":return this.getters.getFigure(e.sheetId,e.figureId)?"DuplicatedFigureId":"Success";case"UPDATE_CAROUSEL":return this.carousels[e.sheetId]?.[e.figureId]?"Success":"InvalidFigureId"}return"Success"}handle(e){switch(e.type){case"CREATE_CAROUSEL":this.getters.getFigure(e.sheetId,e.figureId)||this.dispatch("CREATE_FIGURE",{...e,tag:"carousel"}),this.history.update("carousels",e.sheetId,e.figureId,e.definition);break;case"UPDATE_CAROUSEL":this.removeDeletedCharts(e,this.getters.getCarousel(e.figureId).items),this.history.update("carousels",e.sheetId,e.figureId,e.definition);break;case"DUPLICATE_SHEET":{const t=this.getters.getFigures(e.sheetId);for(const o of t)if("carousel"===o.tag){const t=o.id.split($e).pop(),s=`${e.sheetIdTo}${$e}${t}`,i=this.getCarousel(o.id);if(i){const t={width:o.width,height:o.height};this.dispatch("CREATE_CAROUSEL",{sheetId:e.sheetIdTo,figureId:s,offset:o.offset,col:o.col,row:o.row,size:t,definition:{items:i.items.map((t=>{if("carouselDataView"===t.type)return{...t};const o=t.chartId.split($e).pop(),s=`${e.sheetIdTo}${$e}${o}`;return{...t,chartId:s}}))}})}}break}case"DELETE_FIGURE":this.history.update("carousels",e.sheetId,e.figureId,void 0);break;case"DELETE_SHEET":this.history.update("carousels",e.sheetId,void 0)}}doesCarouselExist(e){for(const t in this.carousels)if(this.carousels[t]?.[e])return!0;return!1}getCarousel(e){for(const t in this.carousels)if(this.carousels[t]?.[e])return this.carousels[t][e];throw new Error(`There is no carousel with the given figureId: ${e}`)}removeDeletedCharts(e,t){const o=new Set(e.definition.items.filter((e=>"chart"===e.type)).map((e=>e.chartId)));for(const s of t)"chart"!==s.type||o.has(s.chartId)||this.dispatch("DELETE_CHART",{chartId:s.chartId,sheetId:e.sheetId})}import(e){for(const t of e.sheets){const e=(t.figures||[]).filter((e=>"carousel"===e.tag));for(const o of e)this.history.update("carousels",t.id,o.id,{items:o.data.items,title:o.data.title})}}export(e){for(const t of e.sheets){const e=t.figures.filter((e=>"carousel"===e.tag));for(const o of e)this.carousels[t.id]?.[o.id]&&(o.data={...o.data,...this.carousels[t.id]?.[o.id]})}}}).add("image",class extends gV{static getters=["getImage","getImagePath","getImageSize"];fileStore;images={};syncedImages=new Set;constructor(e){super(e),this.fileStore=e.external.fileStore}allowDispatch(e){return"CREATE_IMAGE"===e.type&&this.getters.getFigure(e.sheetId,e.figureId)?"InvalidFigureId":"Success"}handle(e){switch(e.type){case"CREATE_IMAGE":this.getters.getFigure(e.sheetId,e.figureId)||this.addFigure(e.figureId,e.sheetId,e.col,e.row,e.offset,e.size),this.history.update("images",e.sheetId,e.figureId,e.definition),this.syncedImages.add(e.definition.path);break;case"DUPLICATE_SHEET":{const t=this.getters.getFigures(e.sheetId);for(const o of t)if("image"===o.tag){const t=o.id.split($e).pop(),s=`${e.sheetIdTo}${$e}${t}`,i=this.getImage(o.id);if(i){const t={width:o.width,height:o.height};this.dispatch("CREATE_IMAGE",{sheetId:e.sheetIdTo,figureId:s,offset:o.offset,col:o.col,row:o.row,size:t,definition:pt(i)})}}break}case"DELETE_FIGURE":this.history.update("images",e.sheetId,e.figureId,void 0);break;case"DELETE_SHEET":this.history.update("images",e.sheetId,void 0)}}garbageCollectExternalResources(){const e=new Set(this.getAllImages().map((e=>e.path)));for(const t of this.syncedImages)e.has(t)||this.fileStore?.delete(t)}getImage(e){for(const t of Object.values(this.images))if(t&&t[e])return t[e];throw new Error(`There is no image with the given figureId: ${e}`)}getImagePath(e){return this.getImage(e).path}getImageSize(e){return this.getImage(e).size}addFigure(e,t,o,s,i,n){this.dispatch("CREATE_FIGURE",{sheetId:t,figureId:e,col:o,row:s,offset:i,size:n,tag:"image"})}import(e){for(const t of e.sheets){const e=(t.figures||[]).filter((e=>"image"===e.tag));for(const o of e)this.history.update("images",t.id,o.id,o.data),this.syncedImages.add(o.data.path)}}export(e){for(const t of e.sheets){const e=t.figures.filter((e=>"image"===e.tag));for(const o of e)o.data=this.images[t.id]?.[o.id]}}exportForExcel(e){for(const t of e.sheets){t.images||(t.images=[]);const e=this.getters.getFigures(t.id),o=[];for(const t of e)if("image"===t?.tag){const e=this.getImage(t.id);e&&o.push({...t,data:pt(e)})}t.images=[...t.images,...o]}}getAllImages(){const e=[];for(const t in this.images)e.push(...Object.values(this.images[t]||{}).filter(Mt));return e}}).add("pivot_core",class extends gV{static getters=["getPivotCoreDefinition","getPivotDisplayName","getPivotId","getPivotFormulaId","getPivotIds","getMeasureCompiledFormula","getPivotName","isExistingPivot"];nextFormulaId=1;pivots={};formulaIds={};compiledMeasureFormulas={};allowDispatch(e){switch(e.type){case"ADD_PIVOT":return this.checkValidations(e.pivot,this.checkDuplicatedMeasureIds,this.checkSortedColumnInMeasures,this.checkCustomFieldsAreValid);case"UPDATE_PIVOT":return e.pivotId in this.pivots?zt(e.pivot,this.pivots[e.pivotId]?.definition)?"NoChanges":""===e.pivot.name?"EmptyName":this.checkValidations(e.pivot,this.checkDuplicatedMeasureIds,this.checkSortedColumnInMeasures,this.checkCustomFieldsAreValid):"PivotIdNotFound";case"RENAME_PIVOT":if(!(e.pivotId in this.pivots))return"PivotIdNotFound";if(""===e.name)return"EmptyName";break;case"REMOVE_PIVOT":case"DUPLICATE_PIVOT":case"INSERT_PIVOT":case"DUPLICATE_PIVOT":if(!(e.pivotId in this.pivots))return"PivotIdNotFound"}return"Success"}handle(e){switch(e.type){case"ADD_PIVOT":{const{pivotId:t,pivot:o}=e;this.addPivot(t,o);break}case"INSERT_PIVOT":{const{sheetId:t,col:o,row:s,pivotId:i,table:n}=e,r={sheetId:t,col:o,row:s},{cols:a,rows:l,measures:c,fieldsType:h}=n,d=new cP(a,l,c,h||{}),u=this.getPivotFormulaId(i);this.insertPivot(r,u,d);break}case"RENAME_PIVOT":this.history.update("pivots",e.pivotId,"definition","name",e.name);break;case"REMOVE_PIVOT":{const t={...this.pivots};delete t[e.pivotId];const o=this.getPivotFormulaId(e.pivotId);this.history.update("formulaIds",o,void 0),this.history.update("pivots",t);break}case"DUPLICATE_PIVOT":{const{pivotId:t,newPivotId:o}=e,s=pt(this.getPivotCore(t).definition);s.name=e.duplicatedPivotName??s.name+" (copy)",this.addPivot(o,s);break}case"UPDATE_PIVOT":this.history.update("pivots",e.pivotId,"definition",pt(e.pivot)),this.compileCalculatedMeasures(e.pivot.measures)}}adaptRanges(e){for(const t in this.compiledMeasureFormulas)for(const o in this.compiledMeasureFormulas[t]){const s=this.compiledMeasureFormulas[t][o],i=[];for(const t of s.dependencies){const o=e(t);"NONE"===o.changeType?i.push(t):i.push(o.range)}const n=this.getters.getFormulaString(t,s.tokens,i);n!==o&&this.replaceMeasureFormula(t,o,n)}}getPivotDisplayName(e){return`(#${this.getPivotFormulaId(e)}) ${this.getPivotName(e)}`}getPivotName(e){return this.getPivotCore(e).definition.name}getPivotCoreDefinition(e){return this.getPivotCore(e).definition}getPivotId(e){return this.formulaIds[e]}getPivotFormulaId(e){return this.getPivotCore(e).formulaId}getPivotIds(){return Object.keys(this.pivots)}isExistingPivot(e){return e in this.pivots}getMeasureCompiledFormula(e){if(!e.computedBy)throw new Error(`Measure ${e.fieldName} is not computed by formula`);const t=e.computedBy.sheetId;return this.compiledMeasureFormulas[t][e.computedBy.formula]}addPivot(e,t,o=this.nextFormulaId.toString()){this.history.update("pivots",e,{definition:pt(t),formulaId:o}),this.compileCalculatedMeasures(t.measures),this.history.update("formulaIds",o,e),this.history.update("nextFormulaId",this.nextFormulaId+1)}compileCalculatedMeasures(e){for(const t of e)if(t.computedBy){const e=t.computedBy.sheetId,o=this.compileMeasureFormula(t.computedBy.sheetId,t.computedBy.formula);this.history.update("compiledMeasureFormulas",e,t.computedBy.formula,o)}}insertPivot(e,t,o){this.resizeSheet(e.sheetId,e,o);const s=o.getPivotCells();for(let o=0;o<s.length;o++)for(let i=0;i<s[o].length;i++){const n=s[o][i];this.dispatch("UPDATE_CELL",{sheetId:e.sheetId,col:e.col+o,row:e.row+i,content:nh(t,n)})}}resizeSheet(e,{col:t,row:o},s){const i=s.getNumberOfDataColumns()+1,n=this.getters.getNumberCols(e),r=n-t;r<i&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"COL",base:n-1,sheetId:e,sheetName:this.getters.getSheetName(e),quantity:i-r,position:"after"});const a=s.columns.length+s.rows.length,l=this.getters.getNumberRows(e),c=l-o;c<a&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"ROW",base:l-1,sheetId:e,sheetName:this.getters.getSheetName(e),quantity:a-c,position:"after"})}getPivotCore(e){const t=this.pivots[e];if(!t)throw new Error(`Pivot with id ${e} not found`);return t}compileMeasureFormula(e,t){const o=$C(t),s=o.dependencies.map((t=>this.getters.getRangeFromSheetXC(e,t)));return{...o,dependencies:s}}replaceMeasureFormula(e,t,o){this.history.update("compiledMeasureFormulas",e,t,void 0),this.history.update("compiledMeasureFormulas",e,o,this.compileMeasureFormula(e,o));for(const s in this.pivots){const i=this.pivots[s];if(i)for(const n of i.definition.measures)if(n.computedBy?.formula===t){const t=i.definition.measures.indexOf(n);this.history.update("pivots",s,"definition","measures",t,"computedBy",{formula:o,sheetId:e})}}}checkSortedColumnInMeasures(e){const t=e.measures.map((e=>e.id));return e.sortedColumn&&!t.includes(e.sortedColumn.measure)?"InvalidDefinition":"Success"}checkDuplicatedMeasureIds(e){const t=new Set(e.measures.map((e=>e.id)));return e.measures.length!==t.size?"InvalidDefinition":"Success"}checkCustomFieldsAreValid(e){for(const t in e.customFields){const o=e.customFields[t],s=new Set,i=new Set;let n=!1;for(const e of o.groups){if(!e.name||i.has(e.name))return"InvalidPivotCustomField";if(e.values.some((e=>s.has(e))))return"InvalidPivotCustomField";if(e.isOtherGroup&&n)return"InvalidPivotCustomField";e.values.forEach((e=>s.add(e))),i.add(e.name),n||=!!e.isOtherGroup}}return"Success"}import(e){if(e.pivots)for(const[t,o]of Object.entries(e.pivots))this.addPivot(t,o,o.formulaId);this.history.update("nextFormulaId",e.pivotNextId||Jc(this.pivots)+1)}export(e){e.pivots={};for(const t in this.pivots)e.pivots[t]={...this.getPivotCoreDefinition(t),formulaId:this.getPivotFormulaId(t)};e.pivotNextId=this.nextFormulaId}}).add("spreadsheet_pivot_core",class extends gV{allowDispatch(e){switch(e.type){case"ADD_PIVOT":case"UPDATE_PIVOT":const t=e.pivot;return this.checkDataSetValidity(t)}return"Success"}adaptRanges(e){for(const t of this.getters.getPivotIds()){const o=this.getters.getPivotCoreDefinition(t);if("SPREADSHEET"===o.type&&o.dataSet){const{sheetId:s,zone:i}=o.dataSet,n=CV(this.getters.getRangeFromZone(s,i),e),r=n&&{sheetId:n.sheetId,zone:n.zone};this.dispatch("UPDATE_PIVOT",{pivotId:t,pivot:{...o,dataSet:r}})}}}checkDataSetValidity(e){if("SPREADSHEET"===e.type&&e.dataSet){const{zone:t,sheetId:o}=e.dataSet;return o&&this.getters.tryGetSheet(o)&&t&&Bo(t)?this.getters.checkZonesExistInSheet(o,[t]):"InvalidDataSet"}return"Success"}}).add("tableStyle",class extends gV{static getters=["getNewCustomTableStyleName","getTableStyle","getTableStyles","isTableStyleEditable"];styles={};allowDispatch(e){switch(e.type){case"CREATE_TABLE":case"UPDATE_TABLE":if(e.config?.styleId&&!this.styles[e.config.styleId])return"InvalidTableConfig";break;case"CREATE_TABLE_STYLE":if(!KT[e.templateName])return"InvalidTableStyle";try{_s(e.primaryColor)}catch(e){return"InvalidTableStyle"}}return"Success"}handle(e){switch(e.type){case"CREATE_TABLE_STYLE":const t=JT(e.tableStyleName,e.templateName,e.primaryColor);this.history.update("styles",e.tableStyleId,t);break;case"REMOVE_TABLE_STYLE":const o={...this.styles};delete o[e.tableStyleId],this.history.update("styles",o);for(const t of this.getters.getSheetIds())for(const o of this.getters.getCoreTables(t))o.config.styleId===e.tableStyleId&&this.dispatch("UPDATE_TABLE",{sheetId:t,zone:o.range.zone,config:{styleId:MT.styleId}})}}getTableStyle(e){if(!this.styles[e])throw new Error(`Table style ${e} does not exist`);return this.styles[e]}getTableStyles(){return this.styles}getNewCustomTableStyleName(){return ho(ui("Custom Table Style"),Object.values(this.styles).map((e=>e.displayName)),{compute:(e,t)=>`${e} ${t}`,start:2})}isTableStyleEditable(e){return!XT[e]}import(e){for(const e in XT)this.styles[e]=XT[e];for(const t in e.customTableStyles){const o=e.customTableStyles[t];this.styles[t]=JT(o.displayName,o.templateName,o.primaryColor)}}export(e){const t={};for(const e in this.styles)XT[e]||(t[e]={displayName:this.styles[e].displayName,templateName:this.styles[e].templateName,primaryColor:this.styles[e].primaryColor});e.customTableStyles=t}}),rH=(new n).add("ui_sheet",class extends tu{static getters=["getCellWidth","getTextWidth","getCellText","getCellMultiLineText","getContiguousZone","computeTextYCoordinate"];ctx=document.createElement("canvas").getContext("2d");allowDispatch(e){return this.chainValidations(this.checkSheetExists,this.checkZonesAreInSheet)(e)}handle(e){switch(e.type){case"AUTORESIZE_COLUMNS":for(const t of e.cols){const o=this.getColMaxWidth(e.sheetId,t);0!==o&&this.dispatch("RESIZE_COLUMNS_ROWS",{elements:[t],dimension:"COL",size:o,sheetId:e.sheetId})}break;case"AUTORESIZE_ROWS":this.autoResizeRows(e.sheetId,e.rows);break;case"DELETE_UNFILTERED_CONTENT":const t=[];for(const o of e.target){const s=yt(Ct(o.top,o.bottom+1).filter((t=>!this.getters.isRowFiltered(e.sheetId,t))));for(const e of s)t.push({...o,top:e[0],bottom:e[e.length-1]})}this.dispatch("DELETE_CONTENT",{sheetId:e.sheetId,target:t})}}getCellWidth(e){const t=this.getters.getCellComputedStyle(e);let o=0;const s=this.getters.getEvaluatedCell(e).formattedValue;if(s){const e=gl(this.ctx,s,t,void 0);o+=Math.max(...e.map((e=>nl(this.ctx,e,t))))}for(const t of this.getters.getCellIcons(e))o+=t.margin+t.size;if(this.getters.getDataValidationChipStyle(e)&&(o+=10),0===o)return 0;if(o+=2*De,"wrap"===t.wrapping){const t=this.getters.getColSize(this.getters.getActiveSheetId(),e.col);return Math.min(t,o)}return o}getTextWidth(e,t){return nl(this.ctx,e,t)}getCellText(e,t){const o=this.getters.getCell(e),s=this.getters.getLocale();if(t?.showFormula&&o?.isFormula)return Zl(o.content,s);if(t?.showFormula&&!o?.content)return"";{const i=this.getters.getEvaluatedCell(e),n=t?.availableWidth?{availableWidth:t.availableWidth,measureText:e=>nl(this.ctx,e,o?.style||{})}:void 0;return Rr(i.value,{format:i.format,locale:s,formatWidth:n})}}getCellMultiLineText(e,t){const o=this.getters.getCellStyle(e),s=this.getters.getCellText(e,{showFormula:this.getters.shouldShowFormulas(),availableWidth:t.maxWidth});return gl(this.ctx,s,o,t.wrapText?t.maxWidth:void 0)}computeTextYCoordinate(e,t,o=Pe,s=1){const i=e.y+1,n=tl(t,s);if(e.height>n+2*Te){if("middle"===o)return Math.ceil(i+(e.height-n)/2);if("bottom"===o)return i+e.height-n-Te}return i+Te}getContiguousZone(e,t){const o=t=>{for(const o of Ct(t.left,t.right+1)){if(!this.isCellEmpty({sheetId:e,col:o,row:t.top-1}))return{...t,top:t.top-1};if(!this.isCellEmpty({sheetId:e,col:o,row:t.bottom+1}))return{...t,bottom:t.bottom+1}}for(const o of Ct(t.top,t.bottom+1)){if(!this.isCellEmpty({sheetId:e,col:t.left-1,row:o}))return{...t,left:t.left-1};if(!this.isCellEmpty({sheetId:e,col:t.right+1,row:o}))return{...t,right:t.right+1}}return t};let s=!1,i=t;do{s=!1;const e=o(i);Ko(i,e)||(s=!0,i=e)}while(s);return i}isCellEmpty(e){const t=this.getters.getMainCellPosition(e);return this.getters.getEvaluatedCell(t).type===r.empty}getColMaxWidth(e,t){const o=is(this.getters.getColsZone(e,t,t)).map((t=>this.getCellWidth({sheetId:e,...t})));return Math.max(0,no(o))}checkSheetExists(e){return"sheetId"in e&&void 0===this.getters.tryGetSheet(e.sheetId)?"InvalidSheetId":"Success"}checkZonesAreInSheet(e){const t="sheetId"in e?e.sheetId:this.getters.tryGetActiveSheetId();if("ranges"in e&&e.ranges.some((e=>!this.getters.tryGetSheet(e._sheetId))))return"InvalidSheetId";const o=this.getters.getCommandZones(e);return!t&&o.length>0?"NoActiveSheet":t&&o.length>0?this.getters.checkZonesExistInSheet(t,o):"Success"}autoResizeRows(e,t){const o=[];for(const s of t){let t=0;for(const o of this.getters.getRowCells(e,s)){const s=this.getters.getCellById(o);if(!s)continue;const i=this.getters.getCellPosition(s.id),n=this.getters.getColSize(e,i.col);if(s.isFormula||this.getters.getArrayFormulaSpreadingOn(i)){const e=this.getters.getEvaluatedCell(i).formattedValue,o=ol(this.ctx,e,s?.style,n);o>t&&o>Ee&&(t=o)}else{const e=s.content,o=ol(this.ctx,e,s?.style,n);o>=t&&o>Ee&&(t=0)}}o.push(t||null)}const s=new Map(o.map((e=>[e,[]])));for(let e=0;e<o.length;e++)s.get(o[e])?.push(t[e]);for(const[t,o]of s)this.dispatch("RESIZE_COLUMNS_ROWS",{elements:o,dimension:"ROW",size:t,sheetId:e})}}).add("ui_options",class extends tu{static getters=["shouldShowFormulas"];showFormulas=!1;handle(e){if("SET_FORMULA_VISIBILITY"===e.type)this.showFormulas=e.show}shouldShowFormulas(){return this.showFormulas}}).add("autofill",class extends tu{static layers=["Autofill"];static getters=["getAutofillTooltip"];autofillZone;steps;lastCellSelected={};direction;tooltip;allowDispatch(e){if("AUTOFILL_SELECT"===e.type){const t=this.getters.getActiveSheetId();return this.lastCellSelected.col=-1===e.col?this.lastCellSelected.col:St(e.col,0,this.getters.getNumberCols(t)),this.lastCellSelected.row=-1===e.row?this.lastCellSelected.row:St(e.row,0,this.getters.getNumberRows(t)),void 0!==this.lastCellSelected.col&&void 0!==this.lastCellSelected.row?"Success":"InvalidAutofillSelection"}return"Success"}handle(e){switch(e.type){case"AUTOFILL":this.autofill(!0);break;case"AUTOFILL_SELECT":this.select(e.col,e.row);break;case"AUTOFILL_AUTO":this.autofillAuto()}}getAutofillTooltip(){return this.tooltip}autofill(e){if(!this.autofillZone||!this.steps||void 0===this.direction)return void(this.tooltip=void 0);const t=this.getters.getSelectedZone(),o=this.autofillZone,s=[];switch(this.direction){case"down":for(let e=t.left;e<=t.right;e++){const i=[];for(let o=t.top;o<=t.bottom;o++)i.push(_o(e,o));const n=this.createGenerator(i);for(let t=o.top;t<=o.bottom;t++)s.push(this.computeNewCell(n,e,t))}break;case"up":for(let e=t.left;e<=t.right;e++){const i=[];for(let o=t.bottom;o>=t.top;o--)i.push(_o(e,o));const n=this.createGenerator(i);for(let t=o.bottom;t>=o.top;t--)s.push(this.computeNewCell(n,e,t))}break;case"left":for(let e=t.top;e<=t.bottom;e++){const i=[];for(let o=t.right;o>=t.left;o--)i.push(_o(o,e));const n=this.createGenerator(i);for(let t=o.right;t>=o.left;t--)s.push(this.computeNewCell(n,t,e))}break;case"right":for(let e=t.top;e<=t.bottom;e++){const i=[];for(let o=t.left;o<=t.right;o++)i.push(_o(o,e));const n=this.createGenerator(i);for(let t=o.left;t<=o.right;t++)s.push(this.computeNewCell(n,t,e))}}if(e){const e={},t={},o={},i=this.getters.getActiveSheetId();for(const n of s)this.collectBordersData(n,e),this.autofillMerge(i,n),this.autofillCell(i,n),this.collectConditionalFormatsData(i,n,t),this.collectDataValidationsData(i,n,o);this.autofillBorders(i,e),this.autofillConditionalFormats(i,t),this.autofillDataValidations(i,o),this.autofillZone=void 0,this.selection.resizeAnchorZone(this.direction,this.steps),this.lastCellSelected={},this.direction=void 0,this.steps=0,this.tooltip=void 0}}collectBordersData(e,t){const o=JSON.stringify(e.border);o in t||(t[o]=[]),t[o].push(cs({col:e.col,row:e.row}))}collectConditionalFormatsData(e,t,o){const{originCol:s,originRow:i,col:n,row:r}=t,a=this.getters.getRulesByCell(e,s,i),l=_o(n,r);for(const e of a)e.id in o||(o[e.id]=[]),o[e.id].push(l)}collectDataValidationsData(e,t,o){const{originCol:s,originRow:i,col:n,row:r}=t,a={sheetId:e,col:s,row:i},l=this.getters.getValidationRuleForCell(a);l&&(l.id in o||(o[l.id]=[]),o[l.id].push(cs({col:n,row:r})))}autofillCell(e,t){this.dispatch("UPDATE_CELL",{sheetId:e,col:t.col,row:t.row,content:t.content||"",style:t.style||null,format:t.format||""}),this.dispatch("AUTOFILL_CELL",t)}autofillBorders(e,t){for(const o in t){const s="undefined"===o?void 0:JSON.parse(o);this.dispatch("SET_BORDERS_ON_TARGET",{sheetId:e,border:s,target:Fo(t[o])})}}autofillConditionalFormats(e,t){for(const o in t){const s=t[o],i=this.getters.getConditionalFormats(e).find((e=>e.id===o));if(!i)continue;const n=this.getters.getAdaptedCfRanges(e,i,s.map(Ho),[]);n&&this.dispatch("ADD_CONDITIONAL_FORMAT",{cf:{id:i.id,rule:i.rule,stopIfTrue:i.stopIfTrue},ranges:n,sheetId:e})}}autofillDataValidations(e,t){for(const o in t){const s=t[o],i=this.getters.getDataValidationRule(e,o);if(!i)continue;const n=i.ranges.map((e=>e.zone)),r=Fo(n.concat(s),[]);this.dispatch("ADD_DATA_VALIDATION_RULE",{rule:i,ranges:r.map((t=>this.getters.getRangeDataFromZone(e,t))),sheetId:e})}}select(e,t){const o=this.getters.getSelectedZone();if(es(e,t,o))this.autofillZone=void 0;else{switch(this.direction=this.getDirection(e,t),this.direction){case"up":this.saveZone(t,o.top-1,o.left,o.right),this.steps=o.top-t;break;case"down":this.saveZone(o.bottom+1,t,o.left,o.right),this.steps=t-o.bottom;break;case"left":this.saveZone(o.top,o.bottom,e,o.left-1),this.steps=o.left-e;break;case"right":this.saveZone(o.top,o.bottom,o.right+1,e),this.steps=e-o.right}this.autofill(!1)}}autofillAuto(){const e=this.getters.getActivePosition(),t=this.getters.getTable(e);let o=t?t.range.zone.bottom:this.getAutofillAutoLastRow();const s=this.getters.getSelectedZone();for(let t=s.bottom+1;t<=o;t++)if(this.getters.getEvaluatedCell({...e,row:t}).type!==r.empty){o=t-1;break}o>s.bottom&&(this.select(e.col,o),this.autofill(!0))}getAutofillAutoLastRow(){const e=this.getters.getSelectedZone(),t=this.getters.getActiveSheetId();let o=e.left,s=e.bottom;if(o>0){let e={sheetId:t,col:o-1,row:s};for(;this.getters.getEvaluatedCell(e).type!==r.empty;)s+=1,e={sheetId:t,col:o-1,row:s}}if(s===e.bottom&&(o=e.right,o<=this.getters.getNumberCols(t))){let e={sheetId:t,col:o+1,row:s};for(;this.getters.getEvaluatedCell(e).type!==r.empty;)s+=1,e={sheetId:t,col:o+1,row:s}}return s-1}computeNewCell(e,t,o){const{cellData:s,tooltip:i,origin:n}=e.next(),{content:r,style:a,border:l,format:c}=s;return this.tooltip=i,{originCol:n.col,originRow:n.row,col:t,row:o,content:r,style:a,border:l,format:c}}getRule(e,t){const o=mU.getAll().sort(((e,t)=>e.sequence-t.sequence)).find((o=>o.condition(e,t)));return o&&this.direction&&o.generateRule(e,t,this.direction)}createGenerator(e){const t=[],o=[],s=this.getters.getActiveSheetId();for(const t of e){const{col:e,row:i}=Do(t),n=this.getters.getCell({sheetId:s,col:e,row:i});o.push({col:e,row:i,cell:n,sheetId:s})}const i=o.map((e=>e.cell));for(const e of o){let o={type:"COPY_MODIFIER"};if(e&&e.cell){o=this.getRule(e.cell,i)||o}const s=this.getters.getCellBorder(e)||void 0;t.push({data:{...e,border:s},rule:o})}return new wU(t,this.getters,this.direction)}saveZone(e,t,o,s){this.autofillZone={top:e,bottom:t,left:o,right:s}}getDirection(e,t){const o=this.getters.getSelectedZone(),s={up:{number:o.top-t,value:"up"},down:{number:t-o.bottom,value:"down"},left:{number:o.left-e,value:"left"},right:{number:e-o.right,value:"right"}};if(1===Object.values(s).map((e=>e.number>0?1:0)).reduce(((e,t)=>e+t)))return Object.values(s).find((e=>e.number>0?1:0)).value;const i=s.up.number>0?"up":"down",n=s.left.number>0?"left":"right";return Math.abs(s[i].number)>=Math.abs(s[n].number)?s[i].value:s[n].value}autofillMerge(e,t){const{originCol:o,originRow:s,col:i,row:n}=t,r={sheetId:e,col:i,row:n},a={sheetId:e,col:o,row:s};if(this.getters.isInMerge(r)&&!this.getters.isInMerge(a)){const t=this.getters.getMerge(r);t&&this.dispatch("REMOVE_MERGE",{sheetId:e,target:[t]})}const l=this.getters.getMerge(a);l?.left===o&&l?.top===s&&this.dispatch("ADD_MERGE",{sheetId:e,target:[{top:n,bottom:n+l.bottom-l.top,left:i,right:i+l.right-l.left}]})}drawLayer(e){if(!this.autofillZone)return;const{ctx:t,thinLineWidth:o}=e,{x:s,y:i,width:n,height:r}=this.getters.getVisibleRect(this.autofillZone);n>0&&r>0&&(t.strokeStyle="black",t.lineWidth=o,t.setLineDash([3]),t.strokeRect(s,i,n,r),t.setLineDash([]))}}).add("sort",class extends tu{allowDispatch(e){return"SORT_CELLS"===e.type?es(e.col,e.row,e.zone)?this.checkValidations(e,this.checkMerge,this.checkMergeSizes,this.checkArrayFormulaInSortZone):"InvalidSortAnchor":"Success"}handle(e){if("SORT_CELLS"===e.type)this.sortZone(e.sheetId,e,e.zone,e.sortDirection,e.sortOptions||{})}checkMerge({sheetId:e,zone:t}){if(!this.getters.doesIntersectMerge(e,t))return"Success";return is(t).some((({col:t,row:o})=>!this.getters.isInMerge({sheetId:e,col:t,row:o})))?"InvalidSortZone":"Success"}checkMergeSizes({sheetId:e,zone:t}){if(!this.getters.doesIntersectMerge(e,t))return"Success";const o=this.getters.getMerges(e).filter((e=>Qo(e,t))),s=os(o[0]),[i,n]=[s.numberOfCols,s.numberOfRows];return o.every((e=>{const[t,o]=[e.right-e.left+1,e.bottom-e.top+1];return t===i&&o===n}))?"Success":"InvalidSortZone"}checkArrayFormulaInSortZone({sheetId:e,zone:t}){return is(t).some((({col:t,row:o})=>{const s=this.getters.getArrayFormulaSpreadingOn({sheetId:e,col:t,row:o});return s&&!zt(s,{sheetId:e,col:t,row:o})}))?"SortZoneWithArrayFormulas":"Success"}hasHeader(e,t){if(1===t[0].length)return!1;let o=t.map((t=>t.map((({col:t,row:o})=>this.getters.getEvaluatedCell({sheetId:e,col:t,row:o}).type))));return o[0][0]===r.empty&&(o=o.slice(1)),!o.some((e=>e[0]===r.empty))&&!!o.some((e=>e[1]!==r.empty&&e[0]!==e[1]))}sortZone(e,t,o,s,i){const[n,a]=this.mainCellsSteps(e,o),l=this.getters.getMainCellPosition({sheetId:e,col:t.col,row:t.row}).col,c=Object.assign({},o);let h=this.mainCells(e,o);!i.sortHeaders&&this.hasHeader(e,h)&&(c.top+=a),h=this.mainCells(e,c);const d=function(e,t,o){const s=e.map(((e,t)=>({index:t,type:e.type,value:e.value})));return(o?s.map((e=>e.type===r.empty?{...e,type:r.number,value:0}:e)):s).sort(mf(t))}(h[l-c.left].map((e=>this.getters.getEvaluatedCell(e))),s,Boolean(i.emptyCellAsZero)),u=d.map((e=>e.index)),[g,p]=[h.length,h[0].length],m=[];for(let e=0;e<g;e++)for(let t=0;t<p;t++){const{col:o,row:s,sheetId:i}=h[e][u[t]],r=this.getters.getCell({sheetId:i,col:o,row:s}),l=c.left+e*n,d=c.top+t*a,g={sheetId:i,col:l,row:d,content:""};if(r){let e=r.content;if(r.isFormula){const t=this.getters.getCellPosition(r.id);e=this.getters.getTranslatedCellFormula(i,0,d-t.row,r.compiledFormula.tokens)}g.style=r.style,g.content=e,g.format=r.format}m.push(g)}m.forEach((e=>this.dispatch("UPDATE_CELL",e)))}mainCellsSteps(e,t){const o=this.getters.getMerge({sheetId:e,col:t.left,row:t.top});return[o?o.right-o.left+1:1,o?o.bottom-o.top+1:1]}mainCells(e,t){const[o,s]=this.mainCellsSteps(e,t),i=[],n=Ct(t.left,t.right+1,o),r=Ct(t.top,t.bottom+1,s);for(const t of n){const o=[];i.push(o);for(const s of r)o.push({sheetId:e,col:t,row:s})}return i}}).add("automatic_sum",class extends tu{static getters=["getAutomaticSums"];handle(e){if("SUM_SELECTION"===e.type){const e=this.getters.getActiveSheetId(),{zones:t,anchor:o}=this.getters.getSelection();for(const s of t){const t=this.getAutomaticSums(e,s,o.cell);this.dispatchCellUpdates(e,t)}}}getAutomaticSums(e,t,o){return this.shouldFindData(e,t)?this.sumAdjacentData(e,t,o):this.sumData(e,t)}sumData(e,t){const o=this.dimensionsToSum(e,t),s=this.sumDimensions(e,t,o).filter((({zone:t})=>!this.getters.isEmpty(e,t)));return o.has("ROW")&&o.has("COL")&&s.push(this.sumTotal(t)),s}sumAdjacentData(e,t,o){const{col:s,row:i}=es(o.col,o.row,t)?o:{col:t.left,row:t.top},n=this.findAdjacentData(e,s,i);return n?this.getters.isSingleCellOrMerge(e,t)||ss(Yo(n,t))?[{position:{col:s,row:i},zone:n}]:this.sumDimensions(e,Yo(n,t),this.transpose(this.dimensionsToSum(e,t))):[]}findAdjacentData(e,t,o){const s=this.getters.getSheet(e),i=this.getters.getMainCellPosition({sheetId:e,col:t,row:o}),n=this.findSuitableZoneToSum(s,i.col,i.row);if(n)return this.getters.expandZone(e,n)}findSuitableZoneToSum(e,t,o){const s=this.getters.getEvaluatedCell({sheetId:e.id,col:t,row:o-1}),i=this.getters.getEvaluatedCell({sheetId:e.id,col:t-1,row:o});if(this.isNumber(i)&&!this.isNumber(s))return this.findHorizontalZone(e,t,o);const n=this.findVerticalZone(e,t,o);if(this.isZoneValid(n))return n;const r=this.findHorizontalZone(e,t,o);return this.isZoneValid(r)?r:void 0}findVerticalZone(e,t,o){const s={top:0,bottom:o-1,left:t,right:t},i=this.reduceZoneStart(e,s,s.bottom);return{...s,top:i}}findHorizontalZone(e,t,o){const s={top:o,bottom:o,left:0,right:t-1},i=this.reduceZoneStart(e,s,s.right);return{...s,left:i}}reduceZoneStart(e,t,o){const s=this.getters.getEvaluatedCellsInZone(e.id,t),i=Ct(o,-1,-1),n=no(i.filter((e=>s[e]&&!s[e].isAutoSummable))),r=yt(i.filter((e=>this.isNumber(s[e]))))[0]||[];return no(r)<n?1/0:ro(r)}shouldFindData(e,t){return this.getters.isEmpty(e,t)||this.getters.isSingleCellOrMerge(e,t)}isNumber(e){return e.type===r.number&&!(e.format&&Mr(e.format))}isZoneValid(e){return e.bottom>=e.top&&e.right>=e.left}lastColIsEmpty(e,t){return this.getters.isEmpty(e,{...t,left:t.right})}lastRowIsEmpty(e,t){return this.getters.isEmpty(e,{...t,top:t.bottom})}dimensionsToSum(e,t){const o=new Set;return ss(t)?(o.add(1===os(t).numberOfCols?"COL":"ROW"),o):(this.lastColIsEmpty(e,t)&&o.add("ROW"),this.lastRowIsEmpty(e,t)&&o.add("COL"),0===o.size&&o.add("COL"),o)}sumDimensions(e,t,o){return[...o.has("COL")?this.sumColumns(t,e):[],...o.has("ROW")?this.sumRows(t,e):[]]}sumTotal(e){const{bottom:t,right:o}=e;return{position:{col:o,row:t},zone:{...e,top:t,right:o-1}}}sumColumns(e,t){const o=this.nextEmptyRow(t,{...e,bottom:e.bottom-1});return e={...e,bottom:Math.min(e.bottom,o.bottom-1)},is(o).map((t=>({position:t,zone:{...e,right:t.col,left:t.col}})))}sumRows(e,t){const o=this.nextEmptyCol(t,{...e,right:e.right-1});return e={...e,right:Math.min(e.right,o.right-1)},is(o).map((t=>({position:t,zone:{...e,top:t.row,bottom:t.row}})))}dispatchCellUpdates(e,t){for(const o of t){const{col:t,row:s}=o.position;this.dispatch("UPDATE_CELL",{sheetId:e,col:t,row:s,content:`=SUM(${this.getters.zoneToXC(e,o.zone)})`})}}nextEmptyRow(e,t){let o=t.bottom+1;const{left:s,right:i}=t;for(;!this.getters.isEmpty(e,{bottom:o,top:o,left:s,right:i});)o++;return{...t,top:o,bottom:o}}nextEmptyCol(e,t){let o=t.right+1;const{top:s,bottom:i}=t;for(;!this.getters.isEmpty(e,{left:o,right:o,top:s,bottom:i});)o++;return{...t,left:o,right:o}}transpose(e){return new Set([...e.values()].map((e=>"COL"===e?"ROW":"COL")))}}).add("format",class extends tu{handle(e){switch(e.type){case"SET_DECIMAL":this.setDecimal(e.sheetId,e.target,e.step);break;case"SET_FORMATTING_WITH_PIVOT":this.setContextualFormat(e.sheetId,e.target,e.format)}}setContextualFormat(e,t,o){const s=[],i={};for(const o of Fo(t))for(let t=o.left;t<=o.right;t++)for(let n=o.top;n<=o.bottom;n++){const o={sheetId:e,col:t,row:n},r=this.getters.getPivotCellFromPosition(o);if(this.isSpilledPivotValueFormula(o,r)){s.push(o);const e=this.getters.getPivotIdFromPosition(o)||"";i[e]??=new Set,i[e].add(r.measure)}}const n=Fo(s.map(cs));for(const e in i){const t=i[e],s=this.getters.getPivotCoreDefinition(e);this.dispatch("UPDATE_PIVOT",{pivotId:e,pivot:{...s,measures:s.measures.map((e=>t.has(e.id)?{...e,format:o}:e))}})}this.dispatch("SET_FORMATTING",{sheetId:e,target:n,format:""}),this.dispatch("SET_FORMATTING",{sheetId:e,target:Fo(t,n),format:o})}isSpilledPivotValueFormula(e,t){const o=this.getters.getCell(e);return"VALUE"===t.type&&!o?.isFormula}setDecimal(e,t,o){const s={};for(const i of Fo(t))for(const t of is(i)){const i=this.getCellNumberFormat({sheetId:e,...t});if(void 0!==i){const e=Yr(i,o);s[e]=s[e]||[],s[e].push(t)}}for(const t in s){const o=Fo(s[t].map((e=>cs(e))));this.setContextualFormat(e,o,t)}}getCellNumberFormat(e){for(const t of[e]){const e=this.getters.getEvaluatedCell(t);if(!(e.type!==r.number||e.format&&Mr(e.format)))return e.format||Lr(e.value)}}}).add("insert_pivot",class extends tu{static getters=[];allowDispatch(e){if("DUPLICATE_PIVOT_IN_NEW_SHEET"===e.type){if(!this.getters.isExistingPivot(e.pivotId))return"PivotIdNotFound";if(!this.getters.getPivot(e.pivotId).isValid())return"PivotInError"}return"Success"}handle(e){switch(e.type){case"INSERT_NEW_PIVOT":this.insertNewPivot(e.pivotId,e.newSheetId);break;case"DUPLICATE_PIVOT_IN_NEW_SHEET":this.duplicatePivotInNewSheet(e.pivotId,e.newPivotId,e.newSheetId);break;case"INSERT_PIVOT_WITH_TABLE":this.insertPivotWithTable(e.sheetId,e.col,e.row,e.pivotId,e.table,e.pivotMode);break;case"SPLIT_PIVOT_FORMULA":this.splitPivotFormula(e.sheetId,e.col,e.row,e.pivotId)}}insertNewPivot(e,t){1===gs(this.getters.getSelectedZone())&&this.selection.selectTableAroundSelection();const o=this.getters.getActiveSheetId();this.dispatch("ADD_PIVOT",{pivotId:e,pivot:{dataSet:{zone:this.getters.getSelectedZone(),sheetId:o},columns:[],rows:[],measures:[],name:ui("New pivot"),type:"SPREADSHEET"}});const s=this.getters.getSheetIds().findIndex((e=>e===o))+1,i=this.getters.getPivotFormulaId(e);this.dispatch("CREATE_SHEET",{sheetId:t,name:ui("Pivot #%(formulaId)s",{formulaId:i}),position:s}),this.dispatch("ACTIVATE_SHEET",{sheetIdFrom:o,sheetIdTo:t});const n=this.getters.getPivot(e);this.insertPivotWithTable(t,0,0,e,n.getCollapsedTableStructure().export(),"dynamic")}duplicatePivotInNewSheet(e,t,o){this.dispatch("DUPLICATE_PIVOT",{pivotId:e,newPivotId:t,duplicatedPivotName:ui("%s (copy)",this.getters.getPivotCoreDefinition(e).name)});const s=this.getters.getActiveSheetId(),i=this.getters.getSheetIds().indexOf(s)+1,n=this.getters.getPivotFormulaId(t),r=this.getters.getPivotName(t);if(this.dispatch("CREATE_SHEET",{sheetId:o,name:this.getPivotDuplicateSheetName(ui("%(newPivotName)s (Pivot #%(formulaId)s)",{newPivotName:r,formulaId:n})),position:i}).isSuccessful){this.dispatch("ACTIVATE_SHEET",{sheetIdFrom:s,sheetIdTo:o});const i=this.getters.getPivot(e);this.insertPivotWithTable(o,0,0,t,i.getCollapsedTableStructure().export(),"dynamic")}}getPivotDuplicateSheetName(e){const t=this.getters.getSheetIds().map((e=>this.getters.getSheetName(e)));return ho(bt(e),t)}insertPivotWithTable(e,t,o,s,i,n){const{cols:r,rows:a,measures:l,fieldsType:c}=i,h=new cP(r,a,l,c||{}),d=h.columns.length-1;this.resizeSheet(e,t,o,h);const u=this.getters.getPivotFormulaId(s);let g;"dynamic"===n?(this.dispatch("UPDATE_CELL",{sheetId:e,col:t,row:o,content:`=PIVOT(${u})`}),g={left:t,right:t,top:o,bottom:o}):(this.dispatch("INSERT_PIVOT",{sheetId:e,col:t,row:o,pivotId:s,table:h.export()}),g={left:t,right:t+h.getNumberOfDataColumns(),top:o,bottom:o+d+h.rows.length}),this.dispatch("CREATE_TABLE",{tableType:n,sheetId:e,ranges:[this.getters.getRangeDataFromZone(e,g)],config:{...it,numberOfHeaders:d}})}resizeSheet(e,t,o,s){const i=s.getNumberOfDataColumns()+1,n=this.getters.getNumberCols(e),r=n-t;r<i&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"COL",base:n-1,sheetId:e,sheetName:this.getters.getSheetName(e),quantity:i-r,position:"after"});const a=s.columns.length+s.rows.length,l=this.getters.getNumberRows(e),c=l-o;c<a&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"ROW",base:l-1,sheetId:e,sheetName:this.getters.getSheetName(e),quantity:a-c,position:"after"})}splitPivotFormula(e,t,o,s){const i=this.getters.getSpreadZone({sheetId:e,col:t,row:o});if(!i)return;const n=this.getters.getPivotFormulaId(s),r=new Map;for(let t=i.left;t<=i.right;t++)for(let o=i.top;o<=i.bottom;o++){const s={sheetId:e,col:t,row:o};r.set(s,this.getters.getPivotCellFromPosition(s))}for(const[e,t]of r)this.dispatch("UPDATE_CELL",{...e,content:nh(n,t)});const a=this.getters.getCoreTable({sheetId:e,col:t,row:o});if("dynamic"===a?.type){const s=cs({col:t,row:o}),n=this.getters.getRangeDataFromZone(e,i);this.dispatch("UPDATE_TABLE",{sheetId:e,zone:s,newTableRange:n,tableType:"static"})}}}).add("pivot_presence",class extends tu{static getters=["getPivotPresenceTracker"];trackPresencePivotId;tracker;handle(e){switch(e.type){case"PIVOT_START_PRESENCE_TRACKING":this.tracker=new tH,this.trackPresencePivotId=e.pivotId;break;case"PIVOT_STOP_PRESENCE_TRACKING":this.trackPresencePivotId=void 0}}getPivotPresenceTracker(e){if(this.trackPresencePivotId===e){if(!this.tracker)throw new Error("Tracker not initialized");return this.tracker}}}).add("split_to_columns",class extends tu{static getters=["getAutomaticSeparator"];allowDispatch(e){return"SPLIT_TEXT_INTO_COLUMNS"===e.type?this.chainValidations(this.batchValidations(this.checkSingleColSelected,this.checkNonEmptySelector),this.batchValidations(this.checkNotOverwritingContent,this.checkSeparatorInSelection))(e):"Success"}handle(e){if("SPLIT_TEXT_INTO_COLUMNS"===e.type)this.splitIntoColumns(e)}getAutomaticSeparator(){const e=this.getters.getSelectedCells();for(const t of e)if(t.value&&t.type===r.text){const e=this.getAutoSeparatorForString(t.value);if(e)return e}return" "}getAutoSeparatorForString(e){const t=[ot,";",","," ","."];for(const o of t)if(e.includes(o))return o}splitIntoColumns({separator:e,addNewColumns:t}){const o=this.getters.getSelectedZone(),s=this.getters.getActiveSheetId(),i=this.getSplittedCols(o,e);t&&this.addColsToAvoidCollisions(o,i),this.removeMergesInSplitZone(o,i),this.addColumnsToNotOverflowSheet(o,i);for(let e=0;e<i.length;e++){const t=o.top+e,n=i[e],r=o.left,a=this.getters.getCell({sheetId:s,col:r,row:t});if(1!==n.length||n[0]!==a?.content)for(const[e,o]of n.entries())this.dispatch("UPDATE_CELL",{sheetId:s,col:r+e,row:t,content:Bl(o,this.getters.getLocale()),format:"",style:a?.style||null})}}getSplittedCols(e,t){if(!t)throw new Error("Separator cannot be empty");const o=this.getters.getActiveSheetId(),s=[];for(const i of Ct(e.top,e.bottom+1)){const n=this.getters.getEvaluatedCell({sheetId:o,col:e.left,row:i}).formattedValue;s.push(this.splitAndRemoveTrailingEmpty(n,t))}return s}splitAndRemoveTrailingEmpty(e,t){const o=e.split(t);for(;o.length>1&&""===o[o.length-1];)o.pop();return o}willSplittedColsOverwriteContent(e,t){const o=this.getters.getActiveSheetId();for(const s of Ct(e.top,e.bottom+1)){const i=t[s-e.top];for(let t=1;t<i.length;t++){const i=this.getters.getCell({sheetId:o,col:e.left+t,row:s});if(i&&i.content)return!0}}return!1}removeMergesInSplitZone(e,t){const o=this.getters.getActiveSheetId(),s=Math.max(...t.map((e=>e.length))),i={...e,right:e.left+s-1},n=this.getters.getMergesInZone(o,i);this.dispatch("REMOVE_MERGE",{sheetId:o,target:n})}addColsToAvoidCollisions(e,t){const o=this.getters.getActiveSheetId();let s=0;for(const i of Ct(e.top,e.bottom+1)){const n={sheetId:o,col:e.left,row:i},r=t[i-e.top],a=this.getColsToAddToAvoidCollision(n,r);s=Math.max(s,a)}s&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"COL",base:e.left,sheetId:o,sheetName:this.getters.getSheetName(o),quantity:s,position:"after"})}getColsToAddToAvoidCollision(e,t){const o=t.length;for(let t=1;t<o;t++){const s=e.col+t,i=this.getters.getCell({...e,col:s});if(i&&i.content)return o-t}return 0}addColumnsToNotOverflowSheet(e,t){const o=this.getters.getActiveSheetId(),s=Math.max(...t.map((e=>e.length-1))),i=this.getters.getNumberCols(o)-1;e.left+s>i&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"COL",base:i,sheetId:o,sheetName:this.getters.getSheetName(o),quantity:e.left+s-i,position:"after"})}checkSingleColSelected(){return this.getters.isSingleColSelected()?"Success":"MoreThanOneColumnSelected"}checkNonEmptySelector(e){return""===e.separator?"EmptySplitSeparator":"Success"}checkNotOverwritingContent(e){if(e.addNewColumns||e.force)return"Success";const t=this.getters.getSelectedZones()[0],o=this.getSplittedCols(t,e.separator);return this.willSplittedColsOverwriteContent(t,o)?"SplitWillOverwriteContent":"Success"}checkSeparatorInSelection({separator:e}){const t=this.getters.getSelectedCells();for(const o of t)if(o.formattedValue.includes(e))return"Success";return"NoSplitSeparatorInSelection"}}).add("subtotal_evaluation",class extends tu{subtotalCells=new Set;handle(e){switch(e.type){case"START":this.subtotalCells.clear();for(const e of this.getters.getSheetIds()){const t=this.getters.getCells(e);for(const e in t){const o=t[e];ou(o)&&this.subtotalCells.add(o.id)}}break;case"UPDATE_CELL":{if(!("content"in e))return;const t=this.getters.getCell(e);if(!t)return;ou(t)?this.subtotalCells.add(t.id):this.subtotalCells.delete(t.id);break}}g.has(e.type)&&this.dispatch("EVALUATE_CELLS",{cellIds:Array.from(this.subtotalCells)})}}).add("collaborative",class extends tu{static getters=["getClientsToDisplay","getClient","getCurrentClient","getConnectedClients","isFullySynchronized"];static layers=["Selection"];colors=new si(12);session;constructor(e){super(e),this.session=e.session}isPositionValid(e){return e.row<this.getters.getNumberRows(e.sheetId)&&e.col<this.getters.getNumberCols(e.sheetId)}getClient(e){return this.session.getClient(e)}getCurrentClient(){return this.session.getCurrentClient()}getConnectedClients(){return[...this.session.getConnectedClients()].map((e=>({...e,color:this.colors.get(e.id)})))}isFullySynchronized(){return this.session.isFullySynchronized()}getClientsToDisplay(){try{this.getters.getCurrentClient()}catch(e){if(e instanceof VU)return[];throw e}const e=this.getters.getActiveSheetId(),t=[];for(const o of this.getters.getConnectedClients())o.id!==this.getters.getCurrentClient().id&&o.position&&o.position.sheetId===e&&this.isPositionValid(o.position)&&t.push({...o,position:o.position});return t}drawLayer(e){if(this.getters.isDashboard())return;const{ctx:t,thinLineWidth:o}=e,s=this.getters.getActiveSheetId();for(const e of this.getClientsToDisplay()){const{row:i,col:n}=e.position,r=this.getters.expandZone(s,{top:i,bottom:i,left:n,right:n}),{x:a,y:l,width:c,height:h}=this.getters.getVisibleRect(r);if(c<=0||h<=0)continue;const d=e.color;t.fillStyle=`${d}10`,t.lineWidth=4*o,t.strokeStyle=d,t.globalCompositeOperation="multiply",t.fillRect(a,l,c,h),t.globalCompositeOperation="source-over",t.strokeRect(a,l,c,h),t.font=`bold ${ke+1}px ${Le}`}}}).add("history",class extends tu{static getters=["canUndo","canRedo"];undoStack=[];redoStack=[];session;constructor(e){super(e),this.session=e.session,this.session.on("new-local-state-update",this,this.onNewLocalStateUpdate),this.session.on("snapshot",this,(()=>{this.undoStack=[],this.redoStack=[]}))}allowDispatch(e){switch(e.type){case"REQUEST_UNDO":if(!this.canUndo())return"EmptyUndoStack";break;case"REQUEST_REDO":if(!this.canRedo())return"EmptyRedoStack"}return"Success"}handle(e){switch(e.type){case"REQUEST_UNDO":case"REQUEST_REDO":this.requestHistoryChange("REQUEST_UNDO"===e.type?"UNDO":"REDO")}}finalize(){}requestHistoryChange(e){const t="UNDO"===e?this.undoStack.pop():this.redoStack.pop();if(t)"UNDO"===e?(this.session.undo(t),this.redoStack.push(t)):(this.session.redo(t),this.undoStack.push(t));else{const e=this.getPossibleRevisionToRepeat();if(!e)return;const t=eH(e,this.getters);if(!t)return;if(!Array.isArray(t))return void this.dispatch(t.type,t);for(const e of t)this.dispatch(e.type,e)}}canUndo(){return this.undoStack.length>0}canRedo(){if(this.redoStack.length>0)return!0;const e=this.getPossibleRevisionToRepeat();return!(!(t=e)||!t.rootCommand||"object"!=typeof t.rootCommand)&&(f(t.rootCommand)?KU.contains(t.rootCommand.type):JU.contains(t.rootCommand.type));var t}onNewLocalStateUpdate({id:e}){this.undoStack.push(e),this.redoStack=[],this.undoStack.length>99&&this.undoStack.shift()}getPossibleRevisionToRepeat(){return this.session.getLastLocalNonEmptyRevision()}}).add("data_cleanup",class extends tu{allowDispatch(e){return"REMOVE_DUPLICATES"===e.type?this.checkValidations(e,this.chainValidations(this.checkSingleRangeSelected,this.checkNoMergeInZone,this.checkRangeContainsValues,this.checkColumnsIncludedInZone),this.chainValidations(this.checkNoColumnProvided,this.checkColumnsAreUnique)):"Success"}handle(e){switch(e.type){case"REMOVE_DUPLICATES":this.removeDuplicates(e.columns,e.hasHeader);break;case"TRIM_WHITESPACE":this.trimWhitespace()}}removeDuplicates(e,t){const o=this.getters.getActiveSheetId(),s=this.getters.getSelectedZone();t&&(s.top+=1);const i=this.getUniqueRowsIndexes(o,s.top,s.bottom,e),n=i.length;if(n===os(s).numberOfRows)return void this.notifyRowsRemovedAndRemaining(0,n);const r=i.map((e=>({left:s.left,top:e,right:s.right,bottom:e}))),a=new Ch(this.getters,this.dispatch),l=a.copy(bs(o,r),!1);if(!l)return;this.dispatch("CLEAR_CELLS",{target:[s],sheetId:o});const c={left:s.left,top:s.top,right:s.left,bottom:s.top};a.paste({zones:[c],sheetId:o},l,{isCutOperation:!1});const h={left:s.left,top:s.top-(t?1:0),right:s.right,bottom:s.top+n-1};this.selection.selectZone({cell:{col:h.left,row:h.top},zone:h});const d=s.bottom-s.top+1-n;this.notifyRowsRemovedAndRemaining(d,n)}getUniqueRowsIndexes(e,t,o,s){const i=new Map;for(const n of Ct(t,o+1)){const t=s.map((t=>this.getters.getEvaluatedCell({sheetId:e,col:t,row:n}).value));!Object.values(i).some((e=>zt(e,t)))&&(i[n]=t)}return Object.keys(i).map((e=>parseInt(e)))}notifyRowsRemovedAndRemaining(e,t){this.ui.notifyUI({type:"info",text:ui("%s duplicate rows found and removed.\n%s unique rows remain.",e.toString(),t.toString()),sticky:!1})}checkSingleRangeSelected(){return 1!==this.getters.getSelectedZones().length?"MoreThanOneRangeSelected":"Success"}checkNoMergeInZone(){const e=this.getters.getActiveSheetId(),t=this.getters.getSelectedZone();return this.getters.getMergesInZone(e,t).length>0?"WillRemoveExistingMerge":"Success"}checkRangeContainsValues(e){const t=this.getters.getActiveSheetId(),o=this.getters.getSelectedZone();e.hasHeader&&(o.top+=1);return this.getters.getEvaluatedCellsInZone(t,o).every((e=>"empty"===e.type))?"EmptyTarget":"Success"}checkNoColumnProvided(e){return 0===e.columns.length?"NoColumnsProvided":"Success"}checkColumnsIncludedInZone(e){const t=this.getters.getSelectedZone();return e.columns.some((e=>e<t.left||e>t.right))?"ColumnsNotIncludedInZone":"Success"}checkColumnsAreUnique(e){return e.columns.length!==new Set(e.columns).size?"DuplicatesColumnsSelected":"Success"}trimWhitespace(){const e=Fo(this.getters.getSelectedZones()),t=this.getters.getActiveSheetId();let o=0;for(const{col:s,row:i}of e.map(is).flat()){const e=this.getters.getCell({col:s,row:i,sheetId:t});if(!e)continue;const n=oo(e.content);n!==e.content&&(o+=1,this.dispatch("UPDATE_CELL",{sheetId:t,col:s,row:i,content:n}))}const s=o?ui("Trimmed whitespace from %s cells.",o):ui("No selected cells had whitespace trimmed.");this.ui.notifyUI({type:"info",text:s,sticky:!1})}}).add("table_autofill",class extends tu{handle(e){if("AUTOFILL_TABLE_COLUMN"===e.type){const t=this.getters.getCoreTable(e),o=this.getters.getCell(e);if(!t?.config.automaticAutofill||"dynamic"===t.type||!o?.isFormula)return;const{col:s,row:i}=e,n=function(e,t){const o=t.numberOfHeaders,s={...e,top:e.top+o};return s.top<=s.bottom?s:void 0}(t.range.zone,t.config);if(n&&es(s,i,n)){const t=e.autofillRowStart??n.top,o=e.autofillRowEnd??n.bottom,s={...n,top:t,bottom:o};this.autofillTableZone(e,s)}}}autofillTableZone(e,t){if(t.top===t.bottom)return;const{col:o,row:s,sheetId:i}=e;for(let e=t.top;e<=t.bottom;e++)if(e!==s&&this.getters.getEvaluatedCell({col:o,row:e,sheetId:i}).type!==r.empty)return;const n={zone:this.getters.getSelectedZone(),cell:this.getters.getActivePosition()};this.selection.selectCell(o,s),this.dispatch("AUTOFILL_SELECT",{col:o,row:t.bottom}),this.dispatch("AUTOFILL"),this.selection.selectCell(o,s),this.dispatch("AUTOFILL_SELECT",{col:o,row:t.top}),this.dispatch("AUTOFILL"),this.selection.selectZone(n)}}).add("table_ui_resize",class extends tu{allowDispatch(e){if("RESIZE_TABLE"===e.type){const t=this.getters.getCoreTableMatchingTopLeft(e.sheetId,e.zone);if(!t)return"TableNotFound";const o=t.range.zone,s=this.getters.getRangeFromRangeData(e.newTableRange).zone;return s.top!==o.top||s.left!==o.left?"InvalidTableResize":this.canDispatch("UPDATE_TABLE",{...e}).reasons}return"Success"}handle(e){switch(e.type){case"RESIZE_TABLE":{const t=this.getters.getCoreTableMatchingTopLeft(e.sheetId,e.zone);if(this.dispatch("UPDATE_TABLE",{...e}),!t)return;const o=this.getters.getRangeFromRangeData(e.newTableRange).zone;if(this.selection.selectCell(o.right,o.bottom),!t.config.automaticAutofill)return;const s=t.range.zone;if(o.bottom>=s.bottom){for(let t=o.left;t<=o.right;t++){const i={col:t,row:s.bottom,sheetId:e.sheetId};this.getters.getCell(i)?.content.startsWith("=")&&this.dispatch("AUTOFILL_TABLE_COLUMN",{...i,autofillRowStart:s.bottom,autofillRowEnd:o.bottom})}break}}}}}).add("datavalidation_insert",class extends tu{handle(e){if("ADD_DATA_VALIDATION_RULE"===e.type)if("isBoolean"===e.rule.criterion.type){const t=e.ranges.map((e=>this.getters.getRangeFromRangeData(e)));for(const e of $a(t)){const t=this.getters.getCell(e),o=this.getters.getEvaluatedCell(e);if(t?.content)if(t?.content&&o.type===r.empty){let o;if(t.content.startsWith("=")){const s=this.getters.evaluateFormula(e.sheetId,t.content);o=(E(s)?s[0][0]:s)?.toString()}else o=t.content;o&&wt(o)||this.dispatch("UPDATE_CELL",{...e,content:"FALSE"})}else o.type!==r.boolean&&this.dispatch("UPDATE_CELL",{...e,content:"FALSE"});else this.dispatch("UPDATE_CELL",{...e,content:"FALSE"})}}}}).add("checkbox_toggle",class extends tu{static getters=["hasBooleanValidationInZones"];handle(e){if("TOGGLE_CHECKBOX"===e.type)this.toggleCheckbox(e.sheetId,e.target)}hasBooleanValidationInZones(e){const t=this.getters.getActiveSheetId();for(const o of e)for(let e=o.left;e<=o.right;e++)for(let s=o.top;s<=o.bottom;s++)if(this.getters.isCellValidCheckbox({col:e,row:s,sheetId:t}))return!0;return!1}toggleCheckbox(e,t){for(const o of t)for(let t=o.left;t<=o.right;t++)for(let s=o.top;s<=o.bottom;s++){const o={col:t,row:s,sheetId:e};if(this.getters.isCellValidCheckbox(o)){const e=this.getters.getEvaluatedCell(o).value?"FALSE":"TRUE";this.dispatch("UPDATE_CELL",{...o,content:e})}}}}).add("dynamic_translate",class extends tu{static getters=["dynamicTranslate"];dynamicTranslate(e){return e}}).add("geo_features",class extends tu{static getters=["getGeoJsonFeatures","geoFeatureNameToId","getGeoChartAvailableRegions"];geoJsonService;geoJsonCache={};constructor(e){super(e),this.geoJsonService=e.external.geoJsonService}getGeoChartAvailableRegions(){return this.geoJsonService?this.geoJsonService.getAvailableRegions()||[]:(console.error("No geoJsonService provided to the model"),[])}getGeoJsonFeatures(e){if(!this.geoJsonService)return void console.error("No geoJsonService provided to the model");const t=this.geoJsonCache[e];return t instanceof Promise?void 0:void 0!==t?t??void 0:void(this.geoJsonCache[e]=new Promise((async t=>{const o=await(this.geoJsonService?.getTopoJson(e));this.geoJsonCache[e]=this.convertToGeoJson(o),this.dispatch("EVALUATE_CHARTS"),t()})))}geoFeatureNameToId(e,t){if(this.geoJsonService)return this.geoJsonService.geoFeatureNameToId(e,t);console.error("No geoJsonService provided to the model")}convertToGeoJson(e){if(!e)return null;if("Topology"===e.type){const t=window.ChartGeo.topojson.feature(e,Object.values(e.objects)[0]);return"FeatureCollection"===t.type?t.features:[t]}if("FeatureCollection"===e.type)return e.features;throw new Error("Invalid TopoJSON")}}),aH=(new n).add("selection",class extends tu{static layers=["Selection"];static getters=["getActiveSheet","getActiveSheetId","getActiveSheetName","getActiveCell","getActiveCols","getActiveRows","getCurrentStyle","getSelectedZones","getSelectedZone","getSelectedCells","getSelectedFigureId","getSelection","getActivePosition","getSheetPosition","isSingleColSelected","getElementsFromSelection","tryGetActiveSheetId","isGridSelectionActive","getSelectecUnboundedZone"];gridSelection={anchor:{cell:{col:0,row:0},zone:{top:0,left:0,bottom:0,right:0}},zones:[{top:0,left:0,bottom:0,right:0}]};selectedFigureId=null;sheetsData={};moveClient;isUnbounded;activeSheet=null;constructor(e){super(e),this.moveClient=e.moveClient,this.isUnbounded=!1}allowDispatch(e){switch(e.type){case"ACTIVATE_SHEET":try{if(!this.getters.getSheet(e.sheetIdTo).isVisible)return"SheetIsHidden";break}catch(e){return"InvalidSheetId"}case"MOVE_COLUMNS_ROWS":return this.isMoveElementAllowed(e)}return"Success"}handleEvent(e){const t=e.anchor;let o=[];switch(this.isUnbounded=e.options?.unbounded||!1,e.mode){case"overrideSelection":o=[t.zone];break;case"updateAnchor":o=[...this.gridSelection.zones];const s=o.findIndex((t=>Ko(t,e.previousAnchor.zone)));s>=0&&(o[s]=t.zone);break;case"newAnchor":o=[...this.gridSelection.zones,t.zone]}this.setSelectionMixin(e.anchor,o),this.selection.resetDefaultAnchor(this,pt(this.gridSelection.anchor));const{col:s,row:i}=this.gridSelection.anchor.cell;this.moveClient({sheetId:this.getters.getActiveSheetId(),col:s,row:i}),this.selectedFigureId=null}handle(e){switch(e.type){case"ACTIVATE_SHEET":this.selectedFigureId=null;break;case"DELETE_FIGURE":this.selectedFigureId===e.figureId&&(this.selectedFigureId=null);break;case"DELETE_SHEET":this.selectedFigureId&&this.getters.getFigure(e.sheetId,this.selectedFigureId)&&(this.selectedFigureId=null)}switch(e.type){case"START":const t=this.getters.getVisibleSheetIds()[0];this.activateSheet(t,t);const{col:o,row:s}=this.getters.getNextVisibleCellPosition({sheetId:t,col:0,row:0});this.selectCell(o,s),this.selection.registerAsDefault(this,this.gridSelection.anchor,{handleEvent:this.handleEvent.bind(this)}),this.moveClient({sheetId:t,col:0,row:0});break;case"ACTIVATE_SHEET":this.activateSheet(e.sheetIdFrom,e.sheetIdTo);break;case"REMOVE_COLUMNS_ROWS":{const t=this.getters.getActiveSheetId();if(e.sheetId===t){"COL"===e.dimension?this.onColumnsRemoved(e):this.onRowsRemoved(e);const{col:o,row:s}=this.gridSelection.anchor.cell;this.moveClient({sheetId:t,col:o,row:s})}break}case"ADD_COLUMNS_ROWS":{const t=this.getters.getActiveSheetId();if(e.sheetId===t){this.onAddElements(e);const{col:o,row:s}=this.gridSelection.anchor.cell;this.moveClient({sheetId:t,col:o,row:s})}break}case"MOVE_COLUMNS_ROWS":e.sheetId===this.getActiveSheetId()&&this.onMoveElements(e);break;case"SELECT_FIGURE":this.selectedFigureId=e.figureId;break;case"ACTIVATE_NEXT_SHEET":this.activateNextSheet("right");break;case"ACTIVATE_PREVIOUS_SHEET":this.activateNextSheet("left");break;case"HIDE_SHEET":e.sheetId===this.getActiveSheetId()&&this.dispatch("ACTIVATE_SHEET",{sheetIdFrom:e.sheetId,sheetIdTo:this.getters.getVisibleSheetIds()[0]});break;case"UNDO":case"REDO":case"DELETE_SHEET":const i=Object.keys(this.sheetsData).filter((e=>!this.getters.tryGetSheet(e)));for(const e of i)delete this.sheetsData[e];for(const e in this.sheetsData){const t=this.clipSelection(e,this.sheetsData[e].gridSelection);this.sheetsData[e]={gridSelection:pt(t)}}this.fallbackToVisibleSheet();const n=this.getters.getActiveSheetId();this.gridSelection.zones=this.gridSelection.zones.map((e=>this.getters.expandZone(n,e))),this.gridSelection.anchor.zone=this.getters.expandZone(n,this.gridSelection.anchor.zone),this.setSelectionMixin(this.gridSelection.anchor,this.gridSelection.zones),this.selectedFigureId=null}}finalize(){this.fallbackToVisibleSheet(),this.selection.resetDefaultAnchor(this,pt(this.gridSelection.anchor))}isGridSelectionActive(){return this.selection.isListening(this)}getActiveSheet(){return this.activeSheet}getActiveSheetId(){return this.activeSheet.id}getActiveSheetName(){return this.activeSheet.name}tryGetActiveSheetId(){return this.activeSheet?.id}getActiveCell(){return this.getters.getEvaluatedCell(this.getActivePosition())}getActiveCols(){const e=new Set;for(const t of this.gridSelection.zones)if(0===t.top&&t.bottom===this.getters.getNumberRows(this.getters.getActiveSheetId())-1)for(let o=t.left;o<=t.right;o++)e.add(o);return e}getActiveRows(){const e=new Set,t=this.getters.getActiveSheetId();for(const o of this.gridSelection.zones)if(0===o.left&&o.right===this.getters.getNumberCols(t)-1)for(let t=o.top;t<=o.bottom;t++)e.add(t);return e}getCurrentStyle(){const e=this.getters.getSelectedZone(),t=this.getters.getActiveSheetId();return this.getters.getCellStyle({sheetId:t,col:e.left,row:e.top})}getSelectedZones(){return pt(this.gridSelection.zones)}getSelectedZone(){return pt(this.gridSelection.anchor.zone)}getSelectecUnboundedZone(){return pt(this.isUnbounded?this.getters.getUnboundedZone(this.activeSheet.id,this.gridSelection.anchor.zone):this.gridSelection.anchor.zone)}getSelection(){return pt(this.gridSelection)}getSelectedCells(){const e=this.getters.getActiveSheetId(),t=[];for(const o of this.gridSelection.zones)t.push(...this.getters.getEvaluatedCellsInZone(e,o));return t}getSelectedFigureId(){return this.selectedFigureId}getActivePosition(){return this.getters.getMainCellPosition({sheetId:this.getActiveSheetId(),col:this.gridSelection.anchor.cell.col,row:this.gridSelection.anchor.cell.row})}getSheetPosition(e){if(e===this.getters.getActiveSheetId())return this.getActivePosition();{const t=this.sheetsData[e];return t?{sheetId:e,col:t.gridSelection.anchor.cell.col,row:t.gridSelection.anchor.cell.row}:this.getters.getNextVisibleCellPosition({sheetId:e,col:0,row:0})}}isSingleColSelected(){const e=this.getters.getSelectedZones();return 1===e.length&&e[0].left===e[0].right}getElementsFromSelection(e){if("COL"===e&&0===this.getters.getActiveCols().size)return[];if("ROW"===e&&0===this.getters.getActiveRows().size)return[];const t=this.getters.getSelectedZones();let o=[];const s="COL"===e?"left":"top",i="COL"===e?"right":"bottom";for(const e of t){const t=Array.from({length:e[i]-e[s]+1},((t,o)=>e[s]+o));o=o.concat(t)}return[...new Set(o)].sort()}activateSheet(e,t){if(this.setActiveSheet(t),this.sheetsData[e]={gridSelection:pt(this.gridSelection)},t in this.sheetsData)Object.assign(this,this.sheetsData[t]),this.selection.resetDefaultAnchor(this,pt(this.gridSelection.anchor));else{const{col:e,row:o}=this.getters.getNextVisibleCellPosition({sheetId:t,col:0,row:0});this.selectCell(e,o)}const{col:o,row:s}=this.gridSelection.anchor.cell;this.moveClient({sheetId:this.activeSheet.id,col:o,row:s})}setSelectionMixin(e,t){const{anchor:o,zones:s}=this.clipSelection(this.getters.getActiveSheetId(),{anchor:e,zones:t});this.gridSelection.anchor=o,this.gridSelection.zones=function(e){return e.reverse().filter(((e,t,o)=>t===o.findIndex((t=>t.top===e.top&&t.bottom===e.bottom&&t.left===e.left&&t.right===e.right)))).reverse()}(s)}selectCell(e,t){const o=this.getters.getActiveSheetId(),s=this.getters.expandZone(o,{left:e,right:e,top:t,bottom:t});this.setSelectionMixin({zone:s,cell:{col:e,row:t}},[s])}setActiveSheet(e){this.activeSheet=this.getters.getSheet(e)}activateNextSheet(e){const t=this.getters.getSheetIds(),o=(t.findIndex((e=>e===this.activeSheet.id))+("left"===e?t.length-1:1))%t.length;this.dispatch("ACTIVATE_SHEET",{sheetIdFrom:this.getActiveSheetId(),sheetIdTo:t[o]})}onColumnsRemoved(e){const{cell:t,zone:o}=this.gridSelection.anchor,s=Zo(o,"left",[...e.elements]);let i={left:t.col,right:t.col,top:t.row,bottom:t.row};i=Zo(i,"left",[...e.elements]);const n={cell:{col:i.left,row:i.top},zone:s},r=this.gridSelection.zones.map((t=>Zo(t,"left",[...e.elements])));this.setSelectionMixin(n,r)}onRowsRemoved(e){const{cell:t,zone:o}=this.gridSelection.anchor,s=Zo(o,"top",[...e.elements]);let i={left:t.col,right:t.col,top:t.row,bottom:t.row};i=Zo(i,"top",[...e.elements]);const n={cell:{col:i.left,row:i.top},zone:s},r=this.gridSelection.zones.map((t=>Zo(t,"top",[...e.elements])));this.setSelectionMixin(n,r)}onAddElements(e){const t="COL"===e.dimension?"left":"top",o=qo(this.gridSelection.anchor.zone,t,e.base,e.position,e.quantity),s=this.gridSelection.zones.map((o=>qo(o,t,e.base,e.position,e.quantity))),i={cell:{col:o.left,row:o.top},zone:o};this.setSelectionMixin(i,s)}onMoveElements(e){const t=e.elements.length,o=this.getFiguresUpdates(e);this.dispatch("ADD_COLUMNS_ROWS",{dimension:e.dimension,sheetId:e.sheetId,sheetName:e.sheetName,base:e.base,quantity:t,position:e.position});const s="COL"===e.dimension,i=e.elements[0],n=e.elements[t-1],r=e.base<i,a=r&&s?t:0,l=r&&!s?t:0,c=r?e.elements.map((e=>e+t)):e.elements,h={};for(const t of c)h[t]=this.getters.getHeaderSize(e.sheetId,e.dimension,t);const d=[{left:s?i+a:0,right:s?n+a:this.getters.getNumberCols(e.sheetId)-1,top:s?0:i+l,bottom:s?this.getters.getNumberRows(e.sheetId)-1:n+l}],u=this.getActiveSheetId(),g=r?e.base:e.base+1,p=[{left:s?g:0,right:s?g+t-1:this.getters.getNumberCols(e.sheetId)-1,top:s?0:g,bottom:s?this.getters.getNumberRows(e.sheetId)-1:g+t-1}],m=yh.cellHandlers.getKeys().map((e=>[e,new(yh.cellHandlers.get(e))(this.getters,this.dispatch)])),f={};for(const[e,t]of m)f[e]=t.copy(bs(u,d),!1,"shiftCells");for(const[e,t]of m)f[e]&&t.paste({zones:p,sheetId:u},f[e],{isCutOperation:!0});const v=p[0],b=v.left,S=v.top;this.setSelectionMixin({zone:v,cell:{col:b,row:S}},[v]);let C=r?e.base:e.base+1;const y={};for(const t of c){const o=h[t];o!==this.getters.getHeaderSize(e.sheetId,e.dimension,C)&&(y[o]??=[],y[o].push(C)),C+=1}for(const t in y)this.dispatch("RESIZE_COLUMNS_ROWS",{dimension:e.dimension,sheetId:e.sheetId,size:parseInt(t,10),elements:y[t]});this.dispatch("REMOVE_COLUMNS_ROWS",{dimension:e.dimension,sheetId:e.sheetId,sheetName:e.sheetName,elements:c}),this.applyFigureUpdates(o)}getFiguresUpdates(e){const t=[],o={},s=e.elements[0]<e.base?e.base-e.elements.length+1:e.base;for(let t=0;t<e.elements.length;t++)o[e.elements[t]]=s+t;for(const s of this.getters.getFigures(e.sheetId))"COL"===e.dimension&&s.col in o&&t.push({type:"UPDATE_FIGURE",sheetId:e.sheetId,figureId:s.id,col:o[s.col],row:s.row}),"ROW"===e.dimension&&s.row in o&&t.push({type:"UPDATE_FIGURE",sheetId:e.sheetId,figureId:s.id,row:o[s.row],col:s.col});return t}applyFigureUpdates(e){for(const t of e)this.dispatch(t.type,{...t})}isMoveElementAllowed(e){const t="COL"===e.dimension,o=e.elements[0],s=e.elements[e.elements.length-1],i=e.sheetId,n=t?this.getters.doesColumnsHaveCommonMerges:this.getters.doesRowsHaveCommonMerges;if(n(i,o-1,o)||n(i,s,s+1)||n(i,e.base-1,e.base))return"WillRemoveExistingMerge";const r=[e.base,...e.elements],a=t?this.getters.getNumberCols(i):this.getters.getNumberRows(i);return r.some((e=>e<0||e>=a))?"InvalidHeaderIndex":t||this.isTableRowMoveAllowed(i,e.elements)?"Success":"CannotMoveTableHeader"}isTableRowMoveAllowed(e,t){const o=this.getters.getCoreTables(e);if(0===o.length)return!0;const s=new Set(t);return o.every((({range:{zone:e},config:o})=>{const{top:i,bottom:n}=e;if(0===o.numberOfHeaders)return!0;const r=i+o.numberOfHeaders-1;if(!t.some((e=>e>=i&&e<=r)))return!0;return Ct(i,n+1).every((e=>s.has(e)))}))}fallbackToVisibleSheet(){if(!this.getters.tryGetSheet(this.getters.getActiveSheetId())){const e=this.getters.getVisibleSheetIds();if(this.activeSheet=this.getters.getSheet(e[0]),this.activeSheet.id in this.sheetsData){const{anchor:e}=this.clipSelection(this.activeSheet.id,this.sheetsData[this.activeSheet.id].gridSelection);this.selectCell(e.cell.col,e.cell.row)}else this.selectCell(0,0);const{col:t,row:o}=this.gridSelection.anchor.cell;this.moveClient({sheetId:this.getters.getActiveSheetId(),col:t,row:o})}}clipSelection(e,t){const o=this.getters.getNumberCols(e)-1,s=this.getters.getNumberRows(e)-1;return{zones:t.zones.map((e=>({left:St(e.left,0,o),right:St(e.right,0,o),top:St(e.top,0,s),bottom:St(e.bottom,0,s)}))),anchor:{cell:{col:St(t.anchor.cell.col,0,o),row:St(t.anchor.cell.row,0,s)},zone:{left:St(t.anchor.zone.left,0,o),right:St(t.anchor.zone.right,0,o),top:St(t.anchor.zone.top,0,s),bottom:St(t.anchor.zone.bottom,0,s)}}}}drawLayer(e){if(this.getters.isDashboard())return;const{ctx:t,thinLineWidth:o}=e,s=this.getSelectedZones();t.fillStyle="#f3f7fe";const i=1===s.length&&s[0].left===s[0].right&&s[0].top===s[0].bottom;t.fillStyle=i?"#f3f7fe":"#e9f0ff",t.strokeStyle=N,t.lineWidth=1.5*o;for(const e of s){const{x:o,y:s,width:i,height:n}=this.getters.getVisibleRect(e);t.globalCompositeOperation="multiply",t.fillRect(o,s,i,n),t.globalCompositeOperation="source-over",t.strokeRect(o,s,i,n)}t.globalCompositeOperation="source-over";const n=this.getActivePosition();let r;t.strokeStyle=N,t.lineWidth=3*o,r=this.getters.isInMerge(n)?this.getters.getMerge(n):cs(n);const{x:a,y:l,width:c,height:h}=this.getters.getVisibleRect(r);c>0&&h>0&&t.strokeRect(a,l,c,h)}}).add("evaluation_filter",class extends tu{static getters=["getFilterValue","getFilterHiddenValues","getFilterCriterionValue","getFirstTableInSelection","isRowFiltered","isFilterActive"];filterValues={};hiddenRows={};isEvaluationDirty=!1;allowDispatch(e){if("UPDATE_FILTER"===e.type)if(!this.getters.getFilterId(e))return"FilterNotFound";return"Success"}handle(e){switch(e.type){case"UNDO":case"REDO":case"UPDATE_CELL":case"EVALUATE_CELLS":case"ACTIVATE_SHEET":case"REMOVE_TABLE":case"ADD_COLUMNS_ROWS":case"REMOVE_COLUMNS_ROWS":case"UPDATE_TABLE":this.isEvaluationDirty=!0;break;case"START":for(const e of this.getters.getSheetIds())this.filterValues[e]={};break;case"CREATE_SHEET":this.filterValues[e.sheetId]={};break;case"HIDE_COLUMNS_ROWS":case"UNHIDE_COLUMNS_ROWS":case"GROUP_HEADERS":case"UNGROUP_HEADERS":case"FOLD_HEADER_GROUP":case"UNFOLD_HEADER_GROUP":case"FOLD_ALL_HEADER_GROUPS":case"UNFOLD_ALL_HEADER_GROUPS":case"FOLD_HEADER_GROUPS_IN_ZONE":case"UNFOLD_HEADER_GROUPS_IN_ZONE":this.updateHiddenRows(e.sheetId);break;case"UPDATE_FILTER":this.updateFilter(e),this.updateHiddenRows(e.sheetId);break;case"DUPLICATE_SHEET":this.filterValues[e.sheetIdTo]=pt(this.filterValues[e.sheetId])}}finalize(){if(this.isEvaluationDirty){for(const e of this.getters.getSheetIds())this.updateHiddenRows(e);this.isEvaluationDirty=!1}}isRowFiltered(e,t){return!!this.hiddenRows[e]?.has(t)}getFilterValue(e){const t=this.getters.getFilterId(e),o=e.sheetId;return t?this.filterValues[o]?.[t]:void 0}getFilterHiddenValues(e){const t=this.getters.getFilterId(e),o=e.sheetId;if(!t||!this.filterValues[o])return[];const s=this.filterValues[o][t]||[];return"values"===s.filterType?s.hiddenValues:[]}getFilterCriterionValue(e){const t=this.getters.getFilterId(e),o=e.sheetId;if(!t||!this.filterValues[o])return sH;const s=this.filterValues[o][t];return s&&"criterion"===s.filterType?s:sH}isFilterActive(e){const t=this.getters.getFilterId(e);if(!t)return!1;const o=e.sheetId,s=this.filterValues[o]?.[t];return!!s&&("values"===s.filterType?s.hiddenValues.length>0:"none"!==s.type)}getFirstTableInSelection(){const e=this.getters.getActiveSheetId(),t=this.getters.getSelectedZones();return this.getters.getTablesOverlappingZones(e,t)[0]}updateFilter({col:e,row:t,value:o,sheetId:s}){const i=this.getters.getFilterId({sheetId:s,col:e,row:t});i&&(this.filterValues[s]||(this.filterValues[s]={}),this.filterValues[s][i]=o)}updateHiddenRows(e){const t=this.getters.getFilters(e).sort(((e,t)=>e.rangeWithHeaders.zone.top-t.rangeWithHeaders.zone.top)),o=new Set;for(const s of t){const t=this.filterValues[e]?.[s.id],i=s.filteredRange?.zone;if(t&&i&&!o.has(s.rangeWithHeaders.zone.top)&&!this.getters.isRowHiddenByUser(e,s.rangeWithHeaders.zone.top))if("values"===t.filterType){const n=t.hiddenValues?.map(pl);if(!n)continue;const r=new Set(n);for(let t=i.top;t<=i.bottom;t++){const i=this.getCellValueAsString(e,s.col,t);r.has(i)&&o.add(t)}}else{if("none"===t.type)continue;const n=sR.get(t.type),r=t.values.map((t=>t.startsWith("=")?this.getters.evaluateFormula(e,t)??"":ea(t,w)));if(r.some(bc))continue;const a={type:t.type,values:r.map(fc),dateValue:t.dateValue};for(let t=i.top;t<=i.bottom;t++){const i={sheetId:e,col:s.col,row:t},r=this.getters.getEvaluatedCell(i).value??"";n.isValueValid(r,a,this.getters,e)||o.add(t)}}}this.hiddenRows[e]=o}getCellValueAsString(e,t,o){return this.getters.getEvaluatedCell({sheetId:e,col:t,row:o}).formattedValue.toLowerCase()}exportForExcel(e){for(const t of e.sheets){const e=t.id;for(const o of t.tables){const s=Ho(o.range),i=[],n=[];for(const o of Ct(0,os(s).numberOfCols)){const r={sheetId:t.id,col:s.left+o,row:s.top},a=this.getFilterHiddenValues(r),l=this.getters.getFilter(r),c=l?.filteredRange?is(l.filteredRange.zone).map((t=>this.getters.getEvaluatedCell({sheetId:e,...t}).formattedValue)):[];if(a.length){const e=c.filter((e=>e)).filter((e=>!a.includes(e)));i.push({colId:o,displayedValues:[...new Set(e)],displayBlanks:!a.includes("")&&c.some((e=>!e))})}const h=this.getters.getEvaluatedCell(r).formattedValue,d=this.getUniqueColNameForExcel(o,h,n);n.push(d);const u=_o(r.col,r.row);t.cells[u]=d,t.cellValues[u]=d}o.filters=i}}}getUniqueColNameForExcel(e,t,o){return t||(t=`Column${e}`),ho(t,o,{compute:(e,o)=>t+String(o),start:2})}}).add("header_visibility_ui",class extends tu{static getters=["getNextVisibleCellPosition","findVisibleHeader","findLastVisibleColRowIndex","findFirstVisibleColRowIndex","isRowHidden","isColHidden","isHeaderHidden"];isRowHidden(e,t){return this.getters.isRowHiddenByUser(e,t)||this.getters.isRowFiltered(e,t)}isColHidden(e,t){return this.getters.isColHiddenByUser(e,t)}isHeaderHidden(e,t,o){return"COL"===t?this.isColHidden(e,o):this.isRowHidden(e,o)}getNextVisibleCellPosition({sheetId:e,col:t,row:o}){return{sheetId:e,col:this.findVisibleHeader(e,"COL",t,this.getters.getNumberCols(e)-1),row:this.findVisibleHeader(e,"ROW",o,this.getters.getNumberRows(e)-1)}}findVisibleHeader(e,t,o,s){if(o<=s)for(let i=o;i<=s;i++)if(this.getters.doesHeaderExist(e,t,i)&&!this.isHeaderHidden(e,t,i))return i;if(o>s)for(let i=o;i>=s;i--)if(this.getters.doesHeaderExist(e,t,i)&&!this.isHeaderHidden(e,t,i))return i}findLastVisibleColRowIndex(e,t,{last:o,first:s}){return Ct(o,s,-1).find((o=>!this.isHeaderHidden(e,t,o)))||s}findFirstVisibleColRowIndex(e,t){const o=this.getters.getNumberHeaders(e,t);for(let s=0;s<o;s++){if("COL"===t&&!this.isColHidden(e,s))return s;if("ROW"===t&&!this.isRowHidden(e,s))return s}}exportForExcel(e){for(const t of e.sheets)for(const[e,o]of Object.entries(t.rows))o.isHidden=this.isRowHidden(t.id,Number(e))}}).add("cell_computed_style",class extends tu{static getters=["getCellComputedBorder","getCellComputedStyle"];styles=new tF;borders=new tF;handle(e){if(l.has(e.type)||"UPDATE_CELL"===e.type||"SET_FORMATTING"===e.type||"ADD_DATA_VALIDATION_RULE"===e.type||"REMOVE_DATA_VALIDATION_RULE"===e.type||"EVALUATE_CELLS"===e.type)return this.styles=new tF,void(this.borders=new tF);zU(e)?"sheetId"in e?(this.styles.clearSheet(e.sheetId),this.borders.clearSheet(e.sheetId)):(this.styles=new tF,this.borders=new tF):d.has(e.type)?this.styles=new tF:u.has(e.type)&&(this.borders=new tF)}getCellComputedBorder(e,t){let o=this.borders.get(e);return void 0===o&&(this.precomputeCellBorders(e.sheetId,t??cs(e)),o=this.borders.get(e)),o??null}precomputeCellBorders(e,t){const o=this.getters.getCellBordersInZone(e,t),s=this.getters.getCellTableBorderZone(e,t);for(let i=t.left;i<=t.right;i++)for(let n=t.top;n<=t.bottom;n++){const t={sheetId:e,col:i,row:n};if(void 0!==this.borders.get(t))continue;const r=o.get(t),a={...Wt(s.get(t)),...Wt(r)};Nt(a)?this.borders.set(t,null):this.borders.set(t,a)}}getCellComputedStyle(e){let t=this.styles.get(e);return void 0===t&&(t=this.computeCellStyle(e),this.styles.set(e,t)),t}computeCellStyle(e){const t=this.getters.getCell(e),o=this.getters.getCellConditionalFormatStyle(e),s=this.getters.getCellTableStyle(e),i=this.getters.getDataValidationCellStyle(e),n={...Wt(s),...Wt(i),...Wt(t?.style),...Wt(o)};return this.getters.getEvaluatedCell(e).link&&!n.textColor&&(n.textColor=U),n}}).add("table_computed_style",class extends tu{static getters=["getCellTableStyle","getCellTableBorder","getCellTableBorderZone"];tableStyles={};handle(e){l.has(e.type)||"UPDATE_CELL"===e.type&&("content"in e||"format"in e)||"EVALUATE_CELLS"===e.type?this.tableStyles={}:zU(e)&&("sheetId"in e?delete this.tableStyles[e.sheetId]:this.tableStyles={})}finalize(){for(const e of this.getters.getSheetIds()){this.tableStyles[e]||(this.tableStyles[e]={});for(const t of this.getters.getTables(e))this.tableStyles[e][t.id]||(this.tableStyles[e][t.id]=this.computeTableStyle(e,t))}}getCellTableStyle(e){const t=this.getters.getTable(e);if(t)return this.tableStyles[e.sheetId][t.id]().styles[e.col]?.[e.row]}getCellTableBorder(e){const t=this.getters.getTable(e);if(t)return this.tableStyles[e.sheetId][t.id]().borders[e.col]?.[e.row]}getCellTableBorderZone(e,t){const o=new tF;for(const s of this.getters.getTablesOverlappingZones(e,[t])){const t=this.tableStyles[e][s.id]().borders;for(const[s,i]of Object.entries(t)){const t=parseInt(s);for(const[s,n]of Object.entries(i))n&&o.set({sheetId:e,col:t,row:parseInt(s)},n)}}return o}computeTableStyle(e,t){return Vt((()=>{const{config:o,numberOfCols:s,numberOfRows:i}=this.getTableRuntimeConfig(e,t),n=MF(o,this.getters.getTableStyle(t.config.styleId),s,i),r=this.getTableMapping(e,t),a={borders:{},styles:{}};for(let e=0;e<s;e++){const t=r.colMapping[e];a.borders[t]={},a.styles[t]={};for(let o=0;o<i;o++){const s=r.rowMapping[o];a.borders[t][s]=n.borders[e][o],a.styles[t][s]=n.styles[e][o]}}return a}))}getTableRuntimeConfig(e,t){const o=t.range.zone,s={...t.config};let i=o.right-o.left+1,n=o.bottom-o.top+1;for(let i=o.top;i<=o.bottom;i++)this.getters.isRowHidden(e,i)&&(n--,i-o.top<t.config.numberOfHeaders&&(s.numberOfHeaders--,s.numberOfHeaders<0&&(s.numberOfHeaders=0)),i===o.bottom&&(s.totalRow=!1));for(let t=o.left;t<=o.right;t++)this.getters.isColHidden(e,t)&&(i--,t===o.left&&(s.firstColumn=!1),t===o.right&&(s.lastColumn=!1));return{config:s,numberOfCols:i,numberOfRows:n}}getTableMapping(e,t){const o={},s={};let i=0,n=0;const r=t.range.zone;for(let t=r.left;t<=r.right;t++)if(!this.getters.isColHidden(e,t)){o[i]=t,i++;for(let t=r.top;t<=r.bottom;t++)this.getters.isRowHidden(e,t)||(s[n]=t,n++)}return{colMapping:o,rowMapping:s}}}).add("header_positions",class extends tu{static getters=["getColDimensions","getRowDimensions","getColRowOffset"];headerPositions={};isDirty=!0;handle(e){switch(l.has(e.type)&&(this.headerPositions={},this.isDirty=!0),e.type){case"START":for(const e of this.getters.getSheetIds())this.headerPositions[e]=this.computeHeaderPositionsOfSheet(e);break;case"UPDATE_CELL":case"UPDATE_FILTER":case"UPDATE_TABLE":case"REMOVE_TABLE":this.headerPositions={},this.isDirty=!0;break;case"REMOVE_COLUMNS_ROWS":case"RESIZE_COLUMNS_ROWS":case"HIDE_COLUMNS_ROWS":case"ADD_COLUMNS_ROWS":case"UNHIDE_COLUMNS_ROWS":case"FOLD_HEADER_GROUP":case"UNFOLD_HEADER_GROUP":case"FOLD_HEADER_GROUPS_IN_ZONE":case"UNFOLD_HEADER_GROUPS_IN_ZONE":case"UNFOLD_ALL_HEADER_GROUPS":case"FOLD_ALL_HEADER_GROUPS":case"UNGROUP_HEADERS":case"GROUP_HEADERS":case"CREATE_SHEET":this.getters.tryGetSheet(e.sheetId)&&(this.headerPositions[e.sheetId]=this.computeHeaderPositionsOfSheet(e.sheetId));break;case"DUPLICATE_SHEET":this.headerPositions[e.sheetIdTo]=pt(this.headerPositions[e.sheetId])}}finalize(){for(const e of this.getters.getSheetIds())!this.isDirty&&this.headerPositions[e]||(this.headerPositions[e]=this.computeHeaderPositionsOfSheet(e));this.isDirty=!1}getColDimensions(e,t){const o=this.headerPositions[e].COL[t],s=this.getters.getColSize(e,t);return{start:o,size:s,end:o+(this.getters.isColHidden(e,t)?0:s)}}getRowDimensions(e,t){const o=this.headerPositions[e].ROW[t],s=this.getters.getRowSize(e,t);return{start:o,size:s,end:o+(this.getters.isRowHidden(e,t)?0:s)}}getColRowOffset(e,t,o,s=this.getters.getActiveSheetId()){const i=this.headerPositions[s][e][t];return this.headerPositions[s][e][o]-i}computeHeaderPositionsOfSheet(e){return{COL:this.computePositions(e,"COL"),ROW:this.computePositions(e,"ROW")}}computePositions(e,t){const o={};let s=0;for(let i=0;i<this.getters.getNumberHeaders(e,t)+1;i++)o[i]=s,this.getters.isHeaderHidden(e,t,i)||(s+=this.getters.getHeaderSize(e,t,i));return o}}).add("viewport",class extends tu{static getters=["getColIndex","getRowIndex","getActiveMainViewport","getSheetViewDimension","getSheetViewDimensionWithHeaders","getMainViewportRect","isVisibleInViewport","getEdgeScrollCol","getEdgeScrollRow","getVisibleFigures","getVisibleRect","getVisibleRectWithoutHeaders","getVisibleCellPositions","getColRowOffsetInViewport","getMainViewportCoordinates","getActiveSheetScrollInfo","getSheetViewVisibleCols","getSheetViewVisibleRows","getFrozenSheetViewRatio","isPixelPositionVisible","getColDimensionsInViewport","getRowDimensionsInViewport","getAllActiveViewportsZonesAndRect","getRect","getFigureUI","getPositionAnchorOffset","getGridOffset"];viewports={};sheetViewWidth=tt();sheetViewHeight=tt();gridOffsetX=0;gridOffsetY=0;sheetsWithDirtyViewports=new Set;shouldAdjustViewports=!1;allowDispatch(e){switch(e.type){case"SET_VIEWPORT_OFFSET":return this.chainValidations(this.checkScrollingDirection,this.checkIfViewportsWillChange)(e);case"RESIZE_SHEETVIEW":return this.chainValidations(this.checkValuesAreDifferent,this.checkPositiveDimension)(e);default:return"Success"}}handleEvent(e){const t=this.getters.getActiveSheetId();if(e.options.scrollIntoView){let{col:o,row:s}=ls(e.previousAnchor.zone,e.anchor.zone);if("updateAnchor"===e.mode){const i=e.previousAnchor.zone,n=e.anchor.zone,{top:r,bottom:a,left:l,right:c}=this.getMainInternalViewport(t);i.left===n.left&&i.right===n.right&&(o=l>o||o>c?l:o),i.top===n.top&&i.bottom===n.bottom&&(s=r>s||s>a?r:s)}o=Math.min(o,this.getters.getNumberCols(t)-1),s=Math.min(s,this.getters.getNumberRows(t)-1),this.sheetsWithDirtyViewports.has(t)||this.refreshViewport(this.getters.getActiveSheetId(),{col:o,row:s})}}handle(e){if(l.has(e.type))for(const e of this.getters.getSheetIds())this.sheetsWithDirtyViewports.add(e);switch(e.type){case"START":this.selection.observe(this,{handleEvent:this.handleEvent.bind(this)}),this.resetViewports(this.getters.getActiveSheetId());break;case"UNDO":case"REDO":this.cleanViewports();for(const e of this.getters.getSheetIds())this.sheetsWithDirtyViewports.add(e);this.shouldAdjustViewports=!0;break;case"RESIZE_SHEETVIEW":this.resizeSheetView(e.height,e.width,e.gridOffsetX,e.gridOffsetY);break;case"SET_VIEWPORT_OFFSET":this.setSheetViewOffset(e.offsetX,e.offsetY);break;case"SHIFT_VIEWPORT_DOWN":const t=this.getters.getActiveSheetId(),{top:o,viewportHeight:s,offsetCorrectionY:i}=this.getMainInternalViewport(t),n=this.getters.getRowDimensions(t,o);this.shiftVertically(n.start+s-i);break;case"SHIFT_VIEWPORT_UP":{const e=this.getters.getActiveSheetId(),{top:t,viewportHeight:o,offsetCorrectionY:s}=this.getMainInternalViewport(e),i=this.getters.getRowDimensions(e,t);this.shiftVertically(i.end-s-o);break}case"REMOVE_TABLE":case"UPDATE_TABLE":case"UPDATE_FILTER":case"UNFREEZE_ROWS":case"UNFREEZE_COLUMNS":case"FREEZE_COLUMNS":case"FREEZE_ROWS":case"UNFREEZE_COLUMNS_ROWS":case"REMOVE_COLUMNS_ROWS":case"RESIZE_COLUMNS_ROWS":case"HIDE_COLUMNS_ROWS":case"ADD_COLUMNS_ROWS":case"UNHIDE_COLUMNS_ROWS":case"UNGROUP_HEADERS":case"GROUP_HEADERS":case"FOLD_HEADER_GROUP":case"UNFOLD_HEADER_GROUP":case"FOLD_HEADER_GROUPS_IN_ZONE":case"UNFOLD_HEADER_GROUPS_IN_ZONE":case"UNFOLD_ALL_HEADER_GROUPS":case"FOLD_ALL_HEADER_GROUPS":this.sheetsWithDirtyViewports.add(e.sheetId);break;case"UPDATE_CELL":if("content"in e||"format"in e||void 0!==e.style?.fontSize)for(const e of this.getters.getSheetIds())this.sheetsWithDirtyViewports.add(e);break;case"DELETE_SHEET":this.cleanViewports(),this.sheetsWithDirtyViewports.delete(e.sheetId);break;case"ACTIVATE_SHEET":this.sheetsWithDirtyViewports.add(e.sheetIdTo);break;case"SCROLL_TO_CELL":this.refreshViewport(this.getters.getActiveSheetId(),{col:e.col,row:e.row})}}finalize(){for(const e of this.sheetsWithDirtyViewports)if(this.resetViewports(e),this.shouldAdjustViewports){const t=this.getters.getSheetPosition(e);this.getSubViewports(e).forEach((e=>{e.adjustPosition(t)}))}this.sheetsWithDirtyViewports=new Set,this.shouldAdjustViewports=!1,this.setViewports()}setViewports(){const e=this.getters.getSheetIds();for(const t of e)this.viewports[t]?.bottomRight||this.resetViewports(t)}getColIndex(e){const t=this.getters.getActiveSheetId();return Math.max(...this.getSubViewports(t).map((t=>t.getColIndex(e))))}getRowIndex(e){const t=this.getters.getActiveSheetId();return Math.max(...this.getSubViewports(t).map((t=>t.getRowIndex(e))))}getSheetViewDimensionWithHeaders(){return{width:this.sheetViewWidth+this.gridOffsetX,height:this.sheetViewHeight+this.gridOffsetY}}getSheetViewDimension(){return{width:this.sheetViewWidth,height:this.sheetViewHeight}}getGridOffset(){return{x:this.gridOffsetX,y:this.gridOffsetY}}getActiveMainViewport(){const e=this.getters.getActiveSheetId();return this.getMainViewport(e)}getActiveSheetScrollInfo(){const e=this.getters.getActiveSheetId(),t=this.getMainInternalViewport(e);return{scrollX:t.offsetX,scrollY:t.offsetY}}getSheetViewVisibleCols(){const e=this.getters.getActiveSheetId(),t=this.getSubViewports(e);return[...new Set(t.map((e=>Ct(e.left,e.right+1))).flat())].filter((t=>t>=0&&!this.getters.isHeaderHidden(e,"COL",t)))}getSheetViewVisibleRows(){const e=this.getters.getActiveSheetId(),t=this.getSubViewports(e);return[...new Set(t.map((e=>Ct(e.top,e.bottom+1))).flat())].filter((t=>t>=0&&!this.getters.isHeaderHidden(e,"ROW",t)))}getVisibleCellPositions(){const e=this.getSheetViewVisibleCols(),t=this.getSheetViewVisibleRows(),o=this.getters.getActiveSheetId(),s=[];for(const i of e)for(const e of t){const t={sheetId:o,col:i,row:e},n=this.getters.getMainCellPosition(t);n.row===e&&n.col===i&&s.push(t)}return s}getMainViewportRect(){const e=this.getters.getActiveSheetId(),t=this.getMainInternalViewport(e),{xSplit:o,ySplit:s}=this.getters.getPaneDivisions(e),{width:i,height:n}=t.getMaxSize();return{x:this.getters.getColDimensions(e,o).start,y:this.getters.getRowDimensions(e,s).start,width:i,height:n}}getMaximumSheetOffset(){const e=this.getters.getActiveSheetId(),{width:t,height:o}=this.getMainViewportRect(),s=this.getMainInternalViewport(e);return{maxOffsetX:Math.max(0,t-s.viewportWidth),maxOffsetY:Math.max(0,o-s.viewportHeight)}}getColRowOffsetInViewport(e,t,o){if(o<t)return-this.getColRowOffsetInViewport(e,o,t);const s=this.getters.getActiveSheetId(),i="COL"===e?this.getters.getSheetViewVisibleCols():this.getters.getSheetViewVisibleRows(),n=i.findIndex((e=>t>=e));let r=i.findIndex((e=>o<=e));r=-1===r?i.length:r;const a=i.slice(n,r);let l=0;for(const t of a)l+=this.getters.getHeaderSize(s,e,t);return l}isVisibleInViewport({sheetId:e,col:t,row:o}){return this.getSubViewports(e).some((e=>e.isVisible(t,o)))}getEdgeScrollCol(e,t,o){let s=!1,i=0,n=0;const{xSplit:r}=this.getters.getPaneDivisions(this.getters.getActiveSheetId()),{width:a}=this.getSheetViewDimension(),{x:l}=this.getMainViewportCoordinates(),c=this.getActiveSheetScrollInfo().scrollX;return e>a?(s=!0,n=ma(e-a),i=1):e<l&&o>=l&&c>0?(s=!0,n=ma(l-e),i=-1):r&&t<l&&e>l&&(s=!0,n=ma(e),i="reset"),{canEdgeScroll:s,direction:i,delay:n}}getEdgeScrollRow(e,t,o){let s=!1,i=0,n=0;const{ySplit:r}=this.getters.getPaneDivisions(this.getters.getActiveSheetId()),{height:a}=this.getSheetViewDimension(),{y:l}=this.getMainViewportCoordinates(),c=this.getActiveSheetScrollInfo().scrollY;return e>a?(s=!0,n=ma(e-a),i=1):e<l&&o>=l&&c>0?(s=!0,n=ma(l-e),i=-1):r&&t<l&&e>l&&(s=!0,n=ma(e),i="reset"),{canEdgeScroll:s,direction:i,delay:n}}getVisibleRect(e){const t=this.getVisibleRectWithoutHeaders(e);return{...t,x:t.x+this.gridOffsetX,y:t.y+this.gridOffsetY}}getVisibleRectWithoutHeaders(e){const t=this.getters.getActiveSheetId();return this.mapViewportsToRect(t,(t=>t.getVisibleRect(e)))}getRect(e){const t=this.getters.getActiveSheetId(),o=this.mapViewportsToRect(t,(t=>t.getFullRect(e)));return{...o,x:o.x+this.gridOffsetX,y:o.y+this.gridOffsetY}}getRectWithoutHeaders(e){const t=this.getters.getActiveSheetId();return this.mapViewportsToRect(t,(t=>t.getFullRect(e)))}getMainViewportCoordinates(){const e=this.getters.getActiveSheetId(),{xSplit:t,ySplit:o}=this.getters.getPaneDivisions(e);return{x:this.getters.getColDimensions(e,t).start,y:this.getters.getRowDimensions(e,o).start}}getColDimensionsInViewport(e,t){const{top:o}=this.getMainInternalViewport(e),s={left:t,right:t,top:o,bottom:o},{x:i,width:n}=this.getVisibleRect(s),r=i-this.gridOffsetX;return{start:r,size:n,end:r+n}}getRowDimensionsInViewport(e,t){const{left:o}=this.getMainInternalViewport(e),s={left:0,right:o,top:t,bottom:t},{y:i,height:n}=this.getVisibleRect(s),r=i-this.gridOffsetY;return{start:r,size:n,end:r+n}}getAllActiveViewportsZonesAndRect(){const e=this.getters.getActiveSheetId();return this.getSubViewports(e).map((e=>({zone:e,rect:{x:e.offsetCorrectionX+this.gridOffsetX,y:e.offsetCorrectionY+this.gridOffsetY,...e.getMaxSize()}})))}ensureMainViewportExist(e){this.viewports[e]||this.resetViewports(e)}getSubViewports(e){return this.ensureMainViewportExist(e),Object.values(this.viewports[e]).filter(Mt)}checkPositiveDimension(e){return e.width<0||e.height<0?"InvalidViewportSize":"Success"}checkValuesAreDifferent(e){const{height:t,width:o}=this.getSheetViewDimension();return e.gridOffsetX===this.gridOffsetX&&e.gridOffsetY===this.gridOffsetY&&e.width===o&&e.height===t?"ValuesNotChanged":"Success"}checkScrollingDirection({offsetX:e,offsetY:t}){const o=this.getMainInternalViewport(this.getters.getActiveSheetId());return!o.canScrollHorizontally&&e>0||!o.canScrollVertically&&t>0?"InvalidScrollingDirection":"Success"}checkIfViewportsWillChange({offsetX:e,offsetY:t}){const o=this.getters.getActiveSheetId(),{maxOffsetX:s,maxOffsetY:i}=this.getMaximumSheetOffset();return this.getSubViewports(o).some((o=>o.willNewOffsetScrollViewport(St(e,0,s),St(t,0,i))))?"Success":"ViewportScrollLimitsReached"}getMainViewport(e){const t=this.getMainInternalViewport(e);return{top:t.top,left:t.left,bottom:t.bottom,right:t.right}}getMainInternalViewport(e){return this.ensureMainViewportExist(e),this.viewports[e].bottomRight}cleanViewports(){const e={};for(const t of this.getters.getSheetIds())e[t]=this.viewports[t];this.viewports=e}resizeSheetView(e,t,o=0,s=0){this.sheetViewHeight=e,this.sheetViewWidth=t,this.gridOffsetX=o,this.gridOffsetY=s,this.recomputeViewports()}recomputeViewports(){for(const e of this.getters.getSheetIds())this.resetViewports(e)}setSheetViewOffset(e,t){const o=this.getters.getActiveSheetId(),{maxOffsetX:s,maxOffsetY:i}=this.getMaximumSheetOffset();this.getSubViewports(o).forEach((o=>o.setViewportOffset(St(e,0,s),St(t,0,i))))}getViewportOffset(e){return{x:this.viewports[e]?.bottomRight.offsetX||0,y:this.viewports[e]?.bottomRight.offsetY||0}}resetViewports(e){if(!this.getters.tryGetSheet(e))return;const{xSplit:t,ySplit:o}=this.getters.getPaneDivisions(e),s=this.getters.getNumberCols(e),i=this.getters.getNumberRows(e),n=Math.min(this.getters.getColRowOffset("COL",0,t,e),this.sheetViewWidth),r=Math.min(this.getters.getColRowOffset("ROW",0,o,e),this.sheetViewHeight),a=Math.max(this.sheetViewWidth-n,0),l=Math.max(this.sheetViewHeight-r,0),{xRatio:c,yRatio:h}=this.getFrozenSheetViewRatio(e),d=c<1,u=h<1,g=this.getViewportOffset(e),p={topLeft:o&&t&&new iH(this.getters,e,{left:0,right:t-1,top:0,bottom:o-1},{width:n,height:r},{canScrollHorizontally:!1,canScrollVertically:!1},{x:0,y:0})||void 0,topRight:o&&new iH(this.getters,e,{left:t,right:s-1,top:0,bottom:o-1},{width:a,height:r},{canScrollHorizontally:d,canScrollVertically:!1},{x:d?g.x:0,y:0})||void 0,bottomLeft:t&&new iH(this.getters,e,{left:0,right:t-1,top:o,bottom:i-1},{width:n,height:l},{canScrollHorizontally:!1,canScrollVertically:u},{x:0,y:u?g.y:0})||void 0,bottomRight:new iH(this.getters,e,{left:t,right:s-1,top:o,bottom:i-1},{width:a,height:l},{canScrollHorizontally:d,canScrollVertically:u},{x:d?g.x:0,y:u?g.y:0})};this.viewports[e]=p}refreshViewport(e,t){this.getSubViewports(e).forEach((e=>{e.adjustViewportZone(),e.adjustPosition(t)}))}shiftVertically(e){const t=this.getters.getActiveSheetId(),{top:o}=this.getMainInternalViewport(t),{scrollX:s}=this.getActiveSheetScrollInfo();this.setSheetViewOffset(s,e);const{anchor:i}=this.getters.getSelection();if(i.cell.row>=this.getters.getPaneDivisions(t).ySplit){const e=this.getMainInternalViewport(t).top-o;this.selection.selectCell(i.cell.col,i.cell.row+e)}}getColIndexLeftOfMainViewport(e){if(e>=0)return-1;const t=this.getters.getActiveSheetId();let o=this.getActiveMainViewport().left,s=-this.getActiveSheetScrollInfo().scrollX-this.getters.getColRowOffset("COL",o,0);for(;e<s;o--)s-=this.getters.getColSize(t,o-1);return Math.max(o,0)}getRowIndexTopOfMainViewport(e){if(e>=0)return-1;const t=this.getters.getActiveSheetId();let o=this.getActiveMainViewport().top,s=-this.getActiveSheetScrollInfo().scrollY-this.getters.getColRowOffset("ROW",o,0);for(;e<s;o--)s-=this.getters.getRowSize(t,o-1);return Math.max(o,0)}getVisibleFigures(){const e=this.getters.getActiveSheetId(),t=[],o=this.getters.getFigures(e),{scrollX:s,scrollY:i}=this.getters.getActiveSheetScrollInfo(),{x:n,y:r}=this.getMainViewportCoordinates(),{width:a,height:l}=this.getters.getSheetViewDimensionWithHeaders();for(const c of o){const o=this.getFigureUI(e,c),{x:h,y:d}=o;h>=n&&(h+c.width<s+n||h>a+s+n)||(d>=r&&(d+c.height<i+r||d>l+i+r)||t.push(o))}return t}getFigureUI(e,t){const o=t.offset.x+this.getters.getColDimensions(e,t.col).start,s=t.offset.y+this.getters.getRowDimensions(e,t.row).start;return{...t,x:o,y:s}}getPositionAnchorOffset(e){const{scrollX:t,scrollY:o}=this.getters.getActiveSheetScrollInfo(),s=e.x-t,i=e.y-o,n=s>=0?this.getColIndex(s):this.getColIndexLeftOfMainViewport(s),r=i>=0?this.getRowIndex(i):this.getRowIndexTopOfMainViewport(i),{x:a,y:l}=this.getRect(cs({col:n,row:r}));return{col:n,row:r,offset:{x:Math.max(s-a+this.gridOffsetX,0),y:Math.max(i-l+this.gridOffsetY,0)}}}isPixelPositionVisible(e){const{scrollX:t,scrollY:o}=this.getters.getActiveSheetScrollInfo(),{x:s,y:i}=this.getters.getMainViewportCoordinates(),{width:n,height:r}=this.getters.getSheetViewDimension();return!(e.x>=s&&(e.x<s+t||e.x>n+t+s))&&!(e.y>=i&&(e.y<i+o||e.y>r+o+i))}getFrozenSheetViewRatio(e){const{xSplit:t,ySplit:o}=this.getters.getPaneDivisions(e),s=this.getters.getColDimensions(e,t).start,i=this.getters.getRowDimensions(e,o).start;return{xRatio:s/(this.sheetViewWidth+this.gridOffsetX),yRatio:i/(this.sheetViewHeight+this.gridOffsetY)}}mapViewportsToRect(e,t){let o=1/0,s=1/0,i=0,n=0,r=!1;for(const a of this.getSubViewports(e)){const e=t(a);e&&(r=!0,o=Math.min(o,e.x),s=Math.min(s,e.y),i=Math.max(i,e.x+e.width),n=Math.max(n,e.y+e.height))}return r?{x:o,y:s,width:i-o,height:n-s}:{x:0,y:0,width:0,height:0}}}).add("clipboard",class extends tu{static layers=["Clipboard"];static getters=["getClipboardTextAndImageContent","getClipboardId","getClipboardTextContent","isCutOperation"];status="invisible";originSheetId;copiedData;_isCutOperation=!1;clipboardId=(new Sl).uuidv4();fileStore;uuidGenerator;constructor(e){super(e),this.fileStore=e.external.fileStore,this.uuidGenerator=new Sl}allowDispatch(e){switch(e.type){case"CUT":const t=this.getters.getSelectedZones();return this.isCutAllowedOn(t);case"PASTE_FROM_OS_CLIPBOARD":{const t=this.convertTextToClipboardData(e.clipboardContent.text??""),o=e.pasteOption;return this.isPasteAllowed(e.target,t,{pasteOption:o,isCutOperation:!1})}case"PASTE":{if(!this.copiedData)return"EmptyClipboard";const t=e.pasteOption;return this.isPasteAllowed(e.target,this.copiedData,{pasteOption:t,isCutOperation:this._isCutOperation})}case"COPY_PASTE_CELLS_ABOVE":{const e=this.getters.getSelectedZones();if(e.length>1||0===e[0].top&&0===e[0].bottom)return"InvalidCopyPasteSelection";break}case"COPY_PASTE_CELLS_ON_LEFT":{const e=this.getters.getSelectedZones();if(e.length>1||0===e[0].left&&0===e[0].right)return"InvalidCopyPasteSelection";break}case"INSERT_CELL":{const{cut:t,paste:o}=this.getInsertCellsTargets(e.zone,e.shiftDimension),s=this.copy(t,"shiftCells");return this.isPasteAllowed(o,s,{isCutOperation:!0})}case"DELETE_CELL":{const{cut:t,paste:o}=this.getDeleteCellsTargets(e.zone,e.shiftDimension),s=this.copy(t,"shiftCells");return this.isPasteAllowed(o,s,{isCutOperation:!0})}}return"Success"}handle(e){switch(e.type){case"COPY":case"CUT":const t=this.getters.getSelectedZones();this.status="visible",this.originSheetId=this.getters.getActiveSheetId(),this._isCutOperation="CUT"===e.type,this.copiedData=this.copy(t);break;case"PASTE_FROM_OS_CLIPBOARD":{this._isCutOperation=!1;const t=e.clipboardContent.data;if(e.clipboardContent.imageData){const t=this.getters.getActiveSheetId(),o=this.uuidGenerator.uuidv4(),s=e.clipboardContent.imageData,i=uE(this.getters,s.size);this.dispatch("CREATE_IMAGE",{definition:s,size:i,col:e.target[0].left,row:e.target[0].top,offset:{x:0,y:0},sheetId:t,figureId:o})}this.copiedData=t||this.convertTextToClipboardData(e.clipboardContent.text??"");const o=e.pasteOption;this.paste(e.target,this.copiedData,{pasteOption:o,selectTarget:!0,isCutOperation:!1}),this.status="invisible",this.copiedData=void 0;break}case"PASTE":{const t=e.pasteOption;this.paste(e.target,this.copiedData,{pasteOption:t,selectTarget:!0,isCutOperation:this._isCutOperation}),this.status="invisible",this._isCutOperation&&(this.copiedData=void 0,this._isCutOperation=!1);break}case"COPY_PASTE_CELLS_ABOVE":{const e=this.getters.getSelectedZone(),t=e.top!==e.bottom,o={...e,bottom:t?e.top:e.top-1,top:t?e.top:e.top-1};this.originSheetId=this.getters.getActiveSheetId();const s=this.copy([o]);this.paste([e],s,{isCutOperation:!1,selectTarget:!0})}break;case"COPY_PASTE_CELLS_ON_LEFT":{const e=this.getters.getSelectedZone(),t=e.left!==e.right,o={...e,right:t?e.left:e.left-1,left:t?e.left:e.left-1};this.originSheetId=this.getters.getActiveSheetId();const s=this.copy([o]);this.paste([e],s,{isCutOperation:!1,selectTarget:!0})}break;case"CLEAN_CLIPBOARD_HIGHLIGHT":this.status="invisible";break;case"DELETE_CELL":{const{cut:t,paste:o}=this.getDeleteCellsTargets(e.zone,e.shiftDimension);if(!Bo(t[0])){this.dispatch("CLEAR_CELLS",{target:[e.zone],sheetId:this.getters.getActiveSheetId()});break}const s=this.copy(t,"shiftCells");this.paste(o,s,{isCutOperation:!0});break}case"INSERT_CELL":{const{cut:t,paste:o}=this.getInsertCellsTargets(e.zone,e.shiftDimension),s=this.copy(t,"shiftCells");this.paste(o,s,{isCutOperation:!0});break}case"ADD_COLUMNS_ROWS":if(this.status="invisible",!this._isCutOperation||e.sheetId!==this.copiedData?.sheetId)return;this.isColRowDirtyingClipboard("before"===e.position?e.base:e.base+1,e.dimension)&&(this.copiedData=void 0);break;case"REMOVE_COLUMNS_ROWS":if(this.status="invisible",!this._isCutOperation||e.sheetId!==this.copiedData?.sheetId)return;for(const t of e.elements){if(this.isColRowDirtyingClipboard(t,e.dimension)){this.copiedData=void 0;break}}this.status="invisible";break;case"REPEAT_PASTE":this.paste(e.target,this.copiedData,{isCutOperation:!1,pasteOption:e.pasteOption,selectTarget:!0});break;case"DELETE_SHEET":if(!this._isCutOperation)return;this.originSheetId===e.sheetId&&(this.copiedData=void 0,this.status="invisible");break;default:f(e)&&(this.status="invisible")}}convertTextToClipboardData(e){const t=this.selectClipboardHandlers({figureId:!0}).concat(this.selectClipboardHandlers({})),o={};for(const{handlerName:s,handler:i}of t){const t=i.convertTextToClipboardData(e);o[s]=t;const n=["sheetId","cells","zones","figureId"];for(const e of n)t&&e in t&&(o[e]=t[e])}return o}selectClipboardHandlers(e){const t="figureId"in e?yh.figureHandlers:yh.cellHandlers;return t.getKeys().map((e=>({handlerName:e,handler:new(t.get(e))(this.getters,this.dispatch)})))}isCutAllowedOn(e){const t=this.getClipboardData(e);for(const{handler:e}of this.selectClipboardHandlers(t)){const o=e.isCutAllowed(t);if("Success"!==o)return o}return"Success"}isPasteAllowed(e,t,o){for(const{handler:s}of this.selectClipboardHandlers(t)){const i=s.isPasteAllowed(this.getters.getActiveSheetId(),e,t,{...o});if("Success"!==i)return i}return"Success"}isColRowDirtyingClipboard(e,t){if(!this.copiedData||!this.copiedData.zones)return!1;const{zones:o}=this.copiedData;for(const s of o){if("COL"===t&&e<=s.right)return!0;if("ROW"===t&&e<=s.bottom)return!0}return!1}copy(e,t="copyPaste"){const o={},s=this.getClipboardData(e);for(const{handlerName:e,handler:i}of this.selectClipboardHandlers(s)){const n=i.copy(s,this._isCutOperation,t);o[e]=n;const r=["sheetId","cells","zones","figureId"];for(const e of r)n&&e in n&&(o[e]=n[e])}return o}paste(e,t,o){if(!t)return;const s=this.getters.getActiveSheetId(),i=this.selectClipboardHandlers(t),{target:n,zone:r,selectedZones:a}=ws(s,e,t,i,o);void 0!==r&&this.addMissingDimensions(s,r.right-r.left+1,r.bottom-r.top+1,r.left,r.top),Is(i,t,n,o),o?.selectTarget&&xs(this.selection,e,a)}addMissingDimensions(e,t,o,s,i){const n=o+i-this.getters.getNumberRows(e);n>0&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"ROW",base:this.getters.getNumberRows(e)-1,sheetId:e,sheetName:this.getters.getSheetName(e),quantity:n,position:"after"});const r=t+s-this.getters.getNumberCols(e);r>0&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"COL",base:this.getters.getNumberCols(e)-1,sheetId:e,sheetName:this.getters.getSheetName(e),quantity:r,position:"after"})}getClipboardTextContent(){return this.getPlainTextContent()}getClipboardId(){return this.clipboardId}async getClipboardTextAndImageContent(){const e=await this.getImageContent(),t=e?.type,o={[a.PlainText]:this.getPlainTextContent(),[a.Html]:await this.getHTMLContent()};return t&&e&&(o[t]=e),o}getSheetData(){const e={version:I_(),clipboardId:this.clipboardId};return this.copiedData&&"figureId"in this.copiedData?e:{...e,...this.copiedData}}getPlainTextContent(){return this.copiedData?.cells&&this.copiedData.cells.map((e=>e.map((e=>this.getters.shouldShowFormulas()&&e?.tokens?.length?e?.content||"":e.evaluatedCell?.formattedValue||"")).join("\t"))).join("\n")||"\t"}async getHTMLContent(){let e="";const t=this.copiedData?.cells;if(t)if(1===t.length&&1===t[0].length)e=`${this.getters.getCellText(t[0][0].position)}`;else{if(!t[0][0])return"";{let o='<table border="1" style="border-collapse:collapse">';for(const e of t){o+="<tr>";for(const t of e){if(!t)continue;o+=`<td style="${qh(Gh(this.getters.getCellComputedStyle(t.position)))}">`+fE(this.getters.getCellText(t.position))+"</td>"}o+="</tr>"}o+="</table>",e=o}}else if(this.copiedData?.figureId){const t=this.copiedData.figureId,o=this.getters.getFigureSheetId(t);e="image"===this.getters.getFigure(o,t).tag?await this.craftImageHTML(t):"\t"}else e="\t";return`<div data-osheet-clipboard='${fE(JSON.stringify(this.getSheetData()))}'>${e}</div>`}readFileAsDataURL(e){return new Promise((t=>{const o=new FileReader;o.onload=()=>t(o.result),o.readAsDataURL(e)}))}async craftImageHTML(e){if(!this.fileStore)return"\t";const t=this.getters.getImage(e).path,o=await(this.fileStore?.getFile(t))||null;if(o){return`<img src="${fE(await this.readFileAsDataURL(o))}" />`}return"\t"}async getImageContent(){const e=this.copiedData?.figureId;if(!e)return;const t=this.getters.getFigureSheetId(e);let o;if("image"===this.getters.getFigure(t,e).tag){if(!this.fileStore)return;const t=this.getters.getImage(e).path;if(o=await(this.fileStore?.getFile(t)),"image/png"!==o.type){if(o.size>oH)return void this.ui.notifyUI({text:ui("The file you are trying to copy is too large (>%sMB).\nIt will not be added to your OS clipboard.\nYou can download it directly instead.",Math.round(5)),sticky:!1,type:"warning"});o=await async function(e){return new Promise(((t,o)=>{const s=new Image;s.addEventListener("load",(()=>{const e=document.createElement("canvas");e.width=s.width,e.height=s.height;const o=e.getContext("2d");o?.drawImage(s,0,0),e.toBlob(t,"image/png")})),s.addEventListener("error",o),s.src=e}))}(t)}}return o?o instanceof File?o:new File([o],"image.png",{type:"image/png"}):void 0}isCutOperation(){return this._isCutOperation??!1}getDeleteCellsTargets(e,t){const o=this.getters.getActiveSheetId();let s;return s="COL"===t?{...e,left:e.right+1,right:this.getters.getNumberCols(o)-1}:{...e,top:e.bottom+1,bottom:this.getters.getNumberRows(o)-1},{cut:[s],paste:[e]}}getInsertCellsTargets(e,t){const o=this.getters.getActiveSheetId();let s,i;return"COL"===t?(s={...e,right:this.getters.getNumberCols(o)-1},i={...e,left:e.right+1,right:e.right+1}):(s={...e,bottom:this.getters.getNumberRows(o)-1},i={...e,top:e.bottom+1,bottom:this.getters.getNumberRows(o)-1}),{cut:[s],paste:[i]}}getClipboardData(e){const t=this.getters.getActiveSheetId(),o=this.getters.getSelectedFigureId();if(o)return{figureId:o,sheetId:t};const s=bs(t,e);return this._isCutOperation||(s.rowsIndexes=s.rowsIndexes.filter((e=>!this.getters.isRowFiltered(t,e)))),s}drawLayer(e){if("visible"!==this.status||!this.copiedData)return;const{sheetId:t,zones:o}=this.copiedData;if(t!==this.getters.getActiveSheetId()||!o||!o.length)return;const{ctx:s,thinLineWidth:i}=e;s.setLineDash([8,5]),s.strokeStyle=N,s.lineWidth=3.3*i;for(const e of o){const{x:t,y:o,width:i,height:n}=this.getters.getVisibleRect(e);i>0&&n>0&&s.strokeRect(t,o,i,n)}}}).add("carousel_ui",class extends tu{static getters=["getSelectedCarouselItem","getChartFromFigureId","getChartIdFromFigureId"];uuidGenerator=new Sl;carouselStates={};allowDispatch(e){switch(e.type){case"ADD_FIGURE_CHART_TO_CAROUSEL":return this.getters.doesCarouselExist(e.carouselFigureId)&&"chart"===this.getters.getFigure(e.sheetId,e.chartFigureId)?.tag?"Success":"InvalidFigureId";case"ADD_NEW_CHART_TO_CAROUSEL":return this.getters.doesCarouselExist(e.figureId)?"Success":"InvalidFigureId";case"UPDATE_CAROUSEL_ACTIVE_ITEM":return this.getters.doesCarouselExist(e.figureId)?this.getters.getCarousel(e.figureId).items.some((t=>zt(t,e.item)))?"Success":"InvalidCarouselItem":"InvalidFigureId"}return"Success"}handle(e){switch(e.type){case"ADD_NEW_CHART_TO_CAROUSEL":this.addNewChartToCarousel(e.figureId,e.sheetId);break;case"ADD_FIGURE_CHART_TO_CAROUSEL":this.addFigureChartToCarousel(e.carouselFigureId,e.chartFigureId,e.sheetId);break;case"UPDATE_CAROUSEL_ACTIVE_ITEM":this.carouselStates[e.figureId]=this.getCarouselItemId(e.item);break;case"POPOUT_CHART_FROM_CAROUSEL":this.popOutChartFromCarousel(e.carouselId,e.chartId,e.sheetId);break;case"DELETE_FIGURE":delete this.carouselStates[e.figureId];break;case"UPDATE_CAROUSEL":this.fixWrongCarouselState(e.figureId);break;case"DELETE_CHART":case"UNDO":case"REDO":case"DELETE_SHEET":for(const e in this.carouselStates)this.fixWrongCarouselState(e)}}popOutChartFromCarousel(e,t,o){const s=this.getters.getCarousel(e);if(!s)return;const i=this.getters.getFigure(o,e),n=this.getters.getChartDefinition(t);if(!n||!i)return;const r=this.getters.getFigureUI(o,i),a=this.getters.getPositionAnchorOffset({x:r.x+50,y:r.y+50}),l=this.uuidGenerator.smallUuid();this.dispatch("CREATE_CHART",{...a,chartId:this.uuidGenerator.smallUuid(),figureId:l,sheetId:o,size:{width:i.width,height:i.height},definition:{...n}});const c=s.items.filter((e=>"chart"!==e.type||e.chartId!==t));this.dispatch("UPDATE_CAROUSEL",{sheetId:o,figureId:e,definition:{...s,items:c}}),this.dispatch("SELECT_FIGURE",{figureId:l})}getSelectedCarouselItem(e){const t=this.getters.getCarousel(e);if(t.items.length)return this.carouselStates[e]?t.items.find((t=>this.getCarouselItemId(t)===this.carouselStates[e])):t.items[0]}getChartFromFigureId(e){if(!this.getters.getFigureSheetId(e))return;const t=this.getChartIdFromFigureId(e);return t?this.getters.getChart(t):void 0}getChartIdFromFigureId(e){const t=this.getters.getFigureSheetId(e);if(!t)return;const o=this.getters.getFigure(t,e);if(o&&("chart"===o.tag||"carousel"===o.tag)){if("carousel"===o.tag){const t=this.getSelectedCarouselItem(e);return"chart"===t?.type?t.chartId:void 0}return this.getters.getChartIds(t).find((t=>this.getters.getFigureIdFromChartId(t)===e))}}fixWrongCarouselState(e){if(!this.getters.doesCarouselExist(e))return void delete this.carouselStates[e];const t=this.getters.getCarousel(e);0===t.items.length?delete this.carouselStates[e]:this.carouselStates[e]&&t.items.some((t=>this.getCarouselItemId(t)===this.carouselStates[e]))||(this.carouselStates[e]=this.getCarouselItemId(t.items[0]))}addNewChartToCarousel(e,t){const o=this.getters.getCarousel(e),s=this.uuidGenerator.smallUuid();this.dispatch("CREATE_CHART",{chartId:s,figureId:e,sheetId:t,definition:FE});const i={...o,items:[...o.items,{type:"chart",chartId:s}]};this.dispatch("UPDATE_CAROUSEL",{sheetId:t,figureId:e,definition:i})}addFigureChartToCarousel(e,t,o){const s=this.getChartIdFromFigureId(t);if(!s)return;const i=this.getters.getCarousel(e),n={...i,items:[...i.items,{type:"chart",chartId:s}]};this.dispatch("UPDATE_CAROUSEL",{sheetId:o,figureId:e,definition:n}),this.dispatch("UPDATE_CHART",{sheetId:o,chartId:s,figureId:e,definition:this.getters.getChartDefinition(s)}),this.dispatch("DELETE_FIGURE",{sheetId:o,figureId:t})}getCarouselItemId(e){return"chart"===e.type?e.chartId:"carouselDataView"}}),lH=(new n).add("evaluation",class extends yV{static getters=["evaluateFormula","evaluateFormulaResult","evaluateCompiledFormula","getCorrespondingFormulaCell","getRangeFormattedValues","getRangeValues","getRangeFormats","getEvaluatedCell","getEvaluatedCells","getEvaluatedCellsInZone","getEvaluatedCellsPositions","getSpreadZone","getArrayFormulaSpreadingOn","isEmpty"];shouldRebuildDependenciesGraph=!0;evaluator;positionsToUpdate=[];constructor(e){super(e),this.evaluator=new oU(e.custom,this.getters)}beforeHandle(e){(l.has(e.type)||h.has(e.type))&&(this.shouldRebuildDependenciesGraph=!0)}handle(e){switch(e.type){case"UPDATE_CELL":if(!("content"in e)&&!("format"in e)||this.shouldRebuildDependenciesGraph)return;const t={sheetId:e.sheetId,row:e.row,col:e.col};this.positionsToUpdate.push(t),"content"in e&&this.evaluator.updateDependencies(t);break;case"EVALUATE_CELLS":if(e.cellIds)for(let t=0;t<e.cellIds.length;t++)this.positionsToUpdate.push(this.getters.getCellPosition(e.cellIds[t]));else this.evaluator.evaluateAllCells()}}finalize(){this.shouldRebuildDependenciesGraph?(this.evaluator.buildDependencyGraph(),this.evaluator.evaluateAllCells(),this.shouldRebuildDependenciesGraph=!1):this.positionsToUpdate.length&&this.evaluator.evaluateCells(this.positionsToUpdate),this.positionsToUpdate=[]}evaluateFormula(e,t){const o=this.evaluateFormulaResult(e,t);return E(o)?Un(o,(e=>e.value)):o.value}evaluateFormulaResult(e,t){return this.evaluator.evaluateFormulaResult(e,t)}evaluateCompiledFormula(e,t,o){return this.evaluator.evaluateCompiledFormula(e,t,o)}getRangeFormattedValues(e){return void 0===this.getters.tryGetSheet(e.sheetId)?[]:this.mapVisiblePositions(e,(e=>this.getters.getEvaluatedCell(e).formattedValue))}getRangeValues(e){return void 0===this.getters.tryGetSheet(e.sheetId)?[]:this.mapVisiblePositions(e,(e=>this.getters.getEvaluatedCell(e).value))}getRangeFormats(e){const t=this.getters.tryGetSheet(e.sheetId);return void 0===t?[]:this.getters.getEvaluatedCellsInZone(t.id,e.zone).map((e=>e.format))}getEvaluatedCell(e){return this.evaluator.getEvaluatedCell(e)}getEvaluatedCells(e){return this.evaluator.getEvaluatedPositionsInSheet(e).map((e=>this.getEvaluatedCell(e)))}getEvaluatedCellsPositions(e){return this.evaluator.getEvaluatedPositionsInSheet(e)}getEvaluatedCellsInZone(e,t){return is(t).map((({col:t,row:o})=>this.getters.getEvaluatedCell({sheetId:e,col:t,row:o})))}getSpreadZone(e,t={ignoreSpillError:!1}){return this.evaluator.getSpreadZone(e,t)}getArrayFormulaSpreadingOn(e){return this.evaluator.getArrayFormulaSpreadingOn(e)}isEmpty(e,t){return is(t).map((({col:t,row:o})=>this.getEvaluatedCell({sheetId:e,col:t,row:o}))).every((e=>e.type===r.empty))}mapVisiblePositions(e,t){const{sheetId:o,zone:s}=e;return is(s).reduce(((e,s)=>{const{col:i,row:n}=s;return this.getters.isColHidden(o,i)||this.getters.isRowHidden(o,n)||e.push(t({sheetId:o,...s})),e}),[])}exportForExcel(e){for(const t of e.sheets)t.cellValues={},t.formulaSpillRanges={};for(const t of this.evaluator.getEvaluatedPositions()){const o=this.evaluator.getEvaluatedCell(t),s=_o(t.col,t.row),i=o.value;let n,r=!1,a=!0;const l=e.sheets.find((e=>e.id===t.sheetId)),c=this.getCorrespondingFormulaCell(t);if(c){const h=this.getters.getCell(t);if(a=ZC(c.compiledFormula.tokens),r=a&&h?.content===c.content,!a&&""!==i){n=(i??"").toString();const t=o.format;if(t){const o=da(t,e.formats);l.formats[s]=o}}}const h=l.cells[s];let d;d=a&&r&&c instanceof pV?c.contentWithFixedReferences:a?h:n,l.cells[s]=d,l.cellValues[s]="error"!==o.type?i:void 0;const u=this.getSpreadZone(t);u&&(l.formulaSpillRanges[s]=this.getters.getRangeString(this.getters.getRangeFromZone(t.sheetId,u),t.sheetId))}}getCorrespondingFormulaCell(e){const t=this.getters.getCell(e);if(t&&t.isFormula)return t.compiledFormula.isBadExpression?void 0:t;if(t&&t.content)return;const o=this.getArrayFormulaSpreadingOn(e);if(void 0===o)return;const s=this.getters.getCell(o);return s?.isFormula?s:void 0}}).add("evaluation_chart",class extends yV{static getters=["getChartRuntime","getStyleOfSingleCellChart"];charts={};createRuntimeChart=aE(this.getters);handle(e){if(l.has(e.type)||d.has(e.type)||c.has(e.type))for(const e in this.charts)this.charts[e]=void 0;switch(e.type){case"UPDATE_CHART":case"CREATE_CHART":case"DELETE_CHART":this.charts[e.chartId]=void 0;break;case"DELETE_SHEET":for(const e in this.charts)this.getters.isChartDefined(e)||(this.charts[e]=void 0)}}getChartRuntime(e){if(!this.charts[e]){const t=this.getters.getChart(e);if(!t)throw new Error(`No chart for the given id: ${e}`);this.charts[e]=this.createRuntimeChart(t)}return this.charts[e]}getStyleOfSingleCellChart(e,t){if(e)return{background:e,fontColor:hy(e)};if(!t)return{background:k,fontColor:hy(k)};const o=t.zone.left,s=t.zone.top,i=t.sheetId,n=this.getters.getCellComputedStyle({sheetId:i,col:o,row:s}),r=n.fillColor||k;return{background:r,fontColor:n.textColor||hy(r)}}exportForExcel(e){for(const t of e.sheets){t.images||(t.images=[]);const e=this.getters.getFigures(t.id),o=[];for(const s of e){if(!s||"chart"!==s.tag)continue;const e=this.getters.getChartIds(t.id).find((e=>this.getters.getFigureIdFromChartId(e)===s.id));if(!e)continue;const i=this.getters.getChart(e),n=i?.getDefinitionForExcel(this.getters);if(n)o.push({...s,data:n});else{if(!i)continue;const o=this.getters.getChartType(e),n=YI(this.getters.getChartRuntime(e),s,o);n&&t.images.push({...s,tag:"image",data:{mimetype:"image/png",path:n,size:{width:s.width,height:s.height}}})}}t.charts=o}}}).add("evaluation_cf",class extends yV{static getters=["getConditionalIcon","getCellConditionalFormatStyle","getConditionalDataBar"];isStale=!0;computedStyles={};computedIcons={};computedDataBars={};handle(e){(l.has(e.type)||d.has(e.type)||"UPDATE_CELL"===e.type&&("content"in e||"format"in e))&&(this.isStale=!0)}finalize(){if(this.isStale){for(const e of this.getters.getSheetIds())this.computedStyles[e]=Vt((()=>this.getComputedStyles(e))),this.computedIcons[e]=Vt((()=>this.getComputedIcons(e))),this.computedDataBars[e]=Vt((()=>this.getComputedDataBars(e)));this.isStale=!1}}getCellConditionalFormatStyle(e){const{sheetId:t,col:o,row:s}=e,i=this.computedStyles[t]();return i&&i[o]?.[s]}getConditionalIcon({sheetId:e,col:t,row:o}){const s=this.computedIcons[e]();return s&&s[t]?.[o]}getConditionalDataBar({sheetId:e,col:t,row:o}){const s=this.computedDataBars[e]();return s&&s[t]?.[o]}getComputedStyles(e){const t={};for(const o of this.getters.getConditionalFormats(e).reverse())switch(o.rule.type){case"ColorScaleRule":for(const s of o.ranges)this.applyColorScale(e,s,o.rule,t);break;case"CellIsRule":const s=o.rule.values.map((e=>e.startsWith("=")?$C(e):void 0));for(const i of o.ranges){const n=this.getters.getRangeFromSheetXC(e,i).zone;for(let i=n.top;i<=n.bottom;i++)for(let r=n.left;r<=n.right;r++){const a={sheetId:e,col:r,row:i},l=o.rule.values.map(((t,o)=>{const a=s[o];return a?this.getters.getTranslatedCellFormula(e,r-n.left,i-n.top,a.tokens):t}));this.getRuleResultForTarget(a,{...o.rule,values:l})&&(t[r]||(t[r]=[]),t[r][i]=Object.assign(t[r]?.[i]||{},o.rule.style))}}}return t}getComputedIcons(e){const t={};for(const o of this.getters.getConditionalFormats(e).reverse())if("IconSetRule"===o.rule.type)for(const s of o.ranges)this.applyIcon(e,s,o.rule,t);return t}getComputedDataBars(e){const t={};for(const o of this.getters.getConditionalFormats(e).reverse())if("DataBarRule"===o.rule.type)for(const s of o.ranges)this.applyDataBar(e,s,o.rule,t);return t}parsePoint(e,t,o,s){const i=this.getters.getEvaluatedCellsInZone(e,this.getters.getRangeFromSheetXC(e,t).zone).filter((e=>e.type===r.number)).map((e=>e.value));switch(o.type){case"value":return"max"===s?no(i):ro(i);case"number":return Number(o.value);case"percentage":const t=ro(i);return t+(no(i)-t)*Number(o.value)/100;case"percentile":return on(i,Number(o.value)/100,!0);case"formula":const n=o.value&&this.getters.evaluateFormula(e,o.value);return"number"==typeof n?n:null;default:return null}}applyIcon(e,t,o,s){const i=this.parsePoint(e,t,o.lowerInflectionPoint),n=this.parsePoint(e,t,o.upperInflectionPoint);if(null===i||null===n||i>n)return;const a=this.getters.getRangeFromSheetXC(e,t).zone,l=[o.icons.upper,o.icons.middle,o.icons.lower];for(let t=a.top;t<=a.bottom;t++)for(let c=a.left;c<=a.right;c++){const a=this.getters.getEvaluatedCell({sheetId:e,col:c,row:t});if(a.type!==r.number)continue;const h=this.computeIcon(a.value,n,o.upperInflectionPoint.operator,i,o.lowerInflectionPoint.operator,l);s[c]||(s[c]=[]),s[c][t]=h}}computeIcon(e,t,o,s,i,n){return"ge"===o&&e>=t||"gt"===o&&e>t?n[0]:"ge"===i&&e>=s||"gt"===i&&e>s?n[1]:n[2]}applyDataBar(e,t,o,s){const i=this.getters.getRangeFromSheetXC(e,o.rangeValues||t),n=no(this.getters.getEvaluatedCellsInZone(e,i.zone).filter((e=>e.type===r.number)).map((e=>e.value)));if(n<=0)return;const a=o.color,l=this.getters.getRangeFromSheetXC(e,t).zone,c=i.zone;for(let t=l.top;t<=l.bottom;t++)for(let o=l.left;o<=l.right;o++){const i=o-l.left+c.left,h=t-l.top+c.top,d=this.getters.getEvaluatedCell({sheetId:e,col:i,row:h});!es(i,h,c)||d.type!==r.number||d.value<=0||(s[o]||(s[o]=[]),s[o][t]={color:As(a),percentage:100*d.value/n})}}applyColorScale(e,t,o,s){const i=this.parsePoint(e,t,o.minimum,"min"),n=o.midpoint?this.parsePoint(e,t,o.midpoint):null,a=this.parsePoint(e,t,o.maximum,"max");if(null===i||null===a||i>=a||n&&(i>=n||n>=a))return;const l=this.getters.getRangeFromSheetXC(e,t).zone,c=[{value:i,color:o.minimum.color}];o.midpoint&&n&&c.push({value:n,color:o.midpoint.color}),c.push({value:a,color:o.maximum.color});const h=ii(c);for(let t=l.top;t<=l.bottom;t++)for(let o=l.left;o<=l.right;o++){const n=this.getters.getEvaluatedCell({sheetId:e,col:o,row:t});if(n.type===r.number){const e=St(n.value,i,a);s[o]||(s[o]=[]),s[o][t]=s[o]?.[t]||{},s[o][t].fillColor=h(e)}}}getRuleResultForTarget(e,t){const o=this.getters.getEvaluatedCell(e);if(o.type===r.error)return!1;const{sheetId:s}=e,i=sR.get(t.operator),n=t.values.map((e=>e.startsWith("=")?this.getters.evaluateFormula(s,e)??"":ea(e,w)));if(n.some(bc))return!1;const a={type:t.operator,values:n.map(fc)};return i.isValueValid(o.value??"",a,this.getters,s)}}).add("row_size",class extends yV{static getters=["getRowSize","getHeaderSize","getMaxAnchorOffset"];tallestCellInRow={};ctx=document.createElement("canvas").getContext("2d");beforeHandle(e){if("ADD_COLUMNS_ROWS"===e.type){if("COL"===e.dimension)return;const t=Ht(e.position,e.base),o=Array(e.quantity).fill(void 0),s=eo(this.tallestCellInRow[e.sheetId],o,t);this.history.update("tallestCellInRow",e.sheetId,s)}}handle(e){switch(e.type){case"START":for(const e of this.getters.getSheetIds())this.initializeSheet(e);break;case"CREATE_SHEET":this.initializeSheet(e.sheetId);break;case"DUPLICATE_SHEET":{const t=pt(this.tallestCellInRow[e.sheetId]);this.history.update("tallestCellInRow",e.sheetIdTo,t);break}case"DELETE_SHEET":const t={...this.tallestCellInRow};delete t[e.sheetId],this.history.update("tallestCellInRow",t);break;case"REMOVE_COLUMNS_ROWS":{if("COL"===e.dimension)return;const t=Qt(this.tallestCellInRow[e.sheetId],e.elements);this.history.update("tallestCellInRow",e.sheetId,t);break}case"RESIZE_COLUMNS_ROWS":{const t=e.sheetId;if("ROW"===e.dimension)for(const o of e.elements){const e=this.getRowTallestCell(t,o);this.history.update("tallestCellInRow",t,o,e)}else for(const o of Ct(0,this.getters.getNumberRows(t)))for(const s of e.elements)this.updateRowSizeForCellChange(t,o,s)}break;case"UPDATE_CELL":this.updateRowSizeForCellChange(e.sheetId,e.row,e.col);break;case"ADD_MERGE":case"REMOVE_MERGE":for(const t of e.target)for(const o of is(t))this.updateRowSizeForCellChange(e.sheetId,o.row,o.col)}}getRowSize(e,t){return Math.round(this.getters.getUserRowSize(e,t)??this.tallestCellInRow[e][t]?.size??Ee)}getMaxAnchorOffset(e,t,o){let{numberOfRows:s,numberOfCols:i}=this.getters.getSheetSize(e),n=0;for(;n<t&&s>0;s--)n+=this.getRowSize(e,s-1);let r=0;for(;r<o&&i>0;i--)r+=this.getters.getColSize(e,i-1);return{col:i,row:s,offset:{x:r-o,y:n-t}}}getHeaderSize(e,t,o){return this.getters.isHeaderHidden(e,t,o)?0:"ROW"===t?this.getRowSize(e,o):this.getters.getColSize(e,o)}updateRowSizeForCellChange(e,t,o){const s=this.tallestCellInRow[e]?.[t];if(s?.cell.col===o){const o=this.getRowTallestCell(e,t);this.history.update("tallestCellInRow",e,t,o)}const i=this.getCellHeight({sheetId:e,col:o,row:t});if(!(i<=Ee)&&(!s&&i>Ee||s&&i>s.size)){const s={cell:{sheetId:e,col:o,row:t},size:i};this.history.update("tallestCellInRow",e,t,s)}}initializeSheet(e){const t=[];for(let o=0;o<this.getters.getNumberRows(e);o++){const s=this.getRowTallestCell(e,o);t.push(s)}this.history.update("tallestCellInRow",e,t)}getCellHeight(e){if(this.isInMultiRowMerge(e))return Ee;const t=this.getters.getCell(e),o=this.getters.getColSize(e.sheetId,e.col);return function(e,t,o){return t&&(t.isFormula||t.content)?ol(e,t.isFormula?"":t.content,t.style,o):Ee}(this.ctx,t,o)}isInMultiRowMerge(e){const t=this.getters.getMerge(e);return!!t&&t.bottom!==t.top}getRowTallestCell(e,t){if(void 0!==this.getters.getUserRowSize(e,t))return;const o=this.getters.getRowCells(e,t);let s,i=0;for(let e=0;e<o.length;e++){const t=this.getters.getCellById(o[e]);if(!t)continue;const n=this.getters.getCellPosition(t.id),r=this.getCellHeight(n);r>i&&r>Ee&&(i=r,s={cell:n,size:r})}return s&&s.size>Ee?s:void 0}}).add("data_validation_ui",class extends yV{static getters=["getDataValidationInvalidCriterionValueMessage","getInvalidDataValidationMessage","getValidationResultForCellValue","getDataValidationRangeValues","isCellValidCheckbox","getDataValidationCellStyle","getDataValidationChipStyle","isDataValidationInvalid"];validationResults={};handle(e){if(l.has(e.type)||"EVALUATE_CELLS"===e.type||"UPDATE_CELL"===e.type&&("content"in e||"format"in e))this.validationResults={};else switch(e.type){case"ADD_DATA_VALIDATION_RULE":case"REMOVE_DATA_VALIDATION_RULE":delete this.validationResults[e.sheetId]}}isDataValidationInvalid(e){return!this.getValidationResultForCell(e).isValid}getDataValidationCellStyle(e){if(!this.hasChip(e))return this.getDataValidationStyle(e)}getDataValidationChipStyle(e){if(this.hasChip(e))return this.getDataValidationStyle(e)??{fillColor:Q}}getInvalidDataValidationMessage(e){const t=this.getValidationResultForCell(e);return t.isValid?void 0:t.error}getDataValidationInvalidCriterionValueMessage(e,t){const o=sR.get(e);return t.startsWith("=")?"onlyLiterals"===o.allowedValues?ui("The value must not be a formula"):this.isValidFormula(t)?void 0:kb.CriterionError.validFormula:"onlyFormulas"===o.allowedValues?ui("The value must be a formula"):o.isCriterionValueValid(t)?void 0:o.criterionValueErrorString}getDataValidationRangeValues(e,t){const o=this.getters.getRangeFromSheetXC(e,String(t.values[0])),s=[],i=new Set;for(const e of is(o.zone)){const t=this.getters.getEvaluatedCell({...e,sheetId:o.sheetId});t.formattedValue&&!i.has(t.formattedValue)&&(i.add(t.formattedValue),s.push({label:t.formattedValue,value:t.value?.toString()||""}))}return s}isCellValidCheckbox(e){if(!this.getters.isMainCellPosition(e))return!1;const t=this.getters.getValidationRuleForCell(e);return!(!t||"isBoolean"!==t.criterion.type)&&this.getValidationResultForCell(e).isValid}getValidationResultForCellValue(e,t){const o=this.getters.getValidationRuleForCell(t);if(!o)return aU;const s=this.getRuleErrorForCellValue(e,t,o);return s?{error:s,rule:o,isValid:!1}:aU}hasChip(e){const t=this.getters.getValidationRuleForCell(e);return("isValueInList"===t?.criterion.type||"isValueInRange"===t?.criterion.type)&&"chip"===t.criterion.displayStyle}getDataValidationStyle(e){const t=this.getters.getValidationRuleForCell(e);if(!t||this.isDataValidationInvalid(e))return;const o=this.getters.getEvaluatedCell(e),s=this.getValueColor(t,o.value);if(!s)return;return{fillColor:s,textColor:Ws(s)}}getValueColor(e,t){if("isValueInList"===e.criterion.type||"isValueInRange"===e.criterion.type)for(const o in e.criterion.colors)if(o.toLowerCase()===String(t).toLowerCase())return e.criterion.colors[o]}isValidFormula(e){return!$C(e).isBadExpression}getValidationResultForCell(e){const{col:t,row:o,sheetId:s}=e;return this.validationResults[s]||(this.validationResults[s]=this.computeSheetValidationResults(s)),this.validationResults[s][t]?.[o]?.()||aU}computeSheetValidationResults(e){const t={},o=this.getters.getDataValidationRules(e).map((e=>e.ranges));for(const e of $a(o.flat())){const{col:o,row:s}=e;t[o]||(t[o]=[]),t[o][s]=Vt((()=>{const t=this.getters.getEvaluatedCell(e);return t.type===r.empty?aU:this.getValidationResultForCellValue(t.value,e)}))}return t}getRuleErrorForCellValue(e,t,o){const{sheetId:s}=t,i=o.criterion,n=sR.get(i.type),r=this.getCellOffsetInRule(t,o),a=this.getEvaluatedCriterionValues(s,r,i);if(a.some(bc))return;const l={...i,values:a.map(fc)};return n.isValueValid(e,l,this.getters,s)?void 0:n.getErrorString(l,this.getters,s)}getCellOffsetInRule(e,t){const o=t.ranges.find((t=>es(e.col,e.row,t.zone)));if(!o)throw new Error("The cell is not in any range of the rule");return{col:e.col-o.zone.left,row:e.row-o.zone.top}}getEvaluatedCriterionValues(e,t,o){return o.values.map((o=>{if(!o.startsWith("="))return ea(o,w);const s=$C(o),i=this.getters.getTranslatedCellFormula(e,t.col,t.row,s.tokens);return this.getters.evaluateFormula(e,i)}))}}).add("dynamic_tables",class extends yV{static getters=["canCreateDynamicTableOnZones","doesZonesContainFilter","getFilter","getFilters","getTable","getTables","getTablesOverlappingZones","getFilterId","getFilterHeaders","isFilterHeader"];tables={};handle(e){if(l.has(e.type)||"UPDATE_CELL"===e.type&&("content"in e||"format"in e)||"EVALUATE_CELLS"===e.type)this.tables={};else switch(e.type){case"CREATE_TABLE":case"REMOVE_TABLE":case"UPDATE_TABLE":case"DELETE_CONTENT":this.tables={}}}finalize(){for(const e of this.getters.getSheetIds())this.tables[e]||(this.tables[e]=this.computeTables(e))}computeTables(e){const t=[],o=this.getters.getCoreTables(e);for(const e of o)"dynamic"!==e.type&&t.push(e);const s=[...t];for(const i of o){if("dynamic"!==i.type)continue;const o=this.coreTableToTable(e,i);let n=o.range.zone;for(const e of s)Qo(n,e.range.zone)&&(n={...n,right:e.range.zone.left-1});t.push({...o,range:this.getters.getRangeFromZone(e,n)})}return t}getFilters(e){return this.getTables(e).filter((e=>e.config.hasFilters)).map((e=>e.filters)).flat()}getTables(e){return this.tables[e]||[]}getFilter(e){const t=this.getTable(e);if(t&&t.config.hasFilters)return t.filters.find((t=>t.col===e.col))}getFilterId(e){return this.getFilter(e)?.id}getTable({sheetId:e,col:t,row:o}){return this.getTables(e).find((e=>es(t,o,e.range.zone)))}getTablesOverlappingZones(e,t){return this.getTables(e).filter((e=>t.some((t=>Qo(e.range.zone,t)))))}doesZonesContainFilter(e,t){return this.getTablesOverlappingZones(e,t).some((e=>e.config.hasFilters))}getFilterHeaders(e){const t=[];for(const o of this.getTables(e)){if(!o.config.hasFilters)continue;const s=o.range.zone,i=s.top;for(let o=s.left;o<=s.right;o++)t.push({sheetId:e,col:o,row:i})}return t}isFilterHeader({sheetId:e,col:t,row:o}){return this.getFilterHeaders(e).some((e=>e.col===t&&e.row===o))}canCreateDynamicTableOnZones(e,t){if(!ms(t))return!1;const o=Yo(...t),s={col:o.left,row:o.top,sheetId:e},i=this.getters.getArrayFormulaSpreadingOn(s);if(!i){const e=this.getters.getEvaluatedCell(s);return e.value===sn.SpilledBlocked&&!e.errorOriginPosition}if(zt(i,s)&&1===gs(o))return!0;return zt(o,this.getters.getSpreadZone(i))}coreTableToTable(e,t){if("dynamic"!==t.type)return t;const o=t.range.zone,s={sheetId:e,col:o.left,row:o.top},i=this.getters.getSpreadZone(s)??t.range.zone,n=this.getters.getRangeFromZone(e,i),r=this.getDynamicTableFilters(e,t,i);return{id:t.id,range:n,filters:r,config:t.config}}getDynamicTableFilters(e,t,o){const s=[],{top:i,bottom:n,left:r,right:a}=o;for(let o=r;o<=a;o++){const a=o-r,l={left:o,right:o,top:i,bottom:n},c=OF(this.getDynamicTableFilterId(t.id,a),this.getters.getRangeFromZone(e,l),t.config,this.getters.getRangeFromZone);s.push(c)}return s}getDynamicTableFilterId(e,t){return e+"_"+t}exportForExcel(e){for(const t of e.sheets)for(const e of t.tables){const o=Ho(e.range),s={sheetId:t.id,col:o.left,row:o.top},i=this.getters.getCoreTable(s),n=this.getTable(s);"dynamic"===i?.type&&n&&(e.range=Go(n.range.zone))}}}).add("custom_colors",class extends yV{customColors={};shouldUpdateColors=!0;static getters=["getCustomColors"];constructor(e){super(e),this.tryToAddColors(e.customColors??[])}handle(e){switch(e.type){case"START":for(const e of this.getters.getSheetIds())for(const t of this.getters.getChartIds(e))this.tryToAddColors(this.getChartColors(t));break;case"UPDATE_CHART":case"CREATE_CHART":this.tryToAddColors(this.getChartColors(e.chartId));break;case"UPDATE_CELL":case"ADD_CONDITIONAL_FORMAT":case"SET_BORDER":case"SET_ZONE_BORDERS":case"SET_FORMATTING":case"CREATE_TABLE":case"UPDATE_TABLE":this.history.update("shouldUpdateColors",!0)}}finalize(){this.shouldUpdateColors&&(this.history.update("shouldUpdateColors",!1),this.tryToAddColors(this.computeCustomColors()))}getCustomColors(){return function(e){const t=[{leadColor:Ps(255,0,0),colors:[]},{leadColor:Ps(255,128,0),colors:[]},{leadColor:Ps(128,128,0),colors:[]},{leadColor:Ps(128,255,0),colors:[]},{leadColor:Ps(0,255,0),colors:[]},{leadColor:Ps(0,255,128),colors:[]},{leadColor:Ps(0,255,255),colors:[]},{leadColor:Ps(0,127,255),colors:[]},{leadColor:Ps(0,0,255),colors:[]},{leadColor:Ps(127,0,255),colors:[]},{leadColor:Ps(128,0,128),colors:[]},{leadColor:Ps(255,0,128),colors:[]}];for(const o of e.map(ks)){let e=500,s=0;t.forEach(((t,i)=>{const n=(r=o,a=t.leadColor,Math.sqrt(Math.pow(r.r-a.r,2)+Math.pow(r.g-a.g,2)+Math.pow(r.b-a.b,2)));var r,a;e>n&&(e=n,s=i)})),t[s].colors.push(o)}return t.map((e=>e.colors.sort(((e,t)=>Vs(e).s-Vs(t).s)))).flat().map(Ns)}(Object.keys(this.customColors))}computeCustomColors(){let e=[];for(const t of this.getters.getSheetIds())e=e.concat(this.getColorsFromCells(t),this.getFormattingColors(t),this.getTableColors(t));return[...new Set([...e])]}getColorsFromCells(e){const t=Object.values(this.getters.getCells(e)),o=new Set;for(const e of t)e.style?.textColor&&o.add(e.style.textColor),e.style?.fillColor&&o.add(e.style.fillColor);for(const t of this.getters.getBordersColors(e))o.add(t);return[...o]}getFormattingColors(e){const t=this.getters.getConditionalFormats(e),o=[];for(const e of t){const t=e.rule;"CellIsRule"===t.type?(o.push(t.style.textColor),o.push(t.style.fillColor)):"ColorScaleRule"===t.type&&(o.push(As(t.minimum.color)),o.push(t.midpoint?As(t.midpoint.color):void 0),o.push(As(t.maximum.color)))}return o.filter(Mt)}getChartColors(e){const t=this.getters.getChart(e);if(void 0===t)return[];return[...JSON.stringify(t.getDefinition()).matchAll(rU)].map((e=>e[1]))}getTableColors(e){return this.getters.getTables(e).flatMap((e=>{const t=e.config,o=this.getters.getTableStyle(t.styleId);return[this.getTableStyleElementColors(o.wholeTable),t.numberOfHeaders>0?this.getTableStyleElementColors(o.headerRow):[],t.totalRow?this.getTableStyleElementColors(o.totalRow):[],t.bandedColumns?this.getTableStyleElementColors(o.firstColumnStripe):[],t.bandedColumns?this.getTableStyleElementColors(o.secondColumnStripe):[],t.bandedRows?this.getTableStyleElementColors(o.firstRowStripe):[],t.bandedRows?this.getTableStyleElementColors(o.secondRowStripe):[],t.firstColumn?this.getTableStyleElementColors(o.firstColumn):[],t.lastColumn?this.getTableStyleElementColors(o.lastColumn):[]].flat()}))}getTableStyleElementColors(e){return e?[e.style?.fillColor,e.style?.textColor,e.border?.bottom?.color,e.border?.top?.color,e.border?.left?.color,e.border?.right?.color,e.border?.horizontal?.color,e.border?.vertical?.color].filter(Mt):[]}tryToAddColors(e){for(const t of e){if(!Fs(t))continue;const e=_s(t);t&&!ye.includes(e)&&this.history.update("customColors",e,!0)}}}).add("pivot_ui",class extends yV{static getters=["getPivot","getFirstPivotFunction","getPivotCellSortDirection","getPivotIdFromPosition","getPivotCellFromPosition","generateNewCalculatedMeasureName","isPivotUnused","isSpillPivotFormula"];pivots={};unusedPivots;custom;constructor(e){super(e),this.custom=e.custom}beforeHandle(e){if("START"===e.type)for(const e of this.getters.getPivotIds())this.setupPivot(e)}handle(e){if(l.has(e.type))for(const e of this.getters.getPivotIds())yP.get(this.getters.getPivotCoreDefinition(e).type).externalData||this.setupPivot(e,{recreate:!0});switch(e.type){case"REFRESH_PIVOT":this.refreshPivot(e.id);break;case"ADD_PIVOT":this.setupPivot(e.pivotId);break;case"DUPLICATE_PIVOT":this.setupPivot(e.newPivotId);break;case"UPDATE_PIVOT":this.setupPivot(e.pivotId,{recreate:!0});break;case"DELETE_SHEET":case"UPDATE_CELL":this.unusedPivots=void 0;break;case"UNDO":case"REDO":{this.unusedPivots=void 0;const t=e.commands.filter(gU);for(const e of t){const t=e.pivotId;this.getters.isExistingPivot(t)&&this.setupPivot(t,{recreate:!0})}break}case"UPDATE_LOCALE":!function(){for(const e in SP)SP[e].set.clear(),SP[e].values={}}()}}getPivotIdFromPosition(e){const t=this.getters.getCorrespondingFormulaCell(e);if(t&&t.isFormula){const o=this.getFirstPivotFunction(e.sheetId,t.compiledFormula.tokens);if(o){const e=o.args[0]?.toString();return e&&this.getters.getPivotId(e)}}}isSpillPivotFormula(e){const t=this.getters.getCorrespondingFormulaCell(e);if(t&&t.isFormula){const o=this.getFirstPivotFunction(e.sheetId,t.compiledFormula.tokens);return"PIVOT"===o?.functionName}return!1}getFirstPivotFunction(e,t){const o=kL(t);if(!o)return;const{functionName:s,args:i}=o;return{functionName:s,args:i.map((t=>{if("EMPTY"===t.type)return;if("STRING"===t.type||"BOOLEAN"===t.type||"NUMBER"===t.type)return t.value;const o=vN(t);return this.getters.evaluateFormula(e,o)}))}}getPivotCellFromPosition(e){const t=this.getters.getCorrespondingFormulaCell(e);if(!t||!t.isFormula||0===LL(t.compiledFormula.tokens))return hP;const o=this.getters.getCellPosition(t.id),s=this.getters.getFirstPivotFunction(e.sheetId,t.compiledFormula.tokens);if(!s)return hP;let{functionName:i,args:n}=s;const r=n[0];if(!r)return hP;const a=this.getters.getPivotId(r.toString());if(!a)return hP;const l=this.getPivot(a);if(!l.isValid())return hP;if("PIVOT"===i&&!t.content.replaceAll(" ","").toUpperCase().startsWith("=PIVOT"))return hP;if("PIVOT"===i){const t=fc(n[2]),s=void 0===t||An(t),i=fc(n[3]),r=fc(n[5]),a=void 0===r||An(r),c={displayColumnHeaders:void 0===i||An(i),displayTotals:s,displayMeasuresRow:a},h=l.getCollapsedTableStructure().getPivotCells(c),d=e.col-o.col,u=e.row-o.row;return h[d][u]}try{const t=e.row-o.row,s=e.col-o.col;if(n=n.map((e=>E(e)?e[s][t]:e)),"PIVOT.HEADER"===i&&"measure"===n.at(-2)){return{type:"MEASURE_HEADER",domain:l.parseArgsToPivotDomain(n.slice(1,-2).map((e=>({value:e})))),measure:n.at(-1)?.toString()||""}}if("PIVOT.HEADER"===i){const e=l.parseArgsToPivotDomain(n.slice(1).map((e=>({value:e}))));return{type:"HEADER",domain:e,dimension:jO(l,e).colDomain.length?"COL":"ROW"}}const[r,...a]=n.slice(1);return{type:"VALUE",domain:l.parseArgsToPivotDomain(a.map((e=>({value:e})))),measure:r?.toString()||""}}catch(e){return hP}}generateNewCalculatedMeasureName(e){const t=e.map((e=>e.fieldName));return ho(ui("Calculated measure 1"),t,{compute:(e,t)=>ui("Calculated measure %s",t)})}getPivot(e){if(!this.getters.isExistingPivot(e))throw new Error(`pivot ${e} not found`);return this.pivots[e]}isPivotUnused(e){return this._getUnusedPivots().includes(e)}getPivotCellSortDirection(e){const t=this.getters.getPivotIdFromPosition(e),o=this.getters.getPivotCellFromPosition(e);if("EMPTY"===o.type||"HEADER"===o.type||!t)return;const s=this.getters.getPivot(t),i=jO(s,o.domain).colDomain,n=s.definition.sortedColumn;return n?.measure===o.measure&&zt(n.domain,i)?n.order:"none"}refreshPivot(e){this.getters.getPivot(e).init({reload:!0})}setupPivot(e,{recreate:t}={recreate:!1}){const o=this.getters.getPivotCoreDefinition(e);if(e in this.pivots)t&&this.pivots[e].onDefinitionChange(o);else{const t=dU(yP.get(o.type).ui);this.pivots[e]=new t(this.custom,{definition:o,getters:this.getters})}}_getUnusedPivots(){if(void 0!==this.unusedPivots)return this.unusedPivots;const e=new Set(this.getters.getPivotIds());for(const t of this.getters.getSheetIds())for(const o in this.getters.getCells(t)){const t=this.getters.getCellPosition(o),s=this.getPivotIdFromPosition(t);if(s&&(e.delete(s),!e.size))return this.unusedPivots=[],[]}return this.unusedPivots=[...e],this.unusedPivots}}).add("cell_icon",class extends yV{static getters=["doesCellHaveGridIcon","getCellIcons","getCellIconRect"];cellIconsCache={};handle(e){"SET_VIEWPORT_OFFSET"!==e.type&&(this.cellIconsCache={})}getCellIcons(e){return this.cellIconsCache[e.sheetId]||(this.cellIconsCache[e.sheetId]={}),this.cellIconsCache[e.sheetId][e.col]||(this.cellIconsCache[e.sheetId][e.col]={}),this.cellIconsCache[e.sheetId][e.col][e.row]||(this.cellIconsCache[e.sheetId][e.col][e.row]=this.computeCellIcons(e)),this.cellIconsCache[e.sheetId][e.col][e.row]}getCellIconRect(e,t){const o=e.position,s=this.getters.getCell(o);return{x:this.getIconHorizontalPosition(t,e.horizontalAlign,e),y:this.getters.computeTextYCoordinate(t,e.size,s?.style?.verticalAlign),width:e.size,height:e.size}}getIconHorizontalPosition(e,t,o){const s=e.x,i=e.x+e.width;switch(t){case"right":return i-o.margin-o.size;case"left":return s+o.margin;default:const e=Math.floor((i-s-o.size)/2);return i-o.size-e}}computeCellIcons(e){const t={left:void 0,right:void 0,center:void 0},o=lU.getAll();for(const s of o){const o=s(this.getters,e);o&&(!t[o.horizontalAlign]||o.priority>t[o.horizontalAlign].priority)&&(t[o.horizontalAlign]=o)}if(t.center&&(t.left||t.right)){const e=Math.max(t.left?.priority||0,t.right?.priority||0);t.center.priority<e?t.center=void 0:(t.left=void 0,t.right=void 0)}return Object.values(t).filter(Mt)}doesCellHaveGridIcon(e){return Boolean(this.getCellIcons(e).length)}});Rd.add("dataValidation",{displayAllOnInitialContent:!0,canBeToggled:!1,getProposals(e,t){if(uo(t))return[];if(!this.composer.currentEditedCell)return[];const o=this.composer.currentEditedCell,s=this.getters.getValidationRuleForCell(o);if(!s||"isValueInList"!==s.criterion.type&&"isValueInRange"!==s.criterion.type)return[];const i=this.composer.currentEditedCell.sheetId,n="isValueInRange"===s.criterion.type?this.getters.getDataValidationRangeValues(i,s.criterion):s.criterion.values.map((e=>({label:e,value:e})));if(!("chip"===s.criterion.displayStyle))return n.map((e=>({text:e.value,fuzzySearchKey:e.label,htmlContent:[{value:e.label}]})));const r=s.criterion.colors;return n.map((e=>{const t=r?.[e.value];return{text:e.value,htmlContent:[{value:e.label,color:t?Ws(t):void 0,backgroundColor:t||Q,classes:["badge rounded-pill fs-6 fw-normal w-100 mt-1 text-start"]}],fuzzySearchKey:e.label}}))},selectProposal(e,t){this.composer.setCurrentContent(t),this.composer.stopEdition()}}),Rd.add("functions",{sequence:100,autoSelectFirstProposal:!0,maxDisplayedProposals:10,getProposals(e){if("SYMBOL"!==e.type)return[];const t=e.value;if(!uo(this.composer.currentContent))return[];const o=Object.entries(AC.content).filter((([e,{hidden:t}])=>!t)).map((([e,{description:o}])=>({text:e,description:o,htmlContent:xL(t,e,q,"o-semi-bold")}))).sort(((e,t)=>e.text.length-t.text.length||e.text.localeCompare(t.text)));return o},selectProposal(e,t){let o=e.end,s=e.end;["SYMBOL","FUNCTION"].includes(e.type)&&(o=e.start);const i=this.composer.currentTokens;t+="(";const n=i.map((e=>e.start)).indexOf(e.start);if(n+1<i.length){const e=i[n+1];"LEFT_PAREN"===e?.type&&s++}this.composer.changeComposerCursorSelection(o,s),this.composer.replaceComposerCursorSelection(t)}}),Rd.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:ht.NUMBER}],fuzzySearchKey:o+t.name,alwaysExpanded:!0}})).filter(Mt)},selectProposal:MC}),Rd.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=NL(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:ui("Count"),htmlContent:[{value:e,color:ht.STRING}],fuzzySearchKey:ui("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:ht.STRING}],fuzzySearchKey:o}}(e)})).filter(Mt):[]},selectProposal:MC}),Rd.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=NL(e),s=this.getters.getPivotId(o);if(!s||!this.getters.isExistingPivot(s))return;const i=this.getters.getPivot(s);i.init();const n=i.getFields(),{columns:r,rows:a}=i.definition;let l=t.args;"PIVOT.VALUE"===t?.parent.toUpperCase()?(l=l.filter(((e,t)=>t%2==0)),l=l.slice(1,t.argPosition)):l=l.filter(((e,t)=>t%2==1));const c=l.map((e=>e?.value)).filter(Mt),h=r.map((e=>e.nameWithGranularity)),d=a.map((e=>e.nameWithGranularity)),u=[];let g=["ARG_SEPARATOR","SPACE"].includes(e.type)?c.at(-1):c.at(-2);const p=cV.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(Mt);return m.map((e=>{const[t,o]=e.split(":"),s=n[t];return s?ML(s,o):void 0})).concat(m.map((e=>{if(!p)return;const t=e.split(":")[0],o=n[t];if(!o)return;const s=`"#${e}"`;return{text:s,description:ui("%s (positional)",o.string)+(o.help?` (${o.help})`:""),htmlContent:[{value:s,color:ht.STRING}],fuzzySearchKey:o.string+s}}))).filter(Mt)},selectProposal:MC}),Rd.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=NL(e),s=this.getters.getPivotId(o);if(!s||!this.getters.isExistingPivot(s))return;const i=this.getters.getPivot(s);if(!i.isValid())return;const n=t.argPosition,r=e.functionContext?.args[n-1]?.value;if(!r)return;let a;try{a=i.definition.getDimension(r)}catch(e){return}return"month_number"===a.granularity?Object.values(wr).map(((e,t)=>({text:`${t+1}`,fuzzySearchKey:e.toString(),description:e.toString(),htmlContent:[{value:`${t+1}`,color:ht.NUMBER}]}))):"quarter_number"===a.granularity?[1,2,3,4].map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:ui("Quarter %s",e),htmlContent:[{value:`${e}`,color:ht.NUMBER}]}))):"day_of_month"===a.granularity?Ct(1,32).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:ht.NUMBER}]}))):"iso_week_number"===a.granularity?Ct(0,54).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:ht.NUMBER}]}))):"day_of_week"===a.granularity?Ct(1,8).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:ht.NUMBER}]}))):"hour_number"===a.granularity?Ct(0,24).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:ht.NUMBER}]}))):"minute_number"===a.granularity?Ct(0,60).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:ht.NUMBER}]}))):"second_number"===a.granularity?Ct(0,60).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:ht.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?ht.STRING:ht.NUMBER}],fuzzySearchKey:s+i}}))},selectProposal:MC}),Rd.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=vt(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 cH=new n;cH.add("link",{condition:(e,t)=>!!t.getEvaluatedCell(e).link,execute:(e,t,o)=>Ci(t.model.getters.getEvaluatedCell(e).link,t,o),title:(e,t)=>{const o=t.getEvaluatedCell(e).link;return o?o.isExternal?ui("Go to url: %(url)s",{url:o.url}):ui("Go to %(label)s",{label:o.label}):""},sequence:5}),cH.add("dashboard_pivot_sorting",{condition:(e,t)=>{if(!t.isDashboard())return!1;const o=t.getPivotCellFromPosition(e);return FP(t,e)&&"MEASURE_HEADER"===o.type},execute:(e,t)=>{OP(t,e,function(e,t){return hH[e.getPivotCellSortDirection(t)??"none"]}(t.model.getters,e))},component:hV,componentProps:(e,t)=>({position:e,sortDirection:t.getPivotCellSortDirection(e)}),sequence:2});const hH={none:"asc",asc:"desc",desc:"none"};const dH=(new n).add("ADD_COLUMNS_ROWS",(function(e){const t=[];let o=e.base;"after"===e.position&&o++;for(let s=0;s<e.quantity;s++)t.push(s+o);return[{type:"REMOVE_COLUMNS_ROWS",dimension:e.dimension,elements:t,sheetId:e.sheetId,sheetName:e.sheetName}]})).add("REMOVE_COLUMNS_ROWS",(function(e){const t=[],o=[...e.elements].sort(((e,t)=>e-t));for(const s of yt(o)){const o=0===s[0]?0:s[0]-1,i=0===s[0]?"before":"after";t.push({type:"ADD_COLUMNS_ROWS",dimension:e.dimension,quantity:s.length,base:o,sheetId:e.sheetId,sheetName:e.sheetName,position:i})}return t})).add("ADD_MERGE",(function(e){return[{type:"REMOVE_MERGE",sheetId:e.sheetId,target:e.target}]})).add("REMOVE_MERGE",(function(e){return[{type:"ADD_MERGE",sheetId:e.sheetId,target:e.target}]})).add("CREATE_SHEET",(function(e){return[{type:"DELETE_SHEET",sheetId:e.sheetId,sheetName:e.name}]})).add("DELETE_SHEET",(function(e){return[{type:"CREATE_SHEET",sheetId:e.sheetId,position:1,name:e.sheetName}]})).add("DUPLICATE_SHEET",(function(e){return[{type:"DELETE_SHEET",sheetId:e.sheetIdTo,sheetName:""}]})).add("CREATE_FIGURE",(function(e){return[{type:"DELETE_FIGURE",figureId:e.figureId,sheetId:e.sheetId}]})).add("CREATE_CHART",(function(e){return[{type:"DELETE_FIGURE",figureId:e.figureId,sheetId:e.sheetId}]})).add("HIDE_COLUMNS_ROWS",(function(e){return[{type:"UNHIDE_COLUMNS_ROWS",sheetId:e.sheetId,dimension:e.dimension,elements:e.elements}]})).add("UNHIDE_COLUMNS_ROWS",(function(e){return[{type:"HIDE_COLUMNS_ROWS",sheetId:e.sheetId,dimension:e.dimension,elements:e.elements}]})).add("CREATE_TABLE_STYLE",(function(e){return[{type:"REMOVE_TABLE_STYLE",tableStyleId:e.tableStyleId}]})).add("ADD_PIVOT",(function(e){return[{type:"REMOVE_PIVOT",pivotId:e.pivotId}]})).add("RENAME_SHEET",(function(e){return[{type:"RENAME_SHEET",sheetId:e.sheetId,oldName:e.newName,newName:e.oldName}]}));for(const e of m.values())dH.contains(e)||dH.add(e,uH);function uH(e){return[e]}const gH=new n;gH.add("format_number_automatic",{...jP,id:"format_number_automatic",sequence:10}).add("format_number_plain_text",{...YP,id:"format_number_plain_text",sequence:15,separator:!0}).add("format_number_number",{...XP,id:"format_number_number",sequence:20}).add("format_number_percent",{...JP,id:"format_number_percent",sequence:30,separator:!0}).add("format_number_currency",{...QP,id:"format_number_currency",sequence:40}).add("format_number_accounting",{...tM,id:"format_number_accounting",sequence:45}).add("format_number_currency_rounded",{...eM,id:"format_number_currency_rounded",sequence:50}).add("format_custom_currency",{...sM,id:"format_custom_currency",sequence:60,separator:!0}).add("format_number_date",{...iM,id:"format_number_date",sequence:70}).add("format_number_time",{...nM,id:"format_number_time",sequence:80}).add("format_number_date_time",{...rM,id:"format_number_date_time",sequence:90}).add("format_number_duration",{...aM,id:"format_number_duration",sequence:100,separator:!0}).add("more_formats",{...hM,id:"more_formats",sequence:120});const pH=Jt((e=>Mr(e)?"date":e.includes("[$")?"currency":"number")),mH={name:ui("More formats"),icon:"o-spreadsheet-Icon.NUMBER_FORMATS",children:[e=>{const t=function(e){const t=new Set(gH.getAll().map((t=>"function"==typeof t.format?t.format(e):t.format))),o=new Map;for(const s of e.model.getters.getSheetIds()){const i=e.model.getters.getEvaluatedCells(s);for(const e in i){const s=i[e];if(s.format&&!o.has(s.format)&&!t.has(s.format)){const e=pH(s.format);"date"!==e&&"currency"!==e||o.set(s.format,ZP({descriptionValue:"currency"===e?1e3:oM,format:s.format,name:s.format}))}}}return[...o.values()]}(e).map((e=>({...e,sequence:110})));return t.length>0&&(t[t.length-1].separator=!0),o([...gH.getAll(),...t])}]};const fH=new CT;fH.add("file",{name:ui("File"),sequence:10}).addChild("settings",["file"],{name:ui("Settings"),sequence:200,execute:e=>e.openSidePanel("Settings"),isEnabled:e=>!e.isSmall,icon:"o-spreadsheet-Icon.COG"}).add("edit",{name:ui("Edit"),sequence:20}).addChild("undo",["edit"],{...BF,sequence:10}).addChild("redo",["edit"],{...$F,sequence:20,separator:!0}).addChild("copy",["edit"],{...GF,sequence:30}).addChild("cut",["edit"],{...WF,sequence:40}).addChild("paste",["edit"],{...qF,sequence:50}).addChild("paste_special",["edit"],{...ZF,sequence:60,separator:!0}).addChild("paste_special_value",["edit","paste_special"],{...jF,sequence:10}).addChild("paste_special_format",["edit","paste_special"],{...YF,sequence:20}).addChild("edit_table",["edit"],{...lO,isVisible:Y_,sequence:60}).addChild("find_and_replace",["edit"],{...XF,sequence:65,separator:!0}).addChild("delete",["edit"],{name:ui("Delete"),icon:"o-spreadsheet-Icon.TRASH",sequence:70}).addChild("edit_delete_cell_values",["edit","delete"],{...KF,sequence:10}).addChild("edit_delete_row",["edit","delete"],{...JF,sequence:20}).addChild("edit_delete_column",["edit","delete"],{...tO,sequence:30}).addChild("edit_delete_cell_shift_up",["edit","delete"],{...nO,sequence:40}).addChild("edit_delete_cell_shift_left",["edit","delete"],{...rO,sequence:50}).addChild("edit_unhide_columns",["edit"],{...rF,sequence:80}).addChild("edit_unhide_rows",["edit"],{...cF,sequence:80}).add("view",{name:ui("View"),sequence:30}).addChild("unfreeze_panes",["view"],{...hF,sequence:4}).addChild("freeze_panes",["view"],{...dF,sequence:5}).addChild("unfreeze_rows",["view","freeze_panes"],{...uF,sequence:5}).addChild("freeze_first_row",["view","freeze_panes"],{...gF,sequence:10}).addChild("freeze_second_row",["view","freeze_panes"],{...pF,sequence:15}).addChild("freeze_current_row",["view","freeze_panes"],{...mF,sequence:20,separator:!0}).addChild("unfreeze_columns",["view","freeze_panes"],{...fF,sequence:25}).addChild("freeze_first_col",["view","freeze_panes"],{...vF,sequence:30}).addChild("freeze_second_col",["view","freeze_panes"],{...bF,sequence:35}).addChild("freeze_current_col",["view","freeze_panes"],{...SF,sequence:40}).addChild("group_headers",["view"],{name:ui("Group"),sequence:15,separator:!0,icon:"o-spreadsheet-Icon.PLUS_IN_BOX",isVisible:K_}).addChild("group_columns",["view","group_headers"],{...wF,sequence:5}).addChild("ungroup_columns",["view","group_headers"],{...EF,isVisible:e=>DF(e,"COL"),sequence:10}).addChild("group_rows",["view","group_headers"],{...xF,sequence:15}).addChild("ungroup_rows",["view","group_headers"],{...RF,isVisible:e=>DF(e,"ROW"),sequence:20}).addChild("show",["view"],{name:ui("Show"),sequence:1,icon:"o-spreadsheet-Icon.SHOW"}).addChild("view_gridlines",["view","show"],{...CF,sequence:5}).addChild("view_formulas",["view","show"],{...IF,sequence:10}).addChild("view_irregularity_map",["view"],{...yF,sequence:40,separator:!0}).add("insert",{name:ui("Insert"),sequence:40}).addChild("insert_row",["insert"],{...uO,sequence:10}).addChild("insert_row_before",["insert","insert_row"],{...pO,sequence:10}).addChild("insert_row_after",["insert","insert_row"],{...vO,sequence:20}).addChild("insert_column",["insert"],{...bO,sequence:20}).addChild("insert_column_before",["insert","insert_column"],{...CO,sequence:10}).addChild("insert_column_after",["insert","insert_column"],{...wO,sequence:20}).addChild("insert_cell",["insert"],{...xO,sequence:30}).addChild("insert_cell_down",["insert","insert_cell"],{...EO,name:ui("Shift down"),sequence:10}).addChild("insert_cell_right",["insert","insert_cell"],{...RO,name:ui("Shift right"),sequence:20}).addChild("insert_sheet",["insert"],{...BO,sequence:40,separator:!0}).addChild("insert_chart",["insert"],{...TO,sequence:50}).addChild("insert_carousel",["insert"],{...AO,sequence:51}).addChild("insert_pivot",["insert"],{...DO,sequence:52}).addChild("insert_image",["insert"],{..._O,sequence:55}).addChild("insert_table",["insert"],{...FO,sequence:57}).addChild("insert_function",["insert"],{...OO,sequence:60}).addChild("insert_function_sum",["insert","insert_function"],{...PO,sequence:0}).addChild("insert_function_average",["insert","insert_function"],{...MO,sequence:10}).addChild("insert_function_count",["insert","insert_function"],{...NO,sequence:20}).addChild("insert_function_max",["insert","insert_function"],{...kO,sequence:30}).addChild("insert_function_min",["insert","insert_function"],{...LO,sequence:40,separator:!0}).addChild("categorie_function_all",["insert","insert_function"],{...VO,sequence:50}).addChild("categories_function_list",["insert","insert_function"],(()=>{const e=AC.content;return[...new Set(AC.getAll().filter((e=>!e.hidden)).map((e=>e.category)))].filter(Mt).sort().map(((t,o)=>{const s=Object.keys(e).filter((o=>e[o].category===t&&!e[o].hidden));return{name:t,children:$O(s)}}))})).addChild("insert_link",["insert"],{...UO,separator:!0,sequence:70}).addChild("insert_checkbox",["insert"],{...HO,sequence:80}).addChild("insert_dropdown",["insert"],{...zO,separator:!0,sequence:90}).add("format",{name:ui("Format"),sequence:50}).addChild("format_number",["format"],{...mH,name:ui("Number"),sequence:10,separator:!0}).addChild("format_bold",["format"],{...IM,sequence:20}).addChild("format_italic",["format"],{...wM,sequence:30}).addChild("format_underline",["format"],{...xM,sequence:40}).addChild("format_strikethrough",["format"],{...EM,sequence:50,separator:!0}).addChild("format_font_size",["format"],{...RM,sequence:60,separator:!0}).addChild("format_alignment",["format"],{...TM,sequence:70}).addChild("format_alignment_left",["format","format_alignment"],{...DM,sequence:10}).addChild("format_alignment_center",["format","format_alignment"],{..._M,sequence:20}).addChild("format_alignment_right",["format","format_alignment"],{...FM,sequence:30,separator:!0}).addChild("format_alignment_top",["format","format_alignment"],{...PM,sequence:40}).addChild("format_alignment_middle",["format","format_alignment"],{...MM,sequence:50}).addChild("format_alignment_bottom",["format","format_alignment"],{...NM,sequence:60,separator:!0}).addChild("format_wrapping",["format"],{...kM,sequence:80,separator:!0}).addChild("format_wrapping_overflow",["format","format_wrapping"],{...VM,sequence:10}).addChild("format_wrapping_wrap",["format","format_wrapping"],{...UM,sequence:20}).addChild("format_wrapping_clip",["format","format_wrapping"],{...HM,sequence:30}).addChild("format_cf",["format"],{...zM,sequence:90,separator:!0}).addChild("format_clearFormat",["format"],{...BM,sequence:100,separator:!0}).add("data",{name:ui("Data"),sequence:60}).addChild("sort_range",["data"],{...kP,sequence:10,separator:!0}).addChild("sort_ascending",["data","sort_range"],{...LP,sequence:10}).addChild("sort_descending",["data","sort_range"],{...zP,sequence:20}).addChild("data_cleanup",["data"],{...VP,sequence:15}).addChild("remove_duplicates",["data","data_cleanup"],{...UP,sequence:10}).addChild("trim_whitespace",["data","data_cleanup"],{...HP,sequence:20}).addChild("split_to_columns",["data"],{...GP,sequence:20}).addChild("data_validation",["data"],{name:ui("Data Validation"),execute:e=>{e.openSidePanel("DataValidation")},isEnabled:e=>!e.isSmall,icon:"o-spreadsheet-Icon.DATA_VALIDATION",sequence:30,separator:!0}).addChild("add_remove_data_filter",["data"],{...BP,sequence:40,separator:!0}).addChild("pivot_data_sources",["data"],(e=>{const t=e.model.getters.getPivotIds().length;return e.model.getters.getPivotIds().map(((o,s)=>{const i={get highlights(){return yL(e.model.getters,o)}};return{id:`item_pivot_${e.model.getters.getPivotFormulaId(o)}`,name:e.model.getters.getPivotDisplayName(o),sequence:50+s/t,isReadonlyAllowed:!0,execute:e=>e.openSidePanel("PivotSidePanel",{pivotId:o}),isEnabled:e=>!e.isSmall,onStartHover:e=>e.getStore(DR).register(i),onStopHover:e=>e.getStore(DR).unRegister(i),icon:"o-spreadsheet-Icon.PIVOT",separator:s===e.model.getters.getPivotIds().length-1,secondaryIcon:e=>e.model.getters.isPivotUnused(o)?"o-spreadsheet-Icon.UNUSED_PIVOT_WARNING":void 0}}))})).addChild("reinsert_dynamic_pivot",["data"],WP).addChild("reinsert_static_pivot",["data"],qP);const vH=new class extends n{mapping={};uuidGenerator=new Sl;replace(e,t){const o={...t,id:this.uuidGenerator.uuidv4()};return super.replace(e,o)}getAllOrdered(){return this.getAll().sort(((e,t)=>e.sequence-t.sequence))}};class bH{listeners=[];async sendMessage(e){for(const{callback:t}of this.listeners)t(e)}onNewMessage(e,t){this.listeners.push({id:e,callback:t})}leave(e){this.listeners=this.listeners.filter((t=>t.id!==e))}}class SH{fileStore;constructor(e){this.fileStore=e}async requestImage(){const e=await this.userImageUpload(),t=await this.fileStore.upload(e);return{path:t,size:await this.getImageOriginalSize(t),mimetype:e.type}}async uploadFile(e){const t=await this.fileStore.upload(e);return{path:t,size:await this.getImageOriginalSize(t),mimetype:e.type}}userImageUpload(){return new Promise(((e,t)=>{const o=document.createElement("input");o.setAttribute("type","file"),o.setAttribute("accept","image/*"),o.addEventListener("change",(async()=>{null===o.files||1!==o.files.length?t():e(o.files[0])})),o.click()}))}getImageOriginalSize(e){return new Promise(((t,o)=>{const s=new Image;s.addEventListener("load",(()=>{const e={width:s.width,height:s.height};t(e)})),s.addEventListener("error",o),s.src=e}))}}const CH=[{transform:"scale(0)"},{transform:"scale(0.8)",offset:.33},{opacity:"0",transform:"scale(1)",offset:1}];Bh`
1851
+ `;class uV extends t.Component{static template="o_spreadsheet.PivotHTMLRenderer";static components={Checkbox:nT};static props={pivotId:String,onCellClicked:Function};pivot=this.env.model.getters.getPivot(this.props.pivotId);data={columns:[],rows:[],values:[]};state=t.useState({showMissingValuesOnly:!1});setup(){const e=this.pivot.getExpandedTableStructure(),t=this.env.model.getters.getPivotFormulaId(this.props.pivotId);this.data={columns:this._buildColHeaders(t,e),rows:this._buildRowHeaders(t,e),values:this._buildValues(t,e)}}get tracker(){return this.env.model.getters.getPivotPresenceTracker(this.props.pivotId)}getTableData(){if(!this.state.showMissingValuesOnly)return this.data;const e=this.getColumnsIndexes(),t=this.getRowsIndexes();return{columns:this.buildColumnsMissing(e),rows:this.buildRowsMissing(t),values:this.buildValuesMissing(e,t)}}addRecursiveRow(e){const t=this.pivot.getExpandedTableStructure().rows,o=[...t[e].values];if(o.length<=1)return[e];o.pop();const s=t.findIndex((e=>JSON.stringify(e.values)===JSON.stringify(o)));return[e].concat(this.addRecursiveRow(s))}buildColumnsMissing(e){const t=[];for(const e of this.data.columns){const o=[];for(const t in e)for(let s=0;s<e[t].span;s++)o.push(parseInt(t,10));t.push(o)}for(let o=t[t.length-1].length;o>=0;o--)if(!e.includes(o))for(const e of t)e.splice(o,1);const o=[];for(const e in t){const s=[];let i,n=1;for(let o=0;o<t[e].length;o++)i!==t[e][o]?(void 0!==i&&s.push(Object.assign({},this.data.columns[e][i],{span:n})),i=t[e][o],n=1):n++;void 0!==i&&s.push(Object.assign({},this.data.columns[e][i],{span:n})),o.push(s)}return o}buildRowsMissing(e){return e.map((e=>this.data.rows[e]))}buildValuesMissing(e,t){const o=e.map((()=>[]));for(const s of t)for(const t in e)o[t].push(this.data.values[e[t]][s]);return o}getColumnsIndexes(){const e=new Set;for(let t=0;t<this.data.columns.length;t++){const o=[];for(let e=0;e<this.data.columns[t].length;e++)for(let s=0;s<this.data.columns[t][e].span;s++)o.push(this.data.columns[t][e]);for(let t=0;t<o.length;t++)o[t].isMissing&&e.add(t)}for(let t=0;t<this.data.columns[this.data.columns.length-1].length;t++){this.data.values[t].find((e=>e.isMissing))&&e.add(t)}return Array.from(e).sort(((e,t)=>e-t))}getRowsIndexes(){const e=new Set;for(let t=0;t<this.data.rows.length;t++){this.data.rows[t].isMissing&&e.add(t);for(const o of this.data.values)o[t].isMissing&&this.addRecursiveRow(t).forEach((t=>e.add(t)))}return Array.from(e).sort(((e,t)=>e-t))}_buildColHeaders(e,t){const o=[];for(const s of t.columns){const t=[];for(const o of s){const s=[];for(let e=0;e<o.fields.length;e++)s.push({value:o.fields[e]},{value:o.values[e]});const i=this.pivot.parseArgsToPivotDomain(s),n=this.env.model.getters.getLocale();if("measure"===i.at(-1)?.field){const{value:s,format:r}=this.pivot.getPivotMeasureValue(En(i.at(-1).value),i);t.push({formula:`=PIVOT.HEADER(${sh(e,i).join(",")})`,value:Rr(s,{format:r,locale:n}),span:o.width,isMissing:!this.tracker?.isHeaderPresent(i)})}else{const{value:s,format:r}=this.pivot.getPivotHeaderValueAndFormat(i);t.push({formula:`=PIVOT.HEADER(${sh(e,i).join(",")})`,value:Rr(s,{format:r,locale:n}),span:o.width,isMissing:!this.tracker?.isHeaderPresent(i)})}}o.push(t)}const s=o[o.length-1];return o[o.length-1]=s.map((e=>(e.isMissing||(e.style="color: #756f6f;"),e))),o}_buildRowHeaders(e,t){const o=[];for(const s of t.rows){const t=[];for(let e=0;e<s.fields.length;e++)t.push({value:s.fields[e]},{value:s.values[e]});const i=this.pivot.parseArgsToPivotDomain(t),{value:n,format:r}=this.pivot.getPivotHeaderValueAndFormat(i),a=this.env.model.getters.getLocale(),l={formula:`=PIVOT.HEADER(${sh(e,i).join(",")})`,value:Rr(n,{format:r,locale:a}),isMissing:!this.tracker?.isHeaderPresent(i)};s.indent>1&&(l.style=`padding-left: ${s.indent-10}px`),o.push(l)}return o}_buildValues(e,t){const o=[];for(const s of t.columns.at(-1)||[]){const i=[],n=En(s.values[s.values.length-1]);for(const o of t.rows){const t=[];for(let e=0;e<o.fields.length;e++)t.push({value:o.fields[e]},{value:o.values[e]});for(let e=0;e<s.fields.length-1;e++)t.push({value:s.fields[e]},{value:s.values[e]});const r=this.pivot.parseArgsToPivotDomain(t),{value:a,format:l}=this.pivot.getPivotCellValueAndFormat(n,r),c=this.env.model.getters.getLocale();i.push({formula:`=PIVOT.VALUE(${sh(e,r,n).join(",")})`,value:Rr(a,{format:l,locale:c}),isMissing:!this.tracker?.isValuePresent(n,r)})}o.push(i)}return o}}class gV extends eu{getters;dispatch;canDispatch;constructor({getters:e,stateObserver:t,range:o,dispatch:s,canDispatch:i}){super(t),o.addRangeProvider(this.adaptRanges.bind(this)),this.getters=e,this.dispatch=s,this.canDispatch=i}import(e){}export(e){}adaptRanges(e,t,o){}garbageCollectExternalResources(){}}class pV{id;format;style;sheetId;getRangeString;isFormula=!0;compiledFormula;constructor(e,t,o,s,i,n,r){this.id=e,this.format=o,this.style=s,this.sheetId=n,this.getRangeString=r;let a=0;const l=t.tokens.map((e=>{if("REFERENCE"===e.type){const e=a++;return new mV(i,e,this.sheetId,this.getRangeString)}return e}));this.compiledFormula={...t,dependencies:i,tokens:l}}get content(){return Lt(this.compiledFormula.tokens.map((e=>e.value)))}get contentWithFixedReferences(){let e=0;return Lt(this.compiledFormula.tokens.map((t=>{if("REFERENCE"===t.type){const t=e++;return this.getRangeString(this.compiledFormula.dependencies[t],this.sheetId,{useBoundedReference:!0})}return t.value})))}}class mV{ranges;rangeIndex;sheetId;getRangeString;type="REFERENCE";constructor(e,t,o,s){this.ranges=e,this.rangeIndex=t,this.sheetId=o,this.getRangeString=s}get value(){const e=this.ranges[this.rangeIndex];return this.getRangeString(e,this.sheetId)}}function fV(e){return""===e?NaN:Number(e)}function vV(e){return Object.entries(e).map((([e,t])=>t?bV(parseInt(e,10),t):void 0)).filter(Mt).map((e=>_o(e.left,e.top)+":"+_o(e.right,e.bottom)))}function bV(e,t){return{...t.zone,id:e}}class SV{getters;providers=[];constructor(e){this.getters=e}static getters=["adaptFormulaStringDependencies","copyFormulaStringForSheet","extendRange","getRangeString","getRangeFromSheetXC","createAdaptedRanges","getRangeData","getRangeDataFromXc","getRangeDataFromZone","getRangeFromRangeData","getRangeFromZone","getRangesUnion","recomputeRanges","isRangeValid","removeRangesSheetPrefix"];allowDispatch(e){return"MOVE_RANGES"===e.type?1===e.target.length?"Success":"InvalidZones":"Success"}beforeHandle(e){}handle(e){const t=Wa(e);t?.applyChange&&this.executeOnAllRanges(t.applyChange,t.sheetId,t.sheetName)}finalize(){}verifyRangeRemoved(e){return t=>{const o=e(t);return"NONE"===o.changeType||Bo(o.range.zone)?o:{range:o.range,changeType:"REMOVE"}}}executeOnAllRanges(e,t,o){const s=this.verifyRangeRemoved(e);for(const e of this.providers)e(s,t,o)}addRangeProvider(e){this.providers.push(e)}createAdaptedRanges(e,t,o,s){return e.map((e=>{if(!Bo(e.zone))return e;const i=e.prefixSheet?e.sheetId:s,n=Ua(e),r=Va(e),a={...e.unboundedZone,left:n&&!e.unboundedZone.hasHeader?e.unboundedZone.left:e.unboundedZone.left+(e.parts[0].colFixed?0:t),right:n?e.unboundedZone.right:e.unboundedZone.right+((e.parts[1]||e.parts[0]).colFixed?0:t),top:r&&!e.unboundedZone.hasHeader?e.unboundedZone.top:e.unboundedZone.top+(e.parts[0].rowFixed?0:o),bottom:r?e.unboundedZone.bottom:e.unboundedZone.bottom+((e.parts[1]||e.parts[0]).rowFixed?0:o)};return function(e){if($o(e.zone))return e;const t={...e.unboundedZone},o={...e.zone};let s=e.parts;if(void 0!==t.right&&t.right<t.left){const e=t.right;t.right=t.left,t.left=e,o.right=o.left,o.left=e,s=[{colFixed:s[1]?.colFixed||!1,rowFixed:s[0]?.rowFixed||!1},{colFixed:s[0]?.colFixed||!1,rowFixed:s[1]?.rowFixed||!1}]}if(void 0!==t.bottom&&t.bottom<t.top){const e=t.bottom;t.bottom=t.top,t.top=e,o.bottom=o.top,o.top=e,s=[{colFixed:s[0]?.colFixed||!1,rowFixed:s[1]?.rowFixed||!1},{colFixed:s[1]?.colFixed||!1,rowFixed:s[0]?.rowFixed||!1}]}return{unboundedZone:t,zone:o,parts:s,invalidXc:e.invalidXc,prefixSheet:e.prefixSheet,invalidSheetName:e.invalidSheetName,sheetId:e.sheetId}}(Na({...e,sheetId:i,zone:a},this.getters.getSheetSize))}))}removeRangesSheetPrefix(e,t){return t.map((t=>t.prefixSheet&&t.sheetId===e?{...t,prefixSheet:!1}:t))}extendRange(e,t,o){const s="COL"===t?e.zone.right+o:e.zone.right,i="ROW"===t?e.zone.bottom+o:e.zone.bottom,n={left:e.zone.left,top:e.zone.top,right:Ua(e)?void 0:s,bottom:Va(e)?void 0:i};return Na({...e,zone:n},this.getters.getSheetSize)}getRangeFromSheetXC(e,t){if(!Ia.test(t)||!this.getters.tryGetSheet(e))return La(t);const{sheetName:o}=Ta(t);return ka({xc:t,sheetId:this.getters.getSheetIdByName(o)||e,invalidSheetName:o&&!this.getters.getSheetIdByName(o)?o:void 0},this.getters.getSheetSize)}getRangeString(e,t,o={useBoundedReference:!1,useFixedReference:!1}){return e?e.invalidXc?e.invalidXc:this.getters.tryGetSheet(e.sheetId)?Ha(e,t,this.getters.getSheetName,o):sn.InvalidReference:sn.InvalidReference}getRangeDataFromXc(e,t){const o=this.getters.getRangeFromSheetXC(e,t);return this.getRangeDataFromZone(o.sheetId,o.unboundedZone)}getRangeDataFromZone(e,t){return{_sheetId:e,_zone:t=this.getters.getUnboundedZone(e,t)}}getRangeData(e){return this.getRangeDataFromZone(e.sheetId,e.unboundedZone)}getRangeFromZone(e,t){return Na({sheetId:e,zone:t,parts:[{colFixed:!1,rowFixed:!1},{colFixed:!1,rowFixed:!1}],prefixSheet:!1},this.getters.getSheetSize)}recomputeRanges(e,t){const o=e.map((e=>e.unboundedZone)),s=t.map((e=>e.unboundedZone));return Fo(o,s).map((t=>this.getRangeFromZone(e[0].sheetId,t)))}getRangeFromRangeData(e){if(!this.getters.tryGetSheet(e._sheetId))return La(sn.InvalidReference);return Na({prefixSheet:!1,zone:e._zone,sheetId:e._sheetId,invalidSheetName:void 0,parts:[{colFixed:!1,rowFixed:!1},{colFixed:!1,rowFixed:!1}]},this.getters.getSheetSize)}isRangeValid(e){if(!e)return!1;const{xc:t,sheetName:o}=Ta(e);return null!==t.match(Ia)&&(!o||void 0!==this.getters.getSheetIdByName(o))}getRangesUnion(e){const t=e.map((e=>e.unboundedZone)),o=function(...e){return{top:Math.min(...e.map((e=>e.top))),left:Math.min(...e.map((e=>e.left))),bottom:e.some((e=>void 0===e.bottom))?void 0:Math.max(...e.map((e=>e.bottom))),right:e.some((e=>void 0===e.right))?void 0:Math.max(...e.map((e=>e.right)))}}(...t);return this.getRangeFromZone(e[0].sheetId,o)}adaptFormulaStringDependencies(e,t,o){if(!t.startsWith("="))return t;const s=$C(t),i=s.dependencies.map((t=>{const s=this.getters.getRangeFromSheetXC(e,t),i=o(s);return"NONE"===i.changeType?s:i.range}));return this.getters.getFormulaString(e,s.tokens,i)}copyFormulaStringForSheet(e,t,o,s){if(!o.startsWith("="))return o;const i=$C(o),n=i.dependencies.map((o=>{const i=this.getters.getRangeFromSheetXC(e,o);return"keepSameReference"===s?i:za(e,t,i)}));return this.getters.getFormulaString(t,i.tokens,n)}}function CV(e,t){if(!e)return;const o=t(e);switch(o.changeType){case"NONE":return e;case"REMOVE":return;default:return o.range}}class yV extends eu{getters;constructor({getters:e,stateObserver:t}){super(t),this.getters=e}}const IV=new n;IV.add("pivots",(e=>{for(const t of e.getPivotIds()){const o=e.getPivot(t);o.markAsDirtyForEvaluation?.()}}));const wV=AC.mapping;function xV(e,t,o){return new EV(e,t,o).getParameters()}class EV{getters;computeCell;evalContext;rangeCache={};constructor(e,t,o){this.getters=t,this.computeCell=o,this.evalContext=Object.assign(Object.create(wV),e,{getters:this.getters,locale:this.getters.getLocale()})}getParameters(){return{referenceDenormalizer:this.refFn.bind(this),ensureRange:this.range.bind(this),evalContext:this.evalContext}}refFn(e,t){const o=this.getRangeError(e);if(o)return o;const s={sheetId:e.sheetId,col:e.zone.left,row:e.zone.top};if(t){this.computeCell(s);return{value:Aa(this.getters.getSheetName(e.sheetId),Go(e.zone))}}return this.computeCell(s)}range(e,t){const o=this.getRangeError(e);if(o)return[[o]];const s=e.sheetId,i=e.zone,n=Xo(i,this.getters.getSheetZone(s));if(!n)return[[]];const{top:r,left:a,bottom:l,right:c}=i,h=`${s}-${r}-${a}-${l}-${c}-${t}`;if(h in this.rangeCache)return this.rangeCache[h];const d=n.bottom-n.top+1,u=n.right-n.left+1,g=new Array(u),p=this.getters.getSheetName(e.sheetId);for(let e=n.left;e<=n.right;e++){const o=e-n.left;g[o]=new Array(d);for(let i=n.top;i<=n.bottom;i++){const r=i-n.top,a=this.computeCell({sheetId:s,col:e,row:i});g[o][r]=t?{value:Aa(p,_o(e,i))}:a}}return this.rangeCache[h]=g,g}getRangeError(e){return Bo(e.zone)?e.invalidSheetName?new cn(ui("Invalid sheet name: %s",e.invalidSheetName)):void 0:new cn}}function RV(e,t,o,s,i){TV(e,t,o||0,s||e.length-1,i||DV)}function TV(e,t,o,s,i){for(;s>o;){if(s-o>600){var n=s-o+1,r=t-o+1,a=Math.log(n),l=.5*Math.exp(2*a/3),c=.5*Math.sqrt(a*l*(n-l)/n)*(r-n/2<0?-1:1);TV(e,t,Math.max(o,Math.floor(t-r*l/n+c)),Math.min(s,Math.floor(t+(n-r)*l/n+c)),i)}var h=e[t],d=o,u=s;for(AV(e,o,t),i(e[s],h)>0&&AV(e,o,s);d<u;){for(AV(e,d,u),d++,u--;i(e[d],h)<0;)d++;for(;i(e[u],h)>0;)u--}0===i(e[o],h)?AV(e,o,u):AV(e,++u,s),u<=t&&(o=u+1),t<=u&&(s=u-1)}}function AV(e,t,o){var s=e[t];e[t]=e[o],e[o]=s}function DV(e,t){return e<t?-1:e>t?1:0}class _V{constructor(e=9){this._maxEntries=Math.max(4,e),this._minEntries=Math.max(2,Math.ceil(.4*this._maxEntries)),this.clear()}all(){return this._all(this.data,[])}search(e){let t=this.data;const o=[];if(!zV(e,t))return o;const s=this.toBBox,i=[];for(;t;){for(let n=0;n<t.children.length;n++){const r=t.children[n],a=t.leaf?s(r):r;zV(e,a)&&(t.leaf?o.push(r):HV(e,a)?this._all(r,o):i.push(r))}t=i.pop()}return o}collides(e){let t=this.data;if(!zV(e,t))return!1;const o=[];for(;t;){for(let s=0;s<t.children.length;s++){const i=t.children[s],n=t.leaf?this.toBBox(i):i;if(zV(e,n)){if(t.leaf||HV(e,n))return!0;o.push(i)}}t=o.pop()}return!1}load(e){if(!e||!e.length)return this;if(e.length<this._minEntries){for(let t=0;t<e.length;t++)this.insert(e[t]);return this}let t=this._build(e.slice(),0,e.length-1,0);if(this.data.children.length)if(this.data.height===t.height)this._splitRoot(this.data,t);else{if(this.data.height<t.height){const e=this.data;this.data=t,t=e}this._insert(t,this.data.height-t.height-1,!0)}else this.data=t;return this}insert(e){return e&&this._insert(e,this.data.height-1),this}clear(){return this.data=BV([]),this}remove(e,t){if(!e)return this;let o=this.data;const s=this.toBBox(e),i=[],n=[];let r,a,l;for(;o||i.length;){if(o||(o=i.pop(),a=i[i.length-1],r=n.pop(),l=!0),o.leaf){const s=FV(e,o.children,t);if(-1!==s)return o.children.splice(s,1),i.push(o),this._condense(i),this}l||o.leaf||!HV(o,s)?a?(r++,o=a.children[r],l=!1):o=null:(i.push(o),n.push(r),r=0,a=o,o=o.children[0])}return this}toBBox(e){return e}compareMinX(e,t){return e.minX-t.minX}compareMinY(e,t){return e.minY-t.minY}toJSON(){return this.data}fromJSON(e){return this.data=e,this}_all(e,t){const o=[];for(;e;)e.leaf?t.push(...e.children):o.push(...e.children),e=o.pop();return t}_build(e,t,o,s){const i=o-t+1;let n,r=this._maxEntries;if(i<=r)return n=BV(e.slice(t,o+1)),OV(n,this.toBBox),n;s||(s=Math.ceil(Math.log(i)/Math.log(r)),r=Math.ceil(i/Math.pow(r,s-1))),n=BV([]),n.leaf=!1,n.height=s;const a=Math.ceil(i/r),l=a*Math.ceil(Math.sqrt(r));$V(e,t,o,l,this.compareMinX);for(let i=t;i<=o;i+=l){const t=Math.min(i+l-1,o);$V(e,i,t,a,this.compareMinY);for(let o=i;o<=t;o+=a){const i=Math.min(o+a-1,t);n.children.push(this._build(e,o,i,s-1))}}return OV(n,this.toBBox),n}_chooseSubtree(e,t,o,s){for(;s.push(t),!t.leaf&&s.length-1!==o;){let o,s=1/0,r=1/0;for(let a=0;a<t.children.length;a++){const l=t.children[a],c=LV(l),h=(i=e,n=l,(Math.max(n.maxX,i.maxX)-Math.min(n.minX,i.minX))*(Math.max(n.maxY,i.maxY)-Math.min(n.minY,i.minY))-c);h<r?(r=h,s=c<s?c:s,o=l):h===r&&c<s&&(s=c,o=l)}t=o||t.children[0]}var i,n;return t}_insert(e,t,o){const s=o?e:this.toBBox(e),i=[],n=this._chooseSubtree(s,this.data,t,i);for(n.children.push(e),MV(n,s);t>=0&&i[t].children.length>this._maxEntries;)this._split(i,t),t--;this._adjustParentBBoxes(s,i,t)}_split(e,t){const o=e[t],s=o.children.length,i=this._minEntries;this._chooseSplitAxis(o,i,s);const n=this._chooseSplitIndex(o,i,s),r=BV(o.children.splice(n,o.children.length-n));r.height=o.height,r.leaf=o.leaf,OV(o,this.toBBox),OV(r,this.toBBox),t?e[t-1].children.push(r):this._splitRoot(o,r)}_splitRoot(e,t){this.data=BV([e,t]),this.data.height=e.height+1,this.data.leaf=!1,OV(this.data,this.toBBox)}_chooseSplitIndex(e,t,o){let s,i=1/0,n=1/0;for(let r=t;r<=o-t;r++){const t=PV(e,0,r,this.toBBox),a=PV(e,r,o,this.toBBox),l=UV(t,a),c=LV(t)+LV(a);l<i?(i=l,s=r,n=c<n?c:n):l===i&&c<n&&(n=c,s=r)}return s||o-t}_chooseSplitAxis(e,t,o){const s=e.leaf?this.compareMinX:NV,i=e.leaf?this.compareMinY:kV;this._allDistMargin(e,t,o,s)<this._allDistMargin(e,t,o,i)&&e.children.sort(s)}_allDistMargin(e,t,o,s){e.children.sort(s);const i=this.toBBox,n=PV(e,0,t,i),r=PV(e,o-t,o,i);let a=VV(n)+VV(r);for(let s=t;s<o-t;s++){const t=e.children[s];MV(n,e.leaf?i(t):t),a+=VV(n)}for(let s=o-t-1;s>=t;s--){const t=e.children[s];MV(r,e.leaf?i(t):t),a+=VV(r)}return a}_adjustParentBBoxes(e,t,o){for(let s=o;s>=0;s--)MV(t[s],e)}_condense(e){for(let t,o=e.length-1;o>=0;o--)0===e[o].children.length?o>0?(t=e[o-1].children,t.splice(t.indexOf(e[o]),1)):this.clear():OV(e[o],this.toBBox)}}function FV(e,t,o){if(!o)return t.indexOf(e);for(let s=0;s<t.length;s++)if(o(e,t[s]))return s;return-1}function OV(e,t){PV(e,0,e.children.length,t,e)}function PV(e,t,o,s,i){i||(i=BV(null)),i.minX=1/0,i.minY=1/0,i.maxX=-1/0,i.maxY=-1/0;for(let n=t;n<o;n++){const t=e.children[n];MV(i,e.leaf?s(t):t)}return i}function MV(e,t){return e.minX=Math.min(e.minX,t.minX),e.minY=Math.min(e.minY,t.minY),e.maxX=Math.max(e.maxX,t.maxX),e.maxY=Math.max(e.maxY,t.maxY),e}function NV(e,t){return e.minX-t.minX}function kV(e,t){return e.minY-t.minY}function LV(e){return(e.maxX-e.minX)*(e.maxY-e.minY)}function VV(e){return e.maxX-e.minX+(e.maxY-e.minY)}function UV(e,t){const o=Math.max(e.minX,t.minX),s=Math.max(e.minY,t.minY),i=Math.min(e.maxX,t.maxX),n=Math.min(e.maxY,t.maxY);return Math.max(0,i-o)*Math.max(0,n-s)}function HV(e,t){return e.minX<=t.minX&&e.minY<=t.minY&&t.maxX<=e.maxX&&t.maxY<=e.maxY}function zV(e,t){return t.minX<=e.maxX&&t.minY<=e.maxY&&t.maxX>=e.minX&&t.maxY>=e.minY}function BV(e){return{children:e,height:1,leaf:!0,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0}}function $V(e,t,o,s,i){const n=[t,o];for(;n.length;){if((o=n.pop())-(t=n.pop())<=s)continue;const r=t+Math.ceil((o-t)/s/2)*s;RV(e,r,t,o,i),n.push(t,r,r,o)}}class GV{rTrees={};constructor(e=[]){const t={};for(const o of e){const e=o.boundingBox.sheetId;t[e]||(t[e]=[]),t[e].push(o)}for(const e in t)this.rTrees[e]=new WV,this.rTrees[e].load(t[e])}insert(e){const t=e.boundingBox.sheetId;this.rTrees[t]||(this.rTrees[t]=new WV),this.rTrees[t].insert(e)}search({zone:e,sheetId:t}){return this.rTrees[t]?this.rTrees[t].search({minX:e.left,minY:e.top,maxX:e.right,maxY:e.bottom}):[]}remove(e){const t=e.boundingBox.sheetId;this.rTrees[t]&&this.rTrees[t].remove(e,this.rtreeItemComparer)}rtreeItemComparer(e,t){return e.boundingBox.sheetId===t.boundingBox.sheetId&&e.boundingBox?.zone.left===t.boundingBox.zone.left&&e.boundingBox?.zone.top===t.boundingBox.zone.top&&e.boundingBox?.zone.right===t.boundingBox.zone.right&&e.boundingBox?.zone.bottom===t.boundingBox.zone.bottom&&zt(e.data,t.data)}}class WV extends _V{toBBox({boundingBox:e}){const t=e.zone;return{minX:t.left,minY:t.top,maxX:t.right,maxY:t.bottom}}compareMinX(e,t){return e.boundingBox.zone.left-t.boundingBox.zone.left}compareMinY(e,t){return e.boundingBox.zone.top-t.boundingBox.zone.top}}class qV{profilesStartingPosition=[0];profiles=new Map([[0,[]]]);constructor(e=[]){for(const t of e)this.add(t)}isEmpty(){return 1===this.profiles.size&&0===this.profiles.get(0)?.length}add(e){Oo(this.profilesStartingPosition,this.profiles,[e])}delete(e){Oo(this.profilesStartingPosition,this.profiles,[e],!0)}has(e){return function(e,t,o){const s=o.left,i=o.right,n=o.top,r=o.bottom+1,a=Lo(e,s,0),l=Lo(e,i,a);if(-1===a||-1===l)return!1;for(let o=a;o<=l;o++){const s=t.get(e[o]),i=Lo(s,n,0,!0),a=Vo(s,r,0,!0);if(-1===i||i%2!=0)return!1;if(n<s[i]||r>s[a])return!1}return!0}(this.profilesStartingPosition,this.profiles,e)}difference(e){const t=this.copy();for(const o of e)t.delete(o);return t}copy(){const e=new qV;e.profilesStartingPosition=[...this.profilesStartingPosition],e.profiles=new Map;for(const[t,o]of this.profiles)e.profiles.set(t,[...o]);return e}size(){let e=0;for(const t of this.profiles.values())e+=t.length;return e/2}[Symbol.iterator](){return ko(this.profilesStartingPosition,this.profiles)[Symbol.iterator]()}}class ZV{setsBySheetId={};constructor(e=[]){for(const t of e)this.add(t)}add(e){this.setsBySheetId[e.sheetId]||(this.setsBySheetId[e.sheetId]=new qV),this.setsBySheetId[e.sheetId].add(e.zone)}addMany(e){for(const t of e)this.add(t)}addPosition(e){this.add(Ga(e))}addManyPositions(e){for(const t of e)this.addPosition(t)}has(e){return!!this.setsBySheetId[e.sheetId]&&this.setsBySheetId[e.sheetId].has(e.zone)}hasPosition(e){return this.has(Ga(e))}delete(e){this.setsBySheetId[e.sheetId]&&this.setsBySheetId[e.sheetId].delete(e.zone)}deleteMany(e){for(const t of e)this.delete(t)}deleteManyPositions(e){for(const t of e)this.delete(Ga(t))}difference(e){const t=new ZV;for(const e in this.setsBySheetId)t.setsBySheetId[e]=this.setsBySheetId[e];for(const o in e.setsBySheetId)t.setsBySheetId[o]&&(t.setsBySheetId[o]=t.setsBySheetId[o].difference(e.setsBySheetId[o]));return t}copy(){const e=new ZV;for(const t in this.setsBySheetId)e.setsBySheetId[t]=this.setsBySheetId[t].copy();return e}clear(){this.setsBySheetId={}}size(){let e=0;for(const t in this.setsBySheetId)e+=this.setsBySheetId[t].size();return e}isEmpty(){for(const e in this.setsBySheetId)if(!this.setsBySheetId[e].isEmpty())return!1;return!0}[Symbol.iterator](){const e=[];for(const t in this.setsBySheetId)for(const o of this.setsBySheetId[t])e.push({sheetId:t,zone:o});return e[Symbol.iterator]()}}class jV{rTree;constructor(e=[]){const t=function(e){let t=0,o=0;for(let s=0;s<e.length;s++){const i=e[s].boundingBox.zone;i.right>t&&(t=i.right),i.bottom>o&&(o=i.bottom)}t+=1,o+=1;const s=(((o+1)*t+1)*o+1)*t<=Number.MAX_SAFE_INTEGER;s||console.warn("Max col/row size exceeded, using slow zone key");const i={};for(const n of e){const e=n.boundingBox.sheetId;i[e]||(i[e]={});const r=n.boundingBox.zone;let a=0;if(a=s?r.left+r.top*t+r.right*t*o+r.bottom*t*o*t:`${r.left},${r.top},${r.right},${r.bottom}`,i[e][a]){i[e][a].data.add(n.data)}else i[e][a]={boundingBox:n.boundingBox,data:new ZV([n.data])}}const n=[];for(const e in i){const t=i[e];for(const e in t)n.push(t[e])}return n}(e);this.rTree=new GV(t)}insert(e){const t=this.rTree.search(e.boundingBox),o=e.boundingBox,s=t.find((({boundingBox:e})=>e.sheetId===o.sheetId&&e.zone.left===o.zone.left&&e.zone.top===o.zone.top&&e.zone.right===o.zone.right&&e.zone.bottom===o.zone.bottom));s?s.data.add(e.data):this.rTree.insert({...e,data:new ZV([e.data])})}search({zone:e,sheetId:t}){const o=new ZV;for(const{data:s}of this.rTree.search({zone:e,sheetId:t}))o.addMany(s);return o}remove(e){const t=this.rTree.search(e.boundingBox),o=e.boundingBox,s=t.find((({boundingBox:e})=>e.sheetId===o.sheetId&&e.zone.left===o.zone.left&&e.zone.top===o.zone.top&&e.zone.right===o.zone.right&&e.zone.bottom===o.zone.bottom));s?s.data.delete(e.data):this.rTree.remove({...e,data:new ZV([e.data])})}}class YV{dependencies=new tF;rTree;constructor(e=[]){this.rTree=new jV(e)}removeAllDependencies(e){const t=this.dependencies.get(e);if(t){for(const e of t)this.rTree.remove(e);this.dependencies.delete(e)}}addDependencies(e,t){const o=t.map((({sheetId:t,zone:o})=>({data:{sheetId:e.sheetId,zone:cs(e)},boundingBox:{zone:o,sheetId:t}})));for(const e of o)this.rTree.insert(e);const s=this.dependencies.get(e);s?s.push(...o):this.dependencies.set(e,o)}getCellsDependingOn(e,t=new ZV){t=t.copy();const o=Array.from(e).reverse();for(;o.length>0;){const e=o.pop();t.add(e);const s=this.rTree.search(e);o.push(...s.difference(t))}for(const o of e)t.delete(o);return t}}class XV extends Uint32Array{columnOffset=0;cols=0;rows=0;static create(e,t){const o=function(e){if(0===e)return-1/0;if(e<0)return NaN;return 32-Math.clz32(--e)}(t),s=new this((e<<o>>5)+1);return s.columnOffset=o,s.cols=t,s.rows=e,s}getValue(e){const[t,o]=this.getCoordinates(e);return this[t]>>o&1}setValue(e,t){const[o,s]=this.getCoordinates(e),i=0===(this[o]>>s&1)&&1===t;return this[o]=this[o]&~(1<<s)|t<<s,i}isEmpty(){return!this.some((e=>0!==e))}fillAllPositions(){this.fill(-1>>>0)}clear(){this.fill(0)}getCoordinates(e){const{row:t,col:o}=e,s=(t<<this.columnOffset)+o,i=s>>5;return[i,s-(i<<5)]}}class KV{sheets={};insertions=[];maxSize=0;constructor(e){for(const t in e){const o=e[t].cols,s=e[t].rows;this.maxSize+=o*s,this.sheets[t]=XV.create(s,o)}}add(e){this.sheets[e.sheetId].setValue(e,1)&&this.insertions.push(e)}addMany(e){for(const t of e)this.add(t)}delete(e){this.sheets[e.sheetId].setValue(e,0)}deleteMany(e){for(const t of e)this.delete(t)}has(e){return 1===this.sheets[e.sheetId].getValue(e)}clear(){const e=[...this];this.insertions=[];for(const e in this.sheets)this.sheets[e].clear();return e}isEmpty(){if(0===this.insertions.length)return!0;for(const e in this.sheets)if(!this.sheets[e].isEmpty())return!1;return!0}fillAllPositions(){this.insertions=new Array(this.maxSize);let e=0;for(const t in this.sheets){const o=this.sheets[t];o.fillAllPositions();for(let s=0;s<o.rows;s++)for(let i=0;i<o.cols;i++)this.insertions[e++]={sheetId:t,row:s,col:i}}}*[Symbol.iterator](){for(const e of this.insertions)1===this.sheets[e.sheetId].getValue(e)&&(yield e)}}class JV{resultsToArrayFormulas=new GV;arrayFormulasToResults=new tF;searchFormulaPositionsSpreadingOn(e,t){return this.resultsToArrayFormulas.search({sheetId:e,zone:t}).map((e=>e.data))||QV}getArrayResultZone(e){return this.arrayFormulasToResults.get(e)}removeNode(e){this.resultsToArrayFormulas.remove({boundingBox:{sheetId:e.sheetId,zone:cs(e)},data:e}),this.arrayFormulasToResults.delete(e)}addRelation({arrayFormulaPosition:e,resultZone:t}){this.resultsToArrayFormulas.insert({boundingBox:{sheetId:e.sheetId,zone:t},data:e}),this.arrayFormulasToResults.set(e,t)}isArrayFormula(e){return this.arrayFormulasToResults.has(e)}}const QV=[],eU=Object.freeze(ta({...new ln,origin:void 0})),tU=Object.freeze(ta({value:null}));class oU{context;getters;compilationParams;evaluatedCells=new tF;formulaDependencies=Vt(new YV);blockedArrayFormulas=new KV({});spreadingRelations=new JV;constructor(e,t){this.context=e,this.getters=t,this.compilationParams=xV(this.context,this.getters,this.computeAndSave.bind(this))}getEvaluatedCell(e){return this.evaluatedCells.get(e)||tU}getSpreadZone(e,t={ignoreSpillError:!1}){const o=this.spreadingRelations.getArrayResultZone(e);if(!o)return;const s=this.evaluatedCells.get(e);return s?.type!==r.error||t.ignoreSpillError&&s?.value===sn.SpilledBlocked?Yo(cs(e),o):cs(e)}getEvaluatedPositions(){return this.evaluatedCells.keys()}getEvaluatedPositionsInSheet(e){return this.evaluatedCells.keysForSheet(e)}getArrayFormulaSpreadingOn(e){if(this.getEvaluatedCell(e).type===r.empty)return;return this.spreadingRelations.searchFormulaPositionsSpreadingOn(e.sheetId,cs(e)).find((e=>!this.blockedArrayFormulas.has(e)))}updateDependencies(e){this.formulaDependencies().removeAllDependencies(e);const t=this.getDirectDependencies(e);this.formulaDependencies().addDependencies(e,t)}addDependencies(e,t){this.formulaDependencies().addDependencies(e,t);for(const e of t){const t=e.sheetId,{left:o,bottom:s,right:i,top:n}=e.zone;for(let e=o;e<=i;e++)for(let o=n;o<=s;o++)this.computeAndSave({sheetId:t,col:e,row:o})}}updateCompilationParameters(){this.compilationParams=xV(this.context,this.getters,this.computeAndSave.bind(this)),this.compilationParams.evalContext.updateDependencies=this.updateDependencies.bind(this),this.compilationParams.evalContext.addDependencies=this.addDependencies.bind(this),this.compilationParams.evalContext.lookupCaches={forwardSearch:new Map,reverseSearch:new Map}}createEmptyPositionSet(){const e={};for(const t of this.getters.getSheetIds())e[t]={rows:this.getters.getNumberRows(t),cols:this.getters.getNumberCols(t)};return new KV(e)}evaluateCells(e){const t=performance.now(),o=new ZV;o.addManyPositions(e);const s=this.getArrayFormulasImpactedByChangesOf(e);o.addMany(this.getCellsDependingOn(o)),o.addMany(s),o.addMany(this.getCellsDependingOn(s)),this.evaluate(o),console.debug("evaluate Cells",performance.now()-t,"ms")}getArrayFormulasImpactedByChangesOf(e){const t=new ZV;for(const o of e){const e=this.getters.getCell(o)?.content,s=this.getArrayFormulaSpreadingOn(o);void 0!==s&&t.addPosition(s),e||t.addPosition(o)}for(const e of[...t])t.addMany(this.getArrayFormulasBlockedBy(e.sheetId,e.zone));return t}buildDependencyGraph(){this.blockedArrayFormulas=this.createEmptyPositionSet(),this.spreadingRelations=new JV,this.formulaDependencies=Vt((()=>{const e=[];for(const t of this.getters.getSheetIds()){const o=this.getters.getCells(t);for(const s in o){const i=o[s];if(i.isFormula){const o=i.compiledFormula.dependencies;for(const i of o)i.invalidSheetName||i.invalidXc||e.push({data:{sheetId:t,zone:cs(this.getters.getCellPosition(s))},boundingBox:{sheetId:i.sheetId,zone:i.zone}})}}}return new YV(e)}))}evaluateAllCells(){const e=performance.now();this.evaluatedCells=new tF;const t=[];for(const e of this.getters.getSheetIds()){const o=this.getters.getSheetZone(e);t.push({sheetId:e,zone:o})}this.evaluate(t),console.debug("evaluate all cells",performance.now()-e,"ms")}evaluateFormulaResult(e,t){const o=$C(t),s=o.dependencies.map((t=>this.getters.getRangeFromSheetXC(e,t)));return this.updateCompilationParameters(),this.evaluateCompiledFormula(e,{...o,dependencies:s})}evaluateCompiledFormula(e,t,o){try{const s=nU(t,this.compilationParams,e,this.buildSafeGetSymbolValue(o),this.compilationParams.evalContext.__originCellPosition);return E(s)?Un(s,iU):iU(s)}catch(e){return DC(e,"")}}getArrayFormulasBlockedBy(e,t){const o=new ZV,s=this.spreadingRelations.searchFormulaPositionsSpreadingOn(e,t);o.addManyPositions(s);const i=[...s].filter((e=>!this.blockedArrayFormulas.has(e)));return i.length&&o.deleteManyPositions(i),o.addMany(this.getCellsDependingOn(o)),o}nextRangesToUpdate=new ZV;cellsBeingComputed=new Set;symbolsBeingComputed=new Set;evaluate(e){this.cellsBeingComputed=new Set,this.nextRangesToUpdate=new ZV(e);let t=0;for(;!this.nextRangesToUpdate.isEmpty()&&t++<30;){this.updateCompilationParameters();const e=[...this.nextRangesToUpdate];this.nextRangesToUpdate.clear(),this.clearEvaluatedRanges(e);for(const t of e){const{left:e,bottom:o,right:s,top:i}=t.zone;for(let n=e;n<=s;n++)for(let e=i;e<=o;e++){const o={sheetId:t.sheetId,col:n,row:e};if(this.nextRangesToUpdate.hasPosition(o))continue;const s=this.computeCell(o);s!==tU&&this.evaluatedCells.set(o,s)}}IV.getAll().forEach((e=>e(this.getters)))}t>=30&&console.warn("Maximum iteration reached while evaluating cells")}clearEvaluatedRanges(e){for(const t of e){const{left:e,bottom:o,right:s,top:i}=t.zone;for(let n=e;n<=s;n++)for(let e=i;e<=o;e++)this.evaluatedCells.delete({sheetId:t.sheetId,col:n,row:e})}}computeCell(e){const t=this.evaluatedCells.get(e);if(t)return t;this.blockedArrayFormulas.has(e)||this.invalidateSpreading(e),this.spreadingRelations.isArrayFormula(e)&&this.spreadingRelations.removeNode(e);const o=this.getters.getCell(e);if(void 0===o)return tU;const s=o.id,i={format:o.format,locale:this.getters.getLocale()};try{return this.cellsBeingComputed.has(s)?eU:(this.cellsBeingComputed.add(s),o.isFormula?this.computeFormulaCell(e,o):Qr(o,i,e))}catch(t){return t.value=t?.value||sn.GenericError,t.message=t?.message||FC,t.origin=e,ta(t)}finally{this.cellsBeingComputed.delete(s)}}computeAndSave(e){const t=this.computeCell(e);return this.evaluatedCells.has(e)||this.evaluatedCells.set(e,t),t}computeFormulaCell(e,t){const o=nU(t.compiledFormula,this.compilationParams,e.sheetId,this.buildSafeGetSymbolValue(),e);if(!E(o)){const s=ta(iU(o),this.getters.getLocale(),t,e);return s.type===r.error&&(s.errorOriginPosition=o.errorOriginPosition??e),s}this.assertSheetHasEnoughSpaceToSpreadFormulaResult(e,o);const s=o.length,i=o[0].length,n={top:e.row,bottom:e.row+i-1,left:e.col,right:e.col+s-1};return this.spreadingRelations.addRelation({resultZone:n,arrayFormulaPosition:e}),this.assertNoMergedCellsInSpreadZone(e,o),sU(s,i,this.checkCollision(e)),sU(s,i,this.spreadValues(e,o)),this.invalidatePositionsDependingOnSpread(e.sheetId,n),ta(iU(o[0][0]),this.getters.getLocale(),t)}invalidatePositionsDependingOnSpread(e,t){const o=this.getCellsDependingOn(function(e){const{top:t,left:o,bottom:s,right:i}=e;if(1===gs(e))return[];const n={top:t+1,bottom:s,left:o,right:o};if(i===o)return[n];const r={top:t,bottom:s,left:o+1,right:i};return t===s?[r]:[n,r]}(t).map((t=>({sheetId:e,zone:t}))));o.delete({sheetId:e,zone:t}),this.nextRangesToUpdate.addMany(o)}assertSheetHasEnoughSpaceToSpreadFormulaResult({sheetId:e,col:t,row:o},s){const i=this.getters.getNumberCols(e),n=this.getters.getNumberRows(e),r=t+s.length<=i,a=o+s[0].length<=n;if(!r||!a){if(r)throw new un(ui("Result couldn't be automatically expanded. Please insert more rows."));if(a)throw new un(ui("Result couldn't be automatically expanded. Please insert more columns."));throw new un(ui("Result couldn't be automatically expanded. Please insert more columns and rows."))}}assertNoMergedCellsInSpreadZone({sheetId:e,col:t,row:o},s){if(0!==this.getters.getMergesInZone(e,{top:o,bottom:o+s[0].length-1,left:t,right:t+s.length-1}).length)throw new un(ui("Merged cells found in the spill zone. Please unmerge cells before using array formulas."))}checkCollision(e){const{sheetId:t,col:o,row:s}=e;return(i,n)=>{const a={sheetId:t,col:i+o,row:n+s},l=this.getters.getCell(a);if(l?.content||this.getters.getEvaluatedCell(a).type!==r.empty)throw this.blockedArrayFormulas.add(e),new un(ui("Array result was not expanded because it would overwrite data in %s.",_o(a.col,a.row)));this.blockedArrayFormulas.delete(e)}}spreadValues({sheetId:e,col:t,row:o},s){return(i,n)=>{const a={sheetId:e,col:i+t,row:n+o},l=this.getters.getCell(a),c=ta(iU(s[i][n]),this.getters.getLocale(),l,a);c.type===r.error&&(c.errorOriginPosition=s[i][n].errorOriginPosition??a),this.evaluatedCells.set(a,c)}}invalidateSpreading(e){const t=this.spreadingRelations.getArrayResultZone(e);if(!t)return;for(let o=t.left;o<=t.right;o++)for(let s=t.top;s<=t.bottom;s++){const t={sheetId:e.sheetId,col:o,row:s},i=this.getters.getCell(t)?.content;i||this.evaluatedCells.delete(t)}const o=e.sheetId;this.invalidatePositionsDependingOnSpread(o,t),this.nextRangesToUpdate.addMany(this.getArrayFormulasBlockedBy(o,t))}buildSafeGetSymbolValue(e){return t=>{if(this.symbolsBeingComputed.has(t))return eU;this.symbolsBeingComputed.add(t);try{const o=e?.(t);return o||new an(ui("Invalid formula"))}finally{this.symbolsBeingComputed.delete(t)}}}getDirectDependencies(e){const t=this.getters.getCell(e);return t?.isFormula?t.compiledFormula.dependencies:[]}getCellsDependingOn(e){return this.formulaDependencies().getCellsDependingOn(e,this.nextRangesToUpdate)}}function sU(e,t,o){for(let s=0;s<e;++s)for(let e=0;e<t;++e)0===s&&0===e||o(s,e)}function iU(e){return null===e.value||void 0===e.value?{...e,value:0}:e}function nU(e,t,o,s,i){return t.evalContext.__originCellPosition=i,t.evalContext.__originSheetId=o,e.execute(e.dependencies,t.referenceDenormalizer,t.ensureRange,s,t.evalContext)}const rU=/"(#[0-9a-fA-F]{6})"/g;const aU={isValid:!0};const lU=new n;function cU(e,t){const o=t.model.getters.getPivotCellFromPosition(e),s=t.model.getters.getPivotIdFromPosition(e);if(!s||"HEADER"!==o.type)return;const i=t.model.getters.getPivotCoreDefinition(s),n=i.collapsedDomains?.[o.dimension]?[...i.collapsedDomains[o.dimension]]:[],r=n.findIndex((e=>zt(e,o.domain)));-1!==r?n.splice(r,1):n.push(o.domain);const a=i.collapsedDomains?{...i.collapsedDomains}:{COL:[],ROW:[]};a[o.dimension]=n,t.model.dispatch("UPDATE_PIVOT",{pivotId:s,pivot:{...i,collapsedDomains:a}})}lU.add("data_validation_checkbox",((e,t)=>{if(e.isCellValidCheckbox(t)){const o=!!e.getEvaluatedCell(t).value;return{svg:o?aA:nA,hoverSvg:o?aA:rA,priority:2,horizontalAlign:"center",size:17,margin:2,position:t,type:"data_validation_checkbox",onClick:(e,t)=>{const s=t.model.getters.getCell(e);if(t.model.getters.isReadonly()||!!s?.isFormula)return;const i=o?"FALSE":"TRUE";t.model.dispatch("UPDATE_CELL",{...e,content:i})}}}})),lU.add("data_validation_chip_icon",((e,t)=>{const o=e.getDataValidationChipStyle(t);if(o){const s=e.getCellComputedStyle(t);return{svg:sA(o),hoverSvg:iA(o),priority:10,horizontalAlign:"right",size:dl(s),margin:4,position:t,onClick:(e,t)=>{const{col:o,row:s}=e;t.model.selection.selectCell(o,s),t.startCellEdition()},type:"data_validation_chip_icon"}}})),lU.add("data_validation_list_icon",((e,t)=>{if(!e.isReadonly()&&e.cellHasListDataValidationIcon(t)){const s=e.getCellComputedStyle(t);return{svg:eA(s),hoverSvg:(o=s,{name:"CARET_DOWN",width:512,height:512,paths:[{fillColor:o.textColor||oe,path:"M15 15 h482 v482 h-482"},{fillColor:o.fillColor||"#fff",path:"M120 195 h270 l-135 130"}]}),priority:2,horizontalAlign:"right",size:17,margin:2,position:t,onClick:(e,t)=>{const{col:o,row:s}=e;t.model.selection.selectCell(o,s),t.startCellEdition()},type:"data_validation_list_icon"}}var o})),lU.add("filter_icon",((e,t)=>{if(e.isFilterHeader(t)){const o=e.isFilterActive(t),s=Ms(e.getCellComputedStyle(t).fillColor||"#fff")<.45;return{type:"filter_icon",svg:cA(o,s,!1),hoverSvg:cA(o,s,!0),priority:3,horizontalAlign:"right",size:17,margin:2,position:t,onClick:(e,t)=>{const o=t.getStore(KE),s=o.persistentCellPopover;s.isOpen&&s.col===e.col&&s.row===e.row&&"FilterMenu"===s.type?o.close():o.open(e,"FilterMenu")}}}})),lU.add("conditional_formatting",((e,t)=>{const o=e.getConditionalIcon(t);if(o){const s=e.getCellStyle(t);return{type:"conditional_formatting",svg:hA[o].svg,priority:1,horizontalAlign:"left",size:dl(s),margin:4,position:t}}})),lU.add("pivot_collapse",((e,t)=>{if(!e.isSpillPivotFormula(t))return;const o=e.getPivotCellFromPosition(t),s=e.getPivotIdFromPosition(t);if("HEADER"===o.type&&s&&o.domain.length){const i=e.getPivotCoreDefinition(s),n=e.isDashboard(),r="COL"===o.dimension?i.columns:i.rows,a=!n&&o.domain.length!==r.length,l=(i.collapsedDomains?.[o.dimension]??[]).some((e=>zt(e,o.domain))),c="ROW"===o.dimension?15*(o.domain.length-1):0;return{type:"pivot_collapse",priority:4,horizontalAlign:"left",size:a||!n&&"ROW"===o.dimension&&i.rows.length>1?12:0,margin:a?4+c:c,svg:a?lA(l,!1):void 0,hoverSvg:a?lA(l,!0):void 0,position:t,onClick:cU}}})),lU.add("pivot_dashboard_sorting",((e,t)=>{if(!e.isDashboard())return;if("MEASURE_HEADER"!==e.getPivotCellFromPosition(t).type)return;const o=e.getPivotCellSortDirection(t);if("asc"!==o&&"desc"!==o)return;const s=e.getCellComputedStyle(t);return{type:`pivot_dashboard_sorting_${o}`,priority:5,horizontalAlign:"right",size:17,margin:2,svg:"asc"===o?tA(s):eA(s),position:t,onClick:void 0}}));const hU="0.00%";function dU(e){return class extends e{getters;cache={};rankAsc={};rankDesc={};runningTotal={};runningTotalInPercent={};constructor(e,t){super(e,t),this.getters=t.getters}markAsDirtyForEvaluation(){this.cache={},this.rankAsc={},this.rankDesc={},this.runningTotal={},this.runningTotalInPercent={},super.markAsDirtyForEvaluation?.()}getPivotCellValueAndFormat(e,t){return this.getMeasureDisplayValue(e,t)}_getPivotCellValueAndFormat(e,t){const o=`${e}-${t.map((e=>e.field+"="+e.value)).join(",")}`;if(this.cache[o])return this.cache[o];const s=this.getMeasure(e),i=s.computedBy?this.computeMeasure(s,t):super.getPivotCellValueAndFormat(e,t);return s.format?this.cache[o]={...i,format:s.format}:this.cache[o]=i,this.cache[o]}computeMeasure(e,t){if(!e.computedBy)return{value:0};const{columns:o,rows:s}=super.definition;if(e.aggregator&&o.length+s.length!==t.length){const o=this.getValuesToAggregate(e,t),s=Kc[e.aggregator];if(!s)return{value:0};try{return s([o],this.getters.getLocale())}catch(t){return DC(t,e.aggregator.toUpperCase())}}const i=this.getters.getMeasureCompiledFormula(e),n=this.getters.evaluateCompiledFormula(e.computedBy.sheetId,i,(e=>{const{columns:o,rows:s}=this.definition;if(o.find((t=>t.nameWithGranularity===e))){const{colDomain:o}=jO(this,t),s=o.findIndex((t=>t.field===e));return-1===s?new hn:this.getPivotHeaderValueAndFormat(o.slice(0,s+1))}if(s.find((t=>t.nameWithGranularity===e))){const{rowDomain:o}=jO(this,t),s=o.findIndex((t=>t.field===e));return-1===s?new hn:this.getPivotHeaderValueAndFormat(o.slice(0,s+1))}return this.getPivotCellValueAndFormat(e,t)}));return E(n)?n[0][0]:n}getValuesToAggregate(e,t){const{rowDomain:o,colDomain:s}=jO(this,t),i=super.getExpandedTableStructure(),n=[];if(0===s.length&&o.length<this.definition.rows.length&&this.definition.rows.length&&this.definition.columns.length){const t=this.treeToLeafDomains(i.getColTree()),s=this.getSubTreeMatchingDomain(i.getRowTree(),o),r=this.treeToLeafDomains(s);for(const s of t)for(const t of r)n.push(this._getPivotCellValueAndFormat(e.id,o.concat(t).concat(s)));return n}if(o.length===this.definition.rows.length&&0===s.length){const t=i.getColTree(),r=this.getSubTreeMatchingDomain(t,s),a=this.treeToLeafDomains(r,s);for(const t of a)n.push(this._getPivotCellValueAndFormat(e.id,o.concat(t)));return n}if(o.length===this.definition.rows.length&&s.length&&s.length<this.definition.columns.length){const t=this.getSubTreeMatchingDomain(i.getColTree(),s),r=this.treeToLeafDomains(t,s);for(const t of r)n.push(this._getPivotCellValueAndFormat(e.id,o.concat(t)));return n}{const t=i.getRowTree(),r=this.getSubTreeMatchingDomain(t,o),a=this.treeToLeafDomains(r,o);for(const t of a)n.push(this._getPivotCellValueAndFormat(e.id,t.concat(s)));return n}}getSubTreeMatchingDomain(e,t,o=0){if(o>t.length)return[];if(t.length===o)return e;for(const s of e){const e=rh(this.definition.getDimension(s.field),t[o]?.value);if(s.field===t[o]?.field&&s.value===e)return this.getSubTreeMatchingDomain(s.children,t,o+1)}return[]}treeToLeafDomains(e,t=[]){const o=[];for(const s of e){const e=this.definition.getDimension(s.field),i=[...t,{field:s.field,value:s.value,type:e.type}];0===s.children.length?o.push(i):o.push(...this.treeToLeafDomains(s.children,i))}return o}getMeasureDisplayValue(e,t){const o=this.getMeasure(e),s=this._getPivotCellValueAndFormat(e,t);if(!o.display||"no_calculations"===o.display.type||s.message)return s;const i=o.display.fieldNameWithGranularity;if(i&&!this.isFieldInPivot(i))return{value:sn.NotAvailable,message:ui('Field "%s" not found in pivot for measure display calculation',i)};try{const e=o.display;switch(e.type){case"%_of_grand_total":return this.asPercentOfGrandTotal(s,o);case"%_of_col_total":return this.asPercentOfColumnTotal(s,o,t);case"%_of_row_total":return this.asPercentOfRowTotal(s,o,t);case"%_of_parent_row_total":return this.asPercentOfParentRowTotal(s,o,t);case"%_of_parent_col_total":return this.asPercentOfParentColumnTotal(s,o,t);case"index":return this.asIndex(s,o,t);case"%_of_parent_total":return this.asPercentOfParentTotal(s,o,t,e);case"running_total":return this.asRunningTotal(s,o,t,e,"running_total");case"%_running_total":return this.asRunningTotal(s,o,t,e,"%_running_total");case"rank_asc":return this.asRank(s,o,t,e,"asc");case"rank_desc":return this.asRank(s,o,t,e,"desc");case"%_of":return this.asPercentOf(s,o,t,e);case"difference_from":return this.asDifferenceFrom(s,o,t,e);case"%_difference_from":return this.asDifferenceFromInPercent(s,o,t,e)}return s}catch(e){return DC(e,"COMPUTE_MEASURE_DISPLAY_VALUE")}}asPercentOfGrandTotal(e,t){const o=this.getGrandTotal(t.id);return 0===o?{value:sn.DivisionByZero}:{value:this.measureValueToNumber(e)/o,format:hU}}asPercentOfRowTotal(e,t,o){const s=this.getRowTotal(t.id,o);return 0===s?{value:sn.DivisionByZero}:{value:this.measureValueToNumber(e)/s,format:hU}}asPercentOfColumnTotal(e,t,o){const s=this.getColumnTotal(t.id,o);return 0===s?{value:sn.DivisionByZero}:{value:this.measureValueToNumber(e)/s,format:hU}}asPercentOfParentRowTotal(e,t,o){const s=function(e,t){const{colDomain:o,rowDomain:s}=jO(e,t);return[...o,...s.slice(0,s.length-1)]}(this,o),i=this.measureValueToNumber(this._getPivotCellValueAndFormat(t.id,s));return 0===i?{value:""}:{value:this.measureValueToNumber(e)/i,format:hU}}asPercentOfParentColumnTotal(e,t,o){const s=function(e,t){const{colDomain:o,rowDomain:s}=jO(e,t);return[...o.slice(0,o.length-1),...s]}(this,o),i=this.measureValueToNumber(this._getPivotCellValueAndFormat(t.id,s));return 0===i?{value:""}:{value:this.measureValueToNumber(e)/i,format:hU}}asPercentOfParentTotal(e,t,o,s){const{fieldNameWithGranularity:i}=s;if(!i)return e;if(!QO(i,o))return{value:""};const n=function(e,t,o){let{rowDomain:s,colDomain:i}=jO(e,o);if("row"===eP(e,t)){const e=s.findIndex((e=>e.field===t));if(-1===e)return o;s=s.slice(0,e+1)}else{const e=i.findIndex((e=>e.field===t));if(-1===e)return o;i=i.slice(0,e+1)}return[...s,...i]}(this,i,o),r=this._getPivotCellValueAndFormat(t.id,n),a=this.measureValueToNumber(r);return 0===a?{value:""}:{value:this.measureValueToNumber(e)/a,format:hU}}asIndex(e,t,o){const s=this.measureValueToNumber(e),i=this.getRowTotal(t.id,o),n=this.getColumnTotal(t.id,o),r=this.getGrandTotal(t.id);return 0===i||0===n?{value:sn.DivisionByZero}:{value:s*r/(n*i),format:void 0}}asRunningTotal(e,t,o,s,i){const{fieldNameWithGranularity:n}=s;if(!n)return e;const r="running_total"===i?this.runningTotal:this.runningTotalInPercent;let a=r[t.id]?.[n];a||(a=this.computeRunningTotal(t,n,i),r[t.id]||(r[t.id]={}),r[t.id][n]=a);const{rowDomain:l,colDomain:c}=jO(this,o),h=tP(c),d=tP(l),u=a[h]?.[d];return{value:u??"",format:"running_total"===i?e.format:hU}}asPercentOf(e,t,o,s){const{fieldNameWithGranularity:i,value:n}=s;if(void 0===n||!i)return e;if(!QO(i,o))return{value:""};const r=this.getComparisonValue(t,o,i,n),a=this.strictMeasureValueToNumber(e);return 0===r||"sameValue"===r&&0===a?{value:sn.DivisionByZero}:!r||"sameValue"===r&&!a?{value:""}:"sameValue"===r?{value:1,format:hU}:void 0===a?{value:sn.NullError}:{value:a/r,format:hU}}asDifferenceFrom(e,t,o,s){const{fieldNameWithGranularity:i,value:n}=s;if(void 0===n||!i)return e;if(!QO(i,o))return{value:""};const r=this.getComparisonValue(t,o,i,n)||0;return"sameValue"===r?{value:""}:{value:this.measureValueToNumber(e)-r,format:e.format}}asDifferenceFromInPercent(e,t,o,s){const{fieldNameWithGranularity:i,value:n}=s;if(void 0===n||!i)return e;if(!QO(i,o))return{value:""};const r=this.getComparisonValue(t,o,i,n),a=this.strictMeasureValueToNumber(e);return 0===r?{value:sn.DivisionByZero}:r&&"sameValue"!==r?void 0===a?{value:sn.NullError}:{value:(a-r)/r,format:hU}:{value:""}}asRank(e,t,o,s,i){const{fieldNameWithGranularity:n}=s;if(!n)return e;if(!QO(n,o))return{value:""};const r="asc"===i?this.rankAsc:this.rankDesc;let a=r[t.id]?.[n];a||(a=this.computeRank(t,n,i),r[t.id]||(r[t.id]={}),r[t.id][n]=a);const{rowDomain:l,colDomain:c}=jO(this,o),h=tP(c),d=tP(l),u=a[h]?.[d];return{value:u??""}}computeRank(e,t,o){const s={},i=eP(this,t),n="row"===i?"column":"row";let r=this.getPivotValueCells(e.id);"column"===i&&(r=Hn(r));for(const a of r){const r=tP(YO(this,n,a[0].domain)),l=a.map((t=>({...t,value:this.strictMeasureValueToNumber(this._getPivotCellValueAndFormat(e.id,t.domain)),rowDomain:YO(this,i,t.domain)}))).filter((e=>QO(t,e.rowDomain))),c=Object.groupBy(l,(e=>sP(e.rowDomain,t)));for(const e in c)c[e]=lo(c[e]||[],(e=>e.value)).filter((e=>void 0!==e.value)).sort(((e,t)=>"asc"===o?e.value-t.value:t.value-e.value));s[r]={};for(const e of l){const o=tP(YO(this,i,e.domain)),n=c[sP(e.rowDomain,t)];if(!n)continue;const a=n.findIndex((t=>t.value===e.value));-1!==a&&(s[r][o]=a+1)}}return"row"===i?s:co(s)}computeRunningTotal(e,t,o){const s={},i=eP(this,t),n="row"===i?"column":"row";let r=this.getPivotValueCells(e.id);"column"===i&&(r=Hn(r));for(const a of r){const r=tP(YO(this,n,a[0].domain));s[r]={};const l={},c=a.map((t=>({...t,rowDomain:YO(this,i,t.domain),value:this.measureValueToNumber(this._getPivotCellValueAndFormat(e.id,t.domain))}))).filter((e=>QO(t,e.rowDomain)));for(const e of c){const o=tP(e.rowDomain),i=iP(e.rowDomain,t),n=(l[i]||0)+e.value;l[i]=n,s[r][o]=n}if("%_running_total"===o)for(const e of c){const o=e.rowDomain,i=tP(o),n=iP(o,t),a=s[r][i]||0,c=l[n];s[r][i]=c?a/c:void 0}}return"row"===i?s:co(s)}getGrandTotal(e){const t=this._getPivotCellValueAndFormat(e,[]);return this.measureValueToNumber(t)}getRowTotal(e,t){const o=jO(this,t).rowDomain,s=this._getPivotCellValueAndFormat(e,o);return this.measureValueToNumber(s)}getColumnTotal(e,t){const o=jO(this,t).colDomain,s=this._getPivotCellValueAndFormat(e,o);return this.measureValueToNumber(s)}isFieldInPivot(e){return this.definition.columns.some((t=>t.nameWithGranularity===e))||this.definition.rows.some((t=>t.nameWithGranularity===e))}getComparisonValue(e,t,o,s){const i=s===qO||s===ZO?function(e,t,o,s){const i=eP(e,o),n="row"===i?e.getExpandedTableStructure().getRowTree():e.getExpandedTableStructure().getColTree(),r=KO(YO(e,i,t),n,o),a=r?.map((e=>e.value))??[],l=function(e,t){const o=t.find((t=>t.field===e));return o?.value}(o,t);if(void 0===l)return;const c=a.indexOf(l);if(void 0===l||-1===c)return;return JO(t,o,a[St(c+(s===qO?-1:1),0,a.length-1)])}(this,t,o,s):JO(t,o,s);if(zt(i,t))return"sameValue";if(!i||!function(e,t){for(const o of t)if(void 0===e.definition.rows.find((e=>e.nameWithGranularity===o.field))&&void 0===e.definition.columns.find((e=>e.nameWithGranularity===o.field)))return!1;const{rowDomain:o,colDomain:s}=jO(e,t);return XO(o,e.getExpandedTableStructure().getRowTree())&&XO(s,e.getExpandedTableStructure().getColTree())}(this,i))throw new hn;const n=this._getPivotCellValueAndFormat(e.id,i);return this.strictMeasureValueToNumber(n)}getPivotValueCells(e){return this.getCollapsedTableStructure().getPivotCells().map((t=>t.filter((t=>"VALUE"===t.type&&t.measure===e)))).filter((e=>e.length>0))}measureValueToNumber(e){if("number"==typeof e.value)return e.value;if(!e.value)return 0;throw new Error(`Value ${e.value} is not a number`)}strictMeasureValueToNumber(e){if("number"==typeof e.value)return e.value;if(e.value)throw new Error(`Value ${e.value} is not a number`)}getCollapsedTableStructure(){const e=super.getCollapsedTableStructure();return this.sortTableStructure(e),e}getExpandedTableStructure(){const e=super.getExpandedTableStructure();return this.sortTableStructure(e),e}sortTableStructure(e){if(!this.definition.sortedColumn||e.isSorted)return;const t=this.definition.sortedColumn.measure;gh(this.definition.sortedColumn,this)&&e.sort(t,this.definition.sortedColumn,((e,t)=>this._getPivotCellValueAndFormat(e,t)))}}}const uU=["ADD_PIVOT","UPDATE_PIVOT","REMOVE_PIVOT"];function gU(e){return uU.includes(e.type)}const pU=new n;pU.add("ALPHANUMERIC_INCREMENT_MODIFIER",{apply:(e,t)=>{e.current+=e.increment;let o=Math.abs(e.current).toString();o="0".repeat(Math.max(e.numberPostfixLength-o.length,0))+o;const s=`${e.prefix}${o}`;return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:s},tooltip:{props:{content:s}}}}}).add("INCREMENT_MODIFIER",{apply:(e,t,o)=>{e.current+=e.increment;const s=e.current.toString(),i=o.getLocale(),n=Rr(e.current,{format:t.cell?.format,locale:i});return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:s},tooltip:s?{props:{content:n}}:void 0}}}).add("DATE_INCREMENT_MODIFIER",{apply:(e,t,o)=>{const s=Dn(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=zi(s);e.current=i;const n=o.getLocale(),r=Rr(i,{format:t.cell?.format,locale:n});return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:i.toString()},tooltip:i?{props:{content:r}}:void 0}}}).add("COPY_MODIFIER",{apply:(e,t,o)=>{const s=t.cell?.content||"",i={locale:o.getLocale(),format:t.cell?.format};return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:s},tooltip:s?{props:{content:t.cell?Qr(t.cell,i).formattedValue:""}}:void 0}}}).add("FORMULA_MODIFIER",{apply:(e,t,o,s)=>{e.current+=e.increment;let i=0,n=0;switch(s){case"up":i=0,n=-e.current;break;case"down":i=0,n=e.current;break;case"left":i=-e.current,n=0;break;case"right":i=e.current,n=0}const r=t.cell;if(!r||!r.isFormula)return{cellData:{}};const a=t.sheetId,l=o.getTranslatedCellFormula(a,i,n,r.compiledFormula.tokens);return{cellData:{border:t.border,style:r.style,format:r.format,content:l},tooltip:l?{props:{content:l}}:void 0}}});const mU=new n,fU=/(\d+)$/,vU=/^(.*\D+)/,bU=/^(.*\D+)(\d+)$/,SU=/^0*/;function CU(e,t,o){let s=[],i=!1;for(const n of t){n===e&&(i=!0);const t=void 0===n||n.isFormula?void 0:Qr(n,{locale:w,format:n.format});if(t&&o(t))s.push(t);else{if(i)return s;s=[]}}return s}function yU(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 IU(e){if(e.length<2)return 1;const t=e.map((e=>Dn(e,w))),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=Ii.fromTimestamp(e[o-1].getTime()),i=Yi(s,t),n=Zi(s,t)%12;s.setFullYear(s.getFullYear()+i),s.setMonth(s.getMonth()+n);return{years:i,months:n,days:ji(s,t)}}));return t.slice(1)}(t),s=(i=o).length<2?i[0]||{years:0,months:0,days:0}:i.every((e=>e.years===i[0].years&&e.months===i[0].months&&e.days===i[0].days))?i[0]:void 0;var i;if(void 0===s)return;const n=1===Object.values(s).filter((e=>0!==e)).length,r=Object.values(s).every((e=>0===e));if(!n||r){const o=t.map(((e,o)=>{if(0===o)return 0;const s=t[o-1];return Math.floor(e.getTime())-Math.floor(s.getTime())})).slice(1);if(o.every((e=>e===o[0])))return e.length*(e[1]-e[0])}return{years:s.years*e.length,months:s.months*e.length,days:s.days*e.length}}mU.add("simple_value_copy",{condition:(e,t)=>!(1!==t.length||e.isFormula||e.format&&Mr(e.format)),generateRule:()=>({type:"COPY_MODIFIER"}),sequence:10}).add("increment_alphanumeric_value",{condition:e=>!e.isFormula&&Qr(e,{locale:w}).type===r.text&&bU.test(e.content),generateRule:(e,t,o)=>{const s=parseInt(e.content.match(fU)[0]),i=e.content.match(vU)[0],n=CU(e,t,(e=>e.type===r.text&&bU.test(e.value))).filter((e=>i===(e.value??"").toString().match(vU)[0])).map((e=>(e.value??"").toString().match(fU)[0])),a=n.reduce(((e,t)=>{const o=t.match(SU)[0].length;return o>e[1]?[t,o]:e}),[n[0],0]),l=a[1]?a[0].length:0;let c=yU(n.map((e=>parseInt(e))));return["up","left"].includes(o)&&1===n.length&&(c=-c),{type:"ALPHANUMERIC_INCREMENT_MODIFIER",prefix:i,current:s,increment:c,numberPostfixLength:l}},sequence:15}).add("copy_text",{condition:e=>!e.isFormula&&Qr(e,{locale:w}).type===r.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&&Qr(e,{locale:w}).type===r.number&&!!e.format&&Mr(e.format),generateRule:(e,t)=>{const o=IU(CU(e,t,(e=>e.type===r.number&&!!e.format&&Mr(e.format))).map((e=>Number(e.value))));if(void 0===o)return{type:"COPY_MODIFIER"};const s=Qr(e,{locale:w});return"object"==typeof o?{type:"DATE_INCREMENT_MODIFIER",increment:o,current:s.type===r.number?s.value:0}:{type:"INCREMENT_MODIFIER",increment:o,current:s.type===r.number?s.value:0}},sequence:25}).add("increment_number",{condition:e=>!e.isFormula&&Qr(e,{locale:w}).type===r.number,generateRule:(e,t,o)=>{const s=CU(e,t,(e=>e.type===r.number&&!Mr(e.format||""))).map((e=>Number(e.value)));let i=yU(s);["up","left"].includes(o)&&1===s.length&&(i=-i);const n=Qr(e,{locale:w});return{type:"INCREMENT_MODIFIER",increment:i,current:n.type===r.number?n.value:0}},sequence:40});class wU{cells;getters;index=0;direction;constructor(e,t,o){this.cells=e,this.getters=t,this.direction=o}next(){const e=this.cells[this.index++%this.cells.length],t=e.rule,{cellData:o,tooltip:s}=pU.get(t.type).apply(t,e.data,this.getters,this.direction);return{cellData:o,tooltip:s,origin:{col:e.data.col,row:e.data.row}}}}const xU=new class extends n{addTransformation(e,t,o){this.content[e]||(this.content[e]=new Map);for(const s of t)this.content[e].set(s,o);return this}getTransformation(e,t){return this.content[t]&&this.content[t].get(e)}};const EU=new class extends n{add(e,t){return super.add(e,t),this}replace(e,t){return super.replace(e,t),this}get(e){return this.content[e]}};function RU(e,t){if("SPREADSHEET"!==e.pivot.type)return e;if(e.pivot.dataSet?.sheetId!==t.sheetId)return e;const o=Ih(e.pivot.dataSet.zone,t),s=o?{...e.pivot.dataSet,zone:o}:void 0;return{...e,pivot:{...e.pivot,dataSet:s}}}function TU(e,t){if(e.sheetId!==t.sheetId)return e;if(("FREEZE_COLUMNS"===e.type?"COL":"ROW")!==t.dimension)return e;let o=e.quantity;if("REMOVE_COLUMNS_ROWS"===t.type){const e=[...t.elements].sort(((e,t)=>t-e));for(const t of e)o>t&&o--}if("ADD_COLUMNS_ROWS"===t.type){o=o>("before"===t.position?t.base-1:t.base)?o+t.quantity:o}return o>0?{...e,quantity:o}:void 0}function AU(e,t){if(e.sheetId!==t.sheetId)return e;const o=Ih(e.zone,t);if(!o)return;const s=e.newTableRange?wh(e.newTableRange,t):void 0;return{...e,newTableRange:s,zone:o}}function DU(e,t){if(e.sheetId!==t.sheetId||e.dimension!==t.dimension)return e;let o;if("REMOVE_COLUMNS_ROWS"===t.type)o=Fa(t.elements,[e.base])[0];else if("ADD_COLUMNS_ROWS"===t.type){o=_a(Ht(t.position,t.base),t.quantity,[e.base])[0]}return void 0!==o?{...e,base:o}:void 0}function _U(e,t){if(e.sheetId!==t.sheetId||e.dimension!==t.dimension)return e;const o=Ct(e.start,e.end+1);let s=[];if("REMOVE_COLUMNS_ROWS"===t.type)s=Fa(t.elements,o);else if("ADD_COLUMNS_ROWS"===t.type){s=_a(Ht(t.position,t.base),t.quantity,o)}return 0!==s.length?{...e,start:Math.min(...s),end:Math.max(...s)}:void 0}function FU(e,t){return(e=pt(e)).pivot.measures.map((e=>{e.computedBy&&(e.computedBy.formula=YC(e.computedBy.sheetId,e.computedBy.formula,t))})),e}function OU(e,t){return{...e,definition:cE(e.sheetId,e.definition,t)}}xU.addTransformation("ADD_COLUMNS_ROWS",["ADD_COLUMNS_ROWS"],DU),xU.addTransformation("REMOVE_COLUMNS_ROWS",["ADD_COLUMNS_ROWS"],DU),xU.addTransformation("DELETE_SHEET",["MOVE_RANGES"],(function(e,t){const o=t.sheetId;if(e.targetSheetId===o||e.sheetId===o)return;return e})),xU.addTransformation("DELETE_FIGURE",["UPDATE_FIGURE","UPDATE_CHART","UPDATE_CAROUSEL"],(function(e,t){if(e.figureId===t.figureId)return;return e})),xU.addTransformation("DELETE_CHART",["UPDATE_CHART"],(function(e,t){if(e.chartId===t.chartId)return;return e})),xU.addTransformation("DELETE_CHART",["UPDATE_CAROUSEL"],(function(e,t){return{...e,definition:{...e.definition,items:e.definition.items.filter((e=>!("chart"===e.type&&e.chartId===t.chartId)))}}})),xU.addTransformation("CREATE_SHEET",["CREATE_SHEET"],(function(e,t){e.sheetId===t.sheetId&&(e={...e,sheetId:`${e.sheetId}~`});if(e.name===t.name)return{...e,name:e.name?.match(/\d+/)?e.name.replace(/\d+/,(e=>(parseInt(e)+1).toString())):`${e.name}~`,position:e.position+1};return e})),xU.addTransformation("ADD_MERGE",["ADD_MERGE","REMOVE_MERGE"],(function(e,t){if(e.sheetId!==t.sheetId)return e;const o=[];for(const s of e.target)t.target.every((e=>!Qo(s,e)))&&o.push(s);if(o.length)return{...e,target:o};return})),xU.addTransformation("ADD_COLUMNS_ROWS",["FREEZE_COLUMNS","FREEZE_ROWS"],TU),xU.addTransformation("REMOVE_COLUMNS_ROWS",["FREEZE_COLUMNS","FREEZE_ROWS"],TU),xU.addTransformation("ADD_COLUMNS_ROWS",["UPDATE_TABLE"],AU),xU.addTransformation("REMOVE_COLUMNS_ROWS",["UPDATE_TABLE"],AU),xU.addTransformation("REMOVE_TABLE_STYLE",["CREATE_TABLE","UPDATE_TABLE"],(function(e,t){if(e.config?.styleId!==t.tableStyleId)return e;return{...e,config:{...e.config,styleId:MT.styleId}}})),xU.addTransformation("ADD_COLUMNS_ROWS",["GROUP_HEADERS","UNGROUP_HEADERS","FOLD_HEADER_GROUP","UNFOLD_HEADER_GROUP"],_U),xU.addTransformation("REMOVE_COLUMNS_ROWS",["GROUP_HEADERS","UNGROUP_HEADERS","FOLD_HEADER_GROUP","UNFOLD_HEADER_GROUP"],_U),xU.addTransformation("REMOVE_PIVOT",["RENAME_PIVOT","DUPLICATE_PIVOT","INSERT_PIVOT","UPDATE_PIVOT"],(function(e,t){if(e.pivotId===t.pivotId)return;return e})),xU.addTransformation("DELETE_SHEET",["ADD_PIVOT","UPDATE_PIVOT"],(function(e,t){if("SPREADSHEET"!==e.pivot.type)return e;if(e.pivot.dataSet?.sheetId===t.sheetId)return{...e,pivot:{...e.pivot,dataSet:void 0}};return e})),xU.addTransformation("ADD_COLUMNS_ROWS",["ADD_PIVOT","UPDATE_PIVOT"],RU),xU.addTransformation("REMOVE_COLUMNS_ROWS",["ADD_PIVOT","UPDATE_PIVOT"],RU),EU.add("UPDATE_CELL",(function(e,t){const o=e.content&&YC(e.sheetId,e.content,t);return{...e,content:o}})),EU.add("ADD_CONDITIONAL_FORMAT",(function(e,t){const o=e.cf.rule;if(e={...e,cf:{...e.cf}},"CellIsRule"===o.type)e.cf.rule={...o,values:o.values.map((o=>YC(e.sheetId,o,t)))};else if("ColorScaleRule"===o.type){const{minimum:s,maximum:i,midpoint:n}=o;e.cf.rule={...o,minimum:{...s,value:s.value&&YC(e.sheetId,s.value,t)},maximum:{...i,value:i.value&&YC(e.sheetId,i.value,t)},midpoint:n?{...n,value:YC(e.sheetId,n.value,t)}:void 0}}else if("IconSetRule"===o.type){const{upperInflectionPoint:s,lowerInflectionPoint:i}=o;e.cf.rule={...o,upperInflectionPoint:{...s,value:YC(e.sheetId,s.value,t)},lowerInflectionPoint:{...i,value:YC(e.sheetId,i.value,t)}}}else"DataBarRule"===o.type&&(e.cf.rule={...o,rangeValues:o.rangeValues?XC(e.sheetId,o.rangeValues,t):void 0});return e})),EU.add("ADD_DATA_VALIDATION_RULE",(function(e,t){return(e={...e,rule:{...e.rule,criterion:{...e.rule.criterion}}}).rule.criterion.values=e.rule.criterion.values.map((o=>YC(e.sheetId,o,t))),e})),EU.add("ADD_PIVOT",FU),EU.add("UPDATE_PIVOT",FU),EU.add("CREATE_CHART",OU),EU.add("UPDATE_CHART",OU);const PU=[{match:function(e){return"sheetId"in e},fn:kU},{match:function(e){return"target"in e&&"sheetId"in e},fn:function(e,t){const o=kU(e,t);if("SKIP_TRANSFORMATION"!==o)return"IGNORE_COMMAND"===o?"IGNORE_COMMAND":e;const s=[];for(const o of e.target){const e=Ih(o,t);e&&s.push(e)}if(!s.length)return"IGNORE_COMMAND";return{...e,target:s}}},{match:function(e){return"sheetId"in e&&"zone"in e},fn:function(e,t){const o=kU(e,t);if("SKIP_TRANSFORMATION"!==o)return"IGNORE_COMMAND"===o?"IGNORE_COMMAND":e;const s=Ih(e.zone,t);if(s)return{...e,zone:s};return"IGNORE_COMMAND"}},{match:function(e){return"col"in e&&"row"in e&&"sheetId"in e},fn:function(e,t){const o=kU(e,t);if("SKIP_TRANSFORMATION"!==o)return"IGNORE_COMMAND"===o?"IGNORE_COMMAND":e;if("ADD_COLUMNS_ROWS"===t.type||"REMOVE_COLUMNS_ROWS"===t.type)return function(e,t){const o="COL"===t.dimension?"col":"row";let s=e[o];if("REMOVE_COLUMNS_ROWS"===t.type){const e=[...t.elements].sort(((e,t)=>t-e));if(e.includes(s))return"IGNORE_COMMAND";for(const t of e)s>=t&&s--}"ADD_COLUMNS_ROWS"===t.type&&(s>t.base||s===t.base&&"before"===t.position)&&(s+=t.quantity);return{...e,[o]:s}}(e,t);if("ADD_MERGE"===t.type)return function(e,t){for(const o of t.target){if(!(e.col===o.left&&e.row===o.top)&&es(e.col,e.row,o))return"IGNORE_COMMAND"}return e}(e,t);return"SKIP_TRANSFORMATION"}},{match:function(e){return"dimension"in e&&"sheetId"in e&&"elements"in e},fn:function(e,t){const o=kU(e,t);if("SKIP_TRANSFORMATION"!==o)return"IGNORE_COMMAND"===o?"IGNORE_COMMAND":e;if("ADD_COLUMNS_ROWS"!==t.type&&"REMOVE_COLUMNS_ROWS"!==t.type)return"SKIP_TRANSFORMATION";if(t.dimension!==e.dimension)return e;let s=[];if("REMOVE_COLUMNS_ROWS"===t.type)s=Fa(t.elements,e.elements);else if("ADD_COLUMNS_ROWS"===t.type){s=_a(Ht(t.position,t.base),t.quantity,e.elements)}if(0===s.length)return"IGNORE_COMMAND";return{...e,elements:s}}},{match:function(e){return"ranges"in e},fn:function(e,t){if(!("sheetId"in t))return e;const o=e.ranges.map((e=>wh(e,t))).filter(Mt);if(!o.length)return"IGNORE_COMMAND";return{...e,ranges:o}}}];function MU(e,t){const o=xU.getTransformation(e.type,t.type),s=o?o(e,t):function(e,t){for(const{match:o,fn:s}of PU)if(o(e)){const o=s(e,t);if("SKIP_TRANSFORMATION"===o)continue;if("IGNORE_COMMAND"===o)return;e=o}return e}(e,t);return s?function(e,t){const o=EU.get(e.type);if(!o)return e;const s=Wa(t);if(s)return o(e,s);return e}(s,t):s}function NU(e,t){let o=[...e];const s=new Set(xU.getKeys());for(const e of t)(s.has(e.type)||qa.contains(e.type))&&(o=o.reduce(((t,o)=>{const s=MU(o,e);return s&&t.push(s),t}),[]));return o}function kU(e,t){if(!("sheetId"in t))return e;const o="DELETE_SHEET"===t.type&&t.sheetId;return e.sheetId===o?"IGNORE_COMMAND":"CREATE_SHEET"===e.type||"CREATE_SHEET"===t.type||e.sheetId!==t.sheetId?e:"SKIP_TRANSFORMATION"}class LU{rootCommand;timestamp;id;clientId;_commands=[];_changes=[];constructor(e,t,o,s,i,n){this.rootCommand=s,this.timestamp=n,this.id=e,this.clientId=t,this._commands=[...o],this._changes=i?[...i]:[]}setChanges(e){this._changes=e}get commands(){return this._commands}get changes(){return this._changes}}class VU extends Error{}class UU extends xh{revisions;transportService;serverRevisionId;clients={};clientId="local";debouncedMove;pendingMessages=[];awaitingClientPosition;waitingAck=!1;waitingUndoRedoAck=!1;isReplayingInitialRevisions=!1;processedRevisions=new Set;lastRevisionMessage=void 0;uuidGenerator=new Sl;lastLocalOperation;constructor(e,t,o=He){super(),this.revisions=e,this.transportService=t,this.serverRevisionId=o,this.debouncedMove=kt(this._move.bind(this),200)}canApplyOptimisticUpdate(){return!this.waitingUndoRedoAck}save(e,t,o){if(!t.length||!o.length||!this.canApplyOptimisticUpdate())return;const s=new LU(this.uuidGenerator.uuidv4(),this.clientId,t,e,o,Date.now());this.revisions.append(s.id,s),"REQUEST_REDO"!==e.type&&(this.lastLocalOperation=s),this.trigger("new-local-state-update",{id:s.id}),this.sendUpdateMessage({type:"REMOTE_REVISION",version:1,serverRevisionId:this.serverRevisionId,nextRevisionId:s.id,clientId:s.clientId,commands:s.commands})}undo(e){this.waitingUndoRedoAck=!0,this.sendUpdateMessage({type:"REVISION_UNDONE",version:1,serverRevisionId:this.serverRevisionId,nextRevisionId:this.uuidGenerator.uuidv4(),undoneRevisionId:e})}redo(e){this.waitingUndoRedoAck=!0,this.sendUpdateMessage({type:"REVISION_REDONE",version:1,serverRevisionId:this.serverRevisionId,nextRevisionId:this.uuidGenerator.uuidv4(),redoneRevisionId:e})}move(e){this.debouncedMove(e)}join(e){e?(this.clients[e.id]=e,this.clientId=e.id):(this.clients.local={id:"local",name:"local"},this.clientId="local"),this.transportService.onNewMessage(this.clientId,this.onMessageReceived.bind(this)),this.awaitingClientPosition&&(this._move(this.awaitingClientPosition),this.awaitingClientPosition=void 0)}loadInitialMessages(e){const t=performance.now(),o=e.reduce(((e,t)=>e+("REMOTE_REVISION"===t.type?t.commands.length:1)),0);this.isReplayingInitialRevisions=!0;for(const t of e)this.onMessageReceived(t);this.isReplayingInitialRevisions=!1,console.debug("Replayed",o,"commands in",performance.now()-t,"ms")}async leave(e){e&&1===Object.keys(this.clients).length&&this.lastRevisionMessage&&"SNAPSHOT_CREATED"!==this.lastRevisionMessage?.type&&await this.snapshot(e()),delete this.clients[this.clientId],this.transportService.leave(this.clientId),this.transportService.sendMessage({type:"CLIENT_LEFT",clientId:this.clientId,version:1})}async snapshot(e){if(0!==this.pendingMessages.length)return;const t=this.uuidGenerator.uuidv4();await this.transportService.sendMessage({type:"SNAPSHOT",nextRevisionId:t,serverRevisionId:this.serverRevisionId,data:{...e,revisionId:t},version:1})}getCurrentClient(){return this.getClient(this.clientId)}getClient(e){const t=this.clients[e];if(!t)throw new VU("The client left the session");return t}getConnectedClients(){return new Set(Object.values(this.clients).filter(Mt))}getRevisionId(){return this.serverRevisionId}isFullySynchronized(){return 0===this.pendingMessages.length}getLastLocalNonEmptyRevision(){return this.lastLocalOperation}_move(e){if(!this.clients[this.clientId])return void(this.awaitingClientPosition=e);const t=this.clients[this.clientId]?.position;if(t?.col===e.col&&t.row===e.row&&t.sheetId===e.sheetId)return;const o=t?"CLIENT_MOVED":"CLIENT_JOINED",s=this.getCurrentClient();this.clients[this.clientId]={...s,position:e},this.transportService.sendMessage({type:o,version:1,client:{...s,position:e}})}onMessageReceived(e){if(!this.isAlreadyProcessed(e))if(this.isWrongServerRevisionId(e))this.trigger("unexpected-revision-id");else{switch(e.type){case"CLIENT_MOVED":this.onClientMoved(e);break;case"CLIENT_JOINED":this.onClientJoined(e);break;case"CLIENT_LEFT":this.onClientLeft(e);break;case"REVISION_REDONE":this.revisions.redo(e.redoneRevisionId,e.nextRevisionId,e.serverRevisionId),this.trigger("revision-redone",{revisionId:e.redoneRevisionId,commands:this.revisions.get(e.redoneRevisionId).commands});break;case"REVISION_UNDONE":this.revisions.undo(e.undoneRevisionId,e.nextRevisionId,e.serverRevisionId),this.trigger("revision-undone",{revisionId:e.undoneRevisionId,commands:this.revisions.get(e.undoneRevisionId).commands});break;case"REMOTE_REVISION":const{clientId:t,commands:o,timestamp:s}=e,i=new LU(e.nextRevisionId,t,o,void 0,void 0,s);if(i.clientId!==this.clientId){this.revisions.insert(i.id,i,e.serverRevisionId);const t=this.pendingMessages.filter((e=>"REMOTE_REVISION"===e.type)).map((e=>e.commands)).flat();this.trigger("remote-revision-received",{commands:NU(o,t)})}break;case"SNAPSHOT_CREATED":{const t=new LU(e.nextRevisionId,"server",[],void 0,void 0,Date.now());this.revisions.insert(t.id,t,e.serverRevisionId),this.dropPendingHistoryMessages(),this.trigger("snapshot"),this.lastLocalOperation=void 0;break}}this.acknowledge(e),this.trigger("collaborative-event-received")}}onClientMoved(e){e.client.id!==this.clientId&&(this.clients[e.client.id]=e.client)}onClientJoined(e){if(e.client.id!==this.clientId){this.clients[e.client.id]=e.client;const t=this.clients[this.clientId];if(t){const{position:e}=t;e&&this.transportService.sendMessage({type:"CLIENT_MOVED",version:1,client:{...t,position:e}})}}}onClientLeft(e){e.clientId!==this.clientId&&delete this.clients[e.clientId]}sendUpdateMessage(e){this.pendingMessages.push(e),this.waitingAck||this.sendPendingMessage()}sendPendingMessage(){let e=this.pendingMessages[0];if(e){if("REMOTE_REVISION"===e.type){let t=this.revisions.get(e.nextRevisionId);0===t.commands.length&&(this.revisions.rebase(t.id),t=this.revisions.get(e.nextRevisionId)),e={...e,clientId:t.clientId,commands:t.commands}}if(this.isReplayingInitialRevisions)throw new Error(`Trying to send a new revision while replaying initial revision. This can lead to endless dispatches every time the spreadsheet is open.\n ${JSON.stringify(e)}`);this.waitingAck=!0,this.transportService.sendMessage({...e,serverRevisionId:this.serverRevisionId})}}acknowledge(e){switch("REVISION_UNDONE"!==e.type&&"REVISION_REDONE"!==e.type||(this.waitingUndoRedoAck=!1),e.type){case"REMOTE_REVISION":case"REVISION_REDONE":case"SNAPSHOT_CREATED":this.waitingAck=!1,this.pendingMessages=this.pendingMessages.filter((t=>t.nextRevisionId!==e.nextRevisionId)),this.serverRevisionId=e.nextRevisionId,this.processedRevisions.add(e.nextRevisionId),this.lastRevisionMessage=e,this.sendPendingMessage();break;case"REVISION_UNDONE":{this.waitingAck=!1,this.pendingMessages=this.pendingMessages.filter((t=>t.nextRevisionId!==e.nextRevisionId));const t=this.pendingMessages.findIndex((e=>"REMOTE_REVISION"===e.type));-1!==t&&this.revisions.rebase(this.pendingMessages[t].nextRevisionId),this.serverRevisionId=e.nextRevisionId,this.processedRevisions.add(e.nextRevisionId),this.sendPendingMessage();break}}}isAlreadyProcessed(e){if("CLIENT_MOVED"===e.type&&e.client.id===this.clientId)return!0;switch(e.type){case"REMOTE_REVISION":case"REVISION_REDONE":case"REVISION_UNDONE":case"SNAPSHOT_CREATED":return this.processedRevisions.has(e.nextRevisionId);default:return!1}}isWrongServerRevisionId(e){switch(e.type){case"REMOTE_REVISION":case"REVISION_REDONE":case"REVISION_UNDONE":case"SNAPSHOT_CREATED":return e.serverRevisionId!==this.serverRevisionId;default:return!1}}dropPendingHistoryMessages(){this.waitingUndoRedoAck=!1,this.pendingMessages=this.pendingMessages.filter((({type:e})=>"REVISION_REDONE"!==e&&"REVISION_UNDONE"!==e))}}const HU=new Set(["HIDE_COLUMNS_ROWS","UNHIDE_COLUMNS_ROWS","UNFOLD_HEADER_GROUP","UNGROUP_HEADERS","FOLD_HEADER_GROUP","FOLD_ALL_HEADER_GROUPS","UNFOLD_ALL_HEADER_GROUPS","FOLD_HEADER_GROUPS_IN_ZONE","UNFOLD_HEADER_GROUPS_IN_ZONE","CREATE_TABLE","UPDATE_TABLE","UPDATE_FILTER","REMOVE_TABLE","RESIZE_TABLE","CREATE_TABLE_STYLE","REMOVE_TABLE_STYLE"]);function zU(e){return HU.has(e.type)}const BU=[$U,function(e,t){return"target"in t&&Array.isArray(t.target)?{...pt(t),target:e.getSelectedZones()}:t},WU,function(e,t){return"ranges"in t?{...pt(t),ranges:e.getSelectedZones().map((t=>e.getRangeDataFromZone(e.getActiveSheetId(),t)))}:t}];function $U(e,t){return"sheetId"in t?{...pt(t),sheetId:e.getActiveSheetId()}:t}function GU(e,t){return"zone"in t?{...pt(t),zone:e.getSelectedZone()}:t}function WU(e,t){if(!("row"in t)||!("col"in t))return t;const{col:o,row:s}=e.getActivePosition();return{...pt(t),col:o,row:s}}const qU=new Sl;function ZU(e,t){const o=e.getSelectedZone();return{...$U(e,t),elements:"COL"===t.dimension?Ct(o.left,o.right+1):Ct(o.top,o.bottom+1)}}function jU(e,t){const o=e.getSelectedZone();return{...pt(t),zone:o}}function YU(e,t){const o=pt(t),s=e.getSelectedZone(),{top:i,bottom:n,left:r,right:a}=s;return"cols"in o?o.cols=Ct(r,a+1):"rows"in o&&(o.rows=Ct(i,n+1)),o}function XU(e,t){const o=e.getSelectedZone();return{...$U(e,t),start:"COL"===t.dimension?o.left:o.top,end:"COL"===t.dimension?o.right:o.bottom}}const KU=new n;KU.add("UPDATE_CELL",QU),KU.add("CLEAR_CELL",QU),KU.add("CLEAR_CELLS",QU),KU.add("DELETE_CONTENT",QU),KU.add("ADD_MERGE",QU),KU.add("REMOVE_MERGE",QU),KU.add("SET_FORMATTING",QU),KU.add("CLEAR_FORMATTING",QU),KU.add("SET_BORDER",QU),KU.add("CREATE_TABLE",QU),KU.add("REMOVE_TABLE",QU),KU.add("HIDE_SHEET",QU),KU.add("ADD_COLUMNS_ROWS",(function(e,t){const o=e.getActivePosition();return{...$U(e,t),base:"COL"===t.dimension?o.col:o.row}})),KU.add("REMOVE_COLUMNS_ROWS",ZU),KU.add("HIDE_COLUMNS_ROWS",ZU),KU.add("RESIZE_COLUMNS_ROWS",ZU),KU.add("CREATE_SHEET",(function(e,t){const o=pt(t);o.sheetId=qU.smallUuid();const s=t.name||e.getSheet(e.getActiveSheetId()).name,i=s.match(/(.+?)\d*$/)?.[1]||s;return o.name=e.getNextSheetName(i),o})),KU.add("CREATE_FIGURE",(function(e,t){const o=WU(e,$U(e,t));return o.figureId=qU.smallUuid(),o})),KU.add("CREATE_CHART",(function(e,t){const o=qU.smallUuid();return{...$U(e,t),figureId:o,chartId:o}})),KU.add("CREATE_IMAGE",(function(e,t){return{...$U(e,t),figureId:qU.smallUuid()}})),KU.add("GROUP_HEADERS",XU),KU.add("UNGROUP_HEADERS",XU),KU.add("UNFOLD_HEADER_GROUPS_IN_ZONE",GU),KU.add("FOLD_HEADER_GROUPS_IN_ZONE",GU);const JU=new n;function QU(e,t){let o=pt(t);for(const t of BU)o=t(e,o);return o}function eH(e,t){if(e.rootCommand&&"object"==typeof e.rootCommand)return f(e.rootCommand)?function(e,t){if(!t)return;if(!KU.contains(t.type))return;return KU.get(t.type)(e,t)}(t,e.rootCommand):function(e,t,o){if(!JU.contains(t.type))return;return JU.get(t.type)(e,t,o)}(t,e.rootCommand,e.commands)}JU.add("PASTE",(function(e,t){return{type:"REPEAT_PASTE",pasteOption:pt(t.pasteOption),target:e.getSelectedZones()}})),JU.add("INSERT_CELL",jU),JU.add("DELETE_CELL",jU),JU.add("AUTORESIZE_COLUMNS",YU),JU.add("AUTORESIZE_ROWS",YU),JU.add("SORT_CELLS",(function(e,t){const o=e.getSelectedZone();return{...$U(e,t),col:o.left,row:o.top,zone:o}})),JU.add("SUM_SELECTION",QU),JU.add("SET_DECIMAL",QU),JU.add("DELETE_UNFILTERED_CONTENT",QU);class tH{trackedValues=new Set;domainToArray(e){return e.flatMap((e=>[e.field,En(e.value)]))}isValuePresent(e,t){const o=JSON.stringify({measure:e,domain:this.domainToArray(t)});return this.trackedValues.has(o)}isHeaderPresent(e){const t=JSON.stringify({domain:this.domainToArray(e)});return this.trackedValues.has(t)}trackValue(e,t){const o=JSON.stringify({measure:e,domain:this.domainToArray(t)});this.trackedValues.add(o)}trackHeader(e){const t=JSON.stringify({domain:this.domainToArray(e)});this.trackedValues.add(t)}}const oH=5242880;const sH={filterType:"criterion",type:"none",values:[]};class iH{getters;sheetId;boundaries;top;bottom;left;right;offsetX;offsetY;canScrollVertically;canScrollHorizontally;viewportWidth;viewportHeight;offsetCorrectionX;offsetCorrectionY;constructor(e,t,o,s,i,n){if(this.getters=e,this.sheetId=t,this.boundaries=o,s.width<0||s.height<0)throw new Error("Viewport size cannot be negative");this.viewportWidth=s.height&&s.width,this.viewportHeight=s.width&&s.height,this.top=o.top,this.bottom=o.bottom,this.left=o.left,this.right=o.right,this.offsetX=n.x,this.offsetY=n.y,this.canScrollVertically=i.canScrollVertically,this.canScrollHorizontally=i.canScrollHorizontally,this.offsetCorrectionX=this.getters.getColDimensions(this.sheetId,this.boundaries.left).start,this.offsetCorrectionY=this.getters.getRowDimensions(this.sheetId,this.boundaries.top).start,this.adjustViewportOffsetX(),this.adjustViewportOffsetY()}getMaxSize(){const e=this.getters.findLastVisibleColRowIndex(this.sheetId,"COL",{first:this.boundaries.left,last:this.boundaries.right}),t=this.getters.findLastVisibleColRowIndex(this.sheetId,"ROW",{first:this.boundaries.top,last:this.boundaries.bottom}),{end:o}=this.getters.getColDimensions(this.sheetId,e),{end:s}=this.getters.getRowDimensions(this.sheetId,t);let i=o-this.offsetCorrectionX;this.canScrollHorizontally&&(i=Math.max(i,this.viewportWidth));let n=s-this.offsetCorrectionY;return this.canScrollVertically&&(n=Math.max(n,this.viewportHeight),s+Fe>n&&!this.getters.isReadonly()&&(n+=Fe)),{width:i,height:n}}getColIndex(e){return e<this.offsetCorrectionX||e>this.offsetCorrectionX+this.viewportWidth?-1:this.searchHeaderIndex("COL",e-this.offsetCorrectionX+this.snapCorrection.x,this.left)}getRowIndex(e){return e<this.offsetCorrectionY||e>this.offsetCorrectionY+this.viewportHeight?-1:this.searchHeaderIndex("ROW",e-this.offsetCorrectionY+this.snapCorrection.y,this.top)}adjustPosition(e){const t=this.sheetId,o=this.getters.getMainCellPosition({sheetId:t,...e}),{col:s,row:i}=this.getters.getNextVisibleCellPosition(o);es(s,this.boundaries.top,this.boundaries)&&this.adjustPositionX(s),es(this.boundaries.left,i,this.boundaries)&&this.adjustPositionY(i)}adjustPositionX(e){const t=this.sheetId,{start:o,end:s}=this.getters.getColDimensions(t,e);this.offsetX+this.viewportWidth+this.offsetCorrectionX<s?this.offsetX=s-this.viewportWidth:this.offsetX+this.offsetCorrectionX>o&&(this.offsetX=o-this.offsetCorrectionX),this.adjustViewportZoneX()}adjustPositionY(e){const t=this.sheetId,{start:o,end:s}=this.getters.getRowDimensions(t,e);this.offsetY+this.viewportHeight+this.offsetCorrectionY<s?this.offsetY=s-this.viewportHeight:this.offsetY+this.offsetCorrectionY>o&&(this.offsetY=o-this.offsetCorrectionY),this.adjustViewportZoneY()}willNewOffsetScrollViewport(e,t){return this.canScrollHorizontally&&this.offsetX!==e||this.canScrollVertically&&this.offsetY!==t}setViewportOffset(e,t){this.setViewportOffsetX(e),this.setViewportOffsetY(t)}adjustViewportZone(){this.adjustViewportZoneX(),this.adjustViewportZoneY()}getVisibleRect(e){const t=Xo(e,this),o=this.snapCorrection.x,s=this.snapCorrection.y;if(t){return{x:this.getters.getColRowOffset("COL",this.left,t.left)+this.offsetCorrectionX-(this.left!==t.left?o:0),y:this.getters.getColRowOffset("ROW",this.top,t.top)+this.offsetCorrectionY-(this.top!==t.top?s:0),width:Math.min(this.getters.getColRowOffset("COL",t.left,t.right+1)-(this.left===t.left?o:0),this.viewportWidth),height:Math.min(this.getters.getColRowOffset("ROW",t.top,t.bottom+1)-(this.top===t.top?s:0),this.viewportHeight)}}}getFullRect(e){const t=Xo(e,this.boundaries),o=this.snapCorrection.x,s=this.snapCorrection.y;if(t){return{x:this.getters.getColRowOffset("COL",this.left,e.left)+this.offsetCorrectionX-o,y:this.getters.getColRowOffset("ROW",this.top,e.top)+this.offsetCorrectionY-s,width:this.getters.getColRowOffset("COL",e.left,e.right+1),height:this.getters.getColRowOffset("ROW",e.top,e.bottom+1)}}}isVisible(e,t){return t<=this.bottom&&t>=this.top&&e>=this.left&&e<=this.right&&!this.getters.isColHidden(this.sheetId,e)&&!this.getters.isRowHidden(this.sheetId,t)}searchHeaderIndex(e,t,o=0){if(this.viewportWidth<=0||this.viewportHeight<=0)return-1;const s=this.sheetId,i=this.getters.getNumberHeaders(s,e);let n=o,r=i;for(;n<=r&&n!==i&&-1!==r;){const i=Math.floor((n+r)/2),a=this.getters.getColRowOffset(e,o,i),l=this.getters.getHeaderSize(s,e,i);if(t>=a&&t<a+l)return i;t>=a+l?n=i+1:r=i-1}return-1}setViewportOffsetX(e){this.canScrollHorizontally&&(this.offsetX=e,this.adjustViewportZoneX())}setViewportOffsetY(e){this.canScrollVertically&&(this.offsetY=e,this.adjustViewportZoneY())}adjustViewportOffsetX(){if(this.canScrollHorizontally){const{width:e}=this.getMaxSize();this.viewportWidth+this.offsetX>e&&(this.offsetX=Math.max(0,e-this.viewportWidth))}this.adjustViewportZoneX()}adjustViewportOffsetY(){if(this.canScrollVertically){const{height:e}=this.getMaxSize();this.viewportHeight+this.offsetY>e&&(this.offsetY=Math.max(0,e-this.viewportHeight))}this.adjustViewportZoneY()}adjustViewportZoneX(){this.left=this.searchHeaderIndex("COL",this.offsetX,this.boundaries.left),this.right=Math.min(this.boundaries.right,this.searchHeaderIndex("COL",Math.max(this.viewportWidth+this.snapCorrection.x-.1),this.left)),this.viewportWidth&&(-1===this.left&&(this.left=this.boundaries.left),-1===this.right&&(this.right=this.boundaries.right))}adjustViewportZoneY(){this.top=this.searchHeaderIndex("ROW",this.offsetY,this.boundaries.top),this.bottom=Math.min(this.boundaries.bottom,this.searchHeaderIndex("ROW",Math.max(this.viewportHeight+this.snapCorrection.y-.1,0),this.top)),this.viewportHeight&&(-1===this.top&&(this.top=this.boundaries.top),-1===this.bottom&&(this.bottom=this.boundaries.bottom))}get snapCorrection(){return{x:Math.abs(this.offsetX-this.getters.getColRowOffset("COL",this.boundaries.left,Math.max(0,this.left))),y:Math.abs(this.offsetY-this.getters.getColRowOffset("ROW",this.boundaries.top,Math.max(0,this.top)))}}}const nH=(new n).add("settings",class extends gV{static getters=["getLocale"];locale=w;allowDispatch(e){return"UPDATE_LOCALE"===e.type?zl(e.locale)?"Success":"InvalidLocale":"Success"}handle(e){if("UPDATE_LOCALE"===e.type){const t=this.locale,o=e.locale;this.history.update("locale",o),this.changeCellsDateFormatWithLocale(t,o)}}getLocale(){return this.locale}changeCellsDateFormatWithLocale(e,t){for(const o of this.getters.getSheetIds())for(const[s,i]of Object.entries(this.getters.getCells(o))){let o;if(i.format===e.dateFormat&&(o=t.dateFormat),i.format===e.timeFormat&&(o=t.timeFormat),i.format===tc(e)&&(o=tc(t)),o){const{col:e,row:t,sheetId:i}=this.getters.getCellPosition(s);this.dispatch("UPDATE_CELL",{col:e,row:t,sheetId:i,format:o})}}}import(e){this.locale=e.settings?.locale??w}export(e){e.settings={locale:this.locale}}}).add("sheet",class extends gV{static getters=["getSheetName","tryGetSheetName","getSheet","tryGetSheet","getSheetIdByName","getSheetIds","getVisibleSheetIds","isSheetVisible","doesHeaderExist","doesHeadersExist","getCell","getCellPosition","getColsZone","getRowCells","getRowsZone","getNumberCols","getNumberRows","getNumberHeaders","getGridLinesVisibility","getNextSheetName","getSheetSize","getSheetZone","getPaneDivisions","checkZonesExistInSheet","getCommandZones","getUnboundedZone","checkElementsIncludeAllNonFrozenHeaders","getDuplicateSheetName"];sheetIdsMapName={};orderedSheetIds=[];sheets={};cellPosition={};allowDispatch(e){const t=this.chainValidations(this.checkSheetExists,this.checkZonesAreInSheet)(e);if("Success"!==t)return t;switch(e.type){case"HIDE_SHEET":return 1===this.getVisibleSheetIds().length?"NotEnoughSheets":"Success";case"CREATE_SHEET":return this.checkValidations(e,this.checkSheetName,this.checkSheetPosition);case"DUPLICATE_SHEET":return this.sheets[e.sheetIdTo]?"DuplicatedSheetId":this.orderedSheetIds.map(this.getSheetName.bind(this)).includes(e.sheetNameTo)?"DuplicatedSheetName":"Success";case"MOVE_SHEET":try{const t=this.orderedSheetIds.findIndex((t=>t===e.sheetId));return this.findIndexOfTargetSheet(t,e.delta),"Success"}catch(e){return"WrongSheetMove"}case"RENAME_SHEET":return this.isRenameAllowed(e);case"COLOR_SHEET":return!e.color||Fs(e.color)?"Success":"InvalidColor";case"DELETE_SHEET":return this.getVisibleSheetIds().length>1?"Success":"NotEnoughSheets";case"ADD_COLUMNS_ROWS":return this.doesHeaderExist(e.sheetId,e.dimension,e.base)?e.quantity<=0?"InvalidQuantity":"Success":"InvalidHeaderIndex";case"REMOVE_COLUMNS_ROWS":{const t=ro(e.elements),o=no(e.elements);return t<0||!this.doesHeaderExist(e.sheetId,e.dimension,o)?"InvalidHeaderIndex":this.checkElementsIncludeAllNonFrozenHeaders(e.sheetId,e.dimension,e.elements)?"NotEnoughElements":"Success"}case"FREEZE_ROWS":return this.checkValidations(e,this.checkRowFreezeQuantity,this.checkRowFreezeOverlapMerge);case"FREEZE_COLUMNS":return this.checkValidations(e,this.checkColFreezeQuantity,this.checkColFreezeOverlapMerge);default:return"Success"}}handle(e){switch(e.type){case"SET_GRID_LINES_VISIBILITY":this.setGridLinesVisibility(e.sheetId,e.areGridLinesVisible);break;case"CREATE_SHEET":const t=this.createSheet(e.sheetId,e.name||this.getNextSheetName(),e.cols||26,e.rows||100,e.position);this.history.update("sheetIdsMapName",t.name,t.id);break;case"MOVE_SHEET":this.moveSheet(e.sheetId,e.delta);break;case"RENAME_SHEET":this.renameSheet(this.sheets[e.sheetId],e.newName);break;case"COLOR_SHEET":this.history.update("sheets",e.sheetId,"color",e.color);break;case"HIDE_SHEET":this.hideSheet(e.sheetId);break;case"SHOW_SHEET":this.showSheet(e.sheetId);break;case"DUPLICATE_SHEET":this.duplicateSheet(e.sheetId,e.sheetIdTo,e.sheetNameTo);break;case"DELETE_SHEET":this.deleteSheet(this.sheets[e.sheetId]);break;case"REMOVE_COLUMNS_ROWS":"COL"===e.dimension?this.removeColumns(this.sheets[e.sheetId],[...e.elements]):this.removeRows(this.sheets[e.sheetId],[...e.elements]);break;case"ADD_COLUMNS_ROWS":"COL"===e.dimension?this.addColumns(this.sheets[e.sheetId],e.base,e.position,e.quantity):this.addRows(this.sheets[e.sheetId],e.base,e.position,e.quantity);break;case"UPDATE_CELL_POSITION":this.updateCellPosition(e);break;case"FREEZE_COLUMNS":this.setPaneDivisions(e.sheetId,e.quantity,"COL");break;case"FREEZE_ROWS":this.setPaneDivisions(e.sheetId,e.quantity,"ROW");break;case"UNFREEZE_ROWS":this.setPaneDivisions(e.sheetId,0,"ROW");break;case"UNFREEZE_COLUMNS":this.setPaneDivisions(e.sheetId,0,"COL");break;case"UNFREEZE_COLUMNS_ROWS":this.setPaneDivisions(e.sheetId,0,"COL"),this.setPaneDivisions(e.sheetId,0,"ROW")}}import(e){for(const t of e.sheets)this.sheetIdsMapName[t.name]=t.id;for(const t of e.sheets){const e=t.name||"Sheet"+(Object.keys(this.sheets).length+1),{colNumber:o,rowNumber:s}=this.getImportedSheetSize(t),i={id:t.id,name:e,numberOfCols:o,rows:Da(s),areGridLinesVisible:void 0===t.areGridLinesVisible||t.areGridLinesVisible,isVisible:t.isVisible,panes:{xSplit:t.panes?.xSplit||0,ySplit:t.panes?.ySplit||0},color:t.color};this.orderedSheetIds.push(i.id),this.sheets[i.id]=i}}exportSheets(e){e.sheets=this.orderedSheetIds.filter(Mt).map((e=>{const t=this.sheets[e],o={id:t.id,name:t.name,colNumber:t.numberOfCols,rowNumber:this.getters.getNumberRows(t.id),rows:{},cols:{},merges:[],cells:{},styles:{},formats:{},borders:{},conditionalFormats:[],dataValidationRules:[],figures:[],tables:[],areGridLinesVisible:void 0===t.areGridLinesVisible||t.areGridLinesVisible,isVisible:t.isVisible,color:t.color};return(t.panes.xSplit||t.panes.ySplit)&&(o.panes=t.panes),o}))}export(e){this.exportSheets(e)}exportForExcel(e){this.exportSheets(e)}getGridLinesVisibility(e){return this.getSheet(e).areGridLinesVisible}tryGetSheet(e){return this.sheets[e]}getSheet(e){const t=this.sheets[e];if(!t)throw new Error(`Sheet ${e} not found.`);return t}isSheetVisible(e){return this.getSheet(e).isVisible}getSheetName(e){return this.getSheet(e).name}tryGetSheetName(e){return this.tryGetSheet(e)?.name}getSheetIdByName(e){if(e){const t=mt(e);for(const e in this.sheetIdsMapName)if(Ma(e,t))return this.sheetIdsMapName[e]}}getSheetIds(){return this.orderedSheetIds}getVisibleSheetIds(){return this.orderedSheetIds.filter(this.isSheetVisible.bind(this))}doesHeaderExist(e,t,o){return"COL"===t?o>=0&&o<this.getNumberCols(e):o>=0&&o<this.getNumberRows(e)}doesHeadersExist(e,t,o){return o.every((o=>this.doesHeaderExist(e,t,o)))}getCell({sheetId:e,col:t,row:o}){const s=this.tryGetSheet(e),i=s?.rows[o]?.cells[t];if(void 0!==i)return this.getters.getCellById(i)}getColsZone(e,t,o){return{top:0,bottom:this.getNumberRows(e)-1,left:t,right:o}}getRowCells(e,t){return Object.values(this.getSheet(e).rows[t]?.cells).filter(Mt)}getRowsZone(e,t,o){return{top:t,bottom:o,left:0,right:this.getSheet(e).numberOfCols-1}}getCellPosition(e){const t=this.cellPosition[e];if(!t)throw new Error(`asking for a cell position that doesn't exist, cell id: ${e}`);return t}getNumberCols(e){return this.getSheet(e).numberOfCols}getNumberRows(e){return this.getSheet(e).rows.length}getNumberHeaders(e,t){return"COL"===t?this.getNumberCols(e):this.getNumberRows(e)}getNextSheetName(e="Sheet"){return Oa(this.orderedSheetIds.map(this.getSheetName.bind(this)),e)}getSheetSize(e){return{numberOfRows:this.getNumberRows(e),numberOfCols:this.getNumberCols(e)}}getSheetZone(e){return{top:0,left:0,bottom:this.getNumberRows(e)-1,right:this.getNumberCols(e)-1}}getUnboundedZone(e,t){if(void 0===t.bottom||void 0===t.right)return t;const o=0===t.left&&t.right===this.getNumberCols(e)-1,s=0===t.top&&t.bottom===this.getNumberRows(e)-1;return{...t,bottom:s?void 0:t.bottom,right:o&&!s?void 0:t.right}}getPaneDivisions(e){return this.getSheet(e).panes}setPaneDivisions(e,t,o){const s={...this.getPaneDivisions(e)};"COL"===o?s.xSplit=t:"ROW"===o&&(s.ySplit=t),this.history.update("sheets",e,"panes",s)}checkElementsIncludeAllNonFrozenHeaders(e,t,o){const s=this.getters.getPaneDivisions(e),i="ROW"===t?s.ySplit:s.xSplit,n=this.getters.getNumberHeaders(e,t);if(!i)return!1;return Gt(o,Ct(i,n))}getCommandZones(e){const t=[];return"zone"in e&&t.push(e.zone),"target"in e&&t.push(...e.target),"ranges"in e&&t.push(...e.ranges.map((e=>this.getters.getRangeFromRangeData(e).zone))),"col"in e&&void 0!==e.col&&"row"in e&&void 0!==e.row&&t.push({top:e.row,left:e.col,bottom:e.row,right:e.col}),t}checkZonesExistInSheet(e,t){if(!t.every(Bo))return"InvalidRange";if(t.length){const o=this.getSheetZone(e);return t.every((e=>ts(e,o)))?"Success":"TargetOutOfSheet"}return"Success"}updateCellPosition(e){const{sheetId:t,cellId:o,col:s,row:i}=e;o?this.setNewPosition(o,t,s,i):this.clearPosition(t,s,i)}setNewPosition(e,t,o,s){const i=this.cellPosition[e];i&&this.clearPosition(t,i.col,i.row),this.history.update("cellPosition",e,{row:s,col:o,sheetId:t}),this.history.update("sheets",t,"rows",s,"cells",o,e)}clearPosition(e,t,o){const s=this.sheets[e]?.rows[o].cells[t];s&&(this.history.update("cellPosition",s,void 0),this.history.update("sheets",e,"rows",o,"cells",t,void 0))}setGridLinesVisibility(e,t){this.history.update("sheets",e,"areGridLinesVisible",t)}createSheet(e,t,o,s,i){const n={id:e,name:t,numberOfCols:o,rows:Da(s),areGridLinesVisible:!0,isVisible:!0,panes:{xSplit:0,ySplit:0}},r=this.orderedSheetIds.slice();r.splice(i,0,n.id);const a=this.sheets;return this.history.update("orderedSheetIds",r),this.history.update("sheets",Object.assign({},a,{[n.id]:n})),n}moveSheet(e,t){const o=this.orderedSheetIds.slice(),s=o.findIndex((t=>t===e)),i=o.splice(s,1),n=this.findIndexOfTargetSheet(s,t);o.splice(n,0,i[0]),this.history.update("orderedSheetIds",o)}findIndexOfTargetSheet(e,t){for(;0!==t&&0<=e&&e<=this.orderedSheetIds.length;)t>0?(e++,this.isSheetVisible(this.orderedSheetIds[e])&&t--):t<0&&(e--,this.isSheetVisible(this.orderedSheetIds[e])&&t++);if(0===t)return e;throw new Error("There is not enough visible sheets")}checkSheetName(e){const t=this.getters.tryGetSheetName(e.sheetId),o="RENAME_SHEET"===e.type?e.newName:e.name;if(void 0!==t&&o===t)return"UnchangedSheetName";const{orderedSheetIds:s,sheets:i}=this,n=o&&o.trim().toLowerCase();return s.find((t=>Ma(i[t]?.name,n)&&t!==e.sheetId))?"DuplicatedSheetName":Ke.test(n)?"ForbiddenCharactersInSheetName":"Success"}checkSheetPosition(e){const{orderedSheetIds:t}=this;return e.position>t.length||e.position<0?"WrongSheetPosition":"Success"}checkRowFreezeQuantity(e){return e.quantity>=1&&e.quantity<this.getNumberRows(e.sheetId)?"Success":"InvalidFreezeQuantity"}checkColFreezeQuantity(e){return e.quantity>=1&&e.quantity<this.getNumberCols(e.sheetId)?"Success":"InvalidFreezeQuantity"}checkRowFreezeOverlapMerge(e){const t=this.getters.getMerges(e.sheetId);for(const o of t)if(o.top<e.quantity&&e.quantity<=o.bottom)return"MergeOverlap";return"Success"}checkColFreezeOverlapMerge(e){const t=this.getters.getMerges(e.sheetId);for(const o of t)if(o.left<e.quantity&&e.quantity<=o.right)return"MergeOverlap";return"Success"}isRenameAllowed(e){return e.newName&&e.newName.trim().toLowerCase()?this.checkSheetName(e):"MissingSheetName"}renameSheet(e,t){const o=e.name;this.history.update("sheets",e.id,"name",t.trim());const s=Object.assign({},this.sheetIdsMapName);delete s[o],s[t]=e.id,this.history.update("sheetIdsMapName",s)}hideSheet(e){this.history.update("sheets",e,"isVisible",!1)}showSheet(e){this.history.update("sheets",e,"isVisible",!0)}duplicateSheet(e,t,o){const s=pt(this.getSheet(e));s.id=t,s.name=o;for(let e=0;e<=s.numberOfCols;e++)for(let t=0;t<=s.rows.length;t++)s.rows[t]&&(s.rows[t].cells[e]=void 0);const i=this.orderedSheetIds.slice(),n=i.indexOf(e);i.splice(n+1,0,s.id),this.history.update("orderedSheetIds",i),this.history.update("sheets",Object.assign({},this.sheets,{[s.id]:s}));for(const t of Object.values(this.getters.getCells(e))){const{col:e,row:o}=this.getCellPosition(t.id);this.dispatch("UPDATE_CELL",{sheetId:s.id,col:e,row:o,content:t.content,format:t.format,style:t.style})}const r=Object.assign({},this.sheetIdsMapName);r[s.name]=s.id,this.history.update("sheetIdsMapName",r)}getDuplicateSheetName(e){return Pa(e,this.orderedSheetIds.map(this.getSheetName.bind(this)))}deleteSheet(e){const t=e.name,o=Object.assign({},this.sheets);delete o[e.id],this.history.update("sheets",o);const s=this.orderedSheetIds.slice(),i=s.indexOf(e.id);s.splice(i,1),this.history.update("orderedSheetIds",s);const n=Object.assign({},this.sheetIdsMapName);delete n[t],this.history.update("sheetIdsMapName",n)}removeColumns(e,t){t.sort(((e,t)=>t-e));for(const o of t)this.moveCellOnColumnsDeletion(e,o);const o=this.sheets[e.id].numberOfCols;this.history.update("sheets",e.id,"numberOfCols",o-t.length);const s=t.filter((t=>t<e.panes.xSplit)).length;s&&this.setPaneDivisions(e.id,e.panes.xSplit-s,"COL")}removeRows(e,t){t.sort(((e,t)=>t-e));for(const o of yt(t)){const t=o[o.length-1],s=o[0];this.moveCellOnRowsDeletion(e,t,s),this.updateRowsStructureOnDeletion(e,t,s)}const o=t.filter((t=>t<e.panes.ySplit)).length;o&&this.setPaneDivisions(e.id,e.panes.ySplit-o,"ROW")}addColumns(e,t,o,s){const i="before"===o?t:t+1;this.moveCellsOnAddition(e,i,s,"columns");const n=this.sheets[e.id].numberOfCols;this.history.update("sheets",e.id,"numberOfCols",n+s),i<e.panes.xSplit&&this.setPaneDivisions(e.id,e.panes.xSplit+s,"COL")}addRows(e,t,o,s){const i="before"===o?t:t+1;this.addEmptyRows(e,s),this.moveCellsOnAddition(e,i,s,"rows"),i<e.panes.ySplit&&this.setPaneDivisions(e.id,e.panes.ySplit+s,"ROW")}moveCellOnColumnsDeletion(e,t){this.dispatch("CLEAR_CELLS",{sheetId:e.id,target:[{left:t,top:0,right:t,bottom:e.rows.length-1}]});for(let o=0;o<e.rows.length;o++){const s=e.rows[o];for(const i in s.cells){const n=Number(i),r=s.cells[i];r&&n>t&&this.setNewPosition(r,e.id,n-1,o)}}}moveCellsOnAddition(e,t,o,s){const i=[];for(let n=0;n<e.rows.length;n++){const r=e.rows[n];if("rows"!==s||n>=t)for(const a in r.cells){const l=Number(a),c=r.cells[a];c&&("rows"===s||l>=t)&&i.push({sheetId:e.id,cellId:c,col:l+("columns"===s?o:0),row:n+("rows"===s?o:0),type:"UPDATE_CELL_POSITION"})}}for(const e of i.reverse())this.updateCellPosition(e)}moveCellOnRowsDeletion(e,t,o){this.dispatch("CLEAR_CELLS",{sheetId:e.id,target:[{left:0,top:t,right:this.getters.getNumberCols(e.id),bottom:o}]});const s=o-t+1;for(let t=0;t<e.rows.length;t++){const i=e.rows[t];if(t>o)for(const o in i.cells){const n=Number(o),r=i.cells[o];r&&this.setNewPosition(r,e.id,n,t-s)}}}updateRowsStructureOnDeletion(e,t,o){const s=[],i=e.rows.map((e=>e.cells)).reverse();for(const n in e.rows){const e=Number(n);e>=t&&e<=o||s.push({cells:i.pop()})}this.history.update("sheets",e.id,"rows",s)}addEmptyRows(e,t){const o=e.rows.slice();for(let e=0;e<t;e++)o.push({cells:{}});this.history.update("sheets",e.id,"rows",o)}getImportedSheetSize(e){const t=Object.keys(e.cells).map(Do);let o=e.rowNumber,s=e.colNumber;for(const{col:e,row:i}of t)o=Math.max(o,i+1),s=Math.max(s,e+1);return{rowNumber:o,colNumber:s}}checkSheetExists(e){return"CREATE_SHEET"!==e.type&&"sheetId"in e&&void 0===this.sheets[e.sheetId]?"InvalidSheetId":"CREATE_SHEET"===e.type&&void 0!==this.sheets[e.sheetId]?"DuplicatedSheetId":"Success"}checkZonesAreInSheet(e){return"sheetId"in e?"ranges"in e&&e.ranges.some((e=>""!==e._sheetId&&!this.getters.tryGetSheet(e._sheetId)))?"InvalidSheetId":this.checkZonesExistInSheet(e.sheetId,this.getCommandZones(e)):"Success"}}).add("header grouping",class extends gV{static getters=["getHeaderGroups","getGroupsLayers","getVisibleGroupLayers","getHeaderGroup","getHeaderGroupsInZone","isGroupFolded","isRowFolded","isColFolded"];groups={};allowDispatch(e){switch(e.type){case"GROUP_HEADERS":{const{start:t,end:o,sheetId:s}=e;if(!this.getters.tryGetSheet(s))return"InvalidSheetId";if(!this.getters.doesHeadersExist(e.sheetId,e.dimension,[t,o]))return"InvalidHeaderGroupStartEnd";if(t>o)return"InvalidHeaderGroupStartEnd";if(this.findGroupWithStartEnd(e.sheetId,e.dimension,t,o))return"HeaderGroupAlreadyExists";break}case"UNGROUP_HEADERS":{const{start:t,end:o,sheetId:s}=e;if(!this.getters.tryGetSheet(s))return"InvalidSheetId";if(!this.getters.doesHeadersExist(e.sheetId,e.dimension,[t,o]))return"InvalidHeaderGroupStartEnd";if(t>o)return"InvalidHeaderGroupStartEnd";break}case"UNFOLD_HEADER_GROUP":case"FOLD_HEADER_GROUP":if(!this.getters.tryGetSheet(e.sheetId))return"InvalidSheetId";const t=this.findGroupWithStartEnd(e.sheetId,e.dimension,e.start,e.end);if(!t)return"UnknownHeaderGroup";if(Ct(0,this.getters.getNumberHeaders(e.sheetId,e.dimension)).every((o=>o>=t.start&&o<=t.end||this.getters.isHeaderHiddenByUser(e.sheetId,e.dimension,o))))return"NotEnoughElements"}return"Success"}handle(e){switch(e.type){case"CREATE_SHEET":this.history.update("groups",e.sheetId,{ROW:[],COL:[]});break;case"GROUP_HEADERS":this.groupHeaders(e.sheetId,e.dimension,e.start,e.end);break;case"UNGROUP_HEADERS":this.unGroupHeaders(e.sheetId,e.dimension,e.start,e.end);break;case"DUPLICATE_SHEET":{const t=pt(this.groups[e.sheetId]);this.history.update("groups",e.sheetIdTo,t);break}case"DELETE_SHEET":{const t={...this.groups};delete t[e.sheetId],this.history.update("groups",t);break}case"ADD_COLUMNS_ROWS":const t=Ht(e.position,e.base);this.moveGroupsOnHeaderInsertion(e.sheetId,e.dimension,t,e.quantity);break;case"REMOVE_COLUMNS_ROWS":this.moveGroupsOnHeaderDeletion(e.sheetId,e.dimension,e.elements);break;case"UNFOLD_HEADER_GROUP":{const t=this.findGroupWithStartEnd(e.sheetId,e.dimension,e.start,e.end);t&&this.unfoldHeaderGroup(e.sheetId,e.dimension,t);break}case"FOLD_HEADER_GROUP":{const t=this.findGroupWithStartEnd(e.sheetId,e.dimension,e.start,e.end);t&&this.foldHeaderGroup(e.sheetId,e.dimension,t);break}case"UNFOLD_ALL_HEADER_GROUPS":{const t=this.getters.getHeaderGroups(e.sheetId,e.dimension);for(const o of t)this.unfoldHeaderGroup(e.sheetId,e.dimension,o);break}case"FOLD_ALL_HEADER_GROUPS":{const t=this.getters.getHeaderGroups(e.sheetId,e.dimension);for(const o of t)this.foldHeaderGroup(e.sheetId,e.dimension,o);break}case"FOLD_HEADER_GROUPS_IN_ZONE":case"UNFOLD_HEADER_GROUPS_IN_ZONE":{const t="UNFOLD_HEADER_GROUPS_IN_ZONE"===e.type?"unfold":"fold",o=this.getGroupsLayers(e.sheetId,e.dimension);"fold"===t&&o.reverse();const s=o.flat(),i="ROW"===e.dimension?e.zone.top:e.zone.left,n="ROW"===e.dimension?e.zone.bottom:e.zone.right,r=new Set;for(let e=i;e<=n;e++){const o=s.filter((t=>t.start-1<=e&&e<=t.end));for(const e of o)if(!("fold"===t&&e.isFolded||"unfold"===t&&!e.isFolded)){r.add(e);break}}for(const o of r)"unfold"===t?this.unfoldHeaderGroup(e.sheetId,e.dimension,o):this.foldHeaderGroup(e.sheetId,e.dimension,o);break}}}getHeaderGroups(e,t){return this.groups[e][t]}getHeaderGroup(e,t,o,s){return this.getHeaderGroups(e,t).find((e=>e.start===o&&e.end===s))}getHeaderGroupsInZone(e,t,o){return this.getHeaderGroups(e,t).filter((e=>{const s="ROW"===t?o.top:o.left,i="ROW"===t?o.bottom:o.right;return this.doGroupOverlap(e,s,i)}))}getGroupsLayers(e,t){const o=this.getHeaderGroups(e,t);return this.bricksFallingAlgorithm(o,0,0)}getVisibleGroupLayers(e,t){const o=this.getGroupsLayers(e,t);for(const s of o)for(let o=s.length-1;o>=0;o--){const i=s[o];if(0===i.start)continue;Ct(i.start-1,i.end+1).every((o=>this.getters.isHeaderHiddenByUser(e,t,o)))&&s.splice(o,1)}return o.filter((e=>e.length>0))}isGroupFolded(e,t,o,s){return this.getHeaderGroup(e,t,o,s)?.isFolded||!1}isRowFolded(e,t){return this.getters.getHeaderGroups(e,"ROW").some((e=>e.start<=t&&t<=e.end&&e.isFolded))}isColFolded(e,t){return this.getters.getHeaderGroups(e,"COL").some((e=>e.start<=t&&t<=e.end&&e.isFolded))}getGroupId(e){return`${e.start}-${e.end}}`}bricksFallingAlgorithm(e,t,o,s=0){const i={};for(const t of e)i[this.getGroupId(t)]=t.isFolded;const n={};for(const t of e)for(let e=t.start;e<=t.end;e++)n[e]=n[e]?n[e]+1:1;for(let e=t;e<=o;e++)n[e]=n[e]?n[e]+s:s;const r=Math.max(...Object.values(n),0),a=Array.from({length:r},(()=>[])),l=Math.max(o,...e.map((e=>e.end))),c=Math.min(t,...e.map((e=>e.start)));for(let e=c;e<=l;e++){const t=n[e]||0;for(let o=0;o<t;o++){const t=a[o].at(-1);if(t&&Kt([t.end,e]))t.end++;else{const t={start:e,end:e};a[o].push(t)}}}for(const e of a)for(const t of e)t.isFolded=i[this.getGroupId(t)];return a}groupHeaders(e,t,o,s){const i=this.getHeaderGroups(e,t),n=this.bricksFallingAlgorithm(i,o,s,1).flat();this.history.update("groups",e,t,this.removeDuplicateGroups(n))}unGroupHeaders(e,t,o,s){const i=this.getHeaderGroups(e,t),n=this.bricksFallingAlgorithm(i,o,s,-1).flat();this.history.update("groups",e,t,this.removeDuplicateGroups(n))}moveGroupsOnHeaderInsertion(e,t,o,s){const i=this.groups[e][t];for(let n=0;n<i.length;n++){const r=i[n],[a,l]=_a(o,s,[r.start,r.end]);a===r.start&&l===r.end||this.history.update("groups",e,t,n,{...r,start:a,end:l})}}moveGroupsOnHeaderDeletion(e,t,o){const s=this.getHeaderGroups(e,t),i=[];for(const e of s){const t=Fa(o,Ct(e.start,e.end+1));0!==t.length&&i.push({...e,start:Math.min(...t),end:Math.max(...t)})}this.history.update("groups",e,t,this.bricksFallingAlgorithm(i,0,0).flat())}doGroupOverlap(e,t,o){return e.start<=o&&e.end>=t}removeDuplicateGroups(e){const t={};for(const o of e)t[this.getGroupId(o)]=o;return Object.values(t)}findGroupWithStartEnd(e,t,o,s){return this.getHeaderGroups(e,t).find((e=>e.start===o&&e.end===s))}foldHeaderGroup(e,t,o){const s=this.getGroupIndex(e,t,o.start,o.end);if(void 0===s)return;this.history.update("groups",e,t,s,"isFolded",!0);const i=this.getters.getHeaderGroups(e,t);for(let s=0;s<i.length;s++){const n=i[s];n.start===o.start&&n.end<=o.end&&this.history.update("groups",e,t,s,"isFolded",!0)}}unfoldHeaderGroup(e,t,o){const s=this.getGroupIndex(e,t,o.start,o.end);if(void 0===s)return;this.history.update("groups",e,t,s,"isFolded",!1);const i=this.getters.getHeaderGroups(e,t);for(let s=0;s<i.length;s++){const n=i[s];n.start===o.start&&n.end>=o.end&&this.history.update("groups",e,t,s,"isFolded",!1)}}getGroupIndex(e,t,o,s){const i=this.groups[e][t].findIndex((e=>e.start===o&&e.end===s));return-1===i?void 0:i}import(e){for(const t of e.sheets)if(this.groups[t.id]={ROW:[],COL:[]},t.headerGroups)for(const e of["ROW","COL"])for(const o of t.headerGroups[e]||[])this.groups[t.id][e].push({...o})}export(e){for(const t of e.sheets)t.headerGroups=this.groups[t.id]}exportForExcel(e){for(const t of e.sheets)for(const e of["ROW","COL"]){const o=this.getGroupsLayers(t.id,e);for(let s=0;s<o.length;s++){const i=o[s];for(const o of i){for(let i=o.start;i<=o.end;i++){const n=vA(t,e,i);n.outlineLevel=s+1,o.isFolded&&(n.isHidden=!0)}if(o.isFolded){vA(t,e,o.end+1).collapsed=!0}}}}}}).add("header visibility",class extends gV{static getters=["checkElementsIncludeAllVisibleHeaders","getHiddenColsGroups","getHiddenRowsGroups","isHeaderHiddenByUser","isRowHiddenByUser","isColHiddenByUser"];hiddenHeaders={};allowDispatch(e){switch(e.type){case"HIDE_COLUMNS_ROWS":{if(!this.getters.tryGetSheet(e.sheetId))return"InvalidSheetId";const t="COL"===e.dimension?this.getHiddenColsGroups(e.sheetId):this.getHiddenRowsGroups(e.sheetId),o="COL"===e.dimension?this.getters.getNumberCols(e.sheetId):this.getters.getNumberRows(e.sheetId);return new Set((t||[]).flat().concat(e.elements)).size>=o?"TooManyHiddenElements":ro(e.elements)<0||no(e.elements)>o?"InvalidHeaderIndex":"Success"}case"REMOVE_COLUMNS_ROWS":return this.getters.tryGetSheet(e.sheetId)?this.checkElementsIncludeAllVisibleHeaders(e.sheetId,e.dimension,e.elements)?"NotEnoughElements":"Success":"InvalidSheetId"}return"Success"}handle(e){switch(e.type){case"CREATE_SHEET":const t={COL:Array(this.getters.getNumberCols(e.sheetId)).fill(!1),ROW:Array(this.getters.getNumberRows(e.sheetId)).fill(!1)};this.history.update("hiddenHeaders",e.sheetId,t);break;case"DUPLICATE_SHEET":this.history.update("hiddenHeaders",e.sheetIdTo,pt(this.hiddenHeaders[e.sheetId]));break;case"DELETE_SHEET":this.history.update("hiddenHeaders",e.sheetId,void 0);break;case"REMOVE_COLUMNS_ROWS":{const t=[...this.hiddenHeaders[e.sheetId][e.dimension]];for(const o of[...e.elements].sort(((e,t)=>t-e)))t.splice(o,1);this.history.update("hiddenHeaders",e.sheetId,e.dimension,t);break}case"ADD_COLUMNS_ROWS":{const t=Ht(e.position,e.base),o=eo([...this.hiddenHeaders[e.sheetId][e.dimension]],Array(e.quantity).fill(!1),t);this.history.update("hiddenHeaders",e.sheetId,e.dimension,o);break}case"HIDE_COLUMNS_ROWS":for(const t of e.elements)this.history.update("hiddenHeaders",e.sheetId,e.dimension,t,!0);break;case"UNHIDE_COLUMNS_ROWS":for(const t of e.elements)this.history.update("hiddenHeaders",e.sheetId,e.dimension,t,!1)}}checkElementsIncludeAllVisibleHeaders(e,t,o){return Gt(o,this.getAllVisibleHeaders(e,t))}isHeaderHiddenByUser(e,t,o){return"COL"===t?this.isColHiddenByUser(e,o):this.isRowHiddenByUser(e,o)}isRowHiddenByUser(e,t){return this.hiddenHeaders[e].ROW[t]||this.getters.isRowFolded(e,t)}isColHiddenByUser(e,t){return this.hiddenHeaders[e].COL[t]||this.getters.isColFolded(e,t)}getHiddenColsGroups(e){const t=[[]],o=this.hiddenHeaders[e].COL;for(let e=0;e<o.length;e++){o[e]?t[t.length-1].push(e):0!==t[t.length-1].length&&t.push([])}return 0===t[t.length-1].length&&t.pop(),t}getHiddenRowsGroups(e){const t=[[]],o=this.hiddenHeaders[e].ROW;for(let e=0;e<o.length;e++){o[e]?t[t.length-1].push(e):0!==t[t.length-1].length&&t.push([])}return 0===t[t.length-1].length&&t.pop(),t}getAllVisibleHeaders(e,t){const o=Ct(0,this.getters.getNumberHeaders(e,t)),s=[];return this.getters.getHeaderGroups(e,t).forEach((e=>{e.isFolded&&s.push(...Ct(e.start,e.end+1))})),o.filter((o=>!this.hiddenHeaders[e][t][o]&&!s.includes(o)))}import(e){for(const t of e.sheets){this.hiddenHeaders[t.id]={COL:[],ROW:[]};for(let e=0;e<t.rowNumber;e++)this.hiddenHeaders[t.id].ROW[e]=Boolean(t.rows[e]?.isHidden);for(let e=0;e<t.colNumber;e++)this.hiddenHeaders[t.id].COL[e]=Boolean(t.cols[e]?.isHidden)}}exportForExcel(e){this.exportData(e,!0)}export(e){this.exportData(e)}exportData(e,t=!1){for(const o of e.sheets){void 0===o.rows&&(o.rows={});for(let e=0;e<this.getters.getNumberRows(o.id);e++)(t||this.hiddenHeaders[o.id].ROW[e])&&(void 0===o.rows[e]&&(o.rows[e]={}),o.rows[e].isHidden||=this.hiddenHeaders[o.id].ROW[e]);void 0===o.cols&&(o.cols={});for(let e=0;e<this.getters.getNumberCols(o.id);e++)(t||this.hiddenHeaders[o.id].COL[e])&&(void 0===o.cols[e]&&(o.cols[e]={}),o.cols[e].isHidden||=this.hiddenHeaders[o.id].COL[e])}}}).add("tables",class extends gV{static getters=["getCoreTable","getCoreTables","getCoreTableMatchingTopLeft"];tables={};nextTableId=1;adaptRanges(e,t){for(const o of this.getCoreTables(t))this.applyRangeChangeOnTable(t,o,e)}allowDispatch(e){switch(e.type){case"CREATE_TABLE":if(e.ranges.some((t=>!this.getters.tryGetSheet(t._sheetId)||t._sheetId!==e.sheetId)))return"InvalidSheetId";const t=e.ranges.map((e=>this.getters.getRangeFromRangeData(e).zone));return ms(t)?this.checkValidations(e,(e=>this.getTablesOverlappingZones(e.sheetId,t).length?"TableOverlap":"Success"),(e=>this.checkTableConfigUpdateIsValid(e.config))):"NonContinuousTargets";case"UPDATE_TABLE":return this.getCoreTableMatchingTopLeft(e.sheetId,e.zone)?this.checkValidations(e,this.checkUpdatedTableZoneIsValid,(e=>this.checkTableConfigUpdateIsValid(e.config))):"TableNotFound";case"ADD_MERGE":for(const t of this.getCoreTables(e.sheetId)){const o=t.range.zone;for(const t of e.target)if(Qo(o,t))return"MergeInTable"}}return"Success"}handle(e){switch(e.type){case"CREATE_SHEET":this.history.update("tables",e.sheetId,{});break;case"DELETE_SHEET":{const t={...this.tables};delete t[e.sheetId],this.history.update("tables",t);break}case"DUPLICATE_SHEET":{const t={};for(const o of this.getCoreTables(e.sheetId))t[o.id]="dynamic"===o.type?this.copyDynamicTableForSheet(e.sheetIdTo,o):this.copyStaticTableForSheet(e.sheetIdTo,o);this.history.update("tables",e.sheetIdTo,t);break}case"CREATE_TABLE":{const t=e.ranges.map((e=>this.getters.getRangeFromRangeData(e))),o=this.getters.getRangesUnion(t),s=this.getters.getMergesInZone(e.sheetId,o.zone);s.length&&this.dispatch("REMOVE_MERGE",{sheetId:e.sheetId,target:s});const i=this.consumeNextId(),n=e.config||MT,r="dynamic"===e.tableType?this.createDynamicTable(i,o,n):this.createStaticTable(i,e.tableType,o,n);this.history.update("tables",e.sheetId,r.id,r);break}case"REMOVE_TABLE":{const t={};for(const o of this.getCoreTables(e.sheetId))e.target.every((e=>!Xo(o.range.zone,e)))&&(t[o.id]=o);this.history.update("tables",e.sheetId,t);break}case"UPDATE_TABLE":this.updateTable(e);break;case"UPDATE_CELL":{const t=e.sheetId;for(const o of this.getCoreTables(t)){if("dynamic"===o.type)continue;const s=this.canUpdateCellCmdExtendTable(e,o);"down"===s?this.extendTableDown(t,o):"right"===s&&this.extendTableRight(t,o)}break}case"DELETE_CONTENT":{const t={...this.tables[e.sheetId]};for(const o in t){const s=t[o];s&&e.target.some((e=>ts(s.range.zone,e)))&&this.dispatch("REMOVE_TABLE",{sheetId:e.sheetId,target:[s.range.zone]})}break}}}getCoreTables(e){return this.tables[e]?Object.values(this.tables[e]).filter(Mt):[]}getCoreTable({sheetId:e,col:t,row:o}){return this.getCoreTables(e).find((e=>es(t,o,e.range.zone)))}getTablesOverlappingZones(e,t){return this.getCoreTables(e).filter((e=>t.some((t=>Qo(e.range.zone,t)))))}extendTableDown(e,t){const o=this.getters.extendRange(t.range,"ROW",1);this.history.update("tables",e,t.id,this.updateStaticTable(t,o))}extendTableRight(e,t){const o=this.getters.extendRange(t.range,"COL",1);this.history.update("tables",e,t.id,this.updateStaticTable(t,o))}canUpdateCellCmdExtendTable({content:e,sheetId:t,col:o,row:s},i){if(!e)return"none";const n=i.range.zone;let r="none";if(n.bottom+1===s&&o>=n.left&&o<=n.right?r="down":n.right+1===o&&s>=n.top&&s<=n.bottom&&(r="right"),"none"===r)return"none";const a="down"===r?{...n,bottom:n.bottom+1,top:n.bottom+1}:{...n,right:n.right+1,left:n.right+1};for(let e=a.top;e<=a.bottom;e++)for(let o=a.left;o<=a.right;o++){const s={sheetId:t,col:o,row:e},i=this.getters.getCell(s)?.content;if(i||this.getters.isInMerge(s)||this.getTablesOverlappingZones(t,[cs(s)]).length)return"none"}return r}getCoreTableMatchingTopLeft(e,t){for(const o of this.getCoreTables(e)){const e=o.range.zone;if(e.left===t.left&&e.top===t.top)return o}}checkUpdatedTableZoneIsValid(e){if(!e.newTableRange)return"Success";const t=this.getters.getRangeFromRangeData(e.newTableRange).zone,o=this.getters.checkZonesExistInSheet(e.sheetId,[t]);if("Success"!==o)return o;const s=this.getCoreTableMatchingTopLeft(e.sheetId,e.zone);if(!s)return"TableNotFound";return this.getTablesOverlappingZones(e.sheetId,[t]).filter((e=>e.id!==s.id)).length?"TableOverlap":"Success"}checkTableConfigUpdateIsValid(e){return e&&(void 0!==e.numberOfHeaders&&e.numberOfHeaders<0||e.hasFilters&&0===e.numberOfHeaders)?"InvalidTableConfig":"Success"}createStaticTable(e,t,o,s,i){const n=o.zone;if(!i){i=[];for(const e of Ct(n.left,n.right+1)){const t={...n,left:e,right:e},r=this.consumeNextId();i.push(this.createFilterFromZone(r,o.sheetId,t,s))}}return{id:e,range:o,filters:i,config:s,type:t}}createDynamicTable(e,t,o){const s=hs(t.zone);return{id:e,range:this.getters.getRangeFromZone(t.sheetId,s),config:o,type:"dynamic"}}updateTable(e){const t=this.getCoreTableMatchingTopLeft(e.sheetId,e.zone);if(!t)return;const o=e.newTableRange?this.getters.getRangeFromRangeData(e.newTableRange):void 0;if(o){const t=this.getters.getMergesInZone(e.sheetId,o.zone);this.dispatch("REMOVE_MERGE",{sheetId:e.sheetId,target:t})}const s=o||t.range,i=this.updateTableConfig(e.config,t.config),n=e.tableType??t.type;if("dynamic"===n&&"dynamic"!==t.type||"dynamic"!==n&&"dynamic"===t.type){const o="dynamic"===n?this.createDynamicTable(t.id,s,i):this.createStaticTable(t.id,n,s,i);this.history.update("tables",e.sheetId,t.id,o)}else{const o="dynamic"===t.type?this.updateDynamicTable(t,s,i):this.updateStaticTable(t,s,i,n);this.history.update("tables",e.sheetId,t.id,o)}}updateStaticTable(e,t,o,s=e.type){if("dynamic"===s)throw new Error("Cannot use updateStaticTable to update a dynamic table");const i=t||e.range,n=i.zone,r=this.updateTableConfig(o,e.config),a=r||e.config,l=[];if(t||r&&"numberOfHeaders"in r)for(const t of Ct(n.left,n.right+1)){const o=n.top===e.range.zone.top?e.filters.find((e=>e.col===t)):void 0,s={...n,left:t,right:t},r=o?.id||this.consumeNextId();l.push(this.createFilterFromZone(r,i.sheetId,s,a))}return{...e,range:i,config:a,filters:l.length?l:e.filters,type:s}}updateDynamicTable(e,t,o){const s=t?this.getters.getRangeFromZone(t.sheetId,hs(t.zone)):e.range,i=o||e.config;return{...e,range:s,config:i}}updateTableConfig(e,t){if(!e)return t;const o={...t,...e};return 0===e.numberOfHeaders?o.hasFilters=!1:!0===e.hasFilters&&(o.numberOfHeaders||=1),o}createFilterFromZone(e,t,o,s){return OF(e,this.getters.getRangeFromZone(t,o),s,this.getters.getRangeFromZone)}copyStaticTableForSheet(e,t){const o=this.getters.getRangeFromZone(e,t.range.zone),s=t.filters.map((o=>{const s=this.getters.getRangeFromZone(e,o.rangeWithHeaders.zone);return OF(o.id,s,t.config,this.getters.getRangeFromZone)}));return{id:t.id,range:o,filters:s,config:pt(t.config),type:t.type}}copyDynamicTableForSheet(e,t){const o=this.getters.getRangeFromZone(e,t.range.zone);return{id:t.id,range:o,config:pt(t.config),type:"dynamic"}}applyRangeChangeOnTable(e,t,o){const s=o(t.range);let i;switch(s.changeType){case"REMOVE":return void this.history.update("tables",e,t.id,void 0);case"NONE":return;default:i=s.range}if("dynamic"===t.type){const o=this.updateDynamicTable(t,i);return void this.history.update("tables",e,t.id,o)}const n=[];for(const e of t.filters){const s=o(e.rangeWithHeaders);switch(s.changeType){case"REMOVE":continue;case"NONE":n.push(e);break;default:const o=s.range,i=OF(e.id,o,t.config,this.getters.getRangeFromZone);n.push(i)}}const r=i.zone;if(n.length<os(r).numberOfCols){for(let o=r.left;o<=r.right;o++)if(!n.find((e=>e.col===o))){const s=this.consumeNextId(),i={...r,left:o,right:o};n.push(this.createFilterFromZone(s,e,i,t.config))}n.sort(((e,t)=>e.col-t.col))}const a=this.createStaticTable(t.id,t.type,i,t.config,n);this.history.update("tables",e,t.id,a)}consumeNextId(){const e=`${this.nextTableId}`;return this.history.update("nextTableId",this.nextTableId+1),e}import(e){for(const t of e.sheets)for(const e of t.tables||[]){const o=this.consumeNextId(),s=e.config||MT,i=this.getters.getRangeFromSheetXC(t.id,e.range),n=e.type||"static",r="dynamic"===n?this.createDynamicTable(o,i,s):this.createStaticTable(o,n,i,s);this.history.update("tables",t.id,r.id,r)}}export(e){for(const t of e.sheets)for(const e of this.getCoreTables(t.id)){const o={range:Go(e.range.zone),type:e.type};zt(e.config,MT)||(o.config=e.config),t.tables.push(o)}}exportForExcel(e){for(const t of e.sheets)for(const e of this.getCoreTables(t.id)){const o=Go(e.range.zone);t.tables.push({range:o,filters:[],config:e.config})}}}).add("dataValidation",class extends gV{static getters=["cellHasListDataValidationIcon","getDataValidationRule","getDataValidationRules","getValidationRuleForCell"];rules={};adaptRanges(e,t){this.adaptDVRanges(t,e),this.adaptDVFormulas(e)}adaptDVFormulas(e){for(const t in this.rules){for(let o=this.rules[t].length-1;o>=0;o--){const s=this.rules[t][o];for(let i=0;i<s.criterion.values.length;i++){const n=this.getters.adaptFormulaStringDependencies(t,s.criterion.values[i],e);this.history.update("rules",t,o,"criterion","values",i,n)}}}}adaptDVRanges(e,t){for(let o=this.rules[e].length-1;o>=0;o--){const s=this.rules[e][o];for(let i=s.ranges.length-1;i>=0;i--){const n=t(s.ranges[i]);switch(n.changeType){case"REMOVE":if(1===s.ranges.length)this.removeDataValidationRule(e,s.id);else{const t=s.ranges.slice();t.splice(i,1),this.history.update("rules",e,o,"ranges",t)}break;case"RESIZE":case"MOVE":case"CHANGE":this.history.update("rules",e,o,"ranges",i,n.range)}}}}allowDispatch(e){switch(e.type){case"ADD_DATA_VALIDATION_RULE":return this.getters.tryGetSheet(e.sheetId)?e.ranges.some((e=>!this.getters.tryGetSheet(e._sheetId)))?"InvalidSheetId":this.checkValidations(e,this.chainValidations(this.checkEmptyRange,this.checkValidRange,this.checkCriterionTypeIsValid,this.checkCriterionHasValidNumberOfValues,this.checkCriterionValuesAreValid)):"InvalidSheetId";case"REMOVE_DATA_VALIDATION_RULE":if(!this.getters.tryGetSheet(e.sheetId))return"InvalidSheetId";if(!this.rules[e.sheetId].find((t=>t.id===e.id)))return"UnknownDataValidationRule"}return"Success"}handle(e){switch(e.type){case"CREATE_SHEET":this.history.update("rules",e.sheetId,[]);break;case"DUPLICATE_SHEET":{const t=pt(this.rules[e.sheetId]).map((t=>({...t,ranges:t.ranges.map((t=>za(e.sheetId,e.sheetIdTo,t)))})));this.history.update("rules",e.sheetIdTo,t);break}case"DELETE_SHEET":{const t={...this.rules};delete t[e.sheetId],this.history.update("rules",t);break}case"REMOVE_DATA_VALIDATION_RULE":this.removeDataValidationRule(e.sheetId,e.id);break;case"ADD_DATA_VALIDATION_RULE":{const t=e.ranges.map((e=>this.getters.getRangeFromRangeData(e)));this.addDataValidationRule(e.sheetId,{...e.rule,ranges:t});break}case"DELETE_CONTENT":{const t=Fo(e.target),o=e.sheetId;for(const e of t)for(let t=e.top;t<=e.bottom;t++)for(let s=e.left;s<=e.right;s++){const e=this.getValidationRuleForCell({sheetId:o,col:s,row:t});if(e&&("isBoolean"===e.criterion.type||"isValueInList"===e.criterion.type&&!this.getters.getCell({sheetId:o,col:s,row:t})?.content)){const e=this.rules[o],i=[this.getters.getRangeFromSheetXC(o,_o(s,t))],n=this.removeRangesFromRules(o,i,e);this.history.update("rules",o,n)}}}}}getDataValidationRules(e){return this.rules[e]}getDataValidationRule(e,t){return this.rules[e].find((e=>e.id===t))}getValidationRuleForCell({sheetId:e,col:t,row:o}){if(this.rules[e])for(const s of this.rules[e])for(const e of s.ranges)if(es(t,o,e.zone))return s}cellHasListDataValidationIcon(e){const t=this.getValidationRuleForCell(e);return!!t&&!("isValueInList"!==t.criterion.type&&"isValueInRange"!==t.criterion.type||"arrow"!==t.criterion.displayStyle&&"chip"!==t.criterion.displayStyle)}addDataValidationRule(e,t){const o=this.rules[e];"isBoolean"===t.criterion.type?this.setCenterStyleToBooleanCells(t):"isValueInList"===t.criterion.type&&(t.criterion.values=Array.from(new Set(t.criterion.values)));const s=this.removeRangesFromRules(e,t.ranges,o,t.id),i=s.findIndex((e=>e.id===t.id));-1!==i?(s[i]=t,this.history.update("rules",e,s)):this.history.update("rules",e,[...s,t])}removeRangesFromRules(e,t,o,s){o=pt(o);for(const e of o)e.id!==s&&(e.ranges=this.getters.recomputeRanges(e.ranges,t));return o.filter((e=>e.ranges.length>0))}removeDataValidationRule(e,t){const o=this.rules[e].filter((e=>e.id!==t));this.history.update("rules",e,o)}setCenterStyleToBooleanCells(e){for(const t of $a(e.ranges)){const e=this.getters.getCell(t),o={...e?.style,align:e?.style?.align??"center",verticalAlign:e?.style?.verticalAlign??"middle"};this.dispatch("UPDATE_CELL",{...t,style:o})}}checkEmptyRange(e){return e.ranges.length?"Success":"EmptyRange"}import(e){for(const t of e.sheets)if(this.rules[t.id]=[],t.dataValidationRules)for(const e of t.dataValidationRules)this.rules[t.id].push({...e,ranges:e.ranges.map((e=>this.getters.getRangeFromSheetXC(t.id,e)))})}export(e){if(e.sheets)for(const t of e.sheets){t.dataValidationRules=[];for(const e of this.rules[t.id])t.dataValidationRules.push({...e,ranges:e.ranges.map((e=>this.getters.getRangeString(e,t.id)))})}}exportForExcel(e){if(e.sheets)for(const t of e.sheets){t.dataValidationRules=[];for(const e of this.rules[t.id]){const o={...pt(e),ranges:e.ranges.map((e=>this.getters.getRangeString(e,t.id,{useBoundedReference:!0})))};"isValueInRange"===e.criterion.type&&(o.criterion.values=e.criterion.values.map((e=>{const o=this.getters.getRangeFromSheetXC(t.id,e);return this.getters.getRangeString(o,t.id,{useBoundedReference:!0,useFixedReference:!0})}))),t.dataValidationRules.push(o)}}}checkCriterionTypeIsValid(e){return sR.contains(e.rule.criterion.type)?"Success":"UnknownDataValidationCriterionType"}checkCriterionHasValidNumberOfValues(e){const t=e.rule.criterion,o=sR.get(t.type).numberOfValues(t);return void 0!==o&&t.values.length!==o?"InvalidNumberOfCriterionValues":"Success"}checkCriterionValuesAreValid(e){const t=e.rule.criterion,o=sR.get(t.type);return t.values.some((e=>"onlyFormulas"===o.allowedValues&&!e.startsWith("=")||(e.startsWith("=")?"onlyLiterals"===o.allowedValues||$C(e).isBadExpression:!o.isCriterionValueValid(e))))?"InvalidDataValidationCriterionValue":"Success"}checkValidRange(e){const t=e.ranges.map((e=>this.getters.getRangeFromRangeData(e))),o=t.map((t=>this.getters.getRangeString(t,e.sheetId)));return o.some((e=>!this.getters.isRangeValid(e)))?"InvalidRange":"Success"}}).add("cell",class extends gV{static getters=["zoneToXC","getCells","getTranslatedCellFormula","getCellStyle","getCellById","getFormulaString","getFormulaMovedInSheet"];nextId=1;cells={};adaptRanges(e,t,o){for(const s of Object.keys(this.cells))for(const i of Object.values(this.cells[s]||{}))if(i.isFormula)for(const n of i.compiledFormula.dependencies)if(n.sheetId===t||n.invalidSheetName===o.old){const t=e(n);"NONE"!==t.changeType&&this.history.update("cells",s,i.id,"compiledFormula","dependencies",i.compiledFormula.dependencies.indexOf(n),t.range)}}allowDispatch(e){switch(e.type){case"UPDATE_CELL":return this.checkValidations(e,this.checkCellOutOfSheet,this.checkUselessUpdateCell);case"CLEAR_CELL":return this.checkValidations(e,this.checkCellOutOfSheet,this.checkUselessClearCell);case"UPDATE_CELL_POSITION":return!e.cellId||this.cells[e.sheetId]?.[e.cellId]?"Success":"InvalidCellId";default:return"Success"}}handle(e){switch(e.type){case"SET_FORMATTING":"style"in e&&this.setStyle(e.sheetId,e.target,e.style),"format"in e&&void 0!==e.format&&this.setFormatter(e.sheetId,e.target,e.format);break;case"CLEAR_FORMATTING":this.clearFormatting(e.sheetId,e.target);break;case"ADD_COLUMNS_ROWS":"COL"===e.dimension?this.handleAddColumnsRows(e,this.copyColumnStyle.bind(this)):this.handleAddColumnsRows(e,this.copyRowStyle.bind(this));break;case"UPDATE_CELL":this.updateCell(e.sheetId,e.col,e.row,e);break;case"CLEAR_CELL":this.dispatch("UPDATE_CELL",{sheetId:e.sheetId,col:e.col,row:e.row,content:"",style:null,format:""});break;case"CLEAR_CELLS":this.clearCells(e.sheetId,e.target);break;case"DELETE_CONTENT":this.clearZones(e.sheetId,e.target);break;case"DELETE_SHEET":this.history.update("cells",e.sheetId,void 0)}}clearZones(e,t){for(const o of Fo(t))for(let t=o.left;t<=o.right;t++)for(let s=o.top;s<=o.bottom;s++){const o=this.getters.getCell({sheetId:e,col:t,row:s});(o?.isFormula||o?.content)&&this.dispatch("UPDATE_CELL",{sheetId:e,content:"",col:t,row:s})}}setFormatter(e,t,o){for(const s of Fo(t))for(let t=s.top;t<=s.bottom;t++)for(let i=s.left;i<=s.right;i++)this.dispatch("UPDATE_CELL",{sheetId:e,col:i,row:t,format:o})}clearFormatting(e,t){for(const o of Fo(t))for(let t=o.left;t<=o.right;t++)for(let s=o.top;s<=o.bottom;s++)this.dispatch("UPDATE_CELL",{sheetId:e,col:t,row:s,style:null,format:""})}clearCells(e,t){for(const o of t)for(let t=o.left;t<=o.right;t++)for(let s=o.top;s<=o.bottom;s++)this.dispatch("UPDATE_CELL",{sheetId:e,col:t,row:s,content:"",style:null,format:""})}handleAddColumnsRows(e,t){let o,s;"before"===e.position?(o=Ct(e.base,e.base+e.quantity),s=e.base+e.quantity):(o=Ct(e.base+1,e.base+e.quantity+1),s=e.base),t(e.sheetId,s,o)}import(e){for(const t of e.sheets){const o=t.id,s=new tF;for(const e in t.cells)if(t.cells[e]){const{col:o,row:i}=Do(e),n={sheetId:t.id,col:o,row:i};s.set(n,{content:t.cells[e]})}for(const[e,o]of[["style",t.styles],["format",t.formats]])for(const[i,n]of ga(t.id,o)){const t=s.get(i);t?t[e]=n:s.set(i,{[e]:n})}for(const i of s.keysForSheet(o)){const o=s.get(i);if(o?.content||o?.format||o?.style){const s=this.importCell(t.id,o?.content,o?.style?e.styles[o?.style]:void 0,o?.format?e.formats[o?.format]:void 0);this.history.update("cells",t.id,s.id,s),this.dispatch("UPDATE_CELL_POSITION",{cellId:s.id,...i})}}}}export(e){const t={},o={};for(const s of e.sheets){const e=[],i=[],n={},r=Object.keys(this.cells[s.id]||{}).map((e=>this.getters.getCellPosition(e))).sort(((e,t)=>e.col===t.col?e.row-t.row:e.col-t.col));for(const s of r){const r=this.getters.getCell(s),a=_o(s.col,s.row),l=this.removeDefaultStyleValues(r.style);if(Object.keys(l).length){const o=da(l,t);e[o]??=[],e[o].push(s)}if(r.format){const e=da(r.format,o);i[e]??=[],i[e].push(s)}r.content&&(n[a]=r.content)}s.styles=ua(e),s.formats=ua(i),s.cells=n}e.styles=t,e.formats=o}importCell(e,t,o,s){const i=this.getNextUid();return this.createCell(i,t||"",s,o,e)}exportForExcel(e){this.export(e);const t=[];for(const o in e.formats||[])Kr(e.formats[o])||(t.push(Number(o)),delete e.formats[o]);if(t.length)for(const o of e.sheets)for(const e in o.formats){const s=o.formats[e];s&&t.includes(s)&&delete o.formats[e]}}removeDefaultStyleValues(e){const t={...e};for(const e in Oe)t[e]===Oe[e]&&delete t[e];return t}getCells(e){return this.cells[e]||{}}getCellById(e){const t=this.getters.getCellPosition(e);return this.cells[t.sheetId][e]}getFormulaString(e,t,o,s=!1){if(!o.length)return Lt(t.map((e=>e.value)));let i=0;return Lt(t.map((t=>{if("REFERENCE"===t.type){const t=o[i++];return this.getters.getRangeString(t,e,{useBoundedReference:s})}return t.value})))}getTranslatedCellFormula(e,t,o,s){const i=this.getters.createAdaptedRanges(GC(s).dependencies.map((t=>this.getters.getRangeFromSheetXC(e,t))),t,o,e);return this.getFormulaString(e,s,i)}getFormulaMovedInSheet(e,t,o){const s=GC(o).dependencies.map((t=>this.getters.getRangeFromSheetXC(e,t))),i=this.getters.removeRangesSheetPrefix(t,s);return this.getFormulaString(t,o,i)}getCellStyle(e){return this.getters.getCell(e)?.style||{}}zoneToXC(e,t,o=[{colFixed:!1,rowFixed:!1}]){const s=_o((t=this.getters.expandZone(e,t)).left,t.top,o[0]),i=_o(t.right,t.bottom,o.length>1?o[1]:o[0]),n=this.getters.getMainCellPosition({sheetId:e,col:t.left,row:t.top}),r=this.getters.getMainCellPosition({sheetId:e,col:t.right,row:t.bottom}),a=n.col===r.col&&n.row===r.row;return s===i||a?s:s+":"+i}setStyle(e,t,o){for(const s of Fo(t))for(let t=s.left;t<=s.right;t++)for(let i=s.top;i<=s.bottom;i++){const s=this.getters.getCell({sheetId:e,col:t,row:i});this.dispatch("UPDATE_CELL",{sheetId:e,col:t,row:i,style:o?{...s?.style,...o}:void 0})}}copyColumnStyle(e,t,o){for(let s=0;s<this.getters.getNumberRows(e);s++){const i=this.getFormat(e,t,s);if(i.style||i.format)for(const t of o)this.dispatch("UPDATE_CELL",{sheetId:e,col:t,row:s,...i})}}copyRowStyle(e,t,o){for(let s=0;s<this.getters.getNumberCols(e);s++){const i=this.getFormat(e,s,t);if(i.style||i.format)for(const t of o)this.dispatch("UPDATE_CELL",{sheetId:e,col:s,row:t,...i})}}getFormat(e,t,o){const s={},i=this.getters.getMainCellPosition({sheetId:e,col:t,row:o}),n=this.getters.getCell(i);return n&&(n.style&&(s.style=n.style),n.format&&(s.format=n.format)),s}getNextUid(){const e=this.nextId.toString();return this.history.update("nextId",this.nextId+1),e}updateCell(e,t,o,s){const i=this.getters.getCell({sheetId:e,col:t,row:o}),n="content"in s||"formula"in s,r=n?Xt(s?.content):i?.content||"";let a;a=void 0!==s.style?s.style||void 0:i?i.style:void 0;const l="format"in s?s.format:i&&i.format;if((n&&!r&&!s.formula||!n&&(!i||""===i.content))&&!a&&!l)return void(i&&(this.history.update("cells",e,i.id,void 0),this.dispatch("UPDATE_CELL_POSITION",{cellId:void 0,col:t,row:o,sheetId:e})));const c=i?.id||this.getNextUid(),h=this.createCell(c,r,l,a,e);this.history.update("cells",e,h.id,h),this.dispatch("UPDATE_CELL_POSITION",{cellId:h.id,col:t,row:o,sheetId:e})}createCell(e,t,o,s,i){return t.startsWith("=")?this.createFormulaCell(e,t,o,s,i):this.createLiteralCell(e,t,o,s)}createLiteralCell(e,t,o,s){const i=this.getters.getLocale(),n=ea(t,i);return Jr(o=o||("number"==typeof n?Vr(t,i)||Ur(t):void 0))||fn(t)||(t=En(n)),{id:e,content:t,style:s,format:o,isFormula:!1,parsedValue:n}}createFormulaCell(e,t,o,s,i){const n=$C(t);return n.dependencies.length?this.createFormulaCellWithDependencies(e,n,o,s,i):{id:e,content:t,style:s,format:o,isFormula:!0,compiledFormula:{...n,dependencies:[]}}}createFormulaCellWithDependencies(e,t,o,s,i){const n=[];for(const e of t.dependencies)n.push(this.getters.getRangeFromSheetXC(i,e));return new pV(e,t,o,s,n,i,this.getters.getRangeString)}checkCellOutOfSheet(e){const{sheetId:t,col:o,row:s}=e;if(!this.getters.tryGetSheet(t))return"InvalidSheetId";return es(o,s,this.getters.getSheetZone(t))?"Success":"TargetOutOfSheet"}checkUselessClearCell(e){const t=this.getters.getCell(e);return t&&(t.content||t.style||t.format)?"Success":"NoChanges"}checkUselessUpdateCell(e){const t=this.getters.getCell(e),o="style"in e,s="format"in e;return("content"in e||"formula"in e)&&t?.content!==e.content||o&&!zt(t?.style,e.style)||s&&t?.format!==e.format?"Success":"NoChanges"}}).add("merge",class extends gV{static getters=["isInMerge","isInSameMerge","isMergeHidden","getMainCellPosition","expandZone","doesIntersectMerge","doesColumnsHaveCommonMerges","doesRowsHaveCommonMerges","getMerges","getMerge","getMergesInZone","isSingleCellOrMerge","getSelectionRangeString","isMainCellPosition"];nextId=1;merges={};mergeCellMap={};allowDispatch(e){const t="force"in e&&!!e.force;switch(e.type){case"ADD_MERGE":return t?this.checkValidations(e,this.checkFrozenPanes):this.checkValidations(e,this.checkDestructiveMerge,this.checkOverlap,this.checkFrozenPanes);case"UPDATE_CELL":return this.checkMergedContentUpdate(e);case"REMOVE_MERGE":return this.checkMergeExists(e);default:return"Success"}}handle(e){switch(e.type){case"CREATE_SHEET":case"DELETE_SHEET":this.history.update("merges",e.sheetId,{}),this.history.update("mergeCellMap",e.sheetId,{});break;case"DUPLICATE_SHEET":const t=this.merges[e.sheetId];if(!t)break;for(const o of Object.values(t).filter(Mt))this.addMerge(e.sheetIdTo,o.zone);break;case"ADD_MERGE":for(const t of e.target)this.addMerge(e.sheetId,t);break;case"REMOVE_MERGE":for(const t of e.target)this.removeMerge(e.sheetId,t)}}adaptRanges(e,t){this.applyRangeChangeOnSheet(t,e)}getMerges(e){return Object.keys(this.merges[e]||{}).map((t=>this.getMergeById(e,parseInt(t,10)))).filter(Mt)}getMerge({sheetId:e,col:t,row:o}){const s=this.mergeCellMap[e],i=s?t in s&&s[t]?.[o]:void 0;return i?this.getMergeById(e,i):void 0}getMergesInZone(e,t){const o=this.mergeCellMap[e];if(!o)return[];const s=new Set;for(let e=t.left;e<=t.right;e++)for(let i=t.top;i<=t.bottom;i++){const t=o[e]?.[i];t&&s.add(t)}return Array.from(s).map((t=>this.getMergeById(e,t))).filter(Mt)}getSelectionRangeString(e,t){const o=this.getters.expandZone(e.sheetId,e.zone),s=Na({...e,zone:{...o,bottom:Va(e)?void 0:o.bottom,right:Ua(e)?void 0:o.right}},this.getters.getSheetSize),i=this.getters.getRangeString(s,t);if(this.isSingleCellOrMerge(e.sheetId,e.zone)){const{sheetName:e,xc:t}=Ta(i);return Aa(e,t.split(":")[0])}return i}doesIntersectMerge(e,t){for(const o of this.getMerges(e))if(Qo(t,o))return!0;return!1}doesColumnsHaveCommonMerges(e,t,o){const s=this.getters.getSheet(e);for(let i=0;i<this.getters.getNumberRows(e);i++)if(this.isInSameMerge(s.id,t,i,o,i))return!0;return!1}doesRowsHaveCommonMerges(e,t,o){const s=this.getters.getSheet(e);for(let i=0;i<=this.getters.getNumberCols(e);i++)if(this.isInSameMerge(s.id,i,t,i,o))return!0;return!1}expandZone(e,t){const{left:o,right:s,top:i,bottom:n}=t;let r={left:o,right:s,top:i,bottom:n};for(const t in this.merges[e]){const o=this.getMergeById(e,parseInt(t));o&&Qo(o,r)&&(r=Yo(o,r))}return Ko(r,t)?r:this.expandZone(e,r)}isInSameMerge(e,t,o,s,i){const n=this.getMerge({sheetId:e,col:t,row:o}),r=this.getMerge({sheetId:e,col:s,row:i});return!(!n||!r)&&Ko(n,r)}isInMerge({sheetId:e,col:t,row:o}){const s=this.mergeCellMap[e];return!!s&&(t in s&&Boolean(s[t]?.[o]))}getMainCellPosition(e){const t=this.getMerge(e);return t?{sheetId:e.sheetId,col:t.left,row:t.top}:e}isMergeHidden(e,t){const o=this.getters.getHiddenColsGroups(e),s=this.getters.getHiddenRowsGroups(e);for(const e of o)if(t.left>=e[0]&&t.right<=e[e.length-1])return!0;for(const e of s)if(t.top>=e[0]&&t.bottom<=e[e.length-1])return!0;return!1}isSingleCellOrMerge(e,t){const o=this.getMerge({sheetId:e,col:t.left,row:t.top});if(o)return Ko(t,o);const{numberOfCols:s,numberOfRows:i}=os(t);return 1===s&&1===i}isMainCellPosition(e){return zt(this.getMainCellPosition(e),e)}isMergeDestructive(e,t){let{left:o,right:s,top:i,bottom:n}=t;s=St(s,0,this.getters.getNumberCols(e)-1),n=St(n,0,this.getters.getNumberRows(e)-1);for(let t=i;t<=n;t++)for(let n=o;n<=s;n++)if(n!==o||t!==i){const o=this.getters.getCell({sheetId:e,col:n,row:t});if(o&&""!==o.content)return!0}return!1}getMergeById(e,t){const o=this.merges[e]?.[t];return void 0!==o?bV(t,o):void 0}checkDestructiveMerge({sheetId:e,target:t}){if(!this.getters.tryGetSheet(e))return"Success";return t.some((t=>this.isMergeDestructive(e,t)))?"MergeIsDestructive":"Success"}checkOverlap({target:e}){for(const t of e)for(const o of e)if(t!==o&&Qo(t,o))return"MergeOverlap";return"Success"}checkFrozenPanes({sheetId:e,target:t}){if(!this.getters.tryGetSheet(e))return"Success";const{xSplit:o,ySplit:s}=this.getters.getPaneDivisions(e);return ps(t,o,s)?"FrozenPaneOverlap":"Success"}checkMergedContentUpdate(e){const{col:t,row:o,content:s}=e;if(void 0===s)return"Success";const{col:i,row:n}=this.getMainCellPosition(e);return i===t&&n===o?"Success":"CellIsMerged"}checkMergeExists(e){const{sheetId:t,target:o}=e;for(const e of o){const{left:o,top:s}=e,i=this.getMerge({sheetId:t,col:o,row:s});if(void 0===i||!Ko(e,i))return"InvalidTarget"}return"Success"}addMerge(e,t){let{left:o,right:s,top:i,bottom:n}=t;s=St(s,0,this.getters.getNumberCols(e)-1),n=St(n,0,this.getters.getNumberRows(e)-1);if(_o(o,i)===_o(s,n))return;const r=this.getters.getCell({sheetId:e,col:o,row:i}),a=this.nextId++;this.history.update("merges",e,a,this.getters.getRangeFromSheetXC(e,Go({left:o,top:i,right:s,bottom:n})));const l=new Set;for(let t=i;t<=n;t++)for(let n=o;n<=s;n++){n===o&&t===i||this.dispatch("UPDATE_CELL",{sheetId:e,col:n,row:t,style:r?r.style:null,content:""});const s=this.getMerge({sheetId:e,col:n,row:t});s&&l.add(s.id),this.history.update("mergeCellMap",e,n,t,a)}for(const t of l){const{top:o,bottom:s,left:i,right:n}=this.getMergeById(e,t);for(let t=o;t<=s;t++)for(let o=i;o<=n;o++){const s={sheetId:e,col:o,row:t},i=this.getMerge(s);i&&i.id===a||(this.history.update("mergeCellMap",e,o,t,void 0),this.dispatch("CLEAR_CELL",s))}this.history.update("merges",e,t,void 0)}}removeMerge(e,t){const{left:o,top:s,bottom:i,right:n}=t,r=this.getMerge({sheetId:e,col:o,row:s});if(void 0!==r&&Ko(t,r)){this.history.update("merges",e,r.id,void 0);for(let t=s;t<=i;t++)for(let s=o;s<=n;s++)this.history.update("mergeCellMap",e,s,t,void 0)}}applyRangeChangeOnSheet(e,t){const o=Object.entries(this.merges[e]||{});for(const[s,i]of o)if(i){const o=i.zone,n=t(i);switch(n.changeType){case"NONE":break;case"REMOVE":this.removeMerge(e,o);break;default:const{numberOfCols:t,numberOfRows:i}=os(n.range.zone);1===t&&1===i?this.removeMerge(e,o):this.history.update("merges",e,parseInt(s,10),n.range)}}this.history.update("mergeCellMap",e,{});for(const t of this.getMerges(e))for(const{col:o,row:s}of is(t))this.history.update("mergeCellMap",e,o,s,t.id)}import(e){const t=e.sheets||[];for(const e of t)this.history.update("merges",e.id,{}),this.history.update("mergeCellMap",e.id,{}),e.merges&&this.importMerges(e.id,e.merges)}importMerges(e,t){for(const o of t)this.addMerge(e,Ho(o))}export(e){for(const t of e.sheets){const e=this.merges[t.id];e&&t.merges.push(...vV(e))}}exportForExcel(e){this.export(e)}}).add("headerSize",class extends gV{static getters=["getUserRowSize","getColSize"];sizes={};handle(e){switch(e.type){case"CREATE_SHEET":this.history.update("sizes",e.sheetId,{COL:Array(this.getters.getNumberCols(e.sheetId)).fill(void 0),ROW:Array(this.getters.getNumberRows(e.sheetId)).fill(void 0)});break;case"DUPLICATE_SHEET":this.history.update("sizes",e.sheetIdTo,pt(this.sizes[e.sheetId]));break;case"DELETE_SHEET":const t={...this.sizes};delete t[e.sheetId],this.history.update("sizes",t);break;case"REMOVE_COLUMNS_ROWS":{const t=Qt(this.sizes[e.sheetId][e.dimension],e.elements);this.history.update("sizes",e.sheetId,e.dimension,t);break}case"ADD_COLUMNS_ROWS":{const t=this.sizes[e.sheetId][e.dimension],o=Ht(e.position,e.base),s=t[e.base],i=eo(t,Array(e.quantity).fill(s),o);this.history.update("sizes",e.sheetId,e.dimension,i);break}case"RESIZE_COLUMNS_ROWS":if("ROW"===e.dimension)for(const t of e.elements)this.history.update("sizes",e.sheetId,e.dimension,t,e.size||void 0);else for(const t of e.elements)this.history.update("sizes",e.sheetId,e.dimension,t,e.size||void 0)}}getColSize(e,t){return Math.round(this.sizes[e]?.COL[t]||xe)}getUserRowSize(e,t){const o=this.sizes[e]?.ROW[t];return o?Math.round(o):void 0}import(e){for(const t of e.sheets){const e={COL:Array(t.colNumber).fill(void 0),ROW:Array(t.rowNumber).fill(void 0)};for(const[o,s]of Object.entries(t.rows))s.size&&(e.ROW[o]=s.size);for(const[o,s]of Object.entries(t.cols))s.size&&(e.COL[o]=s.size);this.sizes[t.id]=e}}exportForExcel(e){this.exportData(e,!0)}export(e){this.exportData(e)}exportData(e,t=!1){for(const o of e.sheets){void 0===o.rows&&(o.rows={});for(const e of Ct(0,this.getters.getNumberRows(o.id)))(t||this.sizes[o.id].ROW[e])&&(o.rows[e]={...o.rows[e],size:this.getUserRowSize(o.id,e)??Ee});void 0===o.cols&&(o.cols={});for(const e of Ct(0,this.getters.getNumberCols(o.id)))(t||this.sizes[o.id].COL[e])&&(o.cols[e]={...o.cols[e],size:this.getColSize(o.id,e)})}}}).add("borders",class extends gV{static getters=["getCellBorder","getBorders","getBordersColors","getCellBordersInZone"];borders={};allowDispatch(e){return"SET_BORDER"===e.type?this.checkValidations(e,this.checkBordersUnchanged,this.ensureHasBorder):"Success"}handle(e){switch(e.type){case"ADD_MERGE":for(const t of e.target)this.addBordersToMerge(e.sheetId,t);break;case"DUPLICATE_SHEET":this.history.update("borders",e.sheetIdTo,pt(this.borders[e.sheetId]));break;case"DELETE_SHEET":const t={...this.borders};delete t[e.sheetId],this.history.update("borders",t);break;case"SET_BORDER":e.border&&this.addBorders(e.sheetId,[cs(e)],e.border);break;case"SET_BORDERS_ON_TARGET":for(const t of e.target)for(let o=t.left;o<=t.right;o++)for(let s=t.top;s<=t.bottom;s++)this.addBorder(e.sheetId,{left:o,right:o,top:s,bottom:s},e.border&&Object.keys(e.border).length?e.border:void 0);break;case"SET_ZONE_BORDERS":const o=e.target.map((t=>this.getters.expandZone(e.sheetId,t)));"clear"===e.border.position?this.clearBorders(e.sheetId,o):this.addBorders(e.sheetId,o,this.borderDataToNewBorderData(e.border));break;case"CLEAR_FORMATTING":this.clearBorders(e.sheetId,e.target)}}beforeHandle(e){"REMOVE_COLUMNS_ROWS"===e.type&&("ROW"===e.dimension?this.onRowRemove(e.sheetId,e.elements):this.onColRemove(e.sheetId,e.elements))}adaptRanges(e,t){const o=[];for(const s of this.borders[t]??[]){const i=e(this.getters.getRangeFromZone(t,s.zone));switch(i.changeType){case"RESIZE":case"CHANGE":case"MOVE":o.push({...s,zone:i.range.unboundedZone});break;case"NONE":o.push(s)}}this.history.update("borders",t,o.filter((e=>!this.borderIsClear(e))))}onRowRemove(e,t){const o=new Set(t),s=[];for(const t of this.borders[e]??[]){let e=t;o.has(t.zone.top)&&(e=pt(t),e.style.top=t.style.horizontal),void 0!==t.zone.bottom&&o.has(t.zone.bottom)&&(e=e===t?pt(t):e,e.style.bottom=t.style.horizontal),s.push(e)}this.history.update("borders",e,s)}onColRemove(e,t){const o=new Set(t),s=[];for(const t of this.borders[e]??[]){let e=t;o.has(t.zone.left)&&(e=pt(t),e.style.left=t.style.vertical),void 0!==t.zone.right&&o.has(t.zone.right)&&(e=e===t?pt(t):e,e.style.right=t.style.vertical),s.push(e)}this.history.update("borders",e,s.filter((e=>!this.borderIsClear(e))))}getCellBorder(e){return this.getZoneExternalBorders(e.sheetId,cs(e))}getZoneExternalBorders(e,t){const o={};for(const s of this.borders[e]??[])Qo(s.zone,t)&&(o.right=(t.right===s.zone.right?s.style.right:s.style.vertical)??o.right,o.left=(t.left===s.zone.left?s.style.left:s.style.vertical)??o.left,o.bottom=(t.bottom===s.zone.bottom?s.style.bottom:s.style.horizontal)??o.bottom,o.top=(t.top===s.zone.top?s.style.top:s.style.horizontal)??o.top);return o}getCellBordersInZone(e,t){const o=new tF;for(const s of this.borders[e]??[]){const{zone:i,style:n}=s,r=Xo(i,t);if(r)for(let t=r.left;t<=r.right;t++)for(let s=r.top;s<=r.bottom;s++){const r=o.get({sheetId:e,col:t,row:s})??{};r.right=(t===i.right?n.right:n.vertical)??r.right,r.left=(t===i.left?n.left:n.vertical)??r.left,r.bottom=(s===i.bottom?n.bottom:n.horizontal)??r.bottom,r.top=(s===i.top?n.top:n.horizontal)??r.top,o.set({sheetId:e,col:t,row:s},r)}}return o}getBordersColors(e){const t=new Set;for(const o of this.borders[e]??[])for(const e of Object.values(o.style))e?.color&&t.add(e.color);return[...t]}getBorders(e,t){const o=[];for(const s of this.borders[e]??[]){const e=Xo(s.zone,t);e&&o.push(this.computeBorderFromZone(e,s))}return o}computeBorderFromZone(e,t){const o=t.style,s=t.zone,i=e.top===s.top,n=e.bottom===s.bottom,r=e.left===s.left,a=e.right===s.right;return{zone:e,style:{top:i?o.top:o.horizontal,bottom:n?o.bottom:o.horizontal,left:r?o.left:o.vertical,right:a?o.right:o.vertical,vertical:o.vertical,horizontal:o.horizontal}}}borderIsClear(e){const t=e.style;if(t.left||t.right||t.bottom||t.top)return!1;const o=e.zone;return(!(void 0===o.bottom||o.top<o.bottom)||!t.horizontal)&&(!(void 0===o.right||o.left<o.right)||!t.vertical)}clearBorders(e,t){for(const o of t)this.removeAndClearAdjacent(e,o)}removeAndClearAdjacent(e,t){const o=[];for(const s of this.borders[e]??[])for(const e of Fo([s.zone],[t]))for(const i of vs(e,t)){const e=this.computeBorderFromZone(i,s),n=Jo(i,t);switch(n?.position){case"left":e.style.left=void 0;break;case"right":e.style.right=void 0;break;case"top":e.style.top=void 0;break;case"bottom":e.style.bottom=void 0}o.push(e)}this.history.update("borders",e,o)}addBorders(e,t,o){for(const s of t)this.addBorder(e,s,o)}addBorder(e,t,o,s=!1){const i=[],n=o?{zone:t,style:o}:void 0,r={left:s||!!o?.left,right:s||!!o?.right,top:s||!!o?.top,bottom:s||!!o?.bottom};let a=[t];for(const o of this.borders[e]??[]){const e=Xo(o.zone,t);if(e){if(n){let t=this.computeBorderFromZone(e,n).style;s||(t={...this.computeBorderFromZone(e,o).style,...Wt(t)}),i.push({zone:e,style:t})}a=Fo(a,[e]);for(const t of Fo([o.zone],[e]))i.push(this.computeBorderFromZone(t,o))}else{const e=Jo(o.zone,t);if(e&&r[e.position])for(const e of vs(o.zone,t)){const s=this.computeBorderFromZone(e,o),n=Jo(e,t);switch(n?.position){case"left":s.style.left=void 0;break;case"right":s.style.right=void 0;break;case"top":s.style.top=void 0;break;case"bottom":s.style.bottom=void 0}i.push(s)}else i.push(o)}}n&&i.push(...a.map((e=>this.computeBorderFromZone(e,n)))),this.history.update("borders",e,i.filter((e=>!this.borderIsClear(e))))}borderDataToNewBorderData(e){const t={},o={color:e.color??"#000000",style:e.style??"thin"};return["all","external","top"].includes(e.position)&&(t.top={...o}),["all","external","bottom"].includes(e.position)&&(t.bottom={...o}),["all","external","left"].includes(e.position)&&(t.left={...o}),["all","external","right"].includes(e.position)&&(t.right={...o}),["all","hv","v"].includes(e.position)&&(t.vertical={...o}),["all","hv","h"].includes(e.position)&&(t.horizontal={...o}),t}checkBordersUnchanged(e){const t=this.getCellBorder(e),o=!(e.border?.bottom||e.border?.left||e.border?.right||e.border?.top);return!t&&o||zt(t,e.border)?"NoChanges":"Success"}ensureHasBorder(e){return e.border?"Success":"NoChanges"}addBordersToMerge(e,t){const o={...this.getZoneExternalBorders(e,t),...Wt(this.getCellBorder({sheetId:e,col:t.left,row:t.top}))};this.addBorder(e,t,o,!0)}import(e){if(Object.keys(e.borders||{}).length)for(const t of e.sheets)for(const o in t.borders){const s=t.borders[o];this.addBorder(t.id,Ho(o),e.borders[s])}for(const t of e.sheets)if(t.merges)for(const e of t.merges)this.addBordersToMerge(t.id,Ho(e))}export(e){const t={};for(const o of e.sheets){o.borders={};for(const e of this.borders[o.id]??[])o.borders[Go(e.zone)]=da(e.style,t)}e.borders=t}exportForExcel(e){this.export(e)}}).add("conditional formatting",class extends gV{static getters=["getConditionalFormats","getRulesSelection","getRulesByCell","getAdaptedCfRanges"];cfRules={};adaptCFFormulas(e){for(const t in this.cfRules)for(const o of this.cfRules[t])if("DataBarRule"===o.rule.type&&o.rule.rangeValues){const s=e(o.rule.rangeValues);switch(s.changeType){case"REMOVE":this.history.update("cfRules",t,this.cfRules[t].indexOf(o),"rule","rangeValues",void 0);break;case"RESIZE":case"MOVE":case"CHANGE":this.history.update("cfRules",t,this.cfRules[t].indexOf(o),"rule","rangeValues",s.range)}}else if("CellIsRule"===o.rule.type)for(let s=0;s<o.rule.values.length;s++)this.history.update("cfRules",t,this.cfRules[t].indexOf(o),"rule","values",s,this.getters.adaptFormulaStringDependencies(t,o.rule.values[s],e));else if("IconSetRule"===o.rule.type)for(const s of["lowerInflectionPoint","upperInflectionPoint"])"formula"===o.rule[s].type&&this.history.update("cfRules",t,this.cfRules[t].indexOf(o),"rule",s,"value",this.getters.adaptFormulaStringDependencies(t,o.rule[s].value,e));else if("ColorScaleRule"===o.rule.type)for(const s of["minimum","maximum","midpoint"]){const i=o.rule[s];"formula"===i?.type&&i?.value&&this.history.update("cfRules",t,this.cfRules[t].indexOf(o),"rule",s,"value",this.getters.adaptFormulaStringDependencies(t,i.value,e))}}adaptCFRanges(e,t){for(const o of this.cfRules[e])for(const s of o.ranges){const i=t(s);switch(i.changeType){case"REMOVE":const t=o.ranges.slice();t.splice(o.ranges.indexOf(s),1),t.length>=1?this.history.update("cfRules",e,this.cfRules[e].indexOf(o),"ranges",t):this.removeConditionalFormatting(o.id,e);break;case"RESIZE":case"MOVE":case"CHANGE":this.history.update("cfRules",e,this.cfRules[e].indexOf(o),"ranges",o.ranges.indexOf(s),i.range)}}}adaptRanges(e,t){const o=t?[t]:Object.keys(this.cfRules);for(const t of o)this.adaptCFRanges(t,e);this.adaptCFFormulas(e)}allowDispatch(e){switch(e.type){case"ADD_CONDITIONAL_FORMAT":return e.ranges.some((e=>!this.getters.tryGetSheet(e._sheetId)))?"InvalidSheetId":this.checkValidations(e,this.checkCFRule,this.checkEmptyRange,this.checkCFHasChanged);case"CHANGE_CONDITIONAL_FORMAT_PRIORITY":return this.checkValidPriorityChange(e.cfId,e.delta,e.sheetId)}return"Success"}handle(e){switch(e.type){case"CREATE_SHEET":this.cfRules[e.sheetId]=[];break;case"DUPLICATE_SHEET":this.history.update("cfRules",e.sheetIdTo,[]);for(const t of this.getConditionalFormats(e.sheetId))this.addConditionalFormatting(t,e.sheetIdTo);break;case"DELETE_SHEET":const t=Object.assign({},this.cfRules);delete t[e.sheetId],this.history.update("cfRules",t);break;case"ADD_CONDITIONAL_FORMAT":const o={...e.cf,ranges:e.ranges.map((t=>this.getters.getRangeString(this.getters.getRangeFromRangeData(t),e.sheetId)))};this.addConditionalFormatting(o,e.sheetId);break;case"REMOVE_CONDITIONAL_FORMAT":this.removeConditionalFormatting(e.id,e.sheetId);break;case"CHANGE_CONDITIONAL_FORMAT_PRIORITY":this.changeCFPriority(e.cfId,e.delta,e.sheetId)}}import(e){for(const t of e.sheets)this.cfRules[t.id]=t.conditionalFormats.map((e=>this.mapToConditionalFormatInternal(t.id,e)))}export(e){if(e.sheets)for(const t of e.sheets)this.cfRules[t.id]&&(t.conditionalFormats=this.cfRules[t.id].map((e=>this.mapToConditionalFormat(t.id,e))))}exportForExcel(e){if(e.sheets)for(const t of e.sheets)this.cfRules[t.id]&&(t.conditionalFormats=this.cfRules[t.id].map((e=>this.mapToConditionalFormat(t.id,e,{useBoundedReference:!0}))))}getConditionalFormats(e){return this.cfRules[e]?.map((t=>this.mapToConditionalFormat(e,t)))||[]}getRulesSelection(e,t){const o=new Set;return t.forEach((t=>{this.getRulesByZone(e,t).forEach((e=>{o.add(e)}))})),Array.from(o)}getRulesByZone(e,t){const o=new Set;for(let s=t.top;s<=t.bottom;s++)for(let i=t.left;i<=t.right;i++){this.getRulesByCell(e,i,s).forEach((e=>{o.add(e.id)}))}return o}getRulesByCell(e,t,o){const s=[];for(const i of this.cfRules[e])for(const e of i.ranges)es(t,o,e.zone)&&s.push(i);return new Set(s.map((t=>this.mapToConditionalFormat(e,t))))}getAdaptedCfRanges(e,t,o,s){if(0===o.length&&0===s.length)return;const i=this.getters.getConditionalFormats(e),n=i.findIndex((e=>e.id===t.id));let r=[];n>-1&&(r=i[n].ranges.map(Uo));const a=Fo(r,s);return Fo([...o,...a],[]).map((t=>this.getters.getRangeDataFromZone(e,t)))}mapToConditionalFormat(e,t,{useBoundedReference:o}={useBoundedReference:!1}){const s=t.ranges.map((t=>this.getters.getRangeString(t,e,{useBoundedReference:o})));return"DataBarRule"!==t.rule.type?{...t,rule:{...t.rule},ranges:s}:{...t,rule:{...t.rule,rangeValues:t.rule.rangeValues&&this.getters.getRangeString(t.rule.rangeValues,e,{useBoundedReference:o})},ranges:s}}mapToConditionalFormatInternal(e,t){const o=t.ranges.map((t=>this.getters.getRangeFromSheetXC(e,t)));return"DataBarRule"!==t.rule.type?{...t,rule:{...t.rule},ranges:o}:{...t,rule:{...t.rule,rangeValues:t.rule.rangeValues?this.getters.getRangeFromSheetXC(e,t.rule.rangeValues):void 0},ranges:o}}addConditionalFormatting(e,t){const o=this.cfRules[t].slice(),s=o.findIndex((t=>t.id===e.id)),i=this.mapToConditionalFormatInternal(t,e);s>-1?o.splice(s,1,i):o.push(i),this.history.update("cfRules",t,o)}checkValidPriorityChange(e,t,o){if(!this.cfRules[o])return"InvalidSheetId";const s=this.cfRules[o].findIndex((t=>t.id===e));if(-1===s)return"InvalidConditionalFormatId";const i=s-t;return i<0||i>=this.cfRules[o].length?"InvalidConditionalFormatId":"Success"}checkEmptyRange(e){return e.ranges.length?"Success":"EmptyRange"}checkCFRule(e){const t=e.cf.rule;switch(t.type){case"CellIsRule":return this.checkValidations(t,this.checkOperatorArgsNumber,this.checkCFValues);case"ColorScaleRule":return this.checkValidations(t,this.chainValidations(this.checkThresholds(this.checkFormulaCompilation)),this.chainValidations(this.checkThresholds(this.checkNaN),this.batchValidations(this.checkMinBiggerThanMax,this.checkMinBiggerThanMid,this.checkMidBiggerThanMax)));case"IconSetRule":return this.checkValidations(t,this.chainValidations(this.checkInflectionPoints(this.checkNaN),this.checkLowerBiggerThanUpper),this.chainValidations(this.checkInflectionPoints(this.checkFormulaCompilation)))}return"Success"}checkCFHasChanged(e){const t=this.mapToConditionalFormatInternal(e.sheetId,{...e.cf,ranges:e.ranges.map((t=>this.getters.getRangeString(this.getters.getRangeFromRangeData(t),e.sheetId)))}),o=this.cfRules[e.sheetId]?.find((t=>t.id===e.cf.id));return o&&zt(t,o)?"NoChanges":"Success"}checkOperatorArgsNumber(e){const t=sR.get(e.operator).numberOfValues({type:e.operator,values:e.values});if(void 0===t||t>2)throw new Error("Checking more than 2 arguments is currently not supported. Add the appropriate CommandResult if you want to.");const o=[],s=e=>void 0===e||""===e;return t>=1&&s(e.values[0])&&o.push("FirstArgMissing"),t>=2&&s(e.values[1])&&o.push("SecondArgMissing"),o.length?o:"Success"}checkNaN(e,t){if(["number","percentage","percentile"].includes(e.type)&&(""===e.value||isNaN(e.value)))switch(t){case"min":return"MinNaN";case"max":return"MaxNaN";case"mid":return"MidNaN";case"upperInflectionPoint":return"ValueUpperInflectionNaN";case"lowerInflectionPoint":return"ValueLowerInflectionNaN"}return"Success"}checkFormulaCompilation(e,t){if("formula"!==e.type)return"Success";if($C(e.value||"").isBadExpression)switch(t){case"min":return"MinInvalidFormula";case"max":return"MaxInvalidFormula";case"mid":return"MidInvalidFormula";case"upperInflectionPoint":return"ValueUpperInvalidFormula";case"lowerInflectionPoint":return"ValueLowerInvalidFormula"}return"Success"}checkThresholds(e){return this.batchValidations((t=>e(t.minimum,"min")),(t=>e(t.maximum,"max")),(t=>t.midpoint?e(t.midpoint,"mid"):"Success"))}checkInflectionPoints(e){return this.batchValidations((t=>e(t.lowerInflectionPoint,"lowerInflectionPoint")),(t=>e(t.upperInflectionPoint,"upperInflectionPoint")))}checkLowerBiggerThanUpper(e){const t=e.lowerInflectionPoint.value,o=e.upperInflectionPoint.value;return["number","percentage","percentile"].includes(e.lowerInflectionPoint.type)&&e.lowerInflectionPoint.type===e.upperInflectionPoint.type&&Number(t)>Number(o)?"LowerBiggerThanUpper":"Success"}checkMinBiggerThanMax(e){const t=e.minimum.value,o=e.maximum.value;return["number","percentage","percentile"].includes(e.minimum.type)&&e.minimum.type===e.maximum.type&&fV(t)>=fV(o)?"MinBiggerThanMax":"Success"}checkMidBiggerThanMax(e){const t=e.midpoint?.value,o=e.maximum.value;return e.midpoint&&["number","percentage","percentile"].includes(e.midpoint.type)&&e.midpoint.type===e.maximum.type&&fV(t)>=fV(o)?"MidBiggerThanMax":"Success"}checkMinBiggerThanMid(e){const t=e.minimum.value,o=e.midpoint?.value;return e.midpoint&&["number","percentage","percentile"].includes(e.midpoint.type)&&e.minimum.type===e.midpoint.type&&fV(t)>=fV(o)?"MinBiggerThanMid":"Success"}checkCFValues(e){for(const t of e.values){if(!t.startsWith("="))continue;if($C(t||"").isBadExpression)return"ValueCellIsInvalidFormula"}return"Success"}removeConditionalFormatting(e,t){const o=this.cfRules[t].findIndex((t=>t.id===e));if(-1!==o){const e=this.cfRules[t].slice();e.splice(o,1),this.history.update("cfRules",t,e)}}changeCFPriority(e,t,o){const s=this.cfRules[o].findIndex((t=>t.id===e)),i=this.cfRules[o][s],n=s-t,r=[...this.cfRules[o]];r.splice(s,1),r.splice(n,0,i),this.history.update("cfRules",o,r)}}).add("figures",class extends gV{static getters=["getFigures","getFigure","getFigureSheetId"];figures={};insertionOrders=[];adaptRanges(e,t){for(const o of this.getFigures(t)){const s=e(this.getters.getRangeFromZone(t,{left:o.col,right:o.col,top:o.row,bottom:o.row}));if("MOVE"===s.changeType)this.history.update("figures",t,o.id,"col",s.range.zone.right),this.history.update("figures",t,o.id,"row",s.range.zone.bottom);else if("REMOVE"===s.changeType){const s=e(this.getters.getRangeFromZone(t,{left:0,right:o.col-1,top:0,bottom:o.row-1}));let{offset:i,col:n,row:r}=o;"NONE"!==s.changeType&&(n=s.range.zone.right+1,r=s.range.zone.bottom+1),({offset:i,col:n,row:r}=this.getPositionInSheet(t,{...o,col:n,row:r})),this.history.update("figures",t,o.id,"offset",i),this.history.update("figures",t,o.id,"col",n),this.history.update("figures",t,o.id,"row",r)}}}allowDispatch(e){switch(e.type){case"CREATE_FIGURE":return this.checkValidations(e,this.checkFigureDuplicate,this.checkFigureAnchorOffset);case"UPDATE_FIGURE":return this.checkValidations(e,this.checkFigureExists,this.checkFigureAnchorOffset);case"DELETE_FIGURE":return this.checkFigureExists(e);default:return"Success"}}beforeHandle(e){if("DELETE_SHEET"===e.type)this.getters.getFigures(e.sheetId).forEach((t=>{this.dispatch("DELETE_FIGURE",{figureId:t.id,sheetId:e.sheetId})}))}handle(e){switch(e.type){case"CREATE_SHEET":this.figures[e.sheetId]={};break;case"DELETE_SHEET":this.deleteSheet(e.sheetId);break;case"CREATE_FIGURE":const t={id:e.figureId,col:e.col,row:e.row,offset:e.offset,width:e.size.width,height:e.size.height,tag:e.tag};this.addFigure(t,e.sheetId);break;case"UPDATE_FIGURE":this.updateFigure(e);break;case"DELETE_FIGURE":this.removeFigure(e.figureId,e.sheetId);break;case"REMOVE_COLUMNS_ROWS":"COL"===e.dimension?this.onColRemove(e.sheetId):this.onRowRemove(e.sheetId);break;case"DUPLICATE_SHEET":for(const t in this.figures[e.sheetId]){const o=this.figures[e.sheetId]?.[t];if(!o)continue;const s=t.split($e).pop(),i=`${e.sheetIdTo}${$e}${s}`;this.dispatch("CREATE_FIGURE",{figureId:i,...o,size:{width:o.width,height:o.height},sheetId:e.sheetIdTo})}}}onColRemove(e){const t=this.getters.getNumberCols(e),o=new Array(t+1);o[t]=0;for(let s=t-1;s>=0;s--)o[s]=o[s+1]+this.getters.getColSize(e,s);for(const t of this.getFigures(e))if(t.offset.x+t.width>o[t.col]){let s=t.offset.x,i=t.col;for(s=Math.min(s,o[i]-t.width);s<0&&i>0;)i--,s=o[i]-t.width;s!==t.offset.x&&this.history.update("figures",e,t.id,"offset",{x:Math.max(s,0),y:t.offset.y}),i!==t.col&&this.history.update("figures",e,t.id,"col",i)}}onRowRemove(e){const t=this.getters.getNumberRows(e),o=new Array(t+1);o[t]=0;for(let s=t-1;s>=0;s--)o[s]=o[s+1]+(this.getters.getUserRowSize(e,s)??Ee);for(const t of this.getFigures(e))if(t.offset.y+t.height>o[t.row]){let s=t.offset.y,i=t.row;for(let t=this.getters.getUserRowSize(e,i)??Ee;t<s;t=this.getters.getUserRowSize(e,i)??Ee)i+=1,s-=t;for(s=Math.min(s,o[i]-t.height);s<0&&i>0;)i--,s=o[i]-t.height;s!==t.offset.y&&this.history.update("figures",e,t.id,"offset",{x:t.offset.x,y:Math.max(0,s)}),i!==t.row&&this.history.update("figures",e,t.id,"row",i)}else t.offset.y+t.height>o[0]&&this.history.update("figures",e,t.id,"offset",{x:t.offset.x,y:Math.max(o[0]-t.height,0)})}getPositionInSheet(e,t){const{numberOfRows:o,numberOfCols:s}=this.getters.getSheetSize(e);let i,n,r=0,a=0,{col:l,row:c}=t;const h={...t.offset};for(i=o;r<t.height&&i>0;i--)r+=this.getters.getUserRowSize(e,i-1)??Ee;for(c>i?(c=i,h.y=Math.max(r-t.height,0)):c===i&&(h.y=St(h.y,0,Math.max(r-t.height,0))),n=s;a<t.width&&n>0;n--)a+=this.getters.getColSize(e,n-1);return l>n?(l=n,h.x=Math.max(a-t.width,0)):n===l&&(h.x=St(h.x,0,Math.max(a-t.width,0))),{col:l,row:c,offset:h}}updateFigure(e){if(!("figureId"in e)||!("sheetId"in e))return;const{figureId:t,sheetId:o,...s}=e,i={...this.getFigure(o,t),...s};for(const[e,t]of Object.entries(s))switch(e){case"tag":case"offset":this.history.update("figures",o,i.id,e,t);break;case"col":case"row":case"width":case"height":void 0!==t&&this.history.update("figures",o,i.id,e,t)}}addFigure(e,t){this.history.update("figures",t,e.id,e),this.history.update("insertionOrders",this.insertionOrders.length,e.id)}deleteSheet(e){this.history.update("insertionOrders",this.insertionOrders.filter((t=>!this.figures[e]?.[t]))),this.history.update("figures",e,void 0)}removeFigure(e,t){this.history.update("insertionOrders",this.insertionOrders.filter((t=>t!==e))),this.history.update("figures",t,e,void 0)}checkFigureExists(e){return void 0===this.figures[e.sheetId]?.[e.figureId]?"FigureDoesNotExist":"Success"}checkFigureDuplicate(e){return Object.values(this.figures).find((t=>t?.[e.figureId]))?"DuplicatedFigureId":"Success"}checkFigureAnchorOffset(e){return e.col<0||e.row<0||e.offset&&(e.offset.x<0||e.offset.y<0)?"WrongSheetPosition":"Success"}getFigures(e){const t=[];for(const o of this.insertionOrders){const s=this.figures[e]?.[o];s&&t.push(s)}return t}getFigure(e,t){return this.figures[e]?.[t]}getFigureSheetId(e){return Object.keys(this.figures).find((t=>void 0!==this.figures[t]?.[e]))}import(e){for(const t of e.sheets)for(const e of t.figures)this.addFigure(e,t.id)}export(e){for(const t of e.sheets)for(const e of this.getFigures(t.id)){const o=void 0;t.figures.push({...e,data:o})}}exportForExcel(e){return this.export(e)}}).add("chart",class extends gV{static getters=["isChartDefined","getChartDefinition","getChartType","getChartIds","getChart","getFigureIdFromChartId","getContextCreationChart"];charts={};createChart=rE(this.getters);validateChartDefinition=e=>lE(this,e.definition);adaptRanges(e,t,o){for(const[s,i]of Object.entries(this.charts)){if(!i)continue;const n=i.chart.updateRanges(e,t,o);this.history.update("charts",s,n?{figureId:i.figureId,chart:n}:void 0)}}allowDispatch(e){switch(e.type){case"CREATE_CHART":return this.checkValidations(e,this.chainValidations(this.checkFigureArguments,this.validateChartDefinition,this.checkChartDuplicate));case"UPDATE_CHART":return this.checkValidations(e,this.chainValidations(this.validateChartDefinition,this.checkChartExists,this.checkChartChanged));case"DELETE_CHART":return this.checkChartExists(e);default:return"Success"}}handle(e){switch(e.type){case"CREATE_CHART":const{col:t,row:o,offset:s,size:i,sheetId:n,figureId:r}=e;this.getters.getFigure(n,r)||void 0===s||void 0===t||void 0===o||this.addFigure(r,n,t,o,s,i),this.addChart(e.figureId,e.chartId,e.definition);break;case"UPDATE_CHART":this.addChart(e.figureId,e.chartId,e.definition);break;case"DUPLICATE_SHEET":for(const t of this.getChartIds(e.sheetId)){const{chart:o,figureId:s}=this.charts[t]||{};if(!o||!s)continue;const i=this.getters.getFigure(e.sheetId,s);if(!i)continue;const n=s.split($e).pop(),r=`${e.sheetIdTo}${$e}${n}`,a=t.split($e).pop(),l=`${e.sheetIdTo}${$e}${a}`,c=o.duplicateInDuplicatedSheet(e.sheetIdTo);c&&this.dispatch("CREATE_CHART",{figureId:r,chartId:l,col:i.col,row:i.row,offset:i.offset,size:{width:i.width,height:i.height},definition:c.getDefinition(),sheetId:e.sheetIdTo})}break;case"DELETE_FIGURE":for(const t in this.charts)this.charts[t]?.figureId===e.figureId&&this.dispatch("DELETE_CHART",{chartId:t,sheetId:e.sheetId});break;case"DELETE_CHART":this.isChartDefined(e.chartId)&&this.history.update("charts",e.chartId,void 0);break;case"DELETE_SHEET":for(const t of this.getChartIds(e.sheetId))this.history.update("charts",t,void 0)}}getContextCreationChart(e){return this.charts[e]?.chart.getContextCreation()}getChart(e){return this.charts[e]?.chart}getFigureIdFromChartId(e){if(!this.charts[e])throw new Error(`Chart with id ${e} does not exist.`);return this.charts[e].figureId}getChartType(e){const t=this.charts[e]?.chart.type;if(!t)throw new Error("Chart not defined.");return t}isChartDefined(e){return e in this.charts&&void 0!==this.charts}getChartIds(e){return Object.entries(this.charts).filter((([,t])=>t?.chart.sheetId===e)).map((([e])=>e))}getChartDefinition(e){const t=this.charts[e]?.chart.getDefinition();if(!t)throw new Error(`There is no chart with the given id: ${e}`);return t}import(e){for(const t of e.sheets)if(t.figures)for(const e of t.figures)if("chart"===e.tag){const o=e.data.chartId,s=this.createChart(e.id,e.data,t.id);this.charts[o]={chart:s,figureId:e.id}}else if("carousel"===e.tag)for(const o in e.data.chartDefinitions||{}){const s=e.data.chartDefinitions[o],i=this.createChart(e.id,s,t.id);this.charts[o]={chart:i,figureId:e.id}}}export(e){if(e.sheets)for(const t of e.sheets){const e=this.getters.getFigures(t.id),o=[];for(const t of e){const e=t,s=Object.keys(this.charts).find((e=>this.charts[e]?.figureId===t.id));if(e&&"chart"===e.tag&&s){const t=this.charts[s]?.chart.getDefinition();t&&(e.data={...t,chartId:s},o.push(e))}else if(e&&"carousel"===e.tag){const s=Object.keys(this.charts).filter((e=>this.charts[e]?.figureId===t.id)),i={};for(const e of s)i[e]=this.charts[e]?.chart.getDefinition();e.data={chartDefinitions:i},o.push(e)}else o.push(e)}t.figures=o}}addFigure(e,t,o,s,i,n={width:536,height:335}){this.dispatch("CREATE_FIGURE",{sheetId:t,figureId:e,col:o,row:s,offset:i,size:n,tag:"chart"})}addChart(e,t,o){const s=this.getters.getFigureSheetId(e);if(s){const i=this.createChart(e,o,s);this.history.update("charts",t,{figureId:e,chart:i})}}checkChartDuplicate(e){return this.isChartDefined(e.chartId)?"DuplicatedChartId":"Success"}checkChartExists(e){return this.isChartDefined(e.chartId)?"Success":"ChartDoesNotExist"}checkChartChanged(e){return e.figureId!==this.charts[e.chartId]?.figureId?"Success":zt(this.getChartDefinition(e.chartId),e.definition)?"NoChanges":"Success"}checkFigureArguments(e){return this.getters.getFigure(e.sheetId,e.figureId)||void 0!==e.offset&&void 0!==e.col&&void 0!==e.row?"Success":"MissingFigureArguments"}}).add("carousel",class extends gV{static getters=["getCarousel","doesCarouselExist"];carousels={};allowDispatch(e){switch(e.type){case"CREATE_CAROUSEL":return this.getters.getFigure(e.sheetId,e.figureId)?"DuplicatedFigureId":"Success";case"UPDATE_CAROUSEL":return this.carousels[e.sheetId]?.[e.figureId]?"Success":"InvalidFigureId"}return"Success"}handle(e){switch(e.type){case"CREATE_CAROUSEL":this.getters.getFigure(e.sheetId,e.figureId)||this.dispatch("CREATE_FIGURE",{...e,tag:"carousel"}),this.history.update("carousels",e.sheetId,e.figureId,e.definition);break;case"UPDATE_CAROUSEL":this.removeDeletedCharts(e,this.getters.getCarousel(e.figureId).items),this.history.update("carousels",e.sheetId,e.figureId,e.definition);break;case"DUPLICATE_SHEET":{const t=this.getters.getFigures(e.sheetId);for(const o of t)if("carousel"===o.tag){const t=o.id.split($e).pop(),s=`${e.sheetIdTo}${$e}${t}`,i=this.getCarousel(o.id);if(i){const t={width:o.width,height:o.height};this.dispatch("CREATE_CAROUSEL",{sheetId:e.sheetIdTo,figureId:s,offset:o.offset,col:o.col,row:o.row,size:t,definition:{items:i.items.map((t=>{if("carouselDataView"===t.type)return{...t};const o=t.chartId.split($e).pop(),s=`${e.sheetIdTo}${$e}${o}`;return{...t,chartId:s}}))}})}}break}case"DELETE_FIGURE":this.history.update("carousels",e.sheetId,e.figureId,void 0);break;case"DELETE_SHEET":this.history.update("carousels",e.sheetId,void 0)}}doesCarouselExist(e){for(const t in this.carousels)if(this.carousels[t]?.[e])return!0;return!1}getCarousel(e){for(const t in this.carousels)if(this.carousels[t]?.[e])return this.carousels[t][e];throw new Error(`There is no carousel with the given figureId: ${e}`)}removeDeletedCharts(e,t){const o=new Set(e.definition.items.filter((e=>"chart"===e.type)).map((e=>e.chartId)));for(const s of t)"chart"!==s.type||o.has(s.chartId)||this.dispatch("DELETE_CHART",{chartId:s.chartId,sheetId:e.sheetId})}import(e){for(const t of e.sheets){const e=(t.figures||[]).filter((e=>"carousel"===e.tag));for(const o of e)this.history.update("carousels",t.id,o.id,{items:o.data.items,title:o.data.title})}}export(e){for(const t of e.sheets){const e=t.figures.filter((e=>"carousel"===e.tag));for(const o of e)this.carousels[t.id]?.[o.id]&&(o.data={...o.data,...this.carousels[t.id]?.[o.id]})}}}).add("image",class extends gV{static getters=["getImage","getImagePath","getImageSize"];fileStore;images={};syncedImages=new Set;constructor(e){super(e),this.fileStore=e.external.fileStore}allowDispatch(e){return"CREATE_IMAGE"===e.type&&this.getters.getFigure(e.sheetId,e.figureId)?"InvalidFigureId":"Success"}handle(e){switch(e.type){case"CREATE_IMAGE":this.getters.getFigure(e.sheetId,e.figureId)||this.addFigure(e.figureId,e.sheetId,e.col,e.row,e.offset,e.size),this.history.update("images",e.sheetId,e.figureId,e.definition),this.syncedImages.add(e.definition.path);break;case"DUPLICATE_SHEET":{const t=this.getters.getFigures(e.sheetId);for(const o of t)if("image"===o.tag){const t=o.id.split($e).pop(),s=`${e.sheetIdTo}${$e}${t}`,i=this.getImage(o.id);if(i){const t={width:o.width,height:o.height};this.dispatch("CREATE_IMAGE",{sheetId:e.sheetIdTo,figureId:s,offset:o.offset,col:o.col,row:o.row,size:t,definition:pt(i)})}}break}case"DELETE_FIGURE":this.history.update("images",e.sheetId,e.figureId,void 0);break;case"DELETE_SHEET":this.history.update("images",e.sheetId,void 0)}}garbageCollectExternalResources(){const e=new Set(this.getAllImages().map((e=>e.path)));for(const t of this.syncedImages)e.has(t)||this.fileStore?.delete(t)}getImage(e){for(const t of Object.values(this.images))if(t&&t[e])return t[e];throw new Error(`There is no image with the given figureId: ${e}`)}getImagePath(e){return this.getImage(e).path}getImageSize(e){return this.getImage(e).size}addFigure(e,t,o,s,i,n){this.dispatch("CREATE_FIGURE",{sheetId:t,figureId:e,col:o,row:s,offset:i,size:n,tag:"image"})}import(e){for(const t of e.sheets){const e=(t.figures||[]).filter((e=>"image"===e.tag));for(const o of e)this.history.update("images",t.id,o.id,o.data),this.syncedImages.add(o.data.path)}}export(e){for(const t of e.sheets){const e=t.figures.filter((e=>"image"===e.tag));for(const o of e)o.data=this.images[t.id]?.[o.id]}}exportForExcel(e){for(const t of e.sheets){t.images||(t.images=[]);const e=this.getters.getFigures(t.id),o=[];for(const t of e)if("image"===t?.tag){const e=this.getImage(t.id);e&&o.push({...t,data:pt(e)})}t.images=[...t.images,...o]}}getAllImages(){const e=[];for(const t in this.images)e.push(...Object.values(this.images[t]||{}).filter(Mt));return e}}).add("pivot_core",class extends gV{static getters=["getPivotCoreDefinition","getPivotDisplayName","getPivotId","getPivotFormulaId","getPivotIds","getMeasureCompiledFormula","getPivotName","isExistingPivot"];nextFormulaId=1;pivots={};formulaIds={};compiledMeasureFormulas={};allowDispatch(e){switch(e.type){case"ADD_PIVOT":return this.checkValidations(e.pivot,this.checkDuplicatedMeasureIds,this.checkSortedColumnInMeasures,this.checkCustomFieldsAreValid);case"UPDATE_PIVOT":return e.pivotId in this.pivots?zt(e.pivot,this.pivots[e.pivotId]?.definition)?"NoChanges":""===e.pivot.name?"EmptyName":this.checkValidations(e.pivot,this.checkDuplicatedMeasureIds,this.checkSortedColumnInMeasures,this.checkCustomFieldsAreValid):"PivotIdNotFound";case"RENAME_PIVOT":if(!(e.pivotId in this.pivots))return"PivotIdNotFound";if(""===e.name)return"EmptyName";break;case"REMOVE_PIVOT":case"DUPLICATE_PIVOT":case"INSERT_PIVOT":case"DUPLICATE_PIVOT":if(!(e.pivotId in this.pivots))return"PivotIdNotFound"}return"Success"}handle(e){switch(e.type){case"ADD_PIVOT":{const{pivotId:t,pivot:o}=e;this.addPivot(t,o);break}case"INSERT_PIVOT":{const{sheetId:t,col:o,row:s,pivotId:i,table:n}=e,r={sheetId:t,col:o,row:s},{cols:a,rows:l,measures:c,fieldsType:h}=n,d=new cP(a,l,c,h||{}),u=this.getPivotFormulaId(i);this.insertPivot(r,u,d);break}case"RENAME_PIVOT":this.history.update("pivots",e.pivotId,"definition","name",e.name);break;case"REMOVE_PIVOT":{const t={...this.pivots};delete t[e.pivotId];const o=this.getPivotFormulaId(e.pivotId);this.history.update("formulaIds",o,void 0),this.history.update("pivots",t);break}case"DUPLICATE_PIVOT":{const{pivotId:t,newPivotId:o}=e,s=pt(this.getPivotCore(t).definition);s.name=e.duplicatedPivotName??s.name+" (copy)",this.addPivot(o,s);break}case"UPDATE_PIVOT":this.history.update("pivots",e.pivotId,"definition",pt(e.pivot)),this.compileCalculatedMeasures(e.pivot.measures)}}adaptRanges(e){for(const t in this.compiledMeasureFormulas)for(const o in this.compiledMeasureFormulas[t]){const s=this.compiledMeasureFormulas[t][o],i=[];for(const t of s.dependencies){const o=e(t);"NONE"===o.changeType?i.push(t):i.push(o.range)}const n=this.getters.getFormulaString(t,s.tokens,i);n!==o&&this.replaceMeasureFormula(t,o,n)}}getPivotDisplayName(e){return`(#${this.getPivotFormulaId(e)}) ${this.getPivotName(e)}`}getPivotName(e){return this.getPivotCore(e).definition.name}getPivotCoreDefinition(e){return this.getPivotCore(e).definition}getPivotId(e){return this.formulaIds[e]}getPivotFormulaId(e){return this.getPivotCore(e).formulaId}getPivotIds(){return Object.keys(this.pivots)}isExistingPivot(e){return e in this.pivots}getMeasureCompiledFormula(e){if(!e.computedBy)throw new Error(`Measure ${e.fieldName} is not computed by formula`);const t=e.computedBy.sheetId;return this.compiledMeasureFormulas[t][e.computedBy.formula]}addPivot(e,t,o=this.nextFormulaId.toString()){this.history.update("pivots",e,{definition:pt(t),formulaId:o}),this.compileCalculatedMeasures(t.measures),this.history.update("formulaIds",o,e),this.history.update("nextFormulaId",this.nextFormulaId+1)}compileCalculatedMeasures(e){for(const t of e)if(t.computedBy){const e=t.computedBy.sheetId,o=this.compileMeasureFormula(t.computedBy.sheetId,t.computedBy.formula);this.history.update("compiledMeasureFormulas",e,t.computedBy.formula,o)}}insertPivot(e,t,o){this.resizeSheet(e.sheetId,e,o);const s=o.getPivotCells();for(let o=0;o<s.length;o++)for(let i=0;i<s[o].length;i++){const n=s[o][i];this.dispatch("UPDATE_CELL",{sheetId:e.sheetId,col:e.col+o,row:e.row+i,content:nh(t,n)})}}resizeSheet(e,{col:t,row:o},s){const i=s.getNumberOfDataColumns()+1,n=this.getters.getNumberCols(e),r=n-t;r<i&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"COL",base:n-1,sheetId:e,sheetName:this.getters.getSheetName(e),quantity:i-r,position:"after"});const a=s.columns.length+s.rows.length,l=this.getters.getNumberRows(e),c=l-o;c<a&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"ROW",base:l-1,sheetId:e,sheetName:this.getters.getSheetName(e),quantity:a-c,position:"after"})}getPivotCore(e){const t=this.pivots[e];if(!t)throw new Error(`Pivot with id ${e} not found`);return t}compileMeasureFormula(e,t){const o=$C(t),s=o.dependencies.map((t=>this.getters.getRangeFromSheetXC(e,t)));return{...o,dependencies:s}}replaceMeasureFormula(e,t,o){this.history.update("compiledMeasureFormulas",e,t,void 0),this.history.update("compiledMeasureFormulas",e,o,this.compileMeasureFormula(e,o));for(const s in this.pivots){const i=this.pivots[s];if(i)for(const n of i.definition.measures)if(n.computedBy?.formula===t){const t=i.definition.measures.indexOf(n);this.history.update("pivots",s,"definition","measures",t,"computedBy",{formula:o,sheetId:e})}}}checkSortedColumnInMeasures(e){const t=e.measures.map((e=>e.id));return e.sortedColumn&&!t.includes(e.sortedColumn.measure)?"InvalidDefinition":"Success"}checkDuplicatedMeasureIds(e){const t=new Set(e.measures.map((e=>e.id)));return e.measures.length!==t.size?"InvalidDefinition":"Success"}checkCustomFieldsAreValid(e){for(const t in e.customFields){const o=e.customFields[t],s=new Set,i=new Set;let n=!1;for(const e of o.groups){if(!e.name||i.has(e.name))return"InvalidPivotCustomField";if(e.values.some((e=>s.has(e))))return"InvalidPivotCustomField";if(e.isOtherGroup&&n)return"InvalidPivotCustomField";e.values.forEach((e=>s.add(e))),i.add(e.name),n||=!!e.isOtherGroup}}return"Success"}import(e){if(e.pivots)for(const[t,o]of Object.entries(e.pivots))this.addPivot(t,o,o.formulaId);this.history.update("nextFormulaId",e.pivotNextId||Jc(this.pivots)+1)}export(e){e.pivots={};for(const t in this.pivots)e.pivots[t]={...this.getPivotCoreDefinition(t),formulaId:this.getPivotFormulaId(t)};e.pivotNextId=this.nextFormulaId}}).add("spreadsheet_pivot_core",class extends gV{allowDispatch(e){switch(e.type){case"ADD_PIVOT":case"UPDATE_PIVOT":const t=e.pivot;return this.checkDataSetValidity(t)}return"Success"}adaptRanges(e){for(const t of this.getters.getPivotIds()){const o=this.getters.getPivotCoreDefinition(t);if("SPREADSHEET"===o.type&&o.dataSet){const{sheetId:s,zone:i}=o.dataSet,n=CV(this.getters.getRangeFromZone(s,i),e),r=n&&{sheetId:n.sheetId,zone:n.zone};this.dispatch("UPDATE_PIVOT",{pivotId:t,pivot:{...o,dataSet:r}})}}}checkDataSetValidity(e){if("SPREADSHEET"===e.type&&e.dataSet){const{zone:t,sheetId:o}=e.dataSet;return o&&this.getters.tryGetSheet(o)&&t&&Bo(t)?this.getters.checkZonesExistInSheet(o,[t]):"InvalidDataSet"}return"Success"}}).add("tableStyle",class extends gV{static getters=["getNewCustomTableStyleName","getTableStyle","getTableStyles","isTableStyleEditable"];styles={};allowDispatch(e){switch(e.type){case"CREATE_TABLE":case"UPDATE_TABLE":if(e.config?.styleId&&!this.styles[e.config.styleId])return"InvalidTableConfig";break;case"CREATE_TABLE_STYLE":if(!KT[e.templateName])return"InvalidTableStyle";try{_s(e.primaryColor)}catch(e){return"InvalidTableStyle"}}return"Success"}handle(e){switch(e.type){case"CREATE_TABLE_STYLE":const t=JT(e.tableStyleName,e.templateName,e.primaryColor);this.history.update("styles",e.tableStyleId,t);break;case"REMOVE_TABLE_STYLE":const o={...this.styles};delete o[e.tableStyleId],this.history.update("styles",o);for(const t of this.getters.getSheetIds())for(const o of this.getters.getCoreTables(t))o.config.styleId===e.tableStyleId&&this.dispatch("UPDATE_TABLE",{sheetId:t,zone:o.range.zone,config:{styleId:MT.styleId}})}}getTableStyle(e){if(!this.styles[e])throw new Error(`Table style ${e} does not exist`);return this.styles[e]}getTableStyles(){return this.styles}getNewCustomTableStyleName(){return ho(ui("Custom Table Style"),Object.values(this.styles).map((e=>e.displayName)),{compute:(e,t)=>`${e} ${t}`,start:2})}isTableStyleEditable(e){return!XT[e]}import(e){for(const e in XT)this.styles[e]=XT[e];for(const t in e.customTableStyles){const o=e.customTableStyles[t];this.styles[t]=JT(o.displayName,o.templateName,o.primaryColor)}}export(e){const t={};for(const e in this.styles)XT[e]||(t[e]={displayName:this.styles[e].displayName,templateName:this.styles[e].templateName,primaryColor:this.styles[e].primaryColor});e.customTableStyles=t}}),rH=(new n).add("ui_sheet",class extends tu{static getters=["getCellWidth","getTextWidth","getCellText","getCellMultiLineText","getContiguousZone","computeTextYCoordinate"];ctx=document.createElement("canvas").getContext("2d");allowDispatch(e){return this.chainValidations(this.checkSheetExists,this.checkZonesAreInSheet)(e)}handle(e){switch(e.type){case"AUTORESIZE_COLUMNS":for(const t of e.cols){const o=this.getColMaxWidth(e.sheetId,t);0!==o&&this.dispatch("RESIZE_COLUMNS_ROWS",{elements:[t],dimension:"COL",size:o,sheetId:e.sheetId})}break;case"AUTORESIZE_ROWS":this.autoResizeRows(e.sheetId,e.rows);break;case"DELETE_UNFILTERED_CONTENT":const t=[];for(const o of e.target){const s=yt(Ct(o.top,o.bottom+1).filter((t=>!this.getters.isRowFiltered(e.sheetId,t))));for(const e of s)t.push({...o,top:e[0],bottom:e[e.length-1]})}this.dispatch("DELETE_CONTENT",{sheetId:e.sheetId,target:t})}}getCellWidth(e){const t=this.getters.getCellComputedStyle(e);let o=0;const s=this.getters.getEvaluatedCell(e).formattedValue;if(s){const e=gl(this.ctx,s,t,void 0);o+=Math.max(...e.map((e=>nl(this.ctx,e,t))))}for(const t of this.getters.getCellIcons(e))o+=t.margin+t.size;if(this.getters.getDataValidationChipStyle(e)&&(o+=10),0===o)return 0;if(o+=2*De,"wrap"===t.wrapping){const t=this.getters.getColSize(this.getters.getActiveSheetId(),e.col);return Math.min(t,o)}return o}getTextWidth(e,t){return nl(this.ctx,e,t)}getCellText(e,t){const o=this.getters.getCell(e),s=this.getters.getLocale();if(t?.showFormula&&o?.isFormula)return Zl(o.content,s);if(t?.showFormula&&!o?.content)return"";{const i=this.getters.getEvaluatedCell(e),n=t?.availableWidth?{availableWidth:t.availableWidth,measureText:e=>nl(this.ctx,e,o?.style||{})}:void 0;return Rr(i.value,{format:i.format,locale:s,formatWidth:n})}}getCellMultiLineText(e,t){const o=this.getters.getCellStyle(e),s=this.getters.getCellText(e,{showFormula:this.getters.shouldShowFormulas(),availableWidth:t.maxWidth});return gl(this.ctx,s,o,t.wrapText?t.maxWidth:void 0)}computeTextYCoordinate(e,t,o=Pe,s=1){const i=e.y+1,n=tl(t,s);if(e.height>n+2*Te){if("middle"===o)return Math.ceil(i+(e.height-n)/2);if("bottom"===o)return i+e.height-n-Te}return i+Te}getContiguousZone(e,t){const o=t=>{for(const o of Ct(t.left,t.right+1)){if(!this.isCellEmpty({sheetId:e,col:o,row:t.top-1}))return{...t,top:t.top-1};if(!this.isCellEmpty({sheetId:e,col:o,row:t.bottom+1}))return{...t,bottom:t.bottom+1}}for(const o of Ct(t.top,t.bottom+1)){if(!this.isCellEmpty({sheetId:e,col:t.left-1,row:o}))return{...t,left:t.left-1};if(!this.isCellEmpty({sheetId:e,col:t.right+1,row:o}))return{...t,right:t.right+1}}return t};let s=!1,i=t;do{s=!1;const e=o(i);Ko(i,e)||(s=!0,i=e)}while(s);return i}isCellEmpty(e){const t=this.getters.getMainCellPosition(e);return this.getters.getEvaluatedCell(t).type===r.empty}getColMaxWidth(e,t){const o=is(this.getters.getColsZone(e,t,t)).map((t=>this.getCellWidth({sheetId:e,...t})));return Math.max(0,no(o))}checkSheetExists(e){return"sheetId"in e&&void 0===this.getters.tryGetSheet(e.sheetId)?"InvalidSheetId":"Success"}checkZonesAreInSheet(e){const t="sheetId"in e?e.sheetId:this.getters.tryGetActiveSheetId();if("ranges"in e&&e.ranges.some((e=>!this.getters.tryGetSheet(e._sheetId))))return"InvalidSheetId";const o=this.getters.getCommandZones(e);return!t&&o.length>0?"NoActiveSheet":t&&o.length>0?this.getters.checkZonesExistInSheet(t,o):"Success"}autoResizeRows(e,t){const o=[];for(const s of t){let t=0;for(const o of this.getters.getRowCells(e,s)){const s=this.getters.getCellById(o);if(!s)continue;const i=this.getters.getCellPosition(s.id),n=this.getters.getColSize(e,i.col);if(s.isFormula||this.getters.getArrayFormulaSpreadingOn(i)){const e=this.getters.getEvaluatedCell(i).formattedValue,o=ol(this.ctx,e,s?.style,n);o>t&&o>Ee&&(t=o)}else{const e=s.content,o=ol(this.ctx,e,s?.style,n);o>=t&&o>Ee&&(t=0)}}o.push(t||null)}const s=new Map(o.map((e=>[e,[]])));for(let e=0;e<o.length;e++)s.get(o[e])?.push(t[e]);for(const[t,o]of s)this.dispatch("RESIZE_COLUMNS_ROWS",{elements:o,dimension:"ROW",size:t,sheetId:e})}}).add("ui_options",class extends tu{static getters=["shouldShowFormulas"];showFormulas=!1;handle(e){if("SET_FORMULA_VISIBILITY"===e.type)this.showFormulas=e.show}shouldShowFormulas(){return this.showFormulas}}).add("autofill",class extends tu{static layers=["Autofill"];static getters=["getAutofillTooltip"];autofillZone;steps;lastCellSelected={};direction;tooltip;allowDispatch(e){if("AUTOFILL_SELECT"===e.type){const t=this.getters.getActiveSheetId();return this.lastCellSelected.col=-1===e.col?this.lastCellSelected.col:St(e.col,0,this.getters.getNumberCols(t)),this.lastCellSelected.row=-1===e.row?this.lastCellSelected.row:St(e.row,0,this.getters.getNumberRows(t)),void 0!==this.lastCellSelected.col&&void 0!==this.lastCellSelected.row?"Success":"InvalidAutofillSelection"}return"Success"}handle(e){switch(e.type){case"AUTOFILL":this.autofill(!0);break;case"AUTOFILL_SELECT":this.select(e.col,e.row);break;case"AUTOFILL_AUTO":this.autofillAuto()}}getAutofillTooltip(){return this.tooltip}autofill(e){if(!this.autofillZone||!this.steps||void 0===this.direction)return void(this.tooltip=void 0);const t=this.getters.getSelectedZone(),o=this.autofillZone,s=[];switch(this.direction){case"down":for(let e=t.left;e<=t.right;e++){const i=[];for(let o=t.top;o<=t.bottom;o++)i.push(_o(e,o));const n=this.createGenerator(i);for(let t=o.top;t<=o.bottom;t++)s.push(this.computeNewCell(n,e,t))}break;case"up":for(let e=t.left;e<=t.right;e++){const i=[];for(let o=t.bottom;o>=t.top;o--)i.push(_o(e,o));const n=this.createGenerator(i);for(let t=o.bottom;t>=o.top;t--)s.push(this.computeNewCell(n,e,t))}break;case"left":for(let e=t.top;e<=t.bottom;e++){const i=[];for(let o=t.right;o>=t.left;o--)i.push(_o(o,e));const n=this.createGenerator(i);for(let t=o.right;t>=o.left;t--)s.push(this.computeNewCell(n,t,e))}break;case"right":for(let e=t.top;e<=t.bottom;e++){const i=[];for(let o=t.left;o<=t.right;o++)i.push(_o(o,e));const n=this.createGenerator(i);for(let t=o.left;t<=o.right;t++)s.push(this.computeNewCell(n,t,e))}}if(e){const e={},t={},o={},i=this.getters.getActiveSheetId();for(const n of s)this.collectBordersData(n,e),this.autofillMerge(i,n),this.autofillCell(i,n),this.collectConditionalFormatsData(i,n,t),this.collectDataValidationsData(i,n,o);this.autofillBorders(i,e),this.autofillConditionalFormats(i,t),this.autofillDataValidations(i,o),this.autofillZone=void 0,this.selection.resizeAnchorZone(this.direction,this.steps),this.lastCellSelected={},this.direction=void 0,this.steps=0,this.tooltip=void 0}}collectBordersData(e,t){const o=JSON.stringify(e.border);o in t||(t[o]=[]),t[o].push(cs({col:e.col,row:e.row}))}collectConditionalFormatsData(e,t,o){const{originCol:s,originRow:i,col:n,row:r}=t,a=this.getters.getRulesByCell(e,s,i),l=_o(n,r);for(const e of a)e.id in o||(o[e.id]=[]),o[e.id].push(l)}collectDataValidationsData(e,t,o){const{originCol:s,originRow:i,col:n,row:r}=t,a={sheetId:e,col:s,row:i},l=this.getters.getValidationRuleForCell(a);l&&(l.id in o||(o[l.id]=[]),o[l.id].push(cs({col:n,row:r})))}autofillCell(e,t){this.dispatch("UPDATE_CELL",{sheetId:e,col:t.col,row:t.row,content:t.content||"",style:t.style||null,format:t.format||""}),this.dispatch("AUTOFILL_CELL",t)}autofillBorders(e,t){for(const o in t){const s="undefined"===o?void 0:JSON.parse(o);this.dispatch("SET_BORDERS_ON_TARGET",{sheetId:e,border:s,target:Fo(t[o])})}}autofillConditionalFormats(e,t){for(const o in t){const s=t[o],i=this.getters.getConditionalFormats(e).find((e=>e.id===o));if(!i)continue;const n=this.getters.getAdaptedCfRanges(e,i,s.map(Ho),[]);n&&this.dispatch("ADD_CONDITIONAL_FORMAT",{cf:{id:i.id,rule:i.rule,stopIfTrue:i.stopIfTrue},ranges:n,sheetId:e})}}autofillDataValidations(e,t){for(const o in t){const s=t[o],i=this.getters.getDataValidationRule(e,o);if(!i)continue;const n=i.ranges.map((e=>e.zone)),r=Fo(n.concat(s),[]);this.dispatch("ADD_DATA_VALIDATION_RULE",{rule:i,ranges:r.map((t=>this.getters.getRangeDataFromZone(e,t))),sheetId:e})}}select(e,t){const o=this.getters.getSelectedZone();if(es(e,t,o))this.autofillZone=void 0;else{switch(this.direction=this.getDirection(e,t),this.direction){case"up":this.saveZone(t,o.top-1,o.left,o.right),this.steps=o.top-t;break;case"down":this.saveZone(o.bottom+1,t,o.left,o.right),this.steps=t-o.bottom;break;case"left":this.saveZone(o.top,o.bottom,e,o.left-1),this.steps=o.left-e;break;case"right":this.saveZone(o.top,o.bottom,o.right+1,e),this.steps=e-o.right}this.autofill(!1)}}autofillAuto(){const e=this.getters.getActivePosition(),t=this.getters.getTable(e);let o=t?t.range.zone.bottom:this.getAutofillAutoLastRow();const s=this.getters.getSelectedZone();for(let t=s.bottom+1;t<=o;t++)if(this.getters.getEvaluatedCell({...e,row:t}).type!==r.empty){o=t-1;break}o>s.bottom&&(this.select(e.col,o),this.autofill(!0))}getAutofillAutoLastRow(){const e=this.getters.getSelectedZone(),t=this.getters.getActiveSheetId();let o=e.left,s=e.bottom;if(o>0){let e={sheetId:t,col:o-1,row:s};for(;this.getters.getEvaluatedCell(e).type!==r.empty;)s+=1,e={sheetId:t,col:o-1,row:s}}if(s===e.bottom&&(o=e.right,o<=this.getters.getNumberCols(t))){let e={sheetId:t,col:o+1,row:s};for(;this.getters.getEvaluatedCell(e).type!==r.empty;)s+=1,e={sheetId:t,col:o+1,row:s}}return s-1}computeNewCell(e,t,o){const{cellData:s,tooltip:i,origin:n}=e.next(),{content:r,style:a,border:l,format:c}=s;return this.tooltip=i,{originCol:n.col,originRow:n.row,col:t,row:o,content:r,style:a,border:l,format:c}}getRule(e,t){const o=mU.getAll().sort(((e,t)=>e.sequence-t.sequence)).find((o=>o.condition(e,t)));return o&&this.direction&&o.generateRule(e,t,this.direction)}createGenerator(e){const t=[],o=[],s=this.getters.getActiveSheetId();for(const t of e){const{col:e,row:i}=Do(t),n=this.getters.getCell({sheetId:s,col:e,row:i});o.push({col:e,row:i,cell:n,sheetId:s})}const i=o.map((e=>e.cell));for(const e of o){let o={type:"COPY_MODIFIER"};if(e&&e.cell){o=this.getRule(e.cell,i)||o}const s=this.getters.getCellBorder(e)||void 0;t.push({data:{...e,border:s},rule:o})}return new wU(t,this.getters,this.direction)}saveZone(e,t,o,s){this.autofillZone={top:e,bottom:t,left:o,right:s}}getDirection(e,t){const o=this.getters.getSelectedZone(),s={up:{number:o.top-t,value:"up"},down:{number:t-o.bottom,value:"down"},left:{number:o.left-e,value:"left"},right:{number:e-o.right,value:"right"}};if(1===Object.values(s).map((e=>e.number>0?1:0)).reduce(((e,t)=>e+t)))return Object.values(s).find((e=>e.number>0?1:0)).value;const i=s.up.number>0?"up":"down",n=s.left.number>0?"left":"right";return Math.abs(s[i].number)>=Math.abs(s[n].number)?s[i].value:s[n].value}autofillMerge(e,t){const{originCol:o,originRow:s,col:i,row:n}=t,r={sheetId:e,col:i,row:n},a={sheetId:e,col:o,row:s};if(this.getters.isInMerge(r)&&!this.getters.isInMerge(a)){const t=this.getters.getMerge(r);t&&this.dispatch("REMOVE_MERGE",{sheetId:e,target:[t]})}const l=this.getters.getMerge(a);l?.left===o&&l?.top===s&&this.dispatch("ADD_MERGE",{sheetId:e,target:[{top:n,bottom:n+l.bottom-l.top,left:i,right:i+l.right-l.left}]})}drawLayer(e){if(!this.autofillZone)return;const{ctx:t,thinLineWidth:o}=e,{x:s,y:i,width:n,height:r}=this.getters.getVisibleRect(this.autofillZone);n>0&&r>0&&(t.strokeStyle="black",t.lineWidth=o,t.setLineDash([3]),t.strokeRect(s,i,n,r),t.setLineDash([]))}}).add("sort",class extends tu{allowDispatch(e){return"SORT_CELLS"===e.type?es(e.col,e.row,e.zone)?this.checkValidations(e,this.checkMerge,this.checkMergeSizes,this.checkArrayFormulaInSortZone):"InvalidSortAnchor":"Success"}handle(e){if("SORT_CELLS"===e.type)this.sortZone(e.sheetId,e,e.zone,e.sortDirection,e.sortOptions||{})}checkMerge({sheetId:e,zone:t}){if(!this.getters.doesIntersectMerge(e,t))return"Success";return is(t).some((({col:t,row:o})=>!this.getters.isInMerge({sheetId:e,col:t,row:o})))?"InvalidSortZone":"Success"}checkMergeSizes({sheetId:e,zone:t}){if(!this.getters.doesIntersectMerge(e,t))return"Success";const o=this.getters.getMerges(e).filter((e=>Qo(e,t))),s=os(o[0]),[i,n]=[s.numberOfCols,s.numberOfRows];return o.every((e=>{const[t,o]=[e.right-e.left+1,e.bottom-e.top+1];return t===i&&o===n}))?"Success":"InvalidSortZone"}checkArrayFormulaInSortZone({sheetId:e,zone:t}){return is(t).some((({col:t,row:o})=>{const s=this.getters.getArrayFormulaSpreadingOn({sheetId:e,col:t,row:o});return s&&!zt(s,{sheetId:e,col:t,row:o})}))?"SortZoneWithArrayFormulas":"Success"}hasHeader(e,t){if(1===t[0].length)return!1;let o=t.map((t=>t.map((({col:t,row:o})=>this.getters.getEvaluatedCell({sheetId:e,col:t,row:o}).type))));return o[0][0]===r.empty&&(o=o.slice(1)),!o.some((e=>e[0]===r.empty))&&!!o.some((e=>e[1]!==r.empty&&e[0]!==e[1]))}sortZone(e,t,o,s,i){const[n,a]=this.mainCellsSteps(e,o),l=this.getters.getMainCellPosition({sheetId:e,col:t.col,row:t.row}).col,c=Object.assign({},o);let h=this.mainCells(e,o);!i.sortHeaders&&this.hasHeader(e,h)&&(c.top+=a),h=this.mainCells(e,c);const d=function(e,t,o){const s=e.map(((e,t)=>({index:t,type:e.type,value:e.value})));return(o?s.map((e=>e.type===r.empty?{...e,type:r.number,value:0}:e)):s).sort(mf(t))}(h[l-c.left].map((e=>this.getters.getEvaluatedCell(e))),s,Boolean(i.emptyCellAsZero)),u=d.map((e=>e.index)),[g,p]=[h.length,h[0].length],m=[];for(let e=0;e<g;e++)for(let t=0;t<p;t++){const{col:o,row:s,sheetId:i}=h[e][u[t]],r=this.getters.getCell({sheetId:i,col:o,row:s}),l=c.left+e*n,d=c.top+t*a,g={sheetId:i,col:l,row:d,content:""};if(r){let e=r.content;if(r.isFormula){const t=this.getters.getCellPosition(r.id);e=this.getters.getTranslatedCellFormula(i,0,d-t.row,r.compiledFormula.tokens)}g.style=r.style,g.content=e,g.format=r.format}m.push(g)}m.forEach((e=>this.dispatch("UPDATE_CELL",e)))}mainCellsSteps(e,t){const o=this.getters.getMerge({sheetId:e,col:t.left,row:t.top});return[o?o.right-o.left+1:1,o?o.bottom-o.top+1:1]}mainCells(e,t){const[o,s]=this.mainCellsSteps(e,t),i=[],n=Ct(t.left,t.right+1,o),r=Ct(t.top,t.bottom+1,s);for(const t of n){const o=[];i.push(o);for(const s of r)o.push({sheetId:e,col:t,row:s})}return i}}).add("automatic_sum",class extends tu{static getters=["getAutomaticSums"];handle(e){if("SUM_SELECTION"===e.type){const e=this.getters.getActiveSheetId(),{zones:t,anchor:o}=this.getters.getSelection();for(const s of t){const t=this.getAutomaticSums(e,s,o.cell);this.dispatchCellUpdates(e,t)}}}getAutomaticSums(e,t,o){return this.shouldFindData(e,t)?this.sumAdjacentData(e,t,o):this.sumData(e,t)}sumData(e,t){const o=this.dimensionsToSum(e,t),s=this.sumDimensions(e,t,o).filter((({zone:t})=>!this.getters.isEmpty(e,t)));return o.has("ROW")&&o.has("COL")&&s.push(this.sumTotal(t)),s}sumAdjacentData(e,t,o){const{col:s,row:i}=es(o.col,o.row,t)?o:{col:t.left,row:t.top},n=this.findAdjacentData(e,s,i);return n?this.getters.isSingleCellOrMerge(e,t)||ss(Yo(n,t))?[{position:{col:s,row:i},zone:n}]:this.sumDimensions(e,Yo(n,t),this.transpose(this.dimensionsToSum(e,t))):[]}findAdjacentData(e,t,o){const s=this.getters.getSheet(e),i=this.getters.getMainCellPosition({sheetId:e,col:t,row:o}),n=this.findSuitableZoneToSum(s,i.col,i.row);if(n)return this.getters.expandZone(e,n)}findSuitableZoneToSum(e,t,o){const s=this.getters.getEvaluatedCell({sheetId:e.id,col:t,row:o-1}),i=this.getters.getEvaluatedCell({sheetId:e.id,col:t-1,row:o});if(this.isNumber(i)&&!this.isNumber(s))return this.findHorizontalZone(e,t,o);const n=this.findVerticalZone(e,t,o);if(this.isZoneValid(n))return n;const r=this.findHorizontalZone(e,t,o);return this.isZoneValid(r)?r:void 0}findVerticalZone(e,t,o){const s={top:0,bottom:o-1,left:t,right:t},i=this.reduceZoneStart(e,s,s.bottom);return{...s,top:i}}findHorizontalZone(e,t,o){const s={top:o,bottom:o,left:0,right:t-1},i=this.reduceZoneStart(e,s,s.right);return{...s,left:i}}reduceZoneStart(e,t,o){const s=this.getters.getEvaluatedCellsInZone(e.id,t),i=Ct(o,-1,-1),n=no(i.filter((e=>s[e]&&!s[e].isAutoSummable))),r=yt(i.filter((e=>this.isNumber(s[e]))))[0]||[];return no(r)<n?1/0:ro(r)}shouldFindData(e,t){return this.getters.isEmpty(e,t)||this.getters.isSingleCellOrMerge(e,t)}isNumber(e){return e.type===r.number&&!(e.format&&Mr(e.format))}isZoneValid(e){return e.bottom>=e.top&&e.right>=e.left}lastColIsEmpty(e,t){return this.getters.isEmpty(e,{...t,left:t.right})}lastRowIsEmpty(e,t){return this.getters.isEmpty(e,{...t,top:t.bottom})}dimensionsToSum(e,t){const o=new Set;return ss(t)?(o.add(1===os(t).numberOfCols?"COL":"ROW"),o):(this.lastColIsEmpty(e,t)&&o.add("ROW"),this.lastRowIsEmpty(e,t)&&o.add("COL"),0===o.size&&o.add("COL"),o)}sumDimensions(e,t,o){return[...o.has("COL")?this.sumColumns(t,e):[],...o.has("ROW")?this.sumRows(t,e):[]]}sumTotal(e){const{bottom:t,right:o}=e;return{position:{col:o,row:t},zone:{...e,top:t,right:o-1}}}sumColumns(e,t){const o=this.nextEmptyRow(t,{...e,bottom:e.bottom-1});return e={...e,bottom:Math.min(e.bottom,o.bottom-1)},is(o).map((t=>({position:t,zone:{...e,right:t.col,left:t.col}})))}sumRows(e,t){const o=this.nextEmptyCol(t,{...e,right:e.right-1});return e={...e,right:Math.min(e.right,o.right-1)},is(o).map((t=>({position:t,zone:{...e,top:t.row,bottom:t.row}})))}dispatchCellUpdates(e,t){for(const o of t){const{col:t,row:s}=o.position;this.dispatch("UPDATE_CELL",{sheetId:e,col:t,row:s,content:`=SUM(${this.getters.zoneToXC(e,o.zone)})`})}}nextEmptyRow(e,t){let o=t.bottom+1;const{left:s,right:i}=t;for(;!this.getters.isEmpty(e,{bottom:o,top:o,left:s,right:i});)o++;return{...t,top:o,bottom:o}}nextEmptyCol(e,t){let o=t.right+1;const{top:s,bottom:i}=t;for(;!this.getters.isEmpty(e,{left:o,right:o,top:s,bottom:i});)o++;return{...t,left:o,right:o}}transpose(e){return new Set([...e.values()].map((e=>"COL"===e?"ROW":"COL")))}}).add("format",class extends tu{handle(e){switch(e.type){case"SET_DECIMAL":this.setDecimal(e.sheetId,e.target,e.step);break;case"SET_FORMATTING_WITH_PIVOT":this.setContextualFormat(e.sheetId,e.target,e.format)}}setContextualFormat(e,t,o){const s=[],i={};for(const o of Fo(t))for(let t=o.left;t<=o.right;t++)for(let n=o.top;n<=o.bottom;n++){const o={sheetId:e,col:t,row:n},r=this.getters.getPivotCellFromPosition(o);if(this.isSpilledPivotValueFormula(o,r)){s.push(o);const e=this.getters.getPivotIdFromPosition(o)||"";i[e]??=new Set,i[e].add(r.measure)}}const n=Fo(s.map(cs));for(const e in i){const t=i[e],s=this.getters.getPivotCoreDefinition(e);this.dispatch("UPDATE_PIVOT",{pivotId:e,pivot:{...s,measures:s.measures.map((e=>t.has(e.id)?{...e,format:o}:e))}})}this.dispatch("SET_FORMATTING",{sheetId:e,target:n,format:""}),this.dispatch("SET_FORMATTING",{sheetId:e,target:Fo(t,n),format:o})}isSpilledPivotValueFormula(e,t){const o=this.getters.getCell(e);return"VALUE"===t.type&&!o?.isFormula}setDecimal(e,t,o){const s={};for(const i of Fo(t))for(const t of is(i)){const i=this.getCellNumberFormat({sheetId:e,...t});if(void 0!==i){const e=Yr(i,o);s[e]=s[e]||[],s[e].push(t)}}for(const t in s){const o=Fo(s[t].map((e=>cs(e))));this.setContextualFormat(e,o,t)}}getCellNumberFormat(e){for(const t of[e]){const e=this.getters.getEvaluatedCell(t);if(!(e.type!==r.number||e.format&&Mr(e.format)))return e.format||Lr(e.value)}}}).add("insert_pivot",class extends tu{static getters=[];allowDispatch(e){if("DUPLICATE_PIVOT_IN_NEW_SHEET"===e.type){if(!this.getters.isExistingPivot(e.pivotId))return"PivotIdNotFound";if(!this.getters.getPivot(e.pivotId).isValid())return"PivotInError"}return"Success"}handle(e){switch(e.type){case"INSERT_NEW_PIVOT":this.insertNewPivot(e.pivotId,e.newSheetId);break;case"DUPLICATE_PIVOT_IN_NEW_SHEET":this.duplicatePivotInNewSheet(e.pivotId,e.newPivotId,e.newSheetId);break;case"INSERT_PIVOT_WITH_TABLE":this.insertPivotWithTable(e.sheetId,e.col,e.row,e.pivotId,e.table,e.pivotMode);break;case"SPLIT_PIVOT_FORMULA":this.splitPivotFormula(e.sheetId,e.col,e.row,e.pivotId)}}insertNewPivot(e,t){1===gs(this.getters.getSelectedZone())&&this.selection.selectTableAroundSelection();const o=this.getters.getActiveSheetId();this.dispatch("ADD_PIVOT",{pivotId:e,pivot:{dataSet:{zone:this.getters.getSelectedZone(),sheetId:o},columns:[],rows:[],measures:[],name:ui("New pivot"),type:"SPREADSHEET"}});const s=this.getters.getSheetIds().findIndex((e=>e===o))+1,i=this.getters.getPivotFormulaId(e);this.dispatch("CREATE_SHEET",{sheetId:t,name:ui("Pivot #%(formulaId)s",{formulaId:i}),position:s}),this.dispatch("ACTIVATE_SHEET",{sheetIdFrom:o,sheetIdTo:t});const n=this.getters.getPivot(e);this.insertPivotWithTable(t,0,0,e,n.getCollapsedTableStructure().export(),"dynamic")}duplicatePivotInNewSheet(e,t,o){this.dispatch("DUPLICATE_PIVOT",{pivotId:e,newPivotId:t,duplicatedPivotName:ui("%s (copy)",this.getters.getPivotCoreDefinition(e).name)});const s=this.getters.getActiveSheetId(),i=this.getters.getSheetIds().indexOf(s)+1,n=this.getters.getPivotFormulaId(t),r=this.getters.getPivotName(t);if(this.dispatch("CREATE_SHEET",{sheetId:o,name:this.getPivotDuplicateSheetName(ui("%(newPivotName)s (Pivot #%(formulaId)s)",{newPivotName:r,formulaId:n})),position:i}).isSuccessful){this.dispatch("ACTIVATE_SHEET",{sheetIdFrom:s,sheetIdTo:o});const i=this.getters.getPivot(e);this.insertPivotWithTable(o,0,0,t,i.getCollapsedTableStructure().export(),"dynamic")}}getPivotDuplicateSheetName(e){const t=this.getters.getSheetIds().map((e=>this.getters.getSheetName(e)));return ho(bt(e),t)}insertPivotWithTable(e,t,o,s,i,n){const{cols:r,rows:a,measures:l,fieldsType:c}=i,h=new cP(r,a,l,c||{}),d=h.columns.length-1;this.resizeSheet(e,t,o,h);const u=this.getters.getPivotFormulaId(s);let g;"dynamic"===n?(this.dispatch("UPDATE_CELL",{sheetId:e,col:t,row:o,content:`=PIVOT(${u})`}),g={left:t,right:t,top:o,bottom:o}):(this.dispatch("INSERT_PIVOT",{sheetId:e,col:t,row:o,pivotId:s,table:h.export()}),g={left:t,right:t+h.getNumberOfDataColumns(),top:o,bottom:o+d+h.rows.length}),this.dispatch("CREATE_TABLE",{tableType:n,sheetId:e,ranges:[this.getters.getRangeDataFromZone(e,g)],config:{...it,numberOfHeaders:d}})}resizeSheet(e,t,o,s){const i=s.getNumberOfDataColumns()+1,n=this.getters.getNumberCols(e),r=n-t;r<i&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"COL",base:n-1,sheetId:e,sheetName:this.getters.getSheetName(e),quantity:i-r,position:"after"});const a=s.columns.length+s.rows.length,l=this.getters.getNumberRows(e),c=l-o;c<a&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"ROW",base:l-1,sheetId:e,sheetName:this.getters.getSheetName(e),quantity:a-c,position:"after"})}splitPivotFormula(e,t,o,s){const i=this.getters.getSpreadZone({sheetId:e,col:t,row:o});if(!i)return;const n=this.getters.getPivotFormulaId(s),r=new Map;for(let t=i.left;t<=i.right;t++)for(let o=i.top;o<=i.bottom;o++){const s={sheetId:e,col:t,row:o};r.set(s,this.getters.getPivotCellFromPosition(s))}for(const[e,t]of r)this.dispatch("UPDATE_CELL",{...e,content:nh(n,t)});const a=this.getters.getCoreTable({sheetId:e,col:t,row:o});if("dynamic"===a?.type){const s=cs({col:t,row:o}),n=this.getters.getRangeDataFromZone(e,i);this.dispatch("UPDATE_TABLE",{sheetId:e,zone:s,newTableRange:n,tableType:"static"})}}}).add("pivot_presence",class extends tu{static getters=["getPivotPresenceTracker"];trackPresencePivotId;tracker;handle(e){switch(e.type){case"PIVOT_START_PRESENCE_TRACKING":this.tracker=new tH,this.trackPresencePivotId=e.pivotId;break;case"PIVOT_STOP_PRESENCE_TRACKING":this.trackPresencePivotId=void 0}}getPivotPresenceTracker(e){if(this.trackPresencePivotId===e){if(!this.tracker)throw new Error("Tracker not initialized");return this.tracker}}}).add("split_to_columns",class extends tu{static getters=["getAutomaticSeparator"];allowDispatch(e){return"SPLIT_TEXT_INTO_COLUMNS"===e.type?this.chainValidations(this.batchValidations(this.checkSingleColSelected,this.checkNonEmptySelector),this.batchValidations(this.checkNotOverwritingContent,this.checkSeparatorInSelection))(e):"Success"}handle(e){if("SPLIT_TEXT_INTO_COLUMNS"===e.type)this.splitIntoColumns(e)}getAutomaticSeparator(){const e=this.getters.getSelectedCells();for(const t of e)if(t.value&&t.type===r.text){const e=this.getAutoSeparatorForString(t.value);if(e)return e}return" "}getAutoSeparatorForString(e){const t=[ot,";",","," ","."];for(const o of t)if(e.includes(o))return o}splitIntoColumns({separator:e,addNewColumns:t}){const o=this.getters.getSelectedZone(),s=this.getters.getActiveSheetId(),i=this.getSplittedCols(o,e);t&&this.addColsToAvoidCollisions(o,i),this.removeMergesInSplitZone(o,i),this.addColumnsToNotOverflowSheet(o,i);for(let e=0;e<i.length;e++){const t=o.top+e,n=i[e],r=o.left,a=this.getters.getCell({sheetId:s,col:r,row:t});if(1!==n.length||n[0]!==a?.content)for(const[e,o]of n.entries())this.dispatch("UPDATE_CELL",{sheetId:s,col:r+e,row:t,content:Bl(o,this.getters.getLocale()),format:"",style:a?.style||null})}}getSplittedCols(e,t){if(!t)throw new Error("Separator cannot be empty");const o=this.getters.getActiveSheetId(),s=[];for(const i of Ct(e.top,e.bottom+1)){const n=this.getters.getEvaluatedCell({sheetId:o,col:e.left,row:i}).formattedValue;s.push(this.splitAndRemoveTrailingEmpty(n,t))}return s}splitAndRemoveTrailingEmpty(e,t){const o=e.split(t);for(;o.length>1&&""===o[o.length-1];)o.pop();return o}willSplittedColsOverwriteContent(e,t){const o=this.getters.getActiveSheetId();for(const s of Ct(e.top,e.bottom+1)){const i=t[s-e.top];for(let t=1;t<i.length;t++){const i=this.getters.getCell({sheetId:o,col:e.left+t,row:s});if(i&&i.content)return!0}}return!1}removeMergesInSplitZone(e,t){const o=this.getters.getActiveSheetId(),s=Math.max(...t.map((e=>e.length))),i={...e,right:e.left+s-1},n=this.getters.getMergesInZone(o,i);this.dispatch("REMOVE_MERGE",{sheetId:o,target:n})}addColsToAvoidCollisions(e,t){const o=this.getters.getActiveSheetId();let s=0;for(const i of Ct(e.top,e.bottom+1)){const n={sheetId:o,col:e.left,row:i},r=t[i-e.top],a=this.getColsToAddToAvoidCollision(n,r);s=Math.max(s,a)}s&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"COL",base:e.left,sheetId:o,sheetName:this.getters.getSheetName(o),quantity:s,position:"after"})}getColsToAddToAvoidCollision(e,t){const o=t.length;for(let t=1;t<o;t++){const s=e.col+t,i=this.getters.getCell({...e,col:s});if(i&&i.content)return o-t}return 0}addColumnsToNotOverflowSheet(e,t){const o=this.getters.getActiveSheetId(),s=Math.max(...t.map((e=>e.length-1))),i=this.getters.getNumberCols(o)-1;e.left+s>i&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"COL",base:i,sheetId:o,sheetName:this.getters.getSheetName(o),quantity:e.left+s-i,position:"after"})}checkSingleColSelected(){return this.getters.isSingleColSelected()?"Success":"MoreThanOneColumnSelected"}checkNonEmptySelector(e){return""===e.separator?"EmptySplitSeparator":"Success"}checkNotOverwritingContent(e){if(e.addNewColumns||e.force)return"Success";const t=this.getters.getSelectedZones()[0],o=this.getSplittedCols(t,e.separator);return this.willSplittedColsOverwriteContent(t,o)?"SplitWillOverwriteContent":"Success"}checkSeparatorInSelection({separator:e}){const t=this.getters.getSelectedCells();for(const o of t)if(o.formattedValue.includes(e))return"Success";return"NoSplitSeparatorInSelection"}}).add("subtotal_evaluation",class extends tu{subtotalCells=new Set;handle(e){switch(e.type){case"START":this.subtotalCells.clear();for(const e of this.getters.getSheetIds()){const t=this.getters.getCells(e);for(const e in t){const o=t[e];ou(o)&&this.subtotalCells.add(o.id)}}break;case"UPDATE_CELL":{if(!("content"in e))return;const t=this.getters.getCell(e);if(!t)return;ou(t)?this.subtotalCells.add(t.id):this.subtotalCells.delete(t.id);break}}g.has(e.type)&&this.dispatch("EVALUATE_CELLS",{cellIds:Array.from(this.subtotalCells)})}}).add("collaborative",class extends tu{static getters=["getClientsToDisplay","getClient","getCurrentClient","getConnectedClients","isFullySynchronized"];static layers=["Selection"];colors=new si(12);session;constructor(e){super(e),this.session=e.session}isPositionValid(e){return e.row<this.getters.getNumberRows(e.sheetId)&&e.col<this.getters.getNumberCols(e.sheetId)}getClient(e){return this.session.getClient(e)}getCurrentClient(){return this.session.getCurrentClient()}getConnectedClients(){return[...this.session.getConnectedClients()].map((e=>({...e,color:this.colors.get(e.id)})))}isFullySynchronized(){return this.session.isFullySynchronized()}getClientsToDisplay(){try{this.getters.getCurrentClient()}catch(e){if(e instanceof VU)return[];throw e}const e=this.getters.getActiveSheetId(),t=[];for(const o of this.getters.getConnectedClients())o.id!==this.getters.getCurrentClient().id&&o.position&&o.position.sheetId===e&&this.isPositionValid(o.position)&&t.push({...o,position:o.position});return t}drawLayer(e){if(this.getters.isDashboard())return;const{ctx:t,thinLineWidth:o}=e,s=this.getters.getActiveSheetId();for(const e of this.getClientsToDisplay()){const{row:i,col:n}=e.position,r=this.getters.expandZone(s,{top:i,bottom:i,left:n,right:n}),{x:a,y:l,width:c,height:h}=this.getters.getVisibleRect(r);if(c<=0||h<=0)continue;const d=e.color;t.fillStyle=`${d}10`,t.lineWidth=4*o,t.strokeStyle=d,t.globalCompositeOperation="multiply",t.fillRect(a,l,c,h),t.globalCompositeOperation="source-over",t.strokeRect(a,l,c,h),t.font=`bold ${ke+1}px ${Le}`}}}).add("history",class extends tu{static getters=["canUndo","canRedo"];undoStack=[];redoStack=[];session;constructor(e){super(e),this.session=e.session,this.session.on("new-local-state-update",this,this.onNewLocalStateUpdate),this.session.on("snapshot",this,(()=>{this.undoStack=[],this.redoStack=[]}))}allowDispatch(e){switch(e.type){case"REQUEST_UNDO":if(!this.canUndo())return"EmptyUndoStack";break;case"REQUEST_REDO":if(!this.canRedo())return"EmptyRedoStack"}return"Success"}handle(e){switch(e.type){case"REQUEST_UNDO":case"REQUEST_REDO":this.requestHistoryChange("REQUEST_UNDO"===e.type?"UNDO":"REDO")}}finalize(){}requestHistoryChange(e){const t="UNDO"===e?this.undoStack.pop():this.redoStack.pop();if(t)"UNDO"===e?(this.session.undo(t),this.redoStack.push(t)):(this.session.redo(t),this.undoStack.push(t));else{const e=this.getPossibleRevisionToRepeat();if(!e)return;const t=eH(e,this.getters);if(!t)return;if(!Array.isArray(t))return void this.dispatch(t.type,t);for(const e of t)this.dispatch(e.type,e)}}canUndo(){return this.undoStack.length>0}canRedo(){if(this.redoStack.length>0)return!0;const e=this.getPossibleRevisionToRepeat();return!(!(t=e)||!t.rootCommand||"object"!=typeof t.rootCommand)&&(f(t.rootCommand)?KU.contains(t.rootCommand.type):JU.contains(t.rootCommand.type));var t}onNewLocalStateUpdate({id:e}){this.undoStack.push(e),this.redoStack=[],this.undoStack.length>99&&this.undoStack.shift()}getPossibleRevisionToRepeat(){return this.session.getLastLocalNonEmptyRevision()}}).add("data_cleanup",class extends tu{allowDispatch(e){return"REMOVE_DUPLICATES"===e.type?this.checkValidations(e,this.chainValidations(this.checkSingleRangeSelected,this.checkNoMergeInZone,this.checkRangeContainsValues,this.checkColumnsIncludedInZone),this.chainValidations(this.checkNoColumnProvided,this.checkColumnsAreUnique)):"Success"}handle(e){switch(e.type){case"REMOVE_DUPLICATES":this.removeDuplicates(e.columns,e.hasHeader);break;case"TRIM_WHITESPACE":this.trimWhitespace()}}removeDuplicates(e,t){const o=this.getters.getActiveSheetId(),s=this.getters.getSelectedZone();t&&(s.top+=1);const i=this.getUniqueRowsIndexes(o,s.top,s.bottom,e),n=i.length;if(n===os(s).numberOfRows)return void this.notifyRowsRemovedAndRemaining(0,n);const r=i.map((e=>({left:s.left,top:e,right:s.right,bottom:e}))),a=new Ch(this.getters,this.dispatch),l=a.copy(bs(o,r),!1);if(!l)return;this.dispatch("CLEAR_CELLS",{target:[s],sheetId:o});const c={left:s.left,top:s.top,right:s.left,bottom:s.top};a.paste({zones:[c],sheetId:o},l,{isCutOperation:!1});const h={left:s.left,top:s.top-(t?1:0),right:s.right,bottom:s.top+n-1};this.selection.selectZone({cell:{col:h.left,row:h.top},zone:h});const d=s.bottom-s.top+1-n;this.notifyRowsRemovedAndRemaining(d,n)}getUniqueRowsIndexes(e,t,o,s){const i=new Map;for(const n of Ct(t,o+1)){const t=s.map((t=>this.getters.getEvaluatedCell({sheetId:e,col:t,row:n}).value));!Object.values(i).some((e=>zt(e,t)))&&(i[n]=t)}return Object.keys(i).map((e=>parseInt(e)))}notifyRowsRemovedAndRemaining(e,t){this.ui.notifyUI({type:"info",text:ui("%s duplicate rows found and removed.\n%s unique rows remain.",e.toString(),t.toString()),sticky:!1})}checkSingleRangeSelected(){return 1!==this.getters.getSelectedZones().length?"MoreThanOneRangeSelected":"Success"}checkNoMergeInZone(){const e=this.getters.getActiveSheetId(),t=this.getters.getSelectedZone();return this.getters.getMergesInZone(e,t).length>0?"WillRemoveExistingMerge":"Success"}checkRangeContainsValues(e){const t=this.getters.getActiveSheetId(),o=this.getters.getSelectedZone();e.hasHeader&&(o.top+=1);return this.getters.getEvaluatedCellsInZone(t,o).every((e=>"empty"===e.type))?"EmptyTarget":"Success"}checkNoColumnProvided(e){return 0===e.columns.length?"NoColumnsProvided":"Success"}checkColumnsIncludedInZone(e){const t=this.getters.getSelectedZone();return e.columns.some((e=>e<t.left||e>t.right))?"ColumnsNotIncludedInZone":"Success"}checkColumnsAreUnique(e){return e.columns.length!==new Set(e.columns).size?"DuplicatesColumnsSelected":"Success"}trimWhitespace(){const e=Fo(this.getters.getSelectedZones()),t=this.getters.getActiveSheetId();let o=0;for(const{col:s,row:i}of e.map(is).flat()){const e=this.getters.getCell({col:s,row:i,sheetId:t});if(!e)continue;const n=oo(e.content);n!==e.content&&(o+=1,this.dispatch("UPDATE_CELL",{sheetId:t,col:s,row:i,content:n}))}const s=o?ui("Trimmed whitespace from %s cells.",o):ui("No selected cells had whitespace trimmed.");this.ui.notifyUI({type:"info",text:s,sticky:!1})}}).add("table_autofill",class extends tu{handle(e){if("AUTOFILL_TABLE_COLUMN"===e.type){const t=this.getters.getCoreTable(e),o=this.getters.getCell(e);if(!t?.config.automaticAutofill||"dynamic"===t.type||!o?.isFormula)return;const{col:s,row:i}=e,n=function(e,t){const o=t.numberOfHeaders,s={...e,top:e.top+o};return s.top<=s.bottom?s:void 0}(t.range.zone,t.config);if(n&&es(s,i,n)){const t=e.autofillRowStart??n.top,o=e.autofillRowEnd??n.bottom,s={...n,top:t,bottom:o};this.autofillTableZone(e,s)}}}autofillTableZone(e,t){if(t.top===t.bottom)return;const{col:o,row:s,sheetId:i}=e;for(let e=t.top;e<=t.bottom;e++)if(e!==s&&this.getters.getEvaluatedCell({col:o,row:e,sheetId:i}).type!==r.empty)return;const n={zone:this.getters.getSelectedZone(),cell:this.getters.getActivePosition()};this.selection.selectCell(o,s),this.dispatch("AUTOFILL_SELECT",{col:o,row:t.bottom}),this.dispatch("AUTOFILL"),this.selection.selectCell(o,s),this.dispatch("AUTOFILL_SELECT",{col:o,row:t.top}),this.dispatch("AUTOFILL"),this.selection.selectZone(n)}}).add("table_ui_resize",class extends tu{allowDispatch(e){if("RESIZE_TABLE"===e.type){const t=this.getters.getCoreTableMatchingTopLeft(e.sheetId,e.zone);if(!t)return"TableNotFound";const o=t.range.zone,s=this.getters.getRangeFromRangeData(e.newTableRange).zone;return s.top!==o.top||s.left!==o.left?"InvalidTableResize":this.canDispatch("UPDATE_TABLE",{...e}).reasons}return"Success"}handle(e){switch(e.type){case"RESIZE_TABLE":{const t=this.getters.getCoreTableMatchingTopLeft(e.sheetId,e.zone);if(this.dispatch("UPDATE_TABLE",{...e}),!t)return;const o=this.getters.getRangeFromRangeData(e.newTableRange).zone;if(this.selection.selectCell(o.right,o.bottom),!t.config.automaticAutofill)return;const s=t.range.zone;if(o.bottom>=s.bottom){for(let t=o.left;t<=o.right;t++){const i={col:t,row:s.bottom,sheetId:e.sheetId};this.getters.getCell(i)?.content.startsWith("=")&&this.dispatch("AUTOFILL_TABLE_COLUMN",{...i,autofillRowStart:s.bottom,autofillRowEnd:o.bottom})}break}}}}}).add("datavalidation_insert",class extends tu{handle(e){if("ADD_DATA_VALIDATION_RULE"===e.type)if("isBoolean"===e.rule.criterion.type){const t=e.ranges.map((e=>this.getters.getRangeFromRangeData(e)));for(const e of $a(t)){const t=this.getters.getCell(e),o=this.getters.getEvaluatedCell(e);if(t?.content)if(t?.content&&o.type===r.empty){let o;if(t.content.startsWith("=")){const s=this.getters.evaluateFormula(e.sheetId,t.content);o=(E(s)?s[0][0]:s)?.toString()}else o=t.content;o&&wt(o)||this.dispatch("UPDATE_CELL",{...e,content:"FALSE"})}else o.type!==r.boolean&&this.dispatch("UPDATE_CELL",{...e,content:"FALSE"});else this.dispatch("UPDATE_CELL",{...e,content:"FALSE"})}}}}).add("checkbox_toggle",class extends tu{static getters=["hasBooleanValidationInZones"];handle(e){if("TOGGLE_CHECKBOX"===e.type)this.toggleCheckbox(e.sheetId,e.target)}hasBooleanValidationInZones(e){const t=this.getters.getActiveSheetId();for(const o of e)for(let e=o.left;e<=o.right;e++)for(let s=o.top;s<=o.bottom;s++)if(this.getters.isCellValidCheckbox({col:e,row:s,sheetId:t}))return!0;return!1}toggleCheckbox(e,t){for(const o of t)for(let t=o.left;t<=o.right;t++)for(let s=o.top;s<=o.bottom;s++){const o={col:t,row:s,sheetId:e};if(this.getters.isCellValidCheckbox(o)){const e=this.getters.getEvaluatedCell(o).value?"FALSE":"TRUE";this.dispatch("UPDATE_CELL",{...o,content:e})}}}}).add("dynamic_translate",class extends tu{static getters=["dynamicTranslate"];dynamicTranslate(e){return e}}).add("geo_features",class extends tu{static getters=["getGeoJsonFeatures","geoFeatureNameToId","getGeoChartAvailableRegions"];geoJsonService;geoJsonCache={};constructor(e){super(e),this.geoJsonService=e.external.geoJsonService}getGeoChartAvailableRegions(){return this.geoJsonService?this.geoJsonService.getAvailableRegions()||[]:(console.error("No geoJsonService provided to the model"),[])}getGeoJsonFeatures(e){if(!this.geoJsonService)return void console.error("No geoJsonService provided to the model");const t=this.geoJsonCache[e];return t instanceof Promise?void 0:void 0!==t?t??void 0:void(this.geoJsonCache[e]=new Promise((async t=>{const o=await(this.geoJsonService?.getTopoJson(e));this.geoJsonCache[e]=this.convertToGeoJson(o),this.dispatch("EVALUATE_CHARTS"),t()})))}geoFeatureNameToId(e,t){if(this.geoJsonService)return this.geoJsonService.geoFeatureNameToId(e,t);console.error("No geoJsonService provided to the model")}convertToGeoJson(e){if(!e)return null;if("Topology"===e.type){const t=window.ChartGeo.topojson.feature(e,Object.values(e.objects)[0]);return"FeatureCollection"===t.type?t.features:[t]}if("FeatureCollection"===e.type)return e.features;throw new Error("Invalid TopoJSON")}}),aH=(new n).add("selection",class extends tu{static layers=["Selection"];static getters=["getActiveSheet","getActiveSheetId","getActiveSheetName","getActiveCell","getActiveCols","getActiveRows","getCurrentStyle","getSelectedZones","getSelectedZone","getSelectedCells","getSelectedFigureId","getSelection","getActivePosition","getSheetPosition","isSingleColSelected","getElementsFromSelection","tryGetActiveSheetId","isGridSelectionActive","getSelectecUnboundedZone"];gridSelection={anchor:{cell:{col:0,row:0},zone:{top:0,left:0,bottom:0,right:0}},zones:[{top:0,left:0,bottom:0,right:0}]};selectedFigureId=null;sheetsData={};moveClient;isUnbounded;activeSheet=null;constructor(e){super(e),this.moveClient=e.moveClient,this.isUnbounded=!1}allowDispatch(e){switch(e.type){case"ACTIVATE_SHEET":try{if(!this.getters.getSheet(e.sheetIdTo).isVisible)return"SheetIsHidden";break}catch(e){return"InvalidSheetId"}case"MOVE_COLUMNS_ROWS":return this.isMoveElementAllowed(e)}return"Success"}handleEvent(e){const t=e.anchor;let o=[];switch(this.isUnbounded=e.options?.unbounded||!1,e.mode){case"overrideSelection":o=[t.zone];break;case"updateAnchor":o=[...this.gridSelection.zones];const s=o.findIndex((t=>Ko(t,e.previousAnchor.zone)));s>=0&&(o[s]=t.zone);break;case"newAnchor":o=[...this.gridSelection.zones,t.zone]}this.setSelectionMixin(e.anchor,o),this.selection.resetDefaultAnchor(this,pt(this.gridSelection.anchor));const{col:s,row:i}=this.gridSelection.anchor.cell;this.moveClient({sheetId:this.getters.getActiveSheetId(),col:s,row:i}),this.selectedFigureId=null}handle(e){switch(e.type){case"ACTIVATE_SHEET":this.selectedFigureId=null;break;case"DELETE_FIGURE":this.selectedFigureId===e.figureId&&(this.selectedFigureId=null);break;case"DELETE_SHEET":this.selectedFigureId&&this.getters.getFigure(e.sheetId,this.selectedFigureId)&&(this.selectedFigureId=null)}switch(e.type){case"START":const t=this.getters.getVisibleSheetIds()[0];this.activateSheet(t,t);const{col:o,row:s}=this.getters.getNextVisibleCellPosition({sheetId:t,col:0,row:0});this.selectCell(o,s),this.selection.registerAsDefault(this,this.gridSelection.anchor,{handleEvent:this.handleEvent.bind(this)}),this.moveClient({sheetId:t,col:0,row:0});break;case"ACTIVATE_SHEET":this.activateSheet(e.sheetIdFrom,e.sheetIdTo);break;case"REMOVE_COLUMNS_ROWS":{const t=this.getters.getActiveSheetId();if(e.sheetId===t){"COL"===e.dimension?this.onColumnsRemoved(e):this.onRowsRemoved(e);const{col:o,row:s}=this.gridSelection.anchor.cell;this.moveClient({sheetId:t,col:o,row:s})}break}case"ADD_COLUMNS_ROWS":{const t=this.getters.getActiveSheetId();if(e.sheetId===t){this.onAddElements(e);const{col:o,row:s}=this.gridSelection.anchor.cell;this.moveClient({sheetId:t,col:o,row:s})}break}case"MOVE_COLUMNS_ROWS":e.sheetId===this.getActiveSheetId()&&this.onMoveElements(e);break;case"SELECT_FIGURE":this.selectedFigureId=e.figureId;break;case"ACTIVATE_NEXT_SHEET":this.activateNextSheet("right");break;case"ACTIVATE_PREVIOUS_SHEET":this.activateNextSheet("left");break;case"HIDE_SHEET":e.sheetId===this.getActiveSheetId()&&this.dispatch("ACTIVATE_SHEET",{sheetIdFrom:e.sheetId,sheetIdTo:this.getters.getVisibleSheetIds()[0]});break;case"UNDO":case"REDO":case"DELETE_SHEET":const i=Object.keys(this.sheetsData).filter((e=>!this.getters.tryGetSheet(e)));for(const e of i)delete this.sheetsData[e];for(const e in this.sheetsData){const t=this.clipSelection(e,this.sheetsData[e].gridSelection);this.sheetsData[e]={gridSelection:pt(t)}}this.fallbackToVisibleSheet();const n=this.getters.getActiveSheetId();this.gridSelection.zones=this.gridSelection.zones.map((e=>this.getters.expandZone(n,e))),this.gridSelection.anchor.zone=this.getters.expandZone(n,this.gridSelection.anchor.zone),this.setSelectionMixin(this.gridSelection.anchor,this.gridSelection.zones),this.selectedFigureId=null}}finalize(){this.fallbackToVisibleSheet(),this.selection.resetDefaultAnchor(this,pt(this.gridSelection.anchor))}isGridSelectionActive(){return this.selection.isListening(this)}getActiveSheet(){return this.activeSheet}getActiveSheetId(){return this.activeSheet.id}getActiveSheetName(){return this.activeSheet.name}tryGetActiveSheetId(){return this.activeSheet?.id}getActiveCell(){return this.getters.getEvaluatedCell(this.getActivePosition())}getActiveCols(){const e=new Set;for(const t of this.gridSelection.zones)if(0===t.top&&t.bottom===this.getters.getNumberRows(this.getters.getActiveSheetId())-1)for(let o=t.left;o<=t.right;o++)e.add(o);return e}getActiveRows(){const e=new Set,t=this.getters.getActiveSheetId();for(const o of this.gridSelection.zones)if(0===o.left&&o.right===this.getters.getNumberCols(t)-1)for(let t=o.top;t<=o.bottom;t++)e.add(t);return e}getCurrentStyle(){const e=this.getters.getSelectedZone(),t=this.getters.getActiveSheetId();return this.getters.getCellStyle({sheetId:t,col:e.left,row:e.top})}getSelectedZones(){return pt(this.gridSelection.zones)}getSelectedZone(){return pt(this.gridSelection.anchor.zone)}getSelectecUnboundedZone(){return pt(this.isUnbounded?this.getters.getUnboundedZone(this.activeSheet.id,this.gridSelection.anchor.zone):this.gridSelection.anchor.zone)}getSelection(){return pt(this.gridSelection)}getSelectedCells(){const e=this.getters.getActiveSheetId(),t=[];for(const o of this.gridSelection.zones)t.push(...this.getters.getEvaluatedCellsInZone(e,o));return t}getSelectedFigureId(){return this.selectedFigureId}getActivePosition(){return this.getters.getMainCellPosition({sheetId:this.getActiveSheetId(),col:this.gridSelection.anchor.cell.col,row:this.gridSelection.anchor.cell.row})}getSheetPosition(e){if(e===this.getters.getActiveSheetId())return this.getActivePosition();{const t=this.sheetsData[e];return t?{sheetId:e,col:t.gridSelection.anchor.cell.col,row:t.gridSelection.anchor.cell.row}:this.getters.getNextVisibleCellPosition({sheetId:e,col:0,row:0})}}isSingleColSelected(){const e=this.getters.getSelectedZones();return 1===e.length&&e[0].left===e[0].right}getElementsFromSelection(e){if("COL"===e&&0===this.getters.getActiveCols().size)return[];if("ROW"===e&&0===this.getters.getActiveRows().size)return[];const t=this.getters.getSelectedZones();let o=[];const s="COL"===e?"left":"top",i="COL"===e?"right":"bottom";for(const e of t){const t=Array.from({length:e[i]-e[s]+1},((t,o)=>e[s]+o));o=o.concat(t)}return[...new Set(o)].sort()}activateSheet(e,t){if(this.setActiveSheet(t),this.sheetsData[e]={gridSelection:pt(this.gridSelection)},t in this.sheetsData)Object.assign(this,this.sheetsData[t]),this.selection.resetDefaultAnchor(this,pt(this.gridSelection.anchor));else{const{col:e,row:o}=this.getters.getNextVisibleCellPosition({sheetId:t,col:0,row:0});this.selectCell(e,o)}const{col:o,row:s}=this.gridSelection.anchor.cell;this.moveClient({sheetId:this.activeSheet.id,col:o,row:s})}setSelectionMixin(e,t){const{anchor:o,zones:s}=this.clipSelection(this.getters.getActiveSheetId(),{anchor:e,zones:t});this.gridSelection.anchor=o,this.gridSelection.zones=function(e){return e.reverse().filter(((e,t,o)=>t===o.findIndex((t=>t.top===e.top&&t.bottom===e.bottom&&t.left===e.left&&t.right===e.right)))).reverse()}(s)}selectCell(e,t){const o=this.getters.getActiveSheetId(),s=this.getters.expandZone(o,{left:e,right:e,top:t,bottom:t});this.setSelectionMixin({zone:s,cell:{col:e,row:t}},[s])}setActiveSheet(e){this.activeSheet=this.getters.getSheet(e)}activateNextSheet(e){const t=this.getters.getSheetIds(),o=(t.findIndex((e=>e===this.activeSheet.id))+("left"===e?t.length-1:1))%t.length;this.dispatch("ACTIVATE_SHEET",{sheetIdFrom:this.getActiveSheetId(),sheetIdTo:t[o]})}onColumnsRemoved(e){const{cell:t,zone:o}=this.gridSelection.anchor,s=Zo(o,"left",[...e.elements]);let i={left:t.col,right:t.col,top:t.row,bottom:t.row};i=Zo(i,"left",[...e.elements]);const n={cell:{col:i.left,row:i.top},zone:s},r=this.gridSelection.zones.map((t=>Zo(t,"left",[...e.elements])));this.setSelectionMixin(n,r)}onRowsRemoved(e){const{cell:t,zone:o}=this.gridSelection.anchor,s=Zo(o,"top",[...e.elements]);let i={left:t.col,right:t.col,top:t.row,bottom:t.row};i=Zo(i,"top",[...e.elements]);const n={cell:{col:i.left,row:i.top},zone:s},r=this.gridSelection.zones.map((t=>Zo(t,"top",[...e.elements])));this.setSelectionMixin(n,r)}onAddElements(e){const t="COL"===e.dimension?"left":"top",o=qo(this.gridSelection.anchor.zone,t,e.base,e.position,e.quantity),s=this.gridSelection.zones.map((o=>qo(o,t,e.base,e.position,e.quantity))),i={cell:{col:o.left,row:o.top},zone:o};this.setSelectionMixin(i,s)}onMoveElements(e){const t=e.elements.length,o=this.getFiguresUpdates(e);this.dispatch("ADD_COLUMNS_ROWS",{dimension:e.dimension,sheetId:e.sheetId,sheetName:e.sheetName,base:e.base,quantity:t,position:e.position});const s="COL"===e.dimension,i=e.elements[0],n=e.elements[t-1],r=e.base<i,a=r&&s?t:0,l=r&&!s?t:0,c=r?e.elements.map((e=>e+t)):e.elements,h={};for(const t of c)h[t]=this.getters.getHeaderSize(e.sheetId,e.dimension,t);const d=[{left:s?i+a:0,right:s?n+a:this.getters.getNumberCols(e.sheetId)-1,top:s?0:i+l,bottom:s?this.getters.getNumberRows(e.sheetId)-1:n+l}],u=this.getActiveSheetId(),g=r?e.base:e.base+1,p=[{left:s?g:0,right:s?g+t-1:this.getters.getNumberCols(e.sheetId)-1,top:s?0:g,bottom:s?this.getters.getNumberRows(e.sheetId)-1:g+t-1}],m=yh.cellHandlers.getKeys().map((e=>[e,new(yh.cellHandlers.get(e))(this.getters,this.dispatch)])),f={};for(const[e,t]of m)f[e]=t.copy(bs(u,d),!1,"shiftCells");for(const[e,t]of m)f[e]&&t.paste({zones:p,sheetId:u},f[e],{isCutOperation:!0});const v=p[0],b=v.left,S=v.top;this.setSelectionMixin({zone:v,cell:{col:b,row:S}},[v]);let C=r?e.base:e.base+1;const y={};for(const t of c){const o=h[t];o!==this.getters.getHeaderSize(e.sheetId,e.dimension,C)&&(y[o]??=[],y[o].push(C)),C+=1}for(const t in y)this.dispatch("RESIZE_COLUMNS_ROWS",{dimension:e.dimension,sheetId:e.sheetId,size:parseInt(t,10),elements:y[t]});this.dispatch("REMOVE_COLUMNS_ROWS",{dimension:e.dimension,sheetId:e.sheetId,sheetName:e.sheetName,elements:c}),this.applyFigureUpdates(o)}getFiguresUpdates(e){const t=[],o={},s=e.elements[0]<e.base?e.base-e.elements.length+1:e.base;for(let t=0;t<e.elements.length;t++)o[e.elements[t]]=s+t;for(const s of this.getters.getFigures(e.sheetId))"COL"===e.dimension&&s.col in o&&t.push({type:"UPDATE_FIGURE",sheetId:e.sheetId,figureId:s.id,col:o[s.col],row:s.row}),"ROW"===e.dimension&&s.row in o&&t.push({type:"UPDATE_FIGURE",sheetId:e.sheetId,figureId:s.id,row:o[s.row],col:s.col});return t}applyFigureUpdates(e){for(const t of e)this.dispatch(t.type,{...t})}isMoveElementAllowed(e){const t="COL"===e.dimension,o=e.elements[0],s=e.elements[e.elements.length-1],i=e.sheetId,n=t?this.getters.doesColumnsHaveCommonMerges:this.getters.doesRowsHaveCommonMerges;if(n(i,o-1,o)||n(i,s,s+1)||n(i,e.base-1,e.base))return"WillRemoveExistingMerge";const r=[e.base,...e.elements],a=t?this.getters.getNumberCols(i):this.getters.getNumberRows(i);return r.some((e=>e<0||e>=a))?"InvalidHeaderIndex":t||this.isTableRowMoveAllowed(i,e.elements)?"Success":"CannotMoveTableHeader"}isTableRowMoveAllowed(e,t){const o=this.getters.getCoreTables(e);if(0===o.length)return!0;const s=new Set(t);return o.every((({range:{zone:e},config:o})=>{const{top:i,bottom:n}=e;if(0===o.numberOfHeaders)return!0;const r=i+o.numberOfHeaders-1;if(!t.some((e=>e>=i&&e<=r)))return!0;return Ct(i,n+1).every((e=>s.has(e)))}))}fallbackToVisibleSheet(){if(!this.getters.tryGetSheet(this.getters.getActiveSheetId())){const e=this.getters.getVisibleSheetIds();if(this.activeSheet=this.getters.getSheet(e[0]),this.activeSheet.id in this.sheetsData){const{anchor:e}=this.clipSelection(this.activeSheet.id,this.sheetsData[this.activeSheet.id].gridSelection);this.selectCell(e.cell.col,e.cell.row)}else this.selectCell(0,0);const{col:t,row:o}=this.gridSelection.anchor.cell;this.moveClient({sheetId:this.getters.getActiveSheetId(),col:t,row:o})}}clipSelection(e,t){const o=this.getters.getNumberCols(e)-1,s=this.getters.getNumberRows(e)-1;return{zones:t.zones.map((e=>({left:St(e.left,0,o),right:St(e.right,0,o),top:St(e.top,0,s),bottom:St(e.bottom,0,s)}))),anchor:{cell:{col:St(t.anchor.cell.col,0,o),row:St(t.anchor.cell.row,0,s)},zone:{left:St(t.anchor.zone.left,0,o),right:St(t.anchor.zone.right,0,o),top:St(t.anchor.zone.top,0,s),bottom:St(t.anchor.zone.bottom,0,s)}}}}drawLayer(e){if(this.getters.isDashboard())return;const{ctx:t,thinLineWidth:o}=e,s=this.getSelectedZones();t.fillStyle="#f3f7fe";const i=1===s.length&&s[0].left===s[0].right&&s[0].top===s[0].bottom;t.fillStyle=i?"#f3f7fe":"#e9f0ff",t.strokeStyle=N,t.lineWidth=1.5*o;for(const e of s){const{x:o,y:s,width:i,height:n}=this.getters.getVisibleRect(e);t.globalCompositeOperation="multiply",t.fillRect(o,s,i,n),t.globalCompositeOperation="source-over",t.strokeRect(o,s,i,n)}t.globalCompositeOperation="source-over";const n=this.getActivePosition();let r;t.strokeStyle=N,t.lineWidth=3*o,r=this.getters.isInMerge(n)?this.getters.getMerge(n):cs(n);const{x:a,y:l,width:c,height:h}=this.getters.getVisibleRect(r);c>0&&h>0&&t.strokeRect(a,l,c,h)}}).add("evaluation_filter",class extends tu{static getters=["getFilterValue","getFilterHiddenValues","getFilterCriterionValue","getFirstTableInSelection","isRowFiltered","isFilterActive"];filterValues={};hiddenRows={};isEvaluationDirty=!1;allowDispatch(e){if("UPDATE_FILTER"===e.type)if(!this.getters.getFilterId(e))return"FilterNotFound";return"Success"}handle(e){switch(e.type){case"UNDO":case"REDO":case"UPDATE_CELL":case"EVALUATE_CELLS":case"ACTIVATE_SHEET":case"REMOVE_TABLE":case"ADD_COLUMNS_ROWS":case"REMOVE_COLUMNS_ROWS":case"UPDATE_TABLE":this.isEvaluationDirty=!0;break;case"START":for(const e of this.getters.getSheetIds())this.filterValues[e]={};break;case"CREATE_SHEET":this.filterValues[e.sheetId]={};break;case"HIDE_COLUMNS_ROWS":case"UNHIDE_COLUMNS_ROWS":case"GROUP_HEADERS":case"UNGROUP_HEADERS":case"FOLD_HEADER_GROUP":case"UNFOLD_HEADER_GROUP":case"FOLD_ALL_HEADER_GROUPS":case"UNFOLD_ALL_HEADER_GROUPS":case"FOLD_HEADER_GROUPS_IN_ZONE":case"UNFOLD_HEADER_GROUPS_IN_ZONE":this.updateHiddenRows(e.sheetId);break;case"UPDATE_FILTER":this.updateFilter(e),this.updateHiddenRows(e.sheetId);break;case"DUPLICATE_SHEET":this.filterValues[e.sheetIdTo]=pt(this.filterValues[e.sheetId])}}finalize(){if(this.isEvaluationDirty){for(const e of this.getters.getSheetIds())this.updateHiddenRows(e);this.isEvaluationDirty=!1}}isRowFiltered(e,t){return!!this.hiddenRows[e]?.has(t)}getFilterValue(e){const t=this.getters.getFilterId(e),o=e.sheetId;return t?this.filterValues[o]?.[t]:void 0}getFilterHiddenValues(e){const t=this.getters.getFilterId(e),o=e.sheetId;if(!t||!this.filterValues[o])return[];const s=this.filterValues[o][t]||[];return"values"===s.filterType?s.hiddenValues:[]}getFilterCriterionValue(e){const t=this.getters.getFilterId(e),o=e.sheetId;if(!t||!this.filterValues[o])return sH;const s=this.filterValues[o][t];return s&&"criterion"===s.filterType?s:sH}isFilterActive(e){const t=this.getters.getFilterId(e);if(!t)return!1;const o=e.sheetId,s=this.filterValues[o]?.[t];return!!s&&("values"===s.filterType?s.hiddenValues.length>0:"none"!==s.type)}getFirstTableInSelection(){const e=this.getters.getActiveSheetId(),t=this.getters.getSelectedZones();return this.getters.getTablesOverlappingZones(e,t)[0]}updateFilter({col:e,row:t,value:o,sheetId:s}){const i=this.getters.getFilterId({sheetId:s,col:e,row:t});i&&(this.filterValues[s]||(this.filterValues[s]={}),this.filterValues[s][i]=o)}updateHiddenRows(e){const t=this.getters.getFilters(e).sort(((e,t)=>e.rangeWithHeaders.zone.top-t.rangeWithHeaders.zone.top)),o=new Set;for(const s of t){const t=this.filterValues[e]?.[s.id],i=s.filteredRange?.zone;if(t&&i&&!o.has(s.rangeWithHeaders.zone.top)&&!this.getters.isRowHiddenByUser(e,s.rangeWithHeaders.zone.top))if("values"===t.filterType){const n=t.hiddenValues?.map(pl);if(!n)continue;const r=new Set(n);for(let t=i.top;t<=i.bottom;t++){const i=this.getCellValueAsString(e,s.col,t);r.has(i)&&o.add(t)}}else{if("none"===t.type)continue;const n=sR.get(t.type),r=t.values.map((t=>t.startsWith("=")?this.getters.evaluateFormula(e,t)??"":ea(t,w)));if(r.some(bc))continue;const a={type:t.type,values:r.map(fc),dateValue:t.dateValue};for(let t=i.top;t<=i.bottom;t++){const i={sheetId:e,col:s.col,row:t},r=this.getters.getEvaluatedCell(i).value??"";n.isValueValid(r,a,this.getters,e)||o.add(t)}}}this.hiddenRows[e]=o}getCellValueAsString(e,t,o){return this.getters.getEvaluatedCell({sheetId:e,col:t,row:o}).formattedValue.toLowerCase()}exportForExcel(e){for(const t of e.sheets){const e=t.id;for(const o of t.tables){const s=Ho(o.range),i=[],n=[];for(const o of Ct(0,os(s).numberOfCols)){const r={sheetId:t.id,col:s.left+o,row:s.top},a=this.getFilterHiddenValues(r),l=this.getters.getFilter(r),c=l?.filteredRange?is(l.filteredRange.zone).map((t=>this.getters.getEvaluatedCell({sheetId:e,...t}).formattedValue)):[];if(a.length){const e=c.filter((e=>e)).filter((e=>!a.includes(e)));i.push({colId:o,displayedValues:[...new Set(e)],displayBlanks:!a.includes("")&&c.some((e=>!e))})}const h=this.getters.getEvaluatedCell(r).formattedValue,d=this.getUniqueColNameForExcel(o,h,n);n.push(d);const u=_o(r.col,r.row);t.cells[u]=d,t.cellValues[u]=d}o.filters=i}}}getUniqueColNameForExcel(e,t,o){return t||(t=`Column${e}`),ho(t,o,{compute:(e,o)=>t+String(o),start:2})}}).add("header_visibility_ui",class extends tu{static getters=["getNextVisibleCellPosition","findVisibleHeader","findLastVisibleColRowIndex","findFirstVisibleColRowIndex","isRowHidden","isColHidden","isHeaderHidden"];isRowHidden(e,t){return this.getters.isRowHiddenByUser(e,t)||this.getters.isRowFiltered(e,t)}isColHidden(e,t){return this.getters.isColHiddenByUser(e,t)}isHeaderHidden(e,t,o){return"COL"===t?this.isColHidden(e,o):this.isRowHidden(e,o)}getNextVisibleCellPosition({sheetId:e,col:t,row:o}){return{sheetId:e,col:this.findVisibleHeader(e,"COL",t,this.getters.getNumberCols(e)-1),row:this.findVisibleHeader(e,"ROW",o,this.getters.getNumberRows(e)-1)}}findVisibleHeader(e,t,o,s){if(o<=s)for(let i=o;i<=s;i++)if(this.getters.doesHeaderExist(e,t,i)&&!this.isHeaderHidden(e,t,i))return i;if(o>s)for(let i=o;i>=s;i--)if(this.getters.doesHeaderExist(e,t,i)&&!this.isHeaderHidden(e,t,i))return i}findLastVisibleColRowIndex(e,t,{last:o,first:s}){return Ct(o,s,-1).find((o=>!this.isHeaderHidden(e,t,o)))||s}findFirstVisibleColRowIndex(e,t){const o=this.getters.getNumberHeaders(e,t);for(let s=0;s<o;s++){if("COL"===t&&!this.isColHidden(e,s))return s;if("ROW"===t&&!this.isRowHidden(e,s))return s}}exportForExcel(e){for(const t of e.sheets)for(const[e,o]of Object.entries(t.rows))o.isHidden=this.isRowHidden(t.id,Number(e))}}).add("cell_computed_style",class extends tu{static getters=["getCellComputedBorder","getCellComputedStyle"];styles=new tF;borders=new tF;handle(e){if(l.has(e.type)||"UPDATE_CELL"===e.type||"SET_FORMATTING"===e.type||"ADD_DATA_VALIDATION_RULE"===e.type||"REMOVE_DATA_VALIDATION_RULE"===e.type||"EVALUATE_CELLS"===e.type)return this.styles=new tF,void(this.borders=new tF);zU(e)?"sheetId"in e?(this.styles.clearSheet(e.sheetId),this.borders.clearSheet(e.sheetId)):(this.styles=new tF,this.borders=new tF):d.has(e.type)?this.styles=new tF:u.has(e.type)&&(this.borders=new tF)}getCellComputedBorder(e,t){let o=this.borders.get(e);return void 0===o&&(this.precomputeCellBorders(e.sheetId,t??cs(e)),o=this.borders.get(e)),o??null}precomputeCellBorders(e,t){const o=this.getters.getCellBordersInZone(e,t),s=this.getters.getCellTableBorderZone(e,t);for(let i=t.left;i<=t.right;i++)for(let n=t.top;n<=t.bottom;n++){const t={sheetId:e,col:i,row:n};if(void 0!==this.borders.get(t))continue;const r=o.get(t),a={...Wt(s.get(t)),...Wt(r)};Nt(a)?this.borders.set(t,null):this.borders.set(t,a)}}getCellComputedStyle(e){let t=this.styles.get(e);return void 0===t&&(t=this.computeCellStyle(e),this.styles.set(e,t)),t}computeCellStyle(e){const t=this.getters.getCell(e),o=this.getters.getCellConditionalFormatStyle(e),s=this.getters.getCellTableStyle(e),i=this.getters.getDataValidationCellStyle(e),n={...Wt(s),...Wt(i),...Wt(t?.style),...Wt(o)};return this.getters.getEvaluatedCell(e).link&&!n.textColor&&(n.textColor=U),n}}).add("table_computed_style",class extends tu{static getters=["getCellTableStyle","getCellTableBorder","getCellTableBorderZone"];tableStyles={};handle(e){l.has(e.type)||"UPDATE_CELL"===e.type&&("content"in e||"format"in e)||"EVALUATE_CELLS"===e.type?this.tableStyles={}:zU(e)&&("sheetId"in e?delete this.tableStyles[e.sheetId]:this.tableStyles={})}finalize(){for(const e of this.getters.getSheetIds()){this.tableStyles[e]||(this.tableStyles[e]={});for(const t of this.getters.getTables(e))this.tableStyles[e][t.id]||(this.tableStyles[e][t.id]=this.computeTableStyle(e,t))}}getCellTableStyle(e){const t=this.getters.getTable(e);if(t)return this.tableStyles[e.sheetId][t.id]().styles[e.col]?.[e.row]}getCellTableBorder(e){const t=this.getters.getTable(e);if(t)return this.tableStyles[e.sheetId][t.id]().borders[e.col]?.[e.row]}getCellTableBorderZone(e,t){const o=new tF;for(const s of this.getters.getTablesOverlappingZones(e,[t])){const t=this.tableStyles[e][s.id]().borders;for(const[s,i]of Object.entries(t)){const t=parseInt(s);for(const[s,n]of Object.entries(i))n&&o.set({sheetId:e,col:t,row:parseInt(s)},n)}}return o}computeTableStyle(e,t){return Vt((()=>{const{config:o,numberOfCols:s,numberOfRows:i}=this.getTableRuntimeConfig(e,t),n=MF(o,this.getters.getTableStyle(t.config.styleId),s,i),r=this.getTableMapping(e,t),a={borders:{},styles:{}};for(let e=0;e<s;e++){const t=r.colMapping[e];a.borders[t]={},a.styles[t]={};for(let o=0;o<i;o++){const s=r.rowMapping[o];a.borders[t][s]=n.borders[e][o],a.styles[t][s]=n.styles[e][o]}}return a}))}getTableRuntimeConfig(e,t){const o=t.range.zone,s={...t.config};let i=o.right-o.left+1,n=o.bottom-o.top+1;for(let i=o.top;i<=o.bottom;i++)this.getters.isRowHidden(e,i)&&(n--,i-o.top<t.config.numberOfHeaders&&(s.numberOfHeaders--,s.numberOfHeaders<0&&(s.numberOfHeaders=0)),i===o.bottom&&(s.totalRow=!1));for(let t=o.left;t<=o.right;t++)this.getters.isColHidden(e,t)&&(i--,t===o.left&&(s.firstColumn=!1),t===o.right&&(s.lastColumn=!1));return{config:s,numberOfCols:i,numberOfRows:n}}getTableMapping(e,t){const o={},s={};let i=0,n=0;const r=t.range.zone;for(let t=r.left;t<=r.right;t++)if(!this.getters.isColHidden(e,t)){o[i]=t,i++;for(let t=r.top;t<=r.bottom;t++)this.getters.isRowHidden(e,t)||(s[n]=t,n++)}return{colMapping:o,rowMapping:s}}}).add("header_positions",class extends tu{static getters=["getColDimensions","getRowDimensions","getColRowOffset"];headerPositions={};isDirty=!0;handle(e){switch(l.has(e.type)&&(this.headerPositions={},this.isDirty=!0),e.type){case"START":for(const e of this.getters.getSheetIds())this.headerPositions[e]=this.computeHeaderPositionsOfSheet(e);break;case"UPDATE_CELL":case"UPDATE_FILTER":case"UPDATE_TABLE":case"REMOVE_TABLE":this.headerPositions={},this.isDirty=!0;break;case"REMOVE_COLUMNS_ROWS":case"RESIZE_COLUMNS_ROWS":case"HIDE_COLUMNS_ROWS":case"ADD_COLUMNS_ROWS":case"UNHIDE_COLUMNS_ROWS":case"FOLD_HEADER_GROUP":case"UNFOLD_HEADER_GROUP":case"FOLD_HEADER_GROUPS_IN_ZONE":case"UNFOLD_HEADER_GROUPS_IN_ZONE":case"UNFOLD_ALL_HEADER_GROUPS":case"FOLD_ALL_HEADER_GROUPS":case"UNGROUP_HEADERS":case"GROUP_HEADERS":case"CREATE_SHEET":this.getters.tryGetSheet(e.sheetId)&&(this.headerPositions[e.sheetId]=this.computeHeaderPositionsOfSheet(e.sheetId));break;case"DUPLICATE_SHEET":this.headerPositions[e.sheetIdTo]=pt(this.headerPositions[e.sheetId])}}finalize(){for(const e of this.getters.getSheetIds())!this.isDirty&&this.headerPositions[e]||(this.headerPositions[e]=this.computeHeaderPositionsOfSheet(e));this.isDirty=!1}getColDimensions(e,t){const o=this.headerPositions[e].COL[t],s=this.getters.getColSize(e,t);return{start:o,size:s,end:o+(this.getters.isColHidden(e,t)?0:s)}}getRowDimensions(e,t){const o=this.headerPositions[e].ROW[t],s=this.getters.getRowSize(e,t);return{start:o,size:s,end:o+(this.getters.isRowHidden(e,t)?0:s)}}getColRowOffset(e,t,o,s=this.getters.getActiveSheetId()){const i=this.headerPositions[s][e][t];return this.headerPositions[s][e][o]-i}computeHeaderPositionsOfSheet(e){return{COL:this.computePositions(e,"COL"),ROW:this.computePositions(e,"ROW")}}computePositions(e,t){const o={};let s=0;for(let i=0;i<this.getters.getNumberHeaders(e,t)+1;i++)o[i]=s,this.getters.isHeaderHidden(e,t,i)||(s+=this.getters.getHeaderSize(e,t,i));return o}}).add("viewport",class extends tu{static getters=["getColIndex","getRowIndex","getActiveMainViewport","getSheetViewDimension","getSheetViewDimensionWithHeaders","getMainViewportRect","isVisibleInViewport","getEdgeScrollCol","getEdgeScrollRow","getVisibleFigures","getVisibleRect","getVisibleRectWithoutHeaders","getVisibleCellPositions","getColRowOffsetInViewport","getMainViewportCoordinates","getActiveSheetScrollInfo","getSheetViewVisibleCols","getSheetViewVisibleRows","getFrozenSheetViewRatio","isPixelPositionVisible","getColDimensionsInViewport","getRowDimensionsInViewport","getAllActiveViewportsZonesAndRect","getRect","getFigureUI","getPositionAnchorOffset","getGridOffset"];viewports={};sheetViewWidth=tt();sheetViewHeight=tt();gridOffsetX=0;gridOffsetY=0;sheetsWithDirtyViewports=new Set;shouldAdjustViewports=!1;allowDispatch(e){switch(e.type){case"SET_VIEWPORT_OFFSET":return this.chainValidations(this.checkScrollingDirection,this.checkIfViewportsWillChange)(e);case"RESIZE_SHEETVIEW":return this.chainValidations(this.checkValuesAreDifferent,this.checkPositiveDimension)(e);default:return"Success"}}handleEvent(e){const t=this.getters.getActiveSheetId();if(e.options.scrollIntoView){let{col:o,row:s}=ls(e.previousAnchor.zone,e.anchor.zone);if("updateAnchor"===e.mode){const i=e.previousAnchor.zone,n=e.anchor.zone,{top:r,bottom:a,left:l,right:c}=this.getMainInternalViewport(t);i.left===n.left&&i.right===n.right&&(o=l>o||o>c?l:o),i.top===n.top&&i.bottom===n.bottom&&(s=r>s||s>a?r:s)}o=Math.min(o,this.getters.getNumberCols(t)-1),s=Math.min(s,this.getters.getNumberRows(t)-1),this.sheetsWithDirtyViewports.has(t)||this.refreshViewport(this.getters.getActiveSheetId(),{col:o,row:s})}}handle(e){if(l.has(e.type))for(const e of this.getters.getSheetIds())this.sheetsWithDirtyViewports.add(e);switch(e.type){case"START":this.selection.observe(this,{handleEvent:this.handleEvent.bind(this)}),this.resetViewports(this.getters.getActiveSheetId());break;case"UNDO":case"REDO":this.cleanViewports();for(const e of this.getters.getSheetIds())this.sheetsWithDirtyViewports.add(e);this.shouldAdjustViewports=!0;break;case"RESIZE_SHEETVIEW":this.resizeSheetView(e.height,e.width,e.gridOffsetX,e.gridOffsetY);break;case"SET_VIEWPORT_OFFSET":this.setSheetViewOffset(e.offsetX,e.offsetY);break;case"SHIFT_VIEWPORT_DOWN":const t=this.getters.getActiveSheetId(),{top:o,viewportHeight:s,offsetCorrectionY:i}=this.getMainInternalViewport(t),n=this.getters.getRowDimensions(t,o);this.shiftVertically(n.start+s-i);break;case"SHIFT_VIEWPORT_UP":{const e=this.getters.getActiveSheetId(),{top:t,viewportHeight:o,offsetCorrectionY:s}=this.getMainInternalViewport(e),i=this.getters.getRowDimensions(e,t);this.shiftVertically(i.end-s-o);break}case"REMOVE_TABLE":case"UPDATE_TABLE":case"UPDATE_FILTER":case"UNFREEZE_ROWS":case"UNFREEZE_COLUMNS":case"FREEZE_COLUMNS":case"FREEZE_ROWS":case"UNFREEZE_COLUMNS_ROWS":case"REMOVE_COLUMNS_ROWS":case"RESIZE_COLUMNS_ROWS":case"HIDE_COLUMNS_ROWS":case"ADD_COLUMNS_ROWS":case"UNHIDE_COLUMNS_ROWS":case"UNGROUP_HEADERS":case"GROUP_HEADERS":case"FOLD_HEADER_GROUP":case"UNFOLD_HEADER_GROUP":case"FOLD_HEADER_GROUPS_IN_ZONE":case"UNFOLD_HEADER_GROUPS_IN_ZONE":case"UNFOLD_ALL_HEADER_GROUPS":case"FOLD_ALL_HEADER_GROUPS":this.sheetsWithDirtyViewports.add(e.sheetId);break;case"UPDATE_CELL":if("content"in e||"format"in e||void 0!==e.style?.fontSize)for(const e of this.getters.getSheetIds())this.sheetsWithDirtyViewports.add(e);break;case"DELETE_SHEET":this.cleanViewports(),this.sheetsWithDirtyViewports.delete(e.sheetId);break;case"ACTIVATE_SHEET":this.sheetsWithDirtyViewports.add(e.sheetIdTo);break;case"SCROLL_TO_CELL":this.refreshViewport(this.getters.getActiveSheetId(),{col:e.col,row:e.row})}}finalize(){for(const e of this.sheetsWithDirtyViewports)if(this.resetViewports(e),this.shouldAdjustViewports){const t=this.getters.getSheetPosition(e);this.getSubViewports(e).forEach((e=>{e.adjustPosition(t)}))}this.sheetsWithDirtyViewports=new Set,this.shouldAdjustViewports=!1,this.setViewports()}setViewports(){const e=this.getters.getSheetIds();for(const t of e)this.viewports[t]?.bottomRight||this.resetViewports(t)}getColIndex(e){const t=this.getters.getActiveSheetId();return Math.max(...this.getSubViewports(t).map((t=>t.getColIndex(e))))}getRowIndex(e){const t=this.getters.getActiveSheetId();return Math.max(...this.getSubViewports(t).map((t=>t.getRowIndex(e))))}getSheetViewDimensionWithHeaders(){return{width:this.sheetViewWidth+this.gridOffsetX,height:this.sheetViewHeight+this.gridOffsetY}}getSheetViewDimension(){return{width:this.sheetViewWidth,height:this.sheetViewHeight}}getGridOffset(){return{x:this.gridOffsetX,y:this.gridOffsetY}}getActiveMainViewport(){const e=this.getters.getActiveSheetId();return this.getMainViewport(e)}getActiveSheetScrollInfo(){const e=this.getters.getActiveSheetId(),t=this.getMainInternalViewport(e);return{scrollX:t.offsetX,scrollY:t.offsetY}}getSheetViewVisibleCols(){const e=this.getters.getActiveSheetId(),t=this.getSubViewports(e);return[...new Set(t.map((e=>Ct(e.left,e.right+1))).flat())].filter((t=>t>=0&&!this.getters.isHeaderHidden(e,"COL",t)))}getSheetViewVisibleRows(){const e=this.getters.getActiveSheetId(),t=this.getSubViewports(e);return[...new Set(t.map((e=>Ct(e.top,e.bottom+1))).flat())].filter((t=>t>=0&&!this.getters.isHeaderHidden(e,"ROW",t)))}getVisibleCellPositions(){const e=this.getSheetViewVisibleCols(),t=this.getSheetViewVisibleRows(),o=this.getters.getActiveSheetId(),s=[];for(const i of e)for(const e of t){const t={sheetId:o,col:i,row:e},n=this.getters.getMainCellPosition(t);n.row===e&&n.col===i&&s.push(t)}return s}getMainViewportRect(){const e=this.getters.getActiveSheetId(),t=this.getMainInternalViewport(e),{xSplit:o,ySplit:s}=this.getters.getPaneDivisions(e),{width:i,height:n}=t.getMaxSize();return{x:this.getters.getColDimensions(e,o).start,y:this.getters.getRowDimensions(e,s).start,width:i,height:n}}getMaximumSheetOffset(){const e=this.getters.getActiveSheetId(),{width:t,height:o}=this.getMainViewportRect(),s=this.getMainInternalViewport(e);return{maxOffsetX:Math.max(0,t-s.viewportWidth),maxOffsetY:Math.max(0,o-s.viewportHeight)}}getColRowOffsetInViewport(e,t,o){if(o<t)return-this.getColRowOffsetInViewport(e,o,t);const s=this.getters.getActiveSheetId(),i="COL"===e?this.getters.getSheetViewVisibleCols():this.getters.getSheetViewVisibleRows(),n=i.findIndex((e=>t>=e));let r=i.findIndex((e=>o<=e));r=-1===r?i.length:r;const a=i.slice(n,r);let l=0;for(const t of a)l+=this.getters.getHeaderSize(s,e,t);return l}isVisibleInViewport({sheetId:e,col:t,row:o}){return this.getSubViewports(e).some((e=>e.isVisible(t,o)))}getEdgeScrollCol(e,t,o){let s=!1,i=0,n=0;const{xSplit:r}=this.getters.getPaneDivisions(this.getters.getActiveSheetId()),{width:a}=this.getSheetViewDimension(),{x:l}=this.getMainViewportCoordinates(),c=this.getActiveSheetScrollInfo().scrollX;return e>a?(s=!0,n=ma(e-a),i=1):e<l&&o>=l&&c>0?(s=!0,n=ma(l-e),i=-1):r&&t<l&&e>l&&(s=!0,n=ma(e),i="reset"),{canEdgeScroll:s,direction:i,delay:n}}getEdgeScrollRow(e,t,o){let s=!1,i=0,n=0;const{ySplit:r}=this.getters.getPaneDivisions(this.getters.getActiveSheetId()),{height:a}=this.getSheetViewDimension(),{y:l}=this.getMainViewportCoordinates(),c=this.getActiveSheetScrollInfo().scrollY;return e>a?(s=!0,n=ma(e-a),i=1):e<l&&o>=l&&c>0?(s=!0,n=ma(l-e),i=-1):r&&t<l&&e>l&&(s=!0,n=ma(e),i="reset"),{canEdgeScroll:s,direction:i,delay:n}}getVisibleRect(e){const t=this.getVisibleRectWithoutHeaders(e);return{...t,x:t.x+this.gridOffsetX,y:t.y+this.gridOffsetY}}getVisibleRectWithoutHeaders(e){const t=this.getters.getActiveSheetId();return this.mapViewportsToRect(t,(t=>t.getVisibleRect(e)))}getRect(e){const t=this.getters.getActiveSheetId(),o=this.mapViewportsToRect(t,(t=>t.getFullRect(e)));return{...o,x:o.x+this.gridOffsetX,y:o.y+this.gridOffsetY}}getRectWithoutHeaders(e){const t=this.getters.getActiveSheetId();return this.mapViewportsToRect(t,(t=>t.getFullRect(e)))}getMainViewportCoordinates(){const e=this.getters.getActiveSheetId(),{xSplit:t,ySplit:o}=this.getters.getPaneDivisions(e);return{x:this.getters.getColDimensions(e,t).start,y:this.getters.getRowDimensions(e,o).start}}getColDimensionsInViewport(e,t){const{top:o}=this.getMainInternalViewport(e),s={left:t,right:t,top:o,bottom:o},{x:i,width:n}=this.getVisibleRect(s),r=i-this.gridOffsetX;return{start:r,size:n,end:r+n}}getRowDimensionsInViewport(e,t){const{left:o}=this.getMainInternalViewport(e),s={left:0,right:o,top:t,bottom:t},{y:i,height:n}=this.getVisibleRect(s),r=i-this.gridOffsetY;return{start:r,size:n,end:r+n}}getAllActiveViewportsZonesAndRect(){const e=this.getters.getActiveSheetId();return this.getSubViewports(e).map((e=>({zone:e,rect:{x:e.offsetCorrectionX+this.gridOffsetX,y:e.offsetCorrectionY+this.gridOffsetY,...e.getMaxSize()}})))}ensureMainViewportExist(e){this.viewports[e]||this.resetViewports(e)}getSubViewports(e){return this.ensureMainViewportExist(e),Object.values(this.viewports[e]).filter(Mt)}checkPositiveDimension(e){return e.width<0||e.height<0?"InvalidViewportSize":"Success"}checkValuesAreDifferent(e){const{height:t,width:o}=this.getSheetViewDimension();return e.gridOffsetX===this.gridOffsetX&&e.gridOffsetY===this.gridOffsetY&&e.width===o&&e.height===t?"ValuesNotChanged":"Success"}checkScrollingDirection({offsetX:e,offsetY:t}){const o=this.getMainInternalViewport(this.getters.getActiveSheetId());return!o.canScrollHorizontally&&e>0||!o.canScrollVertically&&t>0?"InvalidScrollingDirection":"Success"}checkIfViewportsWillChange({offsetX:e,offsetY:t}){const o=this.getters.getActiveSheetId(),{maxOffsetX:s,maxOffsetY:i}=this.getMaximumSheetOffset();return this.getSubViewports(o).some((o=>o.willNewOffsetScrollViewport(St(e,0,s),St(t,0,i))))?"Success":"ViewportScrollLimitsReached"}getMainViewport(e){const t=this.getMainInternalViewport(e);return{top:t.top,left:t.left,bottom:t.bottom,right:t.right}}getMainInternalViewport(e){return this.ensureMainViewportExist(e),this.viewports[e].bottomRight}cleanViewports(){const e={};for(const t of this.getters.getSheetIds())e[t]=this.viewports[t];this.viewports=e}resizeSheetView(e,t,o=0,s=0){this.sheetViewHeight=e,this.sheetViewWidth=t,this.gridOffsetX=o,this.gridOffsetY=s,this.recomputeViewports()}recomputeViewports(){for(const e of this.getters.getSheetIds())this.resetViewports(e)}setSheetViewOffset(e,t){const o=this.getters.getActiveSheetId(),{maxOffsetX:s,maxOffsetY:i}=this.getMaximumSheetOffset();this.getSubViewports(o).forEach((o=>o.setViewportOffset(St(e,0,s),St(t,0,i))))}getViewportOffset(e){return{x:this.viewports[e]?.bottomRight.offsetX||0,y:this.viewports[e]?.bottomRight.offsetY||0}}resetViewports(e){if(!this.getters.tryGetSheet(e))return;const{xSplit:t,ySplit:o}=this.getters.getPaneDivisions(e),s=this.getters.getNumberCols(e),i=this.getters.getNumberRows(e),n=Math.min(this.getters.getColRowOffset("COL",0,t,e),this.sheetViewWidth),r=Math.min(this.getters.getColRowOffset("ROW",0,o,e),this.sheetViewHeight),a=Math.max(this.sheetViewWidth-n,0),l=Math.max(this.sheetViewHeight-r,0),{xRatio:c,yRatio:h}=this.getFrozenSheetViewRatio(e),d=c<1,u=h<1,g=this.getViewportOffset(e),p={topLeft:o&&t&&new iH(this.getters,e,{left:0,right:t-1,top:0,bottom:o-1},{width:n,height:r},{canScrollHorizontally:!1,canScrollVertically:!1},{x:0,y:0})||void 0,topRight:o&&new iH(this.getters,e,{left:t,right:s-1,top:0,bottom:o-1},{width:a,height:r},{canScrollHorizontally:d,canScrollVertically:!1},{x:d?g.x:0,y:0})||void 0,bottomLeft:t&&new iH(this.getters,e,{left:0,right:t-1,top:o,bottom:i-1},{width:n,height:l},{canScrollHorizontally:!1,canScrollVertically:u},{x:0,y:u?g.y:0})||void 0,bottomRight:new iH(this.getters,e,{left:t,right:s-1,top:o,bottom:i-1},{width:a,height:l},{canScrollHorizontally:d,canScrollVertically:u},{x:d?g.x:0,y:u?g.y:0})};this.viewports[e]=p}refreshViewport(e,t){this.getSubViewports(e).forEach((e=>{e.adjustViewportZone(),e.adjustPosition(t)}))}shiftVertically(e){const t=this.getters.getActiveSheetId(),{top:o}=this.getMainInternalViewport(t),{scrollX:s}=this.getActiveSheetScrollInfo();this.setSheetViewOffset(s,e);const{anchor:i}=this.getters.getSelection();if(i.cell.row>=this.getters.getPaneDivisions(t).ySplit){const e=this.getMainInternalViewport(t).top-o;this.selection.selectCell(i.cell.col,i.cell.row+e)}}getColIndexLeftOfMainViewport(e){if(e>=0)return-1;const t=this.getters.getActiveSheetId();let o=this.getActiveMainViewport().left,s=-this.getActiveSheetScrollInfo().scrollX-this.getters.getColRowOffset("COL",o,0);for(;e<s;o--)s-=this.getters.getColSize(t,o-1);return Math.max(o,0)}getRowIndexTopOfMainViewport(e){if(e>=0)return-1;const t=this.getters.getActiveSheetId();let o=this.getActiveMainViewport().top,s=-this.getActiveSheetScrollInfo().scrollY-this.getters.getColRowOffset("ROW",o,0);for(;e<s;o--)s-=this.getters.getRowSize(t,o-1);return Math.max(o,0)}getVisibleFigures(){const e=this.getters.getActiveSheetId(),t=[],o=this.getters.getFigures(e),{scrollX:s,scrollY:i}=this.getters.getActiveSheetScrollInfo(),{x:n,y:r}=this.getMainViewportCoordinates(),{width:a,height:l}=this.getters.getSheetViewDimensionWithHeaders();for(const c of o){const o=this.getFigureUI(e,c),{x:h,y:d}=o;h>=n&&(h+c.width<s+n||h>a+s+n)||(d>=r&&(d+c.height<i+r||d>l+i+r)||t.push(o))}return t}getFigureUI(e,t){const o=t.offset.x+this.getters.getColDimensions(e,t.col).start,s=t.offset.y+this.getters.getRowDimensions(e,t.row).start;return{...t,x:o,y:s}}getPositionAnchorOffset(e){const{scrollX:t,scrollY:o}=this.getters.getActiveSheetScrollInfo(),s=e.x-t,i=e.y-o,n=s>=0?this.getColIndex(s):this.getColIndexLeftOfMainViewport(s),r=i>=0?this.getRowIndex(i):this.getRowIndexTopOfMainViewport(i),{x:a,y:l}=this.getRect(cs({col:n,row:r}));return{col:n,row:r,offset:{x:Math.max(s-a+this.gridOffsetX,0),y:Math.max(i-l+this.gridOffsetY,0)}}}isPixelPositionVisible(e){const{scrollX:t,scrollY:o}=this.getters.getActiveSheetScrollInfo(),{x:s,y:i}=this.getters.getMainViewportCoordinates(),{width:n,height:r}=this.getters.getSheetViewDimension();return!(e.x>=s&&(e.x<s+t||e.x>n+t+s))&&!(e.y>=i&&(e.y<i+o||e.y>r+o+i))}getFrozenSheetViewRatio(e){const{xSplit:t,ySplit:o}=this.getters.getPaneDivisions(e),s=this.getters.getColDimensions(e,t).start,i=this.getters.getRowDimensions(e,o).start;return{xRatio:s/(this.sheetViewWidth+this.gridOffsetX),yRatio:i/(this.sheetViewHeight+this.gridOffsetY)}}mapViewportsToRect(e,t){let o=1/0,s=1/0,i=0,n=0,r=!1;for(const a of this.getSubViewports(e)){const e=t(a);e&&(r=!0,o=Math.min(o,e.x),s=Math.min(s,e.y),i=Math.max(i,e.x+e.width),n=Math.max(n,e.y+e.height))}return r?{x:o,y:s,width:i-o,height:n-s}:{x:0,y:0,width:0,height:0}}}).add("clipboard",class extends tu{static layers=["Clipboard"];static getters=["getClipboardTextAndImageContent","getClipboardId","getClipboardTextContent","isCutOperation"];status="invisible";originSheetId;copiedData;_isCutOperation=!1;clipboardId=(new Sl).uuidv4();fileStore;uuidGenerator;constructor(e){super(e),this.fileStore=e.external.fileStore,this.uuidGenerator=new Sl}allowDispatch(e){switch(e.type){case"CUT":const t=this.getters.getSelectedZones();return this.isCutAllowedOn(t);case"PASTE_FROM_OS_CLIPBOARD":{const t=this.convertTextToClipboardData(e.clipboardContent.text??""),o=e.pasteOption;return this.isPasteAllowed(e.target,t,{pasteOption:o,isCutOperation:!1})}case"PASTE":{if(!this.copiedData)return"EmptyClipboard";const t=e.pasteOption;return this.isPasteAllowed(e.target,this.copiedData,{pasteOption:t,isCutOperation:this._isCutOperation})}case"COPY_PASTE_CELLS_ABOVE":{const e=this.getters.getSelectedZones();if(e.length>1||0===e[0].top&&0===e[0].bottom)return"InvalidCopyPasteSelection";break}case"COPY_PASTE_CELLS_ON_LEFT":{const e=this.getters.getSelectedZones();if(e.length>1||0===e[0].left&&0===e[0].right)return"InvalidCopyPasteSelection";break}case"INSERT_CELL":{const{cut:t,paste:o}=this.getInsertCellsTargets(e.zone,e.shiftDimension),s=this.copy(t,"shiftCells");return this.isPasteAllowed(o,s,{isCutOperation:!0})}case"DELETE_CELL":{const{cut:t,paste:o}=this.getDeleteCellsTargets(e.zone,e.shiftDimension),s=this.copy(t,"shiftCells");return this.isPasteAllowed(o,s,{isCutOperation:!0})}}return"Success"}handle(e){switch(e.type){case"COPY":case"CUT":const t=this.getters.getSelectedZones();this.status="visible",this.originSheetId=this.getters.getActiveSheetId(),this._isCutOperation="CUT"===e.type,this.copiedData=this.copy(t);break;case"PASTE_FROM_OS_CLIPBOARD":{this._isCutOperation=!1;const t=e.clipboardContent.data;if(e.clipboardContent.imageData){const t=this.getters.getActiveSheetId(),o=this.uuidGenerator.uuidv4(),s=e.clipboardContent.imageData,i=uE(this.getters,s.size);this.dispatch("CREATE_IMAGE",{definition:s,size:i,col:e.target[0].left,row:e.target[0].top,offset:{x:0,y:0},sheetId:t,figureId:o})}this.copiedData=t||this.convertTextToClipboardData(e.clipboardContent.text??"");const o=e.pasteOption;this.paste(e.target,this.copiedData,{pasteOption:o,selectTarget:!0,isCutOperation:!1}),this.status="invisible",this.copiedData=void 0;break}case"PASTE":{const t=e.pasteOption;this.paste(e.target,this.copiedData,{pasteOption:t,selectTarget:!0,isCutOperation:this._isCutOperation}),this.status="invisible",this._isCutOperation&&(this.copiedData=void 0,this._isCutOperation=!1);break}case"COPY_PASTE_CELLS_ABOVE":{const e=this.getters.getSelectedZone(),t=e.top!==e.bottom,o={...e,bottom:t?e.top:e.top-1,top:t?e.top:e.top-1};this.originSheetId=this.getters.getActiveSheetId();const s=this.copy([o]);this.paste([e],s,{isCutOperation:!1,selectTarget:!0})}break;case"COPY_PASTE_CELLS_ON_LEFT":{const e=this.getters.getSelectedZone(),t=e.left!==e.right,o={...e,right:t?e.left:e.left-1,left:t?e.left:e.left-1};this.originSheetId=this.getters.getActiveSheetId();const s=this.copy([o]);this.paste([e],s,{isCutOperation:!1,selectTarget:!0})}break;case"CLEAN_CLIPBOARD_HIGHLIGHT":this.status="invisible";break;case"DELETE_CELL":{const{cut:t,paste:o}=this.getDeleteCellsTargets(e.zone,e.shiftDimension);if(!Bo(t[0])){this.dispatch("CLEAR_CELLS",{target:[e.zone],sheetId:this.getters.getActiveSheetId()});break}const s=this.copy(t,"shiftCells");this.paste(o,s,{isCutOperation:!0});break}case"INSERT_CELL":{const{cut:t,paste:o}=this.getInsertCellsTargets(e.zone,e.shiftDimension),s=this.copy(t,"shiftCells");this.paste(o,s,{isCutOperation:!0});break}case"ADD_COLUMNS_ROWS":if(this.status="invisible",!this._isCutOperation||e.sheetId!==this.copiedData?.sheetId)return;this.isColRowDirtyingClipboard("before"===e.position?e.base:e.base+1,e.dimension)&&(this.copiedData=void 0);break;case"REMOVE_COLUMNS_ROWS":if(this.status="invisible",!this._isCutOperation||e.sheetId!==this.copiedData?.sheetId)return;for(const t of e.elements){if(this.isColRowDirtyingClipboard(t,e.dimension)){this.copiedData=void 0;break}}this.status="invisible";break;case"REPEAT_PASTE":this.paste(e.target,this.copiedData,{isCutOperation:!1,pasteOption:e.pasteOption,selectTarget:!0});break;case"DELETE_SHEET":if(!this._isCutOperation)return;this.originSheetId===e.sheetId&&(this.copiedData=void 0,this.status="invisible");break;default:f(e)&&(this.status="invisible")}}convertTextToClipboardData(e){const t=this.selectClipboardHandlers({figureId:!0}).concat(this.selectClipboardHandlers({})),o={};for(const{handlerName:s,handler:i}of t){const t=i.convertTextToClipboardData(e);o[s]=t;const n=["sheetId","cells","zones","figureId"];for(const e of n)t&&e in t&&(o[e]=t[e])}return o}selectClipboardHandlers(e){const t="figureId"in e?yh.figureHandlers:yh.cellHandlers;return t.getKeys().map((e=>({handlerName:e,handler:new(t.get(e))(this.getters,this.dispatch)})))}isCutAllowedOn(e){const t=this.getClipboardData(e);for(const{handler:e}of this.selectClipboardHandlers(t)){const o=e.isCutAllowed(t);if("Success"!==o)return o}return"Success"}isPasteAllowed(e,t,o){for(const{handler:s}of this.selectClipboardHandlers(t)){const i=s.isPasteAllowed(this.getters.getActiveSheetId(),e,t,{...o});if("Success"!==i)return i}return"Success"}isColRowDirtyingClipboard(e,t){if(!this.copiedData||!this.copiedData.zones)return!1;const{zones:o}=this.copiedData;for(const s of o){if("COL"===t&&e<=s.right)return!0;if("ROW"===t&&e<=s.bottom)return!0}return!1}copy(e,t="copyPaste"){const o={},s=this.getClipboardData(e);for(const{handlerName:e,handler:i}of this.selectClipboardHandlers(s)){const n=i.copy(s,this._isCutOperation,t);o[e]=n;const r=["sheetId","cells","zones","figureId"];for(const e of r)n&&e in n&&(o[e]=n[e])}return o}paste(e,t,o){if(!t)return;const s=this.getters.getActiveSheetId(),i=this.selectClipboardHandlers(t),{target:n,zone:r,selectedZones:a}=ws(s,e,t,i,o);void 0!==r&&this.addMissingDimensions(s,r.right-r.left+1,r.bottom-r.top+1,r.left,r.top),Is(i,t,n,o),o?.selectTarget&&xs(this.selection,e,a)}addMissingDimensions(e,t,o,s,i){const n=o+i-this.getters.getNumberRows(e);n>0&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"ROW",base:this.getters.getNumberRows(e)-1,sheetId:e,sheetName:this.getters.getSheetName(e),quantity:n,position:"after"});const r=t+s-this.getters.getNumberCols(e);r>0&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"COL",base:this.getters.getNumberCols(e)-1,sheetId:e,sheetName:this.getters.getSheetName(e),quantity:r,position:"after"})}getClipboardTextContent(){return this.getPlainTextContent()}getClipboardId(){return this.clipboardId}async getClipboardTextAndImageContent(){const e=await this.getImageContent(),t=e?.type,o={[a.PlainText]:this.getPlainTextContent(),[a.Html]:await this.getHTMLContent()};return t&&e&&(o[t]=e),o}getSheetData(){const e={version:I_(),clipboardId:this.clipboardId};return this.copiedData&&"figureId"in this.copiedData?e:{...e,...this.copiedData}}getPlainTextContent(){return this.copiedData?.cells&&this.copiedData.cells.map((e=>e.map((e=>this.getters.shouldShowFormulas()&&e?.tokens?.length?e?.content||"":e.evaluatedCell?.formattedValue||"")).join("\t"))).join("\n")||"\t"}async getHTMLContent(){let e="";const t=this.copiedData?.cells;if(t)if(1===t.length&&1===t[0].length)e=`${this.getters.getCellText(t[0][0].position)}`;else{if(!t[0][0])return"";{let o='<table border="1" style="border-collapse:collapse">';for(const e of t){o+="<tr>";for(const t of e){if(!t)continue;o+=`<td style="${qh(Gh(this.getters.getCellComputedStyle(t.position)))}">`+fE(this.getters.getCellText(t.position))+"</td>"}o+="</tr>"}o+="</table>",e=o}}else if(this.copiedData?.figureId){const t=this.copiedData.figureId,o=this.getters.getFigureSheetId(t);e="image"===this.getters.getFigure(o,t).tag?await this.craftImageHTML(t):"\t"}else e="\t";return`<div data-osheet-clipboard='${fE(JSON.stringify(this.getSheetData()))}'>${e}</div>`}readFileAsDataURL(e){return new Promise((t=>{const o=new FileReader;o.onload=()=>t(o.result),o.readAsDataURL(e)}))}async craftImageHTML(e){if(!this.fileStore)return"\t";const t=this.getters.getImage(e).path,o=await(this.fileStore?.getFile(t))||null;if(o){return`<img src="${fE(await this.readFileAsDataURL(o))}" />`}return"\t"}async getImageContent(){const e=this.copiedData?.figureId;if(!e)return;const t=this.getters.getFigureSheetId(e);let o;if("image"===this.getters.getFigure(t,e).tag){if(!this.fileStore)return;const t=this.getters.getImage(e).path;if(o=await(this.fileStore?.getFile(t)),"image/png"!==o.type){if(o.size>oH)return void this.ui.notifyUI({text:ui("The file you are trying to copy is too large (>%sMB).\nIt will not be added to your OS clipboard.\nYou can download it directly instead.",Math.round(5)),sticky:!1,type:"warning"});o=await async function(e){return new Promise(((t,o)=>{const s=new Image;s.addEventListener("load",(()=>{const e=document.createElement("canvas");e.width=s.width,e.height=s.height;const o=e.getContext("2d");o?.drawImage(s,0,0),e.toBlob(t,"image/png")})),s.addEventListener("error",o),s.src=e}))}(t)}}return o?o instanceof File?o:new File([o],"image.png",{type:"image/png"}):void 0}isCutOperation(){return this._isCutOperation??!1}getDeleteCellsTargets(e,t){const o=this.getters.getActiveSheetId();let s;return s="COL"===t?{...e,left:e.right+1,right:this.getters.getNumberCols(o)-1}:{...e,top:e.bottom+1,bottom:this.getters.getNumberRows(o)-1},{cut:[s],paste:[e]}}getInsertCellsTargets(e,t){const o=this.getters.getActiveSheetId();let s,i;return"COL"===t?(s={...e,right:this.getters.getNumberCols(o)-1},i={...e,left:e.right+1,right:e.right+1}):(s={...e,bottom:this.getters.getNumberRows(o)-1},i={...e,top:e.bottom+1,bottom:this.getters.getNumberRows(o)-1}),{cut:[s],paste:[i]}}getClipboardData(e){const t=this.getters.getActiveSheetId(),o=this.getters.getSelectedFigureId();if(o)return{figureId:o,sheetId:t};const s=bs(t,e);return this._isCutOperation||(s.rowsIndexes=s.rowsIndexes.filter((e=>!this.getters.isRowFiltered(t,e)))),s}drawLayer(e){if("visible"!==this.status||!this.copiedData)return;const{sheetId:t,zones:o}=this.copiedData;if(t!==this.getters.getActiveSheetId()||!o||!o.length)return;const{ctx:s,thinLineWidth:i}=e;s.setLineDash([8,5]),s.strokeStyle=N,s.lineWidth=3.3*i;for(const e of o){const{x:t,y:o,width:i,height:n}=this.getters.getVisibleRect(e);i>0&&n>0&&s.strokeRect(t,o,i,n)}}}).add("carousel_ui",class extends tu{static getters=["getSelectedCarouselItem","getChartFromFigureId","getChartIdFromFigureId"];uuidGenerator=new Sl;carouselStates={};allowDispatch(e){switch(e.type){case"ADD_FIGURE_CHART_TO_CAROUSEL":return this.getters.doesCarouselExist(e.carouselFigureId)&&"chart"===this.getters.getFigure(e.sheetId,e.chartFigureId)?.tag?"Success":"InvalidFigureId";case"ADD_NEW_CHART_TO_CAROUSEL":return this.getters.doesCarouselExist(e.figureId)?"Success":"InvalidFigureId";case"UPDATE_CAROUSEL_ACTIVE_ITEM":return this.getters.doesCarouselExist(e.figureId)?this.getters.getCarousel(e.figureId).items.some((t=>zt(t,e.item)))?"Success":"InvalidCarouselItem":"InvalidFigureId"}return"Success"}handle(e){switch(e.type){case"ADD_NEW_CHART_TO_CAROUSEL":this.addNewChartToCarousel(e.figureId,e.sheetId);break;case"ADD_FIGURE_CHART_TO_CAROUSEL":this.addFigureChartToCarousel(e.carouselFigureId,e.chartFigureId,e.sheetId);break;case"UPDATE_CAROUSEL_ACTIVE_ITEM":this.carouselStates[e.figureId]=this.getCarouselItemId(e.item);break;case"POPOUT_CHART_FROM_CAROUSEL":this.popOutChartFromCarousel(e.carouselId,e.chartId,e.sheetId);break;case"DELETE_FIGURE":delete this.carouselStates[e.figureId];break;case"UPDATE_CAROUSEL":this.fixWrongCarouselState(e.figureId);break;case"DELETE_CHART":case"UNDO":case"REDO":case"DELETE_SHEET":for(const e in this.carouselStates)this.fixWrongCarouselState(e)}}popOutChartFromCarousel(e,t,o){const s=this.getters.getCarousel(e);if(!s)return;const i=this.getters.getFigure(o,e),n=this.getters.getChartDefinition(t);if(!n||!i)return;const r=this.getters.getFigureUI(o,i),a=this.getters.getPositionAnchorOffset({x:r.x+50,y:r.y+50}),l=this.uuidGenerator.smallUuid();this.dispatch("CREATE_CHART",{...a,chartId:this.uuidGenerator.smallUuid(),figureId:l,sheetId:o,size:{width:i.width,height:i.height},definition:{...n}});const c=s.items.filter((e=>"chart"!==e.type||e.chartId!==t));this.dispatch("UPDATE_CAROUSEL",{sheetId:o,figureId:e,definition:{...s,items:c}}),this.dispatch("SELECT_FIGURE",{figureId:l})}getSelectedCarouselItem(e){const t=this.getters.getCarousel(e);if(t.items.length)return this.carouselStates[e]?t.items.find((t=>this.getCarouselItemId(t)===this.carouselStates[e])):t.items[0]}getChartFromFigureId(e){if(!this.getters.getFigureSheetId(e))return;const t=this.getChartIdFromFigureId(e);return t?this.getters.getChart(t):void 0}getChartIdFromFigureId(e){const t=this.getters.getFigureSheetId(e);if(!t)return;const o=this.getters.getFigure(t,e);if(o&&("chart"===o.tag||"carousel"===o.tag)){if("carousel"===o.tag){const t=this.getSelectedCarouselItem(e);return"chart"===t?.type?t.chartId:void 0}return this.getters.getChartIds(t).find((t=>this.getters.getFigureIdFromChartId(t)===e))}}fixWrongCarouselState(e){if(!this.getters.doesCarouselExist(e))return void delete this.carouselStates[e];const t=this.getters.getCarousel(e);0===t.items.length?delete this.carouselStates[e]:this.carouselStates[e]&&t.items.some((t=>this.getCarouselItemId(t)===this.carouselStates[e]))||(this.carouselStates[e]=this.getCarouselItemId(t.items[0]))}addNewChartToCarousel(e,t){const o=this.getters.getCarousel(e),s=this.uuidGenerator.smallUuid();this.dispatch("CREATE_CHART",{chartId:s,figureId:e,sheetId:t,definition:FE});const i={...o,items:[...o.items,{type:"chart",chartId:s}]};this.dispatch("UPDATE_CAROUSEL",{sheetId:t,figureId:e,definition:i})}addFigureChartToCarousel(e,t,o){const s=this.getChartIdFromFigureId(t);if(!s)return;const i=this.getters.getCarousel(e),n={...i,items:[...i.items,{type:"chart",chartId:s}]};this.dispatch("UPDATE_CAROUSEL",{sheetId:o,figureId:e,definition:n}),this.dispatch("UPDATE_CHART",{sheetId:o,chartId:s,figureId:e,definition:this.getters.getChartDefinition(s)}),this.dispatch("DELETE_FIGURE",{sheetId:o,figureId:t})}getCarouselItemId(e){return"chart"===e.type?e.chartId:"carouselDataView"}}),lH=(new n).add("evaluation",class extends yV{static getters=["evaluateFormula","evaluateFormulaResult","evaluateCompiledFormula","getCorrespondingFormulaCell","getRangeFormattedValues","getRangeValues","getRangeFormats","getEvaluatedCell","getEvaluatedCells","getEvaluatedCellsInZone","getEvaluatedCellsPositions","getSpreadZone","getArrayFormulaSpreadingOn","isEmpty"];shouldRebuildDependenciesGraph=!0;evaluator;positionsToUpdate=[];constructor(e){super(e),this.evaluator=new oU(e.custom,this.getters)}beforeHandle(e){(l.has(e.type)||h.has(e.type))&&(this.shouldRebuildDependenciesGraph=!0)}handle(e){switch(e.type){case"UPDATE_CELL":if(!("content"in e)&&!("format"in e)||this.shouldRebuildDependenciesGraph)return;const t={sheetId:e.sheetId,row:e.row,col:e.col};this.positionsToUpdate.push(t),"content"in e&&this.evaluator.updateDependencies(t);break;case"EVALUATE_CELLS":if(e.cellIds)for(let t=0;t<e.cellIds.length;t++)this.positionsToUpdate.push(this.getters.getCellPosition(e.cellIds[t]));else this.evaluator.evaluateAllCells()}}finalize(){this.shouldRebuildDependenciesGraph?(this.evaluator.buildDependencyGraph(),this.evaluator.evaluateAllCells(),this.shouldRebuildDependenciesGraph=!1):this.positionsToUpdate.length&&this.evaluator.evaluateCells(this.positionsToUpdate),this.positionsToUpdate=[]}evaluateFormula(e,t){const o=this.evaluateFormulaResult(e,t);return E(o)?Un(o,(e=>e.value)):o.value}evaluateFormulaResult(e,t){return this.evaluator.evaluateFormulaResult(e,t)}evaluateCompiledFormula(e,t,o){return this.evaluator.evaluateCompiledFormula(e,t,o)}getRangeFormattedValues(e){return void 0===this.getters.tryGetSheet(e.sheetId)?[]:this.mapVisiblePositions(e,(e=>this.getters.getEvaluatedCell(e).formattedValue))}getRangeValues(e){return void 0===this.getters.tryGetSheet(e.sheetId)?[]:this.mapVisiblePositions(e,(e=>this.getters.getEvaluatedCell(e).value))}getRangeFormats(e){const t=this.getters.tryGetSheet(e.sheetId);return void 0===t?[]:this.getters.getEvaluatedCellsInZone(t.id,e.zone).map((e=>e.format))}getEvaluatedCell(e){return this.evaluator.getEvaluatedCell(e)}getEvaluatedCells(e){return this.evaluator.getEvaluatedPositionsInSheet(e).map((e=>this.getEvaluatedCell(e)))}getEvaluatedCellsPositions(e){return this.evaluator.getEvaluatedPositionsInSheet(e)}getEvaluatedCellsInZone(e,t){return is(t).map((({col:t,row:o})=>this.getters.getEvaluatedCell({sheetId:e,col:t,row:o})))}getSpreadZone(e,t={ignoreSpillError:!1}){return this.evaluator.getSpreadZone(e,t)}getArrayFormulaSpreadingOn(e){return this.evaluator.getArrayFormulaSpreadingOn(e)}isEmpty(e,t){return is(t).map((({col:t,row:o})=>this.getEvaluatedCell({sheetId:e,col:t,row:o}))).every((e=>e.type===r.empty))}mapVisiblePositions(e,t){const{sheetId:o,zone:s}=e;return is(s).reduce(((e,s)=>{const{col:i,row:n}=s;return this.getters.isColHidden(o,i)||this.getters.isRowHidden(o,n)||e.push(t({sheetId:o,...s})),e}),[])}exportForExcel(e){for(const t of e.sheets)t.cellValues={},t.formulaSpillRanges={};for(const t of this.evaluator.getEvaluatedPositions()){const o=this.evaluator.getEvaluatedCell(t),s=_o(t.col,t.row),i=o.value;let n,r=!1,a=!0;const l=e.sheets.find((e=>e.id===t.sheetId)),c=this.getCorrespondingFormulaCell(t);if(c){const h=this.getters.getCell(t);if(a=ZC(c.compiledFormula.tokens),r=a&&h?.content===c.content,!a&&""!==i){n=(i??"").toString();const t=o.format;if(t){const o=da(t,e.formats);l.formats[s]=o}}}const h=l.cells[s];let d;d=a&&r&&c instanceof pV?c.contentWithFixedReferences:a?h:n,l.cells[s]=d,l.cellValues[s]="error"!==o.type?i:void 0;const u=this.getSpreadZone(t);u&&(l.formulaSpillRanges[s]=this.getters.getRangeString(this.getters.getRangeFromZone(t.sheetId,u),t.sheetId))}}getCorrespondingFormulaCell(e){const t=this.getters.getCell(e);if(t&&t.isFormula)return t.compiledFormula.isBadExpression?void 0:t;if(t&&t.content)return;const o=this.getArrayFormulaSpreadingOn(e);if(void 0===o)return;const s=this.getters.getCell(o);return s?.isFormula?s:void 0}}).add("evaluation_chart",class extends yV{static getters=["getChartRuntime","getStyleOfSingleCellChart"];charts={};createRuntimeChart=aE(this.getters);handle(e){if(l.has(e.type)||d.has(e.type)||c.has(e.type))for(const e in this.charts)this.charts[e]=void 0;switch(e.type){case"UPDATE_CHART":case"CREATE_CHART":case"DELETE_CHART":this.charts[e.chartId]=void 0;break;case"DELETE_SHEET":for(const e in this.charts)this.getters.isChartDefined(e)||(this.charts[e]=void 0)}}getChartRuntime(e){if(!this.charts[e]){const t=this.getters.getChart(e);if(!t)throw new Error(`No chart for the given id: ${e}`);this.charts[e]=this.createRuntimeChart(t)}return this.charts[e]}getStyleOfSingleCellChart(e,t){if(e)return{background:e,fontColor:hy(e)};if(!t)return{background:k,fontColor:hy(k)};const o=t.zone.left,s=t.zone.top,i=t.sheetId,n=this.getters.getCellComputedStyle({sheetId:i,col:o,row:s}),r=n.fillColor||k;return{background:r,fontColor:n.textColor||hy(r)}}exportForExcel(e){for(const t of e.sheets){t.images||(t.images=[]);const e=this.getters.getFigures(t.id),o=[];for(const s of e){if(!s||"chart"!==s.tag)continue;const e=this.getters.getChartIds(t.id).find((e=>this.getters.getFigureIdFromChartId(e)===s.id));if(!e)continue;const i=this.getters.getChart(e),n=i?.getDefinitionForExcel(this.getters);if(n)o.push({...s,data:n});else{if(!i)continue;const o=this.getters.getChartType(e),n=YI(this.getters.getChartRuntime(e),s,o);n&&t.images.push({...s,tag:"image",data:{mimetype:"image/png",path:n,size:{width:s.width,height:s.height}}})}}t.charts=o}}}).add("evaluation_cf",class extends yV{static getters=["getConditionalIcon","getCellConditionalFormatStyle","getConditionalDataBar"];isStale=!0;computedStyles={};computedIcons={};computedDataBars={};handle(e){(l.has(e.type)||d.has(e.type)||"UPDATE_CELL"===e.type&&("content"in e||"format"in e))&&(this.isStale=!0)}finalize(){if(this.isStale){for(const e of this.getters.getSheetIds())this.computedStyles[e]=Vt((()=>this.getComputedStyles(e))),this.computedIcons[e]=Vt((()=>this.getComputedIcons(e))),this.computedDataBars[e]=Vt((()=>this.getComputedDataBars(e)));this.isStale=!1}}getCellConditionalFormatStyle(e){const{sheetId:t,col:o,row:s}=e,i=this.computedStyles[t]();return i&&i[o]?.[s]}getConditionalIcon({sheetId:e,col:t,row:o}){const s=this.computedIcons[e]();return s&&s[t]?.[o]}getConditionalDataBar({sheetId:e,col:t,row:o}){const s=this.computedDataBars[e]();return s&&s[t]?.[o]}getComputedStyles(e){const t={};for(const o of this.getters.getConditionalFormats(e).reverse())switch(o.rule.type){case"ColorScaleRule":for(const s of o.ranges)this.applyColorScale(e,s,o.rule,t);break;case"CellIsRule":const s=o.rule.values.map((e=>e.startsWith("=")?$C(e):void 0));for(const i of o.ranges){const n=this.getters.getRangeFromSheetXC(e,i).zone;for(let i=n.top;i<=n.bottom;i++)for(let r=n.left;r<=n.right;r++){const a={sheetId:e,col:r,row:i},l=o.rule.values.map(((t,o)=>{const a=s[o];return a?this.getters.getTranslatedCellFormula(e,r-n.left,i-n.top,a.tokens):t}));this.getRuleResultForTarget(a,{...o.rule,values:l})&&(t[r]||(t[r]=[]),t[r][i]=Object.assign(t[r]?.[i]||{},o.rule.style))}}}return t}getComputedIcons(e){const t={};for(const o of this.getters.getConditionalFormats(e).reverse())if("IconSetRule"===o.rule.type)for(const s of o.ranges)this.applyIcon(e,s,o.rule,t);return t}getComputedDataBars(e){const t={};for(const o of this.getters.getConditionalFormats(e).reverse())if("DataBarRule"===o.rule.type)for(const s of o.ranges)this.applyDataBar(e,s,o.rule,t);return t}parsePoint(e,t,o,s){const i=this.getters.getEvaluatedCellsInZone(e,this.getters.getRangeFromSheetXC(e,t).zone).filter((e=>e.type===r.number)).map((e=>e.value));switch(o.type){case"value":return"max"===s?no(i):ro(i);case"number":return Number(o.value);case"percentage":const t=ro(i);return t+(no(i)-t)*Number(o.value)/100;case"percentile":return on(i,Number(o.value)/100,!0);case"formula":const n=o.value&&this.getters.evaluateFormula(e,o.value);return"number"==typeof n?n:null;default:return null}}applyIcon(e,t,o,s){const i=this.parsePoint(e,t,o.lowerInflectionPoint),n=this.parsePoint(e,t,o.upperInflectionPoint);if(null===i||null===n||i>n)return;const a=this.getters.getRangeFromSheetXC(e,t).zone,l=[o.icons.upper,o.icons.middle,o.icons.lower];for(let t=a.top;t<=a.bottom;t++)for(let c=a.left;c<=a.right;c++){const a=this.getters.getEvaluatedCell({sheetId:e,col:c,row:t});if(a.type!==r.number)continue;const h=this.computeIcon(a.value,n,o.upperInflectionPoint.operator,i,o.lowerInflectionPoint.operator,l);s[c]||(s[c]=[]),s[c][t]=h}}computeIcon(e,t,o,s,i,n){return"ge"===o&&e>=t||"gt"===o&&e>t?n[0]:"ge"===i&&e>=s||"gt"===i&&e>s?n[1]:n[2]}applyDataBar(e,t,o,s){const i=this.getters.getRangeFromSheetXC(e,o.rangeValues||t),n=no(this.getters.getEvaluatedCellsInZone(e,i.zone).filter((e=>e.type===r.number)).map((e=>e.value)));if(n<=0)return;const a=o.color,l=this.getters.getRangeFromSheetXC(e,t).zone,c=i.zone;for(let t=l.top;t<=l.bottom;t++)for(let o=l.left;o<=l.right;o++){const i=o-l.left+c.left,h=t-l.top+c.top,d=this.getters.getEvaluatedCell({sheetId:e,col:i,row:h});!es(i,h,c)||d.type!==r.number||d.value<=0||(s[o]||(s[o]=[]),s[o][t]={color:As(a),percentage:100*d.value/n})}}applyColorScale(e,t,o,s){const i=this.parsePoint(e,t,o.minimum,"min"),n=o.midpoint?this.parsePoint(e,t,o.midpoint):null,a=this.parsePoint(e,t,o.maximum,"max");if(null===i||null===a||i>=a||n&&(i>=n||n>=a))return;const l=this.getters.getRangeFromSheetXC(e,t).zone,c=[{value:i,color:o.minimum.color}];o.midpoint&&n&&c.push({value:n,color:o.midpoint.color}),c.push({value:a,color:o.maximum.color});const h=ii(c);for(let t=l.top;t<=l.bottom;t++)for(let o=l.left;o<=l.right;o++){const n=this.getters.getEvaluatedCell({sheetId:e,col:o,row:t});if(n.type===r.number){const e=St(n.value,i,a);s[o]||(s[o]=[]),s[o][t]=s[o]?.[t]||{},s[o][t].fillColor=h(e)}}}getRuleResultForTarget(e,t){const o=this.getters.getEvaluatedCell(e);if(o.type===r.error)return!1;const{sheetId:s}=e,i=sR.get(t.operator),n=t.values.map((e=>e.startsWith("=")?this.getters.evaluateFormula(s,e)??"":ea(e,w)));if(n.some(bc))return!1;const a={type:t.operator,values:n.map(fc)};return i.isValueValid(o.value??"",a,this.getters,s)}}).add("row_size",class extends yV{static getters=["getRowSize","getHeaderSize","getMaxAnchorOffset"];tallestCellInRow={};ctx=document.createElement("canvas").getContext("2d");beforeHandle(e){if("ADD_COLUMNS_ROWS"===e.type){if("COL"===e.dimension)return;const t=Ht(e.position,e.base),o=Array(e.quantity).fill(void 0),s=eo(this.tallestCellInRow[e.sheetId],o,t);this.history.update("tallestCellInRow",e.sheetId,s)}}handle(e){switch(e.type){case"START":for(const e of this.getters.getSheetIds())this.initializeSheet(e);break;case"CREATE_SHEET":this.initializeSheet(e.sheetId);break;case"DUPLICATE_SHEET":{const t=pt(this.tallestCellInRow[e.sheetId]);this.history.update("tallestCellInRow",e.sheetIdTo,t);break}case"DELETE_SHEET":const t={...this.tallestCellInRow};delete t[e.sheetId],this.history.update("tallestCellInRow",t);break;case"REMOVE_COLUMNS_ROWS":{if("COL"===e.dimension)return;const t=Qt(this.tallestCellInRow[e.sheetId],e.elements);this.history.update("tallestCellInRow",e.sheetId,t);break}case"RESIZE_COLUMNS_ROWS":{const t=e.sheetId;if("ROW"===e.dimension)for(const o of e.elements){const e=this.getRowTallestCell(t,o);this.history.update("tallestCellInRow",t,o,e)}else for(const o of Ct(0,this.getters.getNumberRows(t)))for(const s of e.elements)this.updateRowSizeForCellChange(t,o,s)}break;case"UPDATE_CELL":this.updateRowSizeForCellChange(e.sheetId,e.row,e.col);break;case"ADD_MERGE":case"REMOVE_MERGE":for(const t of e.target)for(const o of is(t))this.updateRowSizeForCellChange(e.sheetId,o.row,o.col)}}getRowSize(e,t){return Math.round(this.getters.getUserRowSize(e,t)??this.tallestCellInRow[e][t]?.size??Ee)}getMaxAnchorOffset(e,t,o){let{numberOfRows:s,numberOfCols:i}=this.getters.getSheetSize(e),n=0;for(;n<t&&s>0;s--)n+=this.getRowSize(e,s-1);let r=0;for(;r<o&&i>0;i--)r+=this.getters.getColSize(e,i-1);return{col:i,row:s,offset:{x:r-o,y:n-t}}}getHeaderSize(e,t,o){return this.getters.isHeaderHidden(e,t,o)?0:"ROW"===t?this.getRowSize(e,o):this.getters.getColSize(e,o)}updateRowSizeForCellChange(e,t,o){const s=this.tallestCellInRow[e]?.[t];if(s?.cell.col===o){const o=this.getRowTallestCell(e,t);this.history.update("tallestCellInRow",e,t,o)}const i=this.getCellHeight({sheetId:e,col:o,row:t});if(!(i<=Ee)&&(!s&&i>Ee||s&&i>s.size)){const s={cell:{sheetId:e,col:o,row:t},size:i};this.history.update("tallestCellInRow",e,t,s)}}initializeSheet(e){const t=[];for(let o=0;o<this.getters.getNumberRows(e);o++){const s=this.getRowTallestCell(e,o);t.push(s)}this.history.update("tallestCellInRow",e,t)}getCellHeight(e){if(this.isInMultiRowMerge(e))return Ee;const t=this.getters.getCell(e),o=this.getters.getColSize(e.sheetId,e.col);return function(e,t,o){return t&&(t.isFormula||t.content)?ol(e,t.isFormula?"":t.content,t.style,o):Ee}(this.ctx,t,o)}isInMultiRowMerge(e){const t=this.getters.getMerge(e);return!!t&&t.bottom!==t.top}getRowTallestCell(e,t){if(void 0!==this.getters.getUserRowSize(e,t))return;const o=this.getters.getRowCells(e,t);let s,i=0;for(let e=0;e<o.length;e++){const t=this.getters.getCellById(o[e]);if(!t)continue;const n=this.getters.getCellPosition(t.id),r=this.getCellHeight(n);r>i&&r>Ee&&(i=r,s={cell:n,size:r})}return s&&s.size>Ee?s:void 0}}).add("data_validation_ui",class extends yV{static getters=["getDataValidationInvalidCriterionValueMessage","getInvalidDataValidationMessage","getValidationResultForCellValue","getDataValidationRangeValues","isCellValidCheckbox","getDataValidationCellStyle","getDataValidationChipStyle","isDataValidationInvalid"];validationResults={};handle(e){if(l.has(e.type)||"EVALUATE_CELLS"===e.type||"UPDATE_CELL"===e.type&&("content"in e||"format"in e))this.validationResults={};else switch(e.type){case"ADD_DATA_VALIDATION_RULE":case"REMOVE_DATA_VALIDATION_RULE":delete this.validationResults[e.sheetId]}}isDataValidationInvalid(e){return!this.getValidationResultForCell(e).isValid}getDataValidationCellStyle(e){if(!this.hasChip(e))return this.getDataValidationStyle(e)}getDataValidationChipStyle(e){if(this.hasChip(e))return this.getDataValidationStyle(e)??{fillColor:Q}}getInvalidDataValidationMessage(e){const t=this.getValidationResultForCell(e);return t.isValid?void 0:t.error}getDataValidationInvalidCriterionValueMessage(e,t){const o=sR.get(e);return t.startsWith("=")?"onlyLiterals"===o.allowedValues?ui("The value must not be a formula"):this.isValidFormula(t)?void 0:kb.CriterionError.validFormula:"onlyFormulas"===o.allowedValues?ui("The value must be a formula"):o.isCriterionValueValid(t)?void 0:o.criterionValueErrorString}getDataValidationRangeValues(e,t){const o=this.getters.getRangeFromSheetXC(e,String(t.values[0])),s=[],i=new Set;for(const e of is(o.zone)){const t=this.getters.getEvaluatedCell({...e,sheetId:o.sheetId});t.formattedValue&&!i.has(t.formattedValue)&&(i.add(t.formattedValue),s.push({label:t.formattedValue,value:t.value?.toString()||""}))}return s}isCellValidCheckbox(e){if(!this.getters.isMainCellPosition(e))return!1;const t=this.getters.getValidationRuleForCell(e);return!(!t||"isBoolean"!==t.criterion.type)&&this.getValidationResultForCell(e).isValid}getValidationResultForCellValue(e,t){const o=this.getters.getValidationRuleForCell(t);if(!o)return aU;const s=this.getRuleErrorForCellValue(e,t,o);return s?{error:s,rule:o,isValid:!1}:aU}hasChip(e){const t=this.getters.getValidationRuleForCell(e);return("isValueInList"===t?.criterion.type||"isValueInRange"===t?.criterion.type)&&"chip"===t.criterion.displayStyle}getDataValidationStyle(e){const t=this.getters.getValidationRuleForCell(e);if(!t||this.isDataValidationInvalid(e))return;const o=this.getters.getEvaluatedCell(e),s=this.getValueColor(t,o.value);if(!s)return;return{fillColor:s,textColor:Ws(s)}}getValueColor(e,t){if("isValueInList"===e.criterion.type||"isValueInRange"===e.criterion.type)for(const o in e.criterion.colors)if(o.toLowerCase()===String(t).toLowerCase())return e.criterion.colors[o]}isValidFormula(e){return!$C(e).isBadExpression}getValidationResultForCell(e){const{col:t,row:o,sheetId:s}=e;return this.validationResults[s]||(this.validationResults[s]=this.computeSheetValidationResults(s)),this.validationResults[s][t]?.[o]?.()||aU}computeSheetValidationResults(e){const t={},o=this.getters.getDataValidationRules(e).map((e=>e.ranges));for(const e of $a(o.flat())){const{col:o,row:s}=e;t[o]||(t[o]=[]),t[o][s]=Vt((()=>{const t=this.getters.getEvaluatedCell(e);return t.type===r.empty?aU:this.getValidationResultForCellValue(t.value,e)}))}return t}getRuleErrorForCellValue(e,t,o){const{sheetId:s}=t,i=o.criterion,n=sR.get(i.type),r=this.getCellOffsetInRule(t,o),a=this.getEvaluatedCriterionValues(s,r,i);if(a.some(bc))return;const l={...i,values:a.map(fc)};return n.isValueValid(e,l,this.getters,s)?void 0:n.getErrorString(l,this.getters,s)}getCellOffsetInRule(e,t){const o=t.ranges.find((t=>es(e.col,e.row,t.zone)));if(!o)throw new Error("The cell is not in any range of the rule");return{col:e.col-o.zone.left,row:e.row-o.zone.top}}getEvaluatedCriterionValues(e,t,o){return o.values.map((o=>{if(!o.startsWith("="))return ea(o,w);const s=$C(o),i=this.getters.getTranslatedCellFormula(e,t.col,t.row,s.tokens);return this.getters.evaluateFormula(e,i)}))}}).add("dynamic_tables",class extends yV{static getters=["canCreateDynamicTableOnZones","doesZonesContainFilter","getFilter","getFilters","getTable","getTables","getTablesOverlappingZones","getFilterId","getFilterHeaders","isFilterHeader"];tables={};handle(e){if(l.has(e.type)||"UPDATE_CELL"===e.type&&("content"in e||"format"in e)||"EVALUATE_CELLS"===e.type)this.tables={};else switch(e.type){case"CREATE_TABLE":case"REMOVE_TABLE":case"UPDATE_TABLE":case"DELETE_CONTENT":this.tables={}}}finalize(){for(const e of this.getters.getSheetIds())this.tables[e]||(this.tables[e]=this.computeTables(e))}computeTables(e){const t=[],o=this.getters.getCoreTables(e);for(const e of o)"dynamic"!==e.type&&t.push(e);const s=[...t];for(const i of o){if("dynamic"!==i.type)continue;const o=this.coreTableToTable(e,i);let n=o.range.zone;for(const e of s)Qo(n,e.range.zone)&&(n={...n,right:e.range.zone.left-1});t.push({...o,range:this.getters.getRangeFromZone(e,n)})}return t}getFilters(e){return this.getTables(e).filter((e=>e.config.hasFilters)).map((e=>e.filters)).flat()}getTables(e){return this.tables[e]||[]}getFilter(e){const t=this.getTable(e);if(t&&t.config.hasFilters)return t.filters.find((t=>t.col===e.col))}getFilterId(e){return this.getFilter(e)?.id}getTable({sheetId:e,col:t,row:o}){return this.getTables(e).find((e=>es(t,o,e.range.zone)))}getTablesOverlappingZones(e,t){return this.getTables(e).filter((e=>t.some((t=>Qo(e.range.zone,t)))))}doesZonesContainFilter(e,t){return this.getTablesOverlappingZones(e,t).some((e=>e.config.hasFilters))}getFilterHeaders(e){const t=[];for(const o of this.getTables(e)){if(!o.config.hasFilters)continue;const s=o.range.zone,i=s.top;for(let o=s.left;o<=s.right;o++)t.push({sheetId:e,col:o,row:i})}return t}isFilterHeader({sheetId:e,col:t,row:o}){return this.getFilterHeaders(e).some((e=>e.col===t&&e.row===o))}canCreateDynamicTableOnZones(e,t){if(!ms(t))return!1;const o=Yo(...t),s={col:o.left,row:o.top,sheetId:e},i=this.getters.getArrayFormulaSpreadingOn(s);if(!i){const e=this.getters.getEvaluatedCell(s);return e.value===sn.SpilledBlocked&&!e.errorOriginPosition}if(zt(i,s)&&1===gs(o))return!0;return zt(o,this.getters.getSpreadZone(i))}coreTableToTable(e,t){if("dynamic"!==t.type)return t;const o=t.range.zone,s={sheetId:e,col:o.left,row:o.top},i=this.getters.getSpreadZone(s)??t.range.zone,n=this.getters.getRangeFromZone(e,i),r=this.getDynamicTableFilters(e,t,i);return{id:t.id,range:n,filters:r,config:t.config}}getDynamicTableFilters(e,t,o){const s=[],{top:i,bottom:n,left:r,right:a}=o;for(let o=r;o<=a;o++){const a=o-r,l={left:o,right:o,top:i,bottom:n},c=OF(this.getDynamicTableFilterId(t.id,a),this.getters.getRangeFromZone(e,l),t.config,this.getters.getRangeFromZone);s.push(c)}return s}getDynamicTableFilterId(e,t){return e+"_"+t}exportForExcel(e){for(const t of e.sheets)for(const e of t.tables){const o=Ho(e.range),s={sheetId:t.id,col:o.left,row:o.top},i=this.getters.getCoreTable(s),n=this.getTable(s);"dynamic"===i?.type&&n&&(e.range=Go(n.range.zone))}}}).add("custom_colors",class extends yV{customColors={};shouldUpdateColors=!0;static getters=["getCustomColors"];constructor(e){super(e),this.tryToAddColors(e.customColors??[])}handle(e){switch(e.type){case"START":for(const e of this.getters.getSheetIds())for(const t of this.getters.getChartIds(e))this.tryToAddColors(this.getChartColors(t));break;case"UPDATE_CHART":case"CREATE_CHART":this.tryToAddColors(this.getChartColors(e.chartId));break;case"UPDATE_CELL":case"ADD_CONDITIONAL_FORMAT":case"SET_BORDER":case"SET_ZONE_BORDERS":case"SET_FORMATTING":case"CREATE_TABLE":case"UPDATE_TABLE":this.history.update("shouldUpdateColors",!0)}}finalize(){this.shouldUpdateColors&&(this.history.update("shouldUpdateColors",!1),this.tryToAddColors(this.computeCustomColors()))}getCustomColors(){return function(e){const t=[{leadColor:Ps(255,0,0),colors:[]},{leadColor:Ps(255,128,0),colors:[]},{leadColor:Ps(128,128,0),colors:[]},{leadColor:Ps(128,255,0),colors:[]},{leadColor:Ps(0,255,0),colors:[]},{leadColor:Ps(0,255,128),colors:[]},{leadColor:Ps(0,255,255),colors:[]},{leadColor:Ps(0,127,255),colors:[]},{leadColor:Ps(0,0,255),colors:[]},{leadColor:Ps(127,0,255),colors:[]},{leadColor:Ps(128,0,128),colors:[]},{leadColor:Ps(255,0,128),colors:[]}];for(const o of e.map(ks)){let e=500,s=0;t.forEach(((t,i)=>{const n=(r=o,a=t.leadColor,Math.sqrt(Math.pow(r.r-a.r,2)+Math.pow(r.g-a.g,2)+Math.pow(r.b-a.b,2)));var r,a;e>n&&(e=n,s=i)})),t[s].colors.push(o)}return t.map((e=>e.colors.sort(((e,t)=>Vs(e).s-Vs(t).s)))).flat().map(Ns)}(Object.keys(this.customColors))}computeCustomColors(){let e=[];for(const t of this.getters.getSheetIds())e=e.concat(this.getColorsFromCells(t),this.getFormattingColors(t),this.getTableColors(t));return[...new Set([...e])]}getColorsFromCells(e){const t=Object.values(this.getters.getCells(e)),o=new Set;for(const e of t)e.style?.textColor&&o.add(e.style.textColor),e.style?.fillColor&&o.add(e.style.fillColor);for(const t of this.getters.getBordersColors(e))o.add(t);return[...o]}getFormattingColors(e){const t=this.getters.getConditionalFormats(e),o=[];for(const e of t){const t=e.rule;"CellIsRule"===t.type?(o.push(t.style.textColor),o.push(t.style.fillColor)):"ColorScaleRule"===t.type&&(o.push(As(t.minimum.color)),o.push(t.midpoint?As(t.midpoint.color):void 0),o.push(As(t.maximum.color)))}return o.filter(Mt)}getChartColors(e){const t=this.getters.getChart(e);if(void 0===t)return[];return[...JSON.stringify(t.getDefinition()).matchAll(rU)].map((e=>e[1]))}getTableColors(e){return this.getters.getTables(e).flatMap((e=>{const t=e.config,o=this.getters.getTableStyle(t.styleId);return[this.getTableStyleElementColors(o.wholeTable),t.numberOfHeaders>0?this.getTableStyleElementColors(o.headerRow):[],t.totalRow?this.getTableStyleElementColors(o.totalRow):[],t.bandedColumns?this.getTableStyleElementColors(o.firstColumnStripe):[],t.bandedColumns?this.getTableStyleElementColors(o.secondColumnStripe):[],t.bandedRows?this.getTableStyleElementColors(o.firstRowStripe):[],t.bandedRows?this.getTableStyleElementColors(o.secondRowStripe):[],t.firstColumn?this.getTableStyleElementColors(o.firstColumn):[],t.lastColumn?this.getTableStyleElementColors(o.lastColumn):[]].flat()}))}getTableStyleElementColors(e){return e?[e.style?.fillColor,e.style?.textColor,e.border?.bottom?.color,e.border?.top?.color,e.border?.left?.color,e.border?.right?.color,e.border?.horizontal?.color,e.border?.vertical?.color].filter(Mt):[]}tryToAddColors(e){for(const t of e){if(!Fs(t))continue;const e=_s(t);t&&!ye.includes(e)&&this.history.update("customColors",e,!0)}}}).add("pivot_ui",class extends yV{static getters=["getPivot","getFirstPivotFunction","getPivotCellSortDirection","getPivotIdFromPosition","getPivotCellFromPosition","generateNewCalculatedMeasureName","isPivotUnused","isSpillPivotFormula"];pivots={};unusedPivots;custom;constructor(e){super(e),this.custom=e.custom}beforeHandle(e){if("START"===e.type)for(const e of this.getters.getPivotIds())this.setupPivot(e)}handle(e){if(l.has(e.type))for(const e of this.getters.getPivotIds())yP.get(this.getters.getPivotCoreDefinition(e).type).externalData||this.setupPivot(e,{recreate:!0});switch(e.type){case"REFRESH_PIVOT":this.refreshPivot(e.id);break;case"ADD_PIVOT":this.setupPivot(e.pivotId);break;case"DUPLICATE_PIVOT":this.setupPivot(e.newPivotId);break;case"UPDATE_PIVOT":this.setupPivot(e.pivotId,{recreate:!0});break;case"DELETE_SHEET":case"UPDATE_CELL":this.unusedPivots=void 0;break;case"UNDO":case"REDO":{this.unusedPivots=void 0;const t=e.commands.filter(gU);for(const e of t){const t=e.pivotId;this.getters.isExistingPivot(t)&&this.setupPivot(t,{recreate:!0})}break}case"UPDATE_LOCALE":!function(){for(const e in SP)SP[e].set.clear(),SP[e].values={}}()}}getPivotIdFromPosition(e){const t=this.getters.getCorrespondingFormulaCell(e);if(t&&t.isFormula){const o=this.getFirstPivotFunction(e.sheetId,t.compiledFormula.tokens);if(o){const e=o.args[0]?.toString();return e&&this.getters.getPivotId(e)}}}isSpillPivotFormula(e){const t=this.getters.getCorrespondingFormulaCell(e);if(t&&t.isFormula){const o=this.getFirstPivotFunction(e.sheetId,t.compiledFormula.tokens);return"PIVOT"===o?.functionName}return!1}getFirstPivotFunction(e,t){const o=kL(t);if(!o)return;const{functionName:s,args:i}=o;return{functionName:s,args:i.map((t=>{if("EMPTY"===t.type)return;if("STRING"===t.type||"BOOLEAN"===t.type||"NUMBER"===t.type)return t.value;const o=vN(t);return this.getters.evaluateFormula(e,o)}))}}getPivotCellFromPosition(e){const t=this.getters.getCorrespondingFormulaCell(e);if(!t||!t.isFormula||0===LL(t.compiledFormula.tokens))return hP;const o=this.getters.getCellPosition(t.id),s=this.getters.getFirstPivotFunction(e.sheetId,t.compiledFormula.tokens);if(!s)return hP;let{functionName:i,args:n}=s;const r=n[0];if(!r)return hP;const a=this.getters.getPivotId(r.toString());if(!a)return hP;const l=this.getPivot(a);if(!l.isValid())return hP;if("PIVOT"===i&&!t.content.replaceAll(" ","").toUpperCase().startsWith("=PIVOT"))return hP;if("PIVOT"===i){const t=fc(n[2]),s=void 0===t||An(t),i=fc(n[3]),r=fc(n[5]),a=void 0===r||An(r),c={displayColumnHeaders:void 0===i||An(i),displayTotals:s,displayMeasuresRow:a},h=l.getCollapsedTableStructure().getPivotCells(c),d=e.col-o.col,u=e.row-o.row;return h[d][u]}try{const t=e.row-o.row,s=e.col-o.col;if(n=n.map((e=>E(e)?e[s][t]:e)),"PIVOT.HEADER"===i&&"measure"===n.at(-2)){return{type:"MEASURE_HEADER",domain:l.parseArgsToPivotDomain(n.slice(1,-2).map((e=>({value:e})))),measure:n.at(-1)?.toString()||""}}if("PIVOT.HEADER"===i){const e=l.parseArgsToPivotDomain(n.slice(1).map((e=>({value:e}))));return{type:"HEADER",domain:e,dimension:jO(l,e).colDomain.length?"COL":"ROW"}}const[r,...a]=n.slice(1);return{type:"VALUE",domain:l.parseArgsToPivotDomain(a.map((e=>({value:e})))),measure:r?.toString()||""}}catch(e){return hP}}generateNewCalculatedMeasureName(e){const t=e.map((e=>e.fieldName));return ho(ui("Calculated measure 1"),t,{compute:(e,t)=>ui("Calculated measure %s",t)})}getPivot(e){if(!this.getters.isExistingPivot(e))throw new Error(`pivot ${e} not found`);return this.pivots[e]}isPivotUnused(e){return this._getUnusedPivots().includes(e)}getPivotCellSortDirection(e){const t=this.getters.getPivotIdFromPosition(e),o=this.getters.getPivotCellFromPosition(e);if("EMPTY"===o.type||"HEADER"===o.type||!t)return;const s=this.getters.getPivot(t),i=jO(s,o.domain).colDomain,n=s.definition.sortedColumn;return n?.measure===o.measure&&zt(n.domain,i)?n.order:"none"}refreshPivot(e){this.getters.getPivot(e).init({reload:!0})}setupPivot(e,{recreate:t}={recreate:!1}){const o=this.getters.getPivotCoreDefinition(e);if(e in this.pivots)t&&this.pivots[e].onDefinitionChange(o);else{const t=dU(yP.get(o.type).ui);this.pivots[e]=new t(this.custom,{definition:o,getters:this.getters})}}_getUnusedPivots(){if(void 0!==this.unusedPivots)return this.unusedPivots;const e=new Set(this.getters.getPivotIds());for(const t of this.getters.getSheetIds())for(const o in this.getters.getCells(t)){const t=this.getters.getCellPosition(o),s=this.getPivotIdFromPosition(t);if(s&&(e.delete(s),!e.size))return this.unusedPivots=[],[]}return this.unusedPivots=[...e],this.unusedPivots}}).add("cell_icon",class extends yV{static getters=["doesCellHaveGridIcon","getCellIcons","getCellIconRect"];cellIconsCache={};handle(e){"SET_VIEWPORT_OFFSET"!==e.type&&(this.cellIconsCache={})}getCellIcons(e){return this.cellIconsCache[e.sheetId]||(this.cellIconsCache[e.sheetId]={}),this.cellIconsCache[e.sheetId][e.col]||(this.cellIconsCache[e.sheetId][e.col]={}),this.cellIconsCache[e.sheetId][e.col][e.row]||(this.cellIconsCache[e.sheetId][e.col][e.row]=this.computeCellIcons(e)),this.cellIconsCache[e.sheetId][e.col][e.row]}getCellIconRect(e,t){const o=e.position,s=this.getters.getCell(o);return{x:this.getIconHorizontalPosition(t,e.horizontalAlign,e),y:this.getters.computeTextYCoordinate(t,e.size,s?.style?.verticalAlign),width:e.size,height:e.size}}getIconHorizontalPosition(e,t,o){const s=e.x,i=e.x+e.width;switch(t){case"right":return i-o.margin-o.size;case"left":return s+o.margin;default:const e=Math.floor((i-s-o.size)/2);return i-o.size-e}}computeCellIcons(e){const t={left:void 0,right:void 0,center:void 0},o=lU.getAll();for(const s of o){const o=s(this.getters,e);o&&(!t[o.horizontalAlign]||o.priority>t[o.horizontalAlign].priority)&&(t[o.horizontalAlign]=o)}if(t.center&&(t.left||t.right)){const e=Math.max(t.left?.priority||0,t.right?.priority||0);t.center.priority<e?t.center=void 0:(t.left=void 0,t.right=void 0)}return Object.values(t).filter(Mt)}doesCellHaveGridIcon(e){return Boolean(this.getCellIcons(e).length)}});Rd.add("dataValidation",{displayAllOnInitialContent:!0,canBeToggled:!1,getProposals(e,t){if(uo(t))return[];if(!this.composer.currentEditedCell)return[];const o=this.composer.currentEditedCell,s=this.getters.getValidationRuleForCell(o);if(!s||"isValueInList"!==s.criterion.type&&"isValueInRange"!==s.criterion.type)return[];const i=this.composer.currentEditedCell.sheetId,n="isValueInRange"===s.criterion.type?this.getters.getDataValidationRangeValues(i,s.criterion):s.criterion.values.map((e=>({label:e,value:e})));if(!("chip"===s.criterion.displayStyle))return n.map((e=>({text:e.value,fuzzySearchKey:e.label,htmlContent:[{value:e.label}]})));const r=s.criterion.colors;return n.map((e=>{const t=r?.[e.value];return{text:e.value,htmlContent:[{value:e.label,color:t?Ws(t):void 0,backgroundColor:t||Q,classes:["badge rounded-pill fs-6 fw-normal w-100 mt-1 text-start"]}],fuzzySearchKey:e.label}}))},selectProposal(e,t){this.composer.setCurrentContent(t),this.composer.stopEdition()}}),Rd.add("functions",{sequence:100,autoSelectFirstProposal:!0,maxDisplayedProposals:10,getProposals(e){if("SYMBOL"!==e.type)return[];const t=e.value;if(!uo(this.composer.currentContent))return[];const o=Object.entries(AC.content).filter((([e,{hidden:t}])=>!t)).map((([e,{description:o}])=>({text:e,description:o,htmlContent:xL(t,e,q,"o-semi-bold")}))).sort(((e,t)=>e.text.length-t.text.length||e.text.localeCompare(t.text)));return o},selectProposal(e,t){let o=e.end,s=e.end;["SYMBOL","FUNCTION"].includes(e.type)&&(o=e.start);const i=this.composer.currentTokens;t+="(";const n=i.map((e=>e.start)).indexOf(e.start);if(n+1<i.length){const e=i[n+1];"LEFT_PAREN"===e?.type&&s++}this.composer.changeComposerCursorSelection(o,s),this.composer.replaceComposerCursorSelection(t)}}),Rd.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:ht.NUMBER}],fuzzySearchKey:o+t.name,alwaysExpanded:!0}})).filter(Mt)},selectProposal:MC}),Rd.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=NL(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:ui("Count"),htmlContent:[{value:e,color:ht.STRING}],fuzzySearchKey:ui("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:ht.STRING}],fuzzySearchKey:o}}(e)})).filter(Mt):[]},selectProposal:MC}),Rd.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=NL(e),s=this.getters.getPivotId(o);if(!s||!this.getters.isExistingPivot(s))return;const i=this.getters.getPivot(s);i.init();const n=i.getFields(),{columns:r,rows:a}=i.definition;let l=t.args;"PIVOT.VALUE"===t?.parent.toUpperCase()?(l=l.filter(((e,t)=>t%2==0)),l=l.slice(1,t.argPosition)):l=l.filter(((e,t)=>t%2==1));const c=l.map((e=>e?.value)).filter(Mt),h=r.map((e=>e.nameWithGranularity)),d=a.map((e=>e.nameWithGranularity)),u=[];let g=["ARG_SEPARATOR","SPACE"].includes(e.type)?c.at(-1):c.at(-2);const p=cV.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(Mt);return m.map((e=>{const[t,o]=e.split(":"),s=n[t];return s?ML(s,o):void 0})).concat(m.map((e=>{if(!p)return;const t=e.split(":")[0],o=n[t];if(!o)return;const s=`"#${e}"`;return{text:s,description:ui("%s (positional)",o.string)+(o.help?` (${o.help})`:""),htmlContent:[{value:s,color:ht.STRING}],fuzzySearchKey:o.string+s}}))).filter(Mt)},selectProposal:MC}),Rd.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=NL(e),s=this.getters.getPivotId(o);if(!s||!this.getters.isExistingPivot(s))return;const i=this.getters.getPivot(s);if(!i.isValid())return;const n=t.argPosition,r=e.functionContext?.args[n-1]?.value;if(!r)return;let a;try{a=i.definition.getDimension(r)}catch(e){return}return"month_number"===a.granularity?Object.values(wr).map(((e,t)=>({text:`${t+1}`,fuzzySearchKey:e.toString(),description:e.toString(),htmlContent:[{value:`${t+1}`,color:ht.NUMBER}]}))):"quarter_number"===a.granularity?[1,2,3,4].map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:ui("Quarter %s",e),htmlContent:[{value:`${e}`,color:ht.NUMBER}]}))):"day_of_month"===a.granularity?Ct(1,32).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:ht.NUMBER}]}))):"iso_week_number"===a.granularity?Ct(0,54).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:ht.NUMBER}]}))):"day_of_week"===a.granularity?Ct(1,8).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:ht.NUMBER}]}))):"hour_number"===a.granularity?Ct(0,24).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:ht.NUMBER}]}))):"minute_number"===a.granularity?Ct(0,60).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:ht.NUMBER}]}))):"second_number"===a.granularity?Ct(0,60).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:ht.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?ht.STRING:ht.NUMBER}],fuzzySearchKey:s+i}}))},selectProposal:MC}),Rd.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=vt(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 cH=new n;cH.add("link",{condition:(e,t)=>!!t.getEvaluatedCell(e).link,execute:(e,t,o)=>Ci(t.model.getters.getEvaluatedCell(e).link,t,o),title:(e,t)=>{const o=t.getEvaluatedCell(e).link;return o?o.isExternal?ui("Go to url: %(url)s",{url:o.url}):ui("Go to %(label)s",{label:o.label}):""},sequence:5}),cH.add("dashboard_pivot_sorting",{condition:(e,t)=>{if(!t.isDashboard())return!1;const o=t.getPivotCellFromPosition(e);return FP(t,e)&&"MEASURE_HEADER"===o.type},execute:(e,t)=>{OP(t,e,function(e,t){return hH[e.getPivotCellSortDirection(t)??"none"]}(t.model.getters,e))},component:hV,componentProps:(e,t)=>({position:e,sortDirection:t.getPivotCellSortDirection(e)}),sequence:2});const hH={none:"asc",asc:"desc",desc:"none"};const dH=(new n).add("ADD_COLUMNS_ROWS",(function(e){const t=[];let o=e.base;"after"===e.position&&o++;for(let s=0;s<e.quantity;s++)t.push(s+o);return[{type:"REMOVE_COLUMNS_ROWS",dimension:e.dimension,elements:t,sheetId:e.sheetId,sheetName:e.sheetName}]})).add("REMOVE_COLUMNS_ROWS",(function(e){const t=[],o=[...e.elements].sort(((e,t)=>e-t));for(const s of yt(o)){const o=0===s[0]?0:s[0]-1,i=0===s[0]?"before":"after";t.push({type:"ADD_COLUMNS_ROWS",dimension:e.dimension,quantity:s.length,base:o,sheetId:e.sheetId,sheetName:e.sheetName,position:i})}return t})).add("ADD_MERGE",(function(e){return[{type:"REMOVE_MERGE",sheetId:e.sheetId,target:e.target}]})).add("REMOVE_MERGE",(function(e){return[{type:"ADD_MERGE",sheetId:e.sheetId,target:e.target}]})).add("CREATE_SHEET",(function(e){return[{type:"DELETE_SHEET",sheetId:e.sheetId,sheetName:e.name}]})).add("DELETE_SHEET",(function(e){return[{type:"CREATE_SHEET",sheetId:e.sheetId,position:1,name:e.sheetName}]})).add("DUPLICATE_SHEET",(function(e){return[{type:"DELETE_SHEET",sheetId:e.sheetIdTo,sheetName:""}]})).add("CREATE_FIGURE",(function(e){return[{type:"DELETE_FIGURE",figureId:e.figureId,sheetId:e.sheetId}]})).add("CREATE_CHART",(function(e){return[{type:"DELETE_FIGURE",figureId:e.figureId,sheetId:e.sheetId}]})).add("HIDE_COLUMNS_ROWS",(function(e){return[{type:"UNHIDE_COLUMNS_ROWS",sheetId:e.sheetId,dimension:e.dimension,elements:e.elements}]})).add("UNHIDE_COLUMNS_ROWS",(function(e){return[{type:"HIDE_COLUMNS_ROWS",sheetId:e.sheetId,dimension:e.dimension,elements:e.elements}]})).add("CREATE_TABLE_STYLE",(function(e){return[{type:"REMOVE_TABLE_STYLE",tableStyleId:e.tableStyleId}]})).add("ADD_PIVOT",(function(e){return[{type:"REMOVE_PIVOT",pivotId:e.pivotId}]})).add("RENAME_SHEET",(function(e){return[{type:"RENAME_SHEET",sheetId:e.sheetId,oldName:e.newName,newName:e.oldName}]}));for(const e of m.values())dH.contains(e)||dH.add(e,uH);function uH(e){return[e]}const gH=new n;gH.add("format_number_automatic",{...jP,id:"format_number_automatic",sequence:10}).add("format_number_plain_text",{...YP,id:"format_number_plain_text",sequence:15,separator:!0}).add("format_number_number",{...XP,id:"format_number_number",sequence:20}).add("format_number_percent",{...JP,id:"format_number_percent",sequence:30,separator:!0}).add("format_number_currency",{...QP,id:"format_number_currency",sequence:40}).add("format_number_accounting",{...tM,id:"format_number_accounting",sequence:45}).add("format_number_currency_rounded",{...eM,id:"format_number_currency_rounded",sequence:50}).add("format_custom_currency",{...sM,id:"format_custom_currency",sequence:60,separator:!0}).add("format_number_date",{...iM,id:"format_number_date",sequence:70}).add("format_number_time",{...nM,id:"format_number_time",sequence:80}).add("format_number_date_time",{...rM,id:"format_number_date_time",sequence:90}).add("format_number_duration",{...aM,id:"format_number_duration",sequence:100,separator:!0}).add("more_formats",{...hM,id:"more_formats",sequence:120});const pH=Jt((e=>Mr(e)?"date":e.includes("[$")?"currency":"number")),mH={name:ui("More formats"),icon:"o-spreadsheet-Icon.NUMBER_FORMATS",children:[e=>{const t=function(e){const t=new Set(gH.getAll().map((t=>"function"==typeof t.format?t.format(e):t.format))),o=new Map;for(const s of e.model.getters.getSheetIds()){const i=e.model.getters.getEvaluatedCells(s);for(const e in i){const s=i[e];if(s.format&&!o.has(s.format)&&!t.has(s.format)){const e=pH(s.format);"date"!==e&&"currency"!==e||o.set(s.format,ZP({descriptionValue:"currency"===e?1e3:oM,format:s.format,name:s.format}))}}}return[...o.values()]}(e).map((e=>({...e,sequence:110})));return t.length>0&&(t[t.length-1].separator=!0),o([...gH.getAll(),...t])}]};const fH=new CT;fH.add("file",{name:ui("File"),sequence:10,isReadonlyAllowed:!0}).addChild("settings",["file"],{name:ui("Settings"),sequence:200,execute:e=>e.openSidePanel("Settings"),isEnabled:e=>!e.isSmall,icon:"o-spreadsheet-Icon.COG"}).add("edit",{name:ui("Edit"),sequence:20,isReadonlyAllowed:!0}).addChild("undo",["edit"],{...BF,sequence:10}).addChild("redo",["edit"],{...$F,sequence:20,separator:!0}).addChild("copy",["edit"],{...GF,sequence:30}).addChild("cut",["edit"],{...WF,sequence:40}).addChild("paste",["edit"],{...qF,sequence:50}).addChild("paste_special",["edit"],{...ZF,sequence:60,separator:!0}).addChild("paste_special_value",["edit","paste_special"],{...jF,sequence:10}).addChild("paste_special_format",["edit","paste_special"],{...YF,sequence:20}).addChild("edit_table",["edit"],{...lO,isVisible:Y_,sequence:60}).addChild("find_and_replace",["edit"],{...XF,sequence:65,separator:!0}).addChild("delete",["edit"],{name:ui("Delete"),icon:"o-spreadsheet-Icon.TRASH",sequence:70}).addChild("edit_delete_cell_values",["edit","delete"],{...KF,sequence:10}).addChild("edit_delete_row",["edit","delete"],{...JF,sequence:20}).addChild("edit_delete_column",["edit","delete"],{...tO,sequence:30}).addChild("edit_delete_cell_shift_up",["edit","delete"],{...nO,sequence:40}).addChild("edit_delete_cell_shift_left",["edit","delete"],{...rO,sequence:50}).addChild("edit_unhide_columns",["edit"],{...rF,sequence:80}).addChild("edit_unhide_rows",["edit"],{...cF,sequence:80}).add("view",{name:ui("View"),sequence:30,isReadonlyAllowed:!0}).addChild("unfreeze_panes",["view"],{...hF,sequence:4}).addChild("freeze_panes",["view"],{...dF,sequence:5}).addChild("unfreeze_rows",["view","freeze_panes"],{...uF,sequence:5}).addChild("freeze_first_row",["view","freeze_panes"],{...gF,sequence:10}).addChild("freeze_second_row",["view","freeze_panes"],{...pF,sequence:15}).addChild("freeze_current_row",["view","freeze_panes"],{...mF,sequence:20,separator:!0}).addChild("unfreeze_columns",["view","freeze_panes"],{...fF,sequence:25}).addChild("freeze_first_col",["view","freeze_panes"],{...vF,sequence:30}).addChild("freeze_second_col",["view","freeze_panes"],{...bF,sequence:35}).addChild("freeze_current_col",["view","freeze_panes"],{...SF,sequence:40}).addChild("group_headers",["view"],{name:ui("Group"),sequence:15,separator:!0,icon:"o-spreadsheet-Icon.PLUS_IN_BOX",isVisible:K_}).addChild("group_columns",["view","group_headers"],{...wF,sequence:5}).addChild("ungroup_columns",["view","group_headers"],{...EF,isVisible:e=>DF(e,"COL"),sequence:10}).addChild("group_rows",["view","group_headers"],{...xF,sequence:15}).addChild("ungroup_rows",["view","group_headers"],{...RF,isVisible:e=>DF(e,"ROW"),sequence:20}).addChild("show",["view"],{name:ui("Show"),sequence:1,icon:"o-spreadsheet-Icon.SHOW"}).addChild("view_gridlines",["view","show"],{...CF,sequence:5}).addChild("view_formulas",["view","show"],{...IF,sequence:10}).addChild("view_irregularity_map",["view"],{...yF,sequence:40,separator:!0}).add("insert",{name:ui("Insert"),sequence:40,isReadonlyAllowed:!0}).addChild("insert_row",["insert"],{...uO,sequence:10}).addChild("insert_row_before",["insert","insert_row"],{...pO,sequence:10}).addChild("insert_row_after",["insert","insert_row"],{...vO,sequence:20}).addChild("insert_column",["insert"],{...bO,sequence:20}).addChild("insert_column_before",["insert","insert_column"],{...CO,sequence:10}).addChild("insert_column_after",["insert","insert_column"],{...wO,sequence:20}).addChild("insert_cell",["insert"],{...xO,sequence:30}).addChild("insert_cell_down",["insert","insert_cell"],{...EO,name:ui("Shift down"),sequence:10}).addChild("insert_cell_right",["insert","insert_cell"],{...RO,name:ui("Shift right"),sequence:20}).addChild("insert_sheet",["insert"],{...BO,sequence:40,separator:!0}).addChild("insert_chart",["insert"],{...TO,sequence:50}).addChild("insert_carousel",["insert"],{...AO,sequence:51}).addChild("insert_pivot",["insert"],{...DO,sequence:52}).addChild("insert_image",["insert"],{..._O,sequence:55}).addChild("insert_table",["insert"],{...FO,sequence:57}).addChild("insert_function",["insert"],{...OO,sequence:60}).addChild("insert_function_sum",["insert","insert_function"],{...PO,sequence:0}).addChild("insert_function_average",["insert","insert_function"],{...MO,sequence:10}).addChild("insert_function_count",["insert","insert_function"],{...NO,sequence:20}).addChild("insert_function_max",["insert","insert_function"],{...kO,sequence:30}).addChild("insert_function_min",["insert","insert_function"],{...LO,sequence:40,separator:!0}).addChild("categorie_function_all",["insert","insert_function"],{...VO,sequence:50}).addChild("categories_function_list",["insert","insert_function"],(()=>{const e=AC.content;return[...new Set(AC.getAll().filter((e=>!e.hidden)).map((e=>e.category)))].filter(Mt).sort().map(((t,o)=>{const s=Object.keys(e).filter((o=>e[o].category===t&&!e[o].hidden));return{name:t,children:$O(s)}}))})).addChild("insert_link",["insert"],{...UO,separator:!0,sequence:70}).addChild("insert_checkbox",["insert"],{...HO,sequence:80}).addChild("insert_dropdown",["insert"],{...zO,separator:!0,sequence:90}).add("format",{name:ui("Format"),sequence:50,isReadonlyAllowed:!0}).addChild("format_number",["format"],{...mH,name:ui("Number"),sequence:10,separator:!0}).addChild("format_bold",["format"],{...IM,sequence:20}).addChild("format_italic",["format"],{...wM,sequence:30}).addChild("format_underline",["format"],{...xM,sequence:40}).addChild("format_strikethrough",["format"],{...EM,sequence:50,separator:!0}).addChild("format_font_size",["format"],{...RM,sequence:60,separator:!0}).addChild("format_alignment",["format"],{...TM,sequence:70}).addChild("format_alignment_left",["format","format_alignment"],{...DM,sequence:10}).addChild("format_alignment_center",["format","format_alignment"],{..._M,sequence:20}).addChild("format_alignment_right",["format","format_alignment"],{...FM,sequence:30,separator:!0}).addChild("format_alignment_top",["format","format_alignment"],{...PM,sequence:40}).addChild("format_alignment_middle",["format","format_alignment"],{...MM,sequence:50}).addChild("format_alignment_bottom",["format","format_alignment"],{...NM,sequence:60,separator:!0}).addChild("format_wrapping",["format"],{...kM,sequence:80,separator:!0}).addChild("format_wrapping_overflow",["format","format_wrapping"],{...VM,sequence:10}).addChild("format_wrapping_wrap",["format","format_wrapping"],{...UM,sequence:20}).addChild("format_wrapping_clip",["format","format_wrapping"],{...HM,sequence:30}).addChild("format_cf",["format"],{...zM,sequence:90,separator:!0}).addChild("format_clearFormat",["format"],{...BM,sequence:100,separator:!0}).add("data",{name:ui("Data"),sequence:60,isReadonlyAllowed:!0}).addChild("sort_range",["data"],{...kP,sequence:10,separator:!0}).addChild("sort_ascending",["data","sort_range"],{...LP,sequence:10}).addChild("sort_descending",["data","sort_range"],{...zP,sequence:20}).addChild("data_cleanup",["data"],{...VP,sequence:15}).addChild("remove_duplicates",["data","data_cleanup"],{...UP,sequence:10}).addChild("trim_whitespace",["data","data_cleanup"],{...HP,sequence:20}).addChild("split_to_columns",["data"],{...GP,sequence:20}).addChild("data_validation",["data"],{name:ui("Data Validation"),execute:e=>{e.openSidePanel("DataValidation")},isEnabled:e=>!e.isSmall,icon:"o-spreadsheet-Icon.DATA_VALIDATION",sequence:30,separator:!0}).addChild("add_remove_data_filter",["data"],{...BP,sequence:40,separator:!0}).addChild("pivot_data_sources",["data"],(e=>{const t=e.model.getters.getPivotIds().length;return e.model.getters.getPivotIds().map(((o,s)=>{const i={get highlights(){return yL(e.model.getters,o)}};return{id:`item_pivot_${e.model.getters.getPivotFormulaId(o)}`,name:e.model.getters.getPivotDisplayName(o),sequence:50+s/t,isReadonlyAllowed:!0,execute:e=>e.openSidePanel("PivotSidePanel",{pivotId:o}),isEnabled:e=>!e.isSmall,onStartHover:e=>e.getStore(DR).register(i),onStopHover:e=>e.getStore(DR).unRegister(i),icon:"o-spreadsheet-Icon.PIVOT",separator:s===e.model.getters.getPivotIds().length-1,secondaryIcon:e=>e.model.getters.isPivotUnused(o)?"o-spreadsheet-Icon.UNUSED_PIVOT_WARNING":void 0}}))})).addChild("reinsert_dynamic_pivot",["data"],WP).addChild("reinsert_static_pivot",["data"],qP);const vH=new class extends n{mapping={};uuidGenerator=new Sl;replace(e,t){const o={...t,id:this.uuidGenerator.uuidv4()};return super.replace(e,o)}getAllOrdered(){return this.getAll().sort(((e,t)=>e.sequence-t.sequence))}};class bH{listeners=[];async sendMessage(e){for(const{callback:t}of this.listeners)t(e)}onNewMessage(e,t){this.listeners.push({id:e,callback:t})}leave(e){this.listeners=this.listeners.filter((t=>t.id!==e))}}class SH{fileStore;constructor(e){this.fileStore=e}async requestImage(){const e=await this.userImageUpload(),t=await this.fileStore.upload(e);return{path:t,size:await this.getImageOriginalSize(t),mimetype:e.type}}async uploadFile(e){const t=await this.fileStore.upload(e);return{path:t,size:await this.getImageOriginalSize(t),mimetype:e.type}}userImageUpload(){return new Promise(((e,t)=>{const o=document.createElement("input");o.setAttribute("type","file"),o.setAttribute("accept","image/*"),o.addEventListener("change",(async()=>{null===o.files||1!==o.files.length?t():e(o.files[0])})),o.click()}))}getImageOriginalSize(e){return new Promise(((t,o)=>{const s=new Image;s.addEventListener("load",(()=>{const e={width:s.width,height:s.height};t(e)})),s.addEventListener("error",o),s.src=e}))}}const CH=[{transform:"scale(0)"},{transform:"scale(0.8)",offset:.33},{opacity:"0",transform:"scale(1)",offset:1}];Bh`
1852
1852
  .o-ripple {
1853
1853
  z-index: 1;
1854
1854
  }
@@ -3364,4 +3364,4 @@
3364
3364
  <tableParts count="${e.tables.length}">
3365
3365
  ${yE(a)}
3366
3366
  </tableParts>
3367
- `}var mB;!function(e){e[e.Ready=0]="Ready",e[e.Running=1]="Running",e[e.RunningCore=2]="RunningCore",e[e.Finalizing=3]="Finalizing"}(mB||(mB={}));function fB(e,t={}){const o=pt(t);return o.type=e,o}const vB={},bB={MIN_ROW_HEIGHT:10,MIN_COL_WIDTH:5,HEADER_HEIGHT:Ie,HEADER_WIDTH:we,DESKTOP_BOTTOMBAR_HEIGHT:36,DEFAULT_CELL_WIDTH:xe,DEFAULT_CELL_HEIGHT:Ee,SCROLLBAR_WIDTH:Re},SB={autoCompleteProviders:Rd,autofillModifiersRegistry:pU,autofillRulesRegistry:mU,cellMenuRegistry:NP,colMenuRegistry:ZM,errorTypes:nn,linkMenuRegistry:yT,functionRegistry:AC,featurePluginRegistry:rH,iconsOnCellRegistry:lU,statefulUIPluginRegistry:aH,coreViewsPluginRegistry:lH,corePluginRegistry:nH,rowMenuRegistry:QM,sidePanelRegistry:eV,figureRegistry:ZE,chartSidePanelComponentRegistry:Kk,chartComponentRegistry:sE,chartRegistry:oE,chartSubtypeRegistry:nE,topbarMenuRegistry:fH,topbarComponentRegistry:vH,clickableCellRegistry:cH,otRegistry:xU,inverseCommandRegistry:dH,urlRegistry:mi,cellPopoverRegistry:XE,numberFormatMenuRegistry:gH,repeatLocalCommandTransformRegistry:JU,repeatCommandTransformRegistry:KU,clipboardHandlersRegistries:yh,pivotRegistry:yP,pivotTimeAdapterRegistry:Pc,pivotSidePanelRegistry:HL,pivotNormalizationValueRegistry:hh,supportedPivotPositionalFormulaRegistry:cV,pivotToFunctionValueRegistry:dh,migrationStepRegistry:C_,chartJsExtensionRegistry:Zh},CB={arg:Id,isEvaluationError:fn,toBoolean:An,toJsDate:Dn,toNumber:Sn,toString:En,toNormalizedPivotValue:rh,toFunctionPivotValue:lh,toXC:_o,toZone:Ho,toUnboundedZone:Uo,toCartesian:Do,numberToLetters:So,lettersToNumber:Co,UuidGenerator:Sl,formatValue:Rr,createCurrencyFormat:Hr,ColorGenerator:ti,computeTextWidth:nl,createEmptyWorkbookData:F_,createEmptySheet:__,createEmptyExcelSheet:O_,rgbaToHex:Ns,colorToRGBA:ks,positionToZone:cs,isDefined:Mt,isMatrix:E,lazy:Vt,genericRepeat:QU,createAction:i,createActions:o,transformRangeData:wh,deepEquals:zt,overlap:Qo,union:Yo,isInside:es,deepCopy:pt,expandZoneOnInsertion:Wo,reduceZoneOnDeletion:jo,unquote:ft,getMaxObjectId:Jc,getFunctionsFromTokens:jC,getFirstPivotFunction:kL,getNumberOfPivotFunctions:LL,parseDimension:th,isDateOrDatetimeField:oh,makeFieldProposal:ML,insertTokenAfterArgSeparator:function(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)},insertTokenAfterLeftParenthesis:function(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)},mergeContiguousZones:fs,getPivotHighlights:yL,pivotTimeAdapter:Mc,UNDO_REDO_PIVOT_COMMANDS:uU,createPivotFormula:nh,areDomainArgsFieldsValid:ih,splitReference:Ta,sanitizeSheetName:bt,getUniqueText:ho,isNumber:Qi,isDateTime:ki,createCustomFields:fh},yB={isMarkdownLink:Rt,parseMarkdownLink:Dt,markdownLink:At,openLink:Ci,urlRepresentation:Si},IB={Checkbox:nT,Section:GR,RoundColorPicker:WR,ChartDataSeries:hk,ChartErrorSection:dk,ChartLabelRange:uk,ChartTitle:fk,ChartPanel:eL,ChartFigure:WE,ChartJsComponent:Jy,ClickableCellSortIcon:hV,ZoomableChartJsComponent:Ex,Grid:lV,GridOverlay:LN,ScorecardChart:gI,GaugeChartComponent:Fx,LineConfigPanel:Lk,BarConfigPanel:pk,PieChartDesignPanel:Hk,GenericChartConfigPanel:gk,ChartWithAxisDesignPanel:Ek,GenericZoomableChartDesignPanel:Tk,LineChartDesignPanel:Vk,GaugeChartConfigPanel:_k,GaugeChartDesignPanel:Fk,ScorecardChartConfigPanel:Bk,ScorecardChartDesignPanel:$k,GeoChartDesignPanel:Nk,RadarChartDesignPanel:zk,WaterfallChartDesignPanel:Xk,ComboChartDesignPanel:Ak,FunnelChartDesignPanel:Dk,SunburstChartDesignPanel:Gk,TreeMapChartDesignPanel:Yk,ChartTypePicker:Jk,FigureComponent:jE,MenuPopover:BE,Popover:VE,SelectionInput:QR,ValidationMessages:DN,AddDimensionButton:EL,PivotDimensionGranularity:TL,PivotDimensionOrder:AL,PivotDimension:RL,PivotLayoutConfigurator:FL,PivotHTMLRenderer:uV,PivotDeferUpdate:IL,PivotTitleSection:OL,CogWheelMenu:lk,TextInput:sk,SidePanelCollapsible:tR,RadioSelection:bk,GeoChartRegionSelectSection:Ok,ChartDashboardMenu:$E,FullScreenFigure:dV},wB={useDragAndDropListItems:qR,useHighlights:sL,useHighlightsOnHover:oL},xB={useStoreProvider:Ah,DependencyContainer:Eh,CellPopoverStore:KE,ComposerFocusStore:Uh,CellComposerStore:yN,FindAndReplaceStore:mL,HighlightStore:DR,DelayedHoveredCellStore:YE,HoveredTableStore:MN,ModelStore:Mh,NotificationStore:_R,RendererStore:kh,SelectionInputStore:JR,SpreadsheetStore:Lh,useStore:Dh,useLocalStore:_h,SidePanelStore:iV,PivotSidePanelStore:VL,PivotMeasureDisplayPanelStore:SL,ClientFocusStore:tN,GridRenderer:WN};const EB={DEFAULT_LOCALE:w,HIGHLIGHT_COLOR:A,PIVOT_TABLE_CONFIG:it,ChartTerms:_b,FIGURE_ID_SPLITTER:$e,GRID_ICON_EDGE_LENGTH:17,GRID_ICON_MARGIN:2},RB={...hE,...bx};e.AbstractCellClipboardHandler=yl,e.AbstractChart=Qy,e.AbstractFigureClipboardHandler=Il,e.CellErrorType=sn,e.ClientDisconnectedError=VU,e.CorePlugin=gV,e.CoreViewPlugin=yV,e.DispatchResult=v,e.EvaluationError=rn,e.LocalTransportService=bH,e.Model=class extends xh{corePlugins=[];statefulUIPlugins=[];range;session;isReplayingCommand=!1;renderers={};status=0;config;corePluginConfig;coreViewPluginConfig;uiPluginConfig;state;selection;getters;coreGetters;uuidGenerator;handlers=[];uiHandlers=[];coreHandlers=[];constructor(e={},o={},s=[],i=new Sl,n=!1){const r=performance.now();console.debug("##### Model creation #####"),super(),ci===ai&&hi===li&&(hi=()=>!0),s=A_(e,s);const a=E_(e,n);this.state=new gz,this.uuidGenerator=i,this.config=this.setupConfig(o),this.session=this.setupSession(a.revisionId),this.coreGetters={},this.range=new SV(this.coreGetters),this.coreGetters.getRangeString=this.range.getRangeString.bind(this.range),this.coreGetters.getRangeFromSheetXC=this.range.getRangeFromSheetXC.bind(this.range),this.coreGetters.createAdaptedRanges=this.range.createAdaptedRanges.bind(this.range),this.coreGetters.getRangeData=this.range.getRangeData.bind(this.range),this.coreGetters.getRangeDataFromXc=this.range.getRangeDataFromXc.bind(this.range),this.coreGetters.getRangeDataFromZone=this.range.getRangeDataFromZone.bind(this.range),this.coreGetters.getRangeFromRangeData=this.range.getRangeFromRangeData.bind(this.range),this.coreGetters.getRangeFromZone=this.range.getRangeFromZone.bind(this.range),this.coreGetters.recomputeRanges=this.range.recomputeRanges.bind(this.range),this.coreGetters.isRangeValid=this.range.isRangeValid.bind(this.range),this.coreGetters.extendRange=this.range.extendRange.bind(this.range),this.coreGetters.getRangesUnion=this.range.getRangesUnion.bind(this.range),this.coreGetters.removeRangesSheetPrefix=this.range.removeRangesSheetPrefix.bind(this.range),this.coreGetters.adaptFormulaStringDependencies=this.range.adaptFormulaStringDependencies.bind(this.range),this.coreGetters.copyFormulaStringForSheet=this.range.copyFormulaStringForSheet.bind(this.range),this.getters={isReadonly:()=>"readonly"===this.config.mode||"dashboard"===this.config.mode,isDashboard:()=>"dashboard"===this.config.mode},this.selection=new dz(this.getters),this.coreHandlers.push(this.range),this.handlers.push(this.range),this.corePluginConfig=this.setupCorePluginConfig(),this.coreViewPluginConfig=this.setupCoreViewPluginConfig(),this.uiPluginConfig=this.setupUiPluginConfig();for(const e of nH.getAll())this.setupCorePlugin(e,a);Object.assign(this.getters,this.coreGetters),this.session.loadInitialMessages(s);for(const e of lH.getAll()){const t=this.setupCoreViewPlugin(e);this.handlers.push(t),this.uiHandlers.push(t),this.coreHandlers.push(t)}for(const e of aH.getAll()){const t=this.setupUiPlugin(e);this.statefulUIPlugins.push(t),this.handlers.push(t),this.uiHandlers.push(t)}for(const e of rH.getAll()){const t=this.setupUiPlugin(e);this.handlers.push(t),this.uiHandlers.push(t)}if(this.dispatch("START"),this.selection.observe(this,{handleEvent:()=>this.trigger("update")}),this.setupSessionEvents(),this.joinSession(),o.snapshotRequested||e["[Content_Types].xml"]&&!this.getters.isReadonly()){const e=performance.now();console.debug("Snapshot requested"),this.session.snapshot(this.exportData()),this.garbageCollectExternalResources(),console.debug("Snapshot taken in",performance.now()-e,"ms")}t.markRaw(this),console.debug("Model created in",performance.now()-r,"ms"),console.debug("######")}joinSession(){this.session.join(this.config.client)}async leaveSession(){const e=this.getters.isReadonly()?void 0:Vt((()=>this.exportData()));await this.session.leave(e)}setupUiPlugin(e){const t=new e(this.uiPluginConfig);for(const o of e.getters){if(!(o in t))throw new Error(`Invalid getter name: ${o} for plugin ${t.constructor}`);if(o in this.getters)throw new Error(`Getter "${o}" is already defined.`);this.getters[o]=t[o].bind(t)}for(const o of e.layers)this.renderers[o]||(this.renderers[o]=[]),this.renderers[o].push(t);return t}setupCoreViewPlugin(e){const t=new e(this.coreViewPluginConfig);for(const o of e.getters){if(!(o in t))throw new Error(`Invalid getter name: ${o} for plugin ${t.constructor}`);if(o in this.getters)throw new Error(`Getter "${o}" is already defined.`);this.getters[o]=t[o].bind(t)}return t}setupCorePlugin(e,t){const o=new e(this.corePluginConfig);for(const t of e.getters){if(!(t in o))throw new Error(`Invalid getter name: ${t} for plugin ${o.constructor}`);if(t in this.coreGetters)throw new Error(`Getter "${t}" is already defined.`);this.coreGetters[t]=o[t].bind(o)}o.import(t),this.corePlugins.push(o),this.coreHandlers.push(o),this.handlers.push(o)}onRemoteRevisionReceived({commands:e}){for(const t of e){const e=this.status;this.status=2,this.dispatchToHandlers(this.statefulUIPlugins,t),this.status=e}this.finalize()}setupSession(e){return new UU(lz({initialRevisionId:e,recordChanges:this.state.recordChanges.bind(this.state),dispatch:e=>{this.checkDispatchAllowed(e).isSuccessful?(this.isReplayingCommand=!0,this.dispatchToHandlers(this.coreHandlers,e),this.isReplayingCommand=!1):this.dispatchToHandlers(this.coreHandlers,{type:"UNDO",commands:[e]})}}),this.config.transportService,e)}setupSessionEvents(){this.session.on("remote-revision-received",this,this.onRemoteRevisionReceived),this.session.on("revision-undone",this,(({commands:e})=>{this.dispatchFromCorePlugin("UNDO",{commands:e}),this.finalize()})),this.session.on("revision-redone",this,(({commands:e})=>{this.dispatchFromCorePlugin("REDO",{commands:e}),this.finalize()})),this.session.on("unexpected-revision-id",this,(()=>this.trigger("unexpected-revision-id"))),this.session.on("collaborative-event-received",this,(()=>{this.trigger("update")}))}setupConfig(e){const t=e.client||{id:this.uuidGenerator.smallUuid(),name:ui("Anonymous").toString()},o=e.transportService||new bH,s="readonly"===e.mode||"dashboard"===e.mode;return{...e,mode:e.mode||"normal",custom:e.custom||{},external:this.setupExternalConfig(e.external||{}),transportService:s?new ez(o):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(I));return{...e,loadLocales:t}}setupCorePluginConfig(){return{getters:this.coreGetters,stateObserver:this.state,range:this.range,dispatch:this.dispatchFromCorePlugin,canDispatch:this.canDispatch,custom:this.config.custom,external:this.config.external}}setupCoreViewPluginConfig(){return{getters:this.getters,stateObserver:this.state,selection:this.selection,moveClient:this.session.move.bind(this.session),custom:this.config.custom,uiActions:this.config,session:this.session,defaultCurrency:this.config.defaultCurrency,customColors:this.config.customColors||[],external:this.config.external}}setupUiPluginConfig(){return{getters:this.getters,stateObserver:this.state,dispatch:this.dispatch,canDispatch:this.canDispatch,selection:this.selection,moveClient:this.session.move.bind(this.session),custom:this.config.custom,uiActions:this.config,session:this.session,defaultCurrency:this.config.defaultCurrency,customColors:this.config.customColors||[],external:this.config.external}}checkDispatchAllowed(e){const t=f(e)?this.checkDispatchAllowedCoreCommand(e):this.checkDispatchAllowedLocalCommand(e);return t.some((e=>"Success"!==e))?new v(t.flat()):v.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(fB(e,t));dispatch=(e,t)=>{const o=fB(e,t),s=this.status;if(this.getters.isReadonly()&&(i=o,!p.has(i.type)))return new v("Readonly");var i;if(!this.session.canApplyOptimisticUpdate())return new v("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();f(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(f(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(f(o))throw new Error(`A UI plugin cannot dispatch ${e} while handling a core command`);this.dispatchToHandlers(this.handlers,o)}return v.Success};dispatchFromCorePlugin=(e,t)=>{const o=fB(e,t),s=this.status;this.status=2;const i=this.isReplayingCommand?this.coreHandlers:this.handlers;return this.dispatchToHandlers(i,o),this.status=s,v.Success};dispatchToHandlers(e,t){const o=f(t);for(const s of e)!o&&s instanceof gV||s.beforeHandle(t);for(const s of e)!o&&s instanceof gV||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=F_();for(const t of this.handlers)t instanceof gV&&t.export(e);return e.revisionId=this.session.getRevisionId()||He,e=pt(e),e}updateMode(e){this.config.mode=e,this.trigger("update")}exportXLSX(){this.dispatch("EVALUATE_CELLS");let e={...F_(),sheets:[O_(x_,"Sheet1")]};for(const t of this.handlers)t instanceof eu&&t.exportForExcel(e);return e=pt(e),gB(e)}garbageCollectExternalResources(){for(const e of this.corePlugins)e.garbageCollectExternalResources()}},e.PivotRuntimeDefinition=aP,e.Registry=n,e.Revision=LU,e.SPREADSHEET_DIMENSIONS=bB,e.Spreadsheet=QH,e.SpreadsheetPivotTable=cP,e.UIPlugin=tu,e.__info__=vB,e.addFunction=function e(t,o){return AC.add(t,o),{addFunction:(t,o)=>e(t,o)}},e.addRenderingLayer=function(e,t){if(go[e])throw new Error(`Layer ${e} already exists`);go[e]=t},e.astToFormula=vN,e.chartHelpers=RB,e.compile=$C,e.compileTokens=GC,e.components=IB,e.constants=EB,e.convertAstNodes=Yv,e.coreTypes=m,e.findCellInNewZone=ls,e.functionCache=BC,e.getCaretDownSvg=eA,e.getCaretUpSvg=tA,e.helpers=CB,e.hooks=wB,e.invalidateCFEvaluationCommands=d,e.invalidateChartEvaluationCommands=c,e.invalidateDependenciesCommands=h,e.invalidateEvaluationCommands=l,e.iterateAstNodes=Xv,e.links=yB,e.load=E_,e.parse=Zv,e.parseTokens=jv,e.readonlyAllowedCommands=p,e.registries=SB,e.setDefaultSheetViewSize=function(e){et=e},e.setTranslationMethod=function(e,t=(()=>!0)){ci=e,hi=t},e.stores=xB,e.tokenColors=ht,e.tokenize=El,vB.version="19.0.9",vB.date="2025-11-03T12:32:15.473Z",vB.hash="10359f4"}(this.o_spreadsheet=this.o_spreadsheet||{},owl);
3367
+ `}var mB;!function(e){e[e.Ready=0]="Ready",e[e.Running=1]="Running",e[e.RunningCore=2]="RunningCore",e[e.Finalizing=3]="Finalizing"}(mB||(mB={}));function fB(e,t={}){const o=pt(t);return o.type=e,o}const vB={},bB={MIN_ROW_HEIGHT:10,MIN_COL_WIDTH:5,HEADER_HEIGHT:Ie,HEADER_WIDTH:we,DESKTOP_BOTTOMBAR_HEIGHT:36,DEFAULT_CELL_WIDTH:xe,DEFAULT_CELL_HEIGHT:Ee,SCROLLBAR_WIDTH:Re},SB={autoCompleteProviders:Rd,autofillModifiersRegistry:pU,autofillRulesRegistry:mU,cellMenuRegistry:NP,colMenuRegistry:ZM,errorTypes:nn,linkMenuRegistry:yT,functionRegistry:AC,featurePluginRegistry:rH,iconsOnCellRegistry:lU,statefulUIPluginRegistry:aH,coreViewsPluginRegistry:lH,corePluginRegistry:nH,rowMenuRegistry:QM,sidePanelRegistry:eV,figureRegistry:ZE,chartSidePanelComponentRegistry:Kk,chartComponentRegistry:sE,chartRegistry:oE,chartSubtypeRegistry:nE,topbarMenuRegistry:fH,topbarComponentRegistry:vH,clickableCellRegistry:cH,otRegistry:xU,inverseCommandRegistry:dH,urlRegistry:mi,cellPopoverRegistry:XE,numberFormatMenuRegistry:gH,repeatLocalCommandTransformRegistry:JU,repeatCommandTransformRegistry:KU,clipboardHandlersRegistries:yh,pivotRegistry:yP,pivotTimeAdapterRegistry:Pc,pivotSidePanelRegistry:HL,pivotNormalizationValueRegistry:hh,supportedPivotPositionalFormulaRegistry:cV,pivotToFunctionValueRegistry:dh,migrationStepRegistry:C_,chartJsExtensionRegistry:Zh},CB={arg:Id,isEvaluationError:fn,toBoolean:An,toJsDate:Dn,toNumber:Sn,toString:En,toNormalizedPivotValue:rh,toFunctionPivotValue:lh,toXC:_o,toZone:Ho,toUnboundedZone:Uo,toCartesian:Do,numberToLetters:So,lettersToNumber:Co,UuidGenerator:Sl,formatValue:Rr,createCurrencyFormat:Hr,ColorGenerator:ti,computeTextWidth:nl,createEmptyWorkbookData:F_,createEmptySheet:__,createEmptyExcelSheet:O_,rgbaToHex:Ns,colorToRGBA:ks,positionToZone:cs,isDefined:Mt,isMatrix:E,lazy:Vt,genericRepeat:QU,createAction:i,createActions:o,transformRangeData:wh,deepEquals:zt,overlap:Qo,union:Yo,isInside:es,deepCopy:pt,expandZoneOnInsertion:Wo,reduceZoneOnDeletion:jo,unquote:ft,getMaxObjectId:Jc,getFunctionsFromTokens:jC,getFirstPivotFunction:kL,getNumberOfPivotFunctions:LL,parseDimension:th,isDateOrDatetimeField:oh,makeFieldProposal:ML,insertTokenAfterArgSeparator:function(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)},insertTokenAfterLeftParenthesis:function(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)},mergeContiguousZones:fs,getPivotHighlights:yL,pivotTimeAdapter:Mc,UNDO_REDO_PIVOT_COMMANDS:uU,createPivotFormula:nh,areDomainArgsFieldsValid:ih,splitReference:Ta,sanitizeSheetName:bt,getUniqueText:ho,isNumber:Qi,isDateTime:ki,createCustomFields:fh},yB={isMarkdownLink:Rt,parseMarkdownLink:Dt,markdownLink:At,openLink:Ci,urlRepresentation:Si},IB={Checkbox:nT,Section:GR,RoundColorPicker:WR,ChartDataSeries:hk,ChartErrorSection:dk,ChartLabelRange:uk,ChartTitle:fk,ChartPanel:eL,ChartFigure:WE,ChartJsComponent:Jy,ClickableCellSortIcon:hV,ZoomableChartJsComponent:Ex,Grid:lV,GridOverlay:LN,ScorecardChart:gI,GaugeChartComponent:Fx,LineConfigPanel:Lk,BarConfigPanel:pk,PieChartDesignPanel:Hk,GenericChartConfigPanel:gk,ChartWithAxisDesignPanel:Ek,GenericZoomableChartDesignPanel:Tk,LineChartDesignPanel:Vk,GaugeChartConfigPanel:_k,GaugeChartDesignPanel:Fk,ScorecardChartConfigPanel:Bk,ScorecardChartDesignPanel:$k,GeoChartDesignPanel:Nk,RadarChartDesignPanel:zk,WaterfallChartDesignPanel:Xk,ComboChartDesignPanel:Ak,FunnelChartDesignPanel:Dk,SunburstChartDesignPanel:Gk,TreeMapChartDesignPanel:Yk,ChartTypePicker:Jk,FigureComponent:jE,MenuPopover:BE,Popover:VE,SelectionInput:QR,ValidationMessages:DN,AddDimensionButton:EL,PivotDimensionGranularity:TL,PivotDimensionOrder:AL,PivotDimension:RL,PivotLayoutConfigurator:FL,PivotHTMLRenderer:uV,PivotDeferUpdate:IL,PivotTitleSection:OL,CogWheelMenu:lk,TextInput:sk,SidePanelCollapsible:tR,RadioSelection:bk,GeoChartRegionSelectSection:Ok,ChartDashboardMenu:$E,FullScreenFigure:dV},wB={useDragAndDropListItems:qR,useHighlights:sL,useHighlightsOnHover:oL},xB={useStoreProvider:Ah,DependencyContainer:Eh,CellPopoverStore:KE,ComposerFocusStore:Uh,CellComposerStore:yN,FindAndReplaceStore:mL,HighlightStore:DR,DelayedHoveredCellStore:YE,HoveredTableStore:MN,ModelStore:Mh,NotificationStore:_R,RendererStore:kh,SelectionInputStore:JR,SpreadsheetStore:Lh,useStore:Dh,useLocalStore:_h,SidePanelStore:iV,PivotSidePanelStore:VL,PivotMeasureDisplayPanelStore:SL,ClientFocusStore:tN,GridRenderer:WN};const EB={DEFAULT_LOCALE:w,HIGHLIGHT_COLOR:A,PIVOT_TABLE_CONFIG:it,ChartTerms:_b,FIGURE_ID_SPLITTER:$e,GRID_ICON_EDGE_LENGTH:17,GRID_ICON_MARGIN:2},RB={...hE,...bx};e.AbstractCellClipboardHandler=yl,e.AbstractChart=Qy,e.AbstractFigureClipboardHandler=Il,e.CellErrorType=sn,e.ClientDisconnectedError=VU,e.CorePlugin=gV,e.CoreViewPlugin=yV,e.DispatchResult=v,e.EvaluationError=rn,e.LocalTransportService=bH,e.Model=class extends xh{corePlugins=[];statefulUIPlugins=[];range;session;isReplayingCommand=!1;renderers={};status=0;config;corePluginConfig;coreViewPluginConfig;uiPluginConfig;state;selection;getters;coreGetters;uuidGenerator;handlers=[];uiHandlers=[];coreHandlers=[];constructor(e={},o={},s=[],i=new Sl,n=!1){const r=performance.now();console.debug("##### Model creation #####"),super(),ci===ai&&hi===li&&(hi=()=>!0),s=A_(e,s);const a=E_(e,n);this.state=new gz,this.uuidGenerator=i,this.config=this.setupConfig(o),this.session=this.setupSession(a.revisionId),this.coreGetters={},this.range=new SV(this.coreGetters),this.coreGetters.getRangeString=this.range.getRangeString.bind(this.range),this.coreGetters.getRangeFromSheetXC=this.range.getRangeFromSheetXC.bind(this.range),this.coreGetters.createAdaptedRanges=this.range.createAdaptedRanges.bind(this.range),this.coreGetters.getRangeData=this.range.getRangeData.bind(this.range),this.coreGetters.getRangeDataFromXc=this.range.getRangeDataFromXc.bind(this.range),this.coreGetters.getRangeDataFromZone=this.range.getRangeDataFromZone.bind(this.range),this.coreGetters.getRangeFromRangeData=this.range.getRangeFromRangeData.bind(this.range),this.coreGetters.getRangeFromZone=this.range.getRangeFromZone.bind(this.range),this.coreGetters.recomputeRanges=this.range.recomputeRanges.bind(this.range),this.coreGetters.isRangeValid=this.range.isRangeValid.bind(this.range),this.coreGetters.extendRange=this.range.extendRange.bind(this.range),this.coreGetters.getRangesUnion=this.range.getRangesUnion.bind(this.range),this.coreGetters.removeRangesSheetPrefix=this.range.removeRangesSheetPrefix.bind(this.range),this.coreGetters.adaptFormulaStringDependencies=this.range.adaptFormulaStringDependencies.bind(this.range),this.coreGetters.copyFormulaStringForSheet=this.range.copyFormulaStringForSheet.bind(this.range),this.getters={isReadonly:()=>"readonly"===this.config.mode||"dashboard"===this.config.mode,isDashboard:()=>"dashboard"===this.config.mode},this.selection=new dz(this.getters),this.coreHandlers.push(this.range),this.handlers.push(this.range),this.corePluginConfig=this.setupCorePluginConfig(),this.coreViewPluginConfig=this.setupCoreViewPluginConfig(),this.uiPluginConfig=this.setupUiPluginConfig();for(const e of nH.getAll())this.setupCorePlugin(e,a);Object.assign(this.getters,this.coreGetters),this.session.loadInitialMessages(s);for(const e of lH.getAll()){const t=this.setupCoreViewPlugin(e);this.handlers.push(t),this.uiHandlers.push(t),this.coreHandlers.push(t)}for(const e of aH.getAll()){const t=this.setupUiPlugin(e);this.statefulUIPlugins.push(t),this.handlers.push(t),this.uiHandlers.push(t)}for(const e of rH.getAll()){const t=this.setupUiPlugin(e);this.handlers.push(t),this.uiHandlers.push(t)}if(this.dispatch("START"),this.selection.observe(this,{handleEvent:()=>this.trigger("update")}),this.setupSessionEvents(),this.joinSession(),o.snapshotRequested||e["[Content_Types].xml"]&&!this.getters.isReadonly()){const e=performance.now();console.debug("Snapshot requested"),this.session.snapshot(this.exportData()),this.garbageCollectExternalResources(),console.debug("Snapshot taken in",performance.now()-e,"ms")}t.markRaw(this),console.debug("Model created in",performance.now()-r,"ms"),console.debug("######")}joinSession(){this.session.join(this.config.client)}async leaveSession(){const e=this.getters.isReadonly()?void 0:Vt((()=>this.exportData()));await this.session.leave(e)}setupUiPlugin(e){const t=new e(this.uiPluginConfig);for(const o of e.getters){if(!(o in t))throw new Error(`Invalid getter name: ${o} for plugin ${t.constructor}`);if(o in this.getters)throw new Error(`Getter "${o}" is already defined.`);this.getters[o]=t[o].bind(t)}for(const o of e.layers)this.renderers[o]||(this.renderers[o]=[]),this.renderers[o].push(t);return t}setupCoreViewPlugin(e){const t=new e(this.coreViewPluginConfig);for(const o of e.getters){if(!(o in t))throw new Error(`Invalid getter name: ${o} for plugin ${t.constructor}`);if(o in this.getters)throw new Error(`Getter "${o}" is already defined.`);this.getters[o]=t[o].bind(t)}return t}setupCorePlugin(e,t){const o=new e(this.corePluginConfig);for(const t of e.getters){if(!(t in o))throw new Error(`Invalid getter name: ${t} for plugin ${o.constructor}`);if(t in this.coreGetters)throw new Error(`Getter "${t}" is already defined.`);this.coreGetters[t]=o[t].bind(o)}o.import(t),this.corePlugins.push(o),this.coreHandlers.push(o),this.handlers.push(o)}onRemoteRevisionReceived({commands:e}){for(const t of e){const e=this.status;this.status=2,this.dispatchToHandlers(this.statefulUIPlugins,t),this.status=e}this.finalize()}setupSession(e){return new UU(lz({initialRevisionId:e,recordChanges:this.state.recordChanges.bind(this.state),dispatch:e=>{this.checkDispatchAllowed(e).isSuccessful?(this.isReplayingCommand=!0,this.dispatchToHandlers(this.coreHandlers,e),this.isReplayingCommand=!1):this.dispatchToHandlers(this.coreHandlers,{type:"UNDO",commands:[e]})}}),this.config.transportService,e)}setupSessionEvents(){this.session.on("remote-revision-received",this,this.onRemoteRevisionReceived),this.session.on("revision-undone",this,(({commands:e})=>{this.dispatchFromCorePlugin("UNDO",{commands:e}),this.finalize()})),this.session.on("revision-redone",this,(({commands:e})=>{this.dispatchFromCorePlugin("REDO",{commands:e}),this.finalize()})),this.session.on("unexpected-revision-id",this,(()=>this.trigger("unexpected-revision-id"))),this.session.on("collaborative-event-received",this,(()=>{this.trigger("update")}))}setupConfig(e){const t=e.client||{id:this.uuidGenerator.smallUuid(),name:ui("Anonymous").toString()},o=e.transportService||new bH,s="readonly"===e.mode||"dashboard"===e.mode;return{...e,mode:e.mode||"normal",custom:e.custom||{},external:this.setupExternalConfig(e.external||{}),transportService:s?new ez(o):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(I));return{...e,loadLocales:t}}setupCorePluginConfig(){return{getters:this.coreGetters,stateObserver:this.state,range:this.range,dispatch:this.dispatchFromCorePlugin,canDispatch:this.canDispatch,custom:this.config.custom,external:this.config.external}}setupCoreViewPluginConfig(){return{getters:this.getters,stateObserver:this.state,selection:this.selection,moveClient:this.session.move.bind(this.session),custom:this.config.custom,uiActions:this.config,session:this.session,defaultCurrency:this.config.defaultCurrency,customColors:this.config.customColors||[],external:this.config.external}}setupUiPluginConfig(){return{getters:this.getters,stateObserver:this.state,dispatch:this.dispatch,canDispatch:this.canDispatch,selection:this.selection,moveClient:this.session.move.bind(this.session),custom:this.config.custom,uiActions:this.config,session:this.session,defaultCurrency:this.config.defaultCurrency,customColors:this.config.customColors||[],external:this.config.external}}checkDispatchAllowed(e){const t=f(e)?this.checkDispatchAllowedCoreCommand(e):this.checkDispatchAllowedLocalCommand(e);return t.some((e=>"Success"!==e))?new v(t.flat()):v.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(fB(e,t));dispatch=(e,t)=>{const o=fB(e,t),s=this.status;if(this.getters.isReadonly()&&(i=o,!p.has(i.type)))return new v("Readonly");var i;if(!this.session.canApplyOptimisticUpdate())return new v("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();f(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(f(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(f(o))throw new Error(`A UI plugin cannot dispatch ${e} while handling a core command`);this.dispatchToHandlers(this.handlers,o)}return v.Success};dispatchFromCorePlugin=(e,t)=>{const o=fB(e,t),s=this.status;this.status=2;const i=this.isReplayingCommand?this.coreHandlers:this.handlers;return this.dispatchToHandlers(i,o),this.status=s,v.Success};dispatchToHandlers(e,t){const o=f(t);for(const s of e)!o&&s instanceof gV||s.beforeHandle(t);for(const s of e)!o&&s instanceof gV||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=F_();for(const t of this.handlers)t instanceof gV&&t.export(e);return e.revisionId=this.session.getRevisionId()||He,e=pt(e),e}updateMode(e){this.config.mode=e,this.trigger("update")}exportXLSX(){this.dispatch("EVALUATE_CELLS");let e={...F_(),sheets:[O_(x_,"Sheet1")]};for(const t of this.handlers)t instanceof eu&&t.exportForExcel(e);return e=pt(e),gB(e)}garbageCollectExternalResources(){for(const e of this.corePlugins)e.garbageCollectExternalResources()}},e.PivotRuntimeDefinition=aP,e.Registry=n,e.Revision=LU,e.SPREADSHEET_DIMENSIONS=bB,e.Spreadsheet=QH,e.SpreadsheetPivotTable=cP,e.UIPlugin=tu,e.__info__=vB,e.addFunction=function e(t,o){return AC.add(t,o),{addFunction:(t,o)=>e(t,o)}},e.addRenderingLayer=function(e,t){if(go[e])throw new Error(`Layer ${e} already exists`);go[e]=t},e.astToFormula=vN,e.chartHelpers=RB,e.compile=$C,e.compileTokens=GC,e.components=IB,e.constants=EB,e.convertAstNodes=Yv,e.coreTypes=m,e.findCellInNewZone=ls,e.functionCache=BC,e.getCaretDownSvg=eA,e.getCaretUpSvg=tA,e.helpers=CB,e.hooks=wB,e.invalidateCFEvaluationCommands=d,e.invalidateChartEvaluationCommands=c,e.invalidateDependenciesCommands=h,e.invalidateEvaluationCommands=l,e.iterateAstNodes=Xv,e.links=yB,e.load=E_,e.parse=Zv,e.parseTokens=jv,e.readonlyAllowedCommands=p,e.registries=SB,e.setDefaultSheetViewSize=function(e){et=e},e.setTranslationMethod=function(e,t=(()=>!0)){ci=e,hi=t},e.stores=xB,e.tokenColors=ht,e.tokenize=El,vB.version="19.0.10",vB.date="2025-11-12T14:15:51.076Z",vB.hash="18ac688"}(this.o_spreadsheet=this.o_spreadsheet||{},owl);