@univerjs/sheets-formula-ui 0.8.3 → 0.9.0
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 +6 -6
- package/lib/es/index.js +581 -571
- package/lib/index.js +581 -571
- package/lib/umd/index.js +6 -6
- package/package.json +13 -13
package/lib/cjs/index.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
"use strict";var Xt=Object.defineProperty;var Qt=(e,t,n)=>t in e?Xt(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n;var Y=(e,t,n)=>Qt(e,typeof t!="symbol"?t+"":t,n);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const l=require("@univerjs/core"),w=require("@univerjs/sheets-ui"),T=require("@univerjs/engine-formula"),q=require("rxjs"),Q=require("@univerjs/docs-ui"),B=require("@univerjs/engine-render"),A=require("@univerjs/sheets"),Ce=require("@univerjs/sheets-formula"),a=require("@univerjs/ui"),E=require("react/jsx-runtime"),v=require("react"),W=require("@univerjs/design"),bt=require("@univerjs/docs"),Jt=require("rxjs/operators"),Xe={id:"sheet.command.paste-formula",type:l.CommandType.COMMAND,handler:async e=>e.get(l.ICommandService).executeCommand(w.SheetPasteCommand.id,{value:w.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMULA})},Ee={id:"formula-ui.operation.select-editor-formula",type:l.CommandType.OPERATION,handler:(e,t)=>!0};var en=Object.getOwnPropertyDescriptor,tn=(e,t,n,s)=>{for(var r=s>1?void 0:s?en(t,n):t,o=e.length-1,i;o>=0;o--)(i=e[o])&&(r=i(r)||r);return r},nn=(e,t)=>(n,s)=>t(n,s,e);const Tt="FORMULA_PROMPT_ACTIVATED",it=l.createIdentifier("formula-ui.prompt-service");let rt=class{constructor(e){Y(this,"_search$",new q.Subject);Y(this,"_help$",new q.Subject);Y(this,"_navigate$",new q.Subject);Y(this,"_accept$",new q.Subject);Y(this,"_acceptFormulaName$",new q.Subject);Y(this,"search$",this._search$.asObservable());Y(this,"help$",this._help$.asObservable());Y(this,"navigate$",this._navigate$.asObservable());Y(this,"accept$",this._accept$.asObservable());Y(this,"acceptFormulaName$",this._acceptFormulaName$.asObservable());Y(this,"_searching",!1);Y(this,"_helping",!1);Y(this,"_sequenceNodes",[]);Y(this,"_isLockedOnSelectionChangeRefString",!1);Y(this,"_isLockedOnSelectionInsertRefString",!1);this._contextService=e}dispose(){this._search$.complete(),this._help$.complete(),this._navigate$.complete(),this._accept$.complete(),this._acceptFormulaName$.complete(),this._sequenceNodes=[]}search(e){this._contextService.setContextValue(Tt,e.visible),this._searching=e.visible,this._search$.next(e)}isSearching(){return this._searching}help(e){this._helping=e.visible,this._help$.next(e)}isHelping(){return this._helping}navigate(e){this._navigate$.next(e)}accept(e){this._accept$.next(e)}acceptFormulaName(e){this._acceptFormulaName$.next(e)}getSequenceNodes(){return[...this._sequenceNodes]}setSequenceNodes(e){this._sequenceNodes=e}clearSequenceNodes(){this._sequenceNodes=[]}getCurrentSequenceNode(e){return this._sequenceNodes[this.getCurrentSequenceNodeIndex(e)]}getCurrentSequenceNodeByIndex(e){return this._sequenceNodes[e]}getCurrentSequenceNodeIndex(e){let t=0;const n=this._sequenceNodes[0];for(let s=0,r=this._sequenceNodes.length;s<r;s++){const o=this._sequenceNodes[s];if(typeof o=="string")t++;else{const{endIndex:i}=o;t=i}if(e<=t)return typeof n=="string"&&e!==0?s+1:s}return this._sequenceNodes.length}updateSequenceRef(e,t){const n=this._sequenceNodes[e];if(typeof n=="string"||n.nodeType!==T.sequenceNodeType.REFERENCE)return;const s=t.length-n.token.length,r={...n};r.token=t,r.endIndex+=s,this._sequenceNodes[e]=r;for(let o=e+1,i=this._sequenceNodes.length;o<i;o++){const c=this._sequenceNodes[o];if(typeof c=="string")continue;const d={...c};d.startIndex+=s,d.endIndex+=s,this._sequenceNodes[o]=d}}insertSequenceRef(e,t){const n=t.length,s=this.getCurrentSequenceNodeIndex(e);this._sequenceNodes.splice(s,0,{token:t,startIndex:e,endIndex:e+n-1,nodeType:T.sequenceNodeType.REFERENCE});for(let r=s+1,o=this._sequenceNodes.length;r<o;r++){const i=this._sequenceNodes[r];if(typeof i=="string")continue;const c={...i};c.startIndex+=n,c.endIndex+=n,this._sequenceNodes[r]=c}}insertSequenceString(e,t){const n=this.getCurrentSequenceNodeIndex(e),s=t.split("");this._sequenceNodes.splice(n,0,...s);const r=s.length;for(let o=n+r,i=this._sequenceNodes.length;o<i;o++){const c=this._sequenceNodes[o];if(typeof c=="string")continue;const d={...c};d.startIndex+=r,d.endIndex+=r,this._sequenceNodes[o]=d}}enableLockedSelectionChange(){this._isLockedOnSelectionChangeRefString=!0}disableLockedSelectionChange(){this._isLockedOnSelectionChangeRefString=!1}isLockedSelectionChange(){return this._isLockedOnSelectionChangeRefString}enableLockedSelectionInsert(){this._isLockedOnSelectionInsertRefString=!0}disableLockedSelectionInsert(){this._isLockedOnSelectionInsertRefString=!1}isLockedSelectionInsert(){return this._isLockedOnSelectionInsertRefString}};rt=tn([nn(0,l.IContextService)],rt);const xt={id:"formula-ui.operation.help-function",type:l.CommandType.OPERATION,handler:async(e,t)=>(e.get(it).help(t),!0)},ce={id:"formula-ui.operation.insert-function",type:l.CommandType.OPERATION,handler:async(e,t)=>{var R,b;const n=e.get(A.SheetsSelectionsService),s=e.get(Q.IEditorService),r=n.getCurrentSelections();if(!r||!r.length)return!1;const o=A.getSheetCommandTarget(e.get(l.IUniverInstanceService));if(!o)return!1;const{worksheet:i,unitId:c,subUnitId:d}=o,f=i.getCellMatrix(),{value:m}=t,p=e.get(l.ICommandService);e.get(w.IEditorBridgeService);const h=[],g=[];let u=null,_=0,S=0,C="";if(r.length===1&&(on(r[0].range)||cn(r[0].range)&&vt(f,r[0].range))){const{range:y,primary:I}=r[0],M=(R=I==null?void 0:I.actualRow)!=null?R:y.startRow,F=(b=I==null?void 0:I.actualColumn)!=null?b:y.startColumn;u=y,_=M,S=F;const L=St(f,M,F);L&&(C=T.serializeRange(L))}else r.some(y=>{var F,L;const{range:I,primary:M}=y;if(vt(f,I)){const U=(F=M==null?void 0:M.actualRow)!=null?F:I.startRow,k=(L=M==null?void 0:M.actualColumn)!=null?L:I.startColumn,$=St(f,U,k);if(!$)return u=I,_=U,S=k,!0;const D=T.serializeRange($),N=`=${m}(${D})`;h.push({range:I,primary:{row:U,column:k},formula:N})}else{const{startRow:U,startColumn:k,endRow:$,endColumn:D}=I;if(U===$){const N=an(f,U,D,i.getColumnCount()-1),x=N===D?D-1:D,O=T.serializeRange({startRow:U,endRow:$,startColumn:k,endColumn:x}),P=`=${m}(${O})`;g.push({range:I,primary:{row:U,column:N},formula:P})}else{let N=-1;for(let O=k;O<=D;O++){const P=ln(f,O,$,i.getRowCount()-1);N=Math.max(N,P)}const x=N===$?$-1:$;for(let O=k;O<=D;O++){const P=T.serializeRange({startRow:U,endRow:x,startColumn:O,endColumn:O}),j=`=${m}(${P})`;g.push({range:I,primary:{row:N,column:O},formula:j})}}}return!1});if(u){const y=A.getCellAtRowCol(_,S,i),I={range:l.Rectangle.clone(u),primary:{startRow:y.startRow,startColumn:y.startColumn,endRow:y.endRow,endColumn:y.endColumn,actualRow:_,actualColumn:S,isMerged:y.isMerged,isMergedMainCell:y.startRow===_&&y.startColumn===S}},M={unitId:c,subUnitId:d,selections:[I]};await p.executeCommand(A.SetSelectionsOperation.id,M);const F=s.getEditor(l.DOCS_NORMAL_EDITOR_UNIT_ID_KEY),L=s.getEditor(l.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY);p.syncExecuteCommand(w.SetCellEditVisibleOperation.id,{visible:!0,unitId:c,eventType:B.DeviceInputEventType.Dblclick});const U=`=${m}(${C}`;F==null||F.replaceText(U),L==null||L.replaceText(U,!1)}return h.length===0&&g.length===0?!1:p.executeCommand(Ce.InsertFunctionCommand.id,{list:h,listOfRangeHasNumber:g})}};function St(e,t,n){const s=rn(e,t,n);if(s!==t)return{startRow:s,endRow:t-1,startColumn:n,endColumn:n};const r=sn(e,t,n);return r!==n?{startRow:t,endRow:t,startColumn:r,endColumn:n-1}:null}function rn(e,t,n){let s=!1;if(t===0)return t;for(let r=t-1;r>=0;r--){const o=e.getValue(r,n);if(Pe(o)&&!s){if(r===0)return 0;s=!0}else{if(s&&!Pe(o))return r+1;if(s&&r===0)return 0}}return t}function sn(e,t,n){let s=!1;if(n===0)return n;for(let r=n-1;r>=0;r--){const o=e.getValue(t,r);if(Pe(o)&&!s){if(r===0)return 0;s=!0}else{if(s&&!Pe(o))return r+1;if(s&&r===0)return 0}}return n}function Pe(e){if(e!=null&&e.p){const t=e==null?void 0:e.p.body;if(t==null)return!1;const n=t.dataStream,r=n.substring(n.length-2,n.length)===l.DEFAULT_EMPTY_DOCUMENT_VALUE?n.substring(0,n.length-2):n;return l.isRealNum(r)}return e&&(e.t===l.CellValueType.NUMBER||l.getCellValueType(e)===l.CellValueType.NUMBER)}function on(e){return e.startRow===e.endRow&&e.startColumn===e.endColumn}function cn(e){return e.startRow!==e.endRow&&e.startColumn!==e.endColumn}function vt(e,t){for(let n=t.startRow;n<=t.endRow;n++)for(let s=t.startColumn;s<=t.endColumn;s++)if(Pe(e.getValue(n,s)))return!1;return!0}function an(e,t,n,s){for(let r=n;r<=s;r++)if(!e.getValue(t,r))return r;return s}function ln(e,t,n,s){for(let r=n;r<=s;r++)if(!e.getValue(r,t))return r;return s}const Mt="SHEET_FORMULA_UI_PLUGIN",Ot=`${Mt}_MORE_FUNCTIONS_COMPONENT`,Qe={id:"formula-ui.operation.more-functions",type:l.CommandType.OPERATION,handler:async e=>(e.get(a.ISidebarService).open({header:{title:"formula.insert.tooltip"},children:{label:Ot}}),!0)},ct={id:"formula-ui.operation.change-ref-to-absolute",type:l.CommandType.OPERATION,handler:async e=>!0},Nt={id:"formula-ui.operation.search-function",type:l.CommandType.OPERATION,handler:async(e,t)=>(e.get(it).search(t),!0)};var un=Object.getOwnPropertyDescriptor,dn=(e,t,n,s)=>{for(var r=s>1?void 0:s?un(t,n):t,o=e.length-1,i;o>=0;o--)(i=e[o])&&(r=i(r)||r);return r},He=(e,t)=>(n,s)=>t(n,s,e);exports.FormulaReorderController=class extends l.Disposable{constructor(t,n,s,r){super(),this._sheetInterceptorService=t,this._univerInstanceService=n,this._formulaDataModel=s,this._lexerTreeBuilder=r,this._initialize()}_initialize(){this.disposeWithMe(this._sheetInterceptorService.interceptCommand({getMutations:t=>t.id===A.ReorderRangeCommand.id?this._reorderFormula(t.params):{redos:[],undos:[]}}))}_reorderFormula(t){const n=[],s=[],{unitId:r,subUnitId:o,range:i,order:c}=t,d=this._univerInstanceService.getUniverSheetInstance(r),f=d==null?void 0:d.getSheetBySheetId(o);if(!f)return{redos:n,undos:s};const m=f.getCellMatrix(),p=new l.ObjectMatrix,h=new l.ObjectMatrix;let g=!1;return l.Range.foreach(i,(u,_)=>{let S=u;c.hasOwnProperty(u)&&(S=c[u]);const C=m.getValue(S,_);if(C!=null&&C.f||C!=null&&C.si){g=!0;const R=this._formulaDataModel.getFormulaStringByCell(S,_,o,r),b=this._lexerTreeBuilder.moveFormulaRefOffset(R,0,u-S),y=l.Tools.deepClone(C);y.f=b,y.si=null,p.setValue(u,_,y)}else p.setValue(u,_,C);h.setValue(u,_,m.getValue(u,_))}),g?(n.push({id:A.SetRangeValuesMutation.id,params:{unitId:r,subUnitId:o,cellValue:p.getMatrix()}}),s.push({id:A.SetRangeValuesMutation.id,params:{unitId:r,subUnitId:o,cellValue:h.getMatrix()}}),{redos:n,undos:s}):{redos:n,undos:s}}};exports.FormulaReorderController=dn([He(0,l.Inject(A.SheetInterceptorService)),He(1,l.Inject(l.IUniverInstanceService)),He(2,l.Inject(T.FormulaDataModel)),He(3,l.Inject(T.LexerTreeBuilder))],exports.FormulaReorderController);const hn="sheets-formula-ui.base.config",Ct={};function fn(e){return e.getContextValue(l.FOCUSING_DOC)&&e.getContextValue(l.FOCUSING_UNIVER_EDITOR)}function Dt(e,t=!1){return!t&&!(l.isFormulaString(e==null?void 0:e.f)||l.isFormulaId(e==null?void 0:e.si))?null:typeof(e==null?void 0:e.v)=="string"&&T.ERROR_TYPE_SET.has(e.v)?e.v:null}var gn=Object.getOwnPropertyDescriptor,mn=(e,t,n,s)=>{for(var r=s>1?void 0:s?gn(t,n):t,o=e.length-1,i;o>=0;o--)(i=e[o])&&(r=i(r)||r);return r},ke=(e,t)=>(n,s)=>t(n,s,e);const tt="SHEET_FORMULA_ALERT",pn={[T.ErrorType.DIV_BY_ZERO]:"divByZero",[T.ErrorType.NAME]:"name",[T.ErrorType.VALUE]:"value",[T.ErrorType.NUM]:"num",[T.ErrorType.NA]:"na",[T.ErrorType.CYCLE]:"cycle",[T.ErrorType.REF]:"ref",[T.ErrorType.SPILL]:"spill",[T.ErrorType.CALC]:"calc",[T.ErrorType.ERROR]:"error",[T.ErrorType.CONNECT]:"connect",[T.ErrorType.NULL]:"null"};let st=class extends l.Disposable{constructor(e,t,n,s,r,o){super(),this._context=e,this._hoverManagerService=t,this._cellAlertManagerService=n,this._localeService=s,this._formulaDataModel=r,this._zenZoneService=o,this._init()}_init(){this._initCellAlertPopup(),this._initZenService()}_initCellAlertPopup(){this.disposeWithMe(this._hoverManagerService.currentCell$.pipe(q.debounceTime(100)).subscribe(e=>{var t,n,s,r,o;if(e){const c=this._context.unit.getActiveSheet();if(!c)return;const d=c.getCell(e.location.row,e.location.col),f=(r=(s=(n=(t=this._formulaDataModel.getArrayFormulaCellData())==null?void 0:t[e.location.unitId])==null?void 0:n[e.location.subUnitId])==null?void 0:s[e.location.row])==null?void 0:r[e.location.col];if(l.isICellData(d)){const m=Dt(d,!!f);if(!m){this._hideAlert();return}const p=this._cellAlertManagerService.currentAlert.get(tt),h=(o=p==null?void 0:p.alert)==null?void 0:o.location;if(h&&h.row===e.location.row&&h.col===e.location.col&&h.subUnitId===e.location.subUnitId&&h.unitId===e.location.unitId)return;this._cellAlertManagerService.showAlert({type:w.CellAlertType.ERROR,title:this._localeService.t("formula.error.title"),message:this._localeService.t(`formula.error.${pn[m]}`),location:e.location,width:200,height:74,key:tt});return}}this._hideAlert()}))}_initZenService(){this.disposeWithMe(this._zenZoneService.visible$.subscribe(e=>{e&&this._hideAlert()}))}_hideAlert(){this._cellAlertManagerService.removeAlert(tt)}};st=mn([ke(1,l.Inject(w.HoverManagerService)),ke(2,l.Inject(w.CellAlertManagerService)),ke(3,l.Inject(l.LocaleService)),ke(4,l.Inject(T.FormulaDataModel)),ke(5,a.IZenZoneService)],st);var Sn=Object.getOwnPropertyDescriptor,vn=(e,t,n,s)=>{for(var r=s>1?void 0:s?Sn(t,n):t,o=e.length-1,i;o>=0;o--)(i=e[o])&&(r=i(r)||r);return r},_t=(e,t)=>(n,s)=>t(n,s,e);let qe=class extends l.Disposable{constructor(e,t){super(),this._autoFillService=e,this._lexerTreeBuilder=t,this._registerAutoFill()}_registerAutoFill(){const e={type:w.DATA_TYPE.FORMULA,priority:1001,match:t=>l.isFormulaString(t==null?void 0:t.f)||l.isFormulaId(t==null?void 0:t.si),isContinue:(t,n)=>t.type===w.DATA_TYPE.FORMULA,applyFunctions:{[w.APPLY_TYPE.COPY]:(t,n,s,r,o)=>{const{data:i,index:c}=t;return this._fillCopyFormula(i,n,s,c,r,o)}}};this._autoFillService.registerRule(e)}_fillCopyFormula(e,t,n,s,r,o){var f,m;const i=_n(r),c=[],d=new Map;for(let p=1;p<=t;p++){const h=(p-1)%e.length,g=s[h],u=l.Tools.deepClone(e[h]);if(u){const _=((f=e[h])==null?void 0:f.f)||"",S=((m=e[h])==null?void 0:m.si)||"",C=l.isFormulaString(_);if(l.isFormulaId(S))u.si=S,u.f=null,u.v=null,u.p=null,u.t=null,c.push(u);else if(C){let b=d.get(h);if(b)u.si=b,u.f=null,u.v=null,u.p=null,u.t=null;else{b=l.Tools.generateRandomId(6),d.set(h,b);const{offsetX:y,offsetY:I}=Cn(i,t,n,o,g),M=this._lexerTreeBuilder.moveFormulaRefOffset(_,y,I);u.si=b,u.f=M,u.v=null,u.p=null,u.t=null}c.push(u)}}}return c}};qe=vn([_t(0,w.IAutoFillService),_t(1,l.Inject(T.LexerTreeBuilder))],qe);function Cn(e,t,n,s,r){const{source:o,target:i}=s,{rows:c}=i,{rows:d}=o;let f=0,m=0;switch(n){case l.Direction.UP:m=c[r]-d[r];break;case l.Direction.RIGHT:f=e;break;case l.Direction.DOWN:m=c[r]-d[r];break;case l.Direction.LEFT:f=-e*t;break}return{offsetX:f,offsetY:m}}function _n(e){let t=0;for(const n in e)e[n].forEach(s=>{t+=s.data.length});return t}var Rn=Object.getOwnPropertyDescriptor,In=(e,t,n,s)=>{for(var r=s>1?void 0:s?Rn(t,n):t,o=e.length-1,i;o>=0;o--)(i=e[o])&&(r=i(r)||r);return r},Ae=(e,t)=>(n,s)=>t(n,s,e);const yn="default-paste-formula";let Ye=class extends l.Disposable{constructor(e,t,n,s,r){super(),this._currentUniverSheet=e,this._lexerTreeBuilder=t,this._sheetClipboardService=n,this._injector=s,this._formulaDataModel=r,this._initialize()}_initialize(){this._registerClipboardHook()}_registerClipboardHook(){this.disposeWithMe(this._sheetClipboardService.addClipboardHook(this._pasteFormulaHook())),this.disposeWithMe(this._sheetClipboardService.addClipboardHook(this._pasteWithFormulaHook()))}_pasteFormulaHook(){return{id:w.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMULA,priority:10,specialPasteInfo:{label:"specialPaste.formula"},onPasteCells:(e,t,n,s)=>this._onPasteCells(e,t,n,s,!0)}}_pasteWithFormulaHook(){return{id:yn,priority:10,onPasteCells:(e,t,n,s)=>this._onPasteCells(e,t,n,s,!1)}}_onPasteCells(e,t,n,s,r){var h;if([w.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMAT,w.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_COL_WIDTH].includes(s.pasteType))return{undos:[],redos:[]};const i=this._currentUniverSheet.getCurrentUnitForType(l.UniverInstanceType.UNIVER_SHEET),c=t.unitId||i.getUnitId(),d=t.subUnitId||((h=i.getActiveSheet())==null?void 0:h.getSheetId());if(!c||!d)return{undos:[],redos:[]};const f=t.range,m=n,p={copyType:s.copyType||w.COPY_TYPE.COPY,copyRange:e==null?void 0:e.range,pasteType:s.pasteType};return this._injector.invoke(g=>En(c,d,f,m,g,p,this._lexerTreeBuilder,this._formulaDataModel,r,e))}};Ye=In([Ae(0,l.IUniverInstanceService),Ae(1,l.Inject(T.LexerTreeBuilder)),Ae(2,w.ISheetClipboardService),Ae(3,l.Inject(l.Injector)),Ae(4,l.Inject(T.FormulaDataModel))],Ye);function En(e,t,n,s,r,o,i,c,d=!1,f){const m=[],p=[],h=bn(e,t,n,s,o,i,c,f);if(!h.hasValue())return{undos:[],redos:[]};const g={unitId:e,subUnitId:t,cellValue:h.getData()};m.push({id:A.SetRangeValuesMutation.id,params:g});const u=A.SetRangeValuesUndoMutationFactory(r,g);return p.push({id:A.SetRangeValuesMutation.id,params:u}),{undos:p,redos:m}}function bn(e,t,n,s,r,o,i,c){return c?r.pasteType===w.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_VALUE?xn(e,t,n,s,i,c):r.pasteType===w.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMULA?Mn(e,t,n,s,o,i,c):On(e,t,n,s,r.copyType,o,i,c):Tn(e,t,n,s,i)}function Tn(e,t,n,s,r){const o=new l.ObjectMatrix,i=r.getSheetFormulaData(e,t);return s.forValue((c,d,f)=>{var g;const m=n.rows[c],p=n.cols[d],h={};l.isFormulaString(f.v)?(h.v=null,h.f=`${f.v}`,h.si=null,h.p=null,o.setValue(m,p,h)):(g=i==null?void 0:i[m])!=null&&g[p]&&(h.v=f.v,h.f=null,h.si=null,h.p=null,o.setValue(m,p,h))}),o}function xn(e,t,n,s,r,o){var f,m;const i=new l.ObjectMatrix,c=(m=(f=r.getArrayFormulaCellData())==null?void 0:f[o.unitId])==null?void 0:m[o.subUnitId],d=r.getSheetFormulaData(e,t);return s.forValue((p,h,g)=>{var b,y;const u=o.range.rows[p%o.range.rows.length],_=o.range.cols[h%o.range.cols.length],S=n.rows[p],C=n.cols[h],R={};if(l.isFormulaString(g.f)||l.isFormulaId(g.si))R.v=g.v,R.f=null,R.si=null,R.p=null,i.setValue(S,C,R);else if((b=c==null?void 0:c[u])!=null&&b[_]){const I=c[u][_];R.v=I.v,R.f=null,R.si=null,R.p=null,i.setValue(S,C,R)}else if((y=d==null?void 0:d[S])!=null&&y[C]){if(R.v=g.v,R.f=null,R.si=null,R.p=null,g.p){const I=wt(g);I&&(R.v=I)}i.setValue(S,C,R)}}),i}function Mn(e,t,n,s,r,o,i){const c=new l.ObjectMatrix,d=new Map;return s.forValue((f,m,p)=>{const h=n.rows[f],g=n.cols[m],u={};if(l.isFormulaId(p.si)){if(i.unitId!==e||i.subUnitId!==t){const _=o.getFormulaStringByCell(i.range.rows[f%i.range.rows.length],i.range.cols[m%i.range.cols.length],i.subUnitId,i.unitId),S=n.cols[m]-i.range.cols[m%i.range.cols.length],C=n.rows[f]-i.range.rows[f%i.range.rows.length],R=r.moveFormulaRefOffset(_||"",S,C);u.si=null,u.f=R}else u.si=p.si,u.f=null;u.v=null,u.p=null,c.setValue(h,g,u)}else if(l.isFormulaString(p.f)){const _=`${f%i.range.rows.length}_${m%i.range.cols.length}`;let S=d.get(_);if(S)u.si=S,u.f=null;else{S=l.Tools.generateRandomId(6),d.set(_,S);const C=n.cols[m]-i.range.cols[m%i.range.cols.length],R=n.rows[f]-i.range.rows[f%i.range.rows.length],b=r.moveFormulaRefOffset(p.f||"",C,R);u.si=S,u.f=b}u.v=null,u.p=null,c.setValue(h,g,u)}else{if(u.v=p.v,u.f=null,u.si=null,u.p=null,p.p){const _=wt(p);_&&(u.v=_)}c.setValue(h,g,u)}}),c}function On(e,t,n,s,r,o,i,c){const d=new l.ObjectMatrix,f=new Map,m=i.getSheetFormulaData(e,t),p=[];return r===w.COPY_TYPE.CUT?s.forValue((h,g,u)=>{const _=n.rows[h],S=n.cols[g],C={};if(l.isFormulaId(u.si)){if(l.isFormulaString(u.f))p.push(u.si),C.f=u.f,C.si=u.si;else if(p.includes(u.si))C.f=null,C.si=u.si;else{const R=i.getFormulaStringByCell(c.range.rows[h%c.range.rows.length],c.range.cols[g%c.range.cols.length],c.subUnitId,c.unitId);C.f=R,C.si=null}C.v=null,C.p=null,d.setValue(_,S,C)}else l.isFormulaString(u.f)&&(C.f=u.f,C.si=null,C.v=null,C.p=null,d.setValue(_,S,C))}):s.forValue((h,g,u)=>{var R;const _=n.rows[h],S=n.cols[g],C={};if(l.isFormulaId(u.si)){if(c.unitId!==e||c.subUnitId!==t){const b=i.getFormulaStringByCell(c.range.rows[h%c.range.rows.length],c.range.cols[g%c.range.cols.length],c.subUnitId,c.unitId),y=n.cols[g]-c.range.cols[g%c.range.cols.length],I=n.rows[h]-c.range.rows[h%c.range.rows.length],M=o.moveFormulaRefOffset(b||"",y,I);C.si=null,C.f=M}else C.si=u.si,C.f=null;C.v=null,C.p=null,d.setValue(_,S,C)}else if(l.isFormulaString(u.f)){const b=`${h%c.range.rows.length}_${g%c.range.cols.length}`;let y=f.get(b);if(y)C.si=y,C.f=null;else{y=l.Tools.generateRandomId(6),f.set(b,y);const I=n.cols[g]-c.range.cols[g%c.range.cols.length],M=n.rows[h]-c.range.rows[h%c.range.rows.length],F=o.moveFormulaRefOffset(u.f||"",I,M);C.si=y,C.f=F}C.v=null,C.p=null,d.setValue(_,S,C)}else(R=m==null?void 0:m[_])!=null&&R[S]&&(C.v=u.v,C.f=null,C.si=null,C.p=u.p,d.setValue(_,S,C))}),p.length>0&&new l.ObjectMatrix(m).forValue((h,g,u)=>{if(!(c.range.rows.includes(h)&&c.range.cols.includes(g))&&!(n.rows.includes(h)&&n.cols.includes(g))&&p.includes(u==null?void 0:u.si)){const _=i.getFormulaStringByCell(h,g,c.subUnitId,c.unitId);d.setValue(h,g,{f:_,si:null,v:null,p:null})}}),d}function wt(e){if(e!=null&&e.p){const t=e==null?void 0:e.p.body;if(t==null)return;const n=t.dataStream;return n.substring(n.length-2,n.length)===l.DEFAULT_EMPTY_DOCUMENT_VALUE?n.substring(0,n.length-2):n}}var Nn=Object.getOwnPropertyDescriptor,Dn=(e,t,n,s)=>{for(var r=s>1?void 0:s?Nn(t,n):t,o=e.length-1,i;o>=0;o--)(i=e[o])&&(r=i(r)||r);return r},Ie=(e,t)=>(n,s)=>t(n,s,e);let ze=class extends l.Disposable{constructor(t,n,s,r,o,i,c,d){super();Y(this,"_previousShape");Y(this,"_skeleton");this._context=t,this._sheetInterceptorService=n,this._formulaDataModel=s,this._themeService=r,this._renderManagerService=o,this._sheetSkeletonManagerService=i,this._commandService=c,this._logService=d,this._initSkeletonChangeListener(),this._initInterceptorEditorStart(),this._commandExecutedListener()}_initSkeletonChangeListener(){this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(t=>{var n,s;if(t==null)this._logService.debug("[FormulaEditorShowController]: should not receive currentSkeleton$ as null!");else{const{skeleton:r}=t,o=(s=(n=this._skeleton)==null?void 0:n.worksheet)==null?void 0:s.getSheetId();if(this._changeRuntime(r),o!==r.worksheet.getSheetId())this._removeArrayFormulaRangeShape();else{const{unitId:i,sheetId:c}=t;this._updateArrayFormulaRangeShape(i,c)}}}))}_changeRuntime(t){this._skeleton=t}_initInterceptorEditorStart(){this.disposeWithMe(l.toDisposable(this._sheetInterceptorService.writeCellInterceptor.intercept(A.BEFORE_CELL_EDIT,{handler:(t,n,s)=>{var u,_,S,C;const{row:r,col:o,unitId:i,subUnitId:c,worksheet:d}=n,f=this._formulaDataModel.getArrayFormulaRange(),m=this._formulaDataModel.getArrayFormulaCellData();if(this._removeArrayFormulaRangeShape(),t==null)return s(t);let p=null;const h=this._formulaDataModel.getFormulaStringByCell(r,o,c,i);if(h!==null&&(p={f:h}),t.v!=null&&t.v!==""&&((S=(_=(u=m[i])==null?void 0:u[c])==null?void 0:_[r])==null?void 0:S[o])==null)return p?{...t,...p}:s(t);const g=(C=f==null?void 0:f[i])==null?void 0:C[c];return g!=null&&(p=this._displayArrayFormulaRangeShape(g,r,o,i,c,d,p)),p?{...t,...p}:s(t)}})))}_commandExecutedListener(){this.disposeWithMe(this._commandService.onCommandExecuted((t,n)=>{(t.id===T.SetFormulaCalculationResultMutation.id||t.id===T.SetArrayFormulaDataMutation.id&&n&&n.remove)&&this._removeArrayFormulaRangeShape()})),this.disposeWithMe(this._commandService.beforeCommandExecuted(t=>{A.SetWorksheetRowAutoHeightMutation.id===t.id&&requestIdleCallback(()=>{const n=t.params,{unitId:s,subUnitId:r,rowsAutoHeightInfo:o}=n;this._refreshArrayFormulaRangeShapeByRow(s,r,o)})}))}_displayArrayFormulaRangeShape(t,n,s,r,o,i,c){const d=this._formulaDataModel.getSheetFormulaData(r,o);return new l.ObjectMatrix(t).forValue((f,m,p)=>{var S;if(p==null)return!0;const{startRow:h,startColumn:g,endRow:u,endColumn:_}=p;if(f===n&&m===s)return this._createArrayFormulaRangeShape(p,r),!1;if(n>=h&&n<=u&&s>=g&&s<=_){const C=i.getCell(h,g);if((C==null?void 0:C.v)===T.ErrorType.SPILL)return;const R=(S=d==null?void 0:d[f])==null?void 0:S[m];return R==null||R.f==null?!0:(c==null&&(c={f:R.f,isInArrayFormulaRange:!0}),this._createArrayFormulaRangeShape(p,r),!1)}}),c}_createArrayFormulaRangeShape(t,n){const s=this._renderManagerService.getRenderById(n),r=this._sheetSkeletonManagerService.getCurrentSkeleton();if(!s||!r)return;const{scene:o}=s;if(!o)return;const i={range:t,primary:null,style:{strokeWidth:1,stroke:this._themeService.getColorFromTheme("primary.600"),fill:new l.ColorKit(this._themeService.getColorFromTheme("white")).setAlpha(0).toString(),widgets:{}}},c=w.attachSelectionWithCoord(i,r),{rowHeaderWidth:d,columnHeaderHeight:f}=r,m=new w.SelectionControl(o,w.SELECTION_SHAPE_DEPTH.FORMULA_EDITOR_SHOW,this._themeService,{highlightHeader:!1,rowHeaderWidth:d,columnHeaderHeight:f});m.updateRangeBySelectionWithCoord(c),m.setEvent(!1),this._previousShape=m}_removeArrayFormulaRangeShape(){this._previousShape!=null&&(this._previousShape.dispose(),this._previousShape=null)}_refreshArrayFormulaRangeShape(t,n){if(this._previousShape){const{startRow:s,endRow:r,startColumn:o,endColumn:i}=this._previousShape.getRange(),c={startRow:s,endRow:r,startColumn:o,endColumn:i};this._removeArrayFormulaRangeShape(),this._createArrayFormulaRangeShape(c,t)}}_checkCurrentSheet(t,n){const s=this._sheetSkeletonManagerService.getCurrentSkeleton();if(!s)return!1;const r=s.worksheet;return r?r.unitId===t&&r.getSheetId()===n:!1}_updateArrayFormulaRangeShape(t,n){this._checkCurrentSheet(t,n)&&this._previousShape&&this._refreshArrayFormulaRangeShape(t)}_refreshArrayFormulaRangeShapeByRow(t,n,s){if(!this._checkCurrentSheet(t,n)||!this._previousShape)return;const{startRow:r,endRow:o,startColumn:i,endColumn:c}=this._previousShape.getRange();for(let d=0;d<s.length;d++){const{row:f}=s[d];if(r>=f){const m={startRow:r,endRow:o,startColumn:i,endColumn:c};this._refreshArrayFormulaRangeShape(t,m);break}}}};ze=Dn([Ie(1,l.Inject(A.SheetInterceptorService)),Ie(2,l.Inject(T.FormulaDataModel)),Ie(3,l.Inject(l.ThemeService)),Ie(4,B.IRenderManagerService),Ie(5,l.Inject(w.SheetSkeletonManagerService)),Ie(6,l.ICommandService),Ie(7,l.ILogService)],ze);var wn=Object.getOwnPropertyDescriptor,kn=(e,t,n,s)=>{for(var r=s>1?void 0:s?wn(t,n):t,o=e.length-1,i;o>=0;o--)(i=e[o])&&(r=i(r)||r);return r},Rt=(e,t)=>(n,s)=>t(n,s,e);const An={tl:{size:6,color:"#409f11"}};let Ge=class extends l.RxDisposable{constructor(e,t){super(),this._sheetInterceptorService=e,this._formulaDataModel=t,this.disposeWithMe(this._sheetInterceptorService.intercept(A.INTERCEPTOR_POINT.CELL_CONTENT,{effect:l.InterceptorEffectEnum.Style,handler:(n,s,r)=>{var c,d,f,m;const o=(m=(f=(d=(c=this._formulaDataModel.getArrayFormulaCellData())==null?void 0:c[s.unitId])==null?void 0:d[s.subUnitId])==null?void 0:f[s.row])==null?void 0:m[s.col];return!Dt(n,!!o)||!n||(n===s.rawData&&(n={...s.rawData}),n.markers={...n==null?void 0:n.markers,...An}),r(n)},priority:10}))}};Ge=kn([Rt(0,l.Inject(A.SheetInterceptorService)),Rt(1,l.Inject(T.FormulaDataModel))],Ge);function Fn(){const e=a.useDependency(Ce.TriggerCalculationController),t=a.useDependency(l.ICommandService),n=a.useObservable(e.progress$),s=v.useCallback(()=>{t.executeCommand(T.SetFormulaCalculationStopMutation.id)},[t]),r=v.useCallback(()=>{e.clearProgress()},[e]);return E.jsx(a.ProgressBar,{progress:n,onTerminate:s,onClearProgress:r})}function Pn(e,t){return Object.keys(e).filter(n=>isNaN(Number(n))&&n!=="DefinedName").map(n=>({label:t.t(`formula.functionType.${n.toLocaleLowerCase()}`),value:`${e[n]}`}))}function kt(e){if(!e.require&&!e.repeat)return`[${e.name}]`;if(e.require&&!e.repeat)return e.name;if(!e.require&&e.repeat)return`[${e.name},...]`;if(e.require&&e.repeat)return`${e.name},...`}function At(e){const{prefix:t,value:n}=e;return E.jsxs("div",{children:[E.jsxs("span",{children:[t,"("]}),n&&n.map((s,r)=>E.jsxs("span",{children:[E.jsx("span",{children:kt(s)}),r===n.length-1?"":","]},r)),")"]})}function Fe(e){const{className:t,value:n,title:s}=e;return E.jsxs("div",{className:"univer-mb-2 univer-text-xs",children:[E.jsx("div",{className:W.clsx("univer-mb-2 univer-font-medium univer-text-gray-500 dark:!univer-text-gray-300",t),children:s}),E.jsx("div",{className:"univer-break-all univer-text-gray-900 dark:!univer-text-white",children:n})]})}function Ln(e){const{functionInfo:t,onChange:n}=e;if(!t)return null;const[s,r]=v.useState([]),[o,i]=v.useState(t.functionParameter),[c,d]=v.useState(-1);return E.jsxs("div",{children:[E.jsx("div",{className:W.clsx("univer-h-[364px] univer-overflow-y-auto",W.scrollbarClassName),children:o.map((f,m)=>E.jsxs("div",{children:[E.jsx("div",{className:"univer-text-sm",children:f.name}),E.jsx("div",{className:"univer-mb-2 univer-mt-1"})]},m))}),E.jsx("div",{className:W.clsx("univer-flex-1 univer-p-3",W.borderLeftClassName),children:E.jsx(Fe,{title:c===-1?E.jsx(At,{prefix:t.functionName,value:o}):o[c].name,value:c===-1?t.description:o[c].detail})})]})}var ie=function(){return ie=Object.assign||function(e){for(var t,n=1,s=arguments.length;n<s;n++){t=arguments[n];for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])}return e},ie.apply(this,arguments)},Un=function(e,t){var n={};for(var s in e)Object.prototype.hasOwnProperty.call(e,s)&&t.indexOf(s)<0&&(n[s]=e[s]);if(e!=null&&typeof Object.getOwnPropertySymbols=="function")for(var r=0,s=Object.getOwnPropertySymbols(e);r<s.length;r++)t.indexOf(s[r])<0&&Object.prototype.propertyIsEnumerable.call(e,s[r])&&(n[s[r]]=e[s[r]]);return n},be=v.forwardRef(function(e,t){var n=e.icon,s=e.id,r=e.className,o=e.extend,i=Un(e,["icon","id","className","extend"]),c="univerjs-icon univerjs-icon-".concat(s," ").concat(r||"").trim(),d=v.useRef("_".concat(Wn()));return Ft(n,"".concat(s),{defIds:n.defIds,idSuffix:d.current},ie({ref:t,className:c},i),o)});function Ft(e,t,n,s,r){return v.createElement(e.tag,ie(ie({key:t},$n(e,n,r)),s),(jn(e,n).children||[]).map(function(o,i){return Ft(o,"".concat(t,"-").concat(e.tag,"-").concat(i),n,void 0,r)}))}function $n(e,t,n){var s=ie({},e.attrs);n!=null&&n.colorChannel1&&s.fill==="colorChannel1"&&(s.fill=n.colorChannel1),e.tag==="mask"&&s.id&&(s.id=s.id+t.idSuffix),Object.entries(s).forEach(function(o){var i=o[0],c=o[1];i==="mask"&&typeof c=="string"&&(s[i]=c.replace(/url\(#(.*)\)/,"url(#$1".concat(t.idSuffix,")")))});var r=t.defIds;return!r||r.length===0||(e.tag==="use"&&s["xlink:href"]&&(s["xlink:href"]=s["xlink:href"]+t.idSuffix),Object.entries(s).forEach(function(o){var i=o[0],c=o[1];typeof c=="string"&&(s[i]=c.replace(/url\(#(.*)\)/,"url(#$1".concat(t.idSuffix,")")))})),s}function jn(e,t){var n,s=t.defIds;return!s||s.length===0?e:e.tag==="defs"&&(!((n=e.children)===null||n===void 0)&&n.length)?ie(ie({},e),{children:e.children.map(function(r){return typeof r.attrs.id=="string"&&s&&s.includes(r.attrs.id)?ie(ie({},r),{attrs:ie(ie({},r.attrs),{id:r.attrs.id+t.idSuffix})}):r})}):e}function Wn(){return Math.random().toString(36).substring(2,8)}be.displayName="UniverIcon";var Vn={tag:"svg",attrs:{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M14.1544 3.75557C14.3887 3.98988 14.3887 4.36978 14.1544 4.6041L6.51409 12.2444C6.40157 12.3569 6.24896 12.4201 6.08983 12.4201C5.9307 12.4201 5.77808 12.3569 5.66556 12.2444L1.84541 8.42425C1.6111 8.18993 1.6111 7.81003 1.84541 7.57572C2.07973 7.34141 2.45963 7.34141 2.69394 7.57572L6.08983 10.9716L13.3059 3.75557C13.5402 3.52126 13.9201 3.52126 14.1544 3.75557Z",fillRule:"evenodd",clipRule:"evenodd"}}]},Pt=v.forwardRef(function(e,t){return v.createElement(be,Object.assign({},e,{id:"check-mark-icon",ref:t,icon:Vn}))});Pt.displayName="CheckMarkIcon";var Hn={tag:"svg",attrs:{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M3.71274 2.86421C3.47843 2.6299 3.09853 2.6299 2.86421 2.86421C2.6299 3.09853 2.6299 3.47843 2.86421 3.71274L7.15154 8.00007L2.86421 12.2874C2.6299 12.5217 2.6299 12.9016 2.86421 13.1359C3.09853 13.3702 3.47843 13.3702 3.71274 13.1359L8.00007 8.84859L12.2874 13.1359C12.5217 13.3702 12.9016 13.3702 13.1359 13.1359C13.3702 12.9016 13.3702 12.5217 13.1359 12.2874L8.84859 8.00007L13.1359 3.71274C13.3702 3.47843 13.3702 3.09853 13.1359 2.86421C12.9016 2.6299 12.5217 2.6299 12.2874 2.86421L8.00007 7.15154L3.71274 2.86421Z"}}]},Lt=v.forwardRef(function(e,t){return v.createElement(be,Object.assign({},e,{id:"close-icon",ref:t,icon:Hn}))});Lt.displayName="CloseIcon";var Bn={tag:"svg",attrs:{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M5.3313 1.4667C5.3313 1.13533 5.59993 0.866699 5.9313 0.866699H10.069C10.4004 0.866699 10.669 1.13533 10.669 1.4667C10.669 1.79807 10.4004 2.0667 10.069 2.0667H5.9313C5.59993 2.0667 5.3313 1.79807 5.3313 1.4667Z"}},{tag:"path",attrs:{fill:"currentColor",d:"M1.09985 3.64443C1.09985 3.31306 1.36848 3.04443 1.69985 3.04443H14.2999C14.6312 3.04443 14.8999 3.31306 14.8999 3.64443C14.8999 3.9758 14.6312 4.24443 14.2999 4.24443H1.69985C1.36848 4.24443 1.09985 3.9758 1.09985 3.64443Z"}},{tag:"path",attrs:{fill:"currentColor",d:"M6.12398 8.30171C6.35829 8.0674 6.73819 8.0674 6.97251 8.30171L8.00007 9.32928L9.02764 8.30171C9.26195 8.0674 9.64185 8.0674 9.87617 8.30171C10.1105 8.53603 10.1105 8.91593 9.87617 9.15024L8.8486 10.1778L9.87617 11.2054C10.1105 11.4397 10.1105 11.8196 9.87617 12.0539C9.64185 12.2882 9.26195 12.2882 9.02764 12.0539L8.00007 11.0263L6.97251 12.0539C6.73819 12.2882 6.35829 12.2882 6.12398 12.0539C5.88966 11.8196 5.88966 11.4397 6.12398 11.2054L7.15154 10.1778L6.12398 9.15024C5.88966 8.91593 5.88966 8.53603 6.12398 8.30171Z"}},{tag:"path",attrs:{fill:"currentColor",d:"M4.75332 5.22217C3.86966 5.22217 3.15332 5.93851 3.15332 6.82217V12.5331C3.15332 13.9691 4.31738 15.1332 5.75332 15.1332H10.2465C11.6825 15.1332 12.8465 13.9691 12.8465 12.5331V6.82217C12.8465 5.93851 12.1302 5.22217 11.2465 5.22217H4.75332ZM4.35332 6.82217C4.35332 6.60125 4.53241 6.42217 4.75332 6.42217H11.2465C11.4674 6.42217 11.6465 6.60125 11.6465 6.82217V12.5331C11.6465 13.3063 11.0197 13.9332 10.2465 13.9332H5.75332C4.98012 13.9332 4.35332 13.3063 4.35332 12.5331V6.82217Z",fillRule:"evenodd",clipRule:"evenodd"}}]},Ut=v.forwardRef(function(e,t){return v.createElement(be,Object.assign({},e,{id:"delete-icon",ref:t,icon:Bn}))});Ut.displayName="DeleteIcon";var Kn={tag:"svg",attrs:{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M8.6 1.99991C8.60001 1.66854 8.33138 1.39991 8.00001 1.3999C7.66864 1.3999 7.40001 1.66853 7.4 1.9999L7.39996 7.3999H1.9999C1.66853 7.3999 1.3999 7.66853 1.3999 7.9999C1.3999 8.33127 1.66853 8.5999 1.9999 8.5999H7.39995L7.3999 13.9999C7.3999 14.3313 7.66853 14.5999 7.9999 14.5999C8.33127 14.5999 8.5999 14.3313 8.5999 13.9999L8.59995 8.5999H13.9999C14.3313 8.5999 14.5999 8.33127 14.5999 7.9999C14.5999 7.66853 14.3313 7.3999 13.9999 7.3999H8.59996L8.6 1.99991Z"}}]},$t=v.forwardRef(function(e,t){return v.createElement(be,Object.assign({},e,{id:"increase-icon",ref:t,icon:Kn}))});$t.displayName="IncreaseIcon";var qn={tag:"svg",attrs:{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M5.90913 3.57564C6.14345 3.34132 6.52335 3.34132 6.75766 3.57564L10.7577 7.57564C10.992 7.80995 10.992 8.18985 10.7577 8.42417L6.75766 12.4242C6.52335 12.6585 6.14345 12.6585 5.90913 12.4242C5.67482 12.1899 5.67482 11.81 5.90913 11.5756L9.48487 7.9999L5.90913 4.42417C5.67482 4.18985 5.67482 3.80995 5.90913 3.57564Z",fillRule:"evenodd",clipRule:"evenodd"}}]},jt=v.forwardRef(function(e,t){return v.createElement(be,Object.assign({},e,{id:"more-icon",ref:t,icon:qn}))});jt.displayName="MoreIcon";var Yn={tag:"svg",attrs:{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M12.6185 12.4423C12.5907 12.2749 12.7773 12.15 12.9343 12.2308L15.4242 13.5126C15.6102 13.6084 15.5544 13.8745 15.3439 13.8955L14.2456 14.184L13.4521 15.1286C13.3495 15.2939 13.085 15.2463 13.0534 15.0568L12.6185 12.4423Z"}},{tag:"path",attrs:{fill:"currentColor",d:"M1 3.6C1 2.16406 2.16406 1 3.6 1H12.3C13.7359 1 14.9 2.16406 14.9 3.6V5.81156C14.9003 5.81881 14.9004 5.82609 14.9004 5.8334C14.9004 5.84071 14.9003 5.84799 14.9 5.85524V10.045C14.9003 10.0522 14.9004 10.0595 14.9004 10.0668C14.9004 10.3982 14.6318 10.6668 14.3004 10.6668H11.1668C10.8907 10.6668 10.6668 10.8907 10.6668 11.1668V14.3C10.6668 14.6314 10.3982 14.9 10.0668 14.9L10.05 14.8998L3.6 14.9C2.16406 14.9 1 13.7359 1 12.3V3.6ZM13.2 5.2334C13.4761 5.2334 13.7 5.00954 13.7 4.7334V3.6C13.7 2.8268 13.0732 2.2 12.3 2.2H11.1668C10.8907 2.2 10.6668 2.42386 10.6668 2.7V4.7334C10.6668 5.00954 10.8907 5.2334 11.1668 5.2334H13.2ZM10.6668 6.9334C10.6668 6.65726 10.8907 6.4334 11.1668 6.4334H13.2C13.4761 6.4334 13.7 6.65726 13.7 6.9334V8.9668C13.7 9.24294 13.4761 9.4668 13.2 9.4668H11.1668C10.8907 9.4668 10.6668 9.24294 10.6668 8.9668V6.9334ZM8.9668 5.2334C9.24294 5.2334 9.4668 5.00954 9.4668 4.7334V2.7C9.4668 2.42386 9.24294 2.2 8.9668 2.2H6.9334C6.65726 2.2 6.4334 2.42386 6.4334 2.7V4.7334C6.4334 5.00954 6.65726 5.2334 6.9334 5.2334L8.9668 5.2334ZM6.4334 6.9334C6.4334 6.65726 6.65726 6.4334 6.9334 6.4334L8.9668 6.4334C9.24294 6.4334 9.4668 6.65726 9.4668 6.9334V8.9668C9.4668 9.24294 9.24294 9.4668 8.9668 9.4668L6.9334 9.4668C6.65726 9.4668 6.4334 9.24294 6.4334 8.9668V6.9334ZM4.7334 5.2334C5.00954 5.2334 5.2334 5.00954 5.2334 4.7334V2.7C5.2334 2.42386 5.00954 2.2 4.7334 2.2H3.6C2.8268 2.2 2.2 2.8268 2.2 3.6V4.7334C2.2 5.00954 2.42386 5.2334 2.7 5.2334H4.7334ZM2.2 6.9334C2.2 6.65726 2.42386 6.4334 2.7 6.4334H4.7334C5.00954 6.4334 5.2334 6.65725 5.2334 6.9334V8.9668C5.2334 9.24294 5.00954 9.4668 4.7334 9.4668H2.7C2.42386 9.4668 2.2 9.24294 2.2 8.9668V6.9334ZM5.2334 11.1668C5.2334 10.8907 5.00954 10.6668 4.7334 10.6668H2.7C2.42386 10.6668 2.2 10.8907 2.2 11.1668V12.3C2.2 13.0732 2.8268 13.7 3.6 13.7H4.7334C5.00954 13.7 5.2334 13.4761 5.2334 13.2V11.1668ZM9.4668 11.1668C9.4668 10.8907 9.24294 10.6668 8.9668 10.6668H6.9334C6.65726 10.6668 6.4334 10.8907 6.4334 11.1668V13.2C6.4334 13.4761 6.65726 13.7 6.9334 13.7H8.9668C9.24294 13.7 9.4668 13.4761 9.4668 13.2V11.1668Z",fillRule:"evenodd",clipRule:"evenodd"}}]},Wt=v.forwardRef(function(e,t){return v.createElement(be,Object.assign({},e,{id:"select-range-icon",ref:t,icon:Yn}))});Wt.displayName="SelectRangeIcon";function zn(e){const{onChange:t}=e,n="-1",[s,r]=v.useState(""),[o,i]=v.useState([]),[c,d]=v.useState(0),[f,m]=v.useState(n),[p,h]=v.useState(0),[g,u]=v.useState(null),_=a.useDependency(Ce.IDescriptionService),S=a.useDependency(l.LocaleService),C=a.useDependency(a.ISidebarService),R=a.useObservable(C.sidebarOptions$),b=Pn(T.FunctionType,S);b.unshift({label:S.t("formula.moreFunctions.allFunctions"),value:n});const y=S.t("formula.prompt.required"),I=S.t("formula.prompt.optional");v.useEffect(()=>{L(n)},[]),v.useEffect(()=>{F(0)},[o]),v.useEffect(()=>{R!=null&&R.visible&&(r(""),i([]),d(0),m(n),h(0),u(null),L(n))},[R]);const M=N=>{if(s.trim()==="")return N;const x=new RegExp(`(${s.toLocaleUpperCase()})`);return N.split(x).filter(Boolean).map((P,j)=>P.match(x)?E.jsx("span",{className:"univer-text-red-500",children:P},j):P)},F=N=>{if(o.length===0){u(null);return}h(N);const x=_.getFunctionInfo(o[N].name);if(!x){u(null);return}u(x),t(x)};function L(N){m(N);const x=_.getSearchListByType(+N);i(x)}function U(N){r(N);const x=_.getSearchListByName(N);i(x)}function k(N){if(N.stopPropagation(),N.key==="ArrowDown"){const x=c+1;d(x===o.length?0:x)}else if(N.key==="ArrowUp"){const x=c-1;d(x===-1?o.length-1:x)}else N.key==="Enter"&&F(c)}const $=N=>{d(N)},D=()=>{d(-1)};return E.jsxs("div",{children:[E.jsxs("div",{className:"univer-flex univer-items-center univer-justify-between univer-gap-2",children:[E.jsx(W.Select,{value:f,options:b,onChange:L}),E.jsx(W.Input,{placeholder:S.t("formula.moreFunctions.searchFunctionPlaceholder"),onKeyDown:k,value:s,onChange:U,size:"small",allowClear:!0})]}),o.length>0&&E.jsx("ul",{className:W.clsx("univer-m-0 univer-mt-2 univer-box-border univer-max-h-72 univer-w-full univer-select-none univer-list-none univer-overflow-y-auto univer-rounded univer-p-3 univer-outline-none",W.borderClassName,W.scrollbarClassName),onKeyDown:k,tabIndex:-1,children:o.map(({name:N},x)=>E.jsxs("li",{className:W.clsx("univer-relative univer-box-border univer-cursor-pointer univer-rounded univer-px-7 univer-py-1 univer-text-sm univer-text-gray-900 univer-transition-colors dark:!univer-text-white",{"univer-bg-gray-200 dark:!univer-bg-gray-600":c===x}),onMouseEnter:()=>$(x),onMouseLeave:D,onClick:()=>F(x),children:[p===x&&E.jsx(Pt,{className:"univer-absolute univer-left-1.5 univer-top-1/2 univer-inline-flex -univer-translate-y-1/2 univer-text-base univer-text-primary-600"}),E.jsx("span",{className:"univer-block",children:M(N)})]},x))}),g&&E.jsxs("div",{className:W.clsx("univer-mx-0 univer-my-2 univer-overflow-y-auto",W.scrollbarClassName),children:[E.jsx(Fe,{title:g.functionName,value:g.description}),E.jsx(Fe,{title:S.t("formula.moreFunctions.syntax"),value:E.jsx(At,{prefix:g.functionName,value:g.functionParameter})}),E.jsx(Fe,{title:S.t("formula.prompt.helpExample"),value:`${g.functionName}(${g.functionParameter.map(N=>N.example).join(",")})`}),g.functionParameter&&g.functionParameter.map(N=>E.jsx(Fe,{title:N.name,value:`${N.require?y:I} ${N.detail}`},N.name))]})]})}function Gn(){const e=w.useActiveWorkbook(),[t,n]=v.useState(!0),[s,r]=v.useState(!1),[o,i]=v.useState(null);a.useDependency(w.IEditorBridgeService);const c=a.useDependency(l.LocaleService),d=a.useDependency(Q.IEditorService),f=a.useDependency(l.IUniverInstanceService),m=a.useDependency(l.ICommandService);function p(){n(!t),r(!s)}function h(){const g=A.getSheetCommandTarget(f);if(!g)return;m.executeCommand(w.SetCellEditVisibleOperation.id,{visible:!0,unitId:g.unitId,eventType:B.DeviceInputEventType.Dblclick});const u=d.getEditor(l.DOCS_NORMAL_EDITOR_UNIT_ID_KEY),_=d.getEditor(l.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),S=`=${o==null?void 0:o.functionName}(`;u==null||u.replaceText(S),_==null||_.replaceText(S,!1)}return E.jsxs("div",{"data-u-comp":"sheets-formula-functions-panel",className:"univer-box-border univer-flex univer-h-full univer-flex-col univer-justify-between univer-py-2",children:[t&&E.jsx(zn,{onChange:i}),s&&E.jsx(Ln,{functionInfo:o,onChange:()=>{}}),E.jsxs("div",{className:"univer-flex univer-justify-end",children:[s&&E.jsx(W.Button,{variant:"primary",onClick:p,className:"univer-mb-5 univer-ml-4 univer-mr-0 univer-mt-0",children:c.t("formula.moreFunctions.next")}),s&&E.jsx(W.Button,{onClick:p,className:"univer-mb-5 univer-ml-4 univer-mr-0 univer-mt-0",children:c.t("formula.moreFunctions.prev")}),t&&!!e&&E.jsx(W.Button,{variant:"primary",onClick:h,className:"univer-mb-5 univer-ml-4 univer-mr-0 univer-mt-0",children:c.t("formula.moreFunctions.confirm")})]})]})}function Zn(e){return{id:ce.id,title:"SUM",icon:"SumIcon",type:a.MenuItemType.BUTTON,params:{value:"SUM"},hidden$:a.getMenuHiddenObservable(e,l.UniverInstanceType.UNIVER_SHEET),disabled$:w.getCurrentRangeDisable$(e,{workbookTypes:[A.WorkbookEditablePermission],worksheetTypes:[A.WorksheetEditPermission,A.WorksheetSetCellValuePermission],rangeTypes:[A.RangeProtectionPermissionEditPoint]})}}function Xn(e){return{id:ce.id,title:"COUNT",icon:"CntIcon",type:a.MenuItemType.BUTTON,params:{value:"COUNT"},hidden$:a.getMenuHiddenObservable(e,l.UniverInstanceType.UNIVER_SHEET),disabled$:w.getCurrentRangeDisable$(e,{workbookTypes:[A.WorkbookEditablePermission],worksheetTypes:[A.WorksheetEditPermission,A.WorksheetSetCellValuePermission],rangeTypes:[A.RangeProtectionPermissionEditPoint]})}}function Qn(e){return{id:ce.id,title:"AVERAGE",icon:"AvgIcon",type:a.MenuItemType.BUTTON,params:{value:"AVERAGE"},hidden$:a.getMenuHiddenObservable(e,l.UniverInstanceType.UNIVER_SHEET),disabled$:w.getCurrentRangeDisable$(e,{workbookTypes:[A.WorkbookEditablePermission],worksheetTypes:[A.WorksheetEditPermission,A.WorksheetSetCellValuePermission],rangeTypes:[A.RangeProtectionPermissionEditPoint]})}}function Jn(e){return{id:ce.id,title:"MAX",icon:"MaxIcon",type:a.MenuItemType.BUTTON,params:{value:"MAX"},hidden$:a.getMenuHiddenObservable(e,l.UniverInstanceType.UNIVER_SHEET),disabled$:w.getCurrentRangeDisable$(e,{workbookTypes:[A.WorkbookEditablePermission],worksheetTypes:[A.WorksheetEditPermission,A.WorksheetSetCellValuePermission],rangeTypes:[A.RangeProtectionPermissionEditPoint]})}}function er(e){return{id:ce.id,title:"MIN",icon:"MinIcon",type:a.MenuItemType.BUTTON,params:{value:"MIN"},hidden$:a.getMenuHiddenObservable(e,l.UniverInstanceType.UNIVER_SHEET),disabled$:w.getCurrentRangeDisable$(e,{workbookTypes:[A.WorkbookEditablePermission],worksheetTypes:[A.WorksheetEditPermission,A.WorksheetSetCellValuePermission],rangeTypes:[A.RangeProtectionPermissionEditPoint]})}}function tr(e){return{id:Qe.id,title:"formula.insert.more",tooltip:"formula.insert.tooltip",type:a.MenuItemType.BUTTON,hidden$:a.getMenuHiddenObservable(e,l.UniverInstanceType.UNIVER_SHEET),disabled$:w.getCurrentRangeDisable$(e,{workbookTypes:[A.WorkbookEditablePermission],worksheetTypes:[A.WorksheetEditPermission,A.WorksheetSetCellValuePermission],rangeTypes:[A.RangeProtectionPermissionEditPoint]})}}function nr(e){return e.get(l.IUniverInstanceService).getCurrentTypeOfUnit$(l.UniverInstanceType.UNIVER_SHEET).pipe(q.switchMap(s=>s&&e.get(a.IClipboardInterfaceService)?new q.Observable(o=>o.next(!e.get(a.IClipboardInterfaceService).supportClipboard)):q.of(!0)))}function rr(e){return{id:Xe.id,type:a.MenuItemType.BUTTON,title:"formula.operation.pasteFormula",disabled$:nr(e).pipe(q.combineLatestWith(w.getCurrentRangeDisable$(e,{workbookTypes:[A.WorkbookEditablePermission],rangeTypes:[A.RangeProtectionPermissionEditPoint],worksheetTypes:[A.WorksheetSetCellValuePermission,A.WorksheetEditPermission]})),q.map(([t,n])=>t||n))}}const sr={[a.RibbonFormulasGroup.BASIC]:{[`${ce.id}.sum`]:{order:0,menuItemFactory:Zn},[`${ce.id}.count`]:{order:1,menuItemFactory:Xn},[`${ce.id}.average`]:{order:2,menuItemFactory:Qn},[`${ce.id}.max`]:{order:3,menuItemFactory:Jn},[`${ce.id}.min`]:{order:4,menuItemFactory:er}},[a.RibbonFormulasGroup.OTHERS]:{[Qe.id]:{order:0,menuItemFactory:tr}},[w.PASTE_SPECIAL_MENU_ID]:{[Xe.id]:{order:4,menuItemFactory:rr}}},or="meta_key_ctrl_And_Shift",Je=[a.KeyCode.ARROW_DOWN,a.KeyCode.ARROW_UP,a.KeyCode.ARROW_LEFT,a.KeyCode.ARROW_RIGHT],ir=[...Je,a.KeyCode.ENTER,a.KeyCode.TAB,a.KeyCode.ESC];function cr(){const e=[];for(const t of ir)e.push({id:Ee.id,binding:t,preconditions:n=>w.whenFormulaEditorActivated(n),staticParameters:{eventType:B.DeviceInputEventType.Keyboard,keycode:t}});return e}function ar(){const e=[];for(const t of Je)e.push({id:Ee.id,binding:t|a.MetaKeys.SHIFT,preconditions:n=>w.whenFormulaEditorActivated(n),staticParameters:{eventType:B.DeviceInputEventType.Keyboard,keycode:t,metaKey:a.MetaKeys.SHIFT}});return e}function lr(){const e=[];for(const t of Je)e.push({id:Ee.id,binding:t|a.MetaKeys.CTRL_COMMAND,preconditions:n=>w.whenFormulaEditorActivated(n),staticParameters:{eventType:B.DeviceInputEventType.Keyboard,keycode:t,metaKey:a.MetaKeys.CTRL_COMMAND}});return e}function ur(){const e=[];for(const t of Je)e.push({id:Ee.id,binding:t|a.MetaKeys.SHIFT|a.MetaKeys.CTRL_COMMAND,preconditions:n=>w.whenFormulaEditorActivated(n),staticParameters:{eventType:B.DeviceInputEventType.Keyboard,keycode:t,metaKey:or}});return e}const dr={id:ct.id,binding:a.KeyCode.F4,preconditions:e=>w.whenFormulaEditorActivated(e)};function hr(){const e=[];for(const t of[a.KeyCode.ENTER,a.KeyCode.TAB,a.KeyCode.ARROW_DOWN,a.KeyCode.ARROW_UP])e.push({id:Ee.id,binding:t,preconditions:n=>fn(n),staticParameters:{eventType:B.DeviceInputEventType.Keyboard,keycode:t,isSingleEditor:!0}});return e}const fr={id:Ce.QuickSumCommand.id,binding:a.MetaKeys.ALT|a.KeyCode.EQUAL,preconditions:w.whenSheetEditorFocused,mac:a.MetaKeys.CTRL_COMMAND|a.MetaKeys.ALT|a.KeyCode.EQUAL,description:"shortcut.sheets-formula-ui.quick-sum",group:"4_sheet-edit"};var gr=Object.getOwnPropertyDescriptor,mr=(e,t,n,s)=>{for(var r=s>1?void 0:s?gr(t,n):t,o=e.length-1,i;o>=0;o--)(i=e[o])&&(r=i(r)||r);return r},ye=(e,t)=>(n,s)=>t(n,s,e);let Ze=class extends l.Disposable{constructor(e,t,n,s,r,o,i){super(),this._injector=e,this._menuManagerService=t,this._commandService=n,this._shortcutService=s,this._uiPartsService=r,this._renderManagerService=o,this._componentManager=i,this._initialize()}_initialize(){this._registerCommands(),this._registerMenus(),this._registerShortcuts(),this._registerComponents(),this._registerRenderModules()}_registerMenus(){this._menuManagerService.mergeMenu(sr)}_registerCommands(){[Xe,ce,Qe,Nt,xt,Ee,ct].forEach(e=>this.disposeWithMe(this._commandService.registerCommand(e)))}_registerShortcuts(){[...cr(),...ar(),...lr(),...ur(),...hr(),fr,dr].forEach(e=>{this.disposeWithMe(this._shortcutService.registerShortcut(e))})}_registerComponents(){this.disposeWithMe(this._uiPartsService.registerComponent(w.SheetsUIPart.FORMULA_AUX,()=>a.connectInjector(Fn,this._injector))),this._componentManager.register(Ot,Gn)}_registerRenderModules(){this.disposeWithMe(this._renderManagerService.registerRenderModule(l.UniverInstanceType.UNIVER_SHEET,[ze]))}};Ze=mr([ye(0,l.Inject(l.Injector)),ye(1,a.IMenuManagerService),ye(2,l.ICommandService),ye(3,a.IShortcutService),ye(4,a.IUIPartsService),ye(5,B.IRenderManagerService),ye(6,l.Inject(a.ComponentManager))],Ze);class at{constructor(){Y(this,"_currentSelector$",new q.BehaviorSubject(null));Y(this,"currentSelector$",this._currentSelector$.asObservable())}showRangeSelectorDialog(t){const n=t.callback,s=new Promise(r=>{t.callback=o=>{r(o),n(o)}});return this._currentSelector$.next(t),s}}var pr=Object.getOwnPropertyDescriptor,Sr=(e,t,n,s)=>{for(var r=s>1?void 0:s?pr(t,n):t,o=e.length-1,i;o>=0;o--)(i=e[o])&&(r=i(r)||r);return r},Oe=(e,t)=>(n,s)=>t(n,s,e);exports.RefSelectionsRenderService=class extends w.BaseSelectionRenderService{constructor(n,s,r,o,i,c,d){super(s,r,o,i,c);Y(this,"_workbookSelections");Y(this,"_eventDisposables");this._context=n,this._contextService=c,this._refSelectionsService=d,this._workbookSelections=this._refSelectionsService.getWorkbookSelections(this._context.unitId),this._initSelectionChangeListener(),this._initSkeletonChangeListener(),this._initUserActionSyncListener(),this._setSelectionStyle(vr(this._themeService)),this._remainLastEnabled=!0,this._highlightHeader=!1}getLocation(){return this._skeleton.getLocation()}setRemainLastEnabled(n){this._remainLastEnabled=n}setSkipLastEnabled(n){this._skipLastEnabled=n}clearLastSelection(){const n=this._selectionControls[this._selectionControls.length-1];n&&(n.dispose(),this._selectionControls.pop())}enableSelectionChanging(){return this._disableSelectionChanging(),this._eventDisposables=this._initCanvasEventListeners(),l.toDisposable(()=>this._disableSelectionChanging())}_disableSelectionChanging(){var n;(n=this._eventDisposables)==null||n.dispose(),this._eventDisposables=null}disableSelectionChanging(){this._disableSelectionChanging()}_initCanvasEventListeners(){const n=this._getSheetObject(),{spreadsheetRowHeader:s,spreadsheetColumnHeader:r,spreadsheet:o,spreadsheetLeftTopPlaceholder:i}=n,{scene:c}=this._context,d=new l.DisposableCollection;return d.add(o==null?void 0:o.onPointerDown$.subscribeEvent((f,m)=>{this.inRefSelectionMode()&&(this._onPointerDown(f,o.zIndex+1,l.RANGE_TYPE.NORMAL,this._getActiveViewport(f)),f.button!==2&&m.stopPropagation())})),d.add(s==null?void 0:s.onPointerDown$.subscribeEvent((f,m)=>{if(!this.inRefSelectionMode())return;const p=this._sheetSkeletonManagerService.getCurrent().skeleton,{row:h}=w.getCoordByOffset(f.offsetX,f.offsetY,c,p);w.checkInHeaderRanges(this._workbookSelections.getCurrentSelections(),h,l.RANGE_TYPE.ROW)||(this._onPointerDown(f,(o.zIndex||1)+1,l.RANGE_TYPE.ROW,this._getActiveViewport(f),B.ScrollTimerType.Y),f.button!==2&&m.stopPropagation())})),d.add(r==null?void 0:r.onPointerDown$.subscribeEvent((f,m)=>{if(!this.inRefSelectionMode())return;const p=this._sheetSkeletonManagerService.getCurrent().skeleton,{column:h}=w.getCoordByOffset(f.offsetX,f.offsetY,c,p);w.checkInHeaderRanges(this._workbookSelections.getCurrentSelections(),h,l.RANGE_TYPE.COLUMN)||(this._onPointerDown(f,(o.zIndex||1)+1,l.RANGE_TYPE.COLUMN,this._getActiveViewport(f),B.ScrollTimerType.X),f.button!==2&&m.stopPropagation())})),d.add(i==null?void 0:i.onPointerDown$.subscribeEvent((f,m)=>{if(this._reset(),!this.inRefSelectionMode())return;const p=this._sheetSkeletonManagerService.getCurrent().skeleton,h=w.getAllSelection(p);this._addSelectionControlByModelData(h),this._selectionMoveStart$.next(this.getSelectionDataWithStyle());const g=c.onPointerUp$.subscribeEvent(()=>{g.unsubscribe(),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle())});f.button!==2&&m.stopPropagation()})),d}_addSelectionControlByModelData(n){var c;const s=this._skeleton,r=(c=n.style)!=null?c:w.genNormalSelectionStyle(this._themeService),o=this._scene;return n.style=r,this.newSelectionControl(o,s,n)}_initSelectionChangeListener(){this.disposeWithMe(this._refSelectionsService.selectionSet$.subscribe(n=>{this._reset(),this._skeleton&&this.resetSelectionsByModelData(n||[])}))}_initUserActionSyncListener(){this.disposeWithMe(this.selectionMoveStart$.subscribe(n=>{this._updateSelections(n,A.SelectionMoveType.MOVE_START)})),this.disposeWithMe(this.selectionMoving$.subscribe(n=>{this._updateSelections(n,A.SelectionMoveType.MOVING)})),this.disposeWithMe(this.selectionMoveEnd$.subscribe(n=>{this._updateSelections(n,A.SelectionMoveType.MOVE_END)}))}_updateSelections(n,s){const o=this._context.unit.getActiveSheet().getSheetId();n.length!==0&&this._workbookSelections.setSelections(o,n.map(i=>A.convertSelectionDataToRange(i)),s)}_initSkeletonChangeListener(){this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(n=>{if(!n)return;const{skeleton:s}=n,{scene:r}=this._context,o=r.getViewport(B.SHEET_VIEWPORT_KEY.VIEW_MAIN);this._skeleton&&this._skeleton.worksheet.getSheetId()!==s.worksheet.getSheetId()&&this._reset(),this._changeRuntime(s,r,o);const i=this._workbookSelections.getCurrentSelections();this.resetSelectionsByModelData(i)}))}_getActiveViewport(n){const s=this._getSheetObject();return s==null?void 0:s.scene.getActiveViewportByCoord(B.Vector2.FromArray([n.offsetX,n.offsetY]))}_getSheetObject(){return w.getSheetObject(this._context.unit,this._context)}_onPointerDown(n,s=0,r=l.RANGE_TYPE.NORMAL,o,i=B.ScrollTimerType.ALL){var $;this._rangeType=r;const c=this._skeleton,d=this._scene;if(!d||!c)return;o&&(this._activeViewport=o);const{offsetX:f,offsetY:m}=n,p=d.getViewport(B.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(!p)return;const h=d.getCoordRelativeToViewport(B.Vector2.FromArray([f,m])),{x:g,y:u}=h;this._startViewportPosX=g,this._startViewportPosY=u;const _=d.getScrollXYInfoByViewport(h),{scaleX:S,scaleY:C}=d.getAncestorScale(),R=this._skeleton.getCellByOffset(g,u,S,C,_);if(!R)return;switch(r){case l.RANGE_TYPE.NORMAL:break;case l.RANGE_TYPE.ROW:R.startColumn=0,R.endColumn=this._skeleton.getColumnCount()-1;break;case l.RANGE_TYPE.COLUMN:R.startRow=0,R.endRow=this._skeleton.getRowCount()-1;break;case l.RANGE_TYPE.ALL:R.startRow=0,R.startColumn=0,R.endRow=this._skeleton.getRowCount()-1,R.endColumn=this._skeleton.getColumnCount()-1}const b={range:R,primary:R,style:null};b.range.rangeType=r;const y=w.attachSelectionWithCoord(b,this._skeleton);this._startRangeWhenPointerDown={...y.rangeWithCoord};const I={...y.rangeWithCoord,rangeType:r};let M=this.getActiveSelectionControl();const F=this.getSelectionControls();for(const D of F){if(n.button===2&&l.Rectangle.contains(D.model,I)){M=D;return}if(D.model.isEqual(I)){M=D;break}}this._checkClearPreviousControls(n);const L=M==null?void 0:M.model.currentCell,U=n.shiftKey&&L,k=this._remainLastEnabled&&!n.ctrlKey&&!n.shiftKey&&!this._skipLastEnabled&&!this._singleSelectionEnabled;U&&L?this._makeSelectionByTwoCells(L,I,c,r,M):k&&M?M.updateRangeBySelectionWithCoord(y):M=this.newSelectionControl(d,c,b);for(let D=0;D<this.getSelectionControls().length-1;D++)this.getSelectionControls()[D].clearHighlight();this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),d.disableObjectsEvent(),this._clearUpdatingListeners(),this._addEndingListeners(),($=d.getTransformer())==null||$.clearSelectedObjects(),this._setupPointerMoveListener(p,M,r,i,g,u),this._escapeShortcutDisposable=this._shortcutService.forceEscape(),this._scenePointerUpSub=d.onPointerUp$.subscribeEvent(()=>{var D;this._clearUpdatingListeners(),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()),(D=this._escapeShortcutDisposable)==null||D.dispose(),this._escapeShortcutDisposable=null})}newSelectionControl(n,s,r){const o=this.getSelectionControls().length,{rowHeaderWidth:i,columnHeaderHeight:c}=s,d=new w.SelectionControl(n,o,this._themeService,{highlightHeader:this._highlightHeader,enableAutoFill:!1,rowHeaderWidth:i,columnHeaderHeight:c}),f=w.attachSelectionWithCoord(r,s);return d.updateRangeBySelectionWithCoord(f),this._selectionControls.push(d),d.setControlExtension({skeleton:s,scene:n,themeService:this._themeService,injector:this._injector,selectionHooks:{selectionMoveEnd:()=>{this._selectionMoveEnd$.next(this.getSelectionDataWithStyle())}}}),d}};exports.RefSelectionsRenderService=Sr([Oe(1,l.Inject(l.Injector)),Oe(2,l.Inject(l.ThemeService)),Oe(3,a.IShortcutService),Oe(4,l.Inject(w.SheetSkeletonManagerService)),Oe(5,l.IContextService),Oe(6,A.IRefSelectionsService)],exports.RefSelectionsRenderService);function vr(e){const t=w.genNormalSelectionStyle(e);return t.widgets={tl:!0,tc:!0,tr:!0,ml:!0,mr:!0,bl:!0,bc:!0,br:!0},t}const lt=(e,t,n=!0)=>{let s=-1;return e.reduce((r,o,i)=>{if(r.isFinish)return r;const c=r.currentIndex;if(typeof o!="string")r.currentIndex+=o.token.length;else{const d=o.length;r.currentIndex+=d}return(n?r.currentIndex===t:t>c&&t<=r.currentIndex)&&(s=i,r.isFinish=!0),r},{currentIndex:0,isFinish:!1}),s},Vt=(e,t)=>{const n=e[t];let s=-1;if(!n||typeof n=="string"||n.nodeType!==T.sequenceNodeType.REFERENCE)return-1;for(let r=0;r<=t;r++){const o=e[r];typeof o!="string"&&o.nodeType===T.sequenceNodeType.REFERENCE&&s++}return s},Cr=(e,t=100)=>{v.useEffect(()=>{let n=null;const s=()=>{n===null&&(n=window.setTimeout(()=>{e(),n=null},t))};return window.addEventListener("scroll",s),window.addEventListener("resize",s),()=>{n!==null&&clearTimeout(n),window.removeEventListener("scroll",s),window.removeEventListener("resize",s)}},[e,t])};function Ht(e,t,n){const s=a.useDependency(Q.IEditorService),r=v.useMemo(()=>new q.BehaviorSubject({left:-999,top:-999,right:-999,bottom:-999}),[]),o=a.useDependency(a.ISidebarService),i=a.useDependency(l.IUniverInstanceService),c=a.useEvent(()=>{var b;const d=s.getEditor(e);if(!d)return;const f=d.getBoundingClientRect(),{marginTop:m=0,marginBottom:p=0}=d.getDocumentData().documentStyle,h=d.getSkeleton();if(!h)return;const g=(b=h.getSkeletonData())==null?void 0:b.pages[0].height;let{left:u,top:_,right:S,bottom:C}=f;_=_+m,C=g?_+g:C-p;const R=r.getValue();if(!(R.left===u&&R.top===_&&R.right===S&&R.bottom===C))return r.next({left:u-1,right:S+1,top:_-1,bottom:C+1}),f});return v.useEffect(()=>{t&&c()},[e,s,i.unitAdded$,c,t,...n!=null?n:[]]),Cr(c),v.useEffect(()=>{const d=o.scrollEvent$.pipe(q.throttleTime(100)).subscribe(c);return()=>{d.unsubscribe()}},[]),[r,c]}const Te=e=>{const t=v.useRef(e);return t.current=e,t},_r=(e,t,n)=>{const s=a.useDependency(Ce.IDescriptionService),r=a.useDependency(T.LexerTreeBuilder),[o,i]=v.useState(),[c,d]=v.useState(-1),[f,m]=v.useState(!0),p=Te(f),h=v.useRef(t);h.current=t;const g=()=>{i(void 0),d(-1),m(!1)};return v.useEffect(()=>{if(n&&e){const u=n.selectionChange$.pipe(q.debounceTime(50)).subscribe(S=>{if(S.textRanges.length===1){const[C]=S.textRanges;if(C.collapsed&&p.current){const R=r.getFunctionAndParameter(`${h.current}A`,C.startOffset-1);if(R){const{functionName:b,paramIndex:y}=R,I=s.getFunctionInfo(b);i(I),d(y);return}}}i(void 0),d(-1)}),_=n.selectionChange$.pipe(q.filter(S=>S.isEditing),q.filter(S=>S.textRanges.length===1),q.map(S=>S.textRanges[0].startOffset),q.distinctUntilChanged()).subscribe(()=>{m(!0)});return()=>{u.unsubscribe(),_.unsubscribe()}}},[n,e]),v.useEffect(()=>{e||g()},[e]),{functionInfo:o,paramIndex:c,reset:g}},Rr=({onClick:e})=>E.jsx("div",{className:"univer-z-[15] univer-box-border univer-h-[18px] univer-cursor-pointer univer-overflow-visible univer-whitespace-nowrap univer-rounded-l univer-border univer-border-r-0 univer-border-gray-600 univer-bg-primary-600 univer-p-0.5 univer-text-xs univer-font-bold univer-leading-[13px] univer-text-white",onClick:e,children:"?"}),nt=({className:e,title:t,value:n})=>E.jsxs("div",{className:"univer-my-2",children:[E.jsx("div",{className:W.clsx("univer-mb-2 univer-text-sm univer-font-medium univer-text-gray-900 dark:!univer-text-white",e),children:t}),E.jsx("div",{className:"univer-whitespace-pre-wrap univer-break-words univer-text-xs univer-text-gray-500",children:n})]}),Ir=e=>{const{prefix:t,value:n,active:s,onClick:r}=e;return E.jsxs("div",{children:[E.jsxs("span",{children:[t,"("]}),n&&n.map((o,i)=>E.jsxs("span",{children:[E.jsx("span",{className:s===i?"univer-text-primary-500":"",onClick:()=>r(i),children:kt(o)}),i===n.length-1?"":","]},o.name)),")"]})},It=()=>{};function yr(e){const{onParamsSwitch:t=It,onClose:n=It,isFocus:s,editor:r,formulaText:o}=e,{functionInfo:i,paramIndex:c,reset:d}=_r(s,o,r),f=v.useMemo(()=>!!i&&c>=0,[i,c]),m=a.useDependency(w.IEditorBridgeService),p=!a.useObservable(m.helpFunctionVisible$),[h,g]=v.useState(!0),u=a.useDependency(l.LocaleService),_=u.t("formula.prompt.required"),S=u.t("formula.prompt.optional"),C=r.getEditorId(),[R]=Ht(C,f,[i,c]);function b(M){t&&t(M)}const y=a.useEvent(M=>{m.helpFunctionVisible$.next(!M)}),I=()=>{y(!0),n()};return f&&i?p?E.jsx(a.RectPopup,{portal:!0,anchorRect$:R,direction:"left-center",children:E.jsx(Rr,{onClick:()=>y(!1)})},"hidden"):E.jsx(a.RectPopup,{portal:!0,onClickOutside:()=>d(),anchorRect$:R,direction:"vertical",children:E.jsxs("div",{className:W.clsx("univer-m-0 univer-box-border univer-w-[250px] univer-select-none univer-list-none univer-rounded-lg univer-bg-white univer-leading-5 univer-shadow-md univer-outline-none dark:!univer-bg-gray-900",W.borderClassName),children:[E.jsxs("div",{className:W.clsx("univer-wrap-anywhere univer-box-border univer-flex univer-items-center univer-justify-between univer-px-4 univer-py-3 univer-text-xs univer-font-medium univer-text-gray-900 dark:!univer-text-white",W.borderTopClassName),children:[E.jsx(Ir,{prefix:i.functionName,value:i.functionParameter,active:c,onClick:b}),E.jsxs("div",{className:"univer-flex",children:[E.jsx("div",{className:"univer-ml-2 univer-flex univer-h-6 univer-w-6 univer-cursor-pointer univer-items-center univer-justify-center univer-rounded univer-bg-transparent univer-p-0 univer-text-xs univer-text-gray-500 univer-outline-none univer-transition-colors hover:univer-bg-gray-200 dark:hover:!univer-bg-gray-600",style:{transform:h?"rotateZ(-90deg)":"rotateZ(90deg)"},onClick:()=>g(!h),children:E.jsx(jt,{})}),E.jsx("div",{className:"univer-ml-2 univer-flex univer-h-6 univer-w-6 univer-cursor-pointer univer-items-center univer-justify-center univer-rounded univer-bg-transparent univer-p-0 univer-text-xs univer-text-gray-600 univer-outline-none univer-transition-colors hover:univer-bg-gray-300 dark:!univer-text-gray-200 dark:hover:!univer-bg-gray-600",onClick:I,children:E.jsx(Lt,{})})]})]}),E.jsx("div",{className:W.clsx("univer-box-border univer-max-h-[350px] univer-overflow-y-auto univer-px-4 univer-pb-3 univer-pt-0",W.scrollbarClassName),style:{height:h?"unset":0,padding:h?"revert-layer":0},children:E.jsxs("div",{className:"univer-mt-3",children:[E.jsx(nt,{title:u.t("formula.prompt.helpExample"),value:`${i.functionName}(${i.functionParameter.map(M=>M.example).join(",")})`}),E.jsx(nt,{title:u.t("formula.prompt.helpAbstract"),value:i.description}),i&&i.functionParameter&&i.functionParameter.map((M,F)=>E.jsx(nt,{className:c===F?"univer-text-primary-500":"",title:M.name,value:`${M.require?_:S} ${M.detail}`},F))]})})]})},"show"):null}const Er=e=>{const t=a.useDependency(Q.IEditorService);return a.useEvent(s=>{var r,o;if(e){t.focus(e.getEditorId());const i=[...e.getSelectionRanges()];if(l.Tools.isDefine(s))e.setSelectionRanges([{startOffset:s,endOffset:s}]);else if(!i.length&&!e.docSelectionRenderService.isOnPointerEvent){const c=(o=(r=e.getDocumentData().body)==null?void 0:r.dataStream)!=null?o:`\r
|
|
2
|
-
`,d=Math.max(
|
|
3
|
-
`;let
|
|
4
|
-
`).slice(0,-2),c=(h=n.sequenceNodesBuilder(i.slice(1)))!=null?h:[],d=lt(c,o,!1),f=Vt(c,d);return{nodeIndex:d,updatingRefIndex:f,sequenceNodes:c,offset:o}},Lr=()=>{},Ur=(e,t,n,s,r,o,i,c,d,f=Lr)=>{var $;const m=a.useDependency(B.IRenderManagerService),p=a.useDependency(l.IUniverInstanceService),h=a.useDependency(l.ICommandService),g=a.useDependency(bt.DocSelectionManagerService),u=a.useDependency(l.ThemeService),_=a.useDependency(T.LexerTreeBuilder),S=p.getUnit(s),C=a.useEvent((D,N)=>{var x,O,P;return(P=(O=(x=p.getUnit(D))==null?void 0:x.getSheetBySheetId(N))==null?void 0:O.getName())!=null?P:""}),R=v.useMemo(()=>C(s,r),[C,r,s]),b=a.useObservable(S==null?void 0:S.activeSheet$),y=Te({activeSheet:b,sheetName:R}),I=a.useObservable(v.useMemo(()=>p.getCurrentTypeOfUnit$(l.UniverInstanceType.UNIVER_SHEET),[p])),M=m.getRenderById(($=I==null?void 0:I.getUnitId())!=null?$:""),F=M==null?void 0:M.with(exports.RefSelectionsRenderService),L=M==null?void 0:M.with(w.SheetSkeletonManagerService),U=a.useDependency(A.IRefSelectionsService),k=a.useEvent((D,N)=>{var H,re,z,he,xe,ee,Le,Ne,Ue;const x=Pr({editor:d,lexerTreeBuilder:_});if(!x)return;const{nodeIndex:O,updatingRefIndex:P,sequenceNodes:j,offset:V}=x;if(n.current===ve.NEED_ADD)if(V!==0){if(O===-1&&j.length)return;const K=D[D.length-1],J=j.splice(O+1),ae=(H=K.sheetId)!=null?H:r,ue={range:K,unitId:(re=K.unitId)!=null?re:I.getUnitId(),sheetName:C((z=K.unitId)!=null?z:I.getUnitId(),ae)},se=ae!==r,X=(I==null?void 0:I.getUnitId())!==s,de=Be([ue],i&&(se||X),R,X);j.push({token:de[0],nodeType:T.sequenceNodeType.REFERENCE});const De=[...j,...J],ge=ot(De);f(ge,Fr(j),N)}else{const K=D[D.length-1],J=(he=K.sheetId)!=null?he:r,ae={range:K,unitId:(xe=K.unitId)!=null?xe:I.getUnitId(),sheetName:C((ee=K.unitId)!=null?ee:I.getUnitId(),J)},ue=J!==r,se=(I==null?void 0:I.getUnitId())!==s,X=Be([ae],i&&(ue||se),R,se);j.unshift({token:X[0],nodeType:T.sequenceNodeType.REFERENCE});const de=ot(j);f(de,X[0].length,N)}else if(n.current===ve.EDIT_OTHER_SHEET_REFERENCE){const K=D.pop();if(!K)return;const J=j[O];if(typeof J=="object"&&J.nodeType===T.sequenceNodeType.REFERENCE){const ae=J.token;J.token=R===(b==null?void 0:b.getName())?T.serializeRange(K):T.serializeRangeWithSheet(b.getName(),K);const ue=V+(J.token.length-ae.length);f(T.generateStringWithSequence(j),ue,N)}}else{const K=[...D];if(P!==-1){const G=K.pop();G&&K.splice(P,0,G)}let J=0;const ae=j.map(G=>{var oe,me,Me,_e;if(typeof G=="string")return G;if(G.nodeType===T.sequenceNodeType.REFERENCE){const le=T.deserializeRangeWithSheet(G.token);if(le.sheetName||(le.sheetName=R),i&&((oe=y.current.activeSheet)==null?void 0:oe.getName())!==le.sheetName)return G.token;const te=K[J];if(J++,!te)return"";const we=(me=te.sheetId)!=null?me:r,et={range:te,unitId:(Me=te.unitId)!=null?Me:I.getUnitId(),sheetName:C((_e=te.unitId)!=null?_e:I.getUnitId(),we)},$e=(I==null?void 0:I.getUnitId())!==s;return Be([et],i&&(we!==r||$e),R,$e)[0]}return G.token});let ue="",se;ae.forEach((G,oe)=>{ue+=G,oe===O&&(se=ue.length)});const X=[];for(let G=J;G<=D.length-1;G++){const oe=D[G],me=(Le=oe.sheetId)!=null?Le:r,Me={range:oe,unitId:(Ne=oe.unitId)!=null?Ne:I.getUnitId(),sheetName:C((Ue=oe.unitId)!=null?Ue:I.getUnitId(),me)},_e=(I==null?void 0:I.getUnitId())!==s,te=Be([Me],i&&(me!==r||_e),R,_e);X.push(te[0])}const de=j[j.length-1],De=de&&(typeof de=="string"?!1:de.nodeType===T.sequenceNodeType.REFERENCE),ge=`${ue}${X.length&&De?",":""}${X.join(",")}`;f(ge,!X.length&&se?se:ge.length,N)}});v.useEffect(()=>{if(F&&e){let D=!0;const N=(O,P)=>{if(D){D=!1;return}k(O.map(j=>j.rangeWithCoord),P)},x=new l.DisposableCollection;return x.add(F.selectionMoving$.subscribe(O=>{N(O,!1)})),x.add(F.selectionMoveEnd$.subscribe(O=>{N(O,!0)})),()=>{x.dispose()}}},[e,k,F]),v.useEffect(()=>{if(t&&F&&d){const D=new l.DisposableCollection,N=()=>{D.dispose(),F.getSelectionControls().forEach((P,j)=>{D.add(P.selectionScaling$.subscribe(V=>{const H=F.getSelectionDataWithStyle().map(z=>z.rangeWithCoord),re=H[j];V.sheetId=re.sheetId,V.unitId=re.unitId,H[j]=V,k(H,!1)})),D.add(P.selectionMoving$.subscribe(V=>{const H=F.getSelectionDataWithStyle().map(z=>z.rangeWithCoord),re=H[j];V.sheetId=re.sheetId,V.unitId=re.unitId,H[j]=V,k(H,!0)}))})},x=q.merge(d.input$,U.selectionSet$,F.selectionMoveEnd$).pipe(Jt.debounceTime(50)).subscribe(()=>{N()});return()=>{x.unsubscribe(),D.dispose()}}},[d,t,k,F,U.selectionSet$]),F==null||F.getSelectionDataWithStyle(),v.useEffect(()=>{if(c){const D=h.onCommandExecuted(N=>{var O;if(N.id!==A.SetSelectionsOperation.id)return;const x=N.params;if(x.extra==="formula-editor"&&x.selections.length){const P=x.selections[x.selections.length-1];if(P){const j=n.current===ve.NEED_ADD,V=((O=F==null?void 0:F.getSelectionDataWithStyle())!=null?O:[]).map(H=>H.rangeWithCoord);j?V.push(P.range):V[V.length-1]=P.range,k(V,!0)}}});return()=>{D.dispose()}}},[h,d,n,_,c,k,F]),v.useEffect(()=>{if(!d)return;const D=g.textSelection$.subscribe(N=>{N.unitId===d.getEditorId()&&Bt({unitId:s,subUnitId:r,refSelections:o.current,editor:d,refSelectionsService:U,refSelectionsRenderService:F,sheetSkeletonManagerService:L,themeService:u,univerInstanceService:p,currentWorkbook:I})});return()=>D.unsubscribe()},[g.textSelection$,d,o,F,U,L,r,u,s,p])},$r=(e,t,n,s,r,o)=>{const i=a.useDependency(l.ICommandService),c=a.useDependency(Q.IEditorService),f=a.useDependency(B.IRenderManagerService).getRenderById(t),m=a.useDependency(l.IUniverInstanceService),p=f==null?void 0:f.with(exports.RefSelectionsRenderService);v.useEffect(()=>{if(e&&p)if(n){const h=()=>{const _=p.getSelectionControls().length;for(let S=1;S<=_;S++)p.clearLastSelection();return setTimeout(()=>{o()},30)},g=i.onCommandExecuted(_=>{_.id===A.SetWorksheetActiveOperation.id&&h()}),u=m.getCurrentTypeOfUnit$(l.UniverInstanceType.UNIVER_SHEET).subscribe(_=>{h()});return()=>{g.dispose(),u.unsubscribe()}}else{const h=i.beforeCommandExecuted(g=>{if(g.id===A.SetWorksheetActiveOperation.id){s(!1),r(),o();const u=c.getEditor(l.DOCS_NORMAL_EDITOR_UNIT_ID_KEY);u==null||u.focus()}});return()=>{h.dispose()}}},[e,p])},jr=(e,t,n)=>{const s=a.useDependency(T.LexerTreeBuilder),r=v.useRef(!0);v.useEffect(()=>{if(e){const o=setTimeout(()=>{r.current=!1},500);return()=>{clearTimeout(o)}}},[e]),v.useEffect(()=>{if(!r.current&&t){const o=s.checkIfAddBracket(n);t(o===0&&n.startsWith(T.operatorToken.EQUALS),`${n}`)}},[n,t])},Wr=(e,t=[],n)=>{const s=a.useDependency(Ce.IDescriptionService),[r,o]=v.useState([]),[i,c]=v.useState(""),d=v.useRef(-1),f=Te({nodes:t}),m=()=>{o([]),c(""),d.current=-1};return v.useEffect(()=>{if(n&&e){const h=n.input$.pipe(q.debounceTime(300)).subscribe(()=>{const g=n.getSelectionRanges();if(g.length===1){const u=f.current.nodes,_=g[0];if(_.collapsed){const S=lt(u,_.startOffset-1,!1);d.current=S;const C=u[S];if(C&&typeof C!="string"&&C.nodeType===T.sequenceNodeType.FUNCTION){d.current=S;const R=C.token,b=s.getSearchListByNameFirstLetter(R);o(b),c(R);return}}}d.current=-1,c(""),o(u=>u!=null&&u.length?[]:u)});return()=>{h.unsubscribe()}}},[n,e]),v.useEffect(()=>{e||m()},[e]),{searchList:r,searchText:i,handlerFormulaReplace:h=>{const g=[...f.current.nodes];if(d.current!==-1){const u=g.splice(d.current+1),_=g.pop()||"";let S=(typeof _=="string"?_.length:_.token.length)-h.length;return g.push(h),u[0]!==T.matchToken.OPEN_BRACKET&&(g.push(T.matchToken.OPEN_BRACKET),S--),{text:ot([...g,...u]),offset:S}}},reset:m}},Vr=()=>{},Hr=v.forwardRef(Br);function Br(e,t){const{isFocus:n,sequenceNodes:s,onSelect:r,editor:o,onClose:i=Vr}=e,c=o.getEditorId(),d=a.useDependency(a.IShortcutService),f=a.useDependency(l.ICommandService),{searchList:m,searchText:p,handlerFormulaReplace:h,reset:g}=Wr(n,s,o),u=v.useMemo(()=>!!m.length,[m]),_=v.useRef(void 0),[S,C]=v.useState(0),R=v.useRef(!1),[b]=Ht(c,u,[p,m]),y=Te({searchList:m,active:S}),I=k=>{const $=h(k);$&&(g(),r($))};function M(k){R.current&&C(k)}function F(){R.current&&C(-1)}v.useEffect(()=>{if(!m.length)return;const k=`sheet.formula-embedding-editor.search_function.${c}`,$=new l.DisposableCollection,D=N=>{const{searchList:x,active:O}=y.current;switch(N){case a.KeyCode.ARROW_UP:{C(P=>{const j=Math.max(0,P-1);return L(j),j});break}case a.KeyCode.ARROW_DOWN:{C(P=>{const j=Math.min(x.length-1,P+1);return L(j),j});break}case a.KeyCode.TAB:case a.KeyCode.ENTER:{const P=x[O];I(P.name);break}case a.KeyCode.ESC:{g(),i();break}}};return $.add(f.registerCommand({id:k,type:l.CommandType.OPERATION,handler(N,x){const{keyCode:O}=x;D(O)}})),[a.KeyCode.ARROW_UP,a.KeyCode.ARROW_DOWN,a.KeyCode.ENTER,a.KeyCode.ESC,a.KeyCode.TAB].map(N=>({id:k,binding:N,preconditions:()=>!0,priority:1e3,staticParameters:{eventType:B.DeviceInputEventType.Keyboard,keyCode:N}})).forEach(N=>{$.add(d.registerShortcut(N))}),()=>{$.dispose()}},[m]);function L(k){const $=_.current;if(!$)return;const D=$.children[k];if(!D)return;const x=$.getBoundingClientRect().top,O=$.offsetHeight,P=D.getBoundingClientRect(),j=P.top,V=P.height;if(j>=0&&j>x&&j-x+V<=O)return;const H=D.offsetTop-(O-V)/2;$.scrollTo({top:H,behavior:"smooth"})}const U=v.useMemo(()=>{let k="";return()=>{clearTimeout(k),R.current=!0,k=setTimeout(()=>{R.current=!1},300)}},[]);return m.length>0&&u&&E.jsx(a.RectPopup,{portal:!0,anchorRect$:b,direction:"vertical",children:E.jsx("ul",{ref:k=>{_.current=k,t&&(t.current=k)},"data-u-comp":"sheets-formula-editor",className:W.clsx("univer-m-0 univer-box-border univer-max-h-[400px] univer-w-[250px] univer-list-none univer-overflow-y-auto univer-rounded-lg univer-bg-white univer-p-2 univer-leading-5 univer-shadow-md univer-outline-none dark:!univer-bg-gray-900",W.borderClassName,W.scrollbarClassName),children:m.map((k,$)=>E.jsxs("li",{className:W.clsx("univer-box-border univer-cursor-pointer univer-rounded univer-px-2 univer-py-1 univer-text-gray-900 univer-transition-colors dark:!univer-text-white",{"univer-bg-gray-200 dark:!univer-bg-gray-600":S===$}),onMouseEnter:()=>M($),onMouseLeave:F,onMouseMove:U,onClick:()=>{I(k.name),o&&o.focus()},children:[E.jsxs("span",{className:"univer-text-xs",children:[E.jsx("span",{className:"univer-text-red-500",children:k.name.substring(0,p.length)}),E.jsx("span",{children:k.name.slice(p.length)})]}),E.jsx("span",{className:"univer-block univer-text-xs univer-text-gray-400",children:k.desc})]},k.name))})})}const Kr=e=>e.startsWith(T.operatorToken.EQUALS)?e.slice(1):"",yt=()=>{},qt=v.forwardRef((e,t)=>{var ft,gt;const{errorText:n,initValue:s,unitId:r,subUnitId:o,isFocus:i=!0,isSupportAcrossSheet:c=!1,onFocus:d=yt,onBlur:f=yt,onChange:m,onVerify:p,className:h,editorId:g,moveCursor:u=!0,onFormulaSelectingChange:_,keyboardEventConfig:S,onMoveInEditor:C,resetSelectionOnBlur:R=!0,autoScrollbar:b=!0,isSingle:y=!0,disableSelectionOnClick:I=!1,autofocus:M=!0,disableContextMenu:F,style:L}=e,U=a.useDependency(Q.IEditorService),k=v.useRef(null),$=a.useEvent(m);v.useImperativeHandle(t,()=>({isClickOutSide:Z=>k.current?!k.current.contains(Z.target):!1}));const D=a.useEvent(_),N=v.useRef(null),x=v.useRef(void 0),O=x.current,[P,j]=v.useState(i),V=v.useRef(null),H=v.useMemo(()=>g!=null?g:l.createInternalEditorID(`${w.EMBEDDING_FORMULA_EDITOR}-${l.generateRandomId(4)}`),[]),re=v.useMemo(()=>n!==void 0,[n]),z=a.useDependency(l.IUniverInstanceService),he=z.getUnit(H);a.useObservable(he==null?void 0:he.change$);const xe=xr(),ee=l.BuildTextUtils.transform.getPlainText((gt=(ft=he==null?void 0:he.getBody())==null?void 0:ft.dataStream)!=null?gt:""),Le=Te(ee),Ne=v.useMemo(()=>Kr(ee),[ee]),Ue=v.useMemo(()=>xe(Ne),[Ne,xe]),{isSelecting:K,isSelectingRef:J}=Tr({unitId:r,subUnitId:o,editorId:H,isFocus:P,disableOnClick:I}),ae=v.useRef(""),se=a.useDependency(B.IRenderManagerService).getRenderById(H),X=se==null?void 0:se.with(Q.DocSelectionRenderService),de=X==null?void 0:X.isFocusing,De=v.useMemo(()=>z.getCurrentTypeOfUnit$(l.UniverInstanceType.UNIVER_DOC),[z]),ge=a.useObservable(De),G=(ge==null?void 0:ge.getUnitId())===H,oe=v.useRef([]),me=K;a.useUpdateEffect(()=>{$(ee)},[ee,$]);const Me=Kt("="),_e=Or(r,o),le=a.useEvent((Z,ne=!0,pe,fe)=>{if(!x.current)return;ae.current=Z;const je=Z[0]==="="?Z.slice(1):"",Se=xe(je),zt=Se.reduce((Re,Ve)=>typeof Ve=="object"?`${Re}${Ve.token}`:`${Re}${Ve}`,""),We=Me(x.current,zt===je?Se:[],ne,fe);if(oe.current=We,pe){const Re=fe!=null?fe:O==null?void 0:O.getSelectionRanges();if((Re==null?void 0:Re.length)!==1)return;const Gt=Re[0].startOffset-1,Zt=lt(Se,Gt,!1),mt=Vt(Se,Zt);if(mt>=0){const pt=We.splice(mt,1)[0];pt&&We.push(pt)}_e(P?We:[],x.current)}});v.useEffect(()=>{P&&le(ee,!1,!0)},[P]),v.useEffect(()=>{if(P){if(ae.current===ee)return;le(ee,!1,!0)}},[ee]),jr(P,p,ee);const te=Er(O),we=Ar(P,r,o);v.useEffect(()=>{var Z;D(K,(Z=X==null?void 0:X.isFocusing)!=null?Z:!0)},[D,K]),Q.useKeyboardEvent(P,S,O),v.useLayoutEffect(()=>{let Z;if(V.current){Z=U.register({autofocus:M,editorUnitId:H,initialSnapshot:{id:H,body:{dataStream:`${s}\r
|
|
5
|
-
`,textRuns:[],customBlocks:[],customDecorations:[],customRanges:[]},documentStyle:{}}},V.current);const ne=U.getEditor(
|
|
1
|
+
"use strict";var Xt=Object.defineProperty;var Qt=(e,t,n)=>t in e?Xt(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n;var q=(e,t,n)=>Qt(e,typeof t!="symbol"?t+"":t,n);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const l=require("@univerjs/core"),w=require("@univerjs/sheets-ui"),T=require("@univerjs/engine-formula"),Y=require("rxjs"),Q=require("@univerjs/docs-ui"),H=require("@univerjs/engine-render"),A=require("@univerjs/sheets"),Ce=require("@univerjs/sheets-formula"),a=require("@univerjs/ui"),b=require("react/jsx-runtime"),C=require("react"),W=require("@univerjs/design"),bt=require("@univerjs/docs"),Jt=require("rxjs/operators"),Xe={id:"sheet.command.paste-formula",type:l.CommandType.COMMAND,handler:async e=>e.get(l.ICommandService).executeCommand(w.SheetPasteCommand.id,{value:w.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMULA})},Ee={id:"formula-ui.operation.select-editor-formula",type:l.CommandType.OPERATION,handler:(e,t)=>!0};var en=Object.getOwnPropertyDescriptor,tn=(e,t,n,s)=>{for(var r=s>1?void 0:s?en(t,n):t,o=e.length-1,c;o>=0;o--)(c=e[o])&&(r=c(r)||r);return r},nn=(e,t)=>(n,s)=>t(n,s,e);const Tt="FORMULA_PROMPT_ACTIVATED",Qe=l.createIdentifier("formula-ui.prompt-service");let st=class{constructor(e){q(this,"_search$",new Y.Subject);q(this,"_help$",new Y.Subject);q(this,"_navigate$",new Y.Subject);q(this,"_accept$",new Y.Subject);q(this,"_acceptFormulaName$",new Y.Subject);q(this,"search$",this._search$.asObservable());q(this,"help$",this._help$.asObservable());q(this,"navigate$",this._navigate$.asObservable());q(this,"accept$",this._accept$.asObservable());q(this,"acceptFormulaName$",this._acceptFormulaName$.asObservable());q(this,"_searching",!1);q(this,"_helping",!1);q(this,"_sequenceNodes",[]);q(this,"_isLockedOnSelectionChangeRefString",!1);q(this,"_isLockedOnSelectionInsertRefString",!1);this._contextService=e}dispose(){this._search$.complete(),this._help$.complete(),this._navigate$.complete(),this._accept$.complete(),this._acceptFormulaName$.complete(),this._sequenceNodes=[]}search(e){this._contextService.setContextValue(Tt,e.visible),this._searching=e.visible,this._search$.next(e)}isSearching(){return this._searching}help(e){this._helping=e.visible,this._help$.next(e)}isHelping(){return this._helping}navigate(e){this._navigate$.next(e)}accept(e){this._accept$.next(e)}acceptFormulaName(e){this._acceptFormulaName$.next(e)}getSequenceNodes(){return[...this._sequenceNodes]}setSequenceNodes(e){this._sequenceNodes=e}clearSequenceNodes(){this._sequenceNodes=[]}getCurrentSequenceNode(e){return this._sequenceNodes[this.getCurrentSequenceNodeIndex(e)]}getCurrentSequenceNodeByIndex(e){return this._sequenceNodes[e]}getCurrentSequenceNodeIndex(e){let t=0;const n=this._sequenceNodes[0];for(let s=0,r=this._sequenceNodes.length;s<r;s++){const o=this._sequenceNodes[s];if(typeof o=="string")t++;else{const{endIndex:c}=o;t=c}if(e<=t)return typeof n=="string"&&e!==0?s+1:s}return this._sequenceNodes.length}updateSequenceRef(e,t){const n=this._sequenceNodes[e];if(typeof n=="string"||n.nodeType!==T.sequenceNodeType.REFERENCE)return;const s=t.length-n.token.length,r={...n};r.token=t,r.endIndex+=s,this._sequenceNodes[e]=r;for(let o=e+1,c=this._sequenceNodes.length;o<c;o++){const i=this._sequenceNodes[o];if(typeof i=="string")continue;const d={...i};d.startIndex+=s,d.endIndex+=s,this._sequenceNodes[o]=d}}insertSequenceRef(e,t){const n=t.length,s=this.getCurrentSequenceNodeIndex(e);this._sequenceNodes.splice(s,0,{token:t,startIndex:e,endIndex:e+n-1,nodeType:T.sequenceNodeType.REFERENCE});for(let r=s+1,o=this._sequenceNodes.length;r<o;r++){const c=this._sequenceNodes[r];if(typeof c=="string")continue;const i={...c};i.startIndex+=n,i.endIndex+=n,this._sequenceNodes[r]=i}}insertSequenceString(e,t){const n=this.getCurrentSequenceNodeIndex(e),s=t.split("");this._sequenceNodes.splice(n,0,...s);const r=s.length;for(let o=n+r,c=this._sequenceNodes.length;o<c;o++){const i=this._sequenceNodes[o];if(typeof i=="string")continue;const d={...i};d.startIndex+=r,d.endIndex+=r,this._sequenceNodes[o]=d}}enableLockedSelectionChange(){this._isLockedOnSelectionChangeRefString=!0}disableLockedSelectionChange(){this._isLockedOnSelectionChangeRefString=!1}isLockedSelectionChange(){return this._isLockedOnSelectionChangeRefString}enableLockedSelectionInsert(){this._isLockedOnSelectionInsertRefString=!0}disableLockedSelectionInsert(){this._isLockedOnSelectionInsertRefString=!1}isLockedSelectionInsert(){return this._isLockedOnSelectionInsertRefString}};st=tn([nn(0,l.IContextService)],st);const xt={id:"formula-ui.operation.help-function",type:l.CommandType.OPERATION,handler:async(e,t)=>(e.get(Qe).help(t),!0)},ce={id:"formula-ui.operation.insert-function",type:l.CommandType.OPERATION,handler:async(e,t)=>{var I,E;const n=e.get(A.SheetsSelectionsService),s=e.get(Q.IEditorService),r=n.getCurrentSelections();if(!r||!r.length)return!1;const o=A.getSheetCommandTarget(e.get(l.IUniverInstanceService));if(!o)return!1;const{worksheet:c,unitId:i,subUnitId:d}=o,h=c.getCellMatrix(),{value:m}=t,p=e.get(l.ICommandService);e.get(w.IEditorBridgeService);const f=[],g=[];let u=null,_=0,v=0,S="";if(r.length===1&&(on(r[0].range)||cn(r[0].range)&&vt(h,r[0].range))){const{range:y,primary:R}=r[0],O=(I=R==null?void 0:R.actualRow)!=null?I:y.startRow,F=(E=R==null?void 0:R.actualColumn)!=null?E:y.startColumn;u=y,_=O,v=F;const L=St(h,O,F);L&&(S=T.serializeRange(L))}else r.some(y=>{var F,L;const{range:R,primary:O}=y;if(vt(h,R)){const U=(F=O==null?void 0:O.actualRow)!=null?F:R.startRow,k=(L=O==null?void 0:O.actualColumn)!=null?L:R.startColumn,$=St(h,U,k);if(!$)return u=R,_=U,v=k,!0;const D=T.serializeRange($),N=`=${m}(${D})`;f.push({range:R,primary:{row:U,column:k},formula:N})}else{const{startRow:U,startColumn:k,endRow:$,endColumn:D}=R;if(U===$){const N=an(h,U,D,c.getColumnCount()-1),x=N===D?D-1:D,M=T.serializeRange({startRow:U,endRow:$,startColumn:k,endColumn:x}),P=`=${m}(${M})`;g.push({range:R,primary:{row:U,column:N},formula:P})}else{let N=-1;for(let M=k;M<=D;M++){const P=ln(h,M,$,c.getRowCount()-1);N=Math.max(N,P)}const x=N===$?$-1:$;for(let M=k;M<=D;M++){const P=T.serializeRange({startRow:U,endRow:x,startColumn:M,endColumn:M}),j=`=${m}(${P})`;g.push({range:R,primary:{row:N,column:M},formula:j})}}}return!1});if(u){const y=A.getCellAtRowCol(_,v,c),R={range:l.Rectangle.clone(u),primary:{startRow:y.startRow,startColumn:y.startColumn,endRow:y.endRow,endColumn:y.endColumn,actualRow:_,actualColumn:v,isMerged:y.isMerged,isMergedMainCell:y.startRow===_&&y.startColumn===v}},O={unitId:i,subUnitId:d,selections:[R]};await p.executeCommand(A.SetSelectionsOperation.id,O);const F=s.getEditor(l.DOCS_NORMAL_EDITOR_UNIT_ID_KEY),L=s.getEditor(l.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY);p.syncExecuteCommand(w.SetCellEditVisibleOperation.id,{visible:!0,unitId:i,eventType:H.DeviceInputEventType.Dblclick});const U=`=${m}(${S}`;F==null||F.replaceText(U),L==null||L.replaceText(U,!1)}return f.length===0&&g.length===0?!1:p.executeCommand(Ce.InsertFunctionCommand.id,{list:f,listOfRangeHasNumber:g})}};function St(e,t,n){const s=rn(e,t,n);if(s!==t)return{startRow:s,endRow:t-1,startColumn:n,endColumn:n};const r=sn(e,t,n);return r!==n?{startRow:t,endRow:t,startColumn:r,endColumn:n-1}:null}function rn(e,t,n){let s=!1;if(t===0)return t;for(let r=t-1;r>=0;r--){const o=e.getValue(r,n);if(Pe(o)&&!s){if(r===0)return 0;s=!0}else{if(s&&!Pe(o))return r+1;if(s&&r===0)return 0}}return t}function sn(e,t,n){let s=!1;if(n===0)return n;for(let r=n-1;r>=0;r--){const o=e.getValue(t,r);if(Pe(o)&&!s){if(r===0)return 0;s=!0}else{if(s&&!Pe(o))return r+1;if(s&&r===0)return 0}}return n}function Pe(e){if(e!=null&&e.p){const t=e==null?void 0:e.p.body;if(t==null)return!1;const n=t.dataStream,r=n.substring(n.length-2,n.length)===l.DEFAULT_EMPTY_DOCUMENT_VALUE?n.substring(0,n.length-2):n;return l.isRealNum(r)}return e&&(e.t===l.CellValueType.NUMBER||l.getCellValueType(e)===l.CellValueType.NUMBER)}function on(e){return e.startRow===e.endRow&&e.startColumn===e.endColumn}function cn(e){return e.startRow!==e.endRow&&e.startColumn!==e.endColumn}function vt(e,t){for(let n=t.startRow;n<=t.endRow;n++)for(let s=t.startColumn;s<=t.endColumn;s++)if(Pe(e.getValue(n,s)))return!1;return!0}function an(e,t,n,s){for(let r=n;r<=s;r++)if(!e.getValue(t,r))return r;return s}function ln(e,t,n,s){for(let r=n;r<=s;r++)if(!e.getValue(r,t))return r;return s}const Mt="SHEET_FORMULA_UI_PLUGIN",Ot=`${Mt}_MORE_FUNCTIONS_COMPONENT`,Je={id:"formula-ui.operation.more-functions",type:l.CommandType.OPERATION,handler:async e=>(e.get(a.ISidebarService).open({header:{title:"formula.insert.tooltip"},children:{label:Ot}}),!0)},ct={id:"formula-ui.operation.change-ref-to-absolute",type:l.CommandType.OPERATION,handler:async e=>!0},Nt={id:"formula-ui.operation.search-function",type:l.CommandType.OPERATION,handler:async(e,t)=>(e.get(Qe).search(t),!0)};var un=Object.getOwnPropertyDescriptor,dn=(e,t,n,s)=>{for(var r=s>1?void 0:s?un(t,n):t,o=e.length-1,c;o>=0;o--)(c=e[o])&&(r=c(r)||r);return r},Be=(e,t)=>(n,s)=>t(n,s,e);exports.FormulaReorderController=class extends l.Disposable{constructor(t,n,s,r){super(),this._sheetInterceptorService=t,this._univerInstanceService=n,this._formulaDataModel=s,this._lexerTreeBuilder=r,this._initialize()}_initialize(){this.disposeWithMe(this._sheetInterceptorService.interceptCommand({getMutations:t=>t.id===A.ReorderRangeCommand.id?this._reorderFormula(t.params):{redos:[],undos:[]}}))}_reorderFormula(t){const n=[],s=[],{unitId:r,subUnitId:o,range:c,order:i}=t,d=this._univerInstanceService.getUniverSheetInstance(r),h=d==null?void 0:d.getSheetBySheetId(o);if(!h)return{redos:n,undos:s};const m=h.getCellMatrix(),p=new l.ObjectMatrix,f=new l.ObjectMatrix;let g=!1;return l.Range.foreach(c,(u,_)=>{let v=u;i.hasOwnProperty(u)&&(v=i[u]);const S=m.getValue(v,_);if(S!=null&&S.f||S!=null&&S.si){g=!0;const I=this._formulaDataModel.getFormulaStringByCell(v,_,o,r),E=this._lexerTreeBuilder.moveFormulaRefOffset(I,0,u-v),y=l.Tools.deepClone(S);y.f=E,y.si=null,p.setValue(u,_,y)}else p.setValue(u,_,S);f.setValue(u,_,m.getValue(u,_))}),g?(n.push({id:A.SetRangeValuesMutation.id,params:{unitId:r,subUnitId:o,cellValue:p.getMatrix()}}),s.push({id:A.SetRangeValuesMutation.id,params:{unitId:r,subUnitId:o,cellValue:f.getMatrix()}}),{redos:n,undos:s}):{redos:n,undos:s}}};exports.FormulaReorderController=dn([Be(0,l.Inject(A.SheetInterceptorService)),Be(1,l.Inject(l.IUniverInstanceService)),Be(2,l.Inject(T.FormulaDataModel)),Be(3,l.Inject(T.LexerTreeBuilder))],exports.FormulaReorderController);const hn="sheets-formula-ui.base.config",Ct={};function fn(e){return e.getContextValue(l.FOCUSING_DOC)&&e.getContextValue(l.FOCUSING_UNIVER_EDITOR)}function Dt(e,t=!1){return!t&&!(l.isFormulaString(e==null?void 0:e.f)||l.isFormulaId(e==null?void 0:e.si))?null:typeof(e==null?void 0:e.v)=="string"&&T.ERROR_TYPE_SET.has(e.v)?e.v:null}var gn=Object.getOwnPropertyDescriptor,mn=(e,t,n,s)=>{for(var r=s>1?void 0:s?gn(t,n):t,o=e.length-1,c;o>=0;o--)(c=e[o])&&(r=c(r)||r);return r},ke=(e,t)=>(n,s)=>t(n,s,e);const nt="SHEET_FORMULA_ALERT",pn={[T.ErrorType.DIV_BY_ZERO]:"divByZero",[T.ErrorType.NAME]:"name",[T.ErrorType.VALUE]:"value",[T.ErrorType.NUM]:"num",[T.ErrorType.NA]:"na",[T.ErrorType.CYCLE]:"cycle",[T.ErrorType.REF]:"ref",[T.ErrorType.SPILL]:"spill",[T.ErrorType.CALC]:"calc",[T.ErrorType.ERROR]:"error",[T.ErrorType.CONNECT]:"connect",[T.ErrorType.NULL]:"null"};let ot=class extends l.Disposable{constructor(e,t,n,s,r,o){super(),this._context=e,this._hoverManagerService=t,this._cellAlertManagerService=n,this._localeService=s,this._formulaDataModel=r,this._zenZoneService=o,this._init()}_init(){this._initCellAlertPopup(),this._initZenService()}_initCellAlertPopup(){this.disposeWithMe(this._hoverManagerService.currentCell$.pipe(Y.debounceTime(100)).subscribe(e=>{var t,n,s,r,o;if(e){const i=this._context.unit.getActiveSheet();if(!i)return;const d=i.getCell(e.location.row,e.location.col),h=(r=(s=(n=(t=this._formulaDataModel.getArrayFormulaCellData())==null?void 0:t[e.location.unitId])==null?void 0:n[e.location.subUnitId])==null?void 0:s[e.location.row])==null?void 0:r[e.location.col];if(l.isICellData(d)){const m=Dt(d,!!h);if(!m){this._hideAlert();return}const p=this._cellAlertManagerService.currentAlert.get(nt),f=(o=p==null?void 0:p.alert)==null?void 0:o.location;if(f&&f.row===e.location.row&&f.col===e.location.col&&f.subUnitId===e.location.subUnitId&&f.unitId===e.location.unitId)return;this._cellAlertManagerService.showAlert({type:w.CellAlertType.ERROR,title:this._localeService.t("formula.error.title"),message:this._localeService.t(`formula.error.${pn[m]}`),location:e.location,width:200,height:74,key:nt});return}}this._hideAlert()}))}_initZenService(){this.disposeWithMe(this._zenZoneService.visible$.subscribe(e=>{e&&this._hideAlert()}))}_hideAlert(){this._cellAlertManagerService.removeAlert(nt)}};ot=mn([ke(1,l.Inject(w.HoverManagerService)),ke(2,l.Inject(w.CellAlertManagerService)),ke(3,l.Inject(l.LocaleService)),ke(4,l.Inject(T.FormulaDataModel)),ke(5,a.IZenZoneService)],ot);var Sn=Object.getOwnPropertyDescriptor,vn=(e,t,n,s)=>{for(var r=s>1?void 0:s?Sn(t,n):t,o=e.length-1,c;o>=0;o--)(c=e[o])&&(r=c(r)||r);return r},_t=(e,t)=>(n,s)=>t(n,s,e);let qe=class extends l.Disposable{constructor(e,t){super(),this._autoFillService=e,this._lexerTreeBuilder=t,this._registerAutoFill()}_registerAutoFill(){const e={type:w.DATA_TYPE.FORMULA,priority:1001,match:t=>l.isFormulaString(t==null?void 0:t.f)||l.isFormulaId(t==null?void 0:t.si),isContinue:(t,n)=>t.type===w.DATA_TYPE.FORMULA,applyFunctions:{[w.APPLY_TYPE.COPY]:(t,n,s,r,o)=>{const{data:c,index:i}=t;return this._fillCopyFormula(c,n,s,i,r,o)}}};this._autoFillService.registerRule(e)}_fillCopyFormula(e,t,n,s,r,o){var h,m;const c=_n(r),i=[],d=new Map;for(let p=1;p<=t;p++){const f=(p-1)%e.length,g=s[f],u=l.Tools.deepClone(e[f]);if(u){const _=((h=e[f])==null?void 0:h.f)||"",v=((m=e[f])==null?void 0:m.si)||"",S=l.isFormulaString(_);if(l.isFormulaId(v))u.si=v,u.f=null,u.v=null,u.p=null,u.t=null,i.push(u);else if(S){let E=d.get(f);if(E)u.si=E,u.f=null,u.v=null,u.p=null,u.t=null;else{E=l.Tools.generateRandomId(6),d.set(f,E);const{offsetX:y,offsetY:R}=Cn(c,t,n,o,g),O=this._lexerTreeBuilder.moveFormulaRefOffset(_,y,R);u.si=E,u.f=O,u.v=null,u.p=null,u.t=null}i.push(u)}}}return i}};qe=vn([_t(0,w.IAutoFillService),_t(1,l.Inject(T.LexerTreeBuilder))],qe);function Cn(e,t,n,s,r){const{source:o,target:c}=s,{rows:i}=c,{rows:d}=o;let h=0,m=0;switch(n){case l.Direction.UP:m=i[r]-d[r];break;case l.Direction.RIGHT:h=e;break;case l.Direction.DOWN:m=i[r]-d[r];break;case l.Direction.LEFT:h=-e*t;break}return{offsetX:h,offsetY:m}}function _n(e){let t=0;for(const n in e)e[n].forEach(s=>{t+=s.data.length});return t}var Rn=Object.getOwnPropertyDescriptor,In=(e,t,n,s)=>{for(var r=s>1?void 0:s?Rn(t,n):t,o=e.length-1,c;o>=0;o--)(c=e[o])&&(r=c(r)||r);return r},Ae=(e,t)=>(n,s)=>t(n,s,e);const yn="default-paste-formula";let Ye=class extends l.Disposable{constructor(e,t,n,s,r){super(),this._currentUniverSheet=e,this._lexerTreeBuilder=t,this._sheetClipboardService=n,this._injector=s,this._formulaDataModel=r,this._initialize()}_initialize(){this._registerClipboardHook()}_registerClipboardHook(){this.disposeWithMe(this._sheetClipboardService.addClipboardHook(this._pasteFormulaHook())),this.disposeWithMe(this._sheetClipboardService.addClipboardHook(this._pasteWithFormulaHook()))}_pasteFormulaHook(){return{id:w.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMULA,priority:10,specialPasteInfo:{label:"specialPaste.formula"},onPasteCells:(e,t,n,s)=>this._onPasteCells(e,t,n,s,!0)}}_pasteWithFormulaHook(){return{id:yn,priority:10,onPasteCells:(e,t,n,s)=>this._onPasteCells(e,t,n,s,!1)}}_onPasteCells(e,t,n,s,r){var f;if([w.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMAT,w.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_COL_WIDTH].includes(s.pasteType))return{undos:[],redos:[]};const c=this._currentUniverSheet.getCurrentUnitForType(l.UniverInstanceType.UNIVER_SHEET),i=t.unitId||c.getUnitId(),d=t.subUnitId||((f=c.getActiveSheet())==null?void 0:f.getSheetId());if(!i||!d)return{undos:[],redos:[]};const h=t.range,m=n,p={copyType:s.copyType||w.COPY_TYPE.COPY,copyRange:e==null?void 0:e.range,pasteType:s.pasteType};return this._injector.invoke(g=>En(i,d,h,m,g,p,this._lexerTreeBuilder,this._formulaDataModel,r,e))}};Ye=In([Ae(0,l.IUniverInstanceService),Ae(1,l.Inject(T.LexerTreeBuilder)),Ae(2,w.ISheetClipboardService),Ae(3,l.Inject(l.Injector)),Ae(4,l.Inject(T.FormulaDataModel))],Ye);function En(e,t,n,s,r,o,c,i,d=!1,h){const m=[],p=[],f=bn(e,t,n,s,o,c,i,h);if(!f.hasValue())return{undos:[],redos:[]};const g={unitId:e,subUnitId:t,cellValue:f.getData()};m.push({id:A.SetRangeValuesMutation.id,params:g});const u=A.SetRangeValuesUndoMutationFactory(r,g);return p.push({id:A.SetRangeValuesMutation.id,params:u}),{undos:p,redos:m}}function bn(e,t,n,s,r,o,c,i){return i?r.pasteType===w.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_VALUE?xn(e,t,n,s,c,i):r.pasteType===w.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMULA?Mn(e,t,n,s,o,c,i):On(e,t,n,s,r.copyType,o,c,i):Tn(e,t,n,s,c)}function Tn(e,t,n,s,r){const o=new l.ObjectMatrix,c=r.getSheetFormulaData(e,t);return s.forValue((i,d,h)=>{var g;const m=n.rows[i],p=n.cols[d],f={};l.isFormulaString(h.v)?(f.v=null,f.f=`${h.v}`,f.si=null,f.p=null,o.setValue(m,p,f)):(g=c==null?void 0:c[m])!=null&&g[p]&&(f.v=h.v,f.f=null,f.si=null,f.p=null,o.setValue(m,p,f))}),o}function xn(e,t,n,s,r,o){var h,m;const c=new l.ObjectMatrix,i=(m=(h=r.getArrayFormulaCellData())==null?void 0:h[o.unitId])==null?void 0:m[o.subUnitId],d=r.getSheetFormulaData(e,t);return s.forValue((p,f,g)=>{var E,y;const u=o.range.rows[p%o.range.rows.length],_=o.range.cols[f%o.range.cols.length],v=n.rows[p],S=n.cols[f],I={};if(l.isFormulaString(g.f)||l.isFormulaId(g.si))I.v=g.v,I.f=null,I.si=null,I.p=null,c.setValue(v,S,I);else if((E=i==null?void 0:i[u])!=null&&E[_]){const R=i[u][_];I.v=R.v,I.f=null,I.si=null,I.p=null,c.setValue(v,S,I)}else if((y=d==null?void 0:d[v])!=null&&y[S]){if(I.v=g.v,I.f=null,I.si=null,I.p=null,g.p){const R=wt(g);R&&(I.v=R)}c.setValue(v,S,I)}}),c}function Mn(e,t,n,s,r,o,c){const i=new l.ObjectMatrix,d=new Map;return s.forValue((h,m,p)=>{const f=n.rows[h],g=n.cols[m],u={};if(l.isFormulaId(p.si)){if(c.unitId!==e||c.subUnitId!==t){const _=o.getFormulaStringByCell(c.range.rows[h%c.range.rows.length],c.range.cols[m%c.range.cols.length],c.subUnitId,c.unitId),v=n.cols[m]-c.range.cols[m%c.range.cols.length],S=n.rows[h]-c.range.rows[h%c.range.rows.length],I=r.moveFormulaRefOffset(_||"",v,S);u.si=null,u.f=I}else u.si=p.si,u.f=null;u.v=null,u.p=null,i.setValue(f,g,u)}else if(l.isFormulaString(p.f)){const _=`${h%c.range.rows.length}_${m%c.range.cols.length}`;let v=d.get(_);if(v)u.si=v,u.f=null;else{v=l.Tools.generateRandomId(6),d.set(_,v);const S=n.cols[m]-c.range.cols[m%c.range.cols.length],I=n.rows[h]-c.range.rows[h%c.range.rows.length],E=r.moveFormulaRefOffset(p.f||"",S,I);u.si=v,u.f=E}u.v=null,u.p=null,i.setValue(f,g,u)}else{if(u.v=p.v,u.f=null,u.si=null,u.p=null,p.p){const _=wt(p);_&&(u.v=_)}i.setValue(f,g,u)}}),i}function On(e,t,n,s,r,o,c,i){const d=new l.ObjectMatrix,h=new Map,m=c.getSheetFormulaData(e,t),p=[];return r===w.COPY_TYPE.CUT?s.forValue((f,g,u)=>{const _=n.rows[f],v=n.cols[g],S={};if(l.isFormulaId(u.si)){if(l.isFormulaString(u.f))p.push(u.si),S.f=u.f,S.si=u.si;else if(p.includes(u.si))S.f=null,S.si=u.si;else{const I=c.getFormulaStringByCell(i.range.rows[f%i.range.rows.length],i.range.cols[g%i.range.cols.length],i.subUnitId,i.unitId);S.f=I,S.si=null}S.v=null,S.p=null,d.setValue(_,v,S)}else l.isFormulaString(u.f)&&(S.f=u.f,S.si=null,S.v=null,S.p=null,d.setValue(_,v,S))}):s.forValue((f,g,u)=>{var I;const _=n.rows[f],v=n.cols[g],S={};if(l.isFormulaId(u.si)){if(i.unitId!==e||i.subUnitId!==t){const E=c.getFormulaStringByCell(i.range.rows[f%i.range.rows.length],i.range.cols[g%i.range.cols.length],i.subUnitId,i.unitId),y=n.cols[g]-i.range.cols[g%i.range.cols.length],R=n.rows[f]-i.range.rows[f%i.range.rows.length],O=o.moveFormulaRefOffset(E||"",y,R);S.si=null,S.f=O}else S.si=u.si,S.f=null;S.v=null,S.p=null,d.setValue(_,v,S)}else if(l.isFormulaString(u.f)){const E=`${f%i.range.rows.length}_${g%i.range.cols.length}`;let y=h.get(E);if(y)S.si=y,S.f=null;else{y=l.Tools.generateRandomId(6),h.set(E,y);const R=n.cols[g]-i.range.cols[g%i.range.cols.length],O=n.rows[f]-i.range.rows[f%i.range.rows.length],F=o.moveFormulaRefOffset(u.f||"",R,O);S.si=y,S.f=F}S.v=null,S.p=null,d.setValue(_,v,S)}else(I=m==null?void 0:m[_])!=null&&I[v]&&(S.v=u.v,S.f=null,S.si=null,S.p=u.p,d.setValue(_,v,S))}),p.length>0&&new l.ObjectMatrix(m).forValue((f,g,u)=>{if(!(i.range.rows.includes(f)&&i.range.cols.includes(g))&&!(n.rows.includes(f)&&n.cols.includes(g))&&p.includes(u==null?void 0:u.si)){const _=c.getFormulaStringByCell(f,g,i.subUnitId,i.unitId);d.setValue(f,g,{f:_,si:null,v:null,p:null})}}),d}function wt(e){if(e!=null&&e.p){const t=e==null?void 0:e.p.body;if(t==null)return;const n=t.dataStream;return n.substring(n.length-2,n.length)===l.DEFAULT_EMPTY_DOCUMENT_VALUE?n.substring(0,n.length-2):n}}var Nn=Object.getOwnPropertyDescriptor,Dn=(e,t,n,s)=>{for(var r=s>1?void 0:s?Nn(t,n):t,o=e.length-1,c;o>=0;o--)(c=e[o])&&(r=c(r)||r);return r},Ie=(e,t)=>(n,s)=>t(n,s,e);let ze=class extends l.Disposable{constructor(t,n,s,r,o,c,i,d){super();q(this,"_previousShape");q(this,"_skeleton");this._context=t,this._sheetInterceptorService=n,this._formulaDataModel=s,this._themeService=r,this._renderManagerService=o,this._sheetSkeletonManagerService=c,this._commandService=i,this._logService=d,this._initSkeletonChangeListener(),this._initInterceptorEditorStart(),this._commandExecutedListener()}_initSkeletonChangeListener(){this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(t=>{var n,s;if(t==null)this._logService.debug("[FormulaEditorShowController]: should not receive currentSkeleton$ as null!");else{const{skeleton:r}=t,o=(s=(n=this._skeleton)==null?void 0:n.worksheet)==null?void 0:s.getSheetId();if(this._changeRuntime(r),o!==r.worksheet.getSheetId())this._removeArrayFormulaRangeShape();else{const{unitId:c,sheetId:i}=t;this._updateArrayFormulaRangeShape(c,i)}}}))}_changeRuntime(t){this._skeleton=t}_initInterceptorEditorStart(){this.disposeWithMe(l.toDisposable(this._sheetInterceptorService.writeCellInterceptor.intercept(A.BEFORE_CELL_EDIT,{handler:(t,n,s)=>{var u,_,v,S;const{row:r,col:o,unitId:c,subUnitId:i,worksheet:d}=n,h=this._formulaDataModel.getArrayFormulaRange(),m=this._formulaDataModel.getArrayFormulaCellData();if(this._removeArrayFormulaRangeShape(),t==null)return s(t);let p=null;const f=this._formulaDataModel.getFormulaStringByCell(r,o,i,c);if(f!==null&&(p={f}),t.v!=null&&t.v!==""&&((v=(_=(u=m[c])==null?void 0:u[i])==null?void 0:_[r])==null?void 0:v[o])==null)return p?{...t,...p}:s(t);const g=(S=h==null?void 0:h[c])==null?void 0:S[i];return g!=null&&(p=this._displayArrayFormulaRangeShape(g,r,o,c,i,d,p)),p?{...t,...p}:s(t)}})))}_commandExecutedListener(){this.disposeWithMe(this._commandService.onCommandExecuted((t,n)=>{(t.id===T.SetFormulaCalculationResultMutation.id||t.id===T.SetArrayFormulaDataMutation.id&&n&&n.remove)&&this._removeArrayFormulaRangeShape()})),this.disposeWithMe(this._commandService.beforeCommandExecuted(t=>{A.SetWorksheetRowAutoHeightMutation.id===t.id&&requestIdleCallback(()=>{const n=t.params,{unitId:s,subUnitId:r,rowsAutoHeightInfo:o}=n;this._refreshArrayFormulaRangeShapeByRow(s,r,o)})}))}_displayArrayFormulaRangeShape(t,n,s,r,o,c,i){const d=this._formulaDataModel.getSheetFormulaData(r,o);return new l.ObjectMatrix(t).forValue((h,m,p)=>{var v;if(p==null)return!0;const{startRow:f,startColumn:g,endRow:u,endColumn:_}=p;if(h===n&&m===s)return this._createArrayFormulaRangeShape(p,r),!1;if(n>=f&&n<=u&&s>=g&&s<=_){const S=c.getCell(f,g);if((S==null?void 0:S.v)===T.ErrorType.SPILL)return;const I=(v=d==null?void 0:d[h])==null?void 0:v[m];return I==null||I.f==null?!0:(i==null&&(i={f:I.f,isInArrayFormulaRange:!0}),this._createArrayFormulaRangeShape(p,r),!1)}}),i}_createArrayFormulaRangeShape(t,n){const s=this._renderManagerService.getRenderById(n),r=this._sheetSkeletonManagerService.getCurrentSkeleton();if(!s||!r)return;const{scene:o}=s;if(!o)return;const c={range:t,primary:null,style:{strokeWidth:1,stroke:this._themeService.getColorFromTheme("primary.600"),fill:new l.ColorKit(this._themeService.getColorFromTheme("white")).setAlpha(0).toString(),widgets:{}}},i=w.attachSelectionWithCoord(c,r),{rowHeaderWidth:d,columnHeaderHeight:h}=r,m=new w.SelectionControl(o,w.SELECTION_SHAPE_DEPTH.FORMULA_EDITOR_SHOW,this._themeService,{highlightHeader:!1,rowHeaderWidth:d,columnHeaderHeight:h});m.updateRangeBySelectionWithCoord(i),m.setEvent(!1),this._previousShape=m}_removeArrayFormulaRangeShape(){this._previousShape!=null&&(this._previousShape.dispose(),this._previousShape=null)}_refreshArrayFormulaRangeShape(t,n){if(this._previousShape){const{startRow:s,endRow:r,startColumn:o,endColumn:c}=this._previousShape.getRange(),i={startRow:s,endRow:r,startColumn:o,endColumn:c};this._removeArrayFormulaRangeShape(),this._createArrayFormulaRangeShape(i,t)}}_checkCurrentSheet(t,n){const s=this._sheetSkeletonManagerService.getCurrentSkeleton();if(!s)return!1;const r=s.worksheet;return r?r.unitId===t&&r.getSheetId()===n:!1}_updateArrayFormulaRangeShape(t,n){this._checkCurrentSheet(t,n)&&this._previousShape&&this._refreshArrayFormulaRangeShape(t)}_refreshArrayFormulaRangeShapeByRow(t,n,s){if(!this._checkCurrentSheet(t,n)||!this._previousShape)return;const{startRow:r,endRow:o,startColumn:c,endColumn:i}=this._previousShape.getRange();for(let d=0;d<s.length;d++){const{row:h}=s[d];if(r>=h){const m={startRow:r,endRow:o,startColumn:c,endColumn:i};this._refreshArrayFormulaRangeShape(t,m);break}}}};ze=Dn([Ie(1,l.Inject(A.SheetInterceptorService)),Ie(2,l.Inject(T.FormulaDataModel)),Ie(3,l.Inject(l.ThemeService)),Ie(4,H.IRenderManagerService),Ie(5,l.Inject(w.SheetSkeletonManagerService)),Ie(6,l.ICommandService),Ie(7,l.ILogService)],ze);var wn=Object.getOwnPropertyDescriptor,kn=(e,t,n,s)=>{for(var r=s>1?void 0:s?wn(t,n):t,o=e.length-1,c;o>=0;o--)(c=e[o])&&(r=c(r)||r);return r},Rt=(e,t)=>(n,s)=>t(n,s,e);const An={tl:{size:6,color:"#409f11"}};let Ge=class extends l.RxDisposable{constructor(e,t){super(),this._sheetInterceptorService=e,this._formulaDataModel=t,this.disposeWithMe(this._sheetInterceptorService.intercept(A.INTERCEPTOR_POINT.CELL_CONTENT,{effect:l.InterceptorEffectEnum.Style,handler:(n,s,r)=>{var i,d,h,m;const o=(m=(h=(d=(i=this._formulaDataModel.getArrayFormulaCellData())==null?void 0:i[s.unitId])==null?void 0:d[s.subUnitId])==null?void 0:h[s.row])==null?void 0:m[s.col];return!Dt(n,!!o)||!n||(n===s.rawData&&(n={...s.rawData}),n.markers={...n==null?void 0:n.markers,...An}),r(n)},priority:10}))}};Ge=kn([Rt(0,l.Inject(A.SheetInterceptorService)),Rt(1,l.Inject(T.FormulaDataModel))],Ge);function Fn(){const e=a.useDependency(Ce.TriggerCalculationController),t=a.useDependency(l.ICommandService),n=a.useObservable(e.progress$),s=C.useCallback(()=>{t.executeCommand(T.SetFormulaCalculationStopMutation.id)},[t]),r=C.useCallback(()=>{e.clearProgress()},[e]);return b.jsx(a.ProgressBar,{progress:n,onTerminate:s,onClearProgress:r})}function Pn(e,t){return Object.keys(e).filter(n=>isNaN(Number(n))&&n!=="DefinedName").map(n=>({label:t.t(`formula.functionType.${n.toLocaleLowerCase()}`),value:`${e[n]}`}))}function kt(e){if(!e.require&&!e.repeat)return`[${e.name}]`;if(e.require&&!e.repeat)return e.name;if(!e.require&&e.repeat)return`[${e.name},...]`;if(e.require&&e.repeat)return`${e.name},...`}function At(e){const{prefix:t,value:n}=e;return b.jsxs("div",{children:[b.jsxs("span",{children:[t,"("]}),n&&n.map((s,r)=>b.jsxs("span",{children:[b.jsx("span",{children:kt(s)}),r===n.length-1?"":","]},r)),")"]})}function Fe(e){const{className:t,value:n,title:s}=e;return b.jsxs("div",{className:"univer-mb-2 univer-text-xs",children:[b.jsx("div",{className:W.clsx("univer-mb-2 univer-font-medium univer-text-gray-500 dark:!univer-text-gray-300",t),children:s}),b.jsx("div",{className:"univer-break-all univer-text-gray-900 dark:!univer-text-white",children:n})]})}function Ln(e){const{functionInfo:t,onChange:n}=e;if(!t)return null;const[s,r]=C.useState([]),[o,c]=C.useState(t.functionParameter),[i,d]=C.useState(-1);return b.jsxs("div",{children:[b.jsx("div",{className:W.clsx("univer-h-[364px] univer-overflow-y-auto",W.scrollbarClassName),children:o.map((h,m)=>b.jsxs("div",{children:[b.jsx("div",{className:"univer-text-sm",children:h.name}),b.jsx("div",{className:"univer-mb-2 univer-mt-1"})]},m))}),b.jsx("div",{className:W.clsx("univer-flex-1 univer-p-3",W.borderLeftClassName),children:b.jsx(Fe,{title:i===-1?b.jsx(At,{prefix:t.functionName,value:o}):o[i].name,value:i===-1?t.description:o[i].detail})})]})}var ie=function(){return ie=Object.assign||function(e){for(var t,n=1,s=arguments.length;n<s;n++){t=arguments[n];for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])}return e},ie.apply(this,arguments)},Un=function(e,t){var n={};for(var s in e)Object.prototype.hasOwnProperty.call(e,s)&&t.indexOf(s)<0&&(n[s]=e[s]);if(e!=null&&typeof Object.getOwnPropertySymbols=="function")for(var r=0,s=Object.getOwnPropertySymbols(e);r<s.length;r++)t.indexOf(s[r])<0&&Object.prototype.propertyIsEnumerable.call(e,s[r])&&(n[s[r]]=e[s[r]]);return n},be=C.forwardRef(function(e,t){var n=e.icon,s=e.id,r=e.className,o=e.extend,c=Un(e,["icon","id","className","extend"]),i="univerjs-icon univerjs-icon-".concat(s," ").concat(r||"").trim(),d=C.useRef("_".concat(Wn()));return Ft(n,"".concat(s),{defIds:n.defIds,idSuffix:d.current},ie({ref:t,className:i},c),o)});function Ft(e,t,n,s,r){return C.createElement(e.tag,ie(ie({key:t},$n(e,n,r)),s),(jn(e,n).children||[]).map(function(o,c){return Ft(o,"".concat(t,"-").concat(e.tag,"-").concat(c),n,void 0,r)}))}function $n(e,t,n){var s=ie({},e.attrs);n!=null&&n.colorChannel1&&s.fill==="colorChannel1"&&(s.fill=n.colorChannel1),e.tag==="mask"&&s.id&&(s.id=s.id+t.idSuffix),Object.entries(s).forEach(function(o){var c=o[0],i=o[1];c==="mask"&&typeof i=="string"&&(s[c]=i.replace(/url\(#(.*)\)/,"url(#$1".concat(t.idSuffix,")")))});var r=t.defIds;return!r||r.length===0||(e.tag==="use"&&s["xlink:href"]&&(s["xlink:href"]=s["xlink:href"]+t.idSuffix),Object.entries(s).forEach(function(o){var c=o[0],i=o[1];typeof i=="string"&&(s[c]=i.replace(/url\(#(.*)\)/,"url(#$1".concat(t.idSuffix,")")))})),s}function jn(e,t){var n,s=t.defIds;return!s||s.length===0?e:e.tag==="defs"&&(!((n=e.children)===null||n===void 0)&&n.length)?ie(ie({},e),{children:e.children.map(function(r){return typeof r.attrs.id=="string"&&s&&s.includes(r.attrs.id)?ie(ie({},r),{attrs:ie(ie({},r.attrs),{id:r.attrs.id+t.idSuffix})}):r})}):e}function Wn(){return Math.random().toString(36).substring(2,8)}be.displayName="UniverIcon";var Vn={tag:"svg",attrs:{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M14.1544 3.75557C14.3887 3.98988 14.3887 4.36978 14.1544 4.6041L6.51409 12.2444C6.40157 12.3569 6.24896 12.4201 6.08983 12.4201C5.9307 12.4201 5.77808 12.3569 5.66556 12.2444L1.84541 8.42425C1.6111 8.18993 1.6111 7.81003 1.84541 7.57572C2.07973 7.34141 2.45963 7.34141 2.69394 7.57572L6.08983 10.9716L13.3059 3.75557C13.5402 3.52126 13.9201 3.52126 14.1544 3.75557Z",fillRule:"evenodd",clipRule:"evenodd"}}]},Pt=C.forwardRef(function(e,t){return C.createElement(be,Object.assign({},e,{id:"check-mark-icon",ref:t,icon:Vn}))});Pt.displayName="CheckMarkIcon";var Bn={tag:"svg",attrs:{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M3.71274 2.86421C3.47843 2.6299 3.09853 2.6299 2.86421 2.86421C2.6299 3.09853 2.6299 3.47843 2.86421 3.71274L7.15154 8.00007L2.86421 12.2874C2.6299 12.5217 2.6299 12.9016 2.86421 13.1359C3.09853 13.3702 3.47843 13.3702 3.71274 13.1359L8.00007 8.84859L12.2874 13.1359C12.5217 13.3702 12.9016 13.3702 13.1359 13.1359C13.3702 12.9016 13.3702 12.5217 13.1359 12.2874L8.84859 8.00007L13.1359 3.71274C13.3702 3.47843 13.3702 3.09853 13.1359 2.86421C12.9016 2.6299 12.5217 2.6299 12.2874 2.86421L8.00007 7.15154L3.71274 2.86421Z"}}]},Lt=C.forwardRef(function(e,t){return C.createElement(be,Object.assign({},e,{id:"close-icon",ref:t,icon:Bn}))});Lt.displayName="CloseIcon";var Hn={tag:"svg",attrs:{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M5.3313 1.4667C5.3313 1.13533 5.59993 0.866699 5.9313 0.866699H10.069C10.4004 0.866699 10.669 1.13533 10.669 1.4667C10.669 1.79807 10.4004 2.0667 10.069 2.0667H5.9313C5.59993 2.0667 5.3313 1.79807 5.3313 1.4667Z"}},{tag:"path",attrs:{fill:"currentColor",d:"M1.09985 3.64443C1.09985 3.31306 1.36848 3.04443 1.69985 3.04443H14.2999C14.6312 3.04443 14.8999 3.31306 14.8999 3.64443C14.8999 3.9758 14.6312 4.24443 14.2999 4.24443H1.69985C1.36848 4.24443 1.09985 3.9758 1.09985 3.64443Z"}},{tag:"path",attrs:{fill:"currentColor",d:"M6.12398 8.30171C6.35829 8.0674 6.73819 8.0674 6.97251 8.30171L8.00007 9.32928L9.02764 8.30171C9.26195 8.0674 9.64185 8.0674 9.87617 8.30171C10.1105 8.53603 10.1105 8.91593 9.87617 9.15024L8.8486 10.1778L9.87617 11.2054C10.1105 11.4397 10.1105 11.8196 9.87617 12.0539C9.64185 12.2882 9.26195 12.2882 9.02764 12.0539L8.00007 11.0263L6.97251 12.0539C6.73819 12.2882 6.35829 12.2882 6.12398 12.0539C5.88966 11.8196 5.88966 11.4397 6.12398 11.2054L7.15154 10.1778L6.12398 9.15024C5.88966 8.91593 5.88966 8.53603 6.12398 8.30171Z"}},{tag:"path",attrs:{fill:"currentColor",d:"M4.75332 5.22217C3.86966 5.22217 3.15332 5.93851 3.15332 6.82217V12.5331C3.15332 13.9691 4.31738 15.1332 5.75332 15.1332H10.2465C11.6825 15.1332 12.8465 13.9691 12.8465 12.5331V6.82217C12.8465 5.93851 12.1302 5.22217 11.2465 5.22217H4.75332ZM4.35332 6.82217C4.35332 6.60125 4.53241 6.42217 4.75332 6.42217H11.2465C11.4674 6.42217 11.6465 6.60125 11.6465 6.82217V12.5331C11.6465 13.3063 11.0197 13.9332 10.2465 13.9332H5.75332C4.98012 13.9332 4.35332 13.3063 4.35332 12.5331V6.82217Z",fillRule:"evenodd",clipRule:"evenodd"}}]},Ut=C.forwardRef(function(e,t){return C.createElement(be,Object.assign({},e,{id:"delete-icon",ref:t,icon:Hn}))});Ut.displayName="DeleteIcon";var Kn={tag:"svg",attrs:{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M8.6 1.99991C8.60001 1.66854 8.33138 1.39991 8.00001 1.3999C7.66864 1.3999 7.40001 1.66853 7.4 1.9999L7.39996 7.3999H1.9999C1.66853 7.3999 1.3999 7.66853 1.3999 7.9999C1.3999 8.33127 1.66853 8.5999 1.9999 8.5999H7.39995L7.3999 13.9999C7.3999 14.3313 7.66853 14.5999 7.9999 14.5999C8.33127 14.5999 8.5999 14.3313 8.5999 13.9999L8.59995 8.5999H13.9999C14.3313 8.5999 14.5999 8.33127 14.5999 7.9999C14.5999 7.66853 14.3313 7.3999 13.9999 7.3999H8.59996L8.6 1.99991Z"}}]},$t=C.forwardRef(function(e,t){return C.createElement(be,Object.assign({},e,{id:"increase-icon",ref:t,icon:Kn}))});$t.displayName="IncreaseIcon";var qn={tag:"svg",attrs:{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M5.90913 3.57564C6.14345 3.34132 6.52335 3.34132 6.75766 3.57564L10.7577 7.57564C10.992 7.80995 10.992 8.18985 10.7577 8.42417L6.75766 12.4242C6.52335 12.6585 6.14345 12.6585 5.90913 12.4242C5.67482 12.1899 5.67482 11.81 5.90913 11.5756L9.48487 7.9999L5.90913 4.42417C5.67482 4.18985 5.67482 3.80995 5.90913 3.57564Z",fillRule:"evenodd",clipRule:"evenodd"}}]},jt=C.forwardRef(function(e,t){return C.createElement(be,Object.assign({},e,{id:"more-icon",ref:t,icon:qn}))});jt.displayName="MoreIcon";var Yn={tag:"svg",attrs:{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M12.6185 12.4423C12.5907 12.2749 12.7773 12.15 12.9343 12.2308L15.4242 13.5126C15.6102 13.6084 15.5544 13.8745 15.3439 13.8955L14.2456 14.184L13.4521 15.1286C13.3495 15.2939 13.085 15.2463 13.0534 15.0568L12.6185 12.4423Z"}},{tag:"path",attrs:{fill:"currentColor",d:"M1 3.6C1 2.16406 2.16406 1 3.6 1H12.3C13.7359 1 14.9 2.16406 14.9 3.6V5.81156C14.9003 5.81881 14.9004 5.82609 14.9004 5.8334C14.9004 5.84071 14.9003 5.84799 14.9 5.85524V10.045C14.9003 10.0522 14.9004 10.0595 14.9004 10.0668C14.9004 10.3982 14.6318 10.6668 14.3004 10.6668H11.1668C10.8907 10.6668 10.6668 10.8907 10.6668 11.1668V14.3C10.6668 14.6314 10.3982 14.9 10.0668 14.9L10.05 14.8998L3.6 14.9C2.16406 14.9 1 13.7359 1 12.3V3.6ZM13.2 5.2334C13.4761 5.2334 13.7 5.00954 13.7 4.7334V3.6C13.7 2.8268 13.0732 2.2 12.3 2.2H11.1668C10.8907 2.2 10.6668 2.42386 10.6668 2.7V4.7334C10.6668 5.00954 10.8907 5.2334 11.1668 5.2334H13.2ZM10.6668 6.9334C10.6668 6.65726 10.8907 6.4334 11.1668 6.4334H13.2C13.4761 6.4334 13.7 6.65726 13.7 6.9334V8.9668C13.7 9.24294 13.4761 9.4668 13.2 9.4668H11.1668C10.8907 9.4668 10.6668 9.24294 10.6668 8.9668V6.9334ZM8.9668 5.2334C9.24294 5.2334 9.4668 5.00954 9.4668 4.7334V2.7C9.4668 2.42386 9.24294 2.2 8.9668 2.2H6.9334C6.65726 2.2 6.4334 2.42386 6.4334 2.7V4.7334C6.4334 5.00954 6.65726 5.2334 6.9334 5.2334L8.9668 5.2334ZM6.4334 6.9334C6.4334 6.65726 6.65726 6.4334 6.9334 6.4334L8.9668 6.4334C9.24294 6.4334 9.4668 6.65726 9.4668 6.9334V8.9668C9.4668 9.24294 9.24294 9.4668 8.9668 9.4668L6.9334 9.4668C6.65726 9.4668 6.4334 9.24294 6.4334 8.9668V6.9334ZM4.7334 5.2334C5.00954 5.2334 5.2334 5.00954 5.2334 4.7334V2.7C5.2334 2.42386 5.00954 2.2 4.7334 2.2H3.6C2.8268 2.2 2.2 2.8268 2.2 3.6V4.7334C2.2 5.00954 2.42386 5.2334 2.7 5.2334H4.7334ZM2.2 6.9334C2.2 6.65726 2.42386 6.4334 2.7 6.4334H4.7334C5.00954 6.4334 5.2334 6.65725 5.2334 6.9334V8.9668C5.2334 9.24294 5.00954 9.4668 4.7334 9.4668H2.7C2.42386 9.4668 2.2 9.24294 2.2 8.9668V6.9334ZM5.2334 11.1668C5.2334 10.8907 5.00954 10.6668 4.7334 10.6668H2.7C2.42386 10.6668 2.2 10.8907 2.2 11.1668V12.3C2.2 13.0732 2.8268 13.7 3.6 13.7H4.7334C5.00954 13.7 5.2334 13.4761 5.2334 13.2V11.1668ZM9.4668 11.1668C9.4668 10.8907 9.24294 10.6668 8.9668 10.6668H6.9334C6.65726 10.6668 6.4334 10.8907 6.4334 11.1668V13.2C6.4334 13.4761 6.65726 13.7 6.9334 13.7H8.9668C9.24294 13.7 9.4668 13.4761 9.4668 13.2V11.1668Z",fillRule:"evenodd",clipRule:"evenodd"}}]},Wt=C.forwardRef(function(e,t){return C.createElement(be,Object.assign({},e,{id:"select-range-icon",ref:t,icon:Yn}))});Wt.displayName="SelectRangeIcon";function zn(e){const{onChange:t}=e,n="-1",[s,r]=C.useState(""),[o,c]=C.useState([]),[i,d]=C.useState(0),[h,m]=C.useState(n),[p,f]=C.useState(0),[g,u]=C.useState(null),_=a.useDependency(Ce.IDescriptionService),v=a.useDependency(l.LocaleService),S=a.useDependency(a.ISidebarService),I=a.useObservable(S.sidebarOptions$),E=Pn(T.FunctionType,v);E.unshift({label:v.t("formula.moreFunctions.allFunctions"),value:n});const y=v.t("formula.prompt.required"),R=v.t("formula.prompt.optional");C.useEffect(()=>{L(n)},[]),C.useEffect(()=>{F(0)},[o]),C.useEffect(()=>{I!=null&&I.visible&&(r(""),c([]),d(0),m(n),f(0),u(null),L(n))},[I]);const O=N=>{if(s.trim()==="")return N;const x=new RegExp(`(${s.toLocaleUpperCase()})`);return N.split(x).filter(Boolean).map((P,j)=>P.match(x)?b.jsx("span",{className:"univer-text-red-500",children:P},j):P)},F=N=>{if(o.length===0){u(null);return}f(N);const x=_.getFunctionInfo(o[N].name);if(!x){u(null);return}u(x),t(x)};function L(N){m(N);const x=_.getSearchListByType(+N);c(x)}function U(N){r(N);const x=_.getSearchListByName(N);c(x)}function k(N){if(N.stopPropagation(),N.key==="ArrowDown"){const x=i+1;d(x===o.length?0:x)}else if(N.key==="ArrowUp"){const x=i-1;d(x===-1?o.length-1:x)}else N.key==="Enter"&&F(i)}const $=N=>{d(N)},D=()=>{d(-1)};return b.jsxs("div",{children:[b.jsxs("div",{className:"univer-flex univer-items-center univer-justify-between univer-gap-2",children:[b.jsx(W.Select,{value:h,options:E,onChange:L}),b.jsx(W.Input,{placeholder:v.t("formula.moreFunctions.searchFunctionPlaceholder"),onKeyDown:k,value:s,onChange:U,size:"small",allowClear:!0})]}),o.length>0&&b.jsx("ul",{className:W.clsx("univer-m-0 univer-mt-2 univer-box-border univer-max-h-72 univer-w-full univer-select-none univer-list-none univer-overflow-y-auto univer-rounded univer-p-3 univer-outline-none",W.borderClassName,W.scrollbarClassName),onKeyDown:k,tabIndex:-1,children:o.map(({name:N},x)=>b.jsxs("li",{className:W.clsx("univer-relative univer-box-border univer-cursor-pointer univer-rounded univer-px-7 univer-py-1 univer-text-sm univer-text-gray-900 univer-transition-colors dark:!univer-text-white",{"univer-bg-gray-200 dark:!univer-bg-gray-600":i===x}),onMouseEnter:()=>$(x),onMouseLeave:D,onClick:()=>F(x),children:[p===x&&b.jsx(Pt,{className:"univer-absolute univer-left-1.5 univer-top-1/2 univer-inline-flex -univer-translate-y-1/2 univer-text-base univer-text-primary-600"}),b.jsx("span",{className:"univer-block",children:O(N)})]},x))}),g&&b.jsxs("div",{className:W.clsx("univer-mx-0 univer-my-2 univer-overflow-y-auto",W.scrollbarClassName),children:[b.jsx(Fe,{title:g.functionName,value:g.description}),b.jsx(Fe,{title:v.t("formula.moreFunctions.syntax"),value:b.jsx(At,{prefix:g.functionName,value:g.functionParameter})}),b.jsx(Fe,{title:v.t("formula.prompt.helpExample"),value:`${g.functionName}(${g.functionParameter.map(N=>N.example).join(",")})`}),g.functionParameter&&g.functionParameter.map(N=>b.jsx(Fe,{title:N.name,value:`${N.require?y:R} ${N.detail}`},N.name))]})]})}function Gn(){const e=w.useActiveWorkbook(),[t,n]=C.useState(!0),[s,r]=C.useState(!1),[o,c]=C.useState(null);a.useDependency(w.IEditorBridgeService);const i=a.useDependency(l.LocaleService),d=a.useDependency(Q.IEditorService),h=a.useDependency(l.IUniverInstanceService),m=a.useDependency(l.ICommandService);function p(){n(!t),r(!s)}function f(){const g=A.getSheetCommandTarget(h);if(!g)return;m.executeCommand(w.SetCellEditVisibleOperation.id,{visible:!0,unitId:g.unitId,eventType:H.DeviceInputEventType.Dblclick});const u=d.getEditor(l.DOCS_NORMAL_EDITOR_UNIT_ID_KEY),_=d.getEditor(l.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),v=`=${o==null?void 0:o.functionName}(`;u==null||u.replaceText(v),_==null||_.replaceText(v,!1)}return b.jsxs("div",{"data-u-comp":"sheets-formula-functions-panel",className:"univer-box-border univer-flex univer-h-full univer-flex-col univer-justify-between univer-py-2",children:[t&&b.jsx(zn,{onChange:c}),s&&b.jsx(Ln,{functionInfo:o,onChange:()=>{}}),b.jsxs("div",{className:"univer-flex univer-justify-end",children:[s&&b.jsx(W.Button,{variant:"primary",onClick:p,className:"univer-mb-5 univer-ml-4 univer-mr-0 univer-mt-0",children:i.t("formula.moreFunctions.next")}),s&&b.jsx(W.Button,{onClick:p,className:"univer-mb-5 univer-ml-4 univer-mr-0 univer-mt-0",children:i.t("formula.moreFunctions.prev")}),t&&!!e&&b.jsx(W.Button,{variant:"primary",onClick:f,className:"univer-mb-5 univer-ml-4 univer-mr-0 univer-mt-0",children:i.t("formula.moreFunctions.confirm")})]})]})}function Zn(e){return{id:ce.id,title:"SUM",icon:"SumIcon",type:a.MenuItemType.BUTTON,params:{value:"SUM"},hidden$:a.getMenuHiddenObservable(e,l.UniverInstanceType.UNIVER_SHEET),disabled$:w.getCurrentRangeDisable$(e,{workbookTypes:[A.WorkbookEditablePermission],worksheetTypes:[A.WorksheetEditPermission,A.WorksheetSetCellValuePermission],rangeTypes:[A.RangeProtectionPermissionEditPoint]})}}function Xn(e){return{id:ce.id,title:"COUNT",icon:"CntIcon",type:a.MenuItemType.BUTTON,params:{value:"COUNT"},hidden$:a.getMenuHiddenObservable(e,l.UniverInstanceType.UNIVER_SHEET),disabled$:w.getCurrentRangeDisable$(e,{workbookTypes:[A.WorkbookEditablePermission],worksheetTypes:[A.WorksheetEditPermission,A.WorksheetSetCellValuePermission],rangeTypes:[A.RangeProtectionPermissionEditPoint]})}}function Qn(e){return{id:ce.id,title:"AVERAGE",icon:"AvgIcon",type:a.MenuItemType.BUTTON,params:{value:"AVERAGE"},hidden$:a.getMenuHiddenObservable(e,l.UniverInstanceType.UNIVER_SHEET),disabled$:w.getCurrentRangeDisable$(e,{workbookTypes:[A.WorkbookEditablePermission],worksheetTypes:[A.WorksheetEditPermission,A.WorksheetSetCellValuePermission],rangeTypes:[A.RangeProtectionPermissionEditPoint]})}}function Jn(e){return{id:ce.id,title:"MAX",icon:"MaxIcon",type:a.MenuItemType.BUTTON,params:{value:"MAX"},hidden$:a.getMenuHiddenObservable(e,l.UniverInstanceType.UNIVER_SHEET),disabled$:w.getCurrentRangeDisable$(e,{workbookTypes:[A.WorkbookEditablePermission],worksheetTypes:[A.WorksheetEditPermission,A.WorksheetSetCellValuePermission],rangeTypes:[A.RangeProtectionPermissionEditPoint]})}}function er(e){return{id:ce.id,title:"MIN",icon:"MinIcon",type:a.MenuItemType.BUTTON,params:{value:"MIN"},hidden$:a.getMenuHiddenObservable(e,l.UniverInstanceType.UNIVER_SHEET),disabled$:w.getCurrentRangeDisable$(e,{workbookTypes:[A.WorkbookEditablePermission],worksheetTypes:[A.WorksheetEditPermission,A.WorksheetSetCellValuePermission],rangeTypes:[A.RangeProtectionPermissionEditPoint]})}}function tr(e){return{id:Je.id,title:"formula.insert.more",tooltip:"formula.insert.tooltip",type:a.MenuItemType.BUTTON,hidden$:a.getMenuHiddenObservable(e,l.UniverInstanceType.UNIVER_SHEET),disabled$:w.getCurrentRangeDisable$(e,{workbookTypes:[A.WorkbookEditablePermission],worksheetTypes:[A.WorksheetEditPermission,A.WorksheetSetCellValuePermission],rangeTypes:[A.RangeProtectionPermissionEditPoint]})}}function nr(e){return e.get(l.IUniverInstanceService).getCurrentTypeOfUnit$(l.UniverInstanceType.UNIVER_SHEET).pipe(Y.switchMap(s=>s&&e.get(a.IClipboardInterfaceService)?new Y.Observable(o=>o.next(!e.get(a.IClipboardInterfaceService).supportClipboard)):Y.of(!0)))}function rr(e){return{id:Xe.id,type:a.MenuItemType.BUTTON,title:"formula.operation.pasteFormula",disabled$:nr(e).pipe(Y.combineLatestWith(w.getCurrentRangeDisable$(e,{workbookTypes:[A.WorkbookEditablePermission],rangeTypes:[A.RangeProtectionPermissionEditPoint],worksheetTypes:[A.WorksheetSetCellValuePermission,A.WorksheetEditPermission]})),Y.map(([t,n])=>t||n))}}const sr={[a.RibbonFormulasGroup.BASIC]:{[`${ce.id}.sum`]:{order:0,menuItemFactory:Zn},[`${ce.id}.count`]:{order:1,menuItemFactory:Xn},[`${ce.id}.average`]:{order:2,menuItemFactory:Qn},[`${ce.id}.max`]:{order:3,menuItemFactory:Jn},[`${ce.id}.min`]:{order:4,menuItemFactory:er}},[a.RibbonFormulasGroup.OTHERS]:{[Je.id]:{order:0,menuItemFactory:tr}},[w.PASTE_SPECIAL_MENU_ID]:{[Xe.id]:{order:4,menuItemFactory:rr}}},or="meta_key_ctrl_And_Shift",et=[a.KeyCode.ARROW_DOWN,a.KeyCode.ARROW_UP,a.KeyCode.ARROW_LEFT,a.KeyCode.ARROW_RIGHT],ir=[...et,a.KeyCode.ENTER,a.KeyCode.TAB,a.KeyCode.ESC];function cr(){const e=[];for(const t of ir)e.push({id:Ee.id,binding:t,preconditions:n=>w.whenFormulaEditorActivated(n),staticParameters:{eventType:H.DeviceInputEventType.Keyboard,keycode:t}});return e}function ar(){const e=[];for(const t of et)e.push({id:Ee.id,binding:t|a.MetaKeys.SHIFT,preconditions:n=>w.whenFormulaEditorActivated(n),staticParameters:{eventType:H.DeviceInputEventType.Keyboard,keycode:t,metaKey:a.MetaKeys.SHIFT}});return e}function lr(){const e=[];for(const t of et)e.push({id:Ee.id,binding:t|a.MetaKeys.CTRL_COMMAND,preconditions:n=>w.whenFormulaEditorActivated(n),staticParameters:{eventType:H.DeviceInputEventType.Keyboard,keycode:t,metaKey:a.MetaKeys.CTRL_COMMAND}});return e}function ur(){const e=[];for(const t of et)e.push({id:Ee.id,binding:t|a.MetaKeys.SHIFT|a.MetaKeys.CTRL_COMMAND,preconditions:n=>w.whenFormulaEditorActivated(n),staticParameters:{eventType:H.DeviceInputEventType.Keyboard,keycode:t,metaKey:or}});return e}const dr={id:ct.id,binding:a.KeyCode.F4,preconditions:e=>w.whenFormulaEditorActivated(e)};function hr(){const e=[];for(const t of[a.KeyCode.ENTER,a.KeyCode.TAB,a.KeyCode.ARROW_DOWN,a.KeyCode.ARROW_UP])e.push({id:Ee.id,binding:t,preconditions:n=>fn(n),staticParameters:{eventType:H.DeviceInputEventType.Keyboard,keycode:t,isSingleEditor:!0}});return e}const fr={id:Ce.QuickSumCommand.id,binding:a.MetaKeys.ALT|a.KeyCode.EQUAL,preconditions:w.whenSheetEditorFocused,mac:a.MetaKeys.CTRL_COMMAND|a.MetaKeys.ALT|a.KeyCode.EQUAL,description:"shortcut.sheets-formula-ui.quick-sum",group:"4_sheet-edit"};var gr=Object.getOwnPropertyDescriptor,mr=(e,t,n,s)=>{for(var r=s>1?void 0:s?gr(t,n):t,o=e.length-1,c;o>=0;o--)(c=e[o])&&(r=c(r)||r);return r},ye=(e,t)=>(n,s)=>t(n,s,e);let Ze=class extends l.Disposable{constructor(e,t,n,s,r,o,c){super(),this._injector=e,this._menuManagerService=t,this._commandService=n,this._shortcutService=s,this._uiPartsService=r,this._renderManagerService=o,this._componentManager=c,this._initialize()}_initialize(){this._registerCommands(),this._registerMenus(),this._registerShortcuts(),this._registerComponents(),this._registerRenderModules()}_registerMenus(){this._menuManagerService.mergeMenu(sr)}_registerCommands(){[Xe,ce,Je,Nt,xt,Ee,ct].forEach(e=>this.disposeWithMe(this._commandService.registerCommand(e)))}_registerShortcuts(){[...cr(),...ar(),...lr(),...ur(),...hr(),fr,dr].forEach(e=>{this.disposeWithMe(this._shortcutService.registerShortcut(e))})}_registerComponents(){this.disposeWithMe(this._uiPartsService.registerComponent(w.SheetsUIPart.FORMULA_AUX,()=>a.connectInjector(Fn,this._injector))),this._componentManager.register(Ot,Gn)}_registerRenderModules(){this.disposeWithMe(this._renderManagerService.registerRenderModule(l.UniverInstanceType.UNIVER_SHEET,[ze]))}};Ze=mr([ye(0,l.Inject(l.Injector)),ye(1,a.IMenuManagerService),ye(2,l.ICommandService),ye(3,a.IShortcutService),ye(4,a.IUIPartsService),ye(5,H.IRenderManagerService),ye(6,l.Inject(a.ComponentManager))],Ze);class at{constructor(){q(this,"_currentSelector$",new Y.BehaviorSubject(null));q(this,"currentSelector$",this._currentSelector$.asObservable())}showRangeSelectorDialog(t){const n=t.callback,s=new Promise(r=>{t.callback=o=>{r(o),n(o)}});return this._currentSelector$.next(t),s}}var pr=Object.getOwnPropertyDescriptor,Sr=(e,t,n,s)=>{for(var r=s>1?void 0:s?pr(t,n):t,o=e.length-1,c;o>=0;o--)(c=e[o])&&(r=c(r)||r);return r},Ne=(e,t)=>(n,s)=>t(n,s,e);exports.RefSelectionsRenderService=class extends w.BaseSelectionRenderService{constructor(n,s,r,o,c,i,d){super(s,r,o,c,i);q(this,"_workbookSelections");q(this,"_eventDisposables");this._context=n,this._contextService=i,this._refSelectionsService=d,this._workbookSelections=this._refSelectionsService.getWorkbookSelections(this._context.unitId),this._initSelectionChangeListener(),this._initSkeletonChangeListener(),this._initUserActionSyncListener(),this._setSelectionStyle(vr(this._themeService)),this._remainLastEnabled=!0,this._highlightHeader=!1}getLocation(){return this._skeleton.getLocation()}setRemainLastEnabled(n){this._remainLastEnabled=n}setSkipLastEnabled(n){this._skipLastEnabled=n}clearLastSelection(){const n=this._selectionControls[this._selectionControls.length-1];n&&(n.dispose(),this._selectionControls.pop())}enableSelectionChanging(){return this._disableSelectionChanging(),this._eventDisposables=this._initCanvasEventListeners(),l.toDisposable(()=>this._disableSelectionChanging())}_disableSelectionChanging(){var n;(n=this._eventDisposables)==null||n.dispose(),this._eventDisposables=null}disableSelectionChanging(){this._disableSelectionChanging()}_initCanvasEventListeners(){const n=this._getSheetObject(),{spreadsheetRowHeader:s,spreadsheetColumnHeader:r,spreadsheet:o,spreadsheetLeftTopPlaceholder:c}=n,{scene:i}=this._context,d=new l.DisposableCollection;return d.add(o==null?void 0:o.onPointerDown$.subscribeEvent((h,m)=>{this.inRefSelectionMode()&&(this._onPointerDown(h,o.zIndex+1,l.RANGE_TYPE.NORMAL,this._getActiveViewport(h)),h.button!==2&&m.stopPropagation())})),d.add(s==null?void 0:s.onPointerDown$.subscribeEvent((h,m)=>{if(!this.inRefSelectionMode())return;const p=this._sheetSkeletonManagerService.getCurrent().skeleton,{row:f}=w.getCoordByOffset(h.offsetX,h.offsetY,i,p);w.checkInHeaderRanges(this._workbookSelections.getCurrentSelections(),f,l.RANGE_TYPE.ROW)||(this._onPointerDown(h,(o.zIndex||1)+1,l.RANGE_TYPE.ROW,this._getActiveViewport(h),H.ScrollTimerType.Y),h.button!==2&&m.stopPropagation())})),d.add(r==null?void 0:r.onPointerDown$.subscribeEvent((h,m)=>{if(!this.inRefSelectionMode())return;const p=this._sheetSkeletonManagerService.getCurrent().skeleton,{column:f}=w.getCoordByOffset(h.offsetX,h.offsetY,i,p);w.checkInHeaderRanges(this._workbookSelections.getCurrentSelections(),f,l.RANGE_TYPE.COLUMN)||(this._onPointerDown(h,(o.zIndex||1)+1,l.RANGE_TYPE.COLUMN,this._getActiveViewport(h),H.ScrollTimerType.X),h.button!==2&&m.stopPropagation())})),d.add(c==null?void 0:c.onPointerDown$.subscribeEvent((h,m)=>{if(this._reset(),!this.inRefSelectionMode())return;const p=this._sheetSkeletonManagerService.getCurrent().skeleton,f=w.getAllSelection(p);this._addSelectionControlByModelData(f),this._selectionMoveStart$.next(this.getSelectionDataWithStyle());const g=i.onPointerUp$.subscribeEvent(()=>{g.unsubscribe(),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle())});h.button!==2&&m.stopPropagation()})),d}_addSelectionControlByModelData(n){var i;const s=this._skeleton,r=(i=n.style)!=null?i:w.genNormalSelectionStyle(this._themeService),o=this._scene;return n.style=r,this.newSelectionControl(o,s,n)}_initSelectionChangeListener(){this.disposeWithMe(this._refSelectionsService.selectionSet$.subscribe(n=>{this._reset(),this._skeleton&&this.resetSelectionsByModelData(n||[])}))}_initUserActionSyncListener(){this.disposeWithMe(this.selectionMoveStart$.subscribe(n=>{this._updateSelections(n,A.SelectionMoveType.MOVE_START)})),this.disposeWithMe(this.selectionMoving$.subscribe(n=>{this._updateSelections(n,A.SelectionMoveType.MOVING)})),this.disposeWithMe(this.selectionMoveEnd$.subscribe(n=>{this._updateSelections(n,A.SelectionMoveType.MOVE_END)}))}_updateSelections(n,s){const o=this._context.unit.getActiveSheet().getSheetId();n.length!==0&&this._workbookSelections.setSelections(o,n.map(c=>A.convertSelectionDataToRange(c)),s)}_initSkeletonChangeListener(){this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(n=>{if(!n)return;const{skeleton:s}=n,{scene:r}=this._context,o=r.getViewport(H.SHEET_VIEWPORT_KEY.VIEW_MAIN);this._skeleton&&this._skeleton.worksheet.getSheetId()!==s.worksheet.getSheetId()&&this._reset(),this._changeRuntime(s,r,o);const c=this._workbookSelections.getCurrentSelections();this.resetSelectionsByModelData(c)}))}_getActiveViewport(n){const s=this._getSheetObject();return s==null?void 0:s.scene.getActiveViewportByCoord(H.Vector2.FromArray([n.offsetX,n.offsetY]))}_getSheetObject(){return w.getSheetObject(this._context.unit,this._context)}_onPointerDown(n,s=0,r=l.RANGE_TYPE.NORMAL,o,c=H.ScrollTimerType.ALL){var $;this._rangeType=r;const i=this._skeleton,d=this._scene;if(!d||!i)return;o&&(this._activeViewport=o);const{offsetX:h,offsetY:m}=n,p=d.getViewport(H.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(!p)return;const f=d.getCoordRelativeToViewport(H.Vector2.FromArray([h,m])),{x:g,y:u}=f;this._startViewportPosX=g,this._startViewportPosY=u;const _=d.getScrollXYInfoByViewport(f),{scaleX:v,scaleY:S}=d.getAncestorScale(),I=this._skeleton.getCellByOffset(g,u,v,S,_);if(!I)return;switch(r){case l.RANGE_TYPE.NORMAL:break;case l.RANGE_TYPE.ROW:I.startColumn=0,I.endColumn=this._skeleton.getColumnCount()-1;break;case l.RANGE_TYPE.COLUMN:I.startRow=0,I.endRow=this._skeleton.getRowCount()-1;break;case l.RANGE_TYPE.ALL:I.startRow=0,I.startColumn=0,I.endRow=this._skeleton.getRowCount()-1,I.endColumn=this._skeleton.getColumnCount()-1}const E={range:I,primary:I,style:null};E.range.rangeType=r;const y=w.attachSelectionWithCoord(E,this._skeleton);this._startRangeWhenPointerDown={...y.rangeWithCoord};const R={...y.rangeWithCoord,rangeType:r};let O=this.getActiveSelectionControl();const F=this.getSelectionControls();for(const D of F){if(n.button===2&&l.Rectangle.contains(D.model,R)){O=D;return}if(D.model.isEqual(R)){O=D;break}}this._checkClearPreviousControls(n);const L=O==null?void 0:O.model.currentCell,U=n.shiftKey&&L,k=this._remainLastEnabled&&!n.ctrlKey&&!n.shiftKey&&!this._skipLastEnabled&&!this._singleSelectionEnabled;U&&L?this._makeSelectionByTwoCells(L,R,i,r,O):k&&O?O.updateRangeBySelectionWithCoord(y):O=this.newSelectionControl(d,i,E);for(let D=0;D<this.getSelectionControls().length-1;D++)this.getSelectionControls()[D].clearHighlight();this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),d.disableObjectsEvent(),this._clearUpdatingListeners(),this._addEndingListeners(),($=d.getTransformer())==null||$.clearSelectedObjects(),this._setupPointerMoveListener(p,O,r,c,g,u),this._escapeShortcutDisposable=this._shortcutService.forceEscape(),this._scenePointerUpSub=d.onPointerUp$.subscribeEvent(()=>{var D;this._clearUpdatingListeners(),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()),(D=this._escapeShortcutDisposable)==null||D.dispose(),this._escapeShortcutDisposable=null})}newSelectionControl(n,s,r){const o=this.getSelectionControls().length,{rowHeaderWidth:c,columnHeaderHeight:i}=s,d=new w.SelectionControl(n,o,this._themeService,{highlightHeader:this._highlightHeader,enableAutoFill:!1,rowHeaderWidth:c,columnHeaderHeight:i}),h=w.attachSelectionWithCoord(r,s);return d.updateRangeBySelectionWithCoord(h),this._selectionControls.push(d),d.setControlExtension({skeleton:s,scene:n,themeService:this._themeService,injector:this._injector,selectionHooks:{selectionMoveEnd:()=>{this._selectionMoveEnd$.next(this.getSelectionDataWithStyle())}}}),d}};exports.RefSelectionsRenderService=Sr([Ne(1,l.Inject(l.Injector)),Ne(2,l.Inject(l.ThemeService)),Ne(3,a.IShortcutService),Ne(4,l.Inject(w.SheetSkeletonManagerService)),Ne(5,l.IContextService),Ne(6,A.IRefSelectionsService)],exports.RefSelectionsRenderService);function vr(e){const t=w.genNormalSelectionStyle(e);return t.widgets={tl:!0,tc:!0,tr:!0,ml:!0,mr:!0,bl:!0,bc:!0,br:!0},t}const lt=(e,t,n=!0)=>{let s=-1;return e.reduce((r,o,c)=>{if(r.isFinish)return r;const i=r.currentIndex;if(typeof o!="string")r.currentIndex+=o.token.length;else{const d=o.length;r.currentIndex+=d}return(n?r.currentIndex===t:t>i&&t<=r.currentIndex)&&(s=c,r.isFinish=!0),r},{currentIndex:0,isFinish:!1}),s},Vt=(e,t)=>{const n=e[t];let s=-1;if(!n||typeof n=="string"||n.nodeType!==T.sequenceNodeType.REFERENCE)return-1;for(let r=0;r<=t;r++){const o=e[r];typeof o!="string"&&o.nodeType===T.sequenceNodeType.REFERENCE&&s++}return s},Cr=(e,t=100)=>{C.useEffect(()=>{let n=null;const s=()=>{n===null&&(n=window.setTimeout(()=>{e(),n=null},t))};return window.addEventListener("scroll",s),window.addEventListener("resize",s),()=>{n!==null&&clearTimeout(n),window.removeEventListener("scroll",s),window.removeEventListener("resize",s)}},[e,t])};function Bt(e,t,n){const s=a.useDependency(Q.IEditorService),r=C.useMemo(()=>new Y.BehaviorSubject({left:-999,top:-999,right:-999,bottom:-999}),[]),o=a.useDependency(a.ISidebarService),c=a.useDependency(l.IUniverInstanceService),i=a.useEvent(()=>{var E;const d=s.getEditor(e);if(!d)return;const h=d.getBoundingClientRect(),{marginTop:m=0,marginBottom:p=0}=d.getDocumentData().documentStyle,f=d.getSkeleton();if(!f)return;const g=(E=f.getSkeletonData())==null?void 0:E.pages[0].height;let{left:u,top:_,right:v,bottom:S}=h;_=_+m,S=g?_+g:S-p;const I=r.getValue();if(!(I.left===u&&I.top===_&&I.right===v&&I.bottom===S))return r.next({left:u-1,right:v+1,top:_-1,bottom:S+1}),h});return C.useEffect(()=>{t&&i()},[e,s,c.unitAdded$,i,t,...n!=null?n:[]]),Cr(i),C.useEffect(()=>{const d=o.scrollEvent$.pipe(Y.throttleTime(100)).subscribe(i);return()=>{d.unsubscribe()}},[]),[r,i]}const Te=e=>{const t=C.useRef(e);return t.current=e,t},_r=(e,t,n)=>{const s=a.useDependency(Qe),r=a.useDependency(Ce.IDescriptionService),o=a.useDependency(T.LexerTreeBuilder),[c,i]=C.useState(),[d,h]=C.useState(-1),[m,p]=C.useState(!0),f=Te(m),g=C.useRef(t);g.current=t;const u=()=>{i(void 0),h(-1),p(!1)};return C.useEffect(()=>{const _=o.sequenceNodesBuilder(t.slice(1));s.setSequenceNodes(_!=null?_:[])},[t]),C.useEffect(()=>{if(n&&e){const _=n.selectionChange$.pipe(Y.debounceTime(50)).subscribe(S=>{if(S.textRanges.length===1){const[I]=S.textRanges;if(I.collapsed&&f.current){const{startOffset:E}=I,y=s.getCurrentSequenceNode(E-2);if(y)if(typeof y!="string"&&y.nodeType===3&&!r.hasDefinedNameDescription(y.token.trim())){const R=r.getFunctionInfo(y.token);i(R),h(-1);return}else{const R=o.getFunctionAndParameter(`${g.current}A`,E-1);if(R){const{functionName:O,paramIndex:F}=R,L=r.getFunctionInfo(O);i(L),h(F);return}}}}i(void 0),h(-1)}),v=n.selectionChange$.pipe(Y.filter(S=>S.textRanges.length===1),Y.map(S=>S.textRanges[0].startOffset),Y.distinctUntilChanged()).subscribe(()=>{p(!0)});return()=>{_.unsubscribe(),v.unsubscribe()}}},[n,e]),C.useEffect(()=>{e||u()},[e]),{functionInfo:c,paramIndex:d,reset:u}},Rr=({onClick:e})=>b.jsx("div",{className:"univer-z-[15] univer-box-border univer-h-[18px] univer-cursor-pointer univer-overflow-visible univer-whitespace-nowrap univer-rounded-l univer-border univer-border-r-0 univer-border-gray-600 univer-bg-primary-600 univer-p-0.5 univer-text-xs univer-font-bold univer-leading-[13px] univer-text-white",onClick:e,children:"?"}),rt=({className:e,title:t,value:n})=>b.jsxs("div",{className:"univer-my-2",children:[b.jsx("div",{className:W.clsx("univer-mb-2 univer-text-sm univer-font-medium univer-text-gray-900 dark:!univer-text-white",e),children:t}),b.jsx("div",{className:"univer-whitespace-pre-wrap univer-break-words univer-text-xs univer-text-gray-500",children:n})]}),Ir=e=>{const{prefix:t,value:n,active:s,onClick:r}=e;return b.jsxs("div",{children:[b.jsxs("span",{children:[t,"("]}),n&&n.map((o,c)=>b.jsxs("span",{children:[b.jsx("span",{className:s===c?"univer-text-primary-500":"",onClick:()=>r(c),children:kt(o)}),c===n.length-1?"":","]},o.name)),")"]})},It=()=>{};function yr(e){const{onParamsSwitch:t=It,onClose:n=It,isFocus:s,editor:r,formulaText:o}=e,{functionInfo:c,paramIndex:i,reset:d}=_r(s,o,r),h=a.useDependency(w.IEditorBridgeService),m=!a.useObservable(h.helpFunctionVisible$),[p,f]=C.useState(!0),g=a.useDependency(l.LocaleService),u=g.t("formula.prompt.required"),_=g.t("formula.prompt.optional"),v=r.getEditorId(),[S]=Bt(v,!!c,[c,i]);function I(R){t&&t(R)}const E=a.useEvent(R=>{h.helpFunctionVisible$.next(!R)}),y=()=>{E(!0),n()};return c?m?b.jsx(a.RectPopup,{portal:!0,anchorRect$:S,direction:"left-center",children:b.jsx(Rr,{onClick:()=>E(!1)})},"hidden"):b.jsx(a.RectPopup,{portal:!0,onClickOutside:()=>d(),anchorRect$:S,direction:"vertical",children:b.jsxs("div",{className:W.clsx("univer-m-0 univer-box-border univer-w-[250px] univer-select-none univer-list-none univer-rounded-lg univer-bg-white univer-leading-5 univer-shadow-md univer-outline-none dark:!univer-bg-gray-900",W.borderClassName),children:[b.jsxs("div",{className:W.clsx("univer-wrap-anywhere univer-box-border univer-flex univer-items-center univer-justify-between univer-px-4 univer-py-3 univer-text-xs univer-font-medium univer-text-gray-900 dark:!univer-text-white",W.borderTopClassName),children:[b.jsx(Ir,{prefix:c.functionName,value:c.functionParameter,active:i,onClick:I}),b.jsxs("div",{className:"univer-flex",children:[b.jsx("div",{className:"univer-ml-2 univer-flex univer-h-6 univer-w-6 univer-cursor-pointer univer-items-center univer-justify-center univer-rounded univer-bg-transparent univer-p-0 univer-text-xs univer-text-gray-500 univer-outline-none univer-transition-colors hover:univer-bg-gray-200 dark:hover:!univer-bg-gray-600",style:{transform:p?"rotateZ(-90deg)":"rotateZ(90deg)"},onClick:()=>f(!p),children:b.jsx(jt,{})}),b.jsx("div",{className:"univer-ml-2 univer-flex univer-h-6 univer-w-6 univer-cursor-pointer univer-items-center univer-justify-center univer-rounded univer-bg-transparent univer-p-0 univer-text-xs univer-text-gray-600 univer-outline-none univer-transition-colors hover:univer-bg-gray-300 dark:!univer-text-gray-200 dark:hover:!univer-bg-gray-600",onClick:y,children:b.jsx(Lt,{})})]})]}),b.jsx("div",{className:W.clsx("univer-box-border univer-max-h-[350px] univer-overflow-y-auto univer-px-4 univer-pb-3 univer-pt-0",W.scrollbarClassName),style:{height:p?"unset":0,padding:p?"revert-layer":0},children:b.jsxs("div",{className:"univer-mt-3",children:[b.jsx(rt,{title:g.t("formula.prompt.helpExample"),value:`${c.functionName}(${c.functionParameter.map(R=>R.example).join(",")})`}),b.jsx(rt,{title:g.t("formula.prompt.helpAbstract"),value:c.description}),c&&c.functionParameter&&c.functionParameter.map((R,O)=>b.jsx(rt,{className:i===O?"univer-text-primary-500":"",title:R.name,value:`${R.require?u:_} ${R.detail}`},O))]})})]})},"show"):null}const Er=e=>{const t=a.useDependency(Q.IEditorService);return a.useEvent(s=>{var r,o;if(e){t.focus(e.getEditorId());const c=[...e.getSelectionRanges()];if(l.Tools.isDefine(s))e.setSelectionRanges([{startOffset:s,endOffset:s}]);else if(!c.length&&!e.docSelectionRenderService.isOnPointerEvent){const i=(o=(r=e.getDocumentData().body)==null?void 0:r.dataStream)!=null?o:`\r
|
|
2
|
+
`,d=Math.max(i.length-2,0);e.setSelectionRanges([{startOffset:d,endOffset:d}])}else e.setSelectionRanges(c)}})};function br(e){var r,o;const n=e.get(l.IUniverInstanceService).getCurrentUniverDocInstance();return n!=null&&n.getBody()?{dataStream:(o=(r=n.getBody())==null?void 0:r.dataStream)!=null?o:"",offset:0}:void 0}var ve=(e=>(e[e.NOT_SELECT=0]="NOT_SELECT",e[e.NEED_ADD=1]="NEED_ADD",e[e.CAN_EDIT=2]="CAN_EDIT",e[e.EDIT_OTHER_SHEET_REFERENCE=3]="EDIT_OTHER_SHEET_REFERENCE",e))(ve||{});function Tr(e){var F;const{editorId:t,isFocus:n,disableOnClick:s,unitId:r,subUnitId:o}=e,c=a.useDependency(H.IRenderManagerService),i=a.useDependency(l.IUniverInstanceService),d=c.getRenderById(r),h=c.getRenderById(t),m=h==null?void 0:h.with(Q.DocSelectionRenderService),p=a.useDependency(bt.DocSelectionManagerService),f=a.useDependency(l.Injector),[g,u]=C.useState(0),_=a.useDependency(T.LexerTreeBuilder),v=C.useRef(!0),S=d==null?void 0:d.with(exports.RefSelectionsRenderService),I=Te(g),E=i.getUnit(r,l.UniverInstanceType.UNIVER_SHEET),y=E==null?void 0:E.getSheetBySheetId(o),R=a.useEvent(L=>{S&&S.setSkipLastEnabled(L===1||L===3),I.current=L,u(L)}),O=a.useEvent(()=>{var B,re;if(!E)return;const L=E.getActiveSheet(),U=m==null?void 0:m.getActiveTextRange(),k=U!=null&&U.collapsed?U.startOffset:-1,$=br(f);if(!$)return;const D=(B=$==null?void 0:$.dataStream)==null?void 0:B.slice(0,-2),N=((re=_.sequenceNodesBuilder(D))!=null?re:[]).map(z=>typeof z=="object"?z.nodeType===T.sequenceNodeType.REFERENCE?{...z,range:T.deserializeRangeWithSheetWithCache(z.token)}:{...z,range:void 0}:z),x=D[k-1],M=D[k],P=N.find(z=>typeof z=="object"&&z.nodeType===T.sequenceNodeType.REFERENCE&&k===z.endIndex+2),j=x&&T.matchRefDrawToken(x)&&(!M||T.isFormulaLexerToken(M)&&M!==T.matchToken.OPEN_BRACKET),V=!!P;if((D==null?void 0:D.substring(0,1))==="="&&(j||V))if(V){if(v.current)return;!P.range.sheetName&&L.getSheetId()===(y==null?void 0:y.getSheetId())||P.range.sheetName===L.getName()?R(2):R(3)}else v.current=!1,R(1);else R(0)});return C.useEffect(()=>{const L=p.textSelection$.pipe(Y.filter(U=>U.unitId===t)).subscribe(()=>{O()});return()=>L.unsubscribe()},[O,p.textSelection$,t]),C.useEffect(()=>{n||(R(0),v.current=!0)},[n,R]),C.useEffect(()=>{var U;if(!s)return;const L=(U=h==null?void 0:h.mainComponent)==null?void 0:U.onPointerDown$.subscribeEvent(()=>{R(0),v.current=!0});return()=>L==null?void 0:L.unsubscribe()},[s,(F=h==null?void 0:h.mainComponent)==null?void 0:F.onPointerDown$,R]),C.useEffect(()=>{if(!n)return;const L=E==null?void 0:E.activeSheet$.subscribe(()=>{O()});return()=>L==null?void 0:L.unsubscribe()},[O,n,E==null?void 0:E.activeSheet$]),{isSelecting:g,isSelectingRef:I}}const xr=()=>{const e=a.useDependency(T.LexerTreeBuilder);return C.useCallback(n=>e.sequenceNodesBuilder(n)||[],[e])};function Mr(e,t,n){const s=new l.ColorKit(t).setAlpha(.05).toRgbString();return{id:n,strokeWidth:1,stroke:t,fill:s,widgets:{tl:!0,tc:!0,tr:!0,ml:!0,mr:!0,bl:!0,bc:!0,br:!0},widgetSize:6,widgetStrokeWidth:1,widgetStroke:e.getColorFromTheme("white")}}function Ht(e){var E,y,R;const{unitId:t,subUnitId:n,currentWorkbook:s,refSelections:r,editor:o,refSelectionsService:c,refSelectionsRenderService:i,sheetSkeletonManagerService:d,themeService:h,univerInstanceService:m}=e,p=s.getUnitId(),f=m.getUnit(t,l.UniverInstanceType.UNIVER_SHEET),g=f==null?void 0:f.getActiveSheet(),u=[];if(!f||!g){c.setSelections(u);return}const _=g.getSheetId(),v=O=>{var F;return(F=f==null?void 0:f.getSheetBySheetName(O))==null?void 0:F.getSheetId()};if(!((E=d==null?void 0:d.getWorksheetSkeleton(_))==null?void 0:E.skeleton))return;const I=[];for(let O=0,F=r.length;O<F;O++){const L=r[O],{themeColor:U,token:k,refIndex:$,endIndex:D}=L,N=T.deserializeRangeWithSheet(k),{unitId:x,sheetName:M,range:P}=N,j=v(M);if(!j&&M||p!==t&&x!==p||x&&x!==p||j&&j!==_||!j&&_!==n)continue;const V=A.setEndForRange(P,g.getRowCount(),g.getColumnCount());V.unitId=t,V.sheetId=_,u.push({range:V,primary:null,style:Mr(h,U,$.toString())}),I.push(D)}if(o){const O=(R=(y=o.getSelectionRanges())==null?void 0:y[0])==null?void 0:R.startOffset,F=I.findIndex(L=>L+2===O);F!==-1?i==null||i.setActiveSelectionIndex(F):i==null||i.resetActiveSelectionIndex()}return u}function Or(e,t){const n=a.useDependency(l.IUniverInstanceService),s=a.useDependency(l.ThemeService),r=a.useDependency(A.IRefSelectionsService),o=a.useDependency(H.IRenderManagerService),c=a.useObservable(C.useMemo(()=>n.getCurrentTypeOfUnit$(l.UniverInstanceType.UNIVER_SHEET),[n])),i=c?o.getRenderById(c.getUnitId()):null,d=i==null?void 0:i.with(exports.RefSelectionsRenderService),h=i==null?void 0:i.with(w.SheetSkeletonManagerService),m=a.useEvent((p,f)=>{const g=n.getCurrentUnitOfType(l.UniverInstanceType.UNIVER_SHEET);if(!g||d!=null&&d.selectionMoving)return;const u=Ht({unitId:e,subUnitId:t,currentWorkbook:g,refSelections:p,editor:f,refSelectionsService:r,refSelectionsRenderService:d,sheetSkeletonManagerService:h,themeService:s,univerInstanceService:n});u&&r.setSelections(u)});return C.useEffect(()=>()=>{d==null||d.resetActiveSelectionIndex()},[d]),m}function Kt(e=""){const t=a.useDependency(Ce.IDescriptionService),n=Nr(),s=a.useDependency(l.ICommandService),r=C.useMemo(()=>e.length,[e]);return a.useEvent((c,i,d=!0,h)=>{const m=c.getDocumentData(),p=c.getEditorId();if(!m)return[];const f=m.body;if(!f)return[];const g=f.dataStream.slice(0,f.dataStream.length-2),u={dataStream:"",...m.body};if(!g.startsWith(e))return[];if(i==null||i.length===0)return u.textRuns=[],s.syncExecuteCommand(Q.ReplaceTextRunsCommand.id,{unitId:p,body:l.getBodySlice(u,0,u.dataStream.length-2)}),[];{const{textRuns:_,refSelections:v}=Dr(t,n,i);r&&_.forEach(E=>{E.ed=E.ed+r,E.st=E.st+r}),u.textRuns=[{st:0,ed:1,ts:{fs:11}},..._];const S=i.reduce((E,y)=>typeof y=="string"?`${E}${y}`:`${E}${y.token}`,"");u.dataStream=`${e}${S}\r
|
|
3
|
+
`;let I;if(d){I=c.getSelectionRanges();const E=u.dataStream.length-2+r;I.forEach(y=>{y.startOffset=Math.max(0,Math.min(y.startOffset,E)),y.endOffset=Math.max(0,Math.min(y.endOffset,E))})}return s.syncExecuteCommand(Q.ReplaceTextRunsCommand.id,{unitId:p,body:l.getBodySlice(u,0,u.dataStream.length-2),textRanges:h!=null?h:I}),v}})}function Nr(){const e=a.useDependency(l.ThemeService),t=e.getCurrentTheme();return C.useMemo(()=>{const s=[e.getColorFromTheme("loop-color.1"),e.getColorFromTheme("loop-color.2"),e.getColorFromTheme("loop-color.3"),e.getColorFromTheme("loop-color.4"),e.getColorFromTheme("loop-color.5"),e.getColorFromTheme("loop-color.6"),e.getColorFromTheme("loop-color.7"),e.getColorFromTheme("loop-color.8"),e.getColorFromTheme("loop-color.9"),e.getColorFromTheme("loop-color.10"),e.getColorFromTheme("loop-color.11"),e.getColorFromTheme("loop-color.12")].map(i=>e.isValidThemeColor(i)?e.getColorFromTheme(i):i),r=e.getColorFromTheme("blue.700"),o=e.getColorFromTheme("jiqing.800"),c=e.getColorFromTheme("black");return{formulaRefColors:s,numberColor:r,stringColor:o,plainTextColor:c}},[t])}function Dr(e,t,n){const{formulaRefColors:s,numberColor:r,stringColor:o,plainTextColor:c}=t,i=[],d=[],h=new Map;let m=0;for(let p=0,f=n.length;p<f;p++){const g=n[p];if(typeof g=="string"){const E=i[i.length-1],y=E?E.ed:0,R=y+g.length;i.push({st:y,ed:R,ts:{cl:{rgb:c},fs:11}});continue}if(e.hasDefinedNameDescription(g.token.trim())){i.push({st:g.startIndex,ed:g.endIndex+1,ts:{cl:{rgb:c},fs:11}});continue}const{startIndex:u,endIndex:_,nodeType:v,token:S}=g;let I="";if(v===T.sequenceNodeType.REFERENCE){if(h.has(S))I=h.get(S);else{const E=m%s.length;I=s[E],h.set(S,I),m++}d.push({refIndex:p,themeColor:I,token:S,startIndex:g.startIndex,endIndex:g.endIndex,index:d.length})}else v===T.sequenceNodeType.NUMBER?I=r:(v===T.sequenceNodeType.STRING||v===T.sequenceNodeType.ARRAY)&&(I=o);I&&I.length>0?i.push({st:u,ed:_+1,ts:{cl:{rgb:I},fs:11}}):i.push({st:u,ed:_+1,ts:{cl:{rgb:c},fs:11}})}return{textRuns:i,refSelections:d}}const wr=(e,t,n,s)=>{const r=a.useDependency(l.ICommandService),o=a.useDependency(a.IShortcutService),c=C.useRef(t);c.current=t;const i=C.useRef(s);i.current=s,C.useEffect(()=>{if(!n||!e)return;const h=`sheet.formula-embedding-editor.${n.getEditorId()}`,m=new l.DisposableCollection,p=(u,_)=>{if(i.current){i.current(u,_);return}let v=l.Direction.LEFT;u===a.KeyCode.ARROW_DOWN?v=l.Direction.DOWN:u===a.KeyCode.ARROW_UP?v=l.Direction.UP:u===a.KeyCode.ARROW_RIGHT&&(v=l.Direction.RIGHT),_===a.MetaKeys.SHIFT?r.executeCommand(Q.MoveSelectionOperation.id,{direction:v}):r.executeCommand(Q.MoveCursorOperation.id,{direction:v})},f=(u,_)=>{let v=l.Direction.DOWN;u===a.KeyCode.ARROW_DOWN?v=l.Direction.DOWN:u===a.KeyCode.ARROW_UP?v=l.Direction.UP:u===a.KeyCode.ARROW_LEFT?v=l.Direction.LEFT:u===a.KeyCode.ARROW_RIGHT&&(v=l.Direction.RIGHT),c.current?_===a.MetaKeys.CTRL_COMMAND?r.executeCommand(w.MoveSelectionCommand.id,{direction:v,jumpOver:w.JumpOver.moveGap,extra:"formula-editor",fromCurrentSelection:c.current===ve.NEED_ADD||c.current===ve.EDIT_OTHER_SHEET_REFERENCE}):_===a.MetaKeys.SHIFT?r.executeCommand(w.ExpandSelectionCommand.id,{direction:v,extra:"formula-editor"}):_===(a.MetaKeys.CTRL_COMMAND|a.MetaKeys.SHIFT)?r.executeCommand(w.ExpandSelectionCommand.id,{direction:v,jumpOver:w.JumpOver.moveGap,extra:"formula-editor"}):r.executeCommand(w.MoveSelectionCommand.id,{direction:v,extra:"formula-editor",fromCurrentSelection:c.current===ve.NEED_ADD||c.current===ve.EDIT_OTHER_SHEET_REFERENCE}):p(u,_)};return m.add(r.registerCommand({id:h,type:l.CommandType.OPERATION,handler(u,_){const{keyCode:v,metaKey:S}=_;f(v,S)}})),[{keyCode:a.KeyCode.ARROW_DOWN},{keyCode:a.KeyCode.ARROW_LEFT},{keyCode:a.KeyCode.ARROW_RIGHT},{keyCode:a.KeyCode.ARROW_UP},{keyCode:a.KeyCode.ARROW_DOWN,metaKey:a.MetaKeys.SHIFT},{keyCode:a.KeyCode.ARROW_LEFT,metaKey:a.MetaKeys.SHIFT},{keyCode:a.KeyCode.ARROW_RIGHT,metaKey:a.MetaKeys.SHIFT},{keyCode:a.KeyCode.ARROW_UP,metaKey:a.MetaKeys.SHIFT},{keyCode:a.KeyCode.ARROW_DOWN,metaKey:a.MetaKeys.CTRL_COMMAND},{keyCode:a.KeyCode.ARROW_LEFT,metaKey:a.MetaKeys.CTRL_COMMAND},{keyCode:a.KeyCode.ARROW_RIGHT,metaKey:a.MetaKeys.CTRL_COMMAND},{keyCode:a.KeyCode.ARROW_UP,metaKey:a.MetaKeys.CTRL_COMMAND},{keyCode:a.KeyCode.ARROW_DOWN,metaKey:a.MetaKeys.CTRL_COMMAND|a.MetaKeys.SHIFT},{keyCode:a.KeyCode.ARROW_LEFT,metaKey:a.MetaKeys.CTRL_COMMAND|a.MetaKeys.SHIFT},{keyCode:a.KeyCode.ARROW_RIGHT,metaKey:a.MetaKeys.CTRL_COMMAND|a.MetaKeys.SHIFT},{keyCode:a.KeyCode.ARROW_UP,metaKey:a.MetaKeys.CTRL_COMMAND|a.MetaKeys.SHIFT}].map(({keyCode:u,metaKey:_})=>({id:h,binding:_?u|_:u,preconditions:()=>!0,priority:900,staticParameters:{eventType:H.DeviceInputEventType.Keyboard,keyCode:u,metaKey:_}})).forEach(u=>{m.add(o.registerShortcut(u))}),()=>{m.dispose()}},[r,n,e,o])},kr=(e,t,n,s=!0)=>{var f;const r=a.useDependency(H.IRenderManagerService),o=a.useDependency(l.IContextService),c=a.useDependency(a.IContextMenuService),i=a.useDependency(A.IRefSelectionsService),d=a.useDependency(l.IUniverInstanceService),h=a.useObservable(C.useMemo(()=>d.getCurrentTypeOfUnit$(l.UniverInstanceType.UNIVER_SHEET),[d])),m=r.getRenderById((f=h==null?void 0:h.getUnitId())!=null?f:""),p=m==null?void 0:m.with(exports.RefSelectionsRenderService);C.useLayoutEffect(()=>{if(e)return o.setContextValue(l.EDITOR_ACTIVATED,!0),()=>{o.setContextValue(l.EDITOR_ACTIVATED,!1),i.clear()}},[o,e,i]),C.useLayoutEffect(()=>{if(e&&t){const g=p==null?void 0:p.enableSelectionChanging();return o.setContextValue(A.REF_SELECTIONS_ENABLED,!0),()=>{o.setContextValue(A.REF_SELECTIONS_ENABLED,!1),g==null||g.dispose()}}},[o,e,p,t]),C.useEffect(()=>{if(e)return o.setContextValue(l.EDITOR_ACTIVATED,!0),s&&c.disable(),()=>{o.setContextValue(l.EDITOR_ACTIVATED,!1),s&&c.enable()}},[c,o,e,s]),C.useEffect(()=>{e&&(p==null||p.setSkipLastEnabled(!1))},[e,p])},Ar=(e,t,n)=>{const s=a.useDependency(l.IUniverInstanceService),r=a.useDependency(A.SheetsSelectionsService);return C.useCallback(()=>{if(e){const c=[...r.getWorkbookSelections(t).getSelectionsOfWorksheet(n)],i=s.getCurrentUnitForType(l.UniverInstanceType.UNIVER_SHEET),d=i==null?void 0:i.getActiveSheet();(i==null?void 0:i.getUnitId())!==t&&s.setCurrentUnitForType(t),d&&d.getSheetId()===n&&r.setSelections(c)}},[e,r,n,t,s])},Fr=e=>e.reduce((t,n)=>typeof n=="string"?t+n.length:t+n.token.length,0),it=e=>e.map(t=>typeof t=="string"?t:t.token).join(""),He=(e,t=!1,n="",s=!1)=>!t&&!s?e.map(r=>T.serializeRange(r.range)):e.map(r=>s?T.serializeRangeToRefString(r):r.sheetName!==""&&r.sheetName!==n?T.serializeRangeWithSheet(r.sheetName,r.range):T.serializeRange(r.range)),Pr=e=>{var m,p,f;const{editor:t,lexerTreeBuilder:n}=e,s=t==null?void 0:t.getSelectionRanges();if((s==null?void 0:s.length)!==1)return;const o=s[0].startOffset-1,c=((p=(m=t==null?void 0:t.getDocumentData().body)==null?void 0:m.dataStream)!=null?p:`\r
|
|
4
|
+
`).slice(0,-2),i=(f=n.sequenceNodesBuilder(c.slice(1)))!=null?f:[],d=lt(i,o,!1),h=Vt(i,d);return{nodeIndex:d,updatingRefIndex:h,sequenceNodes:i,offset:o}},Lr=()=>{},Ur=(e,t,n,s,r,o,c,i,d,h=Lr)=>{var $;const m=a.useDependency(H.IRenderManagerService),p=a.useDependency(l.IUniverInstanceService),f=a.useDependency(l.ICommandService),g=a.useDependency(bt.DocSelectionManagerService),u=a.useDependency(l.ThemeService),_=a.useDependency(T.LexerTreeBuilder),v=p.getUnit(s),S=a.useEvent((D,N)=>{var x,M,P;return(P=(M=(x=p.getUnit(D))==null?void 0:x.getSheetBySheetId(N))==null?void 0:M.getName())!=null?P:""}),I=C.useMemo(()=>S(s,r),[S,r,s]),E=a.useObservable(v==null?void 0:v.activeSheet$),y=Te({activeSheet:E,sheetName:I}),R=a.useObservable(C.useMemo(()=>p.getCurrentTypeOfUnit$(l.UniverInstanceType.UNIVER_SHEET),[p])),O=m.getRenderById(($=R==null?void 0:R.getUnitId())!=null?$:""),F=O==null?void 0:O.with(exports.RefSelectionsRenderService),L=O==null?void 0:O.with(w.SheetSkeletonManagerService),U=a.useDependency(A.IRefSelectionsService),k=a.useEvent((D,N)=>{var B,re,z,he,xe,ee,Le,Me,Ue;const x=Pr({editor:d,lexerTreeBuilder:_});if(!x)return;const{nodeIndex:M,updatingRefIndex:P,sequenceNodes:j,offset:V}=x;if(n.current===ve.NEED_ADD)if(V!==0){if(M===-1&&j.length)return;const K=D[D.length-1],J=j.splice(M+1),ae=(B=K.sheetId)!=null?B:r,ue={range:K,unitId:(re=K.unitId)!=null?re:R.getUnitId(),sheetName:S((z=K.unitId)!=null?z:R.getUnitId(),ae)},se=ae!==r,X=(R==null?void 0:R.getUnitId())!==s,de=He([ue],c&&(se||X),I,X);j.push({token:de[0],nodeType:T.sequenceNodeType.REFERENCE});const De=[...j,...J],ge=it(De);h(ge,Fr(j),N)}else{const K=D[D.length-1],J=(he=K.sheetId)!=null?he:r,ae={range:K,unitId:(xe=K.unitId)!=null?xe:R.getUnitId(),sheetName:S((ee=K.unitId)!=null?ee:R.getUnitId(),J)},ue=J!==r,se=(R==null?void 0:R.getUnitId())!==s,X=He([ae],c&&(ue||se),I,se);j.unshift({token:X[0],nodeType:T.sequenceNodeType.REFERENCE});const de=it(j);h(de,X[0].length,N)}else if(n.current===ve.EDIT_OTHER_SHEET_REFERENCE){const K=D.pop();if(!K)return;const J=j[M];if(typeof J=="object"&&J.nodeType===T.sequenceNodeType.REFERENCE){const ae=J.token;J.token=I===(E==null?void 0:E.getName())?T.serializeRange(K):T.serializeRangeWithSheet(E.getName(),K);const ue=V+(J.token.length-ae.length);h(T.generateStringWithSequence(j),ue,N)}}else{const K=[...D];if(P!==-1){const G=K.pop();G&&K.splice(P,0,G)}let J=0;const ae=j.map(G=>{var oe,me,Oe,_e;if(typeof G=="string")return G;if(G.nodeType===T.sequenceNodeType.REFERENCE){const le=T.deserializeRangeWithSheet(G.token);if(le.sheetName||(le.sheetName=I),c&&((oe=y.current.activeSheet)==null?void 0:oe.getName())!==le.sheetName)return G.token;const te=K[J];if(J++,!te)return"";const we=(me=te.sheetId)!=null?me:r,tt={range:te,unitId:(Oe=te.unitId)!=null?Oe:R.getUnitId(),sheetName:S((_e=te.unitId)!=null?_e:R.getUnitId(),we)},$e=(R==null?void 0:R.getUnitId())!==s;return He([tt],c&&(we!==r||$e),I,$e)[0]}return G.token});let ue="",se;ae.forEach((G,oe)=>{ue+=G,oe===M&&(se=ue.length)});const X=[];for(let G=J;G<=D.length-1;G++){const oe=D[G],me=(Le=oe.sheetId)!=null?Le:r,Oe={range:oe,unitId:(Me=oe.unitId)!=null?Me:R.getUnitId(),sheetName:S((Ue=oe.unitId)!=null?Ue:R.getUnitId(),me)},_e=(R==null?void 0:R.getUnitId())!==s,te=He([Oe],c&&(me!==r||_e),I,_e);X.push(te[0])}const de=j[j.length-1],De=de&&(typeof de=="string"?!1:de.nodeType===T.sequenceNodeType.REFERENCE),ge=`${ue}${X.length&&De?",":""}${X.join(",")}`;h(ge,!X.length&&se?se:ge.length,N)}});C.useEffect(()=>{if(F&&e){let D=!0;const N=(M,P)=>{if(D){D=!1;return}k(M.map(j=>j.rangeWithCoord),P)},x=new l.DisposableCollection;return x.add(F.selectionMoving$.subscribe(M=>{N(M,!1)})),x.add(F.selectionMoveEnd$.subscribe(M=>{N(M,!0)})),()=>{x.dispose()}}},[e,k,F]),C.useEffect(()=>{if(t&&F&&d){const D=new l.DisposableCollection,N=()=>{D.dispose(),F.getSelectionControls().forEach((P,j)=>{D.add(P.selectionScaling$.subscribe(V=>{const B=F.getSelectionDataWithStyle().map(z=>z.rangeWithCoord),re=B[j];V.sheetId=re.sheetId,V.unitId=re.unitId,B[j]=V,k(B,!1)})),D.add(P.selectionMoving$.subscribe(V=>{const B=F.getSelectionDataWithStyle().map(z=>z.rangeWithCoord),re=B[j];V.sheetId=re.sheetId,V.unitId=re.unitId,B[j]=V,k(B,!0)}))})},x=Y.merge(d.input$,U.selectionSet$,F.selectionMoveEnd$).pipe(Jt.debounceTime(50)).subscribe(()=>{N()});return()=>{x.unsubscribe(),D.dispose()}}},[d,t,k,F,U.selectionSet$]),F==null||F.getSelectionDataWithStyle(),C.useEffect(()=>{if(i){const D=f.onCommandExecuted(N=>{var M;if(N.id!==A.SetSelectionsOperation.id)return;const x=N.params;if(x.extra==="formula-editor"&&x.selections.length){const P=x.selections[x.selections.length-1];if(P){const j=n.current===ve.NEED_ADD,V=((M=F==null?void 0:F.getSelectionDataWithStyle())!=null?M:[]).map(B=>B.rangeWithCoord);j?V.push(P.range):V[V.length-1]=P.range,k(V,!0)}}});return()=>{D.dispose()}}},[f,d,n,_,i,k,F]),C.useEffect(()=>{if(!d)return;const D=g.textSelection$.subscribe(N=>{N.unitId===d.getEditorId()&&Ht({unitId:s,subUnitId:r,refSelections:o.current,editor:d,refSelectionsService:U,refSelectionsRenderService:F,sheetSkeletonManagerService:L,themeService:u,univerInstanceService:p,currentWorkbook:R})});return()=>D.unsubscribe()},[g.textSelection$,d,o,F,U,L,r,u,s,p])},$r=(e,t,n,s,r,o)=>{const c=a.useDependency(l.ICommandService),i=a.useDependency(Q.IEditorService),h=a.useDependency(H.IRenderManagerService).getRenderById(t),m=a.useDependency(l.IUniverInstanceService),p=h==null?void 0:h.with(exports.RefSelectionsRenderService);C.useEffect(()=>{if(e&&p)if(n){const f=()=>{const _=p.getSelectionControls().length;for(let v=1;v<=_;v++)p.clearLastSelection();return setTimeout(()=>{o()},30)},g=c.onCommandExecuted(_=>{_.id===A.SetWorksheetActiveOperation.id&&f()}),u=m.getCurrentTypeOfUnit$(l.UniverInstanceType.UNIVER_SHEET).subscribe(_=>{f()});return()=>{g.dispose(),u.unsubscribe()}}else{const f=c.beforeCommandExecuted(g=>{if(g.id===A.SetWorksheetActiveOperation.id){s(!1),r(),o();const u=i.getEditor(l.DOCS_NORMAL_EDITOR_UNIT_ID_KEY);u==null||u.focus()}});return()=>{f.dispose()}}},[e,p])},jr=(e,t,n)=>{const s=a.useDependency(T.LexerTreeBuilder),r=C.useRef(!0);C.useEffect(()=>{if(e){const o=setTimeout(()=>{r.current=!1},500);return()=>{clearTimeout(o)}}},[e]),C.useEffect(()=>{if(!r.current&&t){const o=s.checkIfAddBracket(n);t(o===0&&n.startsWith(T.operatorToken.EQUALS),`${n}`)}},[n,t])},Wr=(e,t=[],n)=>{const s=a.useDependency(Ce.IDescriptionService),[r,o]=C.useState([]),[c,i]=C.useState(""),d=C.useRef(-1),h=Te({nodes:t}),m=()=>{o([]),i(""),d.current=-1};return C.useEffect(()=>{if(n&&e){const f=n.input$.pipe(Y.debounceTime(300)).subscribe(()=>{const g=n.getSelectionRanges();if(g.length===1){const u=h.current.nodes,_=g[0];if(_.collapsed){const v=lt(u,_.startOffset-1,!1);d.current=v;const S=u[v];if(S&&typeof S!="string"&&S.nodeType===T.sequenceNodeType.FUNCTION){d.current=v;const I=S.token,E=s.getSearchListByNameFirstLetter(I);o(E),i(I);return}}}d.current=-1,i(""),o(u=>u!=null&&u.length?[]:u)});return()=>{f.unsubscribe()}}},[n,e]),C.useEffect(()=>{e||m()},[e]),{searchList:r,searchText:c,handlerFormulaReplace:f=>{const g=[...h.current.nodes];if(d.current!==-1){const u=g.splice(d.current+1),_=g.pop()||"";let v=(typeof _=="string"?_.length:_.token.length)-f.length;return g.push(f),u[0]!==T.matchToken.OPEN_BRACKET&&(g.push(T.matchToken.OPEN_BRACKET),v--),{text:it([...g,...u]),offset:v}}},reset:m}},Vr=()=>{},Br=C.forwardRef(Hr);function Hr(e,t){const{isFocus:n,sequenceNodes:s,onSelect:r,editor:o,onClose:c=Vr}=e,i=o.getEditorId(),d=a.useDependency(a.IShortcutService),h=a.useDependency(l.ICommandService),{searchList:m,searchText:p,handlerFormulaReplace:f,reset:g}=Wr(n,s,o),u=C.useMemo(()=>!!m.length,[m]),_=C.useRef(void 0),[v,S]=C.useState(0),I=C.useRef(!1),[E]=Bt(i,u,[p,m]),y=Te({searchList:m,active:v}),R=k=>{const $=f(k);$&&(g(),r($))};function O(k){I.current&&S(k)}function F(){I.current&&S(-1)}C.useEffect(()=>{if(!m.length)return;const k=`sheet.formula-embedding-editor.search_function.${i}`,$=new l.DisposableCollection,D=N=>{const{searchList:x,active:M}=y.current;switch(N){case a.KeyCode.ARROW_UP:{S(P=>{const j=Math.max(0,P-1);return L(j),j});break}case a.KeyCode.ARROW_DOWN:{S(P=>{const j=Math.min(x.length-1,P+1);return L(j),j});break}case a.KeyCode.TAB:case a.KeyCode.ENTER:{const P=x[M];R(P.name);break}case a.KeyCode.ESC:{g(),c();break}}};return $.add(h.registerCommand({id:k,type:l.CommandType.OPERATION,handler(N,x){const{keyCode:M}=x;D(M)}})),[a.KeyCode.ARROW_UP,a.KeyCode.ARROW_DOWN,a.KeyCode.ENTER,a.KeyCode.ESC,a.KeyCode.TAB].map(N=>({id:k,binding:N,preconditions:()=>!0,priority:1e3,staticParameters:{eventType:H.DeviceInputEventType.Keyboard,keyCode:N}})).forEach(N=>{$.add(d.registerShortcut(N))}),()=>{$.dispose()}},[m]);function L(k){const $=_.current;if(!$)return;const D=$.children[k];if(!D)return;const x=$.getBoundingClientRect().top,M=$.offsetHeight,P=D.getBoundingClientRect(),j=P.top,V=P.height;if(j>=0&&j>x&&j-x+V<=M)return;const B=D.offsetTop-(M-V)/2;$.scrollTo({top:B,behavior:"smooth"})}const U=C.useMemo(()=>{let k="";return()=>{clearTimeout(k),I.current=!0,k=setTimeout(()=>{I.current=!1},300)}},[]);return m.length>0&&u&&b.jsx(a.RectPopup,{portal:!0,anchorRect$:E,direction:"vertical",children:b.jsx("ul",{ref:k=>{_.current=k,t&&(t.current=k)},"data-u-comp":"sheets-formula-editor",className:W.clsx("univer-m-0 univer-box-border univer-max-h-[400px] univer-w-[250px] univer-list-none univer-overflow-y-auto univer-rounded-lg univer-bg-white univer-p-2 univer-leading-5 univer-shadow-md univer-outline-none dark:!univer-bg-gray-900",W.borderClassName,W.scrollbarClassName),children:m.map((k,$)=>b.jsxs("li",{className:W.clsx("univer-box-border univer-cursor-pointer univer-rounded univer-px-2 univer-py-1 univer-text-gray-900 univer-transition-colors dark:!univer-text-white",{"univer-bg-gray-200 dark:!univer-bg-gray-600":v===$}),onMouseEnter:()=>O($),onMouseLeave:F,onMouseMove:U,onClick:()=>{R(k.name),o&&o.focus()},children:[b.jsxs("span",{className:"univer-text-xs",children:[b.jsx("span",{className:"univer-text-red-500",children:k.name.substring(0,p.length)}),b.jsx("span",{children:k.name.slice(p.length)})]}),b.jsx("span",{className:"univer-block univer-text-xs univer-text-gray-400",children:k.desc})]},k.name))})})}const Kr=e=>e.startsWith(T.operatorToken.EQUALS)?e.slice(1):"",yt=()=>{},qt=C.forwardRef((e,t)=>{var ft,gt;const{errorText:n,initValue:s,unitId:r,subUnitId:o,isFocus:c=!0,isSupportAcrossSheet:i=!1,onFocus:d=yt,onBlur:h=yt,onChange:m,onVerify:p,className:f,editorId:g,moveCursor:u=!0,onFormulaSelectingChange:_,keyboardEventConfig:v,onMoveInEditor:S,resetSelectionOnBlur:I=!0,autoScrollbar:E=!0,isSingle:y=!0,disableSelectionOnClick:R=!1,autofocus:O=!0,disableContextMenu:F,style:L}=e,U=a.useDependency(Q.IEditorService),k=C.useRef(null),$=a.useEvent(m);C.useImperativeHandle(t,()=>({isClickOutSide:Z=>k.current?!k.current.contains(Z.target):!1}));const D=a.useEvent(_),N=C.useRef(null),x=C.useRef(void 0),M=x.current,[P,j]=C.useState(c),V=C.useRef(null),B=C.useMemo(()=>g!=null?g:l.createInternalEditorID(`${w.EMBEDDING_FORMULA_EDITOR}-${l.generateRandomId(4)}`),[]),re=C.useMemo(()=>n!==void 0,[n]),z=a.useDependency(l.IUniverInstanceService),he=z.getUnit(B);a.useObservable(he==null?void 0:he.change$);const xe=xr(),ee=l.BuildTextUtils.transform.getPlainText((gt=(ft=he==null?void 0:he.getBody())==null?void 0:ft.dataStream)!=null?gt:""),Le=Te(ee),Me=C.useMemo(()=>Kr(ee),[ee]),Ue=C.useMemo(()=>xe(Me),[Me,xe]),{isSelecting:K,isSelectingRef:J}=Tr({unitId:r,subUnitId:o,editorId:B,isFocus:P,disableOnClick:R}),ae=C.useRef(""),se=a.useDependency(H.IRenderManagerService).getRenderById(B),X=se==null?void 0:se.with(Q.DocSelectionRenderService),de=X==null?void 0:X.isFocusing,De=C.useMemo(()=>z.getCurrentTypeOfUnit$(l.UniverInstanceType.UNIVER_DOC),[z]),ge=a.useObservable(De),G=(ge==null?void 0:ge.getUnitId())===B,oe=C.useRef([]),me=K;a.useUpdateEffect(()=>{$(ee)},[ee,$]);const Oe=Kt("="),_e=Or(r,o),le=a.useEvent((Z,ne=!0,pe,fe)=>{if(!x.current)return;ae.current=Z;const je=Z[0]==="="?Z.slice(1):"",Se=xe(je),zt=Se.reduce((Re,Ve)=>typeof Ve=="object"?`${Re}${Ve.token}`:`${Re}${Ve}`,""),We=Oe(x.current,zt===je?Se:[],ne,fe);if(oe.current=We,pe){const Re=fe!=null?fe:M==null?void 0:M.getSelectionRanges();if((Re==null?void 0:Re.length)!==1)return;const Gt=Re[0].startOffset-1,Zt=lt(Se,Gt,!1),mt=Vt(Se,Zt);if(mt>=0){const pt=We.splice(mt,1)[0];pt&&We.push(pt)}_e(P?We:[],x.current)}});C.useEffect(()=>{P&&le(ee,!1,!0)},[P]),C.useEffect(()=>{if(P){if(ae.current===ee)return;le(ee,!1,!0)}},[ee]),jr(P,p,ee);const te=Er(M),we=Ar(P,r,o);C.useEffect(()=>{var Z;D(K,(Z=X==null?void 0:X.isFocusing)!=null?Z:!0)},[D,K]),Q.useKeyboardEvent(P,v,M),C.useLayoutEffect(()=>{let Z;if(V.current){Z=U.register({autofocus:O,editorUnitId:B,initialSnapshot:{id:B,body:{dataStream:`${s}\r
|
|
5
|
+
`,textRuns:[],customBlocks:[],customDecorations:[],customRanges:[]},documentStyle:{}}},V.current);const ne=U.getEditor(B);x.current=ne,le(s,!1,!0)}return()=>{Z==null||Z.dispose()}},[]),C.useLayoutEffect(()=>{c?(j(c),te()):(I&&(M==null||M.blur(),we()),j(c))},[c,M,te,we,I]);const{checkScrollBar:tt}=Q.useResize(M,y,E);kr(P,!!(K&&G),r,F),wr(!!(P&&de&&u),me,M,S);const $e=a.useEvent((Z,ne,pe)=>{if(!de)return;const fe=ne!==-1?[{startOffset:ne+1,endOffset:ne+1,collapsed:!0}]:void 0;le(`=${Z}`,!0,pe,fe),pe&&(te(),ne!==-1&&setTimeout(()=>{const je={startOffset:ne+1,endOffset:ne+1},Se=M==null?void 0:M.render.with(Q.DocBackScrollRenderController);Se==null||Se.scrollToRange({...je,collapsed:!0})},50),tt())});Ur(P&&!!(K&&G),P,J,r,o,oe,i,!!me,M,$e),$r(P&&!!(K&&G),r,i,j,h,()=>{le(Le.current,!1,!0)});const dt=Z=>{if(Z){const ne=M==null?void 0:M.getSelectionRanges();if(ne&&ne.length===1){const pe=ne[0];if(pe.collapsed){const fe=Z.offset;setTimeout(()=>{M==null||M.setSelectionRanges([{startOffset:pe.startOffset-fe,endOffset:pe.endOffset-fe}])},30)}}te(),le(`=${Z.text}`)}},ht=()=>{j(!0),d(),te()};return b.jsxs("div",{className:f,children:[b.jsx("div",{className:W.clsx(`
|
|
6
6
|
univer-relative univer-box-border univer-flex univer-h-full univer-w-full univer-items-center
|
|
7
7
|
univer-justify-around univer-gap-2 univer-rounded-none univer-p-0 univer-ring-1
|
|
8
|
-
`,{"univer-ring-primary-500":P,"univer-ring-red-500":re}),ref:k,children:E.jsx("div",{ref:V,className:"univer-relative univer-h-full univer-w-full",onMouseUp:ht})}),n!==void 0?E.jsx("div",{className:"univer-my-1 univer-text-xs univer-text-red-500",children:n}):null,O?E.jsx(yr,{editor:O,isFocus:P,formulaText:ee,onClose:()=>te()}):null,O?E.jsx(Hr,{isFocus:P,sequenceNodes:Ue,onSelect:dt,ref:N,editor:O}):null]})});function qr(e,t,n,s){const r=a.useDependency(T.LexerTreeBuilder),o=Kt(""),i=a.useObservable(e==null?void 0:e.getDocumentDataModel().change$),[c,d]=v.useState([]),f=a.useDependency(w.IMarkSelectionService),m=v.useRef(""),p=a.useDependency(l.IUniverInstanceService);return v.useEffect(()=>{if(!e)return;const h=e.getDocumentDataModel().getPlainText();if(m.current===h)return;m.current=h;const g=r.sequenceNodesBuilder(h);d(g!=null?g:[])},[i,e,r]),v.useEffect(()=>{var u,_;if(!e)return;if(!t){const S=e.getDocumentData();e.setDocumentData({...S,body:{...S.body,dataStream:(_=(u=S.body)==null?void 0:u.dataStream)!=null?_:"",textRuns:[]}});return}const h=o(e,c,!1),g=new l.DisposableCollection;return h.forEach(S=>{const C=T.deserializeRangeWithSheet(S.token),R=p.getCurrentUnitForType(l.UniverInstanceType.UNIVER_SHEET),b=R==null?void 0:R.getActiveSheet();if(!C.sheetName&&s!==(b==null?void 0:b.getSheetId())||C.sheetName&&(b==null?void 0:b.getName())!==C.sheetName)return;const y=new l.ColorKit(S.themeColor).toRgb(),I=f.addShape({range:C.range,style:{stroke:S.themeColor,fill:`rgba(${y.r}, ${y.g}, ${y.b}, 0.1)`,strokeDash:12},primary:null});I&&g.add(()=>f.removeShape(I))}),()=>{g.dispose()}},[e,t,o,f,c]),{sequenceNodes:c}}function Yr(e){const t=a.useDependency(A.SheetsSelectionsService),{supportAcrossSheet:n=!1,unitId:s,subUnitId:r,onChange:o}=e,c=a.useDependency(l.IUniverInstanceService).getUnit(s,l.UniverInstanceType.UNIVER_SHEET),d=a.useEvent(o),f=a.useEvent((m,p)=>{const h=c==null?void 0:c.getActiveSheet();if(!h||!n&&h.getSheetId()!==r||!(m!=null&&m.length))return;const g=m.map(u=>({range:u.range,unitId:s,sheetName:h.getSheetId()===r?"":h.getName()}));d(g,p)});v.useEffect(()=>{const m=new l.DisposableCollection;return m.add(t.selectionMoveStart$.subscribe(p=>{f(p,!0)})),m.add(t.selectionMoving$.subscribe(p=>{f(p,!1)})),m.add(t.selectionMoveEnd$.subscribe(p=>{f(p,!1)})),()=>{m.dispose()}},[f,t.selectionMoveEnd$,t.selectionMoveStart$,t.selectionMoving$])}const Et=e=>!e.some(n=>{if(typeof n=="string"){if(n!==T.matchToken.COMMA)return!0}else if(n.nodeType!==T.sequenceNodeType.REFERENCE)return!0;return!1}),zr=e=>{if(e.endColumn<e.startColumn){const t=e.endColumn;e.endColumn=e.startColumn,e.startColumn=t}if(e.endRow<e.startRow){const t=e.endRow;e.endRow=e.startRow,e.startRow=t}return e};function Gr(e){const{visible:t,initialValue:n,unitId:s,subUnitId:r,maxRangeCount:o=1/0,supportAcrossSheet:i,onConfirm:c,onClose:d,onShowBySelection:f}=e,m=a.useDependency(l.LocaleService),p=a.useDependency(T.LexerTreeBuilder),[h,g]=v.useState([]),[u,_]=v.useState(0),S=v.useRef(null);v.useEffect(()=>{if(t&&n.length){const y=n.map(I=>I.sheetName?T.serializeRangeWithSheet(I.sheetName,I.range):T.serializeRange(I.range));g(y),_(y.length-1)}else g([""]),_(0)},[t]);const C=(y,I)=>{const M=[...h];M[y]=I,g(M)},R=()=>{g([...h,""]),_(h.length)},b=y=>{h.splice(y,1),g([...h])};return Yr({unitId:s,subUnitId:r,supportAcrossSheet:i,onChange:(y,I)=>{if(!t&&f!=null&&f(y))return;const M=new Set(h),F=y.map(k=>k.sheetName?T.serializeRangeWithSheet(k.sheetName,k.range):T.serializeRange(k.range)),L=F.filter(k=>!M.has(k));if(!L.length)return;const U=[...h];if(F.length>1){I||U.splice(u,1),U.push(...L);const k=U.slice(0,o);g(k),_(k.length-1),requestAnimationFrame(()=>{var $;($=S.current)==null||$.scrollTo({top:S.current.scrollHeight})})}else{U.splice(u,1,...L);const k=U.slice(0,o);g(k),_(u+L.length-1)}}}),E.jsx(W.Dialog,{width:"328px",open:t,title:m.t("rangeSelector.title"),draggable:!0,mask:!1,maskClosable:!1,footer:E.jsxs("footer",{className:"univer-flex univer-gap-2",children:[E.jsx(W.Button,{onClick:d,children:m.t("rangeSelector.cancel")}),E.jsx(W.Button,{variant:"primary",onClick:()=>{c(h.filter(y=>{const I=p.sequenceNodesBuilder(y);return I&&I.length===1&&typeof I[0]!="string"&&I[0].nodeType===T.sequenceNodeType.REFERENCE}).map(y=>T.deserializeRangeWithSheet(y)).map(y=>({...y,range:zr(y.range)})))},children:m.t("rangeSelector.confirm")})]}),onClose:d,children:E.jsxs("div",{ref:S,className:W.clsx("-univer-mx-6 univer-max-h-60 univer-overflow-y-auto univer-px-6",W.scrollbarClassName),children:[h.map((y,I)=>E.jsxs("div",{className:"univer-mb-2 univer-flex univer-items-center univer-gap-4",children:[E.jsx(W.Input,{className:W.clsx("univer-w-full",{"univer-border-primary-600":u===I}),placeholder:m.t("rangeSelector.placeHolder"),onFocus:()=>_(I),value:y,onChange:M=>C(I,M)}),h.length>1&&E.jsx(Ut,{className:"univer-cursor-pointer",onClick:()=>b(I)})]},I)),h.length<o&&E.jsx("div",{children:E.jsxs(W.Button,{variant:"link",onClick:R,children:[E.jsx($t,{}),E.jsx("span",{children:m.t("rangeSelector.addAnotherRange")})]})})]})})}function Zr(e){return e.split(T.matchToken.COMMA).filter(t=>!!t).map(t=>T.deserializeRangeWithSheet(t))}function Xr(e){return e.map(t=>t.sheetName?T.serializeRangeWithSheet(t.sheetName,t.range):T.serializeRange(t.range)).join(T.matchToken.COMMA)}function ut(e){const[t,n]=v.useState(null),{onVerify:s,selectorRef:r,unitId:o,subUnitId:i,maxRangeCount:c,supportAcrossSheet:d,autoFocus:f,onChange:m,onRangeSelectorDialogVisibleChange:p,onClickOutside:h,onFocusChange:g,forceShowDialogWhenSelectionChanged:u,hideEditor:_,resetRange:S}=e,[C,R]=v.useState(f!=null?f:!1),[b,y]=v.useState(!1),[I,M]=v.useState([]),F=a.useDependency(l.LocaleService),L=a.useDependency(Q.IEditorService),{sequenceNodes:U}=qr(t,C,o,i),k=Te(U),$=a.useDependency(l.ICommandService),D=a.useEvent(()=>{t==null||t.setSelectionRanges([]),t==null||t.blur(),L.blur()}),N=a.useEvent(()=>{var x;D(),M(Zr((x=t==null?void 0:t.getDocumentDataModel().getPlainText())!=null?x:"")),y(!0)});return v.useEffect(()=>{r&&(r.current={get editor(){return t},focus(){L.focus(t.getEditorId())},blur:D,verify:()=>Et(k.current),showDialog:x=>{D(),M(x),y(!0)},hideDialog:()=>{M([]),y(!1)},getValue:()=>{var x;return(x=t==null?void 0:t.getDocumentDataModel().getPlainText())!=null?x:""}})},[D,t,L,r,k]),v.useEffect(()=>{var x;s==null||s(Et(U),(x=t==null?void 0:t.getDocumentDataModel().getPlainText())!=null?x:"")},[U]),v.useEffect(()=>{p==null||p(b)},[b]),v.useEffect(()=>{if(b&&S)return()=>{const x={unitId:o,subUnitId:i,selections:S};$.executeCommand(A.SetSelectionsOperation.id,x)}},[b]),E.jsxs(E.Fragment,{children:[_?null:E.jsx(Q.RichTextEditor,{isSingle:!0,...e,onFocusChange:(x,O)=>{R(x),g==null||g(x,O)},editorRef:n,onClickOutside:()=>{R(!1),D(),h==null||h()},icon:E.jsx(W.Tooltip,{title:F.t("rangeSelector.buttonTooltip"),placement:"bottom",children:E.jsx(Wt,{className:"univer-cursor-pointer dark:!univer-text-gray-300",onClick:N})})}),E.jsx(Gr,{initialValue:I,unitId:o,subUnitId:i,visible:b,maxRangeCount:c,onConfirm:x=>{const O=Xr(x),P=l.RichTextBuilder.newEmptyData();P.body.dataStream=O,t==null||t.replaceText(O,!1),m==null||m(P,O),y(!1),M([]),requestAnimationFrame(()=>{D()})},onClose:()=>{y(!1),M([])},supportAcrossSheet:d,onShowBySelection:x=>C||u?(M(x),y(!0),!1):!0})]})}const Qr=()=>{var s,r;const e=a.useDependency(at),t=a.useObservable(e.currentSelector$),n=v.useRef(null);return v.useEffect(()=>{var o,i;if(t)return(i=n.current)==null||i.showDialog((o=t.initialValue)!=null?o:[]),()=>{var c;(c=n.current)==null||c.hideDialog()}},[t]),E.jsx(ut,{unitId:(s=t==null?void 0:t.unitId)!=null?s:"",subUnitId:(r=t==null?void 0:t.subUnitId)!=null?r:"",hideEditor:!0,selectorRef:n,onChange:(o,i)=>{var c;t==null||t.callback((c=i==null?void 0:i.split(",").map(d=>T.deserializeRangeWithSheet(d)))!=null?c:[])}})};var Jr=Object.defineProperty,es=Object.getOwnPropertyDescriptor,ts=(e,t,n)=>t in e?Jr(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,ns=(e,t,n,s)=>{for(var r=s>1?void 0:s?es(t,n):t,o=e.length-1,i;o>=0;o--)(i=e[o])&&(r=i(r)||r);return r},Ke=(e,t)=>(n,s)=>t(n,s,e),Yt=(e,t,n)=>ts(e,typeof t!="symbol"?t+"":t,n);exports.UniverSheetsFormulaUIPlugin=class extends l.Plugin{constructor(t=Ct,n,s,r,o){super(),this._config=t,this._injector=n,this._renderManagerService=s,this._configService=r,this._uiPartsService=o;const{menu:i,...c}=l.merge(Ct,this._config);i&&this._configService.setConfig("menu",i,{merge:!0}),this._configService.setConfig(hn,c,{merge:!0})}onStarting(){l.registerDependencies(this._injector,[[it,{useClass:rt}],[at],[Ze],[qe],[Ye],[ze],[Ge],[exports.FormulaReorderController]]),this._initUIPart()}onReady(){[[exports.RefSelectionsRenderService]].forEach(t=>{this.disposeWithMe(this._renderManagerService.registerRenderModule(l.UniverInstanceType.UNIVER_SHEET,t))})}onRendered(){[[st]].forEach(t=>{this.disposeWithMe(this._renderManagerService.registerRenderModule(l.UniverInstanceType.UNIVER_SHEET,t))}),l.touchDependencies(this._injector,[[Ze],[Ye],[Ge]])}onSteady(){this._injector.get(qe),this._injector.get(exports.FormulaReorderController)}_initUIPart(){const t=this._injector.get(a.ComponentManager);this.disposeWithMe(t.register(w.RANGE_SELECTOR_COMPONENT_KEY,ut)),this.disposeWithMe(t.register(w.EMBEDDING_FORMULA_EDITOR_COMPONENT_KEY,qt)),this.disposeWithMe(this._uiPartsService.registerComponent(a.BuiltInUIPart.GLOBAL,()=>a.connectInjector(Qr,this._injector)))}};Yt(exports.UniverSheetsFormulaUIPlugin,"pluginName",Mt);Yt(exports.UniverSheetsFormulaUIPlugin,"type",l.UniverInstanceType.UNIVER_SHEET);exports.UniverSheetsFormulaUIPlugin=ns([l.DependentOn(T.UniverFormulaEnginePlugin,Ce.UniverSheetsFormulaPlugin),Ke(1,l.Inject(l.Injector)),Ke(2,B.IRenderManagerService),Ke(3,l.IConfigService),Ke(4,a.IUIPartsService)],exports.UniverSheetsFormulaUIPlugin);exports.FORMULA_PROMPT_ACTIVATED=Tt;exports.FormulaEditor=qt;exports.GlobalRangeSelectorService=at;exports.HelpFunctionOperation=xt;exports.InsertFunctionOperation=ce;exports.MoreFunctionsOperation=Qe;exports.RangeSelector=ut;exports.ReferenceAbsoluteOperation=ct;exports.SearchFunctionOperation=Nt;exports.SelectEditorFormulaOperation=Ee;exports.SheetOnlyPasteFormulaCommand=Xe;
|
|
8
|
+
`,{"univer-ring-primary-500":P,"univer-ring-red-500":re}),ref:k,children:b.jsx("div",{ref:V,className:"univer-relative univer-h-full univer-w-full",onMouseUp:ht})}),n!==void 0?b.jsx("div",{className:"univer-my-1 univer-text-xs univer-text-red-500",children:n}):null,M&&Me!==""?b.jsx(yr,{editor:M,isFocus:P,formulaText:ee,onClose:()=>te()}):null,M?b.jsx(Br,{isFocus:P,sequenceNodes:Ue,onSelect:dt,ref:N,editor:M}):null]})});function qr(e,t,n,s){const r=a.useDependency(T.LexerTreeBuilder),o=Kt(""),c=a.useObservable(e==null?void 0:e.getDocumentDataModel().change$),[i,d]=C.useState([]),h=a.useDependency(w.IMarkSelectionService),m=C.useRef(""),p=a.useDependency(l.IUniverInstanceService);return C.useEffect(()=>{if(!e)return;const f=e.getDocumentDataModel().getPlainText();if(m.current===f)return;m.current=f;const g=r.sequenceNodesBuilder(f);d(g!=null?g:[])},[c,e,r]),C.useEffect(()=>{var u,_;if(!e)return;if(!t){const v=e.getDocumentData();e.setDocumentData({...v,body:{...v.body,dataStream:(_=(u=v.body)==null?void 0:u.dataStream)!=null?_:"",textRuns:[]}});return}const f=o(e,i,!1),g=new l.DisposableCollection;return f.forEach(v=>{const S=T.deserializeRangeWithSheet(v.token),I=p.getCurrentUnitForType(l.UniverInstanceType.UNIVER_SHEET),E=I==null?void 0:I.getActiveSheet();if(!S.sheetName&&s!==(E==null?void 0:E.getSheetId())||S.sheetName&&(E==null?void 0:E.getName())!==S.sheetName)return;const y=new l.ColorKit(v.themeColor).toRgb(),R=h.addShape({range:S.range,style:{stroke:v.themeColor,fill:`rgba(${y.r}, ${y.g}, ${y.b}, 0.1)`,strokeDash:12},primary:null});R&&g.add(()=>h.removeShape(R))}),()=>{g.dispose()}},[e,t,o,h,i]),{sequenceNodes:i}}function Yr(e){const t=a.useDependency(A.SheetsSelectionsService),{supportAcrossSheet:n=!1,unitId:s,subUnitId:r,onChange:o}=e,i=a.useDependency(l.IUniverInstanceService).getUnit(s,l.UniverInstanceType.UNIVER_SHEET),d=a.useEvent(o),h=a.useEvent((m,p)=>{const f=i==null?void 0:i.getActiveSheet();if(!f||!n&&f.getSheetId()!==r||!(m!=null&&m.length))return;const g=m.map(u=>({range:u.range,unitId:s,sheetName:f.getSheetId()===r?"":f.getName()}));d(g,p)});C.useEffect(()=>{const m=new l.DisposableCollection;return m.add(t.selectionMoveStart$.subscribe(p=>{h(p,!0)})),m.add(t.selectionMoving$.subscribe(p=>{h(p,!1)})),m.add(t.selectionMoveEnd$.subscribe(p=>{h(p,!1)})),()=>{m.dispose()}},[h,t.selectionMoveEnd$,t.selectionMoveStart$,t.selectionMoving$])}const Et=e=>!e.some(n=>{if(typeof n=="string"){if(n!==T.matchToken.COMMA)return!0}else if(n.nodeType!==T.sequenceNodeType.REFERENCE)return!0;return!1}),zr=e=>{if(e.endColumn<e.startColumn){const t=e.endColumn;e.endColumn=e.startColumn,e.startColumn=t}if(e.endRow<e.startRow){const t=e.endRow;e.endRow=e.startRow,e.startRow=t}return e};function Gr(e){const{visible:t,initialValue:n,unitId:s,subUnitId:r,maxRangeCount:o=1/0,supportAcrossSheet:c,onConfirm:i,onClose:d,onShowBySelection:h}=e,m=a.useDependency(l.LocaleService),p=a.useDependency(T.LexerTreeBuilder),[f,g]=C.useState([]),[u,_]=C.useState(0),v=C.useRef(null);C.useEffect(()=>{if(t&&n.length){const y=n.map(R=>R.sheetName?T.serializeRangeWithSheet(R.sheetName,R.range):T.serializeRange(R.range));g(y),_(y.length-1)}else g([""]),_(0)},[t]);const S=(y,R)=>{const O=[...f];O[y]=R,g(O)},I=()=>{g([...f,""]),_(f.length)},E=y=>{f.splice(y,1),g([...f])};return Yr({unitId:s,subUnitId:r,supportAcrossSheet:c,onChange:(y,R)=>{if(!t&&h!=null&&h(y))return;const O=new Set(f),F=y.map(k=>k.sheetName?T.serializeRangeWithSheet(k.sheetName,k.range):T.serializeRange(k.range)),L=F.filter(k=>!O.has(k));if(!L.length)return;const U=[...f];if(F.length>1){R||U.splice(u,1),U.push(...L);const k=U.slice(0,o);g(k),_(k.length-1),requestAnimationFrame(()=>{var $;($=v.current)==null||$.scrollTo({top:v.current.scrollHeight})})}else{U.splice(u,1,...L);const k=U.slice(0,o);g(k),_(u+L.length-1)}}}),b.jsx(W.Dialog,{width:"328px",open:t,title:m.t("rangeSelector.title"),draggable:!0,mask:!1,maskClosable:!1,footer:b.jsxs("footer",{className:"univer-flex univer-gap-2",children:[b.jsx(W.Button,{onClick:d,children:m.t("rangeSelector.cancel")}),b.jsx(W.Button,{variant:"primary",onClick:()=>{i(f.filter(y=>{const R=p.sequenceNodesBuilder(y);return R&&R.length===1&&typeof R[0]!="string"&&R[0].nodeType===T.sequenceNodeType.REFERENCE}).map(y=>T.deserializeRangeWithSheet(y)).map(y=>({...y,range:zr(y.range)})))},children:m.t("rangeSelector.confirm")})]}),onClose:d,children:b.jsxs("div",{ref:v,className:W.clsx("-univer-mx-6 univer-max-h-60 univer-overflow-y-auto univer-px-6",W.scrollbarClassName),children:[f.map((y,R)=>b.jsxs("div",{className:"univer-mb-2 univer-flex univer-items-center univer-gap-4",children:[b.jsx(W.Input,{className:W.clsx("univer-w-full",{"univer-border-primary-600":u===R}),placeholder:m.t("rangeSelector.placeHolder"),onFocus:()=>_(R),value:y,onChange:O=>S(R,O)}),f.length>1&&b.jsx(Ut,{className:"univer-cursor-pointer",onClick:()=>E(R)})]},R)),f.length<o&&b.jsx("div",{children:b.jsxs(W.Button,{variant:"link",onClick:I,children:[b.jsx($t,{}),b.jsx("span",{children:m.t("rangeSelector.addAnotherRange")})]})})]})})}function Zr(e){return e.split(T.matchToken.COMMA).filter(t=>!!t).map(t=>T.deserializeRangeWithSheet(t))}function Xr(e){return e.map(t=>t.sheetName?T.serializeRangeWithSheet(t.sheetName,t.range):T.serializeRange(t.range)).join(T.matchToken.COMMA)}function ut(e){const[t,n]=C.useState(null),{onVerify:s,selectorRef:r,unitId:o,subUnitId:c,maxRangeCount:i,supportAcrossSheet:d,autoFocus:h,onChange:m,onRangeSelectorDialogVisibleChange:p,onClickOutside:f,onFocusChange:g,forceShowDialogWhenSelectionChanged:u,hideEditor:_,resetRange:v}=e,[S,I]=C.useState(h!=null?h:!1),[E,y]=C.useState(!1),[R,O]=C.useState([]),F=a.useDependency(l.LocaleService),L=a.useDependency(Q.IEditorService),{sequenceNodes:U}=qr(t,S,o,c),k=Te(U),$=a.useDependency(l.ICommandService),D=a.useEvent(()=>{t==null||t.setSelectionRanges([]),t==null||t.blur(),L.blur()}),N=a.useEvent(()=>{var x;D(),O(Zr((x=t==null?void 0:t.getDocumentDataModel().getPlainText())!=null?x:"")),y(!0)});return C.useEffect(()=>{r&&(r.current={get editor(){return t},focus(){L.focus(t.getEditorId())},blur:D,verify:()=>Et(k.current),showDialog:x=>{D(),O(x),y(!0)},hideDialog:()=>{O([]),y(!1)},getValue:()=>{var x;return(x=t==null?void 0:t.getDocumentDataModel().getPlainText())!=null?x:""}})},[D,t,L,r,k]),C.useEffect(()=>{var x;s==null||s(Et(U),(x=t==null?void 0:t.getDocumentDataModel().getPlainText())!=null?x:"")},[U]),C.useEffect(()=>{p==null||p(E)},[E]),C.useEffect(()=>{if(E&&v)return()=>{const x={unitId:o,subUnitId:c,selections:v};$.executeCommand(A.SetSelectionsOperation.id,x)}},[E]),b.jsxs(b.Fragment,{children:[_?null:b.jsx(Q.RichTextEditor,{isSingle:!0,...e,onFocusChange:(x,M)=>{I(x),g==null||g(x,M)},editorRef:n,onClickOutside:()=>{I(!1),D(),f==null||f()},icon:b.jsx(W.Tooltip,{title:F.t("rangeSelector.buttonTooltip"),placement:"bottom",children:b.jsx(Wt,{className:"univer-cursor-pointer dark:!univer-text-gray-300",onClick:N})})}),b.jsx(Gr,{initialValue:R,unitId:o,subUnitId:c,visible:E,maxRangeCount:i,onConfirm:x=>{const M=Xr(x),P=l.RichTextBuilder.newEmptyData();P.body.dataStream=M,t==null||t.replaceText(M,!1),m==null||m(P,M),y(!1),O([]),requestAnimationFrame(()=>{D()})},onClose:()=>{y(!1),O([])},supportAcrossSheet:d,onShowBySelection:x=>S||u?(O(x),y(!0),!1):!0})]})}const Qr=()=>{var s,r;const e=a.useDependency(at),t=a.useObservable(e.currentSelector$),n=C.useRef(null);return C.useEffect(()=>{var o,c;if(t)return(c=n.current)==null||c.showDialog((o=t.initialValue)!=null?o:[]),()=>{var i;(i=n.current)==null||i.hideDialog()}},[t]),b.jsx(ut,{unitId:(s=t==null?void 0:t.unitId)!=null?s:"",subUnitId:(r=t==null?void 0:t.subUnitId)!=null?r:"",hideEditor:!0,selectorRef:n,onChange:(o,c)=>{var i;t==null||t.callback((i=c==null?void 0:c.split(",").map(d=>T.deserializeRangeWithSheet(d)))!=null?i:[])}})};var Jr=Object.defineProperty,es=Object.getOwnPropertyDescriptor,ts=(e,t,n)=>t in e?Jr(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,ns=(e,t,n,s)=>{for(var r=s>1?void 0:s?es(t,n):t,o=e.length-1,c;o>=0;o--)(c=e[o])&&(r=c(r)||r);return r},Ke=(e,t)=>(n,s)=>t(n,s,e),Yt=(e,t,n)=>ts(e,typeof t!="symbol"?t+"":t,n);exports.UniverSheetsFormulaUIPlugin=class extends l.Plugin{constructor(t=Ct,n,s,r,o){super(),this._config=t,this._injector=n,this._renderManagerService=s,this._configService=r,this._uiPartsService=o;const{menu:c,...i}=l.merge(Ct,this._config);c&&this._configService.setConfig("menu",c,{merge:!0}),this._configService.setConfig(hn,i,{merge:!0})}onStarting(){l.registerDependencies(this._injector,[[Qe,{useClass:st}],[at],[Ze],[qe],[Ye],[ze],[Ge],[exports.FormulaReorderController]]),this._initUIPart()}onReady(){[[exports.RefSelectionsRenderService]].forEach(t=>{this.disposeWithMe(this._renderManagerService.registerRenderModule(l.UniverInstanceType.UNIVER_SHEET,t))})}onRendered(){[[ot]].forEach(t=>{this.disposeWithMe(this._renderManagerService.registerRenderModule(l.UniverInstanceType.UNIVER_SHEET,t))}),l.touchDependencies(this._injector,[[Ze],[Ye],[Ge]])}onSteady(){this._injector.get(qe),this._injector.get(exports.FormulaReorderController)}_initUIPart(){const t=this._injector.get(a.ComponentManager);this.disposeWithMe(t.register(w.RANGE_SELECTOR_COMPONENT_KEY,ut)),this.disposeWithMe(t.register(w.EMBEDDING_FORMULA_EDITOR_COMPONENT_KEY,qt)),this.disposeWithMe(this._uiPartsService.registerComponent(a.BuiltInUIPart.GLOBAL,()=>a.connectInjector(Qr,this._injector)))}};Yt(exports.UniverSheetsFormulaUIPlugin,"pluginName",Mt);Yt(exports.UniverSheetsFormulaUIPlugin,"type",l.UniverInstanceType.UNIVER_SHEET);exports.UniverSheetsFormulaUIPlugin=ns([l.DependentOn(T.UniverFormulaEnginePlugin,Ce.UniverSheetsFormulaPlugin),Ke(1,l.Inject(l.Injector)),Ke(2,H.IRenderManagerService),Ke(3,l.IConfigService),Ke(4,a.IUIPartsService)],exports.UniverSheetsFormulaUIPlugin);exports.FORMULA_PROMPT_ACTIVATED=Tt;exports.FormulaEditor=qt;exports.GlobalRangeSelectorService=at;exports.HelpFunctionOperation=xt;exports.InsertFunctionOperation=ce;exports.MoreFunctionsOperation=Je;exports.RangeSelector=ut;exports.ReferenceAbsoluteOperation=ct;exports.SearchFunctionOperation=Nt;exports.SelectEditorFormulaOperation=Ee;exports.SheetOnlyPasteFormulaCommand=Xe;
|