@univerjs/sheets-data-validation 0.1.11 → 0.1.13

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/umd/index.js CHANGED
@@ -1,4 +1,4 @@
1
- (function(g,l){typeof exports=="object"&&typeof module<"u"?l(exports,require("@univerjs/core"),require("@wendellhu/redi"),require("@univerjs/data-validation"),require("@univerjs/ui"),require("@univerjs/sheets-ui"),require("@univerjs/engine-render"),require("@univerjs/sheets"),require("react"),require("@wendellhu/redi/react-bindings"),require("@univerjs/design"),require("@univerjs/engine-formula"),require("rxjs"),require("dayjs"),require("clsx"),require("@univerjs/sheets-formula"),require("rxjs/operators")):typeof define=="function"&&define.amd?define(["exports","@univerjs/core","@wendellhu/redi","@univerjs/data-validation","@univerjs/ui","@univerjs/sheets-ui","@univerjs/engine-render","@univerjs/sheets","react","@wendellhu/redi/react-bindings","@univerjs/design","@univerjs/engine-formula","rxjs","dayjs","clsx","@univerjs/sheets-formula","rxjs/operators"],l):(g=typeof globalThis<"u"?globalThis:g||self,l(g.UniverSheetsDataValidation={},g.UniverCore,g["@wendellhu/redi"],g.UniverDataValidation,g.UniverUi,g.UniverSheetsUi,g.UniverEngineRender,g.UniverSheets,g.React,g["@wendellhu/redi/react-bindings"],g.UniverDesign,g.UniverEngineFormula,g.rxjs,g.dayjs,g.clsx,g.UniverSheetsFormula,g.rxjs.operators))})(this,function(g,l,V,M,P,j,X,re,F,N,E,ie,pe,ge,ta,Le,Xe){"use strict";var Vr=Object.defineProperty;var Dr=(g,l,V)=>l in g?Vr(g,l,{enumerable:!0,configurable:!0,writable:!0,value:V}):g[l]=V;var S=(g,l,V)=>(Dr(g,typeof l!="symbol"?l+"":l,V),V);var vt,ze;var _t={exports:{}},Ae={};/**
1
+ (function(g,s){typeof exports=="object"&&typeof module<"u"?s(exports,require("@univerjs/core"),require("@wendellhu/redi"),require("@univerjs/data-validation"),require("@univerjs/ui"),require("@univerjs/sheets-ui"),require("@univerjs/engine-render"),require("@univerjs/sheets"),require("react"),require("@wendellhu/redi/react-bindings"),require("@univerjs/design"),require("@univerjs/engine-formula"),require("rxjs"),require("clsx"),require("@univerjs/sheets-formula"),require("dayjs"),require("rxjs/operators")):typeof define=="function"&&define.amd?define(["exports","@univerjs/core","@wendellhu/redi","@univerjs/data-validation","@univerjs/ui","@univerjs/sheets-ui","@univerjs/engine-render","@univerjs/sheets","react","@wendellhu/redi/react-bindings","@univerjs/design","@univerjs/engine-formula","rxjs","clsx","@univerjs/sheets-formula","dayjs","rxjs/operators"],s):(g=typeof globalThis<"u"?globalThis:g||self,s(g.UniverSheetsDataValidation={},g.UniverCore,g["@wendellhu/redi"],g.UniverDataValidation,g.UniverUi,g.UniverSheetsUi,g.UniverEngineRender,g.UniverSheets,g.React,g["@wendellhu/redi/react-bindings"],g.UniverDesign,g.UniverEngineFormula,g.rxjs,g.clsx,g.UniverSheetsFormula,g.dayjs,g.rxjs.operators))})(this,function(g,s,I,R,W,j,Z,q,E,N,O,ie,ue,ra,Le,Se,Je){"use strict";var Fr=Object.defineProperty;var br=(g,s,I)=>s in g?Fr(g,s,{enumerable:!0,configurable:!0,writable:!0,value:I}):g[s]=I;var _=(g,s,I)=>(br(g,typeof s!="symbol"?s+"":s,I),I);var Vt,Ze;var Rt={exports:{}},Ne={};/**
2
2
  * @license React
3
3
  * react-jsx-runtime.production.min.js
4
4
  *
@@ -6,4 +6,4 @@
6
6
  *
7
7
  * This source code is licensed under the MIT license found in the
8
8
  * LICENSE file in the root directory of this source tree.
9
- */var aa=F,na=Symbol.for("react.element"),ra=Symbol.for("react.fragment"),oa=Object.prototype.hasOwnProperty,ia=aa.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,la={key:!0,ref:!0,__self:!0,__source:!0};function St(i,r,e){var t,a={},n=null,o=null;e!==void 0&&(n=""+e),r.key!==void 0&&(n=""+r.key),r.ref!==void 0&&(o=r.ref);for(t in r)oa.call(r,t)&&!la.hasOwnProperty(t)&&(a[t]=r[t]);if(i&&i.defaultProps)for(t in r=i.defaultProps,r)a[t]===void 0&&(a[t]=r[t]);return{$$typeof:na,type:i,key:n,ref:o,props:a,_owner:ia.current}}Ae.Fragment=ra,Ae.jsx=St,Ae.jsxs=St,_t.exports=Ae;var f=_t.exports;function sa(){const i=N.useDependency(Se),r=P.useObservable(i.activeDropdown$,i.activeDropdown),e=N.useDependency(P.ComponentManager);if(!r)return null;const{location:t,componentKey:a}=r,n=e.get(a),o=`${t.unitId}-${t.subUnitId}-${t.row}-${t.col}`;if(!n)return null;const s=()=>{i.hideDropdown()};return f.jsx(n,{location:t,hideFn:s},o)}const Rt="sheet.ui.dropdown";var ua=Object.defineProperty,da=Object.getOwnPropertyDescriptor,ca=(i,r,e,t)=>{for(var a=t>1?void 0:t?da(r,e):r,n=i.length-1,o;n>=0;n--)(o=i[n])&&(a=(t?o(r,e,a):o(a))||a);return t&&a&&ua(r,e,a),a},_e=(i,r)=>(e,t)=>r(e,t,i);let Se=class extends l.Disposable{constructor(r,e,t,a,n,o,s){super();S(this,"_activeDropdown");S(this,"_activeDropdown$",new pe.Subject);S(this,"_currentPopup",null);S(this,"activeDropdown$",this._activeDropdown$.asObservable());S(this,"_zenVisible",!1);this._canvasPopupManagerService=r,this._univerInstanceService=e,this._sheetSkeletonManagerService=t,this._dataValidatorRegistryService=a,this._zenZoneService=n,this._renderManagerService=o,this._dataValidationModel=s,this._init()}get activeDropdown(){return this._activeDropdown}_init(){this.disposeWithMe(this._zenZoneService.visible$.subscribe(r=>{this._zenVisible=r,r&&this.hideDropdown()}))}showDropdown(r){const{location:e}=r,{row:t,col:a}=e;if(this._currentPopup&&this._currentPopup.dispose(),this._zenVisible)return;this._activeDropdown=r,this._activeDropdown$.next(this._activeDropdown);const n=this._renderManagerService.getRenderById(l.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),o=this._canvasPopupManagerService.attachPopupToCell(t,a,{componentKey:Rt,onClickOutside:()=>{this.hideDropdown()},offset:[0,3],excludeOutside:[n==null?void 0:n.engine.getCanvasElement()].filter(Boolean)});if(!o)throw new Error("[DataValidationDropdownManagerService]: cannot show dropdown!");const s=new l.DisposableCollection;s.add(o),s.add({dispose:()=>{var u,d;(d=(u=this._activeDropdown)==null?void 0:u.onHide)==null||d.call(u)}}),this._currentPopup=s}hideDropdown(){this._activeDropdown&&(this._currentPopup&&this._currentPopup.dispose(),this._currentPopup=null,this._activeDropdown=null,this._activeDropdown$.next(null))}showDataValidationDropdown(r,e,t,a,n){const o=this._univerInstanceService.getUniverSheetInstance(r);if(!o)return;const s=o.getSheetBySheetId(e);if(!s)return;const d=this._dataValidationModel.ensureManager(r,e).getRuleByLocation(t,a);if(!this._sheetSkeletonManagerService.getOrCreateSkeleton({unitId:r,sheetId:e})||!d)return;const h=this._dataValidatorRegistryService.getValidatorItem(d.type);if(!h||!h.dropdown){this.hideDropdown();return}this.showDropdown({location:{workbook:o,worksheet:s,row:t,col:a,unitId:r,subUnitId:e},componentKey:h.dropdown,onHide:n})}};Se=ca([_e(0,V.Inject(j.SheetCanvasPopManagerService)),_e(1,l.IUniverInstanceService),_e(2,V.Inject(j.SheetSkeletonManagerService)),_e(3,V.Inject(M.DataValidatorRegistryService)),_e(4,P.IZenZoneService),_e(5,X.IRenderManagerService),_e(6,V.Inject(M.DataValidationModel))],Se);var ma=Object.defineProperty,ha=Object.getOwnPropertyDescriptor,pa=(i,r,e,t)=>{for(var a=t>1?void 0:t?ha(r,e):r,n=i.length-1,o;n>=0;n--)(o=i[n])&&(a=(t?o(r,e,a):o(a))||a);return t&&a&&ma(r,e,a),a},Mt=(i,r)=>(e,t)=>r(e,t,i);let ue=class extends l.Disposable{constructor(r,e){super();S(this,"_open$",new pe.BehaviorSubject(!1));S(this,"open$",this._open$.pipe(pe.distinctUntilChanged()));S(this,"_activeRule");S(this,"_activeRule$",new pe.BehaviorSubject(void 0));S(this,"activeRule$",this._activeRule$.asObservable());S(this,"_closeDisposable",null);this._univerInstanceService=r,this._sidebarService=e,this.disposeWithMe(this._univerInstanceService.getCurrentTypeOfUnit$(l.UniverInstanceType.UNIVER_SHEET).pipe(pe.filter(t=>!t)).subscribe(()=>{this.close()}))}get activeRule(){return this._activeRule}get isOpen(){return this._open$.getValue()}dispose(){var r;super.dispose(),this._open$.next(!1),this._open$.complete(),(r=this._closeDisposable)==null||r.dispose()}open(){this._open$.next(!0)}close(){var r;this._open$.next(!1),(r=this._closeDisposable)==null||r.dispose()}setCloseDisposable(r){this._closeDisposable=l.toDisposable(()=>{r.dispose(),this._closeDisposable=null})}setActiveRule(r){this._activeRule=r,this._activeRule$.next(r)}};ue=pa([Mt(0,l.IUniverInstanceService),Mt(1,P.ISidebarService)],ue);const Vt="DataValidationPanel",Fe={id:"data-validation.operation.open-validation-panel",type:l.CommandType.OPERATION,handler(i,r){if(!r)return!1;const{ruleId:e,isAdd:t}=r,a=i.get(ue),n=i.get(M.DataValidationModel),o=i.get(l.IUniverInstanceService),s=i.get(P.ISidebarService),u=re.getSheetCommandTarget(o);if(!u)return!1;const{unitId:d,subUnitId:c}=u,h=e?n.getRuleById(d,c,e):void 0;a.open(),a.setActiveRule(h&&{unitId:d,subUnitId:c,rule:h});const p=s.open({header:{title:t?"dataValidation.panel.addTitle":"dataValidation.panel.title"},children:{label:Vt},width:312,onClose:()=>a.close()});return a.setCloseDisposable(p),!0}},Dt={id:"data-validation.operation.close-validation-panel",type:l.CommandType.OPERATION,handler(i){return i.get(ue).close(),!0}},fa={id:"data-validation.operation.toggle-validation-panel",type:l.CommandType.OPERATION,handler(i){const r=i.get(l.ICommandService),e=i.get(ue);return e.open(),e.isOpen?r.executeCommand(Dt.id):r.executeCommand(Fe.id),!0}},be={type:l.CommandType.OPERATION,id:"sheet.operation.show-data-validation-dropdown",handler(i,r){if(!r)return!1;const e=i.get(Se),{unitId:t,subUnitId:a,row:n,column:o}=r,s=e.activeDropdown,u=s==null?void 0:s.location;return u&&u.unitId===t&&u.subUnitId===a&&u.row===n&&u.col===o||e.showDataValidationDropdown(t,a,n,o),!0}},Ot={type:l.CommandType.OPERATION,id:"sheet.operation.hide-data-validation-dropdown",handler(i,r){return r?(i.get(Se).hideDropdown(),!0):!1}};function De(i,r,e){const t=[],a=[];return e.forEach(n=>{switch(n.type){case"delete":t.push({id:M.RemoveDataValidationMutation.id,params:{unitId:i,subUnitId:r,ruleId:n.rule.uid}}),a.unshift({id:M.AddDataValidationMutation.id,params:{unitId:i,subUnitId:r,rule:n.rule,index:n.index}});break;case"update":{t.push({id:M.UpdateDataValidationMutation.id,params:{unitId:i,subUnitId:r,ruleId:n.ruleId,payload:{type:M.UpdateRuleType.RANGE,payload:n.newRanges}}}),a.unshift({id:M.UpdateDataValidationMutation.id,params:{unitId:i,subUnitId:r,ruleId:n.ruleId,payload:{type:M.UpdateRuleType.RANGE,payload:n.oldRanges}}});break}case"add":{t.push({id:M.AddDataValidationMutation.id,params:{unitId:i,subUnitId:r,rule:n.rule}}),a.unshift({id:M.RemoveDataValidationMutation.id,params:{unitId:i,subUnitId:r,ruleId:n.rule.uid}});break}}}),{redoMutations:t,undoMutations:a}}const Qe={type:l.CommandType.COMMAND,id:"sheet.command.updateDataValidationRuleRange",async handler(i,r){if(!r)return!1;const{unitId:e,subUnitId:t,ranges:a,ruleId:n}=r,o=i.get(M.DataValidationModel),s=i.get(l.ICommandService),u=i.get(l.IUndoRedoService),d=o.ensureManager(e,t),c=d.getRuleById(n);if(!c)return!1;const h=c.ranges,p=d.getRuleObjectMatrix().clone();p.updateRange(n,h,a);const m=p.diff(d.getDataValidations()),{redoMutations:_,undoMutations:v}=De(e,t,m);return u.pushUndoRedo({undoMutations:v,redoMutations:_,unitID:e}),await l.sequenceExecuteAsync(_,s),!0}},Ne={type:l.CommandType.COMMAND,id:"sheet.command.addDataValidation",async handler(i,r){if(!r)return!1;const{unitId:e,subUnitId:t,rule:a}=r,n=i.get(M.DataValidationModel),o=i.get(l.ICommandService),s=i.get(l.IUndoRedoService),u=n.ensureManager(e,t),d=u.getRuleObjectMatrix().clone();d.addRule(a);const c=d.diff(u.getDataValidations()),h={unitId:e,subUnitId:t,rule:a},{redoMutations:p,undoMutations:m}=De(e,t,c);return p.push({id:M.AddDataValidationMutation.id,params:h}),m.unshift({id:M.RemoveDataValidationMutation.id,params:{unitId:e,subUnitId:t,ruleId:a.uid}}),s.pushUndoRedo({unitID:e,redoMutations:p,undoMutations:m}),await l.sequenceExecuteAsync(p,o),!0}},Ke={type:l.CommandType.COMMAND,id:"data-validation.command.addRuleAndOpen",async handler(i){const r=i.get(l.IUniverInstanceService),e=re.getSheetCommandTarget(r);if(!e)return!1;const{workbook:t,worksheet:a}=e,n=M.createDefaultNewRule(i),o=i.get(l.ICommandService),s=t.getUnitId(),u=a.getSheetId(),d={rule:n,unitId:s,subUnitId:u};return await o.executeCommand(Ne.id,d)?(o.executeCommand(Fe.id,{ruleId:n.uid,isAdd:!0}),!0):!1}};var oe=function(){return oe=Object.assign||function(i){for(var r,e=1,t=arguments.length;e<t;e++){r=arguments[e];for(var a in r)Object.prototype.hasOwnProperty.call(r,a)&&(i[a]=r[a])}return i},oe.apply(this,arguments)},va=function(i,r){var e={};for(var t in i)Object.prototype.hasOwnProperty.call(i,t)&&r.indexOf(t)<0&&(e[t]=i[t]);if(i!=null&&typeof Object.getOwnPropertySymbols=="function")for(var a=0,t=Object.getOwnPropertySymbols(i);a<t.length;a++)r.indexOf(t[a])<0&&Object.prototype.propertyIsEnumerable.call(i,t[a])&&(e[t[a]]=i[t[a]]);return e},fe=F.forwardRef(function(i,r){var e=i.icon,t=i.id,a=i.className,n=i.extend,o=va(i,["icon","id","className","extend"]),s="univerjs-icon univerjs-icon-".concat(t," ").concat(a||"").trim(),u=F.useRef("_".concat(Sa()));return It(e,"".concat(t),{defIds:e.defIds,idSuffix:u.current},oe({ref:r,className:s},o),n)});function It(i,r,e,t,a){return F.createElement(i.tag,oe(oe({key:r},ga(i,e,a)),t),(_a(i,e).children||[]).map(function(n,o){return It(n,"".concat(r,"-").concat(i.tag,"-").concat(o),e,void 0,a)}))}function ga(i,r,e){var t=oe({},i.attrs);e!=null&&e.colorChannel1&&t.fill==="colorChannel1"&&(t.fill=e.colorChannel1);var a=r.defIds;return!a||a.length===0||(i.tag==="use"&&t["xlink:href"]&&(t["xlink:href"]=t["xlink:href"]+r.idSuffix),Object.entries(t).forEach(function(n){var o=n[0],s=n[1];typeof s=="string"&&(t[o]=s.replace(/url\(#(.*)\)/,"url(#$1".concat(r.idSuffix,")")))})),t}function _a(i,r){var e,t=r.defIds;return!t||t.length===0?i:i.tag==="defs"&&(!((e=i.children)===null||e===void 0)&&e.length)?oe(oe({},i),{children:i.children.map(function(a){return typeof a.attrs.id=="string"&&t&&t.indexOf(a.attrs.id)>-1?oe(oe({},a),{attrs:oe(oe({},a.attrs),{id:a.attrs.id+r.idSuffix})}):a})}):i}function Sa(){return Math.random().toString(36).substring(2,8)}fe.displayName="UniverIcon";var Ra={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M14.44 3.57291C14.698 3.83093 14.698 4.24927 14.44 4.50729L6.44342 12.5037C6.28721 12.6599 6.03395 12.6599 5.87774 12.5037L1.55992 8.18578C1.3019 7.92776 1.3019 7.50942 1.55993 7.2514C1.81795 6.99338 2.23629 6.99338 2.49431 7.25141L6.01916 10.7763C6.09727 10.8544 6.2239 10.8544 6.30201 10.7763L13.5056 3.57291C13.7636 3.31489 14.1819 3.31489 14.44 3.57291Z",fillRule:"evenodd",clipRule:"evenodd"}}]},Ct=F.forwardRef(function(i,r){return F.createElement(fe,Object.assign({},i,{id:"check-mark-single",ref:r,icon:Ra}))});Ct.displayName="CheckMarkSingle";const Ma=Ct;var Va={tag:"svg",attrs:{fill:"none",viewBox:"0 0 17 17",width:"1em",height:"1em"},children:[{tag:"path",attrs:{stroke:"currentColor",d:"M6.06964 2.57153H2.73631C2.36812 2.57153 2.06964 2.87001 2.06964 3.2382V6.57153C2.06964 6.93973 2.36812 7.2382 2.73631 7.2382H6.06964C6.43784 7.2382 6.73631 6.93973 6.73631 6.57153V3.2382C6.73631 2.87001 6.43784 2.57153 6.06964 2.57153zM6.06964 9.90479H2.73631C2.36812 9.90479 2.06964 10.2033 2.06964 10.5715V13.9048C2.06964 14.273 2.36812 14.5715 2.73631 14.5715H6.06964C6.43784 14.5715 6.73631 14.273 6.73631 13.9048V10.5715C6.73631 10.2033 6.43784 9.90479 6.06964 9.90479z",strokeLinejoin:"round",strokeWidth:1.33}},{tag:"path",attrs:{stroke:"currentColor",d:"M9.20471 5.06981L11.2023 6.73445 14.2047 3.73213M13.7047 10.238L9.70465 14.238M9.70477 10.238L13.7048 14.238",strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:1.33}}]},Et=F.forwardRef(function(i,r){return F.createElement(fe,Object.assign({},i,{id:"data-validation-single",ref:r,icon:Va}))});Et.displayName="DataValidationSingle";var Da={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M6.78662 6.17993C7.12169 6.17993 7.39331 6.45156 7.39331 6.78662V10.7301C7.39331 11.0652 7.12169 11.3368 6.78662 11.3368 6.45156 11.3368 6.17993 11.0652 6.17993 10.7301V6.78662C6.17993 6.45156 6.45156 6.17993 6.78662 6.17993zM9.82007 6.78662C9.82007 6.45156 9.54844 6.17993 9.21338 6.17993 8.87831 6.17993 8.60669 6.45156 8.60669 6.78662V10.7301C8.60669 11.0652 8.87831 11.3368 9.21338 11.3368 9.54844 11.3368 9.82007 11.0652 9.82007 10.7301V6.78662z"}},{tag:"path",attrs:{fill:"currentColor",d:"M6.57094 1.32642C6.34938 1.32642 6.14544 1.44719 6.03894 1.64148L5.21395 3.14648H1.93311C1.59804 3.14648 1.32642 3.41811 1.32642 3.75317C1.32642 4.08824 1.59804 4.35986 1.93311 4.35986H2.84314V14.0669C2.84314 14.402 3.11476 14.6736 3.44983 14.6736H12.5502C12.8852 14.6736 13.1569 14.402 13.1569 14.0669V4.35986H14.0669C14.402 4.35986 14.6736 4.08824 14.6736 3.75317C14.6736 3.41811 14.402 3.14648 14.0669 3.14648H10.7895L9.98357 1.64602C9.87785 1.4492 9.67252 1.32642 9.44911 1.32642H6.57094ZM9.4122 3.14648L9.08632 2.53979H6.93024L6.59767 3.14648H9.4122ZM4.05652 4.35986V13.4602H11.9435V4.35986H4.05652Z",fillRule:"evenodd",clipRule:"evenodd"}}]},Ft=F.forwardRef(function(i,r){return F.createElement(fe,Object.assign({},i,{id:"delete-single",ref:r,icon:Da}))});Ft.displayName="DeleteSingle";const wt=Ft;var Oa={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"mask",attrs:{id:"mask0_102_249",style:{maskType:"alpha"},width:16,height:16,x:0,y:0,maskUnits:"userSpaceOnUse"},children:[{tag:"path",attrs:{fill:"#D9D9D9",d:"M0 0H16V16H0z"}}]},{tag:"g",attrs:{mask:"url(#mask0_102_249)"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M8.74717 2.0944C8.74717 1.68671 8.41279 1.3562 8.00032 1.3562C7.58785 1.3562 7.25347 1.68671 7.25347 2.0944V7.26186H2.02541C1.61294 7.26186 1.27856 7.59237 1.27856 8.00007C1.27856 8.40777 1.61294 8.73827 2.02541 8.73827H7.25347V13.9057C7.25347 14.3134 7.58785 14.6439 8.00032 14.6439C8.41279 14.6439 8.74717 14.3134 8.74717 13.9057V8.73827H13.975C14.3874 8.73827 14.7218 8.40777 14.7218 8.00007C14.7218 7.59237 14.3874 7.26186 13.975 7.26186H8.74717V2.0944Z"}}]}]},yt=F.forwardRef(function(i,r){return F.createElement(fe,Object.assign({},i,{id:"increase-single",ref:r,icon:Oa}))});yt.displayName="IncreaseSingle";const Ia=yt;var Ca={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"mask",attrs:{id:"mask0_102_556",style:{maskType:"alpha"},width:16,height:16,x:0,y:0,maskUnits:"userSpaceOnUse"},children:[{tag:"path",attrs:{fill:"#D9D9D9",d:"M0 0H16V16H0z"}}]},{tag:"g",attrs:{mask:"url(#mask0_102_556)"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M0.629584 3.99986C1.13729 3.4922 1.9604 3.49224 2.46806 3.99995L7.57569 9.10806C7.81 9.3424 8.18992 9.3424 8.42424 9.10808L13.5323 3.99998C14.04 3.4923 14.8631 3.4923 15.3708 3.99998C15.8785 4.50766 15.8785 5.33078 15.3708 5.83846L9.41415 11.7951C8.63307 12.5762 7.36669 12.5762 6.58565 11.7951L0.629497 5.83834C0.121839 5.33063 0.121879 4.50752 0.629584 3.99986Z",fillRule:"evenodd",clipRule:"evenodd"}}]}]},Tt=F.forwardRef(function(i,r){return F.createElement(fe,Object.assign({},i,{id:"more-down-single",ref:r,icon:Ca}))});Tt.displayName="MoreDownSingle";const Ea=Tt;var Fa={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"mask",attrs:{id:"mask0_506_5",style:{maskType:"alpha"},width:16,height:16,x:0,y:0,maskUnits:"userSpaceOnUse"},children:[{tag:"path",attrs:{fill:"#D9D9D9",d:"M16 16H32V32H16z",transform:"rotate(180 16 16)"}}]},{tag:"g",attrs:{mask:"url(#mask0_506_5)"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M15.3704 12.0001C14.8627 12.5078 14.0396 12.5078 13.5319 12.0001L8.42431 6.89194C8.19 6.6576 7.81008 6.6576 7.57576 6.89192L2.46766 12C1.95998 12.5077 1.13687 12.5077 0.629185 12C0.121504 11.4923 0.121504 10.6692 0.629185 10.1615L6.58585 4.20487C7.36693 3.4238 8.63331 3.42383 9.41435 4.20494L15.3705 10.1617C15.8782 10.6694 15.8781 11.4925 15.3704 12.0001Z",fillRule:"evenodd",clipRule:"evenodd"}}]}]},Lt=F.forwardRef(function(i,r){return F.createElement(fe,Object.assign({},i,{id:"more-up-single",ref:r,icon:Fa}))});Lt.displayName="MoreUpSingle";const wa=Lt;var ya={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"mask",attrs:{id:"mask0_622_8",style:{maskType:"alpha"},width:16,height:16,x:0,y:0,maskUnits:"userSpaceOnUse"},children:[{tag:"path",attrs:{fill:"#D9D9D9",d:"M0 0H16V16H0z"}}]},{tag:"g",attrs:{fill:"currentColor",mask:"url(#mask0_622_8)"},children:[{tag:"path",attrs:{d:"M6 5C6.55228 5 7 4.55228 7 4 7 3.44772 6.55228 3 6 3 5.44772 3 5 3.44772 5 4 5 4.55228 5.44772 5 6 5zM6 9C6.55228 9 7 8.55229 7 8 7 7.44772 6.55228 7 6 7 5.44772 7 5 7.44772 5 8 5 8.55229 5.44772 9 6 9zM7 12C7 12.5523 6.55228 13 6 13 5.44772 13 5 12.5523 5 12 5 11.4477 5.44772 11 6 11 6.55228 11 7 11.4477 7 12zM10 5C10.5523 5 11 4.55228 11 4 11 3.44772 10.5523 3 10 3 9.44771 3 9 3.44772 9 4 9 4.55228 9.44771 5 10 5zM11 8C11 8.55229 10.5523 9 10 9 9.44771 9 9 8.55229 9 8 9 7.44772 9.44771 7 10 7 10.5523 7 11 7.44772 11 8zM10 13C10.5523 13 11 12.5523 11 12 11 11.4477 10.5523 11 10 11 9.44771 11 9 11.4477 9 12 9 12.5523 9.44771 13 10 13z"}}]}]},At=F.forwardRef(function(i,r){return F.createElement(fe,Object.assign({},i,{id:"sequence-single",ref:r,icon:ya}))});At.displayName="SequenceSingle";const Ta=At,Ze={dataValidationOptionsButton:"univer-data-validation-options-button",dataValidationOptionsButtonIcon:"univer-data-validation-options-button-icon"};function La(i){var d;const r=N.useDependency(l.LocaleService),e=N.useDependency(P.ComponentManager),{value:t,onChange:a,extraComponent:n}=i,[o,s]=F.useState(!1),u=n?e.get(n):null;return f.jsxs(f.Fragment,{children:[f.jsxs("div",{className:Ze.dataValidationOptionsButton,onClick:()=>s(!o),children:[r.t("dataValidation.panel.options"),o?f.jsx(wa,{className:Ze.dataValidationOptionsButtonIcon}):f.jsx(Ea,{className:Ze.dataValidationOptionsButtonIcon})]}),o&&f.jsxs(f.Fragment,{children:[u?f.jsx(u,{value:t,onChange:a}):null,f.jsx(E.FormLayout,{label:r.t("dataValidation.panel.invalid"),children:f.jsxs(E.RadioGroup,{value:`${(d=t.errorStyle)!=null?d:l.DataValidationErrorStyle.WARNING}`,onChange:c=>a({...t,errorStyle:+c}),children:[f.jsx(E.Radio,{value:`${l.DataValidationErrorStyle.WARNING}`,children:r.t("dataValidation.panel.showWarning")}),f.jsx(E.Radio,{value:`${l.DataValidationErrorStyle.STOP}`,children:r.t("dataValidation.panel.rejectInput")})]})}),f.jsx(E.FormLayout,{label:r.t("dataValidation.panel.messageInfo"),children:f.jsx(E.Checkbox,{checked:t.showInputMessage,onChange:()=>a({...t,showInputMessage:!t.showInputMessage}),children:r.t("dataValidation.panel.showInfo")})}),t.showInputMessage?f.jsx(E.FormLayout,{children:f.jsx(E.Input,{value:t.error,onChange:c=>a({...t,error:c})})}):null]})]})}const Oe={dataValidationDetailFormItem:"univer-data-validation-detail-form-item",dataValidationDetailButtons:"univer-data-validation-detail-buttons",dataValidationDetailButton:"univer-data-validation-detail-button"},Aa=i=>l.debounce(async(r,e,t,a)=>{const n=await i.executeCommand(r,e,t);a==null||a(n)},275);function ba(){const[i,r]=F.useState(0),e=N.useDependency(ue),t=P.useObservable(e.activeRule$,e.activeRule),{unitId:a,subUnitId:n,rule:o}=t||{},s=o.uid,u=N.useDependency(M.DataValidatorRegistryService),d=N.useDependency(P.ComponentManager),c=N.useDependency(l.ICommandService),h=N.useDependency(M.DataValidationModel),p=N.useDependency(l.LocaleService),[m,_]=F.useState(o),v=u.getValidatorItem(m.type),[R,D]=F.useState(!1),I=u.getValidatorsByScope(M.DataValidatorRegistryScope.SHEET),[O,C]=F.useState(()=>m.ranges.map(T=>({unitId:"",sheetId:"",range:T}))),y=F.useMemo(()=>Aa(c),[c]);if(F.useEffect(()=>{c.onCommandExecuted(T=>{(T.id===l.UndoCommand.id||T.id===l.RedoCommand.id)&&setTimeout(()=>{const A=h.getRuleById(a,n,s);r(K=>K+1),A&&(_(A),C(A.ranges.map(K=>({unitId:"",sheetId:"",range:K}))))},20)})},[c,h,s,n,a]),!v)return null;const L=v.operators,b=v.operatorNames,q=m.operator?M.TWO_FORMULA_OPERATOR_COUNT.includes(m.operator):!1,x=()=>{v.validatorFormula(m).success?e.setActiveRule(null):D(!0)},B=P.useEvent(T=>{if(l.isUnitRangesEqual(T,O))return;C(T);const A=T.filter(W=>(!W.unitId||W.unitId===a)&&(!W.sheetId||W.sheetId===n)).map(W=>W.range);if(_({...m,ranges:A}),A.length===0)return;const K={unitId:a,subUnitId:n,ruleId:s,ranges:A};y(Qe.id,K)}),U=T=>{if(l.shallowEqual(T,M.getRuleSetting(m)))return;_({...m,...T});const A={unitId:a,subUnitId:n,ruleId:s,setting:T};y(M.UpdateDataValidationSettingCommand.id,A,void 0)},G=async()=>{await c.executeCommand(M.RemoveDataValidationCommand.id,{ruleId:s,unitId:a,subUnitId:n}),e.setActiveRule(null)},H={type:m.type,operator:m.operator,formula1:m.formula1,formula2:m.formula2,allowBlank:m.allowBlank},z=T=>{const A=u.getValidatorItem(T);if(!A)return;const K=A.operators,W=h.getRuleById(a,n,s),w=T===(W==null?void 0:W.type)?{...W}:{...m,type:T,operator:K[0],formula1:void 0,formula2:void 0};_(w),c.executeCommand(M.UpdateDataValidationSettingCommand.id,{unitId:a,subUnitId:n,ruleId:m.uid,setting:M.getRuleSetting(w)})},$=d.get(v.formulaInput),Z=O.map(T=>ie.serializeRange(T.range)).join(","),ne=M.getRuleOptions(m),Q=T=>{l.shallowEqual(T,M.getRuleOptions(m))||(_({...m,...T}),y(M.UpdateDataValidationOptionsCommand.id,{unitId:a,subUnitId:n,ruleId:s,options:T}))};return f.jsxs("div",{children:[f.jsx(E.FormLayout,{label:p.t("dataValidation.panel.range"),children:f.jsx(P.RangeSelector,{className:Oe.dataValidationDetailFormItem,value:Z,id:l.createInternalEditorID("data-validation-detail"),openForSheetUnitId:a,openForSheetSubUnitId:n,onChange:T=>{T.some(A=>!l.isValidRange(A.range)||A.range.endColumn<A.range.startColumn||A.range.endRow<A.range.startRow)||B(T)}},i)}),f.jsx(E.FormLayout,{label:p.t("dataValidation.panel.type"),children:f.jsx(E.Select,{options:I==null?void 0:I.map(T=>({label:p.t(T.title),value:T.id})),value:m.type,onChange:z,className:Oe.dataValidationDetailFormItem})}),L!=null&&L.length?f.jsx(E.FormLayout,{label:p.t("dataValidation.panel.operator"),children:f.jsx(E.Select,{options:L.map((T,A)=>({value:`${T}`,label:b[A]})),value:`${m.operator}`,onChange:T=>{U({...H,operator:T})},className:Oe.dataValidationDetailFormItem})}):null,$?f.jsx($,{isTwoFormula:q,value:{formula1:m.formula1,formula2:m.formula2},onChange:T=>{U({...H,...T})},showError:R,validResult:v.validatorFormula(m),unitId:a,subUnitId:n,ruleId:s},i):null,f.jsx(La,{value:ne,onChange:Q,extraComponent:v.optionsInput}),f.jsxs("div",{className:Oe.dataValidationDetailButtons,children:[f.jsx(E.Button,{className:Oe.dataValidationDetailButton,onClick:G,children:p.t("dataValidation.panel.removeRule")}),f.jsx(E.Button,{className:Oe.dataValidationDetailButton,type:"primary",onClick:x,children:p.t("dataValidation.panel.done")})]})]})}const Ue={dataValidationItemContainer:"univer-data-validation-item-container",dataValidationItemTitle:"univer-data-validation-item-title",dataValidationItemContent:"univer-data-validation-item-content",dataValidationItemIcon:"univer-data-validation-item-icon"},Na=i=>{const{rule:r,onClick:e,unitId:t,subUnitId:a}=i,n=N.useDependency(M.DataValidatorRegistryService),o=N.useDependency(l.ICommandService),s=N.useDependency(j.IMarkSelectionService),u=n.getValidatorItem(r.type),d=F.useRef(),[c,h]=F.useState(!1),p=m=>{o.executeCommand(M.RemoveDataValidationCommand.id,{ruleId:r.uid,unitId:t,subUnitId:a}),m.stopPropagation()};return F.useEffect(()=>()=>{var m;d.current&&((m=d.current)==null||m.forEach(_=>{_&&s.removeShape(_)}))},[s]),f.jsxs("div",{className:Ue.dataValidationItemContainer,onClick:e,onMouseEnter:()=>{h(!0),d.current=r.ranges.map(m=>s.addShape({range:m,style:{hasAutoFill:!1,fill:"rgba(73, 184, 17, 0.05)",strokeWidth:1,stroke:"#49B811",widgets:{}},primary:{startColumn:m.startColumn,endColumn:m.endColumn,startRow:m.startRow,endRow:m.endRow,actualRow:m.startRow,actualColumn:m.startColumn,isMerged:!1,isMergedMainCell:!1}}))},onMouseLeave:()=>{var m;h(!1),(m=d.current)==null||m.forEach(_=>{_&&s.removeShape(_)}),d.current=void 0},children:[f.jsx("div",{className:Ue.dataValidationItemTitle,children:u==null?void 0:u.generateRuleName(r)}),f.jsx("div",{className:Ue.dataValidationItemContent,children:r.ranges.map(m=>ie.serializeRange(m)).join(",")}),c?f.jsx("div",{className:Ue.dataValidationItemIcon,onClick:p,children:f.jsx(wt,{})}):null]})},Je={dataValidationListButtons:"univer-data-validation-list-buttons",dataValidationListButton:"univer-data-validation-list-button"};function Ua(){const i=N.useDependency(l.IUniverInstanceService),r=P.useObservable(()=>i.getCurrentTypeOfUnit$(l.UniverInstanceType.UNIVER_SHEET),void 0,void 0,[]);return r?f.jsx(ja,{workbook:r}):null}function ja(i){const r=N.useDependency(M.DataValidationModel),e=N.useDependency(l.ICommandService),t=N.useDependency(V.Injector),a=N.useDependency(ue),n=N.useDependency(l.LocaleService),[o,s]=F.useState([]),{workbook:u}=i,d=P.useObservable(u.activeSheet$,void 0,!0),c=u.getUnitId(),h=d==null?void 0:d.getSheetId(),p=r.ensureManager(c,h);F.useEffect(()=>{s(p.getDataValidations());const v=p.dataValidations$.subscribe(R=>{s([...R])});return()=>{v.unsubscribe()}},[p]);const m=async()=>{const v=M.createDefaultNewRule(t),R={unitId:c,subUnitId:h,rule:v};await e.executeCommand(Ne.id,R),a.setActiveRule({unitId:c,subUnitId:h,rule:v})},_=()=>{e.executeCommand(M.RemoveAllDataValidationCommand.id,{unitId:c,subUnitId:h})};return f.jsxs("div",{children:[o.map(v=>f.jsx(Na,{unitId:c,subUnitId:h,onClick:()=>a.setActiveRule({unitId:c,subUnitId:h,rule:v}),rule:v},v.uid)),f.jsxs("div",{className:Je.dataValidationListButtons,children:[o.length?f.jsx(E.Button,{className:Je.dataValidationListButton,onClick:_,children:n.t("dataValidation.panel.removeAll")}):null,f.jsx(E.Button,{className:Je.dataValidationListButton,type:"primary",onClick:m,children:n.t("dataValidation.panel.add")})]})]})}const Pa=()=>{const i=N.useDependency(ue),r=P.useObservable(i.activeRule$,i.activeRule);return r?f.jsx(ba,{},r.rule.uid):f.jsx(Ua,{})};function te(i){if(i===null)return"";if(i!=null&&i.p){const r=i==null?void 0:i.p.body;if(r==null)return"";const e=r.dataStream;return e.substring(e.length-2,e.length)===l.DEFAULT_EMPTY_DOCUMENT_VALUE?e.substring(0,e.length-2):e}return i==null?void 0:i.v}function bt(i){return i.filter(Boolean).join(",")}function Ie(i){return i.split(",").filter(Boolean)}function xa(i){const r=te(i);return r==null?"":r.toString()}const je="SHEET_DATA_VALIDATION_PLUGIN",Re="#ECECEC",de={dvListDropdown:"univer-dv-list-dropdown",dvListDropdownTitle:"univer-dv-list-dropdown-title",dvListDropdownList:"univer-dv-list-dropdown-list",dvListDropdownListContainer:"univer-dv-list-dropdown-list-container",dvListDropdownSelectedIcon:"univer-dv-list-dropdown-selected-icon",dvListDropdownItemContainer:"univer-dv-list-dropdown-item-container",dvListDropdownItem:"univer-dv-list-dropdown-item",dvListDropdownSplit:"univer-dv-list-dropdown-split",dvListDropdownEdit:"univer-dv-list-dropdown-edit"},Ba=i=>{const{value:r,onChange:e,multiple:t,options:a,title:n,onEdit:o,style:s}=i;return f.jsxs("div",{className:de.dvListDropdown,style:s,children:[f.jsx("div",{className:de.dvListDropdownTitle,children:n}),f.jsx("div",{className:de.dvListDropdownList,children:f.jsx(E.Scrollbar,{children:f.jsx("div",{className:de.dvListDropdownListContainer,children:a.map((u,d)=>{const c=r.indexOf(u.value)>-1,h=()=>{let p;c?p=new Set(r.filter(_=>_!==u.value)):p=new Set(t?[...r,u.value]:[u.value]);const m=[];a.forEach(_=>{p.has(_.value)&&m.push(_.value)}),e(m)};return f.jsxs("div",{className:de.dvListDropdownItemContainer,onClick:h,children:[f.jsx("div",{className:de.dvListDropdownItem,style:{background:u.color||Re},children:u.label}),f.jsx("div",{className:de.dvListDropdownSelectedIcon,children:c?f.jsx(Ma,{}):null})]},d)})})})}),f.jsx("div",{className:de.dvListDropdownSplit}),f.jsx("div",{className:de.dvListDropdownEdit,children:f.jsx("a",{onClick:o,children:"编辑"})})]})};function $a(i){var q,x;const{location:r,hideFn:e}=i,{worksheet:t,row:a,col:n,unitId:o,subUnitId:s}=r,u=N.useDependency(l.ICommandService),d=N.useDependency(l.LocaleService),[c,h]=F.useState(""),p=N.useDependency(j.IEditorBridgeService),m=E.RectPopup.useContext(),_=m.right-m.left;if(!t)return null;const v=t.getCell(a,n),R=(q=v==null?void 0:v.dataValidation)==null?void 0:q.rule,D=(x=v==null?void 0:v.dataValidation)==null?void 0:x.validator,I=(R==null?void 0:R.renderMode)===l.DataValidationRenderMode.CUSTOM||(R==null?void 0:R.renderMode)===void 0;if(!v||!R||!D)return;const O=R.type===l.DataValidationType.LIST_MULTIPLE,C=D.getListWithColor(R,o,s),y=c||xa(v),L=Ie(y),b=()=>{u.executeCommand(Fe.id,{ruleId:R.uid}),e()};return f.jsx(Ba,{style:{minWidth:_,maxWidth:Math.max(_,200)},title:O?d.t("dataValidation.listMultiple.dropdown"):d.t("dataValidation.list.dropdown"),value:L,multiple:O,onChange:B=>{const U=bt(B),G={unitId:o,subUnitId:s,range:{startColumn:n,endColumn:n,startRow:a,endRow:a},value:{v:U,p:null,f:null,si:null}};p.isVisible()&&p.changeVisible({visible:!1,keycode:P.KeyCode.ESC,eventType:X.DeviceInputEventType.Keyboard}),u.executeCommand(re.SetRangeValuesCommand.id,G),h(U),O||e()},options:C.map(B=>({label:B.label,value:B.label,color:I?B.color:"transparent"})),onEdit:b})}var qa=Object.defineProperty,Ha=Object.getOwnPropertyDescriptor,Wa=(i,r,e,t)=>{for(var a=t>1?void 0:t?Ha(r,e):r,n=i.length-1,o;n>=0;n--)(o=i[n])&&(a=(t?o(r,e,a):o(a))||a);return t&&a&&qa(r,e,a),a},we=(i,r)=>(e,t)=>r(e,t,i);g.DataValidationRejectInputController=class extends l.Disposable{constructor(r,e,t,a,n){super(),this._editorBridgeService=r,this._dataValidationModel=e,this._dataValidatorRegistryService=t,this._dialogService=a,this._localeService=n,this._initEditorBridgeInterceptor()}_initEditorBridgeInterceptor(){this._editorBridgeService.interceptor.intercept(this._editorBridgeService.interceptor.getInterceptPoints().AFTER_CELL_EDIT_ASYNC,{handler:async(r,e,t)=>{const a=await r,{worksheet:n,row:o,col:s,unitId:u,subUnitId:d}=e,c=this._dataValidationModel.ensureManager(u,d),h=c.getRuleIdByLocation(o,s),p=h?c.getRuleById(h):void 0;if(!p||p.errorStyle!==l.DataValidationErrorStyle.STOP)return t(Promise.resolve(a));const m=await this._dataValidatorRegistryService.getValidatorItem(p.type);if(!m||await m.validator({value:te(a),row:o,column:s,unitId:u,subUnitId:d},p))return t(Promise.resolve(a));const v=n.getCellRaw(o,s);return this._dialogService.open({width:368,title:{title:this._localeService.t("dataValidation.alert.title")},id:"reject-input-dialog",children:{title:m.getRuleFinalError(p)},footer:{title:F.createElement(E.Button,{type:"primary",onClick:()=>this._dialogService.close("reject-input-dialog")},this._localeService.t("dataValidation.alert.ok"))},onClose:()=>{this._dialogService.close("reject-input-dialog")}}),t(Promise.resolve(v))}})}showReject(r){this._dialogService.open({width:368,title:{title:this._localeService.t("dataValidation.alert.title")},id:"reject-input-dialog",children:{title:r},footer:{title:F.createElement(E.Button,{type:"primary",onClick:()=>this._dialogService.close("reject-input-dialog")},this._localeService.t("dataValidation.alert.ok"))},onClose:()=>{this._dialogService.close("reject-input-dialog")}})}},g.DataValidationRejectInputController=Wa([l.OnLifecycle(l.LifecycleStages.Ready,g.DataValidationRejectInputController),we(0,j.IEditorBridgeService),we(1,V.Inject(M.DataValidationModel)),we(2,V.Inject(M.DataValidatorRegistryService)),we(3,P.IDialogService),we(4,V.Inject(l.LocaleService))],g.DataValidationRejectInputController);const ka={dvDateDropdown:"univer-dv-date-dropdown"};function Ya(i){var I,O,C;const{location:r,hideFn:e}=i,{worksheet:t,row:a,col:n,unitId:o,subUnitId:s}=r,u=N.useDependency(l.ICommandService),d=N.useDependency(g.DataValidationRejectInputController),[c,h]=F.useState();if(!t)return null;const p=t.getCell(a,n),m=(I=p==null?void 0:p.dataValidation)==null?void 0:I.rule,_=(O=p==null?void 0:p.dataValidation)==null?void 0:O.validator;if(!p||!m||!_)return;const v=te(p),R=(C=_.transformDate(v))!=null?C:ge(),D=R.isValid()?R:ge();return f.jsx("div",{className:ka.dvDateDropdown,children:f.jsx(E.DatePanel,{pickerValue:c!=null?c:D,onSelect:async y=>{const L=y.format("YYYY/MM/DD");m.errorStyle!==l.DataValidationErrorStyle.STOP||await _.validator({value:L,unitId:o,subUnitId:s,row:a,column:n},m)?u.executeCommand(re.SetRangeValuesCommand.id,{unitId:o,subUnitId:s,range:{startColumn:n,endColumn:n,startRow:a,endRow:a},value:{v:L,p:null,f:null,si:null}}):d.showReject(_.getRuleFinalError(m)),e()},onPanelChange:y=>{h(y)}})})}const Nt="data-validation.list.dropdown",Ut="data-validation.date.dropdown";function Ga(i){var u;const{unitId:r,subUnitId:e,value:t,onChange:a,showError:n,validResult:o}=i,s=n?o==null?void 0:o.formula1:"";return f.jsx(E.FormLayout,{error:s,children:f.jsx(P.TextEditor,{value:(u=t==null?void 0:t.formula1)!=null?u:"",id:l.createInternalEditorID(`dataValidation-custom-formula-${r}-${e}`),onChange:d=>{a==null||a({...t,formula1:d!=null?d:""})},onlyInputFormula:!0,openForSheetUnitId:r,openForSheetSubUnitId:e})})}const J={dataValidationFormula:"univer-data-validation-formula",dataValidationFormulaAnd:"univer-data-validation-formula-and",dataValidationFormulaListItem:"univer-data-validation-formula-list-item",dataValidationFormulaListItemIcon:"univer-data-validation-formula-list-item-icon",dataValidationFormulaListItemDrag:"univer-data-validation-formula-list-item-drag",dataValidationFormulaListAdd:"univer-data-validation-formula-list-add",dataValidationFormulaColorSelect:"univer-data-validation-formula-color-select",dataValidationFormulaColorSelectPanel:"univer-data-validation-formula-color-select-panel",dataValidationFormulaColorItem:"univer-data-validation-formula-color-item"},za=i=>{const{isTwoFormula:r=!1,value:e,onChange:t,showError:a,validResult:n}=i,o=N.useDependency(l.LocaleService),s=a?n==null?void 0:n.formula1:"",u=a?n==null?void 0:n.formula2:"";return r?f.jsxs(f.Fragment,{children:[f.jsx(E.FormLayout,{error:s,children:f.jsx(E.Input,{className:J.dataValidationFormula,placeholder:o.t("dataValidation.panel.formulaPlaceholder"),value:e==null?void 0:e.formula1,onChange:d=>{t==null||t({...e,formula1:d})}})}),f.jsx("div",{className:J.dataValidationFormulaAnd,children:o.t("dataValidation.panel.formulaAnd")}),f.jsx(E.FormLayout,{error:u,children:f.jsx(E.Input,{className:J.dataValidationFormula,placeholder:o.t("dataValidation.panel.formulaPlaceholder"),value:e==null?void 0:e.formula2,onChange:d=>{t==null||t({...e,formula2:d})}})})]}):f.jsx(E.FormLayout,{error:s,children:f.jsx(E.Input,{className:J.dataValidationFormula,placeholder:o.t("dataValidation.panel.formulaPlaceholder"),value:e==null?void 0:e.formula1,onChange:d=>{t==null||t({formula1:d})}})})},Xa=["#FFFFFF","#FEE7E7","#FEF0E6","#EFFBD0","#E4F4FE","#E8ECFD","#F1EAFA","#FDE8F3","#E5E5E5","#FDCECE","#FDC49B","#DEF6A2","#9FDAFF","#D0D9FB","#E3D5F6","#FBD0E8","#656565","#FE4B4B","#FF8C51","#8BBB11","#0B9EFB","#3A60F7","#9E6DE3","#F248A6"],Qa=i=>{const{value:r,onChange:e,disabled:t}=i,[a,n]=F.useState(!1);return f.jsx(E.Select,{disabled:t,open:a,onDropdownVisibleChange:n,dropdownStyle:{width:112},className:J.dataValidationFormulaColorSelect,value:r,onChange:e,labelRender:o=>f.jsx("div",{className:J.dataValidationFormulaColorItem,style:{background:o.value}}),dropdownRender:()=>f.jsx("div",{className:J.dataValidationFormulaColorSelectPanel,children:Xa.map(o=>f.jsx("div",{onClick:()=>{e(o),n(!1)},className:J.dataValidationFormulaColorItem,style:{background:o}},o))})})},jt=i=>{const{item:r,commonProps:e,style:t}=i,{onItemChange:a,onItemDelete:n}=e;return f.jsxs("div",{className:J.dataValidationFormulaListItem,style:t,children:[r.isRef?null:f.jsx("div",{className:ta(J.dataValidationFormulaListItemDrag,"draggableHandle"),children:f.jsx(Ta,{})}),f.jsx(Qa,{value:r.color,onChange:o=>{a(r.id,r.label,o)}}),f.jsx(E.Input,{disabled:r.isRef,value:r.label,onChange:o=>{a(r.id,o,r.color)}}),r.isRef?null:f.jsx("div",{className:J.dataValidationFormulaListItemIcon,children:f.jsx(wt,{onClick:()=>n(r.id)})})]})};function Ka(i){const{value:r,onChange:e=()=>{},unitId:t,subUnitId:a,validResult:n,showError:o,ruleId:s}=i,{formula1:u="",formula2:d=""}=r||{},c=F.useRef(null),[h,p]=F.useState(()=>l.isFormulaString(u)?"1":"0"),[m,_]=F.useState(h==="1"?u:"="),[v,R]=F.useState(h==="1"?u:"="),D=N.useDependency(l.LocaleService),I=N.useDependency(M.DataValidatorRegistryService),O=N.useDependency(M.DataValidationModel),[C,y]=F.useState(()=>d.split(",")),L=I.getValidatorItem(l.DataValidationType.LIST),[b,q]=F.useState([]),[x,B]=F.useState(""),U=o?n==null?void 0:n.formula1:"",G=P.useObservable(O.ruleChange$),H=P.useEvent(e);F.useEffect(()=>{(async()=>{await new Promise(k=>{setTimeout(()=>k(!0),100)});const w=O.getRuleById(t,a,s),Y=w==null?void 0:w.formula1;if(l.isFormulaString(Y)&&L&&w){const k=await L.getListAsync(w,t,a);q(k)}})()},[O,G,L,s,a,t]),F.useEffect(()=>{l.isFormulaString(u)&&u!==v&&(_(u),R(v))},[v,u]);const[z,$]=F.useState(()=>{const w=h!=="1"?Ie(u):[],Y=d.split(",");return w.map((k,ee)=>({label:k,color:Y[ee]||Re,isRef:!1,id:l.Tools.generateRandomId(4)}))}),Z=(w,Y,k)=>{const ee=z.find(he=>he.id===w);ee&&(ee.label=Y,ee.color=k,$([...z]))},ne=w=>{const Y=z.findIndex(k=>k.id===w);Y!==-1&&(z.splice(Y,1),$([...z]))},Q=d.split(","),T=F.useMemo(()=>b.map((w,Y)=>({label:w,color:Q[Y]||Re,id:`${Y}`,isRef:!0})),[Q,b]),A=(w,Y,k)=>{const ee=[...C];ee[+w]=k,y(ee),H({formula1:u,formula2:ee.join(",")})},K=()=>{$([...z,{label:"",color:Re,isRef:!1,id:l.Tools.generateRandomId(4)}])};F.useEffect(()=>{if(h==="1")return;const w=new Set,Y=[];z.map(k=>({labelList:k.label.split(","),item:k})).forEach(({item:k,labelList:ee})=>{ee.forEach(he=>{w.has(he)||(w.add(he),Y.push({label:he,color:k.color}))})}),H({formula1:bt(Y.map(k=>k.label)),formula2:Y.map(k=>k.color===Re?"":k.color).join(",")})},[z,H,h,v,C]);const W=F.useMemo(()=>async w=>{if(!l.isFormulaString(w)){H==null||H({formula1:"",formula2:d});return}H==null||H({formula1:l.isFormulaString(w)?w:"",formula2:d})},[d,H]);return f.jsxs(f.Fragment,{children:[f.jsx(E.FormLayout,{label:D.t("dataValidation.list.options"),children:f.jsxs(E.RadioGroup,{value:h,onChange:w=>{p(w),_(v),w==="1"&&H({formula1:v==="="?"":v,formula2:C.join(",")})},children:[f.jsx(E.Radio,{value:"0",children:D.t("dataValidation.list.customOptions")}),f.jsx(E.Radio,{value:"1",children:D.t("dataValidation.list.refOptions")})]})}),h==="1"?f.jsxs(f.Fragment,{children:[f.jsx(E.FormLayout,{error:U||x,children:f.jsx(P.TextEditor,{id:l.createInternalEditorID(`list-ref-range-${t}-${a}`),value:m,openForSheetUnitId:t,openForSheetSubUnitId:a,onlyInputFormula:!0,onChange:async w=>{const Y=w!=null?w:"";R(Y),W(Y)}})}),f.jsx(E.FormLayout,{children:f.jsx("div",{ref:c,children:T.map(w=>f.jsx(jt,{item:w,commonProps:{onItemChange:A},style:{marginBottom:12}},w.id))})})]}):f.jsx(E.FormLayout,{error:U,children:f.jsxs("div",{ref:c,style:{marginTop:"-12px"},children:[f.jsx(E.DraggableList,{list:z,onListChange:$,rowHeight:32,margin:[0,12],draggableHandle:".draggableHandle",itemRender:w=>f.jsx(jt,{item:w,commonProps:{onItemChange:Z,onItemDelete:ne}},w.id),idKey:"id"}),f.jsxs("a",{className:J.dataValidationFormulaListAdd,onClick:K,children:[f.jsx(Ia,{}),D.t("dataValidation.list.add")]})]})})]})}function Za(i){const{value:r,onChange:e,showError:t,validResult:a}=i,n=N.useDependency(l.LocaleService),o=t?a==null?void 0:a.formula1:"",s=t?a==null?void 0:a.formula2:"",[u,d]=F.useState(!((r==null?void 0:r.formula1)===void 0&&(r==null?void 0:r.formula2)===void 0));return f.jsxs(f.Fragment,{children:[f.jsx(E.FormLayout,{children:f.jsx(E.Checkbox,{checked:u,onChange:c=>{c?d(!0):(d(!1),e==null||e({...r,formula1:void 0,formula2:void 0}))},children:n.t("dataValidation.checkbox.tips")})}),u?f.jsx(E.FormLayout,{label:n.t("dataValidation.checkbox.checked"),error:o,children:f.jsx(E.Input,{className:J.dataValidationFormula,placeholder:n.t("dataValidation.panel.formulaPlaceholder"),value:r==null?void 0:r.formula1,onChange:c=>{e==null||e({...r,formula1:c||void 0})}})}):null,u?f.jsx(E.FormLayout,{label:n.t("dataValidation.checkbox.unchecked"),error:s,children:f.jsx(E.Input,{className:J.dataValidationFormula,placeholder:n.t("dataValidation.panel.formulaPlaceholder"),value:r==null?void 0:r.formula2,onChange:c=>{e==null||e({...r,formula2:c||void 0})}})}):null]})}const Pt="data-validation.custom-formula-input",ye="data-validation.formula-input",xt="data-validation.list-formula-input",Bt="data-validation.checkbox-formula-input",Ja=[[Pt,Ga],[ye,za],[xt,Ka],[Bt,Za]],en="LIST_RENDER_MODE_OPTION_INPUT";function Pe(i){var a;const{value:r,onChange:e}=i,t=N.useDependency(l.LocaleService);return f.jsx(E.FormLayout,{label:t.t("dataValidation.renderMode.label"),children:f.jsxs(E.RadioGroup,{value:`${(a=r.renderMode)!=null?a:l.DataValidationRenderMode.CUSTOM}`,onChange:n=>e({...r,renderMode:+n}),children:[f.jsx(E.Radio,{value:`${l.DataValidationRenderMode.CUSTOM}`,children:t.t("dataValidation.renderMode.chip")}),f.jsx(E.Radio,{value:`${l.DataValidationRenderMode.ARROW}`,children:t.t("dataValidation.renderMode.arrow")}),f.jsx(E.Radio,{value:`${l.DataValidationRenderMode.TEXT}`,children:t.t("dataValidation.renderMode.text")})]})})}Pe.componentKey=en;const $t="data-validation-single",et="sheet.menu.data-validation";function tn(i){return{id:et,type:P.MenuItemType.SUBITEMS,positions:[P.MenuPosition.TOOLBAR_START],group:P.MenuGroup.TOOLBAR_FORMULAS_INSERT,icon:$t,tooltip:"dataValidation.title",hidden$:P.getMenuHiddenObservable(i,l.UniverInstanceType.UNIVER_SHEET)}}function an(i){return{id:Fe.id,title:"dataValidation.panel.title",type:P.MenuItemType.BUTTON,positions:[et]}}function nn(i){return{id:Ke.id,title:"dataValidation.panel.add",type:P.MenuItemType.BUTTON,positions:[et]}}var rn=Object.defineProperty,on=Object.getOwnPropertyDescriptor,ln=(i,r,e,t)=>{for(var a=t>1?void 0:t?on(r,e):r,n=i.length-1,o;n>=0;n--)(o=i[n])&&(a=(t?o(r,e,a):o(a))||a);return t&&a&&rn(r,e,a),a},ae=(i,r)=>(e,t)=>r(e,t,i);const sn={tr:{size:6,color:"#fe4b4b"}};g.DataValidationRenderController=class extends l.RxDisposable{constructor(r,e,t,a,n,o,s,u,d,c,h,p,m){super(),this._componentManager=r,this._menuService=e,this._dataValidationModel=t,this._sheetSkeletonManagerService=a,this._renderManagerService=n,this._univerInstanceService=o,this._dataValidatorRegistryService=s,this._editorBridgeService=u,this._dropdownManagerService=d,this._sheetInterceptorService=c,this._injector=h,this._autoHeightController=p,this._commandService=m,this._init()}_init(){this._initComponents(),this._initMenu(),this._initSkeletonChange(),this._initDropdown(),this._initViewModelIntercept(),this._initAutoHeight()}_initMenu(){[tn,an,nn].forEach(r=>{this.disposeWithMe(this._menuService.addMenuItem(r(this._injector)))})}_initComponents(){[[Vt,Pa],[Rt,sa],[Nt,$a],[Ut,Ya],[Pe.componentKey,Pe],...Ja].forEach(([r,e])=>{this.disposeWithMe(this._componentManager.register(r,e))})}_initDropdown(){this.disposeWithMe(this._editorBridgeService.visible$.subscribe(r=>{if(!r.visible)return;const e=this._editorBridgeService.getEditCellState();if(e){const{unitId:t,sheetId:a,row:n,column:o}=e,s=this._univerInstanceService.getUniverSheetInstance(t);if(!s)return;const d=this._dataValidationModel.ensureManager(t,a).getRuleByLocation(n,o);if(!d)return;const c=this._dataValidatorRegistryService.getValidatorItem(d.type);if(!(c!=null&&c.dropdown))return;const h=s.getActiveSheet(),p=this._dropdownManagerService.activeDropdown,m=p==null?void 0:p.location;if(m&&m.unitId===t&&m.subUnitId===a&&m.row===n&&m.col===o)return;this._dropdownManagerService.showDropdown({location:{unitId:t,subUnitId:a,row:n,col:o,workbook:s,worksheet:h},componentKey:c.dropdown,onHide:()=>{}})}}))}_initSkeletonChange(){const r=()=>{const e=this._univerInstanceService.getCurrentUnitForType(l.UniverInstanceType.UNIVER_SHEET);if(!e)return;const t=e.getUnitId(),a=e.getActiveSheet().getSheetId(),n=this._sheetSkeletonManagerService.getOrCreateSkeleton({unitId:t,sheetId:a}),o=this._renderManagerService.getRenderById(t);n==null||n.makeDirty(!0),n==null||n.calculate(),o&&o.mainComponent.makeForceDirty()};this.disposeWithMe(this._dataValidationModel.ruleChange$.subscribe(()=>{r()})),this.disposeWithMe(this._dataValidationModel.validStatusChange$.subscribe(()=>{r()}))}_initViewModelIntercept(){this.disposeWithMe(this._sheetInterceptorService.intercept(re.INTERCEPTOR_POINT.CELL_CONTENT,{handler:(r,e,t)=>{var O,C,y,L;const{row:a,col:n,unitId:o,subUnitId:s}=e,u=this._dataValidationModel.ensureManager(o,s),d=(O=this._sheetSkeletonManagerService.getCurrent())==null?void 0:O.skeleton;if(!u||!d)return t(r);const c=e.workbook.getStyles(),h=(typeof(r==null?void 0:r.s)=="string"?c.get(r==null?void 0:r.s):r==null?void 0:r.s)||{},p=u.getRuleIdByLocation(a,n);if(!p)return t(r);const m=u.getRuleById(p);if(!m)return t(r);const _=e.worksheet.getCellRaw(e.row,e.col),v=this._dataValidationModel.validator(te(_),m,e),R=this._dataValidatorRegistryService.getValidatorItem(m.type),D=te(r);let I={};if((m.type===l.DataValidationType.LIST||m.type===l.DataValidationType.LIST_MULTIPLE)&&(I={interceptorStyle:{...r==null?void 0:r.interceptorStyle,tb:(C=h.tb!==l.WrapStrategy.OVERFLOW?h.tb:l.WrapStrategy.CLIP)!=null?C:l.WrapStrategy.WRAP}}),m.type===l.DataValidationType.CHECKBOX){const{formula2:b}=R.parseFormulaSync(m,e.unitId,e.subUnitId);D||(I={v:b,t:1,p:null,interceptorStyle:{...r==null?void 0:r.interceptorStyle,tb:l.WrapStrategy.CLIP}})}if(m.type===l.DataValidationType.LIST&&(m.renderMode===l.DataValidationRenderMode.ARROW||m.renderMode===l.DataValidationRenderMode.TEXT)){const b=R.getListWithColorMap(m),q=`${(y=te(r))!=null?y:""}`,x=b[q];x&&(I={...I,interceptorStyle:{...I.interceptorStyle,bg:{rgb:x}}})}return t({...r,...I,dataValidation:{ruleId:p,validStatus:v,rule:m,validator:R},markers:{...r==null?void 0:r.markers,...v===l.DataValidationStatus.INVALID?sn:null},customRender:[...(L=r==null?void 0:r.customRender)!=null?L:[],...R!=null&&R.canvasRender?[R.canvasRender]:[]],fontRenderExtension:{...r==null?void 0:r.fontRenderExtension,isSkip:R==null?void 0:R.skipDefaultFontRender(m,D,e)},interceptorStyle:{...r==null?void 0:r.interceptorStyle,...I.interceptorStyle},get interceptorAutoHeight(){var x,B,U,G;const b=d.mergeData.find(H=>{const{startColumn:z,startRow:$,endColumn:Z,endRow:ne}=H;return a>=$&&n>=z&&a<=ne&&n<=Z}),q={data:{...r,dataValidation:{ruleId:p,validStatus:v,rule:m,validator:R}},style:d.getsStyles().getStyleByCell(r),primaryWithCoord:d.getCellByIndex((x=b==null?void 0:b.startRow)!=null?x:a,(B=b==null?void 0:b.startColumn)!=null?B:n),unitId:o,subUnitId:s,row:a,col:n};return(G=(U=R==null?void 0:R.canvasRender)==null?void 0:U.calcCellAutoHeight)==null?void 0:G.call(U,q)}})}}))}_initAutoHeight(){this._dataValidationModel.ruleChange$.subscribe(r=>{var e;if((e=r.rule)!=null&&e.ranges){const t=this._autoHeightController.getUndoRedoParamsOfAutoHeight(r.rule.ranges);l.sequenceExecute(t.redos,this._commandService)}})}},g.DataValidationRenderController=ln([l.OnLifecycle(l.LifecycleStages.Rendered,g.DataValidationRenderController),ae(0,V.Inject(P.ComponentManager)),ae(1,P.IMenuService),ae(2,V.Inject(M.DataValidationModel)),ae(3,V.Inject(j.SheetSkeletonManagerService)),ae(4,X.IRenderManagerService),ae(5,l.IUniverInstanceService),ae(6,V.Inject(M.DataValidatorRegistryService)),ae(7,j.IEditorBridgeService),ae(8,V.Inject(Se)),ae(9,V.Inject(re.SheetInterceptorService)),ae(10,V.Inject(V.Injector)),ae(11,V.Inject(j.AutoHeightController)),ae(12,l.ICommandService)],g.DataValidationRenderController);var un=Object.defineProperty,dn=Object.getOwnPropertyDescriptor,cn=(i,r,e,t)=>{for(var a=t>1?void 0:t?dn(r,e):r,n=i.length-1,o;n>=0;n--)(o=i[n])&&(a=(t?o(r,e,a):o(a))||a);return t&&a&&un(r,e,a),a},mn=(i,r)=>(e,t)=>r(e,t,i);g.SheetDataValidationService=class{constructor(r){S(this,"_currentManager");S(this,"_currentManager$",new pe.Subject);S(this,"currentManager$",this._currentManager$.asObservable());this._dataValidationModel=r}get currentManager(){return this._currentManager}_ensureManager(r,e){return this._dataValidationModel.ensureManager(r,e)}switchCurrent(r,e){var a,n;if(r===((a=this.currentManager)==null?void 0:a.unitId)&&e===((n=this._currentManager)==null?void 0:n.subUnitId))return;const t=this._ensureManager(r,e);this._currentManager={manager:t,unitId:r,subUnitId:e},this._currentManager$.next(this._currentManager)}get(r,e){return this._ensureManager(r,e)}},g.SheetDataValidationService=cn([mn(0,V.Inject(M.DataValidationModel))],g.SheetDataValidationService);class Ce{constructor(){S(this,"_cacheMatrix",new Map)}_ensureCache(r,e){let t=this._cacheMatrix.get(r);t||(t=new Map,this._cacheMatrix.set(r,t));let a=t.get(e);return a||(a=new l.ObjectMatrix,t.set(e,a)),a}ensureCache(r,e){return this._ensureCache(r,e)}addRule(r,e,t){this.markRangeDirty(r,e,t.ranges)}removeRule(r,e,t){this._deleteRange(r,e,t.ranges)}updateRuleRanges(r,e,t,a,n){const o=this._ensureCache(r,e);n.forEach(s=>{l.Range.foreach(s,(u,d)=>{const c=o.getValue(u,d);c&&(c.temp=!0)})}),a.forEach(s=>{l.Range.foreach(s,(u,d)=>{const c=o.getValue(u,d);c&&c.ruleId===t?c.temp=!1:o.setValue(u,d,void 0)})}),n.forEach(s=>{l.Range.foreach(s,(u,d)=>{const c=o.getValue(u,d);c&&c.temp===!0&&o.realDeleteValue(u,d)})})}markRangeDirty(r,e,t){const a=this._ensureCache(r,e);t.forEach(n=>{l.Range.foreach(n,(o,s)=>{a.setValue(o,s,void 0)})})}markCellDirty(r,e,t,a){this._ensureCache(r,e).setValue(t,a,void 0)}_deleteRange(r,e,t){const a=this._ensureCache(r,e);t.forEach(n=>{l.Range.foreach(n,(o,s)=>{a.realDeleteValue(o,s)})})}getValue(r,e,t,a){return this._ensureCache(r,e).getValue(t,a)}setValue(r,e,t,a,n){return this._ensureCache(r,e).setValue(t,a,n)}}var hn=Object.defineProperty,pn=Object.getOwnPropertyDescriptor,fn=(i,r,e,t)=>{for(var a=t>1?void 0:t?pn(r,e):r,n=i.length-1,o;n>=0;n--)(o=i[n])&&(a=(t?o(r,e,a):o(a))||a);return t&&a&&hn(r,e,a),a},xe=(i,r)=>(e,t)=>r(e,t,i);g.DataValidationCustomFormulaService=class extends l.Disposable{constructor(e,t,a,n){super();S(this,"_formulaMap",new Map);S(this,"_ruleFormulaMap",new Map);S(this,"_formulaCellMap",new Map);this._registerOtherFormulaService=e,this._lexerTreeBuilder=t,this._dataValidationModel=a,this._dataValidationCacheService=n,this._initFormulaResultHandler()}_initFormulaResultHandler(){this.disposeWithMe(this._registerOtherFormulaService.formulaResult$.subscribe(e=>{for(const t in e){const a=e[t];for(const n in a){const o=a[n],{formulaCellMap:s,ruleFormulaMap:u}=this._ensureMaps(t,n),d=this._dataValidationModel.ensureManager(t,n);o.forEach(c=>{var _,v;const h=u.get((_=c.extra)==null?void 0:_.ruleId),p=s.get(c.formulaId),m=d.getRuleById((v=c.extra)==null?void 0:v.ruleId);m&&h&&!h.isTransformable&&this._dataValidationCacheService.markRangeDirty(t,n,m.ranges),p&&this._dataValidationCacheService.markCellDirty(t,n,p.row,p.column)})}}}))}_ensureMaps(e,t){let a=this._formulaMap.get(e),n=this._ruleFormulaMap.get(e),o=this._formulaCellMap.get(e);(!a||!n||!o)&&(a=new Map,n=new Map,o=new Map,this._formulaMap.set(e,a),this._ruleFormulaMap.set(e,n),this._formulaCellMap.set(e,o));let s=a.get(t),u=n.get(t),d=o.get(t);return(!s||!u||!d)&&(s=new l.ObjectMatrix,a.set(t,s),u=new Map,n.set(t,u),d=new Map,o.set(t,d)),{formulaMap:s,ruleFormulaMap:u,formulaCellMap:d}}_registerFormula(e,t,a,n){return this._registerOtherFormulaService.registerFormula(e,t,n,{ruleId:a})}deleteByRuleId(e,t,a){const{formulaMap:n,formulaCellMap:o,ruleFormulaMap:s}=this._ensureMaps(e,t),u=this._dataValidationModel.getRuleById(e,t,a),d=new Set,c=s.get(a);!u||!c||(s.delete(a),u.ranges.forEach(h=>{l.Range.foreach(h,(p,m)=>{const _=n.getValue(p,m);if(_&&_.ruleId===a){const{formulaId:v}=_;n.realDeleteValue(p,m),d.add(v),o.delete(v)}})}),this._registerOtherFormulaService.deleteFormula(e,t,Array.from(d.values())))}_addFormulaByRange(e,t,a,n,o){const{formulaMap:s,ruleFormulaMap:u,formulaCellMap:d}=this._ensureMaps(e,t);if(!n)return;const c=ie.isFormulaTransformable(this._lexerTreeBuilder,n),h=o[0].startRow,p=o[0].startColumn;let m;c?o.forEach(_=>{l.Range.foreach(_,(v,R)=>{const D=ie.transformFormula(this._lexerTreeBuilder,n,h,p,v,R),I=this._registerFormula(e,t,a,D);s.setValue(v,R,{formulaId:I,ruleId:a}),d.set(I,{row:v,column:R})})}):(m=this._registerFormula(e,t,a,n),o.forEach(_=>{l.Range.foreach(_,(v,R)=>{s.setValue(v,R,{formulaId:m,ruleId:a})})})),u.set(a,{formula:n,originCol:p,originRow:h,isTransformable:c,formulaId:m})}addRule(e,t,a){const{ranges:n,formula1:o,uid:s,type:u}=a;u!==l.DataValidationType.CUSTOM||!o||!l.isFormulaString(o)||this._addFormulaByRange(e,t,s,o,n)}updateRuleRanges(e,t,a,n,o){const{formulaMap:s,ruleFormulaMap:u,formulaCellMap:d}=this._ensureMaps(e,t),c=u.get(a);if(!c)return;const{formula:h,originCol:p,originRow:m,isTransformable:_,formulaId:v}=c,R=new Set;n.forEach(D=>{l.Range.foreach(D,(I,O)=>{const C=s.getValue(I,O);C&&C.ruleId===a&&(C.temp=!0)})}),o.forEach(D=>{l.Range.foreach(D,(I,O)=>{var y;const C=(y=s.getValue(I,O))!=null?y:{};if(C.ruleId!==a){const L=u.get(C.ruleId);if(L!=null&&L.isTransformable&&R.add(C.formulaId),_){const b=ie.transformFormula(this._lexerTreeBuilder,h,m,p,I,O),q=this._registerFormula(e,t,a,b);s.setValue(I,O,{ruleId:a,formulaId:q}),d.set(q,{row:I,column:O})}else s.setValue(I,O,{ruleId:a,formulaId:v})}else C.temp=!1})}),n.forEach(D=>{l.Range.foreach(D,(I,O)=>{const C=s.getValue(I,O);C&&C.ruleId===a&&C.temp===!0&&(s.realDeleteValue(I,O),_&&R.add(C.formulaId))})}),R.forEach(D=>{d.delete(D)}),this._registerOtherFormulaService.deleteFormula(e,t,Array.from(R.values()))}updateRuleFormula(e,t,a,n,o){const{ruleFormulaMap:s}=this._ensureMaps(e,t),u=s.get(a);(!u||u.formula!==o)&&this._addFormulaByRange(e,t,a,o,n)}getCellFormulaValue(e,t,a,n){const{formulaMap:o}=this._ensureMaps(e,t),s=o.getValue(a,n);return s?this._registerOtherFormulaService.getFormulaValue(e,t,s.formulaId):Promise.resolve(void 0)}getRuleFormulaInfo(e,t,a){const{ruleFormulaMap:n}=this._ensureMaps(e,t);return n.get(a)}},g.DataValidationCustomFormulaService=fn([xe(0,V.Inject(Le.RegisterOtherFormulaService)),xe(1,V.Inject(ie.LexerTreeBuilder)),xe(2,V.Inject(M.DataValidationModel)),xe(3,V.Inject(Ce))],g.DataValidationCustomFormulaService);function ce(i){var r,e;return(e=(r=i==null?void 0:i[0])==null?void 0:r[0])==null?void 0:e.v}class vn extends M.BaseDataValidator{constructor(){super(...arguments);S(this,"id",l.DataValidationType.CUSTOM);S(this,"title","dataValidation.custom.title");S(this,"operators",[]);S(this,"scopes",["sheet"]);S(this,"formulaInput",Pt);S(this,"_customFormulaService",this.injector.get(g.DataValidationCustomFormulaService))}validatorFormula(e){const t=l.isFormulaString(e.formula1);return{success:t,formula1:t?"":this.localeService.t("dataValidation.validFail.formula")}}async parseFormula(e,t,a){return{formula1:void 0,formula2:void 0}}async isValidType(e,t,a){const{column:n,row:o,unitId:s,subUnitId:u}=e,d=await this._customFormulaService.getCellFormulaValue(s,u,o,n);return!!ce(d==null?void 0:d.result)}generateRuleErrorMessage(e){return this.localeService.t("dataValidation.custom.error")}}var gn=Object.defineProperty,_n=Object.getOwnPropertyDescriptor,Sn=(i,r,e,t)=>{for(var a=t>1?void 0:t?_n(r,e):r,n=i.length-1,o;n>=0;n--)(o=i[n])&&(a=(t?o(r,e,a):o(a))||a);return t&&a&&gn(r,e,a),a},tt=(i,r)=>(e,t)=>r(e,t,i);g.DataValidationFormulaService=class extends l.Disposable{constructor(e,t,a){super();S(this,"_formulaRuleMap",new Map);this._registerOtherFormulaService=e,this._dataValidationCacheService=t,this._dataValidationModel=a,this._initFormulaResultHandler()}_initFormulaResultHandler(){this.disposeWithMe(this._registerOtherFormulaService.formulaResult$.subscribe(e=>{for(const t in e){const a=e[t];for(const n in a){const o=a[n],s=this._ensureRuleFormulaMap(t,n),u=this._dataValidationModel.ensureManager(t,n);o.forEach(d=>{var c,h;if(s.get((c=d.extra)==null?void 0:c.ruleId)){const p=u.getRuleById((h=d.extra)==null?void 0:h.ruleId);p&&this._dataValidationCacheService.markRangeDirty(t,n,p.ranges)}})}}}))}_ensureRuleFormulaMap(e,t){let a=this._formulaRuleMap.get(e);a||(a=new Map,this._formulaRuleMap.set(e,a));let n=a.get(t);return n||(n=new Map,a.set(t,n)),n}addRule(e,t,a,n,o){const s=l.isFormulaString(n),u=l.isFormulaString(o);if(!s&&!u)return;const d=this._ensureRuleFormulaMap(e,t),c=[void 0,void 0];if(s){const h=this._registerOtherFormulaService.registerFormula(e,t,n,{ruleId:a});c[0]={id:h,text:n}}if(u){const h=this._registerOtherFormulaService.registerFormula(e,t,o,{ruleId:a});c[1]={id:h,text:o}}d.set(a,c)}removeRule(e,t,a){const o=this._ensureRuleFormulaMap(e,t).get(a);if(!o)return;const[s,u]=o,d=[s==null?void 0:s.id,u==null?void 0:u.id].filter(Boolean);d.length&&this._registerOtherFormulaService.deleteFormula(e,t,d)}updateRuleFormulaText(e,t,a,n,o){const u=this._ensureRuleFormulaMap(e,t).get(a);if(!u){this.addRule(e,t,a,n,o);return}const[d,c]=u;if((d==null?void 0:d.text)!==n)if(d&&this._registerOtherFormulaService.deleteFormula(e,t,[d.id]),l.isFormulaString(n)){const h=this._registerOtherFormulaService.registerFormula(e,t,n,{ruleId:a});u[0]={text:n,id:h}}else u[0]=void 0;if((c==null?void 0:c.text)!==o)if(c&&this._registerOtherFormulaService.deleteFormula(e,t,[c.id]),l.isFormulaString(o)){const h=this._registerOtherFormulaService.registerFormula(e,t,o,{ruleId:a});u[1]={text:o,id:h}}else u[1]=void 0}getRuleFormulaResult(e,t,a){const o=this._ensureRuleFormulaMap(e,t).get(a);if(!o)return Promise.resolve(null);const s=async u=>u&&this._registerOtherFormulaService.getFormulaValue(e,t,u.id);return Promise.all([s(o[0]),s(o[1])])}getRuleFormulaResultSync(e,t,a){const o=this._ensureRuleFormulaMap(e,t).get(a);if(o)return o.map(s=>{if(s)return this._registerOtherFormulaService.getFormulaValueSync(e,t,s.id)})}getRuleFormulaInfo(e,t,a){return this._ensureRuleFormulaMap(e,t).get(a)}},g.DataValidationFormulaService=Sn([tt(0,V.Inject(Le.RegisterOtherFormulaService)),tt(1,V.Inject(Ce)),tt(2,V.Inject(M.DataValidationModel))],g.DataValidationFormulaService);var Rn=Object.defineProperty,Mn=Object.getOwnPropertyDescriptor,Vn=(i,r,e,t)=>{for(var a=t>1?void 0:t?Mn(r,e):r,n=i.length-1,o;n>=0;n--)(o=i[n])&&(a=(t?o(r,e,a):o(a))||a);return t&&a&&Rn(r,e,a),a},at=(i,r)=>(e,t)=>r(e,t,i);const Be=6;let nt=class{constructor(i,r,e){this._commandService=i,this._formulaService=r,this._themeService=e}_calc(i,r){var d,c,h;const{vt:e,ht:t}=r||{},a=i.endX-i.startX-Be*2,n=i.endY-i.startY,o=((d=r==null?void 0:r.fs)!=null?d:10)*1.6;let s=0,u=0;switch(e){case l.VerticalAlign.TOP:u=0;break;case l.VerticalAlign.BOTTOM:u=0+(n-o);break;default:u=0+(n-o)/2;break}switch(t){case l.HorizontalAlign.LEFT:s=Be;break;case l.HorizontalAlign.RIGHT:s=Be+(a-o);break;default:s=Be+(a-o)/2;break}return{left:i.startX+s,top:i.startY+u,width:((c=r==null?void 0:r.fs)!=null?c:10)*1.6,height:((h=r==null?void 0:r.fs)!=null?h:10)*1.6}}calcCellAutoHeight(i){var e;const{style:r}=i;return((e=r==null?void 0:r.fs)!=null?e:10)*1.6}async _parseFormula(i,r,e){var o,s;const{formula1:t=$e,formula2:a=rt}=i,n=await this._formulaService.getRuleFormulaResult(r,e,i.uid);return{formula1:l.isFormulaString(t)?ce((o=n==null?void 0:n[0])==null?void 0:o.result):t,formula2:l.isFormulaString(a)?ce((s=n==null?void 0:n[1])==null?void 0:s.result):a}}drawWith(i,r){var x,B,U,G,H;const{style:e,data:t,primaryWithCoord:a,unitId:n,subUnitId:o}=r,s=a.isMergedMainCell?a.mergeInfo:a,u=te(t),d=(x=t.dataValidation)==null?void 0:x.rule,c=(B=t.dataValidation)==null?void 0:B.validator;if(!d||!c)return;const h=this._themeService.getCurrentTheme();if(!c.skipDefaultFontRender(d,u,{unitId:n,subUnitId:o}))return;const{formula1:p=$e}=d,m=this._calc(s,e),{a:_,d:v}=i.getTransform(),R=X.fixLineWidthByScale(m.left,_),D=X.fixLineWidthByScale(m.top,v),I=X.Transform.create().composeMatrix({left:R,top:D,scaleX:1,scaleY:1,angle:0,skewX:0,skewY:0,flipX:!1,flipY:!1}),O=s.endX-s.startX,C=s.endY-s.startY;i.save(),i.beginPath(),i.rect(s.startX,s.startY,O,C),i.clip();const y=I.getMatrix();i.transform(y[0],y[1],y[2],y[3],y[4],y[5]);const L=((U=e==null?void 0:e.fs)!=null?U:10)*1.6,b=String(u)===String(p),q=h.hyacinth500;X.Checkbox.drawWith(i,{checked:b,width:L,height:L,fill:(H=(G=e==null?void 0:e.cl)==null?void 0:G.rgb)!=null?H:q}),i.restore()}isHit(i,r){const e=r.primaryWithCoord.isMergedMainCell?r.primaryWithCoord.mergeInfo:r.primaryWithCoord,t=this._calc(e,r.style),a=t.top,n=t.top+t.height,o=t.left,s=t.left+t.width,{x:u,y:d}=i;return u<=s&&u>=o&&d<=n&&d>=a}async onPointerDown(i,r){var p,m;if(r.button===2)return;const{primaryWithCoord:e,unitId:t,subUnitId:a,data:n}=i,o=te(n),s=(p=n.dataValidation)==null?void 0:p.rule,u=(m=n.dataValidation)==null?void 0:m.validator;if(!s||!u||!u.skipDefaultFontRender(s,o,{unitId:t,subUnitId:a}))return;const{formula1:d,formula2:c}=await this._parseFormula(s,t,a),h={range:{startColumn:e.actualColumn,endColumn:e.actualColumn,startRow:e.actualRow,endRow:e.actualRow},value:{v:String(o)===String(d)?c:d,p:null}};this._commandService.executeCommand(re.SetRangeValuesCommand.id,h)}};nt=Vn([at(0,l.ICommandService),at(1,V.Inject(g.DataValidationFormulaService)),at(2,V.Inject(l.ThemeService))],nt);const $e=1,rt=0;class Dn extends M.BaseDataValidator{constructor(){super(...arguments);S(this,"id",l.DataValidationType.CHECKBOX);S(this,"title","dataValidation.checkbox.title");S(this,"operators",[]);S(this,"scopes",["sheet"]);S(this,"formulaInput",Bt);S(this,"canvasRender",this.injector.createInstance(nt));S(this,"_formulaService",this.injector.get(g.DataValidationFormulaService))}skipDefaultFontRender(e,t,a){const{formula1:n,formula2:o}=this.parseFormulaSync(e,a.unitId,a.subUnitId),s=`${t!=null?t:""}`;return!s||s===`${n}`||s===`${o}`}validatorFormula(e){const{formula1:t,formula2:a}=e,n=!l.Tools.isBlank(t),o=!l.Tools.isBlank(a),s=t===a;return{success:n&&o&&!s||!n&&!o,formula1:n?s?this.localeService.t("dataValidation.validFail.checkboxEqual"):"":this.localeService.t("dataValidation.validFail.common"),formula2:o?s?this.localeService.t("dataValidation.validFail.checkboxEqual"):"":this.localeService.t("dataValidation.validFail.common")}}async parseFormula(e,t,a){var u,d;const{formula1:n=$e,formula2:o=rt}=e,s=await this._formulaService.getRuleFormulaResult(t,a,e.uid);return{formula1:l.isFormulaString(n)?ce((u=s==null?void 0:s[0])==null?void 0:u.result):n,formula2:l.isFormulaString(o)?ce((d=s==null?void 0:s[1])==null?void 0:d.result):o}}parseFormulaSync(e,t,a){var u,d;const{formula1:n=$e,formula2:o=rt}=e,s=this._formulaService.getRuleFormulaResultSync(t,a,e.uid);return{formula1:l.isFormulaString(n)?ce((u=s==null?void 0:s[0])==null?void 0:u.result):n,formula2:l.isFormulaString(o)?ce((d=s==null?void 0:s[1])==null?void 0:d.result):o}}async isValidType(e,t,a){const{value:n,unitId:o,subUnitId:s}=e,{formula1:u,formula2:d}=await this.parseFormula(a,o,s);return!l.Tools.isDefine(u)||!l.Tools.isDefine(d)?!0:l.Tools.isDefine(n)&&(String(n)===String(u)||String(n)===String(d))}generateRuleErrorMessage(e){return this.localeService.t("dataValidation.checkbox.error")}}const Te=[l.DataValidationOperator.BETWEEN,l.DataValidationOperator.NOT_BETWEEN],ot=86400;function On(i,r=!0){if(r&&i>=0){if(i===0)return[1900,1,0];if(i===60)return[1900,2,29];if(i<60)return[1900,i<32?1:2,(i-1)%31+1]}let e=i+68569+2415019;const t=Math.floor(4*e/146097);e=e-Math.floor((146097*t+3)/4);const a=Math.floor(4e3*(e+1)/1461001);e=e-Math.floor(1461*a/4)+31;const n=Math.floor(80*e/2447),o=e-Math.floor(2447*n/80);e=Math.floor(n/11);const s=n+2-12*e;return[100*(t-49)+a+e|0,s|0,o|0]}const In=i=>{let r=i|0;const e=ot*(i-r);let t=Math.floor(e);e-t>.9999&&(t+=1,t===ot&&(t=0,r+=1));const a=t<0?ot+t:t,[n,o,s]=On(i,!0),u=Math.floor(a/60/60)%60,d=Math.floor(a/60)%60,c=Math.floor(a)%60,h=new Date(0);return h.setUTCFullYear(n,o-1,s),h.setUTCHours(u,d,c),h.getTime()},Cn={[l.DataValidationOperator.BETWEEN]:"dataValidation.date.operators.between",[l.DataValidationOperator.EQUAL]:"dataValidation.date.operators.equal",[l.DataValidationOperator.GREATER_THAN]:"dataValidation.date.operators.greaterThan",[l.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.date.operators.greaterThanOrEqual",[l.DataValidationOperator.LESS_THAN]:"dataValidation.date.operators.lessThan",[l.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.date.operators.lessThanOrEqual",[l.DataValidationOperator.NOT_BETWEEN]:"dataValidation.date.operators.notBetween",[l.DataValidationOperator.NOT_EQUAL]:"dataValidation.date.operators.notEqual"};l.DataValidationOperator.BETWEEN+"",l.DataValidationOperator.EQUAL+"",l.DataValidationOperator.GREATER_THAN+"",l.DataValidationOperator.GREATER_THAN_OR_EQUAL+"",l.DataValidationOperator.LESS_THAN+"",l.DataValidationOperator.LESS_THAN_OR_EQUAL+"",l.DataValidationOperator.NOT_BETWEEN+"",l.DataValidationOperator.NOT_EQUAL+"";const En={[l.DataValidationOperator.BETWEEN]:"dataValidation.date.ruleName.between",[l.DataValidationOperator.EQUAL]:"dataValidation.date.ruleName.equal",[l.DataValidationOperator.GREATER_THAN]:"dataValidation.date.ruleName.greaterThan",[l.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.date.ruleName.greaterThanOrEqual",[l.DataValidationOperator.LESS_THAN]:"dataValidation.date.ruleName.lessThan",[l.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.date.ruleName.lessThanOrEqual",[l.DataValidationOperator.NOT_BETWEEN]:"dataValidation.date.ruleName.notBetween",[l.DataValidationOperator.NOT_EQUAL]:"dataValidation.date.ruleName.notEqual"},Fn={[l.DataValidationOperator.BETWEEN]:"dataValidation.date.errorMsg.between",[l.DataValidationOperator.EQUAL]:"dataValidation.date.errorMsg.equal",[l.DataValidationOperator.GREATER_THAN]:"dataValidation.date.errorMsg.greaterThan",[l.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.date.errorMsg.greaterThanOrEqual",[l.DataValidationOperator.LESS_THAN]:"dataValidation.date.errorMsg.lessThan",[l.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.date.errorMsg.lessThanOrEqual",[l.DataValidationOperator.NOT_BETWEEN]:"dataValidation.date.errorMsg.notBetween",[l.DataValidationOperator.NOT_EQUAL]:"dataValidation.date.errorMsg.notEqual"},qt="{FORMULA1}",Ht="{FORMULA2}",Wt=i=>ge(i).isValid(),qe=i=>{if(!(i==null||typeof i=="boolean"))return typeof i=="number"||!Number.isNaN(+i)?ge(In(+i)):ge(i)};class wn extends M.BaseDataValidator{constructor(){super(...arguments);S(this,"id",l.DataValidationType.DATE);S(this,"title","dataValidation.date.title");S(this,"operators",[l.DataValidationOperator.BETWEEN,l.DataValidationOperator.EQUAL,l.DataValidationOperator.GREATER_THAN,l.DataValidationOperator.GREATER_THAN_OR_EQUAL,l.DataValidationOperator.LESS_THAN,l.DataValidationOperator.LESS_THAN_OR_EQUAL,l.DataValidationOperator.NOT_BETWEEN,l.DataValidationOperator.NOT_EQUAL]);S(this,"scopes",["sheet"]);S(this,"formulaInput",ye);S(this,"dropdown",Ut);S(this,"_formulaService",this.injector.get(g.DataValidationFormulaService));S(this,"transformDate",qe)}async parseFormula(e,t,a){var u,d;const n=await this._formulaService.getRuleFormulaResult(t,a,e.uid),{formula1:o,formula2:s}=e;return{formula1:qe(l.isFormulaString(o)?ce((u=n==null?void 0:n[0])==null?void 0:u.result):o),formula2:qe(l.isFormulaString(s)?ce((d=n==null?void 0:n[1])==null?void 0:d.result):s)}}async isValidType(e){const{value:t}=e;return typeof t=="string"?ge(t).isValid():typeof t=="number"}_validatorSingleFormula(e){return!l.Tools.isBlank(e)&&(l.isFormulaString(e)||!Number.isNaN(+e)||!!e&&ge(e).isValid())}validatorFormula(e){const t=e.operator;if(!t)return{success:!1};const a=this._validatorSingleFormula(e.formula1),n=this.localeService.t("dataValidation.validFail.date");if(Te.includes(t)){const s=this._validatorSingleFormula(e.formula2);return{success:a&&s,formula1:a?void 0:n,formula2:s?void 0:n}}return{success:a,formula1:a?void 0:n}}transform(e,t,a){const{value:n}=e;return{...e,value:qe(n)}}async validatorIsEqual(e,t,a){const{value:n}=e,{formula1:o}=t;return o?n.isSame(o):!0}async validatorIsNotEqual(e,t){const{value:a}=e,{formula1:n}=t;return n?!a.isSame(n):!0}async validatorIsBetween(e,t){const{value:a}=e,{formula1:n,formula2:o}=t;if(!n||!o)return!1;const s=n.isAfter(o)?o:n,u=s===n?o:n;return(a.isAfter(s)||a.isSame(s))&&(a.isBefore(u)||a.isSame(u))}async validatorIsNotBetween(e,t){const{value:a}=e,{formula1:n,formula2:o}=t;if(!n||!o)return!1;const s=n.isAfter(o)?o:n,u=s===n?o:n;return a.isBefore(s)||a.isAfter(u)}async validatorIsGreaterThan(e,t){const{value:a}=e,{formula1:n}=t;return n?a.isAfter(n):!0}async validatorIsGreaterThanOrEqual(e,t){const{value:a}=e,{formula1:n}=t;return n?a.isAfter(n)||a.isSame(n):!0}async validatorIsLessThan(e,t){const{value:a}=e,{formula1:n}=t;return n?a.isBefore(n)||a.isSame(n):!0}async validatorIsLessThanOrEqual(e,t){const{value:a}=e,{formula1:n}=t;return n?a.isBefore(n)||a.isSame(n):!0}validatorFormulaValue(e){if(!l.Tools.isDefine(e.operator))return;if(Te.includes(e.operator)){if(l.Tools.isBlank(e.formula1)||l.Tools.isBlank(e.formula2))return"";if(!Wt(e.formula1)||!Wt(e.formula2))return""}else if(l.Tools.isBlank(e.formula1))return""}get operatorNames(){return this.operators.map(e=>this.localeService.t(Cn[e]))}generateRuleName(e){var a,n;if(!e.operator)return this.titleStr;const t=this.localeService.t(En[e.operator]).replace(qt,(a=e.formula1)!=null?a:"").replace(Ht,(n=e.formula2)!=null?n:"");return`${this.titleStr} ${t}`}generateRuleErrorMessage(e){var a,n;return e.operator?`${this.localeService.t(Fn[e.operator]).replace(qt,(a=e.formula1)!=null?a:"").replace(Ht,(n=e.formula2)!=null?n:"")}`:this.titleStr}}var yn=Object.defineProperty,Tn=Object.getOwnPropertyDescriptor,Ln=(i,r,e,t)=>{for(var a=t>1?void 0:t?Tn(r,e):r,n=i.length-1,o;n>=0;n--)(o=i[n])&&(a=(t?o(r,e,a):o(a))||a);return t&&a&&yn(r,e,a),a},kt=(i,r)=>(e,t)=>r(e,t,i);const Ee=4,An=6,le=14,Me=6,me=2,bn="#565656",Yt=new Path2D("M3.32201 4.84556C3.14417 5.05148 2.85583 5.05148 2.67799 4.84556L0.134292 1.90016C-0.152586 1.56798 0.0505937 1 0.456301 1L5.5437 1C5.94941 1 6.15259 1.56798 5.86571 1.90016L3.32201 4.84556Z");function Nn(i,r){const e=i.length;return{id:"d",body:{dataStream:`${i}${l.DEFAULT_EMPTY_DOCUMENT_VALUE}`,textRuns:[{ts:{fs:11,ff:void 0,it:l.BooleanNumber.FALSE,bl:l.BooleanNumber.FALSE,ul:{s:l.BooleanNumber.FALSE},st:{s:l.BooleanNumber.FALSE},ol:{s:l.BooleanNumber.FALSE},cl:void 0,...r,bg:void 0,bd:void 0},st:0,ed:e}]},documentStyle:{pageSize:{width:Number.POSITIVE_INFINITY,height:Number.POSITIVE_INFINITY}}}}function it(i,r,e){const t=Nn(i,e),a=new l.DocumentDataModel(t),n=new X.DocumentViewModel(a);return{documentSkeleton:X.DocumentSkeleton.create(n,r),docModel:a,docViewModel:n}}function Gt(i,r,e){const{documentSkeleton:t,docModel:a,docViewModel:n}=it(i,r,e);return{documents:new X.Documents(`DOCUMENTS_${l.Tools.generateRandomId()}`,t,{pageMarginLeft:0,pageMarginTop:0}),documentSkeleton:t,docModel:a,docViewModel:n}}let lt=(vt=class{constructor(i,r){S(this,"_dropdownInfoMap",new Map);S(this,"zIndex");S(this,"onPointerEnter");S(this,"onPointerLeave");this._localeService=i,this._commandService=r}_ensureMap(i){let r=this._dropdownInfoMap.get(i);return r||(r=new Map,this._dropdownInfoMap.set(i,r)),r}_generateKey(i,r){return`${i}.${r}`}_drawDownIcon(i,r,e,t,a){const n=e-le+4;let o=4;switch(a){case l.VerticalAlign.MIDDLE:o=(t-le)/2+4;break;case l.VerticalAlign.BOTTOM:o=t-le+4;break}i.save(),i.translateWithPrecision(r.startX+n,r.startY+o),i.fillStyle="#565656",i.fill(Yt),i.restore()}drawWith(i,r,e){var H,z;const{primaryWithCoord:t,row:a,col:n,style:o,data:s,subUnitId:u}=r,d=t.isMergedMainCell?t.mergeInfo:t,c=(H=s.dataValidation)==null?void 0:H.rule,h=(z=s.dataValidation)==null?void 0:z.validator,p=s.fontRenderExtension,{leftOffset:m=0,rightOffset:_=0,topOffset:v=0,downOffset:R=0}=p||{};if(!c||!h||!h.skipDefaultFontRender(c))return;const D={startX:d.startX+m,endX:d.endX-_,startY:d.startY+v,endY:d.endY-R},I=D.endX-D.startX,O=D.endY-D.startY,C=this._ensureMap(u),y=this._generateKey(a,n),L=h.getListWithColor(c),b=te(s),q=`${b!=null?b:""}`,x=L.find($=>$.label===q);let{tb:B,vt:U,ht:G}=o||{};if(B=B!=null?B:l.WrapStrategy.WRAP,U=U!=null?U:l.VerticalAlign.TOP,G=G!=null?G:l.HorizontalAlign.LEFT,c.renderMode===l.DataValidationRenderMode.ARROW){this._drawDownIcon(i,D,I,O,U),i.save(),i.translateWithPrecision(D.startX,D.startY),i.beginPath(),i.rect(0,0,I,O),i.clip();const $=I-le,{documentSkeleton:Z,documents:ne,docModel:Q}=Gt(q,this._localeService,o);B===l.WrapStrategy.WRAP&&Q.updateDocumentDataPageSize(Math.max($,1)),Z.calculate(),Z.getActualSize();const T=X.getDocsSkeletonPageSize(Z),{height:A,width:K}=T;let W=0;switch(U){case l.VerticalAlign.BOTTOM:W=O-me-A;break;case l.VerticalAlign.MIDDLE:W=(O-me-A)/2;break;default:W=me;break}let w=0;switch(G){case l.HorizontalAlign.CENTER:w=($-K)/2;break;case l.HorizontalAlign.RIGHT:w=$-K;break}i.translate(0,W),i.save(),i.translateWithPrecision(Ee,0),i.beginPath(),i.rect(0,0,$,A),i.clip(),ne.render(i),i.translateWithPrecision(w,0),i.restore(),i.restore(),C.set(y,{left:D.endX+e.rowHeaderWidth-le,top:D.startY+e.columnHeaderHeight,width:le,height:O})}else{i.save(),i.translateWithPrecision(D.startX,D.startY),i.beginPath(),i.rect(0,0,I,O),i.clip();const $=I-Me*2-Ee-le,{documentSkeleton:Z,documents:ne,docModel:Q}=Gt(q,this._localeService,o);B===l.WrapStrategy.WRAP&&Q.updateDocumentDataPageSize(Math.max($,1)),Z.calculate();const T=X.getDocsSkeletonPageSize(Z),{height:A,width:K}=T;let W=0;switch(U){case l.VerticalAlign.BOTTOM:W=O-me-A;break;case l.VerticalAlign.MIDDLE:W=(O-me-A)/2;break;default:W=me;break}let w=0;switch(G){case l.HorizontalAlign.CENTER:w=($-K)/2;break;case l.HorizontalAlign.RIGHT:w=$-K;break}i.translate(Me,W);const Y=Math.max(I-Me*2,1),k=A;X.Rect.drawWith(i,{width:Y,height:k,fill:(x==null?void 0:x.color)||Re,radius:8}),i.save(),i.translateWithPrecision(Ee,0),i.beginPath(),i.rect(0,0,$,A),i.clip(),i.translateWithPrecision(w,0),ne.render(i),i.restore(),i.translate($+Ee+4,(A-An)/2),i.fillStyle=bn,i.fill(Yt),i.restore(),C.set(y,{left:D.startX+Me+e.rowHeaderWidth,top:D.startY+W+e.columnHeaderHeight,width:Y,height:k})}}calcCellAutoHeight(i){var R;const{primaryWithCoord:r,style:e,data:t}=i,a=r.isMergedMainCell?r.mergeInfo:r,n=t.fontRenderExtension,{leftOffset:o=0,rightOffset:s=0,topOffset:u=0,downOffset:d=0}=n||{},c=(R=t.dataValidation)==null?void 0:R.rule;if(!c||c.renderMode===l.DataValidationRenderMode.TEXT)return;const h={startX:a.startX+o,endX:a.endX-s,startY:a.startY+u,endY:a.endY-d},p=h.endX-h.startX,m=te(t),_=`${m!=null?m:""}`;let{tb:v}=e||{};if(v=v!=null?v:l.WrapStrategy.WRAP,c.renderMode===l.DataValidationRenderMode.ARROW){const D=p-le,{documentSkeleton:I,docModel:O}=it(_,this._localeService,e);v===l.WrapStrategy.WRAP&&O.updateDocumentDataPageSize(Math.max(D,1)),I.calculate(),I.getActualSize();const C=X.getDocsSkeletonPageSize(I),{height:y}=C;return y}else{const D=p-Me*2-Ee-le,{documentSkeleton:I,docModel:O}=it(_,this._localeService,e);v===l.WrapStrategy.WRAP&&O.updateDocumentDataPageSize(Math.max(D,1)),I.calculate();const C=X.getDocsSkeletonPageSize(I),{height:y}=C;return y+me*2}}isHit(i,r){const{data:e,subUnitId:t,row:a,col:n}=r,s=this._ensureMap(t).get(this._generateKey(a,n)),u=e.dataValidation;if(!u||!s||u.rule.renderMode===l.DataValidationRenderMode.TEXT)return!1;const{top:d,left:c,width:h,height:p}=s,{x:m,y:_}=i;return m>=c&&m<=c+h&&_>=d&&_<=d+p}onPointerDown(i,r){if(r.button===2)return;const{unitId:e,subUnitId:t,row:a,col:n}=i,o={unitId:e,subUnitId:t,row:a,column:n};this._commandService.executeCommand(be.id,o)}},S(vt,"padding",{l:Me+Ee,r:le+Me,t:me,b:me}),vt);lt=Ln([kt(0,V.Inject(l.LocaleService)),kt(1,l.ICommandService)],lt);function st(i){if(!i)return[];const r=new Set;return i.forEach(e=>{e.forEach(t=>{const a=te(t);a!=null&&r.add(a.toString())})}),[...r]}const Un=["if","indirect","choose","offset"];function jn(i,r){if(!l.isFormulaString(i)||ie.isReferenceString(i.slice(1)))return!0;const t=r.sequenceNodesBuilder(i);return t&&t.some(a=>typeof a=="object"&&a.nodeType===ie.sequenceNodeType.FUNCTION&&Un.indexOf(a.token.toLowerCase())>-1)}class zt extends M.BaseDataValidator{constructor(){super(...arguments);S(this,"formulaService",this.injector.get(g.DataValidationFormulaService));S(this,"_lexer",this.injector.get(ie.LexerTreeBuilder));S(this,"id",l.DataValidationType.LIST);S(this,"title","dataValidation.list.title");S(this,"operators",[]);S(this,"scopes",["sheet"]);S(this,"formulaInput",xt);S(this,"canvasRender",this.injector.createInstance(lt));S(this,"dropdown",Nt);S(this,"optionsInput",Pe.componentKey)}skipDefaultFontRender(e){return e.renderMode!==l.DataValidationRenderMode.TEXT}validatorFormula(e){var n;const t=!l.Tools.isBlank(e.formula1),a=jn((n=e.formula1)!=null?n:"",this._lexer);return{success:!!(t&&a),formula1:t?a?void 0:this.localeService.t("dataValidation.validFail.listInvalid"):this.localeService.t("dataValidation.validFail.list")}}parseCellValue(e){const t=e.toString();return Ie(t)}async parseFormula(e,t,a){var s;const{formula1:n=""}=e,o=await this.formulaService.getRuleFormulaResult(t,a,e.uid);return{formula1:l.isFormulaString(n)?st((s=o==null?void 0:o[0])==null?void 0:s.result):Ie(n),formula2:void 0}}async isValidType(e,t,a){const{value:n}=e,{formula1:o=[]}=t;return this.parseCellValue(n).every(u=>o.includes(u))}generateRuleName(){return this.localeService.t("dataValidation.list.name")}generateRuleErrorMessage(){return this.localeService.t("dataValidation.list.error")}getList(e,t,a){var p,m,_;const{formula1:n=""}=e,o=this.injector.get(l.IUniverInstanceService),s=(p=t?o.getUniverSheetInstance(t):void 0)!=null?p:o.getCurrentUnitForType(l.UniverInstanceType.UNIVER_SHEET);if(!s)return[];const u=(m=a?s.getSheetBySheetId(a):void 0)!=null?m:s.getActiveSheet(),d=s.getUnitId(),c=u.getSheetId(),h=this.formulaService.getRuleFormulaResultSync(d,c,e.uid);return l.isFormulaString(n)?st((_=h==null?void 0:h[0])==null?void 0:_.result):Ie(n)}async getListAsync(e,t,a){var p,m,_;const{formula1:n=""}=e,o=this.injector.get(l.IUniverInstanceService),s=(p=t?o.getUniverSheetInstance(t):void 0)!=null?p:o.getCurrentUnitForType(l.UniverInstanceType.UNIVER_SHEET);if(!s)return[];const u=(m=a?s.getSheetBySheetId(a):void 0)!=null?m:s.getActiveSheet(),d=s.getUnitId(),c=u.getSheetId(),h=await this.formulaService.getRuleFormulaResult(d,c,e.uid);return l.isFormulaString(n)?st((_=h==null?void 0:h[0])==null?void 0:_.result):Ie(n)}getListWithColor(e,t,a){const n=this.getList(e,t,a),o=(e.formula2||"").split(",");return n.map((s,u)=>({label:s,color:o[u]}))}getListWithColorMap(e,t,a){const n=this.getListWithColor(e,t,a),o={};return n.forEach(s=>{s.color&&(o[s.label]=s.color)}),o}}function He(i){let r=i;return typeof i=="string"?((i.startsWith("¥")||i.startsWith("$"))&&(r=i.slice(1)),+r):+i}class Pn extends M.BaseDataValidator{constructor(){super(...arguments);S(this,"_formulaService",this.injector.get(g.DataValidationFormulaService));S(this,"id",l.DataValidationType.DECIMAL);S(this,"title",this.localeService.t("dataValidation.decimal.title"));S(this,"operators",[l.DataValidationOperator.BETWEEN,l.DataValidationOperator.EQUAL,l.DataValidationOperator.GREATER_THAN,l.DataValidationOperator.GREATER_THAN_OR_EQUAL,l.DataValidationOperator.LESS_THAN,l.DataValidationOperator.LESS_THAN_OR_EQUAL,l.DataValidationOperator.NOT_BETWEEN,l.DataValidationOperator.NOT_EQUAL]);S(this,"scopes",["sheet"]);S(this,"formulaInput",ye);S(this,"dropDownInput")}_isFormulaOrNumber(e){return!l.Tools.isBlank(e)&&(l.isFormulaString(e)||!Number.isNaN(+e))}async isValidType(e,t,a){const{value:n}=e;return!Number.isNaN(He(n))}transform(e,t,a){const{value:n}=e;return{...e,value:He(n)}}_parseNumber(e){return e==null?Number.NaN:+e}async parseFormula(e,t,a){var d,c,h,p,m,_,v,R;const n=await this._formulaService.getRuleFormulaResult(t,a,e.uid),{formula1:o,formula2:s}=e;return{formula1:this._parseNumber(l.isFormulaString(o)?(p=(h=(c=(d=n==null?void 0:n[0])==null?void 0:d.result)==null?void 0:c[0])==null?void 0:h[0])==null?void 0:p.v:o),formula2:this._parseNumber(l.isFormulaString(s)?(R=(v=(_=(m=n==null?void 0:n[1])==null?void 0:m.result)==null?void 0:_[0])==null?void 0:v[0])==null?void 0:R.v:s)}}validatorFormula(e){const t=e.operator;if(!t)return{success:!1};const a=l.Tools.isDefine(e.formula1)&&this._isFormulaOrNumber(e.formula1),n=l.Tools.isDefine(e.formula2)&&this._isFormulaOrNumber(e.formula2),o=Te.includes(t),s=this.localeService.t("dataValidation.validFail.number");return o?{success:a&&n,formula1:a?void 0:s,formula2:n?void 0:s}:{success:a,formula1:a?"":s}}async validatorIsEqual(e,t,a){const{formula1:n}=t,{value:o}=e;return Number.isNaN(n)?!0:o===n}async validatorIsNotEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value!==n}async validatorIsBetween(e,t,a){const{formula1:n,formula2:o}=t;if(Number.isNaN(n)||Number.isNaN(o))return!0;const s=Math.min(n,o),u=Math.max(n,o);return e.value>=s&&e.value<=u}async validatorIsNotBetween(e,t,a){const{formula1:n,formula2:o}=t;if(Number.isNaN(n)||Number.isNaN(o))return!0;const s=Math.min(n,o),u=Math.max(n,o);return e.value<s||e.value>u}async validatorIsGreaterThan(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value>n}async validatorIsGreaterThanOrEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value>=n}async validatorIsLessThan(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value<n}async validatorIsLessThanOrEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value<=n}}const xn="{FORMULA1}",Bn="{FORMULA2}";class $n extends M.BaseDataValidator{constructor(){super(...arguments);S(this,"id",l.DataValidationType.TEXT_LENGTH);S(this,"title","dataValidation.textLength.title");S(this,"operators",[l.DataValidationOperator.BETWEEN,l.DataValidationOperator.EQUAL,l.DataValidationOperator.GREATER_THAN,l.DataValidationOperator.GREATER_THAN_OR_EQUAL,l.DataValidationOperator.LESS_THAN,l.DataValidationOperator.LESS_THAN_OR_EQUAL,l.DataValidationOperator.NOT_BETWEEN,l.DataValidationOperator.NOT_EQUAL]);S(this,"scopes",["sheet"]);S(this,"formulaInput",ye);S(this,"_formulaService",this.injector.get(g.DataValidationFormulaService))}_isFormulaOrInt(e){return!l.Tools.isBlank(e)&&(l.isFormulaString(e)||!Number.isNaN(+e)&&Number.isInteger(+e))}validatorFormula(e){const t=e.operator;if(!t)return{success:!1};const a=l.Tools.isDefine(e.formula1)&&this._isFormulaOrInt(e.formula1),n=l.Tools.isDefine(e.formula2)&&this._isFormulaOrInt(e.formula2),o=Te.includes(t),s=this.localeService.t("dataValidation.validFail.number");return o?{success:a&&n,formula1:a?void 0:s,formula2:n?void 0:s}:{success:a,formula1:s}}_parseNumber(e){return e==null?Number.NaN:+e}_isValidFormula(e){return!Number.isNaN(e)}async parseFormula(e,t,a){var u,d,c,h,p,m,_,v;const n=await this._formulaService.getRuleFormulaResult(t,a,e.uid),{formula1:o,formula2:s}=e;return{formula1:this._parseNumber(l.isFormulaString(o)?(h=(c=(d=(u=n==null?void 0:n[0])==null?void 0:u.result)==null?void 0:d[0])==null?void 0:c[0])==null?void 0:h.v:o),formula2:this._parseNumber(l.isFormulaString(s)?(v=(_=(m=(p=n==null?void 0:n[1])==null?void 0:p.result)==null?void 0:m[0])==null?void 0:_[0])==null?void 0:v.v:s)}}transform(e,t,a){return{...e,value:e.value.toString().length}}async isValidType(e,t,a){const{value:n}=e;return typeof n=="string"||typeof n=="number"}async validatorIsEqual(e,t,a){const{formula1:n}=t;return l.Tools.isDefine(n)?e.value===n:!1}async validatorIsNotEqual(e,t,a){const{formula1:n}=t;return l.Tools.isDefine(n)?e.value!==n:!1}async validatorIsBetween(e,t,a){const{formula1:n,formula2:o}=t,{value:s}=e;if(!this._isValidFormula(n)||!this._isValidFormula(o))return!1;const u=Math.max(n,o),d=Math.min(n,o);return s>=d&&s<=u}async validatorIsNotBetween(e,t,a){const{formula1:n,formula2:o}=t,{value:s}=e;if(!this._isValidFormula(n)||!this._isValidFormula(o))return!1;const u=Math.max(n,o),d=Math.min(n,o);return s<d||s>u}async validatorIsGreaterThan(e,t,a){const{formula1:n}=t,{value:o}=e;return this._isValidFormula(n)?o>n:!1}async validatorIsGreaterThanOrEqual(e,t,a){const{formula1:n}=t,{value:o}=e;return this._isValidFormula(n)?o>=n:!1}async validatorIsLessThan(e,t,a){const{formula1:n}=t,{value:o}=e;return this._isValidFormula(n)?o<n:!1}async validatorIsLessThanOrEqual(e,t,a){const{formula1:n}=t,{value:o}=e;return this._isValidFormula(n)?o<=n:!1}generateRuleErrorMessage(e){var a,n;return e.operator?`${this.localeService.t(M.TextLengthErrorTitleMap[e.operator]).replace(xn,(a=e.formula1)!=null?a:"").replace(Bn,(n=e.formula2)!=null?n:"")}`:this.titleStr}}class qn extends M.BaseDataValidator{constructor(){super(...arguments);S(this,"_formulaService",this.injector.get(g.DataValidationFormulaService));S(this,"id",l.DataValidationType.WHOLE);S(this,"title",this.localeService.t("dataValidation.whole.title"));S(this,"operators",[l.DataValidationOperator.BETWEEN,l.DataValidationOperator.EQUAL,l.DataValidationOperator.GREATER_THAN,l.DataValidationOperator.GREATER_THAN_OR_EQUAL,l.DataValidationOperator.LESS_THAN,l.DataValidationOperator.LESS_THAN_OR_EQUAL,l.DataValidationOperator.NOT_BETWEEN,l.DataValidationOperator.NOT_EQUAL]);S(this,"scopes",["sheet"]);S(this,"formulaInput",ye);S(this,"dropDownInput")}_isFormulaOrInt(e){return!l.Tools.isBlank(e)&&(l.isFormulaString(e)||!Number.isNaN(+e)&&Number.isInteger(+e))}async isValidType(e,t,a){const{value:n}=e,o=He(n);return!Number.isNaN(o)&&Number.isInteger(o)}transform(e,t,a){const{value:n}=e;return{...e,value:He(n)}}_parseNumber(e){return e==null?Number.NaN:+e}async parseFormula(e,t,a){var d,c,h,p,m,_,v,R;const n=await this._formulaService.getRuleFormulaResult(t,a,e.uid),{formula1:o,formula2:s}=e;return{formula1:this._parseNumber(l.isFormulaString(o)?(p=(h=(c=(d=n==null?void 0:n[0])==null?void 0:d.result)==null?void 0:c[0])==null?void 0:h[0])==null?void 0:p.v:o),formula2:this._parseNumber(l.isFormulaString(s)?(R=(v=(_=(m=n==null?void 0:n[1])==null?void 0:m.result)==null?void 0:_[0])==null?void 0:v[0])==null?void 0:R.v:s)}}validatorFormula(e){const t=e.operator;if(!t)return{success:!1};const a=l.Tools.isDefine(e.formula1)&&this._isFormulaOrInt(e.formula1),n=l.Tools.isDefine(e.formula2)&&this._isFormulaOrInt(e.formula2),o=Te.includes(t),s=this.localeService.t("dataValidation.validFail.number");return o?{success:a&&n,formula1:a?void 0:s,formula2:n?void 0:s}:{success:a,formula1:s}}async validatorIsEqual(e,t,a){const{formula1:n}=t,{value:o}=e;return Number.isNaN(n)?!0:o===n}async validatorIsNotEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value!==n}async validatorIsBetween(e,t,a){const{formula1:n,formula2:o}=t;if(Number.isNaN(n)||Number.isNaN(o))return!0;const s=Math.min(n,o),u=Math.max(n,o);return e.value>=s&&e.value<=u}async validatorIsNotBetween(e,t,a){const{formula1:n,formula2:o}=t;if(Number.isNaN(n)||Number.isNaN(o))return!0;const s=Math.min(n,o),u=Math.max(n,o);return e.value<s||e.value>u}async validatorIsGreaterThan(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value>n}async validatorIsGreaterThanOrEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value>=n}async validatorIsLessThan(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value<n}async validatorIsLessThanOrEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value<=n}}const Xt=4,Hn=0,ut=4,Qt=4,dt=6,We=6,Ve=14;function Wn(i,r){const e=X.FontCache.getTextSize(i,r),t=e.width+Xt*2,{ba:a,bd:n}=e,o=a+n;return{width:t,height:o+Hn*2,ba:a}}function Kt(i,r,e,t){const a=e-Ve-dt,n=t-We*2,o=i.map(c=>({layout:Wn(c,r),text:c}));let s;const u=[];o.forEach(c=>{const{layout:h}=c,{width:p,height:m}=h;!s||s.width+p+ut>a?(s={width:p,height:m,items:[{...c,left:0}]},u.push(s)):(s.items.push({...c,left:s.width+ut}),s.width=s.width+p+ut)});let d=0;return u.forEach((c,h)=>{h===u.length-1?d+=c.height:d+=c.height+Qt}),{lines:u,totalHeight:d,contentWidth:a,contentHeight:n,cellAutoHeight:d+We*2}}const kn=8;class Yn extends X.Shape{static drawWith(r,e){const{fontFamily:t,fontString:a,fontSize:n,info:o,fill:s,color:u}=e,{layout:d,text:c}=o;r.save(),X.Rect.drawWith(r,{width:d.width,height:d.height,radius:kn,fill:s||Re}),r.translateWithPrecision(Xt,d.ba),r.font=a,r.fillStyle=u,r.fillText(c,0,0),r.restore()}}var Gn=Object.defineProperty,zn=Object.getOwnPropertyDescriptor,Xn=(i,r,e,t)=>{for(var a=t>1?void 0:t?zn(r,e):r,n=i.length-1,o;n>=0;n--)(o=i[n])&&(a=(t?o(r,e,a):o(a))||a);return t&&a&&Gn(r,e,a),a},Qn=(i,r)=>(e,t)=>r(e,t,i);const Kn=new Path2D("M3.32201 4.84556C3.14417 5.05148 2.85583 5.05148 2.67799 4.84556L0.134292 1.90016C-0.152586 1.56798 0.0505937 1 0.456301 1L5.5437 1C5.94941 1 6.15259 1.56798 5.86571 1.90016L3.32201 4.84556Z");let ct=class{constructor(i){S(this,"zIndex");S(this,"_dropdownInfoMap",new Map);this._commandService=i}_ensureMap(i){let r=this._dropdownInfoMap.get(i);return r||(r=new Map,this._dropdownInfoMap.set(i,r)),r}_generateKey(i,r){return`${i}.${r}`}_drawDownIcon(i,r,e,t,a){const n=e-Ve+4;let o=4;switch(a){case l.VerticalAlign.MIDDLE:o=(t-Ve)/2+4;break;case l.VerticalAlign.BOTTOM:o=t-Ve+4;break}i.save(),i.translateWithPrecision(r.startX+n,r.startY+o),i.fillStyle="#565656",i.fill(Kn),i.restore()}drawWith(i,r,e,t){var A,K;const{primaryWithCoord:a,row:n,col:o,style:s,data:u,subUnitId:d}=r,c=a.isMergedMainCell?a.mergeInfo:a,h=u.fontRenderExtension,{leftOffset:p=0,rightOffset:m=0,topOffset:_=0,downOffset:v=0}=h||{},R=u.dataValidation,D=this._ensureMap(d),I=this._generateKey(n,o);if(!R)return;const O={startX:c.startX+p,endX:c.endX-m,startY:c.startY+_,endY:c.endY-v},C=O.endX-O.startX,y=O.endY-O.startY,{cl:L}=s||{},b=(A=typeof L=="object"?L==null?void 0:L.rgb:L)!=null?A:"#000",q=X.getFontStyleString(s!=null?s:void 0),{rule:x,validator:B}=R,U=B,{vt:G,ht:H}=s||{},z=G!=null?G:l.VerticalAlign.MIDDLE,$=(K=te(u))!=null?K:"",Z=U.parseCellValue($),ne=U.getListWithColorMap(x),Q=Kt(Z,q,C,y);this._drawDownIcon(i,O,C,y,z),i.save(),i.translateWithPrecision(O.startX,O.startY),i.beginPath(),i.rect(0,0,C-Ve,y),i.clip(),i.translateWithPrecision(dt,We);let T=0;switch(z){case l.VerticalAlign.MIDDLE:T=(Q.contentHeight-Q.totalHeight)/2;break;case l.VerticalAlign.BOTTOM:T=Q.contentHeight-Q.totalHeight;break}i.translateWithPrecision(0,T),Q.lines.forEach((W,w)=>{i.save();const{width:Y,height:k,items:ee}=W;let he=0;switch(H){case l.HorizontalAlign.RIGHT:he=Q.contentWidth-Y;break;case l.HorizontalAlign.CENTER:he=(Q.contentWidth-Y)/2;break}i.translate(he,w*(k+Qt)),ee.forEach(gt=>{i.save(),i.translateWithPrecision(gt.left,0),Yn.drawWith(i,{...q,info:gt,color:b,fill:ne[gt.text]}),i.restore()}),i.restore()}),i.restore(),D.set(I,{left:O.startX,top:O.startY,width:Q.contentWidth+dt+Ve,height:Q.contentHeight+We*2})}calcCellAutoHeight(i){var C;const{primaryWithCoord:r,style:e,data:t}=i,a=t.fontRenderExtension,{leftOffset:n=0,rightOffset:o=0,topOffset:s=0,downOffset:u=0}=a||{},d=r.isMergedMainCell?r.mergeInfo:r,c={startX:d.startX+n,endX:d.endX-o,startY:d.startY+s,endY:d.endY-u},h=t.dataValidation;if(!h)return;const p=c.endX-c.startX,m=c.endY-c.startY,_=(C=te(t))!=null?C:"",{validator:v}=h,D=v.parseCellValue(_),I=X.getFontStyleString(e!=null?e:void 0);return Kt(D,I,p,m).cellAutoHeight}isHit(i,r){const{primaryWithCoord:e}=r,t=e.isMergedMainCell?e.mergeInfo:e,{endX:a}=t,{x:n}=i;return n>=a-Ve&&n<=a}onPointerDown(i,r){if(r.button===2)return;const{unitId:e,subUnitId:t,row:a,col:n}=i,o={unitId:e,subUnitId:t,row:a,column:n};this._commandService.executeCommand(be.id,o)}};ct=Xn([Qn(0,l.ICommandService)],ct);class Zn extends zt{constructor(){super(...arguments);S(this,"id",l.DataValidationType.LIST_MULTIPLE);S(this,"title","dataValidation.listMultiple.title");S(this,"canvasRender",this.injector.createInstance(ct))}skipDefaultFontRender(){return!0}}var Jn=Object.defineProperty,er=Object.getOwnPropertyDescriptor,tr=(i,r,e,t)=>{for(var a=t>1?void 0:t?er(r,e):r,n=i.length-1,o;n>=0;n--)(o=i[n])&&(a=(t?o(r,e,a):o(a))||a);return t&&a&&Jn(r,e,a),a},ve=(i,r)=>(e,t)=>r(e,t,i);g.DataValidationController=class extends l.RxDisposable{constructor(r,e,t,a,n,o,s,u){super(),this._univerInstanceService=r,this._sheetDataValidationService=e,this._dataValidatorRegistryService=t,this._injector=a,this._componentManger=n,this._selectionManagerService=o,this._sheetInterceptorService=s,this._dataValidationModel=u,this._init()}_init(){this._registerValidators(),this._initInstanceChange(),this._componentManger.register($t,Et),this._initCommandInterceptor()}_registerValidators(){[Pn,qn,$n,wn,Dn,zt,Zn,vn].forEach(r=>{const e=this._injector.createInstance(r);this.disposeWithMe(this._dataValidatorRegistryService.register(e)),this.disposeWithMe({dispose:()=>{this._injector.delete(r)}})})}_initInstanceChange(){const r=new l.DisposableCollection;this._univerInstanceService.getCurrentTypeOfUnit$(l.UniverInstanceType.UNIVER_SHEET).subscribe(e=>{r.dispose(),e&&(this._sheetDataValidationService.switchCurrent(e.getUnitId(),e.getActiveSheet().getSheetId()),r.add(l.toDisposable(e.activeSheet$.subscribe(t=>{if(t){const a=e.getUnitId(),n=t.getSheetId();this._sheetDataValidationService.switchCurrent(a,n)}}))))}),this.disposeWithMe(r)}_initCommandInterceptor(){this._sheetInterceptorService.interceptCommand({getMutations:r=>{if(r.id===re.ClearSelectionAllCommand.id){const e=this._univerInstanceService.getCurrentUnitForType(l.UniverInstanceType.UNIVER_SHEET),t=e.getUnitId(),n=e.getActiveSheet().getSheetId(),o=this._selectionManagerService.getSelectionRanges(),s=this._dataValidationModel.ensureManager(t,n),u=s.getRuleObjectMatrix().clone();o&&u.removeRange(o);const d=u.diff(s.getDataValidations()),{redoMutations:c,undoMutations:h}=De(t,n,d);return{undos:h,redos:c}}return{undos:[],redos:[]}}})}},g.DataValidationController=tr([l.OnLifecycle(l.LifecycleStages.Rendered,g.DataValidationController),ve(0,l.IUniverInstanceService),ve(1,V.Inject(g.SheetDataValidationService)),ve(2,V.Inject(M.DataValidatorRegistryService)),ve(3,V.Inject(V.Injector)),ve(4,V.Inject(P.ComponentManager)),ve(5,V.Inject(re.SelectionManagerService)),ve(6,V.Inject(re.SheetInterceptorService)),ve(7,V.Inject(M.DataValidationModel))],g.DataValidationController);var ar=Object.defineProperty,nr=Object.getOwnPropertyDescriptor,rr=(i,r,e,t)=>{for(var a=t>1?void 0:t?nr(r,e):r,n=i.length-1,o;n>=0;n--)(o=i[n])&&(a=(t?o(r,e,a):o(a))||a);return t&&a&&ar(r,e,a),a},ke=(i,r)=>(e,t)=>r(e,t,i);const mt="SHEET_DATA_VALIDATION_ALERT";g.DataValidationAlertController=class extends l.Disposable{constructor(r,e,t,a){super(),this._hoverManagerService=r,this._cellAlertManagerService=e,this._univerInstanceService=t,this._localeService=a,this._init()}_init(){this._initCellAlertPopup()}_initCellAlertPopup(){this.disposeWithMe(this._hoverManagerService.currentCell$.subscribe(r=>{var e,t;if(r){const o=this._univerInstanceService.getCurrentUnitForType(l.UniverInstanceType.UNIVER_SHEET).getActiveSheet().getCell(r.location.row,r.location.col);if(((e=o==null?void 0:o.dataValidation)==null?void 0:e.validStatus)===l.DataValidationStatus.INVALID){const s=this._cellAlertManagerService.currentAlert.get(mt),u=(t=s==null?void 0:s.alert)==null?void 0:t.location;if(u&&u.row===r.location.row&&u.col===r.location.col&&u.subUnitId===r.location.subUnitId&&u.unitId===r.location.unitId)return;const d=o.dataValidation.validator,c=o.dataValidation.rule;if(!d)return;this._cellAlertManagerService.showAlert({type:j.CellAlertType.ERROR,title:this._localeService.t("dataValidation.error.title"),message:d==null?void 0:d.getRuleFinalError(c),location:r.location,width:200,height:74,key:mt});return}}this._cellAlertManagerService.removeAlert(mt)}))}},g.DataValidationAlertController=rr([l.OnLifecycle(l.LifecycleStages.Rendered,g.DataValidationAlertController),ke(0,V.Inject(j.HoverManagerService)),ke(1,V.Inject(j.CellAlertManagerService)),ke(2,l.IUniverInstanceService),ke(3,V.Inject(l.LocaleService))],g.DataValidationAlertController);var or=Object.defineProperty,ir=Object.getOwnPropertyDescriptor,lr=(i,r,e,t)=>{for(var a=t>1?void 0:t?ir(r,e):r,n=i.length-1,o;n>=0;n--)(o=i[n])&&(a=(t?o(r,e,a):o(a))||a);return t&&a&&or(r,e,a),a},se=(i,r)=>(e,t)=>r(e,t,i);g.DataValidationRefRangeController=class extends l.Disposable{constructor(e,t,a,n,o,s,u,d,c,h){super();S(this,"_disposableMap",new Map);S(this,"registerRule",(e,t,a)=>{this.register(e,t,a),this.registerFormula(e,t,a)});this._dataValidationModel=e,this._univerInstanceService=t,this._injector=a,this._sheetSkeletonManagerService=n,this._refRangeService=o,this._dataValidationCustomFormulaService=s,this._dataValidationFormulaService=u,this._formulaRefRangeService=d,this._commandService=c,this._dataValidationCacheService=h,this._initRefRange()}_getIdWithUnitId(e,t,a){return`${e}_${t}_${a}`}registerFormula(e,t,a){var d;const n=a.uid,o=this._getIdWithUnitId(e,t,n),s=(d=this._disposableMap.get(o))!=null?d:new Set,u=(c,h)=>{const p=this._dataValidationModel.getRuleById(e,t,n);if(!p)return{redos:[],undos:[]};const m=p[c];if(!m||m===h)return{redos:[],undos:[]};const _={unitId:e,subUnitId:t,ruleId:a.uid,payload:{type:M.UpdateRuleType.SETTING,payload:{type:p.type,formula1:p.formula1,formula2:p.formula2,[c]:h}}},v={unitId:e,subUnitId:t,ruleId:a.uid,payload:{type:M.UpdateRuleType.SETTING,payload:{type:p.type,formula1:p.formula1,formula2:p.formula2}}},R=[{id:M.UpdateDataValidationMutation.id,params:_}],D=[{id:M.UpdateDataValidationMutation.id,params:v}];return{redos:R,undos:D}};if(a.type===l.DataValidationType.CUSTOM){const c=this._dataValidationCustomFormulaService.getRuleFormulaInfo(e,t,n);if(c){const h=this._formulaRefRangeService.registerFormula(c.formula,p=>u("formula1",p));s.add(()=>h.dispose())}}if(a.type!==l.DataValidationType.CUSTOM){const c=this._dataValidationFormulaService.getRuleFormulaInfo(e,t,n);if(c){const[h,p]=c;if(h){const m=this._formulaRefRangeService.registerFormula(h.text,_=>u("formula1",_));s.add(()=>m.dispose())}if(p){const m=this._formulaRefRangeService.registerFormula(p.text,_=>u("formula1",_));s.add(()=>m.dispose())}}}}register(e,t,a){var d;const n=c=>{const h=[...a.ranges],m=h.map(v=>re.handleCommonDefaultRangeChangeWithEffectRefCommands(v,c)).filter(v=>!!v).flat();if(l.isRangesEqual(m,h))return{redos:[],undos:[]};if(m.length){const v={unitId:e,subUnitId:t,ruleId:a.uid,payload:{type:M.UpdateRuleType.RANGE,payload:m}},R=[{id:M.UpdateDataValidationMutation.id,params:v}],D=[{id:M.UpdateDataValidationMutation.id,params:{unitId:e,subUnitId:t,ruleId:a.uid,payload:{type:M.UpdateRuleType.RANGE,payload:h}}}];return{redos:R,undos:D}}else{const v={unitId:e,subUnitId:t,ruleId:a.uid},R=[{id:M.RemoveDataValidationMutation.id,params:v}],D=M.removeDataValidationUndoFactory(this._injector,v);return{redos:R,undos:D}}},o=[];a.ranges.forEach(c=>{const h=this._refRangeService.registerRefRange(c,n,e,t);o.push(()=>h.dispose())});const s=this._getIdWithUnitId(e,t,a.uid),u=(d=this._disposableMap.get(s))!=null?d:new Set;u.add(()=>o.forEach(c=>c())),this._disposableMap.set(s,u)}_initRefRange(){this.disposeWithMe(pe.merge(this._sheetSkeletonManagerService.currentSkeleton$.pipe(Xe.map(e=>e==null?void 0:e.sheetId),Xe.distinctUntilChanged())).pipe(Xe.switchMap(()=>new pe.Observable(e=>{const t=new l.DisposableCollection;return e.next(t),()=>{t.dispose()}}))).subscribe(e=>{e.add(l.toDisposable(this._dataValidationModel.ruleChange$.subscribe(t=>{const{unitId:a,subUnitId:n,rule:o}=t;switch(t.type){case"add":{const s=t.rule;this.registerRule(t.unitId,t.subUnitId,s);break}case"remove":{const s=this._disposableMap.get(this._getIdWithUnitId(a,n,o.uid));s&&s.forEach(u=>u());break}case"update":{const s=t.rule,u=this._disposableMap.get(this._getIdWithUnitId(a,n,s.uid));u&&u.forEach(d=>d()),this.registerRule(t.unitId,t.subUnitId,s);break}}})))})),this.disposeWithMe(l.toDisposable(()=>{this._disposableMap.forEach(e=>{e.forEach(t=>t())}),this._disposableMap.clear()}))}},g.DataValidationRefRangeController=lr([l.OnLifecycle(l.LifecycleStages.Ready,g.DataValidationRefRangeController),se(0,V.Inject(M.DataValidationModel)),se(1,V.Inject(l.IUniverInstanceService)),se(2,V.Inject(V.Injector)),se(3,V.Inject(j.SheetSkeletonManagerService)),se(4,V.Inject(re.RefRangeService)),se(5,V.Inject(g.DataValidationCustomFormulaService)),se(6,V.Inject(g.DataValidationFormulaService)),se(7,V.Inject(Le.FormulaRefRangeService)),se(8,l.ICommandService),se(9,V.Inject(Ce))],g.DataValidationRefRangeController);const Zt={dataValidation:{title:"Data validation",validFail:{common:"Please input value or formula",number:"Please input number or formula",formula:"Please input formula",integer:"Please input integer or formula",date:"Please input date or formula",list:"Please input options",listInvalid:"The list source must be a delimited list or a reference to a single row or column",checkboxEqual:"Enter different values for ticked and unticked cell contents."},panel:{title:"Data validation management",addTitle:"Create new data validation",removeAll:"Remove All",add:"Create Data validation",range:"Ranges",type:"Type",options:"Advance options",operator:"Operator",removeRule:"Remove",done:"Done",formulaPlaceholder:"Please input value or formula",formulaAnd:"and",invalid:"Invalid",showWarning:"Show warning",rejectInput:"Reject input",messageInfo:"Helper message",showInfo:"Show help text for a selected cell"},operators:{between:"between",greaterThan:"greater than",greaterThanOrEqual:"greater than or equal",lessThan:"less than",lessThanOrEqual:"less than or equal",equal:"equal",notEqual:"not equal",notBetween:"not between"},ruleName:{between:"is between {FORMULA1} and {FORMULA2}",greaterThan:"is greater than {FORMULA1}",greaterThanOrEqual:"is greater than or equal to {FORMULA1}",lessThan:"is less than {FORMULA1}",lessThanOrEqual:"is less than or equal to {FORMULA1}",equal:"is equal to {FORMULA1}",notEqual:"is not equal to {FORMULA1}",notBetween:"is not between {FORMULA1} and {FORMULA2}"},errorMsg:{between:"Value must be between {FORMULA1} and {FORMULA2}",greaterThan:"Value must be greater than {FORMULA1}",greaterThanOrEqual:"Value must be greater than or equal to {FORMULA1}",lessThan:"Value must be less than {FORMULA1}",lessThanOrEqual:"Value must be less than or equal to {FORMULA1}",equal:"Value must be equal to {FORMULA1}",notEqual:"Value must be not equal to {FORMULA1}",notBetween:"Value must be not between {FORMULA1} and {FORMULA2}"},date:{title:"Date",operators:{between:"between",greaterThan:"after",greaterThanOrEqual:"on or after",lessThan:"before",lessThanOrEqual:"on or before",equal:"equal",notEqual:"not equal",notBetween:"not between"},ruleName:{between:"is between {FORMULA1} and {FORMULA2}",greaterThan:"is after {FORMULA1}",greaterThanOrEqual:"is on or after {FORMULA1}",lessThan:"is before {FORMULA1}",lessThanOrEqual:"is on or before {FORMULA1}",equal:"is {FORMULA1}",notEqual:"is not {FORMULA1}",notBetween:"is not between {FORMULA1}"},errorMsg:{between:"Value must be between {FORMULA1} and {FORMULA2}",greaterThan:"Value must be after {FORMULA1}",greaterThanOrEqual:"Value must be on or after {FORMULA1}",lessThan:"Value must be before {FORMULA1}",lessThanOrEqual:"Value must be on or before {FORMULA1}",equal:"Value must be {FORMULA1}",notEqual:"Value must be not {FORMULA1}",notBetween:"Value must be not between {FORMULA1}"}},list:{title:"Dropdown",name:"Value contains one from range",error:"Input must fall within specified range",emptyError:"Please enter a value",add:"Add",dropdown:"Select",options:"Options",customOptions:"Custom",refOptions:"From a range",formulaError:"The list source must be a delimited list of data, or a reference to a single row or column."},listMultiple:{title:"Dropdown-Multiple",dropdown:"Multiple select"},textLength:{title:"Text length",errorMsg:{between:"Text length must be between {FORMULA1} and {FORMULA2}",greaterThan:"Text length must be after {FORMULA1}",greaterThanOrEqual:"Text length must be on or after {FORMULA1}",lessThan:"Text length must be before {FORMULA1}",lessThanOrEqual:"Text length must be on or before {FORMULA1}",equal:"Text length must be {FORMULA1}",notEqual:"Text length must be not {FORMULA1}",notBetween:"Text length must be not between {FORMULA1}"}},decimal:{title:"Number"},whole:{title:"Integer"},checkbox:{title:"Checkbox",error:"This cell's contents violate its validation rule",tips:"Use custom values within cells",checked:"Selected value",unchecked:"Unselected value"},custom:{title:"Custom formula",error:"This cell's contents violate its validation rule",validFail:"Please input a valid formula"},alert:{title:"Error",ok:"OK"},error:{title:"Invalid:"},renderMode:{arrow:"Arrow",chip:"Chip",text:"Plain text",label:"Display style"}}},Jt={dataValidation:{title:"数据验证",validFail:{common:"请输入值或公式",number:"请输入合法的数字或公式",formula:"请输入合法的公式或公式",integer:"请输入合法的整数或公式",date:"请输入合法的日期或公式",list:"请输入至少一个合法选项",listInvalid:"列表源必须是分隔列表或对单行或列的引用。",checkboxEqual:"为勾选和未勾选的单元格内容输入不同的值。"},panel:{title:"管理数据验证",addTitle:"新建数据验证",removeAll:"全部删除",add:"新建规则",range:"应用范围",type:"条件类型",options:"高级设置",operator:"数据",removeRule:"删除规则",done:"确认",formulaPlaceholder:"请输入值或公式",formulaAnd:"与",invalid:"数据无效时",showWarning:"显示警告",rejectInput:"拒绝输入",messageInfo:"文字提示",showInfo:"显示所选单元格的提示文字"},operators:{between:"介于",greaterThan:"大于",greaterThanOrEqual:"大于或等于",lessThan:"小于",lessThanOrEqual:"小于或等于",equal:"等于",notEqual:"不等于",notBetween:"未介于"},ruleName:{between:"介于 {FORMULA1} 和 {FORMULA2} 之间",greaterThan:"大于 {FORMULA1}",greaterThanOrEqual:"大于或等于 {FORMULA1}",lessThan:"小于 {FORMULA1}",lessThanOrEqual:"小于或等于 {FORMULA1}",equal:"等于 {FORMULA1}",notEqual:"不等于 {FORMULA1}",notBetween:"在 {FORMULA1} 和 {FORMULA2} 范围之外"},errorMsg:{between:"值必须介于 {FORMULA1} 和 {FORMULA2} 之间",greaterThan:"值必须大于 {FORMULA1}",greaterThanOrEqual:"值必须大于或等于 {FORMULA1}",lessThan:"值必须小于 {FORMULA1}",lessThanOrEqual:"值必须小于或等于 {FORMULA1}",equal:"值必须等于 {FORMULA1}",notEqual:"值必须不等于 {FORMULA1}",notBetween:"值必须在 {FORMULA1} 和 {FORMULA2} 范围之外"},date:{title:"日期",operators:{between:"介于",greaterThan:"晚于",greaterThanOrEqual:"晚于或等于",lessThan:"早于",lessThanOrEqual:"早于或等于",equal:"等于",notEqual:"不等于",notBetween:"未介于"},ruleName:{between:"介于 {FORMULA1} 和 {FORMULA2} 之间",greaterThan:"晚于 {FORMULA1}",greaterThanOrEqual:"晚于或等于 {FORMULA1}",lessThan:"早于 {FORMULA1}",lessThanOrEqual:"早于或等于 {FORMULA1}",equal:"等于 {FORMULA1}",notEqual:"不等于 {FORMULA1}",notBetween:"在 {FORMULA1} 和 {FORMULA2} 范围之外"},errorMsg:{between:"日期必须介于 {FORMULA1} 和 {FORMULA2} 之间",greaterThan:"日期必须晚于 {FORMULA1}",greaterThanOrEqual:"日期必须晚于或等于 {FORMULA1}",lessThan:"日期必须早于 {FORMULA1}",lessThanOrEqual:"早于或等于 {FORMULA1}",equal:"日期必须等于 {FORMULA1}",notEqual:"日期必须不等于 {FORMULA1}",notBetween:"日期必须在 {FORMULA1} 和 {FORMULA2} 范围之外"}},list:{title:"下拉菜单",name:"值必须是列表中的值",error:"输入必须在指定的范围内",emptyError:"请输入一个值",add:"添加选项",dropdown:"单选",options:"选项来源",customOptions:"自定义",refOptions:"引用数据",formulaError:"列表源必须是划定分界后的数据列表,或是对单一行或一列的引用。"},listMultiple:{title:"下拉菜单-多选",dropdown:"多选"},textLength:{title:"文本长度",errorMsg:{between:"文本长度必须介于 {FORMULA1} 和 {FORMULA2} 之间",greaterThan:"文本长度必须大于 {FORMULA1}",greaterThanOrEqual:"文本长度必须大于或等于 {FORMULA1}",lessThan:"文本长度必须小于 {FORMULA1}",lessThanOrEqual:"文本长度必须小于或等于 {FORMULA1}",equal:"文本长度必须等于 {FORMULA1}",notEqual:"文本长度必须不等于 {FORMULA1}",notBetween:"文本长度必须在 {FORMULA1} 和 {FORMULA2} 范围之外"}},decimal:{title:"数字"},whole:{title:"整数"},checkbox:{title:"复选框",error:"此单元格的内容违反了验证规则",tips:"在单元格内使用自定义值",checked:"选中值",unchecked:"未选中值"},custom:{title:"自定义公式",error:"此单元格的内容违反了验证规则",validFail:"请输入合法的公式"},alert:{title:"提示",ok:"确定"},error:{title:"无效:"},renderMode:{arrow:"箭头",chip:"条状标签",text:"纯文本",label:"显示样式"}}},sr={dataValidation:{title:"Проверка данных",validFail:{common:"Пожалуйста, введите значение или формулу",number:"Пожалуйста, введите число или формулу",formula:"Пожалуйста, введите формулу",integer:"Пожалуйста, введите целое число или формулу",date:"Пожалуйста, введите дату или формулу",list:"Пожалуйста, введите параметры",listInvalid:"Источник списка должен быть разделенным списком или ссылкой на одну строку или столбец",checkboxEqual:"Для выбранных и не выбранных ячеек введите разные значения"},panel:{title:"Управление проверкой данных",addTitle:"Создать новую проверку данных",removeAll:"Удалить все",add:"Создать проверку данных",range:"Диапазоны",type:"Тип",options:"Дополнительные параметры",operator:"Оператор",removeRule:"Удалить",done:"Готово",formulaPlaceholder:"Пожалуйста, введите значение или формулу",formulaAnd:"и",invalid:"Недопустимо",showWarning:"Показать предупреждение",rejectInput:"Отклонить ввод",messageInfo:"Сообщение помощи",showInfo:"Показать текст помощи для выбранной ячейки"},operators:{between:"между",greaterThan:"больше чем",greaterThanOrEqual:"больше или равно",lessThan:"меньше чем",lessThanOrEqual:"меньше или равно",equal:"равно",notEqual:"не равно",notBetween:"не между"},ruleName:{between:"между {FORMULA1} и {FORMULA2}",greaterThan:"больше чем {FORMULA1}",greaterThanOrEqual:"больше или равно {FORMULA1}",lessThan:"меньше чем {FORMULA1}",lessThanOrEqual:"меньше или равно {FORMULA1}",equal:"равно {FORMULA1}",notEqual:"не равно {FORMULA1}",notBetween:"не между {FORMULA1} и {FORMULA2}"},errorMsg:{between:"Значение должно быть между {FORMULA1} и {FORMULA2}",greaterThan:"Значение должно быть больше {FORMULA1}",greaterThanOrEqual:"Значение должно быть больше или равно {FORMULA1}",lessThan:"Значение должно быть меньше {FORMULA1}",lessThanOrEqual:"Значение должно быть меньше или равно {FORMULA1}",equal:"Значение должно быть равно {FORMULA1}",notEqual:"Значение должно быть не равно {FORMULA1}",notBetween:"Значение должно быть не между {FORMULA1} и {FORMULA2}"},date:{title:"Дата",operators:{between:"между",greaterThan:"после",greaterThanOrEqual:"в или после",lessThan:"до",lessThanOrEqual:"в или до",equal:"равно",notEqual:"не равно",notBetween:"не между"},ruleName:{between:"между {FORMULA1} и {FORMULA2}",greaterThan:"после {FORMULA1}",greaterThanOrEqual:"в или после {FORMULA1}",lessThan:"до {FORMULA1}",lessThanOrEqual:"в или до {FORMULA1}",equal:"равно {FORMULA1}",notEqual:"не равно {FORMULA1}",notBetween:"не между {FORMULA1}"},errorMsg:{between:"Значение должно быть между {FORMULA1} и {FORMULA2}",greaterThan:"Значение должно быть после {FORMULA1}",greaterThanOrEqual:"Значение должно быть в или после {FORMULA1}",lessThan:"Значение должно быть до {FORMULA1}",lessThanOrEqual:"Значение должно быть в или до {FORMULA1}",equal:"Значение должно быть {FORMULA1}",notEqual:"Значение должно быть не {FORMULA1}",notBetween:"Значение должно быть не между {FORMULA1}"}},list:{title:"Выпадающий список",name:"Значение содержит одно из диапазона",error:"Ввод должен соответствовать указанному диапазону",emptyError:"Пожалуйста, введите значение",add:"Добавить",dropdown:"Выбрать",options:"Параметры",customOptions:"Пользовательские",refOptions:"Из диапазона",formulaError:"Источник списка должен быть разделенным списком данных или ссылкой на одну строку или столбец."},listMultiple:{title:"Выпадающий список - Множественный",dropdown:"Множественный выбор"},textLength:{title:"Длина текста",errorMsg:{between:"Длина текста должна быть между {FORMULA1} и {FORMULA2}",greaterThan:"Длина текста должна быть больше {FORMULA1}",greaterThanOrEqual:"Длина текста должна быть больше или равна {FORMULA1}",lessThan:"Длина текста должна быть меньше {FORMULA1}",lessThanOrEqual:"Длина текста должна быть меньше или равна {FORMULA1}",equal:"Длина текста должна быть равна {FORMULA1}",notEqual:"Длина текста должна быть не равна {FORMULA1}",notBetween:"Длина текста должна быть не между {FORMULA1}"}},decimal:{title:"Число"},whole:{title:"Целое число"},checkbox:{title:"Флажок",error:"Содержимое этой ячейки нарушает правило проверки",tips:"Используйте пользовательские значения в ячейках",checked:"Выбранное значение",unchecked:"Не выбранное значение"},custom:{title:"Пользовательская формула",error:"Содержимое этой ячейки нарушает правило проверки",validFail:"Пожалуйста, введите допустимую формулу"},alert:{title:"Ошибка",ok:"ОК"},error:{title:"Недопустимо:"},renderMode:{arrow:"Стрелка",chip:"Чип",text:"Простой текст",label:"Стиль отображения"}}};var ur=Object.defineProperty,dr=Object.getOwnPropertyDescriptor,cr=(i,r,e,t)=>{for(var a=t>1?void 0:t?dr(r,e):r,n=i.length-1,o;n>=0;n--)(o=i[n])&&(a=(t?o(r,e,a):o(a))||a);return t&&a&&ur(r,e,a),a},ea=(i,r)=>(e,t)=>r(e,t,i);g.DataValidationAutoFillController=class extends l.Disposable{constructor(r,e){super(),this._autoFillService=r,this._dataValidationModel=e,this._initAutoFill()}_initAutoFill(){const r=()=>({redos:[],undos:[]}),e=a=>{const{source:n,target:o,unitId:s,subUnitId:u}=a,d=this._dataValidationModel.ensureManager(s,u),c=d.getRuleObjectMatrix().clone(),h=j.virtualizeDiscreteRanges([n,o]),[p,m]=h.ranges,{mapFunc:_}=h,v={row:p.startRow,col:p.startColumn};j.getAutoFillRepeatRange(p,m).forEach(C=>{const y=C.repeatStartCell,L=C.relativeRange,b={startRow:v.row,startColumn:v.col,endColumn:v.col,endRow:v.row},q={startRow:y.row,startColumn:y.col,endColumn:y.col,endRow:y.row};l.Range.foreach(L,(x,B)=>{const U=l.Rectangle.getPositionRange({startRow:x,startColumn:B,endColumn:B,endRow:x},b),{row:G,col:H}=_(U.startRow,U.startColumn),z=d.getRuleIdByLocation(G,H);if(z){const $=l.Rectangle.getPositionRange({startRow:x,startColumn:B,endColumn:B,endRow:x},q),{row:Z,col:ne}=_($.startRow,$.startColumn);c.setValue(Z,ne,z)}})});const D=c.diff(d.getDataValidations()),{redoMutations:I,undoMutations:O}=De(s,u,D);return{undos:O,redos:I}},t={id:je,onFillData:(a,n,o)=>o===j.APPLY_TYPE.COPY||o===j.APPLY_TYPE.ONLY_FORMAT||o===j.APPLY_TYPE.SERIES?e(a):r()};this.disposeWithMe(this._autoFillService.addHook(t))}},g.DataValidationAutoFillController=cr([l.OnLifecycle(l.LifecycleStages.Ready,g.DataValidationAutoFillController),ea(0,j.IAutoFillService),ea(1,V.Inject(M.DataValidationModel))],g.DataValidationAutoFillController);var mr=Object.defineProperty,hr=Object.getOwnPropertyDescriptor,pr=(i,r,e,t)=>{for(var a=t>1?void 0:t?hr(r,e):r,n=i.length-1,o;n>=0;n--)(o=i[n])&&(a=(t?o(r,e,a):o(a))||a);return t&&a&&mr(r,e,a),a},ht=(i,r)=>(e,t)=>r(e,t,i);g.DataValidationCopyPasteController=class extends l.Disposable{constructor(e,t,a){super();S(this,"_copyInfo");this._sheetClipboardService=e,this._dataValidationModel=t,this._injector=a,this._initCopyPaste()}_initCopyPaste(){this._sheetClipboardService.addClipboardHook({id:je,onBeforeCopy:(e,t,a)=>this._collect(e,t,a),onPasteCells:(e,t,a,n)=>{const{copyType:o=j.COPY_TYPE.COPY,pasteType:s}=n,{range:u}=e||{},{range:d,unitId:c,subUnitId:h}=t;return this._generateMutations(d,{copyType:o,pasteType:s,copyRange:u,unitId:c,subUnitId:h})}})}_collect(e,t,a){const n=new l.ObjectMatrix;this._copyInfo={unitId:e,subUnitId:t,matrix:n};const o=this._dataValidationModel.ensureManager(e,t),s={get:this._injector.get.bind(this._injector)},u=j.rangeToDiscreteRange(a,s,e,t);if(!u)return;const{rows:d,cols:c}=u;d.forEach((h,p)=>{c.forEach((m,_)=>{const v=o.getRuleIdByLocation(h,m);n.setValue(p,_,v!=null?v:"")})})}_generateMutations(e,t){if(!this._copyInfo)return{redos:[],undos:[]};if(t.copyType===j.COPY_TYPE.CUT)return this._copyInfo=null,{redos:[],undos:[]};if(!this._copyInfo||!this._copyInfo.matrix.getSizeOf()||!t.copyRange)return{redos:[],undos:[]};if([j.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_COL_WIDTH,j.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_VALUE,j.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMAT,Le.SPECIAL_PASTE_FORMULA].includes(t.pasteType))return{redos:[],undos:[]};const{unitId:a,subUnitId:n}=this._copyInfo;if(t.unitId!==a||n!==t.subUnitId){const o=this._dataValidationModel.ensureManager(a,n),s=this._dataValidationModel.ensureManager(t.unitId,t.subUnitId),u=s.getRuleObjectMatrix().clone(),{ranges:[d,c],mapFunc:h}=j.virtualizeDiscreteRanges([t.copyRange,e]),p=j.getRepeatRange(d,c,!0),m=new Map;p.forEach(({startRange:R})=>{var D;(D=this._copyInfo)==null||D.matrix.forValue((I,O,C)=>{const y=l.Rectangle.getPositionRange({startRow:I,endRow:I,startColumn:O,endColumn:O},R),L=`${n}-${C}`,b=o.getRuleById(C);!s.getRuleById(L)&&b&&m.set(L,{...b,uid:L});const{row:q,col:x}=h(y.startRow,y.startColumn);u.setValue(q,x,L)})});const{redoMutations:_,undoMutations:v}=De(t.unitId,t.subUnitId,u.diffWithAddition(s.getDataValidations(),m.values()));return{redos:_,undos:v}}else{const o=this._dataValidationModel.ensureManager(a,n),s=o.getRuleObjectMatrix().clone(),{ranges:[u,d],mapFunc:c}=j.virtualizeDiscreteRanges([t.copyRange,e]);j.getRepeatRange(u,d,!0).forEach(({startRange:_})=>{var v;(v=this._copyInfo)==null||v.matrix.forValue((R,D,I)=>{const O=l.Rectangle.getPositionRange({startRow:R,endRow:R,startColumn:D,endColumn:D},_),{row:C,col:y}=c(O.startRow,O.startColumn);s.setValue(C,y,I)})});const{redoMutations:p,undoMutations:m}=De(a,n,s.diff(o.getDataValidations()));return{redos:p,undos:m}}}},g.DataValidationCopyPasteController=pr([l.OnLifecycle(l.LifecycleStages.Ready,g.DataValidationCopyPasteController),ht(0,j.ISheetClipboardService),ht(1,V.Inject(M.DataValidationModel)),ht(2,V.Inject(V.Injector))],g.DataValidationCopyPasteController);class pt{constructor(r){S(this,"value");this.value=r}addRule(r){const e=r.uid;r.ranges.forEach(t=>{l.Range.foreach(t,(a,n)=>{this.value.setValue(a,n,e)})})}removeRange(r){r.forEach(e=>{l.Range.foreach(e,(t,a)=>{this.value.realDeleteValue(t,a)})})}removeRule(r){r.ranges.forEach(e=>{l.Range.foreach(e,(t,a)=>{this.value.setValue(t,a,"")})})}updateRange(r,e,t){const a=`${r}$`;e.forEach(n=>{l.Range.foreach(n,(o,s)=>{this.value.getValue(o,s)===r&&this.value.setValue(o,s,a)})}),t.forEach(n=>{l.Range.foreach(n,(o,s)=>{this.value.setValue(o,s,r)})}),e.forEach(n=>{l.Range.foreach(n,(o,s)=>{this.value.getValue(o,s)===a&&this.value.realDeleteValue(o,s)})})}diff(r){const e=[];let t=0;return r.forEach((a,n)=>{const o=l.queryObjectMatrix(this.value,u=>u===a.uid),s=a.ranges;(o.length!==s.length||o.some((u,d)=>!l.Rectangle.equals(u,s[d])))&&e.push({type:"update",ruleId:a.uid,oldRanges:s,newRanges:o}),o.length===0&&(e.push({type:"delete",rule:a,index:n-t}),t++)}),e}diffWithAddition(r,e){const t=[];let a=0;return r.forEach((n,o)=>{const s=l.queryObjectMatrix(this.value,d=>d===n.uid),u=n.ranges;(s.length!==u.length||s.some((d,c)=>!l.Rectangle.equals(d,u[c])))&&t.push({type:"update",ruleId:n.uid,oldRanges:u,newRanges:s}),s.length===0&&(t.push({type:"delete",rule:n,index:o-a}),a++)}),Array.from(e).forEach(n=>{const o=l.queryObjectMatrix(this.value,s=>s===n.uid);t.push({type:"add",rule:{...n,ranges:o}})}),t}clone(){return new pt(new l.ObjectMatrix(this.value.clone()))}getValue(r,e){return this.value.getValue(r,e)}setValue(r,e,t){return this.value.setValue(r,e,t)}}class fr extends M.DataValidationManager{constructor(e,t,a,n){super(e,t,a);S(this,"_ruleMatrix");S(this,"_dataValidatorRegistryService");S(this,"_dataValidationCacheService");S(this,"_dataValidationFormulaService");S(this,"_dataValidationCustomFormulaService");S(this,"_cache");S(this,"_dataValidationRefRangeController");this._injector=n,this._dataValidatorRegistryService=this._injector.get(M.DataValidatorRegistryService),this._dataValidationCacheService=this._injector.get(Ce),this._dataValidationFormulaService=this._injector.get(g.DataValidationFormulaService),this._dataValidationCustomFormulaService=this._injector.get(g.DataValidationCustomFormulaService),this._dataValidationRefRangeController=this._injector.get(g.DataValidationRefRangeController),this._cache=this._dataValidationCacheService.ensureCache(e,t);const o=new l.ObjectMatrix;a==null||a.forEach(s=>{const u=s.uid;s.ranges.forEach(d=>{l.Range.foreach(d,(c,h)=>{o.setValue(c,h,u)})})}),a==null||a.forEach(s=>{this._dataValidationRefRangeController.register(e,t,s)}),this._ruleMatrix=new pt(o)}_addRuleSideEffect(e){var n;const{unitId:t,subUnitId:a}=this;(e.type===l.DataValidationType.LIST||e.type===l.DataValidationType.LIST_MULTIPLE)&&ie.isReferenceString((n=e.formula1)!=null?n:"")&&(e.formula1=`=${e.formula1}`),this._ruleMatrix.addRule(e),this._dataValidationCacheService.addRule(t,a,e),this._dataValidationFormulaService.addRule(t,a,e.uid,e.formula1,e.formula2),this._dataValidationCustomFormulaService.addRule(t,a,e)}addRule(e,t){(Array.isArray(e)?e:[e]).forEach(n=>{this._addRuleSideEffect(n)}),super.addRule(e,t)}updateRule(e,t){const a=this.getRuleById(e);if(!a)throw new Error(`Rule not found! id: ${e}`);return t.type===M.UpdateRuleType.RANGE?(this._ruleMatrix.updateRange(e,a.ranges,t.payload),this._dataValidationCacheService.updateRuleRanges(this.unitId,this.subUnitId,e,t.payload,a.ranges),this._dataValidationCustomFormulaService.updateRuleRanges(this.unitId,this.subUnitId,e,a.ranges,t.payload)):t.type===M.UpdateRuleType.SETTING&&(this._dataValidationCacheService.markRangeDirty(this.unitId,this.subUnitId,a.ranges),this._dataValidationFormulaService.updateRuleFormulaText(this.unitId,this.subUnitId,e,t.payload.formula1,t.payload.formula2),this._dataValidationCustomFormulaService.updateRuleFormula(this.unitId,this.subUnitId,e,a.ranges,t.payload.formula1)),super.updateRule(e,t)}removeRule(e){const t=this.getRuleById(e);t&&(this._ruleMatrix.removeRule(t),this._dataValidationCacheService.removeRule(this.unitId,this.subUnitId,t)),super.removeRule(e)}getRuleIdByLocation(e,t){return this._ruleMatrix.getValue(e,t)}getRuleByLocation(e,t){const a=this.getRuleIdByLocation(e,t);if(a)return this.getRuleById(a)}validator(e,t,a,n){const{col:o,row:s,unitId:u,subUnitId:d}=a,c=t.uid,h=this._dataValidatorRegistryService.getValidatorItem(t.type);if(h){const p=this._cache.getValue(s,o);return!p||p.value!==e?(this._cache.setValue(s,o,{value:e,status:l.DataValidationStatus.VALIDATING,ruleId:c}),h.validator({value:e,unitId:u,subUnitId:d,row:s,column:o},t).then(m=>{const _=m?l.DataValidationStatus.VALID:l.DataValidationStatus.INVALID;this._cache.setValue(s,o,{value:e,status:_,ruleId:c}),n(_)}),l.DataValidationStatus.VALIDATING):p.status}else return l.DataValidationStatus.VALID}getRuleErrorMsg(e){const t=this.getRuleById(e);if(!t)return"";const a=this._dataValidatorRegistryService.getValidatorItem(t.type);return t.error?t.error:a?a.getRuleFinalError(t):""}getRuleObjectMatrix(){return this._ruleMatrix}}var vr=Object.defineProperty,gr=Object.getOwnPropertyDescriptor,_r=(i,r,e,t)=>{for(var a=t>1?void 0:t?gr(r,e):r,n=i.length-1,o;n>=0;n--)(o=i[n])&&(a=(t?o(r,e,a):o(a))||a);return t&&a&&vr(r,e,a),a},Ye=(i,r)=>(e,t)=>r(e,t,i);let Ge=class extends l.Disposable{constructor(i,r,e,t){super(),this._resourceManagerService=i,this._univerInstanceService=r,this._dataValidationModel=e,this._injector=t,this._initDataValidationDataSource()}_createSheetDataValidationManager(i,r){return new fr(i,r,[],this._injector)}_initDataValidationDataSource(){this._dataValidationModel.setManagerCreator(this._createSheetDataValidationManager.bind(this))}};Ge=_r([l.OnLifecycle(l.LifecycleStages.Starting,Ge),Ye(0,l.IResourceManagerService),Ye(1,l.IUniverInstanceService),Ye(2,V.Inject(M.DataValidationModel)),Ye(3,V.Inject(V.Injector))],Ge);var Sr=Object.defineProperty,Rr=Object.getOwnPropertyDescriptor,Mr=(i,r,e,t)=>{for(var a=t>1?void 0:t?Rr(r,e):r,n=i.length-1,o;n>=0;n--)(o=i[n])&&(a=(t?o(r,e,a):o(a))||a);return t&&a&&Sr(r,e,a),a},ft=(i,r)=>(e,t)=>r(e,t,i);g.UniverSheetsDataValidationPlugin=(ze=class extends l.Plugin{constructor(r,e,t,a){super(),this._injector=e,this._commandService=t,this._localeService=a}onStarting(r){[[ue],[g.SheetDataValidationService],[Ce],[g.DataValidationFormulaService],[g.DataValidationCustomFormulaService],[Se],[Ge],[g.DataValidationController],[g.DataValidationRenderController],[g.DataValidationAlertController],[g.DataValidationRefRangeController],[g.DataValidationAutoFillController],[g.DataValidationCopyPasteController],[g.DataValidationRejectInputController]].forEach(e=>{r.add(e)}),[Ne,Ke,Qe,be,Ot,Dt,Fe,fa].forEach(e=>{this._commandService.registerCommand(e)}),this._localeService.load({zhCN:Jt,enUS:Zt})}},S(ze,"pluginName",je),S(ze,"type",l.UniverInstanceType.UNIVER_SHEET),ze),g.UniverSheetsDataValidationPlugin=Mr([ft(1,V.Inject(V.Injector)),ft(2,l.ICommandService),ft(3,V.Inject(l.LocaleService))],g.UniverSheetsDataValidationPlugin),Object.defineProperty(g,"ICommandService",{enumerable:!0,get:()=>l.ICommandService}),Object.defineProperty(g,"LocaleService",{enumerable:!0,get:()=>l.LocaleService}),Object.defineProperty(g,"Plugin",{enumerable:!0,get:()=>l.Plugin}),g.AddSheetDataValidationAndOpenCommand=Ke,g.AddSheetDataValidationCommand=Ne,g.DATA_VALIDATION_PLUGIN_NAME=je,g.DataValidationCacheService=Ce,g.HideDataValidationDropdown=Ot,g.ShowDataValidationDropdown=be,g.UpdateSheetDataValidationRangeCommand=Qe,g.enUS=Zt,g.ruRU=sr,g.zhCN=Jt,Object.defineProperty(g,Symbol.toStringTag,{value:"Module"})});
9
+ */var oa=E,ia=Symbol.for("react.element"),sa=Symbol.for("react.fragment"),la=Object.prototype.hasOwnProperty,da=oa.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,ua={key:!0,ref:!0,__self:!0,__source:!0};function It(o,r,e){var t,a={},n=null,i=null;e!==void 0&&(n=""+e),r.key!==void 0&&(n=""+r.key),r.ref!==void 0&&(i=r.ref);for(t in r)la.call(r,t)&&!ua.hasOwnProperty(t)&&(a[t]=r[t]);if(o&&o.defaultProps)for(t in r=o.defaultProps,r)a[t]===void 0&&(a[t]=r[t]);return{$$typeof:ia,type:o,key:n,ref:i,props:a,_owner:da.current}}Ne.Fragment=sa,Ne.jsx=It,Ne.jsxs=It,Rt.exports=Ne;var v=Rt.exports;function ca(){const o=N.useDependency(De),r=W.useObservable(o.activeDropdown$,o.activeDropdown),e=N.useDependency(W.ComponentManager);if(!r)return null;const{location:t,componentKey:a}=r,n=e.get(a),i=`${t.unitId}-${t.subUnitId}-${t.row}-${t.col}`;if(!n)return null;const l=()=>{o.hideDropdown()};return v.jsx(n,{location:t,hideFn:l},i)}const Mt="sheet.ui.dropdown";var ma=Object.defineProperty,ha=Object.getOwnPropertyDescriptor,fa=(o,r,e,t)=>{for(var a=t>1?void 0:t?ha(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&ma(r,e,a),a},_e=(o,r)=>(e,t)=>r(e,t,o);let De=class extends s.Disposable{constructor(r,e,t,a,n,i,l){super();_(this,"_activeDropdown");_(this,"_activeDropdown$",new ue.Subject);_(this,"_currentPopup",null);_(this,"activeDropdown$",this._activeDropdown$.asObservable());_(this,"_zenVisible",!1);this._canvasPopupManagerService=r,this._univerInstanceService=e,this._sheetSkeletonManagerService=t,this._dataValidatorRegistryService=a,this._zenZoneService=n,this._renderManagerService=i,this._dataValidationModel=l,this._init()}get activeDropdown(){return this._activeDropdown}_init(){this.disposeWithMe(this._zenZoneService.visible$.subscribe(r=>{this._zenVisible=r,r&&this.hideDropdown()}))}showDropdown(r){const{location:e}=r,{row:t,col:a}=e;if(this._currentPopup&&this._currentPopup.dispose(),this._zenVisible)return;this._activeDropdown=r,this._activeDropdown$.next(this._activeDropdown);const n=this._renderManagerService.getRenderById(s.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),i=this._canvasPopupManagerService.attachPopupToCell(t,a,{componentKey:Mt,onClickOutside:()=>{this.hideDropdown()},offset:[0,3],excludeOutside:[n==null?void 0:n.engine.getCanvasElement()].filter(Boolean)});if(!i)throw new Error("[DataValidationDropdownManagerService]: cannot show dropdown!");const l=new s.DisposableCollection;l.add(i),l.add({dispose:()=>{var d,u;(u=(d=this._activeDropdown)==null?void 0:d.onHide)==null||u.call(d)}}),this._currentPopup=l}hideDropdown(){this._activeDropdown&&(this._currentPopup&&this._currentPopup.dispose(),this._currentPopup=null,this._activeDropdown=null,this._activeDropdown$.next(null))}showDataValidationDropdown(r,e,t,a,n){const i=this._univerInstanceService.getUniverSheetInstance(r);if(!i)return;const l=i.getSheetBySheetId(e);if(!l)return;const u=this._dataValidationModel.ensureManager(r,e).getRuleByLocation(t,a);if(!this._sheetSkeletonManagerService.getOrCreateSkeleton({unitId:r,sheetId:e})||!u)return;const m=this._dataValidatorRegistryService.getValidatorItem(u.type);if(!m||!m.dropdown){this.hideDropdown();return}this.showDropdown({location:{workbook:i,worksheet:l,row:t,col:a,unitId:r,subUnitId:e},componentKey:m.dropdown,onHide:n})}};De=fa([_e(0,I.Inject(j.SheetCanvasPopManagerService)),_e(1,s.IUniverInstanceService),_e(2,I.Inject(j.SheetSkeletonManagerService)),_e(3,I.Inject(R.DataValidatorRegistryService)),_e(4,W.IZenZoneService),_e(5,Z.IRenderManagerService),_e(6,I.Inject(R.DataValidationModel))],De);var pa=Object.defineProperty,va=Object.getOwnPropertyDescriptor,ga=(o,r,e,t)=>{for(var a=t>1?void 0:t?va(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&pa(r,e,a),a},yt=(o,r)=>(e,t)=>r(e,t,o);let ce=class extends s.Disposable{constructor(r,e){super();_(this,"_open$",new ue.BehaviorSubject(!1));_(this,"open$",this._open$.pipe(ue.distinctUntilChanged()));_(this,"_activeRule");_(this,"_activeRule$",new ue.BehaviorSubject(void 0));_(this,"activeRule$",this._activeRule$.asObservable());_(this,"_closeDisposable",null);this._univerInstanceService=r,this._sidebarService=e,this.disposeWithMe(this._univerInstanceService.getCurrentTypeOfUnit$(s.UniverInstanceType.UNIVER_SHEET).pipe(ue.filter(t=>!t)).subscribe(()=>{this.close()}))}get activeRule(){return this._activeRule}get isOpen(){return this._open$.getValue()}dispose(){var r;super.dispose(),this._open$.next(!1),this._open$.complete(),(r=this._closeDisposable)==null||r.dispose()}open(){this._open$.next(!0)}close(){var r;this._open$.next(!1),(r=this._closeDisposable)==null||r.dispose()}setCloseDisposable(r){this._closeDisposable=s.toDisposable(()=>{r.dispose(),this._closeDisposable=null})}setActiveRule(r){this._activeRule=r,this._activeRule$.next(r)}};ce=ga([yt(0,s.IUniverInstanceService),yt(1,W.ISidebarService)],ce);const wt="DataValidationPanel",Ee={id:"data-validation.operation.open-validation-panel",type:s.CommandType.OPERATION,handler(o,r){if(!r)return!1;const{ruleId:e,isAdd:t}=r,a=o.get(ce),n=o.get(R.DataValidationModel),i=o.get(s.IUniverInstanceService),l=o.get(W.ISidebarService),d=q.getSheetCommandTarget(i);if(!d)return!1;const{unitId:u,subUnitId:c}=d,m=e?n.getRuleById(u,c,e):void 0;a.open(),a.setActiveRule(m&&{unitId:u,subUnitId:c,rule:m});const f=l.open({header:{title:t?"dataValidation.panel.addTitle":"dataValidation.panel.title"},children:{label:wt},width:312,onClose:()=>a.close()});return a.setCloseDisposable(f),!0}},Ot={id:"data-validation.operation.close-validation-panel",type:s.CommandType.OPERATION,handler(o){return o.get(ce).close(),!0}},Sa={id:"data-validation.operation.toggle-validation-panel",type:s.CommandType.OPERATION,handler(o){const r=o.get(s.ICommandService),e=o.get(ce);return e.open(),e.isOpen?r.executeCommand(Ot.id):r.executeCommand(Ee.id),!0}},Ae={type:s.CommandType.OPERATION,id:"sheet.operation.show-data-validation-dropdown",handler(o,r){if(!r)return!1;const e=o.get(De),{unitId:t,subUnitId:a,row:n,column:i}=r,l=e.activeDropdown,d=l==null?void 0:l.location;return d&&d.unitId===t&&d.subUnitId===a&&d.row===n&&d.col===i||e.showDataValidationDropdown(t,a,n,i),!0}},Et={type:s.CommandType.OPERATION,id:"sheet.operation.hide-data-validation-dropdown",handler(o,r){return r?(o.get(De).hideDropdown(),!0):!1}};function Ie(o,r,e){const t=[],a=[];return e.forEach(n=>{switch(n.type){case"delete":t.push({id:R.RemoveDataValidationMutation.id,params:{unitId:o,subUnitId:r,ruleId:n.rule.uid}}),a.unshift({id:R.AddDataValidationMutation.id,params:{unitId:o,subUnitId:r,rule:n.rule,index:n.index}});break;case"update":{t.push({id:R.UpdateDataValidationMutation.id,params:{unitId:o,subUnitId:r,ruleId:n.ruleId,payload:{type:R.UpdateRuleType.RANGE,payload:n.newRanges}}}),a.unshift({id:R.UpdateDataValidationMutation.id,params:{unitId:o,subUnitId:r,ruleId:n.ruleId,payload:{type:R.UpdateRuleType.RANGE,payload:n.oldRanges}}});break}case"add":{t.push({id:R.AddDataValidationMutation.id,params:{unitId:o,subUnitId:r,rule:n.rule}}),a.unshift({id:R.RemoveDataValidationMutation.id,params:{unitId:o,subUnitId:r,ruleId:n.rule.uid}});break}}}),{redoMutations:t,undoMutations:a}}const Pe={type:s.CommandType.COMMAND,id:"sheet.command.updateDataValidationRuleRange",async handler(o,r){if(!r)return!1;const{unitId:e,subUnitId:t,ranges:a,ruleId:n}=r,i=o.get(R.DataValidationModel),l=o.get(s.ICommandService),d=o.get(s.IUndoRedoService),u=i.ensureManager(e,t),c=u.getRuleById(n);if(!c)return!1;const m=c.ranges,f=u.getRuleObjectMatrix().clone();f.updateRange(n,m,a);const h=f.diff(u.getDataValidations()),{redoMutations:p,undoMutations:S}=Ie(e,t,h);return d.pushUndoRedo({undoMutations:S,redoMutations:p,unitID:e}),await s.sequenceExecuteAsync(p,l),!0}},je={type:s.CommandType.COMMAND,id:"sheet.command.addDataValidation",async handler(o,r){if(!r)return!1;const{unitId:e,subUnitId:t,rule:a}=r,n=o.get(R.DataValidationModel),i=o.get(s.ICommandService),l=o.get(s.IUndoRedoService),d=n.ensureManager(e,t),u=d.getRuleObjectMatrix().clone();u.addRule(a);const c=u.diff(d.getDataValidations()),m={unitId:e,subUnitId:t,rule:a},{redoMutations:f,undoMutations:h}=Ie(e,t,c);return f.push({id:R.AddDataValidationMutation.id,params:m}),h.unshift({id:R.RemoveDataValidationMutation.id,params:{unitId:e,subUnitId:t,ruleId:a.uid}}),l.pushUndoRedo({unitID:e,redoMutations:f,undoMutations:h}),await s.sequenceExecuteAsync(f,i),!0}},et={type:s.CommandType.COMMAND,id:"data-validation.command.addRuleAndOpen",async handler(o){const r=o.get(s.IUniverInstanceService),e=q.getSheetCommandTarget(r);if(!e)return!1;const{workbook:t,worksheet:a}=e,n=R.createDefaultNewRule(o),i=o.get(s.ICommandService),l=t.getUnitId(),d=a.getSheetId(),u={rule:n,unitId:l,subUnitId:d};return await i.executeCommand(je.id,u)?(i.executeCommand(Ee.id,{ruleId:n.uid,isAdd:!0}),!0):!1}};var se=function(){return se=Object.assign||function(o){for(var r,e=1,t=arguments.length;e<t;e++){r=arguments[e];for(var a in r)Object.prototype.hasOwnProperty.call(r,a)&&(o[a]=r[a])}return o},se.apply(this,arguments)},_a=function(o,r){var e={};for(var t in o)Object.prototype.hasOwnProperty.call(o,t)&&r.indexOf(t)<0&&(e[t]=o[t]);if(o!=null&&typeof Object.getOwnPropertySymbols=="function")for(var a=0,t=Object.getOwnPropertySymbols(o);a<t.length;a++)r.indexOf(t[a])<0&&Object.prototype.propertyIsEnumerable.call(o,t[a])&&(e[t[a]]=o[t[a]]);return e},ve=E.forwardRef(function(o,r){var e=o.icon,t=o.id,a=o.className,n=o.extend,i=_a(o,["icon","id","className","extend"]),l="univerjs-icon univerjs-icon-".concat(t," ").concat(a||"").trim(),d=E.useRef("_".concat(Ca()));return Tt(e,"".concat(t),{defIds:e.defIds,idSuffix:d.current},se({ref:r,className:l},i),n)});function Tt(o,r,e,t,a){return E.createElement(o.tag,se(se({key:r},Da(o,e,a)),t),(Va(o,e).children||[]).map(function(n,i){return Tt(n,"".concat(r,"-").concat(o.tag,"-").concat(i),e,void 0,a)}))}function Da(o,r,e){var t=se({},o.attrs);e!=null&&e.colorChannel1&&t.fill==="colorChannel1"&&(t.fill=e.colorChannel1);var a=r.defIds;return!a||a.length===0||(o.tag==="use"&&t["xlink:href"]&&(t["xlink:href"]=t["xlink:href"]+r.idSuffix),Object.entries(t).forEach(function(n){var i=n[0],l=n[1];typeof l=="string"&&(t[i]=l.replace(/url\(#(.*)\)/,"url(#$1".concat(r.idSuffix,")")))})),t}function Va(o,r){var e,t=r.defIds;return!t||t.length===0?o:o.tag==="defs"&&(!((e=o.children)===null||e===void 0)&&e.length)?se(se({},o),{children:o.children.map(function(a){return typeof a.attrs.id=="string"&&t&&t.indexOf(a.attrs.id)>-1?se(se({},a),{attrs:se(se({},a.attrs),{id:a.attrs.id+r.idSuffix})}):a})}):o}function Ca(){return Math.random().toString(36).substring(2,8)}ve.displayName="UniverIcon";var Ra={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"}}]},Ft=E.forwardRef(function(o,r){return E.createElement(ve,Object.assign({},o,{id:"check-mark-single",ref:r,icon:Ra}))});Ft.displayName="CheckMarkSingle";const Ia=Ft;var Ma={tag:"svg",attrs:{fill:"none",viewBox:"0 0 17 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M1.4917 3.07803C1.4917 2.19437 2.20804 1.47803 3.0917 1.47803H5.6917C6.57536 1.47803 7.2917 2.19437 7.2917 3.07803V5.67803C7.2917 6.56168 6.57535 7.27803 5.6917 7.27803H3.0917C2.20804 7.27803 1.4917 6.56168 1.4917 5.67803V3.07803ZM3.0917 2.67803C2.87078 2.67803 2.6917 2.85711 2.6917 3.07803V5.67803C2.6917 5.89894 2.87079 6.07803 3.0917 6.07803H5.6917C5.91261 6.07803 6.0917 5.89894 6.0917 5.67803V3.07803C6.0917 2.85711 5.91261 2.67803 5.6917 2.67803H3.0917Z",fillRule:"evenodd",clipRule:"evenodd"}},{tag:"path",attrs:{fill:"currentColor",d:"M14.6175 2.45279C14.8518 2.68711 14.8518 3.06701 14.6175 3.30132L11.6151 6.30365C11.3957 6.52307 11.0451 6.53897 10.8067 6.34031L8.80915 4.67566C8.55458 4.46352 8.52019 4.08518 8.73233 3.83062 8.94447 3.57605 9.32281 3.54166 9.57737 3.7538L11.154 5.06767 13.769 2.45278C14.0033 2.21847 14.3832 2.21848 14.6175 2.45279zM14.1175 9.19746C14.3518 9.43178 14.3518 9.81168 14.1175 10.046L12.5418 11.6217 14.1175 13.1975C14.3518 13.4318 14.3518 13.8117 14.1175 14.046 13.8832 14.2803 13.5033 14.2803 13.269 14.046L11.6933 12.4703 10.1175 14.046C9.88321 14.2803 9.50331 14.2803 9.269 14.046 9.03468 13.8117 9.03468 13.4318 9.269 13.1975L10.8447 11.6217 9.269 10.046C9.03468 9.81168 9.03468 9.43178 9.269 9.19746 9.50331 8.96315 9.88321 8.96315 10.1175 9.19746L11.6933 10.7732 13.269 9.19746C13.5033 8.96315 13.8832 8.96315 14.1175 9.19746z"}},{tag:"path",attrs:{fill:"currentColor",d:"M3.0917 8.72168C2.20804 8.72168 1.4917 9.43802 1.4917 10.3217V12.9217C1.4917 13.8053 2.20804 14.5217 3.0917 14.5217H5.6917C6.57535 14.5217 7.2917 13.8053 7.2917 12.9217V10.3217C7.2917 9.43802 6.57536 8.72168 5.6917 8.72168H3.0917ZM2.6917 10.3217C2.6917 10.1008 2.87078 9.92168 3.0917 9.92168H5.6917C5.91261 9.92168 6.0917 10.1008 6.0917 10.3217V12.9217C6.0917 13.1426 5.91261 13.3217 5.6917 13.3217H3.0917C2.87079 13.3217 2.6917 13.1426 2.6917 12.9217V10.3217Z",fillRule:"evenodd",clipRule:"evenodd"}}]},bt=E.forwardRef(function(o,r){return E.createElement(ve,Object.assign({},o,{id:"data-validation-single",ref:r,icon:Ma}))});bt.displayName="DataValidationSingle";var ya={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"}}]},Lt=E.forwardRef(function(o,r){return E.createElement(ve,Object.assign({},o,{id:"delete-single",ref:r,icon:ya}))});Lt.displayName="DeleteSingle";const Nt=Lt;var wa={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"}}]},At=E.forwardRef(function(o,r){return E.createElement(ve,Object.assign({},o,{id:"increase-single",ref:r,icon:wa}))});At.displayName="IncreaseSingle";const Oa=At;var Ea={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M11.3536 6.14645C11.5488 6.34171 11.5488 6.65829 11.3536 6.85355L8.35355 9.85355C8.15829 10.0488 7.84171 10.0488 7.64645 9.85355L4.64645 6.85355C4.45118 6.65829 4.45118 6.34171 4.64645 6.14645C4.84171 5.95118 5.15829 5.95118 5.35355 6.14645L8 8.79289L10.6464 6.14645C10.8417 5.95118 11.1583 5.95118 11.3536 6.14645Z",fillRule:"evenodd",clipRule:"evenodd"}}]},Pt=E.forwardRef(function(o,r){return E.createElement(ve,Object.assign({},o,{id:"more-down-single",ref:r,icon:Ea}))});Pt.displayName="MoreDownSingle";const Ta=Pt;var Fa={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M4.64645 9.85355C4.45118 9.65829 4.45118 9.34171 4.64645 9.14645L7.64645 6.14645C7.84171 5.95118 8.15829 5.95118 8.35355 6.14645L11.3536 9.14645C11.5488 9.34171 11.5488 9.65829 11.3536 9.85355C11.1583 10.0488 10.8417 10.0488 10.6464 9.85355L8 7.20711L5.35355 9.85355C5.15829 10.0488 4.84171 10.0488 4.64645 9.85355Z",fillRule:"evenodd",clipRule:"evenodd"}}]},jt=E.forwardRef(function(o,r){return E.createElement(ve,Object.assign({},o,{id:"more-up-single",ref:r,icon:Fa}))});jt.displayName="MoreUpSingle";const ba=jt;var La={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"mask",attrs:{id:"mask0_622_8",style:{maskType:"alpha"},width:16,height:16,x:0,y:0,maskUnits:"userSpaceOnUse"},children:[{tag:"path",attrs:{fill:"#D9D9D9",d:"M0 0H16V16H0z"}}]},{tag:"g",attrs:{fill:"currentColor",mask:"url(#mask0_622_8)"},children:[{tag:"path",attrs:{d:"M6 5C6.55228 5 7 4.55228 7 4 7 3.44772 6.55228 3 6 3 5.44772 3 5 3.44772 5 4 5 4.55228 5.44772 5 6 5zM6 9C6.55228 9 7 8.55229 7 8 7 7.44772 6.55228 7 6 7 5.44772 7 5 7.44772 5 8 5 8.55229 5.44772 9 6 9zM7 12C7 12.5523 6.55228 13 6 13 5.44772 13 5 12.5523 5 12 5 11.4477 5.44772 11 6 11 6.55228 11 7 11.4477 7 12zM10 5C10.5523 5 11 4.55228 11 4 11 3.44772 10.5523 3 10 3 9.44771 3 9 3.44772 9 4 9 4.55228 9.44771 5 10 5zM11 8C11 8.55229 10.5523 9 10 9 9.44771 9 9 8.55229 9 8 9 7.44772 9.44771 7 10 7 10.5523 7 11 7.44772 11 8zM10 13C10.5523 13 11 12.5523 11 12 11 11.4477 10.5523 11 10 11 9.44771 11 9 11.4477 9 12 9 12.5523 9.44771 13 10 13z"}}]}]},Ut=E.forwardRef(function(o,r){return E.createElement(ve,Object.assign({},o,{id:"sequence-single",ref:r,icon:La}))});Ut.displayName="SequenceSingle";const Na=Ut,tt={dataValidationOptionsButton:"univer-data-validation-options-button",dataValidationOptionsButtonIcon:"univer-data-validation-options-button-icon"};function Aa(o){var u;const r=N.useDependency(s.LocaleService),e=N.useDependency(W.ComponentManager),{value:t,onChange:a,extraComponent:n}=o,[i,l]=E.useState(!1),d=n?e.get(n):null;return v.jsxs(v.Fragment,{children:[v.jsxs("div",{className:tt.dataValidationOptionsButton,onClick:()=>l(!i),children:[r.t("dataValidation.panel.options"),i?v.jsx(ba,{className:tt.dataValidationOptionsButtonIcon}):v.jsx(Ta,{className:tt.dataValidationOptionsButtonIcon})]}),i&&v.jsxs(v.Fragment,{children:[d?v.jsx(d,{value:t,onChange:a}):null,v.jsx(O.FormLayout,{label:r.t("dataValidation.panel.invalid"),children:v.jsxs(O.RadioGroup,{value:`${(u=t.errorStyle)!=null?u:s.DataValidationErrorStyle.WARNING}`,onChange:c=>a({...t,errorStyle:+c}),children:[v.jsx(O.Radio,{value:`${s.DataValidationErrorStyle.WARNING}`,children:r.t("dataValidation.panel.showWarning")}),v.jsx(O.Radio,{value:`${s.DataValidationErrorStyle.STOP}`,children:r.t("dataValidation.panel.rejectInput")})]})}),v.jsx(O.FormLayout,{label:r.t("dataValidation.panel.messageInfo"),children:v.jsx(O.Checkbox,{checked:t.showInputMessage,onChange:()=>a({...t,showInputMessage:!t.showInputMessage}),children:r.t("dataValidation.panel.showInfo")})}),t.showInputMessage?v.jsx(O.FormLayout,{children:v.jsx(O.Input,{value:t.error,onChange:c=>a({...t,error:c})})}):null]})]})}const Me={dataValidationDetailFormItem:"univer-data-validation-detail-form-item",dataValidationDetailButtons:"univer-data-validation-detail-buttons",dataValidationDetailButton:"univer-data-validation-detail-button"},Pa=o=>s.debounce(async(r,e,t,a)=>{const n=await o.executeCommand(r,e,t);a==null||a(n)},275);function ja(){const[o,r]=E.useState(0),e=N.useDependency(ce),t=W.useObservable(e.activeRule$,e.activeRule),{unitId:a,subUnitId:n,rule:i}=t||{},l=i.uid,d=N.useDependency(R.DataValidatorRegistryService),u=N.useDependency(W.ComponentManager),c=N.useDependency(s.ICommandService),m=N.useDependency(R.DataValidationModel),f=N.useDependency(s.LocaleService),[h,p]=E.useState(i),S=d.getValidatorItem(h.type),[D,C]=E.useState(!1),M=d.getValidatorsByScope(R.DataValidatorRegistryScope.SHEET),[V,y]=E.useState(()=>h.ranges.map(w=>({unitId:"",sheetId:"",range:w}))),T=E.useMemo(()=>Pa(c),[c]);if(E.useEffect(()=>{c.onCommandExecuted(w=>{(w.id===s.UndoCommand.id||w.id===s.RedoCommand.id)&&setTimeout(()=>{const $=m.getRuleById(a,n,l);r(z=>z+1),$&&(p($),y($.ranges.map(z=>({unitId:"",sheetId:"",range:z}))))},20)})},[c,m,l,n,a]),!S)return null;const b=S.operators,L=S.operatorNames,U=h.operator?R.TWO_FORMULA_OPERATOR_COUNT.includes(h.operator):!1,B=()=>{S.validatorFormula(h).success?e.setActiveRule(null):C(!0)},x=W.useEvent(w=>{if(s.isUnitRangesEqual(w,V))return;y(w);const $=w.filter(Q=>(!Q.unitId||Q.unitId===a)&&(!Q.sheetId||Q.sheetId===n)).map(Q=>Q.range);if(p({...h,ranges:$}),$.length===0)return;const z={unitId:a,subUnitId:n,ruleId:l,ranges:$};T(Pe.id,z)}),A=w=>{if(s.shallowEqual(w,R.getRuleSetting(h)))return;p({...h,...w});const $={unitId:a,subUnitId:n,ruleId:l,setting:w};T(R.UpdateDataValidationSettingCommand.id,$,void 0)},k=async()=>{await c.executeCommand(R.RemoveDataValidationCommand.id,{ruleId:l,unitId:a,subUnitId:n}),e.setActiveRule(null)},ee={type:h.type,operator:h.operator,formula1:h.formula1,formula2:h.formula2,allowBlank:h.allowBlank},P=w=>{const $=d.getValidatorItem(w);if(!$)return;const z=$.operators,Q=m.getRuleById(a,n,l),te=w===(Q==null?void 0:Q.type)?{...Q}:{...h,type:w,operator:z[0],formula1:void 0,formula2:void 0};p(te),c.executeCommand(R.UpdateDataValidationSettingCommand.id,{unitId:a,subUnitId:n,ruleId:h.uid,setting:R.getRuleSetting(te)})},G=u.get(S.formulaInput),H=V.map(w=>ie.serializeRange(w.range)).join(","),J=R.getRuleOptions(h),K=w=>{s.shallowEqual(w,R.getRuleOptions(h))||(p({...h,...w}),T(R.UpdateDataValidationOptionsCommand.id,{unitId:a,subUnitId:n,ruleId:l,options:w}))};return v.jsxs("div",{children:[v.jsx(O.FormLayout,{label:f.t("dataValidation.panel.range"),children:v.jsx(W.RangeSelector,{className:Me.dataValidationDetailFormItem,value:H,id:s.createInternalEditorID("data-validation-detail"),openForSheetUnitId:a,openForSheetSubUnitId:n,onChange:w=>{w.some($=>!s.isValidRange($.range)||$.range.endColumn<$.range.startColumn||$.range.endRow<$.range.startRow)||x(w)}},o)}),v.jsx(O.FormLayout,{label:f.t("dataValidation.panel.type"),children:v.jsx(O.Select,{options:M==null?void 0:M.map(w=>({label:f.t(w.title),value:w.id})),value:h.type,onChange:P,className:Me.dataValidationDetailFormItem})}),b!=null&&b.length?v.jsx(O.FormLayout,{label:f.t("dataValidation.panel.operator"),children:v.jsx(O.Select,{options:b.map((w,$)=>({value:`${w}`,label:L[$]})),value:`${h.operator}`,onChange:w=>{A({...ee,operator:w})},className:Me.dataValidationDetailFormItem})}):null,G?v.jsx(G,{isTwoFormula:U,value:{formula1:h.formula1,formula2:h.formula2},onChange:w=>{A({...ee,...w})},showError:D,validResult:S.validatorFormula(h),unitId:a,subUnitId:n,ruleId:l},o):null,v.jsx(Aa,{value:J,onChange:K,extraComponent:S.optionsInput}),v.jsxs("div",{className:Me.dataValidationDetailButtons,children:[v.jsx(O.Button,{className:Me.dataValidationDetailButton,onClick:k,children:f.t("dataValidation.panel.removeRule")}),v.jsx(O.Button,{className:Me.dataValidationDetailButton,type:"primary",onClick:B,children:f.t("dataValidation.panel.done")})]})]})}var Ue=(o=>(o[o.View=0]="View",o[o.Edit=1]="Edit",o[o.ManageCollaborator=2]="ManageCollaborator",o[o.Print=3]="Print",o[o.Duplicate=4]="Duplicate",o[o.Comment=5]="Comment",o[o.Copy=6]="Copy",o[o.Share=7]="Share",o[o.Export=8]="Export",o[o.MoveWorksheet=9]="MoveWorksheet",o[o.DeleteWorksheet=10]="DeleteWorksheet",o[o.HideWorksheet=11]="HideWorksheet",o[o.RenameWorksheet=12]="RenameWorksheet",o[o.CreateWorksheet=13]="CreateWorksheet",o[o.SetWorksheetStyle=14]="SetWorksheetStyle",o[o.EditWorksheetCell=15]="EditWorksheetCell",o[o.InsertHyperlink=16]="InsertHyperlink",o[o.Sort=17]="Sort",o[o.Filter=18]="Filter",o[o.PivotTable=19]="PivotTable",o[o.FloatImg=20]="FloatImg",o[o.History=21]="History",o[o.RwHgtClWdt=22]="RwHgtClWdt",o[o.ViemRwHgtClWdt=23]="ViemRwHgtClWdt",o[o.ViewFilter=24]="ViewFilter",o[o.MoveSheet=25]="MoveSheet",o[o.DeleteSheet=26]="DeleteSheet",o[o.HideSheet=27]="HideSheet",o[o.CopySheet=28]="CopySheet",o[o.RenameSheet=29]="RenameSheet",o[o.CreateSheet=30]="CreateSheet",o[o.SelectProtectedCells=31]="SelectProtectedCells",o[o.SelectUnProtectedCells=32]="SelectUnProtectedCells",o[o.SetCellStyle=33]="SetCellStyle",o[o.SetCellValue=34]="SetCellValue",o[o.SetRowStyle=35]="SetRowStyle",o[o.SetColumnStyle=36]="SetColumnStyle",o[o.InsertRow=37]="InsertRow",o[o.InsertColumn=38]="InsertColumn",o[o.DeleteRow=39]="DeleteRow",o[o.DeleteColumn=40]="DeleteColumn",o[o.EditExtraObject=41]="EditExtraObject",o[o.UNRECOGNIZED=-1]="UNRECOGNIZED",o))(Ue||{});const xe={dataValidationItemContainer:"univer-data-validation-item-container",dataValidationItemTitle:"univer-data-validation-item-title",dataValidationItemContent:"univer-data-validation-item-content",dataValidationItemIcon:"univer-data-validation-item-icon"},Ua=o=>{const{rule:r,onClick:e,unitId:t,subUnitId:a,disable:n}=o,i=N.useDependency(R.DataValidatorRegistryService),l=N.useDependency(s.ICommandService),d=N.useDependency(j.IMarkSelectionService),u=i.getValidatorItem(r.type),c=E.useRef(),[m,f]=E.useState(!1),h=p=>{l.executeCommand(R.RemoveDataValidationCommand.id,{ruleId:r.uid,unitId:t,subUnitId:a}),p.stopPropagation()};return E.useEffect(()=>()=>{var p;c.current&&((p=c.current)==null||p.forEach(S=>{S&&d.removeShape(S)}))},[d]),v.jsxs("div",{className:xe.dataValidationItemContainer,onClick:e,onMouseEnter:()=>{n||(f(!0),c.current=r.ranges.map(p=>d.addShape({range:p,style:{hasAutoFill:!1,fill:"rgba(73, 184, 17, 0.05)",strokeWidth:1,stroke:"#49B811",widgets:{}},primary:{startColumn:p.startColumn,endColumn:p.endColumn,startRow:p.startRow,endRow:p.endRow,actualRow:p.startRow,actualColumn:p.startColumn,isMerged:!1,isMergedMainCell:!1}})))},onMouseLeave:()=>{var p;f(!1),(p=c.current)==null||p.forEach(S=>{S&&d.removeShape(S)}),c.current=void 0},children:[v.jsx("div",{className:xe.dataValidationItemTitle,children:u==null?void 0:u.generateRuleName(r)}),v.jsx("div",{className:xe.dataValidationItemContent,children:r.ranges.map(p=>ie.serializeRange(p)).join(",")}),m?v.jsx("div",{className:xe.dataValidationItemIcon,onClick:h,children:v.jsx(Nt,{})}):null]})};var xa=Object.defineProperty,Ba=Object.getOwnPropertyDescriptor,$a=(o,r,e,t)=>{for(var a=t>1?void 0:t?Ba(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&xa(r,e,a),a},Wa=(o,r)=>(e,t)=>r(e,t,o);g.SheetDataValidationService=class{constructor(r){_(this,"_currentManager");_(this,"_currentManager$",new ue.Subject);_(this,"currentManager$",this._currentManager$.asObservable());this._dataValidationModel=r}get currentManager(){return this._currentManager}_ensureManager(r,e){return this._dataValidationModel.ensureManager(r,e)}switchCurrent(r,e){var a,n;if(r===((a=this.currentManager)==null?void 0:a.unitId)&&e===((n=this._currentManager)==null?void 0:n.subUnitId))return;const t=this._ensureManager(r,e);this._currentManager={manager:t,unitId:r,subUnitId:e},this._currentManager$.next(this._currentManager)}get(r,e){return this._ensureManager(r,e)}},g.SheetDataValidationService=$a([Wa(0,I.Inject(R.DataValidationModel))],g.SheetDataValidationService);function Ha(o){var d;const{unitId:r,subUnitId:e,value:t,onChange:a,showError:n,validResult:i}=o,l=n?i==null?void 0:i.formula1:"";return v.jsx(O.FormLayout,{error:l,children:v.jsx(W.TextEditor,{value:(d=t==null?void 0:t.formula1)!=null?d:"",id:s.createInternalEditorID(`dataValidation-custom-formula-${r}-${e}`),onChange:u=>{a==null||a({...t,formula1:u!=null?u:""})},onlyInputFormula:!0,openForSheetUnitId:r,openForSheetSubUnitId:e})})}const ae={dataValidationFormula:"univer-data-validation-formula",dataValidationFormulaAnd:"univer-data-validation-formula-and",dataValidationFormulaListItem:"univer-data-validation-formula-list-item",dataValidationFormulaListItemIcon:"univer-data-validation-formula-list-item-icon",dataValidationFormulaListItemDrag:"univer-data-validation-formula-list-item-drag",dataValidationFormulaListAdd:"univer-data-validation-formula-list-add",dataValidationFormulaColorSelect:"univer-data-validation-formula-color-select",dataValidationFormulaColorSelectPanel:"univer-data-validation-formula-color-select-panel",dataValidationFormulaColorItem:"univer-data-validation-formula-color-item"},ka=o=>{const{isTwoFormula:r=!1,value:e,onChange:t,showError:a,validResult:n}=o,i=N.useDependency(s.LocaleService),l=a?n==null?void 0:n.formula1:"",d=a?n==null?void 0:n.formula2:"";return r?v.jsxs(v.Fragment,{children:[v.jsx(O.FormLayout,{error:l,children:v.jsx(O.Input,{className:ae.dataValidationFormula,placeholder:i.t("dataValidation.panel.formulaPlaceholder"),value:e==null?void 0:e.formula1,onChange:u=>{t==null||t({...e,formula1:u})}})}),v.jsx("div",{className:ae.dataValidationFormulaAnd,children:i.t("dataValidation.panel.formulaAnd")}),v.jsx(O.FormLayout,{error:d,children:v.jsx(O.Input,{className:ae.dataValidationFormula,placeholder:i.t("dataValidation.panel.formulaPlaceholder"),value:e==null?void 0:e.formula2,onChange:u=>{t==null||t({...e,formula2:u})}})})]}):v.jsx(O.FormLayout,{error:l,children:v.jsx(O.Input,{className:ae.dataValidationFormula,placeholder:i.t("dataValidation.panel.formulaPlaceholder"),value:e==null?void 0:e.formula1,onChange:u=>{t==null||t({formula1:u})}})})};function re(o){if(o===null)return"";if(o!=null&&o.p){const r=o==null?void 0:o.p.body;if(r==null)return"";const e=r.dataStream;return e.substring(e.length-2,e.length)===s.DEFAULT_EMPTY_DOCUMENT_VALUE?e.substring(0,e.length-2):e}return o==null?void 0:o.v}function xt(o){return o.filter(Boolean).join(",")}function ye(o){return o.split(",").filter(Boolean)}function Ya(o){const r=re(o);return r==null?"":r.toString()}const Be="SHEET_DATA_VALIDATION_PLUGIN",Ve="#ECECEC";var qa=Object.defineProperty,Ga=Object.getOwnPropertyDescriptor,Xa=(o,r,e,t)=>{for(var a=t>1?void 0:t?Ga(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&qa(r,e,a),a},at=(o,r)=>(e,t)=>r(e,t,o);g.DataValidationFormulaController=class extends s.Disposable{constructor(r,e,t){super(),this._univerInstanceService=r,this._permissionService=e,this._lexerTreeBuilder=t}getFormulaRefCheck(r){var t,a;const e=this._lexerTreeBuilder.sequenceNodesBuilder(r);if(!e)return!0;for(let n=0;n<e.length;n++){const i=e[n];if(typeof i=="string")continue;const{token:l}=i,d=ie.deserializeRangeWithSheet(l),u=this._univerInstanceService.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET);let c=u.getActiveSheet();const m=u.getUnitId();if(d.sheetName){if(c=u.getSheetBySheetName(d.sheetName),!c)return!1;const D=c==null?void 0:c.getSheetId();if(!this._permissionService.getPermissionPoint(new q.WorksheetViewPermission(m,D).id))return!1}if(!c)return!1;const{startRow:f,endRow:h,startColumn:p,endColumn:S}=d.range;for(let D=f;D<=h;D++)for(let C=p;C<=S;C++){const M=(a=(t=c.getCell(D,C))==null?void 0:t.selectionProtection)==null?void 0:a[0];if((M==null?void 0:M[Ue.View])===!1)return!1}}return!0}},g.DataValidationFormulaController=Xa([s.OnLifecycle(s.LifecycleStages.Rendered,g.DataValidationFormulaController),at(0,s.IUniverInstanceService),at(1,s.IPermissionService),at(2,I.Inject(ie.LexerTreeBuilder))],g.DataValidationFormulaController);const za=["#FFFFFF","#FEE7E7","#FEF0E6","#EFFBD0","#E4F4FE","#E8ECFD","#F1EAFA","#FDE8F3","#E5E5E5","#FDCECE","#FDC49B","#DEF6A2","#9FDAFF","#D0D9FB","#E3D5F6","#FBD0E8","#656565","#FE4B4B","#FF8C51","#8BBB11","#0B9EFB","#3A60F7","#9E6DE3","#F248A6"],Qa=o=>{const{value:r,onChange:e,disabled:t}=o,[a,n]=E.useState(!1);return v.jsx(O.Select,{disabled:t,open:a,onDropdownVisibleChange:n,dropdownStyle:{width:112},className:ae.dataValidationFormulaColorSelect,value:r,onChange:e,labelRender:i=>v.jsx("div",{className:ae.dataValidationFormulaColorItem,style:{background:i.value}}),dropdownRender:()=>v.jsx("div",{className:ae.dataValidationFormulaColorSelectPanel,children:za.map(i=>v.jsx("div",{onClick:()=>{e(i),n(!1)},className:ae.dataValidationFormulaColorItem,style:{background:i}},i))})})},Bt=o=>{const{item:r,commonProps:e,style:t}=o,{onItemChange:a,onItemDelete:n}=e;return v.jsxs("div",{className:ae.dataValidationFormulaListItem,style:t,children:[r.isRef?null:v.jsx("div",{className:ra(ae.dataValidationFormulaListItemDrag,"draggableHandle"),children:v.jsx(Na,{})}),v.jsx(Qa,{value:r.color,onChange:i=>{a(r.id,r.label,i)}}),v.jsx(O.Input,{disabled:r.isRef,value:r.label,onChange:i=>{a(r.id,i,r.color)}}),r.isRef?null:v.jsx("div",{className:ae.dataValidationFormulaListItemIcon,children:v.jsx(Nt,{onClick:()=>n(r.id)})})]})};function Ka(o){const{value:r,onChange:e=()=>{},unitId:t,subUnitId:a,validResult:n,showError:i,ruleId:l}=o,{formula1:d="",formula2:u=""}=r||{},c=E.useRef(null),[m,f]=E.useState(()=>s.isFormulaString(d)?"1":"0"),[h,p]=E.useState(m==="1"?d:"="),[S,D]=E.useState(m==="1"?d:"="),C=N.useDependency(s.LocaleService),M=N.useDependency(R.DataValidatorRegistryService),V=N.useDependency(R.DataValidationModel),y=N.useDependency(g.DataValidationFormulaController),[T,b]=E.useState(()=>u.split(",")),L=M.getValidatorItem(s.DataValidationType.LIST),[U,B]=E.useState([]),[x,A]=E.useState(""),k=i?n==null?void 0:n.formula1:"",ee=W.useObservable(V.ruleChange$),P=W.useEvent(e);E.useEffect(()=>{(async()=>{await new Promise(Y=>{setTimeout(()=>Y(!0),100)});const F=V.getRuleById(t,a,l),X=F==null?void 0:F.formula1;if(s.isFormulaString(X)&&L&&F){const Y=await L.getListAsync(F,t,a);B(Y)}})()},[V,ee,L,l,a,t]),E.useEffect(()=>{s.isFormulaString(d)&&d!==S&&(p(d),D(S))},[S,d]);const[G,H]=E.useState(()=>{const F=m!=="1"?ye(d):[],X=u.split(",");return F.map((Y,ne)=>({label:Y,color:X[ne]||Ve,isRef:!1,id:s.Tools.generateRandomId(4)}))}),J=(F,X,Y)=>{const ne=G.find(pe=>pe.id===F);ne&&(ne.label=X,ne.color=Y,H([...G]))},K=F=>{const X=G.findIndex(Y=>Y.id===F);X!==-1&&(G.splice(X,1),H([...G]))},w=u.split(","),$=E.useMemo(()=>U.map((F,X)=>({label:F,color:w[X]||Ve,id:`${X}`,isRef:!0})),[w,U]),z=(F,X,Y)=>{const ne=[...T];ne[+F]=Y,b(ne),P({formula1:d,formula2:ne.join(",")})},Q=()=>{H([...G,{label:"",color:Ve,isRef:!1,id:s.Tools.generateRandomId(4)}])};E.useEffect(()=>{if(m==="1")return;const F=new Set,X=[];G.map(Y=>({labelList:Y.label.split(","),item:Y})).forEach(({item:Y,labelList:ne})=>{ne.forEach(pe=>{F.has(pe)||(F.add(pe),X.push({label:pe,color:Y.color}))})}),P({formula1:xt(X.map(Y=>Y.label)),formula2:X.map(Y=>Y.color===Ve?"":Y.color).join(",")})},[G,P,m,S,T]);const te=E.useMemo(()=>async F=>{if(!s.isFormulaString(F)){P==null||P({formula1:"",formula2:u});return}y.getFormulaRefCheck(F)?(P==null||P({formula1:s.isFormulaString(F)?F:"",formula2:u}),A("")):(P==null||P({formula1:"",formula2:u}),p("="),A(C.t("dataValidation.validFail.formulaError")))},[u,P]);return v.jsxs(v.Fragment,{children:[v.jsx(O.FormLayout,{label:C.t("dataValidation.list.options"),children:v.jsxs(O.RadioGroup,{value:m,onChange:F=>{f(F),p(S),F==="1"&&P({formula1:S==="="?"":S,formula2:T.join(",")})},children:[v.jsx(O.Radio,{value:"0",children:C.t("dataValidation.list.customOptions")}),v.jsx(O.Radio,{value:"1",children:C.t("dataValidation.list.refOptions")})]})}),m==="1"?v.jsxs(v.Fragment,{children:[v.jsx(O.FormLayout,{error:k||x,children:v.jsx(W.TextEditor,{id:s.createInternalEditorID(`list-ref-range-${t}-${a}`),value:h,openForSheetUnitId:t,openForSheetSubUnitId:a,onlyInputFormula:!0,onChange:async F=>{const X=F!=null?F:"";D(X),te(X)}})}),v.jsx(O.FormLayout,{children:v.jsx("div",{ref:c,children:$.map(F=>v.jsx(Bt,{item:F,commonProps:{onItemChange:z},style:{marginBottom:12}},F.id))})})]}):v.jsx(O.FormLayout,{error:k,children:v.jsxs("div",{ref:c,style:{marginTop:"-12px"},children:[v.jsx(O.DraggableList,{list:G,onListChange:H,rowHeight:32,margin:[0,12],draggableHandle:".draggableHandle",itemRender:F=>v.jsx(Bt,{item:F,commonProps:{onItemChange:J,onItemDelete:K}},F.id),idKey:"id"}),v.jsxs("a",{className:ae.dataValidationFormulaListAdd,onClick:Q,children:[v.jsx(Oa,{}),C.t("dataValidation.list.add")]})]})})]})}function Za(o){const{value:r,onChange:e,showError:t,validResult:a}=o,n=N.useDependency(s.LocaleService),i=t?a==null?void 0:a.formula1:"",l=t?a==null?void 0:a.formula2:"",[d,u]=E.useState(!((r==null?void 0:r.formula1)===void 0&&(r==null?void 0:r.formula2)===void 0));return v.jsxs(v.Fragment,{children:[v.jsx(O.FormLayout,{children:v.jsx(O.Checkbox,{checked:d,onChange:c=>{c?u(!0):(u(!1),e==null||e({...r,formula1:void 0,formula2:void 0}))},children:n.t("dataValidation.checkbox.tips")})}),d?v.jsx(O.FormLayout,{label:n.t("dataValidation.checkbox.checked"),error:i,children:v.jsx(O.Input,{className:ae.dataValidationFormula,placeholder:n.t("dataValidation.panel.formulaPlaceholder"),value:r==null?void 0:r.formula1,onChange:c=>{e==null||e({...r,formula1:c||void 0})}})}):null,d?v.jsx(O.FormLayout,{label:n.t("dataValidation.checkbox.unchecked"),error:l,children:v.jsx(O.Input,{className:ae.dataValidationFormula,placeholder:n.t("dataValidation.panel.formulaPlaceholder"),value:r==null?void 0:r.formula2,onChange:c=>{e==null||e({...r,formula2:c||void 0})}})}):null]})}const $t="data-validation.custom-formula-input",Te="data-validation.formula-input",Wt="data-validation.list-formula-input",Ht="data-validation.checkbox-formula-input",Ja=[[$t,Ha],[Te,ka],[Wt,Ka],[Ht,Za]];class we{constructor(){_(this,"_cacheMatrix",new Map)}_ensureCache(r,e){let t=this._cacheMatrix.get(r);t||(t=new Map,this._cacheMatrix.set(r,t));let a=t.get(e);return a||(a=new s.ObjectMatrix,t.set(e,a)),a}ensureCache(r,e){return this._ensureCache(r,e)}addRule(r,e,t){this.markRangeDirty(r,e,t.ranges)}removeRule(r,e,t){this._deleteRange(r,e,t.ranges)}updateRuleRanges(r,e,t,a,n){const i=this._ensureCache(r,e);n.forEach(l=>{s.Range.foreach(l,(d,u)=>{const c=i.getValue(d,u);c&&(c.temp=!0)})}),a.forEach(l=>{s.Range.foreach(l,(d,u)=>{const c=i.getValue(d,u);c&&c.ruleId===t?c.temp=!1:i.setValue(d,u,void 0)})}),n.forEach(l=>{s.Range.foreach(l,(d,u)=>{const c=i.getValue(d,u);c&&c.temp===!0&&i.realDeleteValue(d,u)})})}markRangeDirty(r,e,t){const a=this._ensureCache(r,e);t.forEach(n=>{s.Range.foreach(n,(i,l)=>{a.setValue(i,l,void 0)})})}markCellDirty(r,e,t,a){this._ensureCache(r,e).setValue(t,a,void 0)}_deleteRange(r,e,t){const a=this._ensureCache(r,e);t.forEach(n=>{s.Range.foreach(n,(i,l)=>{a.realDeleteValue(i,l)})})}getValue(r,e,t,a){return this._ensureCache(r,e).getValue(t,a)}setValue(r,e,t,a,n){return this._ensureCache(r,e).setValue(t,a,n)}}var en=Object.defineProperty,tn=Object.getOwnPropertyDescriptor,an=(o,r,e,t)=>{for(var a=t>1?void 0:t?tn(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&en(r,e,a),a},$e=(o,r)=>(e,t)=>r(e,t,o);g.DataValidationCustomFormulaService=class extends s.Disposable{constructor(e,t,a,n){super();_(this,"_formulaMap",new Map);_(this,"_ruleFormulaMap",new Map);_(this,"_formulaCellMap",new Map);this._registerOtherFormulaService=e,this._lexerTreeBuilder=t,this._dataValidationModel=a,this._dataValidationCacheService=n,this._initFormulaResultHandler()}_initFormulaResultHandler(){this.disposeWithMe(this._registerOtherFormulaService.formulaResult$.subscribe(e=>{for(const t in e){const a=e[t];for(const n in a){const i=a[n],{formulaCellMap:l,ruleFormulaMap:d}=this._ensureMaps(t,n),u=this._dataValidationModel.ensureManager(t,n);i.forEach(c=>{var p,S;const m=d.get((p=c.extra)==null?void 0:p.ruleId),f=l.get(c.formulaId),h=u.getRuleById((S=c.extra)==null?void 0:S.ruleId);h&&m&&!m.isTransformable&&this._dataValidationCacheService.markRangeDirty(t,n,h.ranges),f&&this._dataValidationCacheService.markCellDirty(t,n,f.row,f.column)})}}}))}_ensureMaps(e,t){let a=this._formulaMap.get(e),n=this._ruleFormulaMap.get(e),i=this._formulaCellMap.get(e);(!a||!n||!i)&&(a=new Map,n=new Map,i=new Map,this._formulaMap.set(e,a),this._ruleFormulaMap.set(e,n),this._formulaCellMap.set(e,i));let l=a.get(t),d=n.get(t),u=i.get(t);return(!l||!d||!u)&&(l=new s.ObjectMatrix,a.set(t,l),d=new Map,n.set(t,d),u=new Map,i.set(t,u)),{formulaMap:l,ruleFormulaMap:d,formulaCellMap:u}}_registerFormula(e,t,a,n){return this._registerOtherFormulaService.registerFormula(e,t,n,{ruleId:a})}deleteByRuleId(e,t,a){const{formulaMap:n,formulaCellMap:i,ruleFormulaMap:l}=this._ensureMaps(e,t),d=this._dataValidationModel.getRuleById(e,t,a),u=new Set,c=l.get(a);!d||!c||(l.delete(a),d.ranges.forEach(m=>{s.Range.foreach(m,(f,h)=>{const p=n.getValue(f,h);if(p&&p.ruleId===a){const{formulaId:S}=p;n.realDeleteValue(f,h),u.add(S),i.delete(S)}})}),this._registerOtherFormulaService.deleteFormula(e,t,Array.from(u.values())))}_addFormulaByRange(e,t,a,n,i){const{formulaMap:l,ruleFormulaMap:d,formulaCellMap:u}=this._ensureMaps(e,t);if(!n)return;const c=ie.isFormulaTransformable(this._lexerTreeBuilder,n),m=i[0].startRow,f=i[0].startColumn;let h;c?i.forEach(p=>{s.Range.foreach(p,(S,D)=>{const C=ie.transformFormula(this._lexerTreeBuilder,n,m,f,S,D),M=this._registerFormula(e,t,a,C);l.setValue(S,D,{formulaId:M,ruleId:a}),u.set(M,{row:S,column:D})})}):(h=this._registerFormula(e,t,a,n),i.forEach(p=>{s.Range.foreach(p,(S,D)=>{l.setValue(S,D,{formulaId:h,ruleId:a})})})),d.set(a,{formula:n,originCol:f,originRow:m,isTransformable:c,formulaId:h})}addRule(e,t,a){const{ranges:n,formula1:i,uid:l,type:d}=a;d!==s.DataValidationType.CUSTOM||!i||!s.isFormulaString(i)||this._addFormulaByRange(e,t,l,i,n)}updateRuleRanges(e,t,a,n,i){const{formulaMap:l,ruleFormulaMap:d,formulaCellMap:u}=this._ensureMaps(e,t),c=d.get(a);if(!c)return;const{formula:m,originCol:f,originRow:h,isTransformable:p,formulaId:S}=c,D=new Set;n.forEach(C=>{s.Range.foreach(C,(M,V)=>{const y=l.getValue(M,V);y&&y.ruleId===a&&(y.temp=!0)})}),i.forEach(C=>{s.Range.foreach(C,(M,V)=>{var T;const y=(T=l.getValue(M,V))!=null?T:{};if(y.ruleId!==a){const b=d.get(y.ruleId);if(b!=null&&b.isTransformable&&D.add(y.formulaId),p){const L=ie.transformFormula(this._lexerTreeBuilder,m,h,f,M,V),U=this._registerFormula(e,t,a,L);l.setValue(M,V,{ruleId:a,formulaId:U}),u.set(U,{row:M,column:V})}else l.setValue(M,V,{ruleId:a,formulaId:S})}else y.temp=!1})}),n.forEach(C=>{s.Range.foreach(C,(M,V)=>{const y=l.getValue(M,V);y&&y.ruleId===a&&y.temp===!0&&(l.realDeleteValue(M,V),p&&D.add(y.formulaId))})}),D.forEach(C=>{u.delete(C)}),this._registerOtherFormulaService.deleteFormula(e,t,Array.from(D.values()))}updateRuleFormula(e,t,a,n,i){const{ruleFormulaMap:l}=this._ensureMaps(e,t),d=l.get(a);(!d||d.formula!==i)&&this._addFormulaByRange(e,t,a,i,n)}getCellFormulaValue(e,t,a,n){const{formulaMap:i}=this._ensureMaps(e,t),l=i.getValue(a,n);return l?this._registerOtherFormulaService.getFormulaValue(e,t,l.formulaId):Promise.resolve(void 0)}getRuleFormulaInfo(e,t,a){const{ruleFormulaMap:n}=this._ensureMaps(e,t);return n.get(a)}},g.DataValidationCustomFormulaService=an([$e(0,I.Inject(Le.RegisterOtherFormulaService)),$e(1,I.Inject(ie.LexerTreeBuilder)),$e(2,I.Inject(R.DataValidationModel)),$e(3,I.Inject(we))],g.DataValidationCustomFormulaService);function me(o){var r,e;return(e=(r=o==null?void 0:o[0])==null?void 0:r[0])==null?void 0:e.v}class nn extends R.BaseDataValidator{constructor(){super(...arguments);_(this,"id",s.DataValidationType.CUSTOM);_(this,"title","dataValidation.custom.title");_(this,"operators",[]);_(this,"scopes",["sheet"]);_(this,"formulaInput",$t);_(this,"_customFormulaService",this.injector.get(g.DataValidationCustomFormulaService))}validatorFormula(e){const t=s.isFormulaString(e.formula1);return{success:t,formula1:t?"":this.localeService.t("dataValidation.validFail.formula")}}async parseFormula(e,t,a){return{formula1:void 0,formula2:void 0}}async isValidType(e,t,a){const{column:n,row:i,unitId:l,subUnitId:d}=e,u=await this._customFormulaService.getCellFormulaValue(l,d,i,n);return!!me(u==null?void 0:u.result)}generateRuleErrorMessage(e){return this.localeService.t("dataValidation.custom.error")}}var rn=Object.defineProperty,on=Object.getOwnPropertyDescriptor,sn=(o,r,e,t)=>{for(var a=t>1?void 0:t?on(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&rn(r,e,a),a},nt=(o,r)=>(e,t)=>r(e,t,o);g.DataValidationFormulaService=class extends s.Disposable{constructor(e,t,a){super();_(this,"_formulaRuleMap",new Map);this._registerOtherFormulaService=e,this._dataValidationCacheService=t,this._dataValidationModel=a,this._initFormulaResultHandler()}_initFormulaResultHandler(){this.disposeWithMe(this._registerOtherFormulaService.formulaResult$.subscribe(e=>{for(const t in e){const a=e[t];for(const n in a){const i=a[n],l=this._ensureRuleFormulaMap(t,n),d=this._dataValidationModel.ensureManager(t,n);i.forEach(u=>{var c,m;if(l.get((c=u.extra)==null?void 0:c.ruleId)){const f=d.getRuleById((m=u.extra)==null?void 0:m.ruleId);f&&this._dataValidationCacheService.markRangeDirty(t,n,f.ranges)}})}}}))}_ensureRuleFormulaMap(e,t){let a=this._formulaRuleMap.get(e);a||(a=new Map,this._formulaRuleMap.set(e,a));let n=a.get(t);return n||(n=new Map,a.set(t,n)),n}addRule(e,t,a,n,i){const l=s.isFormulaString(n),d=s.isFormulaString(i);if(!l&&!d)return;const u=this._ensureRuleFormulaMap(e,t),c=[void 0,void 0];if(l){const m=this._registerOtherFormulaService.registerFormula(e,t,n,{ruleId:a});c[0]={id:m,text:n}}if(d){const m=this._registerOtherFormulaService.registerFormula(e,t,i,{ruleId:a});c[1]={id:m,text:i}}u.set(a,c)}removeRule(e,t,a){const i=this._ensureRuleFormulaMap(e,t).get(a);if(!i)return;const[l,d]=i,u=[l==null?void 0:l.id,d==null?void 0:d.id].filter(Boolean);u.length&&this._registerOtherFormulaService.deleteFormula(e,t,u)}updateRuleFormulaText(e,t,a,n,i){const d=this._ensureRuleFormulaMap(e,t).get(a);if(!d){this.addRule(e,t,a,n,i);return}const[u,c]=d;if((u==null?void 0:u.text)!==n)if(u&&this._registerOtherFormulaService.deleteFormula(e,t,[u.id]),s.isFormulaString(n)){const m=this._registerOtherFormulaService.registerFormula(e,t,n,{ruleId:a});d[0]={text:n,id:m}}else d[0]=void 0;if((c==null?void 0:c.text)!==i)if(c&&this._registerOtherFormulaService.deleteFormula(e,t,[c.id]),s.isFormulaString(i)){const m=this._registerOtherFormulaService.registerFormula(e,t,i,{ruleId:a});d[1]={text:i,id:m}}else d[1]=void 0}getRuleFormulaResult(e,t,a){const i=this._ensureRuleFormulaMap(e,t).get(a);if(!i)return Promise.resolve(null);const l=async d=>d&&this._registerOtherFormulaService.getFormulaValue(e,t,d.id);return Promise.all([l(i[0]),l(i[1])])}getRuleFormulaResultSync(e,t,a){const i=this._ensureRuleFormulaMap(e,t).get(a);if(i)return i.map(l=>{if(l)return this._registerOtherFormulaService.getFormulaValueSync(e,t,l.id)})}getRuleFormulaInfo(e,t,a){return this._ensureRuleFormulaMap(e,t).get(a)}},g.DataValidationFormulaService=sn([nt(0,I.Inject(Le.RegisterOtherFormulaService)),nt(1,I.Inject(we)),nt(2,I.Inject(R.DataValidationModel))],g.DataValidationFormulaService);var ln=Object.defineProperty,dn=Object.getOwnPropertyDescriptor,un=(o,r,e,t)=>{for(var a=t>1?void 0:t?dn(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&ln(r,e,a),a},rt=(o,r)=>(e,t)=>r(e,t,o);const We=6;let ot=class{constructor(o,r,e){this._commandService=o,this._formulaService=r,this._themeService=e}_calc(o,r){var u,c,m;const{vt:e,ht:t}=r||{},a=o.endX-o.startX-We*2,n=o.endY-o.startY,i=((u=r==null?void 0:r.fs)!=null?u:10)*1.6;let l=0,d=0;switch(e){case s.VerticalAlign.TOP:d=0;break;case s.VerticalAlign.BOTTOM:d=0+(n-i);break;default:d=0+(n-i)/2;break}switch(t){case s.HorizontalAlign.LEFT:l=We;break;case s.HorizontalAlign.RIGHT:l=We+(a-i);break;default:l=We+(a-i)/2;break}return{left:o.startX+l,top:o.startY+d,width:((c=r==null?void 0:r.fs)!=null?c:10)*1.6,height:((m=r==null?void 0:r.fs)!=null?m:10)*1.6}}calcCellAutoHeight(o){var e;const{style:r}=o;return((e=r==null?void 0:r.fs)!=null?e:10)*1.6}async _parseFormula(o,r,e){var i,l;const{formula1:t=He,formula2:a=it}=o,n=await this._formulaService.getRuleFormulaResult(r,e,o.uid);return{formula1:s.isFormulaString(t)?me((i=n==null?void 0:n[0])==null?void 0:i.result):t,formula2:s.isFormulaString(a)?me((l=n==null?void 0:n[1])==null?void 0:l.result):a}}drawWith(o,r){var B,x,A,k,ee,P;const{style:e,data:t,primaryWithCoord:a,unitId:n,subUnitId:i}=r,l=a.isMergedMainCell?a.mergeInfo:a,d=re(t),u=(B=t.dataValidation)==null?void 0:B.rule,c=(x=t.dataValidation)==null?void 0:x.validator;if(!u||!c||(A=t.dataValidation)!=null&&A.isSkip)return;const m=this._themeService.getCurrentTheme();if(!c.skipDefaultFontRender(u,d,{unitId:n,subUnitId:i}))return;const{formula1:f=He}=u,h=this._calc(l,e),{a:p,d:S}=o.getTransform(),D=Z.fixLineWidthByScale(h.left,p),C=Z.fixLineWidthByScale(h.top,S),M=Z.Transform.create().composeMatrix({left:D,top:C,scaleX:1,scaleY:1,angle:0,skewX:0,skewY:0,flipX:!1,flipY:!1}),V=l.endX-l.startX,y=l.endY-l.startY;o.save(),o.beginPath(),o.rect(l.startX,l.startY,V,y),o.clip();const T=M.getMatrix();o.transform(T[0],T[1],T[2],T[3],T[4],T[5]);const b=((k=e==null?void 0:e.fs)!=null?k:10)*1.6,L=String(d)===String(f),U=m.hyacinth500;Z.Checkbox.drawWith(o,{checked:L,width:b,height:b,fill:(P=(ee=e==null?void 0:e.cl)==null?void 0:ee.rgb)!=null?P:U}),o.restore()}isHit(o,r){const e=r.primaryWithCoord.isMergedMainCell?r.primaryWithCoord.mergeInfo:r.primaryWithCoord,t=this._calc(e,r.style),a=t.top,n=t.top+t.height,i=t.left,l=t.left+t.width,{x:d,y:u}=o;return d<=l&&d>=i&&u<=n&&u>=a}async onPointerDown(o,r){var f,h;if(r.button===2)return;const{primaryWithCoord:e,unitId:t,subUnitId:a,data:n}=o,i=re(n),l=(f=n.dataValidation)==null?void 0:f.rule,d=(h=n.dataValidation)==null?void 0:h.validator;if(!l||!d||!d.skipDefaultFontRender(l,i,{unitId:t,subUnitId:a}))return;const{formula1:u,formula2:c}=await this._parseFormula(l,t,a),m={range:{startColumn:e.actualColumn,endColumn:e.actualColumn,startRow:e.actualRow,endRow:e.actualRow},value:{v:String(i)===String(u)?c:u,p:null}};this._commandService.executeCommand(q.SetRangeValuesCommand.id,m)}};ot=un([rt(0,s.ICommandService),rt(1,I.Inject(g.DataValidationFormulaService)),rt(2,I.Inject(s.ThemeService))],ot);const He=1,it=0;class cn extends R.BaseDataValidator{constructor(){super(...arguments);_(this,"id",s.DataValidationType.CHECKBOX);_(this,"title","dataValidation.checkbox.title");_(this,"operators",[]);_(this,"scopes",["sheet"]);_(this,"formulaInput",Ht);_(this,"canvasRender",this.injector.createInstance(ot));_(this,"_formulaService",this.injector.get(g.DataValidationFormulaService))}skipDefaultFontRender(e,t,a){const{formula1:n,formula2:i}=this.parseFormulaSync(e,a.unitId,a.subUnitId),l=`${t!=null?t:""}`;return!l||l===`${n}`||l===`${i}`}validatorFormula(e){const{formula1:t,formula2:a}=e,n=!s.Tools.isBlank(t),i=!s.Tools.isBlank(a),l=t===a;return{success:n&&i&&!l||!n&&!i,formula1:n?l?this.localeService.t("dataValidation.validFail.checkboxEqual"):"":this.localeService.t("dataValidation.validFail.common"),formula2:i?l?this.localeService.t("dataValidation.validFail.checkboxEqual"):"":this.localeService.t("dataValidation.validFail.common")}}async parseFormula(e,t,a){var d,u;const{formula1:n=He,formula2:i=it}=e,l=await this._formulaService.getRuleFormulaResult(t,a,e.uid);return{formula1:s.isFormulaString(n)?me((d=l==null?void 0:l[0])==null?void 0:d.result):n,formula2:s.isFormulaString(i)?me((u=l==null?void 0:l[1])==null?void 0:u.result):i}}parseFormulaSync(e,t,a){var d,u;const{formula1:n=He,formula2:i=it}=e,l=this._formulaService.getRuleFormulaResultSync(t,a,e.uid);return{formula1:s.isFormulaString(n)?me((d=l==null?void 0:l[0])==null?void 0:d.result):n,formula2:s.isFormulaString(i)?me((u=l==null?void 0:l[1])==null?void 0:u.result):i}}async isValidType(e,t,a){const{value:n,unitId:i,subUnitId:l}=e,{formula1:d,formula2:u}=await this.parseFormula(a,i,l);return!s.Tools.isDefine(d)||!s.Tools.isDefine(u)?!0:s.Tools.isDefine(n)&&(String(n)===String(d)||String(n)===String(u))}generateRuleErrorMessage(e){return this.localeService.t("dataValidation.checkbox.error")}}const Fe=[s.DataValidationOperator.BETWEEN,s.DataValidationOperator.NOT_BETWEEN],st=86400;function mn(o,r=!0){if(r&&o>=0){if(o===0)return[1900,1,0];if(o===60)return[1900,2,29];if(o<60)return[1900,o<32?1:2,(o-1)%31+1]}let e=o+68569+2415019;const t=Math.floor(4*e/146097);e=e-Math.floor((146097*t+3)/4);const a=Math.floor(4e3*(e+1)/1461001);e=e-Math.floor(1461*a/4)+31;const n=Math.floor(80*e/2447),i=e-Math.floor(2447*n/80);e=Math.floor(n/11);const l=n+2-12*e;return[100*(t-49)+a+e|0,l|0,i|0]}const hn=o=>{let r=o|0;const e=st*(o-r);let t=Math.floor(e);e-t>.9999&&(t+=1,t===st&&(t=0,r+=1));const a=t<0?st+t:t,[n,i,l]=mn(o,!0),d=Math.floor(a/60/60)%60,u=Math.floor(a/60)%60,c=Math.floor(a)%60,m=new Date(0);return m.setUTCFullYear(n,i-1,l),m.setUTCHours(d,u,c),m.getTime()},fn={[s.DataValidationOperator.BETWEEN]:"dataValidation.date.operators.between",[s.DataValidationOperator.EQUAL]:"dataValidation.date.operators.equal",[s.DataValidationOperator.GREATER_THAN]:"dataValidation.date.operators.greaterThan",[s.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.date.operators.greaterThanOrEqual",[s.DataValidationOperator.LESS_THAN]:"dataValidation.date.operators.lessThan",[s.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.date.operators.lessThanOrEqual",[s.DataValidationOperator.NOT_BETWEEN]:"dataValidation.date.operators.notBetween",[s.DataValidationOperator.NOT_EQUAL]:"dataValidation.date.operators.notEqual"};s.DataValidationOperator.BETWEEN+"",s.DataValidationOperator.EQUAL+"",s.DataValidationOperator.GREATER_THAN+"",s.DataValidationOperator.GREATER_THAN_OR_EQUAL+"",s.DataValidationOperator.LESS_THAN+"",s.DataValidationOperator.LESS_THAN_OR_EQUAL+"",s.DataValidationOperator.NOT_BETWEEN+"",s.DataValidationOperator.NOT_EQUAL+"";const pn={[s.DataValidationOperator.BETWEEN]:"dataValidation.date.ruleName.between",[s.DataValidationOperator.EQUAL]:"dataValidation.date.ruleName.equal",[s.DataValidationOperator.GREATER_THAN]:"dataValidation.date.ruleName.greaterThan",[s.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.date.ruleName.greaterThanOrEqual",[s.DataValidationOperator.LESS_THAN]:"dataValidation.date.ruleName.lessThan",[s.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.date.ruleName.lessThanOrEqual",[s.DataValidationOperator.NOT_BETWEEN]:"dataValidation.date.ruleName.notBetween",[s.DataValidationOperator.NOT_EQUAL]:"dataValidation.date.ruleName.notEqual"},vn={[s.DataValidationOperator.BETWEEN]:"dataValidation.date.errorMsg.between",[s.DataValidationOperator.EQUAL]:"dataValidation.date.errorMsg.equal",[s.DataValidationOperator.GREATER_THAN]:"dataValidation.date.errorMsg.greaterThan",[s.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.date.errorMsg.greaterThanOrEqual",[s.DataValidationOperator.LESS_THAN]:"dataValidation.date.errorMsg.lessThan",[s.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.date.errorMsg.lessThanOrEqual",[s.DataValidationOperator.NOT_BETWEEN]:"dataValidation.date.errorMsg.notBetween",[s.DataValidationOperator.NOT_EQUAL]:"dataValidation.date.errorMsg.notEqual"},kt="{FORMULA1}",Yt="{FORMULA2}",qt=o=>Se(o).isValid(),ke=o=>{if(!(o==null||typeof o=="boolean"))return typeof o=="number"||!Number.isNaN(+o)?Se(hn(+o)):Se(o)};class gn extends R.BaseDataValidator{constructor(){super(...arguments);_(this,"id",s.DataValidationType.DATE);_(this,"title","dataValidation.date.title");_(this,"operators",[s.DataValidationOperator.BETWEEN,s.DataValidationOperator.EQUAL,s.DataValidationOperator.GREATER_THAN,s.DataValidationOperator.GREATER_THAN_OR_EQUAL,s.DataValidationOperator.LESS_THAN,s.DataValidationOperator.LESS_THAN_OR_EQUAL,s.DataValidationOperator.NOT_BETWEEN,s.DataValidationOperator.NOT_EQUAL]);_(this,"scopes",["sheet"]);_(this,"formulaInput",Te);_(this,"dropdown",aa);_(this,"_formulaService",this.injector.get(g.DataValidationFormulaService));_(this,"transformDate",ke)}async parseFormula(e,t,a){var d,u;const n=await this._formulaService.getRuleFormulaResult(t,a,e.uid),{formula1:i,formula2:l}=e;return{formula1:ke(s.isFormulaString(i)?me((d=n==null?void 0:n[0])==null?void 0:d.result):i),formula2:ke(s.isFormulaString(l)?me((u=n==null?void 0:n[1])==null?void 0:u.result):l)}}async isValidType(e){const{value:t}=e;return typeof t=="string"?Se(t).isValid():typeof t=="number"}_validatorSingleFormula(e){return!s.Tools.isBlank(e)&&(s.isFormulaString(e)||!Number.isNaN(+e)||!!e&&Se(e).isValid())}validatorFormula(e){const t=e.operator;if(!t)return{success:!1};const a=this._validatorSingleFormula(e.formula1),n=this.localeService.t("dataValidation.validFail.date");if(Fe.includes(t)){const l=this._validatorSingleFormula(e.formula2);return{success:a&&l,formula1:a?void 0:n,formula2:l?void 0:n}}return{success:a,formula1:a?void 0:n}}transform(e,t,a){const{value:n}=e;return{...e,value:ke(n)}}async validatorIsEqual(e,t,a){const{value:n}=e,{formula1:i}=t;return i?n.isSame(i):!0}async validatorIsNotEqual(e,t){const{value:a}=e,{formula1:n}=t;return n?!a.isSame(n):!0}async validatorIsBetween(e,t){const{value:a}=e,{formula1:n,formula2:i}=t;if(!n||!i)return!1;const l=n.isAfter(i)?i:n,d=l===n?i:n;return(a.isAfter(l)||a.isSame(l))&&(a.isBefore(d)||a.isSame(d))}async validatorIsNotBetween(e,t){const{value:a}=e,{formula1:n,formula2:i}=t;if(!n||!i)return!1;const l=n.isAfter(i)?i:n,d=l===n?i:n;return a.isBefore(l)||a.isAfter(d)}async validatorIsGreaterThan(e,t){const{value:a}=e,{formula1:n}=t;return n?a.isAfter(n):!0}async validatorIsGreaterThanOrEqual(e,t){const{value:a}=e,{formula1:n}=t;return n?a.isAfter(n)||a.isSame(n):!0}async validatorIsLessThan(e,t){const{value:a}=e,{formula1:n}=t;return n?a.isBefore(n)||a.isSame(n):!0}async validatorIsLessThanOrEqual(e,t){const{value:a}=e,{formula1:n}=t;return n?a.isBefore(n)||a.isSame(n):!0}validatorFormulaValue(e){if(!s.Tools.isDefine(e.operator))return;if(Fe.includes(e.operator)){if(s.Tools.isBlank(e.formula1)||s.Tools.isBlank(e.formula2))return"";if(!qt(e.formula1)||!qt(e.formula2))return""}else if(s.Tools.isBlank(e.formula1))return""}get operatorNames(){return this.operators.map(e=>this.localeService.t(fn[e]))}generateRuleName(e){var a,n;if(!e.operator)return this.titleStr;const t=this.localeService.t(pn[e.operator]).replace(kt,(a=e.formula1)!=null?a:"").replace(Yt,(n=e.formula2)!=null?n:"");return`${this.titleStr} ${t}`}generateRuleErrorMessage(e){var a,n;return e.operator?`${this.localeService.t(vn[e.operator]).replace(kt,(a=e.formula1)!=null?a:"").replace(Yt,(n=e.formula2)!=null?n:"")}`:this.titleStr}}var Sn=Object.defineProperty,_n=Object.getOwnPropertyDescriptor,Dn=(o,r,e,t)=>{for(var a=t>1?void 0:t?_n(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&Sn(r,e,a),a},Gt=(o,r)=>(e,t)=>r(e,t,o);const Oe=4,Vn=6,le=14,Ce=6,he=2,Cn="#565656",Xt=new Path2D("M3.32201 4.84556C3.14417 5.05148 2.85583 5.05148 2.67799 4.84556L0.134292 1.90016C-0.152586 1.56798 0.0505937 1 0.456301 1L5.5437 1C5.94941 1 6.15259 1.56798 5.86571 1.90016L3.32201 4.84556Z");function Rn(o,r){const e=o.length;return{id:"d",body:{dataStream:`${o}${s.DEFAULT_EMPTY_DOCUMENT_VALUE}`,textRuns:[{ts:{fs:11,ff:void 0,it:s.BooleanNumber.FALSE,bl:s.BooleanNumber.FALSE,ul:{s:s.BooleanNumber.FALSE},st:{s:s.BooleanNumber.FALSE},ol:{s:s.BooleanNumber.FALSE},cl:void 0,...r,bg:void 0,bd:void 0},st:0,ed:e}]},documentStyle:{pageSize:{width:Number.POSITIVE_INFINITY,height:Number.POSITIVE_INFINITY}}}}function lt(o,r,e){const t=Rn(o,e),a=new s.DocumentDataModel(t),n=new Z.DocumentViewModel(a);return{documentSkeleton:Z.DocumentSkeleton.create(n,r),docModel:a,docViewModel:n}}function zt(o,r,e){const{documentSkeleton:t,docModel:a,docViewModel:n}=lt(o,r,e);return{documents:new Z.Documents(`DOCUMENTS_${s.Tools.generateRandomId()}`,t,{pageMarginLeft:0,pageMarginTop:0}),documentSkeleton:t,docModel:a,docViewModel:n}}let dt=(Vt=class{constructor(o,r){_(this,"_dropdownInfoMap",new Map);_(this,"zIndex");_(this,"onPointerEnter");_(this,"onPointerLeave");this._localeService=o,this._commandService=r}_ensureMap(o){let r=this._dropdownInfoMap.get(o);return r||(r=new Map,this._dropdownInfoMap.set(o,r)),r}_generateKey(o,r){return`${o}.${r}`}_drawDownIcon(o,r,e,t,a){const n=e-le+4;let i=4;switch(a){case s.VerticalAlign.MIDDLE:i=(t-le)/2+4;break;case s.VerticalAlign.BOTTOM:i=t-le+4;break}o.save(),o.translateWithPrecision(r.startX+n,r.startY+i),o.fillStyle="#565656",o.fill(Xt),o.restore()}drawWith(o,r,e){var ee,P,G;const{primaryWithCoord:t,row:a,col:n,style:i,data:l,subUnitId:d}=r,u=t.isMergedMainCell?t.mergeInfo:t,c=(ee=l.dataValidation)==null?void 0:ee.rule,m=(P=l.dataValidation)==null?void 0:P.validator,f=l.fontRenderExtension,{leftOffset:h=0,rightOffset:p=0,topOffset:S=0,downOffset:D=0}=f||{};if(!c||!m||!m.skipDefaultFontRender(c)||(G=l.dataValidation)!=null&&G.isSkip)return;const C={startX:u.startX+h,endX:u.endX-p,startY:u.startY+S,endY:u.endY-D},M=C.endX-C.startX,V=C.endY-C.startY,y=this._ensureMap(d),T=this._generateKey(a,n),b=m.getListWithColor(c),L=re(l),U=`${L!=null?L:""}`,B=b.find(H=>H.label===U);let{tb:x,vt:A,ht:k}=i||{};if(x=x!=null?x:s.WrapStrategy.WRAP,A=A!=null?A:s.VerticalAlign.TOP,k=k!=null?k:s.HorizontalAlign.LEFT,c.renderMode===s.DataValidationRenderMode.ARROW){this._drawDownIcon(o,C,M,V,A),o.save(),o.translateWithPrecision(C.startX,C.startY),o.beginPath(),o.rect(0,0,M,V),o.clip();const H=M-le,{documentSkeleton:J,documents:K,docModel:w}=zt(U,this._localeService,i);x===s.WrapStrategy.WRAP&&w.updateDocumentDataPageSize(Math.max(H,1)),J.calculate(),J.getActualSize();const $=Z.getDocsSkeletonPageSize(J),{height:z,width:Q}=$;let te=0;switch(A){case s.VerticalAlign.BOTTOM:te=V-he-z;break;case s.VerticalAlign.MIDDLE:te=(V-he-z)/2;break;default:te=he;break}let F=0;switch(k){case s.HorizontalAlign.CENTER:F=(H-Q)/2;break;case s.HorizontalAlign.RIGHT:F=H-Q;break}o.translate(0,te),o.save(),o.translateWithPrecision(Oe,0),o.beginPath(),o.rect(0,0,H,z),o.clip(),K.render(o),o.translateWithPrecision(F,0),o.restore(),o.restore(),y.set(T,{left:C.endX+e.rowHeaderWidth-le,top:C.startY+e.columnHeaderHeight,width:le,height:V})}else{o.save(),o.translateWithPrecision(C.startX,C.startY),o.beginPath(),o.rect(0,0,M,V),o.clip();const H=M-Ce*2-Oe-le,{documentSkeleton:J,documents:K,docModel:w}=zt(U,this._localeService,i);x===s.WrapStrategy.WRAP&&w.updateDocumentDataPageSize(Math.max(H,1)),J.calculate();const $=Z.getDocsSkeletonPageSize(J),{height:z,width:Q}=$;let te=0;switch(A){case s.VerticalAlign.BOTTOM:te=V-he-z;break;case s.VerticalAlign.MIDDLE:te=(V-he-z)/2;break;default:te=he;break}let F=0;switch(k){case s.HorizontalAlign.CENTER:F=(H-Q)/2;break;case s.HorizontalAlign.RIGHT:F=H-Q;break}o.translate(Ce,te);const X=Math.max(M-Ce*2,1),Y=z;Z.Rect.drawWith(o,{width:X,height:Y,fill:(B==null?void 0:B.color)||Ve,radius:8}),o.save(),o.translateWithPrecision(Oe,0),o.beginPath(),o.rect(0,0,H,z),o.clip(),o.translateWithPrecision(F,0),K.render(o),o.restore(),o.translate(H+Oe+4,(z-Vn)/2),o.fillStyle=Cn,o.fill(Xt),o.restore(),y.set(T,{left:C.startX+Ce+e.rowHeaderWidth,top:C.startY+te+e.columnHeaderHeight,width:X,height:Y})}}calcCellAutoHeight(o){var D;const{primaryWithCoord:r,style:e,data:t}=o,a=r.isMergedMainCell?r.mergeInfo:r,n=t.fontRenderExtension,{leftOffset:i=0,rightOffset:l=0,topOffset:d=0,downOffset:u=0}=n||{},c=(D=t.dataValidation)==null?void 0:D.rule;if(!c||c.renderMode===s.DataValidationRenderMode.TEXT)return;const m={startX:a.startX+i,endX:a.endX-l,startY:a.startY+d,endY:a.endY-u},f=m.endX-m.startX,h=re(t),p=`${h!=null?h:""}`;let{tb:S}=e||{};if(S=S!=null?S:s.WrapStrategy.WRAP,c.renderMode===s.DataValidationRenderMode.ARROW){const C=f-le,{documentSkeleton:M,docModel:V}=lt(p,this._localeService,e);S===s.WrapStrategy.WRAP&&V.updateDocumentDataPageSize(Math.max(C,1)),M.calculate(),M.getActualSize();const y=Z.getDocsSkeletonPageSize(M),{height:T}=y;return T}else{const C=f-Ce*2-Oe-le,{documentSkeleton:M,docModel:V}=lt(p,this._localeService,e);S===s.WrapStrategy.WRAP&&V.updateDocumentDataPageSize(Math.max(C,1)),M.calculate();const y=Z.getDocsSkeletonPageSize(M),{height:T}=y;return T+he*2}}isHit(o,r){const{data:e,subUnitId:t,row:a,col:n}=r,l=this._ensureMap(t).get(this._generateKey(a,n)),d=e.dataValidation;if(!d||!l||d.rule.renderMode===s.DataValidationRenderMode.TEXT)return!1;const{top:u,left:c,width:m,height:f}=l,{x:h,y:p}=o;return h>=c&&h<=c+m&&p>=u&&p<=u+f}onPointerDown(o,r){if(r.button===2)return;const{unitId:e,subUnitId:t,row:a,col:n}=o,i={unitId:e,subUnitId:t,row:a,column:n};this._commandService.executeCommand(Ae.id,i)}},_(Vt,"padding",{l:Ce+Oe,r:le+Ce,t:he,b:he}),Vt);dt=Dn([Gt(0,I.Inject(s.LocaleService)),Gt(1,s.ICommandService)],dt);const In="LIST_RENDER_MODE_OPTION_INPUT";function Ye(o){var a;const{value:r,onChange:e}=o,t=N.useDependency(s.LocaleService);return v.jsx(O.FormLayout,{label:t.t("dataValidation.renderMode.label"),children:v.jsxs(O.RadioGroup,{value:`${(a=r.renderMode)!=null?a:s.DataValidationRenderMode.CUSTOM}`,onChange:n=>e({...r,renderMode:+n}),children:[v.jsx(O.Radio,{value:`${s.DataValidationRenderMode.CUSTOM}`,children:t.t("dataValidation.renderMode.chip")}),v.jsx(O.Radio,{value:`${s.DataValidationRenderMode.ARROW}`,children:t.t("dataValidation.renderMode.arrow")}),v.jsx(O.Radio,{value:`${s.DataValidationRenderMode.TEXT}`,children:t.t("dataValidation.renderMode.text")})]})})}Ye.componentKey=In;function ut(o){if(!o)return[];const r=new Set;return o.forEach(e=>{e.forEach(t=>{const a=re(t);a!=null&&r.add(a.toString())})}),[...r]}const Mn=["if","indirect","choose","offset"];function yn(o,r){if(!s.isFormulaString(o)||ie.isReferenceString(o.slice(1)))return!0;const t=r.sequenceNodesBuilder(o);return t&&t.some(a=>typeof a=="object"&&a.nodeType===ie.sequenceNodeType.FUNCTION&&Mn.indexOf(a.token.toLowerCase())>-1)}class Qt extends R.BaseDataValidator{constructor(){super(...arguments);_(this,"formulaService",this.injector.get(g.DataValidationFormulaService));_(this,"_lexer",this.injector.get(ie.LexerTreeBuilder));_(this,"id",s.DataValidationType.LIST);_(this,"title","dataValidation.list.title");_(this,"operators",[]);_(this,"scopes",["sheet"]);_(this,"formulaInput",Wt);_(this,"canvasRender",this.injector.createInstance(dt));_(this,"dropdown",ta);_(this,"optionsInput",Ye.componentKey)}skipDefaultFontRender(e){return e.renderMode!==s.DataValidationRenderMode.TEXT}validatorFormula(e){var n;const t=!s.Tools.isBlank(e.formula1),a=yn((n=e.formula1)!=null?n:"",this._lexer);return{success:!!(t&&a),formula1:t?a?void 0:this.localeService.t("dataValidation.validFail.listInvalid"):this.localeService.t("dataValidation.validFail.list")}}parseCellValue(e){const t=e.toString();return ye(t)}async parseFormula(e,t,a){var l;const{formula1:n=""}=e,i=await this.formulaService.getRuleFormulaResult(t,a,e.uid);return{formula1:s.isFormulaString(n)?ut((l=i==null?void 0:i[0])==null?void 0:l.result):ye(n),formula2:void 0}}async isValidType(e,t,a){const{value:n}=e,{formula1:i=[]}=t;return this.parseCellValue(n).every(d=>i.includes(d))}generateRuleName(){return this.localeService.t("dataValidation.list.name")}generateRuleErrorMessage(){return this.localeService.t("dataValidation.list.error")}getList(e,t,a){var f,h,p;const{formula1:n=""}=e,i=this.injector.get(s.IUniverInstanceService),l=(f=t?i.getUniverSheetInstance(t):void 0)!=null?f:i.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET);if(!l)return[];const d=(h=a?l.getSheetBySheetId(a):void 0)!=null?h:l.getActiveSheet(),u=l.getUnitId(),c=d.getSheetId(),m=this.formulaService.getRuleFormulaResultSync(u,c,e.uid);return s.isFormulaString(n)?ut((p=m==null?void 0:m[0])==null?void 0:p.result):ye(n)}async getListAsync(e,t,a){var f,h,p;const{formula1:n=""}=e,i=this.injector.get(s.IUniverInstanceService),l=(f=t?i.getUniverSheetInstance(t):void 0)!=null?f:i.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET);if(!l)return[];const d=(h=a?l.getSheetBySheetId(a):void 0)!=null?h:l.getActiveSheet(),u=l.getUnitId(),c=d.getSheetId(),m=await this.formulaService.getRuleFormulaResult(u,c,e.uid);return s.isFormulaString(n)?ut((p=m==null?void 0:m[0])==null?void 0:p.result):ye(n)}getListWithColor(e,t,a){const n=this.getList(e,t,a),i=(e.formula2||"").split(",");return n.map((l,d)=>({label:l,color:i[d]}))}getListWithColorMap(e,t,a){const n=this.getListWithColor(e,t,a),i={};return n.forEach(l=>{l.color&&(i[l.label]=l.color)}),i}}function qe(o){let r=o;return typeof o=="string"?((o.startsWith("¥")||o.startsWith("$"))&&(r=o.slice(1)),+r):+o}class wn extends R.BaseDataValidator{constructor(){super(...arguments);_(this,"_formulaService",this.injector.get(g.DataValidationFormulaService));_(this,"id",s.DataValidationType.DECIMAL);_(this,"title","dataValidation.decimal.title");_(this,"operators",[s.DataValidationOperator.BETWEEN,s.DataValidationOperator.EQUAL,s.DataValidationOperator.GREATER_THAN,s.DataValidationOperator.GREATER_THAN_OR_EQUAL,s.DataValidationOperator.LESS_THAN,s.DataValidationOperator.LESS_THAN_OR_EQUAL,s.DataValidationOperator.NOT_BETWEEN,s.DataValidationOperator.NOT_EQUAL]);_(this,"scopes",["sheet"]);_(this,"formulaInput",Te);_(this,"dropDownInput")}_isFormulaOrNumber(e){return!s.Tools.isBlank(e)&&(s.isFormulaString(e)||!Number.isNaN(+e))}async isValidType(e,t,a){const{value:n}=e;return!Number.isNaN(qe(n))}transform(e,t,a){const{value:n}=e;return{...e,value:qe(n)}}_parseNumber(e){return e==null?Number.NaN:+e}async parseFormula(e,t,a){var u,c,m,f,h,p,S,D;const n=await this._formulaService.getRuleFormulaResult(t,a,e.uid),{formula1:i,formula2:l}=e;return{formula1:this._parseNumber(s.isFormulaString(i)?(f=(m=(c=(u=n==null?void 0:n[0])==null?void 0:u.result)==null?void 0:c[0])==null?void 0:m[0])==null?void 0:f.v:i),formula2:this._parseNumber(s.isFormulaString(l)?(D=(S=(p=(h=n==null?void 0:n[1])==null?void 0:h.result)==null?void 0:p[0])==null?void 0:S[0])==null?void 0:D.v:l)}}validatorFormula(e){const t=e.operator;if(!t)return{success:!1};const a=s.Tools.isDefine(e.formula1)&&this._isFormulaOrNumber(e.formula1),n=s.Tools.isDefine(e.formula2)&&this._isFormulaOrNumber(e.formula2),i=Fe.includes(t),l=this.localeService.t("dataValidation.validFail.number");return i?{success:a&&n,formula1:a?void 0:l,formula2:n?void 0:l}:{success:a,formula1:a?"":l}}async validatorIsEqual(e,t,a){const{formula1:n}=t,{value:i}=e;return Number.isNaN(n)?!0:i===n}async validatorIsNotEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value!==n}async validatorIsBetween(e,t,a){const{formula1:n,formula2:i}=t;if(Number.isNaN(n)||Number.isNaN(i))return!0;const l=Math.min(n,i),d=Math.max(n,i);return e.value>=l&&e.value<=d}async validatorIsNotBetween(e,t,a){const{formula1:n,formula2:i}=t;if(Number.isNaN(n)||Number.isNaN(i))return!0;const l=Math.min(n,i),d=Math.max(n,i);return e.value<l||e.value>d}async validatorIsGreaterThan(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value>n}async validatorIsGreaterThanOrEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value>=n}async validatorIsLessThan(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value<n}async validatorIsLessThanOrEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value<=n}}const On="{FORMULA1}",En="{FORMULA2}";class Tn extends R.BaseDataValidator{constructor(){super(...arguments);_(this,"id",s.DataValidationType.TEXT_LENGTH);_(this,"title","dataValidation.textLength.title");_(this,"operators",[s.DataValidationOperator.BETWEEN,s.DataValidationOperator.EQUAL,s.DataValidationOperator.GREATER_THAN,s.DataValidationOperator.GREATER_THAN_OR_EQUAL,s.DataValidationOperator.LESS_THAN,s.DataValidationOperator.LESS_THAN_OR_EQUAL,s.DataValidationOperator.NOT_BETWEEN,s.DataValidationOperator.NOT_EQUAL]);_(this,"scopes",["sheet"]);_(this,"formulaInput",Te);_(this,"_formulaService",this.injector.get(g.DataValidationFormulaService))}_isFormulaOrInt(e){return!s.Tools.isBlank(e)&&(s.isFormulaString(e)||!Number.isNaN(+e)&&Number.isInteger(+e))}validatorFormula(e){const t=e.operator;if(!t)return{success:!1};const a=s.Tools.isDefine(e.formula1)&&this._isFormulaOrInt(e.formula1),n=s.Tools.isDefine(e.formula2)&&this._isFormulaOrInt(e.formula2),i=Fe.includes(t),l=this.localeService.t("dataValidation.validFail.number");return i?{success:a&&n,formula1:a?void 0:l,formula2:n?void 0:l}:{success:a,formula1:l}}_parseNumber(e){return e==null?Number.NaN:+e}_isValidFormula(e){return!Number.isNaN(e)}async parseFormula(e,t,a){var d,u,c,m,f,h,p,S;const n=await this._formulaService.getRuleFormulaResult(t,a,e.uid),{formula1:i,formula2:l}=e;return{formula1:this._parseNumber(s.isFormulaString(i)?(m=(c=(u=(d=n==null?void 0:n[0])==null?void 0:d.result)==null?void 0:u[0])==null?void 0:c[0])==null?void 0:m.v:i),formula2:this._parseNumber(s.isFormulaString(l)?(S=(p=(h=(f=n==null?void 0:n[1])==null?void 0:f.result)==null?void 0:h[0])==null?void 0:p[0])==null?void 0:S.v:l)}}transform(e,t,a){return{...e,value:e.value.toString().length}}async isValidType(e,t,a){const{value:n}=e;return typeof n=="string"||typeof n=="number"}async validatorIsEqual(e,t,a){const{formula1:n}=t;return s.Tools.isDefine(n)?e.value===n:!1}async validatorIsNotEqual(e,t,a){const{formula1:n}=t;return s.Tools.isDefine(n)?e.value!==n:!1}async validatorIsBetween(e,t,a){const{formula1:n,formula2:i}=t,{value:l}=e;if(!this._isValidFormula(n)||!this._isValidFormula(i))return!1;const d=Math.max(n,i),u=Math.min(n,i);return l>=u&&l<=d}async validatorIsNotBetween(e,t,a){const{formula1:n,formula2:i}=t,{value:l}=e;if(!this._isValidFormula(n)||!this._isValidFormula(i))return!1;const d=Math.max(n,i),u=Math.min(n,i);return l<u||l>d}async validatorIsGreaterThan(e,t,a){const{formula1:n}=t,{value:i}=e;return this._isValidFormula(n)?i>n:!1}async validatorIsGreaterThanOrEqual(e,t,a){const{formula1:n}=t,{value:i}=e;return this._isValidFormula(n)?i>=n:!1}async validatorIsLessThan(e,t,a){const{formula1:n}=t,{value:i}=e;return this._isValidFormula(n)?i<n:!1}async validatorIsLessThanOrEqual(e,t,a){const{formula1:n}=t,{value:i}=e;return this._isValidFormula(n)?i<=n:!1}generateRuleErrorMessage(e){var a,n;return e.operator?`${this.localeService.t(R.TextLengthErrorTitleMap[e.operator]).replace(On,(a=e.formula1)!=null?a:"").replace(En,(n=e.formula2)!=null?n:"")}`:this.titleStr}}class Fn extends R.BaseDataValidator{constructor(){super(...arguments);_(this,"_formulaService",this.injector.get(g.DataValidationFormulaService));_(this,"id",s.DataValidationType.WHOLE);_(this,"title","dataValidation.whole.title");_(this,"operators",[s.DataValidationOperator.BETWEEN,s.DataValidationOperator.EQUAL,s.DataValidationOperator.GREATER_THAN,s.DataValidationOperator.GREATER_THAN_OR_EQUAL,s.DataValidationOperator.LESS_THAN,s.DataValidationOperator.LESS_THAN_OR_EQUAL,s.DataValidationOperator.NOT_BETWEEN,s.DataValidationOperator.NOT_EQUAL]);_(this,"scopes",["sheet"]);_(this,"formulaInput",Te);_(this,"dropDownInput")}_isFormulaOrInt(e){return!s.Tools.isBlank(e)&&(s.isFormulaString(e)||!Number.isNaN(+e)&&Number.isInteger(+e))}async isValidType(e,t,a){const{value:n}=e,i=qe(n);return!Number.isNaN(i)&&Number.isInteger(i)}transform(e,t,a){const{value:n}=e;return{...e,value:qe(n)}}_parseNumber(e){return e==null?Number.NaN:+e}async parseFormula(e,t,a){var u,c,m,f,h,p,S,D;const n=await this._formulaService.getRuleFormulaResult(t,a,e.uid),{formula1:i,formula2:l}=e;return{formula1:this._parseNumber(s.isFormulaString(i)?(f=(m=(c=(u=n==null?void 0:n[0])==null?void 0:u.result)==null?void 0:c[0])==null?void 0:m[0])==null?void 0:f.v:i),formula2:this._parseNumber(s.isFormulaString(l)?(D=(S=(p=(h=n==null?void 0:n[1])==null?void 0:h.result)==null?void 0:p[0])==null?void 0:S[0])==null?void 0:D.v:l)}}validatorFormula(e){const t=e.operator;if(!t)return{success:!1};const a=s.Tools.isDefine(e.formula1)&&this._isFormulaOrInt(e.formula1),n=s.Tools.isDefine(e.formula2)&&this._isFormulaOrInt(e.formula2),i=Fe.includes(t),l=this.localeService.t("dataValidation.validFail.number");return i?{success:a&&n,formula1:a?void 0:l,formula2:n?void 0:l}:{success:a,formula1:l}}async validatorIsEqual(e,t,a){const{formula1:n}=t,{value:i}=e;return Number.isNaN(n)?!0:i===n}async validatorIsNotEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value!==n}async validatorIsBetween(e,t,a){const{formula1:n,formula2:i}=t;if(Number.isNaN(n)||Number.isNaN(i))return!0;const l=Math.min(n,i),d=Math.max(n,i);return e.value>=l&&e.value<=d}async validatorIsNotBetween(e,t,a){const{formula1:n,formula2:i}=t;if(Number.isNaN(n)||Number.isNaN(i))return!0;const l=Math.min(n,i),d=Math.max(n,i);return e.value<l||e.value>d}async validatorIsGreaterThan(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value>n}async validatorIsGreaterThanOrEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value>=n}async validatorIsLessThan(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value<n}async validatorIsLessThanOrEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value<=n}}const Kt=4,bn=0,ct=4,Zt=4,mt=6,Ge=6,Re=14;function Ln(o,r){const e=Z.FontCache.getTextSize(o,r),t=e.width+Kt*2,{ba:a,bd:n}=e,i=a+n;return{width:t,height:i+bn*2,ba:a}}function Jt(o,r,e,t){const a=e-Re-mt,n=t-Ge*2,i=o.map(c=>({layout:Ln(c,r),text:c}));let l;const d=[];i.forEach(c=>{const{layout:m}=c,{width:f,height:h}=m;!l||l.width+f+ct>a?(l={width:f,height:h,items:[{...c,left:0}]},d.push(l)):(l.items.push({...c,left:l.width+ct}),l.width=l.width+f+ct)});let u=0;return d.forEach((c,m)=>{m===d.length-1?u+=c.height:u+=c.height+Zt}),{lines:d,totalHeight:u,contentWidth:a,contentHeight:n,cellAutoHeight:u+Ge*2}}const Nn=8;class An extends Z.Shape{static drawWith(r,e){const{fontFamily:t,fontString:a,fontSize:n,info:i,fill:l,color:d}=e,{layout:u,text:c}=i;r.save(),Z.Rect.drawWith(r,{width:u.width,height:u.height,radius:Nn,fill:l||Ve}),r.translateWithPrecision(Kt,u.ba),r.font=a,r.fillStyle=d,r.fillText(c,0,0),r.restore()}}var Pn=Object.defineProperty,jn=Object.getOwnPropertyDescriptor,Un=(o,r,e,t)=>{for(var a=t>1?void 0:t?jn(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&Pn(r,e,a),a},xn=(o,r)=>(e,t)=>r(e,t,o);const Bn=new Path2D("M3.32201 4.84556C3.14417 5.05148 2.85583 5.05148 2.67799 4.84556L0.134292 1.90016C-0.152586 1.56798 0.0505937 1 0.456301 1L5.5437 1C5.94941 1 6.15259 1.56798 5.86571 1.90016L3.32201 4.84556Z");let ht=class{constructor(o){_(this,"zIndex");_(this,"_dropdownInfoMap",new Map);this._commandService=o}_ensureMap(o){let r=this._dropdownInfoMap.get(o);return r||(r=new Map,this._dropdownInfoMap.set(o,r)),r}_generateKey(o,r){return`${o}.${r}`}_drawDownIcon(o,r,e,t,a){const n=e-Re+4;let i=4;switch(a){case s.VerticalAlign.MIDDLE:i=(t-Re)/2+4;break;case s.VerticalAlign.BOTTOM:i=t-Re+4;break}o.save(),o.translateWithPrecision(r.startX+n,r.startY+i),o.fillStyle="#565656",o.fill(Bn),o.restore()}drawWith(o,r,e,t){var $,z,Q;const{primaryWithCoord:a,row:n,col:i,style:l,data:d,subUnitId:u}=r,c=a.isMergedMainCell?a.mergeInfo:a,m=d.fontRenderExtension,{leftOffset:f=0,rightOffset:h=0,topOffset:p=0,downOffset:S=0}=m||{},D=d.dataValidation,C=this._ensureMap(u),M=this._generateKey(n,i);if(!D||($=d.dataValidation)!=null&&$.isSkip)return;const V={startX:c.startX+f,endX:c.endX-h,startY:c.startY+p,endY:c.endY-S},y=V.endX-V.startX,T=V.endY-V.startY,{cl:b}=l||{},L=(z=typeof b=="object"?b==null?void 0:b.rgb:b)!=null?z:"#000",U=Z.getFontStyleString(l!=null?l:void 0),{rule:B,validator:x}=D,A=x,{vt:k,ht:ee}=l||{},P=k!=null?k:s.VerticalAlign.MIDDLE,G=(Q=re(d))!=null?Q:"",H=A.parseCellValue(G),J=A.getListWithColorMap(B),K=Jt(H,U,y,T);this._drawDownIcon(o,V,y,T,P),o.save(),o.translateWithPrecision(V.startX,V.startY),o.beginPath(),o.rect(0,0,y-Re,T),o.clip(),o.translateWithPrecision(mt,Ge);let w=0;switch(P){case s.VerticalAlign.MIDDLE:w=(K.contentHeight-K.totalHeight)/2;break;case s.VerticalAlign.BOTTOM:w=K.contentHeight-K.totalHeight;break}o.translateWithPrecision(0,w),K.lines.forEach((te,F)=>{o.save();const{width:X,height:Y,items:ne}=te;let pe=0;switch(ee){case s.HorizontalAlign.RIGHT:pe=K.contentWidth-X;break;case s.HorizontalAlign.CENTER:pe=(K.contentWidth-X)/2;break}o.translate(pe,F*(Y+Zt)),ne.forEach(Ct=>{o.save(),o.translateWithPrecision(Ct.left,0),An.drawWith(o,{...U,info:Ct,color:L,fill:J[Ct.text]}),o.restore()}),o.restore()}),o.restore(),C.set(M,{left:V.startX,top:V.startY,width:K.contentWidth+mt+Re,height:K.contentHeight+Ge*2})}calcCellAutoHeight(o){var y;const{primaryWithCoord:r,style:e,data:t}=o,a=t.fontRenderExtension,{leftOffset:n=0,rightOffset:i=0,topOffset:l=0,downOffset:d=0}=a||{},u=r.isMergedMainCell?r.mergeInfo:r,c={startX:u.startX+n,endX:u.endX-i,startY:u.startY+l,endY:u.endY-d},m=t.dataValidation;if(!m)return;const f=c.endX-c.startX,h=c.endY-c.startY,p=(y=re(t))!=null?y:"",{validator:S}=m,C=S.parseCellValue(p),M=Z.getFontStyleString(e!=null?e:void 0);return Jt(C,M,f,h).cellAutoHeight}isHit(o,r){const{primaryWithCoord:e}=r,t=e.isMergedMainCell?e.mergeInfo:e,{endX:a}=t,{x:n}=o;return n>=a-Re&&n<=a}onPointerDown(o,r){if(r.button===2)return;const{unitId:e,subUnitId:t,row:a,col:n}=o,i={unitId:e,subUnitId:t,row:a,column:n};this._commandService.executeCommand(Ae.id,i)}};ht=Un([xn(0,s.ICommandService)],ht);class $n extends Qt{constructor(){super(...arguments);_(this,"id",s.DataValidationType.LIST_MULTIPLE);_(this,"title","dataValidation.listMultiple.title");_(this,"canvasRender",this.injector.createInstance(ht))}skipDefaultFontRender(){return!0}}const ea="data-validation-single",ft="sheet.menu.data-validation";function Wn(o){return{id:ft,type:W.MenuItemType.SUBITEMS,positions:[W.MenuPosition.TOOLBAR_START],group:W.MenuGroup.TOOLBAR_FORMULAS_INSERT,icon:ea,tooltip:"dataValidation.title",hidden$:W.getMenuHiddenObservable(o,s.UniverInstanceType.UNIVER_SHEET),disabled$:j.getCurrentRangeDisable$(o,{workbookTypes:[q.WorkbookEditablePermission],worksheetTypes:[q.WorksheetSetCellStylePermission,q.WorksheetEditPermission],rangeTypes:[q.RangeProtectionPermissionEditPoint]})}}function Hn(o){return{id:Ee.id,title:"dataValidation.panel.title",type:W.MenuItemType.BUTTON,positions:[ft]}}function kn(o){return{id:et.id,title:"dataValidation.panel.add",type:W.MenuItemType.BUTTON,positions:[ft]}}var Yn=Object.defineProperty,qn=Object.getOwnPropertyDescriptor,Gn=(o,r,e,t)=>{for(var a=t>1?void 0:t?qn(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&Yn(r,e,a),a},ge=(o,r)=>(e,t)=>r(e,t,o);g.DataValidationController=class extends s.RxDisposable{constructor(r,e,t,a,n,i,l,d){super(),this._univerInstanceService=r,this._sheetDataValidationService=e,this._dataValidatorRegistryService=t,this._injector=a,this._componentManger=n,this._selectionManagerService=i,this._sheetInterceptorService=l,this._dataValidationModel=d,this._init()}_init(){this._registerValidators(),this._initInstanceChange(),this._componentManger.register(ea,bt),this._initCommandInterceptor()}_registerValidators(){[wn,Fn,Tn,gn,cn,Qt,$n,nn].forEach(r=>{const e=this._injector.createInstance(r);this.disposeWithMe(this._dataValidatorRegistryService.register(e)),this.disposeWithMe({dispose:()=>{this._injector.delete(r)}})})}_initInstanceChange(){const r=new s.DisposableCollection;this._univerInstanceService.getCurrentTypeOfUnit$(s.UniverInstanceType.UNIVER_SHEET).subscribe(e=>{r.dispose(),e&&(this._sheetDataValidationService.switchCurrent(e.getUnitId(),e.getActiveSheet().getSheetId()),r.add(s.toDisposable(e.activeSheet$.subscribe(t=>{if(t){const a=e.getUnitId(),n=t.getSheetId();this._sheetDataValidationService.switchCurrent(a,n)}}))))}),this.disposeWithMe(r)}_initCommandInterceptor(){this._sheetInterceptorService.interceptCommand({getMutations:r=>{if(r.id===q.ClearSelectionAllCommand.id){const e=this._univerInstanceService.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET),t=e.getUnitId(),n=e.getActiveSheet().getSheetId(),i=this._selectionManagerService.getSelectionRanges(),l=this._dataValidationModel.ensureManager(t,n),d=l.getRuleObjectMatrix().clone();i&&d.removeRange(i);const u=d.diff(l.getDataValidations()),{redoMutations:c,undoMutations:m}=Ie(t,n,u);return{undos:m,redos:c}}return{undos:[],redos:[]}}})}},g.DataValidationController=Gn([s.OnLifecycle(s.LifecycleStages.Rendered,g.DataValidationController),ge(0,s.IUniverInstanceService),ge(1,I.Inject(g.SheetDataValidationService)),ge(2,I.Inject(R.DataValidatorRegistryService)),ge(3,I.Inject(I.Injector)),ge(4,I.Inject(W.ComponentManager)),ge(5,I.Inject(q.SelectionManagerService)),ge(6,I.Inject(q.SheetInterceptorService)),ge(7,I.Inject(R.DataValidationModel))],g.DataValidationController);const pt={dataValidationListButtons:"univer-data-validation-list-buttons",dataValidationListButton:"univer-data-validation-list-button"};function Xn(){const o=N.useDependency(s.IUniverInstanceService),r=W.useObservable(()=>o.getCurrentTypeOfUnit$(s.UniverInstanceType.UNIVER_SHEET),void 0,void 0,[]);return r?v.jsx(zn,{workbook:r}):null}function zn(o){const r=N.useDependency(R.DataValidationModel),e=N.useDependency(s.IUniverInstanceService),t=N.useDependency(s.ICommandService),a=N.useDependency(I.Injector),n=N.useDependency(ce);N.useDependency(g.DataValidationController);const i=N.useDependency(s.LocaleService),[l,d]=E.useState([]),{workbook:u}=o,c=W.useObservable(u.activeSheet$,void 0,!0),m=u.getUnitId(),f=c==null?void 0:c.getSheetId(),h=r.ensureManager(m,f);E.useEffect(()=>{d(h.getDataValidations());const V=h.dataValidations$.subscribe(y=>{d([...y])});return()=>{V.unsubscribe()}},[h]);const p=async()=>{const V=R.createDefaultNewRule(a),y={unitId:m,subUnitId:f,rule:V};await t.executeCommand(je.id,y),n.setActiveRule({unitId:m,subUnitId:f,rule:V})},S=()=>{t.executeCommand(R.RemoveAllDataValidationCommand.id,{unitId:m,subUnitId:f})},C=(V=>{const T=e.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET).getActiveSheet();return V.map(L=>{const{ranges:U}=L;return(U==null?void 0:U.some(x=>{var G,H;const{startRow:A,startColumn:k,endRow:ee,endColumn:P}=x;for(let J=A;J<=ee;J++)for(let K=k;K<=P;K++){const w=(H=(G=T.getCell(J,K))==null?void 0:G.selectionProtection)==null?void 0:H[0];if((w==null?void 0:w[Ue.Edit])===!1||(w==null?void 0:w[Ue.View])===!1)return!0}return!1}))?{...L,disable:!0}:{...L}})})(l),M=C==null?void 0:C.some(V=>V.disable);return v.jsxs("div",{children:[C==null?void 0:C.map(V=>{var y;return v.jsx(Ua,{unitId:m,subUnitId:f,onClick:()=>{V.disable||n.setActiveRule({unitId:m,subUnitId:f,rule:V})},rule:V,disable:(y=V.disable)!=null?y:!1},V.uid)}),v.jsxs("div",{className:pt.dataValidationListButtons,children:[l.length&&!M?v.jsx(O.Button,{className:pt.dataValidationListButton,onClick:S,children:i.t("dataValidation.panel.removeAll")}):null,v.jsx(O.Button,{className:pt.dataValidationListButton,type:"primary",onClick:p,children:i.t("dataValidation.panel.add")})]})]})}const Qn=()=>{const o=N.useDependency(ce),r=W.useObservable(o.activeRule$,o.activeRule);return r?v.jsx(ja,{},r.rule.uid):v.jsx(Xn,{})},fe={dvListDropdown:"univer-dv-list-dropdown",dvListDropdownTitle:"univer-dv-list-dropdown-title",dvListDropdownList:"univer-dv-list-dropdown-list",dvListDropdownListContainer:"univer-dv-list-dropdown-list-container",dvListDropdownSelectedIcon:"univer-dv-list-dropdown-selected-icon",dvListDropdownItemContainer:"univer-dv-list-dropdown-item-container",dvListDropdownItem:"univer-dv-list-dropdown-item",dvListDropdownSplit:"univer-dv-list-dropdown-split",dvListDropdownEdit:"univer-dv-list-dropdown-edit"},Kn=o=>{const{value:r,onChange:e,multiple:t,options:a,title:n,onEdit:i,style:l}=o;return v.jsxs("div",{className:fe.dvListDropdown,style:l,children:[v.jsx("div",{className:fe.dvListDropdownTitle,children:n}),v.jsx("div",{className:fe.dvListDropdownList,children:v.jsx(O.Scrollbar,{children:v.jsx("div",{className:fe.dvListDropdownListContainer,children:a.map((d,u)=>{const c=r.indexOf(d.value)>-1,m=()=>{let f;c?f=new Set(r.filter(p=>p!==d.value)):f=new Set(t?[...r,d.value]:[d.value]);const h=[];a.forEach(p=>{f.has(p.value)&&h.push(p.value)}),e(h)};return v.jsxs("div",{className:fe.dvListDropdownItemContainer,onClick:m,children:[v.jsx("div",{className:fe.dvListDropdownItem,style:{background:d.color||Ve},children:d.label}),v.jsx("div",{className:fe.dvListDropdownSelectedIcon,children:c?v.jsx(Ia,{}):null})]},u)})})})}),v.jsx("div",{className:fe.dvListDropdownSplit}),v.jsx("div",{className:fe.dvListDropdownEdit,children:v.jsx("a",{onClick:i,children:"编辑"})})]})};function Zn(o){var U,B;const{location:r,hideFn:e}=o,{worksheet:t,row:a,col:n,unitId:i,subUnitId:l}=r,d=N.useDependency(s.ICommandService),u=N.useDependency(s.LocaleService),[c,m]=E.useState(""),f=N.useDependency(j.IEditorBridgeService),h=O.RectPopup.useContext(),p=h.right-h.left;if(!t)return null;const S=t.getCell(a,n),D=(U=S==null?void 0:S.dataValidation)==null?void 0:U.rule,C=(B=S==null?void 0:S.dataValidation)==null?void 0:B.validator,M=(D==null?void 0:D.renderMode)===s.DataValidationRenderMode.CUSTOM||(D==null?void 0:D.renderMode)===void 0;if(!S||!D||!C)return;const V=D.type===s.DataValidationType.LIST_MULTIPLE,y=C.getListWithColor(D,i,l),T=c||Ya(S),b=ye(T),L=()=>{d.executeCommand(Ee.id,{ruleId:D.uid}),e()};return v.jsx(Kn,{style:{minWidth:p,maxWidth:Math.max(p,200)},title:V?u.t("dataValidation.listMultiple.dropdown"):u.t("dataValidation.list.dropdown"),value:b,multiple:V,onChange:x=>{const A=xt(x),k={unitId:i,subUnitId:l,range:{startColumn:n,endColumn:n,startRow:a,endRow:a},value:{v:A,p:null,f:null,si:null}};f.isVisible()&&f.changeVisible({visible:!1,keycode:W.KeyCode.ESC,eventType:Z.DeviceInputEventType.Keyboard}),d.executeCommand(q.SetRangeValuesCommand.id,k),m(A),V||e()},options:y.map(x=>({label:x.label,value:x.label,color:M?x.color:"transparent"})),onEdit:L})}var Jn=Object.defineProperty,er=Object.getOwnPropertyDescriptor,tr=(o,r,e,t)=>{for(var a=t>1?void 0:t?er(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&Jn(r,e,a),a},be=(o,r)=>(e,t)=>r(e,t,o);g.DataValidationRejectInputController=class extends s.Disposable{constructor(r,e,t,a,n){super(),this._editorBridgeService=r,this._dataValidationModel=e,this._dataValidatorRegistryService=t,this._dialogService=a,this._localeService=n,this._initEditorBridgeInterceptor()}_initEditorBridgeInterceptor(){this._editorBridgeService.interceptor.intercept(this._editorBridgeService.interceptor.getInterceptPoints().AFTER_CELL_EDIT_ASYNC,{handler:async(r,e,t)=>{const a=await r,{worksheet:n,row:i,col:l,unitId:d,subUnitId:u}=e,c=this._dataValidationModel.ensureManager(d,u),m=c.getRuleIdByLocation(i,l),f=m?c.getRuleById(m):void 0;if(!f||f.errorStyle!==s.DataValidationErrorStyle.STOP)return t(Promise.resolve(a));const h=await this._dataValidatorRegistryService.getValidatorItem(f.type);if(!h||await h.validator({value:re(a),row:i,column:l,unitId:d,subUnitId:u},f))return t(Promise.resolve(a));const S=n.getCellRaw(i,l);return this._dialogService.open({width:368,title:{title:this._localeService.t("dataValidation.alert.title")},id:"reject-input-dialog",children:{title:h.getRuleFinalError(f)},footer:{title:E.createElement(O.Button,{type:"primary",onClick:()=>this._dialogService.close("reject-input-dialog")},this._localeService.t("dataValidation.alert.ok"))},onClose:()=>{this._dialogService.close("reject-input-dialog")}}),t(Promise.resolve(S))}})}showReject(r){this._dialogService.open({width:368,title:{title:this._localeService.t("dataValidation.alert.title")},id:"reject-input-dialog",children:{title:r},footer:{title:E.createElement(O.Button,{type:"primary",onClick:()=>this._dialogService.close("reject-input-dialog")},this._localeService.t("dataValidation.alert.ok"))},onClose:()=>{this._dialogService.close("reject-input-dialog")}})}},g.DataValidationRejectInputController=tr([s.OnLifecycle(s.LifecycleStages.Ready,g.DataValidationRejectInputController),be(0,j.IEditorBridgeService),be(1,I.Inject(R.DataValidationModel)),be(2,I.Inject(R.DataValidatorRegistryService)),be(3,W.IDialogService),be(4,I.Inject(s.LocaleService))],g.DataValidationRejectInputController);const ar={dvDateDropdown:"univer-dv-date-dropdown"};function nr(o){var M,V,y;const{location:r,hideFn:e}=o,{worksheet:t,row:a,col:n,unitId:i,subUnitId:l}=r,d=N.useDependency(s.ICommandService),u=N.useDependency(g.DataValidationRejectInputController),[c,m]=E.useState();if(!t)return null;const f=t.getCell(a,n),h=(M=f==null?void 0:f.dataValidation)==null?void 0:M.rule,p=(V=f==null?void 0:f.dataValidation)==null?void 0:V.validator;if(!f||!h||!p)return;const S=re(f),D=(y=p.transformDate(S))!=null?y:Se(),C=D.isValid()?D:Se();return v.jsx("div",{className:ar.dvDateDropdown,children:v.jsx(O.DatePanel,{pickerValue:c!=null?c:C,onSelect:async T=>{const b=T.format("YYYY/MM/DD");h.errorStyle!==s.DataValidationErrorStyle.STOP||await p.validator({value:b,unitId:i,subUnitId:l,row:a,column:n},h)?d.executeCommand(q.SetRangeValuesCommand.id,{unitId:i,subUnitId:l,range:{startColumn:n,endColumn:n,startRow:a,endRow:a},value:{v:b,p:null,f:null,si:null}}):u.showReject(p.getRuleFinalError(h)),e()},onPanelChange:T=>{m(T)}})})}const ta="data-validation.list.dropdown",aa="data-validation.date.dropdown";var rr=Object.defineProperty,or=Object.getOwnPropertyDescriptor,ir=(o,r,e,t)=>{for(var a=t>1?void 0:t?or(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&rr(r,e,a),a},oe=(o,r)=>(e,t)=>r(e,t,o);const sr={},lr={tr:{size:6,color:"#fe4b4b"}};g.DataValidationRenderController=class extends s.RxDisposable{constructor(r,e,t,a,n,i,l,d,u,c,m,f,h,p){super(),this._config=r,this._componentManager=e,this._menuService=t,this._dataValidationModel=a,this._sheetSkeletonManagerService=n,this._renderManagerService=i,this._univerInstanceService=l,this._dataValidatorRegistryService=d,this._editorBridgeService=u,this._dropdownManagerService=c,this._sheetInterceptorService=m,this._injector=f,this._autoHeightController=h,this._commandService=p,this._init()}_init(){this._initComponents(),this._initMenu(),this._initSkeletonChange(),this._initDropdown(),this._initViewModelIntercept(),this._initAutoHeight()}_initMenu(){const{menu:r={}}=this._config;[Wn,Hn,kn].forEach(e=>{this.disposeWithMe(this._menuService.addMenuItem(e(this._injector),r))})}_initComponents(){[[wt,Qn],[Mt,ca],[ta,Zn],[aa,nr],[Ye.componentKey,Ye],...Ja].forEach(([r,e])=>{this.disposeWithMe(this._componentManager.register(r,e))})}_initDropdown(){this.disposeWithMe(this._editorBridgeService.visible$.subscribe(r=>{if(!r.visible)return;const e=this._editorBridgeService.getEditCellState();if(e){const{unitId:t,sheetId:a,row:n,column:i}=e,l=this._univerInstanceService.getUniverSheetInstance(t);if(!l)return;const u=this._dataValidationModel.ensureManager(t,a).getRuleByLocation(n,i);if(!u)return;const c=this._dataValidatorRegistryService.getValidatorItem(u.type);if(!(c!=null&&c.dropdown))return;const m=l.getActiveSheet(),f=this._dropdownManagerService.activeDropdown,h=f==null?void 0:f.location;if(h&&h.unitId===t&&h.subUnitId===a&&h.row===n&&h.col===i)return;this._dropdownManagerService.showDropdown({location:{unitId:t,subUnitId:a,row:n,col:i,workbook:l,worksheet:m},componentKey:c.dropdown,onHide:()=>{}})}}))}_initSkeletonChange(){const r=()=>{const e=this._univerInstanceService.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET);if(!e)return;const t=e.getUnitId(),a=e.getActiveSheet().getSheetId(),n=this._sheetSkeletonManagerService.getOrCreateSkeleton({unitId:t,sheetId:a}),i=this._renderManagerService.getRenderById(t);n==null||n.makeDirty(!0),n==null||n.calculate(),i&&i.mainComponent.makeForceDirty()};this.disposeWithMe(this._dataValidationModel.ruleChange$.subscribe(()=>{r()})),this.disposeWithMe(this._dataValidationModel.validStatusChange$.subscribe(()=>{r()}))}_initViewModelIntercept(){this.disposeWithMe(this._sheetInterceptorService.intercept(q.INTERCEPTOR_POINT.CELL_CONTENT,{priority:200,handler:(r,e,t)=>{var V,y,T,b;const{row:a,col:n,unitId:i,subUnitId:l}=e,d=this._dataValidationModel.ensureManager(i,l),u=(V=this._sheetSkeletonManagerService.getCurrent())==null?void 0:V.skeleton;if(!d||!u)return t(r);const c=e.workbook.getStyles(),m=(typeof(r==null?void 0:r.s)=="string"?c.get(r==null?void 0:r.s):r==null?void 0:r.s)||{},f=d.getRuleIdByLocation(a,n);if(!f)return t(r);const h=d.getRuleById(f);if(!h)return t(r);const p=e.worksheet.getCellRaw(e.row,e.col),S=this._dataValidationModel.validator(re(p),h,e),D=this._dataValidatorRegistryService.getValidatorItem(h.type),C=re(r);let M={};if((h.type===s.DataValidationType.LIST||h.type===s.DataValidationType.LIST_MULTIPLE)&&(M={interceptorStyle:{...r==null?void 0:r.interceptorStyle,tb:(y=m.tb!==s.WrapStrategy.OVERFLOW?m.tb:s.WrapStrategy.CLIP)!=null?y:s.WrapStrategy.WRAP}}),h.type===s.DataValidationType.CHECKBOX){const{formula2:L}=D.parseFormulaSync(h,e.unitId,e.subUnitId);C||(M={v:L,t:1,p:null,interceptorStyle:{...r==null?void 0:r.interceptorStyle,tb:s.WrapStrategy.CLIP}})}if(h.type===s.DataValidationType.LIST&&(h.renderMode===s.DataValidationRenderMode.ARROW||h.renderMode===s.DataValidationRenderMode.TEXT)){const L=D.getListWithColorMap(h),U=`${(T=re(r))!=null?T:""}`,B=L[U];B&&(M={...M,interceptorStyle:{...M.interceptorStyle,bg:{rgb:B}}})}return t({...r,...M,dataValidation:{ruleId:f,validStatus:S,rule:h,validator:D},markers:{...r==null?void 0:r.markers,...S===s.DataValidationStatus.INVALID?lr:null},customRender:[...(b=r==null?void 0:r.customRender)!=null?b:[],...D!=null&&D.canvasRender?[D.canvasRender]:[]],fontRenderExtension:{...r==null?void 0:r.fontRenderExtension,isSkip:D==null?void 0:D.skipDefaultFontRender(h,C,e)},interceptorStyle:{...r==null?void 0:r.interceptorStyle,...M.interceptorStyle},get interceptorAutoHeight(){var B,x,A,k;const L=u.mergeData.find(ee=>{const{startColumn:P,startRow:G,endColumn:H,endRow:J}=ee;return a>=G&&n>=P&&a<=J&&n<=H}),U={data:{...r,dataValidation:{ruleId:f,validStatus:S,rule:h,validator:D}},style:u.getsStyles().getStyleByCell(r),primaryWithCoord:u.getCellByIndex((B=L==null?void 0:L.startRow)!=null?B:a,(x=L==null?void 0:L.startColumn)!=null?x:n),unitId:i,subUnitId:l,row:a,col:n};return(k=(A=D==null?void 0:D.canvasRender)==null?void 0:A.calcCellAutoHeight)==null?void 0:k.call(A,U)}})}}))}_initAutoHeight(){this._dataValidationModel.ruleChange$.subscribe(r=>{var e;if((e=r.rule)!=null&&e.ranges){const t=this._autoHeightController.getUndoRedoParamsOfAutoHeight(r.rule.ranges);s.sequenceExecute(t.redos,this._commandService)}})}},g.DataValidationRenderController=ir([s.OnLifecycle(s.LifecycleStages.Rendered,g.DataValidationRenderController),oe(1,I.Inject(W.ComponentManager)),oe(2,W.IMenuService),oe(3,I.Inject(R.DataValidationModel)),oe(4,I.Inject(j.SheetSkeletonManagerService)),oe(5,Z.IRenderManagerService),oe(6,s.IUniverInstanceService),oe(7,I.Inject(R.DataValidatorRegistryService)),oe(8,j.IEditorBridgeService),oe(9,I.Inject(De)),oe(10,I.Inject(q.SheetInterceptorService)),oe(11,I.Inject(I.Injector)),oe(12,I.Inject(j.AutoHeightController)),oe(13,s.ICommandService)],g.DataValidationRenderController);var dr=Object.defineProperty,ur=Object.getOwnPropertyDescriptor,cr=(o,r,e,t)=>{for(var a=t>1?void 0:t?ur(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&dr(r,e,a),a},Xe=(o,r)=>(e,t)=>r(e,t,o);const vt="SHEET_DATA_VALIDATION_ALERT";g.DataValidationAlertController=class extends s.Disposable{constructor(r,e,t,a){super(),this._hoverManagerService=r,this._cellAlertManagerService=e,this._univerInstanceService=t,this._localeService=a,this._init()}_init(){this._initCellAlertPopup()}_initCellAlertPopup(){this.disposeWithMe(this._hoverManagerService.currentCell$.pipe(ue.debounceTime(100)).subscribe(r=>{var e,t,a;if(r){const l=this._univerInstanceService.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET).getActiveSheet().getCell(r.location.row,r.location.col);if(((e=l==null?void 0:l.dataValidation)==null?void 0:e.validStatus)===s.DataValidationStatus.INVALID){if((t=l.dataValidation)!=null&&t.isSkip)return;const d=this._cellAlertManagerService.currentAlert.get(vt),u=(a=d==null?void 0:d.alert)==null?void 0:a.location;if(u&&u.row===r.location.row&&u.col===r.location.col&&u.subUnitId===r.location.subUnitId&&u.unitId===r.location.unitId)return;const c=l.dataValidation.validator,m=l.dataValidation.rule;if(!c)return;this._cellAlertManagerService.showAlert({type:j.CellAlertType.ERROR,title:this._localeService.t("dataValidation.error.title"),message:c==null?void 0:c.getRuleFinalError(m),location:r.location,width:200,height:74,key:vt});return}}this._cellAlertManagerService.removeAlert(vt)}))}},g.DataValidationAlertController=cr([s.OnLifecycle(s.LifecycleStages.Rendered,g.DataValidationAlertController),Xe(0,I.Inject(j.HoverManagerService)),Xe(1,I.Inject(j.CellAlertManagerService)),Xe(2,s.IUniverInstanceService),Xe(3,I.Inject(s.LocaleService))],g.DataValidationAlertController);var mr=Object.defineProperty,hr=Object.getOwnPropertyDescriptor,fr=(o,r,e,t)=>{for(var a=t>1?void 0:t?hr(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&mr(r,e,a),a},de=(o,r)=>(e,t)=>r(e,t,o);g.DataValidationRefRangeController=class extends s.Disposable{constructor(e,t,a,n,i,l,d,u,c,m){super();_(this,"_disposableMap",new Map);_(this,"registerRule",(e,t,a)=>{this.register(e,t,a),this.registerFormula(e,t,a)});this._dataValidationModel=e,this._univerInstanceService=t,this._injector=a,this._sheetSkeletonManagerService=n,this._refRangeService=i,this._dataValidationCustomFormulaService=l,this._dataValidationFormulaService=d,this._formulaRefRangeService=u,this._commandService=c,this._dataValidationCacheService=m,this._initRefRange()}_getIdWithUnitId(e,t,a){return`${e}_${t}_${a}`}registerFormula(e,t,a){var u;const n=a.uid,i=this._getIdWithUnitId(e,t,n),l=(u=this._disposableMap.get(i))!=null?u:new Set,d=(c,m)=>{const f=this._dataValidationModel.getRuleById(e,t,n);if(!f)return{redos:[],undos:[]};const h=f[c];if(!h||h===m)return{redos:[],undos:[]};const p={unitId:e,subUnitId:t,ruleId:a.uid,payload:{type:R.UpdateRuleType.SETTING,payload:{type:f.type,formula1:f.formula1,formula2:f.formula2,[c]:m}}},S={unitId:e,subUnitId:t,ruleId:a.uid,payload:{type:R.UpdateRuleType.SETTING,payload:{type:f.type,formula1:f.formula1,formula2:f.formula2}}},D=[{id:R.UpdateDataValidationMutation.id,params:p}],C=[{id:R.UpdateDataValidationMutation.id,params:S}];return{redos:D,undos:C}};if(a.type===s.DataValidationType.CUSTOM){const c=this._dataValidationCustomFormulaService.getRuleFormulaInfo(e,t,n);if(c){const m=this._formulaRefRangeService.registerFormula(c.formula,f=>d("formula1",f));l.add(()=>m.dispose())}}if(a.type!==s.DataValidationType.CUSTOM){const c=this._dataValidationFormulaService.getRuleFormulaInfo(e,t,n);if(c){const[m,f]=c;if(m){const h=this._formulaRefRangeService.registerFormula(m.text,p=>d("formula1",p));l.add(()=>h.dispose())}if(f){const h=this._formulaRefRangeService.registerFormula(f.text,p=>d("formula1",p));l.add(()=>h.dispose())}}}}register(e,t,a){var u;const n=c=>{const m=[...a.ranges],h=m.map(S=>q.handleCommonDefaultRangeChangeWithEffectRefCommands(S,c)).filter(S=>!!S).flat();if(s.isRangesEqual(h,m))return{redos:[],undos:[]};if(h.length){const S={unitId:e,subUnitId:t,ruleId:a.uid,payload:{type:R.UpdateRuleType.RANGE,payload:h}},D=[{id:R.UpdateDataValidationMutation.id,params:S}],C=[{id:R.UpdateDataValidationMutation.id,params:{unitId:e,subUnitId:t,ruleId:a.uid,payload:{type:R.UpdateRuleType.RANGE,payload:m}}}];return{redos:D,undos:C}}else{const S={unitId:e,subUnitId:t,ruleId:a.uid},D=[{id:R.RemoveDataValidationMutation.id,params:S}],C=R.removeDataValidationUndoFactory(this._injector,S);return{redos:D,undos:C}}},i=[];a.ranges.forEach(c=>{const m=this._refRangeService.registerRefRange(c,n,e,t);i.push(()=>m.dispose())});const l=this._getIdWithUnitId(e,t,a.uid),d=(u=this._disposableMap.get(l))!=null?u:new Set;d.add(()=>i.forEach(c=>c())),this._disposableMap.set(l,d)}_initRefRange(){this.disposeWithMe(ue.merge(this._sheetSkeletonManagerService.currentSkeleton$.pipe(Je.map(e=>e==null?void 0:e.sheetId),Je.distinctUntilChanged())).pipe(Je.switchMap(()=>new ue.Observable(e=>{const t=new s.DisposableCollection;return e.next(t),()=>{t.dispose()}}))).subscribe(e=>{e.add(s.toDisposable(this._dataValidationModel.ruleChange$.subscribe(t=>{const{unitId:a,subUnitId:n,rule:i}=t;switch(t.type){case"add":{const l=t.rule;this.registerRule(t.unitId,t.subUnitId,l);break}case"remove":{const l=this._disposableMap.get(this._getIdWithUnitId(a,n,i.uid));l&&l.forEach(d=>d());break}case"update":{const l=t.rule,d=this._disposableMap.get(this._getIdWithUnitId(a,n,l.uid));d&&d.forEach(u=>u()),this.registerRule(t.unitId,t.subUnitId,l);break}}})))})),this.disposeWithMe(s.toDisposable(()=>{this._disposableMap.forEach(e=>{e.forEach(t=>t())}),this._disposableMap.clear()}))}},g.DataValidationRefRangeController=fr([s.OnLifecycle(s.LifecycleStages.Ready,g.DataValidationRefRangeController),de(0,I.Inject(R.DataValidationModel)),de(1,I.Inject(s.IUniverInstanceService)),de(2,I.Inject(I.Injector)),de(3,I.Inject(j.SheetSkeletonManagerService)),de(4,I.Inject(q.RefRangeService)),de(5,I.Inject(g.DataValidationCustomFormulaService)),de(6,I.Inject(g.DataValidationFormulaService)),de(7,I.Inject(Le.FormulaRefRangeService)),de(8,s.ICommandService),de(9,I.Inject(we))],g.DataValidationRefRangeController);var pr=Object.defineProperty,vr=Object.getOwnPropertyDescriptor,gr=(o,r,e,t)=>{for(var a=t>1?void 0:t?vr(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&pr(r,e,a),a},na=(o,r)=>(e,t)=>r(e,t,o);g.DataValidationAutoFillController=class extends s.Disposable{constructor(r,e){super(),this._autoFillService=r,this._dataValidationModel=e,this._initAutoFill()}_initAutoFill(){const r=()=>({redos:[],undos:[]}),e=a=>{const{source:n,target:i,unitId:l,subUnitId:d}=a,u=this._dataValidationModel.ensureManager(l,d),c=u.getRuleObjectMatrix().clone(),m=j.virtualizeDiscreteRanges([n,i]),[f,h]=m.ranges,{mapFunc:p}=m,S={row:f.startRow,col:f.startColumn};j.getAutoFillRepeatRange(f,h).forEach(y=>{const T=y.repeatStartCell,b=y.relativeRange,L={startRow:S.row,startColumn:S.col,endColumn:S.col,endRow:S.row},U={startRow:T.row,startColumn:T.col,endColumn:T.col,endRow:T.row};s.Range.foreach(b,(B,x)=>{const A=s.Rectangle.getPositionRange({startRow:B,startColumn:x,endColumn:x,endRow:B},L),{row:k,col:ee}=p(A.startRow,A.startColumn),P=u.getRuleIdByLocation(k,ee);if(P){const G=s.Rectangle.getPositionRange({startRow:B,startColumn:x,endColumn:x,endRow:B},U),{row:H,col:J}=p(G.startRow,G.startColumn);c.setValue(H,J,P)}})});const C=c.diff(u.getDataValidations()),{redoMutations:M,undoMutations:V}=Ie(l,d,C);return{undos:V,redos:M}},t={id:Be,onFillData:(a,n,i)=>i===j.APPLY_TYPE.COPY||i===j.APPLY_TYPE.ONLY_FORMAT||i===j.APPLY_TYPE.SERIES?e(a):r()};this.disposeWithMe(this._autoFillService.addHook(t))}},g.DataValidationAutoFillController=gr([s.OnLifecycle(s.LifecycleStages.Ready,g.DataValidationAutoFillController),na(0,j.IAutoFillService),na(1,I.Inject(R.DataValidationModel))],g.DataValidationAutoFillController);var Sr=Object.defineProperty,_r=Object.getOwnPropertyDescriptor,Dr=(o,r,e,t)=>{for(var a=t>1?void 0:t?_r(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&Sr(r,e,a),a},gt=(o,r)=>(e,t)=>r(e,t,o);g.DataValidationCopyPasteController=class extends s.Disposable{constructor(e,t,a){super();_(this,"_copyInfo");this._sheetClipboardService=e,this._dataValidationModel=t,this._injector=a,this._initCopyPaste()}_initCopyPaste(){this._sheetClipboardService.addClipboardHook({id:Be,onBeforeCopy:(e,t,a)=>this._collect(e,t,a),onPasteCells:(e,t,a,n)=>{const{copyType:i=j.COPY_TYPE.COPY,pasteType:l}=n,{range:d}=e||{},{range:u,unitId:c,subUnitId:m}=t;return this._generateMutations(u,{copyType:i,pasteType:l,copyRange:d,unitId:c,subUnitId:m})}})}_collect(e,t,a){const n=new s.ObjectMatrix;this._copyInfo={unitId:e,subUnitId:t,matrix:n};const i=this._dataValidationModel.ensureManager(e,t),l={get:this._injector.get.bind(this._injector)},d=j.rangeToDiscreteRange(a,l,e,t);if(!d)return;const{rows:u,cols:c}=d;u.forEach((m,f)=>{c.forEach((h,p)=>{const S=i.getRuleIdByLocation(m,h);n.setValue(f,p,S!=null?S:"")})})}_generateMutations(e,t){if(!this._copyInfo)return{redos:[],undos:[]};if(t.copyType===j.COPY_TYPE.CUT)return this._copyInfo=null,{redos:[],undos:[]};if(!this._copyInfo||!this._copyInfo.matrix.getSizeOf()||!t.copyRange)return{redos:[],undos:[]};if([j.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_COL_WIDTH,j.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_VALUE,j.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMAT,Le.SPECIAL_PASTE_FORMULA].includes(t.pasteType))return{redos:[],undos:[]};const{unitId:a,subUnitId:n}=this._copyInfo;if(t.unitId!==a||n!==t.subUnitId){const i=this._dataValidationModel.ensureManager(a,n),l=this._dataValidationModel.ensureManager(t.unitId,t.subUnitId),d=l.getRuleObjectMatrix().clone(),{ranges:[u,c],mapFunc:m}=j.virtualizeDiscreteRanges([t.copyRange,e]),f=j.getRepeatRange(u,c,!0),h=new Map;f.forEach(({startRange:D})=>{var C;(C=this._copyInfo)==null||C.matrix.forValue((M,V,y)=>{const T=s.Rectangle.getPositionRange({startRow:M,endRow:M,startColumn:V,endColumn:V},D),b=`${n}-${y}`,L=i.getRuleById(y);!l.getRuleById(b)&&L&&h.set(b,{...L,uid:b});const{row:U,col:B}=m(T.startRow,T.startColumn);d.setValue(U,B,b)})});const{redoMutations:p,undoMutations:S}=Ie(t.unitId,t.subUnitId,d.diffWithAddition(l.getDataValidations(),h.values()));return{redos:p,undos:S}}else{const i=this._dataValidationModel.ensureManager(a,n),l=i.getRuleObjectMatrix().clone(),{ranges:[d,u],mapFunc:c}=j.virtualizeDiscreteRanges([t.copyRange,e]);j.getRepeatRange(d,u,!0).forEach(({startRange:p})=>{var S;(S=this._copyInfo)==null||S.matrix.forValue((D,C,M)=>{const V=s.Rectangle.getPositionRange({startRow:D,endRow:D,startColumn:C,endColumn:C},p),{row:y,col:T}=c(V.startRow,V.startColumn);l.setValue(y,T,M)})});const{redoMutations:f,undoMutations:h}=Ie(a,n,l.diff(i.getDataValidations()));return{redos:f,undos:h}}}},g.DataValidationCopyPasteController=Dr([s.OnLifecycle(s.LifecycleStages.Ready,g.DataValidationCopyPasteController),gt(0,j.ISheetClipboardService),gt(1,I.Inject(R.DataValidationModel)),gt(2,I.Inject(I.Injector))],g.DataValidationCopyPasteController);class St{constructor(r){_(this,"value");this.value=r}addRule(r){const e=r.uid;r.ranges.forEach(t=>{s.Range.foreach(t,(a,n)=>{this.value.setValue(a,n,e)})})}removeRange(r){r.forEach(e=>{s.Range.foreach(e,(t,a)=>{this.value.realDeleteValue(t,a)})})}removeRule(r){r.ranges.forEach(e=>{s.Range.foreach(e,(t,a)=>{this.value.setValue(t,a,"")})})}updateRange(r,e,t){const a=`${r}$`;e.forEach(n=>{s.Range.foreach(n,(i,l)=>{this.value.getValue(i,l)===r&&this.value.setValue(i,l,a)})}),t.forEach(n=>{s.Range.foreach(n,(i,l)=>{this.value.setValue(i,l,r)})}),e.forEach(n=>{s.Range.foreach(n,(i,l)=>{this.value.getValue(i,l)===a&&this.value.realDeleteValue(i,l)})})}diff(r){const e=[];let t=0;return r.forEach((a,n)=>{const i=s.queryObjectMatrix(this.value,d=>d===a.uid),l=a.ranges;(i.length!==l.length||i.some((d,u)=>!s.Rectangle.equals(d,l[u])))&&e.push({type:"update",ruleId:a.uid,oldRanges:l,newRanges:i}),i.length===0&&(e.push({type:"delete",rule:a,index:n-t}),t++)}),e}diffWithAddition(r,e){const t=[];let a=0;return r.forEach((n,i)=>{const l=s.queryObjectMatrix(this.value,u=>u===n.uid),d=n.ranges;(l.length!==d.length||l.some((u,c)=>!s.Rectangle.equals(u,d[c])))&&t.push({type:"update",ruleId:n.uid,oldRanges:d,newRanges:l}),l.length===0&&(t.push({type:"delete",rule:n,index:i-a}),a++)}),Array.from(e).forEach(n=>{const i=s.queryObjectMatrix(this.value,l=>l===n.uid);t.push({type:"add",rule:{...n,ranges:i}})}),t}clone(){return new St(new s.ObjectMatrix(this.value.clone()))}getValue(r,e){return this.value.getValue(r,e)}setValue(r,e,t){return this.value.setValue(r,e,t)}}class Vr extends R.DataValidationManager{constructor(e,t,a,n){super(e,t,a);_(this,"_ruleMatrix");_(this,"_dataValidatorRegistryService");_(this,"_dataValidationCacheService");_(this,"_dataValidationFormulaService");_(this,"_dataValidationCustomFormulaService");_(this,"_cache");_(this,"_dataValidationRefRangeController");this._injector=n,this._dataValidatorRegistryService=this._injector.get(R.DataValidatorRegistryService),this._dataValidationCacheService=this._injector.get(we),this._dataValidationFormulaService=this._injector.get(g.DataValidationFormulaService),this._dataValidationCustomFormulaService=this._injector.get(g.DataValidationCustomFormulaService),this._dataValidationRefRangeController=this._injector.get(g.DataValidationRefRangeController),this._cache=this._dataValidationCacheService.ensureCache(e,t);const i=new s.ObjectMatrix;a==null||a.forEach(l=>{const d=l.uid;l.ranges.forEach(u=>{s.Range.foreach(u,(c,m)=>{i.setValue(c,m,d)})})}),a==null||a.forEach(l=>{this._dataValidationRefRangeController.register(e,t,l)}),this._ruleMatrix=new St(i)}_addRuleSideEffect(e){var n;const{unitId:t,subUnitId:a}=this;(e.type===s.DataValidationType.LIST||e.type===s.DataValidationType.LIST_MULTIPLE)&&ie.isReferenceString((n=e.formula1)!=null?n:"")&&(e.formula1=`=${e.formula1}`),this._ruleMatrix.addRule(e),this._dataValidationCacheService.addRule(t,a,e),this._dataValidationFormulaService.addRule(t,a,e.uid,e.formula1,e.formula2),this._dataValidationCustomFormulaService.addRule(t,a,e)}addRule(e,t){(Array.isArray(e)?e:[e]).forEach(n=>{this._addRuleSideEffect(n)}),super.addRule(e,t)}updateRule(e,t){const a=this.getRuleById(e);if(!a)throw new Error(`Rule not found! id: ${e}`);return t.type===R.UpdateRuleType.RANGE?(this._ruleMatrix.updateRange(e,a.ranges,t.payload),this._dataValidationCacheService.updateRuleRanges(this.unitId,this.subUnitId,e,t.payload,a.ranges),this._dataValidationCustomFormulaService.updateRuleRanges(this.unitId,this.subUnitId,e,a.ranges,t.payload)):t.type===R.UpdateRuleType.SETTING&&(this._dataValidationCacheService.markRangeDirty(this.unitId,this.subUnitId,a.ranges),this._dataValidationFormulaService.updateRuleFormulaText(this.unitId,this.subUnitId,e,t.payload.formula1,t.payload.formula2),this._dataValidationCustomFormulaService.updateRuleFormula(this.unitId,this.subUnitId,e,a.ranges,t.payload.formula1)),super.updateRule(e,t)}removeRule(e){const t=this.getRuleById(e);t&&(this._ruleMatrix.removeRule(t),this._dataValidationCacheService.removeRule(this.unitId,this.subUnitId,t)),super.removeRule(e)}getRuleIdByLocation(e,t){return this._ruleMatrix.getValue(e,t)}getRuleByLocation(e,t){const a=this.getRuleIdByLocation(e,t);if(a)return this.getRuleById(a)}validator(e,t,a,n){const{col:i,row:l,unitId:d,subUnitId:u}=a,c=t.uid,m=this._dataValidatorRegistryService.getValidatorItem(t.type);if(m){const f=this._cache.getValue(l,i);return!f||f.value!==e?(this._cache.setValue(l,i,{value:e,status:s.DataValidationStatus.VALIDATING,ruleId:c}),m.validator({value:e,unitId:d,subUnitId:u,row:l,column:i},t).then(h=>{const p=h?s.DataValidationStatus.VALID:s.DataValidationStatus.INVALID;this._cache.setValue(l,i,{value:e,status:p,ruleId:c}),n(p)}),s.DataValidationStatus.VALIDATING):f.status}else return s.DataValidationStatus.VALID}getRuleErrorMsg(e){const t=this.getRuleById(e);if(!t)return"";const a=this._dataValidatorRegistryService.getValidatorItem(t.type);return t.error?t.error:a?a.getRuleFinalError(t):""}getRuleObjectMatrix(){return this._ruleMatrix}}var Cr=Object.defineProperty,Rr=Object.getOwnPropertyDescriptor,Ir=(o,r,e,t)=>{for(var a=t>1?void 0:t?Rr(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&Cr(r,e,a),a},ze=(o,r)=>(e,t)=>r(e,t,o);let Qe=class extends s.Disposable{constructor(o,r,e,t){super(),this._resourceManagerService=o,this._univerInstanceService=r,this._dataValidationModel=e,this._injector=t,this._initDataValidationDataSource()}_createSheetDataValidationManager(o,r){return new Vr(o,r,[],this._injector)}_initDataValidationDataSource(){this._dataValidationModel.setManagerCreator(this._createSheetDataValidationManager.bind(this))}};Qe=Ir([s.OnLifecycle(s.LifecycleStages.Starting,Qe),ze(0,s.IResourceManagerService),ze(1,s.IUniverInstanceService),ze(2,I.Inject(R.DataValidationModel)),ze(3,I.Inject(I.Injector))],Qe);var Mr=Object.defineProperty,yr=Object.getOwnPropertyDescriptor,wr=(o,r,e,t)=>{for(var a=t>1?void 0:t?yr(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&Mr(r,e,a),a},_t=(o,r)=>(e,t)=>r(e,t,o);let Ke=class extends s.Disposable{constructor(o,r,e){super(),this._localeService=o,this._commandService=r,this._sheetPermissionInterceptorBaseController=e,this._commandExecutedListener()}_commandExecutedListener(){this.disposeWithMe(this._commandService.beforeCommandExecuted(o=>{o.id===R.AddDataValidationCommand.id&&(this._sheetPermissionInterceptorBaseController.permissionCheckWithRanges({workbookTypes:[q.WorkbookEditablePermission],rangeTypes:[q.RangeProtectionPermissionEditPoint],worksheetTypes:[q.WorksheetEditPermission,q.WorksheetSetCellStylePermission]})||this._sheetPermissionInterceptorBaseController.haveNotPermissionHandle(this._localeService.t("permission.dialog.setStyleErr"))),o.id===Pe.id&&(this._sheetPermissionInterceptorBaseController.permissionCheckWithRanges({workbookTypes:[q.WorkbookEditablePermission],rangeTypes:[q.RangeProtectionPermissionEditPoint],worksheetTypes:[q.WorksheetEditPermission,q.WorksheetSetCellStylePermission]},o.params.ranges)||this._sheetPermissionInterceptorBaseController.haveNotPermissionHandle(this._localeService.t("permission.dialog.setStyleErr")))}))}};Ke=wr([s.OnLifecycle(s.LifecycleStages.Ready,Ke),_t(0,I.Inject(s.LocaleService)),_t(1,s.ICommandService),_t(2,I.Inject(j.SheetPermissionInterceptorBaseController))],Ke);var Or=Object.defineProperty,Er=Object.getOwnPropertyDescriptor,Tr=(o,r,e,t)=>{for(var a=t>1?void 0:t?Er(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&Or(r,e,a),a},Dt=(o,r)=>(e,t)=>r(e,t,o);g.UniverSheetsDataValidationPlugin=(Ze=class extends s.Plugin{constructor(r={},e,t,a){super(),this._config=r,this._injector=e,this._commandService=t,this._localeService=a,this._config=s.Tools.deepMerge({},sr,this._config)}onStarting(r){[[ce],[g.SheetDataValidationService],[we],[g.DataValidationFormulaService],[g.DataValidationCustomFormulaService],[De],[Qe],[g.DataValidationController],[g.DataValidationRenderController,{useFactory:()=>this._injector.createInstance(g.DataValidationRenderController,this._config)}],[g.DataValidationAlertController],[g.DataValidationRefRangeController],[Ke],[g.DataValidationAutoFillController],[g.DataValidationCopyPasteController],[g.DataValidationFormulaController],[g.DataValidationRejectInputController]].forEach(e=>{r.add(e)}),[je,et,Pe,Ae,Et,Ot,Ee,Sa].forEach(e=>{this._commandService.registerCommand(e)})}},_(Ze,"pluginName",Be),_(Ze,"type",s.UniverInstanceType.UNIVER_SHEET),Ze),g.UniverSheetsDataValidationPlugin=Tr([Dt(1,I.Inject(I.Injector)),Dt(2,s.ICommandService),Dt(3,I.Inject(s.LocaleService))],g.UniverSheetsDataValidationPlugin),Object.defineProperty(g,"ICommandService",{enumerable:!0,get:()=>s.ICommandService}),Object.defineProperty(g,"LocaleService",{enumerable:!0,get:()=>s.LocaleService}),Object.defineProperty(g,"Plugin",{enumerable:!0,get:()=>s.Plugin}),g.AddSheetDataValidationAndOpenCommand=et,g.AddSheetDataValidationCommand=je,g.DATA_VALIDATION_PLUGIN_NAME=Be,g.DataValidationCacheService=we,g.HideDataValidationDropdown=Et,g.ShowDataValidationDropdown=Ae,g.UpdateSheetDataValidationRangeCommand=Pe,Object.defineProperty(g,Symbol.toStringTag,{value:"Module"})});