@univerjs/sheets-formula-ui 0.4.1 → 0.4.2
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 +2 -2
- package/lib/es/index.js +17 -10
- package/lib/locale/en-US.json +240 -237
- package/lib/locale/fa-IR.json +240 -237
- package/lib/locale/ru-RU.json +135 -104
- package/lib/locale/vi-VN.json +327 -160
- package/lib/locale/zh-CN.json +240 -237
- package/lib/locale/zh-TW.json +240 -237
- package/lib/types/locale/en-US.d.ts +122 -119
- package/lib/types/locale/fa-IR.d.ts +122 -119
- package/lib/types/locale/function-list/database/en-US.d.ts +72 -24
- package/lib/types/locale/function-list/database/ja-JP.d.ts +72 -24
- package/lib/types/locale/function-list/database/ru-RU.d.ts +72 -24
- package/lib/types/locale/function-list/database/vi-VN.d.ts +72 -24
- package/lib/types/locale/function-list/database/zh-CN.d.ts +72 -24
- package/lib/types/locale/function-list/database/zh-TW.d.ts +72 -24
- package/lib/types/locale/function-list/information/en-US.d.ts +2 -15
- package/lib/types/locale/function-list/information/ja-JP.d.ts +2 -15
- package/lib/types/locale/function-list/information/vi-VN.d.ts +23 -0
- package/lib/types/locale/function-list/information/zh-CN.d.ts +2 -15
- package/lib/types/locale/function-list/information/zh-TW.d.ts +2 -15
- package/lib/types/locale/function-list/math/en-US.d.ts +3 -7
- package/lib/types/locale/function-list/math/ja-JP.d.ts +3 -7
- package/lib/types/locale/function-list/math/vi-VN.d.ts +32 -0
- package/lib/types/locale/function-list/math/zh-CN.d.ts +3 -7
- package/lib/types/locale/function-list/math/zh-TW.d.ts +3 -7
- package/lib/types/locale/function-list/text/en-US.d.ts +45 -73
- package/lib/types/locale/function-list/text/ja-JP.d.ts +45 -73
- package/lib/types/locale/function-list/text/vi-VN.d.ts +87 -39
- package/lib/types/locale/function-list/text/zh-CN.d.ts +45 -73
- package/lib/types/locale/function-list/text/zh-TW.d.ts +45 -73
- package/lib/types/locale/ru-RU.d.ts +77 -46
- package/lib/types/locale/vi-VN.d.ts +214 -63
- package/lib/types/locale/zh-CN.d.ts +122 -119
- package/lib/types/locale/zh-TW.d.ts +122 -119
- package/lib/types/views/formula-progress/FormulaProgress.d.ts +2 -0
- package/lib/umd/index.js +2 -2
- package/package.json +14 -14
package/lib/cjs/index.js
CHANGED
|
@@ -8,7 +8,7 @@
|
|
|
8
8
|
* LICENSE file in the root directory of this source tree.
|
|
9
9
|
*/var f=require$$0,k=Symbol.for("react.element"),l=Symbol.for("react.fragment"),m=Object.prototype.hasOwnProperty,n=f.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,p={key:!0,ref:!0,__self:!0,__source:!0};function q(c,a,g){var b,d={},e=null,h=null;g!==void 0&&(e=""+g),a.key!==void 0&&(e=""+a.key),a.ref!==void 0&&(h=a.ref);for(b in a)m.call(a,b)&&!p.hasOwnProperty(b)&&(d[b]=a[b]);if(c&&c.defaultProps)for(b in a=c.defaultProps,a)d[b]===void 0&&(d[b]=a[b]);return{$$typeof:k,type:c,key:e,ref:h,props:d,_owner:n.current}}__name(q,"q");reactJsxRuntime_production_min.Fragment=l;reactJsxRuntime_production_min.jsx=q;reactJsxRuntime_production_min.jsxs=q;jsxRuntime.exports=reactJsxRuntime_production_min;var jsxRuntimeExports=jsxRuntime.exports,__assign=function(){return __assign=Object.assign||function(t){for(var s,i=1,n2=arguments.length;i<n2;i++){s=arguments[i];for(var p2 in s)Object.prototype.hasOwnProperty.call(s,p2)&&(t[p2]=s[p2])}return t},__assign.apply(this,arguments)},__rest=function(s,e){var t={};for(var p2 in s)Object.prototype.hasOwnProperty.call(s,p2)&&e.indexOf(p2)<0&&(t[p2]=s[p2]);if(s!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,p2=Object.getOwnPropertySymbols(s);i<p2.length;i++)e.indexOf(p2[i])<0&&Object.prototype.propertyIsEnumerable.call(s,p2[i])&&(t[p2[i]]=s[p2[i]]);return t},IconBase=require$$0.forwardRef(function(props,ref){var icon=props.icon,id=props.id,className=props.className,extend=props.extend,restProps=__rest(props,["icon","id","className","extend"]),cls="univerjs-icon univerjs-icon-".concat(id," ").concat(className||"").trim(),idSuffix=require$$0.useRef("_".concat(generateShortUuid()));return render(icon,"".concat(id),{defIds:icon.defIds,idSuffix:idSuffix.current},__assign({ref,className:cls},restProps),extend)});function render(node,id,runtimeProps,rootProps,extend){return require$$0.createElement(node.tag,__assign(__assign({key:id},replaceRuntimeIdsAndExtInAttrs(node,runtimeProps,extend)),rootProps),(replaceRuntimeIdsInDefs(node,runtimeProps).children||[]).map(function(child,index){return render(child,"".concat(id,"-").concat(node.tag,"-").concat(index),runtimeProps,void 0,extend)}))}__name(render,"render");function replaceRuntimeIdsAndExtInAttrs(node,runtimeProps,extend){var attrs=__assign({},node.attrs);extend!=null&&extend.colorChannel1&&attrs.fill==="colorChannel1"&&(attrs.fill=extend.colorChannel1);var defIds=runtimeProps.defIds;return!defIds||defIds.length===0||(node.tag==="use"&&attrs["xlink:href"]&&(attrs["xlink:href"]=attrs["xlink:href"]+runtimeProps.idSuffix),Object.entries(attrs).forEach(function(_a11){var key=_a11[0],value=_a11[1];typeof value=="string"&&(attrs[key]=value.replace(/url\(#(.*)\)/,"url(#$1".concat(runtimeProps.idSuffix,")")))})),attrs}__name(replaceRuntimeIdsAndExtInAttrs,"replaceRuntimeIdsAndExtInAttrs");function replaceRuntimeIdsInDefs(node,runtimeProps){var _a11,defIds=runtimeProps.defIds;return!defIds||defIds.length===0?node:node.tag==="defs"&&(!((_a11=node.children)===null||_a11===void 0)&&_a11.length)?__assign(__assign({},node),{children:node.children.map(function(child){return typeof child.attrs.id=="string"&&defIds&&defIds.indexOf(child.attrs.id)>-1?__assign(__assign({},child),{attrs:__assign(__assign({},child.attrs),{id:child.attrs.id+runtimeProps.idSuffix})}):child})}):node}__name(replaceRuntimeIdsInDefs,"replaceRuntimeIdsInDefs");function generateShortUuid(){return Math.random().toString(36).substring(2,8)}__name(generateShortUuid,"generateShortUuid");IconBase.displayName="UniverIcon";var element$6={tag:"svg",attrs:{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"}}]},CheckMarkSingle=require$$0.forwardRef(function(props,ref){return require$$0.createElement(IconBase,Object.assign({},props,{id:"check-mark-single",ref,icon:element$6}))});CheckMarkSingle.displayName="CheckMarkSingle";var element$5={tag:"svg",attrs:{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"}}]},CloseSingle=require$$0.forwardRef(function(props,ref){return require$$0.createElement(IconBase,Object.assign({},props,{id:"close-single",ref,icon:element$5}))});CloseSingle.displayName="CloseSingle";var element$4={tag:"svg",attrs:{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.866699 5.9313.866699H10.069C10.4004.866699 10.669 1.13533 10.669 1.4667 10.669 1.79807 10.4004 2.0667 10.069 2.0667H5.9313C5.59993 2.0667 5.3313 1.79807 5.3313 1.4667zM1.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.64443 14.8999 3.9758 14.6312 4.24443 14.2999 4.24443H1.69985C1.36848 4.24443 1.09985 3.9758 1.09985 3.64443zM6.12398 8.30171C6.35829 8.0674 6.73819 8.0674 6.97251 8.30171L8.00007 9.32928 9.02764 8.30171C9.26195 8.0674 9.64185 8.0674 9.87617 8.30171 10.1105 8.53603 10.1105 8.91593 9.87617 9.15024L8.8486 10.1778 9.87617 11.2054C10.1105 11.4397 10.1105 11.8196 9.87617 12.0539 9.64185 12.2882 9.26195 12.2882 9.02764 12.0539L8.00007 11.0263 6.97251 12.0539C6.73819 12.2882 6.35829 12.2882 6.12398 12.0539 5.88966 11.8196 5.88966 11.4397 6.12398 11.2054L7.15154 10.1778 6.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"}}]},DeleteSingle=require$$0.forwardRef(function(props,ref){return require$$0.createElement(IconBase,Object.assign({},props,{id:"delete-single",ref,icon:element$4}))});DeleteSingle.displayName="DeleteSingle";var element$3={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M8.75 5.32495C8.75 5.73916 8.41421 6.07495 8 6.07495 7.58579 6.07495 7.25 5.73916 7.25 5.32495 7.25 4.91074 7.58579 4.57495 8 4.57495 8.41421 4.57495 8.75 4.91074 8.75 5.32495zM8.5999 7.52505C8.5999 7.19368 8.33127 6.92505 7.9999 6.92505 7.66853 6.92505 7.3999 7.19368 7.3999 7.52505V11.425C7.3999 11.7564 7.66853 12.025 7.9999 12.025 8.33127 12.025 8.5999 11.7564 8.5999 11.425V7.52505z"}},{tag:"path",attrs:{fill:"currentColor",d:"M0.899902 8.00002C0.899902 4.0788 4.07868 0.900024 7.9999 0.900024C11.9211 0.900024 15.0999 4.0788 15.0999 8.00002C15.0999 11.9212 11.9211 15.1 7.9999 15.1C4.07868 15.1 0.899902 11.9212 0.899902 8.00002ZM7.9999 2.10002C4.74142 2.10002 2.0999 4.74154 2.0999 8.00002C2.0999 11.2585 4.74142 13.9 7.9999 13.9C11.2584 13.9 13.8999 11.2585 13.8999 8.00002C13.8999 4.74154 11.2584 2.10002 7.9999 2.10002Z",fillRule:"evenodd",clipRule:"evenodd"}}]},DetailsSingle=require$$0.forwardRef(function(props,ref){return require$$0.createElement(IconBase,Object.assign({},props,{id:"details-single",ref,icon:element$3}))});DetailsSingle.displayName="DetailsSingle";var element$2={tag:"svg",attrs:{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"}}]},IncreaseSingle=require$$0.forwardRef(function(props,ref){return require$$0.createElement(IconBase,Object.assign({},props,{id:"increase-single",ref,icon:element$2}))});IncreaseSingle.displayName="IncreaseSingle";var element$1={tag:"svg",attrs:{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"}}]},MoreSingle=require$$0.forwardRef(function(props,ref){return require$$0.createElement(IconBase,Object.assign({},props,{id:"more-single",ref,icon:element$1}))});MoreSingle.displayName="MoreSingle";var element={tag:"svg",attrs:{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"}}]},SelectRangeSingle=require$$0.forwardRef(function(props,ref){return require$$0.createElement(IconBase,Object.assign({},props,{id:"select-range-single",ref,icon:element}))});SelectRangeSingle.displayName="SelectRangeSingle";function r(e){var t,f2,n2="";if(typeof e=="string"||typeof e=="number")n2+=e;else if(typeof e=="object")if(Array.isArray(e)){var o=e.length;for(t=0;t<o;t++)e[t]&&(f2=r(e[t]))&&(n2&&(n2+=" "),n2+=f2)}else for(f2 in e)e[f2]&&(n2&&(n2+=" "),n2+=f2);return n2}__name(r,"r");function clsx(){for(var e,t,f2=0,n2="",o=arguments.length;f2<o;f2++)(e=arguments[f2])&&(t=r(e))&&(n2&&(n2+=" "),n2+=t);return n2}__name(clsx,"clsx");var __defProp$8=Object.defineProperty,__getOwnPropDesc$8=Object.getOwnPropertyDescriptor,__decorateClass$8=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$8(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$8(target,key,result),result},"__decorateClass$8"),__decorateParam$8=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$8"),_a2;exports.RefSelectionsRenderService=(_a2=class extends sheetsUi.BaseSelectionRenderService{constructor(_context,injector,themeService,shortcutService,sheetSkeletonManagerService,_refSelectionsService){super(injector,themeService,shortcutService,sheetSkeletonManagerService);__publicField(this,"_workbookSelections");__publicField(this,"_eventDisposables");this._context=_context,this._refSelectionsService=_refSelectionsService,this._workbookSelections=this._refSelectionsService.getWorkbookSelections(this._context.unitId),this._initSelectionChangeListener(),this._initSkeletonChangeListener(),this._initUserActionSyncListener(),this._setSelectionStyle(getDefaultRefSelectionStyle(this._themeService)),this._remainLastEnabled=!0}getLocation(){return this._skeleton.getLocation()}setRemainLastEnabled(enabled){this._remainLastEnabled=enabled}setSkipLastEnabled(enabled){this._skipLastEnabled=enabled}clearLastSelection(){const last=this._selectionControls[this._selectionControls.length-1];last&&(last.dispose(),this._selectionControls.pop())}enableSelectionChanging(){return this._disableSelectionChanging(),this._eventDisposables=this._initCanvasEventListeners(),core.toDisposable(()=>this._disableSelectionChanging())}_disableSelectionChanging(){var _a11;(_a11=this._eventDisposables)==null||_a11.dispose(),this._eventDisposables=null}_initCanvasEventListeners(){const sheetObject=this._getSheetObject(),{spreadsheetRowHeader,spreadsheetColumnHeader,spreadsheet,spreadsheetLeftTopPlaceholder}=sheetObject,{scene}=this._context,listenerDisposables=new core.DisposableCollection;return listenerDisposables.add(spreadsheet==null?void 0:spreadsheet.onPointerDown$.subscribeEvent((evt,state)=>{this._onPointerDown(evt,spreadsheet.zIndex+1,core.RANGE_TYPE.NORMAL,this._getActiveViewport(evt)),evt.button!==2&&state.stopPropagation()})),listenerDisposables.add(spreadsheetRowHeader==null?void 0:spreadsheetRowHeader.onPointerDown$.subscribeEvent((evt,state)=>{const skeleton=this._sheetSkeletonManagerService.getCurrent().skeleton,{row}=sheetsUi.getCoordByOffset(evt.offsetX,evt.offsetY,scene,skeleton);sheetsUi.checkInHeaderRanges(this._workbookSelections.getCurrentSelections(),row,core.RANGE_TYPE.ROW)||(this._onPointerDown(evt,(spreadsheet.zIndex||1)+1,core.RANGE_TYPE.ROW,this._getActiveViewport(evt),engineRender.ScrollTimerType.Y),evt.button!==2&&state.stopPropagation())})),listenerDisposables.add(spreadsheetColumnHeader==null?void 0:spreadsheetColumnHeader.onPointerDown$.subscribeEvent((evt,state)=>{const skeleton=this._sheetSkeletonManagerService.getCurrent().skeleton,{column}=sheetsUi.getCoordByOffset(evt.offsetX,evt.offsetY,scene,skeleton);sheetsUi.checkInHeaderRanges(this._workbookSelections.getCurrentSelections(),column,core.RANGE_TYPE.COLUMN)||(this._onPointerDown(evt,(spreadsheet.zIndex||1)+1,core.RANGE_TYPE.COLUMN,this._getActiveViewport(evt),engineRender.ScrollTimerType.X),evt.button!==2&&state.stopPropagation())})),listenerDisposables.add(spreadsheetLeftTopPlaceholder==null?void 0:spreadsheetLeftTopPlaceholder.onPointerDown$.subscribeEvent((evt,state)=>{this._reset();const skeleton=this._sheetSkeletonManagerService.getCurrent().skeleton,selectionWithStyle=sheetsUi.getAllSelection(skeleton),selectionData=this.attachSelectionWithCoord(selectionWithStyle);this._addSelectionControlBySelectionData(selectionData),this._selectionMoveStart$.next(this.getSelectionDataWithStyle());const dispose=scene.onPointerUp$.subscribeEvent(()=>{dispose.unsubscribe(),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle())});evt.button!==2&&state.stopPropagation()})),listenerDisposables}_initUserActionSyncListener(){this.disposeWithMe(this.selectionMoveStart$.subscribe(selectionDataWithStyle=>{this._updateSelections(selectionDataWithStyle,sheets.SelectionMoveType.MOVE_START)})),this.disposeWithMe(this.selectionMoving$.subscribe(selectionDataWithStyle=>{this._updateSelections(selectionDataWithStyle,sheets.SelectionMoveType.MOVING)})),this.disposeWithMe(this.selectionMoveEnd$.subscribe(selectionDataWithStyle=>{this._updateSelections(selectionDataWithStyle,sheets.SelectionMoveType.MOVE_END)}))}_updateSelections(selectionDataWithStyleList,type){const sheetId=this._context.unit.getActiveSheet().getSheetId();selectionDataWithStyleList.length!==0&&this._workbookSelections.setSelections(sheetId,selectionDataWithStyleList.map(selectionDataWithStyle=>sheets.convertSelectionDataToRange(selectionDataWithStyle)),type)}_initSelectionChangeListener(){this.disposeWithMe(rxjs.merge(this._workbookSelections.selectionMoveEnd$,this._workbookSelections.selectionSet$).subscribe(selectionsWithStyles=>{this._reset();for(const selectionWithStyle of selectionsWithStyles){const selectionData=this.attachSelectionWithCoord(selectionWithStyle);this._addSelectionControlBySelectionData(selectionData)}}))}_initSkeletonChangeListener(){this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(param=>{if(!param)return;const{skeleton}=param,{scene}=this._context,viewportMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);this._skeleton&&this._skeleton.worksheet.getSheetId()!==skeleton.worksheet.getSheetId()&&this._reset(),this._changeRuntime(skeleton,scene,viewportMain);const currentSelections=this._workbookSelections.getCurrentSelections();this._refreshSelectionControl(currentSelections||[])}))}_refreshSelectionControl(selectionsData){const selections=selectionsData.map(selectionWithStyle=>sheetsUi.attachSelectionWithCoord(selectionWithStyle,this._skeleton));this.updateControlForCurrentByRangeData(selections)}_getActiveViewport(evt){const sheetObject=this._getSheetObject();return sheetObject==null?void 0:sheetObject.scene.getActiveViewportByCoord(engineRender.Vector2.FromArray([evt.offsetX,evt.offsetY]))}_getSheetObject(){return sheetsUi.getSheetObject(this._context.unit,this._context)}},__name(_a2,"RefSelectionsRenderService"),_a2);exports.RefSelectionsRenderService=__decorateClass$8([__decorateParam$8(1,core.Inject(core.Injector)),__decorateParam$8(2,core.Inject(core.ThemeService)),__decorateParam$8(3,ui.IShortcutService),__decorateParam$8(4,core.Inject(sheetsUi.SheetSkeletonManagerService)),__decorateParam$8(5,sheets.IRefSelectionsService)],exports.RefSelectionsRenderService);function getDefaultRefSelectionStyle(themeService){const style=sheets.getNormalSelectionStyle(themeService);return style.hasAutoFill=!1,style.hasRowHeader=!1,style.hasColumnHeader=!1,style.widgets={tl:!0,tc:!0,tr:!0,ml:!0,mr:!0,bl:!0,bc:!0,br:!0},style}__name(getDefaultRefSelectionStyle,"getDefaultRefSelectionStyle");const useEditorInput=__name((unitId,rangeString,editor)=>{const render2=core.useDependency(engineRender.IRenderManagerService).getRenderById(unitId),refSelectionsRenderService=render2==null?void 0:render2.with(exports.RefSelectionsRenderService);require$$0.useEffect(()=>{if(editor&&refSelectionsRenderService){const d=editor.input$.subscribe(e=>{e.content===engineFormula.matchToken.COMMA?refSelectionsRenderService.setSkipLastEnabled(!0):refSelectionsRenderService.setSkipLastEnabled(!1)});return()=>{d.unsubscribe()}}},[editor,refSelectionsRenderService]),require$$0.useEffect(()=>{refSelectionsRenderService&&(rangeString.endsWith(engineFormula.matchToken.COMMA)||refSelectionsRenderService.setSkipLastEnabled(!1))},[rangeString,refSelectionsRenderService])},"useEditorInput"),useFormulaToken=__name(text=>{const lexerTreeBuilder=core.useDependency(engineFormula.LexerTreeBuilder),[sequenceNodes,sequenceNodesSet]=require$$0.useState([]);return require$$0.useEffect(()=>{var _a11;sequenceNodesSet((_a11=lexerTreeBuilder.sequenceNodesBuilder(text))!=null?_a11:[])},[text]),{sequenceNodes,sequenceNodesSet}},"useFormulaToken");function useSheetHighlight(isNeed,unitId,subUnitId,refSelections){const univerInstanceService=core.useDependency(core.IUniverInstanceService),themeService=core.useDependency(core.ThemeService),refSelectionsService=core.useDependency(sheets.IRefSelectionsService),render2=core.useDependency(engineRender.IRenderManagerService).getRenderById(unitId),refSelectionsRenderService=render2==null?void 0:render2.with(exports.RefSelectionsRenderService),sheetSkeletonManagerService=render2==null?void 0:render2.with(sheetsUi.SheetSkeletonManagerService),[ranges,rangesSet]=require$$0.useState([]);require$$0.useEffect(()=>{const workbook=univerInstanceService.getUnit(unitId),worksheet=workbook==null?void 0:workbook.getActiveSheet(),selectionWithStyle=[];if(!workbook||!worksheet||!isNeed){rangesSet(selectionWithStyle);return}const currentSheetId=worksheet==null?void 0:worksheet.getSheetId(),getSheetIdByName=__name(name=>{var _a11;return(_a11=workbook==null?void 0:workbook.getSheetBySheetName(name))==null?void 0:_a11.getSheetId()},"getSheetIdByName");for(let i=0,len=refSelections.length;i<len;i++){const refSelection=refSelections[i],{themeColor,token,refIndex}=refSelection,unitRangeName=engineFormula.deserializeRangeWithSheet(token),{unitId:refUnitId,sheetName,range:rawRange}=unitRangeName;if(refUnitId&&unitId!==refUnitId)continue;const refSheetId=getSheetIdByName(sheetName);if(refSheetId&&refSheetId!==currentSheetId)continue;const range=sheets.setEndForRange(rawRange,worksheet.getRowCount(),worksheet.getColumnCount());selectionWithStyle.push({range,primary:void 0,style:getFormulaRefSelectionStyle$1(themeService,themeColor,refIndex.toString())})}rangesSet(selectionWithStyle)},[unitId,subUnitId,refSelections,isNeed]),require$$0.useEffect(()=>{const skeleton=sheetSkeletonManagerService==null?void 0:sheetSkeletonManagerService.getCurrentSkeleton();if(skeleton){const allControls=(refSelectionsRenderService==null?void 0:refSelectionsRenderService.getSelectionControls())||[];allControls.length===ranges.length?allControls.forEach((control,index)=>{const selection=ranges[index],primaryCell=skeleton.getCellByIndex(selection.range.startRow,selection.range.startColumn);control.updateRange(sheetsUi.attachRangeWithCoord(skeleton,selection.range),primaryCell),control.updateStyle(selection.style)}):refSelectionsService.setSelections(ranges)}},[ranges,sheetSkeletonManagerService]),require$$0.useEffect(()=>()=>{refSelectionsService.setSelections([])},[])}__name(useSheetHighlight,"useSheetHighlight");function useDocHight(editorId,sequenceNodes){const editorService=core.useDependency(docsUi.IEditorService),descriptionService=core.useDependency(sheetsFormula.IDescriptionService),colorMap=useColor(),[ranges,rangesSet]=require$$0.useState([]);return require$$0.useEffect(()=>{const editor=editorService.getEditor(editorId);if(!editor)return;const data=editor.getDocumentData();if(!data||!data.body)return;const cloneBody={dataStream:"",...data.body};if(sequenceNodes==null||sequenceNodes.length===0)cloneBody.textRuns=[],cloneBody.dataStream=`\r
|
|
10
10
|
`,rangesSet([]);else{const{textRuns,refSelections}=buildTextRuns(descriptionService,colorMap,sequenceNodes);cloneBody.textRuns=textRuns;const text=sequenceNodes.reduce((pre,cur)=>typeof cur=="string"?`${pre}${cur}`:`${pre}${cur.token}`,"");cloneBody.dataStream=`${text}\r
|
|
11
|
-
`,rangesSet(refSelections)}const selection=editor.getSelectionRanges(),cloneData={...data,body:cloneBody};editor.setDocumentData(cloneData,selection)},[editorId,sequenceNodes,colorMap]),ranges}__name(useDocHight,"useDocHight");function useColor(){const style=core.useDependency(core.ThemeService).getCurrentTheme();return require$$0.useMemo(()=>{const formulaRefColors=[style.loopColor1,style.loopColor2,style.loopColor3,style.loopColor4,style.loopColor5,style.loopColor6,style.loopColor7,style.loopColor8,style.loopColor9,style.loopColor10,style.loopColor11,style.loopColor12],numberColor=style.hyacinth700,stringColor=style.verdancy800;return{formulaRefColors,numberColor,stringColor}},[style])}__name(useColor,"useColor");function buildTextRuns(descriptionService,colorMap,sequenceNodes){const{formulaRefColors,numberColor,stringColor}=colorMap,textRuns=[],refSelections=[],themeColorMap=new Map;let refColorIndex=0;for(let i=0,len=sequenceNodes.length;i<len;i++){const node=sequenceNodes[i];if(typeof node=="string"){const theLastItem=textRuns[textRuns.length-1],start=theLastItem?theLastItem.ed:0,end=start+node.length;textRuns.push({st:start,ed:end});continue}if(descriptionService.hasDefinedNameDescription(node.token.trim()))continue;const{startIndex,endIndex,nodeType,token}=node;let themeColor="";if(nodeType===engineFormula.sequenceNodeType.REFERENCE){if(themeColorMap.has(token))themeColor=themeColorMap.get(token);else{const colorIndex=refColorIndex%formulaRefColors.length;themeColor=formulaRefColors[colorIndex],themeColorMap.set(token,themeColor),refColorIndex++}refSelections.push({refIndex:i,themeColor,token})}else nodeType===engineFormula.sequenceNodeType.NUMBER?themeColor=numberColor:(nodeType===engineFormula.sequenceNodeType.STRING||nodeType===engineFormula.sequenceNodeType.ARRAY)&&(themeColor=stringColor);themeColor&&themeColor.length>0&&textRuns.push({st:startIndex,ed:endIndex+1,ts:{cl:{rgb:themeColor}}})}return{textRuns,refSelections}}__name(buildTextRuns,"buildTextRuns");function getFormulaRefSelectionStyle$1(themeService,refColor,id){const style=themeService.getCurrentTheme(),fill=new core.ColorKit(refColor).setAlpha(.05).toRgbString();return{id,strokeWidth:1,stroke:refColor,fill,widgets:{tl:!0,tc:!0,tr:!0,ml:!0,mr:!0,bl:!0,bc:!0,br:!0},widgetSize:6,widgetStrokeWidth:1,widgetStroke:style.colorWhite,hasAutoFill:!1,hasRowHeader:!1,hasColumnHeader:!1}}__name(getFormulaRefSelectionStyle$1,"getFormulaRefSelectionStyle$1");const useRefactorEffect=__name((isNeed,unitId,isOnlyOneRange)=>{const renderManagerService=core.useDependency(engineRender.IRenderManagerService),univerInstanceService=core.useDependency(core.IUniverInstanceService),contextService=core.useDependency(core.IContextService),editorBridgeService=core.useDependency(sheetsUi.IEditorBridgeService),sheetsSelectionsService=core.useDependency(sheets.SheetsSelectionsService),contextMenuService=core.useDependency(ui.IContextMenuService),render2=renderManagerService.getRenderById(unitId),refSelectionsRenderService=render2==null?void 0:render2.with(exports.RefSelectionsRenderService);require$$0.useEffect(()=>{if(isNeed){const d1=refSelectionsRenderService==null?void 0:refSelectionsRenderService.enableSelectionChanging();return contextService.setContextValue(sheets.DISABLE_NORMAL_SELECTIONS,!0),editorBridgeService.enableForceKeepVisible(),()=>{d1==null||d1.dispose(),contextService.setContextValue(sheets.DISABLE_NORMAL_SELECTIONS,!1),editorBridgeService.disableForceKeepVisible()}}},[isNeed]),require$$0.useLayoutEffect(()=>{if(isNeed){const workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),sheet=workbook==null?void 0:workbook.getActiveSheet(),selections=[...sheetsSelectionsService.getCurrentSelections()];return()=>{const workbook2=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),currentSheet=workbook2==null?void 0:workbook2.getActiveSheet();currentSheet&¤tSheet===sheet&&sheetsSelectionsService.setSelections(selections)}}},[isNeed]),require$$0.useEffect(()=>{if(isNeed)return contextMenuService.disable(),()=>{contextMenuService.enable()}},[isNeed]),require$$0.useEffect(()=>{isNeed&&(refSelectionsRenderService==null||refSelectionsRenderService.setSkipLastEnabled(!1))},[isNeed]),require$$0.useEffect(()=>{isOnlyOneRange?refSelectionsRenderService==null||refSelectionsRenderService.setRemainLastEnabled(!1):refSelectionsRenderService==null||refSelectionsRenderService.setRemainLastEnabled(!0)},[isOnlyOneRange])},"useRefactorEffect"),useResize=__name(editor=>{const resize=__name(()=>{if(editor){const{scene,mainComponent}=editor.render,docSkeletonManagerService=editor.render.with(docs.DocSkeletonManagerService),{width,height}=editor.getBoundingClientRect();docSkeletonManagerService.getViewModel().getDataModel().updateDocumentDataPageSize(1/0),scene.transformByState({width,height}),mainComponent==null||mainComponent.resize(width,height)}},"resize"),checkScrollBar=require$$0.useMemo(()=>core.debounce(()=>{var _a11;if(!editor)return;const skeleton=editor.render.with(docs.DocSkeletonManagerService).getSkeleton(),{scene,mainComponent}=editor.render,viewportMain=scene.getViewport(docsUi.VIEWPORT_KEY.VIEW_MAIN),{actualWidth}=skeleton.getActualSize(),{width,height}=editor.getBoundingClientRect();let scrollBar=viewportMain==null?void 0:viewportMain.getScrollBar();const contentWidth=Math.max(actualWidth,width),contentHeight=height;scene.transformByState({width:contentWidth,height:contentHeight}),mainComponent==null||mainComponent.resize(contentWidth,contentHeight),actualWidth>width?scrollBar==null?viewportMain&&new engineRender.ScrollBar(viewportMain,{barSize:8,enableVertical:!1}):viewportMain==null||viewportMain.resetCanvasSizeAndUpdateScroll():(scrollBar=null,viewportMain==null||viewportMain.scrollToBarPos({x:0,y:0}),(_a11=viewportMain==null?void 0:viewportMain.getScrollBar())==null||_a11.dispose())},30),[editor]);return require$$0.useEffect(()=>{if(editor){const time=setTimeout(()=>{resize(),checkScrollBar()},500);return()=>{clearTimeout(time)}}},[editor]),require$$0.useEffect(()=>{if(editor){const d=editor.input$.subscribe(()=>{checkScrollBar()});return()=>{d.unsubscribe()}}},[editor]),{resize,checkScrollBar}},"useResize"),isComma=__name(e=>typeof e=="string"?e===engineFormula.matchToken.COMMA:!1,"isComma"),isReference=__name(e=>{if(typeof e=="object")return e.nodeType===engineFormula.sequenceNodeType.REFERENCE},"isReference"),filterReferenceNode=__name(nodes=>nodes.filter(node=>isComma(node)||isReference(node)),"filterReferenceNode"),rangePreProcess=__name(range=>{if(range.endColumn<range.startColumn){const end=range.endColumn;range.endColumn=range.startColumn,range.startColumn=end}if(range.endRow<range.startRow){const end=range.endRow;range.endRow=range.startRow,range.startRow=end}return range},"rangePreProcess"),sequenceNodeToText=__name(sequenceNode=>sequenceNode.map(item=>typeof item=="string"?item:item.token).join(""),"sequenceNodeToText");function getSheetNameById(univerInstanceService,unitId,sheetId){var _a11,_b;return((_b=(_a11=univerInstanceService.getUnit(unitId))==null?void 0:_a11.getSheetBySheetId(sheetId))==null?void 0:_b.getName())||""}__name(getSheetNameById,"getSheetNameById");const unitRangesToText=__name((ranges,isSupportAcrossSheet=!1)=>isSupportAcrossSheet?ranges.map(item=>item.sheetName!==""?engineFormula.serializeRangeWithSheet(item.sheetName,item.range):engineFormula.serializeRange(item.range)):ranges.map(item=>engineFormula.serializeRange(item.range)),"unitRangesToText"),useSheetSelectionChange=__name((isNeed,unitId,_subUnitId,sequenceNodes,isSupportAcrossSheet,isOnlyOneRange,handleRangeChange)=>{const renderManagerService=core.useDependency(engineRender.IRenderManagerService),univerInstanceService=core.useDependency(core.IUniverInstanceService),isScalingRef=require$$0.useRef(!1),debounceReset=require$$0.useMemo(()=>core.debounce(()=>{isScalingRef.current=!1},300),[]),setIsScaling=__name(()=>{isScalingRef.current=!0,debounceReset()},"setIsScaling"),render2=renderManagerService.getRenderById(unitId),refSelectionsRenderService=render2==null?void 0:render2.with(exports.RefSelectionsRenderService),oldFilterReferenceNodes=require$$0.useRef([]),filterReferenceNodes=require$$0.useMemo(()=>{const newFilterReferenceNodes=filterReferenceNode(sequenceNodes),old=oldFilterReferenceNodes.current;return newFilterReferenceNodes.length===old.length?(old.splice(0),old.push(...newFilterReferenceNodes),old):newFilterReferenceNodes},[sequenceNodes]);oldFilterReferenceNodes.current=filterReferenceNodes,require$$0.useEffect(()=>{if(isNeed&&refSelectionsRenderService){let isFirst=!0;const handleSelectionsChange=__name(selections=>{var _a11;if(isFirst){isFirst=!1;return}const cloneSelectionList=[...selections],workbook=univerInstanceService.getUnit(unitId),currentSheetName=((_a11=workbook==null?void 0:workbook.getActiveSheet())==null?void 0:_a11.getName())||"",newSequenceNodes=filterReferenceNodes.map((node,index)=>{if(typeof node=="string"){if(!filterReferenceNodes[index-1])return null;const nextItem=filterReferenceNodes[index+1];return isComma(node)&&(isComma(nextItem)||index===filterReferenceNodes.length-1)?null:node}else if(node.nodeType===engineFormula.sequenceNodeType.REFERENCE){const unitRange=engineFormula.deserializeRangeWithSheet(node.token);unitRange.unitId=unitRange.unitId===""?unitId:unitRange.unitId,unitRange.sheetName=unitRange.sheetName===""?currentSheetName:unitRange.sheetName;const{unitId:rangeUnitId,sheetName:rangeSubName}=unitRange;if(isOnlyOneRange&&(rangeUnitId!==unitId||currentSheetName!==rangeSubName))return null;if(rangeUnitId===unitId&¤tSheetName===rangeSubName){const currentSelection=cloneSelectionList.shift();if(currentSelection&&getSheetNameById(univerInstanceService,unitId,currentSelection.rangeWithCoord.sheetId||"")===rangeSubName){const cloneNode={...node};return rangePreProcess(currentSelection.rangeWithCoord),isSupportAcrossSheet?cloneNode.token=engineFormula.serializeRangeWithSheet(currentSheetName,currentSelection.rangeWithCoord):cloneNode.token=engineFormula.serializeRange(currentSelection.rangeWithCoord),cloneNode}}return node}return null}).filter(e=>!!e),theLast=unitRangesToText(cloneSelectionList.map(e=>{var _a12,_b,_c;return{range:e.rangeWithCoord,unitId:(_a12=e.rangeWithCoord.unitId)!=null?_a12:"",sheetName:getSheetNameById(univerInstanceService,(_b=e.rangeWithCoord.unitId)!=null?_b:"",(_c=e.rangeWithCoord.sheetId)!=null?_c:"")}}),isSupportAcrossSheet).join(engineFormula.matchToken.COMMA),thePre=sequenceNodeToText(newSequenceNodes),result=`${thePre}${thePre&&theLast?engineFormula.matchToken.COMMA:""}${theLast}`,isScaling=isScalingRef.current;handleRangeChange(result,isScaling?-1:result.length)},"handleSelectionsChange"),d1=refSelectionsRenderService.selectionMoveEnd$.subscribe(selections=>{handleSelectionsChange(selections)}),d2=refSelectionsRenderService.selectionMoving$.pipe(operators.throttleTime(50)).subscribe(selections=>{handleSelectionsChange(selections)});return()=>{d1.unsubscribe(),d2.unsubscribe()}}},[isNeed,filterReferenceNodes,refSelectionsRenderService,isSupportAcrossSheet,isOnlyOneRange]),require$$0.useEffect(()=>{if(isNeed&&refSelectionsRenderService){const disposableCollection=new core.DisposableCollection,handleSequenceNodeReplace=__name((token,index)=>{var _a11;let currentIndex=0,offset=0,isFinish=!1;const workbook=univerInstanceService.getUnit(unitId),currentSheetName=((_a11=workbook==null?void 0:workbook.getActiveSheet())==null?void 0:_a11.getName())||"",newSequenceNodes=filterReferenceNodes.map(node=>{if(typeof node=="string")return isFinish||(offset+=node.length),node;if(node.nodeType===engineFormula.sequenceNodeType.REFERENCE){isFinish||(offset+=node.token.length);const unitRange=engineFormula.deserializeRangeWithSheet(token);if(unitRange.unitId=unitRange.unitId===""?unitId:unitRange.unitId,unitRange.sheetName=unitRange.sheetName===""?currentSheetName:unitRange.sheetName,currentIndex===index){isFinish=!0;const cloneNode={...node,token};return isSupportAcrossSheet?cloneNode.token=engineFormula.serializeRangeWithSheet(unitRange.sheetName,unitRange.range):cloneNode.token=engineFormula.serializeRange(unitRange.range),currentIndex++,cloneNode}return currentIndex++,node}return node}),result=sequenceNodeToText(newSequenceNodes);handleRangeChange(result,offset||-1)},"handleSequenceNodeReplace");let time=0;const dispose=refSelectionsRenderService.selectionMoveEnd$.subscribe(()=>{time=setTimeout(()=>{refSelectionsRenderService.getSelectionControls().forEach((control,index)=>{disposableCollection.add(control.selectionScaling$.subscribe(e=>{const rangeText=engineFormula.serializeRange(e);handleSequenceNodeReplace(rangeText,index),setIsScaling()})),disposableCollection.add(control.selectionMoving$.pipe(rxjs.map(e=>engineFormula.serializeRange(e)),rxjs.distinctUntilChanged()).subscribe(rangeText=>{handleSequenceNodeReplace(rangeText,index),setIsScaling()}))})},30)});return()=>{dispose.unsubscribe(),disposableCollection.dispose(),clearTimeout(time)}}},[isNeed,refSelectionsRenderService,filterReferenceNodes])},"useSheetSelectionChange"),verifyRange=__name(sequenceNodes=>!sequenceNodes.some(item=>{if(typeof item=="string"){if(item!==engineFormula.matchToken.COMMA)return!0}else if(item.nodeType!==engineFormula.sequenceNodeType.REFERENCE)return!0;return!1}),"verifyRange"),useVerify=__name((onVerify,sequenceNodes)=>{const isInitRender=require$$0.useRef(!0);require$$0.useEffect(()=>{const time=setTimeout(()=>{isInitRender.current=!1},500);return()=>{clearTimeout(time)}}),require$$0.useEffect(()=>{if(!isInitRender.current&&onVerify){const result=verifyRange(sequenceNodes);onVerify(result,sequenceNodeToText(sequenceNodes))}},[sequenceNodes,onVerify])},"useVerify"),sheetRangeSelectorTextWrap="univer-sheet-range-selector-text-wrap",sheetRangeSelectorPlaceholder="univer-sheet-range-selector-placeholder",sheetRangeSelectorError="univer-sheet-range-selector-error",sheetRangeSelectorErrorWrap="univer-sheet-range-selector-error-wrap",sheetRangeSelectorText="univer-sheet-range-selector-text",sheetRangeSelectorActive="univer-sheet-range-selector-active",sheetRangeSelectorIcon="univer-sheet-range-selector-icon",sheetRangeSelectorDialogItem="univer-sheet-range-selector-dialog-item",sheetRangeSelectorDialogItemDelete="univer-sheet-range-selector-dialog-item-delete",styles$6={sheetRangeSelectorTextWrap,sheetRangeSelectorPlaceholder,sheetRangeSelectorError,sheetRangeSelectorErrorWrap,sheetRangeSelectorText,sheetRangeSelectorActive,sheetRangeSelectorIcon,sheetRangeSelectorDialogItem,sheetRangeSelectorDialogItemDelete},noopFunction=__name(()=>{},"noopFunction");function RangeSelector(props){const{initValue,unitId,subUnitId,errorText,placeholder,actions,onChange=noopFunction,onVerify=noopFunction,onRangeSelectorDialogVisibleChange=noopFunction,onBlur=noopFunction,isFocus:_isFocus=!0,isOnlyOneRange=!1,isSupportAcrossSheet=!1}=props,editorService=core.useDependency(docsUi.IEditorService),localeService=core.useDependency(core.LocaleService),commandService=core.useDependency(core.ICommandService),lexerTreeBuilder=core.useDependency(engineFormula.LexerTreeBuilder),rangeSelectorWrapRef=require$$0.useRef(null),[rangeDialogVisible,rangeDialogVisibleSet]=require$$0.useState(!1),[isFocus,isFocusSet]=require$$0.useState(_isFocus),editorId=require$$0.useMemo(()=>core.createInternalEditorID(`${sheetsUi.RANGE_SELECTOR_SYMBOLS}-${core.generateRandomId(4)}`),[]),[editor,editorSet]=require$$0.useState(),containerRef=require$$0.useRef(null),[rangeString,rangeStringSet]=require$$0.useState(()=>typeof initValue=="string"?initValue:unitRangesToText(initValue,isSupportAcrossSheet).join(engineFormula.matchToken.COMMA));actions&&(actions.handleOutClick=(e,cb)=>{if(rangeSelectorWrapRef.current){const isContain=rangeSelectorWrapRef.current.contains(e.target);cb(isContain)}});const ranges=require$$0.useMemo(()=>rangeString.split(engineFormula.matchToken.COMMA).filter(e=>!!e).map(text=>engineFormula.deserializeRangeWithSheet(text)),[rangeString]),isError=require$$0.useMemo(()=>errorText!==void 0,[errorText]),handleInputDebounce=require$$0.useMemo(()=>core.debounce(text=>{const nodes=lexerTreeBuilder.sequenceNodesBuilder(text);if(nodes){if(verifyRange(nodes)){const preNodes=nodes.map(node=>{if(typeof node=="string")return node;if(node.nodeType===engineFormula.sequenceNodeType.REFERENCE){const unitRange=engineFormula.deserializeRangeWithSheet(node.token);unitRange.range=rangePreProcess(unitRange.range),isSupportAcrossSheet||(unitRange.sheetName="",unitRange.unitId=""),node.token=unitRangesToText([unitRange],isSupportAcrossSheet)[0]}return node}),result=sequenceNodeToText(preNodes);onChange(result)}}else rangeStringSet("")},30),[isSupportAcrossSheet]),handleConfirm=__name(ranges2=>{const text=unitRangesToText(ranges2,isSupportAcrossSheet).join(engineFormula.matchToken.COMMA);rangeStringSet(text),onChange(text),rangeDialogVisibleSet(!1),onRangeSelectorDialogVisibleChange(!1)},"handleConfirm"),handleClose=__name(()=>{rangeDialogVisibleSet(!1),onRangeSelectorDialogVisibleChange(!1)},"handleClose"),handleOpenModal=__name(()=>{isError||(rangeDialogVisibleSet(!0),onRangeSelectorDialogVisibleChange(!0))},"handleOpenModal"),focus=require$$0.useMemo(()=>{let time=0;return()=>{clearTimeout(time),editor&&(time=setTimeout(()=>{editor.focus()},30))}},[editor]),{checkScrollBar}=useResize(editor),handleSheetSelectionChange=require$$0.useMemo(()=>(text,offset)=>{rangeStringSet(text),onChange(text),focus(),offset!==-1&&setTimeout(()=>{const range={startOffset:offset,endOffset:offset};editor==null||editor.setSelectionRanges([range]);const docBackScrollRenderController=editor==null?void 0:editor.render.with(docsUi.DocBackScrollRenderController);docBackScrollRenderController==null||docBackScrollRenderController.scrollToRange({...range,collapsed:!0})},50),checkScrollBar()},[editor]),{sequenceNodes,sequenceNodesSet}=useFormulaToken(rangeString),sheetHighlightRanges=useDocHight(editorId,sequenceNodes);return useSheetHighlight(!rangeDialogVisible&&isFocus,unitId,subUnitId,sheetHighlightRanges),useSheetSelectionChange(!rangeDialogVisible&&isFocus,unitId,subUnitId,sequenceNodes,isSupportAcrossSheet,isOnlyOneRange,handleSheetSelectionChange),useRefactorEffect(!rangeDialogVisible&&isFocus,unitId,isOnlyOneRange),useEditorInput(unitId,rangeString,editor),useVerify(onVerify,sequenceNodes),require$$0.useEffect(()=>{if(editor){const dispose=editor.input$.subscribe(e=>{var _a11,_b;const text=((_b=(_a11=e.data.body)==null?void 0:_a11.dataStream)!=null?_b:"").replaceAll(/\n|\r/g,"").replaceAll(/,{2,}/g,",").replaceAll(/(^,)/g,"");rangeStringSet(text),handleInputDebounce(text)});return()=>{dispose.unsubscribe()}}},[editor]),require$$0.useEffect(()=>{const d1=commandService.beforeCommandExecuted(info=>{info.id===sheets.SetWorksheetActiveOperation.id&&(isFocusSet(!1),onBlur(),sequenceNodesSet(pre=>[...pre]))}),d2=commandService.onCommandExecuted(info=>{info.id===sheetsUi.SetCellEditVisibleOperation.id&&(rangeDialogVisibleSet(!1),onRangeSelectorDialogVisibleChange(!1),isFocusSet(!1),onBlur())});return()=>{d1.dispose(),d2.dispose()}},[]),require$$0.useEffect(()=>{isFocusSet(_isFocus)},[_isFocus]),require$$0.useEffect(()=>{if(editor&&rangeDialogVisible){editor.blur();const d=editor.focus$.subscribe(()=>{editor.blur()});return()=>{d.unsubscribe()}}},[editor,rangeDialogVisible]),require$$0.useLayoutEffect(()=>{let dispose;if(containerRef.current){dispose=editorService.register({autofocus:!0,editorUnitId:editorId,isSingle:!0,initialSnapshot:{id:editorId,body:{dataStream:`\r
|
|
12
|
-
`},documentStyle:{}}},containerRef.current);const editor2=editorService.getEditor(editorId);editorSet(editor2)}return()=>{dispose==null||dispose.dispose()}},[containerRef.current]),jsxRuntimeExports.jsxs("div",{className:styles$6.sheetRangeSelector,ref:rangeSelectorWrapRef,children:[jsxRuntimeExports.jsxs("div",{className:clsx(styles$6.sheetRangeSelectorTextWrap,{[styles$6.sheetRangeSelectorActive]:isFocus&&!isError,[styles$6.sheetRangeSelectorError]:isError}),children:[jsxRuntimeExports.jsx("div",{className:styles$6.sheetRangeSelectorText,ref:containerRef}),jsxRuntimeExports.jsx(design.Tooltip,{title:localeService.t("rangeSelector.buttonTooltip"),placement:"bottom",children:jsxRuntimeExports.jsx(SelectRangeSingle,{className:styles$6.sheetRangeSelectorIcon,onClick:handleOpenModal})}),errorText!==void 0?jsxRuntimeExports.jsx("div",{className:styles$6.sheetRangeSelectorErrorWrap,children:errorText}):null,placeholder!==void 0&&!rangeString?jsxRuntimeExports.jsx("div",{className:styles$6.sheetRangeSelectorPlaceholder,children:placeholder}):null]}),rangeDialogVisible&&jsxRuntimeExports.jsx(RangeSelectorDialog,{handleConfirm,handleClose,unitId,subUnitId,initValue:ranges,visible:rangeDialogVisible,isOnlyOneRange,isSupportAcrossSheet})]})}__name(RangeSelector,"RangeSelector");function RangeSelectorDialog(props){const{handleConfirm,handleClose:_handleClose,visible,initValue,unitId,subUnitId,isOnlyOneRange,isSupportAcrossSheet}=props,localeService=core.useDependency(core.LocaleService),descriptionService=core.useDependency(sheetsFormula.IDescriptionService),lexerTreeBuilder=core.useDependency(engineFormula.LexerTreeBuilder),render2=core.useDependency(engineRender.IRenderManagerService).getRenderById(unitId),refSelectionsRenderService=render2==null?void 0:render2.with(exports.RefSelectionsRenderService),[ranges,rangesSet]=require$$0.useState(()=>{if(isOnlyOneRange){const firstRange=initValue[0];return firstRange?unitRangesToText([firstRange],isSupportAcrossSheet):[""]}return unitRangesToText(initValue,isSupportAcrossSheet)}),[focusIndex,focusIndexSet]=require$$0.useState(()=>ranges.length-1),colorMap=useColor(),rangeText=require$$0.useMemo(()=>ranges.join(engineFormula.matchToken.COMMA),[ranges]),{sequenceNodes,sequenceNodesSet}=useFormulaToken(rangeText),refSelections=require$$0.useMemo(()=>buildTextRuns(descriptionService,colorMap,sequenceNodes).refSelections,[sequenceNodes]),handleClose=__name(()=>{sequenceNodesSet([]),setTimeout(()=>{_handleClose()},30)},"handleClose"),handleRangeInput=__name((index,value)=>{value?refSelectionsRenderService==null||refSelectionsRenderService.setSkipLastEnabled(!1):refSelectionsRenderService==null||refSelectionsRenderService.setSkipLastEnabled(!0),rangesSet(v=>{const result=[...v];return result[index]=value,result})},"handleRangeInput"),handleRangeRemove=__name(index=>{refSelectionsRenderService==null||refSelectionsRenderService.setSkipLastEnabled(!1),rangesSet(v=>{if(v.length===1)return v;const result=[];return v.forEach((r2,i)=>{index!==i&&result.push(r2)}),result})},"handleRangeRemove"),handleRangeAdd=__name(()=>{refSelectionsRenderService==null||refSelectionsRenderService.setSkipLastEnabled(!0),rangesSet(v=>(v.push(""),focusIndexSet(v.length-1),[...v]))},"handleRangeAdd"),handleSheetSelectionChange=require$$0.useCallback(rangeText2=>{var _a11;refSelectionsRenderService==null||refSelectionsRenderService.setSkipLastEnabled(!1);const ranges2=rangeText2.split(engineFormula.matchToken.COMMA).filter(e=>!!e);rangesSet(isOnlyOneRange?[(_a11=ranges2[0])!=null?_a11:""]:ranges2)},[focusIndex,isOnlyOneRange]);return useSheetHighlight(visible,unitId,subUnitId,refSelections),useSheetSelectionChange(focusIndex>=0,unitId,subUnitId,sequenceNodes,isSupportAcrossSheet,isOnlyOneRange,handleSheetSelectionChange),useRefactorEffect(focusIndex>=0,unitId,isOnlyOneRange),require$$0.useEffect(()=>{(ranges.length===0||ranges.length===1&&!ranges[0])&&(refSelectionsRenderService==null||refSelectionsRenderService.setSkipLastEnabled(!0))},[ranges]),jsxRuntimeExports.jsx(design.Dialog,{width:"328px",visible,title:localeService.t("rangeSelector.title"),draggable:!0,closeIcon:jsxRuntimeExports.jsx(CloseSingle,{}),footer:jsxRuntimeExports.jsxs("footer",{children:[jsxRuntimeExports.jsx(design.Button,{onClick:handleClose,children:localeService.t("rangeSelector.cancel")}),jsxRuntimeExports.jsx(design.Button,{style:{marginLeft:10},onClick:__name(()=>handleConfirm(ranges.filter(text=>{const nodes=lexerTreeBuilder.sequenceNodesBuilder(text);return nodes&&nodes.length===1&&typeof nodes[0]!="string"&&nodes[0].nodeType===engineFormula.sequenceNodeType.REFERENCE}).map(text=>engineFormula.deserializeRangeWithSheet(text)).map(unitRange=>({...unitRange,range:rangePreProcess(unitRange.range)}))),"onClick"),type:"primary",children:localeService.t("rangeSelector.confirm")})]}),onClose:handleClose,children:jsxRuntimeExports.jsxs("div",{className:styles$6.sheetRangeSelectorDialog,children:[ranges.map((text,index)=>jsxRuntimeExports.jsxs("div",{className:styles$6.sheetRangeSelectorDialogItem,children:[jsxRuntimeExports.jsx(design.Input,{affixWrapperStyle:{width:"100%"},placeholder:localeService.t("rangeSelector.placeHolder"),onFocus:__name(()=>focusIndexSet(index),"onFocus"),value:text,onChange:__name(value=>handleRangeInput(index,value),"onChange")},`input_${index}`),ranges.length>1&&!isOnlyOneRange&&jsxRuntimeExports.jsx(DeleteSingle,{className:styles$6.sheetRangeSelectorDialogItemDelete,onClick:__name(()=>handleRangeRemove(index),"onClick")})]},index)),!isOnlyOneRange&&jsxRuntimeExports.jsx("div",{children:jsxRuntimeExports.jsxs(design.Button,{type:"link",size:"small",onClick:handleRangeAdd,children:[jsxRuntimeExports.jsx(IncreaseSingle,{}),jsxRuntimeExports.jsx("span",{children:localeService.t("rangeSelector.addAnotherRange")})]})})]})})}__name(RangeSelectorDialog,"RangeSelectorDialog");const PLUGIN_CONFIG_KEY_BASE="sheets-formula.base.config",defaultPluginBaseConfig={};function whenEditorStandalone(contextService){return contextService.getContextValue(core.FOCUSING_DOC)&&contextService.getContextValue(core.FOCUSING_UNIVER_EDITOR)&&contextService.getContextValue(core.FOCUSING_UNIVER_EDITOR_STANDALONE_SINGLE_MODE)}__name(whenEditorStandalone,"whenEditorStandalone");function extractFormulaError(cell,isArrayFormulaCell=!1){return!isArrayFormulaCell&&!(core.isFormulaString(cell==null?void 0:cell.f)||core.isFormulaId(cell==null?void 0:cell.si))?null:typeof(cell==null?void 0:cell.v)=="string"&&engineFormula.ERROR_TYPE_SET.has(cell.v)?cell.v:null}__name(extractFormulaError,"extractFormulaError");var __defProp$7=Object.defineProperty,__getOwnPropDesc$7=Object.getOwnPropertyDescriptor,__decorateClass$7=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$7(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$7(target,key,result),result},"__decorateClass$7"),__decorateParam$7=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$7");const ALERT_KEY="SHEET_FORMULA_ALERT",ErrorTypeToMessageMap={[engineFormula.ErrorType.DIV_BY_ZERO]:"divByZero",[engineFormula.ErrorType.NAME]:"name",[engineFormula.ErrorType.VALUE]:"value",[engineFormula.ErrorType.NUM]:"num",[engineFormula.ErrorType.NA]:"na",[engineFormula.ErrorType.CYCLE]:"cycle",[engineFormula.ErrorType.REF]:"ref",[engineFormula.ErrorType.SPILL]:"spill",[engineFormula.ErrorType.CALC]:"calc",[engineFormula.ErrorType.ERROR]:"error",[engineFormula.ErrorType.CONNECT]:"connect",[engineFormula.ErrorType.NULL]:"null"};var _a3;let FormulaAlertRenderController=(_a3=class extends core.Disposable{constructor(_context,_hoverManagerService,_cellAlertManagerService,_localeService,_formulaDataModel,_zenZoneService){super(),this._context=_context,this._hoverManagerService=_hoverManagerService,this._cellAlertManagerService=_cellAlertManagerService,this._localeService=_localeService,this._formulaDataModel=_formulaDataModel,this._zenZoneService=_zenZoneService,this._init()}_init(){this._initCellAlertPopup(),this._initZenService()}_initCellAlertPopup(){this.disposeWithMe(this._hoverManagerService.currentCell$.subscribe(cellPos=>{var _a11,_b,_c,_d,_e;if(cellPos){const worksheet=this._context.unit.getActiveSheet();if(!worksheet)return;const cellData=worksheet.getCell(cellPos.location.row,cellPos.location.col),arrayFormulaCellData=(_d=(_c=(_b=(_a11=this._formulaDataModel.getArrayFormulaCellData())==null?void 0:_a11[cellPos.location.unitId])==null?void 0:_b[cellPos.location.subUnitId])==null?void 0:_c[cellPos.location.row])==null?void 0:_d[cellPos.location.col];if(core.isICellData(cellData)){const errorType=extractFormulaError(cellData,!!arrayFormulaCellData);if(!errorType)return;const currentAlert=this._cellAlertManagerService.currentAlert.get(ALERT_KEY),currentLoc=(_e=currentAlert==null?void 0:currentAlert.alert)==null?void 0:_e.location;if(currentLoc&¤tLoc.row===cellPos.location.row&¤tLoc.col===cellPos.location.col&¤tLoc.subUnitId===cellPos.location.subUnitId&¤tLoc.unitId===cellPos.location.unitId)return;this._cellAlertManagerService.showAlert({type:sheetsUi.CellAlertType.ERROR,title:this._localeService.t("formula.error.title"),message:this._localeService.t(`formula.error.${ErrorTypeToMessageMap[errorType]}`),location:cellPos.location,width:200,height:74,key:ALERT_KEY});return}}this._cellAlertManagerService.removeAlert(ALERT_KEY)}))}_initZenService(){this.disposeWithMe(this._zenZoneService.visible$.subscribe(visible=>{visible&&this._cellAlertManagerService.removeAlert(ALERT_KEY)}))}},__name(_a3,"FormulaAlertRenderController"),_a3);FormulaAlertRenderController=__decorateClass$7([__decorateParam$7(1,core.Inject(sheetsUi.HoverManagerService)),__decorateParam$7(2,core.Inject(sheetsUi.CellAlertManagerService)),__decorateParam$7(3,core.Inject(core.LocaleService)),__decorateParam$7(4,core.Inject(engineFormula.FormulaDataModel)),__decorateParam$7(5,ui.IZenZoneService)],FormulaAlertRenderController);var __defProp$6=Object.defineProperty,__getOwnPropDesc$6=Object.getOwnPropertyDescriptor,__decorateClass$6=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$6(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$6(target,key,result),result},"__decorateClass$6"),__decorateParam$6=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$6"),_a4;let FormulaAutoFillController=(_a4=class extends core.Disposable{constructor(_autoFillService,_lexerTreeBuilder){super(),this._autoFillService=_autoFillService,this._lexerTreeBuilder=_lexerTreeBuilder,this._registerAutoFill()}_registerAutoFill(){const formulaRule={type:sheetsUi.DATA_TYPE.FORMULA,priority:1001,match:__name(cellData=>core.isFormulaString(cellData==null?void 0:cellData.f)||core.isFormulaId(cellData==null?void 0:cellData.si),"match"),isContinue:__name((prev,cur)=>prev.type===sheetsUi.DATA_TYPE.FORMULA,"isContinue"),applyFunctions:{[sheetsUi.APPLY_TYPE.COPY]:(dataWithIndex,len,direction,copyDataPiece)=>{const{data,index}=dataWithIndex;return this._fillCopyFormula(data,len,direction,index,copyDataPiece)}}};this._autoFillService.registerRule(formulaRule)}_fillCopyFormula(data,len,direction,index,copyDataPiece){var _a11,_b;const step=getDataLength(copyDataPiece),applyData=[],formulaIdMap=new Map;for(let i=1;i<=len;i++){const index2=(i-1)%data.length,d=core.Tools.deepClone(data[index2]);if(d){const originalFormula=((_a11=data[index2])==null?void 0:_a11.f)||"",originalFormulaId=((_b=data[index2])==null?void 0:_b.si)||"",checkFormula=core.isFormulaString(originalFormula);if(core.isFormulaId(originalFormulaId))d.si=originalFormulaId,d.f=null,d.v=null,d.p=null,d.t=null,direction===core.Direction.DOWN||direction===core.Direction.RIGHT?applyData.push(d):applyData.unshift(d);else if(checkFormula){let formulaId=formulaIdMap.get(index2);if(formulaId)d.si=formulaId,d.f=null,d.v=null,d.p=null,d.t=null;else{formulaId=core.Tools.generateRandomId(6),formulaIdMap.set(index2,formulaId);const{offsetX,offsetY}=directionToOffset(step,direction),shiftedFormula=this._lexerTreeBuilder.moveFormulaRefOffset(originalFormula,offsetX,offsetY);d.si=formulaId,d.f=shiftedFormula,d.v=null,d.p=null,d.t=null}direction===core.Direction.DOWN||direction===core.Direction.RIGHT?applyData.push(d):applyData.unshift(d)}}}return applyData}},__name(_a4,"FormulaAutoFillController"),_a4);FormulaAutoFillController=__decorateClass$6([__decorateParam$6(0,sheetsUi.IAutoFillService),__decorateParam$6(1,core.Inject(engineFormula.LexerTreeBuilder))],FormulaAutoFillController);function directionToOffset(step,direction){let offsetX=0,offsetY=0;switch(direction){case core.Direction.UP:offsetY=-step;break;case core.Direction.RIGHT:offsetX=step;break;case core.Direction.DOWN:offsetY=step;break;case core.Direction.LEFT:offsetX=-step;break}return{offsetX,offsetY}}__name(directionToOffset,"directionToOffset");function getDataLength(copyDataPiece){let length=0;for(const t in copyDataPiece)copyDataPiece[t].forEach(item=>{length+=item.data.length});return length}__name(getDataLength,"getDataLength");var __defProp$5=Object.defineProperty,__getOwnPropDesc$5=Object.getOwnPropertyDescriptor,__decorateClass$5=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$5(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$5(target,key,result),result},"__decorateClass$5"),__decorateParam$5=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$5");const DEFAULT_PASTE_FORMULA="default-paste-formula";var _a5;let FormulaClipboardController=(_a5=class extends core.Disposable{constructor(_currentUniverSheet,_lexerTreeBuilder,_sheetClipboardService,_injector,_formulaDataModel){super(),this._currentUniverSheet=_currentUniverSheet,this._lexerTreeBuilder=_lexerTreeBuilder,this._sheetClipboardService=_sheetClipboardService,this._injector=_injector,this._formulaDataModel=_formulaDataModel,this._initialize()}_initialize(){this._registerClipboardHook()}_registerClipboardHook(){this.disposeWithMe(this._sheetClipboardService.addClipboardHook(this._pasteFormulaHook())),this.disposeWithMe(this._sheetClipboardService.addClipboardHook(this._pasteWithFormulaHook()))}_pasteFormulaHook(){return{id:sheetsUi.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMULA,priority:10,specialPasteInfo:{label:"specialPaste.formula"},onPasteCells:__name((pasteFrom,pasteTo,data,payload)=>this._onPasteCells(pasteFrom,pasteTo,data,payload,!0),"onPasteCells")}}_pasteWithFormulaHook(){return{id:DEFAULT_PASTE_FORMULA,priority:10,onPasteCells:__name((pasteFrom,pasteTo,data,payload)=>this._onPasteCells(pasteFrom,pasteTo,data,payload,!1),"onPasteCells")}}_onPasteCells(pasteFrom,pasteTo,data,payload,isSpecialPaste){var _a11;if([sheetsUi.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMAT,sheetsUi.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_COL_WIDTH].includes(payload.pasteType))return{undos:[],redos:[]};const workbook=this._currentUniverSheet.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),unitId=pasteTo.unitId||workbook.getUnitId(),subUnitId=pasteTo.subUnitId||((_a11=workbook.getActiveSheet())==null?void 0:_a11.getSheetId());if(!unitId||!subUnitId)return{undos:[],redos:[]};const pastedRange=pasteTo.range,matrix=data,copyInfo={copyType:payload.copyType||sheetsUi.COPY_TYPE.COPY,copyRange:pasteFrom==null?void 0:pasteFrom.range,pasteType:payload.pasteType};return this._injector.invoke(accessor=>getSetCellFormulaMutations(unitId,subUnitId,pastedRange,matrix,accessor,copyInfo,this._lexerTreeBuilder,this._formulaDataModel,isSpecialPaste,pasteFrom))}},__name(_a5,"FormulaClipboardController"),_a5);FormulaClipboardController=__decorateClass$5([__decorateParam$5(0,core.IUniverInstanceService),__decorateParam$5(1,core.Inject(engineFormula.LexerTreeBuilder)),__decorateParam$5(2,sheetsUi.ISheetClipboardService),__decorateParam$5(3,core.Inject(core.Injector)),__decorateParam$5(4,core.Inject(engineFormula.FormulaDataModel))],FormulaClipboardController);function getSetCellFormulaMutations(unitId,subUnitId,range,matrix,accessor,copyInfo,lexerTreeBuilder,formulaDataModel,isSpecialPaste=!1,pasteFrom){const redoMutationsInfo=[],undoMutationsInfo=[],valueMatrix=getValueMatrix(unitId,subUnitId,range,matrix,copyInfo,lexerTreeBuilder,formulaDataModel,pasteFrom),setValuesMutation={unitId,subUnitId,cellValue:valueMatrix.getData()};redoMutationsInfo.push({id:sheets.SetRangeValuesMutation.id,params:setValuesMutation});const undoSetValuesMutation=sheets.SetRangeValuesUndoMutationFactory(accessor,setValuesMutation);return undoMutationsInfo.push({id:sheets.SetRangeValuesMutation.id,params:undoSetValuesMutation}),{undos:undoMutationsInfo,redos:redoMutationsInfo}}__name(getSetCellFormulaMutations,"getSetCellFormulaMutations");function getValueMatrix(unitId,subUnitId,range,matrix,copyInfo,lexerTreeBuilder,formulaDataModel,pasteFrom){return pasteFrom?copyInfo.pasteType===sheetsUi.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_VALUE?getSpecialPasteValueValueMatrix(unitId,subUnitId,range,matrix,formulaDataModel,pasteFrom):copyInfo.pasteType===sheetsUi.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMULA?getSpecialPasteFormulaValueMatrix(unitId,subUnitId,range,matrix,lexerTreeBuilder,formulaDataModel,pasteFrom):getDefaultPasteValueMatrix(unitId,subUnitId,range,matrix,lexerTreeBuilder,formulaDataModel,pasteFrom):getValueMatrixOfPasteFromIsNull(unitId,subUnitId,range,matrix,formulaDataModel)}__name(getValueMatrix,"getValueMatrix");function getValueMatrixOfPasteFromIsNull(unitId,subUnitId,range,matrix,formulaDataModel){var _a11,_b;const valueMatrix=new core.ObjectMatrix,formulaData=(_b=(_a11=formulaDataModel.getFormulaData())==null?void 0:_a11[unitId])==null?void 0:_b[subUnitId];return matrix.forValue((row,col,value)=>{var _a12;const toRow=range.rows[row],toCol=range.cols[col],valueObject={};core.isFormulaString(value.v)?(valueObject.v=null,valueObject.f=`${value.v}`,valueObject.si=null,valueObject.p=null,valueMatrix.setValue(toRow,toCol,valueObject)):(_a12=formulaData==null?void 0:formulaData[toRow])!=null&&_a12[toCol]&&(valueObject.v=value.v,valueObject.f=null,valueObject.si=null,valueObject.p=null,valueMatrix.setValue(toRow,toCol,valueObject))}),valueMatrix}__name(getValueMatrixOfPasteFromIsNull,"getValueMatrixOfPasteFromIsNull");function getSpecialPasteValueValueMatrix(unitId,subUnitId,range,matrix,formulaDataModel,pasteFrom){var _a11,_b,_c,_d;const valueMatrix=new core.ObjectMatrix,arrayFormulaCellData=(_b=(_a11=formulaDataModel.getArrayFormulaCellData())==null?void 0:_a11[pasteFrom.unitId])==null?void 0:_b[pasteFrom.subUnitId],formulaData=(_d=(_c=formulaDataModel.getFormulaData())==null?void 0:_c[unitId])==null?void 0:_d[subUnitId];return matrix.forValue((row,col,value)=>{var _a12,_b2;const fromRow=pasteFrom.range.rows[row%pasteFrom.range.rows.length],fromCol=pasteFrom.range.cols[col%pasteFrom.range.cols.length],toRow=range.rows[row],toCol=range.cols[col],valueObject={};if(core.isFormulaString(value.f)||core.isFormulaId(value.si))valueObject.v=value.v,valueObject.f=null,valueObject.si=null,valueObject.p=null,valueMatrix.setValue(toRow,toCol,valueObject);else if((_a12=arrayFormulaCellData==null?void 0:arrayFormulaCellData[fromRow])!=null&&_a12[fromCol]){const cell=arrayFormulaCellData[fromRow][fromCol];valueObject.v=cell.v,valueObject.f=null,valueObject.si=null,valueObject.p=null,valueMatrix.setValue(toRow,toCol,valueObject)}else if((_b2=formulaData==null?void 0:formulaData[toRow])!=null&&_b2[toCol]){if(valueObject.v=value.v,valueObject.f=null,valueObject.si=null,valueObject.p=null,value.p){const richText=getCellRichText(value);richText&&(valueObject.v=richText)}valueMatrix.setValue(toRow,toCol,valueObject)}}),valueMatrix}__name(getSpecialPasteValueValueMatrix,"getSpecialPasteValueValueMatrix");function getSpecialPasteFormulaValueMatrix(unitId,subUnitId,range,matrix,lexerTreeBuilder,formulaDataModel,pasteFrom){const valueMatrix=new core.ObjectMatrix,formulaIdMap=new Map;return matrix.forValue((row,col,value)=>{const toRow=range.rows[row],toCol=range.cols[col],valueObject={};if(core.isFormulaId(value.si)){if(pasteFrom.unitId!==unitId||pasteFrom.subUnitId!==subUnitId){const formulaString=formulaDataModel.getFormulaStringByCell(pasteFrom.range.rows[row%pasteFrom.range.rows.length],pasteFrom.range.cols[col%pasteFrom.range.cols.length],pasteFrom.subUnitId,pasteFrom.unitId),offsetX=range.cols[col]-pasteFrom.range.cols[col%pasteFrom.range.cols.length],offsetY=range.rows[row]-pasteFrom.range.rows[row%pasteFrom.range.rows.length],shiftedFormula=lexerTreeBuilder.moveFormulaRefOffset(formulaString||"",offsetX,offsetY);valueObject.si=null,valueObject.f=shiftedFormula}else valueObject.si=value.si,valueObject.f=null;valueObject.v=null,valueObject.p=null,valueMatrix.setValue(toRow,toCol,valueObject)}else if(core.isFormulaString(value.f)){const index=`${row%pasteFrom.range.rows.length}_${col%pasteFrom.range.cols.length}`;let formulaId=formulaIdMap.get(index);if(formulaId)valueObject.si=formulaId,valueObject.f=null;else{formulaId=core.Tools.generateRandomId(6),formulaIdMap.set(index,formulaId);const offsetX=range.cols[col]-pasteFrom.range.cols[col%pasteFrom.range.cols.length],offsetY=range.rows[row]-pasteFrom.range.rows[row%pasteFrom.range.rows.length],shiftedFormula=lexerTreeBuilder.moveFormulaRefOffset(value.f||"",offsetX,offsetY);valueObject.si=formulaId,valueObject.f=shiftedFormula}valueObject.v=null,valueObject.p=null,valueMatrix.setValue(toRow,toCol,valueObject)}else{if(valueObject.v=value.v,valueObject.f=null,valueObject.si=null,valueObject.p=null,value.p){const richText=getCellRichText(value);richText&&(valueObject.v=richText)}valueMatrix.setValue(toRow,toCol,valueObject)}}),valueMatrix}__name(getSpecialPasteFormulaValueMatrix,"getSpecialPasteFormulaValueMatrix");function getDefaultPasteValueMatrix(unitId,subUnitId,range,matrix,lexerTreeBuilder,formulaDataModel,pasteFrom){var _a11,_b;const valueMatrix=new core.ObjectMatrix,formulaIdMap=new Map,formulaData=(_b=(_a11=formulaDataModel.getFormulaData())==null?void 0:_a11[unitId])==null?void 0:_b[subUnitId];return matrix.forValue((row,col,value)=>{var _a12;const toRow=range.rows[row],toCol=range.cols[col],valueObject={};if(core.isFormulaId(value.si)){if(pasteFrom.unitId!==unitId||pasteFrom.subUnitId!==subUnitId){const formulaString=formulaDataModel.getFormulaStringByCell(pasteFrom.range.rows[row%pasteFrom.range.rows.length],pasteFrom.range.cols[col%pasteFrom.range.cols.length],pasteFrom.subUnitId,pasteFrom.unitId),offsetX=range.cols[col]-pasteFrom.range.cols[col%pasteFrom.range.cols.length],offsetY=range.rows[row]-pasteFrom.range.rows[row%pasteFrom.range.rows.length],shiftedFormula=lexerTreeBuilder.moveFormulaRefOffset(formulaString||"",offsetX,offsetY);valueObject.si=null,valueObject.f=shiftedFormula}else valueObject.si=value.si,valueObject.f=null;valueObject.v=null,valueObject.p=null,valueMatrix.setValue(toRow,toCol,valueObject)}else if(core.isFormulaString(value.f)){const index=`${row%pasteFrom.range.rows.length}_${col%pasteFrom.range.cols.length}`;let formulaId=formulaIdMap.get(index);if(formulaId)valueObject.si=formulaId,valueObject.f=null;else{formulaId=core.Tools.generateRandomId(6),formulaIdMap.set(index,formulaId);const offsetX=range.cols[col]-pasteFrom.range.cols[col%pasteFrom.range.cols.length],offsetY=range.rows[row]-pasteFrom.range.rows[row%pasteFrom.range.rows.length],shiftedFormula=lexerTreeBuilder.moveFormulaRefOffset(value.f||"",offsetX,offsetY);valueObject.si=formulaId,valueObject.f=shiftedFormula}valueObject.v=null,valueObject.p=null,valueMatrix.setValue(toRow,toCol,valueObject)}else(_a12=formulaData==null?void 0:formulaData[toRow])!=null&&_a12[toCol]&&(valueObject.v=value.v,valueObject.f=null,valueObject.si=null,valueObject.p=value.p,valueMatrix.setValue(toRow,toCol,valueObject))}),valueMatrix}__name(getDefaultPasteValueMatrix,"getDefaultPasteValueMatrix");function getCellRichText(cell){if(cell!=null&&cell.p){const body=cell==null?void 0:cell.p.body;if(body==null)return;const data=body.dataStream;return data.substring(data.length-2,data.length)===core.DEFAULT_EMPTY_DOCUMENT_VALUE?data.substring(0,data.length-2):data}}__name(getCellRichText,"getCellRichText");var __defProp$4=Object.defineProperty,__getOwnPropDesc$4=Object.getOwnPropertyDescriptor,__decorateClass$4=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$4(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$4(target,key,result),result},"__decorateClass$4"),__decorateParam$4=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$4"),_a6;let FormulaEditorShowController=(_a6=class extends core.Disposable{constructor(_context,_editorBridgeService,_formulaDataModel,_themeService,_renderManagerService,_sheetSkeletonManagerService,_commandService,_logService){super();__publicField(this,"_previousShape");__publicField(this,"_skeleton");this._context=_context,this._editorBridgeService=_editorBridgeService,this._formulaDataModel=_formulaDataModel,this._themeService=_themeService,this._renderManagerService=_renderManagerService,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._commandService=_commandService,this._logService=_logService,this._initSkeletonChangeListener(),this._initInterceptorEditorStart(),this._commandExecutedListener()}_initSkeletonChangeListener(){this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(param=>{var _a11,_b;if(param==null)this._logService.debug("[FormulaEditorShowController]: should not receive currentSkeleton$ as null!");else{const{skeleton}=param,prevSheetId=(_b=(_a11=this._skeleton)==null?void 0:_a11.worksheet)==null?void 0:_b.getSheetId();if(this._changeRuntime(skeleton),prevSheetId!==skeleton.worksheet.getSheetId())this._removeArrayFormulaRangeShape();else{const{unitId,sheetId}=param;this._updateArrayFormulaRangeShape(unitId,sheetId)}}}))}_changeRuntime(skeleton){this._skeleton=skeleton}_initInterceptorEditorStart(){this.disposeWithMe(core.toDisposable(this._editorBridgeService.interceptor.intercept(this._editorBridgeService.interceptor.getInterceptPoints().BEFORE_CELL_EDIT,{handler:__name((value,context,next)=>{var _a11,_b,_c,_d;const{row,col,unitId,subUnitId,worksheet}=context,arrayFormulaMatrixRange=this._formulaDataModel.getArrayFormulaRange(),arrayFormulaMatrixCell=this._formulaDataModel.getArrayFormulaCellData();if(this._removeArrayFormulaRangeShape(),value==null)return next(value);let cellInfo=null;const formulaString=this._formulaDataModel.getFormulaStringByCell(row,col,subUnitId,unitId);if(formulaString!==null&&(cellInfo={f:formulaString}),value.v!=null&&value.v!==""&&((_c=(_b=(_a11=arrayFormulaMatrixCell[unitId])==null?void 0:_a11[subUnitId])==null?void 0:_b[row])==null?void 0:_c[col])==null)return cellInfo?{...value,...cellInfo}:next(value);const matrixRange=(_d=arrayFormulaMatrixRange==null?void 0:arrayFormulaMatrixRange[unitId])==null?void 0:_d[subUnitId];return matrixRange!=null&&(cellInfo=this._displayArrayFormulaRangeShape(matrixRange,row,col,unitId,subUnitId,worksheet,cellInfo)),cellInfo?{...value,...cellInfo}:next(value)},"handler")})))}_commandExecutedListener(){this.disposeWithMe(this._commandService.onCommandExecuted((command,options)=>{(command.id===engineFormula.SetFormulaCalculationResultMutation.id||command.id===engineFormula.SetArrayFormulaDataMutation.id&&options&&options.remove)&&this._removeArrayFormulaRangeShape()})),this.disposeWithMe(this._commandService.beforeCommandExecuted(command=>{sheets.SetWorksheetRowAutoHeightMutation.id===command.id&&requestIdleCallback(()=>{const params=command.params,{unitId,subUnitId,rowsAutoHeightInfo}=params;this._refreshArrayFormulaRangeShapeByRow(unitId,subUnitId,rowsAutoHeightInfo)})}))}_displayArrayFormulaRangeShape(matrixRange,row,col,unitId,subUnitId,worksheet,cellInfo){return new core.ObjectMatrix(matrixRange).forValue((rowIndex,columnIndex,range)=>{if(range==null)return!0;const{startRow,startColumn,endRow,endColumn}=range;if(rowIndex===row&&columnIndex===col)return this._createArrayFormulaRangeShape(range,unitId),!1;if(row>=startRow&&row<=endRow&&col>=startColumn&&col<=endColumn){const mainCellValue=worksheet.getCell(startRow,startColumn);if((mainCellValue==null?void 0:mainCellValue.v)===engineFormula.ErrorType.SPILL)return;const formulaDataItem=this._formulaDataModel.getFormulaDataItem(rowIndex,columnIndex,subUnitId,unitId);return formulaDataItem==null||formulaDataItem.f==null?!0:(cellInfo==null&&(cellInfo={f:formulaDataItem.f,isInArrayFormulaRange:!0}),this._createArrayFormulaRangeShape(range,unitId),!1)}}),cellInfo}_createArrayFormulaRangeShape(arrayRange,unitId){const styleSheet=this._themeService.getCurrentTheme(),fill=new core.ColorKit(styleSheet.colorWhite).setAlpha(0).toString(),style={strokeWidth:1,stroke:styleSheet.hyacinth700,fill,widgets:{},hasAutoFill:!1,hasRowHeader:!1,hasColumnHeader:!1},renderUnit=this._renderManagerService.getRenderById(unitId);if(!renderUnit)return;const{scene}=renderUnit,{rangeWithCoord,primaryWithCoord}=renderUnit.with(sheetsUi.ISheetSelectionRenderService).attachSelectionWithCoord({range:arrayRange,primary:null,style}),skeleton=this._sheetSkeletonManagerService.getCurrentSkeleton();if(!scene||!skeleton)return;const{rowHeaderWidth,columnHeaderHeight}=skeleton,control=new sheetsUi.SelectionShape(scene,sheetsUi.SELECTION_SHAPE_DEPTH.FORMULA_EDITOR_SHOW,this._themeService,!1);control.update(rangeWithCoord,rowHeaderWidth,columnHeaderHeight,style,primaryWithCoord),control.setEvent(!1),this._previousShape=control}_removeArrayFormulaRangeShape(){this._previousShape!=null&&(this._previousShape.dispose(),this._previousShape=null)}_refreshArrayFormulaRangeShape(unitId,_range){if(this._previousShape){const{startRow,endRow,startColumn,endColumn}=this._previousShape.getRange(),range={startRow,endRow,startColumn,endColumn};this._removeArrayFormulaRangeShape(),this._createArrayFormulaRangeShape(range,unitId)}}_checkCurrentSheet(unitId,subUnitId){const skeleton=this._sheetSkeletonManagerService.getCurrentSkeleton();if(!skeleton)return!1;const worksheet=skeleton.worksheet;return worksheet?worksheet.unitId===unitId&&worksheet.getSheetId()===subUnitId:!1}_updateArrayFormulaRangeShape(unitId,subUnitId){this._checkCurrentSheet(unitId,subUnitId)&&this._previousShape&&this._refreshArrayFormulaRangeShape(unitId)}_refreshArrayFormulaRangeShapeByRow(unitId,subUnitId,rowAutoHeightInfo){if(!this._checkCurrentSheet(unitId,subUnitId)||!this._previousShape)return;const{startRow:shapeStartRow,endRow:shapeEndRow,startColumn:shapeStartColumn,endColumn:shapeEndColumn}=this._previousShape.getRange();for(let i=0;i<rowAutoHeightInfo.length;i++){const{row}=rowAutoHeightInfo[i];if(shapeStartRow>=row){const shapeRange={startRow:shapeStartRow,endRow:shapeEndRow,startColumn:shapeStartColumn,endColumn:shapeEndColumn};this._refreshArrayFormulaRangeShape(unitId,shapeRange);break}}}},__name(_a6,"FormulaEditorShowController"),_a6);FormulaEditorShowController=__decorateClass$4([__decorateParam$4(1,core.Inject(sheetsUi.IEditorBridgeService)),__decorateParam$4(2,core.Inject(engineFormula.FormulaDataModel)),__decorateParam$4(3,core.Inject(core.ThemeService)),__decorateParam$4(4,engineRender.IRenderManagerService),__decorateParam$4(5,core.Inject(sheetsUi.SheetSkeletonManagerService)),__decorateParam$4(6,core.ICommandService),__decorateParam$4(7,core.ILogService)],FormulaEditorShowController);var __defProp$3=Object.defineProperty,__getOwnPropDesc$3=Object.getOwnPropertyDescriptor,__decorateClass$3=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$3(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$3(target,key,result),result},"__decorateClass$3"),__decorateParam$3=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$3");const FORMULA_ERROR_MARK={tl:{size:6,color:"#409f11"}};var _a7;let FormulaRenderManagerController=(_a7=class extends core.RxDisposable{constructor(_sheetInterceptorService,_formulaDataModel){super(),this._sheetInterceptorService=_sheetInterceptorService,this._formulaDataModel=_formulaDataModel,this.disposeWithMe(this._sheetInterceptorService.intercept(sheets.INTERCEPTOR_POINT.CELL_CONTENT,{effect:core.InterceptorEffectEnum.Style,handler:__name((cell,pos,next)=>{var _a11,_b,_c,_d;const arrayFormulaCellData=(_d=(_c=(_b=(_a11=this._formulaDataModel.getArrayFormulaCellData())==null?void 0:_a11[pos.unitId])==null?void 0:_b[pos.subUnitId])==null?void 0:_c[pos.row])==null?void 0:_d[pos.col];return extractFormulaError(cell,!!arrayFormulaCellData)?next({...cell,markers:{...cell==null?void 0:cell.markers,...FORMULA_ERROR_MARK}}):next(cell)},"handler"),priority:10}))}},__name(_a7,"FormulaRenderManagerController"),_a7);FormulaRenderManagerController=__decorateClass$3([__decorateParam$3(0,core.Inject(sheets.SheetInterceptorService)),__decorateParam$3(1,core.Inject(engineFormula.FormulaDataModel))],FormulaRenderManagerController);function getFunctionTypeValues(enumObj,localeService){return Object.keys(enumObj).filter(key=>isNaN(Number(key))&&key!=="DefinedName").map(key=>({label:localeService.t(`formula.functionType.${key.toLocaleLowerCase()}`),value:`${enumObj[key]}`}))}__name(getFunctionTypeValues,"getFunctionTypeValues");function generateParam(param){if(!param.require&&!param.repeat)return`[${param.name}]`;if(param.require&&!param.repeat)return param.name;if(!param.require&¶m.repeat)return`[${param.name},...]`;if(param.require&¶m.repeat)return`${param.name},...`}__name(generateParam,"generateParam");const useResizeScrollObserver=__name((callback,delay=100)=>{require$$0.useEffect(()=>{let throttleTimeout=null;const throttledCallback=__name(()=>{throttleTimeout===null&&(throttleTimeout=window.setTimeout(()=>{callback(),throttleTimeout=null},delay))},"throttledCallback");return window.addEventListener("scroll",throttledCallback),window.addEventListener("resize",throttledCallback),()=>{throttleTimeout!==null&&clearTimeout(throttleTimeout),window.removeEventListener("scroll",throttledCallback),window.removeEventListener("resize",throttledCallback)}},[callback,delay])},"useResizeScrollObserver"),formulaHelpFunction="univer-formula-help-function",formulaHelpFunctionTitle="univer-formula-help-function-title",formulaHelpFunctionTitleIcons="univer-formula-help-function-title-icons",formulaHelpFunctionTitleIcon="univer-formula-help-function-title-icon",formulaHelpFunctionContent="univer-formula-help-function-content",formulaHelpFunctionContentInner="univer-formula-help-function-content-inner",formulaHelpFunctionContentParams="univer-formula-help-function-content-params",formulaHelpFunctionContentParamsTitle="univer-formula-help-function-content-params-title",formulaHelpFunctionContentParamsDetail="univer-formula-help-function-content-params-detail",formulaHelpFunctionActive="univer-formula-help-function-active",formulaHelpDecorator="univer-formula-help-decorator",formulaHelpParam="univer-formula-help-param",formulaHelpParamPrefix="univer-formula-help-param-prefix",formulaHelpParamItem="univer-formula-help-param-item",formulaHelpParamActive="univer-formula-help-param-active",styles$5={formulaHelpFunction,formulaHelpFunctionTitle,formulaHelpFunctionTitleIcons,formulaHelpFunctionTitleIcon,formulaHelpFunctionContent,formulaHelpFunctionContentInner,formulaHelpFunctionContentParams,formulaHelpFunctionContentParamsTitle,formulaHelpFunctionContentParamsDetail,formulaHelpFunctionActive,formulaHelpDecorator,formulaHelpParam,formulaHelpParamPrefix,formulaHelpParamItem,formulaHelpParamActive};function HelpFunction(){const[visible,setVisible]=require$$0.useState(!1),[contentVisible,setContentVisible]=require$$0.useState(!0),[helpVisible,setHelpVisible]=require$$0.useState(!0),[paramIndex,setParamIndex]=require$$0.useState(0),[offset,setOffset]=require$$0.useState([0,0]),[decoratorPosition,setDecoratorPosition]=require$$0.useState({left:0,top:0}),[functionInfo,setFunctionInfo]=require$$0.useState(null),promptService=core.useDependency(IFormulaPromptService),localeService=core.useDependency(core.LocaleService),required=localeService.t("formula.prompt.required"),optional=localeService.t("formula.prompt.optional"),univerInstanceService=core.useDependency(core.IUniverInstanceService),editorService=core.useDependency(docsUi.IEditorService),sidebarService=core.useDependency(ui.ISidebarService),injector=core.useInjector();useResizeScrollObserver(updatePosition),require$$0.useEffect(()=>{const subscription=promptService.help$.subscribe(params=>{const{visible:visible2,paramIndex:paramIndex2,functionInfo:functionInfo2}=params;if(!visible2){setVisible(visible2);return}const position=getPosition();if(position==null)return;const{left,top,height}=position;functionInfo2.description===""&&functionInfo2.functionParameter.length===0||(setOffset([left,top+height]),setParamIndex(paramIndex2),setFunctionInfo(functionInfo2),setDecoratorPosition({left,top}),setVisible(visible2))}),sidebarSubscription=sidebarService.scrollEvent$.pipe(rxjs.throttleTime(100)).subscribe(updatePosition);return()=>{subscription==null||subscription.unsubscribe(),sidebarSubscription.unsubscribe()}},[]);function updatePosition(){if(!helpVisible)return;const position=getPosition();if(position==null)return;const{left,top,height}=position;setOffset([left,top+height])}__name(updatePosition,"updatePosition");function getPosition(){const documentDataModel=univerInstanceService.getCurrentUniverDocInstance();if(!documentDataModel)return;const editorUnitId=documentDataModel.getUnitId();if(!editorService.isEditor(editorUnitId))return;const editor=editorService.getEditor(editorUnitId);return editor==null?void 0:editor.getBoundingClientRect()}__name(getPosition,"getPosition");function handleSwitchActive(paramIndex2){setParamIndex(paramIndex2)}__name(handleSwitchActive,"handleSwitchActive");function handleClose(){setHelpVisible(!helpVisible),injector.get(ui.ILayoutService).focus()}return __name(handleClose,"handleClose"),jsxRuntimeExports.jsx(jsxRuntimeExports.Fragment,{children:helpVisible?jsxRuntimeExports.jsx(design.Popup,{visible,offset,children:functionInfo?jsxRuntimeExports.jsxs("div",{className:styles$5.formulaHelpFunction,children:[jsxRuntimeExports.jsxs("div",{className:styles$5.formulaHelpFunctionTitle,children:[jsxRuntimeExports.jsx(Help,{prefix:functionInfo.functionName,value:functionInfo.functionParameter,active:paramIndex,onClick:handleSwitchActive}),jsxRuntimeExports.jsxs("div",{className:styles$5.formulaHelpFunctionTitleIcons,children:[jsxRuntimeExports.jsx("div",{className:styles$5.formulaHelpFunctionTitleIcon,style:{transform:contentVisible?"rotateZ(-90deg)":"rotateZ(90deg)"},onClick:__name(()=>setContentVisible(!contentVisible),"onClick"),children:jsxRuntimeExports.jsx(MoreSingle,{})}),jsxRuntimeExports.jsx("div",{className:styles$5.formulaHelpFunctionTitleIcon,onClick:handleClose,children:jsxRuntimeExports.jsx(CloseSingle,{})})]})]}),jsxRuntimeExports.jsx("div",{className:styles$5.formulaHelpFunctionContent,style:{height:contentVisible?"unset":0,padding:contentVisible?"revert-layer":0},children:jsxRuntimeExports.jsxs("div",{className:styles$5.formulaHelpFunctionContentInner,children:[jsxRuntimeExports.jsx(Params,{title:localeService.t("formula.prompt.helpExample"),value:`${functionInfo.functionName}(${functionInfo.functionParameter.map(item=>item.example).join(",")})`}),jsxRuntimeExports.jsx(Params,{title:localeService.t("formula.prompt.helpAbstract"),value:functionInfo.description}),functionInfo&&functionInfo.functionParameter&&functionInfo.functionParameter.map((item,i)=>jsxRuntimeExports.jsx(Params,{className:paramIndex===i?styles$5.formulaHelpFunctionActive:"",title:item.name,value:`${item.require?required:optional} ${item.detail}`},i))]})})]}):jsxRuntimeExports.jsx(jsxRuntimeExports.Fragment,{})}):visible?jsxRuntimeExports.jsx("div",{className:styles$5.formulaHelpDecorator,onClick:__name(()=>setHelpVisible(!helpVisible),"onClick"),style:{left:decoratorPosition.left-24,top:decoratorPosition.top},children:jsxRuntimeExports.jsx(DetailsSingle,{})}):jsxRuntimeExports.jsx(jsxRuntimeExports.Fragment,{})})}__name(HelpFunction,"HelpFunction");const Params=__name(props=>jsxRuntimeExports.jsxs("div",{className:styles$5.formulaHelpFunctionContentParams,children:[jsxRuntimeExports.jsx("div",{className:`${styles$5.formulaHelpFunctionContentParamsTitle} ${props.className}`,children:props.title}),jsxRuntimeExports.jsx("div",{className:styles$5.formulaHelpFunctionContentParamsDetail,children:props.value})]}),"Params"),Help=__name(props=>{const{prefix,value,active,onClick}=props;return jsxRuntimeExports.jsxs("div",{className:styles$5.formulaHelpParam,children:[jsxRuntimeExports.jsxs("span",{className:styles$5.formulaHelpParamPrefix,children:[prefix,"("]}),value&&value.map((item,i)=>jsxRuntimeExports.jsxs("span",{className:styles$5.formulaHelpParamItem,children:[jsxRuntimeExports.jsx("span",{className:active===i?styles$5.formulaHelpFunctionActive:styles$5.formulaHelpParamActive,onClick:__name(()=>onClick(i),"onClick"),children:generateParam(item)}),i===value.length-1?"":","]},i)),")"]})},"Help"),formulaSearchFunction="univer-formula-search-function",formulaSearchFunctionItem="univer-formula-search-function-item",formulaSearchFunctionItemName="univer-formula-search-function-item-name",formulaSearchFunctionItemNameLight="univer-formula-search-function-item-name-light",formulaSearchFunctionItemDesc="univer-formula-search-function-item-desc",formulaSearchFunctionItemActive="univer-formula-search-function-item-active",styles$4={formulaSearchFunction,formulaSearchFunctionItem,formulaSearchFunctionItemName,formulaSearchFunctionItemNameLight,formulaSearchFunctionItemDesc,formulaSearchFunctionItemActive};function SearchFunction(){const[visible,setVisible]=require$$0.useState(!1),[active,setActive]=require$$0.useState(0),[offset,setOffset]=require$$0.useState([0,0]),[searchList,setSearchList]=require$$0.useState([]),[searchText,setSearchText]=require$$0.useState(""),ulRef=require$$0.useRef(null),promptService=core.useDependency(IFormulaPromptService),univerInstanceService=core.useDependency(core.IUniverInstanceService),editorService=core.useDependency(docsUi.IEditorService);require$$0.useEffect(()=>{let updatedSearchList=[],updatedActive=0;const subscribeSearch=promptService.search$.subscribe(params=>{const{visible:visible2,searchText:searchText2,searchList:searchList2}=params;if(!visible2){setVisible(visible2);return}const position=getPosition();if(position==null)return;const{left,top,height}=position;setSearchText(searchText2),setSearchList(searchList2),updatedSearchList=searchList2,setOffset([left,top+height]),setVisible(visible2),setActive(0),updatedActive=0}),subscribeNavigate=promptService.navigate$.subscribe(params=>{const{direction}=params;if(direction===core.Direction.UP){let nextActive=updatedActive-1;nextActive=nextActive<0?updatedSearchList.length-1:nextActive,setActive(nextActive),updatedActive=nextActive}else if(direction===core.Direction.DOWN){let nextActive=updatedActive+1;nextActive=nextActive>=updatedSearchList.length?0:nextActive,setActive(nextActive),updatedActive=nextActive}scrollToVisible(updatedActive)}),subscribeAccept=promptService.accept$.subscribe(params=>{const functionName=updatedSearchList[updatedActive].name;promptService.acceptFormulaName(functionName)});return()=>{subscribeSearch==null||subscribeSearch.unsubscribe(),subscribeNavigate==null||subscribeNavigate.unsubscribe(),subscribeAccept==null||subscribeAccept.unsubscribe()}},[]);function getPosition(){const editorUnitId=univerInstanceService.getCurrentUniverDocInstance().getUnitId();if(!editorService.isEditor(editorUnitId))return;const editor=editorService.getEditor(editorUnitId);return editor==null?void 0:editor.getBoundingClientRect()}__name(getPosition,"getPosition");function handleLiMouseEnter(index){setActive(index)}__name(handleLiMouseEnter,"handleLiMouseEnter");function handleLiMouseLeave(){setActive(-1)}__name(handleLiMouseLeave,"handleLiMouseLeave");function scrollToVisible(liIndex){var _a11;const liElement=(_a11=ulRef.current)==null?void 0:_a11.querySelectorAll(`.${styles$4.formulaSearchFunctionItem}`)[liIndex];if(!liElement)return;const ulElement=liElement.parentNode;if(!ulElement)return;const ulTop=ulElement.getBoundingClientRect().top,ulHeight=ulElement.offsetHeight,liRect=liElement.getBoundingClientRect(),liTop=liRect.top,liHeight=liRect.height;if(liTop>=0&&liTop>ulTop&&liTop-ulTop+liHeight<=ulHeight)return;const scrollTo=liElement.offsetTop-(ulHeight-liHeight)/2;ulElement.scrollTo({top:scrollTo,behavior:"smooth"})}return __name(scrollToVisible,"scrollToVisible"),searchList.length>0&&jsxRuntimeExports.jsx(design.Popup,{visible,offset,children:jsxRuntimeExports.jsx("ul",{className:styles$4.formulaSearchFunction,ref:ulRef,children:searchList.map((item,index)=>jsxRuntimeExports.jsxs("li",{className:active===index?`${styles$4.formulaSearchFunctionItem} ${styles$4.formulaSearchFunctionItemActive}`:styles$4.formulaSearchFunctionItem,onMouseEnter:__name(()=>handleLiMouseEnter(index),"onMouseEnter"),onMouseLeave:handleLiMouseLeave,onClick:__name(()=>promptService.acceptFormulaName(item.name),"onClick"),children:[jsxRuntimeExports.jsxs("span",{className:styles$4.formulaSearchFunctionItemName,children:[jsxRuntimeExports.jsx("span",{className:styles$4.formulaSearchFunctionItemNameLight,children:item.name.substring(0,searchText.length)}),jsxRuntimeExports.jsx("span",{children:item.name.slice(searchText.length)})]}),jsxRuntimeExports.jsx("span",{className:styles$4.formulaSearchFunctionItemDesc,children:item.desc})]},index))})})}__name(SearchFunction,"SearchFunction");function RenderFormulaPromptContent(){return jsxRuntimeExports.jsxs(jsxRuntimeExports.Fragment,{children:[jsxRuntimeExports.jsx(SearchFunction,{}),jsxRuntimeExports.jsx(HelpFunction,{})]})}__name(RenderFormulaPromptContent,"RenderFormulaPromptContent");const formulaMoreFunctions="univer-formula-more-functions",formulaMoreFunctionsOperation="univer-formula-more-functions-operation",styles$3={formulaMoreFunctions,formulaMoreFunctionsOperation};function FunctionHelp(props){const{prefix,value}=props;return jsxRuntimeExports.jsxs("div",{children:[jsxRuntimeExports.jsxs("span",{children:[prefix,"("]}),value&&value.map((item,i)=>jsxRuntimeExports.jsxs("span",{children:[jsxRuntimeExports.jsx("span",{children:generateParam(item)}),i===value.length-1?"":","]},i)),")"]})}__name(FunctionHelp,"FunctionHelp");const formulaFunctionParams="univer-formula-function-params",formulaFunctionParamsTitle="univer-formula-function-params-title",formulaFunctionParamsDetail="univer-formula-function-params-detail",styles$2={formulaFunctionParams,formulaFunctionParamsTitle,formulaFunctionParamsDetail};function FunctionParams(props){const{className,value,title}=props;return jsxRuntimeExports.jsxs("div",{className:styles$2.formulaFunctionParams,children:[jsxRuntimeExports.jsx("div",{className:`${styles$2.formulaFunctionParamsTitle} ${className}`,children:title}),jsxRuntimeExports.jsx("div",{className:styles$2.formulaFunctionParamsDetail,children:value})]})}__name(FunctionParams,"FunctionParams");const formulaInputParamsList="univer-formula-input-params-list",formulaInputParamsListItemName="univer-formula-input-params-list-item-name",formulaInputParamsListItemSelector="univer-formula-input-params-list-item-selector",styles$1={formulaInputParamsList,formulaInputParamsListItemName,formulaInputParamsListItemSelector};function InputParams(props){const{functionInfo,onChange}=props;if(!functionInfo)return null;require$$0.useState([]);const[functionParameter,setFunctionParameter]=require$$0.useState(functionInfo.functionParameter),[activeIndex,setActiveIndex]=require$$0.useState(-1);return jsxRuntimeExports.jsxs("div",{className:styles$1.formulaInputParams,children:[jsxRuntimeExports.jsx("div",{className:styles$1.formulaInputParamsList,children:functionParameter.map((item,i)=>jsxRuntimeExports.jsxs("div",{children:[jsxRuntimeExports.jsx("div",{className:styles$1.formulaInputParamsListItemName,children:item.name}),jsxRuntimeExports.jsx("div",{className:styles$1.formulaInputParamsListItemSelector})]},i))}),jsxRuntimeExports.jsx("div",{className:styles$1.formulaInputParamsInfo,children:jsxRuntimeExports.jsx(FunctionParams,{title:activeIndex===-1?jsxRuntimeExports.jsx(FunctionHelp,{prefix:functionInfo.functionName,value:functionParameter}):functionParameter[activeIndex].name,value:activeIndex===-1?functionInfo.description:functionParameter[activeIndex].detail})})]})}__name(InputParams,"InputParams");const formulaSelectFunctionSelect="univer-formula-select-function-select",formulaSelectFunctionResult="univer-formula-select-function-result",formulaSelectFunctionResultItem="univer-formula-select-function-result-item",formulaSelectFunctionResultItemNameLight="univer-formula-select-function-result-item-name-light",formulaSelectFunctionResultItemSelected="univer-formula-select-function-result-item-selected",formulaSelectFunctionResultItemActive="univer-formula-select-function-result-item-active",formulaSelectFunctionContent="univer-formula-select-function-content",styles={formulaSelectFunctionSelect,formulaSelectFunctionResult,formulaSelectFunctionResultItem,formulaSelectFunctionResultItemNameLight,formulaSelectFunctionResultItemSelected,formulaSelectFunctionResultItemActive,formulaSelectFunctionContent};function SelectFunction(props){const{onChange}=props,allTypeValue="-1",[searchText,setSearchText]=require$$0.useState(""),[selectList,setSelectList]=require$$0.useState([]),[active,setActive]=require$$0.useState(0),[typeSelected,setTypeSelected]=require$$0.useState(allTypeValue),[nameSelected,setNameSelected]=require$$0.useState(0),[functionInfo,setFunctionInfo]=require$$0.useState(null),descriptionService=core.useDependency(sheetsFormula.IDescriptionService),localeService=core.useDependency(core.LocaleService),sidebarService=core.useDependency(ui.ISidebarService),sidebarOptions=core.useObservable(sidebarService.sidebarOptions$),options=getFunctionTypeValues(engineFormula.FunctionType,localeService);options.unshift({label:localeService.t("formula.moreFunctions.allFunctions"),value:allTypeValue});const required=localeService.t("formula.prompt.required"),optional=localeService.t("formula.prompt.optional");require$$0.useEffect(()=>{handleSelectChange(allTypeValue)},[]),require$$0.useEffect(()=>{setCurrentFunctionInfo(0)},[selectList]),require$$0.useEffect(()=>{sidebarOptions!=null&&sidebarOptions.visible&&(setSearchText(""),setSelectList([]),setActive(0),setTypeSelected(allTypeValue),setNameSelected(0),setFunctionInfo(null),handleSelectChange(allTypeValue))},[sidebarOptions]);const highlightSearchText=__name(text=>{if(searchText.trim()==="")return text;const regex=new RegExp(`(${searchText.toLocaleUpperCase()})`);return text.split(regex).filter(Boolean).map((part,index)=>part.match(regex)?jsxRuntimeExports.jsx("span",{className:styles.formulaSelectFunctionResultItemNameLight,children:part},index):part)},"highlightSearchText"),setCurrentFunctionInfo=__name(selectedIndex=>{if(selectList.length===0){setFunctionInfo(null);return}setNameSelected(selectedIndex);const functionInfo2=descriptionService.getFunctionInfo(selectList[selectedIndex].name);if(!functionInfo2){setFunctionInfo(null);return}setFunctionInfo(functionInfo2),onChange(functionInfo2)},"setCurrentFunctionInfo");function handleSelectChange(value){setTypeSelected(value);const selectList2=descriptionService.getSearchListByType(+value);setSelectList(selectList2)}__name(handleSelectChange,"handleSelectChange");function handleSearchInputChange(value){setSearchText(value);const selectList2=descriptionService.getSearchListByName(value);setSelectList(selectList2)}__name(handleSearchInputChange,"handleSearchInputChange");function handleSelectListKeyDown(e){if(e.stopPropagation(),e.key==="ArrowDown"){const nextActive=active+1;setActive(nextActive===selectList.length?0:nextActive)}else if(e.key==="ArrowUp"){const nextActive=active-1;setActive(nextActive===-1?selectList.length-1:nextActive)}else e.key==="Enter"&&setCurrentFunctionInfo(active)}__name(handleSelectListKeyDown,"handleSelectListKeyDown");const handleLiMouseEnter=__name(index=>{setActive(index)},"handleLiMouseEnter"),handleLiMouseLeave=__name(()=>{setActive(-1)},"handleLiMouseLeave");return jsxRuntimeExports.jsxs("div",{children:[jsxRuntimeExports.jsxs("div",{className:styles.formulaSelectFunctionSelect,children:[jsxRuntimeExports.jsx(design.Select,{value:typeSelected,options,onChange:handleSelectChange}),jsxRuntimeExports.jsx(design.Input,{placeholder:localeService.t("formula.moreFunctions.searchFunctionPlaceholder"),onKeyDown:handleSelectListKeyDown,value:searchText,onChange:handleSearchInputChange,size:"large",allowClear:!0})]}),jsxRuntimeExports.jsx("ul",{className:styles.formulaSelectFunctionResult,onKeyDown:handleSelectListKeyDown,tabIndex:-1,children:selectList.map(({name},index)=>jsxRuntimeExports.jsxs("li",{className:active===index?`${styles.formulaSelectFunctionResultItem} ${styles.formulaSelectFunctionResultItemActive}`:styles.formulaSelectFunctionResultItem,onMouseEnter:__name(()=>handleLiMouseEnter(index),"onMouseEnter"),onMouseLeave:handleLiMouseLeave,onClick:__name(()=>setCurrentFunctionInfo(index),"onClick"),children:[nameSelected===index&&jsxRuntimeExports.jsx(CheckMarkSingle,{className:styles.formulaSelectFunctionResultItemSelected}),jsxRuntimeExports.jsx("span",{className:styles.formulaSelectFunctionResultItemName,children:highlightSearchText(name)})]},index))}),functionInfo&&jsxRuntimeExports.jsxs("div",{className:styles.formulaSelectFunctionContent,children:[jsxRuntimeExports.jsx(FunctionParams,{title:functionInfo.functionName,value:functionInfo.description}),jsxRuntimeExports.jsx(FunctionParams,{title:localeService.t("formula.moreFunctions.syntax"),value:jsxRuntimeExports.jsx(FunctionHelp,{prefix:functionInfo.functionName,value:functionInfo.functionParameter})}),jsxRuntimeExports.jsx(FunctionParams,{title:localeService.t("formula.prompt.helpExample"),value:`${functionInfo.functionName}(${functionInfo.functionParameter.map(item=>item.example).join(",")})`}),functionInfo.functionParameter&&functionInfo.functionParameter.map((item,i)=>jsxRuntimeExports.jsx(FunctionParams,{title:item.name,value:`${item.require?required:optional} ${item.detail}`},i))]})]})}__name(SelectFunction,"SelectFunction");function MoreFunctions(){const workbook=sheetsUi.useActiveWorkbook(),[selectFunction,setSelectFunction]=require$$0.useState(!0),[inputParams,setInputParams]=require$$0.useState(!1),[functionInfo,setFunctionInfo]=require$$0.useState(null),localeService=core.useDependency(core.LocaleService),editorService=core.useDependency(docsUi.IEditorService);function handleClickNextPrev(){setSelectFunction(!selectFunction),setInputParams(!inputParams)}__name(handleClickNextPrev,"handleClickNextPrev");function handleConfirm(){editorService.setFormula(`=${functionInfo==null?void 0:functionInfo.functionName}(`)}return __name(handleConfirm,"handleConfirm"),jsxRuntimeExports.jsxs("div",{className:styles$3.formulaMoreFunctions,children:[selectFunction&&jsxRuntimeExports.jsx(SelectFunction,{onChange:setFunctionInfo}),inputParams&&jsxRuntimeExports.jsx(InputParams,{functionInfo,onChange:__name(()=>{},"onChange")}),jsxRuntimeExports.jsxs("div",{className:styles$3.formulaMoreFunctionsOperation,children:[inputParams&&jsxRuntimeExports.jsx(design.Button,{type:"primary",size:"small",onClick:handleClickNextPrev,children:localeService.t("formula.moreFunctions.next")}),inputParams&&jsxRuntimeExports.jsx(design.Button,{size:"small",onClick:handleClickNextPrev,children:localeService.t("formula.moreFunctions.prev")}),selectFunction&&!!workbook&&jsxRuntimeExports.jsx(design.Button,{type:"primary",size:"small",onClick:handleConfirm,children:localeService.t("formula.moreFunctions.confirm")})]})]})}__name(MoreFunctions,"MoreFunctions");function InsertFunctionMenuItemFactory(accessor){return{id:InsertFunctionOperation.id,icon:"FunctionSingle",tooltip:"formula.insert.tooltip",type:ui.MenuItemType.SELECTOR,selections:[{label:"SUM",value:"SUM",icon:"SumSingle"},{label:"AVERAGE",value:"AVERAGE",icon:"AvgSingle"},{label:"COUNT",value:"COUNT",icon:"CntSingle"},{label:"MAX",value:"MAX",icon:"MaxSingle"},{label:"MIN",value:"MIN",icon:"MinSingle"}],hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET),disabled$:sheetsUi.getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellValuePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(InsertFunctionMenuItemFactory,"InsertFunctionMenuItemFactory");function MoreFunctionsMenuItemFactory(accessor){return{id:MoreFunctionsOperation.id,title:"formula.insert.more",type:ui.MenuItemType.BUTTON}}__name(MoreFunctionsMenuItemFactory,"MoreFunctionsMenuItemFactory");function menuClipboardDisabledObservable(injector){return injector.get(core.IUniverInstanceService).getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET).pipe(rxjs.switchMap(workbook=>workbook&&injector.get(ui.IClipboardInterfaceService)?new rxjs.Observable(subscriber=>subscriber.next(!injector.get(ui.IClipboardInterfaceService).supportClipboard)):rxjs.of(!0)))}__name(menuClipboardDisabledObservable,"menuClipboardDisabledObservable");function PasteFormulaMenuItemFactory(accessor){return{id:SheetOnlyPasteFormulaCommand.id,type:ui.MenuItemType.BUTTON,title:"formula.operation.pasteFormula",disabled$:menuClipboardDisabledObservable(accessor).pipe(rxjs.combineLatestWith(sheetsUi.getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetSetCellValuePermission,sheets.WorksheetEditPermission]})),rxjs.map(([d1,d2])=>d1||d2))}}__name(PasteFormulaMenuItemFactory,"PasteFormulaMenuItemFactory");const menuSchema={[ui.RibbonStartGroup.FORMULAS_INSERT]:{[InsertFunctionOperation.id]:{order:1,menuItemFactory:InsertFunctionMenuItemFactory,[MoreFunctionsOperation.id]:{order:1,menuItemFactory:MoreFunctionsMenuItemFactory}}},[sheetsUi.PASTE_SPECIAL_MENU_ID]:{[SheetOnlyPasteFormulaCommand.id]:{order:4,menuItemFactory:PasteFormulaMenuItemFactory}}},META_KEY_CTRL_AND_SHIFT="meta_key_ctrl_And_Shift",PROMPT_SELECTION_KEYCODE_ARROW_LIST=[ui.KeyCode.ARROW_DOWN,ui.KeyCode.ARROW_UP,ui.KeyCode.ARROW_LEFT,ui.KeyCode.ARROW_RIGHT],PROMPT_SELECTION_KEYCODE_LIST=[...PROMPT_SELECTION_KEYCODE_ARROW_LIST,ui.KeyCode.ENTER,ui.KeyCode.TAB,ui.KeyCode.ESC];function promptSelectionShortcutItem(){const shortcutList=[];for(const keycode of PROMPT_SELECTION_KEYCODE_LIST)shortcutList.push({id:SelectEditorFormulaOperation.id,binding:keycode,preconditions:__name(contextService=>sheetsUi.whenFormulaEditorActivated(contextService),"preconditions"),staticParameters:{eventType:engineRender.DeviceInputEventType.Keyboard,keycode}});return shortcutList}__name(promptSelectionShortcutItem,"promptSelectionShortcutItem");function promptSelectionShortcutItemShift(){const shortcutList=[];for(const keycode of PROMPT_SELECTION_KEYCODE_ARROW_LIST)shortcutList.push({id:SelectEditorFormulaOperation.id,binding:keycode|ui.MetaKeys.SHIFT,preconditions:__name(contextService=>sheetsUi.whenFormulaEditorActivated(contextService),"preconditions"),staticParameters:{eventType:engineRender.DeviceInputEventType.Keyboard,keycode,metaKey:ui.MetaKeys.SHIFT}});return shortcutList}__name(promptSelectionShortcutItemShift,"promptSelectionShortcutItemShift");function promptSelectionShortcutItemCtrl(){const shortcutList=[];for(const keycode of PROMPT_SELECTION_KEYCODE_ARROW_LIST)shortcutList.push({id:SelectEditorFormulaOperation.id,binding:keycode|ui.MetaKeys.CTRL_COMMAND,preconditions:__name(contextService=>sheetsUi.whenFormulaEditorActivated(contextService),"preconditions"),staticParameters:{eventType:engineRender.DeviceInputEventType.Keyboard,keycode,metaKey:ui.MetaKeys.CTRL_COMMAND}});return shortcutList}__name(promptSelectionShortcutItemCtrl,"promptSelectionShortcutItemCtrl");function promptSelectionShortcutItemCtrlAndShift(){const shortcutList=[];for(const keycode of PROMPT_SELECTION_KEYCODE_ARROW_LIST)shortcutList.push({id:SelectEditorFormulaOperation.id,binding:keycode|ui.MetaKeys.SHIFT|ui.MetaKeys.CTRL_COMMAND,preconditions:__name(contextService=>sheetsUi.whenFormulaEditorActivated(contextService),"preconditions"),staticParameters:{eventType:engineRender.DeviceInputEventType.Keyboard,keycode,metaKey:META_KEY_CTRL_AND_SHIFT}});return shortcutList}__name(promptSelectionShortcutItemCtrlAndShift,"promptSelectionShortcutItemCtrlAndShift");const ChangeRefToAbsoluteShortcut={id:ReferenceAbsoluteOperation.id,binding:ui.KeyCode.F4,preconditions:__name(contextService=>sheetsUi.whenFormulaEditorActivated(contextService),"preconditions")};function singleEditorPromptSelectionShortcutItem(){const shortcutList=[];for(const keycode of[ui.KeyCode.ENTER,ui.KeyCode.TAB,ui.KeyCode.ARROW_DOWN,ui.KeyCode.ARROW_UP])shortcutList.push({id:SelectEditorFormulaOperation.id,binding:keycode,preconditions:__name(contextService=>whenEditorStandalone(contextService),"preconditions"),staticParameters:{eventType:engineRender.DeviceInputEventType.Keyboard,keycode,isSingleEditor:!0}});return shortcutList}__name(singleEditorPromptSelectionShortcutItem,"singleEditorPromptSelectionShortcutItem");var __defProp$2=Object.defineProperty,__getOwnPropDesc$2=Object.getOwnPropertyDescriptor,__decorateClass$2=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$2(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$2(target,key,result),result},"__decorateClass$2"),__decorateParam$2=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$2"),_a8;let FormulaUIController=(_a8=class extends core.Disposable{constructor(_injector,_menuManagerService,_commandService,_shortcutService,_uiPartsService,_renderManagerService,_componentManager){super(),this._injector=_injector,this._menuManagerService=_menuManagerService,this._commandService=_commandService,this._shortcutService=_shortcutService,this._uiPartsService=_uiPartsService,this._renderManagerService=_renderManagerService,this._componentManager=_componentManager,this._initialize()}_initialize(){this._registerCommands(),this._registerMenus(),this._registerShortcuts(),this._registerComponents(),this._registerRenderModules()}_registerMenus(){this._menuManagerService.mergeMenu(menuSchema)}_registerCommands(){[SheetOnlyPasteFormulaCommand,InsertFunctionOperation,MoreFunctionsOperation,SearchFunctionOperation,HelpFunctionOperation,SelectEditorFormulaOperation,ReferenceAbsoluteOperation].forEach(command=>this.disposeWithMe(this._commandService.registerCommand(command)))}_registerShortcuts(){[...promptSelectionShortcutItem(),...promptSelectionShortcutItemShift(),...promptSelectionShortcutItemCtrl(),...promptSelectionShortcutItemCtrlAndShift(),...singleEditorPromptSelectionShortcutItem(),ChangeRefToAbsoluteShortcut].forEach(item=>{this.disposeWithMe(this._shortcutService.registerShortcut(item))})}_registerComponents(){this.disposeWithMe(this._uiPartsService.registerComponent(ui.BuiltInUIPart.CONTENT,()=>core.connectInjector(RenderFormulaPromptContent,this._injector))),this._componentManager.register(MORE_FUNCTIONS_COMPONENT,MoreFunctions)}_registerRenderModules(){this.disposeWithMe(this._renderManagerService.registerRenderModule(core.UniverInstanceType.UNIVER_SHEET,[FormulaEditorShowController]))}},__name(_a8,"FormulaUIController"),_a8);FormulaUIController=__decorateClass$2([__decorateParam$2(0,core.Inject(core.Injector)),__decorateParam$2(1,ui.IMenuManagerService),__decorateParam$2(2,core.ICommandService),__decorateParam$2(3,ui.IShortcutService),__decorateParam$2(4,ui.IUIPartsService),__decorateParam$2(5,engineRender.IRenderManagerService),__decorateParam$2(6,core.Inject(ui.ComponentManager))],FormulaUIController);function getFormulaRefSelectionStyle(themeService,refColor,id){const style=themeService.getCurrentTheme(),fill=new core.ColorKit(refColor).setAlpha(.05).toRgbString();return{id,strokeWidth:1,stroke:refColor,fill,widgets:{tl:!0,tc:!0,tr:!0,ml:!0,mr:!0,bl:!0,bc:!0,br:!0},widgetSize:6,widgetStrokeWidth:1,widgetStroke:style.colorWhite,hasAutoFill:!1,hasRowHeader:!1,hasColumnHeader:!1}}__name(getFormulaRefSelectionStyle,"getFormulaRefSelectionStyle");var __defProp$1=Object.defineProperty,__getOwnPropDesc$1=Object.getOwnPropertyDescriptor,__decorateClass$1=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$1(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$1(target,key,result),result},"__decorateClass$1"),__decorateParam$1=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$1");const sheetEditorUnitIds=[core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY,core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY];var _a9;let PromptController=(_a9=class extends core.Disposable{constructor(_commandService,_contextService,_editorBridgeService,_formulaPromptService,_lexerTreeBuilder,_renderManagerService,_themeService,_sheetsSelectionsService,_refSelectionsService,_univerInstanceService,_descriptionService,_docSelectionManagerService,_contextMenuService,_editorService,_layoutService){super();__publicField(this,"_listenInputCache",new Set);__publicField(this,"_formulaRefColors",[]);__publicField(this,"_previousSequenceNodes");__publicField(this,"_previousRangesCount",0);__publicField(this,"_previousInsertRefStringIndex");__publicField(this,"_currentInsertRefStringIndex",-1);__publicField(this,"_arrowMoveActionState",0);__publicField(this,"_isSelectionMovingRefSelections",[]);__publicField(this,"_stringColor","");__publicField(this,"_numberColor","");__publicField(this,"_insertSelections",[]);__publicField(this,"_inputPanelState",0);__publicField(this,"_userCursorMove",!1);__publicField(this,"_previousEditorUnitId");__publicField(this,"_existsSequenceNode",!1);__publicField(this,"_currentlyWorkingRefRenderer",null);__publicField(this,"_selectionsChangeDisposables");__publicField(this,"_isSelectingMode",!1);this._commandService=_commandService,this._contextService=_contextService,this._editorBridgeService=_editorBridgeService,this._formulaPromptService=_formulaPromptService,this._lexerTreeBuilder=_lexerTreeBuilder,this._renderManagerService=_renderManagerService,this._themeService=_themeService,this._sheetsSelectionsService=_sheetsSelectionsService,this._refSelectionsService=_refSelectionsService,this._univerInstanceService=_univerInstanceService,this._descriptionService=_descriptionService,this._docSelectionManagerService=_docSelectionManagerService,this._contextMenuService=_contextMenuService,this._editorService=_editorService,this._layoutService=_layoutService,this._initialize()}get _selectionRenderService(){return this._renderManagerService.getRenderById(this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getUnitId()).with(exports.RefSelectionsRenderService)}get _allSelectionRenderServices(){return this._renderManagerService.getAllRenderersOfType(core.UniverInstanceType.UNIVER_SHEET).map(renderer=>renderer.with(exports.RefSelectionsRenderService))}dispose(){this._formulaRefColors=[],this._resetTemp()}_resetTemp(){this._previousSequenceNodes=null,this._previousInsertRefStringIndex=null,this._isSelectionMovingRefSelections=[],this._previousRangesCount=0,this._currentInsertRefStringIndex=-1}_initialize(){this._initialCursorSync(),this._initAcceptFormula(),this._initialFormulaTheme(),this._initSelectionsEndListener(),this._closeRangePromptWhenEditorInvisible(),this._initialEditorInputChange(),this._commandExecutedListener(),this._cursorStateListener(),this._inputFormulaListener(),this._userMouseListener(),this._initialChangeEditor()}_initialFormulaTheme(){const style=this._themeService.getCurrentTheme();this._formulaRefColors=[style.loopColor1,style.loopColor2,style.loopColor3,style.loopColor4,style.loopColor5,style.loopColor6,style.loopColor7,style.loopColor8,style.loopColor9,style.loopColor10,style.loopColor11,style.loopColor12],this._numberColor=style.hyacinth700,this._stringColor=style.verdancy800}_initialCursorSync(){this.disposeWithMe(this._docSelectionManagerService.textSelection$.pipe(rxjs.filter(item=>!sheetsUi.isRangeSelector(item.unitId))).subscribe(params=>{var _a11;if((params==null?void 0:params.unitId)==null)return;const editor=this._editorService.getEditor(params.unitId);if(!editor||editor.onlyInputContent()||editor.isSheetEditor()&&!this._isFormulaEditorActivated()||editor.params.scrollBar)return;const onlyInputRange=editor.onlyInputRange();(_a11=params==null?void 0:params.options)!=null&&_a11.fromSelection||(this._quitSelectingMode(),this._contextSwitch(),this._checkShouldEnterSelectingMode(onlyInputRange),!this._formulaPromptService.isLockedSelectionChange()&&(this._highlightFormula(),!onlyInputRange&&this._changeFunctionPanelState()))}))}_initialEditorInputChange(){const arrows=[ui.KeyCode.ARROW_DOWN,ui.KeyCode.ARROW_UP,ui.KeyCode.ARROW_LEFT,ui.KeyCode.ARROW_RIGHT,ui.KeyCode.CTRL,ui.KeyCode.SHIFT];this._univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_DOC).subscribe(documentDataModel=>{var _a11;const unitId=documentDataModel==null?void 0:documentDataModel.getUnitId();if(unitId==null||sheetsUi.isRangeSelector(unitId)||this._listenInputCache.has(unitId)||this._editorService.getEditor(unitId)==null)return;const docSelectionRenderService=(_a11=this._renderManagerService.getRenderById(unitId))==null?void 0:_a11.with(docsUi.DocSelectionRenderService);docSelectionRenderService&&this.disposeWithMe(docSelectionRenderService.onInputBefore$.subscribe(param=>{this._previousSequenceNodes=null,this._previousInsertRefStringIndex=null,this._selectionRenderService.setSkipLastEnabled(!0);const event=param==null?void 0:param.event;event&&(arrows.includes(event.which)?this._inputPanelState=2:(this._arrowMoveActionState!==1&&(this._arrowMoveActionState=2),this._inputPanelState=1),event.which!==ui.KeyCode.F4&&(this._userCursorMove=!1))})),this._listenInputCache.add(unitId)})}_closeRangePromptWhenEditorInvisible(){this.disposeWithMe(this._editorBridgeService.afterVisible$.pipe(rxjs.distinctUntilKeyChanged("visible")).subscribe(visibleParam=>{visibleParam.visible||this._closeRangePrompt()})),this.disposeWithMe(this._contextService.subscribeContextValue$(core.FORMULA_EDITOR_ACTIVATED).pipe(rxjs.distinctUntilChanged()).subscribe(activated=>{activated||this._closeRangePrompt()}))}_initialChangeEditor(){this.disposeWithMe(this._univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_DOC).subscribe(documentDataModel=>{if(documentDataModel==null)return;const editorId=documentDataModel.getUnitId();sheetsUi.isRangeSelector(editorId)||!this._editorService.isEditor(editorId)||this._previousEditorUnitId===editorId||this._editorService.isSheetEditor(editorId)||(this._closeRangePrompt(editorId),this._previousEditorUnitId=editorId)})),this.disposeWithMe(this._editorService.closeRangePrompt$.subscribe(()=>{(!this._editorService.getSpreadsheetFocusState()||!this._formulaPromptService.isLockedSelectionInsert())&&this._closeRangePrompt()}))}_closeRangePrompt(editorId){this._insertSelections=[],this._refSelectionsService.clear(),editorId&&this._editorService.isSheetEditor(editorId)&&this._updateEditorModel(`\r
|
|
11
|
+
`,rangesSet(refSelections)}const selection=editor.getSelectionRanges(),cloneData={...data,body:cloneBody};editor.setDocumentData(cloneData,selection)},[editorId,sequenceNodes,colorMap]),ranges}__name(useDocHight,"useDocHight");function useColor(){const style=core.useDependency(core.ThemeService).getCurrentTheme();return require$$0.useMemo(()=>{const formulaRefColors=[style.loopColor1,style.loopColor2,style.loopColor3,style.loopColor4,style.loopColor5,style.loopColor6,style.loopColor7,style.loopColor8,style.loopColor9,style.loopColor10,style.loopColor11,style.loopColor12],numberColor=style.hyacinth700,stringColor=style.verdancy800;return{formulaRefColors,numberColor,stringColor}},[style])}__name(useColor,"useColor");function buildTextRuns(descriptionService,colorMap,sequenceNodes){const{formulaRefColors,numberColor,stringColor}=colorMap,textRuns=[],refSelections=[],themeColorMap=new Map;let refColorIndex=0;for(let i=0,len=sequenceNodes.length;i<len;i++){const node=sequenceNodes[i];if(typeof node=="string"){const theLastItem=textRuns[textRuns.length-1],start=theLastItem?theLastItem.ed:0,end=start+node.length;textRuns.push({st:start,ed:end});continue}if(descriptionService.hasDefinedNameDescription(node.token.trim()))continue;const{startIndex,endIndex,nodeType,token}=node;let themeColor="";if(nodeType===engineFormula.sequenceNodeType.REFERENCE){if(themeColorMap.has(token))themeColor=themeColorMap.get(token);else{const colorIndex=refColorIndex%formulaRefColors.length;themeColor=formulaRefColors[colorIndex],themeColorMap.set(token,themeColor),refColorIndex++}refSelections.push({refIndex:i,themeColor,token})}else nodeType===engineFormula.sequenceNodeType.NUMBER?themeColor=numberColor:(nodeType===engineFormula.sequenceNodeType.STRING||nodeType===engineFormula.sequenceNodeType.ARRAY)&&(themeColor=stringColor);themeColor&&themeColor.length>0&&textRuns.push({st:startIndex,ed:endIndex+1,ts:{cl:{rgb:themeColor}}})}return{textRuns,refSelections}}__name(buildTextRuns,"buildTextRuns");function getFormulaRefSelectionStyle$1(themeService,refColor,id){const style=themeService.getCurrentTheme(),fill=new core.ColorKit(refColor).setAlpha(.05).toRgbString();return{id,strokeWidth:1,stroke:refColor,fill,widgets:{tl:!0,tc:!0,tr:!0,ml:!0,mr:!0,bl:!0,bc:!0,br:!0},widgetSize:6,widgetStrokeWidth:1,widgetStroke:style.colorWhite,hasAutoFill:!1,hasRowHeader:!1,hasColumnHeader:!1}}__name(getFormulaRefSelectionStyle$1,"getFormulaRefSelectionStyle$1");const useRefactorEffect=__name((isNeed,unitId,isOnlyOneRange)=>{const renderManagerService=core.useDependency(engineRender.IRenderManagerService),univerInstanceService=core.useDependency(core.IUniverInstanceService),contextService=core.useDependency(core.IContextService),editorBridgeService=core.useDependency(sheetsUi.IEditorBridgeService),sheetsSelectionsService=core.useDependency(sheets.SheetsSelectionsService),contextMenuService=core.useDependency(ui.IContextMenuService),render2=renderManagerService.getRenderById(unitId),refSelectionsRenderService=render2==null?void 0:render2.with(exports.RefSelectionsRenderService);require$$0.useEffect(()=>{if(isNeed){const d1=refSelectionsRenderService==null?void 0:refSelectionsRenderService.enableSelectionChanging();return contextService.setContextValue(sheets.DISABLE_NORMAL_SELECTIONS,!0),editorBridgeService.enableForceKeepVisible(),()=>{d1==null||d1.dispose(),contextService.setContextValue(sheets.DISABLE_NORMAL_SELECTIONS,!1),editorBridgeService.disableForceKeepVisible()}}},[isNeed]),require$$0.useLayoutEffect(()=>{if(isNeed){const workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),sheet=workbook==null?void 0:workbook.getActiveSheet(),selections=[...sheetsSelectionsService.getCurrentSelections()];return()=>{const workbook2=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),currentSheet=workbook2==null?void 0:workbook2.getActiveSheet();currentSheet&¤tSheet===sheet&&sheetsSelectionsService.setSelections(selections)}}},[isNeed]),require$$0.useEffect(()=>{if(isNeed)return contextMenuService.disable(),()=>{contextMenuService.enable()}},[isNeed]),require$$0.useEffect(()=>{isNeed&&(refSelectionsRenderService==null||refSelectionsRenderService.setSkipLastEnabled(!1))},[isNeed]),require$$0.useEffect(()=>{isOnlyOneRange?refSelectionsRenderService==null||refSelectionsRenderService.setRemainLastEnabled(!1):refSelectionsRenderService==null||refSelectionsRenderService.setRemainLastEnabled(!0)},[isOnlyOneRange])},"useRefactorEffect"),useResize=__name(editor=>{const resize=__name(()=>{if(editor){const{scene,mainComponent}=editor.render,docSkeletonManagerService=editor.render.with(docs.DocSkeletonManagerService),{width,height}=editor.getBoundingClientRect();docSkeletonManagerService.getViewModel().getDataModel().updateDocumentDataPageSize(1/0),scene.transformByState({width,height}),mainComponent==null||mainComponent.resize(width,height)}},"resize"),checkScrollBar=require$$0.useMemo(()=>core.debounce(()=>{var _a11;if(!editor)return;const skeleton=editor.render.with(docs.DocSkeletonManagerService).getSkeleton(),{scene,mainComponent}=editor.render,viewportMain=scene.getViewport(docsUi.VIEWPORT_KEY.VIEW_MAIN),{actualWidth}=skeleton.getActualSize(),{width,height}=editor.getBoundingClientRect();let scrollBar=viewportMain==null?void 0:viewportMain.getScrollBar();const contentWidth=Math.max(actualWidth,width),contentHeight=height;scene.transformByState({width:contentWidth,height:contentHeight}),mainComponent==null||mainComponent.resize(contentWidth,contentHeight),actualWidth>width?scrollBar==null?viewportMain&&new engineRender.ScrollBar(viewportMain,{barSize:8,enableVertical:!1}):viewportMain==null||viewportMain.resetCanvasSizeAndUpdateScroll():(scrollBar=null,viewportMain==null||viewportMain.scrollToBarPos({x:0,y:0}),(_a11=viewportMain==null?void 0:viewportMain.getScrollBar())==null||_a11.dispose())},30),[editor]);return require$$0.useEffect(()=>{if(editor){const time=setTimeout(()=>{resize(),checkScrollBar()},500);return()=>{clearTimeout(time)}}},[editor]),require$$0.useEffect(()=>{if(editor){const d=editor.input$.subscribe(()=>{checkScrollBar()});return()=>{d.unsubscribe()}}},[editor]),{resize,checkScrollBar}},"useResize"),isComma=__name(e=>typeof e=="string"?e===engineFormula.matchToken.COMMA:!1,"isComma"),isReference=__name(e=>{if(typeof e=="object")return e.nodeType===engineFormula.sequenceNodeType.REFERENCE},"isReference"),filterReferenceNode=__name(nodes=>nodes.filter(node=>isComma(node)||isReference(node)),"filterReferenceNode"),rangePreProcess=__name(range=>{if(range.endColumn<range.startColumn){const end=range.endColumn;range.endColumn=range.startColumn,range.startColumn=end}if(range.endRow<range.startRow){const end=range.endRow;range.endRow=range.startRow,range.startRow=end}return range},"rangePreProcess"),sequenceNodeToText=__name(sequenceNode=>sequenceNode.map(item=>typeof item=="string"?item:item.token).join(""),"sequenceNodeToText");function getSheetNameById(univerInstanceService,unitId,sheetId){var _a11,_b;return((_b=(_a11=univerInstanceService.getUnit(unitId))==null?void 0:_a11.getSheetBySheetId(sheetId))==null?void 0:_b.getName())||""}__name(getSheetNameById,"getSheetNameById");const unitRangesToText=__name((ranges,isSupportAcrossSheet=!1)=>isSupportAcrossSheet?ranges.map(item=>item.sheetName!==""?engineFormula.serializeRangeWithSheet(item.sheetName,item.range):engineFormula.serializeRange(item.range)):ranges.map(item=>engineFormula.serializeRange(item.range)),"unitRangesToText"),useSheetSelectionChange=__name((isNeed,unitId,_subUnitId,sequenceNodes,isSupportAcrossSheet,isOnlyOneRange,handleRangeChange)=>{const renderManagerService=core.useDependency(engineRender.IRenderManagerService),univerInstanceService=core.useDependency(core.IUniverInstanceService),isScalingRef=require$$0.useRef(!1),debounceReset=require$$0.useMemo(()=>core.debounce(()=>{isScalingRef.current=!1},300),[]),setIsScaling=__name(()=>{isScalingRef.current=!0,debounceReset()},"setIsScaling"),render2=renderManagerService.getRenderById(unitId),refSelectionsRenderService=render2==null?void 0:render2.with(exports.RefSelectionsRenderService),oldFilterReferenceNodes=require$$0.useRef([]),filterReferenceNodes=require$$0.useMemo(()=>{const newFilterReferenceNodes=filterReferenceNode(sequenceNodes),old=oldFilterReferenceNodes.current;return newFilterReferenceNodes.length===old.length?(old.splice(0),old.push(...newFilterReferenceNodes),old):newFilterReferenceNodes},[sequenceNodes]);oldFilterReferenceNodes.current=filterReferenceNodes,require$$0.useEffect(()=>{if(isNeed&&refSelectionsRenderService){let isFirst=!0;const handleSelectionsChange=__name(selections=>{var _a11;if(isFirst){isFirst=!1;return}const cloneSelectionList=[...selections],workbook=univerInstanceService.getUnit(unitId),currentSheetName=((_a11=workbook==null?void 0:workbook.getActiveSheet())==null?void 0:_a11.getName())||"",newSequenceNodes=filterReferenceNodes.map((node,index)=>{if(typeof node=="string"){if(!filterReferenceNodes[index-1])return null;const nextItem=filterReferenceNodes[index+1];return isComma(node)&&(isComma(nextItem)||index===filterReferenceNodes.length-1)?null:node}else if(node.nodeType===engineFormula.sequenceNodeType.REFERENCE){const unitRange=engineFormula.deserializeRangeWithSheet(node.token);unitRange.unitId=unitRange.unitId===""?unitId:unitRange.unitId,unitRange.sheetName=unitRange.sheetName===""?currentSheetName:unitRange.sheetName;const{unitId:rangeUnitId,sheetName:rangeSubName}=unitRange;if(isOnlyOneRange&&(rangeUnitId!==unitId||currentSheetName!==rangeSubName))return null;if(rangeUnitId===unitId&¤tSheetName===rangeSubName){const currentSelection=cloneSelectionList.shift();if(currentSelection&&getSheetNameById(univerInstanceService,unitId,currentSelection.rangeWithCoord.sheetId||"")===rangeSubName){const cloneNode={...node};return rangePreProcess(currentSelection.rangeWithCoord),isSupportAcrossSheet?cloneNode.token=engineFormula.serializeRangeWithSheet(currentSheetName,currentSelection.rangeWithCoord):cloneNode.token=engineFormula.serializeRange(currentSelection.rangeWithCoord),cloneNode}}return node}return null}).filter(e=>!!e),theLast=unitRangesToText(cloneSelectionList.map(e=>{var _a12,_b,_c;return{range:e.rangeWithCoord,unitId:(_a12=e.rangeWithCoord.unitId)!=null?_a12:"",sheetName:getSheetNameById(univerInstanceService,(_b=e.rangeWithCoord.unitId)!=null?_b:"",(_c=e.rangeWithCoord.sheetId)!=null?_c:"")}}),isSupportAcrossSheet).join(engineFormula.matchToken.COMMA),thePre=sequenceNodeToText(newSequenceNodes),result=`${thePre}${thePre&&theLast?engineFormula.matchToken.COMMA:""}${theLast}`,isScaling=isScalingRef.current;handleRangeChange(result,isScaling?-1:result.length)},"handleSelectionsChange"),d1=refSelectionsRenderService.selectionMoveEnd$.subscribe(selections=>{handleSelectionsChange(selections)}),d2=refSelectionsRenderService.selectionMoving$.pipe(operators.throttleTime(50)).subscribe(selections=>{handleSelectionsChange(selections)});return()=>{d1.unsubscribe(),d2.unsubscribe()}}},[isNeed,filterReferenceNodes,refSelectionsRenderService,isSupportAcrossSheet,isOnlyOneRange]),require$$0.useEffect(()=>{if(isNeed&&refSelectionsRenderService){const disposableCollection=new core.DisposableCollection,handleSequenceNodeReplace=__name((token,index)=>{var _a11;let currentIndex=0,offset=0,isFinish=!1;const workbook=univerInstanceService.getUnit(unitId),currentSheetName=((_a11=workbook==null?void 0:workbook.getActiveSheet())==null?void 0:_a11.getName())||"",newSequenceNodes=filterReferenceNodes.map(node=>{if(typeof node=="string")return isFinish||(offset+=node.length),node;if(node.nodeType===engineFormula.sequenceNodeType.REFERENCE){isFinish||(offset+=node.token.length);const unitRange=engineFormula.deserializeRangeWithSheet(token);if(unitRange.unitId=unitRange.unitId===""?unitId:unitRange.unitId,unitRange.sheetName=unitRange.sheetName===""?currentSheetName:unitRange.sheetName,currentIndex===index){isFinish=!0;const cloneNode={...node,token};return isSupportAcrossSheet?cloneNode.token=engineFormula.serializeRangeWithSheet(unitRange.sheetName,unitRange.range):cloneNode.token=engineFormula.serializeRange(unitRange.range),currentIndex++,cloneNode}return currentIndex++,node}return node}),result=sequenceNodeToText(newSequenceNodes);handleRangeChange(result,offset||-1)},"handleSequenceNodeReplace");let time=0;const dispose=refSelectionsRenderService.selectionMoveEnd$.subscribe(()=>{time=setTimeout(()=>{refSelectionsRenderService.getSelectionControls().forEach((control,index)=>{disposableCollection.add(control.selectionScaling$.subscribe(e=>{const rangeText=engineFormula.serializeRange(e);handleSequenceNodeReplace(rangeText,index),setIsScaling()})),disposableCollection.add(control.selectionMoving$.pipe(rxjs.map(e=>engineFormula.serializeRange(e)),rxjs.distinctUntilChanged()).subscribe(rangeText=>{handleSequenceNodeReplace(rangeText,index),setIsScaling()}))})},30)});return()=>{dispose.unsubscribe(),disposableCollection.dispose(),clearTimeout(time)}}},[isNeed,refSelectionsRenderService,filterReferenceNodes])},"useSheetSelectionChange"),verifyRange=__name(sequenceNodes=>!sequenceNodes.some(item=>{if(typeof item=="string"){if(item!==engineFormula.matchToken.COMMA)return!0}else if(item.nodeType!==engineFormula.sequenceNodeType.REFERENCE)return!0;return!1}),"verifyRange"),useVerify=__name((onVerify,sequenceNodes)=>{const isInitRender=require$$0.useRef(!0);require$$0.useEffect(()=>{const time=setTimeout(()=>{isInitRender.current=!1},500);return()=>{clearTimeout(time)}}),require$$0.useEffect(()=>{if(!isInitRender.current&&onVerify){const result=verifyRange(sequenceNodes);onVerify(result,sequenceNodeToText(sequenceNodes))}},[sequenceNodes,onVerify])},"useVerify"),sheetRangeSelectorTextWrap="univer-sheet-range-selector-text-wrap",sheetRangeSelectorPlaceholder="univer-sheet-range-selector-placeholder",sheetRangeSelectorError="univer-sheet-range-selector-error",sheetRangeSelectorErrorWrap="univer-sheet-range-selector-error-wrap",sheetRangeSelectorText="univer-sheet-range-selector-text",sheetRangeSelectorActive="univer-sheet-range-selector-active",sheetRangeSelectorIcon="univer-sheet-range-selector-icon",sheetRangeSelectorDialogItem="univer-sheet-range-selector-dialog-item",sheetRangeSelectorDialogItemDelete="univer-sheet-range-selector-dialog-item-delete",styles$6={sheetRangeSelectorTextWrap,sheetRangeSelectorPlaceholder,sheetRangeSelectorError,sheetRangeSelectorErrorWrap,sheetRangeSelectorText,sheetRangeSelectorActive,sheetRangeSelectorIcon,sheetRangeSelectorDialogItem,sheetRangeSelectorDialogItemDelete},noopFunction=__name(()=>{},"noopFunction");function RangeSelector(props){const{initValue,unitId,subUnitId,errorText,placeholder,actions,onChange=noopFunction,onVerify=noopFunction,onRangeSelectorDialogVisibleChange=noopFunction,onBlur=noopFunction,isFocus:_isFocus=!0,isOnlyOneRange=!1,isSupportAcrossSheet=!1}=props,editorService=core.useDependency(docsUi.IEditorService),localeService=core.useDependency(core.LocaleService),commandService=core.useDependency(core.ICommandService),lexerTreeBuilder=core.useDependency(engineFormula.LexerTreeBuilder),rangeSelectorWrapRef=require$$0.useRef(null),[rangeDialogVisible,rangeDialogVisibleSet]=require$$0.useState(!1),[isFocus,isFocusSet]=require$$0.useState(_isFocus),editorId=require$$0.useMemo(()=>core.createInternalEditorID(`${sheetsUi.RANGE_SELECTOR_SYMBOLS}-${core.generateRandomId(4)}`),[]),[editor,editorSet]=require$$0.useState(),containerRef=require$$0.useRef(null),[rangeString,rangeStringSet]=require$$0.useState(()=>typeof initValue=="string"?initValue:unitRangesToText(initValue,isSupportAcrossSheet).join(engineFormula.matchToken.COMMA));actions&&(actions.handleOutClick=(e,cb)=>{if(rangeSelectorWrapRef.current){const isContain=rangeSelectorWrapRef.current.contains(e.target);cb(isContain)}});const ranges=require$$0.useMemo(()=>rangeString.split(engineFormula.matchToken.COMMA).filter(e=>!!e).map(text=>engineFormula.deserializeRangeWithSheet(text)),[rangeString]),isError=require$$0.useMemo(()=>errorText!==void 0,[errorText]),handleInputDebounce=require$$0.useMemo(()=>core.debounce(text=>{const nodes=lexerTreeBuilder.sequenceNodesBuilder(text);if(nodes){if(verifyRange(nodes)){const preNodes=nodes.map(node=>{if(typeof node=="string")return node;if(node.nodeType===engineFormula.sequenceNodeType.REFERENCE){const unitRange=engineFormula.deserializeRangeWithSheet(node.token);unitRange.range=rangePreProcess(unitRange.range),isSupportAcrossSheet||(unitRange.sheetName="",unitRange.unitId=""),node.token=unitRangesToText([unitRange],isSupportAcrossSheet)[0]}return node}),result=sequenceNodeToText(preNodes);onChange(result)}}else rangeStringSet("")},30),[isSupportAcrossSheet]),handleConfirm=__name(ranges2=>{const text=unitRangesToText(ranges2,isSupportAcrossSheet).join(engineFormula.matchToken.COMMA);rangeStringSet(text),onChange(text),rangeDialogVisibleSet(!1),onRangeSelectorDialogVisibleChange(!1)},"handleConfirm"),handleClose=__name(()=>{rangeDialogVisibleSet(!1),onRangeSelectorDialogVisibleChange(!1)},"handleClose"),handleOpenModal=__name(()=>{isError||(rangeDialogVisibleSet(!0),onRangeSelectorDialogVisibleChange(!0))},"handleOpenModal"),focus=require$$0.useMemo(()=>{let time=0;return()=>{clearTimeout(time),editor&&(time=setTimeout(()=>{editor.focus()},30))}},[editor]),{checkScrollBar}=useResize(editor),handleSheetSelectionChange=require$$0.useMemo(()=>(text,offset)=>{rangeStringSet(text),onChange(text),focus(),offset!==-1&&setTimeout(()=>{const range={startOffset:offset,endOffset:offset};editor==null||editor.setSelectionRanges([range]);const docBackScrollRenderController=editor==null?void 0:editor.render.with(docsUi.DocBackScrollRenderController);docBackScrollRenderController==null||docBackScrollRenderController.scrollToRange({...range,collapsed:!0})},50),checkScrollBar()},[editor]),{sequenceNodes,sequenceNodesSet}=useFormulaToken(rangeString),sheetHighlightRanges=useDocHight(editorId,sequenceNodes);return useSheetHighlight(!rangeDialogVisible&&isFocus,unitId,subUnitId,sheetHighlightRanges),useSheetSelectionChange(!rangeDialogVisible&&isFocus,unitId,subUnitId,sequenceNodes,isSupportAcrossSheet,isOnlyOneRange,handleSheetSelectionChange),useRefactorEffect(!rangeDialogVisible&&isFocus,unitId,isOnlyOneRange),useEditorInput(unitId,rangeString,editor),useVerify(onVerify,sequenceNodes),require$$0.useEffect(()=>{if(editor){const dispose=editor.input$.subscribe(e=>{var _a11,_b;const text=((_b=(_a11=e.data.body)==null?void 0:_a11.dataStream)!=null?_b:"").replaceAll(/\n|\r/g,"").replaceAll(/,{2,}/g,",").replaceAll(/(^,)/g,"");rangeStringSet(text),handleInputDebounce(text)});return()=>{dispose.unsubscribe()}}},[editor]),require$$0.useEffect(()=>{const d1=commandService.beforeCommandExecuted(info=>{info.id===sheets.SetWorksheetActiveOperation.id&&!isSupportAcrossSheet&&(isFocusSet(!1),onBlur(),sequenceNodesSet(pre=>[...pre]))}),d2=commandService.onCommandExecuted(info=>{info.id===sheetsUi.SetCellEditVisibleOperation.id&&(rangeDialogVisibleSet(!1),onRangeSelectorDialogVisibleChange(!1),isFocusSet(!1),onBlur())});return()=>{d1.dispose(),d2.dispose()}},[isSupportAcrossSheet]),require$$0.useEffect(()=>{isFocusSet(_isFocus)},[_isFocus]),require$$0.useEffect(()=>{if(editor&&rangeDialogVisible){editor.blur();const d=editor.focus$.subscribe(()=>{editor.blur()});return()=>{d.unsubscribe()}}},[editor,rangeDialogVisible]),require$$0.useLayoutEffect(()=>{let dispose;if(containerRef.current){dispose=editorService.register({autofocus:!0,editorUnitId:editorId,isSingle:!0,initialSnapshot:{id:editorId,body:{dataStream:`\r
|
|
12
|
+
`},documentStyle:{}}},containerRef.current);const editor2=editorService.getEditor(editorId);editorSet(editor2)}return()=>{dispose==null||dispose.dispose()}},[containerRef.current]),jsxRuntimeExports.jsxs("div",{className:styles$6.sheetRangeSelector,ref:rangeSelectorWrapRef,children:[jsxRuntimeExports.jsxs("div",{className:clsx(styles$6.sheetRangeSelectorTextWrap,{[styles$6.sheetRangeSelectorActive]:isFocus&&!isError,[styles$6.sheetRangeSelectorError]:isError}),children:[jsxRuntimeExports.jsx("div",{className:styles$6.sheetRangeSelectorText,ref:containerRef}),jsxRuntimeExports.jsx(design.Tooltip,{title:localeService.t("rangeSelector.buttonTooltip"),placement:"bottom",children:jsxRuntimeExports.jsx(SelectRangeSingle,{className:styles$6.sheetRangeSelectorIcon,onClick:handleOpenModal})}),errorText!==void 0?jsxRuntimeExports.jsx("div",{className:styles$6.sheetRangeSelectorErrorWrap,children:errorText}):null,placeholder!==void 0&&!rangeString?jsxRuntimeExports.jsx("div",{className:styles$6.sheetRangeSelectorPlaceholder,children:placeholder}):null]}),rangeDialogVisible&&jsxRuntimeExports.jsx(RangeSelectorDialog,{handleConfirm,handleClose,unitId,subUnitId,initValue:ranges,visible:rangeDialogVisible,isOnlyOneRange,isSupportAcrossSheet})]})}__name(RangeSelector,"RangeSelector");function RangeSelectorDialog(props){const{handleConfirm,handleClose:_handleClose,visible,initValue,unitId,subUnitId,isOnlyOneRange,isSupportAcrossSheet}=props,localeService=core.useDependency(core.LocaleService),descriptionService=core.useDependency(sheetsFormula.IDescriptionService),lexerTreeBuilder=core.useDependency(engineFormula.LexerTreeBuilder),render2=core.useDependency(engineRender.IRenderManagerService).getRenderById(unitId),refSelectionsRenderService=render2==null?void 0:render2.with(exports.RefSelectionsRenderService),[ranges,rangesSet]=require$$0.useState(()=>{if(isOnlyOneRange){const firstRange=initValue[0];return firstRange?unitRangesToText([firstRange],isSupportAcrossSheet):[""]}return unitRangesToText(initValue,isSupportAcrossSheet)}),[focusIndex,focusIndexSet]=require$$0.useState(()=>ranges.length-1),colorMap=useColor(),rangeText=require$$0.useMemo(()=>ranges.join(engineFormula.matchToken.COMMA),[ranges]),{sequenceNodes,sequenceNodesSet}=useFormulaToken(rangeText),refSelections=require$$0.useMemo(()=>buildTextRuns(descriptionService,colorMap,sequenceNodes).refSelections,[sequenceNodes]),handleClose=__name(()=>{sequenceNodesSet([]),setTimeout(()=>{_handleClose()},30)},"handleClose"),handleRangeInput=__name((index,value)=>{value?refSelectionsRenderService==null||refSelectionsRenderService.setSkipLastEnabled(!1):refSelectionsRenderService==null||refSelectionsRenderService.setSkipLastEnabled(!0),rangesSet(v=>{const result=[...v];return result[index]=value,result})},"handleRangeInput"),handleRangeRemove=__name(index=>{refSelectionsRenderService==null||refSelectionsRenderService.setSkipLastEnabled(!1),rangesSet(v=>{if(v.length===1)return v;const result=[];return v.forEach((r2,i)=>{index!==i&&result.push(r2)}),result})},"handleRangeRemove"),handleRangeAdd=__name(()=>{refSelectionsRenderService==null||refSelectionsRenderService.setSkipLastEnabled(!0),rangesSet(v=>(v.push(""),focusIndexSet(v.length-1),[...v]))},"handleRangeAdd"),handleSheetSelectionChange=require$$0.useCallback(rangeText2=>{var _a11;refSelectionsRenderService==null||refSelectionsRenderService.setSkipLastEnabled(!1);const ranges2=rangeText2.split(engineFormula.matchToken.COMMA).filter(e=>!!e);rangesSet(isOnlyOneRange?[(_a11=ranges2[0])!=null?_a11:""]:ranges2)},[focusIndex,isOnlyOneRange]);return useSheetHighlight(visible,unitId,subUnitId,refSelections),useSheetSelectionChange(focusIndex>=0,unitId,subUnitId,sequenceNodes,isSupportAcrossSheet,isOnlyOneRange,handleSheetSelectionChange),useRefactorEffect(focusIndex>=0,unitId,isOnlyOneRange),require$$0.useEffect(()=>{(ranges.length===0||ranges.length===1&&!ranges[0])&&(refSelectionsRenderService==null||refSelectionsRenderService.setSkipLastEnabled(!0))},[ranges]),jsxRuntimeExports.jsx(design.Dialog,{width:"328px",visible,title:localeService.t("rangeSelector.title"),draggable:!0,closeIcon:jsxRuntimeExports.jsx(CloseSingle,{}),footer:jsxRuntimeExports.jsxs("footer",{children:[jsxRuntimeExports.jsx(design.Button,{onClick:handleClose,children:localeService.t("rangeSelector.cancel")}),jsxRuntimeExports.jsx(design.Button,{style:{marginLeft:10},onClick:__name(()=>handleConfirm(ranges.filter(text=>{const nodes=lexerTreeBuilder.sequenceNodesBuilder(text);return nodes&&nodes.length===1&&typeof nodes[0]!="string"&&nodes[0].nodeType===engineFormula.sequenceNodeType.REFERENCE}).map(text=>engineFormula.deserializeRangeWithSheet(text)).map(unitRange=>({...unitRange,range:rangePreProcess(unitRange.range)}))),"onClick"),type:"primary",children:localeService.t("rangeSelector.confirm")})]}),onClose:handleClose,children:jsxRuntimeExports.jsxs("div",{className:styles$6.sheetRangeSelectorDialog,children:[ranges.map((text,index)=>jsxRuntimeExports.jsxs("div",{className:styles$6.sheetRangeSelectorDialogItem,children:[jsxRuntimeExports.jsx(design.Input,{affixWrapperStyle:{width:"100%"},placeholder:localeService.t("rangeSelector.placeHolder"),onFocus:__name(()=>focusIndexSet(index),"onFocus"),value:text,onChange:__name(value=>handleRangeInput(index,value),"onChange")},`input_${index}`),ranges.length>1&&!isOnlyOneRange&&jsxRuntimeExports.jsx(DeleteSingle,{className:styles$6.sheetRangeSelectorDialogItemDelete,onClick:__name(()=>handleRangeRemove(index),"onClick")})]},index)),!isOnlyOneRange&&jsxRuntimeExports.jsx("div",{children:jsxRuntimeExports.jsxs(design.Button,{type:"link",size:"small",onClick:handleRangeAdd,children:[jsxRuntimeExports.jsx(IncreaseSingle,{}),jsxRuntimeExports.jsx("span",{children:localeService.t("rangeSelector.addAnotherRange")})]})})]})})}__name(RangeSelectorDialog,"RangeSelectorDialog");const PLUGIN_CONFIG_KEY_BASE="sheets-formula.base.config",defaultPluginBaseConfig={};function whenEditorStandalone(contextService){return contextService.getContextValue(core.FOCUSING_DOC)&&contextService.getContextValue(core.FOCUSING_UNIVER_EDITOR)&&contextService.getContextValue(core.FOCUSING_UNIVER_EDITOR_STANDALONE_SINGLE_MODE)}__name(whenEditorStandalone,"whenEditorStandalone");function extractFormulaError(cell,isArrayFormulaCell=!1){return!isArrayFormulaCell&&!(core.isFormulaString(cell==null?void 0:cell.f)||core.isFormulaId(cell==null?void 0:cell.si))?null:typeof(cell==null?void 0:cell.v)=="string"&&engineFormula.ERROR_TYPE_SET.has(cell.v)?cell.v:null}__name(extractFormulaError,"extractFormulaError");var __defProp$7=Object.defineProperty,__getOwnPropDesc$7=Object.getOwnPropertyDescriptor,__decorateClass$7=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$7(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$7(target,key,result),result},"__decorateClass$7"),__decorateParam$7=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$7");const ALERT_KEY="SHEET_FORMULA_ALERT",ErrorTypeToMessageMap={[engineFormula.ErrorType.DIV_BY_ZERO]:"divByZero",[engineFormula.ErrorType.NAME]:"name",[engineFormula.ErrorType.VALUE]:"value",[engineFormula.ErrorType.NUM]:"num",[engineFormula.ErrorType.NA]:"na",[engineFormula.ErrorType.CYCLE]:"cycle",[engineFormula.ErrorType.REF]:"ref",[engineFormula.ErrorType.SPILL]:"spill",[engineFormula.ErrorType.CALC]:"calc",[engineFormula.ErrorType.ERROR]:"error",[engineFormula.ErrorType.CONNECT]:"connect",[engineFormula.ErrorType.NULL]:"null"};var _a3;let FormulaAlertRenderController=(_a3=class extends core.Disposable{constructor(_context,_hoverManagerService,_cellAlertManagerService,_localeService,_formulaDataModel,_zenZoneService){super(),this._context=_context,this._hoverManagerService=_hoverManagerService,this._cellAlertManagerService=_cellAlertManagerService,this._localeService=_localeService,this._formulaDataModel=_formulaDataModel,this._zenZoneService=_zenZoneService,this._init()}_init(){this._initCellAlertPopup(),this._initZenService()}_initCellAlertPopup(){this.disposeWithMe(this._hoverManagerService.currentCell$.subscribe(cellPos=>{var _a11,_b,_c,_d,_e;if(cellPos){const worksheet=this._context.unit.getActiveSheet();if(!worksheet)return;const cellData=worksheet.getCell(cellPos.location.row,cellPos.location.col),arrayFormulaCellData=(_d=(_c=(_b=(_a11=this._formulaDataModel.getArrayFormulaCellData())==null?void 0:_a11[cellPos.location.unitId])==null?void 0:_b[cellPos.location.subUnitId])==null?void 0:_c[cellPos.location.row])==null?void 0:_d[cellPos.location.col];if(core.isICellData(cellData)){const errorType=extractFormulaError(cellData,!!arrayFormulaCellData);if(!errorType)return;const currentAlert=this._cellAlertManagerService.currentAlert.get(ALERT_KEY),currentLoc=(_e=currentAlert==null?void 0:currentAlert.alert)==null?void 0:_e.location;if(currentLoc&¤tLoc.row===cellPos.location.row&¤tLoc.col===cellPos.location.col&¤tLoc.subUnitId===cellPos.location.subUnitId&¤tLoc.unitId===cellPos.location.unitId)return;this._cellAlertManagerService.showAlert({type:sheetsUi.CellAlertType.ERROR,title:this._localeService.t("formula.error.title"),message:this._localeService.t(`formula.error.${ErrorTypeToMessageMap[errorType]}`),location:cellPos.location,width:200,height:74,key:ALERT_KEY});return}}this._cellAlertManagerService.removeAlert(ALERT_KEY)}))}_initZenService(){this.disposeWithMe(this._zenZoneService.visible$.subscribe(visible=>{visible&&this._cellAlertManagerService.removeAlert(ALERT_KEY)}))}},__name(_a3,"FormulaAlertRenderController"),_a3);FormulaAlertRenderController=__decorateClass$7([__decorateParam$7(1,core.Inject(sheetsUi.HoverManagerService)),__decorateParam$7(2,core.Inject(sheetsUi.CellAlertManagerService)),__decorateParam$7(3,core.Inject(core.LocaleService)),__decorateParam$7(4,core.Inject(engineFormula.FormulaDataModel)),__decorateParam$7(5,ui.IZenZoneService)],FormulaAlertRenderController);var __defProp$6=Object.defineProperty,__getOwnPropDesc$6=Object.getOwnPropertyDescriptor,__decorateClass$6=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$6(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$6(target,key,result),result},"__decorateClass$6"),__decorateParam$6=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$6"),_a4;let FormulaAutoFillController=(_a4=class extends core.Disposable{constructor(_autoFillService,_lexerTreeBuilder){super(),this._autoFillService=_autoFillService,this._lexerTreeBuilder=_lexerTreeBuilder,this._registerAutoFill()}_registerAutoFill(){const formulaRule={type:sheetsUi.DATA_TYPE.FORMULA,priority:1001,match:__name(cellData=>core.isFormulaString(cellData==null?void 0:cellData.f)||core.isFormulaId(cellData==null?void 0:cellData.si),"match"),isContinue:__name((prev,cur)=>prev.type===sheetsUi.DATA_TYPE.FORMULA,"isContinue"),applyFunctions:{[sheetsUi.APPLY_TYPE.COPY]:(dataWithIndex,len,direction,copyDataPiece)=>{const{data,index}=dataWithIndex;return this._fillCopyFormula(data,len,direction,index,copyDataPiece)}}};this._autoFillService.registerRule(formulaRule)}_fillCopyFormula(data,len,direction,index,copyDataPiece){var _a11,_b;const step=getDataLength(copyDataPiece),applyData=[],formulaIdMap=new Map;for(let i=1;i<=len;i++){const index2=(i-1)%data.length,d=core.Tools.deepClone(data[index2]);if(d){const originalFormula=((_a11=data[index2])==null?void 0:_a11.f)||"",originalFormulaId=((_b=data[index2])==null?void 0:_b.si)||"",checkFormula=core.isFormulaString(originalFormula);if(core.isFormulaId(originalFormulaId))d.si=originalFormulaId,d.f=null,d.v=null,d.p=null,d.t=null,direction===core.Direction.DOWN||direction===core.Direction.RIGHT?applyData.push(d):applyData.unshift(d);else if(checkFormula){let formulaId=formulaIdMap.get(index2);if(formulaId)d.si=formulaId,d.f=null,d.v=null,d.p=null,d.t=null;else{formulaId=core.Tools.generateRandomId(6),formulaIdMap.set(index2,formulaId);const{offsetX,offsetY}=directionToOffset(step,direction),shiftedFormula=this._lexerTreeBuilder.moveFormulaRefOffset(originalFormula,offsetX,offsetY);d.si=formulaId,d.f=shiftedFormula,d.v=null,d.p=null,d.t=null}direction===core.Direction.DOWN||direction===core.Direction.RIGHT?applyData.push(d):applyData.unshift(d)}}}return applyData}},__name(_a4,"FormulaAutoFillController"),_a4);FormulaAutoFillController=__decorateClass$6([__decorateParam$6(0,sheetsUi.IAutoFillService),__decorateParam$6(1,core.Inject(engineFormula.LexerTreeBuilder))],FormulaAutoFillController);function directionToOffset(step,direction){let offsetX=0,offsetY=0;switch(direction){case core.Direction.UP:offsetY=-step;break;case core.Direction.RIGHT:offsetX=step;break;case core.Direction.DOWN:offsetY=step;break;case core.Direction.LEFT:offsetX=-step;break}return{offsetX,offsetY}}__name(directionToOffset,"directionToOffset");function getDataLength(copyDataPiece){let length=0;for(const t in copyDataPiece)copyDataPiece[t].forEach(item=>{length+=item.data.length});return length}__name(getDataLength,"getDataLength");var __defProp$5=Object.defineProperty,__getOwnPropDesc$5=Object.getOwnPropertyDescriptor,__decorateClass$5=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$5(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$5(target,key,result),result},"__decorateClass$5"),__decorateParam$5=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$5");const DEFAULT_PASTE_FORMULA="default-paste-formula";var _a5;let FormulaClipboardController=(_a5=class extends core.Disposable{constructor(_currentUniverSheet,_lexerTreeBuilder,_sheetClipboardService,_injector,_formulaDataModel){super(),this._currentUniverSheet=_currentUniverSheet,this._lexerTreeBuilder=_lexerTreeBuilder,this._sheetClipboardService=_sheetClipboardService,this._injector=_injector,this._formulaDataModel=_formulaDataModel,this._initialize()}_initialize(){this._registerClipboardHook()}_registerClipboardHook(){this.disposeWithMe(this._sheetClipboardService.addClipboardHook(this._pasteFormulaHook())),this.disposeWithMe(this._sheetClipboardService.addClipboardHook(this._pasteWithFormulaHook()))}_pasteFormulaHook(){return{id:sheetsUi.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMULA,priority:10,specialPasteInfo:{label:"specialPaste.formula"},onPasteCells:__name((pasteFrom,pasteTo,data,payload)=>this._onPasteCells(pasteFrom,pasteTo,data,payload,!0),"onPasteCells")}}_pasteWithFormulaHook(){return{id:DEFAULT_PASTE_FORMULA,priority:10,onPasteCells:__name((pasteFrom,pasteTo,data,payload)=>this._onPasteCells(pasteFrom,pasteTo,data,payload,!1),"onPasteCells")}}_onPasteCells(pasteFrom,pasteTo,data,payload,isSpecialPaste){var _a11;if([sheetsUi.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMAT,sheetsUi.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_COL_WIDTH].includes(payload.pasteType))return{undos:[],redos:[]};const workbook=this._currentUniverSheet.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),unitId=pasteTo.unitId||workbook.getUnitId(),subUnitId=pasteTo.subUnitId||((_a11=workbook.getActiveSheet())==null?void 0:_a11.getSheetId());if(!unitId||!subUnitId)return{undos:[],redos:[]};const pastedRange=pasteTo.range,matrix=data,copyInfo={copyType:payload.copyType||sheetsUi.COPY_TYPE.COPY,copyRange:pasteFrom==null?void 0:pasteFrom.range,pasteType:payload.pasteType};return this._injector.invoke(accessor=>getSetCellFormulaMutations(unitId,subUnitId,pastedRange,matrix,accessor,copyInfo,this._lexerTreeBuilder,this._formulaDataModel,isSpecialPaste,pasteFrom))}},__name(_a5,"FormulaClipboardController"),_a5);FormulaClipboardController=__decorateClass$5([__decorateParam$5(0,core.IUniverInstanceService),__decorateParam$5(1,core.Inject(engineFormula.LexerTreeBuilder)),__decorateParam$5(2,sheetsUi.ISheetClipboardService),__decorateParam$5(3,core.Inject(core.Injector)),__decorateParam$5(4,core.Inject(engineFormula.FormulaDataModel))],FormulaClipboardController);function getSetCellFormulaMutations(unitId,subUnitId,range,matrix,accessor,copyInfo,lexerTreeBuilder,formulaDataModel,isSpecialPaste=!1,pasteFrom){const redoMutationsInfo=[],undoMutationsInfo=[],valueMatrix=getValueMatrix(unitId,subUnitId,range,matrix,copyInfo,lexerTreeBuilder,formulaDataModel,pasteFrom),setValuesMutation={unitId,subUnitId,cellValue:valueMatrix.getData()};redoMutationsInfo.push({id:sheets.SetRangeValuesMutation.id,params:setValuesMutation});const undoSetValuesMutation=sheets.SetRangeValuesUndoMutationFactory(accessor,setValuesMutation);return undoMutationsInfo.push({id:sheets.SetRangeValuesMutation.id,params:undoSetValuesMutation}),{undos:undoMutationsInfo,redos:redoMutationsInfo}}__name(getSetCellFormulaMutations,"getSetCellFormulaMutations");function getValueMatrix(unitId,subUnitId,range,matrix,copyInfo,lexerTreeBuilder,formulaDataModel,pasteFrom){return pasteFrom?copyInfo.pasteType===sheetsUi.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_VALUE?getSpecialPasteValueValueMatrix(unitId,subUnitId,range,matrix,formulaDataModel,pasteFrom):copyInfo.pasteType===sheetsUi.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMULA?getSpecialPasteFormulaValueMatrix(unitId,subUnitId,range,matrix,lexerTreeBuilder,formulaDataModel,pasteFrom):getDefaultPasteValueMatrix(unitId,subUnitId,range,matrix,lexerTreeBuilder,formulaDataModel,pasteFrom):getValueMatrixOfPasteFromIsNull(unitId,subUnitId,range,matrix,formulaDataModel)}__name(getValueMatrix,"getValueMatrix");function getValueMatrixOfPasteFromIsNull(unitId,subUnitId,range,matrix,formulaDataModel){var _a11,_b;const valueMatrix=new core.ObjectMatrix,formulaData=(_b=(_a11=formulaDataModel.getFormulaData())==null?void 0:_a11[unitId])==null?void 0:_b[subUnitId];return matrix.forValue((row,col,value)=>{var _a12;const toRow=range.rows[row],toCol=range.cols[col],valueObject={};core.isFormulaString(value.v)?(valueObject.v=null,valueObject.f=`${value.v}`,valueObject.si=null,valueObject.p=null,valueMatrix.setValue(toRow,toCol,valueObject)):(_a12=formulaData==null?void 0:formulaData[toRow])!=null&&_a12[toCol]&&(valueObject.v=value.v,valueObject.f=null,valueObject.si=null,valueObject.p=null,valueMatrix.setValue(toRow,toCol,valueObject))}),valueMatrix}__name(getValueMatrixOfPasteFromIsNull,"getValueMatrixOfPasteFromIsNull");function getSpecialPasteValueValueMatrix(unitId,subUnitId,range,matrix,formulaDataModel,pasteFrom){var _a11,_b,_c,_d;const valueMatrix=new core.ObjectMatrix,arrayFormulaCellData=(_b=(_a11=formulaDataModel.getArrayFormulaCellData())==null?void 0:_a11[pasteFrom.unitId])==null?void 0:_b[pasteFrom.subUnitId],formulaData=(_d=(_c=formulaDataModel.getFormulaData())==null?void 0:_c[unitId])==null?void 0:_d[subUnitId];return matrix.forValue((row,col,value)=>{var _a12,_b2;const fromRow=pasteFrom.range.rows[row%pasteFrom.range.rows.length],fromCol=pasteFrom.range.cols[col%pasteFrom.range.cols.length],toRow=range.rows[row],toCol=range.cols[col],valueObject={};if(core.isFormulaString(value.f)||core.isFormulaId(value.si))valueObject.v=value.v,valueObject.f=null,valueObject.si=null,valueObject.p=null,valueMatrix.setValue(toRow,toCol,valueObject);else if((_a12=arrayFormulaCellData==null?void 0:arrayFormulaCellData[fromRow])!=null&&_a12[fromCol]){const cell=arrayFormulaCellData[fromRow][fromCol];valueObject.v=cell.v,valueObject.f=null,valueObject.si=null,valueObject.p=null,valueMatrix.setValue(toRow,toCol,valueObject)}else if((_b2=formulaData==null?void 0:formulaData[toRow])!=null&&_b2[toCol]){if(valueObject.v=value.v,valueObject.f=null,valueObject.si=null,valueObject.p=null,value.p){const richText=getCellRichText(value);richText&&(valueObject.v=richText)}valueMatrix.setValue(toRow,toCol,valueObject)}}),valueMatrix}__name(getSpecialPasteValueValueMatrix,"getSpecialPasteValueValueMatrix");function getSpecialPasteFormulaValueMatrix(unitId,subUnitId,range,matrix,lexerTreeBuilder,formulaDataModel,pasteFrom){const valueMatrix=new core.ObjectMatrix,formulaIdMap=new Map;return matrix.forValue((row,col,value)=>{const toRow=range.rows[row],toCol=range.cols[col],valueObject={};if(core.isFormulaId(value.si)){if(pasteFrom.unitId!==unitId||pasteFrom.subUnitId!==subUnitId){const formulaString=formulaDataModel.getFormulaStringByCell(pasteFrom.range.rows[row%pasteFrom.range.rows.length],pasteFrom.range.cols[col%pasteFrom.range.cols.length],pasteFrom.subUnitId,pasteFrom.unitId),offsetX=range.cols[col]-pasteFrom.range.cols[col%pasteFrom.range.cols.length],offsetY=range.rows[row]-pasteFrom.range.rows[row%pasteFrom.range.rows.length],shiftedFormula=lexerTreeBuilder.moveFormulaRefOffset(formulaString||"",offsetX,offsetY);valueObject.si=null,valueObject.f=shiftedFormula}else valueObject.si=value.si,valueObject.f=null;valueObject.v=null,valueObject.p=null,valueMatrix.setValue(toRow,toCol,valueObject)}else if(core.isFormulaString(value.f)){const index=`${row%pasteFrom.range.rows.length}_${col%pasteFrom.range.cols.length}`;let formulaId=formulaIdMap.get(index);if(formulaId)valueObject.si=formulaId,valueObject.f=null;else{formulaId=core.Tools.generateRandomId(6),formulaIdMap.set(index,formulaId);const offsetX=range.cols[col]-pasteFrom.range.cols[col%pasteFrom.range.cols.length],offsetY=range.rows[row]-pasteFrom.range.rows[row%pasteFrom.range.rows.length],shiftedFormula=lexerTreeBuilder.moveFormulaRefOffset(value.f||"",offsetX,offsetY);valueObject.si=formulaId,valueObject.f=shiftedFormula}valueObject.v=null,valueObject.p=null,valueMatrix.setValue(toRow,toCol,valueObject)}else{if(valueObject.v=value.v,valueObject.f=null,valueObject.si=null,valueObject.p=null,value.p){const richText=getCellRichText(value);richText&&(valueObject.v=richText)}valueMatrix.setValue(toRow,toCol,valueObject)}}),valueMatrix}__name(getSpecialPasteFormulaValueMatrix,"getSpecialPasteFormulaValueMatrix");function getDefaultPasteValueMatrix(unitId,subUnitId,range,matrix,lexerTreeBuilder,formulaDataModel,pasteFrom){var _a11,_b;const valueMatrix=new core.ObjectMatrix,formulaIdMap=new Map,formulaData=(_b=(_a11=formulaDataModel.getFormulaData())==null?void 0:_a11[unitId])==null?void 0:_b[subUnitId];return matrix.forValue((row,col,value)=>{var _a12;const toRow=range.rows[row],toCol=range.cols[col],valueObject={};if(core.isFormulaId(value.si)){if(pasteFrom.unitId!==unitId||pasteFrom.subUnitId!==subUnitId){const formulaString=formulaDataModel.getFormulaStringByCell(pasteFrom.range.rows[row%pasteFrom.range.rows.length],pasteFrom.range.cols[col%pasteFrom.range.cols.length],pasteFrom.subUnitId,pasteFrom.unitId),offsetX=range.cols[col]-pasteFrom.range.cols[col%pasteFrom.range.cols.length],offsetY=range.rows[row]-pasteFrom.range.rows[row%pasteFrom.range.rows.length],shiftedFormula=lexerTreeBuilder.moveFormulaRefOffset(formulaString||"",offsetX,offsetY);valueObject.si=null,valueObject.f=shiftedFormula}else valueObject.si=value.si,valueObject.f=null;valueObject.v=null,valueObject.p=null,valueMatrix.setValue(toRow,toCol,valueObject)}else if(core.isFormulaString(value.f)){const index=`${row%pasteFrom.range.rows.length}_${col%pasteFrom.range.cols.length}`;let formulaId=formulaIdMap.get(index);if(formulaId)valueObject.si=formulaId,valueObject.f=null;else{formulaId=core.Tools.generateRandomId(6),formulaIdMap.set(index,formulaId);const offsetX=range.cols[col]-pasteFrom.range.cols[col%pasteFrom.range.cols.length],offsetY=range.rows[row]-pasteFrom.range.rows[row%pasteFrom.range.rows.length],shiftedFormula=lexerTreeBuilder.moveFormulaRefOffset(value.f||"",offsetX,offsetY);valueObject.si=formulaId,valueObject.f=shiftedFormula}valueObject.v=null,valueObject.p=null,valueMatrix.setValue(toRow,toCol,valueObject)}else(_a12=formulaData==null?void 0:formulaData[toRow])!=null&&_a12[toCol]&&(valueObject.v=value.v,valueObject.f=null,valueObject.si=null,valueObject.p=value.p,valueMatrix.setValue(toRow,toCol,valueObject))}),valueMatrix}__name(getDefaultPasteValueMatrix,"getDefaultPasteValueMatrix");function getCellRichText(cell){if(cell!=null&&cell.p){const body=cell==null?void 0:cell.p.body;if(body==null)return;const data=body.dataStream;return data.substring(data.length-2,data.length)===core.DEFAULT_EMPTY_DOCUMENT_VALUE?data.substring(0,data.length-2):data}}__name(getCellRichText,"getCellRichText");var __defProp$4=Object.defineProperty,__getOwnPropDesc$4=Object.getOwnPropertyDescriptor,__decorateClass$4=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$4(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$4(target,key,result),result},"__decorateClass$4"),__decorateParam$4=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$4"),_a6;let FormulaEditorShowController=(_a6=class extends core.Disposable{constructor(_context,_editorBridgeService,_formulaDataModel,_themeService,_renderManagerService,_sheetSkeletonManagerService,_commandService,_logService){super();__publicField(this,"_previousShape");__publicField(this,"_skeleton");this._context=_context,this._editorBridgeService=_editorBridgeService,this._formulaDataModel=_formulaDataModel,this._themeService=_themeService,this._renderManagerService=_renderManagerService,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._commandService=_commandService,this._logService=_logService,this._initSkeletonChangeListener(),this._initInterceptorEditorStart(),this._commandExecutedListener()}_initSkeletonChangeListener(){this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(param=>{var _a11,_b;if(param==null)this._logService.debug("[FormulaEditorShowController]: should not receive currentSkeleton$ as null!");else{const{skeleton}=param,prevSheetId=(_b=(_a11=this._skeleton)==null?void 0:_a11.worksheet)==null?void 0:_b.getSheetId();if(this._changeRuntime(skeleton),prevSheetId!==skeleton.worksheet.getSheetId())this._removeArrayFormulaRangeShape();else{const{unitId,sheetId}=param;this._updateArrayFormulaRangeShape(unitId,sheetId)}}}))}_changeRuntime(skeleton){this._skeleton=skeleton}_initInterceptorEditorStart(){this.disposeWithMe(core.toDisposable(this._editorBridgeService.interceptor.intercept(this._editorBridgeService.interceptor.getInterceptPoints().BEFORE_CELL_EDIT,{handler:__name((value,context,next)=>{var _a11,_b,_c,_d;const{row,col,unitId,subUnitId,worksheet}=context,arrayFormulaMatrixRange=this._formulaDataModel.getArrayFormulaRange(),arrayFormulaMatrixCell=this._formulaDataModel.getArrayFormulaCellData();if(this._removeArrayFormulaRangeShape(),value==null)return next(value);let cellInfo=null;const formulaString=this._formulaDataModel.getFormulaStringByCell(row,col,subUnitId,unitId);if(formulaString!==null&&(cellInfo={f:formulaString}),value.v!=null&&value.v!==""&&((_c=(_b=(_a11=arrayFormulaMatrixCell[unitId])==null?void 0:_a11[subUnitId])==null?void 0:_b[row])==null?void 0:_c[col])==null)return cellInfo?{...value,...cellInfo}:next(value);const matrixRange=(_d=arrayFormulaMatrixRange==null?void 0:arrayFormulaMatrixRange[unitId])==null?void 0:_d[subUnitId];return matrixRange!=null&&(cellInfo=this._displayArrayFormulaRangeShape(matrixRange,row,col,unitId,subUnitId,worksheet,cellInfo)),cellInfo?{...value,...cellInfo}:next(value)},"handler")})))}_commandExecutedListener(){this.disposeWithMe(this._commandService.onCommandExecuted((command,options)=>{(command.id===engineFormula.SetFormulaCalculationResultMutation.id||command.id===engineFormula.SetArrayFormulaDataMutation.id&&options&&options.remove)&&this._removeArrayFormulaRangeShape()})),this.disposeWithMe(this._commandService.beforeCommandExecuted(command=>{sheets.SetWorksheetRowAutoHeightMutation.id===command.id&&requestIdleCallback(()=>{const params=command.params,{unitId,subUnitId,rowsAutoHeightInfo}=params;this._refreshArrayFormulaRangeShapeByRow(unitId,subUnitId,rowsAutoHeightInfo)})}))}_displayArrayFormulaRangeShape(matrixRange,row,col,unitId,subUnitId,worksheet,cellInfo){return new core.ObjectMatrix(matrixRange).forValue((rowIndex,columnIndex,range)=>{if(range==null)return!0;const{startRow,startColumn,endRow,endColumn}=range;if(rowIndex===row&&columnIndex===col)return this._createArrayFormulaRangeShape(range,unitId),!1;if(row>=startRow&&row<=endRow&&col>=startColumn&&col<=endColumn){const mainCellValue=worksheet.getCell(startRow,startColumn);if((mainCellValue==null?void 0:mainCellValue.v)===engineFormula.ErrorType.SPILL)return;const formulaDataItem=this._formulaDataModel.getFormulaDataItem(rowIndex,columnIndex,subUnitId,unitId);return formulaDataItem==null||formulaDataItem.f==null?!0:(cellInfo==null&&(cellInfo={f:formulaDataItem.f,isInArrayFormulaRange:!0}),this._createArrayFormulaRangeShape(range,unitId),!1)}}),cellInfo}_createArrayFormulaRangeShape(arrayRange,unitId){const styleSheet=this._themeService.getCurrentTheme(),fill=new core.ColorKit(styleSheet.colorWhite).setAlpha(0).toString(),style={strokeWidth:1,stroke:styleSheet.hyacinth700,fill,widgets:{},hasAutoFill:!1,hasRowHeader:!1,hasColumnHeader:!1},renderUnit=this._renderManagerService.getRenderById(unitId);if(!renderUnit)return;const{scene}=renderUnit,{rangeWithCoord,primaryWithCoord}=renderUnit.with(sheetsUi.ISheetSelectionRenderService).attachSelectionWithCoord({range:arrayRange,primary:null,style}),skeleton=this._sheetSkeletonManagerService.getCurrentSkeleton();if(!scene||!skeleton)return;const{rowHeaderWidth,columnHeaderHeight}=skeleton,control=new sheetsUi.SelectionShape(scene,sheetsUi.SELECTION_SHAPE_DEPTH.FORMULA_EDITOR_SHOW,this._themeService,!1);control.update(rangeWithCoord,rowHeaderWidth,columnHeaderHeight,style,primaryWithCoord),control.setEvent(!1),this._previousShape=control}_removeArrayFormulaRangeShape(){this._previousShape!=null&&(this._previousShape.dispose(),this._previousShape=null)}_refreshArrayFormulaRangeShape(unitId,_range){if(this._previousShape){const{startRow,endRow,startColumn,endColumn}=this._previousShape.getRange(),range={startRow,endRow,startColumn,endColumn};this._removeArrayFormulaRangeShape(),this._createArrayFormulaRangeShape(range,unitId)}}_checkCurrentSheet(unitId,subUnitId){const skeleton=this._sheetSkeletonManagerService.getCurrentSkeleton();if(!skeleton)return!1;const worksheet=skeleton.worksheet;return worksheet?worksheet.unitId===unitId&&worksheet.getSheetId()===subUnitId:!1}_updateArrayFormulaRangeShape(unitId,subUnitId){this._checkCurrentSheet(unitId,subUnitId)&&this._previousShape&&this._refreshArrayFormulaRangeShape(unitId)}_refreshArrayFormulaRangeShapeByRow(unitId,subUnitId,rowAutoHeightInfo){if(!this._checkCurrentSheet(unitId,subUnitId)||!this._previousShape)return;const{startRow:shapeStartRow,endRow:shapeEndRow,startColumn:shapeStartColumn,endColumn:shapeEndColumn}=this._previousShape.getRange();for(let i=0;i<rowAutoHeightInfo.length;i++){const{row}=rowAutoHeightInfo[i];if(shapeStartRow>=row){const shapeRange={startRow:shapeStartRow,endRow:shapeEndRow,startColumn:shapeStartColumn,endColumn:shapeEndColumn};this._refreshArrayFormulaRangeShape(unitId,shapeRange);break}}}},__name(_a6,"FormulaEditorShowController"),_a6);FormulaEditorShowController=__decorateClass$4([__decorateParam$4(1,core.Inject(sheetsUi.IEditorBridgeService)),__decorateParam$4(2,core.Inject(engineFormula.FormulaDataModel)),__decorateParam$4(3,core.Inject(core.ThemeService)),__decorateParam$4(4,engineRender.IRenderManagerService),__decorateParam$4(5,core.Inject(sheetsUi.SheetSkeletonManagerService)),__decorateParam$4(6,core.ICommandService),__decorateParam$4(7,core.ILogService)],FormulaEditorShowController);var __defProp$3=Object.defineProperty,__getOwnPropDesc$3=Object.getOwnPropertyDescriptor,__decorateClass$3=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$3(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$3(target,key,result),result},"__decorateClass$3"),__decorateParam$3=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$3");const FORMULA_ERROR_MARK={tl:{size:6,color:"#409f11"}};var _a7;let FormulaRenderManagerController=(_a7=class extends core.RxDisposable{constructor(_sheetInterceptorService,_formulaDataModel){super(),this._sheetInterceptorService=_sheetInterceptorService,this._formulaDataModel=_formulaDataModel,this.disposeWithMe(this._sheetInterceptorService.intercept(sheets.INTERCEPTOR_POINT.CELL_CONTENT,{effect:core.InterceptorEffectEnum.Style,handler:__name((cell,pos,next)=>{var _a11,_b,_c,_d;const arrayFormulaCellData=(_d=(_c=(_b=(_a11=this._formulaDataModel.getArrayFormulaCellData())==null?void 0:_a11[pos.unitId])==null?void 0:_b[pos.subUnitId])==null?void 0:_c[pos.row])==null?void 0:_d[pos.col];return extractFormulaError(cell,!!arrayFormulaCellData)?next({...cell,markers:{...cell==null?void 0:cell.markers,...FORMULA_ERROR_MARK}}):next(cell)},"handler"),priority:10}))}},__name(_a7,"FormulaRenderManagerController"),_a7);FormulaRenderManagerController=__decorateClass$3([__decorateParam$3(0,core.Inject(sheets.SheetInterceptorService)),__decorateParam$3(1,core.Inject(engineFormula.FormulaDataModel))],FormulaRenderManagerController);function FormulaProgressBar(){const triggerCalculationController=core.useDependency(sheetsFormula.TriggerCalculationController),commandService=core.useDependency(core.ICommandService),progress=core.useObservable(triggerCalculationController.progress$),terminateCalculation=require$$0.useCallback(()=>{commandService.executeCommand(engineFormula.SetFormulaCalculationStopMutation.id)},[commandService]),clearProgress=require$$0.useCallback(()=>{triggerCalculationController.clearProgress()},[triggerCalculationController]);return jsxRuntimeExports.jsx(ui.ProgressBar,{progress,onTerminate:terminateCalculation,onClearProgress:clearProgress})}__name(FormulaProgressBar,"FormulaProgressBar");function getFunctionTypeValues(enumObj,localeService){return Object.keys(enumObj).filter(key=>isNaN(Number(key))&&key!=="DefinedName").map(key=>({label:localeService.t(`formula.functionType.${key.toLocaleLowerCase()}`),value:`${enumObj[key]}`}))}__name(getFunctionTypeValues,"getFunctionTypeValues");function generateParam(param){if(!param.require&&!param.repeat)return`[${param.name}]`;if(param.require&&!param.repeat)return param.name;if(!param.require&¶m.repeat)return`[${param.name},...]`;if(param.require&¶m.repeat)return`${param.name},...`}__name(generateParam,"generateParam");const useResizeScrollObserver=__name((callback,delay=100)=>{require$$0.useEffect(()=>{let throttleTimeout=null;const throttledCallback=__name(()=>{throttleTimeout===null&&(throttleTimeout=window.setTimeout(()=>{callback(),throttleTimeout=null},delay))},"throttledCallback");return window.addEventListener("scroll",throttledCallback),window.addEventListener("resize",throttledCallback),()=>{throttleTimeout!==null&&clearTimeout(throttleTimeout),window.removeEventListener("scroll",throttledCallback),window.removeEventListener("resize",throttledCallback)}},[callback,delay])},"useResizeScrollObserver"),formulaHelpFunction="univer-formula-help-function",formulaHelpFunctionTitle="univer-formula-help-function-title",formulaHelpFunctionTitleIcons="univer-formula-help-function-title-icons",formulaHelpFunctionTitleIcon="univer-formula-help-function-title-icon",formulaHelpFunctionContent="univer-formula-help-function-content",formulaHelpFunctionContentInner="univer-formula-help-function-content-inner",formulaHelpFunctionContentParams="univer-formula-help-function-content-params",formulaHelpFunctionContentParamsTitle="univer-formula-help-function-content-params-title",formulaHelpFunctionContentParamsDetail="univer-formula-help-function-content-params-detail",formulaHelpFunctionActive="univer-formula-help-function-active",formulaHelpDecorator="univer-formula-help-decorator",formulaHelpParam="univer-formula-help-param",formulaHelpParamPrefix="univer-formula-help-param-prefix",formulaHelpParamItem="univer-formula-help-param-item",formulaHelpParamActive="univer-formula-help-param-active",styles$5={formulaHelpFunction,formulaHelpFunctionTitle,formulaHelpFunctionTitleIcons,formulaHelpFunctionTitleIcon,formulaHelpFunctionContent,formulaHelpFunctionContentInner,formulaHelpFunctionContentParams,formulaHelpFunctionContentParamsTitle,formulaHelpFunctionContentParamsDetail,formulaHelpFunctionActive,formulaHelpDecorator,formulaHelpParam,formulaHelpParamPrefix,formulaHelpParamItem,formulaHelpParamActive};function HelpFunction(){const[visible,setVisible]=require$$0.useState(!1),[contentVisible,setContentVisible]=require$$0.useState(!0),[helpVisible,setHelpVisible]=require$$0.useState(!0),[paramIndex,setParamIndex]=require$$0.useState(0),[offset,setOffset]=require$$0.useState([0,0]),[decoratorPosition,setDecoratorPosition]=require$$0.useState({left:0,top:0}),[functionInfo,setFunctionInfo]=require$$0.useState(null),promptService=core.useDependency(IFormulaPromptService),localeService=core.useDependency(core.LocaleService),required=localeService.t("formula.prompt.required"),optional=localeService.t("formula.prompt.optional"),univerInstanceService=core.useDependency(core.IUniverInstanceService),editorService=core.useDependency(docsUi.IEditorService),sidebarService=core.useDependency(ui.ISidebarService),injector=core.useInjector();useResizeScrollObserver(updatePosition),require$$0.useEffect(()=>{const subscription=promptService.help$.subscribe(params=>{const{visible:visible2,paramIndex:paramIndex2,functionInfo:functionInfo2}=params;if(!visible2){setVisible(visible2);return}const position=getPosition();if(position==null)return;const{left,top,height}=position;functionInfo2.description===""&&functionInfo2.functionParameter.length===0||(setOffset([left,top+height]),setParamIndex(paramIndex2),setFunctionInfo(functionInfo2),setDecoratorPosition({left,top}),setVisible(visible2))}),sidebarSubscription=sidebarService.scrollEvent$.pipe(rxjs.throttleTime(100)).subscribe(updatePosition);return()=>{subscription==null||subscription.unsubscribe(),sidebarSubscription.unsubscribe()}},[]);function updatePosition(){if(!helpVisible)return;const position=getPosition();if(position==null)return;const{left,top,height}=position;setOffset([left,top+height])}__name(updatePosition,"updatePosition");function getPosition(){const documentDataModel=univerInstanceService.getCurrentUniverDocInstance();if(!documentDataModel)return;const editorUnitId=documentDataModel.getUnitId();if(!editorService.isEditor(editorUnitId))return;const editor=editorService.getEditor(editorUnitId);return editor==null?void 0:editor.getBoundingClientRect()}__name(getPosition,"getPosition");function handleSwitchActive(paramIndex2){setParamIndex(paramIndex2)}__name(handleSwitchActive,"handleSwitchActive");function handleClose(){setHelpVisible(!helpVisible),injector.get(ui.ILayoutService).focus()}return __name(handleClose,"handleClose"),jsxRuntimeExports.jsx(jsxRuntimeExports.Fragment,{children:helpVisible?jsxRuntimeExports.jsx(design.Popup,{visible,offset,children:functionInfo?jsxRuntimeExports.jsxs("div",{className:styles$5.formulaHelpFunction,children:[jsxRuntimeExports.jsxs("div",{className:styles$5.formulaHelpFunctionTitle,children:[jsxRuntimeExports.jsx(Help,{prefix:functionInfo.functionName,value:functionInfo.functionParameter,active:paramIndex,onClick:handleSwitchActive}),jsxRuntimeExports.jsxs("div",{className:styles$5.formulaHelpFunctionTitleIcons,children:[jsxRuntimeExports.jsx("div",{className:styles$5.formulaHelpFunctionTitleIcon,style:{transform:contentVisible?"rotateZ(-90deg)":"rotateZ(90deg)"},onClick:__name(()=>setContentVisible(!contentVisible),"onClick"),children:jsxRuntimeExports.jsx(MoreSingle,{})}),jsxRuntimeExports.jsx("div",{className:styles$5.formulaHelpFunctionTitleIcon,onClick:handleClose,children:jsxRuntimeExports.jsx(CloseSingle,{})})]})]}),jsxRuntimeExports.jsx("div",{className:styles$5.formulaHelpFunctionContent,style:{height:contentVisible?"unset":0,padding:contentVisible?"revert-layer":0},children:jsxRuntimeExports.jsxs("div",{className:styles$5.formulaHelpFunctionContentInner,children:[jsxRuntimeExports.jsx(Params,{title:localeService.t("formula.prompt.helpExample"),value:`${functionInfo.functionName}(${functionInfo.functionParameter.map(item=>item.example).join(",")})`}),jsxRuntimeExports.jsx(Params,{title:localeService.t("formula.prompt.helpAbstract"),value:functionInfo.description}),functionInfo&&functionInfo.functionParameter&&functionInfo.functionParameter.map((item,i)=>jsxRuntimeExports.jsx(Params,{className:paramIndex===i?styles$5.formulaHelpFunctionActive:"",title:item.name,value:`${item.require?required:optional} ${item.detail}`},i))]})})]}):jsxRuntimeExports.jsx(jsxRuntimeExports.Fragment,{})}):visible?jsxRuntimeExports.jsx("div",{className:styles$5.formulaHelpDecorator,onClick:__name(()=>setHelpVisible(!helpVisible),"onClick"),style:{left:decoratorPosition.left-24,top:decoratorPosition.top},children:jsxRuntimeExports.jsx(DetailsSingle,{})}):jsxRuntimeExports.jsx(jsxRuntimeExports.Fragment,{})})}__name(HelpFunction,"HelpFunction");const Params=__name(props=>jsxRuntimeExports.jsxs("div",{className:styles$5.formulaHelpFunctionContentParams,children:[jsxRuntimeExports.jsx("div",{className:`${styles$5.formulaHelpFunctionContentParamsTitle} ${props.className}`,children:props.title}),jsxRuntimeExports.jsx("div",{className:styles$5.formulaHelpFunctionContentParamsDetail,children:props.value})]}),"Params"),Help=__name(props=>{const{prefix,value,active,onClick}=props;return jsxRuntimeExports.jsxs("div",{className:styles$5.formulaHelpParam,children:[jsxRuntimeExports.jsxs("span",{className:styles$5.formulaHelpParamPrefix,children:[prefix,"("]}),value&&value.map((item,i)=>jsxRuntimeExports.jsxs("span",{className:styles$5.formulaHelpParamItem,children:[jsxRuntimeExports.jsx("span",{className:active===i?styles$5.formulaHelpFunctionActive:styles$5.formulaHelpParamActive,onClick:__name(()=>onClick(i),"onClick"),children:generateParam(item)}),i===value.length-1?"":","]},i)),")"]})},"Help"),formulaSearchFunction="univer-formula-search-function",formulaSearchFunctionItem="univer-formula-search-function-item",formulaSearchFunctionItemName="univer-formula-search-function-item-name",formulaSearchFunctionItemNameLight="univer-formula-search-function-item-name-light",formulaSearchFunctionItemDesc="univer-formula-search-function-item-desc",formulaSearchFunctionItemActive="univer-formula-search-function-item-active",styles$4={formulaSearchFunction,formulaSearchFunctionItem,formulaSearchFunctionItemName,formulaSearchFunctionItemNameLight,formulaSearchFunctionItemDesc,formulaSearchFunctionItemActive};function SearchFunction(){const[visible,setVisible]=require$$0.useState(!1),[active,setActive]=require$$0.useState(0),[offset,setOffset]=require$$0.useState([0,0]),[searchList,setSearchList]=require$$0.useState([]),[searchText,setSearchText]=require$$0.useState(""),ulRef=require$$0.useRef(null),promptService=core.useDependency(IFormulaPromptService),univerInstanceService=core.useDependency(core.IUniverInstanceService),editorService=core.useDependency(docsUi.IEditorService);require$$0.useEffect(()=>{let updatedSearchList=[],updatedActive=0;const subscribeSearch=promptService.search$.subscribe(params=>{const{visible:visible2,searchText:searchText2,searchList:searchList2}=params;if(!visible2){setVisible(visible2);return}const position=getPosition();if(position==null)return;const{left,top,height}=position;setSearchText(searchText2),setSearchList(searchList2),updatedSearchList=searchList2,setOffset([left,top+height]),setVisible(visible2),setActive(0),updatedActive=0}),subscribeNavigate=promptService.navigate$.subscribe(params=>{const{direction}=params;if(direction===core.Direction.UP){let nextActive=updatedActive-1;nextActive=nextActive<0?updatedSearchList.length-1:nextActive,setActive(nextActive),updatedActive=nextActive}else if(direction===core.Direction.DOWN){let nextActive=updatedActive+1;nextActive=nextActive>=updatedSearchList.length?0:nextActive,setActive(nextActive),updatedActive=nextActive}scrollToVisible(updatedActive)}),subscribeAccept=promptService.accept$.subscribe(params=>{const functionName=updatedSearchList[updatedActive].name;promptService.acceptFormulaName(functionName)});return()=>{subscribeSearch==null||subscribeSearch.unsubscribe(),subscribeNavigate==null||subscribeNavigate.unsubscribe(),subscribeAccept==null||subscribeAccept.unsubscribe()}},[]);function getPosition(){const editorUnitId=univerInstanceService.getCurrentUniverDocInstance().getUnitId();if(!editorService.isEditor(editorUnitId))return;const editor=editorService.getEditor(editorUnitId);return editor==null?void 0:editor.getBoundingClientRect()}__name(getPosition,"getPosition");function handleLiMouseEnter(index){setActive(index)}__name(handleLiMouseEnter,"handleLiMouseEnter");function handleLiMouseLeave(){setActive(-1)}__name(handleLiMouseLeave,"handleLiMouseLeave");function scrollToVisible(liIndex){var _a11;const liElement=(_a11=ulRef.current)==null?void 0:_a11.querySelectorAll(`.${styles$4.formulaSearchFunctionItem}`)[liIndex];if(!liElement)return;const ulElement=liElement.parentNode;if(!ulElement)return;const ulTop=ulElement.getBoundingClientRect().top,ulHeight=ulElement.offsetHeight,liRect=liElement.getBoundingClientRect(),liTop=liRect.top,liHeight=liRect.height;if(liTop>=0&&liTop>ulTop&&liTop-ulTop+liHeight<=ulHeight)return;const scrollTo=liElement.offsetTop-(ulHeight-liHeight)/2;ulElement.scrollTo({top:scrollTo,behavior:"smooth"})}return __name(scrollToVisible,"scrollToVisible"),searchList.length>0&&jsxRuntimeExports.jsx(design.Popup,{visible,offset,children:jsxRuntimeExports.jsx("ul",{className:styles$4.formulaSearchFunction,ref:ulRef,children:searchList.map((item,index)=>jsxRuntimeExports.jsxs("li",{className:active===index?`${styles$4.formulaSearchFunctionItem} ${styles$4.formulaSearchFunctionItemActive}`:styles$4.formulaSearchFunctionItem,onMouseEnter:__name(()=>handleLiMouseEnter(index),"onMouseEnter"),onMouseLeave:handleLiMouseLeave,onClick:__name(()=>promptService.acceptFormulaName(item.name),"onClick"),children:[jsxRuntimeExports.jsxs("span",{className:styles$4.formulaSearchFunctionItemName,children:[jsxRuntimeExports.jsx("span",{className:styles$4.formulaSearchFunctionItemNameLight,children:item.name.substring(0,searchText.length)}),jsxRuntimeExports.jsx("span",{children:item.name.slice(searchText.length)})]}),jsxRuntimeExports.jsx("span",{className:styles$4.formulaSearchFunctionItemDesc,children:item.desc})]},index))})})}__name(SearchFunction,"SearchFunction");function RenderFormulaPromptContent(){return jsxRuntimeExports.jsxs(jsxRuntimeExports.Fragment,{children:[jsxRuntimeExports.jsx(SearchFunction,{}),jsxRuntimeExports.jsx(HelpFunction,{})]})}__name(RenderFormulaPromptContent,"RenderFormulaPromptContent");const formulaMoreFunctions="univer-formula-more-functions",formulaMoreFunctionsOperation="univer-formula-more-functions-operation",styles$3={formulaMoreFunctions,formulaMoreFunctionsOperation};function FunctionHelp(props){const{prefix,value}=props;return jsxRuntimeExports.jsxs("div",{children:[jsxRuntimeExports.jsxs("span",{children:[prefix,"("]}),value&&value.map((item,i)=>jsxRuntimeExports.jsxs("span",{children:[jsxRuntimeExports.jsx("span",{children:generateParam(item)}),i===value.length-1?"":","]},i)),")"]})}__name(FunctionHelp,"FunctionHelp");const formulaFunctionParams="univer-formula-function-params",formulaFunctionParamsTitle="univer-formula-function-params-title",formulaFunctionParamsDetail="univer-formula-function-params-detail",styles$2={formulaFunctionParams,formulaFunctionParamsTitle,formulaFunctionParamsDetail};function FunctionParams(props){const{className,value,title}=props;return jsxRuntimeExports.jsxs("div",{className:styles$2.formulaFunctionParams,children:[jsxRuntimeExports.jsx("div",{className:`${styles$2.formulaFunctionParamsTitle} ${className}`,children:title}),jsxRuntimeExports.jsx("div",{className:styles$2.formulaFunctionParamsDetail,children:value})]})}__name(FunctionParams,"FunctionParams");const formulaInputParamsList="univer-formula-input-params-list",formulaInputParamsListItemName="univer-formula-input-params-list-item-name",formulaInputParamsListItemSelector="univer-formula-input-params-list-item-selector",styles$1={formulaInputParamsList,formulaInputParamsListItemName,formulaInputParamsListItemSelector};function InputParams(props){const{functionInfo,onChange}=props;if(!functionInfo)return null;require$$0.useState([]);const[functionParameter,setFunctionParameter]=require$$0.useState(functionInfo.functionParameter),[activeIndex,setActiveIndex]=require$$0.useState(-1);return jsxRuntimeExports.jsxs("div",{className:styles$1.formulaInputParams,children:[jsxRuntimeExports.jsx("div",{className:styles$1.formulaInputParamsList,children:functionParameter.map((item,i)=>jsxRuntimeExports.jsxs("div",{children:[jsxRuntimeExports.jsx("div",{className:styles$1.formulaInputParamsListItemName,children:item.name}),jsxRuntimeExports.jsx("div",{className:styles$1.formulaInputParamsListItemSelector})]},i))}),jsxRuntimeExports.jsx("div",{className:styles$1.formulaInputParamsInfo,children:jsxRuntimeExports.jsx(FunctionParams,{title:activeIndex===-1?jsxRuntimeExports.jsx(FunctionHelp,{prefix:functionInfo.functionName,value:functionParameter}):functionParameter[activeIndex].name,value:activeIndex===-1?functionInfo.description:functionParameter[activeIndex].detail})})]})}__name(InputParams,"InputParams");const formulaSelectFunctionSelect="univer-formula-select-function-select",formulaSelectFunctionResult="univer-formula-select-function-result",formulaSelectFunctionResultItem="univer-formula-select-function-result-item",formulaSelectFunctionResultItemNameLight="univer-formula-select-function-result-item-name-light",formulaSelectFunctionResultItemSelected="univer-formula-select-function-result-item-selected",formulaSelectFunctionResultItemActive="univer-formula-select-function-result-item-active",formulaSelectFunctionContent="univer-formula-select-function-content",styles={formulaSelectFunctionSelect,formulaSelectFunctionResult,formulaSelectFunctionResultItem,formulaSelectFunctionResultItemNameLight,formulaSelectFunctionResultItemSelected,formulaSelectFunctionResultItemActive,formulaSelectFunctionContent};function SelectFunction(props){const{onChange}=props,allTypeValue="-1",[searchText,setSearchText]=require$$0.useState(""),[selectList,setSelectList]=require$$0.useState([]),[active,setActive]=require$$0.useState(0),[typeSelected,setTypeSelected]=require$$0.useState(allTypeValue),[nameSelected,setNameSelected]=require$$0.useState(0),[functionInfo,setFunctionInfo]=require$$0.useState(null),descriptionService=core.useDependency(sheetsFormula.IDescriptionService),localeService=core.useDependency(core.LocaleService),sidebarService=core.useDependency(ui.ISidebarService),sidebarOptions=core.useObservable(sidebarService.sidebarOptions$),options=getFunctionTypeValues(engineFormula.FunctionType,localeService);options.unshift({label:localeService.t("formula.moreFunctions.allFunctions"),value:allTypeValue});const required=localeService.t("formula.prompt.required"),optional=localeService.t("formula.prompt.optional");require$$0.useEffect(()=>{handleSelectChange(allTypeValue)},[]),require$$0.useEffect(()=>{setCurrentFunctionInfo(0)},[selectList]),require$$0.useEffect(()=>{sidebarOptions!=null&&sidebarOptions.visible&&(setSearchText(""),setSelectList([]),setActive(0),setTypeSelected(allTypeValue),setNameSelected(0),setFunctionInfo(null),handleSelectChange(allTypeValue))},[sidebarOptions]);const highlightSearchText=__name(text=>{if(searchText.trim()==="")return text;const regex=new RegExp(`(${searchText.toLocaleUpperCase()})`);return text.split(regex).filter(Boolean).map((part,index)=>part.match(regex)?jsxRuntimeExports.jsx("span",{className:styles.formulaSelectFunctionResultItemNameLight,children:part},index):part)},"highlightSearchText"),setCurrentFunctionInfo=__name(selectedIndex=>{if(selectList.length===0){setFunctionInfo(null);return}setNameSelected(selectedIndex);const functionInfo2=descriptionService.getFunctionInfo(selectList[selectedIndex].name);if(!functionInfo2){setFunctionInfo(null);return}setFunctionInfo(functionInfo2),onChange(functionInfo2)},"setCurrentFunctionInfo");function handleSelectChange(value){setTypeSelected(value);const selectList2=descriptionService.getSearchListByType(+value);setSelectList(selectList2)}__name(handleSelectChange,"handleSelectChange");function handleSearchInputChange(value){setSearchText(value);const selectList2=descriptionService.getSearchListByName(value);setSelectList(selectList2)}__name(handleSearchInputChange,"handleSearchInputChange");function handleSelectListKeyDown(e){if(e.stopPropagation(),e.key==="ArrowDown"){const nextActive=active+1;setActive(nextActive===selectList.length?0:nextActive)}else if(e.key==="ArrowUp"){const nextActive=active-1;setActive(nextActive===-1?selectList.length-1:nextActive)}else e.key==="Enter"&&setCurrentFunctionInfo(active)}__name(handleSelectListKeyDown,"handleSelectListKeyDown");const handleLiMouseEnter=__name(index=>{setActive(index)},"handleLiMouseEnter"),handleLiMouseLeave=__name(()=>{setActive(-1)},"handleLiMouseLeave");return jsxRuntimeExports.jsxs("div",{children:[jsxRuntimeExports.jsxs("div",{className:styles.formulaSelectFunctionSelect,children:[jsxRuntimeExports.jsx(design.Select,{value:typeSelected,options,onChange:handleSelectChange}),jsxRuntimeExports.jsx(design.Input,{placeholder:localeService.t("formula.moreFunctions.searchFunctionPlaceholder"),onKeyDown:handleSelectListKeyDown,value:searchText,onChange:handleSearchInputChange,size:"large",allowClear:!0})]}),jsxRuntimeExports.jsx("ul",{className:styles.formulaSelectFunctionResult,onKeyDown:handleSelectListKeyDown,tabIndex:-1,children:selectList.map(({name},index)=>jsxRuntimeExports.jsxs("li",{className:active===index?`${styles.formulaSelectFunctionResultItem} ${styles.formulaSelectFunctionResultItemActive}`:styles.formulaSelectFunctionResultItem,onMouseEnter:__name(()=>handleLiMouseEnter(index),"onMouseEnter"),onMouseLeave:handleLiMouseLeave,onClick:__name(()=>setCurrentFunctionInfo(index),"onClick"),children:[nameSelected===index&&jsxRuntimeExports.jsx(CheckMarkSingle,{className:styles.formulaSelectFunctionResultItemSelected}),jsxRuntimeExports.jsx("span",{className:styles.formulaSelectFunctionResultItemName,children:highlightSearchText(name)})]},index))}),functionInfo&&jsxRuntimeExports.jsxs("div",{className:styles.formulaSelectFunctionContent,children:[jsxRuntimeExports.jsx(FunctionParams,{title:functionInfo.functionName,value:functionInfo.description}),jsxRuntimeExports.jsx(FunctionParams,{title:localeService.t("formula.moreFunctions.syntax"),value:jsxRuntimeExports.jsx(FunctionHelp,{prefix:functionInfo.functionName,value:functionInfo.functionParameter})}),jsxRuntimeExports.jsx(FunctionParams,{title:localeService.t("formula.prompt.helpExample"),value:`${functionInfo.functionName}(${functionInfo.functionParameter.map(item=>item.example).join(",")})`}),functionInfo.functionParameter&&functionInfo.functionParameter.map((item,i)=>jsxRuntimeExports.jsx(FunctionParams,{title:item.name,value:`${item.require?required:optional} ${item.detail}`},i))]})]})}__name(SelectFunction,"SelectFunction");function MoreFunctions(){const workbook=sheetsUi.useActiveWorkbook(),[selectFunction,setSelectFunction]=require$$0.useState(!0),[inputParams,setInputParams]=require$$0.useState(!1),[functionInfo,setFunctionInfo]=require$$0.useState(null),localeService=core.useDependency(core.LocaleService),editorService=core.useDependency(docsUi.IEditorService);function handleClickNextPrev(){setSelectFunction(!selectFunction),setInputParams(!inputParams)}__name(handleClickNextPrev,"handleClickNextPrev");function handleConfirm(){editorService.setFormula(`=${functionInfo==null?void 0:functionInfo.functionName}(`)}return __name(handleConfirm,"handleConfirm"),jsxRuntimeExports.jsxs("div",{className:styles$3.formulaMoreFunctions,children:[selectFunction&&jsxRuntimeExports.jsx(SelectFunction,{onChange:setFunctionInfo}),inputParams&&jsxRuntimeExports.jsx(InputParams,{functionInfo,onChange:__name(()=>{},"onChange")}),jsxRuntimeExports.jsxs("div",{className:styles$3.formulaMoreFunctionsOperation,children:[inputParams&&jsxRuntimeExports.jsx(design.Button,{type:"primary",size:"small",onClick:handleClickNextPrev,children:localeService.t("formula.moreFunctions.next")}),inputParams&&jsxRuntimeExports.jsx(design.Button,{size:"small",onClick:handleClickNextPrev,children:localeService.t("formula.moreFunctions.prev")}),selectFunction&&!!workbook&&jsxRuntimeExports.jsx(design.Button,{type:"primary",size:"small",onClick:handleConfirm,children:localeService.t("formula.moreFunctions.confirm")})]})]})}__name(MoreFunctions,"MoreFunctions");function InsertFunctionMenuItemFactory(accessor){return{id:InsertFunctionOperation.id,icon:"FunctionSingle",tooltip:"formula.insert.tooltip",type:ui.MenuItemType.SELECTOR,selections:[{label:"SUM",value:"SUM",icon:"SumSingle"},{label:"AVERAGE",value:"AVERAGE",icon:"AvgSingle"},{label:"COUNT",value:"COUNT",icon:"CntSingle"},{label:"MAX",value:"MAX",icon:"MaxSingle"},{label:"MIN",value:"MIN",icon:"MinSingle"}],hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET),disabled$:sheetsUi.getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellValuePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(InsertFunctionMenuItemFactory,"InsertFunctionMenuItemFactory");function MoreFunctionsMenuItemFactory(accessor){return{id:MoreFunctionsOperation.id,title:"formula.insert.more",type:ui.MenuItemType.BUTTON}}__name(MoreFunctionsMenuItemFactory,"MoreFunctionsMenuItemFactory");function menuClipboardDisabledObservable(injector){return injector.get(core.IUniverInstanceService).getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET).pipe(rxjs.switchMap(workbook=>workbook&&injector.get(ui.IClipboardInterfaceService)?new rxjs.Observable(subscriber=>subscriber.next(!injector.get(ui.IClipboardInterfaceService).supportClipboard)):rxjs.of(!0)))}__name(menuClipboardDisabledObservable,"menuClipboardDisabledObservable");function PasteFormulaMenuItemFactory(accessor){return{id:SheetOnlyPasteFormulaCommand.id,type:ui.MenuItemType.BUTTON,title:"formula.operation.pasteFormula",disabled$:menuClipboardDisabledObservable(accessor).pipe(rxjs.combineLatestWith(sheetsUi.getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetSetCellValuePermission,sheets.WorksheetEditPermission]})),rxjs.map(([d1,d2])=>d1||d2))}}__name(PasteFormulaMenuItemFactory,"PasteFormulaMenuItemFactory");const menuSchema={[ui.RibbonStartGroup.FORMULAS_INSERT]:{[InsertFunctionOperation.id]:{order:1,menuItemFactory:InsertFunctionMenuItemFactory,[MoreFunctionsOperation.id]:{order:1,menuItemFactory:MoreFunctionsMenuItemFactory}}},[sheetsUi.PASTE_SPECIAL_MENU_ID]:{[SheetOnlyPasteFormulaCommand.id]:{order:4,menuItemFactory:PasteFormulaMenuItemFactory}}},META_KEY_CTRL_AND_SHIFT="meta_key_ctrl_And_Shift",PROMPT_SELECTION_KEYCODE_ARROW_LIST=[ui.KeyCode.ARROW_DOWN,ui.KeyCode.ARROW_UP,ui.KeyCode.ARROW_LEFT,ui.KeyCode.ARROW_RIGHT],PROMPT_SELECTION_KEYCODE_LIST=[...PROMPT_SELECTION_KEYCODE_ARROW_LIST,ui.KeyCode.ENTER,ui.KeyCode.TAB,ui.KeyCode.ESC];function promptSelectionShortcutItem(){const shortcutList=[];for(const keycode of PROMPT_SELECTION_KEYCODE_LIST)shortcutList.push({id:SelectEditorFormulaOperation.id,binding:keycode,preconditions:__name(contextService=>sheetsUi.whenFormulaEditorActivated(contextService),"preconditions"),staticParameters:{eventType:engineRender.DeviceInputEventType.Keyboard,keycode}});return shortcutList}__name(promptSelectionShortcutItem,"promptSelectionShortcutItem");function promptSelectionShortcutItemShift(){const shortcutList=[];for(const keycode of PROMPT_SELECTION_KEYCODE_ARROW_LIST)shortcutList.push({id:SelectEditorFormulaOperation.id,binding:keycode|ui.MetaKeys.SHIFT,preconditions:__name(contextService=>sheetsUi.whenFormulaEditorActivated(contextService),"preconditions"),staticParameters:{eventType:engineRender.DeviceInputEventType.Keyboard,keycode,metaKey:ui.MetaKeys.SHIFT}});return shortcutList}__name(promptSelectionShortcutItemShift,"promptSelectionShortcutItemShift");function promptSelectionShortcutItemCtrl(){const shortcutList=[];for(const keycode of PROMPT_SELECTION_KEYCODE_ARROW_LIST)shortcutList.push({id:SelectEditorFormulaOperation.id,binding:keycode|ui.MetaKeys.CTRL_COMMAND,preconditions:__name(contextService=>sheetsUi.whenFormulaEditorActivated(contextService),"preconditions"),staticParameters:{eventType:engineRender.DeviceInputEventType.Keyboard,keycode,metaKey:ui.MetaKeys.CTRL_COMMAND}});return shortcutList}__name(promptSelectionShortcutItemCtrl,"promptSelectionShortcutItemCtrl");function promptSelectionShortcutItemCtrlAndShift(){const shortcutList=[];for(const keycode of PROMPT_SELECTION_KEYCODE_ARROW_LIST)shortcutList.push({id:SelectEditorFormulaOperation.id,binding:keycode|ui.MetaKeys.SHIFT|ui.MetaKeys.CTRL_COMMAND,preconditions:__name(contextService=>sheetsUi.whenFormulaEditorActivated(contextService),"preconditions"),staticParameters:{eventType:engineRender.DeviceInputEventType.Keyboard,keycode,metaKey:META_KEY_CTRL_AND_SHIFT}});return shortcutList}__name(promptSelectionShortcutItemCtrlAndShift,"promptSelectionShortcutItemCtrlAndShift");const ChangeRefToAbsoluteShortcut={id:ReferenceAbsoluteOperation.id,binding:ui.KeyCode.F4,preconditions:__name(contextService=>sheetsUi.whenFormulaEditorActivated(contextService),"preconditions")};function singleEditorPromptSelectionShortcutItem(){const shortcutList=[];for(const keycode of[ui.KeyCode.ENTER,ui.KeyCode.TAB,ui.KeyCode.ARROW_DOWN,ui.KeyCode.ARROW_UP])shortcutList.push({id:SelectEditorFormulaOperation.id,binding:keycode,preconditions:__name(contextService=>whenEditorStandalone(contextService),"preconditions"),staticParameters:{eventType:engineRender.DeviceInputEventType.Keyboard,keycode,isSingleEditor:!0}});return shortcutList}__name(singleEditorPromptSelectionShortcutItem,"singleEditorPromptSelectionShortcutItem");var __defProp$2=Object.defineProperty,__getOwnPropDesc$2=Object.getOwnPropertyDescriptor,__decorateClass$2=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$2(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$2(target,key,result),result},"__decorateClass$2"),__decorateParam$2=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$2"),_a8;let FormulaUIController=(_a8=class extends core.Disposable{constructor(_injector,_menuManagerService,_commandService,_shortcutService,_uiPartsService,_renderManagerService,_componentManager){super(),this._injector=_injector,this._menuManagerService=_menuManagerService,this._commandService=_commandService,this._shortcutService=_shortcutService,this._uiPartsService=_uiPartsService,this._renderManagerService=_renderManagerService,this._componentManager=_componentManager,this._initialize()}_initialize(){this._registerCommands(),this._registerMenus(),this._registerShortcuts(),this._registerComponents(),this._registerRenderModules()}_registerMenus(){this._menuManagerService.mergeMenu(menuSchema)}_registerCommands(){[SheetOnlyPasteFormulaCommand,InsertFunctionOperation,MoreFunctionsOperation,SearchFunctionOperation,HelpFunctionOperation,SelectEditorFormulaOperation,ReferenceAbsoluteOperation].forEach(command=>this.disposeWithMe(this._commandService.registerCommand(command)))}_registerShortcuts(){[...promptSelectionShortcutItem(),...promptSelectionShortcutItemShift(),...promptSelectionShortcutItemCtrl(),...promptSelectionShortcutItemCtrlAndShift(),...singleEditorPromptSelectionShortcutItem(),ChangeRefToAbsoluteShortcut].forEach(item=>{this.disposeWithMe(this._shortcutService.registerShortcut(item))})}_registerComponents(){this.disposeWithMe(this._uiPartsService.registerComponent(ui.BuiltInUIPart.CONTENT,()=>core.connectInjector(RenderFormulaPromptContent,this._injector))),this.disposeWithMe(this._uiPartsService.registerComponent(sheetsUi.SheetsUIPart.FORMULA_AUX,()=>core.connectInjector(FormulaProgressBar,this._injector))),this._componentManager.register(MORE_FUNCTIONS_COMPONENT,MoreFunctions)}_registerRenderModules(){this.disposeWithMe(this._renderManagerService.registerRenderModule(core.UniverInstanceType.UNIVER_SHEET,[FormulaEditorShowController]))}},__name(_a8,"FormulaUIController"),_a8);FormulaUIController=__decorateClass$2([__decorateParam$2(0,core.Inject(core.Injector)),__decorateParam$2(1,ui.IMenuManagerService),__decorateParam$2(2,core.ICommandService),__decorateParam$2(3,ui.IShortcutService),__decorateParam$2(4,ui.IUIPartsService),__decorateParam$2(5,engineRender.IRenderManagerService),__decorateParam$2(6,core.Inject(ui.ComponentManager))],FormulaUIController);function getFormulaRefSelectionStyle(themeService,refColor,id){const style=themeService.getCurrentTheme(),fill=new core.ColorKit(refColor).setAlpha(.05).toRgbString();return{id,strokeWidth:1,stroke:refColor,fill,widgets:{tl:!0,tc:!0,tr:!0,ml:!0,mr:!0,bl:!0,bc:!0,br:!0},widgetSize:6,widgetStrokeWidth:1,widgetStroke:style.colorWhite,hasAutoFill:!1,hasRowHeader:!1,hasColumnHeader:!1}}__name(getFormulaRefSelectionStyle,"getFormulaRefSelectionStyle");var __defProp$1=Object.defineProperty,__getOwnPropDesc$1=Object.getOwnPropertyDescriptor,__decorateClass$1=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$1(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$1(target,key,result),result},"__decorateClass$1"),__decorateParam$1=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$1");const sheetEditorUnitIds=[core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY,core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY];var _a9;let PromptController=(_a9=class extends core.Disposable{constructor(_commandService,_contextService,_editorBridgeService,_formulaPromptService,_lexerTreeBuilder,_renderManagerService,_themeService,_sheetsSelectionsService,_refSelectionsService,_univerInstanceService,_descriptionService,_docSelectionManagerService,_contextMenuService,_editorService,_layoutService){super();__publicField(this,"_listenInputCache",new Set);__publicField(this,"_formulaRefColors",[]);__publicField(this,"_previousSequenceNodes");__publicField(this,"_previousRangesCount",0);__publicField(this,"_previousInsertRefStringIndex");__publicField(this,"_currentInsertRefStringIndex",-1);__publicField(this,"_arrowMoveActionState",0);__publicField(this,"_isSelectionMovingRefSelections",[]);__publicField(this,"_stringColor","");__publicField(this,"_numberColor","");__publicField(this,"_insertSelections",[]);__publicField(this,"_inputPanelState",0);__publicField(this,"_userCursorMove",!1);__publicField(this,"_previousEditorUnitId");__publicField(this,"_existsSequenceNode",!1);__publicField(this,"_currentlyWorkingRefRenderer",null);__publicField(this,"_selectionsChangeDisposables");__publicField(this,"_isSelectingMode",!1);this._commandService=_commandService,this._contextService=_contextService,this._editorBridgeService=_editorBridgeService,this._formulaPromptService=_formulaPromptService,this._lexerTreeBuilder=_lexerTreeBuilder,this._renderManagerService=_renderManagerService,this._themeService=_themeService,this._sheetsSelectionsService=_sheetsSelectionsService,this._refSelectionsService=_refSelectionsService,this._univerInstanceService=_univerInstanceService,this._descriptionService=_descriptionService,this._docSelectionManagerService=_docSelectionManagerService,this._contextMenuService=_contextMenuService,this._editorService=_editorService,this._layoutService=_layoutService,this._initialize()}get _selectionRenderService(){return this._renderManagerService.getRenderById(this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getUnitId()).with(exports.RefSelectionsRenderService)}get _allSelectionRenderServices(){return this._renderManagerService.getAllRenderersOfType(core.UniverInstanceType.UNIVER_SHEET).map(renderer=>renderer.with(exports.RefSelectionsRenderService))}dispose(){this._formulaRefColors=[],this._resetTemp()}_resetTemp(){this._previousSequenceNodes=null,this._previousInsertRefStringIndex=null,this._isSelectionMovingRefSelections=[],this._previousRangesCount=0,this._currentInsertRefStringIndex=-1}_initialize(){this._initialCursorSync(),this._initAcceptFormula(),this._initialFormulaTheme(),this._initSelectionsEndListener(),this._closeRangePromptWhenEditorInvisible(),this._initialEditorInputChange(),this._commandExecutedListener(),this._cursorStateListener(),this._inputFormulaListener(),this._userMouseListener(),this._initialChangeEditor()}_initialFormulaTheme(){const style=this._themeService.getCurrentTheme();this._formulaRefColors=[style.loopColor1,style.loopColor2,style.loopColor3,style.loopColor4,style.loopColor5,style.loopColor6,style.loopColor7,style.loopColor8,style.loopColor9,style.loopColor10,style.loopColor11,style.loopColor12],this._numberColor=style.hyacinth700,this._stringColor=style.verdancy800}_initialCursorSync(){this.disposeWithMe(this._docSelectionManagerService.textSelection$.pipe(rxjs.filter(item=>!sheetsUi.isRangeSelector(item.unitId))).subscribe(params=>{var _a11;if((params==null?void 0:params.unitId)==null)return;const editor=this._editorService.getEditor(params.unitId);if(!editor||editor.onlyInputContent()||editor.isSheetEditor()&&!this._isFormulaEditorActivated()||editor.params.scrollBar)return;const onlyInputRange=editor.onlyInputRange();(_a11=params==null?void 0:params.options)!=null&&_a11.fromSelection||(this._quitSelectingMode(),this._contextSwitch(),this._checkShouldEnterSelectingMode(onlyInputRange),!this._formulaPromptService.isLockedSelectionChange()&&(this._highlightFormula(),!onlyInputRange&&this._changeFunctionPanelState()))}))}_initialEditorInputChange(){const arrows=[ui.KeyCode.ARROW_DOWN,ui.KeyCode.ARROW_UP,ui.KeyCode.ARROW_LEFT,ui.KeyCode.ARROW_RIGHT,ui.KeyCode.CTRL,ui.KeyCode.SHIFT];this._univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_DOC).subscribe(documentDataModel=>{var _a11;const unitId=documentDataModel==null?void 0:documentDataModel.getUnitId();if(unitId==null||sheetsUi.isRangeSelector(unitId)||this._listenInputCache.has(unitId)||this._editorService.getEditor(unitId)==null)return;const docSelectionRenderService=(_a11=this._renderManagerService.getRenderById(unitId))==null?void 0:_a11.with(docsUi.DocSelectionRenderService);docSelectionRenderService&&this.disposeWithMe(docSelectionRenderService.onInputBefore$.subscribe(param=>{this._previousSequenceNodes=null,this._previousInsertRefStringIndex=null,this._selectionRenderService.setSkipLastEnabled(!0);const event=param==null?void 0:param.event;event&&(arrows.includes(event.which)?this._inputPanelState=2:(this._arrowMoveActionState!==1&&(this._arrowMoveActionState=2),this._inputPanelState=1),event.which!==ui.KeyCode.F4&&(this._userCursorMove=!1))})),this._listenInputCache.add(unitId)})}_closeRangePromptWhenEditorInvisible(){this.disposeWithMe(this._editorBridgeService.afterVisible$.pipe(rxjs.distinctUntilKeyChanged("visible")).subscribe(visibleParam=>{visibleParam.visible||this._closeRangePrompt()})),this.disposeWithMe(this._contextService.subscribeContextValue$(core.FORMULA_EDITOR_ACTIVATED).pipe(rxjs.distinctUntilChanged()).subscribe(activated=>{activated||this._closeRangePrompt()}))}_initialChangeEditor(){this.disposeWithMe(this._univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_DOC).subscribe(documentDataModel=>{if(documentDataModel==null)return;const editorId=documentDataModel.getUnitId();sheetsUi.isRangeSelector(editorId)||!this._editorService.isEditor(editorId)||this._previousEditorUnitId===editorId||this._editorService.isSheetEditor(editorId)||(this._closeRangePrompt(editorId),this._previousEditorUnitId=editorId)})),this.disposeWithMe(this._editorService.closeRangePrompt$.subscribe(()=>{(!this._editorService.getSpreadsheetFocusState()||!this._formulaPromptService.isLockedSelectionInsert())&&this._closeRangePrompt()}))}_closeRangePrompt(editorId){this._insertSelections=[],this._refSelectionsService.clear(),editorId&&this._editorService.isSheetEditor(editorId)&&this._updateEditorModel(`\r
|
|
13
13
|
`,[]),this._contextService.setContextValue(core.FOCUSING_EDITOR_INPUT_FORMULA,!1),this._contextService.setContextValue(sheets.DISABLE_NORMAL_SELECTIONS,!1),this._contextService.setContextValue(ui.UNI_DISABLE_CHANGING_FOCUS_KEY,!1),this._quitSelectingMode(),this._resetTemp(),this._hideFunctionPanel()}_initSelectionsEndListener(){const d=new core.DisposableCollection;this.disposeWithMe(this._refSelectionsService.selectionMoveEnd$.subscribe(selections=>{if(d.dispose(),selections.length===0)return;this._allSelectionRenderServices.map(s=>s.getSelectionControls()).flat().forEach(c=>{c.disableHelperSelection(),d.add(c.selectionMoving$.subscribe(toRange=>this._onSelectionControlChange(toRange,c))),d.add(c.selectionScaling$.subscribe(toRange=>this._onSelectionControlChange(toRange,c))),d.add(c.selectionMoved$.subscribe(()=>this._formulaPromptService.disableLockedSelectionChange())),d.add(c.selectionScaled$.subscribe(()=>this._formulaPromptService.disableLockedSelectionChange()))})}))}_updateSelecting(selectionsWithStyles,performInsertion=!1){if(selectionsWithStyles.length!==0&&!(this._editorService.selectionChangingState()&&!this._formulaPromptService.isLockedSelectionInsert())&&(this._insertControlSelections(selectionsWithStyles),performInsertion)){const currentSelection=selectionsWithStyles[selectionsWithStyles.length-1];this._insertControlSelectionReplace(currentSelection)}}_enableRefSelectionsRenderService(){const d=this._selectionsChangeDisposables=new core.DisposableCollection;this._allSelectionRenderServices.forEach(renderer=>{d.add(renderer.enableSelectionChanging()),d.add(renderer.selectionMoving$.subscribe(selections=>{this._updateSelecting(selections.map(s=>sheets.convertSelectionDataToRange(s)))})),d.add(renderer.selectionMoveStart$.subscribe(selections=>{const performInsertion=this._checkClearingLastSelection(renderer);this._currentlyWorkingRefRenderer=renderer,this._updateSelecting(selections.map(s=>sheets.convertSelectionDataToRange(s)),performInsertion)}))})}_checkClearingLastSelection(renderer){return this._currentlyWorkingRefRenderer&&this._currentlyWorkingRefRenderer!==renderer?(this._currentlyWorkingRefRenderer.clearLastSelection(),!1):!0}_disposeSelectionsChangeListeners(){var _a11;(_a11=this._selectionsChangeDisposables)==null||_a11.dispose(),this._selectionsChangeDisposables=null}_insertControlSelections(selections){const currentSelection=selections[selections.length-1];if(this._resetSequenceNodes(selections.length),(selections.length===this._previousRangesCount||this._previousRangesCount===0)&&this._previousSequenceNodes!=null)this._insertControlSelectionReplace(currentSelection);else{let insertNodes=this._formulaPromptService.getSequenceNodes();const char=this._getCurrentChar();insertNodes.length===0&&this._currentInsertRefStringIndex>0&&(this._currentInsertRefStringIndex=-1),this._previousInsertRefStringIndex=this._currentInsertRefStringIndex,!engineFormula.matchRefDrawToken(char)&&this._focusIsOnlyRange(selections.length)&&(this._formulaPromptService.insertSequenceString(this._currentInsertRefStringIndex,engineFormula.matchToken.COMMA),insertNodes=this._formulaPromptService.getSequenceNodes(),this._previousInsertRefStringIndex+=1),this._previousSequenceNodes=core.Tools.deepClone(insertNodes),this._formulaPromptService.setSequenceNodes(insertNodes);const refString=this._generateRefString(currentSelection);this._formulaPromptService.insertSequenceRef(this._previousInsertRefStringIndex,refString),this._selectionRenderService.setSkipLastEnabled(!1)}this._arrowMoveActionState=2,this._previousRangesCount=selections.length}_initAcceptFormula(){this.disposeWithMe(this._formulaPromptService.acceptFormulaName$.subscribe(formulaString=>{const activeRange=this._docSelectionManagerService.getActiveTextRange();if(activeRange==null){this._hideFunctionPanel();return}const{startOffset}=activeRange,lastSequenceNodes=this._formulaPromptService.getSequenceNodes(),nodeIndex=this._formulaPromptService.getCurrentSequenceNodeIndex(startOffset-2),node=lastSequenceNodes[nodeIndex];if(node==null||typeof node=="string"){this._hideFunctionPanel();return}const difference=formulaString.length-node.token.length,newNode={...node};newNode.token=formulaString,newNode.endIndex+=difference,lastSequenceNodes[nodeIndex]=newNode;const isDefinedName=this._descriptionService.hasDefinedNameDescription(formulaString),isFormulaDefinedName=this._descriptionService.isFormulaDefinedName(formulaString),formulaStringCount=formulaString.length+1,mustAddBracket=!isDefinedName||isFormulaDefinedName;mustAddBracket&&lastSequenceNodes.splice(nodeIndex+1,0,engineFormula.matchToken.OPEN_BRACKET);for(let i=nodeIndex+2,len=lastSequenceNodes.length;i<len;i++){const node2=lastSequenceNodes[i];if(typeof node2=="string")continue;const newNode2={...node2};newNode2.startIndex+=formulaStringCount,newNode2.endIndex+=formulaStringCount,lastSequenceNodes[i]=newNode2}let selectionIndex=newNode.endIndex+1;mustAddBracket&&(selectionIndex+=1),this._syncToEditor(lastSequenceNodes,selectionIndex,void 0,!0,!1)}))}_changeFunctionPanelState(){const activeRange=this._docSelectionManagerService.getActiveTextRange();if(activeRange==null){this._hideFunctionPanel();return}const{startOffset}=activeRange,currentSequenceNode=this._formulaPromptService.getCurrentSequenceNode(startOffset-2);if(currentSequenceNode==null){this._hideFunctionPanel();return}if(typeof currentSequenceNode!="string"&¤tSequenceNode.nodeType===engineFormula.sequenceNodeType.FUNCTION&&!this._descriptionService.hasDefinedNameDescription(currentSequenceNode.token.trim())){const token=currentSequenceNode.token.toUpperCase();if(this._inputPanelState===1){const searchList=this._descriptionService.getSearchListByNameFirstLetter(token);if(this._hideFunctionPanel(),searchList==null||searchList.length===0)return;this._commandService.executeCommand(SearchFunctionOperation.id,{visible:!0,searchText:token,searchList})}else this._changeHelpFunctionPanelState(token,-1);return}const config=this._getCurrentBodyDataStreamAndOffset(),functionAndParameter=this._lexerTreeBuilder.getFunctionAndParameter((config==null?void 0:config.dataStream)||"",startOffset-1+((config==null?void 0:config.offset)||0));if(!functionAndParameter){this._hideFunctionPanel();return}const{functionName,paramIndex}=functionAndParameter;this._changeHelpFunctionPanelState(functionName.toUpperCase(),paramIndex)}_changeHelpFunctionPanelState(token,paramIndex){const functionInfo=this._descriptionService.getFunctionInfo(token);this._hideFunctionPanel(),functionInfo!=null&&this._commandService.executeCommand(HelpFunctionOperation.id,{visible:!0,paramIndex,functionInfo})}_hideFunctionPanel(){this._commandService.executeCommand(SearchFunctionOperation.id,{visible:!1,searchText:""}),this._commandService.executeCommand(HelpFunctionOperation.id,{visible:!1,paramIndex:-1})}_checkShouldEnterSelectingMode(isOnlyInputRangeEditor=!1){if(isOnlyInputRangeEditor){this._enterSelectingMode();return}const char=this._getCurrentChar(),dataStream=this._getCurrentDataStream();(dataStream==null?void 0:dataStream.substring(0,1))==="="&&char&&engineFormula.matchRefDrawToken(char)?this._enterSelectingMode():this._quitSelectingMode()}_getCurrentChar(){const activeRange=this._docSelectionManagerService.getActiveTextRange();if(activeRange==null)return;const{startOffset}=activeRange,config=this._getCurrentBodyDataStreamAndOffset();return config==null||startOffset==null?void 0:config.dataStream[startOffset-1+config.offset]}_getCurrentDataStream(){const config=this._getCurrentBodyDataStreamAndOffset();return config==null?void 0:config.dataStream}_enterSelectingMode(){this._isSelectingMode||(this._editorBridgeService.enableForceKeepVisible(),this._contextMenuService.disable(),this._formulaPromptService.enableLockedSelectionInsert(),this._selectionRenderService.setRemainLastEnabled(!0),this._enableRefSelectionsRenderService(),this._currentlyWorkingRefRenderer=null,this._arrowMoveActionState!==1&&(this._arrowMoveActionState=2),this._isSelectingMode=!0)}_quitSelectingMode(){this._isSelectingMode&&(this._editorBridgeService.disableForceKeepVisible(),this._contextMenuService.enable(),this._formulaPromptService.disableLockedSelectionInsert(),this._currentInsertRefStringIndex=-1,this._disposeSelectionsChangeListeners(),this._arrowMoveActionState===2&&(this._arrowMoveActionState=4),this._isSelectingMode=!1)}_getCurrentBodyDataStreamAndOffset(){var _a11,_b;const documentModel=this._univerInstanceService.getCurrentUniverDocInstance();if(!(documentModel!=null&&documentModel.getBody()))return;const unitId=documentModel.getUnitId(),editor=this._editorService.getEditor(unitId),dataStream=(_b=(_a11=documentModel.getBody())==null?void 0:_a11.dataStream)!=null?_b:"";return!editor||!editor.onlyInputRange()?{dataStream,offset:0}:{dataStream:engineFormula.compareToken.EQUALS+dataStream,offset:1}}_getFormulaAndCellEditorBody(unitIds){return unitIds.map(unitId=>{const dataModel=this._univerInstanceService.getUniverDocInstance(unitId);return dataModel==null?void 0:dataModel.getBody()})}_editorModelUnitIds(){const unitId=this._univerInstanceService.getCurrentUniverDocInstance().getUnitId();return this._editorService.isEditor(unitId)&&!this._editorService.isSheetEditor(unitId)?[unitId]:sheetEditorUnitIds}_contextSwitch(){const config=this._getCurrentBodyDataStreamAndOffset();if(config&&core.isFormulaString(config.dataStream)){this._contextService.setContextValue(core.FOCUSING_EDITOR_INPUT_FORMULA,!0),this._contextService.setContextValue(sheets.DISABLE_NORMAL_SELECTIONS,!0),this._contextService.setContextValue(ui.UNI_DISABLE_CHANGING_FOCUS_KEY,!0);const lastSequenceNodes=this._lexerTreeBuilder.sequenceNodesBuilder(config.dataStream)||[];this._formulaPromptService.setSequenceNodes(lastSequenceNodes);const activeRange=this._docSelectionManagerService.getActiveTextRange();if(activeRange==null)return;const{startOffset}=activeRange;this._currentInsertRefStringIndex=startOffset-1+config.offset;return}this._contextService.setContextValue(core.FOCUSING_EDITOR_INPUT_FORMULA,!1),this._contextService.setContextValue(sheets.DISABLE_NORMAL_SELECTIONS,!1),this._contextService.setContextValue(ui.UNI_DISABLE_CHANGING_FOCUS_KEY,!1),this._formulaPromptService.disableLockedSelectionChange(),this._formulaPromptService.disableLockedSelectionInsert(),this._formulaPromptService.clearSequenceNodes(),this._hideFunctionPanel()}_getContextState(){return this._contextService.getContextValue(core.FOCUSING_EDITOR_INPUT_FORMULA)}_highlightFormula(){if(this._getContextState()===!1)return;const sequenceNodes=this._formulaPromptService.getSequenceNodes(),unitIds=this._editorModelUnitIds(),bodyList=this._getFormulaAndCellEditorBody(unitIds).filter(b=>!!b);if(this._refSelectionsService.clear(),sequenceNodes==null||sequenceNodes.length===0)this._existsSequenceNode=!1,bodyList.forEach(body=>body.textRuns=[]);else{this._existsSequenceNode=!0;const{textRuns,refSelections}=this._buildTextRuns(sequenceNodes);bodyList.forEach(body=>body.textRuns=textRuns),this._allSelectionRenderServices.forEach(r2=>this._refreshSelectionForReference(r2,refSelections))}this._refreshFormulaAndCellEditor(unitIds)}_buildTextRuns(sequenceNodes){var _a11;const textRuns=[],refSelections=[],themeColorMap=new Map;let refColorIndex=0;const offset=((_a11=this._getCurrentBodyDataStreamAndOffset())==null?void 0:_a11.offset)||0;for(let i=0,len=sequenceNodes.length;i<len;i++){const node=sequenceNodes[i];if(typeof node=="string"||this._descriptionService.hasDefinedNameDescription(node.token.trim()))continue;const{startIndex,endIndex,nodeType,token}=node;let themeColor="";if(nodeType===engineFormula.sequenceNodeType.REFERENCE){if(themeColorMap.has(token))themeColor=themeColorMap.get(token);else{const colorIndex=refColorIndex%this._formulaRefColors.length;themeColor=this._formulaRefColors[colorIndex],themeColorMap.set(token,themeColor),refColorIndex++}refSelections.push({refIndex:i,themeColor,token})}else nodeType===engineFormula.sequenceNodeType.NUMBER?themeColor=this._numberColor:nodeType===engineFormula.sequenceNodeType.STRING?themeColor=this._stringColor:nodeType===engineFormula.sequenceNodeType.ARRAY&&(themeColor=this._stringColor);themeColor&&themeColor.length>0&&textRuns.push({st:startIndex+1-offset,ed:endIndex+2-offset,ts:{cl:{rgb:themeColor}}})}return{textRuns,refSelections}}_exceedCurrentRange(range,rowCount,columnCount){const{startRow,startColumn}=range;return startRow>rowCount-1||startColumn>columnCount-1}_refreshSelectionForReference(refSelectionRenderService,refSelections){const{unitId,sheetId}=this._editorBridgeService.getEditCellState(),{unitId:selfUnitId,sheetId:selfSheetId}=this._getCurrentUnitIdAndSheetId(),isSelfSheet=sheetId===selfSheetId,worksheet=this._univerInstanceService.getUniverSheetInstance(unitId).getSheetBySheetId(sheetId);let lastRange=null;const selectionWithStyle=[];for(let i=0,len=refSelections.length;i<len;i++){const refSelection=refSelections[i],{themeColor,token,refIndex}=refSelection,gridRange=engineFormula.deserializeRangeWithSheet(token),{unitId:refUnitId,sheetName,range:rawRange}=gridRange,range=sheets.setEndForRange(rawRange,worksheet.getRowCount(),worksheet.getColumnCount());if(refUnitId!=null&&refUnitId.length>0&&unitId!==refUnitId)continue;const refSheetId=this._getSheetIdByName(unitId,sheetName.trim());if(!isSelfSheet&&refSheetId!==selfSheetId||isSelfSheet&&sheetName.length!==0&&refSheetId!==sheetId||this._exceedCurrentRange(range,worksheet.getRowCount(),worksheet.getColumnCount()))continue;const lastRangeCopy=this._getPrimary(range,themeColor,refIndex);if(lastRangeCopy){lastRange=lastRangeCopy;continue}const primary=sheets.getPrimaryForRange(range,worksheet);!core.Rectangle.equals(primary,range)&&range.startRow===range.endRow&&range.startColumn===range.endColumn&&(range.startRow=primary.startRow,range.endRow=primary.endRow,range.startColumn=primary.startColumn,range.endColumn=primary.endColumn),selectionWithStyle.push({range,primary,style:getFormulaRefSelectionStyle(this._themeService,themeColor,refIndex.toString())})}lastRange&&selectionWithStyle.push(lastRange),selectionWithStyle.length&&this._refSelectionsService.addSelections(unitId,sheetId,selectionWithStyle)}_getPrimary(range,themeColor,refIndex){var _a11;const primary=(_a11=this._insertSelections.find(selection=>{const{startRow,startColumn,endRow,endColumn}=selection.range;return startRow===range.startRow&&startColumn===range.startColumn&&endRow===range.endRow&&endColumn===range.endColumn||startRow===range.startRow&&startColumn===range.startColumn&&range.startRow===range.endRow&&range.startColumn===range.endColumn}))==null?void 0:_a11.primary;if(primary==null)return;const{isMerged,isMergedMainCell,startRow:mergeStartRow,endRow:mergeEndRow,startColumn:mergeStartColumn,endColumn:mergeEndColumn}=primary;return(isMerged||isMergedMainCell)&&mergeStartRow===range.startRow&&mergeStartColumn===range.startColumn&&range.startRow===range.endRow&&range.startColumn===range.endColumn&&(range.endRow=mergeEndRow,range.endColumn=mergeEndColumn),{range,primary,style:getFormulaRefSelectionStyle(this._themeService,themeColor,refIndex.toString())}}_getSheetIdByName(unitId,sheetName){var _a11;const workbook=this._univerInstanceService.getUniverSheetInstance(unitId);return(_a11=workbook==null?void 0:workbook.getSheetBySheetName(engineFormula.normalizeSheetName(sheetName)))==null?void 0:_a11.getSheetId()}_getSheetNameById(unitId,sheetId){var _a11;const workbook=this._univerInstanceService.getUniverSheetInstance(unitId);return((_a11=workbook==null?void 0:workbook.getSheetBySheetId(sheetId))==null?void 0:_a11.getName())||""}_getCurrentUnitIdAndSheetId(){var _a11,_b;const workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook.getActiveSheet(),skeleton=(_b=(_a11=this._renderManagerService.getRenderById(workbook.getUnitId()))==null?void 0:_a11.with(sheetsUi.SheetSkeletonManagerService))==null?void 0:_b.getCurrentSkeleton();return{unitId:workbook.getUnitId(),sheetId:(worksheet==null?void 0:worksheet.getSheetId())||"",skeleton}}_getEditorOpenedForSheet(){const editorUnitId=this._univerInstanceService.getCurrentUniverDocInstance().getUnitId(),editor=this._editorService.getEditor(editorUnitId);return editor?{openUnitId:editor.getOpenForSheetUnitId(),openSheetId:editor.getOpenForSheetSubUnitId()}:{openUnitId:null,openSheetId:null}}_generateRefString(currentSelection){let refUnitId="",refSheetName="";const{unitId,sheetId}=currentSelection.range,{openUnitId,openSheetId}=this._getEditorOpenedForSheet();unitId!==openUnitId&&unitId&&(refUnitId=unitId),sheetId!==openSheetId&&unitId&&sheetId&&(refSheetName=this._getSheetNameById(unitId,sheetId));const{range,primary}=currentSelection;let{startRow,endRow,startColumn,endColumn}=range;const{startAbsoluteRefType,endAbsoluteRefType,rangeType}=range;if(primary){const{isMerged,isMergedMainCell,startRow:mergeStartRow,endRow:mergeEndRow,startColumn:mergeStartColumn,endColumn:mergeEndColumn}=primary;(isMerged||isMergedMainCell)&&mergeStartRow===startRow&&mergeStartColumn===startColumn&&mergeEndRow===endRow&&mergeEndColumn===endColumn&&(startRow=mergeStartRow,startColumn=mergeStartColumn,endRow=mergeStartRow,endColumn=mergeStartColumn)}return engineFormula.serializeRangeToRefString({sheetName:refSheetName,unitId:refUnitId,range:{startRow,endRow,startColumn,endColumn,rangeType,startAbsoluteRefType,endAbsoluteRefType}})}_syncToEditor(sequenceNodes,textSelectionOffset,editorUnitId,canUndo=!0,fromSelection=!0){let dataStream=engineFormula.generateStringWithSequence(sequenceNodes);const{textRuns,refSelections}=this._buildTextRuns(sequenceNodes);this._isSelectionMovingRefSelections=refSelections,this._allSelectionRenderServices.forEach(r2=>this._updateRefSelectionStyle(r2,this._isSelectionMovingRefSelections));const activeRange=this._docSelectionManagerService.getActiveTextRange();if(activeRange==null)return;this._currentInsertRefStringIndex=textSelectionOffset,editorUnitId==null&&(editorUnitId=this._univerInstanceService.getCurrentUniverDocInstance().getUnitId()),this._fitEditorSize();const editor=this._editorService.getEditor(editorUnitId);editor!=null&&editor.isSingleChoice()?(dataStream=dataStream.split(",")[0],this._selectionRenderService.setSingleSelectionEnabled(!0)):this._selectionRenderService.setSingleSelectionEnabled(!1);let formulaString=dataStream,offset=1;(!editor||!editor.onlyInputRange())&&(formulaString=`${engineFormula.compareToken.EQUALS}${dataStream}`,offset=0);const{collapsed,style}=activeRange;canUndo?(this._commandService.executeCommand(docsUi.ReplaceContentCommand.id,{unitId:editorUnitId,body:{dataStream:formulaString,textRuns},textRanges:[{startOffset:textSelectionOffset+1-offset,endOffset:textSelectionOffset+1-offset,collapsed,style}],segmentId:null,options:{fromSelection}}),this._docSelectionManagerService.replaceTextRanges([{startOffset:textSelectionOffset+1-offset,endOffset:textSelectionOffset+1-offset,style}],!0,{fromSelection})):(this._updateEditorModel(`${formulaString}\r
|
|
14
14
|
`,textRuns),this._docSelectionManagerService.replaceTextRanges([{startOffset:textSelectionOffset+1-offset,endOffset:textSelectionOffset+1-offset,style}],!0,{fromSelection})),this._layoutService.focus()}_fitEditorSize(){const editorUnitId=this._univerInstanceService.getCurrentUniverDocInstance().getUnitId();this._editorService.isEditor(editorUnitId)&&!this._editorService.isSheetEditor(editorUnitId)||this._commandService.executeCommand(ui.SetEditorResizeOperation.id,{unitId:editorUnitId})}_updateEditorModel(dataStream,textRuns){var _a11;const documentDataModel=this._univerInstanceService.getCurrentUniverDocInstance(),editorUnitId=documentDataModel.getUnitId();if(!this._editorService.isEditor(editorUnitId))return;const docViewModel=(_a11=this._renderManagerService.getRenderById(editorUnitId))==null?void 0:_a11.with(docs.DocSkeletonManagerService).getViewModel();if(docViewModel==null||documentDataModel==null)return;const snapshot=documentDataModel==null?void 0:documentDataModel.getSnapshot();if(snapshot==null)return;const newBody={dataStream,textRuns};snapshot.body=newBody,docViewModel.reset(documentDataModel)}_insertControlSelectionReplace(currentSelection){this._previousSequenceNodes==null&&(this._previousSequenceNodes=this._formulaPromptService.getSequenceNodes()),this._previousInsertRefStringIndex==null&&(this._previousInsertRefStringIndex=this._currentInsertRefStringIndex);const insertNodes=core.Tools.deepClone(this._previousSequenceNodes);if(insertNodes==null)return;const refString=this._generateRefString(currentSelection);this._formulaPromptService.setSequenceNodes(insertNodes),this._formulaPromptService.insertSequenceRef(this._previousInsertRefStringIndex,refString),this._syncToEditor(insertNodes,this._previousInsertRefStringIndex+refString.length);const selectionDatas=this._selectionRenderService.getSelectionDataWithStyle();this._insertSelections=[],selectionDatas.forEach(currentSelection2=>{const range=sheets.convertSelectionDataToRange(currentSelection2);this._insertSelections.push(range)})}_focusIsOnlyRange(selectionCount){const currentEditor=this._editorService.getFocusEditor();return!currentEditor||!currentEditor.onlyInputRange()||this._existsSequenceNode||selectionCount>1||this._previousSequenceNodes!=null&&this._previousSequenceNodes.length>0?!0:(this._previousInsertRefStringIndex!=null&&(this._previousInsertRefStringIndex+=1),!1)}_resetSequenceNodes(selectionCount){const currentEditor=this._editorService.getFocusEditor();currentEditor&¤tEditor.onlyInputRange()&&(selectionCount>1||this._existsSequenceNode&&(this._formulaPromptService.clearSequenceNodes(),this._previousRangesCount=0,this._existsSequenceNode=!1))}_updateRefSelectionStyle(refSelectionRenderService,refSelections){const controls=refSelectionRenderService.getSelectionControls(),[unitId,sheetId]=refSelectionRenderService.getLocation(),matchedControls=new Set;for(let i=0,len=refSelections.length;i<len;i++){const refSelection=refSelections[i],{refIndex,themeColor,token}=refSelection,rangeWithSheet=engineFormula.deserializeRangeWithSheet(token),{unitId:refUnitId,sheetName,range}=rangeWithSheet;if(!refUnitId&&refUnitId.length>0&&unitId!==refUnitId)continue;const refSheetId=this._getSheetIdByName(unitId,sheetName.trim());if(refSheetId&&refSheetId!==sheetId)continue;const control=controls.find(c=>{const{startRow,startColumn,endRow,endColumn,rangeType}=c.getRange();return rangeType===core.RANGE_TYPE.COLUMN&&startColumn===range.startColumn&&endColumn===range.endColumn||rangeType===core.RANGE_TYPE.ROW&&startRow===range.startRow&&endRow===range.endRow||startRow===range.startRow&&startColumn===range.startColumn&&endRow===range.endRow&&endColumn===range.endColumn||startRow===range.startRow&&startColumn===range.startColumn&&range.startRow===range.endRow&&range.startColumn===range.endColumn});if(control){const style=getFormulaRefSelectionStyle(this._themeService,themeColor,refIndex.toString());control.updateStyle(style),matchedControls.add(control)}}}_onSelectionControlChange(toRange,selectionControl){var _a11;const{skeleton}=this._getCurrentUnitIdAndSheetId();this._formulaPromptService.enableLockedSelectionChange();const id=(_a11=selectionControl.currentStyle)==null?void 0:_a11.id;if(!id||!core.Tools.isStringNumber(id))return;let{startRow,endRow,startColumn,endColumn}=toRange;const primary=skeleton?skeleton.worksheet.getCellInfoInMergeData(startRow,startColumn):{actualRow:startRow,actualColumn:startColumn,isMergedMainCell:!1,isMerged:!1,endRow:startRow,endColumn:startColumn,startRow,startColumn};if(primary){const{isMerged,isMergedMainCell,startRow:mergeStartRow,endRow:mergeEndRow,startColumn:mergeStartColumn,endColumn:mergeEndColumn}=primary;(isMerged||isMergedMainCell)&&mergeStartRow===startRow&&mergeStartColumn===startColumn&&mergeEndRow===endRow&&mergeEndColumn===endColumn&&(startRow=mergeStartRow,startColumn=mergeStartColumn,endRow=mergeStartRow,endColumn=mergeStartColumn)}const nodeIndex=Number(id),currentNode=this._formulaPromptService.getCurrentSequenceNodeByIndex(nodeIndex);if(!currentNode)return;let refType={startAbsoluteRefType:core.AbsoluteRefType.NONE};if(typeof currentNode!="string"){const token=currentNode.token;refType=engineFormula.getAbsoluteRefTypeWitString(token),refType.endAbsoluteRefType==null&&(refType.endAbsoluteRefType=refType.startAbsoluteRefType)}const unitId=skeleton==null?void 0:skeleton.worksheet.getUnitId(),sheetId=skeleton==null?void 0:skeleton.worksheet.getSheetId(),refString=this._generateRefString({range:{startRow:Math.min(startRow,endRow),endRow:Math.max(startRow,endRow),startColumn:Math.min(startColumn,endColumn),endColumn:Math.max(startColumn,endColumn),...refType,sheetId,unitId},primary,style:null});this._formulaPromptService.updateSequenceRef(nodeIndex,refString);const sequenceNodes=this._formulaPromptService.getSequenceNodes(),node=sequenceNodes[nodeIndex];typeof node!="string"&&(this._syncToEditor(sequenceNodes,node.endIndex+1),selectionControl.update(toRange,void 0,void 0,void 0,this._selectionRenderService.attachPrimaryWithCoord(primary)))}_refreshFormulaAndCellEditor(unitIds){var _a11;for(const unitId of unitIds){const editorObject=sheetsUi.getEditorObject(unitId,this._renderManagerService),documentComponent=editorObject==null?void 0:editorObject.document;documentComponent!=null&&((_a11=documentComponent.getSkeleton())==null||_a11.calculate(),documentComponent.makeDirty())}}_cursorStateListener(){const editorObject=this._getEditorObject();if(editorObject==null)return;const{mainComponent:documentComponent}=editorObject;documentComponent&&this.disposeWithMe(documentComponent.onPointerDown$.subscribeEvent(()=>{this._arrowMoveActionState=1,this._inputPanelState=3}))}_pressEnter(params){const{keycode,isSingleEditor=!1}=params;if(this._formulaPromptService.isSearching()){this._formulaPromptService.accept(!0);return}isSingleEditor!==!0&&this._editorBridgeService.changeVisible({visible:!1,eventType:engineRender.DeviceInputEventType.Keyboard,keycode,unitId:""})}_pressTab(params){const{keycode,isSingleEditor=!1}=params;if(this._formulaPromptService.isSearching()){this._formulaPromptService.accept(!0);return}isSingleEditor!==!0&&this._editorBridgeService.changeVisible({visible:!1,eventType:engineRender.DeviceInputEventType.Keyboard,keycode,unitId:""})}_pressEsc(params){const{keycode}=params,focusEditor=this._editorService.getFocusEditor();(!focusEditor||(focusEditor==null?void 0:focusEditor.isSheetEditor())===!0)&&this._editorBridgeService.changeVisible({visible:!1,eventType:engineRender.DeviceInputEventType.Keyboard,keycode,unitId:""})}_pressArrowKey(params){const{keycode,metaKey}=params;let direction=core.Direction.DOWN;keycode===ui.KeyCode.ARROW_DOWN?direction=core.Direction.DOWN:keycode===ui.KeyCode.ARROW_UP?direction=core.Direction.UP:keycode===ui.KeyCode.ARROW_LEFT?direction=core.Direction.LEFT:keycode===ui.KeyCode.ARROW_RIGHT&&(direction=core.Direction.RIGHT),metaKey===ui.MetaKeys.CTRL_COMMAND?this._commandService.executeCommand(sheetsUi.MoveSelectionCommand.id,{direction,jumpOver:sheetsUi.JumpOver.moveGap}):metaKey===ui.MetaKeys.SHIFT?this._commandService.executeCommand(sheetsUi.ExpandSelectionCommand.id,{direction}):metaKey===META_KEY_CTRL_AND_SHIFT?this._commandService.executeCommand(sheetsUi.ExpandSelectionCommand.id,{direction,jumpOver:sheetsUi.JumpOver.moveGap}):this._commandService.executeCommand(sheetsUi.MoveSelectionCommand.id,{direction})}_commandExecutedListener(){const updateCommandList=[SelectEditorFormulaOperation.id];this.disposeWithMe(this._commandService.onCommandExecuted(command=>{if(command.id===ReferenceAbsoluteOperation.id)this._changeRefString();else if(updateCommandList.includes(command.id)){const params=command.params,{keycode,isSingleEditor=!1}=params;if(keycode===ui.KeyCode.ENTER){this._pressEnter(params);return}if(keycode===ui.KeyCode.TAB){this._pressTab(params);return}if(keycode===ui.KeyCode.ESC){this._pressEsc(params);return}if(this._formulaPromptService.isSearching()){if(keycode===ui.KeyCode.ARROW_DOWN){this._formulaPromptService.navigate({direction:core.Direction.DOWN});return}if(keycode===ui.KeyCode.ARROW_UP){this._formulaPromptService.navigate({direction:core.Direction.UP});return}}if(isSingleEditor===!0)return;if(this._arrowMoveActionState===1){this._moveInEditor(keycode);return}if(this._arrowMoveActionState===4){this._editorBridgeService.changeVisible({visible:!1,eventType:engineRender.DeviceInputEventType.Keyboard,keycode,unitId:""});return}if(this._arrowMoveActionState===2&&(this._arrowMoveActionState=3),this._refSelectionsService.getCurrentSelections().length===0){const selectionData=this._sheetsSelectionsService.getCurrentLastSelection();if(selectionData!=null){const selectionDataNew=core.Tools.deepClone(selectionData);this._refSelectionsService.addSelections([selectionDataNew])}}this._pressArrowKey(params);const selectionWithStyles=this._refSelectionsService.getCurrentSelections(),currentSelection=selectionWithStyles[selectionWithStyles.length-1];this._insertControlSelectionReplace(currentSelection),this._highlightFormula()}}))}_moveInEditor(keycode){if(keycode==null)return;let direction=core.Direction.LEFT;keycode===ui.KeyCode.ARROW_DOWN?direction=core.Direction.DOWN:keycode===ui.KeyCode.ARROW_UP?direction=core.Direction.UP:keycode===ui.KeyCode.ARROW_RIGHT&&(direction=core.Direction.RIGHT),this._commandService.executeCommand(docsUi.MoveCursorOperation.id,{direction})}_userMouseListener(){const editorObject=this._getEditorObject();if(editorObject==null)return;const{mainComponent:documentComponent}=editorObject;documentComponent&&this.disposeWithMe(documentComponent==null?void 0:documentComponent.onPointerDown$.subscribeEvent(()=>{this._userCursorMove=!0}))}_inputFormulaListener(){this.disposeWithMe(this._editorService.inputFormula$.subscribe(param=>{const{formulaString,editorUnitId}=param;if(formulaString.substring(0,1)!==engineFormula.compareToken.EQUALS)return;const{unitId}=this._getCurrentUnitIdAndSheetId();this._editorBridgeService.isVisible().visible===!1&&this._editorBridgeService.changeVisible({visible:!0,eventType:engineRender.DeviceInputEventType.Dblclick,unitId});const lastSequenceNodes=this._lexerTreeBuilder.sequenceNodesBuilder(formulaString)||[];this._formulaPromptService.setSequenceNodes(lastSequenceNodes),this._syncToEditor(lastSequenceNodes,formulaString.length-1,editorUnitId,!0,!1)}))}_changeRefString(){const activeRange=this._docSelectionManagerService.getActiveTextRange();if(activeRange==null)return;const{startOffset}=activeRange,strIndex=startOffset-2,nodeIndex=this._formulaPromptService.getCurrentSequenceNodeIndex(strIndex),node=this._formulaPromptService.getCurrentSequenceNodeByIndex(nodeIndex);if(node==null||typeof node=="string"||node.nodeType!==engineFormula.sequenceNodeType.REFERENCE)return;const tokenArray=node.token.split("!");let token=node.token;tokenArray.length>1&&(token=tokenArray[tokenArray.length-1]);let unitIDAndSheetName="";for(let i=0,len=tokenArray.length;i<len-1;i++)unitIDAndSheetName+=tokenArray[i];let finalToken=token;if(token.indexOf(engineFormula.matchToken.COLON)>-1)if(!this._userCursorMove)finalToken=this._changeRangeRef(token);else{const refStringSplit=token.split(engineFormula.matchToken.COLON),prefix=refStringSplit[0],suffix=refStringSplit[1];strIndex-node.startIndex<=prefix.length?finalToken=this._changeSingleRef(prefix)+engineFormula.matchToken.COLON+suffix:finalToken=prefix+engineFormula.matchToken.COLON+this._changeSingleRef(suffix)}else finalToken=this._changeSingleRef(token);finalToken=unitIDAndSheetName+finalToken;const difference=finalToken.length-node.token.length;this._formulaPromptService.updateSequenceRef(nodeIndex,finalToken),this._syncToEditor(this._formulaPromptService.getSequenceNodes(),strIndex+difference+1)}_changeRangeRef(token){const range=engineFormula.deserializeRangeWithSheet(token).range;let resultToken="";return range.startAbsoluteRefType===core.AbsoluteRefType.NONE||range.startAbsoluteRefType==null?(range.startAbsoluteRefType=core.AbsoluteRefType.ALL,range.endAbsoluteRefType=core.AbsoluteRefType.ALL):(range.startAbsoluteRefType=core.AbsoluteRefType.NONE,range.endAbsoluteRefType=core.AbsoluteRefType.NONE),resultToken=engineFormula.serializeRange(range),resultToken}_changeSingleRef(token){const range=engineFormula.deserializeRangeWithSheet(token).range,type=range.startAbsoluteRefType;let resultToken="";return type===core.AbsoluteRefType.NONE||type==null?(range.startAbsoluteRefType=core.AbsoluteRefType.ALL,range.endAbsoluteRefType=core.AbsoluteRefType.ALL):type===core.AbsoluteRefType.ALL?(range.startAbsoluteRefType=core.AbsoluteRefType.ROW,range.endAbsoluteRefType=core.AbsoluteRefType.ROW):type===core.AbsoluteRefType.ROW?(range.startAbsoluteRefType=core.AbsoluteRefType.COLUMN,range.endAbsoluteRefType=core.AbsoluteRefType.COLUMN):(range.startAbsoluteRefType=core.AbsoluteRefType.NONE,range.endAbsoluteRefType=core.AbsoluteRefType.NONE),resultToken=engineFormula.serializeRange(range),resultToken}_getEditorObject(){const editorUnitId=this._univerInstanceService.getCurrentUniverDocInstance().getUnitId(),editor=this._editorService.getEditor(editorUnitId);return editor==null?void 0:editor.render}_isFormulaEditorActivated(){return this._editorBridgeService.isVisible().visible===!0||this._contextService.getContextValue(core.FORMULA_EDITOR_ACTIVATED)}_isSheetOrFormulaEditor(editor){return editor.isSheetEditor()||editor.isFormulaEditor()}},__name(_a9,"PromptController"),_a9);PromptController=__decorateClass$1([__decorateParam$1(0,core.ICommandService),__decorateParam$1(1,core.IContextService),__decorateParam$1(2,core.Inject(sheetsUi.IEditorBridgeService)),__decorateParam$1(3,core.Inject(IFormulaPromptService)),__decorateParam$1(4,core.Inject(engineFormula.LexerTreeBuilder)),__decorateParam$1(5,engineRender.IRenderManagerService),__decorateParam$1(6,core.Inject(core.ThemeService)),__decorateParam$1(7,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$1(8,sheets.IRefSelectionsService),__decorateParam$1(9,core.IUniverInstanceService),__decorateParam$1(10,core.Inject(sheetsFormula.IDescriptionService)),__decorateParam$1(11,core.Inject(docs.DocSelectionManagerService)),__decorateParam$1(12,ui.IContextMenuService),__decorateParam$1(13,docsUi.IEditorService),__decorateParam$1(14,ui.ILayoutService)],PromptController);var __defProp2=Object.defineProperty,__getOwnPropDesc=Object.getOwnPropertyDescriptor,__defNormalProp2=__name((obj,key,value)=>key in obj?__defProp2(obj,key,{enumerable:!0,configurable:!0,writable:!0,value}):obj[key]=value,"__defNormalProp"),__decorateClass=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp2(target,key,result),result},"__decorateClass"),__decorateParam=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam"),__publicField2=__name((obj,key,value)=>__defNormalProp2(obj,typeof key!="symbol"?key+"":key,value),"__publicField"),_a10;exports.UniverSheetsFormulaUIPlugin=(_a10=class extends core.Plugin{constructor(_config=defaultPluginBaseConfig,_injector,_renderManagerService,_configService){super(),this._config=_config,this._injector=_injector,this._renderManagerService=_renderManagerService,this._configService=_configService;const{menu,...rest}=this._config;menu&&this._configService.setConfig("menu",menu,{merge:!0}),this._configService.setConfig(PLUGIN_CONFIG_KEY_BASE,rest)}onStarting(){const j=this._injector;[[IFormulaPromptService,{useClass:FormulaPromptService}],[FormulaUIController],[FormulaAutoFillController],[FormulaClipboardController],[FormulaEditorShowController],[FormulaRenderManagerController],[PromptController]].forEach(dependency=>j.add(dependency))}onReady(){this._injector.get(FormulaUIController)}onRendered(){[[exports.RefSelectionsRenderService],[FormulaAlertRenderController]].forEach(dep=>{this.disposeWithMe(this._renderManagerService.registerRenderModule(core.UniverInstanceType.UNIVER_SHEET,dep))}),this._injector.get(FormulaClipboardController),this._injector.get(FormulaRenderManagerController),this._injector.get(ui.ComponentManager).register(sheetsUi.RANGE_SELECTOR_COMPONENT_KEY,RangeSelector)}onSteady(){this._injector.get(FormulaAutoFillController),this._injector.get(PromptController)}},__name(_a10,"UniverSheetsFormulaUIPlugin"),_a10);__publicField2(exports.UniverSheetsFormulaUIPlugin,"pluginName",FORMULA_UI_PLUGIN_NAME);__publicField2(exports.UniverSheetsFormulaUIPlugin,"type",core.UniverInstanceType.UNIVER_SHEET);exports.UniverSheetsFormulaUIPlugin=__decorateClass([core.DependentOn(engineFormula.UniverFormulaEnginePlugin,sheetsFormula.UniverSheetsFormulaPlugin),__decorateParam(1,core.Inject(core.Injector)),__decorateParam(2,engineRender.IRenderManagerService),__decorateParam(3,core.IConfigService)],exports.UniverSheetsFormulaUIPlugin);exports.FORMULA_PROMPT_ACTIVATED=FORMULA_PROMPT_ACTIVATED;exports.HelpFunctionOperation=HelpFunctionOperation;exports.InsertFunctionOperation=InsertFunctionOperation;exports.MoreFunctionsOperation=MoreFunctionsOperation;exports.RangeSelector=RangeSelector;exports.ReferenceAbsoluteOperation=ReferenceAbsoluteOperation;exports.SearchFunctionOperation=SearchFunctionOperation;exports.SelectEditorFormulaOperation=SelectEditorFormulaOperation;exports.SheetOnlyPasteFormulaCommand=SheetOnlyPasteFormulaCommand;
|