@univerjs/core 0.6.6 → 0.6.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/lib/cjs/index.js CHANGED
@@ -5,6 +5,6 @@
5
5
  `)===r?Ie.TRUE:Ie.FALSE}const Gn=class Gn{constructor(t,n,r){C(this,"_range");C(this,"_worksheet");this._deps=r,this._range=n,this._worksheet=t}static foreach(t,n){const{startRow:r,startColumn:s,endRow:i,endColumn:o}=t;for(let a=r;a<=i;a++)for(let l=s;l<=o;l++)n(a,l)}getRangeData(){return this._range}getValue(){return this.getValues()[0][0]}getValues(){const{startRow:t,endRow:n,startColumn:r,endColumn:s}=this._range,i=[];for(let o=t;o<=n;o++){const a=[];for(let l=r;l<=s;l++)a.push(this.getMatrix().getValue(o,l)||null);i.push(a)}return i}getMatrix(){const{startRow:t,endRow:n,startColumn:r,endColumn:s}=this._range,i=this._worksheet.getCellMatrix(),o=new wt;for(let a=t;a<=n;a++)for(let l=r;l<=s;l++)o.setValue(a,l,i.getValue(a,l)||null);return o}getMatrixObject(){const{startRow:t,endRow:n,startColumn:r,endColumn:s}=this._range,i=this._worksheet.getCellMatrix(),o=new wt;for(let a=t;a<=n;a++)for(let l=r;l<=s;l++)o.setValue(a-t,l-r,i.getValue(a,l)||{});return o}getA1Notation(){const{startRow:t,endRow:n,startColumn:r,endColumn:s}=this._range;let i,o;return r<s?(i=re.numToWord(r+1)+(t+1),o=re.numToWord(s+1)+(n+1)):(i=re.numToWord(s+1)+(n+1),o=re.numToWord(r+1)+(t+1)),i===o?`${i}`:`${i}:${o}`}getBackground(){return this.getBackgrounds()[0][0]}getBackgrounds(){const t=this._deps.getStyles();return this.getValues().map(n=>n.map(r=>{var i;const s=t.getStyleByCell(r);return((i=s==null?void 0:s.bg)==null?void 0:i.rgb)||lt.bg.rgb}))}getCell(t,n){const{startRow:r,startColumn:s}=this._range,i={startRow:r+t,endRow:r+t,startColumn:s+n,endColumn:s+n};return new Gn(this._worksheet,i,this._deps)}getColumn(){return this._range.startColumn}getObjectValue(t={}){return this.getObjectValues(t)[0][0]}getObjectValues(t={}){var a;const{startRow:n,endRow:r,startColumn:s,endColumn:i}=this._range,o=this._worksheet.getCellMatrix().getFragment(n,r,s,i).getData();if(t.isIncludeStyle){const l=this._deps.getStyles();for(let u=0;u<=r-n;u++)for(let c=0;c<=i-s;c++){if(o==null||((a=o==null?void 0:o[u])==null?void 0:a[c])==null)continue;const h=o[u][c].s;h&&(o[u][c].s=l.get(h))}}return o}getFontColor(){return this.getFontColors()[0][0]}getFontColors(){const t=this._deps.getStyles();return this.getValues().map(n=>n.map(r=>{var i;const s=t.getStyleByCell(r);return((i=s==null?void 0:s.cl)==null?void 0:i.rgb)||lt.cl.rgb}))}getFontFamilies(){return this._getStyles("ff")}getFontFamily(){return this.getFontFamilies()[0][0]}getUnderlines(){return this._getStyles("ul")}getUnderline(){var n,r;const{p:t}=(n=this.getValue())!=null?n:{};return t&&Array.isArray((r=t.body)==null?void 0:r.textRuns)&&t.body.textRuns.length>0?_r("ul",t.body)===Ie.TRUE?{s:Ie.TRUE}:{s:Ie.FALSE}:this.getUnderlines()[0][0]}getOverlines(){return this._getStyles("ol")}getOverline(){return this.getOverlines()[0][0]}getStrikeThrough(){var n,r;const{p:t}=(n=this.getValue())!=null?n:{};return t&&Array.isArray((r=t.body)==null?void 0:r.textRuns)&&t.body.textRuns.length>0?_r("st",t.body)===Ie.TRUE?{s:Ie.TRUE}:{s:Ie.FALSE}:this.getStrikeThroughs()[0][0]}getStrikeThroughs(){return this._getStyles("st")}getFontSize(){var n,r;const t=((n=this.getValue())==null?void 0:n.p)||{};return t&&Array.isArray((r=t.body)==null?void 0:r.textRuns)&&t.body.textRuns.length>0?t.body.textRuns.some(s=>{var i;return((i=s==null?void 0:s.ts)==null?void 0:i.fs)!=null})?Math.max(...t.body.textRuns.map(s=>{var i;return((i=s==null?void 0:s.ts)==null?void 0:i.fs)||0})):this.getFontSizes()[0][0]:this.getFontSizes()[0][0]}getFontSizes(){return this._getStyles("fs")}getBorder(){return this.getBorders()[0][0]}getBorders(){return this._getStyles("bd")}getFontStyle(){var n,r;const{p:t}=(n=this.getValue())!=null?n:{};return t&&Array.isArray((r=t.body)==null?void 0:r.textRuns)&&t.body.textRuns.length>0?_r("it",t.body)===Ie.TRUE?Fr.ITALIC:Fr.NORMAL:this._getFontStyles()[0][0]}_getFontStyles(){return this._getStyles("it")}getFontWeight(){var n,r;const{p:t}=(n=this.getValue())!=null?n:{};return t&&Array.isArray((r=t.body)==null?void 0:r.textRuns)&&t.body.textRuns.length>0?_r("bl",t.body)===Ie.TRUE?$r.BOLD:$r.NORMAL:this._getFontWeights()[0][0]}_getFontWeights(){return this._getStyles("bl")}getGridId(){return this._worksheet.getSheetId()}getHeight(){const{_range:t,_worksheet:n}=this,{startRow:r,endRow:s}=t;let i=0;for(let o=0;o<=s-r;o++){const a=n.getRowHeight(o);i+=a}return i}getHorizontalAlignment(){return this.getHorizontalAlignments()[0][0]}getHorizontalAlignments(){return this._getStyles("ht")}getLastColumn(){return this._range.endColumn}getLastRow(){return this._range.endRow}getNumColumns(){const{startColumn:t,endColumn:n}=this._range;return n-t+1}getNumRows(){const{startRow:t,endRow:n}=this._range;return n-t+1}getRichTextValue(){return this.getRichTextValues()[0][0]}getRichTextValues(){return this.getValues().map(t=>t.map(n=>(n==null?void 0:n.p)||""))}getRowIndex(){return this._range.startRow}getSheet(){return this._worksheet}getTextDirection(){return this.getTextDirections()[0][0]}getTextDirections(){return this._getStyles("td")}getTextRotation(){return this.getTextRotations()[0][0]}getTextRotations(){return this._getStyles("tr")}getTextStyle(){return this.getTextStyles()[0][0]}getTextStyles(){const t=this._deps.getStyles();return this.getValues().map(n=>n.map(r=>t.getStyleByCell(r)))}getVerticalAlignment(){return this.getVerticalAlignments()[0][0]}getVerticalAlignments(){return this._getStyles("vt")}getWidth(){const{_range:t,_worksheet:n}=this,{startColumn:r,endColumn:s}=t;let i=0;for(let o=0;o<=s-r;o++)i+=n.getColumnWidth(o);return i}getWrap(){return this.getWrapStrategy()===on.WRAP?Ie.TRUE:Ie.FALSE}getWrapStrategies(){return this._getStyles("tb")}getWrapStrategy(){return this.getWrapStrategies()[0][0]}forEach(t){Gn.foreach(this._range,t)}_getStyles(t){const n=this._deps.getStyles();return this.getValues().map(r=>r.map(s=>{const i=n&&n.getStyleByCell(s);return i&&i[t]||lt[t]}))}};C(Gn,"transformRange",(t,n)=>{const r=n.getMaxColumns()-1,s=n.getMaxRows()-1;return t.rangeType===Le.ALL?{startColumn:0,startRow:0,endColumn:r,endRow:s}:t.rangeType===Le.COLUMN?{startRow:0,endRow:s,startColumn:t.startColumn,endColumn:t.endColumn}:t.rangeType===Le.ROW?{startColumn:0,endColumn:r,startRow:t.startRow,endRow:t.endRow}:{startColumn:t.startColumn,endColumn:Math.min(t.endColumn,r),startRow:t.startRow,endRow:Math.min(t.endRow,s)}});let vn=Gn;function Na(e,t,n=0,r=e.length-1,s=Sd){for(;r>n;){if(r-n>600){const l=r-n+1,u=t-n+1,c=Math.log(l),h=.5*Math.exp(2*c/3),d=.5*Math.sqrt(c*h*(l-h)/l)*(u-l/2<0?-1:1),f=Math.max(n,Math.floor(t-u*h/l+d)),E=Math.min(r,Math.floor(t+(l-u)*h/l+d));Na(e,t,f,E,s)}const i=e[t];let o=n,a=r;for(Mn(e,n,t),s(e[r],i)>0&&Mn(e,n,r);o<a;){for(Mn(e,o,a),o++,a--;s(e[o],i)<0;)o++;for(;s(e[a],i)>0;)a--}s(e[n],i)===0?Mn(e,n,a):(a++,Mn(e,a,r)),a<=t&&(n=a+1),t<=a&&(r=a-1)}}function Mn(e,t,n){const r=e[t];e[t]=e[n],e[n]=r}function Sd(e,t){return e<t?-1:e>t?1:0}class jr{constructor(t=9){this._maxEntries=Math.max(4,t),this._minEntries=Math.max(2,Math.ceil(this._maxEntries*.4)),this.clear()}all(){return this._all(this.data,[])}search(t){let n=this.data;const r=[];if(!Er(t,n))return r;const s=this.toBBox,i=[];for(;n;){for(let o=0;o<n.children.length;o++){const a=n.children[o],l=n.leaf?s(a):a;Er(t,l)&&(n.leaf?r.push(a):hs(t,l)?this._all(a,r):i.push(a))}n=i.pop()}return r}collides(t){let n=this.data;if(!Er(t,n))return!1;const r=[];for(;n;){for(let s=0;s<n.children.length;s++){const i=n.children[s],o=n.leaf?this.toBBox(i):i;if(Er(t,o)){if(n.leaf||hs(t,o))return!0;r.push(i)}}n=r.pop()}return!1}load(t){if(!(t&&t.length))return this;if(t.length<this._minEntries){for(let r=0;r<t.length;r++)this.insert(t[r]);return this}let n=this._build(t.slice(),0,t.length-1,0);if(!this.data.children.length)this.data=n;else if(this.data.height===n.height)this._splitRoot(this.data,n);else{if(this.data.height<n.height){const r=this.data;this.data=n,n=r}this._insert(n,this.data.height-n.height-1,!0)}return this}insert(t){return t&&this._insert(t,this.data.height-1),this}clear(){return this.data=gn([]),this}remove(t,n){if(!t)return this;let r=this.data;const s=this.toBBox(t),i=[],o=[];let a,l,u;for(;r||i.length;){if(r||(r=i.pop(),l=i[i.length-1],a=o.pop(),u=!0),r.leaf){const c=vd(t,r.children,n);if(c!==-1)return r.children.splice(c,1),i.push(r),this._condense(i),this}!u&&!r.leaf&&hs(r,s)?(i.push(r),o.push(a),a=0,l=r,r=r.children[0]):l?(a++,r=l.children[a],u=!1):r=null}return this}toBBox(t){return t}compareMinX(t,n){return t.minX-n.minX}compareMinY(t,n){return t.minY-n.minY}toJSON(){return this.data}fromJSON(t){return this.data=t,this}_all(t,n){const r=[];for(;t;)t.leaf?n.push(...t.children):r.push(...t.children),t=r.pop();return n}_build(t,n,r,s){const i=r-n+1;let o=this._maxEntries,a;if(i<=o)return a=gn(t.slice(n,r+1)),hn(a,this.toBBox),a;s||(s=Math.ceil(Math.log(i)/Math.log(o)),o=Math.ceil(i/Math.pow(o,s-1))),a=gn([]),a.leaf=!1,a.height=s;const l=Math.ceil(i/o),u=l*Math.ceil(Math.sqrt(o));ji(t,n,r,u,this.compareMinX);for(let c=n;c<=r;c+=u){const h=Math.min(c+u-1,r);ji(t,c,h,l,this.compareMinY);for(let d=c;d<=h;d+=l){const f=Math.min(d+l-1,h);a.children.push(this._build(t,d,f,s-1))}}return hn(a,this.toBBox),a}_chooseSubtree(t,n,r,s){for(;s.push(n),!(n.leaf||s.length-1===r);){let i=1/0,o=1/0,a;for(let l=0;l<n.children.length;l++){const u=n.children[l],c=cs(u),h=bd(t,u)-c;h<o?(o=h,i=c<i?c:i,a=u):h===o&&c<i&&(i=c,a=u)}n=a||n.children[0]}return n}_insert(t,n,r){const s=r?t:this.toBBox(t),i=[],o=this._chooseSubtree(s,this.data,n,i);for(o.children.push(t),Bn(o,s);n>=0&&i[n].children.length>this._maxEntries;)this._split(i,n),n--;this._adjustParentBBoxes(s,i,n)}_split(t,n){const r=t[n],s=r.children.length,i=this._minEntries;this._chooseSplitAxis(r,i,s);const o=this._chooseSplitIndex(r,i,s),a=gn(r.children.splice(o,r.children.length-o));a.height=r.height,a.leaf=r.leaf,hn(r,this.toBBox),hn(a,this.toBBox),n?t[n-1].children.push(a):this._splitRoot(r,a)}_splitRoot(t,n){this.data=gn([t,n]),this.data.height=t.height+1,this.data.leaf=!1,hn(this.data,this.toBBox)}_chooseSplitIndex(t,n,r){let s,i=1/0,o=1/0;for(let a=n;a<=r-n;a++){const l=$n(t,0,a,this.toBBox),u=$n(t,a,r,this.toBBox),c=yd(l,u),h=cs(l)+cs(u);c<i?(i=c,s=a,o=h<o?h:o):c===i&&h<o&&(o=h,s=a)}return s||r-n}_chooseSplitAxis(t,n,r){const s=t.leaf?this.compareMinX:Od,i=t.leaf?this.compareMinY:wd,o=this._allDistMargin(t,n,r,s),a=this._allDistMargin(t,n,r,i);o<a&&t.children.sort(s)}_allDistMargin(t,n,r,s){t.children.sort(s);const i=this.toBBox,o=$n(t,0,n,i),a=$n(t,r-n,r,i);let l=pr(o)+pr(a);for(let u=n;u<r-n;u++){const c=t.children[u];Bn(o,t.leaf?i(c):c),l+=pr(o)}for(let u=r-n-1;u>=n;u--){const c=t.children[u];Bn(a,t.leaf?i(c):c),l+=pr(a)}return l}_adjustParentBBoxes(t,n,r){for(let s=r;s>=0;s--)Bn(n[s],t)}_condense(t){for(let n=t.length-1,r;n>=0;n--)t[n].children.length===0?n>0?(r=t[n-1].children,r.splice(r.indexOf(t[n]),1)):this.clear():hn(t[n],this.toBBox)}}function vd(e,t,n){if(!n)return t.indexOf(e);for(let r=0;r<t.length;r++)if(n(e,t[r]))return r;return-1}function hn(e,t){$n(e,0,e.children.length,t,e)}function $n(e,t,n,r,s){s||(s=gn(null)),s.minX=1/0,s.minY=1/0,s.maxX=-1/0,s.maxY=-1/0;for(let i=t;i<n;i++){const o=e.children[i];Bn(s,e.leaf?r(o):o)}return s}function Bn(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 Od(e,t){return e.minX-t.minX}function wd(e,t){return e.minY-t.minY}function cs(e){return(e.maxX-e.minX)*(e.maxY-e.minY)}function pr(e){return e.maxX-e.minX+(e.maxY-e.minY)}function bd(e,t){return(Math.max(t.maxX,e.maxX)-Math.min(t.minX,e.minX))*(Math.max(t.maxY,e.maxY)-Math.min(t.minY,e.minY))}function yd(e,t){const n=Math.max(e.minX,t.minX),r=Math.max(e.minY,t.minY),s=Math.min(e.maxX,t.maxX),i=Math.min(e.maxY,t.maxY);return Math.max(0,s-n)*Math.max(0,i-r)}function hs(e,t){return e.minX<=t.minX&&e.minY<=t.minY&&t.maxX<=e.maxX&&t.maxY<=e.maxY}function Er(e,t){return t.minX<=e.maxX&&t.minY<=e.maxY&&t.maxX>=e.minX&&t.maxY>=e.minY}function gn(e){return{children:e,height:1,leaf:!0,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0}}function ji(e,t,n,r,s){const i=[t,n];for(;i.length;){if(n=i.pop(),t=i.pop(),n-t<=r)continue;const o=t+Math.ceil((n-t)/r/2)*r;Na(e,o,t,n,s),i.push(t,o,o,n)}}function Ad(e,t,n,r=!1){if(t===0&&n===0)return e;let s={...e};const i=s.startAbsoluteRefType||tt.NONE,o=s.endAbsoluteRefType||tt.NONE,a=s.rangeType||Le.NORMAL;if(!r&&i===tt.ALL&&o===tt.ALL)return s;const l=Wi(s.startRow,n,s.startColumn,t,a),u=Wi(s.endRow,n,s.endColumn,t,a);return r||i===tt.NONE&&o===tt.NONE?s={...s,startRow:l.row,startColumn:l.column,endRow:u.row,endColumn:u.column}:(i===tt.NONE?s={...s,startRow:l.row,startColumn:l.column}:i===tt.COLUMN?s={...s,startRow:l.row}:i===tt.ROW&&(s={...s,startColumn:l.column}),o===tt.NONE?s={...s,endRow:u.row,endColumn:u.column}:o===tt.COLUMN?s={...s,endRow:u.row}:o===tt.ROW&&(s={...s,endColumn:u.column}),s)}function Wi(e,t,n,r,s){return s===Le.NORMAL?{row:e+t,column:n+r}:s===Le.ROW?{row:e+t,column:n}:s===Le.COLUMN?{row:e,column:n+r}:{row:e,column:n}}function Zs(e){const t=new Set,n=new Set;for(const o of e)t.add(o.startColumn),t.add(o.endColumn+1),n.add(o.startRow),n.add(o.endRow+1);const r=Array.from(t).sort((o,a)=>o-a),s=Array.from(n).sort((o,a)=>o-a);e.sort((o,a)=>o.startRow-a.startRow||o.startColumn-a.startColumn);const i=[];for(let o=0;o<s.length-1;o++)for(let a=0;a<r.length-1;a++){const l=r[a],u=r[a+1]-1,c=s[o],h=s[o+1]-1;for(const d of e){if(d.startRow>h)break;if(d.startRow<=c&&d.endRow>=h&&d.startColumn<=l&&d.endColumn>=u){i.push({startColumn:l,endColumn:u,startRow:c,endRow:h});break}}}return i}function Td(e){e.sort((r,s)=>r.startRow-s.startRow||r.startColumn-s.startColumn);const t={};for(const r of e)t[r.startRow]||(t[r.startRow]=[]),t[r.startRow].push(r);const n=[];for(const r in t){const s=t[+r];s.sort((o,a)=>o.startColumn-a.startColumn);let i=s[0];for(let o=1;o<s.length;o++){const a=s[o];a.startColumn<=i.endColumn+1&&a.startRow===i.startRow&&a.endRow===i.endRow?i.endColumn=Math.max(i.endColumn,a.endColumn):(n.push(i),i=a)}n.push(i)}return n}function Nd(e){e.sort((r,s)=>r.startColumn-s.startColumn||r.startRow-s.startRow);const t={};for(const r of e)t[r.startColumn]||(t[r.startColumn]=[]),t[r.startColumn].push(r);const n=[];for(const r in t){const s=t[+r];s.sort((o,a)=>o.startRow-a.startRow);let i=s[0];for(let o=1;o<s.length;o++){const a=s[o];a.startRow<=i.endRow+1&&a.startColumn===i.startColumn&&a.endColumn===i.endColumn?i.endRow=Math.max(i.endRow,a.endRow):(n.push(i),i=a)}n.push(i)}return n}function Md(e){const t=Zs(e),n=Td(t);return Nd(n)}function Dd(e,t){const n=[];return e.forEach(r=>{n.push(...Xt.subtract(r,t))}),Xt.mergeRanges(n)}function Ma(e,t){const n=Yi(e.startRow,e.endRow,t.startRow,t.endRow),r=Yi(e.startColumn,e.endColumn,t.startColumn,t.endColumn);if(!n||!r)return null;const[s,i]=n,[o,a]=r,l=Ld(e.rangeType,t.rangeType,s,i,o,a);return{startRow:s,endRow:i,startColumn:o,endColumn:a,rangeType:l}}function Yi(e,t,n,r){const s=isNaN(e)?-1/0:e,i=isNaN(t)?1/0:t,o=isNaN(n)?-1/0:n,a=isNaN(r)?1/0:r,l=Math.max(s,o),u=Math.min(i,a);if(l<=u){const c=l===-1/0?Number.NaN:l,h=u===1/0?Number.NaN:u;return[c,h]}else return null}function Ld(e,t,n,r,s,i){const o=e!==void 0?e:zi(n,r,s,i),a=t!==void 0?t:zi(n,r,s,i);return o===Le.ALL||a===Le.ALL?o===a?o:o===Le.ALL?a:o:o===a?o:(o===Le.NORMAL||a===Le.NORMAL,Le.NORMAL)}function zi(e,t,n,r){const s=!isNaN(e)&&!isNaN(t),i=!isNaN(n)&&!isNaN(r);return s&&i?Le.NORMAL:s?Le.ROW:i?Le.COLUMN:Le.ALL}const Lt=class Lt{static clone(t){return t.rangeType!==void 0?{startRow:t.startRow,startColumn:t.startColumn,endRow:t.endRow,endColumn:t.endColumn,rangeType:t.rangeType}:{startRow:t.startRow,startColumn:t.startColumn,endRow:t.endRow,endColumn:t.endColumn}}static equals(t,n){return t==null||n==null?!1:t.endRow===n.endRow&&t.endColumn===n.endColumn&&t.startRow===n.startRow&&t.startColumn===n.startColumn&&(t.rangeType===n.rangeType||t.rangeType===void 0&&n.rangeType===Le.NORMAL||n.rangeType===void 0&&t.rangeType===Le.NORMAL)}static simpleRangesIntersect(t,n){const{startRow:r,endRow:s,startColumn:i,endColumn:o}=t,{startRow:a,endRow:l,startColumn:u,endColumn:c}=n,h=r<=l&&s>=a,d=i<=c&&o>=u;return h&&d}static intersects(t,n){if(t.rangeType===Le.ROW&&n.rangeType===Le.COLUMN||t.rangeType===Le.COLUMN&&n.rangeType===Le.ROW)return!0;if(t.rangeType===Le.ROW&&n.rangeType===Le.ROW)return t.startRow<=n.endRow&&t.endRow>=n.startRow;if(t.rangeType===Le.COLUMN&&n.rangeType===Le.COLUMN)return t.startColumn<=n.endColumn&&t.endColumn>=n.startColumn;const r=Math.floor(Number.MAX_SAFE_INTEGER/10),s=Number.isNaN(t.startRow)?0:t.startRow,i=Number.isNaN(t.endRow)?r:t.endRow,o=Number.isNaN(t.startColumn)?0:t.startColumn,a=Number.isNaN(t.endColumn)?r:t.endColumn,l=Number.isNaN(n.startRow)?0:n.startRow,u=Number.isNaN(n.endRow)?r:n.endRow,c=Number.isNaN(n.startColumn)?0:n.startColumn,h=Number.isNaN(n.endColumn)?r:n.endColumn,d=Math.abs(o+a-c-h),f=Math.abs(o-a)+Math.abs(c-h),E=Math.abs(s+i-l-u),R=Math.abs(s-i)+Math.abs(l-u);return d<=f&&E<=R}static doAnyRangesIntersect(t,n){const r=new jr;return r.load(t.map(s=>({minX:s.startColumn,minY:s.startRow,maxX:s.endColumn,maxY:s.endRow}))),n.some(s=>r.search({minX:s.startColumn,minY:s.startRow,maxX:s.endColumn,maxY:s.endRow}).length>0)}static getIntersects(t,n){const r=t.startRow,s=t.endRow,i=t.startColumn,o=t.endColumn,a=n.startRow,l=n.endRow,u=n.startColumn,c=n.endColumn;let h,d,f,E;if(a<=s)a>=r?d=a:d=r;else return null;if(l>=r)l>=s?E=s:E=l;else return null;if(u<=o)u>i?h=u:h=i;else return null;if(c>=i)c>=o?f=o:f=c;else return null;return{startRow:d,endRow:E,startColumn:h,endColumn:f,rangeType:Le.NORMAL}}static contains(t,n){return t.startRow<=n.startRow&&t.endRow>=n.endRow&&t.startColumn<=n.startColumn&&t.endColumn>=n.endColumn}static realContain(t,n){return Lt.contains(t,n)&&(t.startRow<n.startRow||t.endRow>n.endRow||t.startColumn<n.startColumn||t.endColumn>n.endColumn)}static union(...t){return t.reduce((n,r)=>({startRow:Math.min(n.startRow,r.startRow),startColumn:Math.min(n.startColumn,r.startColumn),endRow:Math.max(n.endRow,r.endRow),endColumn:Math.max(n.endColumn,r.endColumn),rangeType:Le.NORMAL}),t[0])}static realUnion(...t){const n=t.some(i=>i.rangeType===Le.COLUMN),r=t.some(i=>i.rangeType===Le.ROW),s=Lt.union(...t);return{startColumn:r?Number.NaN:s.startColumn,endColumn:r?Number.NaN:s.endColumn,startRow:n?Number.NaN:s.startRow,endRow:n?Number.NaN:s.endRow,rangeType:r?Le.ROW:n?Le.COLUMN:Le.NORMAL}}static subtract(t,n){if(n.startRow>t.endRow||n.endRow<t.startRow||n.startColumn>t.endColumn||n.endColumn<t.startColumn)return[t];const r=[];n.startRow>=t.startRow&&r.push({startRow:t.startRow,startColumn:t.startColumn,endRow:n.startRow-1,endColumn:t.endColumn}),n.endRow<=t.endRow&&r.push({startRow:n.endRow+1,startColumn:t.startColumn,endRow:t.endRow,endColumn:t.endColumn});const s=Math.max(t.startRow,n.startRow),i=Math.min(t.endRow,n.endRow);return n.startColumn>=t.startColumn&&r.push({startRow:s,startColumn:t.startColumn,endRow:i,endColumn:n.startColumn-1}),n.endColumn<=t.endColumn&&r.push({startRow:s,startColumn:n.endColumn+1,endRow:i,endColumn:t.endColumn}),r.filter(a=>a.startRow<=a.endRow&&a.startColumn<=a.endColumn)}static mergeRanges(t){return Md(t)}static splitIntoGrid(t){return Zs(t)}static subtractMulti(t,n){if(!n.length)return t;let r=t;return n.forEach(s=>{r=Dd(r,s)}),r}static hasIntersectionBetweenTwoRect(t,n){return!(t.left>n.right||t.right<n.left||t.top>n.bottom||t.bottom<n.top)}static getIntersectionBetweenTwoRect(t,n){const r=Math.max(t.left,n.left),s=Math.min(t.right,n.right),i=Math.max(t.top,n.top),o=Math.min(t.bottom,n.bottom);return s<=r||o<=i?null:{left:r,right:s,top:i,bottom:o,width:s-r,height:o-i}}static sort(t){return t.sort((n,r)=>n.startRow-r.startRow||n.startColumn-r.startColumn)}};C(Lt,"getRelativeRange",(t,n)=>({startRow:t.startRow-n.startRow,endRow:t.endRow-t.startRow,startColumn:t.startColumn-n.startColumn,endColumn:t.endColumn-t.startColumn})),C(Lt,"getPositionRange",(t,n,r)=>({...r||{},startRow:r&&[tt.ROW,tt.ALL].includes(r.startAbsoluteRefType||0)?r.startRow:t.startRow+n.startRow,endRow:r&&[tt.ROW,tt.ALL].includes(r.endAbsoluteRefType||0)?r.endRow:t.endRow+t.startRow+n.startRow,startColumn:r&&[tt.COLUMN,tt.ALL].includes(r.startAbsoluteRefType||0)?r.startColumn:t.startColumn+n.startColumn,endColumn:r&&[tt.COLUMN,tt.ALL].includes(r.endAbsoluteRefType||0)?r.endColumn:t.endColumn+t.startColumn+n.startColumn})),C(Lt,"moveHorizontal",(t,n=0,r=0)=>({...t,startColumn:t.startColumn+n,endColumn:t.endColumn+n+r})),C(Lt,"moveVertical",(t,n=0,r=0)=>({...t,startRow:t.startRow+n,endRow:t.endRow+n+r})),C(Lt,"moveOffset",(t,n,r)=>({...t,startRow:t.startRow+r,endRow:t.endRow+r,startColumn:t.startColumn+n,endColumn:t.endColumn+n}));let Xt=Lt;function xd(e,t){if(e.length===0||e[0].length===0)return null;const n=new Array(e[0].length).fill(0);let r=0,s=null;for(let i=0;i<e.length;i++){for(let a=0;a<e[0].length;a++)n[a]=t(e[i][a])?n[a]+1:0;const o=Ud(n);o.area>r&&(r=o.area,s={startColumn:o.start,startRow:i-o.height+1,endColumn:o.end,endRow:i})}return s}function Ud(e){const t=[];let n=0,r={area:0,height:0,start:0,end:0},s=0;for(;s<e.length;)if(t.length===0||e[s]>=e[t[t.length-1]])t.push(s++);else{const i=e[t.pop()],o=t.length===0?s:s-t[t.length-1]-1;i*o>n&&(n=i*o,r={area:n,height:i,start:t.length===0?0:t[t.length-1]+1,end:s-1})}for(;t.length>0;){const i=e[t.pop()],o=t.length===0?s:s-t[t.length-1]-1;i*o>n&&(n=i*o,r={area:n,height:i,start:t.length===0?0:t[t.length-1]+1,end:s-1})}return r}function kd(e,t){vn.foreach(t,(n,r)=>{e[n][r]=void 0})}function Pd(e,t){const n=e.toFullArray(),r=[];for(;;){const s=xd(n,t);if(!s)break;r.push(s),kd(n,s)}return r}class Fd{constructor(t,n){C(this,"_values",[]);C(this,"_keys",[]);C(this,"_keyMaps",new Map);this._values=t,this._keys=n,t.forEach(r=>{this._initKeyMap(r)})}_initKeyMap(t){this._keys.forEach(n=>{const r=t[n],s=this._keyMaps.get(n)||new Map;s.set(r,t),this._keyMaps.set(n,s)})}getValue(t,n){const r=n||this._keys;for(let s=0;s<r.length;s++){const i=this._keyMaps.get(r[s]);if(i!=null&&i.has(t))return i.get(t)}return null}hasValue(t){for(let n=0;n<this._keys.length;n++){const r=this._keyMaps.get(this._keys[n]);if(r!=null&&r.has(t))return!0}return!1}addValue(t){this._values.push(t),this._initKeyMap(t)}setValue(t,n,r){const s=this.getValue(t);s&&Object.keys(s).includes(n)&&(s[n]=r)}deleteValue(t,n){const r=this.getValue(t,n);if(r){this._keys.forEach(i=>{const o=this._keyMaps.get(i),a=r[i];o==null||o.delete(a)});const s=this._values.findIndex(i=>i===r);this._values.splice(s,1)}}getValues(){return this._values}getKeyMap(t){var n;return[...((n=this._keyMaps.get(t))==null?void 0:n.keys())||[]]}clear(){this._values=[],this._keys=[],this._keyMaps.clear()}}function Ds(e,t,n,r){return{forEach(s){for(let i=e;i<=t;i++)for(let o=n;o<=r;o++)s(i,o)}}}function $d(e){if(e==null||e.length===0)return Number.NaN;const t=e.toLowerCase().split(""),n=t.length,r=o=>o.charCodeAt(0)-96;let s=0,i=0;for(let o=0;o<n;o++)i=r(t[o]),s+=i*26**(n-o-1);return s===0?Number.NaN:s-1}const Wr=65,Da=90,Bd=97;function Hd(e){const t=Da-Wr+1;let n="";for(;e>=0;)n=String.fromCharCode(e%t+Wr)+n,e=Math.floor(e/t)-1;return n}function La(e,t){let n="";for(;t>0;)n+=e,t--;return n}function jd(e,t=!1){const n=Da-Wr+1;let r=Bd;t&&(r=Wr);const s=String.fromCharCode(e%n+r),i=Math.floor(e/n)+1;return La(s,i)}function Wd(e,t){return e.zIndex>t.zIndex?1:e.zIndex===t.zIndex?0:-1}function Yd(e,t){return e.zIndex>t.zIndex?-1:e.zIndex===t.zIndex?0:1}function ir(e="index",t=1){return(n,r)=>n[e]>r[e]?t:n[e]===r[e]?0:-t}var xa=(e=>(e[e.character=0]="character",e[e.paragraph=1]="paragraph",e[e.table=2]="table",e[e.numbering=3]="numbering",e))(xa||{}),Ua=(e=>(e[e.TAB=0]="TAB",e[e.SPACE=1]="SPACE",e[e.NOTHING=2]="NOTHING",e))(Ua||{}),Ne=(e=>(e[e.BULLET=0]="BULLET",e[e.NONE=1]="NONE",e[e.DECIMAL=2]="DECIMAL",e[e.DECIMAL_ZERO=3]="DECIMAL_ZERO",e[e.UPPER_LETTER=4]="UPPER_LETTER",e[e.LOWER_LETTER=5]="LOWER_LETTER",e[e.UPPER_ROMAN=6]="UPPER_ROMAN",e[e.LOWER_ROMAN=7]="LOWER_ROMAN",e[e.ORDINAL=8]="ORDINAL",e[e.CARDINAL_TEXT=9]="CARDINAL_TEXT",e[e.ORDINAL_TEXT=10]="ORDINAL_TEXT",e[e.HEX=11]="HEX",e[e.CHICAGO=12]="CHICAGO",e[e.IDEOGRAPH_DIGITAL=13]="IDEOGRAPH_DIGITAL",e[e.JAPANESE_COUNTING=14]="JAPANESE_COUNTING",e[e.AIUEO=15]="AIUEO",e[e.IROHA=16]="IROHA",e[e.DECIMAL_FULL_WIDTH=17]="DECIMAL_FULL_WIDTH",e[e.DECIMAL_HALF_WIDTH=18]="DECIMAL_HALF_WIDTH",e[e.JAPANESE_LEGAL=19]="JAPANESE_LEGAL",e[e.JAPANESE_DIGITAL_TEN_THOUSAND=20]="JAPANESE_DIGITAL_TEN_THOUSAND",e[e.DECIMAL_ENCLOSED_CIRCLE=21]="DECIMAL_ENCLOSED_CIRCLE",e[e.DECIMAL_FULL_WIDTH2=22]="DECIMAL_FULL_WIDTH2",e[e.AIUEO_FULL_WIDTH=23]="AIUEO_FULL_WIDTH",e[e.IROHA_FULL_WIDTH=24]="IROHA_FULL_WIDTH",e[e.GANADA=25]="GANADA",e[e.CHOSUNG=26]="CHOSUNG",e[e.DECIMAL_ENCLOSED_FULLSTOP=27]="DECIMAL_ENCLOSED_FULLSTOP",e[e.DECIMAL_ENCLOSED_PAREN=28]="DECIMAL_ENCLOSED_PAREN",e[e.DECIMAL_ENCLOSED_CIRCLE_CHINESE=29]="DECIMAL_ENCLOSED_CIRCLE_CHINESE",e[e.IDEOGRAPH_ENCLOSED_CIRCLE=30]="IDEOGRAPH_ENCLOSED_CIRCLE",e[e.IDEOGRAPH_TRADITIONAL=31]="IDEOGRAPH_TRADITIONAL",e[e.IDEOGRAPH_ZODIAC=32]="IDEOGRAPH_ZODIAC",e[e.IDEOGRAPH_ZODIAC_TRADITIONAL=33]="IDEOGRAPH_ZODIAC_TRADITIONAL",e[e.TAIWANESE_COUNTING=34]="TAIWANESE_COUNTING",e[e.IDEOGRAPH_LEGAL_TRADITIONAL=35]="IDEOGRAPH_LEGAL_TRADITIONAL",e[e.TAIWANESE_COUNTING_THOUSAND=36]="TAIWANESE_COUNTING_THOUSAND",e[e.TAIWANESE_DIGITAL=37]="TAIWANESE_DIGITAL",e[e.CHINESE_COUNTING=38]="CHINESE_COUNTING",e[e.CHINESE_LEGAL_SIMPLIFIED=39]="CHINESE_LEGAL_SIMPLIFIED",e[e.CHINESE_COUNTING_THOUSAND=40]="CHINESE_COUNTING_THOUSAND",e[e.KOREAN_DIGITAL=41]="KOREAN_DIGITAL",e[e.KOREAN_COUNTING=42]="KOREAN_COUNTING",e[e.KOREAN_LEGAL=43]="KOREAN_LEGAL",e[e.KOREAN_DIGITAL2=44]="KOREAN_DIGITAL2",e[e.VIETNAMESE_COUNTING=45]="VIETNAMESE_COUNTING",e[e.RUSSIAN_LOWER=46]="RUSSIAN_LOWER",e[e.RUSSIAN_UPPER=47]="RUSSIAN_UPPER",e[e.NUMBER_IN_DASH=48]="NUMBER_IN_DASH",e[e.HEBREW1=49]="HEBREW1",e[e.HEBREW2=50]="HEBREW2",e[e.ARABIC_ALPHA=51]="ARABIC_ALPHA",e[e.ARABIC_ABJAD=52]="ARABIC_ABJAD",e[e.HINDI_VOWELS=53]="HINDI_VOWELS",e[e.HINDI_CONSONANTS=54]="HINDI_CONSONANTS",e[e.HINDI_NUMBERS=55]="HINDI_NUMBERS",e[e.HINDI_COUNTING=56]="HINDI_COUNTING",e[e.THAI_LETTERS=57]="THAI_LETTERS",e[e.THAI_NUMBERS=58]="THAI_NUMBERS",e[e.THAI_COUNTING=59]="THAI_COUNTING",e[e.CUSTOM=60]="CUSTOM",e))(Ne||{}),or=(e=>(e[e.BULLET_ALIGNMENT_UNSPECIFIED=0]="BULLET_ALIGNMENT_UNSPECIFIED",e[e.START=1]="START",e[e.CENTER=2]="CENTER",e[e.END=3]="END",e[e.BOTH=4]="BOTH",e))(or||{}),qt=(e=>(e[e.HYPERLINK=0]="HYPERLINK",e[e.FIELD=1]="FIELD",e[e.SDT=2]="SDT",e[e.BOOKMARK=3]="BOOKMARK",e[e.COMMENT=4]="COMMENT",e[e.CUSTOM=5]="CUSTOM",e[e.MENTION=6]="MENTION",e[e.UNI_FORMULA=7]="UNI_FORMULA",e[e.DELTED=9999]="DELTED",e))(qt||{}),nn=(e=>(e[e.COMMENT=0]="COMMENT",e[e.DELETED=9999]="DELETED",e))(nn||{}),ka=(e=>(e[e.DRAWING=0]="DRAWING",e[e.CUSTOM=1]="CUSTOM",e))(ka||{}),Qs=(e=>(e[e.UNSPECIFIED=0]="UNSPECIFIED",e[e.TRADITIONAL=1]="TRADITIONAL",e[e.MODERN=2]="MODERN",e))(Qs||{}),Pa=(e=>(e[e.DEFAULT=0]="DEFAULT",e[e.LINES=1]="LINES",e[e.LINES_AND_CHARS=2]="LINES_AND_CHARS",e[e.SNAP_TO_CHARS=3]="SNAP_TO_CHARS",e))(Pa||{}),Fa=(e=>(e[e.SECTION_TYPE_UNSPECIFIED=0]="SECTION_TYPE_UNSPECIFIED",e[e.CONTINUOUS=1]="CONTINUOUS",e[e.NEXT_PAGE=2]="NEXT_PAGE",e[e.EVEN_PAGE=3]="EVEN_PAGE",e[e.ODD_PAGE=4]="ODD_PAGE",e))(Fa||{}),$a=(e=>(e[e.COLUMN_SEPARATOR_STYLE_UNSPECIFIED=0]="COLUMN_SEPARATOR_STYLE_UNSPECIFIED",e[e.NONE=1]="NONE",e[e.BETWEEN_EACH_COLUMN=2]="BETWEEN_EACH_COLUMN",e))($a||{}),Ba=(e=>(e[e.NORMAL=0]="NORMAL",e[e.TBRL=1]="TBRL",e[e.LRTBV=2]="LRTBV",e))(Ba||{}),Ha=(e=>(e[e.TEXT_RUN=0]="TEXT_RUN",e[e.AUTO_TEXT=1]="AUTO_TEXT",e[e.PAGE_BREAK=2]="PAGE_BREAK",e[e.COLUMN_BREAK=3]="COLUMN_BREAK",e[e.FOOT_NOTE_REFERENCE=4]="FOOT_NOTE_REFERENCE",e[e.HORIZONTAL_RULE=5]="HORIZONTAL_RULE",e[e.EQUATION=6]="EQUATION",e[e.DRAWING=7]="DRAWING",e[e.PERSON=8]="PERSON",e[e.RICH_LINK=9]="RICH_LINK",e))(Ha||{}),ja=(e=>(e[e.BOTH_SIDES=0]="BOTH_SIDES",e[e.LEFT=1]="LEFT",e[e.RIGHT=2]="RIGHT",e[e.LARGEST=3]="LARGEST",e))(ja||{}),Wa=(e=>(e[e.INLINE=0]="INLINE",e[e.WRAP_NONE=1]="WRAP_NONE",e[e.WRAP_POLYGON=2]="WRAP_POLYGON",e[e.WRAP_SQUARE=3]="WRAP_SQUARE",e[e.WRAP_THROUGH=4]="WRAP_THROUGH",e[e.WRAP_TIGHT=5]="WRAP_TIGHT",e[e.WRAP_TOP_AND_BOTTOM=6]="WRAP_TOP_AND_BOTTOM",e))(Wa||{}),Ya=(e=>(e[e.NAMED_STYLE_TYPE_UNSPECIFIED=0]="NAMED_STYLE_TYPE_UNSPECIFIED",e[e.NORMAL_TEXT=1]="NORMAL_TEXT",e[e.TITLE=2]="TITLE",e[e.SUBTITLE=3]="SUBTITLE",e[e.HEADING_1=4]="HEADING_1",e[e.HEADING_2=5]="HEADING_2",e[e.HEADING_3=6]="HEADING_3",e[e.HEADING_4=7]="HEADING_4",e[e.HEADING_5=8]="HEADING_5",e[e.HEADING_6=9]="HEADING_6",e))(Ya||{}),za=(e=>(e[e.AUTO=0]="AUTO",e[e.AT_LEAST=1]="AT_LEAST",e[e.EXACT=2]="EXACT",e))(za||{}),Va=(e=>(e[e.DASH_STYLE_UNSPECIFIED=0]="DASH_STYLE_UNSPECIFIED",e[e.SOLID=1]="SOLID",e[e.DOT=2]="DOT",e[e.DASH=3]="DASH",e))(Va||{}),Ga=(e=>(e[e.TAB_STOP_ALIGNMENT_UNSPECIFIED=0]="TAB_STOP_ALIGNMENT_UNSPECIFIED",e[e.START=1]="START",e[e.CENTER=2]="CENTER",e[e.END=3]="END",e))(Ga||{}),Ka=(e=>(e[e.UNSPECIFIED=0]="UNSPECIFIED",e[e.SPECIFIED=1]="SPECIFIED",e))(Ka||{}),Xa=(e=>(e[e.START=0]="START",e[e.CENTER=1]="CENTER",e[e.END=2]="END",e))(Xa||{}),qa=(e=>(e[e.AUTO_FIT=0]="AUTO_FIT",e[e.FIXED=1]="FIXED",e))(qa||{}),Ja=(e=>(e[e.NONE=0]="NONE",e[e.WRAP=1]="WRAP",e))(Ja||{}),Za=(e=>(e[e.AUTO=0]="AUTO",e[e.AT_LEAST=1]="AT_LEAST",e[e.EXACT=2]="EXACT",e))(Za||{}),Qa=(e=>(e[e.CONTENT_ALIGNMENT_UNSPECIFIED=0]="CONTENT_ALIGNMENT_UNSPECIFIED",e[e.BOTH=1]="BOTH",e[e.TOP=2]="TOP",e[e.CENTER=3]="CENTER",e[e.BOTTOM=4]="BOTTOM",e))(Qa||{}),En=(e=>(e.NORMAL="normal",e.BOLD="bold",e.ITALIC="italic",e))(En||{}),el=(e=>(e[e.PAGE=0]="PAGE",e[e.COLUMN=1]="COLUMN",e[e.CHARACTER=2]="CHARACTER",e[e.MARGIN=3]="MARGIN",e[e.INSIDE_MARGIN=4]="INSIDE_MARGIN",e[e.OUTSIDE_MARGIN=5]="OUTSIDE_MARGIN",e[e.LEFT_MARGIN=6]="LEFT_MARGIN",e[e.RIGHT_MARGIN=7]="RIGHT_MARGIN",e))(el||{}),tl=(e=>(e[e.PAGE=0]="PAGE",e[e.PARAGRAPH=1]="PARAGRAPH",e[e.LINE=2]="LINE",e[e.MARGIN=3]="MARGIN",e[e.TOP_MARGIN=4]="TOP_MARGIN",e[e.BOTTOM_MARGIN=5]="BOTTOM_MARGIN",e[e.INSIDE_MARGIN=6]="INSIDE_MARGIN",e[e.OUTSIDE_MARGIN=7]="OUTSIDE_MARGIN",e))(tl||{}),nl=(e=>(e[e.POINT=0]="POINT",e[e.LINE=1]="LINE",e[e.CHARACTER=2]="CHARACTER",e[e.PIXEL=3]="PIXEL",e[e.PERCENT=4]="PERCENT",e))(nl||{}),rl=(e=>(e[e.CENTER=0]="CENTER",e[e.INSIDE=1]="INSIDE",e[e.LEFT=2]="LEFT",e[e.OUTSIDE=3]="OUTSIDE",e[e.RIGHT=4]="RIGHT",e[e.BOTH=5]="BOTH",e[e.DISTRIBUTE=6]="DISTRIBUTE",e))(rl||{}),sl=(e=>(e[e.BOTTOM=0]="BOTTOM",e[e.CENTER=1]="CENTER",e[e.INSIDE=2]="INSIDE",e[e.OUTSIDE=3]="OUTSIDE",e[e.TOP=4]="TOP",e))(sl||{}),il=(e=>(e[e.compressPunctuation=0]="compressPunctuation",e[e.compressPunctuationAndJapaneseKana=1]="compressPunctuationAndJapaneseKana",e[e.doNotCompress=2]="doNotCompress",e))(il||{}),ol=(e=>(e[e.PORTRAIT=0]="PORTRAIT",e[e.LANDSCAPE=1]="LANDSCAPE",e))(ol||{}),al=(e=>(e[e.forward=0]="forward",e[e.backward=1]="backward",e[e.front=2]="front",e[e.back=3]="back",e))(al||{}),ll=(e=>(e[e.UNRECOGNIZED=-1]="UNRECOGNIZED",e[e.DRAWING_IMAGE=0]="DRAWING_IMAGE",e[e.DRAWING_SHAPE=1]="DRAWING_SHAPE",e[e.DRAWING_CHART=2]="DRAWING_CHART",e[e.DRAWING_TABLE=3]="DRAWING_TABLE",e[e.DRAWING_SMART_ART=4]="DRAWING_SMART_ART",e[e.DRAWING_VIDEO=5]="DRAWING_VIDEO",e[e.DRAWING_GROUP=6]="DRAWING_GROUP",e[e.DRAWING_UNIT=7]="DRAWING_UNIT",e[e.DRAWING_DOM=8]="DRAWING_DOM",e))(ll||{}),ei=(e=>(e[e.SLIDE=0]="SLIDE",e[e.MASTER=1]="MASTER",e[e.LAYOUT=2]="LAYOUT",e[e.HANDOUT_MASTER=3]="HANDOUT_MASTER",e[e.NOTES_MASTER=4]="NOTES_MASTER",e))(ei||{}),ul=(e=>(e[e.SHAPE=0]="SHAPE",e[e.IMAGE=1]="IMAGE",e[e.TEXT=2]="TEXT",e[e.SPREADSHEET=3]="SPREADSHEET",e[e.DOCUMENT=4]="DOCUMENT",e[e.SLIDE=5]="SLIDE",e))(ul||{}),cl=(e=>(e[e.RELATIVE_SLIDE_LINK_UNSPECIFIED=0]="RELATIVE_SLIDE_LINK_UNSPECIFIED",e[e.NEXT_SLIDE=1]="NEXT_SLIDE",e[e.PREVIOUS_SLIDE=2]="PREVIOUS_SLIDE",e[e.FIRST_SLIDE=3]="FIRST_SLIDE",e[e.LAST_SLIDE=4]="LAST_SLIDE",e))(cl||{}),hl=(e=>(e.PARAGRAPH="PARAGRAPH",e.SECTION_BREAK="SECTION_BREAK",e.TABLE="TABLE",e.TABLE_ROW="TABLE_ROW",e.TABLE_CELL="TABLE_CELL",e.CUSTOM_BLOCK="CUSTOM_BLOCK",e))(hl||{}),jt=(e=>(e.PARAGRAPH="\r",e.SECTION_BREAK=`
6
6
  `,e.TABLE_START="",e.TABLE_ROW_START="\x1B",e.TABLE_CELL_START="",e.TABLE_CELL_END="",e.TABLE_ROW_END="",e.TABLE_END="",e.CUSTOM_RANGE_START="",e.CUSTOM_RANGE_END="",e.COLUMN_BREAK="\v",e.PAGE_BREAK="\f",e.DOCS_END="\0",e.TAB=" ",e.CUSTOM_BLOCK="\b",e.LETTER="",e.SPACE=" ",e))(jt||{});function zd(e){return`${e}`}const Vd=[jt.TABLE_START,jt.TABLE_ROW_START,jt.TABLE_CELL_START,jt.TABLE_CELL_END,jt.TABLE_ROW_END,jt.TABLE_END],Zr=e=>{const t=e.endsWith(`\r
7
7
  `)?e.slice(0,-2):e;return Vd.reduce((n,r)=>n.replaceAll(r,""),t)},Gd=e=>e?Zr(e).replaceAll("\r","")==="":!0,Kd=e=>{const t=e.replace(/\n/g,"\r"),n=[],r=[];let s=0,i="";const o=(l,u=!0)=>{const c=t.slice(s,l);if(re.isLegalUrl(c)){const h=Ut(),d=`${c}`,f={startIndex:s,endIndex:s+d.length-1,rangeId:h,rangeType:qt.HYPERLINK,properties:{url:e}};r.push(f),i+=d,s=l+1,u&&(i+="\r",n.push({startIndex:l}))}else i+=t.slice(s,l+1),s=l+1,u&&n.push({startIndex:l})};let a=0;for(let l=0;l<t.length;l++)t[l]==="\r"&&(o(l),a=l);return(a!==t.length-1||t.length===1)&&o(t.length,!1),{dataStream:i,paragraphs:n,customRanges:r}};var dl=typeof global=="object"&&global&&global.Object===Object&&global,Xd=typeof self=="object"&&self&&self.Object===Object&&self,un=dl||Xd||Function("return this")(),On=un.Symbol,fl=Object.prototype,qd=fl.hasOwnProperty,Jd=fl.toString,Dn=On?On.toStringTag:void 0;function Zd(e){var t=qd.call(e,Dn),n=e[Dn];try{e[Dn]=void 0;var r=!0}catch{}var s=Jd.call(e);return r&&(t?e[Dn]=n:delete e[Dn]),s}var Qd=Object.prototype,ef=Qd.toString;function tf(e){return ef.call(e)}var nf="[object Null]",rf="[object Undefined]",Vi=On?On.toStringTag:void 0;function ar(e){return e==null?e===void 0?rf:nf:Vi&&Vi in Object(e)?Zd(e):tf(e)}function An(e){return e!=null&&typeof e=="object"}var sf="[object Symbol]";function Qr(e){return typeof e=="symbol"||An(e)&&ar(e)==sf}function of(e,t){for(var n=-1,r=e==null?0:e.length,s=Array(r);++n<r;)s[n]=t(e[n],n,e);return s}var wn=Array.isArray,Gi=On?On.prototype:void 0,Ki=Gi?Gi.toString:void 0;function gl(e){if(typeof e=="string")return e;if(wn(e))return of(e,gl)+"";if(Qr(e))return Ki?Ki.call(e):"";var t=e+"";return t=="0"&&1/e==-1/0?"-0":t}var af=/\s/;function lf(e){for(var t=e.length;t--&&af.test(e.charAt(t)););return t}var uf=/^\s+/;function cf(e){return e&&e.slice(0,lf(e)+1).replace(uf,"")}function Et(e){var t=typeof e;return e!=null&&(t=="object"||t=="function")}var Xi=NaN,hf=/^[-+]0x[0-9a-f]+$/i,df=/^0b[01]+$/i,ff=/^0o[0-7]+$/i,gf=parseInt;function qi(e){if(typeof e=="number")return e;if(Qr(e))return Xi;if(Et(e)){var t=typeof e.valueOf=="function"?e.valueOf():e;e=Et(t)?t+"":t}if(typeof e!="string")return e===0?e:+e;e=cf(e);var n=df.test(e);return n||ff.test(e)?gf(e.slice(2),n?2:8):hf.test(e)?Xi:+e}function ml(e){return e}var mf="[object AsyncFunction]",_f="[object Function]",pf="[object GeneratorFunction]",Ef="[object Proxy]";function ti(e){if(!Et(e))return!1;var t=ar(e);return t==_f||t==pf||t==mf||t==Ef}var ds=un["__core-js_shared__"],Ji=function(){var e=/[^.]+$/.exec(ds&&ds.keys&&ds.keys.IE_PROTO||"");return e?"Symbol(src)_1."+e:""}();function Cf(e){return!!Ji&&Ji in e}var Rf=Function.prototype,If=Rf.toString;function Sf(e){if(e!=null){try{return If.call(e)}catch{}try{return e+""}catch{}}return""}var vf=/[\\^$.*+?()[\]{}|]/g,Of=/^\[object .+?Constructor\]$/,wf=Function.prototype,bf=Object.prototype,yf=wf.toString,Af=bf.hasOwnProperty,Tf=RegExp("^"+yf.call(Af).replace(vf,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");function Nf(e){if(!Et(e)||Cf(e))return!1;var t=ti(e)?Tf:Of;return t.test(Sf(e))}function Mf(e,t){return e==null?void 0:e[t]}function ni(e,t){var n=Mf(e,t);return Nf(n)?n:void 0}var Zi=Object.create,Df=function(){function e(){}return function(t){if(!Et(t))return{};if(Zi)return Zi(t);e.prototype=t;var n=new e;return e.prototype=void 0,n}}();function Lf(e,t,n){switch(n.length){case 0:return e.call(t);case 1:return e.call(t,n[0]);case 2:return e.call(t,n[0],n[1]);case 3:return e.call(t,n[0],n[1],n[2])}return e.apply(t,n)}function xf(e,t){var n=-1,r=e.length;for(t||(t=Array(r));++n<r;)t[n]=e[n];return t}var Uf=800,kf=16,Pf=Date.now;function Ff(e){var t=0,n=0;return function(){var r=Pf(),s=kf-(r-n);if(n=r,s>0){if(++t>=Uf)return arguments[0]}else t=0;return e.apply(void 0,arguments)}}function $f(e){return function(){return e}}var Yr=function(){try{var e=ni(Object,"defineProperty");return e({},"",{}),e}catch{}}(),Bf=Yr?function(e,t){return Yr(e,"toString",{configurable:!0,enumerable:!1,value:$f(t),writable:!0})}:ml,Hf=Ff(Bf),jf=9007199254740991,Wf=/^(?:0|[1-9]\d*)$/;function ri(e,t){var n=typeof e;return t=t==null?jf:t,!!t&&(n=="number"||n!="symbol"&&Wf.test(e))&&e>-1&&e%1==0&&e<t}function si(e,t,n){t=="__proto__"&&Yr?Yr(e,t,{configurable:!0,enumerable:!0,value:n,writable:!0}):e[t]=n}function es(e,t){return e===t||e!==e&&t!==t}var Yf=Object.prototype,zf=Yf.hasOwnProperty;function _l(e,t,n){var r=e[t];(!(zf.call(e,t)&&es(r,n))||n===void 0&&!(t in e))&&si(e,t,n)}function Vf(e,t,n,r){var s=!n;n||(n={});for(var i=-1,o=t.length;++i<o;){var a=t[i],l=void 0;l===void 0&&(l=e[a]),s?si(n,a,l):_l(n,a,l)}return n}var Qi=Math.max;function Gf(e,t,n){return t=Qi(t===void 0?e.length-1:t,0),function(){for(var r=arguments,s=-1,i=Qi(r.length-t,0),o=Array(i);++s<i;)o[s]=r[t+s];s=-1;for(var a=Array(t+1);++s<t;)a[s]=r[s];return a[t]=n(o),Lf(e,this,a)}}function Kf(e,t){return Hf(Gf(e,t,ml),e+"")}var Xf=9007199254740991;function pl(e){return typeof e=="number"&&e>-1&&e%1==0&&e<=Xf}function ii(e){return e!=null&&pl(e.length)&&!ti(e)}function qf(e,t,n){if(!Et(n))return!1;var r=typeof t;return(r=="number"?ii(n)&&ri(t,n.length):r=="string"&&t in n)?es(n[t],e):!1}function El(e){return Kf(function(t,n){var r=-1,s=n.length,i=s>1?n[s-1]:void 0,o=s>2?n[2]:void 0;for(i=e.length>3&&typeof i=="function"?(s--,i):void 0,o&&qf(n[0],n[1],o)&&(i=s<3?void 0:i,s=1),t=Object(t);++r<s;){var a=n[r];a&&e(t,a,r,i)}return t})}var Jf=Object.prototype;function Cl(e){var t=e&&e.constructor,n=typeof t=="function"&&t.prototype||Jf;return e===n}function Zf(e,t){for(var n=-1,r=Array(e);++n<e;)r[n]=t(n);return r}var Qf="[object Arguments]";function eo(e){return An(e)&&ar(e)==Qf}var Rl=Object.prototype,eg=Rl.hasOwnProperty,tg=Rl.propertyIsEnumerable,Ls=eo(function(){return arguments}())?eo:function(e){return An(e)&&eg.call(e,"callee")&&!tg.call(e,"callee")};function ng(){return!1}var Il=typeof exports=="object"&&exports&&!exports.nodeType&&exports,to=Il&&typeof module=="object"&&module&&!module.nodeType&&module,rg=to&&to.exports===Il,no=rg?un.Buffer:void 0,sg=no?no.isBuffer:void 0,Sl=sg||ng,ig="[object Arguments]",og="[object Array]",ag="[object Boolean]",lg="[object Date]",ug="[object Error]",cg="[object Function]",hg="[object Map]",dg="[object Number]",fg="[object Object]",gg="[object RegExp]",mg="[object Set]",_g="[object String]",pg="[object WeakMap]",Eg="[object ArrayBuffer]",Cg="[object DataView]",Rg="[object Float32Array]",Ig="[object Float64Array]",Sg="[object Int8Array]",vg="[object Int16Array]",Og="[object Int32Array]",wg="[object Uint8Array]",bg="[object Uint8ClampedArray]",yg="[object Uint16Array]",Ag="[object Uint32Array]",Ze={};Ze[Rg]=Ze[Ig]=Ze[Sg]=Ze[vg]=Ze[Og]=Ze[wg]=Ze[bg]=Ze[yg]=Ze[Ag]=!0;Ze[ig]=Ze[og]=Ze[Eg]=Ze[ag]=Ze[Cg]=Ze[lg]=Ze[ug]=Ze[cg]=Ze[hg]=Ze[dg]=Ze[fg]=Ze[gg]=Ze[mg]=Ze[_g]=Ze[pg]=!1;function Tg(e){return An(e)&&pl(e.length)&&!!Ze[ar(e)]}function Ng(e){return function(t){return e(t)}}var vl=typeof exports=="object"&&exports&&!exports.nodeType&&exports,Vn=vl&&typeof module=="object"&&module&&!module.nodeType&&module,Mg=Vn&&Vn.exports===vl,fs=Mg&&dl.process,ro=function(){try{var e=Vn&&Vn.require&&Vn.require("util").types;return e||fs&&fs.binding&&fs.binding("util")}catch{}}(),so=ro&&ro.isTypedArray,Ol=so?Ng(so):Tg;function Dg(e,t){var n=wn(e),r=!n&&Ls(e),s=!n&&!r&&Sl(e),i=!n&&!r&&!s&&Ol(e),o=n||r||s||i,a=o?Zf(e.length,String):[],l=a.length;for(var u in e)o&&(u=="length"||s&&(u=="offset"||u=="parent")||i&&(u=="buffer"||u=="byteLength"||u=="byteOffset")||ri(u,l))||a.push(u);return a}function Lg(e,t){return function(n){return e(t(n))}}function xg(e){var t=[];if(e!=null)for(var n in Object(e))t.push(n);return t}var Ug=Object.prototype,kg=Ug.hasOwnProperty;function Pg(e){if(!Et(e))return xg(e);var t=Cl(e),n=[];for(var r in e)r=="constructor"&&(t||!kg.call(e,r))||n.push(r);return n}function wl(e){return ii(e)?Dg(e):Pg(e)}var Fg=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,$g=/^\w*$/;function Bg(e,t){if(wn(e))return!1;var n=typeof e;return n=="number"||n=="symbol"||n=="boolean"||e==null||Qr(e)?!0:$g.test(e)||!Fg.test(e)||t!=null&&e in Object(t)}var qn=ni(Object,"create");function Hg(){this.__data__=qn?qn(null):{},this.size=0}function jg(e){var t=this.has(e)&&delete this.__data__[e];return this.size-=t?1:0,t}var Wg="__lodash_hash_undefined__",Yg=Object.prototype,zg=Yg.hasOwnProperty;function Vg(e){var t=this.__data__;if(qn){var n=t[e];return n===Wg?void 0:n}return zg.call(t,e)?t[e]:void 0}var Gg=Object.prototype,Kg=Gg.hasOwnProperty;function Xg(e){var t=this.__data__;return qn?t[e]!==void 0:Kg.call(t,e)}var qg="__lodash_hash_undefined__";function Jg(e,t){var n=this.__data__;return this.size+=this.has(e)?0:1,n[e]=qn&&t===void 0?qg:t,this}function ln(e){var t=-1,n=e==null?0:e.length;for(this.clear();++t<n;){var r=e[t];this.set(r[0],r[1])}}ln.prototype.clear=Hg;ln.prototype.delete=jg;ln.prototype.get=Vg;ln.prototype.has=Xg;ln.prototype.set=Jg;function Zg(){this.__data__=[],this.size=0}function ts(e,t){for(var n=e.length;n--;)if(es(e[n][0],t))return n;return-1}var Qg=Array.prototype,em=Qg.splice;function tm(e){var t=this.__data__,n=ts(t,e);if(n<0)return!1;var r=t.length-1;return n==r?t.pop():em.call(t,n,1),--this.size,!0}function nm(e){var t=this.__data__,n=ts(t,e);return n<0?void 0:t[n][1]}function rm(e){return ts(this.__data__,e)>-1}function sm(e,t){var n=this.__data__,r=ts(n,e);return r<0?(++this.size,n.push([e,t])):n[r][1]=t,this}function Ft(e){var t=-1,n=e==null?0:e.length;for(this.clear();++t<n;){var r=e[t];this.set(r[0],r[1])}}Ft.prototype.clear=Zg;Ft.prototype.delete=tm;Ft.prototype.get=nm;Ft.prototype.has=rm;Ft.prototype.set=sm;var bl=ni(un,"Map");function im(){this.size=0,this.__data__={hash:new ln,map:new(bl||Ft),string:new ln}}function om(e){var t=typeof e;return t=="string"||t=="number"||t=="symbol"||t=="boolean"?e!=="__proto__":e===null}function ns(e,t){var n=e.__data__;return om(t)?n[typeof t=="string"?"string":"hash"]:n.map}function am(e){var t=ns(this,e).delete(e);return this.size-=t?1:0,t}function lm(e){return ns(this,e).get(e)}function um(e){return ns(this,e).has(e)}function cm(e,t){var n=ns(this,e),r=n.size;return n.set(e,t),this.size+=n.size==r?0:1,this}function Jt(e){var t=-1,n=e==null?0:e.length;for(this.clear();++t<n;){var r=e[t];this.set(r[0],r[1])}}Jt.prototype.clear=im;Jt.prototype.delete=am;Jt.prototype.get=lm;Jt.prototype.has=um;Jt.prototype.set=cm;var hm="Expected a function";function oi(e,t){if(typeof e!="function"||t!=null&&typeof t!="function")throw new TypeError(hm);var n=function(){var r=arguments,s=t?t.apply(this,r):r[0],i=n.cache;if(i.has(s))return i.get(s);var o=e.apply(this,r);return n.cache=i.set(s,o)||i,o};return n.cache=new(oi.Cache||Jt),n}oi.Cache=Jt;var dm=500;function fm(e){var t=oi(e,function(r){return n.size===dm&&n.clear(),r}),n=t.cache;return t}var gm=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,mm=/\\(\\)?/g,_m=fm(function(e){var t=[];return e.charCodeAt(0)===46&&t.push(""),e.replace(gm,function(n,r,s,i){t.push(s?i.replace(mm,"$1"):r||n)}),t});function pm(e){return e==null?"":gl(e)}function yl(e,t){return wn(e)?e:Bg(e,t)?[e]:_m(pm(e))}function Al(e){if(typeof e=="string"||Qr(e))return e;var t=e+"";return t=="0"&&1/e==-1/0?"-0":t}function Em(e,t){t=yl(t,e);for(var n=0,r=t.length;e!=null&&n<r;)e=e[Al(t[n++])];return n&&n==r?e:void 0}function Cm(e,t,n){var r=e==null?void 0:Em(e,t);return r===void 0?n:r}var Tl=Lg(Object.getPrototypeOf,Object),Rm="[object Object]",Im=Function.prototype,Sm=Object.prototype,Nl=Im.toString,vm=Sm.hasOwnProperty,Om=Nl.call(Object);function wm(e){if(!An(e)||ar(e)!=Rm)return!1;var t=Tl(e);if(t===null)return!0;var n=vm.call(t,"constructor")&&t.constructor;return typeof n=="function"&&n instanceof n&&Nl.call(n)==Om}function bm(){this.__data__=new Ft,this.size=0}function ym(e){var t=this.__data__,n=t.delete(e);return this.size=t.size,n}function Am(e){return this.__data__.get(e)}function Tm(e){return this.__data__.has(e)}var Nm=200;function Mm(e,t){var n=this.__data__;if(n instanceof Ft){var r=n.__data__;if(!bl||r.length<Nm-1)return r.push([e,t]),this.size=++n.size,this;n=this.__data__=new Jt(r)}return n.set(e,t),this.size=n.size,this}function Tn(e){var t=this.__data__=new Ft(e);this.size=t.size}Tn.prototype.clear=bm;Tn.prototype.delete=ym;Tn.prototype.get=Am;Tn.prototype.has=Tm;Tn.prototype.set=Mm;var Ml=typeof exports=="object"&&exports&&!exports.nodeType&&exports,io=Ml&&typeof module=="object"&&module&&!module.nodeType&&module,Dm=io&&io.exports===Ml,oo=Dm?un.Buffer:void 0;oo&&oo.allocUnsafe;function Lm(e,t){return e.slice()}var ao=un.Uint8Array;function xm(e){var t=new e.constructor(e.byteLength);return new ao(t).set(new ao(e)),t}function Um(e,t){var n=xm(e.buffer);return new e.constructor(n,e.byteOffset,e.length)}function km(e){return typeof e.constructor=="function"&&!Cl(e)?Df(Tl(e)):{}}function Pm(e){return function(t,n,r){for(var s=-1,i=Object(t),o=r(t),a=o.length;a--;){var l=o[++s];if(n(i[l],l,i)===!1)break}return t}}var Fm=Pm(),gs=function(){return un.Date.now()},$m="Expected a function",Bm=Math.max,Hm=Math.min;function jm(e,t,n){var r,s,i,o,a,l,u=0,c=!1,h=!1,d=!0;if(typeof e!="function")throw new TypeError($m);t=qi(t)||0,Et(n)&&(c=!!n.leading,h="maxWait"in n,i=h?Bm(qi(n.maxWait)||0,t):i,d="trailing"in n?!!n.trailing:d);function f(A){var j=r,Z=s;return r=s=void 0,u=A,o=e.apply(Z,j),o}function E(A){return u=A,a=setTimeout(L,t),c?f(A):o}function R(A){var j=A-l,Z=A-u,fe=t-j;return h?Hm(fe,i-Z):fe}function w(A){var j=A-l,Z=A-u;return l===void 0||j>=t||j<0||h&&Z>=i}function L(){var A=gs();if(w(A))return J(A);a=setTimeout(L,R(A))}function J(A){return a=void 0,d&&r?f(A):(r=s=void 0,o)}function z(){a!==void 0&&clearTimeout(a),u=0,r=l=s=a=void 0}function de(){return a===void 0?o:J(gs())}function N(){var A=gs(),j=w(A);if(r=arguments,s=this,l=A,j){if(a===void 0)return E(l);if(h)return clearTimeout(a),a=setTimeout(L,t),f(l)}return a===void 0&&(a=setTimeout(L,t)),o}return N.cancel=z,N.flush=de,N}function xs(e,t,n){(n!==void 0&&!es(e[t],n)||n===void 0&&!(t in e))&&si(e,t,n)}function Wm(e){return An(e)&&ii(e)}function Us(e,t){if(!(t==="constructor"&&typeof e[t]=="function")&&t!="__proto__")return e[t]}function Ym(e){return Vf(e,wl(e))}function zm(e,t,n,r,s,i,o){var a=Us(e,n),l=Us(t,n),u=o.get(l);if(u){xs(e,n,u);return}var c=i?i(a,l,n+"",e,t,o):void 0,h=c===void 0;if(h){var d=wn(l),f=!d&&Sl(l),E=!d&&!f&&Ol(l);c=l,d||f||E?wn(a)?c=a:Wm(a)?c=xf(a):f?(h=!1,c=Lm(l)):E?(h=!1,c=Um(l)):c=[]:wm(l)||Ls(l)?(c=a,Ls(a)?c=Ym(a):(!Et(a)||ti(a))&&(c=km(l))):h=!1}h&&(o.set(l,c),s(c,l,r,i,o),o.delete(l)),xs(e,n,c)}function ai(e,t,n,r,s){e!==t&&Fm(t,function(i,o){if(s||(s=new Tn),Et(i))zm(e,t,o,n,ai,r,s);else{var a=r?r(Us(e,o),i,o+"",e,t,s):void 0;a===void 0&&(a=i),xs(e,o,a)}},wl)}var Vm=El(function(e,t,n,r){ai(e,t,n,r)}),li=El(function(e,t,n){ai(e,t,n)});function Gm(e,t,n,r){if(!Et(e))return e;t=yl(t,e);for(var s=-1,i=t.length,o=i-1,a=e;a!=null&&++s<i;){var l=Al(t[s]),u=n;if(l==="__proto__"||l==="constructor"||l==="prototype")return e;if(s!=o){var c=a[l];u=void 0,u===void 0&&(u=Et(c)?c:ri(t[s+1])?[]:{})}_l(a,l,u),a=a[l]}return e}function Km(e,t,n){return e==null?e:Gm(e,t,n)}var ms,lo;function Xm(){if(lo)return ms;lo=1;var e=-1,t=1,n=0;function r(_,H,v,M,b){if(_===H)return _?[[n,_]]:[];if(v!=null){var O=fe(_,H,v);if(O)return O}var P=a(_,H),$=_.substring(0,P);_=_.substring(P),H=H.substring(P),P=u(_,H);var V=_.substring(_.length-P);_=_.substring(0,_.length-P),H=H.substring(0,H.length-P);var se=s(_,H);return $&&se.unshift([n,$]),V&&se.push([n,V]),J(se,b),M&&h(se),se}function s(_,H){var v;if(!_)return[[t,H]];if(!H)return[[e,_]];var M=_.length>H.length?_:H,b=_.length>H.length?H:_,O=M.indexOf(b);if(O!==-1)return v=[[t,M.substring(0,O)],[n,b],[t,M.substring(O+b.length)]],_.length>H.length&&(v[0][0]=v[2][0]=e),v;if(b.length===1)return[[e,_],[t,H]];var P=c(_,H);if(P){var $=P[0],V=P[1],se=P[2],he=P[3],ge=P[4],Te=r($,se),ye=r(V,he);return Te.concat([[n,ge]],ye)}return i(_,H)}function i(_,H){for(var v=_.length,M=H.length,b=Math.ceil((v+M)/2),O=b,P=2*b,$=new Array(P),V=new Array(P),se=0;se<P;se++)$[se]=-1,V[se]=-1;$[O+1]=0,V[O+1]=0;for(var he=v-M,ge=he%2!==0,Te=0,ye=0,S=0,F=0,G=0;G<b;G++){for(var X=-G+Te;X<=G-ye;X+=2){var Y=O+X,W;X===-G||X!==G&&$[Y-1]<$[Y+1]?W=$[Y+1]:W=$[Y-1]+1;for(var le=W-X;W<v&&le<M&&_.charAt(W)===H.charAt(le);)W++,le++;if($[Y]=W,W>v)ye+=2;else if(le>M)Te+=2;else if(ge){var oe=O+he-X;if(oe>=0&&oe<P&&V[oe]!==-1){var B=v-V[oe];if(W>=B)return o(_,H,W,le)}}}for(var te=-G+S;te<=G-F;te+=2){var oe=O+te,B;te===-G||te!==G&&V[oe-1]<V[oe+1]?B=V[oe+1]:B=V[oe-1]+1;for(var ie=B-te;B<v&&ie<M&&_.charAt(v-B-1)===H.charAt(M-ie-1);)B++,ie++;if(V[oe]=B,B>v)F+=2;else if(ie>M)S+=2;else if(!ge){var Y=O+he-te;if(Y>=0&&Y<P&&$[Y]!==-1){var W=$[Y],le=O+W-Y;if(B=v-B,W>=B)return o(_,H,W,le)}}}}return[[e,_],[t,H]]}function o(_,H,v,M){var b=_.substring(0,v),O=H.substring(0,M),P=_.substring(v),$=H.substring(M),V=r(b,O),se=r(P,$);return V.concat(se)}function a(_,H){if(!_||!H||_.charAt(0)!==H.charAt(0))return 0;for(var v=0,M=Math.min(_.length,H.length),b=M,O=0;v<b;)_.substring(O,b)==H.substring(O,b)?(v=b,O=v):M=b,b=Math.floor((M-v)/2+v);return z(_.charCodeAt(b-1))&&b--,b}function l(_,H){var v=_.length,M=H.length;if(v==0||M==0)return 0;v>M?_=_.substring(v-M):v<M&&(H=H.substring(0,v));var b=Math.min(v,M);if(_==H)return b;for(var O=0,P=1;;){var $=_.substring(b-P),V=H.indexOf($);if(V==-1)return O;P+=V,(V==0||_.substring(b-P)==H.substring(0,P))&&(O=P,P++)}}function u(_,H){if(!_||!H||_.slice(-1)!==H.slice(-1))return 0;for(var v=0,M=Math.min(_.length,H.length),b=M,O=0;v<b;)_.substring(_.length-b,_.length-O)==H.substring(H.length-b,H.length-O)?(v=b,O=v):M=b,b=Math.floor((M-v)/2+v);return de(_.charCodeAt(_.length-b))&&b--,b}function c(_,H){var v=_.length>H.length?_:H,M=_.length>H.length?H:_;if(v.length<4||M.length*2<v.length)return null;function b(ye,S,F){for(var G=ye.substring(F,F+Math.floor(ye.length/4)),X=-1,Y="",W,le,oe,B;(X=S.indexOf(G,X+1))!==-1;){var te=a(ye.substring(F),S.substring(X)),ie=u(ye.substring(0,F),S.substring(0,X));Y.length<ie+te&&(Y=S.substring(X-ie,X)+S.substring(X,X+te),W=ye.substring(0,F-ie),le=ye.substring(F+te),oe=S.substring(0,X-ie),B=S.substring(X+te))}return Y.length*2>=ye.length?[W,le,oe,B,Y]:null}var O=b(v,M,Math.ceil(v.length/4)),P=b(v,M,Math.ceil(v.length/2)),$;if(!O&&!P)return null;P?O?$=O[4].length>P[4].length?O:P:$=P:$=O;var V,se,he,ge;_.length>H.length?(V=$[0],se=$[1],he=$[2],ge=$[3]):(he=$[0],ge=$[1],V=$[2],se=$[3]);var Te=$[4];return[V,se,he,ge,Te]}function h(_){for(var H=!1,v=[],M=0,b=null,O=0,P=0,$=0,V=0,se=0;O<_.length;)_[O][0]==n?(v[M++]=O,P=V,$=se,V=0,se=0,b=_[O][1]):(_[O][0]==t?V+=_[O][1].length:se+=_[O][1].length,b&&b.length<=Math.max(P,$)&&b.length<=Math.max(V,se)&&(_.splice(v[M-1],0,[e,b]),_[v[M-1]+1][0]=t,M--,M--,O=M>0?v[M-1]:-1,P=0,$=0,V=0,se=0,b=null,H=!0)),O++;for(H&&J(_),L(_),O=1;O<_.length;){if(_[O-1][0]==e&&_[O][0]==t){var he=_[O-1][1],ge=_[O][1],Te=l(he,ge),ye=l(ge,he);Te>=ye?(Te>=he.length/2||Te>=ge.length/2)&&(_.splice(O,0,[n,ge.substring(0,Te)]),_[O-1][1]=he.substring(0,he.length-Te),_[O+1][1]=ge.substring(Te),O++):(ye>=he.length/2||ye>=ge.length/2)&&(_.splice(O,0,[n,he.substring(0,ye)]),_[O-1][0]=t,_[O-1][1]=ge.substring(0,ge.length-ye),_[O+1][0]=e,_[O+1][1]=he.substring(ye),O++),O++}O++}}var d=/[^a-zA-Z0-9]/,f=/\s/,E=/[\r\n]/,R=/\n\r?\n$/,w=/^\r?\n\r?\n/;function L(_){function H(ye,S){if(!ye||!S)return 6;var F=ye.charAt(ye.length-1),G=S.charAt(0),X=F.match(d),Y=G.match(d),W=X&&F.match(f),le=Y&&G.match(f),oe=W&&F.match(E),B=le&&G.match(E),te=oe&&ye.match(R),ie=B&&S.match(w);return te||ie?5:oe||B?4:X&&!W&&le?3:W||le?2:X||Y?1:0}for(var v=1;v<_.length-1;){if(_[v-1][0]==n&&_[v+1][0]==n){var M=_[v-1][1],b=_[v][1],O=_[v+1][1],P=u(M,b);if(P){var $=b.substring(b.length-P);M=M.substring(0,M.length-P),b=$+b.substring(0,b.length-P),O=$+O}for(var V=M,se=b,he=O,ge=H(M,b)+H(b,O);b.charAt(0)===O.charAt(0);){M+=b.charAt(0),b=b.substring(1)+O.charAt(0),O=O.substring(1);var Te=H(M,b)+H(b,O);Te>=ge&&(ge=Te,V=M,se=b,he=O)}_[v-1][1]!=V&&(V?_[v-1][1]=V:(_.splice(v-1,1),v--),_[v][1]=se,he?_[v+1][1]=he:(_.splice(v+1,1),v--))}v++}}function J(_,H){_.push([n,""]);for(var v=0,M=0,b=0,O="",P="",$;v<_.length;){if(v<_.length-1&&!_[v][1]){_.splice(v,1);continue}switch(_[v][0]){case t:b++,P+=_[v][1],v++;break;case e:M++,O+=_[v][1],v++;break;case n:var V=v-b-M-1;if(H){if(V>=0&&A(_[V][1])){var se=_[V][1].slice(-1);if(_[V][1]=_[V][1].slice(0,-1),O=se+O,P=se+P,!_[V][1]){_.splice(V,1),v--;var he=V-1;_[he]&&_[he][0]===t&&(b++,P=_[he][1]+P,he--),_[he]&&_[he][0]===e&&(M++,O=_[he][1]+O,he--),V=he}}if(N(_[v][1])){var se=_[v][1].charAt(0);_[v][1]=_[v][1].slice(1),O+=se,P+=se}}if(v<_.length-1&&!_[v][1]){_.splice(v,1);break}if(O.length>0||P.length>0){O.length>0&&P.length>0&&($=a(P,O),$!==0&&(V>=0?_[V][1]+=P.substring(0,$):(_.splice(0,0,[n,P.substring(0,$)]),v++),P=P.substring($),O=O.substring($)),$=u(P,O),$!==0&&(_[v][1]=P.substring(P.length-$)+_[v][1],P=P.substring(0,P.length-$),O=O.substring(0,O.length-$)));var ge=b+M;O.length===0&&P.length===0?(_.splice(v-ge,ge),v=v-ge):O.length===0?(_.splice(v-ge,ge,[t,P]),v=v-ge+1):P.length===0?(_.splice(v-ge,ge,[e,O]),v=v-ge+1):(_.splice(v-ge,ge,[e,O],[t,P]),v=v-ge+2)}v!==0&&_[v-1][0]===n?(_[v-1][1]+=_[v][1],_.splice(v,1)):v++,b=0,M=0,O="",P="";break}}_[_.length-1][1]===""&&_.pop();var Te=!1;for(v=1;v<_.length-1;)_[v-1][0]===n&&_[v+1][0]===n&&(_[v][1].substring(_[v][1].length-_[v-1][1].length)===_[v-1][1]?(_[v][1]=_[v-1][1]+_[v][1].substring(0,_[v][1].length-_[v-1][1].length),_[v+1][1]=_[v-1][1]+_[v+1][1],_.splice(v-1,1),Te=!0):_[v][1].substring(0,_[v+1][1].length)==_[v+1][1]&&(_[v-1][1]+=_[v+1][1],_[v][1]=_[v][1].substring(_[v+1][1].length)+_[v+1][1],_.splice(v+1,1),Te=!0)),v++;Te&&J(_,H)}function z(_){return _>=55296&&_<=56319}function de(_){return _>=56320&&_<=57343}function N(_){return de(_.charCodeAt(0))}function A(_){return z(_.charCodeAt(_.length-1))}function j(_){for(var H=[],v=0;v<_.length;v++)_[v][1].length>0&&H.push(_[v]);return H}function Z(_,H,v,M){return A(_)||N(M)?null:j([[n,_],[e,H],[t,v],[n,M]])}function fe(_,H,v){var M=typeof v=="number"?{index:v,length:0}:v.oldRange,b=typeof v=="number"?null:v.newRange,O=_.length,P=H.length;if(M.length===0&&(b===null||b.length===0)){var $=M.index,V=_.slice(0,$),se=_.slice($),he=b?b.index:null;e:{var ge=$+P-O;if(he!==null&&he!==ge||ge<0||ge>P)break e;var Te=H.slice(0,ge),ye=H.slice(ge);if(ye!==se)break e;var S=Math.min($,ge),F=V.slice(0,S),G=Te.slice(0,S);if(F!==G)break e;var X=V.slice(S),Y=Te.slice(S);return Z(F,X,Y,se)}e:{if(he!==null&&he!==$)break e;var W=$,Te=H.slice(0,W),ye=H.slice(W);if(Te!==V)break e;var le=Math.min(O-W,P-W),oe=se.slice(se.length-le),B=ye.slice(ye.length-le);if(oe!==B)break e;var X=se.slice(0,se.length-le),Y=ye.slice(0,ye.length-le);return Z(V,X,Y,oe)}}if(M.length>0&&b&&b.length===0)e:{var F=_.slice(0,M.index),oe=_.slice(M.index+M.length),S=F.length,le=oe.length;if(P<S+le)break e;var G=H.slice(0,S),B=H.slice(P-le);if(F!==G||oe!==B)break e;var X=_.slice(S,O-le),Y=H.slice(S,P-le);return Z(F,X,Y,oe)}return null}function ae(_,H,v,M){return r(_,H,v,M,!0)}return ae.INSERT=t,ae.DELETE=e,ae.EQUAL=n,ms=ae,ms}var qm=Xm();const ui=Ct(qm),Jm=new Set(["true","false"]);function Zm(e){return Jm.has(e.toLowerCase())}function Dl(e,t){if(Object.is(e,t))return!0;if(typeof e!="object"||!e||typeof t!="object"||!t)return!1;const n=Object.keys(e),r=Object.keys(t);if(n.length!==r.length)return!1;const s=Object.prototype.hasOwnProperty.bind(t);for(let i=0;i<n.length;i++){const o=n[i];if(!s(o))return!1;const a=e[o],l=t[o];if(a!==l)return!1}return!0}var $e=(e=>(e[e.UNIVER_UNKNOWN=0]="UNIVER_UNKNOWN",e[e.UNIVER_DOC=1]="UNIVER_DOC",e[e.UNIVER_SHEET=2]="UNIVER_SHEET",e[e.UNIVER_SLIDE=3]="UNIVER_SLIDE",e[e.UNIVER_PROJECT=4]="UNIVER_PROJECT",e[e.UNRECOGNIZED=-1]="UNRECOGNIZED",e))($e||{}),Nt=(e=>(e[e.Reader=0]="Reader",e[e.Editor=1]="Editor",e[e.Owner=2]="Owner",e[e.UNRECOGNIZED=-1]="UNRECOGNIZED",e))(Nt||{}),ks=(e=>(e[e.SomeCollaborator=0]="SomeCollaborator",e[e.AllCollaborator=1]="AllCollaborator",e[e.OneSelf=2]="OneSelf",e[e.UNRECOGNIZED=-1]="UNRECOGNIZED",e))(ks||{});class rs extends rt{}function Qm(e=re.generateRandomId(6),t=rr.EN_US,n=""){return{id:e,locale:t,title:n,tableSource:{},drawings:{},drawingsOrder:[],headers:{},footers:{},body:{dataStream:`\r
8
- `,textRuns:[],customBlocks:[],tables:[],paragraphs:[{startIndex:0,paragraphStyle:{spaceAbove:{v:5},lineSpacing:1,spaceBelow:{v:0}}}],sectionBreaks:[{startIndex:1}]},documentStyle:{pageSize:{width:793.3333333333334,height:1122.6666666666667},documentFlavor:Qs.TRADITIONAL,marginTop:50,marginBottom:50,marginRight:50,marginLeft:50,renderConfig:{zeroWidthParagraphBreak:Ie.FALSE,vertexAngle:0,centerAngle:0,background:{rgb:"#ccc"}},autoHyphenation:Ie.TRUE,doNotHyphenateCaps:Ie.FALSE,consecutiveHyphenLimit:2,defaultHeaderId:"",defaultFooterId:"",evenPageHeaderId:"",evenPageFooterId:"",firstPageHeaderId:"",firstPageFooterId:"",evenAndOddHeaders:Ie.FALSE,useFirstPageHeaderFooter:Ie.FALSE,marginHeader:30,marginFooter:30},settings:{}}}var Qt={},Ln={},Cr={},uo;function e_(){if(uo)return Cr;uo=1,Object.defineProperty(Cr,"__esModule",{value:!0});function e(r,s){if(Array.isArray(s))return!1;for(let i in r)if(!n(r[i],s[i]))return!1;for(let i in s)if(r[i]===void 0)return!1;return!0}function t(r,s){if(!Array.isArray(s)||r.length!==s.length)return!1;for(let i=0;i<r.length;i++)if(!n(r[i],s[i]))return!1;return!0}function n(r,s){return r===s?!0:r===null||s===null||typeof r!="object"||typeof s!="object"?!1:Array.isArray(r)?t(r,s):e(r,s)}return Cr.default=n,Cr}var Rr={},co;function t_(){if(co)return Rr;co=1,Object.defineProperty(Rr,"__esModule",{value:!0});function e(t){if(t===null)return null;if(Array.isArray(t))return t.map(e);if(typeof t=="object"){const n={};for(let r in t)n[r]=e(t[r]);return n}else return t}return Rr.default=e,Rr}var _s={},ho;function Ll(){return ho||(ho=1,function(e){Object.defineProperty(e,"__esModule",{value:!0}),e.eachChildOf=e.advancer=e.readCursor=e.writeCursor=e.WriteCursor=e.ReadCursor=e.isValidPathItem=void 0;function t(c,h){if(!c)throw new Error(h)}const n=c=>c!=null&&typeof c=="object"&&!Array.isArray(c),r=(c,h)=>typeof c==typeof h?c>h:typeof c=="string"&&typeof h=="number";function s(c,h){for(let d in c){const f=d;h.write(f,c[f])}}e.isValidPathItem=c=>typeof c=="number"||typeof c=="string"&&c!=="__proto__";class i{constructor(h=null){this.parents=[],this.indexes=[],this.lcIdx=-1,this.idx=-1,this.container=h}ascend(){t(this.parents.length===this.indexes.length/2),this.idx===0?this.parents.length?(this.lcIdx=this.indexes.pop(),this.container=this.parents.pop(),this.idx=this.indexes.pop()):(this.lcIdx=0,this.idx=-1):(t(this.idx>0),this.idx--,n(this.container[this.idx])&&this.idx--)}getPath(){const h=[];let d=this.container,f=this.parents.length-1,E=this.idx;for(;E>=0;)h.unshift(d[E]),E===0?(E=this.indexes[f*2],d=this.parents[f--]):E-=n(d[E-1])?2:1;return h}}class o extends i{get(){return this.container?this.container.slice(this.idx+1):null}getKey(){return t(this.container!=null,"Invalid call to getKey before cursor descended"),this.container[this.idx]}getComponent(){let h;return this.container&&this.container.length>this.idx+1&&n(h=this.container[this.idx+1])?h:null}descendFirst(){let h=this.idx+1;if(!this.container||h>=this.container.length||n(this.container[h])&&h+1>=this.container.length)return!1;n(this.container[h])&&h++;const d=this.container[h];return Array.isArray(d)?(this.indexes.push(this.idx),this.parents.push(this.container),this.indexes.push(h),this.idx=0,this.container=d):this.idx=h,!0}nextSibling(){if(t(this.parents.length===this.indexes.length/2),this.idx>0||this.parents.length===0)return!1;const h=this.indexes[this.indexes.length-1]+1,d=this.parents[this.parents.length-1];return h>=d.length?!1:(t(!isNaN(h)),this.indexes[this.indexes.length-1]=h,this.container=d[h],!0)}_init(h,d,f,E){this.container=h,this.idx=d,this.parents=f.slice(),this.indexes=E.slice()}clone(){const h=new o;return h._init(this.container,this.idx,this.parents,this.indexes),h}*[Symbol.iterator](){if(this.descendFirst()){do yield this.getKey();while(this.nextSibling());this.ascend()}}traverse(h,d){const f=this.getComponent();f&&d(f,h);for(const E of this)h&&h.descend(E),this.traverse(h,d),h&&h.ascend()}eachPick(h,d){this.traverse(h,(f,E)=>{f.p!=null&&d(f.p,E)})}eachDrop(h,d){this.traverse(h,(f,E)=>{f.d!=null&&d(f.d,E)})}}e.ReadCursor=o;class a extends i{constructor(h=null){super(h),this.pendingDescent=[],this._op=h}flushDescent(){t(this.parents.length===this.indexes.length/2),this.container===null&&(this._op=this.container=[]);for(let h=0;h<this.pendingDescent.length;h++){const d=this.pendingDescent[h];let f=this.idx+1;if(f<this.container.length&&n(this.container[f])&&f++,t(f===this.container.length||!n(this.container[f])),f===this.container.length)this.container.push(d),this.idx=f;else if(this.container[f]===d)this.idx=f;else{if(!Array.isArray(this.container[f])){const E=this.container.splice(f,this.container.length-f);this.container.push(E),this.lcIdx>-1&&(this.lcIdx=f)}for(this.indexes.push(this.idx),this.parents.push(this.container),this.lcIdx!==-1&&(t(r(d,this.container[this.lcIdx][0])),f=this.lcIdx+1,this.lcIdx=-1);f<this.container.length&&r(d,this.container[f][0]);)f++;if(this.indexes.push(f),this.idx=0,f<this.container.length&&this.container[f][0]===d)this.container=this.container[f];else{const E=[d];this.container.splice(f,0,E),this.container=E}}}this.pendingDescent.length=0}reset(){this.lcIdx=-1}getComponent(){this.flushDescent();const h=this.idx+1;if(h<this.container.length&&n(this.container[h]))return this.container[h];{const d={};return this.container.splice(h,0,d),d}}write(h,d){const f=this.getComponent();t(f[h]==null||f[h]===d,"Internal consistency error: Overwritten component. File a bug"),f[h]=d}get(){return this._op}descend(h){if(!e.isValidPathItem(h))throw Error("Invalid JSON key");this.pendingDescent.push(h)}descendPath(h){return this.pendingDescent.push(...h),this}ascend(){this.pendingDescent.length?this.pendingDescent.pop():super.ascend()}mergeTree(h,d=s){if(h===null)return;if(t(Array.isArray(h)),h===this._op)throw Error("Cannot merge into my own tree");const f=this.lcIdx,E=this.parents.length;let R=0;for(let w=0;w<h.length;w++){const L=h[w];typeof L=="string"||typeof L=="number"?(R++,this.descend(L)):Array.isArray(L)?this.mergeTree(L,d):typeof L=="object"&&d(L,this)}for(;R--;)this.ascend();this.lcIdx=this.parents.length===E?f:-1}at(h,d){this.descendPath(h),d(this);for(let f=0;f<h.length;f++)this.ascend();return this}writeAtPath(h,d,f){return this.at(h,()=>this.write(d,f)),this.reset(),this}writeMove(h,d,f=0){return this.writeAtPath(h,"p",f).writeAtPath(d,"d",f)}getPath(){const h=super.getPath();return h.push(...this.pendingDescent),h}}e.WriteCursor=a,e.writeCursor=()=>new a,e.readCursor=c=>new o(c);function l(c,h,d){let f,E;E=f=c?c.descendFirst():!1;function R(w){let L;for(;E;){const J=L=c.getKey();if(w!=null){let z=!1;if(h&&typeof J=="number"&&(L=h(J,c.getComponent()),L<0&&(L=~L,z=!0)),r(L,w))return null;if(L===w&&!z)return c}d&&typeof L=="number"&&d(L,c.getComponent()),E=c.nextSibling()}return null}return R.end=()=>{f&&c.ascend()},R}e.advancer=l;function u(c,h,d){let f,E,R,w;for(f=E=c&&c.descendFirst(),R=w=h&&h.descendFirst();f||R;){let L=f?c.getKey():null,J=R?h.getKey():null;L!==null&&J!==null&&(r(J,L)?J=null:L!==J&&(L=null)),d(L==null?J:L,L!=null?c:null,J!=null?h:null),L!=null&&f&&(f=c.nextSibling()),J!=null&&R&&(R=h.nextSibling())}E&&c.ascend(),w&&h.ascend()}e.eachChildOf=u}(_s)),_s}var ps={},fo;function xl(){return fo||(fo=1,function(e){Object.defineProperty(e,"__esModule",{value:!0}),e.ConflictType=void 0,function(t){t[t.RM_UNEXPECTED_CONTENT=1]="RM_UNEXPECTED_CONTENT",t[t.DROP_COLLISION=2]="DROP_COLLISION",t[t.BLACKHOLE=3]="BLACKHOLE"}(e.ConflictType||(e.ConflictType={}))}(ps)),ps}var It={},en={},go;function ci(){return go||(go=1,Object.defineProperty(en,"__esModule",{value:!0}),en.uniToStrPos=en.strPosToUni=void 0,en.strPosToUni=(e,t=e.length)=>{let n=0,r=0;for(;r<t;r++){const s=e.charCodeAt(r);s>=55296&&s<=57343&&(n++,r++)}if(r!==t)throw Error("Invalid offset - splits unicode bytes");return r-n},en.uniToStrPos=(e,t)=>{let n=0;for(;t>0;t--){const r=e.charCodeAt(n);n+=r>=55296&&r<=57343?2:1}return n}),en}var Es={},mo;function Ps(){return mo||(mo=1,function(e){Object.defineProperty(e,"__esModule",{value:!0}),e.uniSlice=e.dlen=e.eachOp=void 0;const t=ci(),n=N=>{if(!Array.isArray(N))throw Error("Op must be an array of components");let A=null;for(let j=0;j<N.length;j++){const Z=N[j];switch(typeof Z){case"object":if(typeof Z.d!="number"&&typeof Z.d!="string")throw Error("Delete must be number or string");if(e.dlen(Z.d)<=0)throw Error("Deletes must not be empty");break;case"string":if(!(Z.length>0))throw Error("Inserts cannot be empty");break;case"number":if(!(Z>0))throw Error("Skip components must be >0");if(typeof A=="number")throw Error("Adjacent skip components should be combined");break}A=Z}if(typeof A=="number")throw Error("Op has a trailing skip")};function r(N,A){let j=0,Z=0;for(let fe=0;fe<N.length;fe++){const ae=N[fe];switch(A(ae,j,Z),typeof ae){case"object":j+=e.dlen(ae.d);break;case"string":Z+=t.strPosToUni(ae);break;case"number":j+=ae,Z+=ae;break}}}e.eachOp=r;function s(N,A){const j=[],Z=a(j);return r(N,(fe,ae,_)=>{Z(A(fe,ae,_))}),h(j)}const i=N=>N,o=N=>s(N,i);e.dlen=N=>typeof N=="number"?N:t.strPosToUni(N);const a=N=>A=>{if(!(!A||A.d===0||A.d===""))if(N.length===0)N.push(A);else if(typeof A==typeof N[N.length-1])if(typeof A=="object"){const j=N[N.length-1];j.d=typeof j.d=="string"&&typeof A.d=="string"?j.d+A.d:e.dlen(j.d)+e.dlen(A.d)}else N[N.length-1]+=A;else N.push(A)},l=N=>typeof N=="number"?N:typeof N=="string"?t.strPosToUni(N):typeof N.d=="number"?N.d:t.strPosToUni(N.d);e.uniSlice=(N,A,j)=>{const Z=t.uniToStrPos(N,A),fe=j==null?1/0:t.uniToStrPos(N,j);return N.slice(Z,fe)};const u=(N,A,j)=>typeof N=="number"?j==null?N-A:Math.min(N,j)-A:e.uniSlice(N,A,j),c=N=>{let A=0,j=0;return{take:(ae,_)=>{if(A===N.length)return ae===-1?null:ae;const H=N[A];let v;if(typeof H=="number")return ae===-1||H-j<=ae?(v=H-j,++A,j=0,v):(j+=ae,ae);if(typeof H=="string"){if(ae===-1||_==="i"||t.strPosToUni(H.slice(j))<=ae)return v=H.slice(j),++A,j=0,v;{const M=j+t.uniToStrPos(H.slice(j),ae);return v=H.slice(j,M),j=M,v}}else{if(ae===-1||_==="d"||e.dlen(H.d)-j<=ae)return v={d:u(H.d,j)},++A,j=0,v;{let M=u(H.d,j,j+ae);return j+=ae,{d:M}}}},peek:()=>N[A]}},h=N=>(N.length>0&&typeof N[N.length-1]=="number"&&N.pop(),N);function d(N,A,j){if(j!=="left"&&j!=="right")throw Error("side ("+j+") must be 'left' or 'right'");n(N),n(A);const Z=[],fe=a(Z),{take:ae,peek:_}=c(N);for(let v=0;v<A.length;v++){const M=A[v];let b,O;switch(typeof M){case"number":for(b=M;b>0;)O=ae(b,"i"),fe(O),typeof O!="string"&&(b-=l(O));break;case"string":j==="left"&&typeof _()=="string"&&fe(ae(-1)),fe(t.strPosToUni(M));break;case"object":for(b=e.dlen(M.d);b>0;)switch(O=ae(b,"i"),typeof O){case"number":b-=O;break;case"string":fe(O);break;case"object":b-=e.dlen(O.d)}break}}let H;for(;H=ae(-1);)fe(H);return h(Z)}function f(N,A){n(N),n(A);const j=[],Z=a(j),{take:fe}=c(N);for(let _=0;_<A.length;_++){const H=A[_];let v,M;switch(typeof H){case"number":for(v=H;v>0;)M=fe(v,"d"),Z(M),typeof M!="object"&&(v-=l(M));break;case"string":Z(H);break;case"object":v=e.dlen(H.d);let b=0;for(;b<v;)switch(M=fe(v-b,"d"),typeof M){case"number":Z({d:u(H.d,b,b+M)}),b+=M;break;case"string":b+=t.strPosToUni(M);break;case"object":Z(M)}break}}let ae;for(;ae=fe(-1);)Z(ae);return h(j)}const E=(N,A)=>{let j=0;for(let Z=0;Z<A.length&&N>j;Z++){const fe=A[Z];switch(typeof fe){case"number":{j+=fe;break}case"string":const ae=t.strPosToUni(fe);j+=ae,N+=ae;break;case"object":N-=Math.min(e.dlen(fe.d),N-j);break}}return N},R=(N,A)=>typeof N=="number"?E(N,A):N.map(j=>E(j,A));function w(N,A,j){return s(N,(Z,fe)=>typeof Z=="object"&&typeof Z.d=="number"?{d:j.slice(A,fe,fe+Z.d)}:Z)}function L(N){return s(N,A=>{switch(typeof A){case"object":if(typeof A.d=="number")throw Error("Cannot invert text op: Deleted characters missing from operation. makeInvertible must be called first.");return A.d;case"string":return{d:A};case"number":return A}})}function J(N){return s(N,A=>typeof A=="object"&&typeof A.d=="string"?{d:t.strPosToUni(A.d)}:A)}function z(N){let A=!0;return r(N,j=>{typeof j=="object"&&typeof j.d=="number"&&(A=!1)}),A}function de(N){return{name:"text-unicode",uri:"http://sharejs.org/types/text-unicode",trim:h,normalize:o,checkOp:n,create(A=""){if(typeof A!="string")throw Error("Initial data must be a string");return N.create(A)},apply(A,j){n(j);const Z=N.builder(A);for(let fe=0;fe<j.length;fe++){const ae=j[fe];switch(typeof ae){case"number":Z.skip(ae);break;case"string":Z.append(ae);break;case"object":Z.del(e.dlen(ae.d));break}}return Z.build()},transform:d,compose:f,transformPosition:E,transformSelection:R,isInvertible:z,makeInvertible(A,j){return w(A,j,N)},stripInvertible:J,invert:L,invertWithDoc(A,j){return L(w(A,j,N))},isNoop:A=>A.length===0}}e.default=de}(Es)),Es}var Ir={},_o;function n_(){if(_o)return Ir;_o=1,Object.defineProperty(Ir,"__esModule",{value:!0});const e=Ps(),t=ci();function n(r,s){return{get:r,getLength(){return r().length},insert(i,o,a){const l=t.strPosToUni(r(),i);return s([l,o],a)},remove(i,o,a){const l=t.strPosToUni(r(),i);return s([l,{d:o}],a)},_onOp(i){e.eachOp(i,(o,a,l)=>{switch(typeof o){case"string":this.onInsert&&this.onInsert(l,o);break;case"object":const u=e.dlen(o.d);this.onRemove&&this.onRemove(l,u)}})},onInsert:null,onRemove:null}}return Ir.default=n,n.provides={text:!0},Ir}var po;function r_(){return po||(po=1,function(e){var t=It&&It.__createBinding||(Object.create?function(d,f,E,R){R===void 0&&(R=E),Object.defineProperty(d,R,{enumerable:!0,get:function(){return f[E]}})}:function(d,f,E,R){R===void 0&&(R=E),d[R]=f[E]}),n=It&&It.__setModuleDefault||(Object.create?function(d,f){Object.defineProperty(d,"default",{enumerable:!0,value:f})}:function(d,f){d.default=f}),r=It&&It.__importStar||function(d){if(d&&d.__esModule)return d;var f={};if(d!=null)for(var E in d)Object.hasOwnProperty.call(d,E)&&t(f,d,E);return n(f,d),f},s=It&&It.__importDefault||function(d){return d&&d.__esModule?d:{default:d}};Object.defineProperty(e,"__esModule",{value:!0}),e.type=e.remove=e.insert=void 0;const i=ci(),o=r(Ps()),a=s(n_()),l={create(d){return d},toString(d){return d},builder(d){if(typeof d!="string")throw Error("Invalid document snapshot: "+d);const f=[];return{skip(E){let R=i.uniToStrPos(d,E);if(R>d.length)throw Error("The op is too long for this document");f.push(d.slice(0,R)),d=d.slice(R)},append(E){f.push(E)},del(E){d=d.slice(i.uniToStrPos(d,E))},build(){return f.join("")+d}}},slice:o.uniSlice},u=o.default(l),c=Object.assign(Object.assign({},u),{api:a.default});e.type=c,e.insert=(d,f)=>f.length===0?[]:d===0?[f]:[d,f],e.remove=(d,f)=>o.dlen(f)===0?[]:d===0?[{d:f}]:[d,{d:f}];var h=Ps();Object.defineProperty(e,"makeType",{enumerable:!0,get:function(){return h.default}})}(It)),It}var Eo;function s_(){return Eo||(Eo=1,function(e){var t=Ln&&Ln.__importDefault||function(S){return S&&S.__esModule?S:{default:S}};Object.defineProperty(e,"__esModule",{value:!0}),e.editOp=e.replaceOp=e.insertOp=e.moveOp=e.removeOp=e.type=void 0;const n=t(e_()),r=t(t_()),s=Ll(),i=xl();function o(S,F){if(!S)throw new Error(F)}e.type={name:"json1",uri:"http://sharejs.org/types/JSONv1",readCursor:s.readCursor,writeCursor:s.writeCursor,create:S=>S,isNoop:S=>S==null,setDebug(S){},registerSubtype:L,checkValidOp:fe,normalize:ae,apply:_,transformPosition:H,compose:v,tryTransform:V,transform:he,makeInvertible:O,invert:M,invertWithDoc:P,RM_UNEXPECTED_CONTENT:i.ConflictType.RM_UNEXPECTED_CONTENT,DROP_COLLISION:i.ConflictType.DROP_COLLISION,BLACKHOLE:i.ConflictType.BLACKHOLE,transformNoConflict:(S,F,G)=>ye(()=>!0,S,F,G),typeAllowingConflictsPred:S=>Object.assign(Object.assign({},e.type),{transform:(F,G,X)=>ye(S,F,G,X)})};const a=S=>S?S.getComponent():null;function l(S){return S&&typeof S=="object"&&!Array.isArray(S)}const u=S=>Array.isArray(S)?S.slice():S!==null&&typeof S=="object"?Object.assign({},S):S,c=S=>S&&(S.p!=null||S.r!==void 0),h=S=>S&&(S.d!=null||S.i!==void 0);function d(S,F){return o(S!=null),typeof F=="number"?(o(Array.isArray(S),"Invalid key - child is not an array"),(S=S.slice()).splice(F,1)):(o(l(S),"Invalid key - child is not an object"),delete(S=Object.assign({},S))[F]),S}function f(S,F,G){return typeof F=="number"?(o(S!=null,"Container is missing for key"),o(Array.isArray(S),"Cannot use numerical key for object container"),o(S.length>=F,"Cannot insert into out of bounds index"),S.splice(F,0,G)):(o(l(S),"Cannot insert into missing item"),o(S[F]===void 0,"Trying to overwrite value at key. Your op needs to remove it first"),S[F]=G),G}e.removeOp=(S,F=!0)=>s.writeCursor().writeAtPath(S,"r",F).get(),e.moveOp=(S,F)=>s.writeCursor().writeMove(S,F).get(),e.insertOp=(S,F)=>s.writeCursor().writeAtPath(S,"i",F).get(),e.replaceOp=(S,F,G)=>s.writeCursor().at(S,X=>{X.write("r",F),X.write("i",G)}).get(),e.editOp=(S,F,G,X=!1)=>s.writeCursor().at(S,Y=>A(Y,F,G,X)).get();const E=(S,F)=>S!=null&&(typeof F=="number"?Array.isArray(S):typeof S=="object"),R=(S,F)=>E(S,F)?S[F]:void 0,w={};function L(S){let F=S.type?S.type:S;F.name&&(w[F.name]=F),F.uri&&(w[F.uri]=F)}const J=S=>{const F=w[S];if(F)return F;throw Error("Missing type: "+S)};L(r_());const z=(S,F)=>S+F;L({name:"number",apply:z,compose:z,invert:S=>-S,transform:S=>S});const de=S=>S==null?null:S.et?J(S.et):S.es?w["text-unicode"]:S.ena!=null?w.number:null,N=S=>S.es?S.es:S.ena!=null?S.ena:S.e,A=(S,F,G,X=!1)=>{const[Y,W]=typeof F=="string"?[J(F),F]:[F,F.name];!X&&Y.isNoop&&Y.isNoop(G)||(W==="number"?S.write("ena",G):W==="text-unicode"?S.write("es",G):(S.write("et",W),S.write("e",G)))};function j(S){o(typeof S=="number"),o(S>=0),o(S===(0|S))}function Z(S){typeof S=="number"?j(S):o(typeof S=="string")}function fe(S){if(S===null)return;const F=new Set,G=new Set,X=W=>{let le=!0,oe=!1;for(let B in W){const te=W[B];if(le=!1,o(B==="p"||B==="r"||B==="d"||B==="i"||B==="e"||B==="es"||B==="ena"||B==="et","Invalid component item '"+B+"'"),B==="p")j(te),o(!F.has(te)),F.add(te),o(W.r===void 0);else if(B==="d")j(te),o(!G.has(te)),G.add(te),o(W.i===void 0);else if(B==="e"||B==="es"||B==="ena"){o(!oe),oe=!0;const ie=de(W);o(ie,"Missing type in edit"),ie.checkValidOp&&ie.checkValidOp(N(W))}}o(!le)},Y=(W,le,oe)=>{if(!Array.isArray(W))throw Error("Op must be null or a list");if(W.length===0)throw Error("Empty descent");le||Z(W[0]);let B=1,te=0,ie=0;for(let me=0;me<W.length;me++){const be=W[me];if(o(be!=null),Array.isArray(be)){const De=Y(be,!1);if(te){const K=typeof ie,Re=typeof De;K===Re?o(ie<De,"descent keys are not in order"):o(K==="number"&&Re==="string")}ie=De,te++,B=3}else typeof be=="object"?(o(B===1,`Prev not scalar - instead ${B}`),X(be),B=2):(o(B!==3),Z(be),o(s.isValidPathItem(be),"Invalid path key"),B=1)}return o(te!==1,"Operation makes multiple descents. Remove some []"),o(B===2||B===3),W[0]};Y(S,!0),o(F.size===G.size,"Mismatched picks and drops in op");for(let W=0;W<F.size;W++)o(F.has(W)),o(G.has(W))}function ae(S){let F=0,G=[];const X=s.writeCursor();return X.mergeTree(S,(Y,W)=>{const le=de(Y);if(le){const B=N(Y);A(W,le,le.normalize?le.normalize(B):B)}for(const B of["r","p","i","d"])if(Y[B]!==void 0){const te=B==="p"||B==="d"?(oe=Y[B],G[oe]==null&&(G[oe]=F++),G[oe]):Y[B];W.write(B,te)}var oe}),X.get()}function _(S,F){if(fe(F),F===null)return S;const G=[];return function X(Y,W){let le=Y,oe=0,B={root:Y},te=0,ie=B,me="root";function be(){for(;te<oe;te++){let De=W[te];typeof De!="object"&&(o(E(ie,me)),ie=ie[me]=u(ie[me]),me=De)}}for(;oe<W.length;oe++){const De=W[oe];if(Array.isArray(De)){const K=X(le,De);K!==le&&K!==void 0&&(be(),le=ie[me]=K)}else if(typeof De=="object"){De.d!=null?(be(),le=f(ie,me,G[De.d])):De.i!==void 0&&(be(),le=f(ie,me,De.i));const K=de(De);if(K)be(),le=ie[me]=K.apply(le,N(De));else if(De.e!==void 0)throw Error("Subtype "+De.et+" undefined")}else le=R(le,De)}return B.root}(S=function X(Y,W){const le=[];let oe=0;for(;oe<W.length;oe++){const me=W[oe];if(Array.isArray(me))break;typeof me!="object"&&(le.push(Y),Y=R(Y,me))}for(let me=W.length-1;me>=oe;me--)Y=X(Y,W[me]);for(--oe;oe>=0;oe--){const me=W[oe];if(typeof me!="object"){const be=le.pop();Y=Y===R(be,me)?be:Y===void 0?d(be,me):(te=me,ie=Y,(B=u(B=be))[te]=ie,B)}else c(me)&&(o(Y!==void 0,"Cannot pick up or remove undefined"),me.p!=null&&(G[me.p]=Y),Y=void 0)}var B,te,ie;return Y}(S,F),F)}function H(S,F){S=S.slice(),fe(F);const G=s.readCursor(F);let X,Y,W=!1;const le=[];for(let B=0;;B++){const te=S[B],ie=G.getComponent();if(ie&&(ie.r!==void 0?W=!0:ie.p!=null&&(W=!1,X=ie.p,Y=B)),B>=S.length)break;let me=0;const be=s.advancer(G,void 0,(K,Re)=>{c(Re)&&me++});le.unshift(be);const De=be(te);if(typeof te=="number"&&(S[B]-=me),!De)break}if(le.forEach(B=>B.end()),W)return null;const oe=()=>{let B=0;if(X!=null){const te=G.getPath();B=te.length,S=te.concat(S.slice(Y))}for(;B<S.length;B++){const te=S[B],ie=a(G),me=de(ie);if(me){const K=N(ie);me.transformPosition&&(S[B]=me.transformPosition(S[B],K));break}let be=0;const De=s.advancer(G,(K,Re)=>h(Re)?~(K-be):K-be,(K,Re)=>{h(Re)&&be++})(te);if(typeof te=="number"&&(S[B]+=be),!De)break}};return X!=null?G.eachDrop(null,B=>{B===X&&oe()}):oe(),S}function v(S,F){if(fe(S),fe(F),S==null)return F;if(F==null)return S;let G=0;const X=s.readCursor(S),Y=s.readCursor(F),W=s.writeCursor(),le=[],oe=[],B=[],te=[],ie=[],me=[],be=new Set;X.traverse(null,K=>{K.p!=null&&(B[K.p]=X.clone())}),Y.traverse(null,K=>{K.d!=null&&(te[K.d]=Y.clone())});const De=s.writeCursor();return function K(Re,ze,He,xe,qe,mt,Ve,et){o(ze||He);const Ge=a(ze),ut=a(He),ot=!!ut&&ut.r!==void 0,Dt=!!Ge&&Ge.i!==void 0,Fe=Ge?Ge.d:null,ct=ut?ut.p:null,p=(mt||ot)&&ct==null;if(ct!=null)xe=te[ct],Ve=oe[ct]=new s.WriteCursor;else if(ut&&ut.r!==void 0)xe=null;else{const D=a(xe);D&&D.d!=null&&(xe=null)}const g=a(xe);if(Fe!=null)if(Re=B[Fe],et=le[Fe]=new s.WriteCursor,p)mt&&!ot&&et.write("r",!0);else{const D=ie[Fe]=G++;Ve.write("d",D)}else if(Ge&&Ge.i!==void 0)Re=null;else{const D=a(Re);D&&D.p!=null&&(Re=null)}let m;Dt?(o(qe===void 0),m=Ge.i):m=qe;const y=(ct==null?!Dt||mt||ot:m===void 0)?null:Ve.getComponent();if(ct!=null){if(!(qe!==void 0||Dt)){const D=Fe!=null?ie[Fe]:G++;me[ct]=D,et.write("p",D)}}else ot&&(Dt||qe!==void 0||(ut.r,et.write("r",ut.r)));const T=p?null:de(Ge),U=de(g);if((T||U)&&(T&&T.name,U&&U.name),T&&U){o(T===U);const D=N(Ge),ee=N(g),Ce=T.compose(D,ee);A(Ve,T,Ce),be.add(g)}else T?A(Ve,T,N(Ge)):U&&(A(Ve,U,N(g)),be.add(g));const x=typeof m=="object"&&m!=null;let k=!1,I=0,Q=0,pe=0,q=0,_e=0;const Oe=s.advancer(xe,(D,ee)=>h(ee)?q-D-1:D-q,(D,ee)=>{h(ee)&&q++}),ue=s.advancer(Re,(D,ee)=>c(ee)?I-D-1:D-I,(D,ee)=>{c(ee)&&I++});if(s.eachChildOf(ze,He,(D,ee,Ce)=>{let Ae,Ue,Pe=D,We=D,ht=D;if(typeof D=="number"){let Me=D+pe;Ue=Oe(Me),We=Me+q;let ne=D+Q;Ae=ue(ne),h(a(Ue))&&(Ae=null),Pe=ne+I,ht=D+_e,o(Pe>=0,"p1PickKey is negative"),o(We>=0,"p2DropKey is negative");const at=h(a(ee)),Be=c(a(Ce));(at||Be&&!p)&&_e--,at&&Q--,Be&&pe--}else Ae=ue(D),Ue=Oe(D);et.descend(Pe),Ve.descend(We);const ft=x&&!h(a(ee))?m[ht]:void 0,Ee=K(Ae,ee,Ce,Ue,ft,p,Ve,et);var Qe,ve,Se;x&&!p?ft!==Ee&&(k||(m=Array.isArray(m)?m.slice():Object.assign({},m),k=!0),Qe=m,Se=Ee,typeof(ve=ht)=="number"?(o(Array.isArray(Qe)),o(ve<Qe.length)):(o(!Array.isArray(Qe)),o(Qe[ve]!==void 0)),Se===void 0?typeof ve=="number"?Qe.splice(ve,1):delete Qe[ve]:Qe[ve]=Se):o(Ee===void 0),Ve.ascend(),et.ascend()}),ue.end(),Oe.end(),y!=null)y.i=m;else if(!mt&&!ot&&ct==null)return m}(X,X.clone(),Y,Y.clone(),void 0,!1,W,De),W.reset(),W.mergeTree(De.get()),W.reset(),W.get(),le.map(K=>K.get()),oe.map(K=>K.get()),X.traverse(W,(K,Re)=>{const ze=K.p;if(ze!=null){const He=ie[ze];He!=null&&Re.write("p",He);const xe=le[ze];xe&&xe.get(),xe&&Re.mergeTree(xe.get())}else K.r!==void 0&&Re.write("r",K.r)}),W.reset(),W.get(),Y.traverse(W,(K,Re)=>{const ze=K.d;if(ze!=null){const xe=me[ze];xe!=null&&Re.write("d",xe);const qe=oe[ze];qe&&Re.mergeTree(qe.get())}else K.i!==void 0&&Re.write("i",K.i);const He=de(K);He&&!be.has(K)&&A(Re,He,N(K))}),W.get()}function M(S){if(S==null)return null;const F=new s.ReadCursor(S),G=new s.WriteCursor;let X;const Y=[],W=[];return function le(oe,B,te){const ie=oe.getComponent();let me,be=!1;if(ie){ie.p!=null&&(B.write("d",ie.p),Y[ie.p]=oe.clone()),ie.r!==void 0&&B.write("i",ie.r),ie.d!=null&&(B.write("p",ie.d),te=void 0),ie.i!==void 0&&(te=me=ie.i);const K=de(ie);K&&(te===void 0?(X||(X=new Set),X.add(ie)):(N(ie),te=K.apply(te,N(ie)),be=!0))}let De=0;for(const K of oe){B.descend(K);const Re=typeof K=="number"?K-De:K,ze=R(te,Re);h(oe.getComponent())&&De++;const He=le(oe,B,ze);if(te!==void 0&&He!==void 0){if(be||(be=!0,te=u(te)),!E(te,Re))throw Error("Cannot modify child - invalid operation");te[Re]=He}B.ascend()}if(me===void 0)return be?te:void 0;B.write("r",te)}(F,G,void 0),X&&(G.reset(),function le(oe,B,te){const ie=B.getComponent();if(ie){const K=ie.d;if(K!=null&&(oe=Y[K],te=W[K]=s.writeCursor()),X.has(ie)){const Re=de(ie);if(!Re.invert)throw Error(`Cannot invert subtype ${Re.name}`);A(te,Re,Re.invert(N(ie)))}}let me=0,be=0;const De=s.advancer(oe,(K,Re)=>c(Re)?me-K-1:K-me,(K,Re)=>{c(Re)&&me++});for(const K of B)if(typeof K=="number"){const Re=K-be,ze=De(Re),He=Re+me;te.descend(He),le(ze,B,te),h(B.getComponent())&&be++,te.ascend()}else te.descend(K),le(De(K),B,te),te.ascend();De.end()}(F.clone(),F,G),W.length&&(G.reset(),F.traverse(G,(le,oe)=>{const B=le.p;if(B!=null){const te=W[B];te&&te.get(),te&&oe.mergeTree(te.get())}}))),G.get()}const b=(S,F)=>S.some(G=>typeof G=="object"&&(Array.isArray(G)?b(G,F):F(G)));function O(S,F){if(S==null||!b(S,B=>{var te;return B.r!==void 0||((te=de(B))===null||te===void 0?void 0:te.makeInvertible)!=null}))return S;const G=new s.ReadCursor(S),X=new s.WriteCursor;let Y=!1;const W=[],le=[],oe=(B,te,ie)=>{const me=B.getComponent();let be=!1;if(me){me.d!=null&&te.write("d",me.d),me.i!==void 0&&te.write("i",me.i);const K=me.p;if(K!=null&&(W[K]=B.clone(),o(ie!==void 0,"Operation picks up at an invalid key"),le[K]=ie,te.write("p",me.p)),me.r!==void 0&&ie===void 0)throw Error("Invalid doc / op in makeInvertible: removed item missing from doc");const Re=de(me);Re&&(Re.makeInvertible?Y=!0:A(te,Re,N(me),!0))}let De=0;for(const K of B){te.descend(K);const Re=typeof K=="number"?K-De:K,ze=R(ie,Re),He=oe(B,te,ze);ze!==He&&(be||(be=!0,ie=u(ie)),He===void 0?(ie=d(ie,Re),typeof K=="number"&&De++):ie[Re]=He),te.ascend()}return me&&(me.r!==void 0?(te.write("r",r.default(ie)),ie=void 0):me.p!=null&&(ie=void 0)),ie};return oe(G,X,F),X.get(),Y&&(X.reset(),function B(te,ie,me,be,De){const K=ie.getComponent();if(K){K.i!==void 0?(be=K.i,De=!0):K.d!=null&&(be=le[K.d],te=W[K.d],De=!1,K.d);let xe=de(K);if(xe&&xe.makeInvertible){const qe=N(K);A(me,xe,xe.makeInvertible(qe,be),!0)}}let Re=0,ze=0;const He=s.advancer(te,(xe,qe)=>c(qe)?Re-xe-1:xe-Re,(xe,qe)=>{c(qe)&&Re++});for(const xe of ie)if(typeof xe=="number"){const qe=xe-ze,mt=He(qe),Ve=qe+Re,et=R(be,De?qe:Ve);me.descend(xe),B(mt,ie,me,et,De),h(ie.getComponent())&&ze++,me.ascend()}else{const qe=R(be,xe);me.descend(xe),B(He(xe),ie,me,qe,De),me.ascend()}He.end()}(G.clone(),G,X,F,!1)),X.get()}function P(S,F){return M(O(S,F))}const $=S=>{if(S==null)return null;const F=S.slice();for(let G=0;G<S.length;G++){const X=F[G];Array.isArray(X)&&(F[G]=$(X))}return F};function V(S,F,G){o(G==="left"||G==="right","Direction must be left or right");const X=G==="left"?0:1;if(F==null)return{ok:!0,result:S};fe(S),fe(F);let Y=null;const W=[],le=[],oe=[],B=[],te=[],ie=[],me=[],be=[],De=[],K=[],Re=[],ze=[],He=[],xe=[],qe=[];let mt=0;const Ve=s.readCursor(S),et=s.readCursor(F),Ge=s.writeCursor();if(function g(m,y=null,T){const U=a(y);U&&(U.r!==void 0?T=y.clone():U.p!=null&&(T=null,ie[U.p]=m.clone()));const x=m.getComponent();let k;x&&(k=x.p)!=null&&(te[k]=y?y.clone():null,oe[k]=m.clone(),T&&(K[k]=!0,De[k]=T),U&&U.p!=null&&(xe[k]=U.p));const I=s.advancer(y);for(const Q of m)g(m,I(Q),T);I.end()}(et,Ve,null),function g(m,y,T,U,x){const k=T.getComponent();let I,Q=!1;k&&((I=k.d)!=null?(B[I]=T.clone(),U!=null&&(qe[U]==null&&(qe[U]=[]),qe[U].push(I)),K[I],m=te[I]||null,y=oe[I]||null,K[I]?(x&&(Re[I]=!0),x=De[I]||null):!x||X!==1&&xe[I]!=null||Y==null&&(Y={type:i.ConflictType.RM_UNEXPECTED_CONTENT,op1:e.removeOp(x.getPath()),op2:e.moveOp(y.getPath(),T.getPath())}),Q=!0):k.i!==void 0&&(m=y=null,Q=!0,x&&Y==null&&(Y={type:i.ConflictType.RM_UNEXPECTED_CONTENT,op1:e.removeOp(x.getPath()),op2:e.insertOp(T.getPath(),k.i)})));const pe=a(m);pe&&(pe.r!==void 0?x=m.clone():pe.p!=null&&(pe.p,U=pe.p,x=null));const q=de(k);q&&x&&Y==null&&(Y={type:i.ConflictType.RM_UNEXPECTED_CONTENT,op1:e.removeOp(x.getPath()),op2:e.editOp(T.getPath(),q,N(k),!0)});let _e=0,Oe=0;const ue=s.advancer(y,(ee,Ce)=>c(Ce)?_e-ee-1:ee-_e,(ee,Ce)=>{c(Ce)&&_e++}),D=s.advancer(m);for(const ee of T)if(typeof ee=="number"){const Ce=ee-Oe,Ae=ue(Ce);Oe+=+g(D(Ce+_e),Ae,T,U,x)}else{const Ce=ue(ee);g(D(ee),Ce,T,U,x)}return ue.end(),D.end(),Q}(Ve,et,et.clone(),null,null),B.map(g=>g&&g.get()),Y)return{ok:!1,conflict:Y};Re.map(g=>!!g);const ut=[];let ot=null;(function g(m,y,T,U,x){let k=!1;const I=a(y);if(c(I)){const ue=I.p;ue!=null?(T=B[ue],U=ze[ue]=s.writeCursor(),k=!0,x=null):(T=null,x=y.clone())}else h(a(T))&&(T=null);const Q=m.getComponent();if(Q){const ue=Q.p;ue!=null?(x&&(be[ue]=x),ut[ue]=x||X===1&&k?null:U.getComponent(),W[ue]=m.clone(),T&&(me[ue]=T.clone())):Q.r!==void 0&&(x||U.write("r",!0),(x||k)&&(ot==null&&(ot=new Set),ot.add(Q)))}let pe=0,q=0;const _e=s.advancer(y,void 0,(ue,D)=>{c(D)&&pe++}),Oe=s.advancer(T,(ue,D)=>h(D)?~(ue-q):ue-q,(ue,D)=>{h(D)&&q++});if(m)for(const ue of m)if(typeof ue=="string"){const D=_e(ue),ee=Oe(ue);U.descend(ue),g(m,D,ee,U,x),U.ascend()}else{const D=_e(ue),ee=ue-pe,Ce=c(a(D))?null:Oe(ee),Ae=ee+q;o(Ae>=0),U.descend(Ae),g(m,D,Ce,U,x),U.ascend()}_e.end(),Oe.end()})(Ve,et,et.clone(),Ge,null),Ge.reset();let Dt=[];if(function g(m,y,T,U,x,k){o(y);const I=y.getComponent();let Q=a(U),pe=!1;const q=(ve,Se,Me)=>ve?e.moveOp(ve.getPath(),Se.getPath()):e.insertOp(Se.getPath(),Me.i);if(h(I)){const ve=I.d;ve!=null&&(le[ve]=y.clone());const Se=ve!=null?ut[ve]:null;let Me=!1;if(I.i!==void 0||ve!=null&&Se){let ne;Q&&(Q.i!==void 0||(ne=Q.d)!=null&&!K[ne])&&(Me=ne!=null?ve!=null&&ve===xe[ne]:n.default(Q.i,I.i),Me||ne!=null&&X!==1&&xe[ne]!=null||Y==null&&(Y={type:i.ConflictType.DROP_COLLISION,op1:q(ve!=null?W[ve]:null,y,I),op2:q(ne!=null?oe[ne]:null,U,Q)})),Me||(k?Y==null&&(Y={type:i.ConflictType.RM_UNEXPECTED_CONTENT,op1:q(ve!=null?W[ve]:null,y,I),op2:e.removeOp(k.getPath())}):(ve!=null?(Dt[mt]=ve,x.write("d",Se.p=mt++)):x.write("i",r.default(I.i)),pe=!0))}else if(ve!=null&&!Se){const ne=be[ve];ne&&(k=ne.clone())}ve!=null?(m=W[ve],T=ie[ve],U=me[ve]):I.i!==void 0&&(m=T=null,Me||(U=null))}else c(a(m))&&(m=T=U=null);const _e=a(m),Oe=a(T);if(c(Oe)){const ve=Oe.p;Oe.r!==void 0&&(!_e||_e.r===void 0)||K[ve]?(U=null,k=T.clone()):ve!=null&&(U=B[ve],X!==1&&xe[ve]!=null||((x=He[ve])||(x=He[ve]=s.writeCursor()),x.reset(),k=null))}else!h(I)&&h(Q)&&(U=null);Q=U!=null?U.getComponent():null;const ue=de(I);if(ue){const ve=N(I);if(k)Y==null&&(Y={type:i.ConflictType.RM_UNEXPECTED_CONTENT,op1:e.editOp(y.getPath(),ue,ve,!0),op2:e.removeOp(k.getPath())});else{const Se=de(Q);let Me;if(Se){if(ue!==Se)throw Error("Transforming incompatible types");const ne=N(Q);Me=ue.transform(ve,ne,G)}else Me=r.default(ve);A(x,ue,Me)}}let D=0,ee=0,Ce=0,Ae=0,Ue=0,Pe=0,We=m!=null&&m.descendFirst(),ht=We;const ft=s.advancer(T,void 0,(ve,Se)=>{c(Se)&&Ce++});let Ee=U!=null&&U.descendFirst(),Qe=Ee;for(const ve of y)if(typeof ve=="number"){let Se;const Me=h(y.getComponent()),ne=ve-ee;{let $t;for(;We&&typeof($t=m.getKey())=="number";){$t+=D;const Rt=m.getComponent(),cn=c(Rt);if($t>ne||$t===ne&&(!cn||X===0&&Me))break;if(cn){D--;const Zt=Rt.p;xe.includes(Zt),Rt.d,a(He[Rt.d]),c(a(He[Rt.d])),(Rt.r===void 0||ot&&ot.has(Rt))&&(Zt==null||!ut[Zt]||X!==1&&xe.includes(Zt))||Ue--}We=m.nextSibling()}Se=We&&$t===ne?m:null}const at=ne-D;let Be=ft(at);const At=at-Ce;let dr=null;{let $t,Rt;for(;Ee&&typeof($t=U.getKey())=="number";){Rt=$t-Ae;const cn=U.getComponent(),Zt=h(cn);if(Rt>At)break;if(Rt===At){if(!Zt){dr=U;break}{if(X===0&&Me){dr=U;break}const Bt=Be&&c(Be.getComponent());if(X===0&&Bt)break}}if(Zt){const Bt=cn.d;K[Bt],xe[Bt],cn.i===void 0&&(K[Bt]||xe[Bt]!=null&&X!==1)?(K[Bt]||xe[Bt]!=null&&X===0)&&(Ae++,Pe--):Ae++}Ee=U.nextSibling()}}const vi=At+Ae+Ue+Pe;o(vi>=0,"trying to descend to a negative index"),x.descend(vi),Me&&(Se=Be=dr=null,ee++),g(Se,y,Be,dr,x,k)&&Pe++,x.ascend()}else{let Se;for(;We&&(Se=m.getKey(),typeof Se!="string"||!(Se>ve||Se===ve));)We=m.nextSibling();const Me=We&&Se===ve?m:null,ne=ft(ve);let at;for(;Ee&&(at=U.getKey(),typeof at!="string"||!(at>ve||at===ve));)Ee=U.nextSibling();const Be=Ee&&at===ve?U:null;x.descend(ve),g(Me,y,ne,Be,x,k),x.ascend()}return ft.end(),ht&&m.ascend(),Qe&&U.ascend(),pe}(Ve,Ve.clone(),et,et.clone(),Ge,null),Y)return{ok:!1,conflict:Y};Ge.reset();const Fe=(g,m,y)=>g.traverse(m,(T,U)=>{T.d!=null&&y(T.d,g,U)});(K.length||ze.length)&&(Fe(et,Ge,(g,m,y)=>{K[g]&&!Re[g]&&y.write("r",!0),ze[g]&&y.mergeTree(ze[g].get())}),Ge.reset());const ct=[],p=[];if((He.length||K.length)&&!Y){const g=s.readCursor($(Ge.get()));if(Fe(g,null,(m,y)=>{ct[m]=y.clone()}),He.forEach(m=>{m&&Fe(s.readCursor(m.get()),null,(y,T)=>{ct[y]=T.clone()})}),function m(y,T,U,x,k,I){const Q=a(T);if(Q&&c(Q))if(Q.p!=null){const D=Q.p;ct[D].getPath(),U=ct[D],x=p[D]=s.writeCursor()}else Q.r!==void 0&&(U=null);else h(a(U))&&(U=null);const pe=y.getComponent();if(pe){let D;if((D=pe.d)!=null){const ee=He[D];ee&&(ee.get(),x.mergeTree(ee.get()),U=s.readCursor(ee.get()))}}let q=0,_e=0;const Oe=s.advancer(T,void 0,(D,ee)=>{c(ee)&&q--}),ue=s.advancer(U,(D,ee)=>h(ee)?-(D-_e)-1:D-_e,(D,ee)=>{h(ee)&&_e++});for(const D of y)if(typeof D=="number"){const ee=Oe(D),Ce=D+q,Ae=ue(Ce),Ue=Ce+_e;x.descend(Ue),m(y,ee,Ae,x),x.ascend()}else x.descend(D),m(y,Oe(D),ue(D),x),x.ascend();Oe.end(),ue.end()}(et,g,g.clone(),Ge),Ge.reset(),Y)return{ok:!1,conflict:Y};if(Ge.get(),p.length){const m=p.map(T=>T?T.get():null),y=s.readCursor($(Ge.get()));if(Fe(y,Ge,(T,U,x)=>{const k=m[T];k&&(x.mergeTree(k),m[T]=null)}),m.find(T=>T)){const T=s.writeCursor(),U=s.writeCursor();let x=0,k=0;m.forEach(I=>{I!=null&&Fe(s.readCursor(I),null,Q=>{const pe=Dt[Q];T.writeMove(W[pe].getPath(),le[pe].getPath(),x++);const q=qe[pe];q&&q.forEach(_e=>{K[_e]||X!==1&&xe[_e]!=null||U.writeMove(oe[_e].getPath(),B[_e].getPath(),k++)})})}),Y={type:i.ConflictType.BLACKHOLE,op1:T.get(),op2:U.get()}}}}return Y?{ok:!1,conflict:Y}:{ok:!0,result:Ge.get()}}const se=S=>{const F=new Error("Transform detected write conflict");throw F.conflict=S,F.type=F.name="writeConflict",F};function he(S,F,G){const X=V(S,F,G);if(X.ok)return X.result;se(X.conflict)}const ge=S=>{const F=s.writeCursor();return s.readCursor(S).traverse(F,(G,X)=>{(h(G)||de(G))&&X.write("r",!0)}),F.get()},Te=(S,F)=>{const{type:G,op1:X,op2:Y}=S;switch(G){case i.ConflictType.DROP_COLLISION:return F==="left"?[null,ge(Y)]:[ge(X),null];case i.ConflictType.RM_UNEXPECTED_CONTENT:let W=!1;return s.readCursor(X).traverse(null,le=>{le.r!==void 0&&(W=!0)}),W?[null,ge(Y)]:[ge(X),null];case i.ConflictType.BLACKHOLE:return[ge(X),ge(Y)];default:throw Error("Unrecognised conflict: "+G)}};function ye(S,F,G,X){let Y=null;for(;;){const W=V(F,G,X);if(W.ok)return v(Y,W.result);{const{conflict:le}=W;S(le)||se(le);const[oe,B]=Te(le,X);F=v(ae(F),oe),G=v(ae(G),B),Y=v(Y,B)}}}}(Ln)),Ln}var Co;function i_(){return Co||(Co=1,function(e){var t=Qt&&Qt.__createBinding||(Object.create?function(i,o,a,l){l===void 0&&(l=a),Object.defineProperty(i,l,{enumerable:!0,get:function(){return o[a]}})}:function(i,o,a,l){l===void 0&&(l=a),i[l]=o[a]}),n=Qt&&Qt.__exportStar||function(i,o){for(var a in i)a!=="default"&&!o.hasOwnProperty(a)&&t(o,i,a)};Object.defineProperty(e,"__esModule",{value:!0}),n(s_(),e);var r=Ll();Object.defineProperty(e,"ReadCursor",{enumerable:!0,get:function(){return r.ReadCursor}}),Object.defineProperty(e,"WriteCursor",{enumerable:!0,get:function(){return r.WriteCursor}});var s=xl();Object.defineProperty(e,"ConflictType",{enumerable:!0,get:function(){return s.ConflictType}})}(Qt)),Qt}var gt=i_();const o_=Ct(gt),a_=Zu({__proto__:null,default:o_},[gt]);var ce=(e=>(e.RETAIN="r",e.INSERT="i",e.DELETE="d",e))(ce||{});function lr(e,t=!1){const n=[];for(const r of e){const{st:s,ed:i,ts:o}=r;if(r.sId===void 0&&delete r.sId,s===i||!t&&re.isEmptyObject(o)&&r.sId==null)continue;if(n.length===0){n.push(r);continue}const a=n.pop();Ca(r,a)&&re.hasIntersectionBetweenTwoRanges(a.st,a.ed,r.st,r.ed)?n.push({...r,st:a.st,ed:i}):n.push(a,r)}return n}function Ul(e,t,n,r){var u;const{textRuns:s}=e;if(s==null)return;const i=[],o=s.length;let a=!1;const l=(u=t.textRuns)!=null?u:[];if(l.length)for(const c of l)c.st+=r,c.ed+=r;for(let c=0;c<o;c++){const h=s[c],{st:d,ed:f}=h;if(f<=r)i.push(h);else if(r>d&&r<f){a=!0;const E={...h,ed:r};i.push(E),l.length&&i.push(...l);const R={...h,st:r+n,ed:f+n};i.push(R)}else h.st+=n,h.ed+=n,a||(a=!0,i.push(...l)),i.push(h)}a||(a=!0,i.push(...l)),e.textRuns=lr(i)}function kl(e,t,n,r){const{paragraphs:s}=e;if(s==null)return;const{paragraphs:i}=t,o=[];for(let l=0,u=s.length;l<u;l++){const c=s[l],{startIndex:h}=c;h>=r&&(c.startIndex+=n),o.push(c.startIndex)}let a=-1;if(i){for(let l=0,u=i.length;l<u;l++){const c=i[l];c.startIndex+=r;const h=c.startIndex;a=o.indexOf(h)}a!==-1&&s.splice(a,1),s.push(...i),s.sort(ir("startIndex"))}}function Pl(e,t,n,r){const{sectionBreaks:s}=e;if(s==null)return;for(let o=0,a=s.length;o<a;o++){const l=s[o],{startIndex:u}=l;u>=r&&(l.startIndex+=n)}const i=t.sectionBreaks;if(i){for(let o=0,a=i.length;o<a;o++){const l=i[o];l.startIndex+=r}s.push(...i),s.sort(ir("startIndex"))}}function Fl(e,t,n,r){const{customBlocks:s=[]}=e;for(let o=0,a=s.length;o<a;o++){const l=s[o],{startIndex:u}=l;u>=r&&(l.startIndex+=n)}const i=t.customBlocks;if(i){for(let o=0,a=i.length;o<a;o++){const l=i[o];l.startIndex+=r}s.push(...i),s.sort(ir("startIndex"))}s.length&&!e.customBlocks&&(e.customBlocks=s)}function $l(e,t,n,r){const{tables:s}=e;if(s==null)return;for(let o=0,a=s.length;o<a;o++){const l=s[o],{startIndex:u,endIndex:c}=l;u>r?(l.startIndex+=n,l.endIndex+=n):c>r&&(l.endIndex+=n)}const i=t.tables;if(i){for(let o=0,a=i.length;o<a;o++){const l=i[o];l.startIndex+=r,l.endIndex+=r}s.push(...i),s.sort(ir("startIndex"))}}const Bl="$",Ro=e=>e.split(Bl)[0];function hi(e){if(e.length<=1)return e;e.sort((s,i)=>s.startIndex-i.startIndex);const t=[];let n={...e[0]};n.rangeId=Ro(n.rangeId);for(let s=1;s<e.length;s++){const i=e[s];i.rangeId=Ro(i.rangeId),i.rangeId===n.rangeId&&Dl(n.properties,i.properties)&&n.endIndex+1>=i.startIndex?n.endIndex=i.endIndex:(t.push(n),n={...i})}t.push(n);const r=Object.create(null);for(let s=0,i=t.length;s<i;s++){const o=t[s],a=o.rangeId;r[a]?(o.rangeId=`${a}${Bl}${r[a]}`,r[a]=r[a]+1):r[a]=1}return t}function Fs(e,t){const n=e.findIndex(s=>s.startIndex<t&&s.endIndex>=t),r=e[n];r&&e.splice(n,1,{rangeId:r.rangeId,rangeType:r.rangeType,startIndex:r.startIndex,endIndex:t-1,properties:{...r.properties}},{rangeId:r.rangeId,rangeType:r.rangeType,startIndex:t,endIndex:r.endIndex,properties:{...r.properties}})}function Hl(e){if(e.length<=1)return e;e.sort((r,s)=>r.startIndex-s.startIndex);const t=[];let n={...e[0]};for(let r=1;r<e.length;r++){const s=e[r];s.id===n.id&&n.endIndex+1>=s.startIndex?n.endIndex=s.endIndex:(t.push(n),n={...s})}return t.push(n),t}function $s(e,t){e.filter(r=>r.startIndex<t&&r.endIndex>=t).forEach(r=>{const s=e.indexOf(r);e.splice(s,1,{id:r.id,type:r.type,startIndex:r.startIndex,endIndex:t-1},{id:r.id,type:r.type,startIndex:t,endIndex:r.endIndex})})}function l_(e,t,n,r){e.customRanges||(e.customRanges=[]);const{customRanges:s}=e;Fs(s,r);for(let o=0,a=s.length;o<a;o++){const l=s[o],{startIndex:u}=l;u>=r&&(l.startIndex+=n,l.endIndex+=n)}const i=[];if(t.customRanges){for(let o=0,a=t.customRanges.length;o<a;o++){const l=t.customRanges[o];l.startIndex+=r,l.endIndex+=r,i.push(l)}s.push(...i)}e.customRanges=hi(s)}function u_(e,t,n,r){e.customDecorations||(e.customDecorations=[]);const{customDecorations:s}=e;$s(s,r);for(let o=0,a=s.length;o<a;o++){const l=s[o],{startIndex:u}=l;u>=r&&(l.startIndex+=n,l.endIndex+=n)}const i=[];if(t.customDecorations){for(let o=0,a=t.customDecorations.length;o<a;o++){const l=t.customDecorations[o];l.startIndex+=r,l.endIndex+=r,i.push(l)}s.push(...i)}e.customDecorations=Hl(s)}function jl(e,t,n){const{textRuns:r}=e,s=n,i=n+t,o=[];if(r){const a=[];for(let l=0,u=r.length;l<u;l++){const c=r[l],{st:h,ed:d}=c;if(s<=h&&i>=d){o.push({...c,st:h-s,ed:d-s});continue}else h<=s&&d>=i?(o.push({...c,st:s-s,ed:i-s}),c.ed-=t):s>=h&&s<d?(o.push({...c,st:s-s,ed:d-s}),c.ed=s):i>h&&i<=d?(o.push({...c,st:h-s,ed:i-s}),c.st=i-t,c.ed-=t):h>=i&&(c.st-=t,c.ed-=t);a.push(c)}e.textRuns=a}return o.length===0&&o.push({st:0,ed:t,ts:{}}),o}function Wl(e,t,n){const{paragraphs:r}=e,s=n,i=n+t,o=[];if(r){const a=[];for(let l=0,u=r.length;l<u;l++){const c=r[l],{startIndex:h}=c;if(h>=s&&h<i){o.push({...c,startIndex:h-n});continue}else h>=i&&(c.startIndex-=t);a.push(c)}e.paragraphs=a}return o}function Yl(e,t,n){const{sectionBreaks:r}=e,s=n,i=n+t-1,o=[];if(r){const a=[];for(let l=0,u=r.length;l<u;l++){const c=r[l],{startIndex:h}=c;if(h>=s&&h<=i){o.push({...c,startIndex:h-n});continue}else h>i&&(c.startIndex-=t);a.push(c)}e.sectionBreaks=a}return o}function zl(e,t,n){const{customBlocks:r=[]}=e,s=n,i=n+t-1,o=[];if(r){const a=[];for(let l=0,u=r.length;l<u;l++){const c=r[l],{startIndex:h}=c;if(h>=s&&h<=i){o.push({...c,startIndex:h-n});continue}else h>i&&(c.startIndex-=t);a.push(c)}e.customBlocks=a}return r.length&&!e.customBlocks&&(e.customBlocks=r),o}function Vl(e,t,n){const{tables:r}=e,s=n,i=n+t-1,o=[];if(r){const a=[];for(let l=0,u=r.length;l<u;l++){const c=r[l],{startIndex:h,endIndex:d}=c;if(s<=h&&i>=d){o.push({...c,startIndex:h-n,endIndex:d-n});continue}else if(h<=s&&d>=i){const f=Jr(h,d,s,i);if(f.length===0||(c.startIndex=f[0],c.endIndex=f[1],c.startIndex===c.endIndex))continue}else i<h&&(c.startIndex-=t,c.endIndex-=t);a.push(c)}e.tables=a}return o}function c_(e,t,n){const{customRanges:r}=e,s=n,i=n+t-1,o=[];if(r){const a=[];for(let l=0,u=r.length;l<u;l++){const c=r[l],{startIndex:h,endIndex:d}=c;if(h>=s&&d<=i){o.push(c);continue}else if(Math.max(s,h)<=Math.min(i,d)){const f=Jr(h,d,s,i);if(f.length===0)continue;c.startIndex=f[0],c.endIndex=f[1]}else i<h&&(c.startIndex-=t,c.endIndex-=t);a.push(c)}e.customRanges=hi(a)}return o}function h_(e,t,n,r=!0){const{customDecorations:s}=e,i=n,o=n+t-1,a=[];if(s){const l=[];for(let u=0,c=s.length;u<c;u++){const h=s[u],{startIndex:d,endIndex:f}=h;if(d>=i&&f<=o){a.push(h);continue}else if(Math.max(i,d)<=Math.min(o,f)){const E=Jr(d,f,i,o);if(E.length===0)continue;h.startIndex=E[0],h.endIndex=E[1]}else o<d&&r&&(h.startIndex-=t,h.endIndex-=t);l.push(h)}e.customDecorations=l}return a}var Gl=(e=>(e.ORDER_LIST_QUICK_1="1.",e.ORDER_LIST_QUICK_2="a)",e.ORDER_LIST_QUICK_3="a.",e.ORDER_LIST_QUICK_4="i.",e.ORDER_LIST_QUICK_5="A.",e.ORDER_LIST_QUICK_6="I.",e.ORDER_LIST_QUICK_7="01.",e))(Gl||{}),Mt=(e=>(e.BULLET_LIST="BULLET_LIST",e.BULLET_LIST_1="BULLET_LIST_1",e.BULLET_LIST_2="BULLET_LIST_2",e.BULLET_LIST_3="BULLET_LIST_3",e.BULLET_LIST_4="BULLET_LIST_4",e.BULLET_LIST_5="BULLET_LIST_5",e.ORDER_LIST="ORDER_LIST",e.ORDER_LIST_1="ORDER_LIST_1",e.ORDER_LIST_2="ORDER_LIST_2",e.ORDER_LIST_3="ORDER_LIST_3",e.ORDER_LIST_4="ORDER_LIST_4",e.ORDER_LIST_5="ORDER_LIST_5",e.ORDER_LIST_QUICK_2="ORDER_LIST_QUICK_2",e.ORDER_LIST_QUICK_3="ORDER_LIST_QUICK_3",e.ORDER_LIST_QUICK_4="ORDER_LIST_QUICK_4",e.ORDER_LIST_QUICK_5="ORDER_LIST_QUICK_5",e.ORDER_LIST_QUICK_6="ORDER_LIST_QUICK_6",e.CHECK_LIST="CHECK_LIST",e.CHECK_LIST_CHECKED="CHECK_LIST_CHECKED",e))(Mt||{});const Sr={"a)":{glyphFormat:"%1)",glyphType:Ne.DECIMAL},"1.":{glyphType:Ne.DECIMAL},"a.":{glyphFormat:"%1.",glyphType:Ne.LOWER_LETTER},"A.":{glyphType:Ne.UPPER_LETTER},"i.":{glyphFormat:"%1.",glyphType:Ne.LOWER_ROMAN},"I.":{glyphFormat:"%1.",glyphType:Ne.UPPER_LETTER}},dn=e=>[...e,...e,...e].map((t,n)=>({glyphFormat:` %${n+1}`,glyphSymbol:t,bulletAlignment:or.START,textStyle:{fs:12},startNumber:0,paragraphProperties:{hanging:{v:21},indentStart:{v:21*n}}})),fn=e=>e.map((t,n)=>({...t,bulletAlignment:or.START,textStyle:{fs:12},startNumber:0,paragraphProperties:{hanging:{v:21},indentStart:{v:21*n}}})),Io=(e,t)=>new Array(9).fill(0).map((n,r)=>({glyphFormat:` %${r+1}`,glyphSymbol:e,bulletAlignment:or.START,textStyle:{fs:16},startNumber:0,paragraphProperties:{hanging:{v:21},indentStart:{v:21*r},textStyle:t}})),ur={BULLET_LIST:{listType:"BULLET_LIST",nestingLevel:dn(["●","○","■"])},BULLET_LIST_1:{listType:"BULLET_LIST",nestingLevel:dn(["❖","➢","■"])},BULLET_LIST_2:{listType:"BULLET_LIST",nestingLevel:dn(["✔","●","◆"])},BULLET_LIST_3:{listType:"BULLET_LIST",nestingLevel:dn(["■","◆","○"])},BULLET_LIST_4:{listType:"BULLET_LIST",nestingLevel:dn(["✧","○","■"])},BULLET_LIST_5:{listType:"BULLET_LIST",nestingLevel:dn(["➢","○","◆"])},ORDER_LIST:{listType:"ORDER_LIST",nestingLevel:fn([{glyphFormat:"%1.",glyphType:Ne.DECIMAL},{glyphFormat:"%2.",glyphType:Ne.LOWER_LETTER},{glyphFormat:"%3.",glyphType:Ne.LOWER_ROMAN},{glyphFormat:"%4.",glyphType:Ne.DECIMAL},{glyphFormat:"%5.",glyphType:Ne.LOWER_LETTER},{glyphFormat:"%6.",glyphType:Ne.LOWER_ROMAN},{glyphFormat:"%7.",glyphType:Ne.DECIMAL},{glyphFormat:"%8.",glyphType:Ne.LOWER_LETTER},{glyphFormat:"%9.",glyphType:Ne.LOWER_ROMAN}])},ORDER_LIST_1:{listType:"ORDER_LIST",nestingLevel:fn([{glyphFormat:"%1)",glyphType:Ne.DECIMAL},{glyphFormat:"%2)",glyphType:Ne.LOWER_LETTER},{glyphFormat:"%3)",glyphType:Ne.LOWER_ROMAN},{glyphFormat:"%4)",glyphType:Ne.DECIMAL},{glyphFormat:"%5)",glyphType:Ne.LOWER_LETTER},{glyphFormat:"%6)",glyphType:Ne.LOWER_ROMAN},{glyphFormat:"%7)",glyphType:Ne.DECIMAL},{glyphFormat:"%8)",glyphType:Ne.LOWER_LETTER},{glyphFormat:"%9)",glyphType:Ne.LOWER_ROMAN}])},ORDER_LIST_2:{listType:"ORDER_LIST",nestingLevel:fn(["%1.","%1.%2.","%1.%2.%3.","%1.%2.%3.%4.","%1.%2.%3.%4.%5.","%1.%2.%3.%4.%5.%6.","%1.%2.%3.%4.%5.%6.%7."].map(e=>({glyphFormat:e,glyphType:Ne.DECIMAL})))},ORDER_LIST_3:{listType:"ORDER_LIST",nestingLevel:fn([{glyphFormat:"%1.",glyphType:Ne.UPPER_LETTER},{glyphFormat:"%2.",glyphType:Ne.LOWER_LETTER},{glyphFormat:"%3.",glyphType:Ne.LOWER_ROMAN},{glyphFormat:"%4.",glyphType:Ne.UPPER_LETTER},{glyphFormat:"%5.",glyphType:Ne.LOWER_LETTER},{glyphFormat:"%6.",glyphType:Ne.LOWER_ROMAN},{glyphFormat:"%7.",glyphType:Ne.UPPER_LETTER},{glyphFormat:"%8.",glyphType:Ne.LOWER_LETTER},{glyphFormat:"%9.",glyphType:Ne.LOWER_ROMAN}])},ORDER_LIST_4:{listType:"ORDER_LIST",nestingLevel:fn([{glyphFormat:"%1.",glyphType:Ne.UPPER_LETTER},{glyphFormat:"%2.",glyphType:Ne.DECIMAL},{glyphFormat:"%3.",glyphType:Ne.LOWER_ROMAN},{glyphFormat:"%4.",glyphType:Ne.UPPER_LETTER},{glyphFormat:"%5.",glyphType:Ne.DECIMAL},{glyphFormat:"%6.",glyphType:Ne.LOWER_ROMAN},{glyphFormat:"%7.",glyphType:Ne.UPPER_LETTER},{glyphFormat:"%8.",glyphType:Ne.DECIMAL},{glyphFormat:"%9.",glyphType:Ne.LOWER_ROMAN}])},ORDER_LIST_5:{listType:"ORDER_LIST",nestingLevel:fn([{glyphFormat:"%1.",glyphType:Ne.DECIMAL_ZERO},{glyphFormat:"%2.",glyphType:Ne.LOWER_LETTER},{glyphFormat:"%3.",glyphType:Ne.LOWER_ROMAN},{glyphFormat:"%4.",glyphType:Ne.DECIMAL_ZERO},{glyphFormat:"%5.",glyphType:Ne.LOWER_LETTER},{glyphFormat:"%6.",glyphType:Ne.LOWER_ROMAN},{glyphFormat:"%7.",glyphType:Ne.DECIMAL_ZERO},{glyphFormat:"%8.",glyphType:Ne.LOWER_LETTER},{glyphFormat:"%9.",glyphType:Ne.LOWER_ROMAN}])},CHECK_LIST:{listType:"CHECK_LIST",nestingLevel:Io("☐")},CHECK_LIST_CHECKED:{listType:"CHECK_LIST_CHECKED",nestingLevel:Io("☑",{st:{s:Ie.TRUE}})}},vr=e=>{const{glyphFormat:t,glyphType:n}=e,r=re.deepClone(ur.ORDER_LIST);return r.nestingLevel[0].glyphFormat=t,r.nestingLevel[0].glyphType=n,r},d_={ORDER_LIST_QUICK_2:vr(Sr["a)"]),ORDER_LIST_QUICK_3:vr(Sr["a."]),ORDER_LIST_QUICK_4:vr(Sr["i."]),ORDER_LIST_QUICK_6:vr(Sr["I."])};Object.assign(ur,d_);const f_={"1.":"ORDER_LIST","a)":"ORDER_LIST_QUICK_2","a.":"ORDER_LIST_QUICK_3","i.":"ORDER_LIST_QUICK_4","A.":"ORDER_LIST_3","I.":"ORDER_LIST_QUICK_6","01.":"ORDER_LIST_5"};function g_(e,t,n,r,s){const i=m_(e,t,n,r,s),o=__(e,t,n,r,s),a=p_(e,t,n,r,s),l=E_(e,t,n,r,s),u=C_(e,t,n,r,s),c=R_(e,t,n,r),h=I_(e,t,n,r,s);return{dataStream:"",textRuns:i,paragraphs:o,sectionBreaks:a,customBlocks:l,tables:u,customRanges:c,customDecorations:h}}function m_(e,t,n,r,s){const{textRuns:i}=e,{textRuns:o}=t;if(i==null||o==null)return;const a=jl(e,n,r);if(s!==ke.REPLACE){const l=Kl(o,a,s);t.textRuns=l}return Ul(e,t,n,r),a}function Kl(e,t,n){if(t.length===0)return e;e=re.deepClone(e),t=re.deepClone(t);const r=[],s=e.length,i=t.length;let o=0,a=0,l=null;function u(){return l?(r.push(l),l=null,!0):!1}for(;o<s&&a<i;){const{st:f,ed:E,ts:R}=e[o],{st:w,ed:L,ts:J,sId:z}=t[a];let de;if(n===ke.COVER?de={...J,...R}:de={...R},E<w)u()||r.push(e[o]),o++;else if(L<f)u()||r.push(t[a]),a++;else{const N={st:Math.min(f,w),ed:Math.max(f,w),ts:f<w?{...R}:{...J},sId:f<w?void 0:z};N.ed>N.st&&r.push(N),r.push({st:Math.max(f,w),ed:Math.min(E,L),ts:de,sId:z}),E<L?(o++,t[a].st=E,t[a].st===t[a].ed&&a++):(a++,e[o].st=L,e[o].st===e[o].ed&&o++);const A={st:Math.min(E,L),ed:Math.max(E,L),ts:E<L?{...J}:{...R},sId:E<L?z:void 0};l=A.ed>A.st?A:null}}u();const c=r[r.length-1],h=e[s-1],d=t[i-1];return c&&c.ed!==Math.max(h.ed,d.ed)&&(h.ed>d.ed?r.push(h):r.push(d)),lr(r)}function __(e,t,n,r,s){const{paragraphs:i}=e,{paragraphs:o}=t;if(i==null||o==null)return;const a=Wl(e,n,r);if(s!==ke.REPLACE){const l=[];for(const u of o){const{startIndex:c,paragraphStyle:h,bullet:d}=u;let f=[];for(const E of a){const{startIndex:R,paragraphStyle:w,bullet:L}=E;let J,z;if(s===ke.COVER?(J={...w,...h},z={listId:"",listType:Mt.BULLET_LIST,nestingLevel:0,textStyle:{},...L,...d}):(J={...h,...w},z={listId:"",listType:Mt.BULLET_LIST,nestingLevel:0,textStyle:{},...d,...L}),c===R){f.push({startIndex:c,paragraphStyle:J,bullet:z});break}}l.push(...f),f=[]}t.paragraphs=l}return kl(e,t,n,r),a}function p_(e,t,n,r,s){const{sectionBreaks:i}=e,{sectionBreaks:o}=t;if(i==null||o==null)return;const a=Yl(e,n,r);if(s!==ke.REPLACE){const l=[];for(const u of o){const{startIndex:c}=u;let h=[];for(const d of a){const{startIndex:f}=d;if(c===f){s===ke.COVER?h.push({...d,...u}):h.push({...u,...d});break}}l.push(...h),h=[]}t.sectionBreaks=l}return Pl(e,t,n,r),a}function E_(e,t,n,r,s){const{customBlocks:i=[]}=e,{customBlocks:o}=t;if(i==null||o==null)return;const a=zl(e,n,r);if(s!==ke.REPLACE){const l=[];for(const u of o){const{startIndex:c}=u;let h=[];for(const d of a){const{startIndex:f}=d;if(c===f){s===ke.COVER?h.push({...d,...u}):h.push({...u,...d});break}}l.push(...h),h=[]}t.customBlocks=l}return Fl(e,t,n,r),i.length&&!e.customBlocks&&(e.customBlocks=i),a}function C_(e,t,n,r,s){const{tables:i}=e,{tables:o}=t;if(i==null||o==null)return;const a=Vl(e,n,r);if(s!==ke.REPLACE){const l=[];for(const u of o){const{startIndex:c,endIndex:h}=u;let d=[];for(const f of a){const{startIndex:E,endIndex:R}=f;if(E>=c&&R<=h){s===ke.COVER?d.push({...f,...u}):d.push({...u,...f});break}}l.push(...d),d=[]}t.tables=l}return $l(e,t,n,r),a}function R_(e,t,n,r,s){e.customRanges||(e.customRanges=[]),Fs(e.customRanges,r),Fs(e.customRanges,r+n);const i=r,o=r+n-1,{customRanges:a}=t,l=[],u=new Map;e.customRanges.forEach(h=>{const{startIndex:d,endIndex:f}=h;d>=i&&f<=o?u.set(h.rangeId,h):l.push(h)});const c=[];return a?(a.forEach(h=>{const{startIndex:d,endIndex:f}=h;l.push({...h,startIndex:d+r,endIndex:f+r})}),e.customRanges=hi(l),c):[]}function I_(e,t,n,r,s){e.customDecorations||(e.customDecorations=[]),$s(e.customDecorations,r),$s(e.customDecorations,r+n);const i=[],{customDecorations:o}=e,{customDecorations:a=[]}=t;if(s===ke.REPLACE){for(let l=0;l<o.length;l++){const u=o[l],{startIndex:c,endIndex:h}=u;c>=r&&h<=r+n-1&&i.push(u)}a.forEach(l=>{const{startIndex:u,endIndex:c}=l;o.push({...l,startIndex:u+r,endIndex:c+r})})}else for(const l of a){const{id:u}=l;if(l.type===nn.DELETED){const c=o.filter(h=>h.id===u);c.length&&i.push(...c)}else o.push({...l,startIndex:l.startIndex+r,endIndex:l.endIndex+r})}for(const l of i){const{id:u}=l,c=o.findIndex(h=>h.id===u);c!==-1&&o.splice(c,1)}return e.customDecorations=Hl(o),i}var di=(e=>(e[e.copy=0]="copy",e[e.cut=1]="cut",e))(di||{});function zr(e,t,n,r=!0){const{textRuns:s}=e;if(s){const i=[];for(const o of s){const a=re.deepClone(o),{st:l,ed:u}=a;re.hasIntersectionBetweenTwoRanges(l,u,t,n)&&(t>=l&&t<=u?i.push({...a,st:t,ed:Math.min(n,u)}):n>=l&&n<=u?i.push({...a,st:Math.max(t,l),ed:n}):i.push(a))}return lr(i.map(o=>{const{st:a,ed:l}=o;return{...o,st:a-t,ed:l-t}}))}else if(r)return[{st:0,ed:n-t,ts:{}}]}function Xl(e,t,n){const{tables:r=[]}=e,s=[];for(const i of r){const o=re.deepClone(i),{startIndex:a,endIndex:l}=o;a>=t&&l<=n&&s.push({...o,startIndex:a-t,endIndex:l-t})}return s}function ql(e,t,n){const{paragraphs:r=[]}=e,s=[];for(const i of r){const{startIndex:o}=i;o>=t&&o<n&&s.push(re.deepClone(i))}if(s.length)return s.map(i=>({...i,startIndex:i.startIndex-t}))}function S_(e,t,n){const{sectionBreaks:r=[]}=e,s=[];for(const i of r){const{startIndex:o}=i;o>=t&&o<=n&&s.push(re.deepClone(i))}if(s.length)return s.map(i=>({...i,startIndex:i.startIndex-t}))}function Jl(e,t,n){const{customBlocks:r=[]}=e,s=[];for(const i of r){const{startIndex:o}=i;o>=t&&o<=n&&s.push(re.deepClone(i))}if(s.length)return s.map(i=>({...i,startIndex:i.startIndex-t}))}function bt(e,t,n,r=!0,s=1){const{dataStream:i}=e,o={dataStream:i.slice(t,n)};o.textRuns=zr(e,t,n,r);const a=Xl(e,t,n);if(a.length&&(o.tables=a),o.paragraphs=ql(e,t,n),s===1){const u=Ql(e,t,n);u?o.customDecorations=u:r&&(o.customDecorations=[])}const{customRanges:l}=Zl(e,t,n);return l?o.customRanges=l:r&&(o.customRanges=[]),o.customBlocks=Jl(e,t,n),o}function v_(e){const{dataStream:t,textRuns:n,paragraphs:r,customRanges:s,customDecorations:i,tables:o}=e;let a=0,l=0;s==null||s.forEach(c=>{c.startIndex<0&&(a=Math.max(a,-c.startIndex)),c.endIndex>t.length-1&&(l=Math.max(l,c.endIndex-t.length+1))});const u=`${t}`;return n&&(n[0]&&(n[0].st=n[0].st-a),n[n.length-1]&&(n[n.length-1].ed=n[n.length-1].ed+l)),n==null||n.forEach(c=>{c.st+=a,c.ed+=a}),r==null||r.forEach(c=>{c.startIndex+=a}),s==null||s.forEach(c=>{c.startIndex+=a,c.endIndex+=a}),i==null||i.forEach(c=>{c.startIndex+=a,c.endIndex+=l}),o==null||o.forEach(c=>{c.startIndex+=a,c.endIndex+=l}),{...e,dataStream:u,textRuns:n,paragraphs:r,customRanges:s,customDecorations:i,tables:o}}function Zl(e,t,n){if(e.customRanges==null)return{};const{customRanges:r}=e;return{customRanges:r.filter(a=>Math.max(a.startIndex,t)<=Math.min(a.endIndex,n-1)).map(a=>({...a,startIndex:Math.max(a.startIndex,t),endIndex:Math.min(a.endIndex,n-1)})).map(a=>({...a,startIndex:a.startIndex-t,endIndex:a.endIndex-t})),leftOffset:0,rightOffset:0}}function Ql(e,t,n){if(e.customDecorations==null)return;const{customDecorations:r=[]}=e,s=[];return r.forEach(i=>{if(Math.max(i.startIndex,t)<=Math.min(i.endIndex,n-1)){const o=re.deepClone(i);s.push({...o,startIndex:Math.max(o.startIndex-t,0),endIndex:Math.min(o.endIndex,n-1)-t})}}),s}function O_(e,t,n){return e==null||t==null?e!=null?e:t:Kl(e,t,n)}function w_(e,t,n){if(e==null||t==null)return e!=null?e:t;if(t.length===0||e.length===0)return e;if(t.length>1||e.length>1)throw new Error("Cannot cover multiple customRanges");return n===ke.REPLACE?[{...e[0]}]:[{...t[0],...e[0]}]}function b_(e,t,n){return t.length===0||e.length===0||n===ke.REPLACE?e:[...e,...t.filter(r=>!e.some(s=>r.id===s.id))]}function Bs(e,t,n=ke.COVER){if(t.dataStream!=="")throw new Error("Cannot compose other body with non-empty dataStream");const r={dataStream:e.dataStream},{textRuns:s,paragraphs:i=[],customRanges:o,customDecorations:a=[]}=e,{textRuns:l,paragraphs:u=[],customRanges:c,customDecorations:h=[]}=t;r.textRuns=O_(l,s,n),r.customRanges=w_(c,o,n);const d=b_(h,a,n);d.length&&(r.customDecorations=d);const f=[];let E=0,R=0;for(;E<i.length&&R<u.length;){const w=i[E],L=u[R],{startIndex:J}=w,{startIndex:z}=L;J===z?(f.push(re.deepMerge(w,L)),E++,R++):J<z?(f.push(re.deepClone(w)),E++):(f.push(re.deepClone(L)),R++)}return E<i.length&&f.push(...i.slice(E)),R<u.length&&f.push(...u.slice(R)),f.length&&(r.paragraphs=f),r}function y_(e){const{body:t}=e;if(t==null)return!0;const{textRuns:n,paragraphs:r,customRanges:s,customBlocks:i,customDecorations:o,tables:a}=t;return n==null&&r==null&&s==null&&i==null&&o==null&&a==null}class mn{constructor(t){C(this,"_index",0);C(this,"_offset",0);this._actions=t}hasNext(){return this.peekLength()<Number.POSITIVE_INFINITY}next(t){t||(t=Number.POSITIVE_INFINITY);const n=this._actions[this._index];if(n){const r=this._offset,s=n.len;return t>=s-r?(t=s-r,this._index+=1,this._offset=0):this._offset+=t,n.t===ce.DELETE||n.t===ce.RETAIN&&n.body==null?re.deepClone({...n,len:t}):re.deepClone({...n,len:t,body:bt(n.body,r,r+t,!1)})}else return{t:ce.RETAIN,len:Number.POSITIVE_INFINITY}}peek(){return this._actions[this._index]}peekLength(){return this._actions[this._index]?this._actions[this._index].len-this._offset:Number.POSITIVE_INFINITY}peekType(){const t=this._actions[this._index];return t?t.t:ce.RETAIN}rest(){if(this.hasNext()){if(this._offset===0)return this._actions.slice(this._index);{const t=this._offset,n=this._index,r=this.next(),s=this._actions.slice(this._index);return this._offset=t,this._index=n,[r].concat(s)}}else return[]}}class Nn{constructor(){C(this,"cursor",0)}reset(){return this.cursor=0,this}moveCursor(t){this.cursor+=t}moveCursorTo(t){this.cursor=t}}function eu(e,t,n){const{dataStream:r}=e,s=n,i=n+t,o=jl(e,t,n),a=Wl(e,t,n),l=Yl(e,t,n),u=zl(e,t,n),c=Vl(e,t,n),h=c_(e,t,n),d=h_(e,t,n);let f="";return r&&(e.dataStream=Sa(r,s,i),f=r.slice(s,i)),{dataStream:f,textRuns:o,paragraphs:a,sectionBreaks:l,customBlocks:u,tables:c,customRanges:h,customDecorations:d}}function tu(e,t,n,r){e.dataStream=Ia(e.dataStream,r,t.dataStream),Ul(e,t,n,r),kl(e,t,n,r),Pl(e,t,n,r),Fl(e,t,n,r),$l(e,t,n,r),l_(e,t,n,r),u_(e,t,n,r)}function A_(e,t,n,r,s=ke.COVER){return g_(e,t,n,r,s)}function T_(e,t,n){return t<=0?{dataStream:""}:eu(e,t,n)}function N_(e,t,n,r){n!==0&&tu(e,t,n,r)}function M_(e,t){const n=new Nn;return n.reset(),t.forEach(r=>{const s=re.deepClone(r);switch(s.t){case ce.RETAIN:{const{coverType:i,body:o,len:a}=s;o!=null&&A_(e,o,a,n.cursor,i),n.moveCursor(a);break}case ce.INSERT:{const{body:i,len:o}=s;N_(e,i,o,n.cursor),n.moveCursor(o);break}case ce.DELETE:{const{len:i}=s;T_(e,i,n.cursor);break}default:throw new Error(`Unknown action type for action: ${s}.`)}}),e}function D_(e,t,n,r,s){if(e==null||t==null)return t;if(e.length===0||t.length===0)return[];t=re.deepClone(t),e=re.deepClone(e);const i=[],o=t.length,a=e.length;let l=0,u=0,c=null;function h(){return c?(i.push(c),c=null,!0):!1}for(;l<o&&u<a;){const{st:R,ed:w,ts:L}=t[l],{st:J,ed:z,ts:de,sId:N}=e[u];let A={};if(s===0)A={...L},n===ke.COVER&&r===ke.REPLACE&&de&&(A=Object.assign({},de,A));else if(A={...L},n===ke.REPLACE){if(r===ke.REPLACE)A={...de};else if(L&&de){const j=Object.keys(L);for(const Z of j)de[Z]&&delete A[Z]}}else if(r===ke.REPLACE){if(de){const j=Object.keys(de);for(const Z of j)de[Z]!==void 0&&(A[Z]=de[Z])}}else if(de){const j=Object.keys(de);for(const Z of j)A[Z]!==void 0&&delete A[Z]}if(w<J)h()||i.push(t[l]),l++;else if(z<R)h()||i.push(e[u]),u++;else{const j={st:Math.min(R,J),ed:Math.max(R,J),ts:R<J?{...L}:{...de}};j.ed>j.st&&i.push(),i.push({st:Math.max(R,J),ed:Math.min(w,z),ts:A,sId:N}),w<z?(l++,e[u].st=w,e[u].st===e[u].ed&&u++):(u++,t[l].st=z,t[l].st===t[l].ed&&l++);const Z={st:Math.min(w,z),ed:Math.max(w,z),ts:w<z?{...de}:{...L},sId:w<z?N:void 0};c=Z.ed>Z.st?Z:null}}h();const d=i[i.length-1],f=t[o-1],E=e[a-1];return d.ed!==Math.max(f.ed,E.ed)&&(f.ed>E.ed?i.push(f):i.push(E)),lr(i,!0)}function L_(e,t,n,r,s){if(e==null||t==null)return t;if(e.length===0||t.length===0)return[];if(e.length>1||t.length>1)throw new Error("CustomRanges is only supported transform for length one now.");const i=e[0],o=t[0];if(n===ke.REPLACE)return s===1?[re.deepClone(i)]:[re.deepClone(o)];if(r===ke.REPLACE){const a=re.deepClone(o);return s===1&&Object.assign(a,re.deepClone(i)),[a]}else{const a=re.deepClone(o);return s===1&&Object.assign(a,re.deepClone(i)),[a]}}function So(e,t,n,r,s){const i={startIndex:t.startIndex};if(t.paragraphStyle&&(i.paragraphStyle=re.deepClone(t.paragraphStyle),e.paragraphStyle)){if(n===ke.REPLACE)if(r===ke.REPLACE)s===1&&(i.paragraphStyle={...e.paragraphStyle});else if(s===1){const o=Object.keys(e.paragraphStyle);for(const a of o)e.paragraphStyle[a]!==void 0&&(i.paragraphStyle[a]=e.paragraphStyle[a])}else{const o=Object.keys(e.paragraphStyle);for(const a of o)i.paragraphStyle[a]===void 0&&(i.paragraphStyle[a]=e.paragraphStyle[a])}else if(r===ke.REPLACE)if(s===1){const o=Object.keys(e.paragraphStyle);for(const a of o)e.paragraphStyle[a]!==void 0&&(i.paragraphStyle[a]=e.paragraphStyle[a])}else{const o=Object.keys(e.paragraphStyle);for(const a of o)i.paragraphStyle[a]===void 0&&(i.paragraphStyle[a]=e.paragraphStyle[a])}else if(s===1){const o=Object.keys(e.paragraphStyle);for(const a of o)i.paragraphStyle[a]&&delete i.paragraphStyle[a]}}return n===ke.REPLACE&&r===ke.REPLACE?i.bullet=s===1?re.deepClone(e.bullet):re.deepClone(t.bullet):e.bullet===void 0?i.bullet=re.deepClone(t.bullet):n===ke.REPLACE||r===ke.REPLACE?i.bullet=s===0&&t.bullet?re.deepClone(t.bullet):re.deepClone(e.bullet):s===0&&t.bullet!==void 0&&(i.bullet=re.deepClone(t.bullet)),i}function x_(e,t){if(e==null||t==null)return t;if(e.length===0||t.length===0)return re.deepClone(t);const n=[];for(const r of t){const{id:s,type:i}=r;let o=!1;for(const a of e)if(a.id===s){(a.type===nn.DELETED||i===nn.DELETED)&&(o=!0,n.push({...r,type:nn.DELETED}));break}o||n.push(r)}return n}function U_(e,t,n=!1){const{body:r,coverType:s=ke.COVER}=e,{body:i,coverType:o=ke.COVER}=t;if(r==null||r.dataStream!==""||i==null||i.dataStream!=="")throw new Error("Data stream is not supported in retain transform.");const a={dataStream:""},l=o,{textRuns:u,paragraphs:c=[],customRanges:h,customDecorations:d}=r,{textRuns:f,paragraphs:E=[],customRanges:R,customDecorations:w}=i,L=D_(u,f,s,o,n?1:0);L&&(a.textRuns=L);const J=L_(h,R,s,o,n?1:0);J&&(a.customRanges=J);const z=x_(d,w);z&&(a.customDecorations=z);const de=[];let N=0,A=0;for(;N<c.length&&A<E.length;){const j=c[N],Z=E[A],{startIndex:fe}=j,{startIndex:ae}=Z;if(fe===ae){let _={startIndex:fe};n?_=So(j,Z,s,o,1):_=So(j,Z,s,o,0),de.push(_),N++,A++}else fe<ae?N++:(de.push(re.deepClone(Z)),A++)}return A<E.length&&de.push(...E.slice(A)),de.length&&(a.paragraphs=de),{coverType:l,body:a}}function vo(e){return Object.keys(e).length===1}const In=class In{constructor(){C(this,"_actions",[])}static apply(t,n){return M_(t,n)}static compose(t,n){const r=new mn(t),s=new mn(n),i=new In;for(;r.hasNext()||s.hasNext();)if(s.peekType()===ce.INSERT)i.push(s.next());else if(r.peekType()===ce.DELETE)i.push(r.next());else{const o=Math.min(r.peekLength(),s.peekLength()),a=r.next(o),l=s.next(o);if(a.t===ce.INSERT&&l.t===ce.RETAIN)l.body==null?i.push(a):i.push({...a,body:Bs(a.body,l.body,l.coverType)});else if(a.t===ce.RETAIN&&l.t===ce.RETAIN)if(a.body==null&&l.body==null)i.push(a.len!==Number.POSITIVE_INFINITY?a:l);else if(a.body&&l.body){const u=a.coverType===ke.REPLACE||l.coverType===ke.REPLACE?ke.REPLACE:ke.COVER;i.push({...a,t:ce.RETAIN,coverType:u,body:Bs(a.body,l.body,l.coverType)})}else i.push(a.body?a:l);else a.t===ce.RETAIN&&l.t===ce.DELETE?i.push(l):a.t===ce.INSERT&&(l.t,ce.DELETE)}return i.trimEndUselessRetainAction(),i.serialize()}static transform(t,n,r="right"){return this._transform(n,t,r==="left"?"right":"left")}static _transform(t,n,r="right"){const s=new mn(t),i=new mn(n),o=new In;for(;s.hasNext()||i.hasNext();)if(s.peekType()===ce.INSERT&&(r==="left"||i.peekType()!==ce.INSERT)){const a=s.next();o.retain(a.len)}else if(i.peekType()===ce.INSERT)o.push(i.next());else{const a=Math.min(s.peekLength(),i.peekLength()),l=s.next(a),u=i.next(a);if(l.t===ce.DELETE)continue;if(u.t===ce.DELETE){o.push(u);continue}if(l.body==null||u.body==null)o.push(u);else{const{coverType:c,body:h}=U_(l,u,r==="left");o.push({...u,t:ce.RETAIN,coverType:c,body:h})}}return o.trimEndUselessRetainAction(),o.serialize()}static transformPosition(t,n,r=!1){const s=new mn(t);let i=0;for(;s.hasNext()&&i<=n;){const o=s.peekLength(),a=s.peekType();if(s.next(),a===ce.DELETE){n-=Math.min(o,n-i);continue}else a===ce.INSERT&&(i<n||!r)&&(n+=o);i+=o}return n}static isNoop(t){return t.length===0}static invert(t){const n=[];for(const r of t)if(r.t===ce.INSERT)n.push({t:ce.DELETE,len:r.len,body:r.body});else if(r.t===ce.DELETE){if(r.body==null)throw new Error("Can not invert DELETE action without body property, makeInvertible must be called first.");n.push({t:ce.INSERT,body:r.body,len:r.len})}else if(r.body!=null){if(r.oldBody==null)throw new Error("Can not invert RETAIN action without oldBody property, makeInvertible must be called first.");n.push({t:ce.RETAIN,body:r.oldBody,oldBody:r.body,len:r.len,coverType:ke.REPLACE})}else n.push(r);return n}static makeInvertible(t,n){const r=[];let s=0;for(const i of t){if(i.t===ce.DELETE&&(i.body==null||i.body&&i.body.dataStream.length!==i.len)){const o=bt(n,s,s+i.len,!1);i.len=o.dataStream.length,i.body=o}if(i.t===ce.RETAIN&&i.body!=null){const o=bt(n,s,s+i.len,!0);i.oldBody={...o,dataStream:""},i.len=o.dataStream.length}r.push(i),i.t!==ce.INSERT&&(s+=i.len)}return r}insert(t,n){const r={t:ce.INSERT,body:n,len:t};return this.push(r),this}retain(t,n,r){const s={t:ce.RETAIN,len:t};return n!=null&&(s.body=n),r!=null&&(s.coverType=r),this.push(s),this}delete(t){const n={t:ce.DELETE,len:t};return this.push(n),this}empty(){return this._actions=[],this}serialize(){return this._actions}push(...t){if(t.length>1){for(const i of t)this.push(i);return this}let n=this._actions.length,r=this._actions[n-1];const s=re.deepClone(t[0]);if(s.t===ce.RETAIN&&s.len===0&&s.body==null)return this;if(typeof r=="object"){if(r.t===ce.DELETE&&s.t===ce.DELETE)return r.len+=s.len,this;if(r.t===ce.DELETE&&s.t===ce.INSERT&&(n-=1,r=this._actions[n-1],r==null))return this._actions.unshift(s),this;if(r.t===ce.RETAIN&&s.t===ce.RETAIN&&r.body==null&&s.body==null)return r.len+=s.len,this;if(r.t===ce.INSERT&&vo(r.body)&&s.t===ce.INSERT&&vo(s.body))return r.len+=s.len,r.body.dataStream+=s.body.dataStream,this}return n===this._actions.length?this._actions.push(s):this._actions.splice(n,0,s),this}trimEndUselessRetainAction(){let t=this._actions[this._actions.length-1];for(;t&&t.t===ce.RETAIN&&y_(t);)this._actions.pop(),t=this._actions[this._actions.length-1];return this}};C(In,"id","text-x"),C(In,"uri","https://github.com/dream-num/univer#text-x");let Ye=In;Object.defineProperty(Ye,"name",{value:"text-x"});const Sn=class Sn{static registerSubtype(t){var n;t==null||this._subTypes.has(t.name)&&((n=this._subTypes.get(t.name))==null?void 0:n.id)!==Ye.id||(this._subTypes.set(t.name,t),gt.type.registerSubtype(t))}static apply(t,n){if(!gt.type.isNoop(n))return gt.type.apply(t,n)}static compose(t,n){return gt.type.compose(t,n)}static transform(t,n,r){return gt.type.transform(t,n,r)}static transformPosition(t,n,r="right"){return t&&t.length===2&&t[0]==="body"&&t[1].et===Ye.name?Ye.transformPosition(t[1].e,n,r==="left"):n}static invertWithDoc(t,n){return gt.type.invertWithDoc(t,n)}static isNoop(t){return gt.type.isNoop(t)}static getInstance(){return this._instance==null&&(this._instance=new Sn),this._instance}removeOp(t,n){return gt.removeOp(t,n)}moveOp(t,n){return gt.moveOp(t,n)}insertOp(t,n){return gt.insertOp(t,n)}replaceOp(t,n,r){return gt.replaceOp(t,n,r)}editOp(t,n=["body"]){return gt.editOp(n,Ye.name,t)}};C(Sn,"uri","https://github.com/dream-num/univer#json-x"),C(Sn,"_subTypes",new Map),C(Sn,"_instance",null);let kt=Sn;kt.registerSubtype(Ye);const fi={id:"default_doc",documentStyle:{}};class k_ extends rs{constructor(n){var r;super();C(this,"type",$e.UNIVER_DOC);C(this,"_name$",new we.BehaviorSubject(""));C(this,"name$",this._name$.asObservable());C(this,"snapshot");this.snapshot={...fi,...n},this._name$.next((r=this.snapshot.title)!=null?r:"No Title")}getUnitId(){throw new Error("Method not implemented.")}getRev(){var n;return(n=this.snapshot.rev)!=null?n:1}incrementRev(){this.snapshot.rev=this.getRev()+1}setRev(n){this.snapshot.rev=n}setName(n){this.snapshot.title=n,this._name$.next(n)}get drawings(){return this.snapshot.drawings}get documentStyle(){return this.snapshot.documentStyle}get lists(){return this.snapshot.lists}get zoomRatio(){var n;return((n=this.snapshot.settings)==null?void 0:n.zoomRatio)||1}resetDrawing(n,r){this.snapshot.drawings=n,this.snapshot.drawingsOrder=r}getBody(){return this.snapshot.body}getSnapshot(){return this.snapshot}getBulletPresetList(){var s;const n=(s=this.snapshot.lists)!=null?s:{};return{...ur,...n}}updateDocumentId(n){this.snapshot.id=n}updateDocumentRenderConfig(n){const{documentStyle:r}=this.snapshot;r.renderConfig==null?r.renderConfig=n:r.renderConfig={...r.renderConfig,...n}}updateDocumentStyle(n){this.snapshot.documentStyle==null?this.snapshot.documentStyle=n:this.snapshot.documentStyle={...this.snapshot.documentStyle,...n}}updateDocumentDataMargin(n){const{t:r,l:s,b:i,r:o}=n,{documentStyle:a}=this.snapshot;r!=null&&(a.marginTop=r),s!=null&&(a.marginLeft=s),i!=null&&(a.marginBottom=i),o!=null&&(a.marginRight=o)}updateDocumentDataPageSize(n,r){const{documentStyle:s}=this.snapshot;if(!s.pageSize){n=n!=null?n:Number.POSITIVE_INFINITY,r=r!=null?r:Number.POSITIVE_INFINITY,s.pageSize={width:n,height:r};return}n!==void 0&&(s.pageSize.width=n),r!==void 0&&(s.pageSize.height=r)}updateDrawing(n,r){const{drawings:s}=this,{width:i,height:o,left:a,top:l}=r,u=s==null?void 0:s[n];if(!u)return;const c=u.docTransform;c.size.width=i,c.size.height=o,c.positionH.posOffset=a,c.positionV.posOffset=l}setZoomRatio(n=1){this.snapshot.settings==null?this.snapshot.settings={zoomRatio:n}:this.snapshot.settings.zoomRatio=1}}class yt extends k_{constructor(n){var s,i;super(re.isEmptyObject(n)?Qm():n);C(this,"_unitId");C(this,"headerModelMap",new Map);C(this,"footerModelMap",new Map);C(this,"change$",new we.BehaviorSubject(0));const r=6;this._unitId=(s=this.snapshot.id)!=null?s:re.generateRandomId(r),this._initializeHeaderFooterModel(),this._name$.next((i=this.snapshot.title)!=null?i:"")}dispose(){super.dispose(),this.headerModelMap.forEach(n=>{n.dispose()}),this.footerModelMap.forEach(n=>{n.dispose()}),this._name$.complete()}getDrawings(){return this.snapshot.drawings}getDrawingsOrder(){return this.snapshot.drawingsOrder}getCustomRanges(){var n;return(n=this.snapshot.body)==null?void 0:n.customRanges}getCustomDecorations(){var n;return(n=this.snapshot.body)==null?void 0:n.customDecorations}getSettings(){return this.snapshot.settings}reset(n){if(n.id&&n.id!==this._unitId)throw new Error("Cannot reset a document model with a different unit id!");this.snapshot={...fi,...n},this._initializeHeaderFooterModel(),this.change$.next(this.change$.value+1)}getSelfOrHeaderFooterModel(n){if(n!=null){if(this.headerModelMap.has(n))return this.headerModelMap.get(n);if(this.footerModelMap.has(n))return this.footerModelMap.get(n)}return this}getUnitId(){return this._unitId}apply(n){if(!kt.isNoop(n))return this.snapshot=kt.apply(this.snapshot,n),n!=null&&n.some(r=>Array.isArray(r)&&((r==null?void 0:r[0])==="headers"||(r==null?void 0:r[0])==="footers"))&&(this.headerModelMap.clear(),this.footerModelMap.clear(),this._initializeHeaderFooterModel()),this.change$.next(this.change$.value+1),this.snapshot}sliceBody(n,r,s=di.copy){const i=this.getBody();if(i!=null)return bt(i,n,r,!1,s)}_initializeHeaderFooterModel(){const{headers:n,footers:r}=this.getSnapshot();if(n)for(const s in n){const i=n[s];this.headerModelMap.set(s,new yt(i)),this.headerModelMap.get(s).updateDocumentId(this.getUnitId())}if(r)for(const s in r){const i=r[s];this.footerModelMap.set(s,new yt(i)),this.footerModelMap.get(s).updateDocumentId(this.getUnitId())}}updateDocumentId(n){super.updateDocumentId(n),this._unitId=n}getPlainText(){var n,r;return Zr((r=(n=this.getBody())==null?void 0:n.dataStream)!=null?r:"")}}function P_(e){const{ranges:t,id:n,type:r}=e,s=new Ye;let i=0;for(let o=0;o<t.length;o++){const a=t[o],{startOffset:l,endOffset:u}=a;l>0&&s.push({t:ce.RETAIN,len:l-i}),s.push({t:ce.RETAIN,body:{dataStream:"",customDecorations:[{id:n,type:r,startIndex:0,endIndex:u-l-1}]},len:u-l}),i=u}return s}function F_(e){var c,h,d;const{id:t,segmentId:n,documentDataModel:r}=e,s=r==null?void 0:r.getBody();if(!r||!s)return!1;const i=(d=(h=(c=r.getSelfOrHeaderFooterModel(n))==null?void 0:c.getBody())==null?void 0:h.customDecorations)==null?void 0:d.find(f=>f.id===t);if(!i)return!1;const o=new Ye,{startIndex:a,endIndex:l}=i,u=l-a+1;return o.push({t:ce.RETAIN,len:a}),o.push({t:ce.RETAIN,len:u,body:{dataStream:"",customDecorations:[{startIndex:0,endIndex:u-1,id:t,type:nn.DELETED}]}}),o}function nu(e,t,n,r){return e<=n&&t>=n||e>=n&&e<=r}function $_(e,t){const n=[];for(let r=0,s=t.length;r<s;r++){const i=t[r];e.collapsed?i.startIndex<e.startOffset&&e.startOffset<=i.endIndex&&n.push(i):nu(e.startOffset,e.endOffset-1,i.startIndex,i.endIndex)&&n.push(i)}return n}function B_(e){return{...re.deepClone(e),rangeId:Ut()}}function H_(e,t){const n=[];let r=e[0];for(const s of t)s<e[0]||s>e[1]||(r<s&&n.push([r,s-1]),r=s+1);return r<=e[1]&&n.push([r,e[1]]),n}function ru(e,t,n,r){const s=[];for(let i=0,o=n.length;i<o;i++){const a=n[i];if((r===void 0||a.rangeType===r)&&Math.max(a.startIndex,e)<=Math.min(a.endIndex,t)&&s.push({...a}),a.startIndex>t)break}return s}function j_(e,t){var i,o,a,l,u;const n=ru(e.startOffset,e.collapsed?e.startOffset:e.endOffset-1,(i=t.customRanges)!=null?i:[]),r=Math.min(e.startOffset,(a=(o=n[0])==null?void 0:o.startIndex)!=null?a:1/0),s=Math.max(e.endOffset,((u=(l=n[n.length-1])==null?void 0:l.endIndex)!=null?u:-1/0)+1);return{startOffset:r,endOffset:s,collapsed:r===s}}function W_(e){var h,d,f;const{rangeId:t,segmentId:n,documentDataModel:r,insert:s}=e,i=(d=(h=r.getSelfOrHeaderFooterModel(n).getBody())==null?void 0:h.customRanges)==null?void 0:d.find(E=>E.rangeId===t);if(!i)return!1;const{startIndex:o,endIndex:a}=i,l=new Ye,u=a-o+1;l.push({t:ce.RETAIN,len:o}),l.push({t:ce.RETAIN,len:u,body:{dataStream:"",customRanges:[]}}),s&&l.push({t:ce.INSERT,body:s,len:s.dataStream.length});const c=a+1+((f=s==null?void 0:s.dataStream.length)!=null?f:0);return l.selections=[{startOffset:c,endOffset:c,collapsed:!0}],l}function Y_(e){const{ranges:t,rangeId:n,rangeType:r,wholeEntity:s,properties:i,body:o}=e;let a=0;const l=new Ye;let u=!1;return t.forEach(c=>{var z,de,N;const h=j_(c,o);if(!h||!o)return!1;const{startOffset:d,endOffset:f}=h,E=(z=o.customRanges)!=null?z:[],R=(A,j,Z)=>{var v,M,b,O;const fe=ru(A,j,E,r),ae=Math.min((M=(v=fe[0])==null?void 0:v.startIndex)!=null?M:1/0,A),_=Math.max((O=(b=fe[fe.length-1])==null?void 0:b.endIndex)!=null?O:-1/0,j),H={rangeId:Z?`${n}$${Z}`:n,rangeType:r,startIndex:0,endIndex:_-ae,wholeEntity:s,properties:{...i}};l.push({t:ce.RETAIN,len:ae-a}),l.push({t:ce.RETAIN,len:_-ae+1,body:{dataStream:"",customRanges:[H]},coverType:ke.COVER}),a=_+1},w=((de=o.paragraphs)!=null?de:[]).filter(A=>A.startIndex<f&&A.startIndex>d),L=((N=o.customBlocks)!=null?N:[]).filter(A=>A.startIndex<f&&A.startIndex>d);H_([d,f-1],[...w.map(A=>A.startIndex),...L.map(A=>A.startIndex)]).forEach(([A,j],Z)=>R(A,j,Z)),u=!0,l.selections=[{startOffset:h.endOffset,endOffset:h.endOffset,collapsed:!0}]}),u?l:!1}function su(e,t,n=0,r=null,s=!0){e.sort((u,c)=>u.startOffset-c.startOffset);const i=[],{paragraphs:o=[]}=t,a=o==null?void 0:o.find(u=>u.startIndex>=e[0].startOffset&&u.startIndex<e[0].endOffset);let l=n;if(e.forEach(u=>{const{startOffset:c,endOffset:h}=u;c>l&&(i.push({t:ce.RETAIN,len:c-l}),l=c),l<h&&(i.push({t:ce.DELETE,len:h-l}),l=h)}),r&&i.push({t:ce.INSERT,body:r,len:r.dataStream.length}),a&&s){const u=o.find(c=>c.startIndex-n>=e[e.length-1].endOffset-1);u&&(u.startIndex>l&&(i.push({t:ce.RETAIN,len:u.startIndex-l}),l=u.startIndex),i.push({t:ce.RETAIN,len:1,body:{dataStream:"",paragraphs:[{...u,startIndex:0,bullet:a==null?void 0:a.bullet}]},coverType:ke.REPLACE}))}return i}function z_(e,t,n=0){const r=[];let s=n;return e.forEach(i=>{const{startOffset:o,endOffset:a}=i;o>s&&(r.push({t:ce.RETAIN,len:o-s}),s=o),a>s&&(r.push({t:ce.RETAIN,len:a-s,body:{...re.deepClone(t),dataStream:""}}),s=a)}),r}const V_=e=>{var h;const{selection:t,body:n,doc:r}=e,s=t.segmentId,i=(h=r.getSelfOrHeaderFooterModel(s))==null?void 0:h.getBody();if(!i)return!1;const o=t.collapsed?null:bt(i,t.startOffset,t.endOffset),a=ui(o?o.dataStream:"",n.dataStream);let l=0;const u=a.map(([d,f])=>{switch(d){case 0:{const E={t:ce.RETAIN,body:{...bt(n,l,l+f.length,!1),dataStream:""},len:f.length};return l+=f.length,E}case 1:{const E={t:ce.INSERT,body:bt(n,l,l+f.length),len:f.length};return l+=f.length,E}default:return{t:ce.DELETE,len:f.length}}}),c=new Ye;return c.push({t:ce.RETAIN,len:t.startOffset}),c.push(...u),c};function G_(e,t){return!!((e==null?void 0:e.length)===(t==null?void 0:t.length)&&(e!=null&&e.every((n,r)=>JSON.stringify(n)===JSON.stringify(t==null?void 0:t[r]))))}const K_=e=>{var h;const{selection:t,body:n,doc:r}=e,s=t.segmentId,i=(h=r.getSelfOrHeaderFooterModel(s))==null?void 0:h.getBody();if(!i)return!1;const o=t.collapsed?null:bt(i,t.startOffset,t.endOffset),a=ui(o?o.dataStream:"",n.dataStream);let l=0;const u=a.map(([d,f])=>{switch(d){case 0:{const E=zr(n,l,l+f.length,!1),R=zr(o,l,l+f.length,!1),w={t:ce.RETAIN,body:G_(E,R)?void 0:{textRuns:E,dataStream:""},len:f.length};return l+=f.length,w}case 1:{const E={t:ce.INSERT,body:bt(n,l,l+f.length),len:f.length};return l+=f.length,E}default:return{t:ce.DELETE,len:f.length}}});if(u.every(d=>d.t===ce.RETAIN&&!d.body))return!1;const c=new Ye;return c.push({t:ce.RETAIN,len:t.startOffset}),c.push(...u),c};function X_(e,t){const n=[],{customBlocks:r=[]}=e;for(const s of t){const{startOffset:i,endOffset:o}=s;if(!(i==null||o==null))for(const a of r){const{startIndex:l}=a;l>=i&&l<o&&n.push(a.blockId)}}return n}function q_(e,t=""){if(!t)return["body"];const{headers:n,footers:r}=e.getSnapshot();if(n==null&&r==null)throw new Error("Document data model must have headers or footers when update by segment id");if((n==null?void 0:n[t])!=null)return["headers",t,"body"];if((r==null?void 0:r[t])!=null)return["footers",t,"body"];throw new Error("Segment id not found in headers or footers")}const J_=e=>{var R,w,L,J;const{selection:t,documentDataModel:n,drawings:r}=e,{collapsed:s,startOffset:i,segmentId:o}=t,a=new Ye,l=kt.getInstance(),u=[],c=n.getSelfOrHeaderFooterModel(o).getBody();if(!c)return!1;const h=(w=(R=n.getSnapshot().drawingsOrder)==null?void 0:R.length)!=null?w:0;let d=0;if(s)i>0&&a.push({t:ce.RETAIN,len:i});else{const z=su([t],c,0,null,!1);a.push(...z);const de=X_(c,[t]),N=(L=n.getDrawings())!=null?L:{},A=(J=n.getDrawingsOrder())!=null?J:[],j=de.sort((Z,fe)=>A.indexOf(Z)>A.indexOf(fe)?-1:A.indexOf(Z)<A.indexOf(fe)?1:0);if(j.length>0)for(const Z of j){const fe=N[Z],ae=A.indexOf(Z);if(fe==null||ae<0)continue;const _=l.removeOp(["drawings",Z],fe),H=l.removeOp(["drawingsOrder",ae],Z);u.push(_),u.push(H),d++}}a.push({t:ce.INSERT,body:{dataStream:"\b".repeat(r.length),customBlocks:r.map((z,de)=>({startIndex:de,blockId:z.drawingId}))},len:r.length});const f=q_(n,o),E=l.editOp(a.serialize(),f);u.push(E);for(const z of r){const{drawingId:de}=z,N=l.insertOp(["drawings",de],z),A=l.insertOp(["drawingsOrder",h-d],de);u.push(N),u.push(A)}return u.reduce((z,de)=>kt.compose(z,de),null)},Z_=e=>{var h,d,f;const{paragraphs:t,segmentId:n,document:r}=e;let s=e.listType;const i=(d=(h=r.getSelfOrHeaderFooterModel(n).getBody())==null?void 0:h.paragraphs)!=null?d:[],o=t.every(E=>{var R;return((R=E.bullet)==null?void 0:R.listType.indexOf(s))===0});let l=re.generateRandomId(6);if(t.length===1){const E=i.indexOf(t[0]),R=i[E-1],w=i[E+1];R&&R.bullet&&R.bullet.listType.indexOf(s)===0?(l=R.bullet.listId,s!==Mt.CHECK_LIST&&(s=R.bullet.listType)):w&&w.bullet&&w.bullet.listType.indexOf(s)===0&&(l=w.bullet.listId,s!==Mt.CHECK_LIST&&(s=w.bullet.listType))}const u=new Nn;u.reset();const c=new Ye;for(const E of t){const{startIndex:R,paragraphStyle:w={},bullet:L}=E;c.push({t:ce.RETAIN,len:R-u.cursor}),c.push({t:ce.RETAIN,len:1,body:{dataStream:"",paragraphs:[o?{paragraphStyle:w,startIndex:0}:{startIndex:0,paragraphStyle:{...w},bullet:{nestingLevel:(f=L==null?void 0:L.nestingLevel)!=null?f:0,textStyle:{fs:20},listType:s,listId:l}}]},coverType:ke.REPLACE}),u.moveCursorTo(R+1)}return c},Q_=e=>{var h;const{paragraphIndex:t,segmentId:n,document:r}=e,s=(h=r.getSelfOrHeaderFooterModel(n).getBody())==null?void 0:h.paragraphs;if(s==null)return!1;const i=s.find(d=>d.startIndex===t);if(!(i!=null&&i.bullet)||i.bullet.listType.indexOf(Mt.CHECK_LIST)===-1)return!1;const o=new Nn;o.reset();const a=new Ye,{startIndex:l,paragraphStyle:u={}}=i,c=i.bullet.listType===Mt.CHECK_LIST?Mt.CHECK_LIST_CHECKED:Mt.CHECK_LIST;return a.push({t:ce.RETAIN,len:l-o.cursor}),a.push({t:ce.RETAIN,len:1,body:{dataStream:"",paragraphs:[{...i,paragraphStyle:u,startIndex:0,bullet:{...i.bullet,listType:c}}]},coverType:ke.REPLACE}),o.moveCursorTo(l+1),a},ep=e=>{var c,h;const{paragraphs:t,listType:n,segmentId:r,document:s}=e;if(((c=s.getSelfOrHeaderFooterModel(r).getBody())==null?void 0:c.paragraphs)==null)return!1;const a=re.generateRandomId(6),l=new Nn;l.reset();const u=new Ye;for(const d of t){const{startIndex:f,paragraphStyle:E={},bullet:R}=d;u.push({t:ce.RETAIN,len:f-l.cursor}),u.push({t:ce.RETAIN,len:1,body:{dataStream:"",paragraphs:[{startIndex:0,paragraphStyle:E,bullet:{nestingLevel:(h=R==null?void 0:R.nestingLevel)!=null?h:0,textStyle:(R==null?void 0:R.listType)===n?R.textStyle:{fs:20},listType:n,listId:a}}]},coverType:ke.REPLACE}),l.moveCursorTo(f+1)}return u};function tp(e,t){return t.some(n=>e.startIndex>n.startIndex&&e.startIndex<n.endIndex)}const np=e=>{var c,h,d;const{paragraphs:t,segmentId:n,document:r,type:s}=e,i=new Nn;i.reset();const o=new Ye,a=(c=r.getSnapshot().lists)!=null?c:{},l=(d=(h=r.getBody())==null?void 0:h.tables)!=null?d:[],u={...ur,...a};for(const f of t){const{startIndex:E,paragraphStyle:R={},bullet:w}=f,L=tp(f,l);if(o.push({t:ce.RETAIN,len:E-i.cursor}),w){const J=w.listType;let z=u[J].nestingLevel.length-1;L&&(z=Math.min(z,2)),o.push({t:ce.RETAIN,len:1,body:{dataStream:"",paragraphs:[{startIndex:0,paragraphStyle:{...R},bullet:{...w,nestingLevel:Math.max(Math.min(w.nestingLevel+s,z),0)}}]},coverType:ke.REPLACE})}else o.push({t:ce.RETAIN,len:1});i.moveCursorTo(E+1)}return o};function rp(e,t){if(typeof t>"u")return{startOffset:e,endOffset:e,collapsed:!0};if(t<e)throw new Error(`Cannot make a doc selection when endOffset ${t} is less than startOffset ${e}.`);return{startOffset:e,endOffset:t,collapsed:e===t}}function sp(e){const{startOffset:t,endOffset:n,collapsed:r}=e,s=Math.min(t,n),i=Math.max(t,n);return{startOffset:s,endOffset:i,collapsed:r}}function ip(e,t,n,r){return Math.max(e,n)<=Math.min(t,r)}class it{}C(it,"customRange",{add:Y_,delete:W_,copyCustomRange:B_,getCustomRangesInterestsWithSelection:$_,isIntersecting:nu}),C(it,"customDecoration",{add:P_,delete:F_}),C(it,"selection",{replace:V_,makeSelection:rp,normalizeSelection:sp,delete:su,replaceTextRuns:K_,retain:z_}),C(it,"range",{isIntersects:ip}),C(it,"transform",{getPlainText:Zr,fromPlainText:Kd,isEmptyDocument:Gd}),C(it,"paragraph",{bullet:{set:ep,switch:Z_,toggleChecklist:Q_,changeNestLevel:np}}),C(it,"drawing",{add:J_});function op(e){if(e.customRanges||(e.customRanges=[]),!e.paragraphs){e.paragraphs=[];for(let t=0;t<e.dataStream.length;t++)e.dataStream[t]==="\r"&&e.paragraphs.push({startIndex:t})}return e.customBlocks||(e.customBlocks=[]),e.textRuns||(e.textRuns=[]),e.customDecorations||(e.customDecorations=[]),e.sectionBreaks||(e.sectionBreaks=[]),e.tables||(e.tables=[]),e}function iu(e){var t;return e.body=op((t=e.body)!=null?t:{dataStream:""}),e.drawingsOrder||(e.drawingsOrder=[]),e.drawings||(e.drawings={}),e.documentStyle||(e.documentStyle={}),e}class cr{constructor(t={}){C(this,"_style");this._style=t}static create(t={}){return new cr(t)}get fontFamily(){return this._style.ff}get fontSize(){return this._style.fs}get italic(){return this._style.it===Ie.TRUE}get bold(){return this._style.bl===Ie.TRUE}get underline(){return this._style.ul&&Yt.create(this._style.ul)}get bottomBorderLine(){return this._style.bbl&&Yt.create(this._style.bbl)}get strikethrough(){return this._style.st&&Yt.create(this._style.st)}get overline(){return this._style.ol&&Yt.create(this._style.ol)}get background(){return this._style.bg}get border(){return this._style.bd}get color(){return this._style.cl}get verticalAlign(){return this._style.va}get numberFormat(){return this._style.n}copy(){return Kt.create(re.deepClone(this._style))}getValue(){return{...this._style}}}class Kt extends cr{static create(t={}){return new Kt(t)}constructor(t={}){super(t)}setFontFamily(t){return this._style.ff=t,this}setFontSize(t){return this._style.fs=t,this}setItalic(t){return this._style.it=t?1:0,this}setBold(t){return this._style.bl=t?1:0,this}setUnderline(t){return this._style.ul=t.build(),this}setBottomBorderLine(t){return this._style.bbl=t.build(),this}setStrikethrough(t){return this._style.st=t.build(),this}setOverline(t){return this._style.ol=t.build(),this}setBackground(t){return this._style.bg=t,this}setBorder(t){return this._style.bd=t,this}setColor(t){return this._style.cl=t,this}setVerticalAlign(t){return this._style.va=t,this}copy(){return Kt.create(re.deepClone(this._style))}build(){return this.getValue()}}class Yt{constructor(t={s:1}){C(this,"_decoration");this._decoration=t}static create(t={s:1}){return new Yt(t)}get show(){return this._decoration.s===Ie.TRUE}get followFontColor(){return this._decoration.c===Ie.TRUE}get color(){return this._decoration.cl}get type(){return this._decoration.t}setShow(t){return this._decoration.s=t?1:0,this}setFollowFontColor(t){return this._decoration.c=t?1:0,this}setColor(t){return this._decoration.cl=t,this}setLineType(t){return this._decoration.t=t,this}copy(){return Yt.create(re.deepClone(this._decoration))}build(){return{...this._decoration}}}class hr{constructor(t={}){C(this,"_style");this._style=t}static create(t={}){return new hr(t)}get indentFirstLine(){return this._style.indentFirstLine}get hanging(){return this._style.hanging}get indentStart(){return this._style.indentStart}get tabStops(){return this._style.tabStops}get indentEnd(){return this._style.indentEnd}get textStyle(){return this._style.textStyle}get headingId(){return this._style.headingId}get namedStyleType(){return this._style.namedStyleType}get horizontalAlign(){return this._style.horizontalAlign}get lineSpacing(){return this._style.lineSpacing}get direction(){return this._style.direction}get spacingRule(){return this._style.spacingRule}get snapToGrid(){return this._style.snapToGrid}get spaceAbove(){return this._style.spaceAbove}get spaceBelow(){return this._style.spaceBelow}get borderBetween(){return this._style.borderBetween}get borderTop(){return this._style.borderTop}get borderBottom(){return this._style.borderBottom}get borderLeft(){return this._style.borderLeft}get borderRight(){return this._style.borderRight}get keepLines(){return this._style.keepLines===Ie.TRUE}get keepNext(){return this._style.keepNext===Ie.TRUE}get wordWrap(){return this._style.wordWrap===Ie.TRUE}get widowControl(){return this._style.widowControl===Ie.TRUE}get shading(){return this._style.shading}get suppressHyphenation(){return this._style.suppressHyphenation===Ie.TRUE}copy(){return Jn.create(re.deepClone(this._style))}getValue(){return this._style}}class Jn extends hr{static create(t={}){return new Jn(t)}constructor(t={}){super(t)}setIndentFirstLine(t){return this._style.indentFirstLine=t,this}setHanging(t){return this._style.hanging=t,this}setIndentStart(t){return this._style.indentStart=t,this}setTabStops(t){return this._style.tabStops=t,this}setIndentEnd(t){return this._style.indentEnd=t,this}setTextStyle(t){return this._style.textStyle=t,this}setHeadingId(t){return this._style.headingId=t,this}setNamedStyleType(t){return this._style.namedStyleType=t,this}setHorizontalAlign(t){return this._style.horizontalAlign=t,this}setLineSpacing(t){return this._style.lineSpacing=t,this}setDirection(t){return this._style.direction=t,this}setSpacingRule(t){return this._style.spacingRule=t,this}setSnapToGrid(t){return this._style.snapToGrid=t?1:0,this}setSpaceAbove(t){return this._style.spaceAbove=t,this}setSpaceBelow(t){return this._style.spaceBelow=t,this}setBorderBetween(t){return this._style.borderBetween=t,this}setBorderTop(t){return this._style.borderTop=t,this}setBorderBottom(t){return this._style.borderBottom=t,this}setBorderLeft(t){return this._style.borderLeft=t,this}setBorderRight(t){return this._style.borderRight=t,this}setKeepLines(t){return this._style.keepLines=t?1:0,this}setKeepNext(t){return this._style.keepNext=t?1:0,this}setWordWrap(t){return this._style.wordWrap=t?1:0,this}setWidowControl(t){return this._style.widowControl=t?1:0,this}setShading(t){return this._style.shading=t,this}setSuppressHyphenation(t){return this._style.suppressHyphenation=t?1:0,this}copy(){return Jn.create(re.deepClone(this._style))}build(){return this.getValue()}}class zt{constructor(t){C(this,"_data");if(!t.body)throw new Error("Invalid document data, body is required");this._data=iu(t)}static create(t){return new zt(t)}static createByBody(t){return new zt({body:t,id:"d",documentStyle:{}})}copy(){return rn.create(re.deepClone(this._data))}slice(t,n){const{body:r,...s}=this._data;return rn.create({...re.deepClone(s),body:bt(r,t,n)})}toPlainText(){var t,n;return it.transform.getPlainText((n=(t=this._data.body)==null?void 0:t.dataStream)!=null?n:"").replaceAll("\r",`
8
+ `,textRuns:[],customBlocks:[],tables:[],paragraphs:[{startIndex:0,paragraphStyle:{spaceAbove:{v:5},lineSpacing:1,spaceBelow:{v:0}}}],sectionBreaks:[{startIndex:1}]},documentStyle:{pageSize:{width:793.3333333333334,height:1122.6666666666667},documentFlavor:Qs.TRADITIONAL,marginTop:50,marginBottom:50,marginRight:50,marginLeft:50,renderConfig:{zeroWidthParagraphBreak:Ie.FALSE,vertexAngle:0,centerAngle:0,background:{rgb:"#ccc"}},autoHyphenation:Ie.TRUE,doNotHyphenateCaps:Ie.FALSE,consecutiveHyphenLimit:2,defaultHeaderId:"",defaultFooterId:"",evenPageHeaderId:"",evenPageFooterId:"",firstPageHeaderId:"",firstPageFooterId:"",evenAndOddHeaders:Ie.FALSE,useFirstPageHeaderFooter:Ie.FALSE,marginHeader:30,marginFooter:30},settings:{}}}var Qt={},Ln={},Cr={},uo;function e_(){if(uo)return Cr;uo=1,Object.defineProperty(Cr,"__esModule",{value:!0});function e(r,s){if(Array.isArray(s))return!1;for(let i in r)if(!n(r[i],s[i]))return!1;for(let i in s)if(r[i]===void 0)return!1;return!0}function t(r,s){if(!Array.isArray(s)||r.length!==s.length)return!1;for(let i=0;i<r.length;i++)if(!n(r[i],s[i]))return!1;return!0}function n(r,s){return r===s?!0:r===null||s===null||typeof r!="object"||typeof s!="object"?!1:Array.isArray(r)?t(r,s):e(r,s)}return Cr.default=n,Cr}var Rr={},co;function t_(){if(co)return Rr;co=1,Object.defineProperty(Rr,"__esModule",{value:!0});function e(t){if(t===null)return null;if(Array.isArray(t))return t.map(e);if(typeof t=="object"){const n={};for(let r in t)n[r]=e(t[r]);return n}else return t}return Rr.default=e,Rr}var _s={},ho;function Ll(){return ho||(ho=1,function(e){Object.defineProperty(e,"__esModule",{value:!0}),e.eachChildOf=e.advancer=e.readCursor=e.writeCursor=e.WriteCursor=e.ReadCursor=e.isValidPathItem=void 0;function t(c,h){if(!c)throw new Error(h)}const n=c=>c!=null&&typeof c=="object"&&!Array.isArray(c),r=(c,h)=>typeof c==typeof h?c>h:typeof c=="string"&&typeof h=="number";function s(c,h){for(let d in c){const f=d;h.write(f,c[f])}}e.isValidPathItem=c=>typeof c=="number"||typeof c=="string"&&c!=="__proto__";class i{constructor(h=null){this.parents=[],this.indexes=[],this.lcIdx=-1,this.idx=-1,this.container=h}ascend(){t(this.parents.length===this.indexes.length/2),this.idx===0?this.parents.length?(this.lcIdx=this.indexes.pop(),this.container=this.parents.pop(),this.idx=this.indexes.pop()):(this.lcIdx=0,this.idx=-1):(t(this.idx>0),this.idx--,n(this.container[this.idx])&&this.idx--)}getPath(){const h=[];let d=this.container,f=this.parents.length-1,E=this.idx;for(;E>=0;)h.unshift(d[E]),E===0?(E=this.indexes[f*2],d=this.parents[f--]):E-=n(d[E-1])?2:1;return h}}class o extends i{get(){return this.container?this.container.slice(this.idx+1):null}getKey(){return t(this.container!=null,"Invalid call to getKey before cursor descended"),this.container[this.idx]}getComponent(){let h;return this.container&&this.container.length>this.idx+1&&n(h=this.container[this.idx+1])?h:null}descendFirst(){let h=this.idx+1;if(!this.container||h>=this.container.length||n(this.container[h])&&h+1>=this.container.length)return!1;n(this.container[h])&&h++;const d=this.container[h];return Array.isArray(d)?(this.indexes.push(this.idx),this.parents.push(this.container),this.indexes.push(h),this.idx=0,this.container=d):this.idx=h,!0}nextSibling(){if(t(this.parents.length===this.indexes.length/2),this.idx>0||this.parents.length===0)return!1;const h=this.indexes[this.indexes.length-1]+1,d=this.parents[this.parents.length-1];return h>=d.length?!1:(t(!isNaN(h)),this.indexes[this.indexes.length-1]=h,this.container=d[h],!0)}_init(h,d,f,E){this.container=h,this.idx=d,this.parents=f.slice(),this.indexes=E.slice()}clone(){const h=new o;return h._init(this.container,this.idx,this.parents,this.indexes),h}*[Symbol.iterator](){if(this.descendFirst()){do yield this.getKey();while(this.nextSibling());this.ascend()}}traverse(h,d){const f=this.getComponent();f&&d(f,h);for(const E of this)h&&h.descend(E),this.traverse(h,d),h&&h.ascend()}eachPick(h,d){this.traverse(h,(f,E)=>{f.p!=null&&d(f.p,E)})}eachDrop(h,d){this.traverse(h,(f,E)=>{f.d!=null&&d(f.d,E)})}}e.ReadCursor=o;class a extends i{constructor(h=null){super(h),this.pendingDescent=[],this._op=h}flushDescent(){t(this.parents.length===this.indexes.length/2),this.container===null&&(this._op=this.container=[]);for(let h=0;h<this.pendingDescent.length;h++){const d=this.pendingDescent[h];let f=this.idx+1;if(f<this.container.length&&n(this.container[f])&&f++,t(f===this.container.length||!n(this.container[f])),f===this.container.length)this.container.push(d),this.idx=f;else if(this.container[f]===d)this.idx=f;else{if(!Array.isArray(this.container[f])){const E=this.container.splice(f,this.container.length-f);this.container.push(E),this.lcIdx>-1&&(this.lcIdx=f)}for(this.indexes.push(this.idx),this.parents.push(this.container),this.lcIdx!==-1&&(t(r(d,this.container[this.lcIdx][0])),f=this.lcIdx+1,this.lcIdx=-1);f<this.container.length&&r(d,this.container[f][0]);)f++;if(this.indexes.push(f),this.idx=0,f<this.container.length&&this.container[f][0]===d)this.container=this.container[f];else{const E=[d];this.container.splice(f,0,E),this.container=E}}}this.pendingDescent.length=0}reset(){this.lcIdx=-1}getComponent(){this.flushDescent();const h=this.idx+1;if(h<this.container.length&&n(this.container[h]))return this.container[h];{const d={};return this.container.splice(h,0,d),d}}write(h,d){const f=this.getComponent();t(f[h]==null||f[h]===d,"Internal consistency error: Overwritten component. File a bug"),f[h]=d}get(){return this._op}descend(h){if(!e.isValidPathItem(h))throw Error("Invalid JSON key");this.pendingDescent.push(h)}descendPath(h){return this.pendingDescent.push(...h),this}ascend(){this.pendingDescent.length?this.pendingDescent.pop():super.ascend()}mergeTree(h,d=s){if(h===null)return;if(t(Array.isArray(h)),h===this._op)throw Error("Cannot merge into my own tree");const f=this.lcIdx,E=this.parents.length;let R=0;for(let w=0;w<h.length;w++){const L=h[w];typeof L=="string"||typeof L=="number"?(R++,this.descend(L)):Array.isArray(L)?this.mergeTree(L,d):typeof L=="object"&&d(L,this)}for(;R--;)this.ascend();this.lcIdx=this.parents.length===E?f:-1}at(h,d){this.descendPath(h),d(this);for(let f=0;f<h.length;f++)this.ascend();return this}writeAtPath(h,d,f){return this.at(h,()=>this.write(d,f)),this.reset(),this}writeMove(h,d,f=0){return this.writeAtPath(h,"p",f).writeAtPath(d,"d",f)}getPath(){const h=super.getPath();return h.push(...this.pendingDescent),h}}e.WriteCursor=a,e.writeCursor=()=>new a,e.readCursor=c=>new o(c);function l(c,h,d){let f,E;E=f=c?c.descendFirst():!1;function R(w){let L;for(;E;){const J=L=c.getKey();if(w!=null){let z=!1;if(h&&typeof J=="number"&&(L=h(J,c.getComponent()),L<0&&(L=~L,z=!0)),r(L,w))return null;if(L===w&&!z)return c}d&&typeof L=="number"&&d(L,c.getComponent()),E=c.nextSibling()}return null}return R.end=()=>{f&&c.ascend()},R}e.advancer=l;function u(c,h,d){let f,E,R,w;for(f=E=c&&c.descendFirst(),R=w=h&&h.descendFirst();f||R;){let L=f?c.getKey():null,J=R?h.getKey():null;L!==null&&J!==null&&(r(J,L)?J=null:L!==J&&(L=null)),d(L==null?J:L,L!=null?c:null,J!=null?h:null),L!=null&&f&&(f=c.nextSibling()),J!=null&&R&&(R=h.nextSibling())}E&&c.ascend(),w&&h.ascend()}e.eachChildOf=u}(_s)),_s}var ps={},fo;function xl(){return fo||(fo=1,function(e){Object.defineProperty(e,"__esModule",{value:!0}),e.ConflictType=void 0,function(t){t[t.RM_UNEXPECTED_CONTENT=1]="RM_UNEXPECTED_CONTENT",t[t.DROP_COLLISION=2]="DROP_COLLISION",t[t.BLACKHOLE=3]="BLACKHOLE"}(e.ConflictType||(e.ConflictType={}))}(ps)),ps}var It={},en={},go;function ci(){return go||(go=1,Object.defineProperty(en,"__esModule",{value:!0}),en.uniToStrPos=en.strPosToUni=void 0,en.strPosToUni=(e,t=e.length)=>{let n=0,r=0;for(;r<t;r++){const s=e.charCodeAt(r);s>=55296&&s<=57343&&(n++,r++)}if(r!==t)throw Error("Invalid offset - splits unicode bytes");return r-n},en.uniToStrPos=(e,t)=>{let n=0;for(;t>0;t--){const r=e.charCodeAt(n);n+=r>=55296&&r<=57343?2:1}return n}),en}var Es={},mo;function Ps(){return mo||(mo=1,function(e){Object.defineProperty(e,"__esModule",{value:!0}),e.uniSlice=e.dlen=e.eachOp=void 0;const t=ci(),n=N=>{if(!Array.isArray(N))throw Error("Op must be an array of components");let A=null;for(let j=0;j<N.length;j++){const Z=N[j];switch(typeof Z){case"object":if(typeof Z.d!="number"&&typeof Z.d!="string")throw Error("Delete must be number or string");if(e.dlen(Z.d)<=0)throw Error("Deletes must not be empty");break;case"string":if(!(Z.length>0))throw Error("Inserts cannot be empty");break;case"number":if(!(Z>0))throw Error("Skip components must be >0");if(typeof A=="number")throw Error("Adjacent skip components should be combined");break}A=Z}if(typeof A=="number")throw Error("Op has a trailing skip")};function r(N,A){let j=0,Z=0;for(let fe=0;fe<N.length;fe++){const ae=N[fe];switch(A(ae,j,Z),typeof ae){case"object":j+=e.dlen(ae.d);break;case"string":Z+=t.strPosToUni(ae);break;case"number":j+=ae,Z+=ae;break}}}e.eachOp=r;function s(N,A){const j=[],Z=a(j);return r(N,(fe,ae,_)=>{Z(A(fe,ae,_))}),h(j)}const i=N=>N,o=N=>s(N,i);e.dlen=N=>typeof N=="number"?N:t.strPosToUni(N);const a=N=>A=>{if(!(!A||A.d===0||A.d===""))if(N.length===0)N.push(A);else if(typeof A==typeof N[N.length-1])if(typeof A=="object"){const j=N[N.length-1];j.d=typeof j.d=="string"&&typeof A.d=="string"?j.d+A.d:e.dlen(j.d)+e.dlen(A.d)}else N[N.length-1]+=A;else N.push(A)},l=N=>typeof N=="number"?N:typeof N=="string"?t.strPosToUni(N):typeof N.d=="number"?N.d:t.strPosToUni(N.d);e.uniSlice=(N,A,j)=>{const Z=t.uniToStrPos(N,A),fe=j==null?1/0:t.uniToStrPos(N,j);return N.slice(Z,fe)};const u=(N,A,j)=>typeof N=="number"?j==null?N-A:Math.min(N,j)-A:e.uniSlice(N,A,j),c=N=>{let A=0,j=0;return{take:(ae,_)=>{if(A===N.length)return ae===-1?null:ae;const H=N[A];let v;if(typeof H=="number")return ae===-1||H-j<=ae?(v=H-j,++A,j=0,v):(j+=ae,ae);if(typeof H=="string"){if(ae===-1||_==="i"||t.strPosToUni(H.slice(j))<=ae)return v=H.slice(j),++A,j=0,v;{const M=j+t.uniToStrPos(H.slice(j),ae);return v=H.slice(j,M),j=M,v}}else{if(ae===-1||_==="d"||e.dlen(H.d)-j<=ae)return v={d:u(H.d,j)},++A,j=0,v;{let M=u(H.d,j,j+ae);return j+=ae,{d:M}}}},peek:()=>N[A]}},h=N=>(N.length>0&&typeof N[N.length-1]=="number"&&N.pop(),N);function d(N,A,j){if(j!=="left"&&j!=="right")throw Error("side ("+j+") must be 'left' or 'right'");n(N),n(A);const Z=[],fe=a(Z),{take:ae,peek:_}=c(N);for(let v=0;v<A.length;v++){const M=A[v];let b,O;switch(typeof M){case"number":for(b=M;b>0;)O=ae(b,"i"),fe(O),typeof O!="string"&&(b-=l(O));break;case"string":j==="left"&&typeof _()=="string"&&fe(ae(-1)),fe(t.strPosToUni(M));break;case"object":for(b=e.dlen(M.d);b>0;)switch(O=ae(b,"i"),typeof O){case"number":b-=O;break;case"string":fe(O);break;case"object":b-=e.dlen(O.d)}break}}let H;for(;H=ae(-1);)fe(H);return h(Z)}function f(N,A){n(N),n(A);const j=[],Z=a(j),{take:fe}=c(N);for(let _=0;_<A.length;_++){const H=A[_];let v,M;switch(typeof H){case"number":for(v=H;v>0;)M=fe(v,"d"),Z(M),typeof M!="object"&&(v-=l(M));break;case"string":Z(H);break;case"object":v=e.dlen(H.d);let b=0;for(;b<v;)switch(M=fe(v-b,"d"),typeof M){case"number":Z({d:u(H.d,b,b+M)}),b+=M;break;case"string":b+=t.strPosToUni(M);break;case"object":Z(M)}break}}let ae;for(;ae=fe(-1);)Z(ae);return h(j)}const E=(N,A)=>{let j=0;for(let Z=0;Z<A.length&&N>j;Z++){const fe=A[Z];switch(typeof fe){case"number":{j+=fe;break}case"string":const ae=t.strPosToUni(fe);j+=ae,N+=ae;break;case"object":N-=Math.min(e.dlen(fe.d),N-j);break}}return N},R=(N,A)=>typeof N=="number"?E(N,A):N.map(j=>E(j,A));function w(N,A,j){return s(N,(Z,fe)=>typeof Z=="object"&&typeof Z.d=="number"?{d:j.slice(A,fe,fe+Z.d)}:Z)}function L(N){return s(N,A=>{switch(typeof A){case"object":if(typeof A.d=="number")throw Error("Cannot invert text op: Deleted characters missing from operation. makeInvertible must be called first.");return A.d;case"string":return{d:A};case"number":return A}})}function J(N){return s(N,A=>typeof A=="object"&&typeof A.d=="string"?{d:t.strPosToUni(A.d)}:A)}function z(N){let A=!0;return r(N,j=>{typeof j=="object"&&typeof j.d=="number"&&(A=!1)}),A}function de(N){return{name:"text-unicode",uri:"http://sharejs.org/types/text-unicode",trim:h,normalize:o,checkOp:n,create(A=""){if(typeof A!="string")throw Error("Initial data must be a string");return N.create(A)},apply(A,j){n(j);const Z=N.builder(A);for(let fe=0;fe<j.length;fe++){const ae=j[fe];switch(typeof ae){case"number":Z.skip(ae);break;case"string":Z.append(ae);break;case"object":Z.del(e.dlen(ae.d));break}}return Z.build()},transform:d,compose:f,transformPosition:E,transformSelection:R,isInvertible:z,makeInvertible(A,j){return w(A,j,N)},stripInvertible:J,invert:L,invertWithDoc(A,j){return L(w(A,j,N))},isNoop:A=>A.length===0}}e.default=de}(Es)),Es}var Ir={},_o;function n_(){if(_o)return Ir;_o=1,Object.defineProperty(Ir,"__esModule",{value:!0});const e=Ps(),t=ci();function n(r,s){return{get:r,getLength(){return r().length},insert(i,o,a){const l=t.strPosToUni(r(),i);return s([l,o],a)},remove(i,o,a){const l=t.strPosToUni(r(),i);return s([l,{d:o}],a)},_onOp(i){e.eachOp(i,(o,a,l)=>{switch(typeof o){case"string":this.onInsert&&this.onInsert(l,o);break;case"object":const u=e.dlen(o.d);this.onRemove&&this.onRemove(l,u)}})},onInsert:null,onRemove:null}}return Ir.default=n,n.provides={text:!0},Ir}var po;function r_(){return po||(po=1,function(e){var t=It&&It.__createBinding||(Object.create?function(d,f,E,R){R===void 0&&(R=E),Object.defineProperty(d,R,{enumerable:!0,get:function(){return f[E]}})}:function(d,f,E,R){R===void 0&&(R=E),d[R]=f[E]}),n=It&&It.__setModuleDefault||(Object.create?function(d,f){Object.defineProperty(d,"default",{enumerable:!0,value:f})}:function(d,f){d.default=f}),r=It&&It.__importStar||function(d){if(d&&d.__esModule)return d;var f={};if(d!=null)for(var E in d)Object.hasOwnProperty.call(d,E)&&t(f,d,E);return n(f,d),f},s=It&&It.__importDefault||function(d){return d&&d.__esModule?d:{default:d}};Object.defineProperty(e,"__esModule",{value:!0}),e.type=e.remove=e.insert=void 0;const i=ci(),o=r(Ps()),a=s(n_()),l={create(d){return d},toString(d){return d},builder(d){if(typeof d!="string")throw Error("Invalid document snapshot: "+d);const f=[];return{skip(E){let R=i.uniToStrPos(d,E);if(R>d.length)throw Error("The op is too long for this document");f.push(d.slice(0,R)),d=d.slice(R)},append(E){f.push(E)},del(E){d=d.slice(i.uniToStrPos(d,E))},build(){return f.join("")+d}}},slice:o.uniSlice},u=o.default(l),c=Object.assign(Object.assign({},u),{api:a.default});e.type=c,e.insert=(d,f)=>f.length===0?[]:d===0?[f]:[d,f],e.remove=(d,f)=>o.dlen(f)===0?[]:d===0?[{d:f}]:[d,{d:f}];var h=Ps();Object.defineProperty(e,"makeType",{enumerable:!0,get:function(){return h.default}})}(It)),It}var Eo;function s_(){return Eo||(Eo=1,function(e){var t=Ln&&Ln.__importDefault||function(S){return S&&S.__esModule?S:{default:S}};Object.defineProperty(e,"__esModule",{value:!0}),e.editOp=e.replaceOp=e.insertOp=e.moveOp=e.removeOp=e.type=void 0;const n=t(e_()),r=t(t_()),s=Ll(),i=xl();function o(S,F){if(!S)throw new Error(F)}e.type={name:"json1",uri:"http://sharejs.org/types/JSONv1",readCursor:s.readCursor,writeCursor:s.writeCursor,create:S=>S,isNoop:S=>S==null,setDebug(S){},registerSubtype:L,checkValidOp:fe,normalize:ae,apply:_,transformPosition:H,compose:v,tryTransform:V,transform:he,makeInvertible:O,invert:M,invertWithDoc:P,RM_UNEXPECTED_CONTENT:i.ConflictType.RM_UNEXPECTED_CONTENT,DROP_COLLISION:i.ConflictType.DROP_COLLISION,BLACKHOLE:i.ConflictType.BLACKHOLE,transformNoConflict:(S,F,G)=>ye(()=>!0,S,F,G),typeAllowingConflictsPred:S=>Object.assign(Object.assign({},e.type),{transform:(F,G,X)=>ye(S,F,G,X)})};const a=S=>S?S.getComponent():null;function l(S){return S&&typeof S=="object"&&!Array.isArray(S)}const u=S=>Array.isArray(S)?S.slice():S!==null&&typeof S=="object"?Object.assign({},S):S,c=S=>S&&(S.p!=null||S.r!==void 0),h=S=>S&&(S.d!=null||S.i!==void 0);function d(S,F){return o(S!=null),typeof F=="number"?(o(Array.isArray(S),"Invalid key - child is not an array"),(S=S.slice()).splice(F,1)):(o(l(S),"Invalid key - child is not an object"),delete(S=Object.assign({},S))[F]),S}function f(S,F,G){return typeof F=="number"?(o(S!=null,"Container is missing for key"),o(Array.isArray(S),"Cannot use numerical key for object container"),o(S.length>=F,"Cannot insert into out of bounds index"),S.splice(F,0,G)):(o(l(S),"Cannot insert into missing item"),o(S[F]===void 0,"Trying to overwrite value at key. Your op needs to remove it first"),S[F]=G),G}e.removeOp=(S,F=!0)=>s.writeCursor().writeAtPath(S,"r",F).get(),e.moveOp=(S,F)=>s.writeCursor().writeMove(S,F).get(),e.insertOp=(S,F)=>s.writeCursor().writeAtPath(S,"i",F).get(),e.replaceOp=(S,F,G)=>s.writeCursor().at(S,X=>{X.write("r",F),X.write("i",G)}).get(),e.editOp=(S,F,G,X=!1)=>s.writeCursor().at(S,Y=>A(Y,F,G,X)).get();const E=(S,F)=>S!=null&&(typeof F=="number"?Array.isArray(S):typeof S=="object"),R=(S,F)=>E(S,F)?S[F]:void 0,w={};function L(S){let F=S.type?S.type:S;F.name&&(w[F.name]=F),F.uri&&(w[F.uri]=F)}const J=S=>{const F=w[S];if(F)return F;throw Error("Missing type: "+S)};L(r_());const z=(S,F)=>S+F;L({name:"number",apply:z,compose:z,invert:S=>-S,transform:S=>S});const de=S=>S==null?null:S.et?J(S.et):S.es?w["text-unicode"]:S.ena!=null?w.number:null,N=S=>S.es?S.es:S.ena!=null?S.ena:S.e,A=(S,F,G,X=!1)=>{const[Y,W]=typeof F=="string"?[J(F),F]:[F,F.name];!X&&Y.isNoop&&Y.isNoop(G)||(W==="number"?S.write("ena",G):W==="text-unicode"?S.write("es",G):(S.write("et",W),S.write("e",G)))};function j(S){o(typeof S=="number"),o(S>=0),o(S===(0|S))}function Z(S){typeof S=="number"?j(S):o(typeof S=="string")}function fe(S){if(S===null)return;const F=new Set,G=new Set,X=W=>{let le=!0,oe=!1;for(let B in W){const te=W[B];if(le=!1,o(B==="p"||B==="r"||B==="d"||B==="i"||B==="e"||B==="es"||B==="ena"||B==="et","Invalid component item '"+B+"'"),B==="p")j(te),o(!F.has(te)),F.add(te),o(W.r===void 0);else if(B==="d")j(te),o(!G.has(te)),G.add(te),o(W.i===void 0);else if(B==="e"||B==="es"||B==="ena"){o(!oe),oe=!0;const ie=de(W);o(ie,"Missing type in edit"),ie.checkValidOp&&ie.checkValidOp(N(W))}}o(!le)},Y=(W,le,oe)=>{if(!Array.isArray(W))throw Error("Op must be null or a list");if(W.length===0)throw Error("Empty descent");le||Z(W[0]);let B=1,te=0,ie=0;for(let me=0;me<W.length;me++){const be=W[me];if(o(be!=null),Array.isArray(be)){const De=Y(be,!1);if(te){const K=typeof ie,Re=typeof De;K===Re?o(ie<De,"descent keys are not in order"):o(K==="number"&&Re==="string")}ie=De,te++,B=3}else typeof be=="object"?(o(B===1,`Prev not scalar - instead ${B}`),X(be),B=2):(o(B!==3),Z(be),o(s.isValidPathItem(be),"Invalid path key"),B=1)}return o(te!==1,"Operation makes multiple descents. Remove some []"),o(B===2||B===3),W[0]};Y(S,!0),o(F.size===G.size,"Mismatched picks and drops in op");for(let W=0;W<F.size;W++)o(F.has(W)),o(G.has(W))}function ae(S){let F=0,G=[];const X=s.writeCursor();return X.mergeTree(S,(Y,W)=>{const le=de(Y);if(le){const B=N(Y);A(W,le,le.normalize?le.normalize(B):B)}for(const B of["r","p","i","d"])if(Y[B]!==void 0){const te=B==="p"||B==="d"?(oe=Y[B],G[oe]==null&&(G[oe]=F++),G[oe]):Y[B];W.write(B,te)}var oe}),X.get()}function _(S,F){if(fe(F),F===null)return S;const G=[];return function X(Y,W){let le=Y,oe=0,B={root:Y},te=0,ie=B,me="root";function be(){for(;te<oe;te++){let De=W[te];typeof De!="object"&&(o(E(ie,me)),ie=ie[me]=u(ie[me]),me=De)}}for(;oe<W.length;oe++){const De=W[oe];if(Array.isArray(De)){const K=X(le,De);K!==le&&K!==void 0&&(be(),le=ie[me]=K)}else if(typeof De=="object"){De.d!=null?(be(),le=f(ie,me,G[De.d])):De.i!==void 0&&(be(),le=f(ie,me,De.i));const K=de(De);if(K)be(),le=ie[me]=K.apply(le,N(De));else if(De.e!==void 0)throw Error("Subtype "+De.et+" undefined")}else le=R(le,De)}return B.root}(S=function X(Y,W){const le=[];let oe=0;for(;oe<W.length;oe++){const me=W[oe];if(Array.isArray(me))break;typeof me!="object"&&(le.push(Y),Y=R(Y,me))}for(let me=W.length-1;me>=oe;me--)Y=X(Y,W[me]);for(--oe;oe>=0;oe--){const me=W[oe];if(typeof me!="object"){const be=le.pop();Y=Y===R(be,me)?be:Y===void 0?d(be,me):(te=me,ie=Y,(B=u(B=be))[te]=ie,B)}else c(me)&&(o(Y!==void 0,"Cannot pick up or remove undefined"),me.p!=null&&(G[me.p]=Y),Y=void 0)}var B,te,ie;return Y}(S,F),F)}function H(S,F){S=S.slice(),fe(F);const G=s.readCursor(F);let X,Y,W=!1;const le=[];for(let B=0;;B++){const te=S[B],ie=G.getComponent();if(ie&&(ie.r!==void 0?W=!0:ie.p!=null&&(W=!1,X=ie.p,Y=B)),B>=S.length)break;let me=0;const be=s.advancer(G,void 0,(K,Re)=>{c(Re)&&me++});le.unshift(be);const De=be(te);if(typeof te=="number"&&(S[B]-=me),!De)break}if(le.forEach(B=>B.end()),W)return null;const oe=()=>{let B=0;if(X!=null){const te=G.getPath();B=te.length,S=te.concat(S.slice(Y))}for(;B<S.length;B++){const te=S[B],ie=a(G),me=de(ie);if(me){const K=N(ie);me.transformPosition&&(S[B]=me.transformPosition(S[B],K));break}let be=0;const De=s.advancer(G,(K,Re)=>h(Re)?~(K-be):K-be,(K,Re)=>{h(Re)&&be++})(te);if(typeof te=="number"&&(S[B]+=be),!De)break}};return X!=null?G.eachDrop(null,B=>{B===X&&oe()}):oe(),S}function v(S,F){if(fe(S),fe(F),S==null)return F;if(F==null)return S;let G=0;const X=s.readCursor(S),Y=s.readCursor(F),W=s.writeCursor(),le=[],oe=[],B=[],te=[],ie=[],me=[],be=new Set;X.traverse(null,K=>{K.p!=null&&(B[K.p]=X.clone())}),Y.traverse(null,K=>{K.d!=null&&(te[K.d]=Y.clone())});const De=s.writeCursor();return function K(Re,ze,He,xe,qe,mt,Ve,et){o(ze||He);const Ge=a(ze),ut=a(He),ot=!!ut&&ut.r!==void 0,Dt=!!Ge&&Ge.i!==void 0,Fe=Ge?Ge.d:null,ct=ut?ut.p:null,p=(mt||ot)&&ct==null;if(ct!=null)xe=te[ct],Ve=oe[ct]=new s.WriteCursor;else if(ut&&ut.r!==void 0)xe=null;else{const D=a(xe);D&&D.d!=null&&(xe=null)}const g=a(xe);if(Fe!=null)if(Re=B[Fe],et=le[Fe]=new s.WriteCursor,p)mt&&!ot&&et.write("r",!0);else{const D=ie[Fe]=G++;Ve.write("d",D)}else if(Ge&&Ge.i!==void 0)Re=null;else{const D=a(Re);D&&D.p!=null&&(Re=null)}let m;Dt?(o(qe===void 0),m=Ge.i):m=qe;const y=(ct==null?!Dt||mt||ot:m===void 0)?null:Ve.getComponent();if(ct!=null){if(!(qe!==void 0||Dt)){const D=Fe!=null?ie[Fe]:G++;me[ct]=D,et.write("p",D)}}else ot&&(Dt||qe!==void 0||(ut.r,et.write("r",ut.r)));const T=p?null:de(Ge),U=de(g);if((T||U)&&(T&&T.name,U&&U.name),T&&U){o(T===U);const D=N(Ge),ee=N(g),Ce=T.compose(D,ee);A(Ve,T,Ce),be.add(g)}else T?A(Ve,T,N(Ge)):U&&(A(Ve,U,N(g)),be.add(g));const x=typeof m=="object"&&m!=null;let k=!1,I=0,Q=0,pe=0,q=0,_e=0;const Oe=s.advancer(xe,(D,ee)=>h(ee)?q-D-1:D-q,(D,ee)=>{h(ee)&&q++}),ue=s.advancer(Re,(D,ee)=>c(ee)?I-D-1:D-I,(D,ee)=>{c(ee)&&I++});if(s.eachChildOf(ze,He,(D,ee,Ce)=>{let Ae,Ue,Pe=D,We=D,ht=D;if(typeof D=="number"){let Me=D+pe;Ue=Oe(Me),We=Me+q;let ne=D+Q;Ae=ue(ne),h(a(Ue))&&(Ae=null),Pe=ne+I,ht=D+_e,o(Pe>=0,"p1PickKey is negative"),o(We>=0,"p2DropKey is negative");const at=h(a(ee)),Be=c(a(Ce));(at||Be&&!p)&&_e--,at&&Q--,Be&&pe--}else Ae=ue(D),Ue=Oe(D);et.descend(Pe),Ve.descend(We);const ft=x&&!h(a(ee))?m[ht]:void 0,Ee=K(Ae,ee,Ce,Ue,ft,p,Ve,et);var Qe,ve,Se;x&&!p?ft!==Ee&&(k||(m=Array.isArray(m)?m.slice():Object.assign({},m),k=!0),Qe=m,Se=Ee,typeof(ve=ht)=="number"?(o(Array.isArray(Qe)),o(ve<Qe.length)):(o(!Array.isArray(Qe)),o(Qe[ve]!==void 0)),Se===void 0?typeof ve=="number"?Qe.splice(ve,1):delete Qe[ve]:Qe[ve]=Se):o(Ee===void 0),Ve.ascend(),et.ascend()}),ue.end(),Oe.end(),y!=null)y.i=m;else if(!mt&&!ot&&ct==null)return m}(X,X.clone(),Y,Y.clone(),void 0,!1,W,De),W.reset(),W.mergeTree(De.get()),W.reset(),W.get(),le.map(K=>K.get()),oe.map(K=>K.get()),X.traverse(W,(K,Re)=>{const ze=K.p;if(ze!=null){const He=ie[ze];He!=null&&Re.write("p",He);const xe=le[ze];xe&&xe.get(),xe&&Re.mergeTree(xe.get())}else K.r!==void 0&&Re.write("r",K.r)}),W.reset(),W.get(),Y.traverse(W,(K,Re)=>{const ze=K.d;if(ze!=null){const xe=me[ze];xe!=null&&Re.write("d",xe);const qe=oe[ze];qe&&Re.mergeTree(qe.get())}else K.i!==void 0&&Re.write("i",K.i);const He=de(K);He&&!be.has(K)&&A(Re,He,N(K))}),W.get()}function M(S){if(S==null)return null;const F=new s.ReadCursor(S),G=new s.WriteCursor;let X;const Y=[],W=[];return function le(oe,B,te){const ie=oe.getComponent();let me,be=!1;if(ie){ie.p!=null&&(B.write("d",ie.p),Y[ie.p]=oe.clone()),ie.r!==void 0&&B.write("i",ie.r),ie.d!=null&&(B.write("p",ie.d),te=void 0),ie.i!==void 0&&(te=me=ie.i);const K=de(ie);K&&(te===void 0?(X||(X=new Set),X.add(ie)):(N(ie),te=K.apply(te,N(ie)),be=!0))}let De=0;for(const K of oe){B.descend(K);const Re=typeof K=="number"?K-De:K,ze=R(te,Re);h(oe.getComponent())&&De++;const He=le(oe,B,ze);if(te!==void 0&&He!==void 0){if(be||(be=!0,te=u(te)),!E(te,Re))throw Error("Cannot modify child - invalid operation");te[Re]=He}B.ascend()}if(me===void 0)return be?te:void 0;B.write("r",te)}(F,G,void 0),X&&(G.reset(),function le(oe,B,te){const ie=B.getComponent();if(ie){const K=ie.d;if(K!=null&&(oe=Y[K],te=W[K]=s.writeCursor()),X.has(ie)){const Re=de(ie);if(!Re.invert)throw Error(`Cannot invert subtype ${Re.name}`);A(te,Re,Re.invert(N(ie)))}}let me=0,be=0;const De=s.advancer(oe,(K,Re)=>c(Re)?me-K-1:K-me,(K,Re)=>{c(Re)&&me++});for(const K of B)if(typeof K=="number"){const Re=K-be,ze=De(Re),He=Re+me;te.descend(He),le(ze,B,te),h(B.getComponent())&&be++,te.ascend()}else te.descend(K),le(De(K),B,te),te.ascend();De.end()}(F.clone(),F,G),W.length&&(G.reset(),F.traverse(G,(le,oe)=>{const B=le.p;if(B!=null){const te=W[B];te&&te.get(),te&&oe.mergeTree(te.get())}}))),G.get()}const b=(S,F)=>S.some(G=>typeof G=="object"&&(Array.isArray(G)?b(G,F):F(G)));function O(S,F){if(S==null||!b(S,B=>{var te;return B.r!==void 0||((te=de(B))===null||te===void 0?void 0:te.makeInvertible)!=null}))return S;const G=new s.ReadCursor(S),X=new s.WriteCursor;let Y=!1;const W=[],le=[],oe=(B,te,ie)=>{const me=B.getComponent();let be=!1;if(me){me.d!=null&&te.write("d",me.d),me.i!==void 0&&te.write("i",me.i);const K=me.p;if(K!=null&&(W[K]=B.clone(),o(ie!==void 0,"Operation picks up at an invalid key"),le[K]=ie,te.write("p",me.p)),me.r!==void 0&&ie===void 0)throw Error("Invalid doc / op in makeInvertible: removed item missing from doc");const Re=de(me);Re&&(Re.makeInvertible?Y=!0:A(te,Re,N(me),!0))}let De=0;for(const K of B){te.descend(K);const Re=typeof K=="number"?K-De:K,ze=R(ie,Re),He=oe(B,te,ze);ze!==He&&(be||(be=!0,ie=u(ie)),He===void 0?(ie=d(ie,Re),typeof K=="number"&&De++):ie[Re]=He),te.ascend()}return me&&(me.r!==void 0?(te.write("r",r.default(ie)),ie=void 0):me.p!=null&&(ie=void 0)),ie};return oe(G,X,F),X.get(),Y&&(X.reset(),function B(te,ie,me,be,De){const K=ie.getComponent();if(K){K.i!==void 0?(be=K.i,De=!0):K.d!=null&&(be=le[K.d],te=W[K.d],De=!1,K.d);let xe=de(K);if(xe&&xe.makeInvertible){const qe=N(K);A(me,xe,xe.makeInvertible(qe,be),!0)}}let Re=0,ze=0;const He=s.advancer(te,(xe,qe)=>c(qe)?Re-xe-1:xe-Re,(xe,qe)=>{c(qe)&&Re++});for(const xe of ie)if(typeof xe=="number"){const qe=xe-ze,mt=He(qe),Ve=qe+Re,et=R(be,De?qe:Ve);me.descend(xe),B(mt,ie,me,et,De),h(ie.getComponent())&&ze++,me.ascend()}else{const qe=R(be,xe);me.descend(xe),B(He(xe),ie,me,qe,De),me.ascend()}He.end()}(G.clone(),G,X,F,!1)),X.get()}function P(S,F){return M(O(S,F))}const $=S=>{if(S==null)return null;const F=S.slice();for(let G=0;G<S.length;G++){const X=F[G];Array.isArray(X)&&(F[G]=$(X))}return F};function V(S,F,G){o(G==="left"||G==="right","Direction must be left or right");const X=G==="left"?0:1;if(F==null)return{ok:!0,result:S};fe(S),fe(F);let Y=null;const W=[],le=[],oe=[],B=[],te=[],ie=[],me=[],be=[],De=[],K=[],Re=[],ze=[],He=[],xe=[],qe=[];let mt=0;const Ve=s.readCursor(S),et=s.readCursor(F),Ge=s.writeCursor();if(function g(m,y=null,T){const U=a(y);U&&(U.r!==void 0?T=y.clone():U.p!=null&&(T=null,ie[U.p]=m.clone()));const x=m.getComponent();let k;x&&(k=x.p)!=null&&(te[k]=y?y.clone():null,oe[k]=m.clone(),T&&(K[k]=!0,De[k]=T),U&&U.p!=null&&(xe[k]=U.p));const I=s.advancer(y);for(const Q of m)g(m,I(Q),T);I.end()}(et,Ve,null),function g(m,y,T,U,x){const k=T.getComponent();let I,Q=!1;k&&((I=k.d)!=null?(B[I]=T.clone(),U!=null&&(qe[U]==null&&(qe[U]=[]),qe[U].push(I)),K[I],m=te[I]||null,y=oe[I]||null,K[I]?(x&&(Re[I]=!0),x=De[I]||null):!x||X!==1&&xe[I]!=null||Y==null&&(Y={type:i.ConflictType.RM_UNEXPECTED_CONTENT,op1:e.removeOp(x.getPath()),op2:e.moveOp(y.getPath(),T.getPath())}),Q=!0):k.i!==void 0&&(m=y=null,Q=!0,x&&Y==null&&(Y={type:i.ConflictType.RM_UNEXPECTED_CONTENT,op1:e.removeOp(x.getPath()),op2:e.insertOp(T.getPath(),k.i)})));const pe=a(m);pe&&(pe.r!==void 0?x=m.clone():pe.p!=null&&(pe.p,U=pe.p,x=null));const q=de(k);q&&x&&Y==null&&(Y={type:i.ConflictType.RM_UNEXPECTED_CONTENT,op1:e.removeOp(x.getPath()),op2:e.editOp(T.getPath(),q,N(k),!0)});let _e=0,Oe=0;const ue=s.advancer(y,(ee,Ce)=>c(Ce)?_e-ee-1:ee-_e,(ee,Ce)=>{c(Ce)&&_e++}),D=s.advancer(m);for(const ee of T)if(typeof ee=="number"){const Ce=ee-Oe,Ae=ue(Ce);Oe+=+g(D(Ce+_e),Ae,T,U,x)}else{const Ce=ue(ee);g(D(ee),Ce,T,U,x)}return ue.end(),D.end(),Q}(Ve,et,et.clone(),null,null),B.map(g=>g&&g.get()),Y)return{ok:!1,conflict:Y};Re.map(g=>!!g);const ut=[];let ot=null;(function g(m,y,T,U,x){let k=!1;const I=a(y);if(c(I)){const ue=I.p;ue!=null?(T=B[ue],U=ze[ue]=s.writeCursor(),k=!0,x=null):(T=null,x=y.clone())}else h(a(T))&&(T=null);const Q=m.getComponent();if(Q){const ue=Q.p;ue!=null?(x&&(be[ue]=x),ut[ue]=x||X===1&&k?null:U.getComponent(),W[ue]=m.clone(),T&&(me[ue]=T.clone())):Q.r!==void 0&&(x||U.write("r",!0),(x||k)&&(ot==null&&(ot=new Set),ot.add(Q)))}let pe=0,q=0;const _e=s.advancer(y,void 0,(ue,D)=>{c(D)&&pe++}),Oe=s.advancer(T,(ue,D)=>h(D)?~(ue-q):ue-q,(ue,D)=>{h(D)&&q++});if(m)for(const ue of m)if(typeof ue=="string"){const D=_e(ue),ee=Oe(ue);U.descend(ue),g(m,D,ee,U,x),U.ascend()}else{const D=_e(ue),ee=ue-pe,Ce=c(a(D))?null:Oe(ee),Ae=ee+q;o(Ae>=0),U.descend(Ae),g(m,D,Ce,U,x),U.ascend()}_e.end(),Oe.end()})(Ve,et,et.clone(),Ge,null),Ge.reset();let Dt=[];if(function g(m,y,T,U,x,k){o(y);const I=y.getComponent();let Q=a(U),pe=!1;const q=(ve,Se,Me)=>ve?e.moveOp(ve.getPath(),Se.getPath()):e.insertOp(Se.getPath(),Me.i);if(h(I)){const ve=I.d;ve!=null&&(le[ve]=y.clone());const Se=ve!=null?ut[ve]:null;let Me=!1;if(I.i!==void 0||ve!=null&&Se){let ne;Q&&(Q.i!==void 0||(ne=Q.d)!=null&&!K[ne])&&(Me=ne!=null?ve!=null&&ve===xe[ne]:n.default(Q.i,I.i),Me||ne!=null&&X!==1&&xe[ne]!=null||Y==null&&(Y={type:i.ConflictType.DROP_COLLISION,op1:q(ve!=null?W[ve]:null,y,I),op2:q(ne!=null?oe[ne]:null,U,Q)})),Me||(k?Y==null&&(Y={type:i.ConflictType.RM_UNEXPECTED_CONTENT,op1:q(ve!=null?W[ve]:null,y,I),op2:e.removeOp(k.getPath())}):(ve!=null?(Dt[mt]=ve,x.write("d",Se.p=mt++)):x.write("i",r.default(I.i)),pe=!0))}else if(ve!=null&&!Se){const ne=be[ve];ne&&(k=ne.clone())}ve!=null?(m=W[ve],T=ie[ve],U=me[ve]):I.i!==void 0&&(m=T=null,Me||(U=null))}else c(a(m))&&(m=T=U=null);const _e=a(m),Oe=a(T);if(c(Oe)){const ve=Oe.p;Oe.r!==void 0&&(!_e||_e.r===void 0)||K[ve]?(U=null,k=T.clone()):ve!=null&&(U=B[ve],X!==1&&xe[ve]!=null||((x=He[ve])||(x=He[ve]=s.writeCursor()),x.reset(),k=null))}else!h(I)&&h(Q)&&(U=null);Q=U!=null?U.getComponent():null;const ue=de(I);if(ue){const ve=N(I);if(k)Y==null&&(Y={type:i.ConflictType.RM_UNEXPECTED_CONTENT,op1:e.editOp(y.getPath(),ue,ve,!0),op2:e.removeOp(k.getPath())});else{const Se=de(Q);let Me;if(Se){if(ue!==Se)throw Error("Transforming incompatible types");const ne=N(Q);Me=ue.transform(ve,ne,G)}else Me=r.default(ve);A(x,ue,Me)}}let D=0,ee=0,Ce=0,Ae=0,Ue=0,Pe=0,We=m!=null&&m.descendFirst(),ht=We;const ft=s.advancer(T,void 0,(ve,Se)=>{c(Se)&&Ce++});let Ee=U!=null&&U.descendFirst(),Qe=Ee;for(const ve of y)if(typeof ve=="number"){let Se;const Me=h(y.getComponent()),ne=ve-ee;{let $t;for(;We&&typeof($t=m.getKey())=="number";){$t+=D;const Rt=m.getComponent(),cn=c(Rt);if($t>ne||$t===ne&&(!cn||X===0&&Me))break;if(cn){D--;const Zt=Rt.p;xe.includes(Zt),Rt.d,a(He[Rt.d]),c(a(He[Rt.d])),(Rt.r===void 0||ot&&ot.has(Rt))&&(Zt==null||!ut[Zt]||X!==1&&xe.includes(Zt))||Ue--}We=m.nextSibling()}Se=We&&$t===ne?m:null}const at=ne-D;let Be=ft(at);const At=at-Ce;let dr=null;{let $t,Rt;for(;Ee&&typeof($t=U.getKey())=="number";){Rt=$t-Ae;const cn=U.getComponent(),Zt=h(cn);if(Rt>At)break;if(Rt===At){if(!Zt){dr=U;break}{if(X===0&&Me){dr=U;break}const Bt=Be&&c(Be.getComponent());if(X===0&&Bt)break}}if(Zt){const Bt=cn.d;K[Bt],xe[Bt],cn.i===void 0&&(K[Bt]||xe[Bt]!=null&&X!==1)?(K[Bt]||xe[Bt]!=null&&X===0)&&(Ae++,Pe--):Ae++}Ee=U.nextSibling()}}const vi=At+Ae+Ue+Pe;o(vi>=0,"trying to descend to a negative index"),x.descend(vi),Me&&(Se=Be=dr=null,ee++),g(Se,y,Be,dr,x,k)&&Pe++,x.ascend()}else{let Se;for(;We&&(Se=m.getKey(),typeof Se!="string"||!(Se>ve||Se===ve));)We=m.nextSibling();const Me=We&&Se===ve?m:null,ne=ft(ve);let at;for(;Ee&&(at=U.getKey(),typeof at!="string"||!(at>ve||at===ve));)Ee=U.nextSibling();const Be=Ee&&at===ve?U:null;x.descend(ve),g(Me,y,ne,Be,x,k),x.ascend()}return ft.end(),ht&&m.ascend(),Qe&&U.ascend(),pe}(Ve,Ve.clone(),et,et.clone(),Ge,null),Y)return{ok:!1,conflict:Y};Ge.reset();const Fe=(g,m,y)=>g.traverse(m,(T,U)=>{T.d!=null&&y(T.d,g,U)});(K.length||ze.length)&&(Fe(et,Ge,(g,m,y)=>{K[g]&&!Re[g]&&y.write("r",!0),ze[g]&&y.mergeTree(ze[g].get())}),Ge.reset());const ct=[],p=[];if((He.length||K.length)&&!Y){const g=s.readCursor($(Ge.get()));if(Fe(g,null,(m,y)=>{ct[m]=y.clone()}),He.forEach(m=>{m&&Fe(s.readCursor(m.get()),null,(y,T)=>{ct[y]=T.clone()})}),function m(y,T,U,x,k,I){const Q=a(T);if(Q&&c(Q))if(Q.p!=null){const D=Q.p;ct[D].getPath(),U=ct[D],x=p[D]=s.writeCursor()}else Q.r!==void 0&&(U=null);else h(a(U))&&(U=null);const pe=y.getComponent();if(pe){let D;if((D=pe.d)!=null){const ee=He[D];ee&&(ee.get(),x.mergeTree(ee.get()),U=s.readCursor(ee.get()))}}let q=0,_e=0;const Oe=s.advancer(T,void 0,(D,ee)=>{c(ee)&&q--}),ue=s.advancer(U,(D,ee)=>h(ee)?-(D-_e)-1:D-_e,(D,ee)=>{h(ee)&&_e++});for(const D of y)if(typeof D=="number"){const ee=Oe(D),Ce=D+q,Ae=ue(Ce),Ue=Ce+_e;x.descend(Ue),m(y,ee,Ae,x),x.ascend()}else x.descend(D),m(y,Oe(D),ue(D),x),x.ascend();Oe.end(),ue.end()}(et,g,g.clone(),Ge),Ge.reset(),Y)return{ok:!1,conflict:Y};if(Ge.get(),p.length){const m=p.map(T=>T?T.get():null),y=s.readCursor($(Ge.get()));if(Fe(y,Ge,(T,U,x)=>{const k=m[T];k&&(x.mergeTree(k),m[T]=null)}),m.find(T=>T)){const T=s.writeCursor(),U=s.writeCursor();let x=0,k=0;m.forEach(I=>{I!=null&&Fe(s.readCursor(I),null,Q=>{const pe=Dt[Q];T.writeMove(W[pe].getPath(),le[pe].getPath(),x++);const q=qe[pe];q&&q.forEach(_e=>{K[_e]||X!==1&&xe[_e]!=null||U.writeMove(oe[_e].getPath(),B[_e].getPath(),k++)})})}),Y={type:i.ConflictType.BLACKHOLE,op1:T.get(),op2:U.get()}}}}return Y?{ok:!1,conflict:Y}:{ok:!0,result:Ge.get()}}const se=S=>{const F=new Error("Transform detected write conflict");throw F.conflict=S,F.type=F.name="writeConflict",F};function he(S,F,G){const X=V(S,F,G);if(X.ok)return X.result;se(X.conflict)}const ge=S=>{const F=s.writeCursor();return s.readCursor(S).traverse(F,(G,X)=>{(h(G)||de(G))&&X.write("r",!0)}),F.get()},Te=(S,F)=>{const{type:G,op1:X,op2:Y}=S;switch(G){case i.ConflictType.DROP_COLLISION:return F==="left"?[null,ge(Y)]:[ge(X),null];case i.ConflictType.RM_UNEXPECTED_CONTENT:let W=!1;return s.readCursor(X).traverse(null,le=>{le.r!==void 0&&(W=!0)}),W?[null,ge(Y)]:[ge(X),null];case i.ConflictType.BLACKHOLE:return[ge(X),ge(Y)];default:throw Error("Unrecognised conflict: "+G)}};function ye(S,F,G,X){let Y=null;for(;;){const W=V(F,G,X);if(W.ok)return v(Y,W.result);{const{conflict:le}=W;S(le)||se(le);const[oe,B]=Te(le,X);F=v(ae(F),oe),G=v(ae(G),B),Y=v(Y,B)}}}}(Ln)),Ln}var Co;function i_(){return Co||(Co=1,function(e){var t=Qt&&Qt.__createBinding||(Object.create?function(i,o,a,l){l===void 0&&(l=a),Object.defineProperty(i,l,{enumerable:!0,get:function(){return o[a]}})}:function(i,o,a,l){l===void 0&&(l=a),i[l]=o[a]}),n=Qt&&Qt.__exportStar||function(i,o){for(var a in i)a!=="default"&&!o.hasOwnProperty(a)&&t(o,i,a)};Object.defineProperty(e,"__esModule",{value:!0}),n(s_(),e);var r=Ll();Object.defineProperty(e,"ReadCursor",{enumerable:!0,get:function(){return r.ReadCursor}}),Object.defineProperty(e,"WriteCursor",{enumerable:!0,get:function(){return r.WriteCursor}});var s=xl();Object.defineProperty(e,"ConflictType",{enumerable:!0,get:function(){return s.ConflictType}})}(Qt)),Qt}var gt=i_();const o_=Ct(gt),a_=Zu({__proto__:null,default:o_},[gt]);var ce=(e=>(e.RETAIN="r",e.INSERT="i",e.DELETE="d",e))(ce||{});function lr(e,t=!1){const n=[];for(const r of e){const{st:s,ed:i,ts:o}=r;if(r.sId===void 0&&delete r.sId,s===i||!t&&re.isEmptyObject(o)&&r.sId==null)continue;if(n.length===0){n.push(r);continue}const a=n.pop();Ca(r,a)&&re.hasIntersectionBetweenTwoRanges(a.st,a.ed,r.st,r.ed)?n.push({...r,st:a.st,ed:i}):n.push(a,r)}return n}function Ul(e,t,n,r){var u;const{textRuns:s}=e;if(s==null)return;const i=[],o=s.length;let a=!1;const l=(u=t.textRuns)!=null?u:[];if(l.length)for(const c of l)c.st+=r,c.ed+=r;for(let c=0;c<o;c++){const h=s[c],{st:d,ed:f}=h;if(f<=r)i.push(h);else if(r>d&&r<f){a=!0;const E={...h,ed:r};i.push(E),l.length&&i.push(...l);const R={...h,st:r+n,ed:f+n};i.push(R)}else h.st+=n,h.ed+=n,a||(a=!0,i.push(...l)),i.push(h)}a||(a=!0,i.push(...l)),e.textRuns=lr(i)}function kl(e,t,n,r){const{paragraphs:s}=e;if(s==null)return;const{paragraphs:i}=t,o=[];for(let l=0,u=s.length;l<u;l++){const c=s[l],{startIndex:h}=c;h>=r&&(c.startIndex+=n),o.push(c.startIndex)}let a=-1;if(i){for(let l=0,u=i.length;l<u;l++){const c=i[l];c.startIndex+=r;const h=c.startIndex;a=o.indexOf(h)}a!==-1&&s.splice(a,1),s.push(...i),s.sort(ir("startIndex"))}}function Pl(e,t,n,r){const{sectionBreaks:s}=e;if(s==null)return;for(let o=0,a=s.length;o<a;o++){const l=s[o],{startIndex:u}=l;u>=r&&(l.startIndex+=n)}const i=t.sectionBreaks;if(i){for(let o=0,a=i.length;o<a;o++){const l=i[o];l.startIndex+=r}s.push(...i),s.sort(ir("startIndex"))}}function Fl(e,t,n,r){const{customBlocks:s=[]}=e;for(let o=0,a=s.length;o<a;o++){const l=s[o],{startIndex:u}=l;u>=r&&(l.startIndex+=n)}const i=t.customBlocks;if(i){for(let o=0,a=i.length;o<a;o++){const l=i[o];l.startIndex+=r}s.push(...i),s.sort(ir("startIndex"))}s.length&&!e.customBlocks&&(e.customBlocks=s)}function $l(e,t,n,r){const{tables:s}=e;if(s==null)return;for(let o=0,a=s.length;o<a;o++){const l=s[o],{startIndex:u,endIndex:c}=l;u>r?(l.startIndex+=n,l.endIndex+=n):c>r&&(l.endIndex+=n)}const i=t.tables;if(i){for(let o=0,a=i.length;o<a;o++){const l=i[o];l.startIndex+=r,l.endIndex+=r}s.push(...i),s.sort(ir("startIndex"))}}const Bl="$",Ro=e=>e.split(Bl)[0];function hi(e){if(e.length<=1)return e;e.sort((s,i)=>s.startIndex-i.startIndex);const t=[];let n={...e[0]};n.rangeId=Ro(n.rangeId);for(let s=1;s<e.length;s++){const i=e[s];i.rangeId=Ro(i.rangeId),i.rangeId===n.rangeId&&Dl(n.properties,i.properties)&&n.endIndex+1>=i.startIndex?n.endIndex=i.endIndex:(t.push(n),n={...i})}t.push(n);const r=Object.create(null);for(let s=0,i=t.length;s<i;s++){const o=t[s],a=o.rangeId;r[a]?(o.rangeId=`${a}${Bl}${r[a]}`,r[a]=r[a]+1):r[a]=1}return t}function Fs(e,t){const n=e.findIndex(s=>s.startIndex<t&&s.endIndex>=t),r=e[n];r&&e.splice(n,1,{rangeId:r.rangeId,rangeType:r.rangeType,startIndex:r.startIndex,endIndex:t-1,properties:{...r.properties}},{rangeId:r.rangeId,rangeType:r.rangeType,startIndex:t,endIndex:r.endIndex,properties:{...r.properties}})}function Hl(e){if(e.length<=1)return e;e.sort((r,s)=>r.startIndex-s.startIndex);const t=[];let n={...e[0]};for(let r=1;r<e.length;r++){const s=e[r];s.id===n.id&&n.endIndex+1>=s.startIndex?n.endIndex=s.endIndex:(t.push(n),n={...s})}return t.push(n),t}function $s(e,t){e.filter(r=>r.startIndex<t&&r.endIndex>=t).forEach(r=>{const s=e.indexOf(r);e.splice(s,1,{id:r.id,type:r.type,startIndex:r.startIndex,endIndex:t-1},{id:r.id,type:r.type,startIndex:t,endIndex:r.endIndex})})}function l_(e,t,n,r){e.customRanges||(e.customRanges=[]);const{customRanges:s}=e;Fs(s,r);for(let o=0,a=s.length;o<a;o++){const l=s[o],{startIndex:u}=l;u>=r&&(l.startIndex+=n,l.endIndex+=n)}const i=[];if(t.customRanges){for(let o=0,a=t.customRanges.length;o<a;o++){const l=t.customRanges[o];l.startIndex+=r,l.endIndex+=r,i.push(l)}s.push(...i)}e.customRanges=hi(s)}function u_(e,t,n,r){e.customDecorations||(e.customDecorations=[]);const{customDecorations:s}=e;$s(s,r);for(let o=0,a=s.length;o<a;o++){const l=s[o],{startIndex:u}=l;u>=r&&(l.startIndex+=n,l.endIndex+=n)}const i=[];if(t.customDecorations){for(let o=0,a=t.customDecorations.length;o<a;o++){const l=t.customDecorations[o];l.startIndex+=r,l.endIndex+=r,i.push(l)}s.push(...i)}e.customDecorations=Hl(s)}function jl(e,t,n){const{textRuns:r}=e,s=n,i=n+t,o=[];if(r){const a=[];for(let l=0,u=r.length;l<u;l++){const c=r[l],{st:h,ed:d}=c;if(s<=h&&i>=d){o.push({...c,st:h-s,ed:d-s});continue}else h<=s&&d>=i?(o.push({...c,st:s-s,ed:i-s}),c.ed-=t):s>=h&&s<d?(o.push({...c,st:s-s,ed:d-s}),c.ed=s):i>h&&i<=d?(o.push({...c,st:h-s,ed:i-s}),c.st=i-t,c.ed-=t):h>=i&&(c.st-=t,c.ed-=t);a.push(c)}e.textRuns=a}return o.length===0&&o.push({st:0,ed:t,ts:{}}),o}function Wl(e,t,n){const{paragraphs:r}=e,s=n,i=n+t,o=[];if(r){const a=[];for(let l=0,u=r.length;l<u;l++){const c=r[l],{startIndex:h}=c;if(h>=s&&h<i){o.push({...c,startIndex:h-n});continue}else h>=i&&(c.startIndex-=t);a.push(c)}e.paragraphs=a}return o}function Yl(e,t,n){const{sectionBreaks:r}=e,s=n,i=n+t-1,o=[];if(r){const a=[];for(let l=0,u=r.length;l<u;l++){const c=r[l],{startIndex:h}=c;if(h>=s&&h<=i){o.push({...c,startIndex:h-n});continue}else h>i&&(c.startIndex-=t);a.push(c)}e.sectionBreaks=a}return o}function zl(e,t,n){const{customBlocks:r=[]}=e,s=n,i=n+t-1,o=[];if(r){const a=[];for(let l=0,u=r.length;l<u;l++){const c=r[l],{startIndex:h}=c;if(h>=s&&h<=i){o.push({...c,startIndex:h-n});continue}else h>i&&(c.startIndex-=t);a.push(c)}e.customBlocks=a}return r.length&&!e.customBlocks&&(e.customBlocks=r),o}function Vl(e,t,n){const{tables:r}=e,s=n,i=n+t-1,o=[];if(r){const a=[];for(let l=0,u=r.length;l<u;l++){const c=r[l],{startIndex:h,endIndex:d}=c;if(s<=h&&i>=d){o.push({...c,startIndex:h-n,endIndex:d-n});continue}else if(h<=s&&d>=i){const f=Jr(h,d,s,i);if(f.length===0||(c.startIndex=f[0],c.endIndex=f[1],c.startIndex===c.endIndex))continue}else i<h&&(c.startIndex-=t,c.endIndex-=t);a.push(c)}e.tables=a}return o}function c_(e,t,n){const{customRanges:r}=e,s=n,i=n+t-1,o=[];if(r){const a=[];for(let l=0,u=r.length;l<u;l++){const c=r[l],{startIndex:h,endIndex:d}=c;if(h>=s&&d<=i){o.push(c);continue}else if(Math.max(s,h)<=Math.min(i,d)){const f=Jr(h,d,s,i);if(f.length===0)continue;c.startIndex=f[0],c.endIndex=f[1]}else i<h&&(c.startIndex-=t,c.endIndex-=t);a.push(c)}e.customRanges=hi(a)}return o}function h_(e,t,n,r=!0){const{customDecorations:s}=e,i=n,o=n+t-1,a=[];if(s){const l=[];for(let u=0,c=s.length;u<c;u++){const h=s[u],{startIndex:d,endIndex:f}=h;if(d>=i&&f<=o){a.push(h);continue}else if(Math.max(i,d)<=Math.min(o,f)){const E=Jr(d,f,i,o);if(E.length===0)continue;h.startIndex=E[0],h.endIndex=E[1]}else o<d&&r&&(h.startIndex-=t,h.endIndex-=t);l.push(h)}e.customDecorations=l}return a}var Gl=(e=>(e.ORDER_LIST_QUICK_1="1.",e.ORDER_LIST_QUICK_2="a)",e.ORDER_LIST_QUICK_3="a.",e.ORDER_LIST_QUICK_4="i.",e.ORDER_LIST_QUICK_5="A.",e.ORDER_LIST_QUICK_6="I.",e.ORDER_LIST_QUICK_7="01.",e))(Gl||{}),Mt=(e=>(e.BULLET_LIST="BULLET_LIST",e.BULLET_LIST_1="BULLET_LIST_1",e.BULLET_LIST_2="BULLET_LIST_2",e.BULLET_LIST_3="BULLET_LIST_3",e.BULLET_LIST_4="BULLET_LIST_4",e.BULLET_LIST_5="BULLET_LIST_5",e.ORDER_LIST="ORDER_LIST",e.ORDER_LIST_1="ORDER_LIST_1",e.ORDER_LIST_2="ORDER_LIST_2",e.ORDER_LIST_3="ORDER_LIST_3",e.ORDER_LIST_4="ORDER_LIST_4",e.ORDER_LIST_5="ORDER_LIST_5",e.ORDER_LIST_QUICK_2="ORDER_LIST_QUICK_2",e.ORDER_LIST_QUICK_3="ORDER_LIST_QUICK_3",e.ORDER_LIST_QUICK_4="ORDER_LIST_QUICK_4",e.ORDER_LIST_QUICK_5="ORDER_LIST_QUICK_5",e.ORDER_LIST_QUICK_6="ORDER_LIST_QUICK_6",e.CHECK_LIST="CHECK_LIST",e.CHECK_LIST_CHECKED="CHECK_LIST_CHECKED",e))(Mt||{});const Sr={"a)":{glyphFormat:"%1)",glyphType:Ne.DECIMAL},"1.":{glyphType:Ne.DECIMAL},"a.":{glyphFormat:"%1.",glyphType:Ne.LOWER_LETTER},"A.":{glyphType:Ne.UPPER_LETTER},"i.":{glyphFormat:"%1.",glyphType:Ne.LOWER_ROMAN},"I.":{glyphFormat:"%1.",glyphType:Ne.UPPER_LETTER}},dn=e=>[...e,...e,...e].map((t,n)=>({glyphFormat:` %${n+1}`,glyphSymbol:t,bulletAlignment:or.START,textStyle:{fs:12},startNumber:0,paragraphProperties:{hanging:{v:21},indentStart:{v:21*n}}})),fn=e=>e.map((t,n)=>({...t,bulletAlignment:or.START,textStyle:{fs:12},startNumber:0,paragraphProperties:{hanging:{v:21},indentStart:{v:21*n}}})),Io=(e,t)=>new Array(9).fill(0).map((n,r)=>({glyphFormat:` %${r+1}`,glyphSymbol:e,bulletAlignment:or.START,textStyle:{fs:16},startNumber:0,paragraphProperties:{hanging:{v:21},indentStart:{v:21*r},textStyle:t}})),ur={BULLET_LIST:{listType:"BULLET_LIST",nestingLevel:dn(["●","○","■"])},BULLET_LIST_1:{listType:"BULLET_LIST",nestingLevel:dn(["❖","➢","■"])},BULLET_LIST_2:{listType:"BULLET_LIST",nestingLevel:dn(["✔","●","◆"])},BULLET_LIST_3:{listType:"BULLET_LIST",nestingLevel:dn(["■","◆","○"])},BULLET_LIST_4:{listType:"BULLET_LIST",nestingLevel:dn(["✧","○","■"])},BULLET_LIST_5:{listType:"BULLET_LIST",nestingLevel:dn(["➢","○","◆"])},ORDER_LIST:{listType:"ORDER_LIST",nestingLevel:fn([{glyphFormat:"%1.",glyphType:Ne.DECIMAL},{glyphFormat:"%2.",glyphType:Ne.LOWER_LETTER},{glyphFormat:"%3.",glyphType:Ne.LOWER_ROMAN},{glyphFormat:"%4.",glyphType:Ne.DECIMAL},{glyphFormat:"%5.",glyphType:Ne.LOWER_LETTER},{glyphFormat:"%6.",glyphType:Ne.LOWER_ROMAN},{glyphFormat:"%7.",glyphType:Ne.DECIMAL},{glyphFormat:"%8.",glyphType:Ne.LOWER_LETTER},{glyphFormat:"%9.",glyphType:Ne.LOWER_ROMAN}])},ORDER_LIST_1:{listType:"ORDER_LIST",nestingLevel:fn([{glyphFormat:"%1)",glyphType:Ne.DECIMAL},{glyphFormat:"%2)",glyphType:Ne.LOWER_LETTER},{glyphFormat:"%3)",glyphType:Ne.LOWER_ROMAN},{glyphFormat:"%4)",glyphType:Ne.DECIMAL},{glyphFormat:"%5)",glyphType:Ne.LOWER_LETTER},{glyphFormat:"%6)",glyphType:Ne.LOWER_ROMAN},{glyphFormat:"%7)",glyphType:Ne.DECIMAL},{glyphFormat:"%8)",glyphType:Ne.LOWER_LETTER},{glyphFormat:"%9)",glyphType:Ne.LOWER_ROMAN}])},ORDER_LIST_2:{listType:"ORDER_LIST",nestingLevel:fn(["%1.","%1.%2.","%1.%2.%3.","%1.%2.%3.%4.","%1.%2.%3.%4.%5.","%1.%2.%3.%4.%5.%6.","%1.%2.%3.%4.%5.%6.%7."].map(e=>({glyphFormat:e,glyphType:Ne.DECIMAL})))},ORDER_LIST_3:{listType:"ORDER_LIST",nestingLevel:fn([{glyphFormat:"%1.",glyphType:Ne.UPPER_LETTER},{glyphFormat:"%2.",glyphType:Ne.LOWER_LETTER},{glyphFormat:"%3.",glyphType:Ne.LOWER_ROMAN},{glyphFormat:"%4.",glyphType:Ne.UPPER_LETTER},{glyphFormat:"%5.",glyphType:Ne.LOWER_LETTER},{glyphFormat:"%6.",glyphType:Ne.LOWER_ROMAN},{glyphFormat:"%7.",glyphType:Ne.UPPER_LETTER},{glyphFormat:"%8.",glyphType:Ne.LOWER_LETTER},{glyphFormat:"%9.",glyphType:Ne.LOWER_ROMAN}])},ORDER_LIST_4:{listType:"ORDER_LIST",nestingLevel:fn([{glyphFormat:"%1.",glyphType:Ne.UPPER_LETTER},{glyphFormat:"%2.",glyphType:Ne.DECIMAL},{glyphFormat:"%3.",glyphType:Ne.LOWER_ROMAN},{glyphFormat:"%4.",glyphType:Ne.UPPER_LETTER},{glyphFormat:"%5.",glyphType:Ne.DECIMAL},{glyphFormat:"%6.",glyphType:Ne.LOWER_ROMAN},{glyphFormat:"%7.",glyphType:Ne.UPPER_LETTER},{glyphFormat:"%8.",glyphType:Ne.DECIMAL},{glyphFormat:"%9.",glyphType:Ne.LOWER_ROMAN}])},ORDER_LIST_5:{listType:"ORDER_LIST",nestingLevel:fn([{glyphFormat:"%1.",glyphType:Ne.DECIMAL_ZERO},{glyphFormat:"%2.",glyphType:Ne.LOWER_LETTER},{glyphFormat:"%3.",glyphType:Ne.LOWER_ROMAN},{glyphFormat:"%4.",glyphType:Ne.DECIMAL_ZERO},{glyphFormat:"%5.",glyphType:Ne.LOWER_LETTER},{glyphFormat:"%6.",glyphType:Ne.LOWER_ROMAN},{glyphFormat:"%7.",glyphType:Ne.DECIMAL_ZERO},{glyphFormat:"%8.",glyphType:Ne.LOWER_LETTER},{glyphFormat:"%9.",glyphType:Ne.LOWER_ROMAN}])},CHECK_LIST:{listType:"CHECK_LIST",nestingLevel:Io("☐")},CHECK_LIST_CHECKED:{listType:"CHECK_LIST_CHECKED",nestingLevel:Io("☑",{st:{s:Ie.TRUE}})}},vr=e=>{const{glyphFormat:t,glyphType:n}=e,r=re.deepClone(ur.ORDER_LIST);return r.nestingLevel[0].glyphFormat=t,r.nestingLevel[0].glyphType=n,r},d_={ORDER_LIST_QUICK_2:vr(Sr["a)"]),ORDER_LIST_QUICK_3:vr(Sr["a."]),ORDER_LIST_QUICK_4:vr(Sr["i."]),ORDER_LIST_QUICK_6:vr(Sr["I."])};Object.assign(ur,d_);const f_={"1.":"ORDER_LIST","a)":"ORDER_LIST_QUICK_2","a.":"ORDER_LIST_QUICK_3","i.":"ORDER_LIST_QUICK_4","A.":"ORDER_LIST_3","I.":"ORDER_LIST_QUICK_6","01.":"ORDER_LIST_5"};function g_(e,t,n,r,s){const i=m_(e,t,n,r,s),o=__(e,t,n,r,s),a=p_(e,t,n,r,s),l=E_(e,t,n,r,s),u=C_(e,t,n,r,s),c=R_(e,t,n,r),h=I_(e,t,n,r,s);return{dataStream:"",textRuns:i,paragraphs:o,sectionBreaks:a,customBlocks:l,tables:u,customRanges:c,customDecorations:h}}function m_(e,t,n,r,s){const{textRuns:i}=e,{textRuns:o}=t;if(i==null||o==null)return;const a=jl(e,n,r);if(s!==ke.REPLACE){const l=Kl(o,a,s);t.textRuns=l}return Ul(e,t,n,r),a}function Kl(e,t,n){if(t.length===0)return e;e=re.deepClone(e),t=re.deepClone(t);const r=[],s=e.length,i=t.length;let o=0,a=0,l=null;function u(){return l?(r.push(l),l=null,!0):!1}for(;o<s&&a<i;){const{st:f,ed:E,ts:R}=e[o],{st:w,ed:L,ts:J,sId:z}=t[a];let de;if(n===ke.COVER?de={...J,...R}:de={...R},E<w)u()||r.push(e[o]),o++;else if(L<f)u()||r.push(t[a]),a++;else{const N={st:Math.min(f,w),ed:Math.max(f,w),ts:f<w?{...R}:{...J},sId:f<w?void 0:z};N.ed>N.st&&r.push(N),r.push({st:Math.max(f,w),ed:Math.min(E,L),ts:de,sId:z}),E<L?(o++,t[a].st=E,t[a].st===t[a].ed&&a++):(a++,e[o].st=L,e[o].st===e[o].ed&&o++);const A={st:Math.min(E,L),ed:Math.max(E,L),ts:E<L?{...J}:{...R},sId:E<L?z:void 0};l=A.ed>A.st?A:null}}u();const c=r[r.length-1],h=e[s-1],d=t[i-1];return c&&c.ed!==Math.max(h.ed,d.ed)&&(h.ed>d.ed?r.push(h):r.push(d)),lr(r)}function __(e,t,n,r,s){const{paragraphs:i}=e,{paragraphs:o}=t;if(i==null||o==null)return;const a=Wl(e,n,r);if(s!==ke.REPLACE){const l=[];for(const u of o){const{startIndex:c,paragraphStyle:h,bullet:d}=u;let f=[];for(const E of a){const{startIndex:R,paragraphStyle:w,bullet:L}=E;let J,z;if(s===ke.COVER?(J={...w,...h},z={listId:"",listType:Mt.BULLET_LIST,nestingLevel:0,textStyle:{},...L,...d}):(J={...h,...w},z={listId:"",listType:Mt.BULLET_LIST,nestingLevel:0,textStyle:{},...d,...L}),c===R){f.push({startIndex:c,paragraphStyle:J,bullet:z});break}}l.push(...f),f=[]}t.paragraphs=l}return kl(e,t,n,r),a}function p_(e,t,n,r,s){const{sectionBreaks:i}=e,{sectionBreaks:o}=t;if(i==null||o==null)return;const a=Yl(e,n,r);if(s!==ke.REPLACE){const l=[];for(const u of o){const{startIndex:c}=u;let h=[];for(const d of a){const{startIndex:f}=d;if(c===f){s===ke.COVER?h.push({...d,...u}):h.push({...u,...d});break}}l.push(...h),h=[]}t.sectionBreaks=l}return Pl(e,t,n,r),a}function E_(e,t,n,r,s){const{customBlocks:i=[]}=e,{customBlocks:o}=t;if(i==null||o==null)return;const a=zl(e,n,r);if(s!==ke.REPLACE){const l=[];for(const u of o){const{startIndex:c}=u;let h=[];for(const d of a){const{startIndex:f}=d;if(c===f){s===ke.COVER?h.push({...d,...u}):h.push({...u,...d});break}}l.push(...h),h=[]}t.customBlocks=l}return Fl(e,t,n,r),i.length&&!e.customBlocks&&(e.customBlocks=i),a}function C_(e,t,n,r,s){const{tables:i}=e,{tables:o}=t;if(i==null||o==null)return;const a=Vl(e,n,r);if(s!==ke.REPLACE){const l=[];for(const u of o){const{startIndex:c,endIndex:h}=u;let d=[];for(const f of a){const{startIndex:E,endIndex:R}=f;if(E>=c&&R<=h){s===ke.COVER?d.push({...f,...u}):d.push({...u,...f});break}}l.push(...d),d=[]}t.tables=l}return $l(e,t,n,r),a}function R_(e,t,n,r,s){e.customRanges||(e.customRanges=[]),Fs(e.customRanges,r),Fs(e.customRanges,r+n);const i=r,o=r+n-1,{customRanges:a}=t,l=[],u=new Map;e.customRanges.forEach(h=>{const{startIndex:d,endIndex:f}=h;d>=i&&f<=o?u.set(h.rangeId,h):l.push(h)});const c=[];return a?(a.forEach(h=>{const{startIndex:d,endIndex:f}=h;l.push({...h,startIndex:d+r,endIndex:f+r})}),e.customRanges=hi(l),c):[]}function I_(e,t,n,r,s){e.customDecorations||(e.customDecorations=[]),$s(e.customDecorations,r),$s(e.customDecorations,r+n);const i=[],{customDecorations:o}=e,{customDecorations:a=[]}=t;if(s===ke.REPLACE){for(let l=0;l<o.length;l++){const u=o[l],{startIndex:c,endIndex:h}=u;c>=r&&h<=r+n-1&&i.push(u)}a.forEach(l=>{const{startIndex:u,endIndex:c}=l;o.push({...l,startIndex:u+r,endIndex:c+r})})}else for(const l of a){const{id:u}=l;if(l.type===nn.DELETED){const c=o.filter(h=>h.id===u);c.length&&i.push(...c)}else o.push({...l,startIndex:l.startIndex+r,endIndex:l.endIndex+r})}for(const l of i){const{id:u}=l,c=o.findIndex(h=>h.id===u);c!==-1&&o.splice(c,1)}return e.customDecorations=Hl(o),i}var di=(e=>(e[e.copy=0]="copy",e[e.cut=1]="cut",e))(di||{});function zr(e,t,n,r=!0){const{textRuns:s}=e;if(s){const i=[];for(const o of s){const a=re.deepClone(o),{st:l,ed:u}=a;re.hasIntersectionBetweenTwoRanges(l,u,t,n)&&(t>=l&&t<=u?i.push({...a,st:t,ed:Math.min(n,u)}):n>=l&&n<=u?i.push({...a,st:Math.max(t,l),ed:n}):i.push(a))}return lr(i.map(o=>{const{st:a,ed:l}=o;return{...o,st:a-t,ed:l-t}}))}else if(r)return[{st:0,ed:n-t,ts:{}}]}function Xl(e,t,n){const{tables:r=[]}=e,s=[];for(const i of r){const o=re.deepClone(i),{startIndex:a,endIndex:l}=o;a>=t&&l<=n&&s.push({...o,startIndex:a-t,endIndex:l-t})}return s}function ql(e,t,n){const{paragraphs:r=[]}=e,s=[];for(const i of r){const{startIndex:o}=i;o>=t&&o<n&&s.push(re.deepClone(i))}if(s.length)return s.map(i=>({...i,startIndex:i.startIndex-t}))}function S_(e,t,n){const{sectionBreaks:r=[]}=e,s=[];for(const i of r){const{startIndex:o}=i;o>=t&&o<=n&&s.push(re.deepClone(i))}if(s.length)return s.map(i=>({...i,startIndex:i.startIndex-t}))}function Jl(e,t,n){const{customBlocks:r=[]}=e,s=[];for(const i of r){const{startIndex:o}=i;o>=t&&o<=n&&s.push(re.deepClone(i))}if(s.length)return s.map(i=>({...i,startIndex:i.startIndex-t}))}function bt(e,t,n,r=!0,s=1){const{dataStream:i}=e,o={dataStream:i.slice(t,n)};o.textRuns=zr(e,t,n,r);const a=Xl(e,t,n);if(a.length&&(o.tables=a),o.paragraphs=ql(e,t,n),s===1){const u=Ql(e,t,n);u?o.customDecorations=u:r&&(o.customDecorations=[])}const{customRanges:l}=Zl(e,t,n);return l?o.customRanges=l:r&&(o.customRanges=[]),o.customBlocks=Jl(e,t,n),o}function v_(e){const{dataStream:t,textRuns:n,paragraphs:r,customRanges:s,customDecorations:i,tables:o}=e;let a=0,l=0;s==null||s.forEach(c=>{c.startIndex<0&&(a=Math.max(a,-c.startIndex)),c.endIndex>t.length-1&&(l=Math.max(l,c.endIndex-t.length+1))});const u=`${t}`;return n&&(n[0]&&(n[0].st=n[0].st-a),n[n.length-1]&&(n[n.length-1].ed=n[n.length-1].ed+l)),n==null||n.forEach(c=>{c.st+=a,c.ed+=a}),r==null||r.forEach(c=>{c.startIndex+=a}),s==null||s.forEach(c=>{c.startIndex+=a,c.endIndex+=a}),i==null||i.forEach(c=>{c.startIndex+=a,c.endIndex+=l}),o==null||o.forEach(c=>{c.startIndex+=a,c.endIndex+=l}),{...e,dataStream:u,textRuns:n,paragraphs:r,customRanges:s,customDecorations:i,tables:o}}function Zl(e,t,n){if(e.customRanges==null)return{};const{customRanges:r}=e;return{customRanges:r.filter(a=>Math.max(a.startIndex,t)<=Math.min(a.endIndex,n-1)).map(a=>({...a,startIndex:Math.max(a.startIndex,t),endIndex:Math.min(a.endIndex,n-1)})).map(a=>({...a,startIndex:a.startIndex-t,endIndex:a.endIndex-t})),leftOffset:0,rightOffset:0}}function Ql(e,t,n){if(e.customDecorations==null)return;const{customDecorations:r=[]}=e,s=[];return r.forEach(i=>{if(Math.max(i.startIndex,t)<=Math.min(i.endIndex,n-1)){const o=re.deepClone(i);s.push({...o,startIndex:Math.max(o.startIndex-t,0),endIndex:Math.min(o.endIndex,n-1)-t})}}),s}function O_(e,t,n){return e==null||t==null?e!=null?e:t:Kl(e,t,n)}function w_(e,t,n){if(e==null||t==null)return e!=null?e:t;if(t.length===0||e.length===0)return e;if(t.length>1||e.length>1)throw new Error("Cannot cover multiple customRanges");return n===ke.REPLACE?[{...e[0]}]:[{...t[0],...e[0]}]}function b_(e,t,n){return t.length===0||e.length===0||n===ke.REPLACE?e:[...e,...t.filter(r=>!e.some(s=>r.id===s.id))]}function Bs(e,t,n=ke.COVER){if(t.dataStream!=="")throw new Error("Cannot compose other body with non-empty dataStream");const r={dataStream:e.dataStream},{textRuns:s,paragraphs:i=[],customRanges:o,customDecorations:a=[]}=e,{textRuns:l,paragraphs:u=[],customRanges:c,customDecorations:h=[]}=t;r.textRuns=O_(l,s,n),r.customRanges=w_(c,o,n);const d=b_(h,a,n);d.length&&(r.customDecorations=d);const f=[];let E=0,R=0;for(;E<i.length&&R<u.length;){const w=i[E],L=u[R],{startIndex:J}=w,{startIndex:z}=L;J===z?(f.push(re.deepMerge(w,L)),E++,R++):J<z?(f.push(re.deepClone(w)),E++):(f.push(re.deepClone(L)),R++)}return E<i.length&&f.push(...i.slice(E)),R<u.length&&f.push(...u.slice(R)),f.length&&(r.paragraphs=f),r}function y_(e){const{body:t}=e;if(t==null)return!0;const{textRuns:n,paragraphs:r,customRanges:s,customBlocks:i,customDecorations:o,tables:a}=t;return n==null&&r==null&&s==null&&i==null&&o==null&&a==null}class mn{constructor(t){C(this,"_index",0);C(this,"_offset",0);this._actions=t}hasNext(){return this.peekLength()<Number.POSITIVE_INFINITY}next(t){t||(t=Number.POSITIVE_INFINITY);const n=this._actions[this._index];if(n){const r=this._offset,s=n.len;return t>=s-r?(t=s-r,this._index+=1,this._offset=0):this._offset+=t,n.t===ce.DELETE||n.t===ce.RETAIN&&n.body==null?re.deepClone({...n,len:t}):re.deepClone({...n,len:t,body:bt(n.body,r,r+t,!1)})}else return{t:ce.RETAIN,len:Number.POSITIVE_INFINITY}}peek(){return this._actions[this._index]}peekLength(){return this._actions[this._index]?this._actions[this._index].len-this._offset:Number.POSITIVE_INFINITY}peekType(){const t=this._actions[this._index];return t?t.t:ce.RETAIN}rest(){if(this.hasNext()){if(this._offset===0)return this._actions.slice(this._index);{const t=this._offset,n=this._index,r=this.next(),s=this._actions.slice(this._index);return this._offset=t,this._index=n,[r].concat(s)}}else return[]}}class Nn{constructor(){C(this,"cursor",0)}reset(){return this.cursor=0,this}moveCursor(t){this.cursor+=t}moveCursorTo(t){this.cursor=t}}function eu(e,t,n){const{dataStream:r}=e,s=n,i=n+t,o=jl(e,t,n),a=Wl(e,t,n),l=Yl(e,t,n),u=zl(e,t,n),c=Vl(e,t,n),h=c_(e,t,n),d=h_(e,t,n);let f="";return r&&(e.dataStream=Sa(r,s,i),f=r.slice(s,i)),{dataStream:f,textRuns:o,paragraphs:a,sectionBreaks:l,customBlocks:u,tables:c,customRanges:h,customDecorations:d}}function tu(e,t,n,r){e.dataStream=Ia(e.dataStream,r,t.dataStream),Ul(e,t,n,r),kl(e,t,n,r),Pl(e,t,n,r),Fl(e,t,n,r),$l(e,t,n,r),l_(e,t,n,r),u_(e,t,n,r)}function A_(e,t,n,r,s=ke.COVER){return g_(e,t,n,r,s)}function T_(e,t,n){return t<=0?{dataStream:""}:eu(e,t,n)}function N_(e,t,n,r){n!==0&&tu(e,t,n,r)}function M_(e,t){const n=new Nn;return n.reset(),t.forEach(r=>{const s=re.deepClone(r);switch(s.t){case ce.RETAIN:{const{coverType:i,body:o,len:a}=s;o!=null&&A_(e,o,a,n.cursor,i),n.moveCursor(a);break}case ce.INSERT:{const{body:i,len:o}=s;N_(e,i,o,n.cursor),n.moveCursor(o);break}case ce.DELETE:{const{len:i}=s;T_(e,i,n.cursor);break}default:throw new Error(`Unknown action type for action: ${s}.`)}}),e}function D_(e,t,n,r,s){if(e==null||t==null)return t;if(e.length===0||t.length===0)return[];t=re.deepClone(t),e=re.deepClone(e);const i=[],o=t.length,a=e.length;let l=0,u=0,c=null;function h(){return c?(i.push(c),c=null,!0):!1}for(;l<o&&u<a;){const{st:R,ed:w,ts:L}=t[l],{st:J,ed:z,ts:de,sId:N}=e[u];let A={};if(s===0)A={...L},n===ke.COVER&&r===ke.REPLACE&&de&&(A=Object.assign({},de,A));else if(A={...L},n===ke.REPLACE){if(r===ke.REPLACE)A={...de};else if(L&&de){const j=Object.keys(L);for(const Z of j)de[Z]&&delete A[Z]}}else if(r===ke.REPLACE){if(de){const j=Object.keys(de);for(const Z of j)de[Z]!==void 0&&(A[Z]=de[Z])}}else if(de){const j=Object.keys(de);for(const Z of j)A[Z]!==void 0&&delete A[Z]}if(w<J)h()||i.push(t[l]),l++;else if(z<R)h()||i.push(e[u]),u++;else{const j={st:Math.min(R,J),ed:Math.max(R,J),ts:R<J?{...L}:{...de}};j.ed>j.st&&i.push(),i.push({st:Math.max(R,J),ed:Math.min(w,z),ts:A,sId:N}),w<z?(l++,e[u].st=w,e[u].st===e[u].ed&&u++):(u++,t[l].st=z,t[l].st===t[l].ed&&l++);const Z={st:Math.min(w,z),ed:Math.max(w,z),ts:w<z?{...de}:{...L},sId:w<z?N:void 0};c=Z.ed>Z.st?Z:null}}h();const d=i[i.length-1],f=t[o-1],E=e[a-1];return d.ed!==Math.max(f.ed,E.ed)&&(f.ed>E.ed?i.push(f):i.push(E)),lr(i,!0)}function L_(e,t,n,r,s){if(e==null||t==null)return t;if(e.length===0||t.length===0)return[];if(e.length>1||t.length>1)throw new Error("CustomRanges is only supported transform for length one now.");const i=e[0],o=t[0];if(n===ke.REPLACE)return s===1?[re.deepClone(i)]:[re.deepClone(o)];if(r===ke.REPLACE){const a=re.deepClone(o);return s===1&&Object.assign(a,re.deepClone(i)),[a]}else{const a=re.deepClone(o);return s===1&&Object.assign(a,re.deepClone(i)),[a]}}function So(e,t,n,r,s){const i={startIndex:t.startIndex};if(t.paragraphStyle&&(i.paragraphStyle=re.deepClone(t.paragraphStyle),e.paragraphStyle)){if(n===ke.REPLACE)if(r===ke.REPLACE)s===1&&(i.paragraphStyle={...e.paragraphStyle});else if(s===1){const o=Object.keys(e.paragraphStyle);for(const a of o)e.paragraphStyle[a]!==void 0&&(i.paragraphStyle[a]=e.paragraphStyle[a])}else{const o=Object.keys(e.paragraphStyle);for(const a of o)i.paragraphStyle[a]===void 0&&(i.paragraphStyle[a]=e.paragraphStyle[a])}else if(r===ke.REPLACE)if(s===1){const o=Object.keys(e.paragraphStyle);for(const a of o)e.paragraphStyle[a]!==void 0&&(i.paragraphStyle[a]=e.paragraphStyle[a])}else{const o=Object.keys(e.paragraphStyle);for(const a of o)i.paragraphStyle[a]===void 0&&(i.paragraphStyle[a]=e.paragraphStyle[a])}else if(s===1){const o=Object.keys(e.paragraphStyle);for(const a of o)i.paragraphStyle[a]&&delete i.paragraphStyle[a]}}return n===ke.REPLACE&&r===ke.REPLACE?i.bullet=s===1?re.deepClone(e.bullet):re.deepClone(t.bullet):e.bullet===void 0?i.bullet=re.deepClone(t.bullet):n===ke.REPLACE||r===ke.REPLACE?i.bullet=s===0&&t.bullet?re.deepClone(t.bullet):re.deepClone(e.bullet):s===0&&t.bullet!==void 0&&(i.bullet=re.deepClone(t.bullet)),i}function x_(e,t){if(e==null||t==null)return t;if(e.length===0||t.length===0)return re.deepClone(t);const n=[];for(const r of t){const{id:s,type:i}=r;let o=!1;for(const a of e)if(a.id===s){(a.type===nn.DELETED||i===nn.DELETED)&&(o=!0,n.push({...r,type:nn.DELETED}));break}o||n.push(r)}return n}function U_(e,t,n=!1){const{body:r,coverType:s=ke.COVER}=e,{body:i,coverType:o=ke.COVER}=t;if(r==null||r.dataStream!==""||i==null||i.dataStream!=="")throw new Error("Data stream is not supported in retain transform.");const a={dataStream:""},l=o,{textRuns:u,paragraphs:c=[],customRanges:h,customDecorations:d}=r,{textRuns:f,paragraphs:E=[],customRanges:R,customDecorations:w}=i,L=D_(u,f,s,o,n?1:0);L&&(a.textRuns=L);const J=L_(h,R,s,o,n?1:0);J&&(a.customRanges=J);const z=x_(d,w);z&&(a.customDecorations=z);const de=[];let N=0,A=0;for(;N<c.length&&A<E.length;){const j=c[N],Z=E[A],{startIndex:fe}=j,{startIndex:ae}=Z;if(fe===ae){let _={startIndex:fe};n?_=So(j,Z,s,o,1):_=So(j,Z,s,o,0),de.push(_),N++,A++}else fe<ae?N++:(de.push(re.deepClone(Z)),A++)}return A<E.length&&de.push(...E.slice(A)),de.length&&(a.paragraphs=de),{coverType:l,body:a}}function vo(e){return Object.keys(e).length===1}const In=class In{constructor(){C(this,"_actions",[])}static apply(t,n){return M_(t,n)}static compose(t,n){const r=new mn(t),s=new mn(n),i=new In;for(;r.hasNext()||s.hasNext();)if(s.peekType()===ce.INSERT)i.push(s.next());else if(r.peekType()===ce.DELETE)i.push(r.next());else{const o=Math.min(r.peekLength(),s.peekLength()),a=r.next(o),l=s.next(o);if(a.t===ce.INSERT&&l.t===ce.RETAIN)l.body==null?i.push(a):i.push({...a,body:Bs(a.body,l.body,l.coverType)});else if(a.t===ce.RETAIN&&l.t===ce.RETAIN)if(a.body==null&&l.body==null)i.push(a.len!==Number.POSITIVE_INFINITY?a:l);else if(a.body&&l.body){const u=a.coverType===ke.REPLACE||l.coverType===ke.REPLACE?ke.REPLACE:ke.COVER;i.push({...a,t:ce.RETAIN,coverType:u,body:Bs(a.body,l.body,l.coverType)})}else i.push(a.body?a:l);else a.t===ce.RETAIN&&l.t===ce.DELETE?i.push(l):a.t===ce.INSERT&&(l.t,ce.DELETE)}return i.trimEndUselessRetainAction(),i.serialize()}static transform(t,n,r="right"){return this._transform(n,t,r==="left"?"right":"left")}static _transform(t,n,r="right"){const s=new mn(t),i=new mn(n),o=new In;for(;s.hasNext()||i.hasNext();)if(s.peekType()===ce.INSERT&&(r==="left"||i.peekType()!==ce.INSERT)){const a=s.next();o.retain(a.len)}else if(i.peekType()===ce.INSERT)o.push(i.next());else{const a=Math.min(s.peekLength(),i.peekLength()),l=s.next(a),u=i.next(a);if(l.t===ce.DELETE)continue;if(u.t===ce.DELETE){o.push(u);continue}if(l.body==null||u.body==null)o.push(u);else{const{coverType:c,body:h}=U_(l,u,r==="left");o.push({...u,t:ce.RETAIN,coverType:c,body:h})}}return o.trimEndUselessRetainAction(),o.serialize()}static transformPosition(t,n,r=!1){const s=new mn(t);let i=0;for(;s.hasNext()&&i<=n;){const o=s.peekLength(),a=s.peekType();if(s.next(),a===ce.DELETE){n-=Math.min(o,n-i);continue}else a===ce.INSERT&&(i<n||!r)&&(n+=o);i+=o}return n}static isNoop(t){return t.length===0}static invert(t){const n=[];for(const r of t)if(r.t===ce.INSERT)n.push({t:ce.DELETE,len:r.len,body:r.body});else if(r.t===ce.DELETE){if(r.body==null)throw new Error("Can not invert DELETE action without body property, makeInvertible must be called first.");n.push({t:ce.INSERT,body:r.body,len:r.len})}else if(r.body!=null){if(r.oldBody==null)throw new Error("Can not invert RETAIN action without oldBody property, makeInvertible must be called first.");n.push({t:ce.RETAIN,body:r.oldBody,oldBody:r.body,len:r.len,coverType:ke.REPLACE})}else n.push(r);return n}static makeInvertible(t,n){const r=[];let s=0;for(const i of t){if(i.t===ce.DELETE&&(i.body==null||i.body&&i.body.dataStream.length!==i.len)){const o=bt(n,s,s+i.len,!1);i.len=o.dataStream.length,i.body=o}if(i.t===ce.RETAIN&&i.body!=null){const o=bt(n,s,s+i.len,!0);i.oldBody={...o,dataStream:""},i.len=o.dataStream.length}r.push(i),i.t!==ce.INSERT&&(s+=i.len)}return r}insert(t,n){const r={t:ce.INSERT,body:n,len:t};return this.push(r),this}retain(t,n,r){const s={t:ce.RETAIN,len:t};return n!=null&&(s.body=n),r!=null&&(s.coverType=r),this.push(s),this}delete(t){const n={t:ce.DELETE,len:t};return this.push(n),this}empty(){return this._actions=[],this}serialize(){return this._actions}push(...t){if(t.length>1){for(const i of t)this.push(i);return this}let n=this._actions.length,r=this._actions[n-1];const s=re.deepClone(t[0]);if(s.t===ce.RETAIN&&s.len===0&&s.body==null)return this;if(typeof r=="object"){if(r.t===ce.DELETE&&s.t===ce.DELETE)return r.len+=s.len,this;if(r.t===ce.DELETE&&s.t===ce.INSERT&&(n-=1,r=this._actions[n-1],r==null))return this._actions.unshift(s),this;if(r.t===ce.RETAIN&&s.t===ce.RETAIN&&r.body==null&&s.body==null)return r.len+=s.len,this;if(r.t===ce.INSERT&&vo(r.body)&&s.t===ce.INSERT&&vo(s.body))return r.len+=s.len,r.body.dataStream+=s.body.dataStream,this}return n===this._actions.length?this._actions.push(s):this._actions.splice(n,0,s),this}trimEndUselessRetainAction(){let t=this._actions[this._actions.length-1];for(;t&&t.t===ce.RETAIN&&y_(t);)this._actions.pop(),t=this._actions[this._actions.length-1];return this}};C(In,"id","text-x"),C(In,"uri","https://github.com/dream-num/univer#text-x");let Ye=In;Object.defineProperty(Ye,"name",{value:"text-x"});const Sn=class Sn{static registerSubtype(t){var n;t==null||this._subTypes.has(t.name)&&((n=this._subTypes.get(t.name))==null?void 0:n.id)!==Ye.id||(this._subTypes.set(t.name,t),gt.type.registerSubtype(t))}static apply(t,n){if(!gt.type.isNoop(n))return gt.type.apply(t,n)}static compose(t,n){return gt.type.compose(t,n)}static transform(t,n,r){return gt.type.transform(t,n,r)}static transformPosition(t,n,r="right"){return t&&t.length===2&&t[0]==="body"&&t[1].et===Ye.name?Ye.transformPosition(t[1].e,n,r==="left"):n}static invertWithDoc(t,n){return gt.type.invertWithDoc(t,n)}static isNoop(t){return gt.type.isNoop(t)}static getInstance(){return this._instance==null&&(this._instance=new Sn),this._instance}removeOp(t,n){return gt.removeOp(t,n)}moveOp(t,n){return gt.moveOp(t,n)}insertOp(t,n){return gt.insertOp(t,n)}replaceOp(t,n,r){return gt.replaceOp(t,n,r)}editOp(t,n=["body"]){return gt.editOp(n,Ye.name,t)}};C(Sn,"uri","https://github.com/dream-num/univer#json-x"),C(Sn,"_subTypes",new Map),C(Sn,"_instance",null);let kt=Sn;kt.registerSubtype(Ye);const fi={id:"default_doc",documentStyle:{}};class k_ extends rs{constructor(n){var r;super();C(this,"type",$e.UNIVER_DOC);C(this,"_name$",new we.BehaviorSubject(""));C(this,"name$",this._name$.asObservable());C(this,"snapshot");this.snapshot={...fi,...n},this._name$.next((r=this.snapshot.title)!=null?r:"No Title")}getUnitId(){throw new Error("Method not implemented.")}getRev(){var n;return(n=this.snapshot.rev)!=null?n:1}incrementRev(){this.snapshot.rev=this.getRev()+1}setRev(n){this.snapshot.rev=n}setName(n){this.snapshot.title=n,this._name$.next(n)}get drawings(){return this.snapshot.drawings}get documentStyle(){return this.snapshot.documentStyle}get lists(){return this.snapshot.lists}get zoomRatio(){var n;return((n=this.snapshot.settings)==null?void 0:n.zoomRatio)||1}resetDrawing(n,r){this.snapshot.drawings=n,this.snapshot.drawingsOrder=r}getBody(){return this.snapshot.body}getSnapshot(){return this.snapshot}getBulletPresetList(){var s;const n=(s=this.snapshot.lists)!=null?s:{};return{...ur,...n}}updateDocumentId(n){this.snapshot.id=n}updateDocumentRenderConfig(n){const{documentStyle:r}=this.snapshot;r.renderConfig==null?r.renderConfig=n:r.renderConfig={...r.renderConfig,...n}}updateDocumentStyle(n){this.snapshot.documentStyle==null?this.snapshot.documentStyle=n:this.snapshot.documentStyle={...this.snapshot.documentStyle,...n}}updateDocumentDataMargin(n){const{t:r,l:s,b:i,r:o}=n,{documentStyle:a}=this.snapshot;r!=null&&(a.marginTop=r),s!=null&&(a.marginLeft=s),i!=null&&(a.marginBottom=i),o!=null&&(a.marginRight=o)}updateDocumentDataPageSize(n,r){const{documentStyle:s}=this.snapshot;if(!s.pageSize){n=n!=null?n:Number.POSITIVE_INFINITY,r=r!=null?r:Number.POSITIVE_INFINITY,s.pageSize={width:n,height:r};return}n!==void 0&&(s.pageSize.width=n),r!==void 0&&(s.pageSize.height=r)}updateDrawing(n,r){const{drawings:s}=this,{width:i,height:o,left:a,top:l}=r,u=s==null?void 0:s[n];if(!u)return;const c=u.docTransform;c.size.width=i,c.size.height=o,c.positionH.posOffset=a,c.positionV.posOffset=l}setZoomRatio(n=1){this.snapshot.settings==null?this.snapshot.settings={zoomRatio:n}:this.snapshot.settings.zoomRatio=1}setDisabled(n){this.snapshot.disabled=n}getDisabled(){return this.snapshot.disabled}}class yt extends k_{constructor(n){var s,i;super(re.isEmptyObject(n)?Qm():n);C(this,"_unitId");C(this,"headerModelMap",new Map);C(this,"footerModelMap",new Map);C(this,"change$",new we.BehaviorSubject(0));const r=6;this._unitId=(s=this.snapshot.id)!=null?s:re.generateRandomId(r),this._initializeHeaderFooterModel(),this._name$.next((i=this.snapshot.title)!=null?i:"")}dispose(){super.dispose(),this.headerModelMap.forEach(n=>{n.dispose()}),this.footerModelMap.forEach(n=>{n.dispose()}),this._name$.complete()}getDrawings(){return this.snapshot.drawings}getDrawingsOrder(){return this.snapshot.drawingsOrder}getCustomRanges(){var n;return(n=this.snapshot.body)==null?void 0:n.customRanges}getCustomDecorations(){var n;return(n=this.snapshot.body)==null?void 0:n.customDecorations}getSettings(){return this.snapshot.settings}reset(n){if(n.id&&n.id!==this._unitId)throw new Error("Cannot reset a document model with a different unit id!");this.snapshot={...fi,...n},this._initializeHeaderFooterModel(),this.change$.next(this.change$.value+1)}getSelfOrHeaderFooterModel(n){if(n!=null){if(this.headerModelMap.has(n))return this.headerModelMap.get(n);if(this.footerModelMap.has(n))return this.footerModelMap.get(n)}return this}getUnitId(){return this._unitId}apply(n){if(!kt.isNoop(n))return this.snapshot=kt.apply(this.snapshot,n),n!=null&&n.some(r=>Array.isArray(r)&&((r==null?void 0:r[0])==="headers"||(r==null?void 0:r[0])==="footers"))&&(this.headerModelMap.clear(),this.footerModelMap.clear(),this._initializeHeaderFooterModel()),this.change$.next(this.change$.value+1),this.snapshot}sliceBody(n,r,s=di.copy){const i=this.getBody();if(i!=null)return bt(i,n,r,!1,s)}_initializeHeaderFooterModel(){const{headers:n,footers:r}=this.getSnapshot();if(n)for(const s in n){const i=n[s];this.headerModelMap.set(s,new yt(i)),this.headerModelMap.get(s).updateDocumentId(this.getUnitId())}if(r)for(const s in r){const i=r[s];this.footerModelMap.set(s,new yt(i)),this.footerModelMap.get(s).updateDocumentId(this.getUnitId())}}updateDocumentId(n){super.updateDocumentId(n),this._unitId=n}getPlainText(){var n,r;return Zr((r=(n=this.getBody())==null?void 0:n.dataStream)!=null?r:"")}}function P_(e){const{ranges:t,id:n,type:r}=e,s=new Ye;let i=0;for(let o=0;o<t.length;o++){const a=t[o],{startOffset:l,endOffset:u}=a;l>0&&s.push({t:ce.RETAIN,len:l-i}),s.push({t:ce.RETAIN,body:{dataStream:"",customDecorations:[{id:n,type:r,startIndex:0,endIndex:u-l-1}]},len:u-l}),i=u}return s}function F_(e){var c,h,d;const{id:t,segmentId:n,documentDataModel:r}=e,s=r==null?void 0:r.getBody();if(!r||!s)return!1;const i=(d=(h=(c=r.getSelfOrHeaderFooterModel(n))==null?void 0:c.getBody())==null?void 0:h.customDecorations)==null?void 0:d.find(f=>f.id===t);if(!i)return!1;const o=new Ye,{startIndex:a,endIndex:l}=i,u=l-a+1;return o.push({t:ce.RETAIN,len:a}),o.push({t:ce.RETAIN,len:u,body:{dataStream:"",customDecorations:[{startIndex:0,endIndex:u-1,id:t,type:nn.DELETED}]}}),o}function nu(e,t,n,r){return e<=n&&t>=n||e>=n&&e<=r}function $_(e,t){const n=[];for(let r=0,s=t.length;r<s;r++){const i=t[r];e.collapsed?i.startIndex<e.startOffset&&e.startOffset<=i.endIndex&&n.push(i):nu(e.startOffset,e.endOffset-1,i.startIndex,i.endIndex)&&n.push(i)}return n}function B_(e){return{...re.deepClone(e),rangeId:Ut()}}function H_(e,t){const n=[];let r=e[0];for(const s of t)s<e[0]||s>e[1]||(r<s&&n.push([r,s-1]),r=s+1);return r<=e[1]&&n.push([r,e[1]]),n}function ru(e,t,n,r){const s=[];for(let i=0,o=n.length;i<o;i++){const a=n[i];if((r===void 0||a.rangeType===r)&&Math.max(a.startIndex,e)<=Math.min(a.endIndex,t)&&s.push({...a}),a.startIndex>t)break}return s}function j_(e,t){var i,o,a,l,u;const n=ru(e.startOffset,e.collapsed?e.startOffset:e.endOffset-1,(i=t.customRanges)!=null?i:[]),r=Math.min(e.startOffset,(a=(o=n[0])==null?void 0:o.startIndex)!=null?a:1/0),s=Math.max(e.endOffset,((u=(l=n[n.length-1])==null?void 0:l.endIndex)!=null?u:-1/0)+1);return{startOffset:r,endOffset:s,collapsed:r===s}}function W_(e){var h,d,f;const{rangeId:t,segmentId:n,documentDataModel:r,insert:s}=e,i=(d=(h=r.getSelfOrHeaderFooterModel(n).getBody())==null?void 0:h.customRanges)==null?void 0:d.find(E=>E.rangeId===t);if(!i)return!1;const{startIndex:o,endIndex:a}=i,l=new Ye,u=a-o+1;l.push({t:ce.RETAIN,len:o}),l.push({t:ce.RETAIN,len:u,body:{dataStream:"",customRanges:[]}}),s&&l.push({t:ce.INSERT,body:s,len:s.dataStream.length});const c=a+1+((f=s==null?void 0:s.dataStream.length)!=null?f:0);return l.selections=[{startOffset:c,endOffset:c,collapsed:!0}],l}function Y_(e){const{ranges:t,rangeId:n,rangeType:r,wholeEntity:s,properties:i,body:o}=e;let a=0;const l=new Ye;let u=!1;return t.forEach(c=>{var z,de,N;const h=j_(c,o);if(!h||!o)return!1;const{startOffset:d,endOffset:f}=h,E=(z=o.customRanges)!=null?z:[],R=(A,j,Z)=>{var v,M,b,O;const fe=ru(A,j,E,r),ae=Math.min((M=(v=fe[0])==null?void 0:v.startIndex)!=null?M:1/0,A),_=Math.max((O=(b=fe[fe.length-1])==null?void 0:b.endIndex)!=null?O:-1/0,j),H={rangeId:Z?`${n}$${Z}`:n,rangeType:r,startIndex:0,endIndex:_-ae,wholeEntity:s,properties:{...i}};l.push({t:ce.RETAIN,len:ae-a}),l.push({t:ce.RETAIN,len:_-ae+1,body:{dataStream:"",customRanges:[H]},coverType:ke.COVER}),a=_+1},w=((de=o.paragraphs)!=null?de:[]).filter(A=>A.startIndex<f&&A.startIndex>d),L=((N=o.customBlocks)!=null?N:[]).filter(A=>A.startIndex<f&&A.startIndex>d);H_([d,f-1],[...w.map(A=>A.startIndex),...L.map(A=>A.startIndex)]).forEach(([A,j],Z)=>R(A,j,Z)),u=!0,l.selections=[{startOffset:h.endOffset,endOffset:h.endOffset,collapsed:!0}]}),u?l:!1}function su(e,t,n=0,r=null,s=!0){e.sort((u,c)=>u.startOffset-c.startOffset);const i=[],{paragraphs:o=[]}=t,a=o==null?void 0:o.find(u=>u.startIndex>=e[0].startOffset&&u.startIndex<e[0].endOffset);let l=n;if(e.forEach(u=>{const{startOffset:c,endOffset:h}=u;c>l&&(i.push({t:ce.RETAIN,len:c-l}),l=c),l<h&&(i.push({t:ce.DELETE,len:h-l}),l=h)}),r&&i.push({t:ce.INSERT,body:r,len:r.dataStream.length}),a&&s){const u=o.find(c=>c.startIndex-n>=e[e.length-1].endOffset-1);u&&(u.startIndex>l&&(i.push({t:ce.RETAIN,len:u.startIndex-l}),l=u.startIndex),i.push({t:ce.RETAIN,len:1,body:{dataStream:"",paragraphs:[{...u,startIndex:0,bullet:a==null?void 0:a.bullet}]},coverType:ke.REPLACE}))}return i}function z_(e,t,n=0){const r=[];let s=n;return e.forEach(i=>{const{startOffset:o,endOffset:a}=i;o>s&&(r.push({t:ce.RETAIN,len:o-s}),s=o),a>s&&(r.push({t:ce.RETAIN,len:a-s,body:{...re.deepClone(t),dataStream:""}}),s=a)}),r}const V_=e=>{var h;const{selection:t,body:n,doc:r}=e,s=t.segmentId,i=(h=r.getSelfOrHeaderFooterModel(s))==null?void 0:h.getBody();if(!i)return!1;const o=t.collapsed?null:bt(i,t.startOffset,t.endOffset),a=ui(o?o.dataStream:"",n.dataStream);let l=0;const u=a.map(([d,f])=>{switch(d){case 0:{const E={t:ce.RETAIN,body:{...bt(n,l,l+f.length,!1),dataStream:""},len:f.length};return l+=f.length,E}case 1:{const E={t:ce.INSERT,body:bt(n,l,l+f.length),len:f.length};return l+=f.length,E}default:return{t:ce.DELETE,len:f.length}}}),c=new Ye;return c.push({t:ce.RETAIN,len:t.startOffset}),c.push(...u),c};function G_(e,t){return!!((e==null?void 0:e.length)===(t==null?void 0:t.length)&&(e!=null&&e.every((n,r)=>JSON.stringify(n)===JSON.stringify(t==null?void 0:t[r]))))}const K_=e=>{var h;const{selection:t,body:n,doc:r}=e,s=t.segmentId,i=(h=r.getSelfOrHeaderFooterModel(s))==null?void 0:h.getBody();if(!i)return!1;const o=t.collapsed?null:bt(i,t.startOffset,t.endOffset),a=ui(o?o.dataStream:"",n.dataStream);let l=0;const u=a.map(([d,f])=>{switch(d){case 0:{const E=zr(n,l,l+f.length,!1),R=zr(o,l,l+f.length,!1),w={t:ce.RETAIN,body:G_(E,R)?void 0:{textRuns:E,dataStream:""},len:f.length};return l+=f.length,w}case 1:{const E={t:ce.INSERT,body:bt(n,l,l+f.length),len:f.length};return l+=f.length,E}default:return{t:ce.DELETE,len:f.length}}});if(u.every(d=>d.t===ce.RETAIN&&!d.body))return!1;const c=new Ye;return c.push({t:ce.RETAIN,len:t.startOffset}),c.push(...u),c};function X_(e,t){const n=[],{customBlocks:r=[]}=e;for(const s of t){const{startOffset:i,endOffset:o}=s;if(!(i==null||o==null))for(const a of r){const{startIndex:l}=a;l>=i&&l<o&&n.push(a.blockId)}}return n}function q_(e,t=""){if(!t)return["body"];const{headers:n,footers:r}=e.getSnapshot();if(n==null&&r==null)throw new Error("Document data model must have headers or footers when update by segment id");if((n==null?void 0:n[t])!=null)return["headers",t,"body"];if((r==null?void 0:r[t])!=null)return["footers",t,"body"];throw new Error("Segment id not found in headers or footers")}const J_=e=>{var R,w,L,J;const{selection:t,documentDataModel:n,drawings:r}=e,{collapsed:s,startOffset:i,segmentId:o}=t,a=new Ye,l=kt.getInstance(),u=[],c=n.getSelfOrHeaderFooterModel(o).getBody();if(!c)return!1;const h=(w=(R=n.getSnapshot().drawingsOrder)==null?void 0:R.length)!=null?w:0;let d=0;if(s)i>0&&a.push({t:ce.RETAIN,len:i});else{const z=su([t],c,0,null,!1);a.push(...z);const de=X_(c,[t]),N=(L=n.getDrawings())!=null?L:{},A=(J=n.getDrawingsOrder())!=null?J:[],j=de.sort((Z,fe)=>A.indexOf(Z)>A.indexOf(fe)?-1:A.indexOf(Z)<A.indexOf(fe)?1:0);if(j.length>0)for(const Z of j){const fe=N[Z],ae=A.indexOf(Z);if(fe==null||ae<0)continue;const _=l.removeOp(["drawings",Z],fe),H=l.removeOp(["drawingsOrder",ae],Z);u.push(_),u.push(H),d++}}a.push({t:ce.INSERT,body:{dataStream:"\b".repeat(r.length),customBlocks:r.map((z,de)=>({startIndex:de,blockId:z.drawingId}))},len:r.length});const f=q_(n,o),E=l.editOp(a.serialize(),f);u.push(E);for(const z of r){const{drawingId:de}=z,N=l.insertOp(["drawings",de],z),A=l.insertOp(["drawingsOrder",h-d],de);u.push(N),u.push(A)}return u.reduce((z,de)=>kt.compose(z,de),null)},Z_=e=>{var h,d,f;const{paragraphs:t,segmentId:n,document:r}=e;let s=e.listType;const i=(d=(h=r.getSelfOrHeaderFooterModel(n).getBody())==null?void 0:h.paragraphs)!=null?d:[],o=t.every(E=>{var R;return((R=E.bullet)==null?void 0:R.listType.indexOf(s))===0});let l=re.generateRandomId(6);if(t.length===1){const E=i.indexOf(t[0]),R=i[E-1],w=i[E+1];R&&R.bullet&&R.bullet.listType.indexOf(s)===0?(l=R.bullet.listId,s!==Mt.CHECK_LIST&&(s=R.bullet.listType)):w&&w.bullet&&w.bullet.listType.indexOf(s)===0&&(l=w.bullet.listId,s!==Mt.CHECK_LIST&&(s=w.bullet.listType))}const u=new Nn;u.reset();const c=new Ye;for(const E of t){const{startIndex:R,paragraphStyle:w={},bullet:L}=E;c.push({t:ce.RETAIN,len:R-u.cursor}),c.push({t:ce.RETAIN,len:1,body:{dataStream:"",paragraphs:[o?{paragraphStyle:w,startIndex:0}:{startIndex:0,paragraphStyle:{...w},bullet:{nestingLevel:(f=L==null?void 0:L.nestingLevel)!=null?f:0,textStyle:{fs:20},listType:s,listId:l}}]},coverType:ke.REPLACE}),u.moveCursorTo(R+1)}return c},Q_=e=>{var h;const{paragraphIndex:t,segmentId:n,document:r}=e,s=(h=r.getSelfOrHeaderFooterModel(n).getBody())==null?void 0:h.paragraphs;if(s==null)return!1;const i=s.find(d=>d.startIndex===t);if(!(i!=null&&i.bullet)||i.bullet.listType.indexOf(Mt.CHECK_LIST)===-1)return!1;const o=new Nn;o.reset();const a=new Ye,{startIndex:l,paragraphStyle:u={}}=i,c=i.bullet.listType===Mt.CHECK_LIST?Mt.CHECK_LIST_CHECKED:Mt.CHECK_LIST;return a.push({t:ce.RETAIN,len:l-o.cursor}),a.push({t:ce.RETAIN,len:1,body:{dataStream:"",paragraphs:[{...i,paragraphStyle:u,startIndex:0,bullet:{...i.bullet,listType:c}}]},coverType:ke.REPLACE}),o.moveCursorTo(l+1),a},ep=e=>{var c,h;const{paragraphs:t,listType:n,segmentId:r,document:s}=e;if(((c=s.getSelfOrHeaderFooterModel(r).getBody())==null?void 0:c.paragraphs)==null)return!1;const a=re.generateRandomId(6),l=new Nn;l.reset();const u=new Ye;for(const d of t){const{startIndex:f,paragraphStyle:E={},bullet:R}=d;u.push({t:ce.RETAIN,len:f-l.cursor}),u.push({t:ce.RETAIN,len:1,body:{dataStream:"",paragraphs:[{startIndex:0,paragraphStyle:E,bullet:{nestingLevel:(h=R==null?void 0:R.nestingLevel)!=null?h:0,textStyle:(R==null?void 0:R.listType)===n?R.textStyle:{fs:20},listType:n,listId:a}}]},coverType:ke.REPLACE}),l.moveCursorTo(f+1)}return u};function tp(e,t){return t.some(n=>e.startIndex>n.startIndex&&e.startIndex<n.endIndex)}const np=e=>{var c,h,d;const{paragraphs:t,segmentId:n,document:r,type:s}=e,i=new Nn;i.reset();const o=new Ye,a=(c=r.getSnapshot().lists)!=null?c:{},l=(d=(h=r.getBody())==null?void 0:h.tables)!=null?d:[],u={...ur,...a};for(const f of t){const{startIndex:E,paragraphStyle:R={},bullet:w}=f,L=tp(f,l);if(o.push({t:ce.RETAIN,len:E-i.cursor}),w){const J=w.listType;let z=u[J].nestingLevel.length-1;L&&(z=Math.min(z,2)),o.push({t:ce.RETAIN,len:1,body:{dataStream:"",paragraphs:[{startIndex:0,paragraphStyle:{...R},bullet:{...w,nestingLevel:Math.max(Math.min(w.nestingLevel+s,z),0)}}]},coverType:ke.REPLACE})}else o.push({t:ce.RETAIN,len:1});i.moveCursorTo(E+1)}return o};function rp(e,t){if(typeof t>"u")return{startOffset:e,endOffset:e,collapsed:!0};if(t<e)throw new Error(`Cannot make a doc selection when endOffset ${t} is less than startOffset ${e}.`);return{startOffset:e,endOffset:t,collapsed:e===t}}function sp(e){const{startOffset:t,endOffset:n,collapsed:r}=e,s=Math.min(t,n),i=Math.max(t,n);return{startOffset:s,endOffset:i,collapsed:r}}function ip(e,t,n,r){return Math.max(e,n)<=Math.min(t,r)}class it{}C(it,"customRange",{add:Y_,delete:W_,copyCustomRange:B_,getCustomRangesInterestsWithSelection:$_,isIntersecting:nu}),C(it,"customDecoration",{add:P_,delete:F_}),C(it,"selection",{replace:V_,makeSelection:rp,normalizeSelection:sp,delete:su,replaceTextRuns:K_,retain:z_}),C(it,"range",{isIntersects:ip}),C(it,"transform",{getPlainText:Zr,fromPlainText:Kd,isEmptyDocument:Gd}),C(it,"paragraph",{bullet:{set:ep,switch:Z_,toggleChecklist:Q_,changeNestLevel:np}}),C(it,"drawing",{add:J_});function op(e){if(e.customRanges||(e.customRanges=[]),!e.paragraphs){e.paragraphs=[];for(let t=0;t<e.dataStream.length;t++)e.dataStream[t]==="\r"&&e.paragraphs.push({startIndex:t})}return e.customBlocks||(e.customBlocks=[]),e.textRuns||(e.textRuns=[]),e.customDecorations||(e.customDecorations=[]),e.sectionBreaks||(e.sectionBreaks=[]),e.tables||(e.tables=[]),e}function iu(e){var t;return e.body=op((t=e.body)!=null?t:{dataStream:""}),e.drawingsOrder||(e.drawingsOrder=[]),e.drawings||(e.drawings={}),e.documentStyle||(e.documentStyle={}),e}class cr{constructor(t={}){C(this,"_style");this._style=t}static create(t={}){return new cr(t)}get fontFamily(){return this._style.ff}get fontSize(){return this._style.fs}get italic(){return this._style.it===Ie.TRUE}get bold(){return this._style.bl===Ie.TRUE}get underline(){return this._style.ul&&Yt.create(this._style.ul)}get bottomBorderLine(){return this._style.bbl&&Yt.create(this._style.bbl)}get strikethrough(){return this._style.st&&Yt.create(this._style.st)}get overline(){return this._style.ol&&Yt.create(this._style.ol)}get background(){return this._style.bg}get border(){return this._style.bd}get color(){return this._style.cl}get verticalAlign(){return this._style.va}get numberFormat(){return this._style.n}copy(){return Kt.create(re.deepClone(this._style))}getValue(){return{...this._style}}}class Kt extends cr{static create(t={}){return new Kt(t)}constructor(t={}){super(t)}setFontFamily(t){return this._style.ff=t,this}setFontSize(t){return this._style.fs=t,this}setItalic(t){return this._style.it=t?1:0,this}setBold(t){return this._style.bl=t?1:0,this}setUnderline(t){return this._style.ul=t.build(),this}setBottomBorderLine(t){return this._style.bbl=t.build(),this}setStrikethrough(t){return this._style.st=t.build(),this}setOverline(t){return this._style.ol=t.build(),this}setBackground(t){return this._style.bg=t,this}setBorder(t){return this._style.bd=t,this}setColor(t){return this._style.cl=t,this}setVerticalAlign(t){return this._style.va=t,this}copy(){return Kt.create(re.deepClone(this._style))}build(){return this.getValue()}}class Yt{constructor(t={s:1}){C(this,"_decoration");this._decoration=t}static create(t={s:1}){return new Yt(t)}get show(){return this._decoration.s===Ie.TRUE}get followFontColor(){return this._decoration.c===Ie.TRUE}get color(){return this._decoration.cl}get type(){return this._decoration.t}setShow(t){return this._decoration.s=t?1:0,this}setFollowFontColor(t){return this._decoration.c=t?1:0,this}setColor(t){return this._decoration.cl=t,this}setLineType(t){return this._decoration.t=t,this}copy(){return Yt.create(re.deepClone(this._decoration))}build(){return{...this._decoration}}}class hr{constructor(t={}){C(this,"_style");this._style=t}static create(t={}){return new hr(t)}get indentFirstLine(){return this._style.indentFirstLine}get hanging(){return this._style.hanging}get indentStart(){return this._style.indentStart}get tabStops(){return this._style.tabStops}get indentEnd(){return this._style.indentEnd}get textStyle(){return this._style.textStyle}get headingId(){return this._style.headingId}get namedStyleType(){return this._style.namedStyleType}get horizontalAlign(){return this._style.horizontalAlign}get lineSpacing(){return this._style.lineSpacing}get direction(){return this._style.direction}get spacingRule(){return this._style.spacingRule}get snapToGrid(){return this._style.snapToGrid}get spaceAbove(){return this._style.spaceAbove}get spaceBelow(){return this._style.spaceBelow}get borderBetween(){return this._style.borderBetween}get borderTop(){return this._style.borderTop}get borderBottom(){return this._style.borderBottom}get borderLeft(){return this._style.borderLeft}get borderRight(){return this._style.borderRight}get keepLines(){return this._style.keepLines===Ie.TRUE}get keepNext(){return this._style.keepNext===Ie.TRUE}get wordWrap(){return this._style.wordWrap===Ie.TRUE}get widowControl(){return this._style.widowControl===Ie.TRUE}get shading(){return this._style.shading}get suppressHyphenation(){return this._style.suppressHyphenation===Ie.TRUE}copy(){return Jn.create(re.deepClone(this._style))}getValue(){return this._style}}class Jn extends hr{static create(t={}){return new Jn(t)}constructor(t={}){super(t)}setIndentFirstLine(t){return this._style.indentFirstLine=t,this}setHanging(t){return this._style.hanging=t,this}setIndentStart(t){return this._style.indentStart=t,this}setTabStops(t){return this._style.tabStops=t,this}setIndentEnd(t){return this._style.indentEnd=t,this}setTextStyle(t){return this._style.textStyle=t,this}setHeadingId(t){return this._style.headingId=t,this}setNamedStyleType(t){return this._style.namedStyleType=t,this}setHorizontalAlign(t){return this._style.horizontalAlign=t,this}setLineSpacing(t){return this._style.lineSpacing=t,this}setDirection(t){return this._style.direction=t,this}setSpacingRule(t){return this._style.spacingRule=t,this}setSnapToGrid(t){return this._style.snapToGrid=t?1:0,this}setSpaceAbove(t){return this._style.spaceAbove=t,this}setSpaceBelow(t){return this._style.spaceBelow=t,this}setBorderBetween(t){return this._style.borderBetween=t,this}setBorderTop(t){return this._style.borderTop=t,this}setBorderBottom(t){return this._style.borderBottom=t,this}setBorderLeft(t){return this._style.borderLeft=t,this}setBorderRight(t){return this._style.borderRight=t,this}setKeepLines(t){return this._style.keepLines=t?1:0,this}setKeepNext(t){return this._style.keepNext=t?1:0,this}setWordWrap(t){return this._style.wordWrap=t?1:0,this}setWidowControl(t){return this._style.widowControl=t?1:0,this}setShading(t){return this._style.shading=t,this}setSuppressHyphenation(t){return this._style.suppressHyphenation=t?1:0,this}copy(){return Jn.create(re.deepClone(this._style))}build(){return this.getValue()}}class zt{constructor(t){C(this,"_data");if(!t.body)throw new Error("Invalid document data, body is required");this._data=iu(t)}static create(t){return new zt(t)}static createByBody(t){return new zt({body:t,id:"d",documentStyle:{}})}copy(){return rn.create(re.deepClone(this._data))}slice(t,n){const{body:r,...s}=this._data;return rn.create({...re.deepClone(s),body:bt(r,t,n)})}toPlainText(){var t,n;return it.transform.getPlainText((n=(t=this._data.body)==null?void 0:t.dataStream)!=null?n:"").replaceAll("\r",`
9
9
  `)}getParagraphStyle(){var t,n;return hr.create((n=(t=this._data.body)==null?void 0:t.paragraphs)==null?void 0:n[0].paragraphStyle)}getParagraphBullet(){var t,n;return(n=(t=this._data.body)==null?void 0:t.paragraphs)==null?void 0:n[0].bullet}getParagraphs(){var r,s;const t=(s=(r=this._data.body)==null?void 0:r.paragraphs)!=null?s:[];let n=0;return t.map(i=>{const o=this.slice(n,i.startIndex);return n=i.startIndex,o})}getTextRuns(){var t,n;return((n=(t=this._data.body)==null?void 0:t.textRuns)!=null?n:[]).map(r=>({...r,ts:r.ts?cr.create(r.ts):null}))}getLinks(){var t,n,r;return(r=(n=(t=this._data.body)==null?void 0:t.customRanges)==null?void 0:n.filter(s=>s.rangeType===qt.HYPERLINK))!=null?r:[]}getData(){return this._data}}class rn extends zt{constructor(n){super(n);C(this,"_doc");this._doc=new yt(n)}static newEmptyData(){return iu({id:"d",documentStyle:{},drawings:{},drawingsOrder:[],body:{dataStream:`\r
10
- `,customBlocks:[],customRanges:[],paragraphs:[{startIndex:0}],textRuns:[],tables:[],sectionBreaks:[]}})}static create(n){return new rn(n!=null?n:rn.newEmptyData())}insertText(n,r,s){var c,h;let i=((h=(c=this._data.body)==null?void 0:c.dataStream.length)!=null?h:2)-2,o,a;if(typeof n=="string"?o=n:(i=Math.min(n,i),o=r),typeof r=="object"?a=r instanceof Kt?r.build():r:a=s instanceof Kt?s.build():s,!o)return this;const l={dataStream:o,textRuns:a?[{ts:a,st:i,ed:i+o.length}]:[]},u=it.selection.replace({doc:this._doc,selection:{startOffset:i,endOffset:i,collapsed:!0},body:l});if(!u)throw new Error("Insert text failed, please check.");return Ye.apply(this._doc.getBody(),u.serialize()),this}insertRichText(n,r){var a,l;let s=((l=(a=this._data.body)==null?void 0:a.dataStream.length)!=null?l:2)-2,i;typeof n=="object"?i=n instanceof zt?n.getData():n:(s=Math.min(n,s),i=r instanceof zt?r.getData():r);const o=it.selection.replace({doc:this._doc,selection:{startOffset:s,endOffset:s,collapsed:!0},body:i.body});if(!o)throw new Error("Insert text failed, please check.");return Ye.apply(this._doc.getBody(),o.serialize()),this}delete(n,r){if(r!==void 0){if(!r)return this;const s=it.selection.delete([{startOffset:n,endOffset:n+r,collapsed:!0}],this._data.body);Ye.apply(this._doc.getBody(),s)}return this}setStyle(n,r,s){const i={dataStream:"",textRuns:[{ts:s instanceof Kt?s.build():s,st:0,ed:r-n}]},o=it.selection.retain([{startOffset:n,endOffset:r,collapsed:!0}],i);return Ye.apply(this._doc.getBody(),o),this}setLink(n,r,s){const i=it.customRange.add({rangeType:qt.HYPERLINK,rangeId:Ut(),properties:{url:s},ranges:[{startOffset:n,endOffset:r,collapsed:!1}],body:this._data.body});if(!i)throw new Error("Insert text failed, please check.");return Ye.apply(this._doc.getBody(),i.serialize()),this}cancelLink(n,r){if(typeof n=="string"){const s=it.customRange.delete({rangeId:n,documentDataModel:this._doc});if(!s)throw new Error("Insert text failed, please check.");Ye.apply(this._doc.getBody(),s.serialize())}else this.slice(n,r).getLinks().forEach(i=>{const o=it.customRange.delete({rangeId:i.rangeId,documentDataModel:this._doc});if(!o)throw new Error("Insert text failed, please check.");Ye.apply(this._doc.getBody(),o.serialize())});return this}updateLink(n,r){var i,o;const s=(o=(i=this._data.body)==null?void 0:i.customRanges)==null?void 0:o.find(a=>a.rangeId===n);if(!s)throw new Error("Link not found");return s.properties.url=r,this}insertParagraph(n,r){var o,a;let s,i;return typeof n=="object"?(s={dataStream:"\r",paragraphs:[{startIndex:0,paragraphStyle:n.build()}]},i=((a=(o=this._data.body)==null?void 0:o.dataStream.length)!=null?a:2)-2):(i=n,s={dataStream:"\r",paragraphs:[{startIndex:0,paragraphStyle:r==null?void 0:r.build()}]}),this.insertRichText(i,zt.create({body:s,id:"d",documentStyle:{}})),this}insertLink(n,r,s){let i="",o="";typeof n=="string"?(i=n,o=r):(i=r,o=s);const a=rn.createByBody({dataStream:i,customRanges:[{rangeType:qt.HYPERLINK,rangeId:Ut(),properties:{url:o},startIndex:0,endIndex:i.length-1}]});return typeof n=="number"?this.insertRichText(n,a):this.insertRichText(a)}}function ap(e,t=16){let n=0,r=null;return function(...i){const o=Date.now();o-n<t?(r&&clearTimeout(r),r=setTimeout(()=>{n=o,e.apply(this,i)},t)):(n=o,e.apply(this,i))}}var Cn=(e=>(e[e.Style=1]="Style",e[e.Value=2]="Value",e))(Cn||{});function lp(e){return`sheet_interceptor_${e}`}const ou=e=>function(t,n){let r=-1,s=t;for(let i=0;i<=e.length;i++){if(i<=r)throw new Error("[SheetInterceptorService]: next() called multiple times!");if(r=i,i===e.length)return s;const o=e[i];let a=!1;if(s=o.handler(s,n,l=>(a=!0,l)),!a)break}return s};class up{constructor(t){C(this,"_interceptorsByName",new Map);C(this,"_interceptorPoints");this._interceptorPoints=t}fetchThroughInterceptors(t,n){const r=t;let s=this._interceptorsByName.get(r);return n&&(s=s.filter(n)),ou(s||[])}intercept(t,n){const r=t;this._interceptorsByName.has(r)||this._interceptorsByName.set(r,[]);const s=this._interceptorsByName.get(r);return s.push(n),this._interceptorsByName.set(r,s.sort((i,o)=>{var a,l;return((a=o.priority)!=null?a:0)-((l=i.priority)!=null?l:0)})),()=>er(this._interceptorsByName.get(r),n)}getInterceptPoints(){return this._interceptorPoints}dispose(){this._interceptorsByName.clear()}}function cp(e){return`sheet_async_interceptor_${e}`}const hp=e=>async function(t,n){let r=-1,s=t;for(let i=0;i<=e.length;i++){if(i<=r)throw new Error("[SheetInterceptorService]: next() called multiple times!");if(r=i,i===e.length)return s;const o=e[i];let a=!1;if(s=await o.handler(s,n,async l=>(a=!0,l)),!a)break}return s};class dp{constructor(t){C(this,"_asyncInterceptorsByName",new Map);C(this,"_asyncInterceptorPoints");this._asyncInterceptorPoints=t}fetchThroughAsyncInterceptors(t,n){const r=t;let s=this._asyncInterceptorsByName.get(r);return n&&(s=s.filter(n)),hp(s||[])}async interceptAsync(t,n){const r=t;this._asyncInterceptorsByName.has(r)||this._asyncInterceptorsByName.set(r,[]);const s=this._asyncInterceptorsByName.get(r);return s.push(n),this._asyncInterceptorsByName.set(r,s.sort((i,o)=>{var a,l;return((a=o.priority)!=null?a:0)-((l=i.priority)!=null?l:0)})),()=>er(this._asyncInterceptorsByName.get(r),n)}getInterceptPoints(){return this._asyncInterceptorPoints}dispose(){this._asyncInterceptorsByName.clear()}}function fp(e,t){for(const n in t)t.hasOwnProperty(n)&&(e[n]=t[n])}function au(e){return/^-?\d+(\.\d+)?$/.test(e)}function gp(e){return au(e)?Number(e)<=Number.MAX_SAFE_INTEGER:!1}class gi{constructor(){C(this,"_data",[])}static create(){return new gi}add(t){this._data.indexOf(t)>-1||this._data.push(t)}delete(t){const n=this._data.indexOf(t);this._data.splice(n,1)}getData(){return this._data}}class mi{constructor(){C(this,"_data",new Map)}static create(){return new mi}add(t,n){this._data.has(t)||this._data.set(t,n)}delete(t){this._data.delete(t)}getData(){return this._data}}function mp(e){const t=new MessageChannel;let n=!1;const r=()=>{n||e()};return t.port1.onmessage=r,t.port2.postMessage(null),()=>{n=!0,t.port1.onmessage=null,t.port1.close(),t.port2.close()}}function _p(e,t){return t.forEach(n=>e.add(n)),e}function pp(e,t,n,r){var u;if(t==="")return e;const s={id:"mock-id",body:e,documentStyle:{}},i=new yt(s),o=t.length;let a;for(;(a=(r?i.getBody().dataStream:i.getBody().dataStream.toLowerCase()).indexOf(t))>=0;){const c=new Ye,h=kt.getInstance();if(a>0&&c.retain(a),n.length>0){const d=i.sliceBody(a,a+o),f={dataStream:n};if(Array.isArray(d==null?void 0:d.textRuns)&&d.textRuns.length&&(f.textRuns=[{...d.textRuns[0],st:0,ed:n.length}]),(u=d==null?void 0:d.customRanges)!=null&&u.length){const E=d.customRanges[0];f.customRanges=[{...E,startIndex:0,endIndex:n.length-1}]}c.insert(n.length,f)}c.delete(o),i.apply(h.editOp(c.serialize()))}const l=i.getBody();return i.dispose(),l}const Ep="__default_document_sub_component_id20231101__";class lu{constructor(){C(this,"skipNextObservers",!1);C(this,"lastReturnValue");C(this,"isStopPropagation",!1)}stopPropagation(){this.isStopPropagation=!0}}class Cp extends we.Subject{constructor(){super(...arguments);C(this,"_sortedObservers",[])}subscribe(){throw new Error("[EventSubject]: please use `subscribeEvent` instead of `subscribe` method for `EventSubject`.")}next(){throw new Error("[EventSubject]: please use `emitEvent` instead of `next` method for `EventSubject`.")}unsubscribe(){super.unsubscribe(),this._sortedObservers.length=0}complete(){super.complete(),this._sortedObservers.length=0}subscribeEvent(n){let r;typeof n=="function"?r={next:([i,o])=>n(i,o)}:r=n;const s=super.subscribe(r);return this._sortedObservers.push(r),this._sortedObservers.sort((i,o)=>{var a,l;return((a=i.priority)!=null?a:0)-((l=o.priority)!=null?l:0)}),s.add(()=>this._sortedObservers=this._sortedObservers.filter(i=>i!==r)),s}clearObservers(){this._sortedObservers.forEach(n=>{var r;return(r=n.complete)==null?void 0:r.call(n)}),this._sortedObservers.length=0}emitEvent(n){var r;if(!this.closed){const s=new lu;s.lastReturnValue=n;for(const i of this._sortedObservers){const o=(r=i.next)==null?void 0:r.call(i,[n,s]);if(s.lastReturnValue=o,s.skipNextObservers)return{handled:!0,lastReturnValue:s.lastReturnValue,stopPropagation:s.isStopPropagation}}return{handled:this._sortedObservers.length>0,lastReturnValue:s.lastReturnValue,stopPropagation:s.isStopPropagation}}throw new Error("[EventSubject]: cannot emit event on a closed subject.")}}function Rp(e){return new we.Observable(t=>{const n=e.subscribeEvent(r=>{t.next(r)});return()=>n.unsubscribe()})}const ss=je.createIdentifier("core.resource-manager.service"),Hs={[Nt.Editor]:"Editor",[Nt.Owner]:"Owner",[Nt.Reader]:"Reader",[Nt.UNRECOGNIZED]:"UNRECOGNIZED"},Vr=e=>e?{userID:`${Hs[e]}_${re.generateRandomId(8)}`,name:Hs[e],avatar:""}:{userID:"",name:"",avatar:"",anonymous:!0,canBindAnonymous:!1},Ip=(e,t)=>e.startsWith(Hs[t]);class Zn{constructor(){C(this,"_model",new Map);C(this,"_userChange$",new we.Subject);C(this,"userChange$",this._userChange$.asObservable());C(this,"_currentUser$",new we.BehaviorSubject(Vr()));C(this,"currentUser$",this._currentUser$.asObservable())}getCurrentUser(){return this._currentUser$.getValue()}setCurrentUser(t){this.addUser(t),this._currentUser$.next(t)}addUser(t){this._model.set(t.userID,t),this._userChange$.next({type:"add",user:t})}getUser(t,n){const r=this._model.get(t);if(r)return r;n&&n()}delete(t){const n=this.getUser(t);this._model.delete(t),n&&this._userChange$.next({type:"delete",user:n})}clear(){this._model.clear(),this._userChange$.next({type:"clear"})}list(){return Array.from(this._model.values())}}var Sp=Object.getOwnPropertyDescriptor,vp=(e,t,n,r)=>{for(var s=r>1?void 0:r?Sp(t,n):t,i=e.length-1,o;i>=0;i--)(o=e[i])&&(s=o(s)||s);return s},Oo=(e,t)=>(n,r)=>t(n,r,e);exports.AuthzIoLocalService=class{constructor(t,n){C(this,"_permissionMap",new Map([]));this._resourceManagerService=t,this._userManagerService=n,this._initSnapshot(),this._initDefaultUser()}_initDefaultUser(){const t=this._userManagerService.getCurrentUser();t&&t.userID||this._userManagerService.setCurrentUser(Vr(Nt.Owner))}_getRole(t){const n=this._userManagerService.getCurrentUser();return n?Ip(n.userID,t):!1}_initSnapshot(){this._resourceManagerService.registerPluginResource({toJson:t=>{const n=[...this._permissionMap.keys()].reduce((r,s)=>{const i=this._permissionMap.get(s);return r[s]=i,r},{});return JSON.stringify(n)},parseJson:t=>JSON.parse(t),pluginName:"SHEET_AuthzIoMockService_PLUGIN",businesses:[$e.UNIVER_SHEET,$e.UNIVER_DOC,$e.UNIVER_SLIDE],onLoad:(t,n)=>{for(const r in n)this._permissionMap.set(r,n[r])},onUnLoad:()=>{this._permissionMap.clear()}})}async create(t){return Ut(8)}async allowed(t){return Promise.resolve([])}async batchAllowed(t){return Promise.resolve([])}async list(t){const n=[];return t.objectIDs.forEach(r=>{const s=this._permissionMap.get(r);if(s){const i={objectID:r,unitID:t.unitID,objectType:s.objectType,name:s.name,shareOn:!1,shareRole:Nt.Owner,shareScope:-1,scope:{read:ks.AllCollaborator,edit:ks.AllCollaborator},creator:Vr(Nt.Owner),strategies:[{action:6,role:1},{action:16,role:1},{action:17,role:1},{action:18,role:1},{action:19,role:1},{action:33,role:1},{action:34,role:1},{action:35,role:1},{action:36,role:1},{action:37,role:1},{action:38,role:1},{action:39,role:1},{action:40,role:1}],actions:t.actions.map(o=>({action:o,allowed:this._getRole(Nt.Owner)||this._getRole(Nt.Editor)}))};n.push(i)}}),n}async listCollaborators(){return[]}async listRoles(){return{roles:[],actions:[]}}async deleteCollaborator(){}async update(t){}async updateCollaborator(){}async createCollaborator(){}async putCollaborators(t){}};exports.AuthzIoLocalService=vp([Oo(0,ss),Oo(1,je.Inject(Zn))],exports.AuthzIoLocalService);const uu=je.createIdentifier("IAuthzIoIoService");var Op=Object.getOwnPropertyDescriptor,wp=(e,t,n,r)=>{for(var s=r>1?void 0:r?Op(t,n):t,i=e.length-1,o;i>=0;i--)(o=e[i])&&(s=o(s)||s);return s},bp=(e,t)=>(n,r)=>t(n,r,e);exports.MentionIOLocalService=class{constructor(t){this._userManagerService=t}async list(t){return{list:[{type:Pr.PERSON,mentions:[{objectType:Pr.PERSON,objectId:this._userManagerService.getCurrentUser().userID,label:this._userManagerService.getCurrentUser().name,metadata:{icon:this._userManagerService.getCurrentUser().avatar}}],metadata:{},title:"PEOPLE"}],page:t.page,size:t.size,total:1}}};exports.MentionIOLocalService=wp([bp(0,je.Inject(Zn))],exports.MentionIOLocalService);const cu=je.createIdentifier("univer.service.mention-io"),_i=je.createIdentifier("univer.config-service");class hu{constructor(){C(this,"_configChanged$",new we.Subject);C(this,"configChanged$",this._configChanged$.asObservable());C(this,"_config",new Map)}dispose(){this._configChanged$.complete()}getConfig(t){return this._config.get(t)}setConfig(t,n,r){var o;const{merge:s=!1}=r||{};let i=(o=this._config.get(t))!=null?o:{};s?i=li(i,n):i=n,this._config.set(t,i),this._configChanged$.next({[t]:i})}deleteConfig(t){return this._config.delete(t)}subscribeConfigValue$(t){return new we.Observable(n=>{Object.prototype.hasOwnProperty.call(this._config,t)&&n.next(this._config.get(t));const r=this.configChanged$.pipe(we.filter(s=>Object.prototype.hasOwnProperty.call(s,t))).subscribe(s=>n.next(s[t]));return()=>r.unsubscribe()})}}const Hn="FOCUSING_UNIT",Rn="FOCUSING_SHEET",jn="FOCUSING_DOC",Wn="FOCUSING_SLIDE",yp="FOCUSING_EDITOR_BUT_HIDDEN",du="EDITOR_ACTIVATED",Ap="FOCUSING_EDITOR_INPUT_FORMULA",fu="FOCUSING_FX_BAR_EDITOR",Tp="FOCUSING_UNIVER_EDITOR",Np="FOCUSING_EDITOR_INPUT_FORMULA",Mp="FOCUSING_PANEL_EDITOR",Dp="FOCUSING_UNIVER_EDITOR_STANDALONE_SINGLE_MODE",Lp="FOCUSING_COMMON_DRAWINGS",xp="FORMULA_EDITOR_ACTIVATED";class gu extends rt{constructor(){super(...arguments);C(this,"_error$",new we.Subject);C(this,"error$",this._error$.asObservable())}dispose(){this._error$.complete()}emit(n){this._error$.next({errorKey:n})}}const Up="0.6.6",kp={version:Up};function Pp(e="",t=rr.ZH_CN,n=""){return{id:e,sheetOrder:[],name:n,appVersion:kp.version,locale:t,styles:{},sheets:{},resources:[]}}class mu{constructor(t={}){C(this,"_styles");C(this,"_cacheMap",new Xn(1e5));this._styles=t,this._generateCacheMap()}each(t){return Object.entries(this._styles).forEach(t),this}search(t,n){if(this._cacheMap.has(n))return this._cacheMap.get(n);const r=this._getExistingStyleId(t);return r||"-1"}get(t){return typeof t!="string"?t:(t=String(t),this._styles[t])}add(t,n){const r=re.generateRandomId(6);return this._styles[r]=t,this._cacheMap.set(n,r),r}setValue(t){if(t==null)return;const n=JSON.stringify(t),r=this.search(t,n);return r!=="-1"?r:this.add(t,n)}toJSON(){return this._styles}getStyleByCell(t){let n;t&&re.isObject(t.s)?n=t.s:n=(t==null?void 0:t.s)&&this.get(t.s);const r=t==null?void 0:t.interceptorStyle;return r?{...n,...r}:n}_generateCacheMap(){const{_styles:t,_cacheMap:n}=this;for(const r in t){const s=JSON.stringify(t[r]);n.set(s,r)}}_getExistingStyleId(t){const{_styles:n}=this;for(const r in n)if(re.diffValue(n[r],t))return r;return null}}const Fp=(e,t)=>t.length===e.length&&!e.some(n=>t.some(r=>!Xt.equals(r,n))),$p=(e,t)=>t.length===e.length&&e.every((n,r)=>{const s=t[r];return s.unitId===n.unitId&&s.sheetId===n.sheetId&&Xt.equals(n.range,s.range)}),js={t:0,b:2,l:2,r:2},Bp=e=>({sbr:.6,sbo:e,spr:.6,spo:e}),wo=90;function Yn(e,t,n={}){const r=e.length,{textRotation:s,paddingData:i,horizontalAlign:o=Ot.UNSPECIFIED,verticalAlign:a=tn.UNSPECIFIED,wrapStrategy:l=on.UNSPECIFIED,cellValueType:u}=n,{t:c,r:h,b:d,l:f}=i||js,{vertexAngle:E,centerAngle:R}=Eu(s),w={id:"d",body:{dataStream:`${e}${Oa}`,textRuns:[{ts:t,st:0,ed:r}],paragraphs:[{startIndex:r,paragraphStyle:{horizontalAlign:o}}],sectionBreaks:[{startIndex:r+1}]},documentStyle:{pageSize:{width:Number.POSITIVE_INFINITY,height:Number.POSITIVE_INFINITY},marginTop:c,marginBottom:d,marginRight:h,marginLeft:f,renderConfig:{horizontalAlign:o,verticalAlign:a,centerAngle:R,vertexAngle:E,wrapStrategy:l,cellValueType:u,zeroWidthParagraphBreak:1}},drawings:{},drawingsOrder:[]};return new yt(w)}function Hp(e){if(!e)return{};const{tr:t,td:n,ht:r,vt:s,tb:i,pd:o}=e;return{textRotation:t,textDirection:n,horizontalAlign:r,verticalAlign:s,wrapStrategy:i,paddingData:o}}function bo(e){if(!e)return{};const{ff:t,fs:n,it:r,bl:s,ul:i,st:o,ol:a,cl:l}=e,u={};return t&&(u.ff=t),n&&(u.fs=n),r&&(u.it=r),s&&(u.bl=s),i&&(u.ul=i),o&&(u.st=o),a&&(u.ol=a),l&&(u.cl=l),u}function _u(e,t,n){var i;const r=e.getBody();if((i=r.customRanges)!=null&&i.some(o=>o.rangeType===qt.HYPERLINK))return;const s=it.customRange.add({ranges:[{startOffset:0,endOffset:r.dataStream.length-1,collapsed:!1}],rangeId:n,rangeType:qt.HYPERLINK,body:r,properties:{url:t,refId:n}});s&&Ye.apply(r,s.serialize())}function pu(e){return e!=null}const jp='"Helvetica Neue", Helvetica, Arial, "PingFang SC", "Hiragino Sans GB", "Heiti SC", "Microsoft YaHei", "WenQuanYi Micro Hei", sans-serif';function yo(e){const t=lt.ff,n=lt.fs;if(!e){const h=`${n}pt ${t}`;return{fontCache:h,fontString:h,fontSize:n,originFontSize:n,fontFamily:t}}let r=En.ITALIC;(e.it===0||e.it===void 0)&&(r=En.NORMAL);let s=En.BOLD;(e.bl===0||e.bl===void 0)&&(s=En.NORMAL);let i=n;e.fs&&(i=Math.ceil(e.fs));let o=t;if(e.ff){let h=e.ff;h=h.replace(/"/g,"").replace(/'/g,""),h.indexOf(" ")>-1&&(h=`"${h}"`),h==null&&(h=t),o=h}const{va:a}=e;let l=i;if(a===xt.SUBSCRIPT||a===xt.SUPERSCRIPT){const h=Wp(o,l),{sbr:d,spr:f}=h;l*=a===xt.SUBSCRIPT?d:f}const u=`${r} ${s} ${l}pt ${o}`,c=`${u}, ${jp} `;return{fontCache:u,fontString:c,fontSize:l,originFontSize:i,fontFamily:o}}function Wp(e,t){return Bp(t)}function Eu(e){const{a:t=0,v:n=Ie.FALSE}=e||{a:0,v:Ie.FALSE};let r=0,s=t;return n===Ie.TRUE&&(r=wo,s=wo),{centerAngle:r,vertexAngle:s}}class Yp{constructor(t,n){C(this,"_columnData",{});this._config=t,this._columnData=n}getColumnData(){return this._columnData}getColVisible(t){const{_columnData:n}=this,r=n[t];return r?r.hd!==Ie.TRUE:!0}getColumnStyle(t){var n;return(n=this._columnData[t])==null?void 0:n.s}setColumnStyle(t,n){const r=this.getColumnOrCreate(t);r.s=n}getHiddenCols(t=0,n=this.getSize()-1){const r=[];let s=!1,i=-1;for(let o=t;o<=n;o++){const a=this.getColVisible(o);s&&a?(s=!1,r.push({rangeType:Le.COLUMN,startColumn:i,endColumn:o-1,startRow:0,endRow:0})):!s&&!a&&(s=!0,i=o)}return s&&r.push({startRow:0,endRow:0,startColumn:i,endColumn:n,rangeType:Le.COLUMN}),r}getVisibleCols(t=0,n=this.getSize()-1){const r=[];let s=!1,i=-1;for(let o=t;o<=n;o++){const a=this.getColVisible(o);s&&!a?(s=!1,r.push({rangeType:Le.COLUMN,startColumn:i,endColumn:o-1,startRow:0,endRow:0})):!s&&a&&(s=!0,i=o)}return s&&r.push({startRow:0,endRow:0,startColumn:i,endColumn:n,rangeType:Le.COLUMN}),r}getColumnDatas(t,n){const r={};let s=0;for(let i=t;i<t+n;i++){const o=this.getColumnOrCreate(i);r[s]=o,s++}return r}getSize(){return Gt(this._columnData)}getColumnWidth(t){const{_columnData:n}=this,r=this._config;let s=0;return s=(n[t]||{hd:Ie.FALSE,w:r.defaultColumnWidth}).w||r.defaultColumnWidth,s}getColumn(t){const n=this._columnData[t];if(n)return n}removeColumn(t){delete this._columnData[t]}getColumnOrCreate(t){const{_columnData:n}=this,r=n[t];if(r)return r;const s={};return this._columnData[t]=s,s}setCustomMetadata(t,n){const r=this.getColumn(t);r&&(r.custom=n)}getCustomMetadata(t){var n;return(n=this.getColumn(t))==null?void 0:n.custom}}class zp{constructor(t,n,r){C(this,"_rowData");this._config=t,this._viewModel=n,this._rowData=r}getRowData(){return this._rowData}getRowStyle(t){var n;return(n=this._rowData[t])==null?void 0:n.s}setRowStyle(t,n){const r=this.getRowOrCreate(t);r.s=n}getRowDatas(t,n){const r={};let s=0;for(let i=t;i<t+n;i++){const o=this.getRowOrCreate(i);r[s]=o,s++}return r}getRowHeight(t,n=1){const{_rowData:r}=this,s=this._config;let i=0;for(let o=0;o<n;o++){const a=r[o+t]||{hd:Ie.FALSE,h:s.defaultRowHeight},{ia:l,ah:u,h:c=s.defaultRowHeight}=a;i+=(l==null||l===Ie.TRUE)&&typeof u=="number"?u:c}return i}getRow(t){return this._rowData[t]}removeRow(t){delete this._rowData[t]}getRowOrCreate(t){const{_rowData:n}=this,r=n[t];if(r)return r;const s={};return n[t]=s,s}getHiddenRows(t=0,n=this.getSize()-1){const r=[];let s=!1,i=-1;for(let o=t;o<=n;o++){const a=this.getRowRawVisible(o);s&&a?(s=!1,r.push({startRow:i,endRow:o-1,startColumn:0,endColumn:0,rangeType:Le.ROW})):!s&&!a&&(s=!0,i=o)}return s&&r.push({startRow:i,endRow:n,startColumn:0,endColumn:0,rangeType:Le.ROW}),r}getVisibleRows(t=0,n=this.getSize()-1){const r=[];let s=!1,i=-1;for(let o=t;o<=n;o++){const a=this.getRowRawVisible(o);s&&!a?(s=!1,r.push({startRow:i,endRow:o-1,startColumn:0,endColumn:0,rangeType:Le.ROW})):!s&&a&&(s=!0,i=o)}return s&&r.push({startRow:i,endRow:n,startColumn:0,endColumn:0,rangeType:Le.ROW}),r}getRowRawVisible(t){const n=this.getRow(t);return n?n.hd!==Ie.TRUE:!0}getSize(){return Gt(this._rowData)}setCustomMetadata(t,n){const r=this.getRow(t);r&&(r.custom=n)}getCustomMetadata(t){var n;return(n=this.getRow(t))==null?void 0:n.custom}}const Vp="DEFAULT_WORKSHEET_ROW_COUNT",Cu=1e3,Gp="DEFAULT_WORKSHEET_COLUMN_COUNT",Ru=20,Kp="DEFAULT_WORKSHEET_ROW_HEIGHT",Iu=24,Xp="DEFAULT_WORKSHEET_COLUMN_WIDTH",Su=88,qp="DEFAULT_WORKSHEET_ROW_TITLE_WIDTH",vu=46,Jp="DEFAULT_WORKSHEET_COLUMN_TITLE_HEIGHT",Ou=20;function wu(e){const t={name:"Sheet1",id:"sheet-01",tabColor:"",hidden:Ie.FALSE,rowCount:Cu,columnCount:Ru,zoomRatio:1,freeze:{xSplit:0,ySplit:0,startRow:-1,startColumn:-1},scrollTop:0,scrollLeft:0,defaultColumnWidth:Su,defaultRowHeight:Iu,mergeData:[],cellData:{},rowData:{},columnData:{},showGridlines:Ie.TRUE,rowHeader:{width:vu,hidden:Ie.FALSE},columnHeader:{height:Ou,hidden:Ie.FALSE},rightToLeft:Ie.FALSE};return Object.keys(t).forEach(n=>{const r=n;typeof e[r]>"u"&&(e[r]=t[r])}),e}class Zp extends rt{constructor(n){super();C(this,"_cellCache",new Map);C(this,"_rowCache",new Map);C(this,"_columnCache",new Map);C(this,"_hasRow",!1);C(this,"_hasColumn",!1);C(this,"_hasAll",!1);C(this,"_allIndex",-1);C(this,"_mergeData");C(this,"_rangeMap",new Xn(5e4));C(this,"_skeletonCache",new Xn(5e4));this._init(n.concat())}_init(n){this._mergeData=n,this._createCache(n)}_clearCache(){this._cellCache.clear(),this._rowCache.clear(),this._columnCache.clear(),this._hasAll=!1,this._allIndex=-1,this._rangeMap.clear(),this._skeletonCache.clear(),this._hasColumn=!1,this._hasRow=!1}_createCache(n){let r=0;for(const s of n){const{rangeType:i}=s;i===Le.ROW?this._createRowCache(s,r):i===Le.COLUMN?this._createColumnCache(s,r):i===Le.ALL?this._createCellAllCache(r):this._createCellCache(s,r),r++}}rebuild(n){this._clearCache(),this._init(n.concat())}_createRowCache(n,r){const{startRow:s,endRow:i}=n;for(let o=s;o<=i;o++)this._rowCache.set(o,r),this._hasRow=!0}_createColumnCache(n,r){const{startColumn:s,endColumn:i}=n;for(let o=s;o<=i;o++)this._columnCache.set(o,r),this._hasColumn=!0}_createCellAllCache(n){this._hasAll=!0,this._allIndex=n}_createCellCache(n,r){for(let s=n.startRow;s<=n.endRow;s++){let i=this._cellCache.get(s);i==null&&(i=new Map,this._cellCache.set(s,i));for(let o=n.startColumn;o<=n.endColumn;o++)i.set(o,r)}}add(n){this._mergeData.push(n),this._clearCache(),this._createCache(this._mergeData)}remove(n,r){const s=this._getMergeDataIndex(n,r);s!==-1&&(this._mergeData.splice(s,1),this._clearCache(),this._createCache(this._mergeData))}getMergedCell(n,r){const s=this._getMergeDataIndex(n,r);return s!==-1?this._mergeData[s]:null}getMergeDataIndex(n,r){return this._getMergeDataIndex(n,r)}isRowContainsMergedCell(n){return this._hasAll||!re.isEmptyObject(this._columnCache)?!0:this._mergeData.some(r=>r.startRow<=n&&n<=r.endRow)}isColumnContainsMergedCell(n){return this._hasAll||!re.isEmptyObject(this._rowCache)?!0:this._mergeData.some(r=>r.startColumn<=n&&n<=r.endColumn)}getMergedCellRange(n,r,s,i){const o=[],a=`${n}-${r}-${s}-${i}`;if(this._rangeMap.has(a))return this._getRangeFromCache(a);let l=0;const u=[];for(const c of this._mergeData||[])Xt.intersects(c,{startRow:n,endRow:s,startColumn:r,endColumn:i})&&(o.push({...c}),u.push(l)),l++;return this._rangeMap.set(a,u),o}getMergedCellRangeForSkeleton(n,r,s,i){const o=[],a=this._mergeData,l=`${n}-${r}-${s}-${i}`;if(this._skeletonCache.has(l))return this._getSkeletonRangeFromCache(l);const u=[];for(let c=0;c<a.length;c++){const{startRow:h,endRow:d,startColumn:f,endColumn:E}=a[c];for(let R=n;R<=s;R++){let w=!1;for(let L=r;L<=i;L++)if(R>=h&&R<=d&&L>=f&&L<=E){o.push({startRow:h,endRow:d,startColumn:f,endColumn:E}),u.push(c),w=!0;break}if(w)break}}return this._skeletonCache.set(l,u),o}_getRangeFromCache(n){const r=this._rangeMap.get(n)||[],s=[];for(const i of r)s.push({...this._mergeData[i]});return s}_getSkeletonRangeFromCache(n){const r=this._skeletonCache.get(n)||[],s=[];for(const i of r)s.push({...this._mergeData[i]});return s}_getMergeDataIndex(n,r){var i;if(this._hasAll)return this._allIndex;if(this._hasRow){const o=this._rowCache.get(n);if(o!==void 0)return o}if(this._hasColumn){const o=this._columnCache.get(r);if(o!==void 0)return o}const s=(i=this._cellCache.get(n))==null?void 0:i.get(r);return s!==void 0?s:-1}getMergeDataSnapshot(){return this._mergeData}dispose(){this._clearCache(),this._mergeData=[]}}class bu extends rt{constructor(n){super();C(this,"_cellContentInterceptor",null);C(this,"_rowFilteredInterceptor",null);this.getRawCell=n}dispose(){super.dispose(),this._cellContentInterceptor=null,this._rowFilteredInterceptor=null}getCell(n,r,s,i){return this._cellContentInterceptor?this._cellContentInterceptor.getCell(n,r,Cn.Value|Cn.Style,s,i):this.getRawCell(n,r)}getCellValueOnly(n,r){return this._cellContentInterceptor?this._cellContentInterceptor.getCell(n,r,Cn.Value):this.getRawCell(n,r)}getCellStyleOnly(n,r){return this._cellContentInterceptor?this._cellContentInterceptor.getCell(n,r,Cn.Style):this.getRawCell(n,r)}getRowFiltered(n){var r,s;return(s=(r=this._rowFilteredInterceptor)==null?void 0:r.getRowFiltered(n))!=null?s:!1}registerCellContentInterceptor(n){if(this._cellContentInterceptor)throw new Error("[SheetViewModel]: Interceptor already registered.");return this._cellContentInterceptor=n,nt(()=>this._cellContentInterceptor=null)}registerRowFilteredInterceptor(n){if(this._rowFilteredInterceptor)throw new Error("[SheetViewModel]: Interceptor already registered.");return this._rowFilteredInterceptor=n,nt(()=>this._rowFilteredInterceptor=null)}}const Ao={isDeepClone:!1,displayRawFormula:!1,ignoreTextRotation:!1};class Qn{constructor(t,n,r){C(this,"_sheetId");C(this,"_snapshot");C(this,"_cellData");C(this,"_rowManager");C(this,"_columnManager");C(this,"_viewModel");C(this,"_spanModel");var a;this.unitId=t,this._styles=r,this._snapshot=wu(n);const{columnData:s,rowData:i,cellData:o}=this._snapshot;this._sheetId=(a=this._snapshot.id)!=null?a:re.generateRandomId(6),this._cellData=new wt(o),this._viewModel=new bu((l,u)=>this.getCellRaw(l,u)),this._rowManager=new zp(this._snapshot,this._viewModel,i),this._columnManager=new Yp(this._snapshot,s),this._spanModel=new Zp(this._snapshot.mergeData)}__interceptViewModel(t){t(this._viewModel)}getSnapshot(){return this._snapshot}setMergeData(t){this._snapshot.mergeData=t,this.getSpanModel().rebuild(t)}getSpanModel(){return this._spanModel}getStyleDataByHash(t){return{...this._styles.get(t)}}setStyleData(t){return this._styles.setValue(t)}getColumnStyle(t,n=!1){return n?this._columnManager.getColumnStyle(t):this._styles.get(this._columnManager.getColumnStyle(t))}setColumnStyle(t,n){this._columnManager.setColumnStyle(t,n)}getRowStyle(t,n=!1){return n?this._rowManager.getRowStyle(t):this._styles.get(this._rowManager.getRowStyle(t))}setRowStyle(t,n){this._rowManager.setRowStyle(t,n)}mixinDefaultStyleToCellRaw(t,n,r,s){const i=this.getColumnStyle(n),o=this.getRowStyle(t),a=this.getDefaultCellStyleInternal();if(a||i||o){let l=r==null?void 0:r.s;typeof l=="string"&&(l=this._styles.get(l));const u=s?ws(a,i,o,l):ws(a,o,i,l);r||(r={}),r.s=u}}getDefaultCellStyle(){return this._snapshot.defaultStyle}getDefaultCellStyleInternal(){const t=this._snapshot.defaultStyle;return this._styles.get(t)}setDefaultCellStyle(t){this._snapshot.defaultStyle=t}getCellMatrix(){return this._cellData}getCellMatrixPrintRange(){const t=this.getCellMatrix(),n=this.getMergeData();let r=-1,s=-1,i=-1,o=-1,a=!1,l=!1;return t.forEach((u,c)=>{Object.keys(c).forEach(h=>{const d=+h,f=t.getValue(u,d),E=f!=null&&f.s?this._styles.get(f.s):null,R=(E==null?void 0:E.bd)&&(E.bd.b||E.bd.l||E.bd.r||E.bd.t||E.bd.bc_tr||E.bd.bl_tr||E.bd.ml_tr||E.bd.tl_bc||E.bd.tl_br||E.bd.tl_mr);(f&&(f.v||f.p)||E!=null&&E.bg||R)&&(a?r=Math.min(r,u):(r=u,a=!0),s=Math.max(s,u),l?i=Math.min(i,d):(l=!0,i=d),o=Math.max(o,d))})}),n.forEach(u=>{a?r=Math.min(r,u.startRow):(r=u.startRow,a=!0),s=Math.max(s,u.endRow),l?i=Math.min(i,u.startColumn):(i=u.startColumn,a=!0),o=Math.max(o,u.endColumn)}),!a||!l?null:{startColumn:i,startRow:r,endColumn:o,endRow:s}}getRowManager(){return this._rowManager}getUnitId(){return this.unitId}getSheetId(){return this._sheetId}getColumnManager(){return this._columnManager}getName(){return this._snapshot.name}clone(){const{_snapshot:t}=this,n=re.deepClone(t);return new Qn(this.unitId,n,this._styles)}getMergeData(){return this._spanModel.getMergeDataSnapshot()}getMergedCell(t,n){return this._spanModel.getMergedCell(t,n)}getMergedCellRange(t,n,r,s){return this._spanModel.getMergedCellRange(t,n,r,s)}isRowContainsMergedCell(t){return this._spanModel.isRowContainsMergedCell(t)}isColumnContainsMergedCell(t){return this._spanModel.isColumnContainsMergedCell(t)}getCellInfoInMergeData(t,n){const r=this.getMergedCell(t,n);let s=!1,i=!1,o=t,a=n,l=t,u=n;if(r){const{startRow:c,endRow:h,startColumn:d,endColumn:f}=r;t===c&&n===d?(o=h,a=f,l=c,u=d,i=!0):t>=c&&t<=h&&n>=d&&n<=f&&(o=h,a=f,l=c,u=d,s=!0)}return{actualRow:t,actualColumn:n,isMergedMainCell:i,isMerged:s,endRow:o,endColumn:a,startRow:l,startColumn:u}}getCell(t,n){return t<0||n<0?null:this._viewModel.getCell(t,n)}getCellValueOnly(t,n){return t<0||n<0?null:this._viewModel.getCellValueOnly(t,n)}getCellStyleOnly(t,n){return t<0||n<0?null:this._viewModel.getCellStyleOnly(t,n)}getCellRaw(t,n){return this.getCellMatrix().getValue(t,n)}getCellWithFilteredInterceptors(t,n,r,s){return this._viewModel.getCell(t,n,r,s)}getRowFiltered(t){return this._viewModel.getRowFiltered(t)}getMatrixWithMergedCells(t,n,r,s,i=pn.Raw){const o=this.getCellMatrix(),a=this._spanModel.getMergedCellRange(t,n,r,s),l=new wt;return Ds(t,r,n,s).forEach((u,c)=>{var d;let h;if(i===pn.Raw)h=this.getCellRaw(u,c);else if(i===pn.Intercepted)h=this.getCell(u,c);else if(i===pn.Both){const f=this.getCellRaw(u,c);if(f){h={...f};const E=(d=this.getCell(u,c))==null?void 0:d.v;pu(E)&&h&&(h.displayV=String(E))}}h&&l.setValue(u,c,h)}),a.forEach(u=>{const{startColumn:c,startRow:h,endColumn:d,endRow:f}=u;Ds(h,f,c,d).forEach((E,R)=>{E===h&&R===c&&l.setValue(E,R,{...o.getValue(E,R),rowSpan:f-h+1,colSpan:d-c+1}),(E!==h||R!==c)&&l.realDeleteValue(E,R)})}),l}getRange(t,n,r,s){return typeof t=="object"?new vn(this,t,{getStyles:()=>this._styles}):new vn(this,{startRow:t,startColumn:n,endColumn:s||n,endRow:r||t},{getStyles:()=>this._styles})}getScrollLeftTopFromSnapshot(){return{scrollLeft:this._snapshot.scrollLeft,scrollTop:this._snapshot.scrollTop}}getZoomRatio(){return this._snapshot.zoomRatio||1}getConfig(){return this._snapshot}getFreeze(){return this._snapshot.freeze}getMaxColumns(){const{_snapshot:t}=this,{columnCount:n}=t;return n}getMaxRows(){const{_snapshot:t}=this,{rowCount:n}=t;return n}getRowCount(){return this._snapshot.rowCount}setRowCount(t){this._snapshot.rowCount=t}getColumnCount(){return this._snapshot.columnCount}setColumnCount(t){this._snapshot.columnCount=t}isSheetHidden(){return this._snapshot.hidden}hasHiddenGridlines(){const{_snapshot:t}=this,{showGridlines:n}=t;return n===0}getGridlinesColor(){return this.getConfig().gridlinesColor}getTabColor(){const{_snapshot:t}=this,{tabColor:n}=t;return n}getColumnWidth(t){return this.getColumnManager().getColumnWidth(t)}getRowHeight(t){return this._viewModel.getRowFiltered(t)?0:this.getRowManager().getRowHeight(t)}isRowFiltered(t){return this._viewModel.getRowFiltered(t)}getRowVisible(t){return!this.isRowFiltered(t)&&this.getRowRawVisible(t)}getRowRawVisible(t){return this.getRowManager().getRowRawVisible(t)}getHiddenRows(t,n){const r=this.getMaxColumns()-1,s=this._rowManager.getHiddenRows(t,n);return s.forEach(i=>i.endColumn=r),s}getColVisible(t){return this._columnManager.getColVisible(t)}getHiddenCols(t,n){const r=this.getMaxRows()-1,s=this._columnManager.getHiddenCols(t,n);return s.forEach(i=>i.endRow=r),s}getVisibleRows(){const t=this.getRowCount();return this._rowManager.getVisibleRows(0,t-1)}getVisibleCols(){const t=this.getColumnCount();return this._columnManager.getVisibleCols(0,t-1)}isRightToLeft(){const{_snapshot:t}=this,{rightToLeft:n}=t;return n}getLastRowWithContent(){return this._cellData.getLength()-1}getLastColumnWithContent(){return this._cellData.getRange().endColumn}getDataRangeScope(){return this._cellData.getStartEndScope()}cellHasValue(t){return t&&(t.v!==void 0||t.f!==void 0||t.p!==void 0)}iterateByRow(t,n=!0){const{startRow:r,startColumn:s,endRow:i,endColumn:o}=t,a=this;return{[Symbol.iterator]:()=>{let l=r,u=s;return{next(){for(;;){if(u>o&&(l+=1,u=s),l>i)return{done:!0,value:void 0};const c=a.getCell(l,u),h=!c,d=a.getMergedCell(l,u);if(d){if(l!==d.startRow||u!==d.startColumn){u=d.endColumn+1;continue}if(h&&n){u=d.endColumn+1;continue}const E={row:l,col:u,value:c};return E.colSpan=d.endColumn-d.startColumn+1,E.rowSpan=d.endRow-d.startRow+1,u=d.endColumn+1,{done:!1,value:E}}if(h&&n)u+=1;else{const f={row:l,col:u,value:c};return u+=1,{done:!1,value:f}}}}}}}}iterateByColumn(t,n=!0,r=!0){const{startRow:s,startColumn:i,endRow:o,endColumn:a}=t,l=this;return{[Symbol.iterator]:()=>{let u=s,c=i;return{next(){for(;;){if(u>o&&(c+=1,u=s),c>a)return{done:!0,value:void 0};const h=l.getMergedCell(u,c);if(h){const E=u!==h.startRow,R=E||c!==h.startColumn;if(r&&R||!r&&E){u=h.endRow+1;continue}const w=l.getCell(h.startRow,h.startColumn);if(!w&&n){u=h.endRow+1;continue}const J={row:u,col:h.startColumn,value:w};return J.colSpan=h.endColumn-h.startColumn+1,J.rowSpan=h.endRow-h.startRow+1,u=h.endRow+1,{done:!1,value:J}}const d=l.getCell(u,c);if(!d&&n)u+=1;else{const E={row:u,col:c,value:d};return u+=1,{done:!1,value:E}}}}}}}}_getCellDocumentModel(t,n=Ao){var R;const{isDeepClone:r,displayRawFormula:s,ignoreTextRotation:i}={...Ao,...n},o=this._styles.getStyleByCell(t);if(!t)return;let a,l="document";const u=Hp(o),c=i?lt.tr:u.textRotation||lt.tr;let h=u.horizontalAlign||lt.ht;const d=u.verticalAlign||lt.vt,f=u.wrapStrategy||lt.tb,E=u.paddingData||js;if(t.f&&s)a=Yn(t.f.toString(),{},{verticalAlign:d}),h=lt.ht;else if(t.p){const{centerAngle:w,vertexAngle:L}=Eu(c);a=this._updateConfigAndGetDocumentModel(r?re.deepClone(t.p):t.p,h,E,{horizontalAlign:h,verticalAlign:d,centerAngle:w,vertexAngle:L,wrapStrategy:f,zeroWidthParagraphBreak:1})}else if(t.v!=null){const w=bo(o);l=yo(w).fontCache;let L=yu(t);t.t===Vt.FORCE_STRING&&s&&(L=`'${L}`),a=Yn(L,w,{...u,textRotation:c,cellValueType:t.t})}return a&&t.linkUrl&&t.linkId&&_u(a,t.linkUrl,t.linkId),{documentModel:a,fontString:l,textRotation:c,wrapStrategy:f,verticalAlign:d,horizontalAlign:h,paddingData:E,fill:(R=o==null?void 0:o.bg)==null?void 0:R.rgb}}_updateConfigAndGetDocumentModel(t,n,r,s){var o,a,l,u,c;if(!s||!((o=t.body)!=null&&o.dataStream))return;t.documentStyle||(t.documentStyle={}),t.documentStyle.marginTop=(a=r.t)!=null?a:0,t.documentStyle.marginBottom=(l=r.b)!=null?l:2,t.documentStyle.marginLeft=(u=r.l)!=null?u:2,t.documentStyle.marginRight=(c=r.r)!=null?c:2,t.documentStyle.pageSize={width:Number.POSITIVE_INFINITY,height:Number.POSITIVE_INFINITY},t.documentStyle.renderConfig={...t.documentStyle.renderConfig,...s};const i=t.body.paragraphs||[];for(const h of i)h.paragraphStyle||(h.paragraphStyle={}),h.paragraphStyle.horizontalAlign=n;return new yt(t)}getBlankCellDocumentModel(t){const n=this._getCellDocumentModel(t,{ignoreTextRotation:!0}),r=this._styles.getStyleByCell(t),s=bo(r);if(n!=null)return n.documentModel==null&&(n.documentModel=Yn("",s)),n;const i="";let o="document";const a=lt.tr,l=lt.ht,u=lt.vt,c=lt.tb,h=js;return o=yo({}).fontCache,{documentModel:Yn(i,s),fontString:o,textRotation:a,wrapStrategy:c,verticalAlign:u,horizontalAlign:l,paddingData:h}}getCellDocumentModelWithFormula(t){return this._getCellDocumentModel(t,{isDeepClone:!0,displayRawFormula:!0,ignoreTextRotation:!0})}getCustomMetadata(){return this._snapshot.custom}setCustomMetadata(t){this._snapshot.custom=t}}function yu(e){var r,s;if(!e)return"";const t=(s=(r=e.p)==null?void 0:r.body)==null?void 0:s.dataStream;if(t)return it.transform.getPlainText(t);const n=e.v;return typeof n=="string"?e.t===Vt.BOOLEAN?n.toUpperCase():n.replace(/[\r\n]/g,""):typeof n=="number"?e.t===Vt.BOOLEAN?n?"TRUE":"FALSE":n.toString():typeof n=="boolean"?n?"TRUE":"FALSE":""}function Qp(e){if(e===null)return"";if(e!=null&&e.p){const t=e==null?void 0:e.p.body;if(t==null)return"";const n=t.dataStream;return it.transform.getPlainText(n)}return e==null?void 0:e.v}var eE=Object.getOwnPropertyDescriptor,tE=(e,t,n,r)=>{for(var s=r>1?void 0:r?eE(t,n):t,i=e.length-1,o;i>=0;i--)(o=e[i])&&(s=o(s)||s);return s},nE=(e,t)=>(n,r)=>t(n,r,e);function rE(e,t){return`${e.getUnitId()}|${t.getSheetId()}`}exports.Workbook=class extends rs{constructor(n={},r){super();C(this,"type",$e.UNIVER_SHEET);C(this,"_sheetCreated$",new we.Subject);C(this,"sheetCreated$",this._sheetCreated$.asObservable());C(this,"_sheetDisposed$",new we.Subject);C(this,"sheetDisposed$",this._sheetDisposed$.asObservable());C(this,"_activeSheet$",new we.BehaviorSubject(null));C(this,"activeSheet$",this._activeSheet$.asObservable());C(this,"_worksheets");C(this,"_styles");C(this,"_snapshot");C(this,"_unitId");C(this,"_count");C(this,"_name$");C(this,"name$");this._logService=r;const s=Pp();re.isEmptyObject(n)?this._snapshot=s:this._snapshot=re.commonExtend(s,n);const{styles:i}=this._snapshot;(this._snapshot.id==null||this._snapshot.id.length===0)&&(this._snapshot.id=re.generateRandomId(6)),this._unitId=this._snapshot.id,this._styles=new mu(i),this._count=1,this._worksheets=new Map,this._name$=new we.BehaviorSubject(n.name||""),this.name$=this._name$.asObservable(),this._parseWorksheetSnapshots()}get _activeSheet(){return this._activeSheet$.getValue()}get name(){return this._name$.getValue()}static isIRangeType(n){return typeof n=="string"||"startRow"in n||"row"in n}dispose(){super.dispose(),this._sheetCreated$.complete(),this._sheetDisposed$.complete(),this._activeSheet$.complete(),this._name$.complete()}save(){return re.deepClone(this._snapshot)}getSnapshot(){return this._snapshot}getName(){return this._snapshot.name}setName(n){this._name$.next(n),this._snapshot.name=n}getUnitId(){return this._unitId}getRev(){var n;return(n=this._snapshot.rev)!=null?n:1}incrementRev(){this._snapshot.rev=this.getRev()+1}setRev(n){this._snapshot.rev=n}addWorksheet(n,r,s){const{sheets:i,sheetOrder:o}=this._snapshot;if(i[n])return!1;i[n]=s,o.splice(r,0,n);const a=new Qn(this._unitId,s,this._styles);return this._worksheets.set(n,a),this._sheetCreated$.next(a),!0}getSheetOrders(){return this._snapshot.sheetOrder}getWorksheets(){return this._worksheets}getActiveSpreadsheet(){return this}getStyles(){return this._styles}getConfig(){return this._snapshot}getIndexBySheetId(n){const{sheetOrder:r}=this._snapshot;return r.findIndex(s=>s===n)}getActiveSheet(n){if(!this._activeSheet&&typeof n>"u")throw new Error(`[Workbook]: no active Worksheet on Workbook ${this._unitId}!`);return this._activeSheet}ensureActiveSheet(){const n=this._activeSheet;if(n)return n;const r=this._snapshot.sheetOrder;for(let i=0,o=r.length;i<o;i++){const a=this._worksheets.get(r[i]);if(a&&a.isSheetHidden()!==Ie.TRUE)return this.setActiveSheet(a),a}const s=this._worksheets.get(r[0]);return this.setActiveSheet(s),s}setActiveSheet(n){this._activeSheet$.next(n)}removeSheet(n){const r=this._worksheets.get(n);return r?(this._worksheets.delete(n),this._snapshot.sheetOrder.splice(this._snapshot.sheetOrder.indexOf(n),1),delete this._snapshot.sheets[n],this._sheetDisposed$.next(r),!0):!1}getActiveSheetIndex(){const{sheetOrder:n}=this._snapshot;return n.findIndex(r=>this._worksheets.get(r)===this._activeSheet)}getSheetSize(){return this._snapshot.sheetOrder.length}getSheets(){const{sheetOrder:n}=this._snapshot;return n.map(r=>this._worksheets.get(r))}getSheetsName(){const{sheetOrder:n}=this._snapshot,r=[];return n.forEach(s=>{const i=this._worksheets.get(s);i&&r.push(i.getName())}),r}getSheetIndex(n){const{sheetOrder:r}=this._snapshot;return r.findIndex(s=>n.getSheetId()===s)}getSheetBySheetName(n){const{sheetOrder:r}=this._snapshot,s=r.find(i=>this._worksheets.get(i).getName()===n);return this._worksheets.get(s)}getSheetBySheetId(n){return this._worksheets.get(n)}getSheetByIndex(n){const{sheetOrder:r}=this._snapshot;return this._worksheets.get(r[n])}getHiddenWorksheets(){return this.getSheets().filter(n=>n.getConfig().hidden===Ie.TRUE).map(n=>n.getConfig().id)}getUnhiddenWorksheets(){return this.getSheets().filter(n=>n.getConfig().hidden!==Ie.TRUE).map(n=>n.getConfig().id)}load(n){this._snapshot=n}checkSheetName(n){return this.getSheetsName().includes(n)}uniqueSheetName(n="Sheet1"){let r=n;for(;this.checkSheetName(r);)r=n+this._count,this._count++;return r}generateNewSheetName(n){let r=n+this._count;for(;this.checkSheetName(r);)r=n+this._count,this._count++;return r}_parseWorksheetSnapshots(){const{_snapshot:n,_worksheets:r}=this,{sheets:s,sheetOrder:i}=n;if(re.isEmptyObject(s)){const o=re.generateRandomId();s[o]={id:o}}for(const o in s){const a=s[o],{name:l}=a;a.name=this.uniqueSheetName(l),a.name!==l&&this._logService.debug("[Workbook]",`The worksheet name ${l} is duplicated, we changed it to ${a.name}. Please fix the problem in your snapshot.`);const u=new Qn(this._unitId,a,this._styles);r.set(o,u),i.includes(o)||i.push(o)}this.ensureActiveSheet()}getCustomMetadata(){return this._snapshot.custom}setCustomMetadata(n){this._snapshot.custom=n}};exports.Workbook=tE([nE(1,vt)],exports.Workbook);class pi extends rs{constructor(n){var r;super();C(this,"type",$e.UNIVER_SLIDE);C(this,"_activePage$",new we.BehaviorSubject(null));C(this,"activePage$",this._activePage$.asObservable());C(this,"_name$");C(this,"name$");C(this,"_snapshot");C(this,"_unitId");this._snapshot={...Aa,...n},this._unitId=(r=this._snapshot.id)!=null?r:re.generateRandomId(6),this._name$=new we.BehaviorSubject(this._snapshot.title),this.name$=this._name$.asObservable()}get _activePage(){var r,s;const n=this._activePage$.getValue();if(!n){const i=(r=this.getPageOrder())==null?void 0:r[0];return i?(s=this.getPages())==null?void 0:s[i]:null}return n}setName(n){var r;this._snapshot.title=n,this._name$.next(n),this._unitId=(r=this._snapshot.id)!=null?r:Ut(6)}getRev(){return 0}incrementRev(){}setRev(n){}getSnapshot(){return this._snapshot}getUnitId(){return this._unitId}getPages(){var n;return(n=this._snapshot.body)==null?void 0:n.pages}getPageOrder(){var n;return(n=this._snapshot.body)==null?void 0:n.pageOrder}getPage(n){const r=this.getPages();return r==null?void 0:r[n]}getElementsByPage(n){var r;return(r=this.getPage(n))==null?void 0:r.pageElements}getElement(n,r){var s;return(s=this.getElementsByPage(n))==null?void 0:s[r]}getPageSize(){return this._snapshot.pageSize}getBlankPage(){const n=Ut(6);return{id:n,pageType:ei.SLIDE,zIndex:10,title:n,description:"",pageBackgroundFill:{rgb:"rgb(255,255,255)"},pageElements:{}}}setActivePage(n){this._activePage$.next(n)}getActivePage(){return this._activePage}updatePage(n,r){this._snapshot.body&&(this._snapshot.body.pages[n]=r)}appendPage(n){var i;if(!this._snapshot.body)return;this._snapshot.body.pages[n.id]=n;const r=this._activePage,s=this._snapshot.body.pageOrder.indexOf((i=r==null?void 0:r.id)!=null?i:"");this._snapshot.body.pageOrder.splice(s+1,0,n.id)}}var sE=Object.getOwnPropertyDescriptor,iE=(e,t,n,r)=>{for(var s=r>1?void 0:r?sE(t,n):t,i=e.length-1,o;i>=0;i--)(o=e[i])&&(s=o(s)||s);return s},To=(e,t)=>(n,r)=>t(n,r,e);const bn=je.createIdentifier("univer.current");exports.UniverInstanceService=class extends rt{constructor(n,r){super();C(this,"_unitsByType",new Map);C(this,"_createHandler");C(this,"_ctorByType",new Map);C(this,"_currentUnits",new Map);C(this,"_currentUnits$",new we.BehaviorSubject(this._currentUnits));C(this,"currentUnits$",this._currentUnits$.asObservable());C(this,"_unitAdded$",new we.Subject);C(this,"unitAdded$",this._unitAdded$.asObservable());C(this,"_unitDisposed$",new we.Subject);C(this,"unitDisposed$",this._unitDisposed$.asObservable());C(this,"_focused$",new we.BehaviorSubject(null));C(this,"focused$",this._focused$.asObservable());this._injector=n,this._contextService=r}dispose(){super.dispose(),this._focused$.complete()}__setCreateHandler(n){this._createHandler=n}createUnit(n,r,s){return this._createHandler(n,r,this._ctorByType.get(n),s)}registerCtorForType(n,r){return this._ctorByType.set(n,r),{dispose:()=>{this._ctorByType.delete(n)}}}getCurrentTypeOfUnit$(n){return this.currentUnits$.pipe(we.map(r=>{var s;return(s=r.get(n))!=null?s:null}),we.distinctUntilChanged())}getCurrentUnitForType(n){return this._currentUnits.get(n)}getCurrentUnitOfType(n){return this.getCurrentUnitForType(n)}setCurrentUnitForType(n){const r=this._getUnitById(n);if(!r)throw new Error(`[UniverInstanceService]: no document with unitId ${n}!`);this._currentUnits.set(r[1],r[0]),this._currentUnits$.next(this._currentUnits)}getTypeOfUnitAdded$(n){return this._unitAdded$.pipe(we.filter(r=>r.type===n))}__addUnit(n,r){var a;const s=n.type;this._unitsByType.has(s)||this._unitsByType.set(s,[]);const i=this._unitsByType.get(s),o=n.getUnitId();if(i.findIndex(l=>l.getUnitId()===o)!==-1)throw new Error(`[UniverInstanceService]: cannot create a unit with the same unit id: ${o}.`);i.push(n),this._unitAdded$.next(n),((a=r==null?void 0:r.makeCurrent)==null||a)&&this.setCurrentUnitForType(n.getUnitId())}getTypeOfUnitDisposed$(n){return this.unitDisposed$.pipe(we.filter(r=>r.type===n))}getUnit(n,r){var i;const s=(i=this._getUnitById(n))==null?void 0:i[0];return r&&(s==null?void 0:s.type)!==r?null:s}getCurrentUniverDocInstance(){return this.getCurrentUnitForType($e.UNIVER_DOC)}getUniverDocInstance(n){return this.getUnit(n,$e.UNIVER_DOC)}getUniverSheetInstance(n){return this.getUnit(n,$e.UNIVER_SHEET)}getAllUnitsForType(n){var r;return(r=this._unitsByType.get(n))!=null?r:[]}changeDoc(n,r){const s=this.getAllUnitsForType($e.UNIVER_DOC),i=s.find(o=>o.getUnitId()===n);if(i!=null){const o=s.indexOf(i);s.splice(o,1)}this.__addUnit(r)}get focused(){var r;const n=this._focused$.getValue();return n?(r=this._getUnitById(n))==null?void 0:r[0]:null}focusUnit(n){this._focused$.next(n),this.focused instanceof exports.Workbook?(this._contextService.setContextValue(Hn,!0),this._contextService.setContextValue(jn,!1),this._contextService.setContextValue(Rn,!0),this._contextService.setContextValue(Wn,!1),this.setCurrentUnitForType(n)):this.focused instanceof yt?(this._contextService.setContextValue(Hn,!0),this._contextService.setContextValue(jn,!0),this._contextService.setContextValue(Rn,!1),this._contextService.setContextValue(Wn,!1),this.setCurrentUnitForType(n)):this.focused instanceof pi?(this._contextService.setContextValue(Hn,!0),this._contextService.setContextValue(jn,!1),this._contextService.setContextValue(Rn,!1),this._contextService.setContextValue(Wn,!0),this.setCurrentUnitForType(n)):(this._contextService.setContextValue(Hn,!1),this._contextService.setContextValue(jn,!1),this._contextService.setContextValue(Rn,!1),this._contextService.setContextValue(Wn,!1))}getFocusedUnit(){return this.focused}getUnitType(n){const r=this._getUnitById(n);return r?r[1]:$e.UNRECOGNIZED}disposeUnit(n){const r=this._getUnitById(n);if(!r)return!1;const[s,i]=r,o=this._unitsByType.get(i),a=o.indexOf(s);return o.splice(a,1),this._tryResetCurrentOnRemoval(n,i),this._tryResetFocusOnRemoval(n),this._unitDisposed$.next(s),!0}_tryResetCurrentOnRemoval(n,r){const s=this.getCurrentUnitForType(r);(s==null?void 0:s.getUnitId())===n&&(this._currentUnits.set(r,null),this._currentUnits$.next(this._currentUnits))}_tryResetFocusOnRemoval(n){var r;((r=this.focused)==null?void 0:r.getUnitId())===n&&this._focused$.next(null)}_getUnitById(n){for(const[r,s]of this._unitsByType){const i=s.find(o=>o.getUnitId()===n);if(i)return[i,r]}}};exports.UniverInstanceService=iE([To(0,je.Inject(je.Injector)),To(1,yn)],exports.UniverInstanceService);var Je=(e=>(e[e.Starting=0]="Starting",e[e.Ready=1]="Ready",e[e.Rendered=2]="Rendered",e[e.Steady=3]="Steady",e))(Je||{});const oE={0:"Starting",1:"Ready",2:"Rendered",3:"Steady"};var aE=Object.getOwnPropertyDescriptor,lE=(e,t,n,r)=>{for(var s=r>1?void 0:r?aE(t,n):t,i=e.length-1,o;i>=0;i--)(o=e[i])&&(s=o(s)||s);return s},uE=(e,t)=>(n,r)=>t(n,r,e);exports.LifecycleService=class extends rt{constructor(n){super();C(this,"_lifecycle$",new we.BehaviorSubject(Je.Starting));C(this,"lifecycle$",this._lifecycle$.asObservable());C(this,"_lock",!1);this._logService=n,this._reportProgress(Je.Starting)}get stage(){return this._lifecycle$.getValue()}set stage(n){if(this._lock)throw new Error("[LifecycleService]: cannot set new stage when related logic is all handled!");if(n<this.stage)throw new Error("[LifecycleService]: lifecycle stage cannot go backward!");n!==this.stage&&(this._lock=!0,this._reportProgress(n),this._lifecycle$.next(n),this._lock=!1)}dispose(){this._lifecycle$.complete(),super.dispose()}onStage(n){return we.firstValueFrom(this.lifecycle$.pipe(we.filter(r=>r>=n),Os(r=>r===n),we.map(()=>{})))}subscribeWithPrevious(){return we.merge(Au(this.stage),this._lifecycle$.pipe(we.skip(1))).pipe(Os(n=>n===Je.Steady))}_reportProgress(n){this._logService.debug("[LifecycleService]",`lifecycle progressed to "${oE[n]}".`)}};exports.LifecycleService=lE([uE(0,vt)],exports.LifecycleService);function Au(e){switch(e){case Je.Starting:return we.of(Je.Starting);case Je.Ready:return we.of(Je.Starting,Je.Ready);case Je.Rendered:return we.of(Je.Starting,Je.Ready,Je.Rendered);default:return we.of(Je.Starting,Je.Ready,Je.Rendered,Je.Steady)}}const cE=je.createIdentifier("ILocalStorageService");class sn extends rt{constructor(){super();C(this,"_currentLocale$",new we.BehaviorSubject(rr.ZH_CN));C(this,"currentLocale$",this._currentLocale$.asObservable());C(this,"_locales",null);C(this,"localeChanged$",new we.Subject);C(this,"t",(n,...r)=>{if(!this._locales)throw new Error("[LocaleService]: Locale not initialized");const s=n.split("."),i=this.resolveKeyPath(this._locales[this._currentLocale],s);if(typeof i=="string"){let o=i;return r.forEach((a,l)=>{o=o.replace(`{${l}}`,a)}),o}else return n});this.disposeWithMe(nt(()=>this.localeChanged$.complete()))}get _currentLocale(){return this._currentLocale$.value}load(n){var r;this._locales=li((r=this._locales)!=null?r:{},n)}setLocale(n){this._currentLocale$.next(n),this.localeChanged$.next()}getLocales(){var n;return(n=this._locales)==null?void 0:n[this._currentLocale]}getCurrentLocale(){return this._currentLocale}resolveKeyPath(n,r){const s=r.shift();if(s&&n&&s in n){const i=n[s];return r.length>0&&(typeof i=="object"||Array.isArray(i))?this.resolveKeyPath(i,r):i}return null}}var Ei=(e=>(e.INIT="init",e.FETCHING="fetching",e.DONE="done",e))(Ei||{});const Tu=je.createIdentifier("univer.permission-service");class Nu extends rt{constructor(){super(...arguments);C(this,"_permissionPointMap",new Map);C(this,"_permissionPointUpdate$",new we.Subject);C(this,"permissionPointUpdate$",this._permissionPointUpdate$.asObservable());C(this,"_showComponents",!0)}setShowComponents(n){this._showComponents=n}getShowComponents(){return this._showComponents}deletePermissionPoint(n){const r=this._permissionPointMap.get(n);r&&(r.complete(),this._permissionPointMap.delete(n))}addPermissionPoint(n){const r=n instanceof we.BehaviorSubject,s=r?n.getValue():n;if(!s.id)return!1;if(this._permissionPointMap.get(s.id))throw new Error(`${s.id} PermissionPoint already exists`);return this._permissionPointMap.set(s.id,r?n:new we.BehaviorSubject(s)),this._permissionPointUpdate$.next(s),!0}updatePermissionPoint(n,r){const s=this._permissionPointMap.get(n);if(!s)return;const i=s.getValue();i.value=r,i.status=Ei.DONE,s.next(i),this._permissionPointUpdate$.next(i)}clearPermissionMap(){this._permissionPointMap.clear()}getPermissionPoint(n){const r=this._permissionPointMap.get(n);if(r)return r.getValue()}getPermissionPoint$(n){const r=this._permissionPointMap.get(n);if(r)return r}composePermission$(n){const r=n.map(s=>{var o;const i=(o=this._permissionPointMap)==null?void 0:o.get(s);if(!i)throw new Error(`[PermissionService]: ${s} permissionPoint does not exist!`);return i.asObservable()});return we.combineLatest(r).pipe(wr.map(s=>s))}composePermission(n){return n.map(s=>{var o;const i=(o=this._permissionPointMap)==null?void 0:o.get(s);if(!i)throw new Error(`[PermissionService]: ${s} permissionPoint does not exist!`);return i.getValue()})}getAllPermissionPoint(){const n=new Map;return this._permissionPointMap.forEach((r,s)=>{n.set(s,r)}),n}}var hE=Object.getOwnPropertyDescriptor,dE=(e,t,n,r)=>{for(var s=r>1?void 0:r?hE(t,n):t,i=e.length-1,o;i>=0;i--)(o=e[i])&&(s=o(s)||s);return s},Cs=(e,t)=>(n,r)=>t(n,r,e);const fE=4,Mu=Symbol("DependentOn");class Ws extends rt{onStarting(){}onReady(){}onRendered(){}onSteady(){}getUnitType(){return this.constructor.type}getPluginName(){return this.constructor.pluginName}}C(Ws,"pluginName"),C(Ws,"type",$e.UNIVER_UNKNOWN);class gE{constructor(){C(this,"_plugins",[])}addPlugin(t){this._plugins.push(t)}removePlugins(){const t=this._plugins.slice();return this._plugins.length=0,t}forEachPlugin(t){this._plugins.forEach(t)}}function mE(...e){return function(t){t[Mu]=e}}exports.PluginService=class{constructor(t,n,r){C(this,"_pluginRegistry",new Map);C(this,"_pluginStore",new gE);C(this,"_seenPlugins",new Set);C(this,"_loadedPlugins",new Set);C(this,"_loadedPluginTypes",new Set([$e.UNIVER_UNKNOWN]));C(this,"_flushTimerByType",new Map);this._injector=t,this._lifecycleService=n,this._logService=r}dispose(){this._pluginStore.removePlugins().forEach(t=>t.dispose()),this._flushTimerByType.forEach(t=>clearTimeout(t))}registerPlugin(t,n){this._assertPluginValid(t);const r={plugin:t,options:n};this._pluginRegistry.set(t.pluginName,r),this._logService.debug("[PluginService]",`Plugin "${t.pluginName}" registered.`);const{type:s}=t;this._loadedPluginTypes.has(s)&&(s===$e.UNIVER_UNKNOWN?this._loadFromPlugins([r]):this._flushType(s))}startPluginsForType(t){this._loadedPluginTypes.has(t)||this._loadPluginsForType(t)}_loadPluginsForType(t){const n=Array.from(this._pluginRegistry.keys()),r=[];n.forEach(s=>{const i=this._pluginRegistry.get(s);i.plugin.type===t&&r.push(i)}),this._loadFromPlugins(r),this._loadedPluginTypes.add(t)}_assertPluginValid(t){const{type:n,pluginName:r}=t;if(n===$e.UNRECOGNIZED)throw new Error(`[PluginService]: invalid plugin type for ${t.name}. Please assign a "type" to your plugin.`);if(!r)throw new Error(`[PluginService]: no plugin name for ${t.name}. Please assign a "pluginName" to your plugin.`);if(this._seenPlugins.has(r))throw new Error(`[PluginService]: duplicated plugin name for "${r}". Maybe a plugin that dependents on "${r} has already registered it. In that case please register "${r}" before the that plugin.`);this._seenPlugins.add(t.pluginName)}_flushType(t){this._flushTimerByType.get(t)===void 0&&this._flushTimerByType.set(t,setTimeout(()=>{this._loadPluginsForType(t),this._flushTimerByType.delete(t)},fE))}_loadFromPlugins(t){const n=[],r=new Set,s=o=>{const{plugin:a}=o,{pluginName:l}=a;if(this._loadedPlugins.has(l)||r.has(l))return;r.add(l),this._pluginRegistry.delete(l);const u=a[Mu];u&&u.forEach(c=>{const h=this._pluginRegistry.get(c.pluginName);if(h)s(h);else if(!this._seenPlugins.has(c.pluginName)&&!r.has(c.pluginName)){if(a.type===$e.UNIVER_UNKNOWN&&c.type!==$e.UNIVER_UNKNOWN)throw new Error(`[PluginService]: cannot register a plugin with Univer type that depends on a plugin with other type. The dependent is ${a.pluginName} and the dependency is ${c.pluginName}.`);a.type!==c.type&&c.type!==$e.UNIVER_UNKNOWN&&this._logService.debug("[PluginService]",`Plugin "${l}" depends on "${c.pluginName}" which has different type.`),this._logService.debug("[PluginService]",`Plugin "${l}" depends on "${c.pluginName}" which is not registered. Univer will automatically register it with default configuration.`),this._assertPluginValid(c),s({plugin:c,options:void 0})}}),n.push(o)};t.forEach(o=>s(o));const i=n.map(o=>this._initPlugin(o.plugin,o.options));this._pluginsRunLifecycle(i)}_pluginsRunLifecycle(t){const n=this._lifecycleService.stage;if(Au(n).subscribe(r=>this._runStage(t,r)),n!==Je.Steady){const r=this._lifecycleService.lifecycle$.pipe(we.skip(1)).subscribe(s=>{this._runStage(t,s),s===Je.Steady&&r.unsubscribe()})}}_runStage(t,n){t.forEach(r=>{switch(n){case Je.Starting:r.onStarting();break;case Je.Ready:r.onReady();break;case Je.Rendered:r.onRendered();break;case Je.Steady:r.onSteady();break}})}_initPlugin(t,n){const r=this._injector.createInstance(t,n);return this._pluginStore.addPlugin(r),this._loadedPlugins.add(t.pluginName),this._logService.debug("[PluginService]",`Plugin "${r.getPluginName()}" loaded.`),r}};exports.PluginService=dE([Cs(0,je.Inject(je.Injector)),Cs(1,je.Inject(exports.LifecycleService)),Cs(2,vt)],exports.PluginService);function Du(e,t){if(!t)return e;const n=[];for(const r of e){const s=t.find(([i])=>i===r[0]);if(s){if(s[1]===null)continue;n.push([r[0],s[1]])}else n.push(r)}return n}const Ys=je.createIdentifier("resource-loader-service");class Lu extends rt{constructor(){super(...arguments);C(this,"_resourceMap",new Map);C(this,"_register$",new we.Subject);C(this,"register$",this._register$.asObservable())}getAllResourceHooks(){return[...this._resourceMap.values()]}getResources(n,r){return r?this.getResourcesByType(n,r):this.getAllResourceHooks().map(o=>{const a=o.toJson(n);return{name:o.pluginName,data:a}})}getResourcesByType(n,r){return this.getAllResourceHooks().filter(o=>o.businesses.includes(r)).map(o=>{const a=o.toJson(n);return{name:o.pluginName,data:a}})}registerPluginResource(n){const r=n.pluginName;if(this._resourceMap.has(r))throw new Error(`the pluginName is registered {${r}}`);return this._resourceMap.set(r,n),this._register$.next(n),nt(()=>this._resourceMap.delete(r))}disposePluginResource(n){this._resourceMap.delete(n)}loadResources(n,r){this.getAllResourceHooks().forEach(s=>{var o;const i=(o=r==null?void 0:r.find(a=>a.name===s.pluginName))==null?void 0:o.data;if(i)try{const a=s.parseJson(i);s.onLoad(n,a)}catch{console.error("LoadResources Error!")}})}unloadResources(n){this.getAllResourceHooks().forEach(r=>{r.onUnLoad(n)})}dispose(){this._register$.complete(),this._resourceMap.clear()}}class Ci extends rt{constructor(){super();C(this,"_currentTheme");C(this,"_currentTheme$",new we.BehaviorSubject({}));C(this,"currentTheme$",this._currentTheme$.asObservable());this.disposeWithMe(nt(()=>this._currentTheme$.complete()))}getCurrentTheme(){if(!this._currentTheme)throw new Error("[ThemeService]: current theme is not set!");return this._currentTheme}setTheme(n){this._currentTheme=n,this._currentTheme$.next(n)}}var _E=Object.getOwnPropertyDescriptor,pE=(e,t,n,r)=>{for(var s=r>1?void 0:r?_E(t,n):t,i=e.length-1,o;i>=0;i--)(o=e[i])&&(s=o(s)||s);return s},Rs=(e,t)=>(n,r)=>t(n,r,e);const is=je.createIdentifier("univer.undo-redo.service"),EE=20;class xu{dispose(){}async dispatchToHandlers(){return!1}}const Uu="univer.command.redo",ku="univer.command.undo",Pu=new class extends xu{constructor(){super(...arguments);C(this,"type",tr.COMMAND);C(this,"id",ku)}handler(t){const n=t.get(is),r=n.pitchTopUndoElement();if(!r)return!1;const s=t.get(nr);return Kr(r.undoMutations,s)?(n.popUndoToRedo(),!0):!1}},Fu=new class extends xu{constructor(){super(...arguments);C(this,"type",tr.COMMAND);C(this,"id",Uu)}handler(t){const n=t.get(is),r=n.pitchTopRedoElement();if(!r)return!1;const s=t.get(nr);return Kr(r.redoMutations,s)?(n.popRedoToUndo(),!0):!1}};exports.LocalUndoRedoService=class extends rt{constructor(n,r,s){super();C(this,"undoRedoStatus$");C(this,"_undoRedoStatus$",new we.BehaviorSubject({undos:0,redos:0}));C(this,"_undoStacks",new Map);C(this,"_redoStacks",new Map);C(this,"_batchingStatus",new Map);this._univerInstanceService=n,this._commandService=r,this._contextService=s,this.undoRedoStatus$=this._undoRedoStatus$.asObservable(),this.disposeWithMe(this._commandService.registerCommand(Pu)),this.disposeWithMe(this._commandService.registerCommand(Fu)),this.disposeWithMe(nt(()=>this._undoRedoStatus$.complete())),this.disposeWithMe(nt(this._univerInstanceService.focused$.subscribe(()=>this._updateStatus())))}pushUndoRedo(n){const{unitID:r}=n,s=this._getRedoStack(r,!0),i=this._getUndoStack(r,!0);if(s.length=0,this._batchingStatus.has(n.unitID)){const a=this._batchingStatus.get(n.unitID),l=this._pitchUndoElement(n.unitID);a===0||!l?(o(n),this._batchingStatus.set(n.unitID,1)):this._tryBatchingElements(l,n)}else o(n);function o(a){i.push(a),i.length>EE&&i.splice(0,1)}this._updateStatus()}clearUndoRedo(n){const r=this._getRedoStack(n);r&&(r.length=0);const s=this._getUndoStack(n);s&&(s.length=0),this._updateStatus()}pitchTopUndoElement(){const n=this._getFocusedUnitId();return this._pitchUndoElement(n)}pitchTopRedoElement(){const n=this._getFocusedUnitId();return this._pitchRedoElement(n)}_pitchUndoElement(n){const r=this._getUndoStack(n);return r!=null&&r.length?r[r.length-1]:null}_pitchRedoElement(n){const r=this._getRedoStack(n);return r!=null&&r.length?r[r.length-1]:null}popUndoToRedo(){const r=this._getUndoStackForFocused().pop();r&&(this._getRedoStackForFocused().push(r),this._updateStatus())}popRedoToUndo(){const r=this._getRedoStackForFocused().pop();r&&(this._getUndoStackForFocused().push(r),this._updateStatus())}rollback(n,r){const s=r||this._getFocusedUnitId(),i=this._getUndoStack(s),o=i==null?void 0:i[(i==null?void 0:i.length)-1];o&&o.id===n&&(i.pop(),Kr(o.undoMutations,this._commandService))}__tempBatchingUndoRedo(n){if(this._batchingStatus.has(n))throw new Error("[LocalUndoRedoService]: cannot batching undo redo twice at the same time!");return this._batchingStatus.set(n,0),nt(()=>this._batchingStatus.delete(n))}_updateStatus(){var i,o;const n=this._getFocusedUnitId(),r=n&&((i=this._undoStacks.get(n))==null?void 0:i.length)||0,s=n&&((o=this._redoStacks.get(n))==null?void 0:o.length)||0;this._undoRedoStatus$.next({undos:r,redos:s})}_getUndoStack(n,r=!1){let s=this._undoStacks.get(n);return!s&&r&&(s=[],this._undoStacks.set(n,s)),s||null}_getRedoStack(n,r=!1){let s=this._redoStacks.get(n);return!s&&r&&(s=[],this._redoStacks.set(n,s)),s||null}_getUndoStackForFocused(){const n=this._getFocusedUnitId();if(!n)throw new Error("No focused univer instance!");return this._getUndoStack(n,!0)}_getRedoStackForFocused(){const n=this._getFocusedUnitId();if(!n)throw new Error("No focused univer instance!");return this._getRedoStack(n,!0)}_tryBatchingElements(n,r){n.redoMutations.push(...r.redoMutations),n.undoMutations.push(...r.undoMutations)}_getFocusedUnitId(){var o,a,l,u;let n="";const r=this._contextService.getContextValue(Rn),s=this._contextService.getContextValue(fu),i=this._contextService.getContextValue(du);return r?s?n=Js:i?n=qs:n=(a=(o=this._univerInstanceService.getFocusedUnit())==null?void 0:o.getUnitId())!=null?a:"":n=(u=(l=this._univerInstanceService.getFocusedUnit())==null?void 0:l.getUnitId())!=null?u:"",n}};exports.LocalUndoRedoService=pE([Rs(0,bn),Rs(1,nr),Rs(2,yn)],exports.LocalUndoRedoService);function CE(e){return!(e.length===0||e.length>31||e.startsWith("'")||e.endsWith("'")||/[:\\\/\?\*\[\]]/.test(e))}function RE(e){return new Promise(t=>setTimeout(t,e))}function IE(e=1){return new Promise(t=>{let n=0;const r=()=>{n++,n>=e?t():requestAnimationFrame(r)};requestAnimationFrame(r)})}var Ri=(e=>(e.URL="URL",e.UUID="UUID",e.BASE64="BASE64",e))(Ri||{}),$u=(e=>(e.SUCCUSS="0",e.ERROR_EXCEED_SIZE="1",e.ERROR_IMAGE_TYPE="2",e.ERROR_UPLOAD_COUNT_LIMIT="3",e.ERROR_IMAGE="4",e))($u||{});const zs=je.createIdentifier("core.image-io.service");class Bu{constructor(t,n=100){C(this,"_imageCacheMap");this._injector=t,this._imageCacheMap=new Xn(n)}_getImageCacheKey(t,n){return`${t}-${n}`}getImage(t,n,r,s){const i=this._getImageCacheKey(t,n);let o=this._imageCacheMap.get(i);return o||((async()=>{o=new Image;const a=this._injector.has(zs)?this._injector.get(zs):null;if(t===Ri.UUID)try{o.src=await(a==null?void 0:a.getImage(n))||""}catch(l){console.error(l)}else o.src=n;o.onload=()=>{r==null||r()},o.onerror=()=>{s==null||s()},this._imageCacheMap.set(i,o)})(),null)}}const SE=["script","style","meta","comment","link"];var Hu=(e=>(e[e.INFO=0]="INFO",e[e.STOP=1]="STOP",e[e.WARNING=2]="WARNING",e))(Hu||{}),ju=(e=>(e[e.DISABLED=0]="DISABLED",e[e.FULL_ALPHA=1]="FULL_ALPHA",e[e.FULL_HANGUL=2]="FULL_HANGUL",e[e.FULL_KATAKANA=3]="FULL_KATAKANA",e[e.HALF_ALPHA=4]="HALF_ALPHA",e[e.HALF_HANGUL=5]="HALF_HANGUL",e[e.HALF_KATAKANA=6]="HALF_KATAKANA",e[e.HIRAGANA=7]="HIRAGANA",e[e.NO_CONTROL=8]="NO_CONTROL",e[e.OFF=9]="OFF",e[e.ON=10]="ON",e))(ju||{}),Wu=(e=>(e.BETWEEN="between",e.EQUAL="equal",e.GREATER_THAN="greaterThan",e.GREATER_THAN_OR_EQUAL="greaterThanOrEqual",e.LESS_THAN="lessThan",e.LESS_THAN_OR_EQUAL="lessThanOrEqual",e.NOT_BETWEEN="notBetween",e.NOT_EQUAL="notEqual",e))(Wu||{}),Yu=(e=>(e[e.TEXT=0]="TEXT",e[e.ARROW=1]="ARROW",e[e.CUSTOM=2]="CUSTOM",e))(Yu||{}),zu=(e=>(e.VALID="valid",e.INVALID="invalid",e.VALIDATING="validating",e))(zu||{}),Vu=(e=>(e.CUSTOM="custom",e.LIST="list",e.LIST_MULTIPLE="listMultiple",e.NONE="none",e.TEXT_LENGTH="textLength",e.DATE="date",e.TIME="time",e.WHOLE="whole",e.DECIMAL="decimal",e.CHECKBOX="checkbox",e.ANY="any",e))(Vu||{}),vE=Object.getOwnPropertyDescriptor,OE=(e,t,n,r)=>{for(var s=r>1?void 0:r?vE(t,n):t,i=e.length-1,o;i>=0;i--)(o=e[i])&&(s=o(s)||s);return s},wE=(e,t)=>(n,r)=>t(n,r,e);exports.Skeleton=class extends rt{constructor(n){super();C(this,"_fontLocale");C(this,"_dirty",!0);this._localeService=n,this._localeInitial()}get dirty(){return this._dirty}getFontLocale(){return this._fontLocale}makeDirty(n){this._dirty=n}dispose(){super.dispose(),this._fontLocale=null}_localeInitial(){}};exports.Skeleton=OE([wE(0,je.Inject(sn))],exports.Skeleton);var bE=Object.getOwnPropertyDescriptor,yE=(e,t,n,r)=>{for(var s=r>1?void 0:r?bE(t,n):t,i=e.length-1,o;i>=0;i--)(o=e[i])&&(s=o(s)||s);return s},Or=(e,t)=>(n,r)=>t(n,r,e);exports.SheetSkeleton=class extends exports.Skeleton{constructor(n,r,s,i,o,a){super(s);C(this,"_worksheetData");C(this,"_renderRawFormula",!1);C(this,"_cellData");C(this,"_imageCacheMap");C(this,"_isRowStylePrecedeColumnStyle",!1);C(this,"_skipAutoHeightForMergedCells",!0);C(this,"_rowTotalHeight",0);C(this,"_columnTotalWidth",0);C(this,"_rowHeaderWidth",0);C(this,"_columnHeaderHeight",0);C(this,"_rowHeightAccumulation",[]);C(this,"_columnWidthAccumulation",[]);C(this,"_marginTop",0);C(this,"_marginLeft",0);C(this,"_scaleX");C(this,"_scaleY");C(this,"_scrollX");C(this,"_scrollY");this.worksheet=n,this._styles=r,this._contextService=i,this._configService=o,this._injector=a,this._worksheetData=this.worksheet.getConfig(),this._cellData=this.worksheet.getCellMatrix(),this._imageCacheMap=new Bu(this._injector),this.initConfig()}initConfig(){var n,r;this._skipAutoHeightForMergedCells=!((n=this._configService.getConfig(ba))!=null&&n),this._isRowStylePrecedeColumnStyle=(r=this._configService.getConfig(wa))!=null?r:!1}resetCache(){}getWorksheetConfig(){return this._worksheetData}getLocation(){return[this.worksheet.getUnitId(),this.worksheet.getSheetId()]}set columnHeaderHeight(n){this._columnHeaderHeight=n,this._worksheetData.columnHeader.height=n}set rowHeaderWidth(n){this._rowHeaderWidth=n,this._worksheetData.rowHeader.width=n}get rowHeightAccumulation(){return this._rowHeightAccumulation}get rowTotalHeight(){return this._rowTotalHeight}get columnWidthAccumulation(){return this._columnWidthAccumulation}get columnTotalWidth(){return this._columnTotalWidth}get rowHeaderWidth(){return this._rowHeaderWidth}get columnHeaderHeight(){return this._columnHeaderHeight}setMarginLeft(n){this._marginLeft=n}setMarginTop(n){this._marginTop=n}setScale(n,r){this._updateLayout(),this._scaleX=n,this._scaleY=r||n,this._updateLayout()}setScroll(n,r){re.isDefine(n)&&(this._scrollX=n),re.isDefine(r)&&(this._scrollY=r)}get scrollX(){return this._scrollX}get scrollY(){return this._scrollY}get scaleX(){return this._scaleX}get scaleY(){return this._scaleY}get rowHeaderWidthAndMarginLeft(){return this.rowHeaderWidth+this._marginLeft}get columnHeaderHeightAndMarginTop(){return this.columnHeaderHeight+this._marginTop}get imageCacheMap(){return this._imageCacheMap}_generateRowMatrixCache(n,r,s){let i=0;const o=[],a=r;for(let l=0;l<n;l++){let u=s;if(this.worksheet.getRowFiltered(l))u=0;else if(a[l]!=null){const c=a[l];if(!c)continue;const{h=s,ah:d,ia:f}=c;(f==null||f===Ie.TRUE)&&typeof d=="number"?u=d:u=h,c.hd===Ie.TRUE&&(u=0)}i+=u,o.push(i)}return{rowTotalHeight:i,rowHeightAccumulation:o}}_generateColumnMatrixCache(n,r,s){let i=0;const o=[],a=r;for(let l=0;l<n;l++){let u=s;if(a[l]!=null){const c=a[l];if(!c)continue;c.w!=null&&(u=c.w),c.hd===Ie.TRUE&&(u=0)}i+=u,o.push(i)}return{columnTotalWidth:i,columnWidthAccumulation:o}}intersectMergeRange(n,r){return!!this.worksheet.getMergedCell(n,r)}_getOverflowBound(n,r,s,i,o=Ot.LEFT){let a=0;if(r>s){const l=this._columnWidthAccumulation.length-1;for(let u=r;u>=s;u--){const c=u,h=this.worksheet.getCell(n,c);if(!As(h)&&c!==r||this.intersectMergeRange(n,c))return c===r?c:c+1>l?l:c+1;const{startX:d,endX:f}=_n(n,c,this.rowHeightAccumulation,this.columnWidthAccumulation);if(o===Ot.CENTER&&c===r?a+=(f-d)/2:a+=f-d,i<a)return c}return r}for(let l=r;l<=s;l++){const u=l,c=this.worksheet.getCell(n,u);if(!As(c)&&u!==r||this.intersectMergeRange(n,u))return u===r?u:u-1<0?0:u-1;const{startX:h,endX:d}=_n(n,u,this.rowHeightAccumulation,this.columnWidthAccumulation);if(o===Ot.CENTER&&u===r?a+=(d-h)/2:a+=d-h,i<a)return u}return s}_updateLayout(){if(!this.dirty)return;const{rowData:n,columnData:r,defaultRowHeight:s,defaultColumnWidth:i,rowCount:o,columnCount:a,rowHeader:l,columnHeader:u}=this._worksheetData,{rowTotalHeight:c,rowHeightAccumulation:h}=this._generateRowMatrixCache(o,n,s),{columnTotalWidth:d,columnWidthAccumulation:f}=this._generateColumnMatrixCache(a,r,i);this._rowHeaderWidth=l.hidden!==Ie.TRUE?this._dynamicallyUpdateRowHeaderWidth(l):0,this._columnHeaderHeight=u.hidden!==Ie.TRUE?u.height:0,this._rowTotalHeight=c,this._rowHeightAccumulation=h,this._columnTotalWidth=d,this._columnWidthAccumulation=f,this.makeDirty(!1)}calculate(){return this.resetCache(),this._updateLayout(),this}resetRangeCache(n){}_dynamicallyUpdateRowHeaderWidth(n){const s=`${this.worksheet.getRowCount()}`.length*8;return Math.max(n.width,s)}_hasUnMergedCellInRow(n,r,s){if(!this.worksheet.getMergeData())return!1;for(let o=r;o<=s;o++){const{isMerged:a,isMergedMainCell:l}=this.worksheet.getCellInfoInMergeData(n,o);if(!a&&!l)return!0}return!1}expandRangeByMerge(n){let{startRow:r,startColumn:s,endRow:i,endColumn:o}=n;const a=this._worksheetData.mergeData;if(!a)return{startRow:r,startColumn:s,endRow:i,endColumn:o};let l=!0;const u=new wt;for(;l;){l=!1;for(let c=0;c<a.length;c++){const{startRow:h,startColumn:d,endRow:f,endColumn:E}=a[c];if(u.getValue(h,d))continue;Ma({startColumn:s,startRow:r,endColumn:o,endRow:i},{startColumn:d,startRow:h,endColumn:E,endRow:f})&&(r=Math.min(r,h),s=Math.min(s,d),i=Math.max(i,f),o=Math.max(o,E),u.setValue(h,d,!0),l=!0)}}return{startRow:r,startColumn:s,endRow:i,endColumn:o}}getColumnCount(){return this._columnWidthAccumulation.length}getRowCount(){return this._rowHeightAccumulation.length}_getCellMergeInfo(n,r){return this.worksheet.getCellInfoInMergeData(n,r)}getNoMergeCellPositionByIndex(n,r,s=!0){return this.getNoMergeCellWithCoordByIndex(n,r,s)}getNoMergeCellWithCoordByIndex(n,r,s=!0){const{rowHeightAccumulation:i,columnWidthAccumulation:o,rowHeaderWidthAndMarginLeft:a,columnHeaderHeightAndMarginTop:l}=this;let{startY:u,endY:c,startX:h,endX:d}=_n(n,r,i,o);return s&&(u+=l,c+=l,h+=a,d+=a),{startY:u,endY:c,startX:h,endX:d}}getNoMergeCellPositionByIndexWithNoHeader(n,r){const{rowHeightAccumulation:s,columnWidthAccumulation:i}=this,{startY:o,endY:a,startX:l,endX:u}=_n(n,r,s,i);return{startY:o,endY:a,startX:l,endX:u}}getRowIndexByOffsetY(n,r,s,i){var l;const{rowHeightAccumulation:o}=this;n=Ku(n,r,s,this.columnHeaderHeightAndMarginTop);let a=kn(o,n,i==null?void 0:i.firstMatch);return i!=null&&i.closeFirst&&Math.abs(o[a]-n)<Math.abs(n-((l=o[a-1])!=null?l:0))&&(a=a+1),a}getColumnIndexByOffsetX(n,r,s,i){var u;const o=Gu(n,r,s,this.rowHeaderWidthAndMarginLeft),{columnWidthAccumulation:a}=this;let l=kn(a,o,i==null?void 0:i.firstMatch);return i!=null&&i.closeFirst&&Math.abs(a[l]-o)<Math.abs(o-((u=a[l-1])!=null?u:0))&&(l=l+1),l}getCellIndexByOffset(n,r,s,i,o,a){const l=this.getRowIndexByOffsetY(r,i,o,a),u=this.getColumnIndexByOffsetX(n,s,o,a);return{row:l,column:u}}getCellByOffset(n,r,s,i,o){const a=this==null?void 0:this.getCellIndexByOffset(n,r,s,i,o,{firstMatch:!0});return a?this.worksheet.getCellInfoInMergeData(a.row,a.column):null}getCellWithCoordByIndex(n,r,s=!0){const{rowHeightAccumulation:i,columnWidthAccumulation:o,rowHeaderWidthAndMarginLeft:a,columnHeaderHeightAndMarginTop:l}=this,u=_n(n,r,i,o,this.worksheet.getCellInfoInMergeData(n,r)),{isMerged:c,isMergedMainCell:h}=u;let{startY:d,endY:f,startX:E,endX:R,mergeInfo:w}=u,L=a,J=l;return s===!1&&(L=0,J=0),d+=J,f+=J,E+=L,R+=L,w.startY+=J,w.endY+=J,w.startX+=L,w.endX+=L,{actualRow:n,actualColumn:r,startX:E,startY:d,endX:R,endY:f,isMerged:c,isMergedMainCell:h,mergeInfo:w}}getCellWithCoordByOffset(n,r,s,i,o,a){const{row:l,column:u}=this.getCellIndexByOffset(n,r,s,i,o,a);return this.getCellWithCoordByIndex(l,u)}getOffsetByColumn(n){const{columnWidthAccumulation:r,rowHeaderWidthAndMarginLeft:s}=this,i=r.length-1,o=r[n];return o!=null?o+s:n<0?s:r[i]+s}getOffsetByRow(n){const{rowHeightAccumulation:r,columnHeaderHeightAndMarginTop:s}=this,i=r.length-1,o=r[n];return o!=null?o+s:n<0?s:r[i]+s}getOffsetRelativeToRowCol(n,r){const s=kn(this.columnWidthAccumulation,n);let i=0;s===0?i=n:i=n-this._columnWidthAccumulation[s-1];const o=kn(this.rowHeightAccumulation,r);let a=0;return o===0?a=r:a=r-this._rowHeightAccumulation[o-1],{row:o,column:s,columnOffset:i,rowOffset:a}}_updateConfigAndGetDocumentModel(n,r,s,i){var a,l,u,c,h;if(!i||!((a=n.body)!=null&&a.dataStream))return;n.documentStyle||(n.documentStyle={}),n.documentStyle.marginTop=(l=s.t)!=null?l:0,n.documentStyle.marginBottom=(u=s.b)!=null?u:2,n.documentStyle.marginLeft=(c=s.l)!=null?c:2,n.documentStyle.marginRight=(h=s.r)!=null?h:2,n.documentStyle.pageSize={width:Number.POSITIVE_INFINITY,height:Number.POSITIVE_INFINITY},n.documentStyle.renderConfig={...n.documentStyle.renderConfig,...i};const o=n.body.paragraphs||[];for(const d of o)d.paragraphStyle||(d.paragraphStyle={}),d.paragraphStyle.horizontalAlign=r;return new yt(n)}dispose(){super.dispose(),this._rowHeightAccumulation=[],this._columnWidthAccumulation=[],this._rowTotalHeight=0,this._columnTotalWidth=0,this._rowHeaderWidth=0,this._columnHeaderHeight=0,this._worksheetData=null,this._cellData=null,this._styles=null}};exports.SheetSkeleton=yE([Or(2,je.Inject(sn)),Or(3,yn),Or(4,_i),Or(5,je.Inject(je.Injector))],exports.SheetSkeleton);function Ii(e,t,n,r){const s=e-1,i=t-1,o=n[s]||0;let a=n[e];a==null&&(a=n[n.length-1]);const l=r[i]||0;let u=r[t];return u==null&&(u=r[r.length-1]),{startY:o,endY:a,startX:l,endX:u}}function AE(e,t,n,r){return Ii(e,t,n,r)}function _n(e,t,n,r,s){e=re.clamp(e,0,n.length-1),t=re.clamp(t,0,r.length-1);let{startY:i,endY:o,startX:a,endX:l}=Ii(e,t,n,r);if(!s)return{startY:i,endY:o,startX:a,endX:l,isMerged:!1,isMergedMainCell:!1,actualRow:e,actualColumn:t,mergeInfo:{startY:i,endY:o,startX:a,endX:l,startRow:e,startColumn:t,endRow:e,endColumn:t}};const{isMerged:u,isMergedMainCell:c,startRow:h,startColumn:d,endRow:f,endColumn:E}=s;let R={startRow:h,startColumn:d,endRow:f,endColumn:E,startY:i,endY:o,startX:a,endX:l};const w=n.length-1,L=r.length-1;if(u&&h!==-1&&d!==-1){const J=n[h-1]||0,z=n[f]||n[w],de=r[d-1]||0,N=r[E]||r[L];R={...R,startY:J,endY:z,startX:de,endX:N}}else if(!u&&f!==-1&&E!==-1){const J=n[f]||n[w],z=r[E]||r[L];R={...R,startY:i,endY:J,startX:a,endX:z}}return{isMerged:u,isMergedMainCell:c,actualRow:e,actualColumn:t,startY:i,endY:o,startX:a,endX:l,mergeInfo:R}}function Gu(e,t,n,r){const{x:s}=n;return e/t+s-r}function Ku(e,t,n,r){const{y:s}=n;return e=e/t+s-r,e}const No=[Int8Array,Uint8Array,Uint8ClampedArray,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array],Is=1,xn=8;class Si{static from(t){if(!(t instanceof ArrayBuffer))throw new Error("Data must be an instance of ArrayBuffer.");const[n,r]=new Uint8Array(t,0,2);if(n!==219)throw new Error("Data does not appear to be in a KDBush format.");const s=r>>4;if(s!==Is)throw new Error(`Got v${s} data when expected v${Is}.`);const i=No[r&15];if(!i)throw new Error("Unrecognized array type.");const[o]=new Uint16Array(t,2,1),[a]=new Uint32Array(t,4,1);return new Si(a,o,i,t)}constructor(t,n=64,r=Float64Array,s){if(isNaN(t)||t<0)throw new Error(`Unpexpected numItems value: ${t}.`);this.numItems=+t,this.nodeSize=Math.min(Math.max(+n,2),65535),this.ArrayType=r,this.IndexArrayType=t<65536?Uint16Array:Uint32Array;const i=No.indexOf(this.ArrayType),o=t*2*this.ArrayType.BYTES_PER_ELEMENT,a=t*this.IndexArrayType.BYTES_PER_ELEMENT,l=(8-a%8)%8;if(i<0)throw new Error(`Unexpected typed array class: ${r}.`);s&&s instanceof ArrayBuffer?(this.data=s,this.ids=new this.IndexArrayType(this.data,xn,t),this.coords=new this.ArrayType(this.data,xn+a+l,t*2),this._pos=t*2,this._finished=!0):(this.data=new ArrayBuffer(xn+o+a+l),this.ids=new this.IndexArrayType(this.data,xn,t),this.coords=new this.ArrayType(this.data,xn+a+l,t*2),this._pos=0,this._finished=!1,new Uint8Array(this.data,0,2).set([219,(Is<<4)+i]),new Uint16Array(this.data,2,1)[0]=n,new Uint32Array(this.data,4,1)[0]=t)}add(t,n){const r=this._pos>>1;return this.ids[r]=r,this.coords[this._pos++]=t,this.coords[this._pos++]=n,r}finish(){const t=this._pos>>1;if(t!==this.numItems)throw new Error(`Added ${t} items when expected ${this.numItems}.`);return Vs(this.ids,this.coords,this.nodeSize,0,this.numItems-1,0),this._finished=!0,this}range(t,n,r,s){if(!this._finished)throw new Error("Data not yet indexed - call index.finish().");const{ids:i,coords:o,nodeSize:a}=this,l=[0,i.length-1,0],u=[];for(;l.length;){const c=l.pop()||0,h=l.pop()||0,d=l.pop()||0;if(h-d<=a){for(let w=d;w<=h;w++){const L=o[2*w],J=o[2*w+1];L>=t&&L<=r&&J>=n&&J<=s&&u.push(i[w])}continue}const f=d+h>>1,E=o[2*f],R=o[2*f+1];E>=t&&E<=r&&R>=n&&R<=s&&u.push(i[f]),(c===0?t<=E:n<=R)&&(l.push(d),l.push(f-1),l.push(1-c)),(c===0?r>=E:s>=R)&&(l.push(f+1),l.push(h),l.push(1-c))}return u}within(t,n,r){if(!this._finished)throw new Error("Data not yet indexed - call index.finish().");const{ids:s,coords:i,nodeSize:o}=this,a=[0,s.length-1,0],l=[],u=r*r;for(;a.length;){const c=a.pop()||0,h=a.pop()||0,d=a.pop()||0;if(h-d<=o){for(let w=d;w<=h;w++)Mo(i[2*w],i[2*w+1],t,n)<=u&&l.push(s[w]);continue}const f=d+h>>1,E=i[2*f],R=i[2*f+1];Mo(E,R,t,n)<=u&&l.push(s[f]),(c===0?t-r<=E:n-r<=R)&&(a.push(d),a.push(f-1),a.push(1-c)),(c===0?t+r>=E:n+r>=R)&&(a.push(f+1),a.push(h),a.push(1-c))}return l}}function Vs(e,t,n,r,s,i){if(s-r<=n)return;const o=r+s>>1;Xu(e,t,o,r,s,i),Vs(e,t,n,r,o-1,1-i),Vs(e,t,n,o+1,s,1-i)}function Xu(e,t,n,r,s,i){for(;s>r;){if(s-r>600){const u=s-r+1,c=n-r+1,h=Math.log(u),d=.5*Math.exp(2*h/3),f=.5*Math.sqrt(h*d*(u-d)/u)*(c-u/2<0?-1:1),E=Math.max(r,Math.floor(n-c*d/u+f)),R=Math.min(s,Math.floor(n+(u-c)*d/u+f));Xu(e,t,n,E,R,i)}const o=t[2*n+i];let a=r,l=s;for(Un(e,t,r,n),t[2*s+i]>o&&Un(e,t,r,s);a<l;){for(Un(e,t,a,l),a++,l--;t[2*a+i]<o;)a++;for(;t[2*l+i]>o;)l--}t[2*r+i]===o?Un(e,t,r,l):(l++,Un(e,t,l,s)),l<=n&&(r=l+1),n<=l&&(s=l-1)}}function Un(e,t,n,r){Ss(e,n,r),Ss(t,2*n,2*r),Ss(t,2*n+1,2*r+1)}function Ss(e,t,n){const r=e[t];e[t]=e[n],e[n]=r}function Mo(e,t,n,r){const s=e-n,i=t-r;return s*s+i*i}class TE{constructor(t=!1){C(this,"_tree",new Map);C(this,"_oneCellCache",new Map);C(this,"_kdTree",new Map);this._enableOneCellCache=t}dispose(){this.clear()}getTree(t,n){return this._tree.has(t)||this._tree.set(t,new Map),this._tree.get(t).has(n)||this._tree.get(t).set(n,new jr),this._tree.get(t).get(n)}_getOneCellCache(t,n,r,s){return this._oneCellCache.has(t)||this._oneCellCache.set(t,new Map),this._oneCellCache.get(t).has(n)||this._oneCellCache.get(t).set(n,new Map),this._oneCellCache.get(t).get(n).has(r)||this._oneCellCache.get(t).get(n).set(r,new Map),this._oneCellCache.get(t).get(n).get(r).has(s)||this._oneCellCache.get(t).get(n).get(r).set(s,new Set),this._oneCellCache.get(t).get(n).get(r).get(s)}_removeOneCellCache(t,n,r,s,i){const o=this._oneCellCache.get(t);if(!o)return;const a=o.get(n);if(!a)return;const l=a.get(r);if(!l)return;const u=l.get(s);u&&u.delete(i)}_removeCellCacheByRange(t){const{unitId:n,sheetId:r,range:s,id:i}=t,o=this._oneCellCache.get(n);if(!o)return;const a=o.get(r);if(!a)return;const{startRow:l,startColumn:u,endRow:c,endColumn:h}=s;for(let d=l;d<=c;d++){const f=a.get(d);if(f)for(let E=u;E<=h;E++){const R=f.get(E);R&&R.delete(i)}}}_insertOneCellCache(t,n,r,s,i){this._getOneCellCache(t,n,r,s).add(i)}_getRdTreeItems(t){const n=[];for(const[r,s]of t)for(const[i,o]of s)n.push({x:i,y:r,ids:o});return n}_searchByOneCellCache(t){var E;const{unitId:n,sheetId:r,range:s}=t,{startRow:i,startColumn:o,endRow:a,endColumn:l}=s,u=(E=this._kdTree.get(n))==null?void 0:E.get(r);if(!u)return[];const{tree:c,items:h}=u,d=c.range(o,i,l,a),f=[];for(const R of d){const w=h[R];f.push(...Array.from(w.ids))}return f}openKdTree(){var t;for(const[n,r]of this._oneCellCache){this._kdTree.has(n)||this._kdTree.set(n,new Map);for(const[s,i]of r){const o=this._getRdTreeItems(i),a=new Si(o.length);(t=this._kdTree.get(n))==null||t.set(s,{tree:a,items:o});for(const l of o)a.add(l.x,l.y);a.finish()}}}closeKdTree(){var t;for(const[n,r]of this._oneCellCache)for(const[s,i]of r)(t=this._kdTree.get(n))==null||t.set(s,void 0)}insert(t){const{unitId:n,sheetId:r,range:s,id:i}=t;if(!n||n.length===0)return;let{startRow:o,endRow:a,startColumn:l,endColumn:u}=s;if(this._enableOneCellCache&&o===a&&l===u){this._insertOneCellCache(n,r,o,l,i);return}const c=this.getTree(n,r);Number.isNaN(o)&&(o=0),Number.isNaN(l)&&(l=0),Number.isNaN(a)&&(a=Number.POSITIVE_INFINITY),Number.isNaN(u)&&(u=Number.POSITIVE_INFINITY),c.insert({minX:l,minY:o,maxX:u,maxY:a,id:i})}bulkInsert(t){for(const n of t)this.insert(n)}*searchGenerator(t){var a;const{unitId:n,sheetId:r,range:s}=t;if(this._enableOneCellCache){const l=this._searchByOneCellCache(t);for(const u of l)yield u}const i=(a=this._tree.get(n))==null?void 0:a.get(r);if(!i)return;const o=i.search({minX:s.startColumn,minY:s.startRow,maxX:s.endColumn,maxY:s.endRow});for(const l of o)yield l.id}bulkSearch(t,n){const r=new Set;for(const s of t)for(const i of this.searchGenerator(s))(n==null?void 0:n.has(i))!==!0&&r.add(i);return r}removeById(t,n){var r,s;n?((r=this._tree.get(t))==null||r.delete(n),(s=this._oneCellCache.get(t))==null||s.delete(n)):(this._tree.delete(t),this._oneCellCache.delete(t))}_removeRTreeItem(t){const{unitId:n,sheetId:r,range:s,id:i}=t,o=this.getTree(n,r),a=o.search({minX:s.startColumn,minY:s.startRow,maxX:s.endColumn,maxY:s.endRow});for(let l=0;l<a.length;l++)a[l].id===i&&o.remove(a[l])}remove(t){const{unitId:n,sheetId:r,range:s,id:i}=t,{startRow:o,startColumn:a,endRow:l,endColumn:u}=s;this._enableOneCellCache?o===l&&a===u?this._removeOneCellCache(n,r,s.startRow,s.startColumn,i):(this._removeCellCacheByRange(t),this._removeRTreeItem(t)):this._removeRTreeItem(t)}bulkRemove(t){for(const n of t)this.remove(n)}clear(){this._tree.clear(),this._oneCellCache.clear()}toJSON(){const t={};return this._tree.forEach((n,r)=>{t[r]={},n.forEach((s,i)=>{t[r][i]=s.toJSON()})}),t}fromJSON(t){this._tree.clear();for(const n in t){this._tree.set(n,new Map);for(const r in t[n]){const s=new jr;s.fromJSON(t[n][r]),this._tree.get(n).set(r,s)}}}}var NE=Object.getOwnPropertyDescriptor,ME=(e,t,n,r)=>{for(var s=r>1?void 0:r?NE(t,n):t,i=e.length-1,o;i>=0;i--)(o=e[i])&&(s=o(s)||s);return s},Do=(e,t)=>(n,r)=>t(n,r,e);let Gs=class extends rt{constructor(e,t){super(),this._resourceManagerService=e,this._univerInstanceService=t,this._init()}_init(){const e=n=>{n.businesses.forEach(r=>{switch(r){case $e.UNRECOGNIZED:case $e.UNIVER_UNKNOWN:case $e.UNIVER_SLIDE:case $e.UNIVER_DOC:{this._univerInstanceService.getAllUnitsForType($e.UNIVER_DOC).forEach(s=>{const o=(s.getSnapshot().resources||[]).find(a=>a.name===n.pluginName);if(o)try{const a=n.parseJson(o.data);n.onLoad(s.getUnitId(),a)}catch{console.error(`Load Document{${s.getUnitId()}} Resources{${n.pluginName}} Data Error.`)}});break}case $e.UNIVER_SHEET:this._univerInstanceService.getAllUnitsForType($e.UNIVER_SHEET).forEach(s=>{const o=(s.getSnapshot().resources||[]).find(a=>a.name===n.pluginName);if(o)try{const a=n.parseJson(o.data);n.onLoad(s.getUnitId(),a)}catch{console.error(`Load Workbook{${s.getUnitId()}} Resources{${n.pluginName}} Data Error.`)}})}})};this._resourceManagerService.getAllResourceHooks().forEach(n=>e(n)),this.disposeWithMe(this._resourceManagerService.register$.subscribe(n=>e(n))),this.disposeWithMe(this._univerInstanceService.getTypeOfUnitAdded$($e.UNIVER_SHEET).subscribe(n=>{this._resourceManagerService.loadResources(n.getUnitId(),n.getSnapshot().resources)})),this.disposeWithMe(this._univerInstanceService.getTypeOfUnitAdded$($e.UNIVER_DOC).subscribe(n=>{const r=n.getUnitId();ya(r)||this._resourceManagerService.loadResources(n.getUnitId(),n.getSnapshot().resources)})),this.disposeWithMe(this._univerInstanceService.getTypeOfUnitDisposed$($e.UNIVER_SHEET).subscribe(n=>{this._resourceManagerService.unloadResources(n.getUnitId())})),this.disposeWithMe(this._univerInstanceService.getTypeOfUnitDisposed$($e.UNIVER_DOC).subscribe(n=>{this._resourceManagerService.unloadResources(n.getUnitId())}))}saveUnit(e){const t=this._univerInstanceService.getUnit(e);if(!t)return null;const n=this._resourceManagerService.getResources(e,t.type),r=re.deepClone(t.getSnapshot());return r.resources=n,r}};Gs=ME([Do(0,je.Inject(ss)),Do(1,je.Inject(bn))],Gs);class DE{constructor(t={},n){C(this,"_startedTypes",new Set);C(this,"_injector");C(this,"_disposingCallbacks",new Gr);const r=this._injector=LE(n,t==null?void 0:t.override),{theme:s,locale:i,locales:o,logLevel:a}=t;s&&this._injector.get(Ci).setTheme(s),o&&this._injector.get(sn).load(o),i&&this._injector.get(sn).setLocale(i),a&&this._injector.get(vt).setLogLevel(a),this._init(r)}get _univerInstanceService(){return this._injector.get(bn)}get _pluginService(){return this._injector.get(exports.PluginService)}__getInjector(){return this._injector}onDispose(t){const n=this._disposingCallbacks.add(nt(t));return nt(()=>n.dispose(!0))}dispose(){this._disposingCallbacks.dispose(),this._injector.dispose()}setLocale(t){this._injector.get(sn).setLocale(t)}createUnit(t,n){return this._univerInstanceService.createUnit(t,n)}createUniverSheet(t){return this._injector.get(vt).warn("[Univer]","Univer.createUniverSheet is deprecated, use createUnit instead"),this._univerInstanceService.createUnit($e.UNIVER_SHEET,t)}createUniverDoc(t){return this._injector.get(vt).warn("[Univer]","Univer.createUniverDoc is deprecated, use createUnit instead"),this._univerInstanceService.createUnit($e.UNIVER_DOC,t)}createUniverSlide(t){return this._injector.get(vt).warn("[Univer]","Univer.createUniverSlide is deprecated, use createUnit instead"),this._univerInstanceService.createUnit($e.UNIVER_SLIDE,t)}_init(t){this._univerInstanceService.registerCtorForType($e.UNIVER_SHEET,exports.Workbook),this._univerInstanceService.registerCtorForType($e.UNIVER_DOC,yt),this._univerInstanceService.registerCtorForType($e.UNIVER_SLIDE,pi);const n=t.get(bn);n.__setCreateHandler((r,s,i,o)=>{if(!this._startedTypes.has(r)){this._pluginService.startPluginsForType(r),this._startedTypes.add(r);const l=t.createInstance(i,s);return n.__addUnit(l,o),this._tryProgressToReady(),l}const a=t.createInstance(i,s);return n.__addUnit(a,o),a})}_tryProgressToReady(){this._injector.get(exports.LifecycleService).stage<Je.Ready&&(this._injector.get(exports.LifecycleService).stage=Je.Ready)}registerPlugin(t,n){this._pluginService.registerPlugin(t,n)}}function LE(e,t){const n=Du([[gu],[sn],[Ci],[exports.LifecycleService],[exports.PluginService],[Zn],[bn,{useClass:exports.UniverInstanceService}],[Tu,{useClass:Nu}],[vt,{useClass:Bo,lazy:!0}],[nr,{useClass:exports.CommandService}],[is,{useClass:exports.LocalUndoRedoService,lazy:!0}],[_i,{useClass:hu}],[yn,{useClass:Fo}],[ss,{useClass:Lu,lazy:!0}],[Ys,{useClass:Gs,lazy:!0}],[uu,{useClass:exports.AuthzIoLocalService}],[cu,{useClass:exports.MentionIOLocalService,lazy:!0}]],t),r=e?e.createChild(n):new je.Injector(n);return Uo(r,[[Zn],[Ys]]),r}ec();exports.ABCToNumber=$d;exports.AUTO_HEIGHT_FOR_MERGED_CELLS=ba;exports.AbsoluteRefType=tt;exports.ActionIterator=mn;exports.AlignTypeH=rl;exports.AlignTypeV=sl;exports.ArrangeTypeEnum=al;exports.ArrowsAndMarkersShapes=ra;exports.AsyncInterceptorManager=dp;exports.AutoFillSeries=Vo;exports.BaselineOffset=xt;exports.BasicShapes=na;exports.BlockType=ka;exports.BooleanNumber=Ie;exports.BorderStyleTypes=Xe;exports.BorderType=Go;exports.BuildTextUtils=it;exports.BulletAlignment=or;exports.COLORS=ys;exports.CanceledError=ac;exports.CellModeEnum=pn;exports.CellValueType=Vt;exports.Color=an;exports.ColorBuilder=qr;exports.ColorKit=St;exports.ColorType=pt;exports.ColumnSeparatorType=$a;exports.CommandType=tr;exports.CommonHideTypes=Ko;exports.ConfigService=hu;exports.ContextService=Fo;exports.CopyPasteType=Xo;exports.CustomCommandExecutionError=vs;exports.CustomDecorationType=nn;exports.CustomRangeType=qt;exports.DEFAULT_CELL=Rd;exports.DEFAULT_DOC=fi;exports.DEFAULT_DOCUMENT_SUB_COMPONENT_ID=Ep;exports.DEFAULT_EMPTY_DOCUMENT_VALUE=Oa;exports.DEFAULT_RANGE=Ed;exports.DEFAULT_RANGE_ARRAY=pd;exports.DEFAULT_SELECTION=Cd;exports.DEFAULT_SLIDE=Aa;exports.DEFAULT_STYLES=lt;exports.DEFAULT_WORKSHEET_COLUMN_COUNT=Ru;exports.DEFAULT_WORKSHEET_COLUMN_COUNT_KEY=Gp;exports.DEFAULT_WORKSHEET_COLUMN_TITLE_HEIGHT=Ou;exports.DEFAULT_WORKSHEET_COLUMN_TITLE_HEIGHT_KEY=Jp;exports.DEFAULT_WORKSHEET_COLUMN_WIDTH=Su;exports.DEFAULT_WORKSHEET_COLUMN_WIDTH_KEY=Xp;exports.DEFAULT_WORKSHEET_ROW_COUNT=Cu;exports.DEFAULT_WORKSHEET_ROW_COUNT_KEY=Vp;exports.DEFAULT_WORKSHEET_ROW_HEIGHT=Iu;exports.DEFAULT_WORKSHEET_ROW_HEIGHT_KEY=Kp;exports.DEFAULT_WORKSHEET_ROW_TITLE_WIDTH=vu;exports.DEFAULT_WORKSHEET_ROW_TITLE_WIDTH_KEY=qp;exports.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY=Js;exports.DOCS_NORMAL_EDITOR_UNIT_ID_KEY=qs;exports.DOCS_ZEN_EDITOR_UNIT_ID_KEY=va;exports.DOC_RANGE_TYPE=_a;exports.DashStyleType=Va;exports.DataStreamTreeNodeType=hl;exports.DataStreamTreeTokenType=jt;exports.DataValidationErrorStyle=Hu;exports.DataValidationImeMode=ju;exports.DataValidationOperator=Wu;exports.DataValidationRenderMode=Yu;exports.DataValidationStatus=zu;exports.DataValidationType=Vu;exports.DeleteDirection=qo;exports.DependentOn=mE;exports.DesktopLogService=Bo;exports.DeveloperMetadataVisibility=Jo;exports.Dimension=Zo;exports.Direction=Qo;exports.Disposable=rt;exports.DisposableCollection=Gr;exports.DocStyleType=xa;exports.DocumentDataModel=yt;exports.DocumentFlavor=Qs;exports.DrawingTypeEnum=ll;exports.EDITOR_ACTIVATED=du;exports.EXTENSION_NAMES=Ta;exports.ErrorService=gu;exports.EventState=lu;exports.EventSubject=Cp;exports.FOCUSING_COMMON_DRAWINGS=Lp;exports.FOCUSING_DOC=jn;exports.FOCUSING_EDITOR_BUT_HIDDEN=yp;exports.FOCUSING_EDITOR_INPUT_FORMULA=Ap;exports.FOCUSING_EDITOR_STANDALONE=Np;exports.FOCUSING_FX_BAR_EDITOR=fu;exports.FOCUSING_PANEL_EDITOR=Mp;exports.FOCUSING_SHEET=Rn;exports.FOCUSING_SLIDE=Wn;exports.FOCUSING_UNIT=Hn;exports.FOCUSING_UNIVER_EDITOR=Tp;exports.FOCUSING_UNIVER_EDITOR_STANDALONE_SINGLE_MODE=Dp;exports.FORMULA_EDITOR_ACTIVATED=xp;exports.FollowNumberWithType=Ua;exports.FontItalic=Fr;exports.FontStyleType=En;exports.FontWeight=$r;exports.GridType=Pa;exports.HLSColor=fa;exports.HorizontalAlign=Ot;exports.IAuthzIoService=uu;exports.ICommandService=nr;exports.IConfigService=_i;exports.IContextService=yn;exports.IImageIoService=zs;exports.ILocalStorageService=cE;exports.ILogService=vt;exports.IMentionIOService=cu;exports.IPermissionService=Tu;exports.IResourceLoaderService=Ys;exports.IResourceManagerService=ss;exports.IS_ROW_STYLE_PRECEDE_COLUMN_STYLE=wa;exports.IUndoRedoService=is;exports.IUniverInstanceService=bn;exports.ImageCacheMap=Bu;exports.ImageSourceType=Ri;exports.ImageUploadStatusType=$u;exports.InterceptorEffectEnum=Cn;exports.InterceptorManager=up;exports.InterpolationPointType=ea;exports.JSON1=a_;exports.JSONX=kt;exports.LRUHelper=Fn;exports.LRUMap=Xn;exports.LifecycleStages=Je;exports.ListGlyphType=Ne;exports.LocaleService=sn;exports.LocaleType=rr;exports.LogLevel=$o;exports.MOVE_BUFFER_VALUE=Pn;exports.MemoryCursor=Nn;exports.MentionType=Pr;exports.NamedStyleType=Ya;exports.NilCommand=Ho;exports.NumberUnitType=nl;exports.ObjectMatrix=wt;exports.ObjectRelativeFromH=el;exports.ObjectRelativeFromV=tl;exports.OtherShapes=sa;exports.PRESET_LIST_TYPE=ur;exports.PageElementType=ul;exports.PageOrientType=ol;exports.PageType=ei;exports.ParagraphElementType=Ha;exports.ParagraphStyleBuilder=Jn;exports.ParagraphStyleValue=hr;exports.PermissionService=Nu;exports.PermissionStatus=Ei;exports.Plugin=Ws;exports.PositionedObjectLayoutType=Wa;exports.PresetListType=Mt;exports.ProtectionType=ta;exports.QuickListType=Gl;exports.QuickListTypeMap=f_;exports.RANGE_DIRECTION=ma;exports.RANGE_TYPE=Le;exports.RBush=jr;exports.RCDisposable=fc;exports.RGBA_PAREN=jc;exports.RGB_PAREN=Hc;exports.ROTATE_BUFFER_VALUE=zo;exports.RTree=TE;exports.Range=vn;exports.Rectangle=Xt;exports.RedoCommand=Fu;exports.RedoCommandId=Uu;exports.RefAlias=Fd;exports.Registry=gi;exports.RegistryAsMap=mi;exports.RelativeDate=oa;exports.RelativeSlideLink=cl;exports.ResourceManagerService=Lu;exports.RgbColor=Br;exports.RichTextBuilder=rn;exports.RichTextValue=zt;exports.RxDisposable=dc;exports.SHEET_EDITOR_UNITS=Id;exports.SectionType=Fa;exports.SheetTypes=aa;exports.SheetViewModel=bu;exports.SliceBodyType=di;exports.SlideDataModel=pi;exports.SpacingRule=za;exports.SpecialShapes=ia;exports.Styles=mu;exports.THEME_COLORS=da;exports.TabStopAlignment=Ga;exports.TableAlignmentType=Xa;exports.TableLayoutType=qa;exports.TableRowHeightRule=Za;exports.TableSizeType=Ka;exports.TableTextWrapType=Ja;exports.TextDecoration=la;exports.TextDecorationBuilder=Yt;exports.TextDirection=Kn;exports.TextDirectionType=Ba;exports.TextStyleBuilder=Kt;exports.TextStyleValue=cr;exports.TextX=Ye;exports.TextXActionType=ce;exports.ThemeColor=Hr;exports.ThemeColorType=dt;exports.ThemeColors=Xr;exports.ThemeService=Ci;exports.Tools=re;exports.UndoCommand=Pu;exports.UndoCommandId=ku;exports.UnitModel=rs;exports.Univer=DE;exports.UniverInstanceType=$e;exports.UpdateDocsAttributeType=ke;exports.UserManagerService=Zn;exports.VerticalAlign=tn;exports.VerticalAlignmentType=Qa;exports.Worksheet=Qn;exports.WrapStrategy=on;exports.WrapTextType=ja;exports.addLinkToDocumentModel=_u;exports.afterInitApply=Sc;exports.afterTime=Ic;exports.awaitTime=RE;exports.binSearchFirstGreaterThanTarget=Yo;exports.binarySearchArray=vc;exports.bufferDebounceTime=Rc;exports.cellToRange=_h;exports.characterSpacingControlType=il;exports.checkForSubstrings=ph;exports.checkIfMove=wc;exports.checkParagraphHasBullet=Qh;exports.checkParagraphHasIndent=ed;exports.checkParagraphHasIndentByStyle=Ra;exports.codeToBlob=Oc;exports.composeBody=Bs;exports.composeInterceptors=ou;exports.composeStyles=ws;exports.concatMatrixArray=dd;exports.convertBodyToHtml=Bc;exports.convertCellToRange=pa;exports.covertTextRunToHtml=bs;exports.createAsyncInterceptorKey=cp;exports.createDefaultUser=Vr;exports.createDocumentModelWithStyle=Yn;exports.createInterceptorKey=lp;exports.createInternalEditorID=_d;exports.createRowColIter=Ds;exports.dayjs=Pt;exports.debounce=jm;exports.dedupe=tc;exports.deepCompare=Xs;exports.delayAnimationFrame=IE;exports.deleteContent=Sa;exports.extractPureTextFromCell=yu;exports.fromCallback=jo;exports.fromEventSubject=Rp;exports.fromObservable=hc;exports.generateRandomId=Ut;exports.get=Cm;exports.getArrayLength=Gt;exports.getBodySlice=bt;exports.getBodySliceHtml=br;exports.getBorderStyleType=fh;exports.getCellCoordByIndexSimple=Ii;exports.getCellInfoInMergeData=ah;exports.getCellPositionByIndexSimple=AE;exports.getCellValueType=rh;exports.getCellWithCoordByIndexCore=_n;exports.getColorStyle=Tt;exports.getCustomBlockSlice=Jl;exports.getCustomDecorationSlice=Ql;exports.getCustomRangeSlice=Zl;exports.getDocsUpdateBody=gh;exports.getIntersectRange=Ma;exports.getOriginCellValue=Qp;exports.getParagraphsSlice=ql;exports.getPlainText=Zr;exports.getReverseDirection=bc;exports.getSectionBreakSlice=S_;exports.getTableSlice=Xl;exports.getTextRunSlice=zr;exports.getTransformOffsetX=Gu;exports.getTransformOffsetY=Ku;exports.getWorksheetUID=rE;exports.groupBy=sc;exports.handleStyleToString=dh;exports.hashAlgorithm=nd;exports.horizontalLineSegmentsSubtraction=Jr;exports.insertMatrixArray=Ts;exports.insertTextToContent=Ia;exports.isBlackColor=eh;exports.isBooleanString=Zm;exports.isCellCoverable=As;exports.isCellV=ih;exports.isEmptyCell=Ea;exports.isFormulaId=hh;exports.isFormulaString=ch;exports.isICellData=nh;exports.isInternalEditorID=ya;exports.isNodeEnv=$c;exports.isNotNullOrUndefined=pu;exports.isNullCell=sh;exports.isNumeric=au;exports.isRangesEqual=Fp;exports.isRealNum=td;exports.isSafeNumeric=gp;exports.isSameStyleTextRun=Ca;exports.isUnitRangesEqual=$p;exports.isValidRange=mh;exports.isWhiteColor=th;exports.makeArray=ic;exports.makeCellRangeToRangeData=uh;exports.makeCellToSelection=lh;exports.makeCustomRangeStream=zd;exports.merge=li;exports.mergeOverrideWithDependencies=Du;exports.mergeSets=_p;exports.mergeWith=Vm;exports.mergeWorksheetSnapshotWithDefault=wu;exports.mixinClass=fp;exports.moveMatrixArray=Ms;exports.moveRangeByOffset=Ad;exports.nameCharacterCheck=CE;exports.normalizeBody=v_;exports.normalizeTextRuns=lr;exports.numberToABC=Hd;exports.numberToListABC=jd;exports.numfmt=hd;exports.queryObjectMatrix=Pd;exports.registerDependencies=oc;exports.remove=er;exports.repeatStringNumTimes=La;exports.replaceInDocumentBody=pp;exports.requestImmediateMacroTask=mp;exports.rotate=rc;exports.searchArray=kn;exports.searchInOrderedArray=Wo;exports.selectionToArray=oh;exports.sequence=Po;exports.sequenceAsync=ko;exports.sequenceExecute=Kr;exports.sequenceExecuteAsync=Cc;exports.set=Km;exports.shallowEqual=Dl;exports.skipParseTagNames=SE;exports.sliceMatrixArray=fd;exports.sortRules=Wd;exports.sortRulesByDesc=Yd;exports.sortRulesFactory=ir;exports.spliceArray=Ns;exports.splitIntoGrid=Zs;exports.takeAfter=Os;exports.textDiff=ui;exports.throttle=ap;exports.toDisposable=nt;exports.touchDependencies=Uo;exports.updateAttributeByDelete=eu;exports.updateAttributeByInsert=tu;Object.keys(je).forEach(e=>{e!=="default"&&!Object.prototype.hasOwnProperty.call(exports,e)&&Object.defineProperty(exports,e,{enumerable:!0,get:()=>je[e]})});
10
+ `,customBlocks:[],customRanges:[],paragraphs:[{startIndex:0}],textRuns:[],tables:[],sectionBreaks:[]}})}static create(n){return new rn(n!=null?n:rn.newEmptyData())}insertText(n,r,s){var c,h;let i=((h=(c=this._data.body)==null?void 0:c.dataStream.length)!=null?h:2)-2,o,a;if(typeof n=="string"?o=n:(i=Math.min(n,i),o=r),typeof r=="object"?a=r instanceof Kt?r.build():r:a=s instanceof Kt?s.build():s,!o)return this;const l={dataStream:o,textRuns:a?[{ts:a,st:i,ed:i+o.length}]:[]},u=it.selection.replace({doc:this._doc,selection:{startOffset:i,endOffset:i,collapsed:!0},body:l});if(!u)throw new Error("Insert text failed, please check.");return Ye.apply(this._doc.getBody(),u.serialize()),this}insertRichText(n,r){var a,l;let s=((l=(a=this._data.body)==null?void 0:a.dataStream.length)!=null?l:2)-2,i;typeof n=="object"?i=n instanceof zt?n.getData():n:(s=Math.min(n,s),i=r instanceof zt?r.getData():r);const o=it.selection.replace({doc:this._doc,selection:{startOffset:s,endOffset:s,collapsed:!0},body:i.body});if(!o)throw new Error("Insert text failed, please check.");return Ye.apply(this._doc.getBody(),o.serialize()),this}delete(n,r){if(r!==void 0){if(!r)return this;const s=it.selection.delete([{startOffset:n,endOffset:n+r,collapsed:!0}],this._data.body);Ye.apply(this._doc.getBody(),s)}return this}setStyle(n,r,s){const i={dataStream:"",textRuns:[{ts:s instanceof Kt?s.build():s,st:0,ed:r-n}]},o=it.selection.retain([{startOffset:n,endOffset:r,collapsed:!0}],i);return Ye.apply(this._doc.getBody(),o),this}setLink(n,r,s){const i=it.customRange.add({rangeType:qt.HYPERLINK,rangeId:Ut(),properties:{url:s},ranges:[{startOffset:n,endOffset:r,collapsed:!1}],body:this._data.body});if(!i)throw new Error("Insert text failed, please check.");return Ye.apply(this._doc.getBody(),i.serialize()),this}cancelLink(n,r){if(typeof n=="string"){const s=it.customRange.delete({rangeId:n,documentDataModel:this._doc});if(!s)throw new Error("Insert text failed, please check.");Ye.apply(this._doc.getBody(),s.serialize())}else this.slice(n,r).getLinks().forEach(i=>{const o=it.customRange.delete({rangeId:i.rangeId,documentDataModel:this._doc});if(!o)throw new Error("Insert text failed, please check.");Ye.apply(this._doc.getBody(),o.serialize())});return this}updateLink(n,r){var i,o;const s=(o=(i=this._data.body)==null?void 0:i.customRanges)==null?void 0:o.find(a=>a.rangeId===n);if(!s)throw new Error("Link not found");return s.properties.url=r,this}insertParagraph(n,r){var o,a;let s,i;return typeof n=="object"?(s={dataStream:"\r",paragraphs:[{startIndex:0,paragraphStyle:n.build()}]},i=((a=(o=this._data.body)==null?void 0:o.dataStream.length)!=null?a:2)-2):(i=n,s={dataStream:"\r",paragraphs:[{startIndex:0,paragraphStyle:r==null?void 0:r.build()}]}),this.insertRichText(i,zt.create({body:s,id:"d",documentStyle:{}})),this}insertLink(n,r,s){let i="",o="";typeof n=="string"?(i=n,o=r):(i=r,o=s);const a=rn.createByBody({dataStream:i,customRanges:[{rangeType:qt.HYPERLINK,rangeId:Ut(),properties:{url:o},startIndex:0,endIndex:i.length-1}]});return typeof n=="number"?this.insertRichText(n,a):this.insertRichText(a)}}function ap(e,t=16){let n=0,r=null;return function(...i){const o=Date.now();o-n<t?(r&&clearTimeout(r),r=setTimeout(()=>{n=o,e.apply(this,i)},t)):(n=o,e.apply(this,i))}}var Cn=(e=>(e[e.Style=1]="Style",e[e.Value=2]="Value",e))(Cn||{});function lp(e){return`sheet_interceptor_${e}`}const ou=e=>function(t,n){let r=-1,s=t;for(let i=0;i<=e.length;i++){if(i<=r)throw new Error("[SheetInterceptorService]: next() called multiple times!");if(r=i,i===e.length)return s;const o=e[i];let a=!1;if(s=o.handler(s,n,l=>(a=!0,l)),!a)break}return s};class up{constructor(t){C(this,"_interceptorsByName",new Map);C(this,"_interceptorPoints");this._interceptorPoints=t}fetchThroughInterceptors(t,n){const r=t;let s=this._interceptorsByName.get(r);return n&&(s=s.filter(n)),ou(s||[])}intercept(t,n){const r=t;this._interceptorsByName.has(r)||this._interceptorsByName.set(r,[]);const s=this._interceptorsByName.get(r);return s.push(n),this._interceptorsByName.set(r,s.sort((i,o)=>{var a,l;return((a=o.priority)!=null?a:0)-((l=i.priority)!=null?l:0)})),()=>er(this._interceptorsByName.get(r),n)}getInterceptPoints(){return this._interceptorPoints}dispose(){this._interceptorsByName.clear()}}function cp(e){return`sheet_async_interceptor_${e}`}const hp=e=>async function(t,n){let r=-1,s=t;for(let i=0;i<=e.length;i++){if(i<=r)throw new Error("[SheetInterceptorService]: next() called multiple times!");if(r=i,i===e.length)return s;const o=e[i];let a=!1;if(s=await o.handler(s,n,async l=>(a=!0,l)),!a)break}return s};class dp{constructor(t){C(this,"_asyncInterceptorsByName",new Map);C(this,"_asyncInterceptorPoints");this._asyncInterceptorPoints=t}fetchThroughAsyncInterceptors(t,n){const r=t;let s=this._asyncInterceptorsByName.get(r);return n&&(s=s.filter(n)),hp(s||[])}async interceptAsync(t,n){const r=t;this._asyncInterceptorsByName.has(r)||this._asyncInterceptorsByName.set(r,[]);const s=this._asyncInterceptorsByName.get(r);return s.push(n),this._asyncInterceptorsByName.set(r,s.sort((i,o)=>{var a,l;return((a=o.priority)!=null?a:0)-((l=i.priority)!=null?l:0)})),()=>er(this._asyncInterceptorsByName.get(r),n)}getInterceptPoints(){return this._asyncInterceptorPoints}dispose(){this._asyncInterceptorsByName.clear()}}function fp(e,t){for(const n in t)t.hasOwnProperty(n)&&(e[n]=t[n])}function au(e){return/^-?\d+(\.\d+)?$/.test(e)}function gp(e){return au(e)?Number(e)<=Number.MAX_SAFE_INTEGER:!1}class gi{constructor(){C(this,"_data",[])}static create(){return new gi}add(t){this._data.indexOf(t)>-1||this._data.push(t)}delete(t){const n=this._data.indexOf(t);this._data.splice(n,1)}getData(){return this._data}}class mi{constructor(){C(this,"_data",new Map)}static create(){return new mi}add(t,n){this._data.has(t)||this._data.set(t,n)}delete(t){this._data.delete(t)}getData(){return this._data}}function mp(e){const t=new MessageChannel;let n=!1;const r=()=>{n||e()};return t.port1.onmessage=r,t.port2.postMessage(null),()=>{n=!0,t.port1.onmessage=null,t.port1.close(),t.port2.close()}}function _p(e,t){return t.forEach(n=>e.add(n)),e}function pp(e,t,n,r){var u;if(t==="")return e;const s={id:"mock-id",body:e,documentStyle:{}},i=new yt(s),o=t.length;let a;for(;(a=(r?i.getBody().dataStream:i.getBody().dataStream.toLowerCase()).indexOf(t))>=0;){const c=new Ye,h=kt.getInstance();if(a>0&&c.retain(a),n.length>0){const d=i.sliceBody(a,a+o),f={dataStream:n};if(Array.isArray(d==null?void 0:d.textRuns)&&d.textRuns.length&&(f.textRuns=[{...d.textRuns[0],st:0,ed:n.length}]),(u=d==null?void 0:d.customRanges)!=null&&u.length){const E=d.customRanges[0];f.customRanges=[{...E,startIndex:0,endIndex:n.length-1}]}c.insert(n.length,f)}c.delete(o),i.apply(h.editOp(c.serialize()))}const l=i.getBody();return i.dispose(),l}const Ep="__default_document_sub_component_id20231101__";class lu{constructor(){C(this,"skipNextObservers",!1);C(this,"lastReturnValue");C(this,"isStopPropagation",!1)}stopPropagation(){this.isStopPropagation=!0}}class Cp extends we.Subject{constructor(){super(...arguments);C(this,"_sortedObservers",[])}subscribe(){throw new Error("[EventSubject]: please use `subscribeEvent` instead of `subscribe` method for `EventSubject`.")}next(){throw new Error("[EventSubject]: please use `emitEvent` instead of `next` method for `EventSubject`.")}unsubscribe(){super.unsubscribe(),this._sortedObservers.length=0}complete(){super.complete(),this._sortedObservers.length=0}subscribeEvent(n){let r;typeof n=="function"?r={next:([i,o])=>n(i,o)}:r=n;const s=super.subscribe(r);return this._sortedObservers.push(r),this._sortedObservers.sort((i,o)=>{var a,l;return((a=i.priority)!=null?a:0)-((l=o.priority)!=null?l:0)}),s.add(()=>this._sortedObservers=this._sortedObservers.filter(i=>i!==r)),s}clearObservers(){this._sortedObservers.forEach(n=>{var r;return(r=n.complete)==null?void 0:r.call(n)}),this._sortedObservers.length=0}emitEvent(n){var r;if(!this.closed){const s=new lu;s.lastReturnValue=n;for(const i of this._sortedObservers){const o=(r=i.next)==null?void 0:r.call(i,[n,s]);if(s.lastReturnValue=o,s.skipNextObservers)return{handled:!0,lastReturnValue:s.lastReturnValue,stopPropagation:s.isStopPropagation}}return{handled:this._sortedObservers.length>0,lastReturnValue:s.lastReturnValue,stopPropagation:s.isStopPropagation}}throw new Error("[EventSubject]: cannot emit event on a closed subject.")}}function Rp(e){return new we.Observable(t=>{const n=e.subscribeEvent(r=>{t.next(r)});return()=>n.unsubscribe()})}const ss=je.createIdentifier("core.resource-manager.service"),Hs={[Nt.Editor]:"Editor",[Nt.Owner]:"Owner",[Nt.Reader]:"Reader",[Nt.UNRECOGNIZED]:"UNRECOGNIZED"},Vr=e=>e?{userID:`${Hs[e]}_${re.generateRandomId(8)}`,name:Hs[e],avatar:""}:{userID:"",name:"",avatar:"",anonymous:!0,canBindAnonymous:!1},Ip=(e,t)=>e.startsWith(Hs[t]);class Zn{constructor(){C(this,"_model",new Map);C(this,"_userChange$",new we.Subject);C(this,"userChange$",this._userChange$.asObservable());C(this,"_currentUser$",new we.BehaviorSubject(Vr()));C(this,"currentUser$",this._currentUser$.asObservable())}getCurrentUser(){return this._currentUser$.getValue()}setCurrentUser(t){this.addUser(t),this._currentUser$.next(t)}addUser(t){this._model.set(t.userID,t),this._userChange$.next({type:"add",user:t})}getUser(t,n){const r=this._model.get(t);if(r)return r;n&&n()}delete(t){const n=this.getUser(t);this._model.delete(t),n&&this._userChange$.next({type:"delete",user:n})}clear(){this._model.clear(),this._userChange$.next({type:"clear"})}list(){return Array.from(this._model.values())}}var Sp=Object.getOwnPropertyDescriptor,vp=(e,t,n,r)=>{for(var s=r>1?void 0:r?Sp(t,n):t,i=e.length-1,o;i>=0;i--)(o=e[i])&&(s=o(s)||s);return s},Oo=(e,t)=>(n,r)=>t(n,r,e);exports.AuthzIoLocalService=class{constructor(t,n){C(this,"_permissionMap",new Map([]));this._resourceManagerService=t,this._userManagerService=n,this._initSnapshot(),this._initDefaultUser()}_initDefaultUser(){const t=this._userManagerService.getCurrentUser();t&&t.userID||this._userManagerService.setCurrentUser(Vr(Nt.Owner))}_getRole(t){const n=this._userManagerService.getCurrentUser();return n?Ip(n.userID,t):!1}_initSnapshot(){this._resourceManagerService.registerPluginResource({toJson:t=>{const n=[...this._permissionMap.keys()].reduce((r,s)=>{const i=this._permissionMap.get(s);return r[s]=i,r},{});return JSON.stringify(n)},parseJson:t=>JSON.parse(t),pluginName:"SHEET_AuthzIoMockService_PLUGIN",businesses:[$e.UNIVER_SHEET,$e.UNIVER_DOC,$e.UNIVER_SLIDE],onLoad:(t,n)=>{for(const r in n)this._permissionMap.set(r,n[r])},onUnLoad:()=>{this._permissionMap.clear()}})}async create(t){return Ut(8)}async allowed(t){return Promise.resolve([])}async batchAllowed(t){return Promise.resolve([])}async list(t){const n=[];return t.objectIDs.forEach(r=>{const s=this._permissionMap.get(r);if(s){const i={objectID:r,unitID:t.unitID,objectType:s.objectType,name:s.name,shareOn:!1,shareRole:Nt.Owner,shareScope:-1,scope:{read:ks.AllCollaborator,edit:ks.AllCollaborator},creator:Vr(Nt.Owner),strategies:[{action:6,role:1},{action:16,role:1},{action:17,role:1},{action:18,role:1},{action:19,role:1},{action:33,role:1},{action:34,role:1},{action:35,role:1},{action:36,role:1},{action:37,role:1},{action:38,role:1},{action:39,role:1},{action:40,role:1}],actions:t.actions.map(o=>({action:o,allowed:this._getRole(Nt.Owner)||this._getRole(Nt.Editor)}))};n.push(i)}}),n}async listCollaborators(){return[]}async listRoles(){return{roles:[],actions:[]}}async deleteCollaborator(){}async update(t){}async updateCollaborator(){}async createCollaborator(){}async putCollaborators(t){}};exports.AuthzIoLocalService=vp([Oo(0,ss),Oo(1,je.Inject(Zn))],exports.AuthzIoLocalService);const uu=je.createIdentifier("IAuthzIoIoService");var Op=Object.getOwnPropertyDescriptor,wp=(e,t,n,r)=>{for(var s=r>1?void 0:r?Op(t,n):t,i=e.length-1,o;i>=0;i--)(o=e[i])&&(s=o(s)||s);return s},bp=(e,t)=>(n,r)=>t(n,r,e);exports.MentionIOLocalService=class{constructor(t){this._userManagerService=t}async list(t){return{list:[{type:Pr.PERSON,mentions:[{objectType:Pr.PERSON,objectId:this._userManagerService.getCurrentUser().userID,label:this._userManagerService.getCurrentUser().name,metadata:{icon:this._userManagerService.getCurrentUser().avatar}}],metadata:{},title:"PEOPLE"}],page:t.page,size:t.size,total:1}}};exports.MentionIOLocalService=wp([bp(0,je.Inject(Zn))],exports.MentionIOLocalService);const cu=je.createIdentifier("univer.service.mention-io"),_i=je.createIdentifier("univer.config-service");class hu{constructor(){C(this,"_configChanged$",new we.Subject);C(this,"configChanged$",this._configChanged$.asObservable());C(this,"_config",new Map)}dispose(){this._configChanged$.complete()}getConfig(t){return this._config.get(t)}setConfig(t,n,r){var o;const{merge:s=!1}=r||{};let i=(o=this._config.get(t))!=null?o:{};s?i=li(i,n):i=n,this._config.set(t,i),this._configChanged$.next({[t]:i})}deleteConfig(t){return this._config.delete(t)}subscribeConfigValue$(t){return new we.Observable(n=>{Object.prototype.hasOwnProperty.call(this._config,t)&&n.next(this._config.get(t));const r=this.configChanged$.pipe(we.filter(s=>Object.prototype.hasOwnProperty.call(s,t))).subscribe(s=>n.next(s[t]));return()=>r.unsubscribe()})}}const Hn="FOCUSING_UNIT",Rn="FOCUSING_SHEET",jn="FOCUSING_DOC",Wn="FOCUSING_SLIDE",yp="FOCUSING_EDITOR_BUT_HIDDEN",du="EDITOR_ACTIVATED",Ap="FOCUSING_EDITOR_INPUT_FORMULA",fu="FOCUSING_FX_BAR_EDITOR",Tp="FOCUSING_UNIVER_EDITOR",Np="FOCUSING_EDITOR_INPUT_FORMULA",Mp="FOCUSING_PANEL_EDITOR",Dp="FOCUSING_UNIVER_EDITOR_STANDALONE_SINGLE_MODE",Lp="FOCUSING_COMMON_DRAWINGS",xp="FORMULA_EDITOR_ACTIVATED";class gu extends rt{constructor(){super(...arguments);C(this,"_error$",new we.Subject);C(this,"error$",this._error$.asObservable())}dispose(){this._error$.complete()}emit(n){this._error$.next({errorKey:n})}}const Up="0.6.7",kp={version:Up};function Pp(e="",t=rr.ZH_CN,n=""){return{id:e,sheetOrder:[],name:n,appVersion:kp.version,locale:t,styles:{},sheets:{},resources:[]}}class mu{constructor(t={}){C(this,"_styles");C(this,"_cacheMap",new Xn(1e5));this._styles=t,this._generateCacheMap()}each(t){return Object.entries(this._styles).forEach(t),this}search(t,n){if(this._cacheMap.has(n))return this._cacheMap.get(n);const r=this._getExistingStyleId(t);return r||"-1"}get(t){return typeof t!="string"?t:(t=String(t),this._styles[t])}add(t,n){const r=re.generateRandomId(6);return this._styles[r]=t,this._cacheMap.set(n,r),r}setValue(t){if(t==null)return;const n=JSON.stringify(t),r=this.search(t,n);return r!=="-1"?r:this.add(t,n)}toJSON(){return this._styles}getStyleByCell(t){let n;t&&re.isObject(t.s)?n=t.s:n=(t==null?void 0:t.s)&&this.get(t.s);const r=t==null?void 0:t.interceptorStyle;return r?{...n,...r}:n}_generateCacheMap(){const{_styles:t,_cacheMap:n}=this;for(const r in t){const s=JSON.stringify(t[r]);n.set(s,r)}}_getExistingStyleId(t){const{_styles:n}=this;for(const r in n)if(re.diffValue(n[r],t))return r;return null}}const Fp=(e,t)=>t.length===e.length&&!e.some(n=>t.some(r=>!Xt.equals(r,n))),$p=(e,t)=>t.length===e.length&&e.every((n,r)=>{const s=t[r];return s.unitId===n.unitId&&s.sheetId===n.sheetId&&Xt.equals(n.range,s.range)}),js={t:0,b:2,l:2,r:2},Bp=e=>({sbr:.6,sbo:e,spr:.6,spo:e}),wo=90;function Yn(e,t,n={}){const r=e.length,{textRotation:s,paddingData:i,horizontalAlign:o=Ot.UNSPECIFIED,verticalAlign:a=tn.UNSPECIFIED,wrapStrategy:l=on.UNSPECIFIED,cellValueType:u}=n,{t:c,r:h,b:d,l:f}=i||js,{vertexAngle:E,centerAngle:R}=Eu(s),w={id:"d",body:{dataStream:`${e}${Oa}`,textRuns:[{ts:t,st:0,ed:r}],paragraphs:[{startIndex:r,paragraphStyle:{horizontalAlign:o}}],sectionBreaks:[{startIndex:r+1}]},documentStyle:{pageSize:{width:Number.POSITIVE_INFINITY,height:Number.POSITIVE_INFINITY},marginTop:c,marginBottom:d,marginRight:h,marginLeft:f,renderConfig:{horizontalAlign:o,verticalAlign:a,centerAngle:R,vertexAngle:E,wrapStrategy:l,cellValueType:u,zeroWidthParagraphBreak:1}},drawings:{},drawingsOrder:[]};return new yt(w)}function Hp(e){if(!e)return{};const{tr:t,td:n,ht:r,vt:s,tb:i,pd:o}=e;return{textRotation:t,textDirection:n,horizontalAlign:r,verticalAlign:s,wrapStrategy:i,paddingData:o}}function bo(e){if(!e)return{};const{ff:t,fs:n,it:r,bl:s,ul:i,st:o,ol:a,cl:l}=e,u={};return t&&(u.ff=t),n&&(u.fs=n),r&&(u.it=r),s&&(u.bl=s),i&&(u.ul=i),o&&(u.st=o),a&&(u.ol=a),l&&(u.cl=l),u}function _u(e,t,n){var i;const r=e.getBody();if((i=r.customRanges)!=null&&i.some(o=>o.rangeType===qt.HYPERLINK))return;const s=it.customRange.add({ranges:[{startOffset:0,endOffset:r.dataStream.length-1,collapsed:!1}],rangeId:n,rangeType:qt.HYPERLINK,body:r,properties:{url:t,refId:n}});s&&Ye.apply(r,s.serialize())}function pu(e){return e!=null}const jp='"Helvetica Neue", Helvetica, Arial, "PingFang SC", "Hiragino Sans GB", "Heiti SC", "Microsoft YaHei", "WenQuanYi Micro Hei", sans-serif';function yo(e){const t=lt.ff,n=lt.fs;if(!e){const h=`${n}pt ${t}`;return{fontCache:h,fontString:h,fontSize:n,originFontSize:n,fontFamily:t}}let r=En.ITALIC;(e.it===0||e.it===void 0)&&(r=En.NORMAL);let s=En.BOLD;(e.bl===0||e.bl===void 0)&&(s=En.NORMAL);let i=n;e.fs&&(i=Math.ceil(e.fs));let o=t;if(e.ff){let h=e.ff;h=h.replace(/"/g,"").replace(/'/g,""),h.indexOf(" ")>-1&&(h=`"${h}"`),h==null&&(h=t),o=h}const{va:a}=e;let l=i;if(a===xt.SUBSCRIPT||a===xt.SUPERSCRIPT){const h=Wp(o,l),{sbr:d,spr:f}=h;l*=a===xt.SUBSCRIPT?d:f}const u=`${r} ${s} ${l}pt ${o}`,c=`${u}, ${jp} `;return{fontCache:u,fontString:c,fontSize:l,originFontSize:i,fontFamily:o}}function Wp(e,t){return Bp(t)}function Eu(e){const{a:t=0,v:n=Ie.FALSE}=e||{a:0,v:Ie.FALSE};let r=0,s=t;return n===Ie.TRUE&&(r=wo,s=wo),{centerAngle:r,vertexAngle:s}}class Yp{constructor(t,n){C(this,"_columnData",{});this._config=t,this._columnData=n}getColumnData(){return this._columnData}getColVisible(t){const{_columnData:n}=this,r=n[t];return r?r.hd!==Ie.TRUE:!0}getColumnStyle(t){var n;return(n=this._columnData[t])==null?void 0:n.s}setColumnStyle(t,n){const r=this.getColumnOrCreate(t);r.s=n}getHiddenCols(t=0,n=this.getSize()-1){const r=[];let s=!1,i=-1;for(let o=t;o<=n;o++){const a=this.getColVisible(o);s&&a?(s=!1,r.push({rangeType:Le.COLUMN,startColumn:i,endColumn:o-1,startRow:0,endRow:0})):!s&&!a&&(s=!0,i=o)}return s&&r.push({startRow:0,endRow:0,startColumn:i,endColumn:n,rangeType:Le.COLUMN}),r}getVisibleCols(t=0,n=this.getSize()-1){const r=[];let s=!1,i=-1;for(let o=t;o<=n;o++){const a=this.getColVisible(o);s&&!a?(s=!1,r.push({rangeType:Le.COLUMN,startColumn:i,endColumn:o-1,startRow:0,endRow:0})):!s&&a&&(s=!0,i=o)}return s&&r.push({startRow:0,endRow:0,startColumn:i,endColumn:n,rangeType:Le.COLUMN}),r}getColumnDatas(t,n){const r={};let s=0;for(let i=t;i<t+n;i++){const o=this.getColumnOrCreate(i);r[s]=o,s++}return r}getSize(){return Gt(this._columnData)}getColumnWidth(t){const{_columnData:n}=this,r=this._config;let s=0;return s=(n[t]||{hd:Ie.FALSE,w:r.defaultColumnWidth}).w||r.defaultColumnWidth,s}getColumn(t){const n=this._columnData[t];if(n)return n}removeColumn(t){delete this._columnData[t]}getColumnOrCreate(t){const{_columnData:n}=this,r=n[t];if(r)return r;const s={};return this._columnData[t]=s,s}setCustomMetadata(t,n){const r=this.getColumn(t);r&&(r.custom=n)}getCustomMetadata(t){var n;return(n=this.getColumn(t))==null?void 0:n.custom}}class zp{constructor(t,n,r){C(this,"_rowData");this._config=t,this._viewModel=n,this._rowData=r}getRowData(){return this._rowData}getRowStyle(t){var n;return(n=this._rowData[t])==null?void 0:n.s}setRowStyle(t,n){const r=this.getRowOrCreate(t);r.s=n}getRowDatas(t,n){const r={};let s=0;for(let i=t;i<t+n;i++){const o=this.getRowOrCreate(i);r[s]=o,s++}return r}getRowHeight(t,n=1){const{_rowData:r}=this,s=this._config;let i=0;for(let o=0;o<n;o++){const a=r[o+t]||{hd:Ie.FALSE,h:s.defaultRowHeight},{ia:l,ah:u,h:c=s.defaultRowHeight}=a;i+=(l==null||l===Ie.TRUE)&&typeof u=="number"?u:c}return i}getRow(t){return this._rowData[t]}removeRow(t){delete this._rowData[t]}getRowOrCreate(t){const{_rowData:n}=this,r=n[t];if(r)return r;const s={};return n[t]=s,s}getHiddenRows(t=0,n=this.getSize()-1){const r=[];let s=!1,i=-1;for(let o=t;o<=n;o++){const a=this.getRowRawVisible(o);s&&a?(s=!1,r.push({startRow:i,endRow:o-1,startColumn:0,endColumn:0,rangeType:Le.ROW})):!s&&!a&&(s=!0,i=o)}return s&&r.push({startRow:i,endRow:n,startColumn:0,endColumn:0,rangeType:Le.ROW}),r}getVisibleRows(t=0,n=this.getSize()-1){const r=[];let s=!1,i=-1;for(let o=t;o<=n;o++){const a=this.getRowRawVisible(o);s&&!a?(s=!1,r.push({startRow:i,endRow:o-1,startColumn:0,endColumn:0,rangeType:Le.ROW})):!s&&a&&(s=!0,i=o)}return s&&r.push({startRow:i,endRow:n,startColumn:0,endColumn:0,rangeType:Le.ROW}),r}getRowRawVisible(t){const n=this.getRow(t);return n?n.hd!==Ie.TRUE:!0}getSize(){return Gt(this._rowData)}setCustomMetadata(t,n){const r=this.getRow(t);r&&(r.custom=n)}getCustomMetadata(t){var n;return(n=this.getRow(t))==null?void 0:n.custom}}const Vp="DEFAULT_WORKSHEET_ROW_COUNT",Cu=1e3,Gp="DEFAULT_WORKSHEET_COLUMN_COUNT",Ru=20,Kp="DEFAULT_WORKSHEET_ROW_HEIGHT",Iu=24,Xp="DEFAULT_WORKSHEET_COLUMN_WIDTH",Su=88,qp="DEFAULT_WORKSHEET_ROW_TITLE_WIDTH",vu=46,Jp="DEFAULT_WORKSHEET_COLUMN_TITLE_HEIGHT",Ou=20;function wu(e){const t={name:"Sheet1",id:"sheet-01",tabColor:"",hidden:Ie.FALSE,rowCount:Cu,columnCount:Ru,zoomRatio:1,freeze:{xSplit:0,ySplit:0,startRow:-1,startColumn:-1},scrollTop:0,scrollLeft:0,defaultColumnWidth:Su,defaultRowHeight:Iu,mergeData:[],cellData:{},rowData:{},columnData:{},showGridlines:Ie.TRUE,rowHeader:{width:vu,hidden:Ie.FALSE},columnHeader:{height:Ou,hidden:Ie.FALSE},rightToLeft:Ie.FALSE};return Object.keys(t).forEach(n=>{const r=n;typeof e[r]>"u"&&(e[r]=t[r])}),e}class Zp extends rt{constructor(n){super();C(this,"_cellCache",new Map);C(this,"_rowCache",new Map);C(this,"_columnCache",new Map);C(this,"_hasRow",!1);C(this,"_hasColumn",!1);C(this,"_hasAll",!1);C(this,"_allIndex",-1);C(this,"_mergeData");C(this,"_rangeMap",new Xn(5e4));C(this,"_skeletonCache",new Xn(5e4));this._init(n.concat())}_init(n){this._mergeData=n,this._createCache(n)}_clearCache(){this._cellCache.clear(),this._rowCache.clear(),this._columnCache.clear(),this._hasAll=!1,this._allIndex=-1,this._rangeMap.clear(),this._skeletonCache.clear(),this._hasColumn=!1,this._hasRow=!1}_createCache(n){let r=0;for(const s of n){const{rangeType:i}=s;i===Le.ROW?this._createRowCache(s,r):i===Le.COLUMN?this._createColumnCache(s,r):i===Le.ALL?this._createCellAllCache(r):this._createCellCache(s,r),r++}}rebuild(n){this._clearCache(),this._init(n.concat())}_createRowCache(n,r){const{startRow:s,endRow:i}=n;for(let o=s;o<=i;o++)this._rowCache.set(o,r),this._hasRow=!0}_createColumnCache(n,r){const{startColumn:s,endColumn:i}=n;for(let o=s;o<=i;o++)this._columnCache.set(o,r),this._hasColumn=!0}_createCellAllCache(n){this._hasAll=!0,this._allIndex=n}_createCellCache(n,r){for(let s=n.startRow;s<=n.endRow;s++){let i=this._cellCache.get(s);i==null&&(i=new Map,this._cellCache.set(s,i));for(let o=n.startColumn;o<=n.endColumn;o++)i.set(o,r)}}add(n){this._mergeData.push(n),this._clearCache(),this._createCache(this._mergeData)}remove(n,r){const s=this._getMergeDataIndex(n,r);s!==-1&&(this._mergeData.splice(s,1),this._clearCache(),this._createCache(this._mergeData))}getMergedCell(n,r){const s=this._getMergeDataIndex(n,r);return s!==-1?this._mergeData[s]:null}getMergeDataIndex(n,r){return this._getMergeDataIndex(n,r)}isRowContainsMergedCell(n){return this._hasAll||!re.isEmptyObject(this._columnCache)?!0:this._mergeData.some(r=>r.startRow<=n&&n<=r.endRow)}isColumnContainsMergedCell(n){return this._hasAll||!re.isEmptyObject(this._rowCache)?!0:this._mergeData.some(r=>r.startColumn<=n&&n<=r.endColumn)}getMergedCellRange(n,r,s,i){const o=[],a=`${n}-${r}-${s}-${i}`;if(this._rangeMap.has(a))return this._getRangeFromCache(a);let l=0;const u=[];for(const c of this._mergeData||[])Xt.intersects(c,{startRow:n,endRow:s,startColumn:r,endColumn:i})&&(o.push({...c}),u.push(l)),l++;return this._rangeMap.set(a,u),o}getMergedCellRangeForSkeleton(n,r,s,i){const o=[],a=this._mergeData,l=`${n}-${r}-${s}-${i}`;if(this._skeletonCache.has(l))return this._getSkeletonRangeFromCache(l);const u=[];for(let c=0;c<a.length;c++){const{startRow:h,endRow:d,startColumn:f,endColumn:E}=a[c];for(let R=n;R<=s;R++){let w=!1;for(let L=r;L<=i;L++)if(R>=h&&R<=d&&L>=f&&L<=E){o.push({startRow:h,endRow:d,startColumn:f,endColumn:E}),u.push(c),w=!0;break}if(w)break}}return this._skeletonCache.set(l,u),o}_getRangeFromCache(n){const r=this._rangeMap.get(n)||[],s=[];for(const i of r)s.push({...this._mergeData[i]});return s}_getSkeletonRangeFromCache(n){const r=this._skeletonCache.get(n)||[],s=[];for(const i of r)s.push({...this._mergeData[i]});return s}_getMergeDataIndex(n,r){var i;if(this._hasAll)return this._allIndex;if(this._hasRow){const o=this._rowCache.get(n);if(o!==void 0)return o}if(this._hasColumn){const o=this._columnCache.get(r);if(o!==void 0)return o}const s=(i=this._cellCache.get(n))==null?void 0:i.get(r);return s!==void 0?s:-1}getMergeDataSnapshot(){return this._mergeData}dispose(){this._clearCache(),this._mergeData=[]}}class bu extends rt{constructor(n){super();C(this,"_cellContentInterceptor",null);C(this,"_rowFilteredInterceptor",null);this.getRawCell=n}dispose(){super.dispose(),this._cellContentInterceptor=null,this._rowFilteredInterceptor=null}getCell(n,r,s,i){return this._cellContentInterceptor?this._cellContentInterceptor.getCell(n,r,Cn.Value|Cn.Style,s,i):this.getRawCell(n,r)}getCellValueOnly(n,r){return this._cellContentInterceptor?this._cellContentInterceptor.getCell(n,r,Cn.Value):this.getRawCell(n,r)}getCellStyleOnly(n,r){return this._cellContentInterceptor?this._cellContentInterceptor.getCell(n,r,Cn.Style):this.getRawCell(n,r)}getRowFiltered(n){var r,s;return(s=(r=this._rowFilteredInterceptor)==null?void 0:r.getRowFiltered(n))!=null?s:!1}registerCellContentInterceptor(n){if(this._cellContentInterceptor)throw new Error("[SheetViewModel]: Interceptor already registered.");return this._cellContentInterceptor=n,nt(()=>this._cellContentInterceptor=null)}registerRowFilteredInterceptor(n){if(this._rowFilteredInterceptor)throw new Error("[SheetViewModel]: Interceptor already registered.");return this._rowFilteredInterceptor=n,nt(()=>this._rowFilteredInterceptor=null)}}const Ao={isDeepClone:!1,displayRawFormula:!1,ignoreTextRotation:!1};class Qn{constructor(t,n,r){C(this,"_sheetId");C(this,"_snapshot");C(this,"_cellData");C(this,"_rowManager");C(this,"_columnManager");C(this,"_viewModel");C(this,"_spanModel");var a;this.unitId=t,this._styles=r,this._snapshot=wu(n);const{columnData:s,rowData:i,cellData:o}=this._snapshot;this._sheetId=(a=this._snapshot.id)!=null?a:re.generateRandomId(6),this._cellData=new wt(o),this._viewModel=new bu((l,u)=>this.getCellRaw(l,u)),this._rowManager=new zp(this._snapshot,this._viewModel,i),this._columnManager=new Yp(this._snapshot,s),this._spanModel=new Zp(this._snapshot.mergeData)}__interceptViewModel(t){t(this._viewModel)}getSnapshot(){return this._snapshot}setMergeData(t){this._snapshot.mergeData=t,this.getSpanModel().rebuild(t)}getSpanModel(){return this._spanModel}getStyleDataByHash(t){return{...this._styles.get(t)}}setStyleData(t){return this._styles.setValue(t)}getColumnStyle(t,n=!1){return n?this._columnManager.getColumnStyle(t):this._styles.get(this._columnManager.getColumnStyle(t))}setColumnStyle(t,n){this._columnManager.setColumnStyle(t,n)}getRowStyle(t,n=!1){return n?this._rowManager.getRowStyle(t):this._styles.get(this._rowManager.getRowStyle(t))}setRowStyle(t,n){this._rowManager.setRowStyle(t,n)}mixinDefaultStyleToCellRaw(t,n,r,s){const i=this.getColumnStyle(n),o=this.getRowStyle(t),a=this.getDefaultCellStyleInternal();if(a||i||o){let l=r==null?void 0:r.s;typeof l=="string"&&(l=this._styles.get(l));const u=s?ws(a,i,o,l):ws(a,o,i,l);r||(r={}),r.s=u}}getDefaultCellStyle(){return this._snapshot.defaultStyle}getDefaultCellStyleInternal(){const t=this._snapshot.defaultStyle;return this._styles.get(t)}setDefaultCellStyle(t){this._snapshot.defaultStyle=t}getCellStyle(t,n){const r=this.getCell(t,n);if(r){const s=r.s;return typeof s=="string"?this._styles.get(s):s}return null}getCellMatrix(){return this._cellData}getCellMatrixPrintRange(){const t=this.getCellMatrix(),n=this.getMergeData();let r=-1,s=-1,i=-1,o=-1,a=!1,l=!1;return t.forEach((u,c)=>{Object.keys(c).forEach(h=>{const d=+h,f=t.getValue(u,d),E=f!=null&&f.s?this._styles.get(f.s):null,R=(E==null?void 0:E.bd)&&(E.bd.b||E.bd.l||E.bd.r||E.bd.t||E.bd.bc_tr||E.bd.bl_tr||E.bd.ml_tr||E.bd.tl_bc||E.bd.tl_br||E.bd.tl_mr);(f&&(f.v||f.p)||E!=null&&E.bg||R)&&(a?r=Math.min(r,u):(r=u,a=!0),s=Math.max(s,u),l?i=Math.min(i,d):(l=!0,i=d),o=Math.max(o,d))})}),n.forEach(u=>{a?r=Math.min(r,u.startRow):(r=u.startRow,a=!0),s=Math.max(s,u.endRow),l?i=Math.min(i,u.startColumn):(i=u.startColumn,a=!0),o=Math.max(o,u.endColumn)}),!a||!l?null:{startColumn:i,startRow:r,endColumn:o,endRow:s}}getRowManager(){return this._rowManager}getUnitId(){return this.unitId}getSheetId(){return this._sheetId}getColumnManager(){return this._columnManager}getName(){return this._snapshot.name}clone(){const{_snapshot:t}=this,n=re.deepClone(t);return new Qn(this.unitId,n,this._styles)}getMergeData(){return this._spanModel.getMergeDataSnapshot()}getMergedCell(t,n){return this._spanModel.getMergedCell(t,n)}getMergedCellRange(t,n,r,s){return this._spanModel.getMergedCellRange(t,n,r,s)}isRowContainsMergedCell(t){return this._spanModel.isRowContainsMergedCell(t)}isColumnContainsMergedCell(t){return this._spanModel.isColumnContainsMergedCell(t)}getCellInfoInMergeData(t,n){const r=this.getMergedCell(t,n);let s=!1,i=!1,o=t,a=n,l=t,u=n;if(r){const{startRow:c,endRow:h,startColumn:d,endColumn:f}=r;t===c&&n===d?(o=h,a=f,l=c,u=d,i=!0):t>=c&&t<=h&&n>=d&&n<=f&&(o=h,a=f,l=c,u=d,s=!0)}return{actualRow:t,actualColumn:n,isMergedMainCell:i,isMerged:s,endRow:o,endColumn:a,startRow:l,startColumn:u}}getCell(t,n){return t<0||n<0?null:this._viewModel.getCell(t,n)}getCellValueOnly(t,n){return t<0||n<0?null:this._viewModel.getCellValueOnly(t,n)}getCellStyleOnly(t,n){return t<0||n<0?null:this._viewModel.getCellStyleOnly(t,n)}getCellRaw(t,n){return this.getCellMatrix().getValue(t,n)}getCellWithFilteredInterceptors(t,n,r,s){return this._viewModel.getCell(t,n,r,s)}getRowFiltered(t){return this._viewModel.getRowFiltered(t)}getMatrixWithMergedCells(t,n,r,s,i=pn.Raw){const o=this.getCellMatrix(),a=this._spanModel.getMergedCellRange(t,n,r,s),l=new wt;return Ds(t,r,n,s).forEach((u,c)=>{var d;let h;if(i===pn.Raw)h=this.getCellRaw(u,c);else if(i===pn.Intercepted)h=this.getCell(u,c);else if(i===pn.Both){const f=this.getCellRaw(u,c);if(f){h={...f};const E=(d=this.getCell(u,c))==null?void 0:d.v;pu(E)&&h&&(h.displayV=String(E))}}h&&l.setValue(u,c,h)}),a.forEach(u=>{const{startColumn:c,startRow:h,endColumn:d,endRow:f}=u;Ds(h,f,c,d).forEach((E,R)=>{E===h&&R===c&&l.setValue(E,R,{...o.getValue(E,R),rowSpan:f-h+1,colSpan:d-c+1}),(E!==h||R!==c)&&l.realDeleteValue(E,R)})}),l}getRange(t,n,r,s){return typeof t=="object"?new vn(this,t,{getStyles:()=>this._styles}):new vn(this,{startRow:t,startColumn:n,endColumn:s||n,endRow:r||t},{getStyles:()=>this._styles})}getScrollLeftTopFromSnapshot(){return{scrollLeft:this._snapshot.scrollLeft,scrollTop:this._snapshot.scrollTop}}getZoomRatio(){return this._snapshot.zoomRatio||1}getConfig(){return this._snapshot}getFreeze(){return this._snapshot.freeze}getMaxColumns(){const{_snapshot:t}=this,{columnCount:n}=t;return n}getMaxRows(){const{_snapshot:t}=this,{rowCount:n}=t;return n}getRowCount(){return this._snapshot.rowCount}setRowCount(t){this._snapshot.rowCount=t}getColumnCount(){return this._snapshot.columnCount}setColumnCount(t){this._snapshot.columnCount=t}isSheetHidden(){return this._snapshot.hidden}hasHiddenGridlines(){const{_snapshot:t}=this,{showGridlines:n}=t;return n===0}getGridlinesColor(){return this.getConfig().gridlinesColor}getTabColor(){const{_snapshot:t}=this,{tabColor:n}=t;return n}getColumnWidth(t){return this.getColumnManager().getColumnWidth(t)}getRowHeight(t){return this._viewModel.getRowFiltered(t)?0:this.getRowManager().getRowHeight(t)}isRowFiltered(t){return this._viewModel.getRowFiltered(t)}getRowVisible(t){return!this.isRowFiltered(t)&&this.getRowRawVisible(t)}getRowRawVisible(t){return this.getRowManager().getRowRawVisible(t)}getHiddenRows(t,n){const r=this.getMaxColumns()-1,s=this._rowManager.getHiddenRows(t,n);return s.forEach(i=>i.endColumn=r),s}getColVisible(t){return this._columnManager.getColVisible(t)}getHiddenCols(t,n){const r=this.getMaxRows()-1,s=this._columnManager.getHiddenCols(t,n);return s.forEach(i=>i.endRow=r),s}getVisibleRows(){const t=this.getRowCount();return this._rowManager.getVisibleRows(0,t-1)}getVisibleCols(){const t=this.getColumnCount();return this._columnManager.getVisibleCols(0,t-1)}isRightToLeft(){const{_snapshot:t}=this,{rightToLeft:n}=t;return n}getLastRowWithContent(){return this._cellData.getLength()-1}getLastColumnWithContent(){return this._cellData.getRange().endColumn}getDataRangeScope(){return this._cellData.getStartEndScope()}cellHasValue(t){return t&&(t.v!==void 0||t.f!==void 0||t.p!==void 0)}iterateByRow(t,n=!0){const{startRow:r,startColumn:s,endRow:i,endColumn:o}=t,a=this;return{[Symbol.iterator]:()=>{let l=r,u=s;return{next(){for(;;){if(u>o&&(l+=1,u=s),l>i)return{done:!0,value:void 0};const c=a.getCell(l,u),h=!c,d=a.getMergedCell(l,u);if(d){if(l!==d.startRow||u!==d.startColumn){u=d.endColumn+1;continue}if(h&&n){u=d.endColumn+1;continue}const E={row:l,col:u,value:c};return E.colSpan=d.endColumn-d.startColumn+1,E.rowSpan=d.endRow-d.startRow+1,u=d.endColumn+1,{done:!1,value:E}}if(h&&n)u+=1;else{const f={row:l,col:u,value:c};return u+=1,{done:!1,value:f}}}}}}}}iterateByColumn(t,n=!0,r=!0){const{startRow:s,startColumn:i,endRow:o,endColumn:a}=t,l=this;return{[Symbol.iterator]:()=>{let u=s,c=i;return{next(){for(;;){if(u>o&&(c+=1,u=s),c>a)return{done:!0,value:void 0};const h=l.getMergedCell(u,c);if(h){const E=u!==h.startRow,R=E||c!==h.startColumn;if(r&&R||!r&&E){u=h.endRow+1;continue}const w=l.getCell(h.startRow,h.startColumn);if(!w&&n){u=h.endRow+1;continue}const J={row:u,col:h.startColumn,value:w};return J.colSpan=h.endColumn-h.startColumn+1,J.rowSpan=h.endRow-h.startRow+1,u=h.endRow+1,{done:!1,value:J}}const d=l.getCell(u,c);if(!d&&n)u+=1;else{const E={row:u,col:c,value:d};return u+=1,{done:!1,value:E}}}}}}}}_getCellDocumentModel(t,n=Ao){var R;const{isDeepClone:r,displayRawFormula:s,ignoreTextRotation:i}={...Ao,...n},o=this._styles.getStyleByCell(t);if(!t)return;let a,l="document";const u=Hp(o),c=i?lt.tr:u.textRotation||lt.tr;let h=u.horizontalAlign||lt.ht;const d=u.verticalAlign||lt.vt,f=u.wrapStrategy||lt.tb,E=u.paddingData||js;if(t.f&&s)a=Yn(t.f.toString(),{},{verticalAlign:d}),h=lt.ht;else if(t.p){const{centerAngle:w,vertexAngle:L}=Eu(c);a=this._updateConfigAndGetDocumentModel(r?re.deepClone(t.p):t.p,h,E,{horizontalAlign:h,verticalAlign:d,centerAngle:w,vertexAngle:L,wrapStrategy:f,zeroWidthParagraphBreak:1})}else if(t.v!=null){const w=bo(o);l=yo(w).fontCache;let L=yu(t);t.t===Vt.FORCE_STRING&&s&&(L=`'${L}`),a=Yn(L,w,{...u,textRotation:c,cellValueType:t.t})}return a&&t.linkUrl&&t.linkId&&_u(a,t.linkUrl,t.linkId),{documentModel:a,fontString:l,textRotation:c,wrapStrategy:f,verticalAlign:d,horizontalAlign:h,paddingData:E,fill:(R=o==null?void 0:o.bg)==null?void 0:R.rgb}}_updateConfigAndGetDocumentModel(t,n,r,s){var o,a,l,u,c;if(!s||!((o=t.body)!=null&&o.dataStream))return;t.documentStyle||(t.documentStyle={}),t.documentStyle.marginTop=(a=r.t)!=null?a:0,t.documentStyle.marginBottom=(l=r.b)!=null?l:2,t.documentStyle.marginLeft=(u=r.l)!=null?u:2,t.documentStyle.marginRight=(c=r.r)!=null?c:2,t.documentStyle.pageSize={width:Number.POSITIVE_INFINITY,height:Number.POSITIVE_INFINITY},t.documentStyle.renderConfig={...t.documentStyle.renderConfig,...s};const i=t.body.paragraphs||[];for(const h of i)h.paragraphStyle||(h.paragraphStyle={}),h.paragraphStyle.horizontalAlign=n;return new yt(t)}getBlankCellDocumentModel(t){const n=this._getCellDocumentModel(t,{ignoreTextRotation:!0}),r=this._styles.getStyleByCell(t),s=bo(r);if(n!=null)return n.documentModel==null&&(n.documentModel=Yn("",s)),n;const i="";let o="document";const a=lt.tr,l=lt.ht,u=lt.vt,c=lt.tb,h=js;return o=yo({}).fontCache,{documentModel:Yn(i,s),fontString:o,textRotation:a,wrapStrategy:c,verticalAlign:u,horizontalAlign:l,paddingData:h}}getCellDocumentModelWithFormula(t){return this._getCellDocumentModel(t,{isDeepClone:!0,displayRawFormula:!0,ignoreTextRotation:!0})}getCustomMetadata(){return this._snapshot.custom}setCustomMetadata(t){this._snapshot.custom=t}}function yu(e){var r,s;if(!e)return"";const t=(s=(r=e.p)==null?void 0:r.body)==null?void 0:s.dataStream;if(t)return it.transform.getPlainText(t);const n=e.v;return typeof n=="string"?e.t===Vt.BOOLEAN?n.toUpperCase():n.replace(/[\r\n]/g,""):typeof n=="number"?e.t===Vt.BOOLEAN?n?"TRUE":"FALSE":n.toString():typeof n=="boolean"?n?"TRUE":"FALSE":""}function Qp(e){if(e===null)return"";if(e!=null&&e.p){const t=e==null?void 0:e.p.body;if(t==null)return"";const n=t.dataStream;return it.transform.getPlainText(n)}return e==null?void 0:e.v}var eE=Object.getOwnPropertyDescriptor,tE=(e,t,n,r)=>{for(var s=r>1?void 0:r?eE(t,n):t,i=e.length-1,o;i>=0;i--)(o=e[i])&&(s=o(s)||s);return s},nE=(e,t)=>(n,r)=>t(n,r,e);function rE(e,t){return`${e.getUnitId()}|${t.getSheetId()}`}exports.Workbook=class extends rs{constructor(n={},r){super();C(this,"type",$e.UNIVER_SHEET);C(this,"_sheetCreated$",new we.Subject);C(this,"sheetCreated$",this._sheetCreated$.asObservable());C(this,"_sheetDisposed$",new we.Subject);C(this,"sheetDisposed$",this._sheetDisposed$.asObservable());C(this,"_activeSheet$",new we.BehaviorSubject(null));C(this,"activeSheet$",this._activeSheet$.asObservable());C(this,"_worksheets");C(this,"_styles");C(this,"_snapshot");C(this,"_unitId");C(this,"_count");C(this,"_name$");C(this,"name$");this._logService=r;const s=Pp();re.isEmptyObject(n)?this._snapshot=s:this._snapshot=re.commonExtend(s,n);const{styles:i}=this._snapshot;(this._snapshot.id==null||this._snapshot.id.length===0)&&(this._snapshot.id=re.generateRandomId(6)),this._unitId=this._snapshot.id,this._styles=new mu(i),this._count=1,this._worksheets=new Map,this._name$=new we.BehaviorSubject(n.name||""),this.name$=this._name$.asObservable(),this._parseWorksheetSnapshots()}get _activeSheet(){return this._activeSheet$.getValue()}get name(){return this._name$.getValue()}static isIRangeType(n){return typeof n=="string"||"startRow"in n||"row"in n}dispose(){super.dispose(),this._sheetCreated$.complete(),this._sheetDisposed$.complete(),this._activeSheet$.complete(),this._name$.complete()}save(){return re.deepClone(this._snapshot)}getSnapshot(){return this._snapshot}getName(){return this._snapshot.name}setName(n){this._name$.next(n),this._snapshot.name=n}getUnitId(){return this._unitId}getRev(){var n;return(n=this._snapshot.rev)!=null?n:1}incrementRev(){this._snapshot.rev=this.getRev()+1}setRev(n){this._snapshot.rev=n}addWorksheet(n,r,s){const{sheets:i,sheetOrder:o}=this._snapshot;if(i[n])return!1;i[n]=s,o.splice(r,0,n);const a=new Qn(this._unitId,s,this._styles);return this._worksheets.set(n,a),this._sheetCreated$.next(a),!0}getSheetOrders(){return this._snapshot.sheetOrder}getWorksheets(){return this._worksheets}getActiveSpreadsheet(){return this}getStyles(){return this._styles}getConfig(){return this._snapshot}getIndexBySheetId(n){const{sheetOrder:r}=this._snapshot;return r.findIndex(s=>s===n)}getActiveSheet(n){if(!this._activeSheet&&typeof n>"u")throw new Error(`[Workbook]: no active Worksheet on Workbook ${this._unitId}!`);return this._activeSheet}ensureActiveSheet(){const n=this._activeSheet;if(n)return n;const r=this._snapshot.sheetOrder;for(let i=0,o=r.length;i<o;i++){const a=this._worksheets.get(r[i]);if(a&&a.isSheetHidden()!==Ie.TRUE)return this.setActiveSheet(a),a}const s=this._worksheets.get(r[0]);return this.setActiveSheet(s),s}setActiveSheet(n){this._activeSheet$.next(n)}removeSheet(n){const r=this._worksheets.get(n);return r?(this._worksheets.delete(n),this._snapshot.sheetOrder.splice(this._snapshot.sheetOrder.indexOf(n),1),delete this._snapshot.sheets[n],this._sheetDisposed$.next(r),!0):!1}getActiveSheetIndex(){const{sheetOrder:n}=this._snapshot;return n.findIndex(r=>this._worksheets.get(r)===this._activeSheet)}getSheetSize(){return this._snapshot.sheetOrder.length}getSheets(){const{sheetOrder:n}=this._snapshot;return n.map(r=>this._worksheets.get(r))}getSheetsName(){const{sheetOrder:n}=this._snapshot,r=[];return n.forEach(s=>{const i=this._worksheets.get(s);i&&r.push(i.getName())}),r}getSheetIndex(n){const{sheetOrder:r}=this._snapshot;return r.findIndex(s=>n.getSheetId()===s)}getSheetBySheetName(n){const{sheetOrder:r}=this._snapshot,s=r.find(i=>this._worksheets.get(i).getName()===n);return this._worksheets.get(s)}getSheetBySheetId(n){return this._worksheets.get(n)}getSheetByIndex(n){const{sheetOrder:r}=this._snapshot;return this._worksheets.get(r[n])}getHiddenWorksheets(){return this.getSheets().filter(n=>n.getConfig().hidden===Ie.TRUE).map(n=>n.getConfig().id)}getUnhiddenWorksheets(){return this.getSheets().filter(n=>n.getConfig().hidden!==Ie.TRUE).map(n=>n.getConfig().id)}load(n){this._snapshot=n}checkSheetName(n){return this.getSheetsName().includes(n)}uniqueSheetName(n="Sheet1"){let r=n;for(;this.checkSheetName(r);)r=n+this._count,this._count++;return r}generateNewSheetName(n){let r=n+this._count;for(;this.checkSheetName(r);)r=n+this._count,this._count++;return r}_parseWorksheetSnapshots(){const{_snapshot:n,_worksheets:r}=this,{sheets:s,sheetOrder:i}=n;if(re.isEmptyObject(s)){const o=re.generateRandomId();s[o]={id:o}}for(const o in s){const a=s[o],{name:l}=a;a.name=this.uniqueSheetName(l),a.name!==l&&this._logService.debug("[Workbook]",`The worksheet name ${l} is duplicated, we changed it to ${a.name}. Please fix the problem in your snapshot.`);const u=new Qn(this._unitId,a,this._styles);r.set(o,u),i.includes(o)||i.push(o)}this.ensureActiveSheet()}getCustomMetadata(){return this._snapshot.custom}setCustomMetadata(n){this._snapshot.custom=n}};exports.Workbook=tE([nE(1,vt)],exports.Workbook);class pi extends rs{constructor(n){var r;super();C(this,"type",$e.UNIVER_SLIDE);C(this,"_activePage$",new we.BehaviorSubject(null));C(this,"activePage$",this._activePage$.asObservable());C(this,"_name$");C(this,"name$");C(this,"_snapshot");C(this,"_unitId");this._snapshot={...Aa,...n},this._unitId=(r=this._snapshot.id)!=null?r:re.generateRandomId(6),this._name$=new we.BehaviorSubject(this._snapshot.title),this.name$=this._name$.asObservable()}get _activePage(){var r,s;const n=this._activePage$.getValue();if(!n){const i=(r=this.getPageOrder())==null?void 0:r[0];return i?(s=this.getPages())==null?void 0:s[i]:null}return n}setName(n){var r;this._snapshot.title=n,this._name$.next(n),this._unitId=(r=this._snapshot.id)!=null?r:Ut(6)}getRev(){return 0}incrementRev(){}setRev(n){}getSnapshot(){return this._snapshot}getUnitId(){return this._unitId}getPages(){var n;return(n=this._snapshot.body)==null?void 0:n.pages}getPageOrder(){var n;return(n=this._snapshot.body)==null?void 0:n.pageOrder}getPage(n){const r=this.getPages();return r==null?void 0:r[n]}getElementsByPage(n){var r;return(r=this.getPage(n))==null?void 0:r.pageElements}getElement(n,r){var s;return(s=this.getElementsByPage(n))==null?void 0:s[r]}getPageSize(){return this._snapshot.pageSize}getBlankPage(){const n=Ut(6);return{id:n,pageType:ei.SLIDE,zIndex:10,title:n,description:"",pageBackgroundFill:{rgb:"rgb(255,255,255)"},pageElements:{}}}setActivePage(n){this._activePage$.next(n)}getActivePage(){return this._activePage}updatePage(n,r){this._snapshot.body&&(this._snapshot.body.pages[n]=r)}appendPage(n){var i;if(!this._snapshot.body)return;this._snapshot.body.pages[n.id]=n;const r=this._activePage,s=this._snapshot.body.pageOrder.indexOf((i=r==null?void 0:r.id)!=null?i:"");this._snapshot.body.pageOrder.splice(s+1,0,n.id)}}var sE=Object.getOwnPropertyDescriptor,iE=(e,t,n,r)=>{for(var s=r>1?void 0:r?sE(t,n):t,i=e.length-1,o;i>=0;i--)(o=e[i])&&(s=o(s)||s);return s},To=(e,t)=>(n,r)=>t(n,r,e);const bn=je.createIdentifier("univer.current");exports.UniverInstanceService=class extends rt{constructor(n,r){super();C(this,"_unitsByType",new Map);C(this,"_createHandler");C(this,"_ctorByType",new Map);C(this,"_currentUnits",new Map);C(this,"_currentUnits$",new we.BehaviorSubject(this._currentUnits));C(this,"currentUnits$",this._currentUnits$.asObservable());C(this,"_unitAdded$",new we.Subject);C(this,"unitAdded$",this._unitAdded$.asObservable());C(this,"_unitDisposed$",new we.Subject);C(this,"unitDisposed$",this._unitDisposed$.asObservable());C(this,"_focused$",new we.BehaviorSubject(null));C(this,"focused$",this._focused$.asObservable());this._injector=n,this._contextService=r}dispose(){super.dispose(),this._focused$.complete()}__setCreateHandler(n){this._createHandler=n}createUnit(n,r,s){return this._createHandler(n,r,this._ctorByType.get(n),s)}registerCtorForType(n,r){return this._ctorByType.set(n,r),{dispose:()=>{this._ctorByType.delete(n)}}}getCurrentTypeOfUnit$(n){return this.currentUnits$.pipe(we.map(r=>{var s;return(s=r.get(n))!=null?s:null}),we.distinctUntilChanged())}getCurrentUnitForType(n){return this._currentUnits.get(n)}getCurrentUnitOfType(n){return this.getCurrentUnitForType(n)}setCurrentUnitForType(n){const r=this._getUnitById(n);if(!r)throw new Error(`[UniverInstanceService]: no document with unitId ${n}!`);this._currentUnits.set(r[1],r[0]),this._currentUnits$.next(this._currentUnits)}getTypeOfUnitAdded$(n){return this._unitAdded$.pipe(we.filter(r=>r.type===n))}__addUnit(n,r){var a;const s=n.type;this._unitsByType.has(s)||this._unitsByType.set(s,[]);const i=this._unitsByType.get(s),o=n.getUnitId();if(i.findIndex(l=>l.getUnitId()===o)!==-1)throw new Error(`[UniverInstanceService]: cannot create a unit with the same unit id: ${o}.`);i.push(n),this._unitAdded$.next(n),((a=r==null?void 0:r.makeCurrent)==null||a)&&this.setCurrentUnitForType(n.getUnitId())}getTypeOfUnitDisposed$(n){return this.unitDisposed$.pipe(we.filter(r=>r.type===n))}getUnit(n,r){var i;const s=(i=this._getUnitById(n))==null?void 0:i[0];return r&&(s==null?void 0:s.type)!==r?null:s}getCurrentUniverDocInstance(){return this.getCurrentUnitForType($e.UNIVER_DOC)}getUniverDocInstance(n){return this.getUnit(n,$e.UNIVER_DOC)}getUniverSheetInstance(n){return this.getUnit(n,$e.UNIVER_SHEET)}getAllUnitsForType(n){var r;return(r=this._unitsByType.get(n))!=null?r:[]}changeDoc(n,r){const s=this.getAllUnitsForType($e.UNIVER_DOC),i=s.find(o=>o.getUnitId()===n);if(i!=null){const o=s.indexOf(i);s.splice(o,1)}this.__addUnit(r)}get focused(){var r;const n=this._focused$.getValue();return n?(r=this._getUnitById(n))==null?void 0:r[0]:null}focusUnit(n){this._focused$.next(n),this.focused instanceof exports.Workbook?(this._contextService.setContextValue(Hn,!0),this._contextService.setContextValue(jn,!1),this._contextService.setContextValue(Rn,!0),this._contextService.setContextValue(Wn,!1),this.setCurrentUnitForType(n)):this.focused instanceof yt?(this._contextService.setContextValue(Hn,!0),this._contextService.setContextValue(jn,!0),this._contextService.setContextValue(Rn,!1),this._contextService.setContextValue(Wn,!1),this.setCurrentUnitForType(n)):this.focused instanceof pi?(this._contextService.setContextValue(Hn,!0),this._contextService.setContextValue(jn,!1),this._contextService.setContextValue(Rn,!1),this._contextService.setContextValue(Wn,!0),this.setCurrentUnitForType(n)):(this._contextService.setContextValue(Hn,!1),this._contextService.setContextValue(jn,!1),this._contextService.setContextValue(Rn,!1),this._contextService.setContextValue(Wn,!1))}getFocusedUnit(){return this.focused}getUnitType(n){const r=this._getUnitById(n);return r?r[1]:$e.UNRECOGNIZED}disposeUnit(n){const r=this._getUnitById(n);if(!r)return!1;const[s,i]=r,o=this._unitsByType.get(i),a=o.indexOf(s);return o.splice(a,1),this._tryResetCurrentOnRemoval(n,i),this._tryResetFocusOnRemoval(n),this._unitDisposed$.next(s),!0}_tryResetCurrentOnRemoval(n,r){const s=this.getCurrentUnitForType(r);(s==null?void 0:s.getUnitId())===n&&(this._currentUnits.set(r,null),this._currentUnits$.next(this._currentUnits))}_tryResetFocusOnRemoval(n){var r;((r=this.focused)==null?void 0:r.getUnitId())===n&&this._focused$.next(null)}_getUnitById(n){for(const[r,s]of this._unitsByType){const i=s.find(o=>o.getUnitId()===n);if(i)return[i,r]}}};exports.UniverInstanceService=iE([To(0,je.Inject(je.Injector)),To(1,yn)],exports.UniverInstanceService);var Je=(e=>(e[e.Starting=0]="Starting",e[e.Ready=1]="Ready",e[e.Rendered=2]="Rendered",e[e.Steady=3]="Steady",e))(Je||{});const oE={0:"Starting",1:"Ready",2:"Rendered",3:"Steady"};var aE=Object.getOwnPropertyDescriptor,lE=(e,t,n,r)=>{for(var s=r>1?void 0:r?aE(t,n):t,i=e.length-1,o;i>=0;i--)(o=e[i])&&(s=o(s)||s);return s},uE=(e,t)=>(n,r)=>t(n,r,e);exports.LifecycleService=class extends rt{constructor(n){super();C(this,"_lifecycle$",new we.BehaviorSubject(Je.Starting));C(this,"lifecycle$",this._lifecycle$.asObservable());C(this,"_lock",!1);this._logService=n,this._reportProgress(Je.Starting)}get stage(){return this._lifecycle$.getValue()}set stage(n){if(this._lock)throw new Error("[LifecycleService]: cannot set new stage when related logic is all handled!");if(n<this.stage)throw new Error("[LifecycleService]: lifecycle stage cannot go backward!");n!==this.stage&&(this._lock=!0,this._reportProgress(n),this._lifecycle$.next(n),this._lock=!1)}dispose(){this._lifecycle$.complete(),super.dispose()}onStage(n){return we.firstValueFrom(this.lifecycle$.pipe(we.filter(r=>r>=n),Os(r=>r===n),we.map(()=>{})))}subscribeWithPrevious(){return we.merge(Au(this.stage),this._lifecycle$.pipe(we.skip(1))).pipe(Os(n=>n===Je.Steady))}_reportProgress(n){this._logService.debug("[LifecycleService]",`lifecycle progressed to "${oE[n]}".`)}};exports.LifecycleService=lE([uE(0,vt)],exports.LifecycleService);function Au(e){switch(e){case Je.Starting:return we.of(Je.Starting);case Je.Ready:return we.of(Je.Starting,Je.Ready);case Je.Rendered:return we.of(Je.Starting,Je.Ready,Je.Rendered);default:return we.of(Je.Starting,Je.Ready,Je.Rendered,Je.Steady)}}const cE=je.createIdentifier("ILocalStorageService");class sn extends rt{constructor(){super();C(this,"_currentLocale$",new we.BehaviorSubject(rr.ZH_CN));C(this,"currentLocale$",this._currentLocale$.asObservable());C(this,"_locales",null);C(this,"localeChanged$",new we.Subject);C(this,"t",(n,...r)=>{if(!this._locales)throw new Error("[LocaleService]: Locale not initialized");const s=n.split("."),i=this.resolveKeyPath(this._locales[this._currentLocale],s);if(typeof i=="string"){let o=i;return r.forEach((a,l)=>{o=o.replace(`{${l}}`,a)}),o}else return n});this.disposeWithMe(nt(()=>this.localeChanged$.complete()))}get _currentLocale(){return this._currentLocale$.value}load(n){var r;this._locales=li((r=this._locales)!=null?r:{},n)}setLocale(n){this._currentLocale$.next(n),this.localeChanged$.next()}getLocales(){var n;return(n=this._locales)==null?void 0:n[this._currentLocale]}getCurrentLocale(){return this._currentLocale}resolveKeyPath(n,r){const s=r.shift();if(s&&n&&s in n){const i=n[s];return r.length>0&&(typeof i=="object"||Array.isArray(i))?this.resolveKeyPath(i,r):i}return null}}var Ei=(e=>(e.INIT="init",e.FETCHING="fetching",e.DONE="done",e))(Ei||{});const Tu=je.createIdentifier("univer.permission-service");class Nu extends rt{constructor(){super(...arguments);C(this,"_permissionPointMap",new Map);C(this,"_permissionPointUpdate$",new we.Subject);C(this,"permissionPointUpdate$",this._permissionPointUpdate$.asObservable());C(this,"_showComponents",!0)}setShowComponents(n){this._showComponents=n}getShowComponents(){return this._showComponents}deletePermissionPoint(n){const r=this._permissionPointMap.get(n);r&&(r.complete(),this._permissionPointMap.delete(n))}addPermissionPoint(n){const r=n instanceof we.BehaviorSubject,s=r?n.getValue():n;if(!s.id)return!1;if(this._permissionPointMap.get(s.id))throw new Error(`${s.id} PermissionPoint already exists`);return this._permissionPointMap.set(s.id,r?n:new we.BehaviorSubject(s)),this._permissionPointUpdate$.next(s),!0}updatePermissionPoint(n,r){const s=this._permissionPointMap.get(n);if(!s)return;const i=s.getValue();i.value=r,i.status=Ei.DONE,s.next(i),this._permissionPointUpdate$.next(i)}clearPermissionMap(){this._permissionPointMap.clear()}getPermissionPoint(n){const r=this._permissionPointMap.get(n);if(r)return r.getValue()}getPermissionPoint$(n){const r=this._permissionPointMap.get(n);if(r)return r}composePermission$(n){const r=n.map(s=>{var o;const i=(o=this._permissionPointMap)==null?void 0:o.get(s);if(!i)throw new Error(`[PermissionService]: ${s} permissionPoint does not exist!`);return i.asObservable()});return we.combineLatest(r).pipe(wr.map(s=>s))}composePermission(n){return n.map(s=>{var o;const i=(o=this._permissionPointMap)==null?void 0:o.get(s);if(!i)throw new Error(`[PermissionService]: ${s} permissionPoint does not exist!`);return i.getValue()})}getAllPermissionPoint(){const n=new Map;return this._permissionPointMap.forEach((r,s)=>{n.set(s,r)}),n}}var hE=Object.getOwnPropertyDescriptor,dE=(e,t,n,r)=>{for(var s=r>1?void 0:r?hE(t,n):t,i=e.length-1,o;i>=0;i--)(o=e[i])&&(s=o(s)||s);return s},Cs=(e,t)=>(n,r)=>t(n,r,e);const fE=4,Mu=Symbol("DependentOn");class Ws extends rt{onStarting(){}onReady(){}onRendered(){}onSteady(){}getUnitType(){return this.constructor.type}getPluginName(){return this.constructor.pluginName}}C(Ws,"pluginName"),C(Ws,"type",$e.UNIVER_UNKNOWN);class gE{constructor(){C(this,"_plugins",[])}addPlugin(t){this._plugins.push(t)}removePlugins(){const t=this._plugins.slice();return this._plugins.length=0,t}forEachPlugin(t){this._plugins.forEach(t)}}function mE(...e){return function(t){t[Mu]=e}}exports.PluginService=class{constructor(t,n,r){C(this,"_pluginRegistry",new Map);C(this,"_pluginStore",new gE);C(this,"_seenPlugins",new Set);C(this,"_loadedPlugins",new Set);C(this,"_loadedPluginTypes",new Set([$e.UNIVER_UNKNOWN]));C(this,"_flushTimerByType",new Map);this._injector=t,this._lifecycleService=n,this._logService=r}dispose(){this._pluginStore.removePlugins().forEach(t=>t.dispose()),this._flushTimerByType.forEach(t=>clearTimeout(t))}registerPlugin(t,n){this._assertPluginValid(t);const r={plugin:t,options:n};this._pluginRegistry.set(t.pluginName,r),this._logService.debug("[PluginService]",`Plugin "${t.pluginName}" registered.`);const{type:s}=t;this._loadedPluginTypes.has(s)&&(s===$e.UNIVER_UNKNOWN?this._loadFromPlugins([r]):this._flushType(s))}startPluginsForType(t){this._loadedPluginTypes.has(t)||this._loadPluginsForType(t)}_loadPluginsForType(t){const n=Array.from(this._pluginRegistry.keys()),r=[];n.forEach(s=>{const i=this._pluginRegistry.get(s);i.plugin.type===t&&r.push(i)}),this._loadFromPlugins(r),this._loadedPluginTypes.add(t)}_assertPluginValid(t){const{type:n,pluginName:r}=t;if(n===$e.UNRECOGNIZED)throw new Error(`[PluginService]: invalid plugin type for ${t.name}. Please assign a "type" to your plugin.`);if(!r)throw new Error(`[PluginService]: no plugin name for ${t.name}. Please assign a "pluginName" to your plugin.`);if(this._seenPlugins.has(r))throw new Error(`[PluginService]: duplicated plugin name for "${r}". Maybe a plugin that dependents on "${r} has already registered it. In that case please register "${r}" before the that plugin.`);this._seenPlugins.add(t.pluginName)}_flushType(t){this._flushTimerByType.get(t)===void 0&&this._flushTimerByType.set(t,setTimeout(()=>{this._loadPluginsForType(t),this._flushTimerByType.delete(t)},fE))}_loadFromPlugins(t){const n=[],r=new Set,s=o=>{const{plugin:a}=o,{pluginName:l}=a;if(this._loadedPlugins.has(l)||r.has(l))return;r.add(l),this._pluginRegistry.delete(l);const u=a[Mu];u&&u.forEach(c=>{const h=this._pluginRegistry.get(c.pluginName);if(h)s(h);else if(!this._seenPlugins.has(c.pluginName)&&!r.has(c.pluginName)){if(a.type===$e.UNIVER_UNKNOWN&&c.type!==$e.UNIVER_UNKNOWN)throw new Error(`[PluginService]: cannot register a plugin with Univer type that depends on a plugin with other type. The dependent is ${a.pluginName} and the dependency is ${c.pluginName}.`);a.type!==c.type&&c.type!==$e.UNIVER_UNKNOWN&&this._logService.debug("[PluginService]",`Plugin "${l}" depends on "${c.pluginName}" which has different type.`),this._logService.debug("[PluginService]",`Plugin "${l}" depends on "${c.pluginName}" which is not registered. Univer will automatically register it with default configuration.`),this._assertPluginValid(c),s({plugin:c,options:void 0})}}),n.push(o)};t.forEach(o=>s(o));const i=n.map(o=>this._initPlugin(o.plugin,o.options));this._pluginsRunLifecycle(i)}_pluginsRunLifecycle(t){const n=this._lifecycleService.stage;if(Au(n).subscribe(r=>this._runStage(t,r)),n!==Je.Steady){const r=this._lifecycleService.lifecycle$.pipe(we.skip(1)).subscribe(s=>{this._runStage(t,s),s===Je.Steady&&r.unsubscribe()})}}_runStage(t,n){t.forEach(r=>{switch(n){case Je.Starting:r.onStarting();break;case Je.Ready:r.onReady();break;case Je.Rendered:r.onRendered();break;case Je.Steady:r.onSteady();break}})}_initPlugin(t,n){const r=this._injector.createInstance(t,n);return this._pluginStore.addPlugin(r),this._loadedPlugins.add(t.pluginName),this._logService.debug("[PluginService]",`Plugin "${r.getPluginName()}" loaded.`),r}};exports.PluginService=dE([Cs(0,je.Inject(je.Injector)),Cs(1,je.Inject(exports.LifecycleService)),Cs(2,vt)],exports.PluginService);function Du(e,t){if(!t)return e;const n=[];for(const r of e){const s=t.find(([i])=>i===r[0]);if(s){if(s[1]===null)continue;n.push([r[0],s[1]])}else n.push(r)}return n}const Ys=je.createIdentifier("resource-loader-service");class Lu extends rt{constructor(){super(...arguments);C(this,"_resourceMap",new Map);C(this,"_register$",new we.Subject);C(this,"register$",this._register$.asObservable())}getAllResourceHooks(){return[...this._resourceMap.values()]}getResources(n,r){return r?this.getResourcesByType(n,r):this.getAllResourceHooks().map(o=>{const a=o.toJson(n);return{name:o.pluginName,data:a}})}getResourcesByType(n,r){return this.getAllResourceHooks().filter(o=>o.businesses.includes(r)).map(o=>{const a=o.toJson(n);return{name:o.pluginName,data:a}})}registerPluginResource(n){const r=n.pluginName;if(this._resourceMap.has(r))throw new Error(`the pluginName is registered {${r}}`);return this._resourceMap.set(r,n),this._register$.next(n),nt(()=>this._resourceMap.delete(r))}disposePluginResource(n){this._resourceMap.delete(n)}loadResources(n,r){this.getAllResourceHooks().forEach(s=>{var o;const i=(o=r==null?void 0:r.find(a=>a.name===s.pluginName))==null?void 0:o.data;if(i)try{const a=s.parseJson(i);s.onLoad(n,a)}catch{console.error("LoadResources Error!")}})}unloadResources(n){this.getAllResourceHooks().forEach(r=>{r.onUnLoad(n)})}dispose(){this._register$.complete(),this._resourceMap.clear()}}class Ci extends rt{constructor(){super();C(this,"_currentTheme");C(this,"_currentTheme$",new we.BehaviorSubject({}));C(this,"currentTheme$",this._currentTheme$.asObservable());this.disposeWithMe(nt(()=>this._currentTheme$.complete()))}getCurrentTheme(){if(!this._currentTheme)throw new Error("[ThemeService]: current theme is not set!");return this._currentTheme}setTheme(n){this._currentTheme=n,this._currentTheme$.next(n)}}var _E=Object.getOwnPropertyDescriptor,pE=(e,t,n,r)=>{for(var s=r>1?void 0:r?_E(t,n):t,i=e.length-1,o;i>=0;i--)(o=e[i])&&(s=o(s)||s);return s},Rs=(e,t)=>(n,r)=>t(n,r,e);const is=je.createIdentifier("univer.undo-redo.service"),EE=20;class xu{dispose(){}async dispatchToHandlers(){return!1}}const Uu="univer.command.redo",ku="univer.command.undo",Pu=new class extends xu{constructor(){super(...arguments);C(this,"type",tr.COMMAND);C(this,"id",ku)}handler(t){const n=t.get(is),r=n.pitchTopUndoElement();if(!r)return!1;const s=t.get(nr);return Kr(r.undoMutations,s)?(n.popUndoToRedo(),!0):!1}},Fu=new class extends xu{constructor(){super(...arguments);C(this,"type",tr.COMMAND);C(this,"id",Uu)}handler(t){const n=t.get(is),r=n.pitchTopRedoElement();if(!r)return!1;const s=t.get(nr);return Kr(r.redoMutations,s)?(n.popRedoToUndo(),!0):!1}};exports.LocalUndoRedoService=class extends rt{constructor(n,r,s){super();C(this,"undoRedoStatus$");C(this,"_undoRedoStatus$",new we.BehaviorSubject({undos:0,redos:0}));C(this,"_undoStacks",new Map);C(this,"_redoStacks",new Map);C(this,"_batchingStatus",new Map);this._univerInstanceService=n,this._commandService=r,this._contextService=s,this.undoRedoStatus$=this._undoRedoStatus$.asObservable(),this.disposeWithMe(this._commandService.registerCommand(Pu)),this.disposeWithMe(this._commandService.registerCommand(Fu)),this.disposeWithMe(nt(()=>this._undoRedoStatus$.complete())),this.disposeWithMe(nt(this._univerInstanceService.focused$.subscribe(()=>this._updateStatus())))}pushUndoRedo(n){const{unitID:r}=n,s=this._getRedoStack(r,!0),i=this._getUndoStack(r,!0);if(s.length=0,this._batchingStatus.has(n.unitID)){const a=this._batchingStatus.get(n.unitID),l=this._pitchUndoElement(n.unitID);a===0||!l?(o(n),this._batchingStatus.set(n.unitID,1)):this._tryBatchingElements(l,n)}else o(n);function o(a){i.push(a),i.length>EE&&i.splice(0,1)}this._updateStatus()}clearUndoRedo(n){const r=this._getRedoStack(n);r&&(r.length=0);const s=this._getUndoStack(n);s&&(s.length=0),this._updateStatus()}pitchTopUndoElement(){const n=this._getFocusedUnitId();return this._pitchUndoElement(n)}pitchTopRedoElement(){const n=this._getFocusedUnitId();return this._pitchRedoElement(n)}_pitchUndoElement(n){const r=this._getUndoStack(n);return r!=null&&r.length?r[r.length-1]:null}_pitchRedoElement(n){const r=this._getRedoStack(n);return r!=null&&r.length?r[r.length-1]:null}popUndoToRedo(){const r=this._getUndoStackForFocused().pop();r&&(this._getRedoStackForFocused().push(r),this._updateStatus())}popRedoToUndo(){const r=this._getRedoStackForFocused().pop();r&&(this._getUndoStackForFocused().push(r),this._updateStatus())}rollback(n,r){const s=r||this._getFocusedUnitId(),i=this._getUndoStack(s),o=i==null?void 0:i[(i==null?void 0:i.length)-1];o&&o.id===n&&(i.pop(),Kr(o.undoMutations,this._commandService))}__tempBatchingUndoRedo(n){if(this._batchingStatus.has(n))throw new Error("[LocalUndoRedoService]: cannot batching undo redo twice at the same time!");return this._batchingStatus.set(n,0),nt(()=>this._batchingStatus.delete(n))}_updateStatus(){var i,o;const n=this._getFocusedUnitId(),r=n&&((i=this._undoStacks.get(n))==null?void 0:i.length)||0,s=n&&((o=this._redoStacks.get(n))==null?void 0:o.length)||0;this._undoRedoStatus$.next({undos:r,redos:s})}_getUndoStack(n,r=!1){let s=this._undoStacks.get(n);return!s&&r&&(s=[],this._undoStacks.set(n,s)),s||null}_getRedoStack(n,r=!1){let s=this._redoStacks.get(n);return!s&&r&&(s=[],this._redoStacks.set(n,s)),s||null}_getUndoStackForFocused(){const n=this._getFocusedUnitId();if(!n)throw new Error("No focused univer instance!");return this._getUndoStack(n,!0)}_getRedoStackForFocused(){const n=this._getFocusedUnitId();if(!n)throw new Error("No focused univer instance!");return this._getRedoStack(n,!0)}_tryBatchingElements(n,r){n.redoMutations.push(...r.redoMutations),n.undoMutations.push(...r.undoMutations)}_getFocusedUnitId(){var o,a,l,u;let n="";const r=this._contextService.getContextValue(Rn),s=this._contextService.getContextValue(fu),i=this._contextService.getContextValue(du);return r?s?n=Js:i?n=qs:n=(a=(o=this._univerInstanceService.getFocusedUnit())==null?void 0:o.getUnitId())!=null?a:"":n=(u=(l=this._univerInstanceService.getFocusedUnit())==null?void 0:l.getUnitId())!=null?u:"",n}};exports.LocalUndoRedoService=pE([Rs(0,bn),Rs(1,nr),Rs(2,yn)],exports.LocalUndoRedoService);function CE(e){return!(e.length===0||e.length>31||e.startsWith("'")||e.endsWith("'")||/[:\\\/\?\*\[\]]/.test(e))}function RE(e){return new Promise(t=>setTimeout(t,e))}function IE(e=1){return new Promise(t=>{let n=0;const r=()=>{n++,n>=e?t():requestAnimationFrame(r)};requestAnimationFrame(r)})}var Ri=(e=>(e.URL="URL",e.UUID="UUID",e.BASE64="BASE64",e))(Ri||{}),$u=(e=>(e.SUCCUSS="0",e.ERROR_EXCEED_SIZE="1",e.ERROR_IMAGE_TYPE="2",e.ERROR_UPLOAD_COUNT_LIMIT="3",e.ERROR_IMAGE="4",e))($u||{});const zs=je.createIdentifier("core.image-io.service");class Bu{constructor(t,n=100){C(this,"_imageCacheMap");this._injector=t,this._imageCacheMap=new Xn(n)}_getImageCacheKey(t,n){return`${t}-${n}`}getImage(t,n,r,s){const i=this._getImageCacheKey(t,n);let o=this._imageCacheMap.get(i);return o||((async()=>{o=new Image;const a=this._injector.has(zs)?this._injector.get(zs):null;if(t===Ri.UUID)try{o.src=await(a==null?void 0:a.getImage(n))||""}catch(l){console.error(l)}else o.src=n;o.onload=()=>{r==null||r()},o.onerror=()=>{s==null||s()},this._imageCacheMap.set(i,o)})(),null)}}const SE=["script","style","meta","comment","link"];var Hu=(e=>(e[e.INFO=0]="INFO",e[e.STOP=1]="STOP",e[e.WARNING=2]="WARNING",e))(Hu||{}),ju=(e=>(e[e.DISABLED=0]="DISABLED",e[e.FULL_ALPHA=1]="FULL_ALPHA",e[e.FULL_HANGUL=2]="FULL_HANGUL",e[e.FULL_KATAKANA=3]="FULL_KATAKANA",e[e.HALF_ALPHA=4]="HALF_ALPHA",e[e.HALF_HANGUL=5]="HALF_HANGUL",e[e.HALF_KATAKANA=6]="HALF_KATAKANA",e[e.HIRAGANA=7]="HIRAGANA",e[e.NO_CONTROL=8]="NO_CONTROL",e[e.OFF=9]="OFF",e[e.ON=10]="ON",e))(ju||{}),Wu=(e=>(e.BETWEEN="between",e.EQUAL="equal",e.GREATER_THAN="greaterThan",e.GREATER_THAN_OR_EQUAL="greaterThanOrEqual",e.LESS_THAN="lessThan",e.LESS_THAN_OR_EQUAL="lessThanOrEqual",e.NOT_BETWEEN="notBetween",e.NOT_EQUAL="notEqual",e))(Wu||{}),Yu=(e=>(e[e.TEXT=0]="TEXT",e[e.ARROW=1]="ARROW",e[e.CUSTOM=2]="CUSTOM",e))(Yu||{}),zu=(e=>(e.VALID="valid",e.INVALID="invalid",e.VALIDATING="validating",e))(zu||{}),Vu=(e=>(e.CUSTOM="custom",e.LIST="list",e.LIST_MULTIPLE="listMultiple",e.NONE="none",e.TEXT_LENGTH="textLength",e.DATE="date",e.TIME="time",e.WHOLE="whole",e.DECIMAL="decimal",e.CHECKBOX="checkbox",e.ANY="any",e))(Vu||{}),vE=Object.getOwnPropertyDescriptor,OE=(e,t,n,r)=>{for(var s=r>1?void 0:r?vE(t,n):t,i=e.length-1,o;i>=0;i--)(o=e[i])&&(s=o(s)||s);return s},wE=(e,t)=>(n,r)=>t(n,r,e);exports.Skeleton=class extends rt{constructor(n){super();C(this,"_fontLocale");C(this,"_dirty",!0);this._localeService=n,this._localeInitial()}get dirty(){return this._dirty}getFontLocale(){return this._fontLocale}makeDirty(n){this._dirty=n}dispose(){super.dispose(),this._fontLocale=null}_localeInitial(){}};exports.Skeleton=OE([wE(0,je.Inject(sn))],exports.Skeleton);var bE=Object.getOwnPropertyDescriptor,yE=(e,t,n,r)=>{for(var s=r>1?void 0:r?bE(t,n):t,i=e.length-1,o;i>=0;i--)(o=e[i])&&(s=o(s)||s);return s},Or=(e,t)=>(n,r)=>t(n,r,e);exports.SheetSkeleton=class extends exports.Skeleton{constructor(n,r,s,i,o,a){super(s);C(this,"_worksheetData");C(this,"_renderRawFormula",!1);C(this,"_cellData");C(this,"_imageCacheMap");C(this,"_isRowStylePrecedeColumnStyle",!1);C(this,"_skipAutoHeightForMergedCells",!0);C(this,"_rowTotalHeight",0);C(this,"_columnTotalWidth",0);C(this,"_rowHeaderWidth",0);C(this,"_columnHeaderHeight",0);C(this,"_rowHeightAccumulation",[]);C(this,"_columnWidthAccumulation",[]);C(this,"_marginTop",0);C(this,"_marginLeft",0);C(this,"_scaleX");C(this,"_scaleY");C(this,"_scrollX");C(this,"_scrollY");this.worksheet=n,this._styles=r,this._contextService=i,this._configService=o,this._injector=a,this._worksheetData=this.worksheet.getConfig(),this._cellData=this.worksheet.getCellMatrix(),this._imageCacheMap=new Bu(this._injector),this.initConfig()}initConfig(){var n,r;this._skipAutoHeightForMergedCells=!((n=this._configService.getConfig(ba))!=null&&n),this._isRowStylePrecedeColumnStyle=(r=this._configService.getConfig(wa))!=null?r:!1}resetCache(){}getWorksheetConfig(){return this._worksheetData}getLocation(){return[this.worksheet.getUnitId(),this.worksheet.getSheetId()]}set columnHeaderHeight(n){this._columnHeaderHeight=n,this._worksheetData.columnHeader.height=n}set rowHeaderWidth(n){this._rowHeaderWidth=n,this._worksheetData.rowHeader.width=n}get rowHeightAccumulation(){return this._rowHeightAccumulation}get rowTotalHeight(){return this._rowTotalHeight}get columnWidthAccumulation(){return this._columnWidthAccumulation}get columnTotalWidth(){return this._columnTotalWidth}get rowHeaderWidth(){return this._rowHeaderWidth}get columnHeaderHeight(){return this._columnHeaderHeight}setMarginLeft(n){this._marginLeft=n}setMarginTop(n){this._marginTop=n}setScale(n,r){this._updateLayout(),this._scaleX=n,this._scaleY=r||n,this._updateLayout()}setScroll(n,r){re.isDefine(n)&&(this._scrollX=n),re.isDefine(r)&&(this._scrollY=r)}get scrollX(){return this._scrollX}get scrollY(){return this._scrollY}get scaleX(){return this._scaleX}get scaleY(){return this._scaleY}get rowHeaderWidthAndMarginLeft(){return this.rowHeaderWidth+this._marginLeft}get columnHeaderHeightAndMarginTop(){return this.columnHeaderHeight+this._marginTop}get imageCacheMap(){return this._imageCacheMap}_generateRowMatrixCache(n,r,s){let i=0;const o=[],a=r;for(let l=0;l<n;l++){let u=s;if(this.worksheet.getRowFiltered(l))u=0;else if(a[l]!=null){const c=a[l];if(!c)continue;const{h=s,ah:d,ia:f}=c;(f==null||f===Ie.TRUE)&&typeof d=="number"?u=d:u=h,c.hd===Ie.TRUE&&(u=0)}i+=u,o.push(i)}return{rowTotalHeight:i,rowHeightAccumulation:o}}_generateColumnMatrixCache(n,r,s){let i=0;const o=[],a=r;for(let l=0;l<n;l++){let u=s;if(a[l]!=null){const c=a[l];if(!c)continue;c.w!=null&&(u=c.w),c.hd===Ie.TRUE&&(u=0)}i+=u,o.push(i)}return{columnTotalWidth:i,columnWidthAccumulation:o}}intersectMergeRange(n,r){return!!this.worksheet.getMergedCell(n,r)}_getOverflowBound(n,r,s,i,o=Ot.LEFT){let a=0;if(r>s){const l=this._columnWidthAccumulation.length-1;for(let u=r;u>=s;u--){const c=u,h=this.worksheet.getCell(n,c);if(!As(h)&&c!==r||this.intersectMergeRange(n,c))return c===r?c:c+1>l?l:c+1;const{startX:d,endX:f}=_n(n,c,this.rowHeightAccumulation,this.columnWidthAccumulation);if(o===Ot.CENTER&&c===r?a+=(f-d)/2:a+=f-d,i<a)return c}return r}for(let l=r;l<=s;l++){const u=l,c=this.worksheet.getCell(n,u);if(!As(c)&&u!==r||this.intersectMergeRange(n,u))return u===r?u:u-1<0?0:u-1;const{startX:h,endX:d}=_n(n,u,this.rowHeightAccumulation,this.columnWidthAccumulation);if(o===Ot.CENTER&&u===r?a+=(d-h)/2:a+=d-h,i<a)return u}return s}_updateLayout(){if(!this.dirty)return;const{rowData:n,columnData:r,defaultRowHeight:s,defaultColumnWidth:i,rowCount:o,columnCount:a,rowHeader:l,columnHeader:u}=this._worksheetData,{rowTotalHeight:c,rowHeightAccumulation:h}=this._generateRowMatrixCache(o,n,s),{columnTotalWidth:d,columnWidthAccumulation:f}=this._generateColumnMatrixCache(a,r,i);this._rowHeaderWidth=l.hidden!==Ie.TRUE?this._dynamicallyUpdateRowHeaderWidth(l):0,this._columnHeaderHeight=u.hidden!==Ie.TRUE?u.height:0,this._rowTotalHeight=c,this._rowHeightAccumulation=h,this._columnTotalWidth=d,this._columnWidthAccumulation=f,this.makeDirty(!1)}calculate(){return this.resetCache(),this._updateLayout(),this}resetRangeCache(n){}_dynamicallyUpdateRowHeaderWidth(n){const s=`${this.worksheet.getRowCount()}`.length*8;return Math.max(n.width,s)}_hasUnMergedCellInRow(n,r,s){if(!this.worksheet.getMergeData())return!1;for(let o=r;o<=s;o++){const{isMerged:a,isMergedMainCell:l}=this.worksheet.getCellInfoInMergeData(n,o);if(!a&&!l)return!0}return!1}expandRangeByMerge(n){let{startRow:r,startColumn:s,endRow:i,endColumn:o}=n;const a=this._worksheetData.mergeData;if(!a)return{startRow:r,startColumn:s,endRow:i,endColumn:o};let l=!0;const u=new wt;for(;l;){l=!1;for(let c=0;c<a.length;c++){const{startRow:h,startColumn:d,endRow:f,endColumn:E}=a[c];if(u.getValue(h,d))continue;Ma({startColumn:s,startRow:r,endColumn:o,endRow:i},{startColumn:d,startRow:h,endColumn:E,endRow:f})&&(r=Math.min(r,h),s=Math.min(s,d),i=Math.max(i,f),o=Math.max(o,E),u.setValue(h,d,!0),l=!0)}}return{startRow:r,startColumn:s,endRow:i,endColumn:o}}getColumnCount(){return this._columnWidthAccumulation.length}getRowCount(){return this._rowHeightAccumulation.length}_getCellMergeInfo(n,r){return this.worksheet.getCellInfoInMergeData(n,r)}getNoMergeCellPositionByIndex(n,r,s=!0){return this.getNoMergeCellWithCoordByIndex(n,r,s)}getNoMergeCellWithCoordByIndex(n,r,s=!0){const{rowHeightAccumulation:i,columnWidthAccumulation:o,rowHeaderWidthAndMarginLeft:a,columnHeaderHeightAndMarginTop:l}=this;let{startY:u,endY:c,startX:h,endX:d}=_n(n,r,i,o);return s&&(u+=l,c+=l,h+=a,d+=a),{startY:u,endY:c,startX:h,endX:d}}getNoMergeCellPositionByIndexWithNoHeader(n,r){const{rowHeightAccumulation:s,columnWidthAccumulation:i}=this,{startY:o,endY:a,startX:l,endX:u}=_n(n,r,s,i);return{startY:o,endY:a,startX:l,endX:u}}getRowIndexByOffsetY(n,r,s,i){var l;const{rowHeightAccumulation:o}=this;n=Ku(n,r,s,this.columnHeaderHeightAndMarginTop);let a=kn(o,n,i==null?void 0:i.firstMatch);return i!=null&&i.closeFirst&&Math.abs(o[a]-n)<Math.abs(n-((l=o[a-1])!=null?l:0))&&(a=a+1),a}getColumnIndexByOffsetX(n,r,s,i){var u;const o=Gu(n,r,s,this.rowHeaderWidthAndMarginLeft),{columnWidthAccumulation:a}=this;let l=kn(a,o,i==null?void 0:i.firstMatch);return i!=null&&i.closeFirst&&Math.abs(a[l]-o)<Math.abs(o-((u=a[l-1])!=null?u:0))&&(l=l+1),l}getCellIndexByOffset(n,r,s,i,o,a){const l=this.getRowIndexByOffsetY(r,i,o,a),u=this.getColumnIndexByOffsetX(n,s,o,a);return{row:l,column:u}}getCellByOffset(n,r,s,i,o){const a=this==null?void 0:this.getCellIndexByOffset(n,r,s,i,o,{firstMatch:!0});return a?this.worksheet.getCellInfoInMergeData(a.row,a.column):null}getCellWithCoordByIndex(n,r,s=!0){const{rowHeightAccumulation:i,columnWidthAccumulation:o,rowHeaderWidthAndMarginLeft:a,columnHeaderHeightAndMarginTop:l}=this,u=_n(n,r,i,o,this.worksheet.getCellInfoInMergeData(n,r)),{isMerged:c,isMergedMainCell:h}=u;let{startY:d,endY:f,startX:E,endX:R,mergeInfo:w}=u,L=a,J=l;return s===!1&&(L=0,J=0),d+=J,f+=J,E+=L,R+=L,w.startY+=J,w.endY+=J,w.startX+=L,w.endX+=L,{actualRow:n,actualColumn:r,startX:E,startY:d,endX:R,endY:f,isMerged:c,isMergedMainCell:h,mergeInfo:w}}getCellWithCoordByOffset(n,r,s,i,o,a){const{row:l,column:u}=this.getCellIndexByOffset(n,r,s,i,o,a);return this.getCellWithCoordByIndex(l,u)}getOffsetByColumn(n){const{columnWidthAccumulation:r,rowHeaderWidthAndMarginLeft:s}=this,i=r.length-1,o=r[n];return o!=null?o+s:n<0?s:r[i]+s}getOffsetByRow(n){const{rowHeightAccumulation:r,columnHeaderHeightAndMarginTop:s}=this,i=r.length-1,o=r[n];return o!=null?o+s:n<0?s:r[i]+s}getOffsetRelativeToRowCol(n,r){const s=kn(this.columnWidthAccumulation,n);let i=0;s===0?i=n:i=n-this._columnWidthAccumulation[s-1];const o=kn(this.rowHeightAccumulation,r);let a=0;return o===0?a=r:a=r-this._rowHeightAccumulation[o-1],{row:o,column:s,columnOffset:i,rowOffset:a}}_updateConfigAndGetDocumentModel(n,r,s,i){var a,l,u,c,h;if(!i||!((a=n.body)!=null&&a.dataStream))return;n.documentStyle||(n.documentStyle={}),n.documentStyle.marginTop=(l=s.t)!=null?l:0,n.documentStyle.marginBottom=(u=s.b)!=null?u:2,n.documentStyle.marginLeft=(c=s.l)!=null?c:2,n.documentStyle.marginRight=(h=s.r)!=null?h:2,n.documentStyle.pageSize={width:Number.POSITIVE_INFINITY,height:Number.POSITIVE_INFINITY},n.documentStyle.renderConfig={...n.documentStyle.renderConfig,...i};const o=n.body.paragraphs||[];for(const d of o)d.paragraphStyle||(d.paragraphStyle={}),d.paragraphStyle.horizontalAlign=r;return new yt(n)}dispose(){super.dispose(),this._rowHeightAccumulation=[],this._columnWidthAccumulation=[],this._rowTotalHeight=0,this._columnTotalWidth=0,this._rowHeaderWidth=0,this._columnHeaderHeight=0,this._worksheetData=null,this._cellData=null,this._styles=null}};exports.SheetSkeleton=yE([Or(2,je.Inject(sn)),Or(3,yn),Or(4,_i),Or(5,je.Inject(je.Injector))],exports.SheetSkeleton);function Ii(e,t,n,r){const s=e-1,i=t-1,o=n[s]||0;let a=n[e];a==null&&(a=n[n.length-1]);const l=r[i]||0;let u=r[t];return u==null&&(u=r[r.length-1]),{startY:o,endY:a,startX:l,endX:u}}function AE(e,t,n,r){return Ii(e,t,n,r)}function _n(e,t,n,r,s){e=re.clamp(e,0,n.length-1),t=re.clamp(t,0,r.length-1);let{startY:i,endY:o,startX:a,endX:l}=Ii(e,t,n,r);if(!s)return{startY:i,endY:o,startX:a,endX:l,isMerged:!1,isMergedMainCell:!1,actualRow:e,actualColumn:t,mergeInfo:{startY:i,endY:o,startX:a,endX:l,startRow:e,startColumn:t,endRow:e,endColumn:t}};const{isMerged:u,isMergedMainCell:c,startRow:h,startColumn:d,endRow:f,endColumn:E}=s;let R={startRow:h,startColumn:d,endRow:f,endColumn:E,startY:i,endY:o,startX:a,endX:l};const w=n.length-1,L=r.length-1;if(u&&h!==-1&&d!==-1){const J=n[h-1]||0,z=n[f]||n[w],de=r[d-1]||0,N=r[E]||r[L];R={...R,startY:J,endY:z,startX:de,endX:N}}else if(!u&&f!==-1&&E!==-1){const J=n[f]||n[w],z=r[E]||r[L];R={...R,startY:i,endY:J,startX:a,endX:z}}return{isMerged:u,isMergedMainCell:c,actualRow:e,actualColumn:t,startY:i,endY:o,startX:a,endX:l,mergeInfo:R}}function Gu(e,t,n,r){const{x:s}=n;return e/t+s-r}function Ku(e,t,n,r){const{y:s}=n;return e=e/t+s-r,e}const No=[Int8Array,Uint8Array,Uint8ClampedArray,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array],Is=1,xn=8;class Si{static from(t){if(!(t instanceof ArrayBuffer))throw new Error("Data must be an instance of ArrayBuffer.");const[n,r]=new Uint8Array(t,0,2);if(n!==219)throw new Error("Data does not appear to be in a KDBush format.");const s=r>>4;if(s!==Is)throw new Error(`Got v${s} data when expected v${Is}.`);const i=No[r&15];if(!i)throw new Error("Unrecognized array type.");const[o]=new Uint16Array(t,2,1),[a]=new Uint32Array(t,4,1);return new Si(a,o,i,t)}constructor(t,n=64,r=Float64Array,s){if(isNaN(t)||t<0)throw new Error(`Unpexpected numItems value: ${t}.`);this.numItems=+t,this.nodeSize=Math.min(Math.max(+n,2),65535),this.ArrayType=r,this.IndexArrayType=t<65536?Uint16Array:Uint32Array;const i=No.indexOf(this.ArrayType),o=t*2*this.ArrayType.BYTES_PER_ELEMENT,a=t*this.IndexArrayType.BYTES_PER_ELEMENT,l=(8-a%8)%8;if(i<0)throw new Error(`Unexpected typed array class: ${r}.`);s&&s instanceof ArrayBuffer?(this.data=s,this.ids=new this.IndexArrayType(this.data,xn,t),this.coords=new this.ArrayType(this.data,xn+a+l,t*2),this._pos=t*2,this._finished=!0):(this.data=new ArrayBuffer(xn+o+a+l),this.ids=new this.IndexArrayType(this.data,xn,t),this.coords=new this.ArrayType(this.data,xn+a+l,t*2),this._pos=0,this._finished=!1,new Uint8Array(this.data,0,2).set([219,(Is<<4)+i]),new Uint16Array(this.data,2,1)[0]=n,new Uint32Array(this.data,4,1)[0]=t)}add(t,n){const r=this._pos>>1;return this.ids[r]=r,this.coords[this._pos++]=t,this.coords[this._pos++]=n,r}finish(){const t=this._pos>>1;if(t!==this.numItems)throw new Error(`Added ${t} items when expected ${this.numItems}.`);return Vs(this.ids,this.coords,this.nodeSize,0,this.numItems-1,0),this._finished=!0,this}range(t,n,r,s){if(!this._finished)throw new Error("Data not yet indexed - call index.finish().");const{ids:i,coords:o,nodeSize:a}=this,l=[0,i.length-1,0],u=[];for(;l.length;){const c=l.pop()||0,h=l.pop()||0,d=l.pop()||0;if(h-d<=a){for(let w=d;w<=h;w++){const L=o[2*w],J=o[2*w+1];L>=t&&L<=r&&J>=n&&J<=s&&u.push(i[w])}continue}const f=d+h>>1,E=o[2*f],R=o[2*f+1];E>=t&&E<=r&&R>=n&&R<=s&&u.push(i[f]),(c===0?t<=E:n<=R)&&(l.push(d),l.push(f-1),l.push(1-c)),(c===0?r>=E:s>=R)&&(l.push(f+1),l.push(h),l.push(1-c))}return u}within(t,n,r){if(!this._finished)throw new Error("Data not yet indexed - call index.finish().");const{ids:s,coords:i,nodeSize:o}=this,a=[0,s.length-1,0],l=[],u=r*r;for(;a.length;){const c=a.pop()||0,h=a.pop()||0,d=a.pop()||0;if(h-d<=o){for(let w=d;w<=h;w++)Mo(i[2*w],i[2*w+1],t,n)<=u&&l.push(s[w]);continue}const f=d+h>>1,E=i[2*f],R=i[2*f+1];Mo(E,R,t,n)<=u&&l.push(s[f]),(c===0?t-r<=E:n-r<=R)&&(a.push(d),a.push(f-1),a.push(1-c)),(c===0?t+r>=E:n+r>=R)&&(a.push(f+1),a.push(h),a.push(1-c))}return l}}function Vs(e,t,n,r,s,i){if(s-r<=n)return;const o=r+s>>1;Xu(e,t,o,r,s,i),Vs(e,t,n,r,o-1,1-i),Vs(e,t,n,o+1,s,1-i)}function Xu(e,t,n,r,s,i){for(;s>r;){if(s-r>600){const u=s-r+1,c=n-r+1,h=Math.log(u),d=.5*Math.exp(2*h/3),f=.5*Math.sqrt(h*d*(u-d)/u)*(c-u/2<0?-1:1),E=Math.max(r,Math.floor(n-c*d/u+f)),R=Math.min(s,Math.floor(n+(u-c)*d/u+f));Xu(e,t,n,E,R,i)}const o=t[2*n+i];let a=r,l=s;for(Un(e,t,r,n),t[2*s+i]>o&&Un(e,t,r,s);a<l;){for(Un(e,t,a,l),a++,l--;t[2*a+i]<o;)a++;for(;t[2*l+i]>o;)l--}t[2*r+i]===o?Un(e,t,r,l):(l++,Un(e,t,l,s)),l<=n&&(r=l+1),n<=l&&(s=l-1)}}function Un(e,t,n,r){Ss(e,n,r),Ss(t,2*n,2*r),Ss(t,2*n+1,2*r+1)}function Ss(e,t,n){const r=e[t];e[t]=e[n],e[n]=r}function Mo(e,t,n,r){const s=e-n,i=t-r;return s*s+i*i}class TE{constructor(t=!1){C(this,"_tree",new Map);C(this,"_oneCellCache",new Map);C(this,"_kdTree",new Map);this._enableOneCellCache=t}dispose(){this.clear()}getTree(t,n){return this._tree.has(t)||this._tree.set(t,new Map),this._tree.get(t).has(n)||this._tree.get(t).set(n,new jr),this._tree.get(t).get(n)}_getOneCellCache(t,n,r,s){return this._oneCellCache.has(t)||this._oneCellCache.set(t,new Map),this._oneCellCache.get(t).has(n)||this._oneCellCache.get(t).set(n,new Map),this._oneCellCache.get(t).get(n).has(r)||this._oneCellCache.get(t).get(n).set(r,new Map),this._oneCellCache.get(t).get(n).get(r).has(s)||this._oneCellCache.get(t).get(n).get(r).set(s,new Set),this._oneCellCache.get(t).get(n).get(r).get(s)}_removeOneCellCache(t,n,r,s,i){const o=this._oneCellCache.get(t);if(!o)return;const a=o.get(n);if(!a)return;const l=a.get(r);if(!l)return;const u=l.get(s);u&&u.delete(i)}_removeCellCacheByRange(t){const{unitId:n,sheetId:r,range:s,id:i}=t,o=this._oneCellCache.get(n);if(!o)return;const a=o.get(r);if(!a)return;const{startRow:l,startColumn:u,endRow:c,endColumn:h}=s;for(let d=l;d<=c;d++){const f=a.get(d);if(f)for(let E=u;E<=h;E++){const R=f.get(E);R&&R.delete(i)}}}_insertOneCellCache(t,n,r,s,i){this._getOneCellCache(t,n,r,s).add(i)}_getRdTreeItems(t){const n=[];for(const[r,s]of t)for(const[i,o]of s)n.push({x:i,y:r,ids:o});return n}_searchByOneCellCache(t){var E;const{unitId:n,sheetId:r,range:s}=t,{startRow:i,startColumn:o,endRow:a,endColumn:l}=s,u=(E=this._kdTree.get(n))==null?void 0:E.get(r);if(!u)return[];const{tree:c,items:h}=u,d=c.range(o,i,l,a),f=[];for(const R of d){const w=h[R];f.push(...Array.from(w.ids))}return f}openKdTree(){var t;for(const[n,r]of this._oneCellCache){this._kdTree.has(n)||this._kdTree.set(n,new Map);for(const[s,i]of r){const o=this._getRdTreeItems(i),a=new Si(o.length);(t=this._kdTree.get(n))==null||t.set(s,{tree:a,items:o});for(const l of o)a.add(l.x,l.y);a.finish()}}}closeKdTree(){var t;for(const[n,r]of this._oneCellCache)for(const[s,i]of r)(t=this._kdTree.get(n))==null||t.set(s,void 0)}insert(t){const{unitId:n,sheetId:r,range:s,id:i}=t;if(!n||n.length===0)return;let{startRow:o,endRow:a,startColumn:l,endColumn:u}=s;if(this._enableOneCellCache&&o===a&&l===u){this._insertOneCellCache(n,r,o,l,i);return}const c=this.getTree(n,r);Number.isNaN(o)&&(o=0),Number.isNaN(l)&&(l=0),Number.isNaN(a)&&(a=Number.POSITIVE_INFINITY),Number.isNaN(u)&&(u=Number.POSITIVE_INFINITY),c.insert({minX:l,minY:o,maxX:u,maxY:a,id:i})}bulkInsert(t){for(const n of t)this.insert(n)}*searchGenerator(t){var a;const{unitId:n,sheetId:r,range:s}=t;if(this._enableOneCellCache){const l=this._searchByOneCellCache(t);for(const u of l)yield u}const i=(a=this._tree.get(n))==null?void 0:a.get(r);if(!i)return;const o=i.search({minX:s.startColumn,minY:s.startRow,maxX:s.endColumn,maxY:s.endRow});for(const l of o)yield l.id}bulkSearch(t,n){const r=new Set;for(const s of t)for(const i of this.searchGenerator(s))(n==null?void 0:n.has(i))!==!0&&r.add(i);return r}removeById(t,n){var r,s;n?((r=this._tree.get(t))==null||r.delete(n),(s=this._oneCellCache.get(t))==null||s.delete(n)):(this._tree.delete(t),this._oneCellCache.delete(t))}_removeRTreeItem(t){const{unitId:n,sheetId:r,range:s,id:i}=t,o=this.getTree(n,r),a=o.search({minX:s.startColumn,minY:s.startRow,maxX:s.endColumn,maxY:s.endRow});for(let l=0;l<a.length;l++)a[l].id===i&&o.remove(a[l])}remove(t){const{unitId:n,sheetId:r,range:s,id:i}=t,{startRow:o,startColumn:a,endRow:l,endColumn:u}=s;this._enableOneCellCache?o===l&&a===u?this._removeOneCellCache(n,r,s.startRow,s.startColumn,i):(this._removeCellCacheByRange(t),this._removeRTreeItem(t)):this._removeRTreeItem(t)}bulkRemove(t){for(const n of t)this.remove(n)}clear(){this._tree.clear(),this._oneCellCache.clear()}toJSON(){const t={};return this._tree.forEach((n,r)=>{t[r]={},n.forEach((s,i)=>{t[r][i]=s.toJSON()})}),t}fromJSON(t){this._tree.clear();for(const n in t){this._tree.set(n,new Map);for(const r in t[n]){const s=new jr;s.fromJSON(t[n][r]),this._tree.get(n).set(r,s)}}}}var NE=Object.getOwnPropertyDescriptor,ME=(e,t,n,r)=>{for(var s=r>1?void 0:r?NE(t,n):t,i=e.length-1,o;i>=0;i--)(o=e[i])&&(s=o(s)||s);return s},Do=(e,t)=>(n,r)=>t(n,r,e);let Gs=class extends rt{constructor(e,t){super(),this._resourceManagerService=e,this._univerInstanceService=t,this._init()}_init(){const e=n=>{n.businesses.forEach(r=>{switch(r){case $e.UNRECOGNIZED:case $e.UNIVER_UNKNOWN:case $e.UNIVER_SLIDE:case $e.UNIVER_DOC:{this._univerInstanceService.getAllUnitsForType($e.UNIVER_DOC).forEach(s=>{const o=(s.getSnapshot().resources||[]).find(a=>a.name===n.pluginName);if(o)try{const a=n.parseJson(o.data);n.onLoad(s.getUnitId(),a)}catch{console.error(`Load Document{${s.getUnitId()}} Resources{${n.pluginName}} Data Error.`)}});break}case $e.UNIVER_SHEET:this._univerInstanceService.getAllUnitsForType($e.UNIVER_SHEET).forEach(s=>{const o=(s.getSnapshot().resources||[]).find(a=>a.name===n.pluginName);if(o)try{const a=n.parseJson(o.data);n.onLoad(s.getUnitId(),a)}catch{console.error(`Load Workbook{${s.getUnitId()}} Resources{${n.pluginName}} Data Error.`)}})}})};this._resourceManagerService.getAllResourceHooks().forEach(n=>e(n)),this.disposeWithMe(this._resourceManagerService.register$.subscribe(n=>e(n))),this.disposeWithMe(this._univerInstanceService.getTypeOfUnitAdded$($e.UNIVER_SHEET).subscribe(n=>{this._resourceManagerService.loadResources(n.getUnitId(),n.getSnapshot().resources)})),this.disposeWithMe(this._univerInstanceService.getTypeOfUnitAdded$($e.UNIVER_DOC).subscribe(n=>{const r=n.getUnitId();ya(r)||this._resourceManagerService.loadResources(n.getUnitId(),n.getSnapshot().resources)})),this.disposeWithMe(this._univerInstanceService.getTypeOfUnitDisposed$($e.UNIVER_SHEET).subscribe(n=>{this._resourceManagerService.unloadResources(n.getUnitId())})),this.disposeWithMe(this._univerInstanceService.getTypeOfUnitDisposed$($e.UNIVER_DOC).subscribe(n=>{this._resourceManagerService.unloadResources(n.getUnitId())}))}saveUnit(e){const t=this._univerInstanceService.getUnit(e);if(!t)return null;const n=this._resourceManagerService.getResources(e,t.type),r=re.deepClone(t.getSnapshot());return r.resources=n,r}};Gs=ME([Do(0,je.Inject(ss)),Do(1,je.Inject(bn))],Gs);class DE{constructor(t={},n){C(this,"_startedTypes",new Set);C(this,"_injector");C(this,"_disposingCallbacks",new Gr);const r=this._injector=LE(n,t==null?void 0:t.override),{theme:s,locale:i,locales:o,logLevel:a}=t;s&&this._injector.get(Ci).setTheme(s),o&&this._injector.get(sn).load(o),i&&this._injector.get(sn).setLocale(i),a&&this._injector.get(vt).setLogLevel(a),this._init(r)}get _univerInstanceService(){return this._injector.get(bn)}get _pluginService(){return this._injector.get(exports.PluginService)}__getInjector(){return this._injector}onDispose(t){const n=this._disposingCallbacks.add(nt(t));return nt(()=>n.dispose(!0))}dispose(){this._disposingCallbacks.dispose(),this._injector.dispose()}setLocale(t){this._injector.get(sn).setLocale(t)}createUnit(t,n){return this._univerInstanceService.createUnit(t,n)}createUniverSheet(t){return this._injector.get(vt).warn("[Univer]","Univer.createUniverSheet is deprecated, use createUnit instead"),this._univerInstanceService.createUnit($e.UNIVER_SHEET,t)}createUniverDoc(t){return this._injector.get(vt).warn("[Univer]","Univer.createUniverDoc is deprecated, use createUnit instead"),this._univerInstanceService.createUnit($e.UNIVER_DOC,t)}createUniverSlide(t){return this._injector.get(vt).warn("[Univer]","Univer.createUniverSlide is deprecated, use createUnit instead"),this._univerInstanceService.createUnit($e.UNIVER_SLIDE,t)}_init(t){this._univerInstanceService.registerCtorForType($e.UNIVER_SHEET,exports.Workbook),this._univerInstanceService.registerCtorForType($e.UNIVER_DOC,yt),this._univerInstanceService.registerCtorForType($e.UNIVER_SLIDE,pi);const n=t.get(bn);n.__setCreateHandler((r,s,i,o)=>{if(!this._startedTypes.has(r)){this._pluginService.startPluginsForType(r),this._startedTypes.add(r);const l=t.createInstance(i,s);return n.__addUnit(l,o),this._tryProgressToReady(),l}const a=t.createInstance(i,s);return n.__addUnit(a,o),a})}_tryProgressToReady(){this._injector.get(exports.LifecycleService).stage<Je.Ready&&(this._injector.get(exports.LifecycleService).stage=Je.Ready)}registerPlugin(t,n){this._pluginService.registerPlugin(t,n)}}function LE(e,t){const n=Du([[gu],[sn],[Ci],[exports.LifecycleService],[exports.PluginService],[Zn],[bn,{useClass:exports.UniverInstanceService}],[Tu,{useClass:Nu}],[vt,{useClass:Bo,lazy:!0}],[nr,{useClass:exports.CommandService}],[is,{useClass:exports.LocalUndoRedoService,lazy:!0}],[_i,{useClass:hu}],[yn,{useClass:Fo}],[ss,{useClass:Lu,lazy:!0}],[Ys,{useClass:Gs,lazy:!0}],[uu,{useClass:exports.AuthzIoLocalService}],[cu,{useClass:exports.MentionIOLocalService,lazy:!0}]],t),r=e?e.createChild(n):new je.Injector(n);return Uo(r,[[Zn],[Ys]]),r}ec();exports.ABCToNumber=$d;exports.AUTO_HEIGHT_FOR_MERGED_CELLS=ba;exports.AbsoluteRefType=tt;exports.ActionIterator=mn;exports.AlignTypeH=rl;exports.AlignTypeV=sl;exports.ArrangeTypeEnum=al;exports.ArrowsAndMarkersShapes=ra;exports.AsyncInterceptorManager=dp;exports.AutoFillSeries=Vo;exports.BaselineOffset=xt;exports.BasicShapes=na;exports.BlockType=ka;exports.BooleanNumber=Ie;exports.BorderStyleTypes=Xe;exports.BorderType=Go;exports.BuildTextUtils=it;exports.BulletAlignment=or;exports.COLORS=ys;exports.CanceledError=ac;exports.CellModeEnum=pn;exports.CellValueType=Vt;exports.Color=an;exports.ColorBuilder=qr;exports.ColorKit=St;exports.ColorType=pt;exports.ColumnSeparatorType=$a;exports.CommandType=tr;exports.CommonHideTypes=Ko;exports.ConfigService=hu;exports.ContextService=Fo;exports.CopyPasteType=Xo;exports.CustomCommandExecutionError=vs;exports.CustomDecorationType=nn;exports.CustomRangeType=qt;exports.DEFAULT_CELL=Rd;exports.DEFAULT_DOC=fi;exports.DEFAULT_DOCUMENT_SUB_COMPONENT_ID=Ep;exports.DEFAULT_EMPTY_DOCUMENT_VALUE=Oa;exports.DEFAULT_RANGE=Ed;exports.DEFAULT_RANGE_ARRAY=pd;exports.DEFAULT_SELECTION=Cd;exports.DEFAULT_SLIDE=Aa;exports.DEFAULT_STYLES=lt;exports.DEFAULT_WORKSHEET_COLUMN_COUNT=Ru;exports.DEFAULT_WORKSHEET_COLUMN_COUNT_KEY=Gp;exports.DEFAULT_WORKSHEET_COLUMN_TITLE_HEIGHT=Ou;exports.DEFAULT_WORKSHEET_COLUMN_TITLE_HEIGHT_KEY=Jp;exports.DEFAULT_WORKSHEET_COLUMN_WIDTH=Su;exports.DEFAULT_WORKSHEET_COLUMN_WIDTH_KEY=Xp;exports.DEFAULT_WORKSHEET_ROW_COUNT=Cu;exports.DEFAULT_WORKSHEET_ROW_COUNT_KEY=Vp;exports.DEFAULT_WORKSHEET_ROW_HEIGHT=Iu;exports.DEFAULT_WORKSHEET_ROW_HEIGHT_KEY=Kp;exports.DEFAULT_WORKSHEET_ROW_TITLE_WIDTH=vu;exports.DEFAULT_WORKSHEET_ROW_TITLE_WIDTH_KEY=qp;exports.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY=Js;exports.DOCS_NORMAL_EDITOR_UNIT_ID_KEY=qs;exports.DOCS_ZEN_EDITOR_UNIT_ID_KEY=va;exports.DOC_RANGE_TYPE=_a;exports.DashStyleType=Va;exports.DataStreamTreeNodeType=hl;exports.DataStreamTreeTokenType=jt;exports.DataValidationErrorStyle=Hu;exports.DataValidationImeMode=ju;exports.DataValidationOperator=Wu;exports.DataValidationRenderMode=Yu;exports.DataValidationStatus=zu;exports.DataValidationType=Vu;exports.DeleteDirection=qo;exports.DependentOn=mE;exports.DesktopLogService=Bo;exports.DeveloperMetadataVisibility=Jo;exports.Dimension=Zo;exports.Direction=Qo;exports.Disposable=rt;exports.DisposableCollection=Gr;exports.DocStyleType=xa;exports.DocumentDataModel=yt;exports.DocumentFlavor=Qs;exports.DrawingTypeEnum=ll;exports.EDITOR_ACTIVATED=du;exports.EXTENSION_NAMES=Ta;exports.ErrorService=gu;exports.EventState=lu;exports.EventSubject=Cp;exports.FOCUSING_COMMON_DRAWINGS=Lp;exports.FOCUSING_DOC=jn;exports.FOCUSING_EDITOR_BUT_HIDDEN=yp;exports.FOCUSING_EDITOR_INPUT_FORMULA=Ap;exports.FOCUSING_EDITOR_STANDALONE=Np;exports.FOCUSING_FX_BAR_EDITOR=fu;exports.FOCUSING_PANEL_EDITOR=Mp;exports.FOCUSING_SHEET=Rn;exports.FOCUSING_SLIDE=Wn;exports.FOCUSING_UNIT=Hn;exports.FOCUSING_UNIVER_EDITOR=Tp;exports.FOCUSING_UNIVER_EDITOR_STANDALONE_SINGLE_MODE=Dp;exports.FORMULA_EDITOR_ACTIVATED=xp;exports.FollowNumberWithType=Ua;exports.FontItalic=Fr;exports.FontStyleType=En;exports.FontWeight=$r;exports.GridType=Pa;exports.HLSColor=fa;exports.HorizontalAlign=Ot;exports.IAuthzIoService=uu;exports.ICommandService=nr;exports.IConfigService=_i;exports.IContextService=yn;exports.IImageIoService=zs;exports.ILocalStorageService=cE;exports.ILogService=vt;exports.IMentionIOService=cu;exports.IPermissionService=Tu;exports.IResourceLoaderService=Ys;exports.IResourceManagerService=ss;exports.IS_ROW_STYLE_PRECEDE_COLUMN_STYLE=wa;exports.IUndoRedoService=is;exports.IUniverInstanceService=bn;exports.ImageCacheMap=Bu;exports.ImageSourceType=Ri;exports.ImageUploadStatusType=$u;exports.InterceptorEffectEnum=Cn;exports.InterceptorManager=up;exports.InterpolationPointType=ea;exports.JSON1=a_;exports.JSONX=kt;exports.LRUHelper=Fn;exports.LRUMap=Xn;exports.LifecycleStages=Je;exports.ListGlyphType=Ne;exports.LocaleService=sn;exports.LocaleType=rr;exports.LogLevel=$o;exports.MOVE_BUFFER_VALUE=Pn;exports.MemoryCursor=Nn;exports.MentionType=Pr;exports.NamedStyleType=Ya;exports.NilCommand=Ho;exports.NumberUnitType=nl;exports.ObjectMatrix=wt;exports.ObjectRelativeFromH=el;exports.ObjectRelativeFromV=tl;exports.OtherShapes=sa;exports.PRESET_LIST_TYPE=ur;exports.PageElementType=ul;exports.PageOrientType=ol;exports.PageType=ei;exports.ParagraphElementType=Ha;exports.ParagraphStyleBuilder=Jn;exports.ParagraphStyleValue=hr;exports.PermissionService=Nu;exports.PermissionStatus=Ei;exports.Plugin=Ws;exports.PositionedObjectLayoutType=Wa;exports.PresetListType=Mt;exports.ProtectionType=ta;exports.QuickListType=Gl;exports.QuickListTypeMap=f_;exports.RANGE_DIRECTION=ma;exports.RANGE_TYPE=Le;exports.RBush=jr;exports.RCDisposable=fc;exports.RGBA_PAREN=jc;exports.RGB_PAREN=Hc;exports.ROTATE_BUFFER_VALUE=zo;exports.RTree=TE;exports.Range=vn;exports.Rectangle=Xt;exports.RedoCommand=Fu;exports.RedoCommandId=Uu;exports.RefAlias=Fd;exports.Registry=gi;exports.RegistryAsMap=mi;exports.RelativeDate=oa;exports.RelativeSlideLink=cl;exports.ResourceManagerService=Lu;exports.RgbColor=Br;exports.RichTextBuilder=rn;exports.RichTextValue=zt;exports.RxDisposable=dc;exports.SHEET_EDITOR_UNITS=Id;exports.SectionType=Fa;exports.SheetTypes=aa;exports.SheetViewModel=bu;exports.SliceBodyType=di;exports.SlideDataModel=pi;exports.SpacingRule=za;exports.SpecialShapes=ia;exports.Styles=mu;exports.THEME_COLORS=da;exports.TabStopAlignment=Ga;exports.TableAlignmentType=Xa;exports.TableLayoutType=qa;exports.TableRowHeightRule=Za;exports.TableSizeType=Ka;exports.TableTextWrapType=Ja;exports.TextDecoration=la;exports.TextDecorationBuilder=Yt;exports.TextDirection=Kn;exports.TextDirectionType=Ba;exports.TextStyleBuilder=Kt;exports.TextStyleValue=cr;exports.TextX=Ye;exports.TextXActionType=ce;exports.ThemeColor=Hr;exports.ThemeColorType=dt;exports.ThemeColors=Xr;exports.ThemeService=Ci;exports.Tools=re;exports.UndoCommand=Pu;exports.UndoCommandId=ku;exports.UnitModel=rs;exports.Univer=DE;exports.UniverInstanceType=$e;exports.UpdateDocsAttributeType=ke;exports.UserManagerService=Zn;exports.VerticalAlign=tn;exports.VerticalAlignmentType=Qa;exports.Worksheet=Qn;exports.WrapStrategy=on;exports.WrapTextType=ja;exports.addLinkToDocumentModel=_u;exports.afterInitApply=Sc;exports.afterTime=Ic;exports.awaitTime=RE;exports.binSearchFirstGreaterThanTarget=Yo;exports.binarySearchArray=vc;exports.bufferDebounceTime=Rc;exports.cellToRange=_h;exports.characterSpacingControlType=il;exports.checkForSubstrings=ph;exports.checkIfMove=wc;exports.checkParagraphHasBullet=Qh;exports.checkParagraphHasIndent=ed;exports.checkParagraphHasIndentByStyle=Ra;exports.codeToBlob=Oc;exports.composeBody=Bs;exports.composeInterceptors=ou;exports.composeStyles=ws;exports.concatMatrixArray=dd;exports.convertBodyToHtml=Bc;exports.convertCellToRange=pa;exports.covertTextRunToHtml=bs;exports.createAsyncInterceptorKey=cp;exports.createDefaultUser=Vr;exports.createDocumentModelWithStyle=Yn;exports.createInterceptorKey=lp;exports.createInternalEditorID=_d;exports.createRowColIter=Ds;exports.dayjs=Pt;exports.debounce=jm;exports.dedupe=tc;exports.deepCompare=Xs;exports.delayAnimationFrame=IE;exports.deleteContent=Sa;exports.extractPureTextFromCell=yu;exports.fromCallback=jo;exports.fromEventSubject=Rp;exports.fromObservable=hc;exports.generateRandomId=Ut;exports.get=Cm;exports.getArrayLength=Gt;exports.getBodySlice=bt;exports.getBodySliceHtml=br;exports.getBorderStyleType=fh;exports.getCellCoordByIndexSimple=Ii;exports.getCellInfoInMergeData=ah;exports.getCellPositionByIndexSimple=AE;exports.getCellValueType=rh;exports.getCellWithCoordByIndexCore=_n;exports.getColorStyle=Tt;exports.getCustomBlockSlice=Jl;exports.getCustomDecorationSlice=Ql;exports.getCustomRangeSlice=Zl;exports.getDocsUpdateBody=gh;exports.getIntersectRange=Ma;exports.getOriginCellValue=Qp;exports.getParagraphsSlice=ql;exports.getPlainText=Zr;exports.getReverseDirection=bc;exports.getSectionBreakSlice=S_;exports.getTableSlice=Xl;exports.getTextRunSlice=zr;exports.getTransformOffsetX=Gu;exports.getTransformOffsetY=Ku;exports.getWorksheetUID=rE;exports.groupBy=sc;exports.handleStyleToString=dh;exports.hashAlgorithm=nd;exports.horizontalLineSegmentsSubtraction=Jr;exports.insertMatrixArray=Ts;exports.insertTextToContent=Ia;exports.isBlackColor=eh;exports.isBooleanString=Zm;exports.isCellCoverable=As;exports.isCellV=ih;exports.isEmptyCell=Ea;exports.isFormulaId=hh;exports.isFormulaString=ch;exports.isICellData=nh;exports.isInternalEditorID=ya;exports.isNodeEnv=$c;exports.isNotNullOrUndefined=pu;exports.isNullCell=sh;exports.isNumeric=au;exports.isRangesEqual=Fp;exports.isRealNum=td;exports.isSafeNumeric=gp;exports.isSameStyleTextRun=Ca;exports.isUnitRangesEqual=$p;exports.isValidRange=mh;exports.isWhiteColor=th;exports.makeArray=ic;exports.makeCellRangeToRangeData=uh;exports.makeCellToSelection=lh;exports.makeCustomRangeStream=zd;exports.merge=li;exports.mergeOverrideWithDependencies=Du;exports.mergeSets=_p;exports.mergeWith=Vm;exports.mergeWorksheetSnapshotWithDefault=wu;exports.mixinClass=fp;exports.moveMatrixArray=Ms;exports.moveRangeByOffset=Ad;exports.nameCharacterCheck=CE;exports.normalizeBody=v_;exports.normalizeTextRuns=lr;exports.numberToABC=Hd;exports.numberToListABC=jd;exports.numfmt=hd;exports.queryObjectMatrix=Pd;exports.registerDependencies=oc;exports.remove=er;exports.repeatStringNumTimes=La;exports.replaceInDocumentBody=pp;exports.requestImmediateMacroTask=mp;exports.rotate=rc;exports.searchArray=kn;exports.searchInOrderedArray=Wo;exports.selectionToArray=oh;exports.sequence=Po;exports.sequenceAsync=ko;exports.sequenceExecute=Kr;exports.sequenceExecuteAsync=Cc;exports.set=Km;exports.shallowEqual=Dl;exports.skipParseTagNames=SE;exports.sliceMatrixArray=fd;exports.sortRules=Wd;exports.sortRulesByDesc=Yd;exports.sortRulesFactory=ir;exports.spliceArray=Ns;exports.splitIntoGrid=Zs;exports.takeAfter=Os;exports.textDiff=ui;exports.throttle=ap;exports.toDisposable=nt;exports.touchDependencies=Uo;exports.updateAttributeByDelete=eu;exports.updateAttributeByInsert=tu;Object.keys(je).forEach(e=>{e!=="default"&&!Object.prototype.hasOwnProperty.call(exports,e)&&Object.defineProperty(exports,e,{enumerable:!0,get:()=>je[e]})});