@univerjs/sheets-data-validation 0.2.4 → 0.2.6

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(v,s){typeof exports=="object"&&typeof module<"u"?s(exports,require("@univerjs/core"),require("@wendellhu/redi"),require("@univerjs/data-validation"),require("@univerjs/sheets"),require("@univerjs/sheets-ui"),require("@univerjs/ui"),require("@univerjs/engine-render"),require("rxjs"),require("react"),require("@wendellhu/redi/react-bindings"),require("@univerjs/sheets-formula"),require("@univerjs/design"),require("clsx"),require("@univerjs/engine-formula"),require("dayjs"),require("@univerjs/engine-numfmt")):typeof define=="function"&&define.amd?define(["exports","@univerjs/core","@wendellhu/redi","@univerjs/data-validation","@univerjs/sheets","@univerjs/sheets-ui","@univerjs/ui","@univerjs/engine-render","rxjs","react","@wendellhu/redi/react-bindings","@univerjs/sheets-formula","@univerjs/design","clsx","@univerjs/engine-formula","dayjs","@univerjs/engine-numfmt"],s):(v=typeof globalThis<"u"?globalThis:v||self,s(v.UniverSheetsDataValidation={},v.UniverCore,v["@wendellhu/redi"],v.UniverDataValidation,v.UniverSheets,v.UniverSheetsUi,v.UniverUi,v.UniverEngineRender,v.rxjs,v.React,v["@wendellhu/redi/react-bindings"],v.UniverSheetsFormula,v.UniverDesign,v.clsx,v.UniverEngineFormula,v.dayjs,v.UniverEngineNumfmt))})(this,function(v,s,M,C,$,B,q,Z,ie,E,H,nt,T,Da,re,de,Va){"use strict";var Ki=Object.defineProperty;var Qi=(v,s,M)=>s in v?Ki(v,s,{enumerable:!0,configurable:!0,writable:!0,value:M}):v[s]=M;var R=(v,s,M)=>Qi(v,typeof s!="symbol"?s+"":s,M);var Tt;function te(r){if(r===null)return"";if(r!=null&&r.p){const n=r==null?void 0:r.p.body;if(n==null)return"";const e=n.dataStream;return e.substring(e.length-2,e.length)===s.DEFAULT_EMPTY_DOCUMENT_VALUE?e.substring(0,e.length-2):e}return r==null?void 0:r.v}function Et(r){var n;return String((n=te(r))!=null?n:"")}var Ra=typeof globalThis<"u"?globalThis:typeof window<"u"?window:typeof global<"u"?global:typeof self<"u"?self:{};function Ca(r){return r&&r.__esModule&&Object.prototype.hasOwnProperty.call(r,"default")?r.default:r}var bt={exports:{}},xe={};/**
1
+ (function(global2,factory){typeof exports=="object"&&typeof module<"u"?factory(exports,require("@univerjs/core"),require("@univerjs/data-validation"),require("@univerjs/sheets"),require("@univerjs/sheets-ui"),require("@univerjs/ui"),require("@univerjs/engine-render"),require("rxjs"),require("react"),require("@univerjs/sheets-formula"),require("@univerjs/design"),require("clsx"),require("@univerjs/engine-formula"),require("dayjs"),require("@univerjs/engine-numfmt")):typeof define=="function"&&define.amd?define(["exports","@univerjs/core","@univerjs/data-validation","@univerjs/sheets","@univerjs/sheets-ui","@univerjs/ui","@univerjs/engine-render","rxjs","react","@univerjs/sheets-formula","@univerjs/design","clsx","@univerjs/engine-formula","dayjs","@univerjs/engine-numfmt"],factory):(global2=typeof globalThis<"u"?globalThis:global2||self,factory(global2.UniverSheetsDataValidation={},global2.UniverCore,global2.UniverDataValidation,global2.UniverSheets,global2.UniverSheetsUi,global2.UniverUi,global2.UniverEngineRender,global2.rxjs,global2.React,global2.UniverSheetsFormula,global2.UniverDesign,global2.clsx,global2.UniverEngineFormula,global2.dayjs,global2.UniverEngineNumfmt))})(this,function(exports2,core,dataValidation,sheets,sheetsUi,ui,engineRender,rxjs,React,sheetsFormula,design,cs,engineFormula,dayjs,engineNumfmt){"use strict";var __defProp=Object.defineProperty;var __defNormalProp=(obj,key,value)=>key in obj?__defProp(obj,key,{enumerable:!0,configurable:!0,writable:!0,value}):obj[key]=value;var __name=(target,value)=>__defProp(target,"name",{value,configurable:!0});var __publicField=(obj,key,value)=>__defNormalProp(obj,typeof key!="symbol"?key+"":key,value);var _a,_b,_c,_d,_e,_f,_g,_h,_i,_j,_k,_l,_m,_n,_o,_p,_q,_r,_s,_t,_u,_v;function getCellValueOrigin(cell){if(cell===null)return"";if(cell!=null&&cell.p){const body=cell==null?void 0:cell.p.body;if(body==null)return"";const data=body.dataStream;return data.substring(data.length-2,data.length)===core.DEFAULT_EMPTY_DOCUMENT_VALUE?data.substring(0,data.length-2):data}return cell==null?void 0:cell.v}__name(getCellValueOrigin,"getCellValueOrigin");function getStringCellValue(cell){var _a2;return String((_a2=getCellValueOrigin(cell))!=null?_a2:"")}__name(getStringCellValue,"getStringCellValue");var commonjsGlobal=typeof globalThis<"u"?globalThis:typeof window<"u"?window:typeof global<"u"?global:typeof self<"u"?self:{};function getDefaultExportFromCjs(x){return x&&x.__esModule&&Object.prototype.hasOwnProperty.call(x,"default")?x.default:x}__name(getDefaultExportFromCjs,"getDefaultExportFromCjs");var jsxRuntime={exports:{}},reactJsxRuntime_production_min={};/**
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 Ia=E,ya=Symbol.for("react.element"),Ma=Symbol.for("react.fragment"),wa=Object.prototype.hasOwnProperty,Oa=Ia.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,Ta={key:!0,ref:!0,__self:!0,__source:!0};function Ft(r,n,e){var t,a={},i=null,o=null;e!==void 0&&(i=""+e),n.key!==void 0&&(i=""+n.key),n.ref!==void 0&&(o=n.ref);for(t in n)wa.call(n,t)&&!Ta.hasOwnProperty(t)&&(a[t]=n[t]);if(r&&r.defaultProps)for(t in n=r.defaultProps,n)a[t]===void 0&&(a[t]=n[t]);return{$$typeof:ya,type:r,key:i,ref:o,props:a,_owner:Oa.current}}xe.Fragment=Ma,xe.jsx=Ft,xe.jsxs=Ft,bt.exports=xe;var S=bt.exports;function Ea(){const r=H.useDependency(fe),n=q.useObservable(r.activeDropdown$,r.activeDropdown),e=H.useDependency(q.ComponentManager);if(!n)return null;const{location:t,componentKey:a}=n,i=e.get(a),o=`${t.unitId}-${t.subUnitId}-${t.row}-${t.col}`;if(!i)return null;const l=()=>{r.hideDropdown()};return S.jsx(i,{location:t,hideFn:l},o)}const Nt="sheet.ui.dropdown";var ba=Object.defineProperty,Fa=Object.getOwnPropertyDescriptor,Na=(r,n,e,t)=>{for(var a=t>1?void 0:t?Fa(n,e):n,i=r.length-1,o;i>=0;i--)(o=r[i])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&ba(n,e,a),a},Ie=(r,n)=>(e,t)=>n(e,t,r);let fe=class extends s.Disposable{constructor(n,e,t,a,i,o){super();R(this,"_activeDropdown");R(this,"_activeDropdown$",new ie.Subject);R(this,"_currentPopup",null);R(this,"activeDropdown$",this._activeDropdown$.asObservable());R(this,"_zenVisible",!1);this._canvasPopupManagerService=n,this._univerInstanceService=e,this._dataValidatorRegistryService=t,this._zenZoneService=a,this._renderManagerService=i,this._dataValidationModel=o,this._init(),this.disposeWithMe(()=>{this._activeDropdown$.complete()})}get activeDropdown(){return this._activeDropdown}_init(){this.disposeWithMe(this._zenZoneService.visible$.subscribe(n=>{this._zenVisible=n,n&&this.hideDropdown()}))}showDropdown(n,e=!0){const{location:t}=n,{row:a,col:i}=t;if(this._currentPopup&&this._currentPopup.dispose(),this._zenVisible)return;this._activeDropdown=n,this._activeDropdown$.next(this._activeDropdown);const o=this._renderManagerService.getRenderById(s.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),l=this._canvasPopupManagerService.attachPopupToCell(a,i,{componentKey:Nt,onClickOutside:()=>{e&&this.hideDropdown()},offset:[0,3],excludeOutside:[o==null?void 0:o.engine.getCanvasElement()].filter(Boolean)});if(!l)throw new Error("[DataValidationDropdownManagerService]: cannot show dropdown!");const d=new s.DisposableCollection;d.add(l),d.add({dispose:()=>{var u,c;(c=(u=this._activeDropdown)==null?void 0:u.onHide)==null||c.call(u)}}),this._currentPopup=d}hideDropdown(){this._activeDropdown&&(this._currentPopup&&this._currentPopup.dispose(),this._currentPopup=null,this._activeDropdown=null,this._activeDropdown$.next(null))}showDataValidationDropdown(n,e,t,a,i){const o=this._univerInstanceService.getUniverSheetInstance(n);if(!o)return;const l=o.getSheetBySheetId(e);if(!l)return;const u=this._dataValidationModel.ensureManager(n,e).getRuleByLocation(t,a);if(!u)return;const c=this._dataValidatorRegistryService.getValidatorItem(u.type);if(!c||!c.dropdown){this.hideDropdown();return}this.showDropdown({location:{workbook:o,worksheet:l,row:t,col:a,unitId:n,subUnitId:e},componentKey:c.dropdown,onHide:i})}};fe=Na([Ie(0,M.Inject(B.SheetCanvasPopManagerService)),Ie(1,s.IUniverInstanceService),Ie(2,M.Inject(C.DataValidatorRegistryService)),Ie(3,q.IZenZoneService),Ie(4,Z.IRenderManagerService),Ie(5,M.Inject(C.DataValidationModel))],fe);var La=Object.defineProperty,Pa=Object.getOwnPropertyDescriptor,Aa=(r,n,e,t)=>{for(var a=t>1?void 0:t?Pa(n,e):n,i=r.length-1,o;i>=0;i--)(o=r[i])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&La(n,e,a),a},Lt=(r,n)=>(e,t)=>n(e,t,r);let ue=class extends s.Disposable{constructor(n,e){super();R(this,"_open$",new ie.BehaviorSubject(!1));R(this,"open$",this._open$.pipe(ie.distinctUntilChanged()));R(this,"_activeRule");R(this,"_activeRule$",new ie.BehaviorSubject(void 0));R(this,"activeRule$",this._activeRule$.asObservable());R(this,"_closeDisposable",null);this._univerInstanceService=n,this._sidebarService=e,this.disposeWithMe(this._univerInstanceService.getCurrentTypeOfUnit$(s.UniverInstanceType.UNIVER_SHEET).pipe(ie.filter(t=>!t)).subscribe(()=>{this.close()}))}get activeRule(){return this._activeRule}get isOpen(){return this._open$.getValue()}dispose(){var n;super.dispose(),this._open$.next(!1),this._open$.complete(),this._activeRule$.complete(),(n=this._closeDisposable)==null||n.dispose()}open(){this._open$.next(!0)}close(){var n;this._open$.next(!1),(n=this._closeDisposable)==null||n.dispose()}setCloseDisposable(n){this._closeDisposable=s.toDisposable(()=>{n.dispose(),this._closeDisposable=null})}setActiveRule(n){this._activeRule=n,this._activeRule$.next(n)}};ue=Aa([Lt(0,s.IUniverInstanceService),Lt(1,q.ISidebarService)],ue);const Pt="DataValidationPanel",Se={id:"data-validation.operation.open-validation-panel",type:s.CommandType.OPERATION,handler(r,n){if(!n)return!1;const{ruleId:e,isAdd:t}=n,a=r.get(ue),i=r.get(C.DataValidationModel),o=r.get(s.IUniverInstanceService),l=r.get(q.ISidebarService),d=$.getSheetCommandTarget(o);if(!d)return!1;const{unitId:u,subUnitId:c}=d,h=e?i.getRuleById(u,c,e):void 0;a.open(),a.setActiveRule(h&&{unitId:u,subUnitId:c,rule:h});const p=l.open({header:{title:t?"dataValidation.panel.addTitle":"dataValidation.panel.title"},children:{label:Pt},width:312,onClose:()=>a.close()});return a.setCloseDisposable(p),!0}},ke={id:"data-validation.operation.close-validation-panel",type:s.CommandType.OPERATION,handler(r){return r.get(ue).close(),!0}},it={id:"data-validation.operation.toggle-validation-panel",type:s.CommandType.OPERATION,handler(r){const n=r.get(s.ICommandService),e=r.get(ue);return e.open(),e.isOpen?n.executeCommand(ke.id):n.executeCommand(Se.id),!0}},Ee={type:s.CommandType.OPERATION,id:"sheet.operation.show-data-validation-dropdown",handler(r,n){if(!n)return!1;const e=r.get(fe),{unitId:t,subUnitId:a,row:i,column:o}=n,l=e.activeDropdown,d=l==null?void 0:l.location;return d&&d.unitId===t&&d.subUnitId===a&&d.row===i&&d.col===o||e.showDataValidationDropdown(t,a,i,o),!0}},rt={type:s.CommandType.OPERATION,id:"sheet.operation.hide-data-validation-dropdown",handler(r,n){return n?(r.get(fe).hideDropdown(),!0):!1}};class _e{constructor(){R(this,"_cacheMatrix",new Map)}_ensureCache(n,e){let t=this._cacheMatrix.get(n);t||(t=new Map,this._cacheMatrix.set(n,t));let a=t.get(e);return a||(a=new s.ObjectMatrix,t.set(e,a)),a}ensureCache(n,e){return this._ensureCache(n,e)}addRule(n,e,t){this.markRangeDirty(n,e,t.ranges)}removeRule(n,e,t){this._deleteRange(n,e,t.ranges)}updateRuleRanges(n,e,t,a,i){const o=this._ensureCache(n,e);i.forEach(l=>{s.Range.foreach(l,(d,u)=>{const c=o.getValue(d,u);c&&(c.temp=!0)})}),a.forEach(l=>{s.Range.foreach(l,(d,u)=>{const c=o.getValue(d,u);c&&c.ruleId===t?c.temp=!1:o.setValue(d,u,void 0)})}),i.forEach(l=>{s.Range.foreach(l,(d,u)=>{const c=o.getValue(d,u);c&&c.temp===!0&&o.realDeleteValue(d,u)})})}markRangeDirty(n,e,t){const a=this._ensureCache(n,e);t.forEach(i=>{s.Range.foreach(i,(o,l)=>{a.setValue(o,l,void 0)})})}markCellDirty(n,e,t,a){this._ensureCache(n,e).setValue(t,a,void 0)}_deleteRange(n,e,t){const a=this._ensureCache(n,e);t.forEach(i=>{s.Range.foreach(i,(o,l)=>{a.realDeleteValue(o,l)})})}getValue(n,e,t,a){return this._ensureCache(n,e).getValue(t,a)}setValue(n,e,t,a,i){return this._ensureCache(n,e).setValue(t,a,i)}}var ja=Object.defineProperty,Ua=Object.getOwnPropertyDescriptor,$a=(r,n,e,t)=>{for(var a=t>1?void 0:t?Ua(n,e):n,i=r.length-1,o;i>=0;i--)(o=r[i])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&ja(n,e,a),a},ot=(r,n)=>(e,t)=>n(e,t,r);v.DataValidationFormulaService=class extends s.Disposable{constructor(e,t,a){super();R(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 i in a){const o=a[i],l=this._ensureRuleFormulaMap(t,i),d=this._dataValidationModel.ensureManager(t,i);o.forEach(u=>{var c,h;if(l.get((c=u.extra)==null?void 0:c.ruleId)){const p=d.getRuleById((h=u.extra)==null?void 0:h.ruleId);p&&this._dataValidationCacheService.markRangeDirty(t,i,p.ranges)}})}}}))}_ensureRuleFormulaMap(e,t){let a=this._formulaRuleMap.get(e);a||(a=new Map,this._formulaRuleMap.set(e,a));let i=a.get(t);return i||(i=new Map,a.set(t,i)),i}addRule(e,t,a,i,o){const l=s.isFormulaString(i),d=s.isFormulaString(o);if(!l&&!d)return;const u=this._ensureRuleFormulaMap(e,t),c=[void 0,void 0];if(l){const h=this._registerOtherFormulaService.registerFormula(e,t,i,{ruleId:a});c[0]={id:h,text:i}}if(d){const h=this._registerOtherFormulaService.registerFormula(e,t,o,{ruleId:a});c[1]={id:h,text:o}}u.set(a,c)}removeRule(e,t,a){const o=this._ensureRuleFormulaMap(e,t).get(a);if(!o)return;const[l,d]=o,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,i,o){const d=this._ensureRuleFormulaMap(e,t).get(a);if(!d){this.addRule(e,t,a,i,o);return}const[u,c]=d;if((u==null?void 0:u.text)!==i)if(u&&this._registerOtherFormulaService.deleteFormula(e,t,[u.id]),s.isFormulaString(i)){const h=this._registerOtherFormulaService.registerFormula(e,t,i,{ruleId:a});d[0]={text:i,id:h}}else d[0]=void 0;if((c==null?void 0:c.text)!==o)if(c&&this._registerOtherFormulaService.deleteFormula(e,t,[c.id]),s.isFormulaString(o)){const h=this._registerOtherFormulaService.registerFormula(e,t,o,{ruleId:a});d[1]={text:o,id:h}}else d[1]=void 0}getRuleFormulaResult(e,t,a){const o=this._ensureRuleFormulaMap(e,t).get(a);if(!o)return Promise.resolve(null);const l=async d=>d&&this._registerOtherFormulaService.getFormulaValue(e,t,d.id);return Promise.all([l(o[0]),l(o[1])])}getRuleFormulaResultSync(e,t,a){const o=this._ensureRuleFormulaMap(e,t).get(a);if(o)return o.map(l=>{if(l)return this._registerOtherFormulaService.getFormulaValueSync(e,t,l.id)})}getRuleFormulaInfo(e,t,a){return this._ensureRuleFormulaMap(e,t).get(a)}},v.DataValidationFormulaService=$a([ot(0,M.Inject(nt.RegisterOtherFormulaService)),ot(1,M.Inject(_e)),ot(2,M.Inject(C.DataValidationModel))],v.DataValidationFormulaService);function le(r){var n,e;return(e=(n=r==null?void 0:r[0])==null?void 0:n[0])==null?void 0:e.v}var Ba=Object.defineProperty,Wa=Object.getOwnPropertyDescriptor,Ha=(r,n,e,t)=>{for(var a=t>1?void 0:t?Wa(n,e):n,i=r.length-1,o;i>=0;i--)(o=r[i])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&Ba(n,e,a),a},st=(r,n)=>(e,t)=>n(e,t,r);const Ye=6;let lt=class{constructor(r,n,e){this._commandService=r,this._formulaService=n,this._themeService=e}_calc(r,n){var u,c,h;const{vt:e,ht:t}=n||{},a=r.endX-r.startX-Ye*2,i=r.endY-r.startY,o=((u=n==null?void 0:n.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+(i-o);break;default:d=0+(i-o)/2;break}switch(t){case s.HorizontalAlign.LEFT:l=Ye;break;case s.HorizontalAlign.RIGHT:l=Ye+(a-o);break;default:l=Ye+(a-o)/2;break}return{left:r.startX+l,top:r.startY+d,width:((c=n==null?void 0:n.fs)!=null?c:10)*1.6,height:((h=n==null?void 0:n.fs)!=null?h:10)*1.6}}calcCellAutoHeight(r){var e;const{style:n}=r;return((e=n==null?void 0:n.fs)!=null?e:10)*1.6}async _parseFormula(r,n,e){var o,l;const{formula1:t=Ne,formula2:a=Le}=r,i=await this._formulaService.getRuleFormulaResult(n,e,r.uid);return{formula1:s.isFormulaString(t)?le((o=i==null?void 0:i[0])==null?void 0:o.result):t,formula2:s.isFormulaString(a)?le((l=i==null?void 0:i[1])==null?void 0:l.result):a}}drawWith(r,n){var x,F,U,k,X;const{style:e,data:t,primaryWithCoord:a,unitId:i,subUnitId:o}=n,l=a.isMergedMainCell?a.mergeInfo:a,d=te(t),u=(x=t.dataValidation)==null?void 0:x.rule,c=(F=t.dataValidation)==null?void 0:F.validator;if(!u||!c)return;const h=this._themeService.getCurrentTheme();if(!c.skipDefaultFontRender(u,d,{unitId:i,subUnitId:o}))return;const p=c.parseFormulaSync(u,i,o),{formula1:f}=p,g=this._calc(l,e),{a:m,d:I}=r.getTransform(),_=Z.fixLineWidthByScale(g.left,m),V=Z.fixLineWidthByScale(g.top,I),D=Z.Transform.create().composeMatrix({left:_,top:V,scaleX:1,scaleY:1,angle:0,skewX:0,skewY:0,flipX:!1,flipY:!1}),y=l.endX-l.startX,O=l.endY-l.startY;r.save(),r.beginPath(),r.rect(l.startX,l.startY,y,O),r.clip();const b=D.getMatrix();r.transform(b[0],b[1],b[2],b[3],b[4],b[5]);const L=((U=e==null?void 0:e.fs)!=null?U:10)*1.6,j=String(d)===String(f),A=h.hyacinth500;Z.Checkbox.drawWith(r,{checked:j,width:L,height:L,fill:(X=(k=e==null?void 0:e.cl)==null?void 0:k.rgb)!=null?X:A}),r.restore()}isHit(r,n){const e=n.primaryWithCoord.isMergedMainCell?n.primaryWithCoord.mergeInfo:n.primaryWithCoord,t=this._calc(e,n.style),a=t.top,i=t.top+t.height,o=t.left,l=t.left+t.width,{x:d,y:u}=r;return d<=l&&d>=o&&u<=i&&u>=a}async onPointerDown(r,n){var p,f;if(n.button===2)return;const{primaryWithCoord:e,unitId:t,subUnitId:a,data:i}=r,o=te(i),l=(p=i.dataValidation)==null?void 0:p.rule,d=(f=i.dataValidation)==null?void 0:f.validator;if(!l||!d||!d.skipDefaultFontRender(l,o,{unitId:t,subUnitId:a}))return;const{formula1:u,formula2:c}=await this._parseFormula(l,t,a),h={range:{startColumn:e.actualColumn,endColumn:e.actualColumn,startRow:e.actualRow,endRow:e.actualRow},value:{v:String(o)===String(u)?c:u,p:null}};this._commandService.executeCommand($.SetRangeValuesCommand.id,h)}};lt=Ha([st(0,s.ICommandService),st(1,M.Inject(v.DataValidationFormulaService)),st(2,M.Inject(s.ThemeService))],lt);function xa(r){var d;const{unitId:n,subUnitId:e,value:t,onChange:a,showError:i,validResult:o}=r,l=i?o==null?void 0:o.formula1:"";return S.jsx(T.FormLayout,{error:l,children:S.jsx(q.TextEditor,{value:(d=t==null?void 0:t.formula1)!=null?d:"",id:s.createInternalEditorID(`dataValidation-custom-formula-${n}-${e}`),onChange:u=>{a==null||a({...t,formula1:u!=null?u:""})},onlyInputFormula:!0,openForSheetUnitId:n,openForSheetSubUnitId:e})})}const oe={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=r=>{const{isTwoFormula:n=!1,value:e,onChange:t,showError:a,validResult:i}=r,o=H.useDependency(s.LocaleService),l=a?i==null?void 0:i.formula1:"",d=a?i==null?void 0:i.formula2:"";return n?S.jsxs(S.Fragment,{children:[S.jsx(T.FormLayout,{error:l,children:S.jsx(T.Input,{className:oe.dataValidationFormula,placeholder:o.t("dataValidation.panel.formulaPlaceholder"),value:e==null?void 0:e.formula1,onChange:u=>{t==null||t({...e,formula1:u})}})}),S.jsx("div",{className:oe.dataValidationFormulaAnd,children:o.t("dataValidation.panel.formulaAnd")}),S.jsx(T.FormLayout,{error:d,children:S.jsx(T.Input,{className:oe.dataValidationFormula,placeholder:o.t("dataValidation.panel.formulaPlaceholder"),value:e==null?void 0:e.formula2,onChange:u=>{t==null||t({...e,formula2:u})}})})]}):S.jsx(T.FormLayout,{error:l,children:S.jsx(T.Input,{className:oe.dataValidationFormula,placeholder:o.t("dataValidation.panel.formulaPlaceholder"),value:e==null?void 0:e.formula1,onChange:u=>{t==null||t({formula1:u})}})})};var se=function(){return se=Object.assign||function(r){for(var n,e=1,t=arguments.length;e<t;e++){n=arguments[e];for(var a in n)Object.prototype.hasOwnProperty.call(n,a)&&(r[a]=n[a])}return r},se.apply(this,arguments)},Ya=function(r,n){var e={};for(var t in r)Object.prototype.hasOwnProperty.call(r,t)&&n.indexOf(t)<0&&(e[t]=r[t]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var a=0,t=Object.getOwnPropertySymbols(r);a<t.length;a++)n.indexOf(t[a])<0&&Object.prototype.propertyIsEnumerable.call(r,t[a])&&(e[t[a]]=r[t[a]]);return e},pe=E.forwardRef(function(r,n){var e=r.icon,t=r.id,a=r.className,i=r.extend,o=Ya(r,["icon","id","className","extend"]),l="univerjs-icon univerjs-icon-".concat(t," ").concat(a||"").trim(),d=E.useRef("_".concat(Ga()));return At(e,"".concat(t),{defIds:e.defIds,idSuffix:d.current},se({ref:n,className:l},o),i)});function At(r,n,e,t,a){return E.createElement(r.tag,se(se({key:n},qa(r,e,a)),t),(Xa(r,e).children||[]).map(function(i,o){return At(i,"".concat(n,"-").concat(r.tag,"-").concat(o),e,void 0,a)}))}function qa(r,n,e){var t=se({},r.attrs);e!=null&&e.colorChannel1&&t.fill==="colorChannel1"&&(t.fill=e.colorChannel1);var a=n.defIds;return!a||a.length===0||(r.tag==="use"&&t["xlink:href"]&&(t["xlink:href"]=t["xlink:href"]+n.idSuffix),Object.entries(t).forEach(function(i){var o=i[0],l=i[1];typeof l=="string"&&(t[o]=l.replace(/url\(#(.*)\)/,"url(#$1".concat(n.idSuffix,")")))})),t}function Xa(r,n){var e,t=n.defIds;return!t||t.length===0?r:r.tag==="defs"&&(!((e=r.children)===null||e===void 0)&&e.length)?se(se({},r),{children:r.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+n.idSuffix})}):a})}):r}function Ga(){return Math.random().toString(36).substring(2,8)}pe.displayName="UniverIcon";var za={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"}}]},jt=E.forwardRef(function(r,n){return E.createElement(pe,Object.assign({},r,{id:"check-mark-single",ref:n,icon:za}))});jt.displayName="CheckMarkSingle";var Ka={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"}}]},Ut=E.forwardRef(function(r,n){return E.createElement(pe,Object.assign({},r,{id:"data-validation-single",ref:n,icon:Ka}))});Ut.displayName="DataValidationSingle";var Qa={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"}}]},dt=E.forwardRef(function(r,n){return E.createElement(pe,Object.assign({},r,{id:"delete-single",ref:n,icon:Qa}))});dt.displayName="DeleteSingle";var Za={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"}}]},$t=E.forwardRef(function(r,n){return E.createElement(pe,Object.assign({},r,{id:"increase-single",ref:n,icon:Za}))});$t.displayName="IncreaseSingle";var Ja={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"}}]},Bt=E.forwardRef(function(r,n){return E.createElement(pe,Object.assign({},r,{id:"more-down-single",ref:n,icon:Ja}))});Bt.displayName="MoreDownSingle";var en={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"}}]},Wt=E.forwardRef(function(r,n){return E.createElement(pe,Object.assign({},r,{id:"more-up-single",ref:n,icon:en}))});Wt.displayName="MoreUpSingle";var tn={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"}}]}]},Ht=E.forwardRef(function(r,n){return E.createElement(pe,Object.assign({},r,{id:"sequence-single",ref:n,icon:tn}))});Ht.displayName="SequenceSingle";function xt(r){return r.filter(Boolean).join(",")}function ye(r){return r.split(",").filter(Boolean)}function an(r){const n=te(r);return n==null?"":n.toString()}const be="SHEET_DATA_VALIDATION_PLUGIN",De="#ECECEC";var qe=(r=>(r[r.View=0]="View",r[r.Edit=1]="Edit",r[r.ManageCollaborator=2]="ManageCollaborator",r[r.Print=3]="Print",r[r.Duplicate=4]="Duplicate",r[r.Comment=5]="Comment",r[r.Copy=6]="Copy",r[r.Share=7]="Share",r[r.Export=8]="Export",r[r.MoveWorksheet=9]="MoveWorksheet",r[r.DeleteWorksheet=10]="DeleteWorksheet",r[r.HideWorksheet=11]="HideWorksheet",r[r.RenameWorksheet=12]="RenameWorksheet",r[r.CreateWorksheet=13]="CreateWorksheet",r[r.SetWorksheetStyle=14]="SetWorksheetStyle",r[r.EditWorksheetCell=15]="EditWorksheetCell",r[r.InsertHyperlink=16]="InsertHyperlink",r[r.Sort=17]="Sort",r[r.Filter=18]="Filter",r[r.PivotTable=19]="PivotTable",r[r.FloatImg=20]="FloatImg",r[r.History=21]="History",r[r.RwHgtClWdt=22]="RwHgtClWdt",r[r.ViemRwHgtClWdt=23]="ViemRwHgtClWdt",r[r.ViewFilter=24]="ViewFilter",r[r.MoveSheet=25]="MoveSheet",r[r.DeleteSheet=26]="DeleteSheet",r[r.HideSheet=27]="HideSheet",r[r.CopySheet=28]="CopySheet",r[r.RenameSheet=29]="RenameSheet",r[r.CreateSheet=30]="CreateSheet",r[r.SelectProtectedCells=31]="SelectProtectedCells",r[r.SelectUnProtectedCells=32]="SelectUnProtectedCells",r[r.SetCellStyle=33]="SetCellStyle",r[r.SetCellValue=34]="SetCellValue",r[r.SetRowStyle=35]="SetRowStyle",r[r.SetColumnStyle=36]="SetColumnStyle",r[r.InsertRow=37]="InsertRow",r[r.InsertColumn=38]="InsertColumn",r[r.DeleteRow=39]="DeleteRow",r[r.DeleteColumn=40]="DeleteColumn",r[r.EditExtraObject=41]="EditExtraObject",r[r.Delete=42]="Delete",r[r.RecoverHistory=43]="RecoverHistory",r[r.ViewHistory=44]="ViewHistory",r[r.UNRECOGNIZED=-1]="UNRECOGNIZED",r))(qe||{}),nn=Object.defineProperty,rn=Object.getOwnPropertyDescriptor,on=(r,n,e,t)=>{for(var a=t>1?void 0:t?rn(n,e):n,i=r.length-1,o;i>=0;i--)(o=r[i])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&nn(n,e,a),a},ut=(r,n)=>(e,t)=>n(e,t,r);v.DataValidationFormulaController=class extends s.Disposable{constructor(n,e,t){super(),this._univerInstanceService=n,this._permissionService=e,this._lexerTreeBuilder=t}getFormulaRefCheck(n){var t,a;const e=this._lexerTreeBuilder.sequenceNodesBuilder(n);if(!e)return!0;for(let i=0;i<e.length;i++){const o=e[i];if(typeof o=="string")continue;const{token:l}=o,d=re.deserializeRangeWithSheet(l),u=this._univerInstanceService.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET);let c=u.getActiveSheet();const h=u.getUnitId();if(d.sheetName){if(c=u.getSheetBySheetName(d.sheetName),!c)return!1;const I=c==null?void 0:c.getSheetId();if(!this._permissionService.getPermissionPoint(new $.WorksheetViewPermission(h,I).id))return!1}if(!c)return!1;const{startRow:p,endRow:f,startColumn:g,endColumn:m}=d.range;for(let I=p;I<=f;I++)for(let _=g;_<=m;_++){const V=(a=(t=c.getCell(I,_))==null?void 0:t.selectionProtection)==null?void 0:a[0];if((V==null?void 0:V[qe.View])===!1)return!1}}return!0}},v.DataValidationFormulaController=on([s.OnLifecycle(s.LifecycleStages.Rendered,v.DataValidationFormulaController),ut(0,s.IUniverInstanceService),ut(1,s.IPermissionService),ut(2,M.Inject(re.LexerTreeBuilder))],v.DataValidationFormulaController);const sn=["#FFFFFF","#FEE7E7","#FEF0E6","#EFFBD0","#E4F4FE","#E8ECFD","#F1EAFA","#FDE8F3","#E5E5E5","#FDCECE","#FDC49B","#DEF6A2","#9FDAFF","#D0D9FB","#E3D5F6","#FBD0E8","#656565","#FE4B4B","#FF8C51","#8BBB11","#0B9EFB","#3A60F7","#9E6DE3","#F248A6"],ln=r=>{const{value:n,onChange:e,disabled:t}=r,[a,i]=E.useState(!1);return S.jsx(T.Select,{disabled:t,open:a,onDropdownVisibleChange:i,dropdownStyle:{width:112},className:oe.dataValidationFormulaColorSelect,value:n,onChange:e,labelRender:o=>S.jsx("div",{className:oe.dataValidationFormulaColorItem,style:{background:o.value,marginTop:5}}),dropdownRender:()=>S.jsx("div",{className:oe.dataValidationFormulaColorSelectPanel,children:sn.map(o=>S.jsx("div",{onClick:()=>{e(o),i(!1)},className:oe.dataValidationFormulaColorItem,style:{background:o}},o))})})},kt=r=>{const{item:n,commonProps:e,style:t}=r,{onItemChange:a,onItemDelete:i}=e;return S.jsxs("div",{className:oe.dataValidationFormulaListItem,style:t,children:[n.isRef?null:S.jsx("div",{className:Da(oe.dataValidationFormulaListItemDrag,"draggableHandle"),children:S.jsx(Ht,{})}),S.jsx(ln,{value:n.color,onChange:o=>{a(n.id,n.label,o)}}),S.jsx(T.Input,{disabled:n.isRef,value:n.label,onChange:o=>{a(n.id,o,n.color)}}),n.isRef?null:S.jsx("div",{className:oe.dataValidationFormulaListItemIcon,children:S.jsx(dt,{onClick:()=>i(n.id)})})]})};function dn(r){const{value:n,onChange:e=()=>{},unitId:t,subUnitId:a,validResult:i,showError:o,ruleId:l}=r,{formula1:d="",formula2:u=""}=n||{},c=E.useRef(null),[h,p]=E.useState(()=>s.isFormulaString(d)?"1":"0"),[f,g]=E.useState(h==="1"?d:"="),[m,I]=E.useState(h==="1"?d:"="),_=H.useDependency(s.LocaleService),V=H.useDependency(C.DataValidatorRegistryService),D=H.useDependency(C.DataValidationModel),y=H.useDependency(v.DataValidationFormulaController),[O,b]=E.useState(()=>u.split(",")),L=V.getValidatorItem(s.DataValidationType.LIST),[j,A]=E.useState([]),[x,F]=E.useState(""),U=o?i==null?void 0:i.formula1:"",k=E.useMemo(()=>D.ruleChange$.pipe(ie.debounceTime(16)),[]),X=q.useObservable(k),N=q.useEvent(e);E.useEffect(()=>{(async()=>{await new Promise(z=>{setTimeout(()=>z(!0),100)});const P=D.getRuleById(t,a,l),J=P==null?void 0:P.formula1;if(s.isFormulaString(J)&&L&&P){const z=await L.getListAsync(P,t,a);A(z)}})()},[D,X,L,l,a,t]),E.useEffect(()=>{s.isFormulaString(d)&&d!==m&&(g(d),I(m))},[m,d]);const[Y,Q]=E.useState(()=>{const P=h!=="1"?ye(d):[],J=u.split(",");return P.map((z,ne)=>({label:z,color:J[ne]||De,isRef:!1,id:s.Tools.generateRandomId(4)}))}),G=(P,J,z)=>{const ne=Y.find(He=>He.id===P);ne&&(ne.label=J,ne.color=z,Q([...Y]))},w=P=>{const J=Y.findIndex(z=>z.id===P);J!==-1&&(Y.splice(J,1),Q([...Y]))},W=u.split(","),ae=E.useMemo(()=>j.map((P,J)=>({label:P,color:W[J]||De,id:`${J}`,isRef:!0})),[W,j]),K=(P,J,z)=>{const ne=[...O];ne[+P]=z,b(ne),N({formula1:d,formula2:ne.join(",")})},me=()=>{Q([...Y,{label:"",color:De,isRef:!1,id:s.Tools.generateRandomId(4)}])};E.useEffect(()=>{if(h==="1")return;const P=new Set,J=[];Y.map(z=>({labelList:z.label.split(","),item:z})).forEach(({item:z,labelList:ne})=>{ne.forEach(He=>{P.has(He)||(P.add(He),J.push({label:He,color:z.color}))})}),N({formula1:xt(J.map(z=>z.label)),formula2:J.map(z=>z.color===De?"":z.color).join(",")})},[Y,N,h,m,O]);const Ce=E.useMemo(()=>async P=>{if(!s.isFormulaString(P)){N==null||N({formula1:"",formula2:u});return}y.getFormulaRefCheck(P)?(N==null||N({formula1:s.isFormulaString(P)?P:"",formula2:u}),F("")):(N==null||N({formula1:"",formula2:u}),g("="),F(_.t("dataValidation.validFail.formulaError")))},[u,N]);return S.jsxs(S.Fragment,{children:[S.jsx(T.FormLayout,{label:_.t("dataValidation.list.options"),children:S.jsxs(T.RadioGroup,{value:h,onChange:P=>{p(P),g(m),P==="1"&&N({formula1:m==="="?"":m,formula2:O.join(",")})},children:[S.jsx(T.Radio,{value:"0",children:_.t("dataValidation.list.customOptions")}),S.jsx(T.Radio,{value:"1",children:_.t("dataValidation.list.refOptions")})]})}),h==="1"?S.jsxs(S.Fragment,{children:[S.jsx(T.FormLayout,{error:U||x,children:S.jsx(q.TextEditor,{id:s.createInternalEditorID(`list-ref-range-${t}-${a}`),value:f,openForSheetUnitId:t,openForSheetSubUnitId:a,onlyInputFormula:!0,onChange:async P=>{const J=P!=null?P:"";I(J),Ce(J)}})}),S.jsx(T.FormLayout,{children:S.jsx("div",{ref:c,children:ae.map(P=>S.jsx(kt,{item:P,commonProps:{onItemChange:K},style:{marginBottom:12}},P.id))})})]}):S.jsx(T.FormLayout,{error:U,children:S.jsxs("div",{ref:c,style:{marginTop:"-12px"},children:[S.jsx(T.DraggableList,{list:Y,onListChange:Q,rowHeight:32,margin:[0,12],draggableHandle:".draggableHandle",itemRender:P=>S.jsx(kt,{item:P,commonProps:{onItemChange:G,onItemDelete:w}},P.id),idKey:"id"}),S.jsxs("a",{className:oe.dataValidationFormulaListAdd,onClick:me,children:[S.jsx($t,{}),_.t("dataValidation.list.add")]})]})})]})}function un(r){const{value:n,onChange:e,showError:t,validResult:a}=r,i=H.useDependency(s.LocaleService),o=t?a==null?void 0:a.formula1:"",l=t?a==null?void 0:a.formula2:"",[d,u]=E.useState(!((n==null?void 0:n.formula1)===void 0&&(n==null?void 0:n.formula2)===void 0));return S.jsxs(S.Fragment,{children:[S.jsx(T.FormLayout,{children:S.jsx(T.Checkbox,{checked:d,onChange:c=>{c?u(!0):(u(!1),e==null||e({...n,formula1:void 0,formula2:void 0}))},children:i.t("dataValidation.checkbox.tips")})}),d?S.jsx(T.FormLayout,{label:i.t("dataValidation.checkbox.checked"),error:o,children:S.jsx(T.Input,{className:oe.dataValidationFormula,placeholder:i.t("dataValidation.panel.valuePlaceholder"),value:n==null?void 0:n.formula1,onChange:c=>{e==null||e({...n,formula1:c||void 0})}})}):null,d?S.jsx(T.FormLayout,{label:i.t("dataValidation.checkbox.unchecked"),error:l,children:S.jsx(T.Input,{className:oe.dataValidationFormula,placeholder:i.t("dataValidation.panel.valuePlaceholder"),value:n==null?void 0:n.formula2,onChange:c=>{e==null||e({...n,formula2:c||void 0})}})}):null]})}const Yt="data-validation.custom-formula-input",Fe="data-validation.formula-input",qt="data-validation.list-formula-input",Xt="data-validation.checkbox-formula-input",cn=[[Yt,xa],[Fe,ka],[qt,dn],[Xt,un]],Ne=1,Le=0;function Gt(r,n){return s.Tools.isBlank(r)?n.t("dataValidation.validFail.value"):s.isFormulaString(r)?n.t("dataValidation.validFail.primitive"):""}class mn extends C.BaseDataValidator{constructor(){super(...arguments);R(this,"id",s.DataValidationType.CHECKBOX);R(this,"title","dataValidation.checkbox.title");R(this,"operators",[]);R(this,"scopes",["sheet"]);R(this,"formulaInput",Xt);R(this,"canvasRender",this.injector.createInstance(lt));R(this,"_formulaService",this.injector.get(v.DataValidationFormulaService))}skipDefaultFontRender(e,t,a){const{formula1:i,formula2:o}=this.parseFormulaSync(e,a.unitId,a.subUnitId),l=`${t!=null?t:""}`;return!l||l===`${i}`||l===`${o}`}validatorFormula(e,t,a){const{formula1:i,formula2:o}=e,l=i===o;if(s.Tools.isBlank(i)&&s.Tools.isBlank(o))return{success:!0};if(l)return{success:!1,formula1:this.localeService.t("dataValidation.validFail.checkboxEqual"),formula2:this.localeService.t("dataValidation.validFail.checkboxEqual")};const d=Gt(i,this.localeService),u=Gt(o,this.localeService);return{success:!d&&!u,formula1:d,formula2:u}}async parseFormula(e,t,a){var d,u;const{formula1:i=Ne,formula2:o=Le}=e,l=await this._formulaService.getRuleFormulaResult(t,a,e.uid);return{formula1:s.isFormulaString(i)?le((d=l==null?void 0:l[0])==null?void 0:d.result):i,formula2:s.isFormulaString(o)?le((u=l==null?void 0:l[1])==null?void 0:u.result):o}}parseFormulaSync(e,t,a){var d,u;const{formula1:i=Ne,formula2:o=Le}=e,l=this._formulaService.getRuleFormulaResultSync(t,a,e.uid);return{formula1:s.isFormulaString(i)?le((d=l==null?void 0:l[0])==null?void 0:d.result):i,formula2:s.isFormulaString(o)?le((u=l==null?void 0:l[1])==null?void 0:u.result):o}}async isValidType(e,t,a){const{value:i,unitId:o,subUnitId:l}=e,{formula1:d,formula2:u}=await this.parseFormula(a,o,l);return!s.Tools.isDefine(d)||!s.Tools.isDefine(u)?!0:s.Tools.isDefine(i)&&(String(i)===String(d)||String(i)===String(u))}generateRuleErrorMessage(e){return this.localeService.t("dataValidation.checkbox.error")}}const Xe=[s.DataValidationOperator.BETWEEN,s.DataValidationOperator.NOT_BETWEEN];function hn(r){return new Date((r-25569)*86400).getTime()}const zt=r=>r/86400+25569,ct={dataValidationOptionsButton:"univer-data-validation-options-button",dataValidationOptionsButtonIcon:"univer-data-validation-options-button-icon"};function fn(r){var u;const n=H.useDependency(s.LocaleService),e=H.useDependency(q.ComponentManager),{value:t,onChange:a,extraComponent:i}=r,[o,l]=E.useState(!1),d=i?e.get(i):null;return S.jsxs(S.Fragment,{children:[S.jsxs("div",{className:ct.dataValidationOptionsButton,onClick:()=>l(!o),children:[n.t("dataValidation.panel.options"),o?S.jsx(Wt,{className:ct.dataValidationOptionsButtonIcon}):S.jsx(Bt,{className:ct.dataValidationOptionsButtonIcon})]}),o&&S.jsxs(S.Fragment,{children:[d?S.jsx(d,{value:t,onChange:a}):null,S.jsx(T.FormLayout,{label:n.t("dataValidation.panel.invalid"),children:S.jsxs(T.RadioGroup,{value:`${(u=t.errorStyle)!=null?u:s.DataValidationErrorStyle.WARNING}`,onChange:c=>a({...t,errorStyle:+c}),children:[S.jsx(T.Radio,{value:`${s.DataValidationErrorStyle.WARNING}`,children:n.t("dataValidation.panel.showWarning")}),S.jsx(T.Radio,{value:`${s.DataValidationErrorStyle.STOP}`,children:n.t("dataValidation.panel.rejectInput")})]})}),S.jsx(T.FormLayout,{label:n.t("dataValidation.panel.messageInfo"),children:S.jsx(T.Checkbox,{checked:t.showInputMessage,onChange:()=>a({...t,showInputMessage:!t.showInputMessage}),children:n.t("dataValidation.panel.showInfo")})}),t.showInputMessage?S.jsx(T.FormLayout,{children:S.jsx(T.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"},pn=r=>s.debounce(async(n,e,t,a)=>{const i=await r.executeCommand(n,e,t);a==null||a(i)},275);function vn(){const[r,n]=E.useState(0),e=H.useDependency(ue),t=q.useObservable(e.activeRule$,e.activeRule),{unitId:a,subUnitId:i,rule:o}=t||{},l=o.uid,d=H.useDependency(C.DataValidatorRegistryService),u=H.useDependency(q.ComponentManager),c=H.useDependency(s.ICommandService),h=H.useDependency(C.DataValidationModel),p=H.useDependency(s.LocaleService),[f,g]=E.useState(o),m=d.getValidatorItem(f.type),[I,_]=E.useState(!1),V=d.getValidatorsByScope(C.DataValidatorRegistryScope.SHEET),[D,y]=E.useState(()=>f.ranges.map(w=>({unitId:"",sheetId:"",range:w}))),O=E.useMemo(()=>pn(c),[c]);if(E.useEffect(()=>{c.onCommandExecuted(w=>{(w.id===s.UndoCommand.id||w.id===s.RedoCommand.id)&&setTimeout(()=>{const W=h.getRuleById(a,i,l);n(ae=>ae+1),W&&(g(W),y(W.ranges.map(ae=>({unitId:"",sheetId:"",range:ae}))))},20)})},[c,h,l,i,a]),!m)return null;const b=m.operators,L=m.operatorNames,j=f.operator?C.TWO_FORMULA_OPERATOR_COUNT.includes(f.operator):!1,A=()=>{m.validatorFormula(f,a,i).success?e.setActiveRule(null):_(!0)},x=q.useEvent(w=>{if(s.isUnitRangesEqual(w,D))return;y(w);const W=w.filter(K=>(!K.unitId||K.unitId===a)&&(!K.sheetId||K.sheetId===i)).map(K=>K.range);if(g({...f,ranges:W}),W.length===0)return;const ae={unitId:a,subUnitId:i,ruleId:l,ranges:W};O(je.id,ae)}),F=w=>{if(s.shallowEqual(w,C.getRuleSetting(f)))return;g({...f,...w});const W={unitId:a,subUnitId:i,ruleId:l,setting:w};O(vt.id,W,void 0)},U=async()=>{await c.executeCommand(C.RemoveDataValidationCommand.id,{ruleId:l,unitId:a,subUnitId:i}),e.setActiveRule(null)},k={type:f.type,operator:f.operator,formula1:f.formula1,formula2:f.formula2,allowBlank:f.allowBlank},X=w=>{const W=d.getValidatorItem(w);if(!W)return;const ae=W.operators,K=h.getRuleById(a,i,l),me=w===(K==null?void 0:K.type)||w.includes("list")&&(K!=null&&K.type.includes("list"))?{...K,type:w}:{...f,type:w,operator:ae[0],formula1:void 0,formula2:void 0};g(me),c.executeCommand(vt.id,{unitId:a,subUnitId:i,ruleId:f.uid,setting:C.getRuleSetting(me)})},N=u.get(m.formulaInput),Y=E.useMemo(()=>D.map(w=>re.serializeRange(w.range)).join(","),[]),Q=C.getRuleOptions(f),G=w=>{s.shallowEqual(w,C.getRuleOptions(f))||(g({...f,...w}),O(la.id,{unitId:a,subUnitId:i,ruleId:l,options:w}))};return S.jsxs("div",{children:[S.jsx(T.FormLayout,{label:p.t("dataValidation.panel.range"),children:S.jsx(q.RangeSelector,{className:Me.dataValidationDetailFormItem,value:Y,id:s.createInternalEditorID("data-validation-detail"),openForSheetUnitId:a,openForSheetSubUnitId:i,onChange:w=>{w.some(W=>!s.isValidRange(W.range)||W.range.endColumn<W.range.startColumn||W.range.endRow<W.range.startRow)||x(w)}},r)}),S.jsx(T.FormLayout,{label:p.t("dataValidation.panel.type"),children:S.jsx(T.Select,{options:V==null?void 0:V.map(w=>({label:p.t(w.title),value:w.id})),value:f.type,onChange:X,className:Me.dataValidationDetailFormItem})}),b!=null&&b.length?S.jsx(T.FormLayout,{label:p.t("dataValidation.panel.operator"),children:S.jsx(T.Select,{options:b.map((w,W)=>({value:`${w}`,label:L[W]})),value:`${f.operator}`,onChange:w=>{F({...k,operator:w})},className:Me.dataValidationDetailFormItem})}):null,N?S.jsx(N,{isTwoFormula:j,value:{formula1:f.formula1,formula2:f.formula2},onChange:w=>{F({...k,...w})},showError:I,validResult:m.validatorFormula(f,a,i),unitId:a,subUnitId:i,ruleId:l},r+f.type):null,S.jsx(fn,{value:Q,onChange:G,extraComponent:m.optionsInput}),S.jsxs("div",{className:Me.dataValidationDetailButtons,children:[S.jsx(T.Button,{className:Me.dataValidationDetailButton,onClick:U,children:p.t("dataValidation.panel.removeRule")}),S.jsx(T.Button,{className:Me.dataValidationDetailButton,type:"primary",onClick:A,children:p.t("dataValidation.panel.done")})]})]})}const Ge={dataValidationItemContainer:"univer-data-validation-item-container",dataValidationItemTitle:"univer-data-validation-item-title",dataValidationItemContent:"univer-data-validation-item-content",dataValidationItemIcon:"univer-data-validation-item-icon"},gn=r=>{const{rule:n,onClick:e,unitId:t,subUnitId:a,disable:i}=r,o=H.useDependency(C.DataValidatorRegistryService),l=H.useDependency(s.ICommandService),d=H.useDependency(B.IMarkSelectionService),u=o.getValidatorItem(n.type),c=E.useRef(),[h,p]=E.useState(!1),f=g=>{l.executeCommand(C.RemoveDataValidationCommand.id,{ruleId:n.uid,unitId:t,subUnitId:a}),g.stopPropagation()};return E.useEffect(()=>()=>{var g;c.current&&((g=c.current)==null||g.forEach(m=>{m&&d.removeShape(m)}))},[d]),S.jsxs("div",{className:Ge.dataValidationItemContainer,onClick:e,onMouseEnter:()=>{i||(p(!0),c.current=n.ranges.map(g=>d.addShape({range:g,style:{hasAutoFill:!1,fill:"rgba(73, 184, 17, 0.05)",strokeWidth:1,stroke:"#49B811",widgets:{}},primary:{startColumn:g.startColumn,endColumn:g.endColumn,startRow:g.startRow,endRow:g.endRow,actualRow:g.startRow,actualColumn:g.startColumn,isMerged:!1,isMergedMainCell:!1}})))},onMouseLeave:()=>{var g;p(!1),(g=c.current)==null||g.forEach(m=>{m&&d.removeShape(m)}),c.current=void 0},children:[S.jsx("div",{className:Ge.dataValidationItemTitle,children:u==null?void 0:u.generateRuleName(n)}),S.jsx("div",{className:Ge.dataValidationItemContent,children:n.ranges.map(g=>re.serializeRange(g)).join(",")}),h?S.jsx("div",{className:Ge.dataValidationItemIcon,onClick:f,children:S.jsx(dt,{})}):null]})},mt={dataValidationListButtons:"univer-data-validation-list-buttons",dataValidationListButton:"univer-data-validation-list-button"};function Sn(){const r=H.useDependency(s.IUniverInstanceService),n=q.useObservable(()=>r.getCurrentTypeOfUnit$(s.UniverInstanceType.UNIVER_SHEET),void 0,void 0,[]);return n?S.jsx(_n,{workbook:n}):null}function _n(r){const n=H.useDependency(C.DataValidationModel),e=H.useDependency(s.IUniverInstanceService),t=H.useDependency(s.ICommandService),a=H.useDependency(M.Injector),i=H.useDependency(ue),o=H.useDependency(s.LocaleService),[l,d]=E.useState([]),{workbook:u}=r,c=q.useObservable(u.activeSheet$,void 0,!0),h=u.getUnitId(),p=c==null?void 0:c.getSheetId(),f=n.ensureManager(h,p);E.useEffect(()=>{d(f.getDataValidations());const D=f.dataValidations$.subscribe(y=>{d([...y])});return()=>{D.unsubscribe()}},[f]);const g=async()=>{const D=C.createDefaultNewRule(a),y={unitId:h,subUnitId:p,rule:D};await t.executeCommand(Ue.id,y),i.setActiveRule({unitId:h,subUnitId:p,rule:D})},m=()=>{t.executeCommand(C.RemoveAllDataValidationCommand.id,{unitId:h,subUnitId:p})},_=(D=>{const O=e.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET).getActiveSheet();return D.map(L=>{const{ranges:j}=L;return(j==null?void 0:j.some(x=>{var N,Y;const{startRow:F,startColumn:U,endRow:k,endColumn:X}=x;for(let Q=F;Q<=k;Q++)for(let G=U;G<=X;G++){const w=(Y=(N=O==null?void 0:O.getCell(Q,G))==null?void 0:N.selectionProtection)==null?void 0:Y[0];if((w==null?void 0:w[qe.Edit])===!1||(w==null?void 0:w[qe.View])===!1)return!0}return!1}))?{...L,disable:!0}:{...L}})})(l),V=_==null?void 0:_.some(D=>D.disable);return S.jsxs("div",{children:[_==null?void 0:_.map(D=>{var y;return S.jsx(gn,{unitId:h,subUnitId:p,onClick:()=>{D.disable||i.setActiveRule({unitId:h,subUnitId:p,rule:D})},rule:D,disable:(y=D.disable)!=null?y:!1},D.uid)}),S.jsxs("div",{className:mt.dataValidationListButtons,children:[l.length&&!V?S.jsx(T.Button,{className:mt.dataValidationListButton,onClick:m,children:o.t("dataValidation.panel.removeAll")}):null,S.jsx(T.Button,{className:mt.dataValidationListButton,type:"primary",onClick:g,children:o.t("dataValidation.panel.add")})]})]})}const Dn=()=>{const r=H.useDependency(ue),n=q.useObservable(r.activeRule$,r.activeRule);return n?S.jsx(vn,{},n.rule.uid):S.jsx(Sn,{})},he={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"},Vn=r=>{const{value:n,onChange:e,multiple:t,options:a,title:i,onEdit:o,style:l}=r;return S.jsxs("div",{className:he.dvListDropdown,style:l,children:[S.jsx("div",{className:he.dvListDropdownTitle,children:i}),S.jsx("div",{className:he.dvListDropdownList,children:S.jsx(T.Scrollbar,{children:S.jsx("div",{className:he.dvListDropdownListContainer,children:a.map((d,u)=>{const c=n.indexOf(d.value)>-1,h=()=>{let p;c?p=new Set(n.filter(g=>g!==d.value)):p=new Set(t?[...n,d.value]:[d.value]);const f=[];a.forEach(g=>{p.has(g.value)&&f.push(g.value)}),e(f)};return S.jsxs("div",{className:he.dvListDropdownItemContainer,onClick:h,children:[S.jsx("div",{className:he.dvListDropdownItem,style:{background:d.color||De},children:d.label}),S.jsx("div",{className:he.dvListDropdownSelectedIcon,children:c?S.jsx(jt,{}):null})]},u)})})})}),S.jsx("div",{className:he.dvListDropdownSplit}),S.jsx("div",{className:he.dvListDropdownEdit,children:S.jsx("a",{onClick:o,children:"编辑"})})]})};function Rn(r){var x,F;const{location:n,hideFn:e}=r,{worksheet:t,row:a,col:i,unitId:o,subUnitId:l}=n,d=H.useDependency(C.DataValidationModel),u=H.useDependency(s.ICommandService),c=H.useDependency(s.LocaleService),[h,p]=E.useState(""),f=H.useDependency(B.IEditorBridgeService),g=E.useMemo(()=>d.ruleChange$.pipe(ie.debounceTime(16)),[]);q.useObservable(g);const m=T.RectPopup.useContext(),I=m.right-m.left;if(!t)return null;const _=t.getCell(a,i),V=(x=_==null?void 0:_.dataValidation)==null?void 0:x.rule,D=(F=_==null?void 0:_.dataValidation)==null?void 0:F.validator,y=(V==null?void 0:V.renderMode)===s.DataValidationRenderMode.CUSTOM||(V==null?void 0:V.renderMode)===void 0;if(!_||!V||!D)return;const O=V.type===s.DataValidationType.LIST_MULTIPLE,b=D.getListWithColor(V,o,l),L=h||an(_),j=ye(L),A=()=>{u.executeCommand(Se.id,{ruleId:V.uid}),e()};return S.jsx(Vn,{style:{minWidth:I,maxWidth:Math.max(I,200)},title:O?c.t("dataValidation.listMultiple.dropdown"):c.t("dataValidation.list.dropdown"),value:j,multiple:O,onChange:U=>{const k=xt(U),X={unitId:o,subUnitId:l,range:{startColumn:i,endColumn:i,startRow:a,endRow:a},value:{v:k,p:null,f:null,si:null,custom:{__link_url:""}}};f.isVisible()&&f.changeVisible({visible:!1,keycode:q.KeyCode.ESC,eventType:Z.DeviceInputEventType.Keyboard,unitId:o}),u.executeCommand($.SetRangeValuesCommand.id,X),p(k),O||e()},options:b.map(U=>({label:U.label,value:U.label,color:y?U.color:"transparent"})),onEdit:A})}var Kt={exports:{}};(function(r,n){(function(e,t){r.exports=t()})(Ra,function(){var e="minute",t=/[+-]\d\d(?::?\d\d)?/g,a=/([+-]|\d\d)/g;return function(i,o,l){var d=o.prototype;l.utc=function(m){var I={date:m,utc:!0,args:arguments};return new o(I)},d.utc=function(m){var I=l(this.toDate(),{locale:this.$L,utc:!0});return m?I.add(this.utcOffset(),e):I},d.local=function(){return l(this.toDate(),{locale:this.$L,utc:!1})};var u=d.parse;d.parse=function(m){m.utc&&(this.$u=!0),this.$utils().u(m.$offset)||(this.$offset=m.$offset),u.call(this,m)};var c=d.init;d.init=function(){if(this.$u){var m=this.$d;this.$y=m.getUTCFullYear(),this.$M=m.getUTCMonth(),this.$D=m.getUTCDate(),this.$W=m.getUTCDay(),this.$H=m.getUTCHours(),this.$m=m.getUTCMinutes(),this.$s=m.getUTCSeconds(),this.$ms=m.getUTCMilliseconds()}else c.call(this)};var h=d.utcOffset;d.utcOffset=function(m,I){var _=this.$utils().u;if(_(m))return this.$u?0:_(this.$offset)?h.call(this):this.$offset;if(typeof m=="string"&&(m=function(O){O===void 0&&(O="");var b=O.match(t);if(!b)return null;var L=(""+b[0]).match(a)||["-",0,0],j=L[0],A=60*+L[1]+ +L[2];return A===0?0:j==="+"?A:-A}(m),m===null))return this;var V=Math.abs(m)<=16?60*m:m,D=this;if(I)return D.$offset=V,D.$u=m===0,D;if(m!==0){var y=this.$u?this.toDate().getTimezoneOffset():-1*this.utcOffset();(D=this.local().add(V+y,e)).$offset=V,D.$x.$localOffset=y}else D=this.utc();return D};var p=d.format;d.format=function(m){var I=m||(this.$u?"YYYY-MM-DDTHH:mm:ss[Z]":"");return p.call(this,I)},d.valueOf=function(){var m=this.$utils().u(this.$offset)?0:this.$offset+(this.$x.$localOffset||this.$d.getTimezoneOffset());return this.$d.valueOf()-6e4*m},d.isUTC=function(){return!!this.$u},d.toISOString=function(){return this.toDate().toISOString()},d.toString=function(){return this.toDate().toUTCString()};var f=d.toDate;d.toDate=function(m){return m==="s"&&this.$offset?l(this.format("YYYY-MM-DD HH:mm:ss:SSS")).toDate():f.call(this)};var g=d.diff;d.diff=function(m,I,_){if(m&&this.$u===m.$u)return g.call(this,m,I,_);var V=this.local(),D=l(m).local();return g.call(V,D,I,_)}}})})(Kt);var Cn=Kt.exports;const In=Ca(Cn);var yn=Object.defineProperty,Mn=Object.getOwnPropertyDescriptor,wn=(r,n,e,t)=>{for(var a=t>1?void 0:t?Mn(n,e):n,i=r.length-1,o;i>=0;i--)(o=r[i])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&yn(n,e,a),a},Pe=(r,n)=>(e,t)=>n(e,t,r);v.DataValidationRejectInputController=class extends s.Disposable{constructor(n,e,t,a,i){super(),this._editorBridgeService=n,this._dataValidationModel=e,this._dataValidatorRegistryService=t,this._dialogService=a,this._localeService=i,this._initEditorBridgeInterceptor()}_initEditorBridgeInterceptor(){this._editorBridgeService.interceptor.intercept(this._editorBridgeService.interceptor.getInterceptPoints().AFTER_CELL_EDIT_ASYNC,{handler:async(n,e,t)=>{const a=await n,{worksheet:i,row:o,col:l,unitId:d,subUnitId:u}=e,c=this._dataValidationModel.ensureManager(d,u),h=c.getRuleIdByLocation(o,l),p=h?c.getRuleById(h):void 0;if(!p||p.errorStyle!==s.DataValidationErrorStyle.STOP)return t(Promise.resolve(a));const f=await this._dataValidatorRegistryService.getValidatorItem(p.type);if(!f||await f.validator({value:te(a),row:o,column:l,unitId:d,subUnitId:u},p))return t(Promise.resolve(a));const m=i.getCellRaw(o,l);return this._dialogService.open({width:368,title:{title:this._localeService.t("dataValidation.alert.title")},id:"reject-input-dialog",children:{title:f.getRuleFinalError(p)},footer:{title:E.createElement(T.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(m))}})}showReject(n){this._dialogService.open({width:368,title:{title:this._localeService.t("dataValidation.alert.title")},id:"reject-input-dialog",children:{title:n},footer:{title:E.createElement(T.Button,{type:"primary",onClick:()=>this._dialogService.close("reject-input-dialog")},this._localeService.t("dataValidation.alert.ok"))},onClose:()=>{this._dialogService.close("reject-input-dialog")}})}},v.DataValidationRejectInputController=wn([s.OnLifecycle(s.LifecycleStages.Ready,v.DataValidationRejectInputController),Pe(0,B.IEditorBridgeService),Pe(1,M.Inject(C.DataValidationModel)),Pe(2,M.Inject(C.DataValidatorRegistryService)),Pe(3,q.IDialogService),Pe(4,M.Inject(s.LocaleService))],v.DataValidationRejectInputController);const Qt={dvDateDropdown:"univer-dv-date-dropdown",dvDateDropdownBtns:"univer-dv-date-dropdown-btns"};de.extend(In);const On=r=>{if(r==null||typeof r=="boolean")return;if(typeof r=="number"||!Number.isNaN(+r)){const e=de.unix(hn(+r)).utc().format().slice(0,-1);return de(e)}const n=de(r);if(n.isValid())return n};function Tn(r){var y,O,b;const{location:n,hideFn:e}=r,{worksheet:t,row:a,col:i,unitId:o,subUnitId:l}=n,d=H.useDependency(s.ICommandService),u=H.useDependency(v.DataValidationRejectInputController),c=t.getCell(a,i),h=(y=c==null?void 0:c.dataValidation)==null?void 0:y.rule,p=(O=c==null?void 0:c.dataValidation)==null?void 0:O.validator,f=te(c),g=On(f),[m,I]=E.useState(g),_=!!((b=h==null?void 0:h.bizInfo)!=null&&b.showTime),V=m&&m.isValid()?m:de();if(!c||!h||!p)return;const D=async()=>{if(!m)return;const j=`${m.format(_?"YYYY-MM-DD HH:mm:ss":"YYYY-MM-DD 00:00:00").split(" ").join("T")}Z`,A=zt(de(j).unix());h.errorStyle!==s.DataValidationErrorStyle.STOP||await p.validator({value:A,unitId:o,subUnitId:l,row:a,column:i},h)?(d.executeCommand($.SetRangeValuesCommand.id,{unitId:o,subUnitId:l,range:{startColumn:i,endColumn:i,startRow:a,endRow:a},value:{v:A,t:2,p:null,f:null,si:null,s:{n:{pattern:_?"yyyy-MM-dd hh:mm:ss":"yyyy-MM-dd"}}}}),e()):u.showReject(p.getRuleFinalError(h))};return S.jsxs("div",{className:Qt.dvDateDropdown,children:[S.jsx(T.DatePanel,{defaultValue:m,pickerValue:m!=null?m:V,showTime:_||void 0,onSelect:async L=>{I(L)},onPanelChange:L=>{I(L)}}),S.jsx("div",{className:Qt.dvDateDropdownBtns,children:S.jsx(T.Button,{size:"small",type:"primary",onClick:D,disabled:!m,children:"确定"})})]})}const Zt="data-validation.list.dropdown",Jt="data-validation.date.dropdown",En={[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 bn={[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"},Fn={[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"},Nn="DATE_SHOW_TIME_OPTION";function ze(r){var a;const{value:n,onChange:e}=r,t=H.useDependency(s.LocaleService);return S.jsx(T.FormLayout,{children:S.jsx(T.Checkbox,{checked:(a=n.bizInfo)==null?void 0:a.showTime,onChange:i=>{e({...n,bizInfo:{...n.bizInfo,showTime:i}})},children:t.t("dataValidation.showTime.label")})})}ze.componentKey=Nn;const ea="{FORMULA1}",ta="{FORMULA2}",Ae=r=>{if(r==null||typeof r=="boolean")return;if(typeof r=="number"||!Number.isNaN(+r))return+r;const n=`${de(r).format("YYYY-MM-DD HH:mm:ss").split(" ").join("T")}Z`;return zt(de(n).unix())};class Ln extends C.BaseDataValidator{constructor(){super(...arguments);R(this,"id",s.DataValidationType.DATE);R(this,"title","dataValidation.date.title");R(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]);R(this,"scopes",["sheet"]);R(this,"formulaInput",Fe);R(this,"optionsInput",ze.componentKey);R(this,"dropdown",Jt);R(this,"_formulaService",this.injector.get(v.DataValidationFormulaService))}async parseFormula(e,t,a){var d,u;const i=await this._formulaService.getRuleFormulaResult(t,a,e.uid),{formula1:o,formula2:l}=e;return{formula1:Ae(s.isFormulaString(o)?le((d=i==null?void 0:i[0])==null?void 0:d.result):o),formula2:Ae(s.isFormulaString(l)?le((u=i==null?void 0:i[1])==null?void 0:u.result):l)}}parseFormulaSync(e,t,a){var d,u;const i=this._formulaService.getRuleFormulaResultSync(t,a,e.uid),{formula1:o,formula2:l}=e;return{formula1:Ae(s.isFormulaString(o)?le((d=i==null?void 0:i[0])==null?void 0:d.result):o),formula2:Ae(s.isFormulaString(l)?le((u=i==null?void 0:i[1])==null?void 0:u.result):l)}}async isValidType(e){const{value:t}=e;return typeof t=="string"?de(t,"YYYY-MM-DD HH:mm:ss",!0).isValid():typeof t=="number"}_validatorSingleFormula(e){return!s.Tools.isBlank(e)&&(s.isFormulaString(e)||!Number.isNaN(+e)||!!e&&de(e).isValid())}validatorFormula(e,t,a){const i=e.operator;if(!i)return{success:!1};const o=this._validatorSingleFormula(e.formula1),l=this.localeService.t("dataValidation.validFail.date");if(Xe.includes(i)){const u=this._validatorSingleFormula(e.formula2);return{success:o&&u,formula1:o?void 0:l,formula2:u?void 0:l}}return{success:o,formula1:o?void 0:l}}transform(e,t,a){const{value:i}=e;return{...e,value:Ae(i)}}async validatorIsEqual(e,t,a){const{formula1:i}=t,{value:o}=e;return Number.isNaN(i)?!0:o===i}async validatorIsNotEqual(e,t,a){const{formula1:i}=t;return Number.isNaN(i)?!0:e.value!==i}async validatorIsBetween(e,t,a){const{formula1:i,formula2:o}=t;if(Number.isNaN(i)||Number.isNaN(o))return!0;const l=Math.min(i,o),d=Math.max(i,o);return e.value>=l&&e.value<=d}async validatorIsNotBetween(e,t,a){const{formula1:i,formula2:o}=t;if(Number.isNaN(i)||Number.isNaN(o))return!0;const l=Math.min(i,o),d=Math.max(i,o);return e.value<l||e.value>d}async validatorIsGreaterThan(e,t,a){const{formula1:i}=t;return Number.isNaN(i)?!0:e.value>i}async validatorIsGreaterThanOrEqual(e,t,a){const{formula1:i}=t;return Number.isNaN(i)?!0:e.value>=i}async validatorIsLessThan(e,t,a){const{formula1:i}=t;return Number.isNaN(i)?!0:e.value<i}async validatorIsLessThanOrEqual(e,t,a){const{formula1:i}=t;return Number.isNaN(i)?!0:e.value<=i}get operatorNames(){return this.operators.map(e=>this.localeService.t(En[e]))}generateRuleName(e){var a,i;if(!e.operator)return this.titleStr;const t=this.localeService.t(bn[e.operator]).replace(ea,(a=e.formula1)!=null?a:"").replace(ta,(i=e.formula2)!=null?i:"");return`${this.titleStr} ${t}`}generateRuleErrorMessage(e){var a,i;return e.operator?`${this.localeService.t(Fn[e.operator]).replace(ea,(a=e.formula1)!=null?a:"").replace(ta,(i=e.formula2)!=null?i:"")}`:this.titleStr}}var Pn=Object.defineProperty,An=Object.getOwnPropertyDescriptor,jn=(r,n,e,t)=>{for(var a=t>1?void 0:t?An(n,e):n,i=r.length-1,o;i>=0;i--)(o=r[i])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&Pn(n,e,a),a},aa=(r,n)=>(e,t)=>n(e,t,r);const we=4,Un=6,ce=14,Ve=6,ve=4,$n="#565656",na=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 Bn(r,n){const e=r.length;return{id:"d",body:{dataStream:`${r}${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,...n,bg:void 0,bd:void 0},st:0,ed:e}]},documentStyle:{pageSize:{width:Number.POSITIVE_INFINITY,height:Number.POSITIVE_INFINITY}}}}function ia(r,n,e){const t=Bn(r,e),a=new s.DocumentDataModel(t),i=new Z.DocumentViewModel(a);return{documentSkeleton:Z.DocumentSkeleton.create(i,n),docModel:a,docViewModel:i}}function ht(r,n,e){const{documentSkeleton:t,docModel:a,docViewModel:i}=ia(r,n,e);return{documents:new Z.Documents(`DOCUMENTS_${s.Tools.generateRandomId()}`,t,{pageMarginLeft:0,pageMarginTop:0}),documentSkeleton:t,docModel:a,docViewModel:i}}function ra(r,n,e,t,a,i){let o=0;switch(a){case s.VerticalAlign.BOTTOM:o=n-ve*2-t+ve;break;case s.VerticalAlign.MIDDLE:o=(n-ve*2-t)/2+ve;break;default:o=ve;break}let l=0;switch(i){case s.HorizontalAlign.CENTER:l=(r-e)/2;break;case s.HorizontalAlign.RIGHT:l=r-e;break}return{paddingLeft:l,paddingTop:o}}let ft=(Tt=class{constructor(r,n){R(this,"_dropdownInfoMap",new Map);R(this,"zIndex");R(this,"onPointerEnter");R(this,"onPointerLeave");this._localeService=r,this._commandService=n}_ensureMap(r){let n=this._dropdownInfoMap.get(r);return n||(n=new Map,this._dropdownInfoMap.set(r,n)),n}_generateKey(r,n){return`${r}.${n}`}_drawDownIcon(r,n,e,t,a){const i=e-ce+4;let o=9;switch(a){case s.VerticalAlign.MIDDLE:o=(t-ce)/2+4;break;case s.VerticalAlign.BOTTOM:o=t-ce-1;break}r.save(),r.translateWithPrecision(n.startX+i,n.startY+o),r.fillStyle="#565656",r.fill(na),r.restore()}drawWith(r,n,e){var k,X;const{primaryWithCoord:t,row:a,col:i,style:o,data:l,subUnitId:d}=n,u=t.isMergedMainCell?t.mergeInfo:t,c=(k=l.dataValidation)==null?void 0:k.rule,h=(X=l.dataValidation)==null?void 0:X.validator,p=l.fontRenderExtension,{leftOffset:f=0,rightOffset:g=0,topOffset:m=0,downOffset:I=0}=p||{};if(!c||!h||!h.skipDefaultFontRender(c))return;const _={startX:u.startX+f,endX:u.endX-g,startY:u.startY+m,endY:u.endY-I},V=_.endX-_.startX,D=_.endY-_.startY,y=this._ensureMap(d),O=this._generateKey(a,i),b=h.getListWithColor(c),L=te(l),j=`${L!=null?L:""}`,A=b.find(N=>N.label===j);let{tb:x,vt:F,ht:U}=o||{};if(x=x!=null?x:s.WrapStrategy.WRAP,F=F!=null?F:s.VerticalAlign.BOTTOM,U=U!=null?U:s.HorizontalAlign.LEFT,c.renderMode===s.DataValidationRenderMode.ARROW){this._drawDownIcon(r,_,V,D,F),r.save(),r.translateWithPrecision(_.startX,_.startY),r.beginPath(),r.rect(0,0,V,D),r.clip();const N=V-ce,{documentSkeleton:Y,documents:Q,docModel:G}=ht(j,this._localeService,o);x===s.WrapStrategy.WRAP&&G.updateDocumentDataPageSize(Math.max(N,1)),Y.calculate(),Y.getActualSize();const w=Z.getDocsSkeletonPageSize(Y),{height:W,width:ae}=w,{paddingTop:K,paddingLeft:me}=ra(N,D,ae,W,F,U);r.translate(0,K),r.save(),r.translateWithPrecision(we,0),r.beginPath(),r.rect(0,0,N,W),r.clip(),Q.render(r),r.translateWithPrecision(me,0),r.restore(),r.restore(),y.set(O,{left:_.endX+e.rowHeaderWidth-ce,top:_.startY+e.columnHeaderHeight,width:ce,height:D})}else{r.save(),r.translateWithPrecision(_.startX,_.startY),r.beginPath(),r.rect(0,0,V,D),r.clip();const N=V-Ve*2-we-ce,{documentSkeleton:Y,documents:Q,docModel:G}=ht(j,this._localeService,o);x===s.WrapStrategy.WRAP&&G.updateDocumentDataPageSize(Math.max(N,1)),Y.calculate();const w=Z.getDocsSkeletonPageSize(Y),{height:W,width:ae}=w,{paddingTop:K,paddingLeft:me}=ra(N,D,ae,W,F,U);r.translate(Ve,K);const Ce=Math.max(V-Ve*2,1),P=W;Z.Rect.drawWith(r,{width:Ce,height:P,fill:(A==null?void 0:A.color)||De,radius:8}),r.save(),r.translateWithPrecision(we,0),r.beginPath(),r.rect(0,0,N,W),r.clip(),r.translateWithPrecision(me,0),Q.render(r),r.restore(),r.translate(N+we+4,(W-Un)/2),r.fillStyle=$n,r.fill(na),r.restore(),y.set(O,{left:_.startX+Ve+e.rowHeaderWidth,top:_.startY+K+e.columnHeaderHeight,width:Ce,height:P})}}calcCellAutoHeight(r){var I;const{primaryWithCoord:n,style:e,data:t}=r,a=n.isMergedMainCell?n.mergeInfo:n,i=t.fontRenderExtension,{leftOffset:o=0,rightOffset:l=0,topOffset:d=0,downOffset:u=0}=i||{},c=(I=t.dataValidation)==null?void 0:I.rule;if(!c||c.renderMode===s.DataValidationRenderMode.TEXT)return;const h={startX:a.startX+o,endX:a.endX-l,startY:a.startY+d,endY:a.endY-u},p=h.endX-h.startX,f=te(t),g=`${f!=null?f:""}`;let{tb:m}=e||{};if(m=m!=null?m:s.WrapStrategy.WRAP,c.renderMode===s.DataValidationRenderMode.ARROW){const _=p-ce,{documentSkeleton:V,docModel:D}=ht(g,this._localeService,e);m===s.WrapStrategy.WRAP&&D.updateDocumentDataPageSize(Math.max(_,1)),V.calculate(),V.getActualSize();const y=Z.getDocsSkeletonPageSize(V),{height:O}=y;return O}else{const _=p-Ve*2-we-ce,{documentSkeleton:V,docModel:D}=ia(g,this._localeService,e);m===s.WrapStrategy.WRAP&&D.updateDocumentDataPageSize(Math.max(_,1)),V.calculate();const y=Z.getDocsSkeletonPageSize(V),{height:O}=y;return O+ve*2}}isHit(r,n){const{data:e,subUnitId:t,row:a,col:i}=n,l=this._ensureMap(t).get(this._generateKey(a,i)),d=e.dataValidation;if(!d||!l||d.rule.renderMode===s.DataValidationRenderMode.TEXT)return!1;const{top:u,left:c,width:h,height:p}=l,{x:f,y:g}=r;return f>=c&&f<=c+h&&g>=u&&g<=u+p}onPointerDown(r,n){if(n.button===2)return;const{unitId:e,subUnitId:t,row:a,col:i}=r,o={unitId:e,subUnitId:t,row:a,column:i};this._commandService.executeCommand(Ee.id,o)}},R(Tt,"padding",{l:Ve+we,r:ce+Ve,t:ve,b:ve}),Tt);ft=jn([aa(0,M.Inject(s.LocaleService)),aa(1,s.ICommandService)],ft);const Wn="LIST_RENDER_MODE_OPTION_INPUT";function Ke(r){var a;const{value:n,onChange:e}=r,t=H.useDependency(s.LocaleService);return S.jsx(T.FormLayout,{label:t.t("dataValidation.renderMode.label"),children:S.jsxs(T.RadioGroup,{value:`${(a=n.renderMode)!=null?a:s.DataValidationRenderMode.CUSTOM}`,onChange:i=>e({...n,renderMode:+i}),children:[S.jsx(T.Radio,{value:`${s.DataValidationRenderMode.CUSTOM}`,children:t.t("dataValidation.renderMode.chip")}),S.jsx(T.Radio,{value:`${s.DataValidationRenderMode.ARROW}`,children:t.t("dataValidation.renderMode.arrow")}),S.jsx(T.Radio,{value:`${s.DataValidationRenderMode.TEXT}`,children:t.t("dataValidation.renderMode.text")})]})})}Ke.componentKey=Wn;function pt(r){if(!r)return[];const n=new Set;return r.forEach(e=>{e.forEach(t=>{var i,o;const a=te(t);if(a!=null){if(typeof a!="string"&&typeof(t==null?void 0:t.s)=="object"&&((o=(i=t.s)==null?void 0:i.n)!=null&&o.pattern)){n.add(Va.numfmt.format(t.s.n.pattern,a));return}n.add(a.toString())}})}),[...n]}const Hn=["if","indirect","choose","offset"];function xn(r,n){if(!s.isFormulaString(r)||re.isReferenceString(r.slice(1)))return!0;const t=n.sequenceNodesBuilder(r);return t&&t.some(a=>typeof a=="object"&&a.nodeType===re.sequenceNodeType.FUNCTION&&Hn.indexOf(a.token.toLowerCase())>-1)}function kn(r,n){const{formula1:e="",ranges:t}=r;if(re.isReferenceString(e.slice(1))){const i=re.deserializeRangeWithSheet(e.slice(1));if((!i.sheetName||i.sheetName===n)&&t.some(o=>s.Rectangle.intersects(o,i.range)))return!0}return!1}class oa extends C.BaseDataValidator{constructor(){super(...arguments);R(this,"formulaService",this.injector.get(v.DataValidationFormulaService));R(this,"_lexer",this.injector.get(re.LexerTreeBuilder));R(this,"_univerInstanceService",this.injector.get(s.IUniverInstanceService));R(this,"id",s.DataValidationType.LIST);R(this,"title","dataValidation.list.title");R(this,"operators",[]);R(this,"scopes",["sheet"]);R(this,"formulaInput",qt);R(this,"canvasRender",this.injector.createInstance(ft));R(this,"dropdown",Zt);R(this,"optionsInput",Ke.componentKey)}skipDefaultFontRender(e){return e.renderMode!==s.DataValidationRenderMode.TEXT}validatorFormula(e,t,a){var u,c,h;const i=!s.Tools.isBlank(e.formula1),o=xn((u=e.formula1)!=null?u:"",this._lexer),l=(h=(c=this._univerInstanceService.getUnit(t,s.UniverInstanceType.UNIVER_SHEET))==null?void 0:c.getSheetBySheetId(a))==null?void 0:h.getName(),d=kn(e,l!=null?l:"");return{success:!!(i&&o&&!d),formula1:i?o?d?this.localeService.t("dataValidation.validFail.listIntersects"):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:i=""}=e,o=await this.formulaService.getRuleFormulaResult(t,a,e.uid);return{formula1:s.isFormulaString(i)?pt((l=o==null?void 0:o[0])==null?void 0:l.result):ye(i),formula2:void 0}}async isValidType(e,t,a){const{value:i}=e,{formula1:o=[]}=t;return this.parseCellValue(i).every(d=>o.includes(d))}generateRuleName(){return this.localeService.t("dataValidation.list.name")}generateRuleErrorMessage(){return this.localeService.t("dataValidation.list.error")}getList(e,t,a){var p,f,g;const{formula1:i=""}=e,o=this.injector.get(s.IUniverInstanceService),l=(p=t?o.getUniverSheetInstance(t):void 0)!=null?p:o.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET);if(!l)return[];const d=(f=a?l.getSheetBySheetId(a):void 0)!=null?f:l.getActiveSheet();if(!d)return[];const u=l.getUnitId(),c=d.getSheetId(),h=this.formulaService.getRuleFormulaResultSync(u,c,e.uid);return s.isFormulaString(i)?pt((g=h==null?void 0:h[0])==null?void 0:g.result):ye(i)}async getListAsync(e,t,a){var p,f,g;const{formula1:i=""}=e,o=this.injector.get(s.IUniverInstanceService),l=(p=t?o.getUniverSheetInstance(t):void 0)!=null?p:o.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET);if(!l)return[];const d=(f=a?l.getSheetBySheetId(a):void 0)!=null?f:l.getActiveSheet();if(!d)return[];const u=l.getUnitId(),c=d.getSheetId(),h=await this.formulaService.getRuleFormulaResult(u,c,e.uid);return s.isFormulaString(i)?pt((g=h==null?void 0:h[0])==null?void 0:g.result):ye(i)}getListWithColor(e,t,a){const i=this.getList(e,t,a),o=(e.formula2||"").split(",");return i.map((l,d)=>({label:l,color:o[d]}))}getListWithColorMap(e,t,a){const i=this.getListWithColor(e,t,a),o={};return i.forEach(l=>{l.color&&(o[l.label]=l.color)}),o}}function Qe(r){let n=r;return typeof r=="string"?((r.startsWith("¥")||r.startsWith("$"))&&(n=r.slice(1)),+n):+r}class Yn extends C.BaseDataValidator{constructor(){super(...arguments);R(this,"_formulaService",this.injector.get(v.DataValidationFormulaService));R(this,"id",s.DataValidationType.DECIMAL);R(this,"title","dataValidation.decimal.title");R(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]);R(this,"scopes",["sheet"]);R(this,"formulaInput",Fe);R(this,"dropDownInput")}_isFormulaOrNumber(e){return!s.Tools.isBlank(e)&&(s.isFormulaString(e)||!Number.isNaN(+e))}async isValidType(e,t,a){const{value:i}=e;return!Number.isNaN(Qe(i))}transform(e,t,a){const{value:i}=e;return{...e,value:Qe(i)}}_parseNumber(e){return e==null?Number.NaN:+e}async parseFormula(e,t,a){var u,c,h,p,f,g,m,I;const i=await this._formulaService.getRuleFormulaResult(t,a,e.uid),{formula1:o,formula2:l}=e;return{formula1:this._parseNumber(s.isFormulaString(o)?(p=(h=(c=(u=i==null?void 0:i[0])==null?void 0:u.result)==null?void 0:c[0])==null?void 0:h[0])==null?void 0:p.v:o),formula2:this._parseNumber(s.isFormulaString(l)?(I=(m=(g=(f=i==null?void 0:i[1])==null?void 0:f.result)==null?void 0:g[0])==null?void 0:m[0])==null?void 0:I.v:l)}}validatorFormula(e,t,a){const i=e.operator;if(!i)return{success:!1};const o=s.Tools.isDefine(e.formula1)&&this._isFormulaOrNumber(e.formula1),l=s.Tools.isDefine(e.formula2)&&this._isFormulaOrNumber(e.formula2),d=Xe.includes(i),u=this.localeService.t("dataValidation.validFail.number");return d?{success:o&&l,formula1:o?void 0:u,formula2:l?void 0:u}:{success:o,formula1:o?"":u}}async validatorIsEqual(e,t,a){const{formula1:i}=t,{value:o}=e;return Number.isNaN(i)?!0:o===i}async validatorIsNotEqual(e,t,a){const{formula1:i}=t;return Number.isNaN(i)?!0:e.value!==i}async validatorIsBetween(e,t,a){const{formula1:i,formula2:o}=t;if(Number.isNaN(i)||Number.isNaN(o))return!0;const l=Math.min(i,o),d=Math.max(i,o);return e.value>=l&&e.value<=d}async validatorIsNotBetween(e,t,a){const{formula1:i,formula2:o}=t;if(Number.isNaN(i)||Number.isNaN(o))return!0;const l=Math.min(i,o),d=Math.max(i,o);return e.value<l||e.value>d}async validatorIsGreaterThan(e,t,a){const{formula1:i}=t;return Number.isNaN(i)?!0:e.value>i}async validatorIsGreaterThanOrEqual(e,t,a){const{formula1:i}=t;return Number.isNaN(i)?!0:e.value>=i}async validatorIsLessThan(e,t,a){const{formula1:i}=t;return Number.isNaN(i)?!0:e.value<i}async validatorIsLessThanOrEqual(e,t,a){const{formula1:i}=t;return Number.isNaN(i)?!0:e.value<=i}}const qn="{FORMULA1}",Xn="{FORMULA2}";class Gn extends C.BaseDataValidator{constructor(){super(...arguments);R(this,"id",s.DataValidationType.TEXT_LENGTH);R(this,"title","dataValidation.textLength.title");R(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]);R(this,"scopes",["sheet"]);R(this,"formulaInput",Fe);R(this,"_formulaService",this.injector.get(v.DataValidationFormulaService))}_isFormulaOrInt(e){return!s.Tools.isBlank(e)&&(s.isFormulaString(e)||!Number.isNaN(+e)&&Number.isInteger(+e))}validatorFormula(e,t,a){const i=e.operator;if(!i)return{success:!1};const o=s.Tools.isDefine(e.formula1)&&this._isFormulaOrInt(e.formula1),l=s.Tools.isDefine(e.formula2)&&this._isFormulaOrInt(e.formula2),d=Xe.includes(i),u=this.localeService.t("dataValidation.validFail.number");return d?{success:o&&l,formula1:o?void 0:u,formula2:l?void 0:u}:{success:o,formula1:u}}_parseNumber(e){return e==null?Number.NaN:+e}_isValidFormula(e){return!Number.isNaN(e)}async parseFormula(e,t,a){var d,u,c,h,p,f,g,m;const i=await this._formulaService.getRuleFormulaResult(t,a,e.uid),{formula1:o,formula2:l}=e;return{formula1:this._parseNumber(s.isFormulaString(o)?(h=(c=(u=(d=i==null?void 0:i[0])==null?void 0:d.result)==null?void 0:u[0])==null?void 0:c[0])==null?void 0:h.v:o),formula2:this._parseNumber(s.isFormulaString(l)?(m=(g=(f=(p=i==null?void 0:i[1])==null?void 0:p.result)==null?void 0:f[0])==null?void 0:g[0])==null?void 0:m.v:l)}}transform(e,t,a){return{...e,value:e.value.toString().length}}async isValidType(e,t,a){const{value:i}=e;return typeof i=="string"||typeof i=="number"}async validatorIsEqual(e,t,a){const{formula1:i}=t;return s.Tools.isDefine(i)?e.value===i:!1}async validatorIsNotEqual(e,t,a){const{formula1:i}=t;return s.Tools.isDefine(i)?e.value!==i:!1}async validatorIsBetween(e,t,a){const{formula1:i,formula2:o}=t,{value:l}=e;if(!this._isValidFormula(i)||!this._isValidFormula(o))return!1;const d=Math.max(i,o),u=Math.min(i,o);return l>=u&&l<=d}async validatorIsNotBetween(e,t,a){const{formula1:i,formula2:o}=t,{value:l}=e;if(!this._isValidFormula(i)||!this._isValidFormula(o))return!1;const d=Math.max(i,o),u=Math.min(i,o);return l<u||l>d}async validatorIsGreaterThan(e,t,a){const{formula1:i}=t,{value:o}=e;return this._isValidFormula(i)?o>i:!1}async validatorIsGreaterThanOrEqual(e,t,a){const{formula1:i}=t,{value:o}=e;return this._isValidFormula(i)?o>=i:!1}async validatorIsLessThan(e,t,a){const{formula1:i}=t,{value:o}=e;return this._isValidFormula(i)?o<i:!1}async validatorIsLessThanOrEqual(e,t,a){const{formula1:i}=t,{value:o}=e;return this._isValidFormula(i)?o<=i:!1}generateRuleErrorMessage(e){var a,i;return e.operator?`${this.localeService.t(C.TextLengthErrorTitleMap[e.operator]).replace(qn,(a=e.formula1)!=null?a:"").replace(Xn,(i=e.formula2)!=null?i:"")}`:this.titleStr}}function sa(r){var e,t;return r?r.p?!((t=(e=r.p.body)==null?void 0:e.dataStream)!=null?t:"").slice(0,-2).trim():s.Tools.isBlank(r.v):!0}function Oe(r,n,e,t){const a=[],i=[],l=t.get(C.DataValidationModel).ensureManager(r,n),d=t.get(s.IUniverInstanceService),u=$.getSheetCommandTarget(d,{unitId:r,subUnitId:n});if(!u)return{redoMutations:a,undoMutations:i};const{worksheet:c}=u,h=new s.ObjectMatrix;function p(m,I){m.forEach(_=>{s.Range.foreach(_,(V,D)=>{const y=c.getCellRaw(V,D),O=Et(y);(sa(y)||O===I)&&h.setValue(V,D,{v:I,p:null})})})}e.forEach(m=>{switch(m.type){case"delete":a.push({id:C.RemoveDataValidationMutation.id,params:{unitId:r,subUnitId:n,ruleId:m.rule.uid}}),i.unshift({id:C.AddDataValidationMutation.id,params:{unitId:r,subUnitId:n,rule:m.rule,index:m.index}});break;case"update":{a.push({id:C.UpdateDataValidationMutation.id,params:{unitId:r,subUnitId:n,ruleId:m.ruleId,payload:{type:C.UpdateRuleType.RANGE,payload:m.newRanges}}}),i.unshift({id:C.UpdateDataValidationMutation.id,params:{unitId:r,subUnitId:n,ruleId:m.ruleId,payload:{type:C.UpdateRuleType.RANGE,payload:m.oldRanges}}});const I=l.getRuleById(m.ruleId);if(I&&I.type===s.DataValidationType.CHECKBOX){const V=l.getValidator(s.DataValidationType.CHECKBOX).parseFormulaSync(I,r,n);p(m.newRanges,V.formula2)}break}case"add":{if(a.push({id:C.AddDataValidationMutation.id,params:{unitId:r,subUnitId:n,rule:m.rule}}),i.unshift({id:C.RemoveDataValidationMutation.id,params:{unitId:r,subUnitId:n,ruleId:m.rule.uid}}),m.rule.type===s.DataValidationType.CHECKBOX){const _=l.getValidator(s.DataValidationType.CHECKBOX).parseFormulaSync(m.rule,r,n);p(m.rule.ranges,_.formula2)}break}}});const f={id:$.SetRangeValuesMutation.id,params:{unitId:r,subUnitId:n,cellValue:h.getData()}},g={id:$.SetRangeValuesMutation.id,params:$.SetRangeValuesUndoMutationFactory(t,f.params)};return a.push(f),i.push(g),{redoMutations:a,undoMutations:i}}const je={type:s.CommandType.COMMAND,id:"sheet.command.updateDataValidationRuleRange",async handler(r,n){if(!n)return!1;const{unitId:e,subUnitId:t,ranges:a,ruleId:i}=n,o=r.get(C.DataValidationModel),l=r.get(s.ICommandService),d=r.get(s.IUndoRedoService),u=o.ensureManager(e,t),c=u.getRuleById(i);if(!c)return!1;const h=c.ranges,p=u.getRuleObjectMatrix().clone();p.updateRange(i,h,a);const f=p.diff(u.getDataValidations()),{redoMutations:g,undoMutations:m}=Oe(e,t,f,r);return d.pushUndoRedo({undoMutations:m,redoMutations:g,unitID:e}),await s.sequenceExecuteAsync(g,l),!0}},Ue={type:s.CommandType.COMMAND,id:"sheet.command.addDataValidation",async handler(r,n){if(!n)return!1;const{unitId:e,subUnitId:t,rule:a}=n,i=r.get(C.DataValidationModel),o=r.get(s.ICommandService),l=r.get(s.IUndoRedoService),d=i.ensureManager(e,t),u=d.getRuleObjectMatrix().clone();u.addRule(a);const c=u.diff(d.getDataValidations()),h={unitId:e,subUnitId:t,rule:a},{redoMutations:p,undoMutations:f}=Oe(e,t,c,r);return p.push({id:C.AddDataValidationMutation.id,params:h}),f.unshift({id:C.RemoveDataValidationMutation.id,params:{unitId:e,subUnitId:t,ruleId:a.uid}}),l.pushUndoRedo({unitID:e,redoMutations:p,undoMutations:f}),await s.sequenceExecuteAsync(p,o),!0}},Ze={type:s.CommandType.COMMAND,id:"data-validation.command.addRuleAndOpen",async handler(r){const n=r.get(s.IUniverInstanceService),e=$.getSheetCommandTarget(n);if(!e)return!1;const{workbook:t,worksheet:a}=e,i=C.createDefaultNewRule(r),o=r.get(s.ICommandService),l=t.getUnitId(),d=a.getSheetId(),u={rule:i,unitId:l,subUnitId:d};return await o.executeCommand(Ue.id,u)?(o.executeCommand(Se.id,{ruleId:i.uid,isAdd:!0}),!0):!1}},vt={type:s.CommandType.COMMAND,id:"sheets.command.update-data-validation-setting",handler(r,n){if(!n)return!1;const e=r.get(s.ICommandService),t=r.get(s.IUndoRedoService),a=r.get(C.DataValidationModel),i=r.get(C.DataValidatorRegistryService),{unitId:o,subUnitId:l,ruleId:d,setting:u}=n,c=i.getValidatorItem(u.type);if(!c)return!1;const h=a.getRuleById(o,l,d);if(!h||!c.validatorFormula({...h,...u},o,l).success)return!1;const p={unitId:o,subUnitId:l,ruleId:d,payload:{type:C.UpdateRuleType.SETTING,payload:u}},f=[{id:C.UpdateDataValidationMutation.id,params:p}],g={unitId:o,subUnitId:l,ruleId:d,payload:{type:C.UpdateRuleType.SETTING,payload:C.getRuleSetting(h)}},m=[{id:C.UpdateDataValidationMutation.id,params:g}];if(u.type===s.DataValidationType.CHECKBOX){const _=h.ranges,V=r.get(s.IUniverInstanceService),D=$.getSheetCommandTarget(V,{unitId:o,subUnitId:l});if(D){const y=new s.ObjectMatrix,{worksheet:O}=D,{formula2:b=Le,formula1:L=Ne}=h,{formula2:j=Le,formula1:A=Ne}=u;_.forEach(U=>{s.Range.foreach(U,(k,X)=>{const N=O.getCellRaw(k,X),Y=Et(N);sa(N)||Y===String(b)?y.setValue(k,X,{v:j,p:null}):Y===String(L)&&y.setValue(k,X,{v:A,p:null})})});const x={id:$.SetRangeValuesMutation.id,params:{unitId:o,subUnitId:l,cellValue:y.getData()}},F={id:$.SetRangeValuesMutation.id,params:$.SetRangeValuesUndoMutationFactory(r,x.params)};f.push(x),m.push(F)}}return s.sequenceExecute(f,e).result?(t.pushUndoRedo({unitID:o,redoMutations:f,undoMutations:m}),!0):!1}},la={type:s.CommandType.COMMAND,id:"sheets.command.update-data-validation-options",handler(r,n){if(!n)return!1;const e=r.get(s.ICommandService),t=r.get(s.IUndoRedoService),a=r.get(C.DataValidationModel),{unitId:i,subUnitId:o,ruleId:l,options:d}=n,u=a.getRuleById(i,o,l);if(!u)return!1;const c={unitId:i,subUnitId:o,ruleId:l,payload:{type:C.UpdateRuleType.OPTIONS,payload:d}},h=[{id:C.UpdateDataValidationMutation.id,params:c}],p={unitId:i,subUnitId:o,ruleId:l,payload:{type:C.UpdateRuleType.OPTIONS,payload:C.getRuleOptions(u)}},f=[{id:C.UpdateDataValidationMutation.id,params:p}];return t.pushUndoRedo({unitID:i,redoMutations:h,undoMutations:f}),e.executeCommand(C.UpdateDataValidationMutation.id,c),!0}},da="data-validation-single",gt="sheet.menu.data-validation";function zn(r){return{id:gt,type:q.MenuItemType.SUBITEMS,positions:[q.MenuPosition.TOOLBAR_START],group:q.MenuGroup.TOOLBAR_FORMULAS_INSERT,icon:da,tooltip:"dataValidation.title",hidden$:q.getMenuHiddenObservable(r,s.UniverInstanceType.UNIVER_SHEET),disabled$:B.getCurrentRangeDisable$(r,{workbookTypes:[$.WorkbookEditablePermission],worksheetTypes:[$.WorksheetSetCellStylePermission,$.WorksheetEditPermission],rangeTypes:[$.RangeProtectionPermissionEditPoint]})}}function Kn(r){return{id:Se.id,title:"dataValidation.panel.title",type:q.MenuItemType.BUTTON,positions:[gt]}}function Qn(r){return{id:Ze.id,title:"dataValidation.panel.add",type:q.MenuItemType.BUTTON,positions:[gt]}}var Zn=Object.defineProperty,Jn=Object.getOwnPropertyDescriptor,ua=(r,n,e,t)=>{for(var a=t>1?void 0:t?Jn(n,e):n,i=r.length-1,o;i>=0;i--)(o=r[i])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&Zn(n,e,a),a},ee=(r,n)=>(e,t)=>n(e,t,r);const ca={},ma={tr:{size:6,color:"#fe4b4b"}};v.SheetsDataValidationRenderController=class extends s.RxDisposable{constructor(n,e,t,a,i,o,l,d,u,c,h,p,f){super(),this._config=n,this._commandService=e,this._menuService=t,this._renderManagerService=a,this._univerInstanceService=i,this._autoHeightController=o,this._componentManager=l,this._dropdownManagerService=d,this._dataValidationModel=u,this._dataValidatorRegistryService=c,this._injector=h,this._sheetInterceptorService=p,this._editorBridgeService=f,this._initMenu(),this._initSkeletonChange(),this._initDropdown(),this._initViewModelIntercept(),this._initAutoHeight()}_initMenu(){const{menu:n={}}=this._config;[zn,Kn,Qn].forEach(e=>{this.disposeWithMe(this._menuService.addMenuItem(e(this._injector),n))})}_initDropdown(){this._editorBridgeService&&this.disposeWithMe(this._editorBridgeService.visible$.subscribe(n=>{if(!n.visible){this._dropdownManagerService.hideDropdown();return}const e=this._editorBridgeService.getEditCellState();if(e){const{unitId:t,sheetId:a,row:i,column:o}=e,l=this._univerInstanceService.getUniverSheetInstance(t);if(!l)return;const u=this._dataValidationModel.ensureManager(t,a).getRuleByLocation(i,o);if(!u)return;const c=this._dataValidatorRegistryService.getValidatorItem(u.type);if(!(c!=null&&c.dropdown))return;const h=l.getActiveSheet();if(!h)return;const p=this._dropdownManagerService.activeDropdown,f=p==null?void 0:p.location;if(f&&f.unitId===t&&f.subUnitId===a&&f.row===i&&f.col===o)return;this._dropdownManagerService.showDropdown({location:{unitId:t,subUnitId:a,row:i,col:o,workbook:l,worksheet:h},componentKey:c.dropdown,onHide:()=>{}},!1)}}))}_initSkeletonChange(){const n=()=>{var l,d,u;const e=this._univerInstanceService.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET);if(!e)return;const t=e.getUnitId(),a=(l=e.getActiveSheet())==null?void 0:l.getSheetId();if(!a)return;const i=(u=(d=this._renderManagerService.getRenderById(t))==null?void 0:d.with(B.SheetSkeletonManagerService).getWorksheetSkeleton(a))==null?void 0:u.skeleton,o=this._renderManagerService.getRenderById(t);i==null||i.makeDirty(!0),i==null||i.calculate(),o&&o.mainComponent.makeForceDirty()};this.disposeWithMe(this._dataValidationModel.ruleChange$.pipe(ie.debounceTime(16)).subscribe(()=>n())),this.disposeWithMe(this._dataValidationModel.validStatusChange$.pipe(ie.debounceTime(16)).subscribe(()=>n()))}_initViewModelIntercept(){this.disposeWithMe(this._sheetInterceptorService.intercept($.INTERCEPTOR_POINT.CELL_CONTENT,{priority:200,handler:(n,e,t)=>{var O,b,L,j,A,x;const{row:a,col:i,unitId:o,subUnitId:l,workbook:d,worksheet:u}=e,c=this._dataValidationModel.ensureManager(o,l);if(!c)return t(n);const h=(b=(O=this._renderManagerService.getRenderById(o))==null?void 0:O.with(B.SheetSkeletonManagerService).getWorksheetSkeleton(l))==null?void 0:b.skeleton;if(!h)return t(n);const p=e.workbook.getStyles(),f=(typeof(n==null?void 0:n.s)=="string"?p.get(n==null?void 0:n.s):n==null?void 0:n.s)||{},g=c.getRuleIdByLocation(a,i);if(!g)return t(n);const m=c.getRuleById(g);if(!m)return t(n);const I=u.getCellRaw(e.row,e.col),_=this._dataValidationModel.validator(te(I),m,e),V=this._dataValidatorRegistryService.getValidatorItem(m.type),D=te(n);let y={};if((m.type===s.DataValidationType.LIST||m.type===s.DataValidationType.LIST_MULTIPLE)&&(y={interceptorStyle:{...n==null?void 0:n.interceptorStyle,tb:(L=f.tb!==s.WrapStrategy.OVERFLOW?f.tb:s.WrapStrategy.CLIP)!=null?L:s.WrapStrategy.WRAP}}),m.type===s.DataValidationType.CHECKBOX&&(y={interceptorStyle:{...n==null?void 0:n.interceptorStyle,tb:s.WrapStrategy.CLIP}}),m.type===s.DataValidationType.LIST&&(m.renderMode===s.DataValidationRenderMode.ARROW||m.renderMode===s.DataValidationRenderMode.TEXT)){const F=V.getListWithColorMap(m),U=`${(j=te(n))!=null?j:""}`,k=F[U];k&&(y={...y,interceptorStyle:{...y.interceptorStyle,bg:{rgb:k}}})}return t({...n,...y,dataValidation:{ruleId:g,validStatus:_,rule:m,validator:V},markers:{...n==null?void 0:n.markers,..._===s.DataValidationStatus.INVALID?ma:null},customRender:[...(A=n==null?void 0:n.customRender)!=null?A:[],...V!=null&&V.canvasRender?[V.canvasRender]:[]],fontRenderExtension:{...n==null?void 0:n.fontRenderExtension,isSkip:V==null?void 0:V.skipDefaultFontRender(m,D,e)},interceptorStyle:{...n==null?void 0:n.interceptorStyle,...y.interceptorStyle},get interceptorAutoHeight(){var k,X,N,Y;const F=h.mergeData.find(Q=>{const{startColumn:G,startRow:w,endColumn:W,endRow:ae}=Q;return a>=w&&i>=G&&a<=ae&&i<=W}),U={data:{...n,dataValidation:{ruleId:g,validStatus:_,rule:m,validator:V}},style:h.getsStyles().getStyleByCell(n),primaryWithCoord:h.getCellByIndex((k=F==null?void 0:F.startRow)!=null?k:a,(X=F==null?void 0:F.startColumn)!=null?X:i),unitId:o,subUnitId:l,row:a,col:i,workbook:d,worksheet:u};return(Y=(N=V==null?void 0:V.canvasRender)==null?void 0:N.calcCellAutoHeight)==null?void 0:Y.call(N,U)},coverable:((x=n==null?void 0:n.coverable)!=null?x:!0)&&!(m.type===s.DataValidationType.LIST||m.type===s.DataValidationType.LIST_MULTIPLE)})}}))}_initAutoHeight(){this._dataValidationModel.ruleChange$.pipe(ie.bufferTime(16)).subscribe(n=>{const e=[];if(n.forEach(t=>{var a;(a=t.rule)!=null&&a.ranges&&e.push(...t.rule.ranges)}),e.length){const t=this._autoHeightController.getUndoRedoParamsOfAutoHeight(e);s.sequenceExecute(t.redos,this._commandService)}})}},v.SheetsDataValidationRenderController=ua([s.OnLifecycle(s.LifecycleStages.Rendered,v.SheetsDataValidationRenderController),ee(1,s.ICommandService),ee(2,q.IMenuService),ee(3,Z.IRenderManagerService),ee(4,s.IUniverInstanceService),ee(5,M.Inject(B.AutoHeightController)),ee(6,M.Inject(q.ComponentManager)),ee(7,M.Inject(fe)),ee(8,M.Inject(C.DataValidationModel)),ee(9,M.Inject(C.DataValidatorRegistryService)),ee(10,M.Inject(M.Injector)),ee(11,M.Inject($.SheetInterceptorService)),ee(12,M.Optional(B.IEditorBridgeService))],v.SheetsDataValidationRenderController);let $e=class extends s.RxDisposable{constructor(r,n,e,t,a,i,o,l){super(),this._config=r,this._commandService=n,this._renderManagerService=e,this._univerInstanceService=t,this._autoHeightController=a,this._dataValidationModel=i,this._dataValidatorRegistryService=o,this._sheetInterceptorService=l,this._initSkeletonChange(),this._initViewModelIntercept(),this._initAutoHeight()}_initSkeletonChange(){const r=()=>{var o,l,d;const n=this._univerInstanceService.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET);if(!n)return;const e=n.getUnitId(),t=(o=n.getActiveSheet())==null?void 0:o.getSheetId();if(!t)return;const a=(d=(l=this._renderManagerService.getRenderById(e))==null?void 0:l.with(B.SheetSkeletonManagerService).getWorksheetSkeleton(t))==null?void 0:d.skeleton,i=this._renderManagerService.getRenderById(e);a==null||a.makeDirty(!0),a==null||a.calculate(),i&&i.mainComponent.makeForceDirty()};this.disposeWithMe(this._dataValidationModel.ruleChange$.pipe(ie.debounceTime(16)).subscribe(()=>r())),this.disposeWithMe(this._dataValidationModel.validStatusChange$.pipe(ie.debounceTime(16)).subscribe(()=>r()))}_initViewModelIntercept(){this.disposeWithMe(this._sheetInterceptorService.intercept($.INTERCEPTOR_POINT.CELL_CONTENT,{priority:200,handler:(r,n,e)=>{var y,O,b,L,j;const{row:t,col:a,unitId:i,subUnitId:o,workbook:l,worksheet:d}=n,u=this._dataValidationModel.ensureManager(i,o);if(!u)return e(r);const c=(O=(y=this._renderManagerService.getRenderById(i))==null?void 0:y.with(B.SheetSkeletonManagerService).getWorksheetSkeleton(o))==null?void 0:O.skeleton;if(!c)return e(r);const h=n.workbook.getStyles(),p=(typeof(r==null?void 0:r.s)=="string"?h.get(r==null?void 0:r.s):r==null?void 0:r.s)||{},f=u.getRuleIdByLocation(t,a);if(!f)return e(r);const g=u.getRuleById(f);if(!g)return e(r);const m=n.worksheet.getCellRaw(n.row,n.col),I=this._dataValidationModel.validator(te(m),g,n),_=this._dataValidatorRegistryService.getValidatorItem(g.type),V=te(r);let D={};if((g.type===s.DataValidationType.LIST||g.type===s.DataValidationType.LIST_MULTIPLE)&&(D={interceptorStyle:{...r==null?void 0:r.interceptorStyle,tb:(b=p.tb!==s.WrapStrategy.OVERFLOW?p.tb:s.WrapStrategy.CLIP)!=null?b:s.WrapStrategy.WRAP}}),g.type===s.DataValidationType.CHECKBOX&&(D={interceptorStyle:{...r==null?void 0:r.interceptorStyle,tb:s.WrapStrategy.CLIP}}),g.type===s.DataValidationType.LIST&&(g.renderMode===s.DataValidationRenderMode.ARROW||g.renderMode===s.DataValidationRenderMode.TEXT)){const A=_.getListWithColorMap(g),x=`${(L=te(r))!=null?L:""}`,F=A[x];F&&(D={...D,interceptorStyle:{...D.interceptorStyle,bg:{rgb:F}}})}return e({...r,...D,dataValidation:{ruleId:f,validStatus:I,rule:g,validator:_},markers:{...r==null?void 0:r.markers,...I===s.DataValidationStatus.INVALID?ma:null},customRender:[...(j=r==null?void 0:r.customRender)!=null?j:[],..._!=null&&_.canvasRender?[_.canvasRender]:[]],fontRenderExtension:{...r==null?void 0:r.fontRenderExtension,isSkip:_==null?void 0:_.skipDefaultFontRender(g,V,n)},interceptorStyle:{...r==null?void 0:r.interceptorStyle,...D.interceptorStyle},get interceptorAutoHeight(){var F,U,k,X;const A=c.mergeData.find(N=>{const{startColumn:Y,startRow:Q,endColumn:G,endRow:w}=N;return t>=Q&&a>=Y&&t<=w&&a<=G}),x={data:{...r,dataValidation:{ruleId:f,validStatus:I,rule:g,validator:_}},style:c.getsStyles().getStyleByCell(r),primaryWithCoord:c.getCellByIndex((F=A==null?void 0:A.startRow)!=null?F:t,(U=A==null?void 0:A.startColumn)!=null?U:a),unitId:i,subUnitId:o,row:t,col:a,worksheet:d,workbook:l};return(X=(k=_==null?void 0:_.canvasRender)==null?void 0:k.calcCellAutoHeight)==null?void 0:X.call(k,x)}})}}))}_initAutoHeight(){this._dataValidationModel.ruleChange$.pipe(ie.bufferTime(16)).subscribe(r=>{const n=[];if(r.forEach(e=>{var t;(t=e.rule)!=null&&t.ranges&&n.push(...e.rule.ranges)}),n.length){const e=this._autoHeightController.getUndoRedoParamsOfAutoHeight(n);s.sequenceExecute(e.redos,this._commandService)}})}};$e=ua([s.OnLifecycle(s.LifecycleStages.Rendered,$e),ee(1,s.ICommandService),ee(2,Z.IRenderManagerService),ee(3,s.IUniverInstanceService),ee(4,M.Inject(B.AutoHeightController)),ee(5,M.Inject(C.DataValidationModel)),ee(6,M.Inject(C.DataValidatorRegistryService)),ee(7,M.Inject($.SheetInterceptorService))],$e);var ei=Object.defineProperty,ti=Object.getOwnPropertyDescriptor,ai=(r,n,e,t)=>{for(var a=t>1?void 0:t?ti(n,e):n,i=r.length-1,o;i>=0;i--)(o=r[i])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&ei(n,e,a),a},ni=(r,n)=>(e,t)=>n(e,t,r);v.SheetDataValidationService=class extends s.Disposable{constructor(e){super();R(this,"_currentManager");R(this,"_currentManager$",new ie.Subject);R(this,"currentManager$",this._currentManager$.asObservable());this._dataValidationModel=e,this.disposeWithMe(()=>{this._currentManager$.complete()})}get currentManager(){return this._currentManager}_ensureManager(e,t){return this._dataValidationModel.ensureManager(e,t)}switchCurrent(e,t){var i,o;if(e===((i=this.currentManager)==null?void 0:i.unitId)&&t===((o=this._currentManager)==null?void 0:o.subUnitId))return;const a=this._ensureManager(e,t);this._currentManager={manager:a,unitId:e,subUnitId:t},this._currentManager$.next(this._currentManager)}get(e,t){return this._ensureManager(e,t)}},v.SheetDataValidationService=ai([ni(0,M.Inject(C.DataValidationModel))],v.SheetDataValidationService);var ii=Object.defineProperty,ri=Object.getOwnPropertyDescriptor,oi=(r,n,e,t)=>{for(var a=t>1?void 0:t?ri(n,e):n,i=r.length-1,o;i>=0;i--)(o=r[i])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&ii(n,e,a),a},Je=(r,n)=>(e,t)=>n(e,t,r);v.DataValidationCustomFormulaService=class extends s.Disposable{constructor(e,t,a,i){super();R(this,"_formulaMap",new Map);R(this,"_ruleFormulaMap",new Map);R(this,"_formulaCellMap",new Map);this._registerOtherFormulaService=e,this._lexerTreeBuilder=t,this._dataValidationModel=a,this._dataValidationCacheService=i,this._initFormulaResultHandler()}_initFormulaResultHandler(){this.disposeWithMe(this._registerOtherFormulaService.formulaResult$.subscribe(e=>{for(const t in e){const a=e[t];for(const i in a){const o=a[i],{formulaCellMap:l,ruleFormulaMap:d}=this._ensureMaps(t,i),u=this._dataValidationModel.ensureManager(t,i);o.forEach(c=>{var g,m;const h=d.get((g=c.extra)==null?void 0:g.ruleId),p=l.get(c.formulaId),f=u.getRuleById((m=c.extra)==null?void 0:m.ruleId);f&&h&&!h.isTransformable&&this._dataValidationCacheService.markRangeDirty(t,i,f.ranges),p&&this._dataValidationCacheService.markCellDirty(t,i,p.row,p.column)})}}}))}_ensureMaps(e,t){let a=this._formulaMap.get(e),i=this._ruleFormulaMap.get(e),o=this._formulaCellMap.get(e);(!a||!i||!o)&&(a=new Map,i=new Map,o=new Map,this._formulaMap.set(e,a),this._ruleFormulaMap.set(e,i),this._formulaCellMap.set(e,o));let l=a.get(t),d=i.get(t),u=o.get(t);return(!l||!d||!u)&&(l=new s.ObjectMatrix,a.set(t,l),d=new Map,i.set(t,d),u=new Map,o.set(t,u)),{formulaMap:l,ruleFormulaMap:d,formulaCellMap:u}}_registerFormula(e,t,a,i){return this._registerOtherFormulaService.registerFormula(e,t,i,{ruleId:a})}deleteByRuleId(e,t,a){const{formulaMap:i,formulaCellMap:o,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(h=>{s.Range.foreach(h,(p,f)=>{const g=i.getValue(p,f);if(g&&g.ruleId===a){const{formulaId:m}=g;i.realDeleteValue(p,f),u.add(m),o.delete(m)}})}),this._registerOtherFormulaService.deleteFormula(e,t,Array.from(u.values())))}_addFormulaByRange(e,t,a,i,o){const{formulaMap:l,ruleFormulaMap:d,formulaCellMap:u}=this._ensureMaps(e,t);if(!i)return;const c=re.isFormulaTransformable(this._lexerTreeBuilder,i),h=o[0].startRow,p=o[0].startColumn;let f;c?o.forEach(g=>{s.Range.foreach(g,(m,I)=>{const _=re.transformFormula(this._lexerTreeBuilder,i,h,p,m,I),V=this._registerFormula(e,t,a,_);l.setValue(m,I,{formulaId:V,ruleId:a}),u.set(V,{row:m,column:I})})}):(f=this._registerFormula(e,t,a,i),o.forEach(g=>{s.Range.foreach(g,(m,I)=>{l.setValue(m,I,{formulaId:f,ruleId:a})})})),d.set(a,{formula:i,originCol:p,originRow:h,isTransformable:c,formulaId:f})}addRule(e,t,a){const{ranges:i,formula1:o,uid:l,type:d}=a;d!==s.DataValidationType.CUSTOM||!o||!s.isFormulaString(o)||this._addFormulaByRange(e,t,l,o,i)}updateRuleRanges(e,t,a,i,o){const{formulaMap:l,ruleFormulaMap:d,formulaCellMap:u}=this._ensureMaps(e,t),c=d.get(a);if(!c)return;const{formula:h,originCol:p,originRow:f,isTransformable:g,formulaId:m}=c,I=new Set;i.forEach(_=>{s.Range.foreach(_,(V,D)=>{const y=l.getValue(V,D);y&&y.ruleId===a&&(y.temp=!0)})}),o.forEach(_=>{s.Range.foreach(_,(V,D)=>{var O;const y=(O=l.getValue(V,D))!=null?O:{};if(y.ruleId!==a){const b=d.get(y.ruleId);if(b!=null&&b.isTransformable&&I.add(y.formulaId),g){const L=re.transformFormula(this._lexerTreeBuilder,h,f,p,V,D),j=this._registerFormula(e,t,a,L);l.setValue(V,D,{ruleId:a,formulaId:j}),u.set(j,{row:V,column:D})}else l.setValue(V,D,{ruleId:a,formulaId:m})}else y.temp=!1})}),i.forEach(_=>{s.Range.foreach(_,(V,D)=>{const y=l.getValue(V,D);y&&y.ruleId===a&&y.temp===!0&&(l.realDeleteValue(V,D),g&&I.add(y.formulaId))})}),I.forEach(_=>{u.delete(_)}),this._registerOtherFormulaService.deleteFormula(e,t,Array.from(I.values()))}updateRuleFormula(e,t,a,i,o){const{ruleFormulaMap:l}=this._ensureMaps(e,t),d=l.get(a);(!d||d.formula!==o)&&this._addFormulaByRange(e,t,a,o,i)}getCellFormulaValue(e,t,a,i){const{formulaMap:o}=this._ensureMaps(e,t),l=o.getValue(a,i);return l?this._registerOtherFormulaService.getFormulaValue(e,t,l.formulaId):Promise.resolve(void 0)}getRuleFormulaInfo(e,t,a){const{ruleFormulaMap:i}=this._ensureMaps(e,t);return i.get(a)}},v.DataValidationCustomFormulaService=oi([Je(0,M.Inject(nt.RegisterOtherFormulaService)),Je(1,M.Inject(re.LexerTreeBuilder)),Je(2,M.Inject(C.DataValidationModel)),Je(3,M.Inject(_e))],v.DataValidationCustomFormulaService);class si extends C.BaseDataValidator{constructor(){super(...arguments);R(this,"id",s.DataValidationType.CUSTOM);R(this,"title","dataValidation.custom.title");R(this,"operators",[]);R(this,"scopes",["sheet"]);R(this,"formulaInput",Yt);R(this,"_customFormulaService",this.injector.get(v.DataValidationCustomFormulaService))}validatorFormula(e,t,a){const i=s.isFormulaString(e.formula1);return{success:i,formula1:i?"":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:i,row:o,unitId:l,subUnitId:d}=e,u=await this._customFormulaService.getCellFormulaValue(l,d,o,i);return!!le(u==null?void 0:u.result)}generateRuleErrorMessage(e){return this.localeService.t("dataValidation.custom.error")}}class li extends C.BaseDataValidator{constructor(){super(...arguments);R(this,"_formulaService",this.injector.get(v.DataValidationFormulaService));R(this,"id",s.DataValidationType.WHOLE);R(this,"title","dataValidation.whole.title");R(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]);R(this,"scopes",["sheet"]);R(this,"formulaInput",Fe);R(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:i}=e,o=Qe(i);return!Number.isNaN(o)&&Number.isInteger(o)}transform(e,t,a){const{value:i}=e;return{...e,value:Qe(i)}}_parseNumber(e){return e==null?Number.NaN:+e}async parseFormula(e,t,a){var u,c,h,p,f,g,m,I;const i=await this._formulaService.getRuleFormulaResult(t,a,e.uid),{formula1:o,formula2:l}=e;return{formula1:this._parseNumber(s.isFormulaString(o)?(p=(h=(c=(u=i==null?void 0:i[0])==null?void 0:u.result)==null?void 0:c[0])==null?void 0:h[0])==null?void 0:p.v:o),formula2:this._parseNumber(s.isFormulaString(l)?(I=(m=(g=(f=i==null?void 0:i[1])==null?void 0:f.result)==null?void 0:g[0])==null?void 0:m[0])==null?void 0:I.v:l)}}validatorFormula(e,t,a){const i=e.operator;if(!i)return{success:!1};const o=s.Tools.isDefine(e.formula1)&&this._isFormulaOrInt(e.formula1),l=s.Tools.isDefine(e.formula2)&&this._isFormulaOrInt(e.formula2),d=Xe.includes(i),u=this.localeService.t("dataValidation.validFail.number");return d?{success:o&&l,formula1:o?void 0:u,formula2:l?void 0:u}:{success:o,formula1:u}}async validatorIsEqual(e,t,a){const{formula1:i}=t,{value:o}=e;return Number.isNaN(i)?!0:o===i}async validatorIsNotEqual(e,t,a){const{formula1:i}=t;return Number.isNaN(i)?!0:e.value!==i}async validatorIsBetween(e,t,a){const{formula1:i,formula2:o}=t;if(Number.isNaN(i)||Number.isNaN(o))return!0;const l=Math.min(i,o),d=Math.max(i,o);return e.value>=l&&e.value<=d}async validatorIsNotBetween(e,t,a){const{formula1:i,formula2:o}=t;if(Number.isNaN(i)||Number.isNaN(o))return!0;const l=Math.min(i,o),d=Math.max(i,o);return e.value<l||e.value>d}async validatorIsGreaterThan(e,t,a){const{formula1:i}=t;return Number.isNaN(i)?!0:e.value>i}async validatorIsGreaterThanOrEqual(e,t,a){const{formula1:i}=t;return Number.isNaN(i)?!0:e.value>=i}async validatorIsLessThan(e,t,a){const{formula1:i}=t;return Number.isNaN(i)?!0:e.value<i}async validatorIsLessThanOrEqual(e,t,a){const{formula1:i}=t;return Number.isNaN(i)?!0:e.value<=i}}const ha=4,di=0,St=4,fa=4,_t=6,et=6,Re=14;function ui(r,n){const e=Z.FontCache.getTextSize(r,n),t=e.width+ha*2,{ba:a,bd:i}=e,o=a+i;return{width:t,height:o+di*2,ba:a}}function pa(r,n,e,t){const a=e-Re-_t,i=t-et*2,o=r.map(c=>({layout:ui(c,n),text:c}));let l;const d=[];o.forEach(c=>{const{layout:h}=c,{width:p,height:f}=h;!l||l.width+p+St>a?(l={width:p,height:f,items:[{...c,left:0}]},d.push(l)):(l.items.push({...c,left:l.width+St}),l.width=l.width+p+St)});let u=0;return d.forEach((c,h)=>{h===d.length-1?u+=c.height:u+=c.height+fa}),{lines:d,totalHeight:u,contentWidth:a,contentHeight:i,cellAutoHeight:u+et*2}}const ci=8;class mi extends Z.Shape{static drawWith(n,e){const{fontFamily:t,fontString:a,fontSize:i,info:o,fill:l,color:d}=e,{layout:u,text:c}=o;n.save(),Z.Rect.drawWith(n,{width:u.width,height:u.height,radius:ci,fill:l||De}),n.translateWithPrecision(ha,u.ba),n.font=a,n.fillStyle=d,n.fillText(c,0,0),n.restore()}}var hi=Object.defineProperty,fi=Object.getOwnPropertyDescriptor,pi=(r,n,e,t)=>{for(var a=t>1?void 0:t?fi(n,e):n,i=r.length-1,o;i>=0;i--)(o=r[i])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&hi(n,e,a),a},vi=(r,n)=>(e,t)=>n(e,t,r);const gi=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 Dt=class{constructor(r){R(this,"zIndex");R(this,"_dropdownInfoMap",new Map);this._commandService=r}_ensureMap(r){let n=this._dropdownInfoMap.get(r);return n||(n=new Map,this._dropdownInfoMap.set(r,n)),n}_generateKey(r,n){return`${r}.${n}`}_drawDownIcon(r,n,e,t,a){const i=e-Re+4;let o=4;switch(a){case s.VerticalAlign.MIDDLE:o=(t-Re)/2+4;break;case s.VerticalAlign.BOTTOM:o=t-Re+4;break}r.save(),r.translateWithPrecision(n.startX+i,n.startY+o),r.fillStyle="#565656",r.fill(gi),r.restore()}drawWith(r,n,e,t){var W,ae;const{primaryWithCoord:a,row:i,col:o,style:l,data:d,subUnitId:u}=n,c=a.isMergedMainCell?a.mergeInfo:a,h=d.fontRenderExtension,{leftOffset:p=0,rightOffset:f=0,topOffset:g=0,downOffset:m=0}=h||{},I=d.dataValidation,_=this._ensureMap(u),V=this._generateKey(i,o);if(!I)return;const D={startX:c.startX+p,endX:c.endX-f,startY:c.startY+g,endY:c.endY-m},y=D.endX-D.startX,O=D.endY-D.startY,{cl:b}=l||{},L=(W=typeof b=="object"?b==null?void 0:b.rgb:b)!=null?W:"#000",j=Z.getFontStyleString(l!=null?l:void 0),{rule:A,validator:x}=I,F=x,{vt:U,ht:k}=l||{},X=U!=null?U:s.VerticalAlign.MIDDLE,N=(ae=te(d))!=null?ae:"",Y=F.parseCellValue(N),Q=F.getListWithColorMap(A),G=pa(Y,j,y,O);this._drawDownIcon(r,D,y,O,X),r.save(),r.translateWithPrecision(D.startX,D.startY),r.beginPath(),r.rect(0,0,y-Re,O),r.clip(),r.translateWithPrecision(_t,et);let w=0;switch(X){case s.VerticalAlign.MIDDLE:w=(G.contentHeight-G.totalHeight)/2;break;case s.VerticalAlign.BOTTOM:w=G.contentHeight-G.totalHeight;break}r.translateWithPrecision(0,w),G.lines.forEach((K,me)=>{r.save();const{width:Ce,height:P,items:J}=K;let z=0;switch(k){case s.HorizontalAlign.RIGHT:z=G.contentWidth-Ce;break;case s.HorizontalAlign.CENTER:z=(G.contentWidth-Ce)/2;break}r.translate(z,me*(P+fa)),J.forEach(ne=>{r.save(),r.translateWithPrecision(ne.left,0),mi.drawWith(r,{...j,info:ne,color:L,fill:Q[ne.text]}),r.restore()}),r.restore()}),r.restore(),_.set(V,{left:D.startX,top:D.startY,width:G.contentWidth+_t+Re,height:G.contentHeight+et*2})}calcCellAutoHeight(r){var y;const{primaryWithCoord:n,style:e,data:t}=r,a=t.fontRenderExtension,{leftOffset:i=0,rightOffset:o=0,topOffset:l=0,downOffset:d=0}=a||{},u=n.isMergedMainCell?n.mergeInfo:n,c={startX:u.startX+i,endX:u.endX-o,startY:u.startY+l,endY:u.endY-d},h=t.dataValidation;if(!h)return;const p=c.endX-c.startX,f=c.endY-c.startY,g=(y=te(t))!=null?y:"",{validator:m}=h,_=m.parseCellValue(g),V=Z.getFontStyleString(e!=null?e:void 0);return pa(_,V,p,f).cellAutoHeight}isHit(r,n){const{primaryWithCoord:e}=n,t=e.isMergedMainCell?e.mergeInfo:e,{endX:a}=t,{x:i}=r;return i>=a-Re&&i<=a}onPointerDown(r,n){if(n.button===2)return;const{unitId:e,subUnitId:t,row:a,col:i}=r,o={unitId:e,subUnitId:t,row:a,column:i};this._commandService.executeCommand(Ee.id,o)}};Dt=pi([vi(0,s.ICommandService)],Dt);class Si extends oa{constructor(){super(...arguments);R(this,"id",s.DataValidationType.LIST_MULTIPLE);R(this,"title","dataValidation.listMultiple.title");R(this,"canvasRender",this.injector.createInstance(Dt))}skipDefaultFontRender(){return!0}}var _i=Object.defineProperty,Di=Object.getOwnPropertyDescriptor,Vi=(r,n,e,t)=>{for(var a=t>1?void 0:t?Di(n,e):n,i=r.length-1,o;i>=0;i--)(o=r[i])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&_i(n,e,a),a},ge=(r,n)=>(e,t)=>n(e,t,r);v.DataValidationController=class extends s.RxDisposable{constructor(n,e,t,a,i,o,l,d){super(),this._univerInstanceService=n,this._sheetDataValidationService=e,this._dataValidatorRegistryService=t,this._injector=a,this._componentManger=i,this._selectionManagerService=o,this._sheetInterceptorService=l,this._dataValidationModel=d,this._init()}_init(){this._registerValidators(),this._initInstanceChange(),this._initCommandInterceptor(),this._initComponents()}_registerValidators(){[Yn,li,Gn,Ln,mn,oa,Si,si].forEach(n=>{const e=this._injector.createInstance(n);this.disposeWithMe(this._dataValidatorRegistryService.register(e)),this.disposeWithMe({dispose:()=>{this._injector.delete(n)}})})}_initInstanceChange(){const n=new s.DisposableCollection;this.disposeWithMe(this._univerInstanceService.getCurrentTypeOfUnit$(s.UniverInstanceType.UNIVER_SHEET).subscribe(e=>{if(n.dispose(),!e)return;const t=e.getActiveSheet();t&&(this._sheetDataValidationService.switchCurrent(e.getUnitId(),t.getSheetId()),n.add(s.toDisposable(e.activeSheet$.subscribe(a=>{if(a){const i=e.getUnitId(),o=a.getSheetId();this._sheetDataValidationService.switchCurrent(i,o)}}))))})),this.disposeWithMe(n)}_initCommandInterceptor(){this._sheetInterceptorService.interceptCommand({getMutations:n=>{var e;if(n.id===$.ClearSelectionAllCommand.id){const t=this._univerInstanceService.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET),a=t.getUnitId(),i=t.getActiveSheet();if(!i)throw new Error("No active sheet found");const o=i.getSheetId(),l=(e=this._selectionManagerService.getCurrentSelections())==null?void 0:e.map(f=>f.range),d=this._dataValidationModel.ensureManager(a,o),u=d.getRuleObjectMatrix().clone();l&&u.removeRange(l);const c=u.diff(d.getDataValidations()),{redoMutations:h,undoMutations:p}=Oe(a,o,c,this._injector);return{undos:p,redos:h}}return{undos:[],redos:[]}}})}_initComponents(){[[da,Ut],[Pt,Dn],[Nt,Ea],[Zt,Rn],[Jt,Tn],[Ke.componentKey,Ke],[ze.componentKey,ze],...cn].forEach(([n,e])=>{this.disposeWithMe(this._componentManger.register(n,e))})}},v.DataValidationController=Vi([s.OnLifecycle(s.LifecycleStages.Rendered,v.DataValidationController),ge(0,s.IUniverInstanceService),ge(1,M.Inject(v.SheetDataValidationService)),ge(2,M.Inject(C.DataValidatorRegistryService)),ge(3,M.Inject(M.Injector)),ge(4,M.Inject(q.ComponentManager)),ge(5,M.Inject($.SheetsSelectionsService)),ge(6,M.Inject($.SheetInterceptorService)),ge(7,M.Inject(C.DataValidationModel))],v.DataValidationController);var Ri=Object.defineProperty,Ci=Object.getOwnPropertyDescriptor,Ii=(r,n,e,t)=>{for(var a=t>1?void 0:t?Ci(n,e):n,i=r.length-1,o;i>=0;i--)(o=r[i])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&Ri(n,e,a),a},tt=(r,n)=>(e,t)=>n(e,t,r);const Vt="SHEET_DATA_VALIDATION_ALERT";v.DataValidationAlertController=class extends s.Disposable{constructor(n,e,t,a){super(),this._hoverManagerService=n,this._cellAlertManagerService=e,this._univerInstanceService=t,this._localeService=a,this._init()}_init(){this._initCellAlertPopup()}_initCellAlertPopup(){this.disposeWithMe(this._hoverManagerService.currentCell$.pipe(ie.debounceTime(100)).subscribe(n=>{var e,t;if(n){const i=this._univerInstanceService.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET).getActiveSheet();if(!i)return;const o=i.getCell(n.location.row,n.location.col);if(((e=o==null?void 0:o.dataValidation)==null?void 0:e.validStatus)===s.DataValidationStatus.INVALID){const l=this._cellAlertManagerService.currentAlert.get(Vt),d=(t=l==null?void 0:l.alert)==null?void 0:t.location;if(d&&d.row===n.location.row&&d.col===n.location.col&&d.subUnitId===n.location.subUnitId&&d.unitId===n.location.unitId)return;const u=o.dataValidation.validator,c=o.dataValidation.rule;if(!u)return;this._cellAlertManagerService.showAlert({type:B.CellAlertType.ERROR,title:this._localeService.t("dataValidation.error.title"),message:u==null?void 0:u.getRuleFinalError(c),location:n.location,width:200,height:74,key:Vt});return}}this._cellAlertManagerService.removeAlert(Vt)}))}},v.DataValidationAlertController=Ii([s.OnLifecycle(s.LifecycleStages.Rendered,v.DataValidationAlertController),tt(0,M.Inject(B.HoverManagerService)),tt(1,M.Inject(B.CellAlertManagerService)),tt(2,s.IUniverInstanceService),tt(3,M.Inject(s.LocaleService))],v.DataValidationAlertController);var yi=Object.defineProperty,Mi=Object.getOwnPropertyDescriptor,wi=(r,n,e,t)=>{for(var a=t>1?void 0:t?Mi(n,e):n,i=r.length-1,o;i>=0;i--)(o=r[i])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&yi(n,e,a),a},Te=(r,n)=>(e,t)=>n(e,t,r);v.DataValidationRefRangeController=class extends s.Disposable{constructor(e,t,a,i,o,l){super();R(this,"_disposableMap",new Map);R(this,"registerRule",(e,t,a)=>{this.register(e,t,a),this.registerFormula(e,t,a)});this._dataValidationModel=e,this._injector=t,this._refRangeService=a,this._dataValidationCustomFormulaService=i,this._dataValidationFormulaService=o,this._formulaRefRangeService=l,this._initRefRange()}_getIdWithUnitId(e,t,a){return`${e}_${t}_${a}`}registerFormula(e,t,a){var u;const i=a.uid,o=this._getIdWithUnitId(e,t,i),l=(u=this._disposableMap.get(o))!=null?u:new Set,d=(c,h)=>{const p=this._dataValidationModel.getRuleById(e,t,i);if(!p)return{redos:[],undos:[]};const f=p[c];if(!f||f===h)return{redos:[],undos:[]};const g={unitId:e,subUnitId:t,ruleId:a.uid,payload:{type:C.UpdateRuleType.SETTING,payload:{type:p.type,formula1:p.formula1,formula2:p.formula2,[c]:h}}},m={unitId:e,subUnitId:t,ruleId:a.uid,payload:{type:C.UpdateRuleType.SETTING,payload:{type:p.type,formula1:p.formula1,formula2:p.formula2}}},I=[{id:C.UpdateDataValidationMutation.id,params:g}],_=[{id:C.UpdateDataValidationMutation.id,params:m}];return{redos:I,undos:_}};if(a.type===s.DataValidationType.CUSTOM){const c=this._dataValidationCustomFormulaService.getRuleFormulaInfo(e,t,i);if(c){const h=this._formulaRefRangeService.registerFormula(c.formula,p=>d("formula1",p));l.add(()=>h.dispose())}}if(a.type!==s.DataValidationType.CUSTOM){const c=this._dataValidationFormulaService.getRuleFormulaInfo(e,t,i);if(c){const[h,p]=c;if(h){const f=this._formulaRefRangeService.registerFormula(h.text,g=>d("formula1",g));l.add(()=>f.dispose())}if(p){const f=this._formulaRefRangeService.registerFormula(p.text,g=>d("formula1",g));l.add(()=>f.dispose())}}}}register(e,t,a){var u;const i=c=>{const h=[...a.ranges],f=h.map(m=>$.handleCommonDefaultRangeChangeWithEffectRefCommands(m,c)).filter(m=>!!m).flat();if(s.isRangesEqual(f,h))return{redos:[],undos:[]};if(f.length){const m={unitId:e,subUnitId:t,ruleId:a.uid,payload:{type:C.UpdateRuleType.RANGE,payload:f}},I=[{id:C.UpdateDataValidationMutation.id,params:m}],_=[{id:C.UpdateDataValidationMutation.id,params:{unitId:e,subUnitId:t,ruleId:a.uid,payload:{type:C.UpdateRuleType.RANGE,payload:h}}}];return{redos:I,undos:_}}else{const m={unitId:e,subUnitId:t,ruleId:a.uid},I=[{id:C.RemoveDataValidationMutation.id,params:m}],_=C.removeDataValidationUndoFactory(this._injector,m);return{redos:I,undos:_}}},o=[];a.ranges.forEach(c=>{const h=this._refRangeService.registerRefRange(c,i,e,t);o.push(()=>h.dispose())});const l=this._getIdWithUnitId(e,t,a.uid),d=(u=this._disposableMap.get(l))!=null?u:new Set;d.add(()=>o.forEach(c=>c())),this._disposableMap.set(l,d)}_initRefRange(){this.disposeWithMe(this._dataValidationModel.ruleChange$.subscribe(e=>{const{unitId:t,subUnitId:a,rule:i}=e;switch(e.type){case"add":{const o=e.rule;this.registerRule(e.unitId,e.subUnitId,o);break}case"remove":{const o=this._disposableMap.get(this._getIdWithUnitId(t,a,i.uid));o&&o.forEach(l=>l());break}case"update":{const o=e.rule,l=this._disposableMap.get(this._getIdWithUnitId(t,a,o.uid));l&&l.forEach(d=>d()),this.registerRule(e.unitId,e.subUnitId,o);break}}})),this.disposeWithMe(s.toDisposable(()=>{this._disposableMap.forEach(e=>{e.forEach(t=>t())}),this._disposableMap.clear()}))}},v.DataValidationRefRangeController=wi([s.OnLifecycle(s.LifecycleStages.Ready,v.DataValidationRefRangeController),Te(0,M.Inject(C.DataValidationModel)),Te(1,M.Inject(M.Injector)),Te(2,M.Inject($.RefRangeService)),Te(3,M.Inject(v.DataValidationCustomFormulaService)),Te(4,M.Inject(v.DataValidationFormulaService)),Te(5,M.Inject(nt.FormulaRefRangeService))],v.DataValidationRefRangeController);var Oi=Object.defineProperty,Ti=Object.getOwnPropertyDescriptor,Ei=(r,n,e,t)=>{for(var a=t>1?void 0:t?Ti(n,e):n,i=r.length-1,o;i>=0;i--)(o=r[i])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&Oi(n,e,a),a},Rt=(r,n)=>(e,t)=>n(e,t,r);v.DataValidationAutoFillController=class extends s.Disposable{constructor(n,e,t){super(),this._autoFillService=n,this._dataValidationModel=e,this._injector=t,this._initAutoFill()}_initAutoFill(){const n=()=>({redos:[],undos:[]}),e=i=>{const{source:o,target:l,unitId:d,subUnitId:u}=i,c=this._dataValidationModel.ensureManager(d,u),h=c.getRuleObjectMatrix().clone(),p=B.virtualizeDiscreteRanges([o,l]),[f,g]=p.ranges,{mapFunc:m}=p,I={row:f.startRow,col:f.startColumn};B.getAutoFillRepeatRange(f,g).forEach(O=>{const b=O.repeatStartCell,L=O.relativeRange,j={startRow:I.row,startColumn:I.col,endColumn:I.col,endRow:I.row},A={startRow:b.row,startColumn:b.col,endColumn:b.col,endRow:b.row};s.Range.foreach(L,(x,F)=>{const U=s.Rectangle.getPositionRange({startRow:x,startColumn:F,endColumn:F,endRow:x},j),{row:k,col:X}=m(U.startRow,U.startColumn),N=c.getRuleIdByLocation(k,X);if(N){const Y=s.Rectangle.getPositionRange({startRow:x,startColumn:F,endColumn:F,endRow:x},A),{row:Q,col:G}=m(Y.startRow,Y.startColumn);h.setValue(Q,G,N)}})});const V=h.diff(c.getDataValidations()),{redoMutations:D,undoMutations:y}=Oe(d,u,V,this._injector);return{undos:y,redos:D}},t=[s.DataValidationType.CHECKBOX],a={id:be,onBeforeFillData:i=>{const{source:o,unitId:l,subUnitId:d}=i,u=this._dataValidationModel.ensureManager(l,d);for(const c of o.rows)for(const h of o.cols){const p=u.getRuleByLocation(c,h);if(p&&t.indexOf(p.type)>-1){this._autoFillService.setDisableApplyType(B.APPLY_TYPE.SERIES,!0);return}}},onFillData:(i,o,l)=>l===B.APPLY_TYPE.COPY||l===B.APPLY_TYPE.ONLY_FORMAT||l===B.APPLY_TYPE.SERIES?e(i):n(),onAfterFillData:()=>{}};this.disposeWithMe(this._autoFillService.addHook(a))}},v.DataValidationAutoFillController=Ei([s.OnLifecycle(s.LifecycleStages.Ready,v.DataValidationAutoFillController),Rt(0,B.IAutoFillService),Rt(1,M.Inject(C.DataValidationModel)),Rt(2,M.Inject(M.Injector))],v.DataValidationAutoFillController);var bi=Object.defineProperty,Fi=Object.getOwnPropertyDescriptor,Ni=(r,n,e,t)=>{for(var a=t>1?void 0:t?Fi(n,e):n,i=r.length-1,o;i>=0;i--)(o=r[i])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&bi(n,e,a),a},Ct=(r,n)=>(e,t)=>n(e,t,r);v.DataValidationCopyPasteController=class extends s.Disposable{constructor(e,t,a){super();R(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,i)=>{const{copyType:o=B.COPY_TYPE.COPY,pasteType:l}=i,{range:d}=e||{},{range:u,unitId:c,subUnitId:h}=t;return this._generateMutations(u,{copyType:o,pasteType:l,copyRange:d,unitId:c,subUnitId:h})}})}_collect(e,t,a){const i=new s.ObjectMatrix;this._copyInfo={unitId:e,subUnitId:t,matrix:i};const o=this._dataValidationModel.ensureManager(e,t),l={get:this._injector.get.bind(this._injector)},d=B.rangeToDiscreteRange(a,l,e,t);if(!d)return;const{rows:u,cols:c}=d;u.forEach((h,p)=>{c.forEach((f,g)=>{const m=o.getRuleIdByLocation(h,f);i.setValue(p,g,m!=null?m:"")})})}_generateMutations(e,t){if(!this._copyInfo)return{redos:[],undos:[]};if(t.copyType===B.COPY_TYPE.CUT)return this._copyInfo=null,{redos:[],undos:[]};if(!this._copyInfo||!this._copyInfo.matrix.getSizeOf()||!t.copyRange)return{redos:[],undos:[]};if([B.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_COL_WIDTH,B.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_VALUE,B.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMAT,B.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMULA].includes(t.pasteType))return{redos:[],undos:[]};const{unitId:a,subUnitId:i}=this._copyInfo;if(t.unitId!==a||i!==t.subUnitId){const o=this._dataValidationModel.ensureManager(a,i),l=this._dataValidationModel.ensureManager(t.unitId,t.subUnitId),d=l.getRuleObjectMatrix().clone(),{ranges:[u,c],mapFunc:h}=B.virtualizeDiscreteRanges([t.copyRange,e]),p=B.getRepeatRange(u,c,!0),f=new Map;p.forEach(({startRange:I})=>{var _;(_=this._copyInfo)==null||_.matrix.forValue((V,D,y)=>{const O=s.Rectangle.getPositionRange({startRow:V,endRow:V,startColumn:D,endColumn:D},I),b=`${i}-${y}`,L=o.getRuleById(y);!l.getRuleById(b)&&L&&f.set(b,{...L,uid:b});const{row:j,col:A}=h(O.startRow,O.startColumn);d.setValue(j,A,b)})});const{redoMutations:g,undoMutations:m}=Oe(t.unitId,t.subUnitId,d.diffWithAddition(l.getDataValidations(),f.values()),this._injector);return{redos:g,undos:m}}else{const o=this._dataValidationModel.ensureManager(a,i),l=o.getRuleObjectMatrix().clone(),{ranges:[d,u],mapFunc:c}=B.virtualizeDiscreteRanges([t.copyRange,e]);B.getRepeatRange(d,u,!0).forEach(({startRange:g})=>{var m;(m=this._copyInfo)==null||m.matrix.forValue((I,_,V)=>{const D=s.Rectangle.getPositionRange({startRow:I,endRow:I,startColumn:_,endColumn:_},g),{row:y,col:O}=c(D.startRow,D.startColumn);l.setValue(y,O,V)})});const{redoMutations:p,undoMutations:f}=Oe(a,i,l.diff(o.getDataValidations()),this._injector);return{redos:p,undos:f}}}},v.DataValidationCopyPasteController=Ni([s.OnLifecycle(s.LifecycleStages.Ready,v.DataValidationCopyPasteController),Ct(0,B.ISheetClipboardService),Ct(1,M.Inject(C.DataValidationModel)),Ct(2,M.Inject(M.Injector))],v.DataValidationCopyPasteController);class It{constructor(n,e){R(this,"value");this._worksheet=e,this.value=n}addRule(n){const e=n.uid;n.ranges.forEach(t=>{s.Range.foreach(s.Range.transformRange(t,this._worksheet),(a,i)=>{this.value.setValue(a,i,e)})})}removeRange(n){n.forEach(e=>{s.Range.foreach(s.Range.transformRange(e,this._worksheet),(t,a)=>{this.value.realDeleteValue(t,a)})})}removeRule(n){n.ranges.forEach(e=>{s.Range.foreach(s.Range.transformRange(e,this._worksheet),(t,a)=>{this.value.setValue(t,a,"")})})}updateRange(n,e,t){const a=`${n}$`,i=e.map(l=>s.Range.transformRange(l,this._worksheet)),o=t.map(l=>s.Range.transformRange(l,this._worksheet));i.forEach(l=>{s.Range.foreach(l,(d,u)=>{this.value.getValue(d,u)===n&&this.value.setValue(d,u,a)})}),o.forEach(l=>{s.Range.foreach(l,(d,u)=>{this.value.setValue(d,u,n)})}),i.forEach(l=>{s.Range.foreach(l,(d,u)=>{this.value.getValue(d,u)===a&&this.value.realDeleteValue(d,u)})})}diff(n){const e=[];let t=0;return n.forEach((a,i)=>{const o=s.queryObjectMatrix(this.value,d=>d===a.uid),l=a.ranges;(o.length!==l.length||o.some((d,u)=>!s.Rectangle.equals(d,l[u])))&&e.push({type:"update",ruleId:a.uid,oldRanges:l,newRanges:o}),o.length===0&&(e.push({type:"delete",rule:a,index:i-t}),t++)}),e}diffWithAddition(n,e){const t=[];let a=0;return n.forEach((i,o)=>{const l=s.queryObjectMatrix(this.value,u=>u===i.uid),d=i.ranges;(l.length!==d.length||l.some((u,c)=>!s.Rectangle.equals(u,d[c])))&&t.push({type:"update",ruleId:i.uid,oldRanges:d,newRanges:l}),l.length===0&&(t.push({type:"delete",rule:i,index:o-a}),a++)}),Array.from(e).forEach(i=>{const o=s.queryObjectMatrix(this.value,l=>l===i.uid);t.push({type:"add",rule:{...i,ranges:o}})}),t}clone(){return new It(new s.ObjectMatrix(this.value.clone()),this._worksheet)}getValue(n,e){return this.value.getValue(n,e)}setValue(n,e,t){return this.value.setValue(n,e,t)}}class Li extends C.DataValidationManager{constructor(e,t,a,i){super(e,t,a);R(this,"_ruleMatrix");R(this,"_dataValidatorRegistryService");R(this,"_dataValidationCacheService");R(this,"_dataValidationFormulaService");R(this,"_dataValidationCustomFormulaService");R(this,"_cache");R(this,"_dataValidationRefRangeController");this._injector=i,this._dataValidatorRegistryService=this._injector.get(C.DataValidatorRegistryService),this._dataValidationCacheService=this._injector.get(_e),this._dataValidationFormulaService=this._injector.get(v.DataValidationFormulaService),this._dataValidationCustomFormulaService=this._injector.get(v.DataValidationCustomFormulaService),this._dataValidationRefRangeController=this._injector.get(v.DataValidationRefRangeController),this._cache=this._dataValidationCacheService.ensureCache(e,t);const l=this._injector.get(s.IUniverInstanceService).getUnit(e,s.UniverInstanceType.UNIVER_SHEET).getSheetBySheetId(t),d=new s.ObjectMatrix;a==null||a.forEach(u=>{const c=u.uid;u.ranges.forEach(h=>{s.Range.foreach(h,(p,f)=>{d.setValue(p,f,c)})})}),a==null||a.forEach(u=>{this._dataValidationRefRangeController.register(e,t,u)}),this._ruleMatrix=new It(d,l)}_addRuleSideEffect(e){var i;const{unitId:t,subUnitId:a}=this;(e.type===s.DataValidationType.LIST||e.type===s.DataValidationType.LIST_MULTIPLE)&&re.isReferenceString((i=e.formula1)!=null?i:"")&&(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(i=>{this._addRuleSideEffect(i)}),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===C.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===C.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)}getValidator(e){return this._dataValidatorRegistryService.getValidatorItem(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,i){const{col:o,row:l,unitId:d,subUnitId:u}=a,c=t.uid,h=this.getValidator(t.type);if(h){const p=this._cache.getValue(l,o);return!p||p.value!==e?(this._cache.setValue(l,o,{value:e,status:s.DataValidationStatus.VALIDATING,ruleId:c}),h.validator({value:e,unitId:d,subUnitId:u,row:l,column:o},t).then(f=>{const g=f?s.DataValidationStatus.VALID:s.DataValidationStatus.INVALID;this._cache.setValue(l,o,{value:e,status:g,ruleId:c}),i(g,!0)}),s.DataValidationStatus.VALIDATING):(i(p.status,!1),p.status)}else return i(s.DataValidationStatus.VALID,!1),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 Pi=Object.defineProperty,Ai=Object.getOwnPropertyDescriptor,ji=(r,n,e,t)=>{for(var a=t>1?void 0:t?Ai(n,e):n,i=r.length-1,o;i>=0;i--)(o=r[i])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&Pi(n,e,a),a},at=(r,n)=>(e,t)=>n(e,t,r);let Be=class extends s.Disposable{constructor(r,n,e,t){super(),this._resourceManagerService=r,this._univerInstanceService=n,this._dataValidationModel=e,this._injector=t,this._initDataValidationDataSource()}_createSheetDataValidationManager(r,n){return new Li(r,n,[],this._injector)}_initDataValidationDataSource(){this._dataValidationModel.setManagerCreator(this._createSheetDataValidationManager.bind(this))}};Be=ji([s.OnLifecycle(s.LifecycleStages.Starting,Be),at(0,s.IResourceManagerService),at(1,s.IUniverInstanceService),at(2,M.Inject(C.DataValidationModel)),at(3,M.Inject(M.Injector))],Be);var Ui=Object.defineProperty,$i=Object.getOwnPropertyDescriptor,Bi=(r,n,e,t)=>{for(var a=t>1?void 0:t?$i(n,e):n,i=r.length-1,o;i>=0;i--)(o=r[i])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&Ui(n,e,a),a},yt=(r,n)=>(e,t)=>n(e,t,r);let We=class extends s.Disposable{constructor(r,n,e){super(),this._localeService=r,this._commandService=n,this._sheetPermissionInterceptorBaseController=e,this._commandExecutedListener()}_commandExecutedListener(){this.disposeWithMe(this._commandService.beforeCommandExecuted(r=>{r.id===C.AddDataValidationCommand.id&&(this._sheetPermissionInterceptorBaseController.permissionCheckWithRanges({workbookTypes:[$.WorkbookEditablePermission],rangeTypes:[$.RangeProtectionPermissionEditPoint],worksheetTypes:[$.WorksheetEditPermission,$.WorksheetSetCellStylePermission]})||this._sheetPermissionInterceptorBaseController.haveNotPermissionHandle(this._localeService.t("permission.dialog.setStyleErr"))),r.id===je.id&&(this._sheetPermissionInterceptorBaseController.permissionCheckWithRanges({workbookTypes:[$.WorkbookEditablePermission],rangeTypes:[$.RangeProtectionPermissionEditPoint],worksheetTypes:[$.WorksheetEditPermission,$.WorksheetSetCellStylePermission]},r.params.ranges)||this._sheetPermissionInterceptorBaseController.haveNotPermissionHandle(this._localeService.t("permission.dialog.setStyleErr")))}))}};We=Bi([s.OnLifecycle(s.LifecycleStages.Ready,We),yt(0,M.Inject(s.LocaleService)),yt(1,s.ICommandService),yt(2,M.Inject(B.SheetPermissionInterceptorBaseController))],We);var Wi=Object.defineProperty,Hi=Object.getOwnPropertyDescriptor,xi=(r,n,e,t)=>{for(var a=t>1?void 0:t?Hi(n,e):n,i=r.length-1,o;i>=0;i--)(o=r[i])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&Wi(n,e,a),a},Mt=(r,n)=>(e,t)=>n(e,t,r);v.SheetsDataValidationValidatorService=class{constructor(n,e,t){this._univerInstanceService=n,this._dataValidationModel=e,this._dataValidationCacheService=t}async validatorCell(n,e,t,a){const i=this._univerInstanceService.getUnit(n,s.UniverInstanceType.UNIVER_SHEET);if(!i)throw new Error(`cannot find current workbook, unitId: ${n}`);const o=i.getSheetBySheetId(e);if(!o)throw new Error(`cannot find current worksheet, sheetId: ${e}`);const l=o.getCellRaw(t,a),d=this._dataValidationModel.ensureManager(n,e),u=d.getRuleByLocation(t,a);return u?new Promise(c=>{d.validator(te(l),u,{unitId:n,subUnitId:e,row:t,col:a},c)}):s.DataValidationStatus.VALID}async validatorWorksheet(n,e){const a=this._dataValidationModel.ensureManager(n,e).getDataValidations();return await Promise.all(a.map(i=>Promise.all(i.ranges.map(o=>{const l=[];return s.Range.foreach(o,(d,u)=>{l.push(this.validatorCell(n,e,d,u))}),l})))),this._dataValidationCacheService.ensureCache(n,e)}async validatorWorkbook(n){const e=this._dataValidationModel.getSubUnitIds(n),t=await Promise.all(e.map(i=>this.validatorWorksheet(n,i))),a={};return t.forEach((i,o)=>{a[e[o]]=i}),a}},v.SheetsDataValidationValidatorService=xi([Mt(0,s.IUniverInstanceService),Mt(1,M.Inject(C.DataValidationModel)),Mt(2,M.Inject(_e))],v.SheetsDataValidationValidatorService);var va=Object.defineProperty,ki=Object.getOwnPropertyDescriptor,Yi=(r,n,e)=>n in r?va(r,n,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[n]=e,qi=(r,n,e,t)=>{for(var a=t>1?void 0:t?ki(n,e):n,i=r.length-1,o;i>=0;i--)(o=r[i])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&va(n,e,a),a},wt=(r,n)=>(e,t)=>n(e,t,r),ga=(r,n,e)=>Yi(r,typeof n!="symbol"?n+"":n,e);v.UniverSheetsDataValidationPlugin=class extends s.Plugin{constructor(n={},e,t,a){super(),this._config=n,this._injector=e,this._commandService=t,this._localeService=a,this._config=s.Tools.deepMerge({},ca,this._config)}onStarting(n){[[ue],[v.SheetDataValidationService],[_e],[v.DataValidationFormulaService],[v.DataValidationCustomFormulaService],[fe],[v.SheetsDataValidationValidatorService],[Be],[v.DataValidationController],[v.SheetsDataValidationRenderController,{useFactory:()=>this._injector.createInstance(v.SheetsDataValidationRenderController,this._config)}],[v.DataValidationAlertController],[v.DataValidationRefRangeController],[We],[v.DataValidationAutoFillController],[v.DataValidationCopyPasteController],[v.DataValidationFormulaController],[v.DataValidationRejectInputController]].forEach(e=>{n.add(e)}),[Ue,Ze,je,vt,la,Ee,rt,ke,Se,it].forEach(e=>{this._commandService.registerCommand(e)})}},ga(v.UniverSheetsDataValidationPlugin,"pluginName",be),ga(v.UniverSheetsDataValidationPlugin,"type",s.UniverInstanceType.UNIVER_SHEET),v.UniverSheetsDataValidationPlugin=qi([s.DependentOn(C.UniverDataValidationPlugin,$.UniverSheetsPlugin,B.UniverSheetsUIPlugin),wt(1,M.Inject(M.Injector)),wt(2,s.ICommandService),wt(3,M.Inject(s.LocaleService))],v.UniverSheetsDataValidationPlugin);var Sa=Object.defineProperty,Xi=Object.getOwnPropertyDescriptor,Gi=(r,n,e)=>n in r?Sa(r,n,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[n]=e,zi=(r,n,e,t)=>{for(var a=t>1?void 0:t?Xi(n,e):n,i=r.length-1,o;i>=0;i--)(o=r[i])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&Sa(n,e,a),a},Ot=(r,n)=>(e,t)=>n(e,t,r),_a=(r,n,e)=>Gi(r,typeof n!="symbol"?n+"":n,e);v.UniverSheetsDataValidationMobilePlugin=class extends s.Plugin{constructor(n={},e,t,a){super(),this._config=n,this._injector=e,this._commandService=t,this._localeService=a,this._config=s.Tools.deepMerge({},ca,this._config)}onStarting(n){[[ue],[v.SheetDataValidationService],[_e],[v.DataValidationFormulaService],[v.DataValidationCustomFormulaService],[fe],[v.SheetsDataValidationValidatorService],[Be],[v.DataValidationController],[$e,{useFactory:()=>this._injector.createInstance($e,this._config)}],[v.DataValidationAlertController],[v.DataValidationRefRangeController],[We],[v.DataValidationCopyPasteController],[v.DataValidationFormulaController]].forEach(e=>{n.add(e)}),[Ue,Ze,je,Ee,rt,ke,Se,it].forEach(e=>{this._commandService.registerCommand(e)})}},_a(v.UniverSheetsDataValidationMobilePlugin,"pluginName",be),_a(v.UniverSheetsDataValidationMobilePlugin,"type",s.UniverInstanceType.UNIVER_SHEET),v.UniverSheetsDataValidationMobilePlugin=zi([s.DependentOn(C.UniverDataValidationPlugin,$.UniverSheetsPlugin,B.UniverSheetsUIPlugin),Ot(1,M.Inject(M.Injector)),Ot(2,s.ICommandService),Ot(3,M.Inject(s.LocaleService))],v.UniverSheetsDataValidationMobilePlugin),Object.defineProperty(v,"ICommandService",{enumerable:!0,get:()=>s.ICommandService}),Object.defineProperty(v,"LocaleService",{enumerable:!0,get:()=>s.LocaleService}),Object.defineProperty(v,"Plugin",{enumerable:!0,get:()=>s.Plugin}),v.AddSheetDataValidationAndOpenCommand=Ze,v.AddSheetDataValidationCommand=Ue,v.CloseValidationPanelOperation=ke,v.DATA_VALIDATION_PLUGIN_NAME=be,v.DataValidationCacheService=_e,v.HideDataValidationDropdown=rt,v.OpenValidationPanelOperation=Se,v.ShowDataValidationDropdown=Ee,v.ToggleValidationPanelOperation=it,v.UpdateSheetDataValidationRangeCommand=je,Object.defineProperty(v,Symbol.toStringTag,{value:"Module"})});
9
+ */var f=React,k=Symbol.for("react.element"),l=Symbol.for("react.fragment"),m=Object.prototype.hasOwnProperty,n=f.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,p={key:!0,ref:!0,__self:!0,__source:!0};function q(c,a,g){var b,d={},e=null,h=null;g!==void 0&&(e=""+g),a.key!==void 0&&(e=""+a.key),a.ref!==void 0&&(h=a.ref);for(b in a)m.call(a,b)&&!p.hasOwnProperty(b)&&(d[b]=a[b]);if(c&&c.defaultProps)for(b in a=c.defaultProps,a)d[b]===void 0&&(d[b]=a[b]);return{$$typeof:k,type:c,key:e,ref:h,props:d,_owner:n.current}}__name(q,"q"),reactJsxRuntime_production_min.Fragment=l,reactJsxRuntime_production_min.jsx=q,reactJsxRuntime_production_min.jsxs=q,jsxRuntime.exports=reactJsxRuntime_production_min;var jsxRuntimeExports=jsxRuntime.exports;function CellDropdown(){const dropdownManagerService=core.useDependency(DataValidationDropdownManagerService),activeDropdown=ui.useObservable(dropdownManagerService.activeDropdown$,dropdownManagerService.activeDropdown),componentManager=core.useDependency(ui.ComponentManager);if(!activeDropdown)return null;const{location,componentKey}=activeDropdown,Component=componentManager.get(componentKey),key=`${location.unitId}-${location.subUnitId}-${location.row}-${location.col}`;if(!Component)return null;const hideFn=__name(()=>{dropdownManagerService.hideDropdown()},"hideFn");return jsxRuntimeExports.jsx(Component,{location,hideFn},key)}__name(CellDropdown,"CellDropdown");const DROP_DOWN_KEY="sheet.ui.dropdown";var __defProp$k=Object.defineProperty,__getOwnPropDesc$k=Object.getOwnPropertyDescriptor,__decorateClass$k=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$k(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$k(target,key,result),result},"__decorateClass$k"),__decorateParam$k=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$k");let DataValidationDropdownManagerService=(_a=class extends core.Disposable{constructor(_canvasPopupManagerService,_univerInstanceService,_dataValidatorRegistryService,_zenZoneService,_renderManagerService,_dataValidationModel){super();__publicField(this,"_activeDropdown");__publicField(this,"_activeDropdown$",new rxjs.Subject);__publicField(this,"_currentPopup",null);__publicField(this,"activeDropdown$",this._activeDropdown$.asObservable());__publicField(this,"_zenVisible",!1);this._canvasPopupManagerService=_canvasPopupManagerService,this._univerInstanceService=_univerInstanceService,this._dataValidatorRegistryService=_dataValidatorRegistryService,this._zenZoneService=_zenZoneService,this._renderManagerService=_renderManagerService,this._dataValidationModel=_dataValidationModel,this._init(),this.disposeWithMe(()=>{this._activeDropdown$.complete()})}get activeDropdown(){return this._activeDropdown}_init(){this.disposeWithMe(this._zenZoneService.visible$.subscribe(visible=>{this._zenVisible=visible,visible&&this.hideDropdown()}))}showDropdown(param,closeOnOutSide=!0){const{location}=param,{row,col}=location;if(this._currentPopup&&this._currentPopup.dispose(),this._zenVisible)return;this._activeDropdown=param,this._activeDropdown$.next(this._activeDropdown);const currentRender=this._renderManagerService.getRenderById(core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),popupDisposable=this._canvasPopupManagerService.attachPopupToCell(row,col,{componentKey:DROP_DOWN_KEY,onClickOutside:__name(()=>{closeOnOutSide&&this.hideDropdown()},"onClickOutside"),offset:[0,3],excludeOutside:[currentRender==null?void 0:currentRender.engine.getCanvasElement()].filter(Boolean)});if(!popupDisposable)throw new Error("[DataValidationDropdownManagerService]: cannot show dropdown!");const disposableCollection=new core.DisposableCollection;disposableCollection.add(popupDisposable),disposableCollection.add({dispose:__name(()=>{var _a2,_b2;(_b2=(_a2=this._activeDropdown)==null?void 0:_a2.onHide)==null||_b2.call(_a2)},"dispose")}),this._currentPopup=disposableCollection}hideDropdown(){this._activeDropdown&&(this._currentPopup&&this._currentPopup.dispose(),this._currentPopup=null,this._activeDropdown=null,this._activeDropdown$.next(null))}showDataValidationDropdown(unitId,subUnitId,row,col,onHide){const workbook=this._univerInstanceService.getUniverSheetInstance(unitId);if(!workbook)return;const worksheet=workbook.getSheetBySheetId(subUnitId);if(!worksheet)return;const rule=this._dataValidationModel.ensureManager(unitId,subUnitId).getRuleByLocation(row,col);if(!rule)return;const validator=this._dataValidatorRegistryService.getValidatorItem(rule.type);if(!validator||!validator.dropdown){this.hideDropdown();return}this.showDropdown({location:{workbook,worksheet,row,col,unitId,subUnitId},componentKey:validator.dropdown,onHide})}},__name(_a,"DataValidationDropdownManagerService"),_a);DataValidationDropdownManagerService=__decorateClass$k([__decorateParam$k(0,core.Inject(sheetsUi.SheetCanvasPopManagerService)),__decorateParam$k(1,core.IUniverInstanceService),__decorateParam$k(2,core.Inject(dataValidation.DataValidatorRegistryService)),__decorateParam$k(3,ui.IZenZoneService),__decorateParam$k(4,engineRender.IRenderManagerService),__decorateParam$k(5,core.Inject(dataValidation.DataValidationModel))],DataValidationDropdownManagerService);var __defProp$j=Object.defineProperty,__getOwnPropDesc$j=Object.getOwnPropertyDescriptor,__decorateClass$j=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$j(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$j(target,key,result),result},"__decorateClass$j"),__decorateParam$j=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$j");let DataValidationPanelService=(_b=class extends core.Disposable{constructor(_univerInstanceService,_sidebarService){super();__publicField(this,"_open$",new rxjs.BehaviorSubject(!1));__publicField(this,"open$",this._open$.pipe(rxjs.distinctUntilChanged()));__publicField(this,"_activeRule");__publicField(this,"_activeRule$",new rxjs.BehaviorSubject(void 0));__publicField(this,"activeRule$",this._activeRule$.asObservable());__publicField(this,"_closeDisposable",null);this._univerInstanceService=_univerInstanceService,this._sidebarService=_sidebarService,this.disposeWithMe(this._univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET).pipe(rxjs.filter(sheet=>!sheet)).subscribe(()=>{this.close()}))}get activeRule(){return this._activeRule}get isOpen(){return this._open$.getValue()}dispose(){var _a2;super.dispose(),this._open$.next(!1),this._open$.complete(),this._activeRule$.complete(),(_a2=this._closeDisposable)==null||_a2.dispose()}open(){this._open$.next(!0)}close(){var _a2;this._open$.next(!1),(_a2=this._closeDisposable)==null||_a2.dispose()}setCloseDisposable(disposable){this._closeDisposable=core.toDisposable(()=>{disposable.dispose(),this._closeDisposable=null})}setActiveRule(rule){this._activeRule=rule,this._activeRule$.next(rule)}},__name(_b,"DataValidationPanelService"),_b);DataValidationPanelService=__decorateClass$j([__decorateParam$j(0,core.IUniverInstanceService),__decorateParam$j(1,ui.ISidebarService)],DataValidationPanelService);const DATA_VALIDATION_PANEL="DataValidationPanel",OpenValidationPanelOperation={id:"data-validation.operation.open-validation-panel",type:core.CommandType.OPERATION,handler(accessor,params){if(!params)return!1;const{ruleId,isAdd}=params,dataValidationPanelService=accessor.get(DataValidationPanelService),dataValidationModel=accessor.get(dataValidation.DataValidationModel),univerInstanceService=accessor.get(core.IUniverInstanceService),sidebarService=accessor.get(ui.ISidebarService),target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{unitId,subUnitId}=target,rule=ruleId?dataValidationModel.getRuleById(unitId,subUnitId,ruleId):void 0;dataValidationPanelService.open(),dataValidationPanelService.setActiveRule(rule&&{unitId,subUnitId,rule});const disposable=sidebarService.open({header:{title:isAdd?"dataValidation.panel.addTitle":"dataValidation.panel.title"},children:{label:DATA_VALIDATION_PANEL},width:312,onClose:__name(()=>dataValidationPanelService.close(),"onClose")});return dataValidationPanelService.setCloseDisposable(disposable),!0}},CloseValidationPanelOperation={id:"data-validation.operation.close-validation-panel",type:core.CommandType.OPERATION,handler(accessor){return accessor.get(DataValidationPanelService).close(),!0}},ToggleValidationPanelOperation={id:"data-validation.operation.toggle-validation-panel",type:core.CommandType.OPERATION,handler(accessor){const commandService=accessor.get(core.ICommandService),dataValidationPanelService=accessor.get(DataValidationPanelService);return dataValidationPanelService.open(),dataValidationPanelService.isOpen?commandService.executeCommand(CloseValidationPanelOperation.id):commandService.executeCommand(OpenValidationPanelOperation.id),!0}},ShowDataValidationDropdown={type:core.CommandType.OPERATION,id:"sheet.operation.show-data-validation-dropdown",handler(accessor,params){if(!params)return!1;const dataValidationDropdownManagerService=accessor.get(DataValidationDropdownManagerService),{unitId,subUnitId,row,column}=params,activeDropdown=dataValidationDropdownManagerService.activeDropdown,currLoc=activeDropdown==null?void 0:activeDropdown.location;return currLoc&&currLoc.unitId===unitId&&currLoc.subUnitId===subUnitId&&currLoc.row===row&&currLoc.col===column||dataValidationDropdownManagerService.showDataValidationDropdown(unitId,subUnitId,row,column),!0}},HideDataValidationDropdown={type:core.CommandType.OPERATION,id:"sheet.operation.hide-data-validation-dropdown",handler(accessor,params){return params?(accessor.get(DataValidationDropdownManagerService).hideDropdown(),!0):!1}},_DataValidationCacheService=class _DataValidationCacheService{constructor(){__publicField(this,"_cacheMatrix",new Map)}_ensureCache(unitId,subUnitId){let unitMap=this._cacheMatrix.get(unitId);unitMap||(unitMap=new Map,this._cacheMatrix.set(unitId,unitMap));let cacheMatrix=unitMap.get(subUnitId);return cacheMatrix||(cacheMatrix=new core.ObjectMatrix,unitMap.set(subUnitId,cacheMatrix)),cacheMatrix}ensureCache(unitId,subUnitId){return this._ensureCache(unitId,subUnitId)}addRule(unitId,subUnitId,rule){this.markRangeDirty(unitId,subUnitId,rule.ranges)}removeRule(unitId,subUnitId,rule){this._deleteRange(unitId,subUnitId,rule.ranges)}updateRuleRanges(unitId,subUnitId,ruleId,newRanges,oldRanges){const cache=this._ensureCache(unitId,subUnitId);oldRanges.forEach(range=>{core.Range.foreach(range,(row,col)=>{const item=cache.getValue(row,col);item&&(item.temp=!0)})}),newRanges.forEach(range=>{core.Range.foreach(range,(row,col)=>{const item=cache.getValue(row,col);item&&item.ruleId===ruleId?item.temp=!1:cache.setValue(row,col,void 0)})}),oldRanges.forEach(range=>{core.Range.foreach(range,(row,col)=>{const item=cache.getValue(row,col);item&&item.temp===!0&&cache.realDeleteValue(row,col)})})}markRangeDirty(unitId,subUnitId,ranges){const cache=this._ensureCache(unitId,subUnitId);ranges.forEach(range=>{core.Range.foreach(range,(row,col)=>{cache.setValue(row,col,void 0)})})}markCellDirty(unitId,subUnitId,row,col){this._ensureCache(unitId,subUnitId).setValue(row,col,void 0)}_deleteRange(unitId,subUnitId,ranges){const cache=this._ensureCache(unitId,subUnitId);ranges.forEach(range=>{core.Range.foreach(range,(row,col)=>{cache.realDeleteValue(row,col)})})}getValue(unitId,subUnitId,row,col){return this._ensureCache(unitId,subUnitId).getValue(row,col)}setValue(unitId,subUnitId,row,col,value){return this._ensureCache(unitId,subUnitId).setValue(row,col,value)}};__name(_DataValidationCacheService,"DataValidationCacheService");let DataValidationCacheService=_DataValidationCacheService;var __defProp$i=Object.defineProperty,__getOwnPropDesc$i=Object.getOwnPropertyDescriptor,__decorateClass$i=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$i(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$i(target,key,result),result},"__decorateClass$i"),__decorateParam$i=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$i");exports2.DataValidationFormulaService=(_c=class extends core.Disposable{constructor(_registerOtherFormulaService,_dataValidationCacheService,_dataValidationModel){super();__publicField(this,"_formulaRuleMap",new Map);this._registerOtherFormulaService=_registerOtherFormulaService,this._dataValidationCacheService=_dataValidationCacheService,this._dataValidationModel=_dataValidationModel,this._initFormulaResultHandler()}_initFormulaResultHandler(){this.disposeWithMe(this._registerOtherFormulaService.formulaResult$.subscribe(resultMap=>{for(const unitId in resultMap){const unitMap=resultMap[unitId];for(const subUnitId in unitMap){const results=unitMap[subUnitId],formulaMap=this._ensureRuleFormulaMap(unitId,subUnitId),manager=this._dataValidationModel.ensureManager(unitId,subUnitId);results.forEach(result=>{var _a2,_b2;if(formulaMap.get((_a2=result.extra)==null?void 0:_a2.ruleId)){const rule=manager.getRuleById((_b2=result.extra)==null?void 0:_b2.ruleId);rule&&this._dataValidationCacheService.markRangeDirty(unitId,subUnitId,rule.ranges)}})}}}))}_ensureRuleFormulaMap(unitId,subUnitId){let unitMap=this._formulaRuleMap.get(unitId);unitMap||(unitMap=new Map,this._formulaRuleMap.set(unitId,unitMap));let subUnitMap=unitMap.get(subUnitId);return subUnitMap||(subUnitMap=new Map,unitMap.set(subUnitId,subUnitMap)),subUnitMap}addRule(unitId,subUnitId,ruleId,formula1,formula2){const isFormula1Legal=core.isFormulaString(formula1),isFormula2Legal=core.isFormulaString(formula2);if(!isFormula1Legal&&!isFormula2Legal)return;const formulaRuleMap=this._ensureRuleFormulaMap(unitId,subUnitId),item=[void 0,void 0];if(isFormula1Legal){const id=this._registerOtherFormulaService.registerFormula(unitId,subUnitId,formula1,{ruleId});item[0]={id,text:formula1}}if(isFormula2Legal){const id=this._registerOtherFormulaService.registerFormula(unitId,subUnitId,formula2,{ruleId});item[1]={id,text:formula2}}formulaRuleMap.set(ruleId,item)}removeRule(unitId,subUnitId,ruleId){const item=this._ensureRuleFormulaMap(unitId,subUnitId).get(ruleId);if(!item)return;const[formula1,formula2]=item,idList=[formula1==null?void 0:formula1.id,formula2==null?void 0:formula2.id].filter(Boolean);idList.length&&this._registerOtherFormulaService.deleteFormula(unitId,subUnitId,idList)}updateRuleFormulaText(unitId,subUnitId,ruleId,formula1,formula2){const item=this._ensureRuleFormulaMap(unitId,subUnitId).get(ruleId);if(!item){this.addRule(unitId,subUnitId,ruleId,formula1,formula2);return}const[oldFormula1,oldFormula2]=item;if((oldFormula1==null?void 0:oldFormula1.text)!==formula1)if(oldFormula1&&this._registerOtherFormulaService.deleteFormula(unitId,subUnitId,[oldFormula1.id]),core.isFormulaString(formula1)){const formulaId=this._registerOtherFormulaService.registerFormula(unitId,subUnitId,formula1,{ruleId});item[0]={text:formula1,id:formulaId}}else item[0]=void 0;if((oldFormula2==null?void 0:oldFormula2.text)!==formula2)if(oldFormula2&&this._registerOtherFormulaService.deleteFormula(unitId,subUnitId,[oldFormula2.id]),core.isFormulaString(formula2)){const formulaId=this._registerOtherFormulaService.registerFormula(unitId,subUnitId,formula2,{ruleId});item[1]={text:formula2,id:formulaId}}else item[1]=void 0}getRuleFormulaResult(unitId,subUnitId,ruleId){const formulaInfo=this._ensureRuleFormulaMap(unitId,subUnitId).get(ruleId);if(!formulaInfo)return Promise.resolve(null);const getResult=__name(async info=>info&&this._registerOtherFormulaService.getFormulaValue(unitId,subUnitId,info.id),"getResult");return Promise.all([getResult(formulaInfo[0]),getResult(formulaInfo[1])])}getRuleFormulaResultSync(unitId,subUnitId,ruleId){const formulaInfo=this._ensureRuleFormulaMap(unitId,subUnitId).get(ruleId);if(formulaInfo)return formulaInfo.map(i=>{if(i)return this._registerOtherFormulaService.getFormulaValueSync(unitId,subUnitId,i.id)})}getRuleFormulaInfo(unitId,subUnitId,ruleId){return this._ensureRuleFormulaMap(unitId,subUnitId).get(ruleId)}},__name(_c,"DataValidationFormulaService"),_c),exports2.DataValidationFormulaService=__decorateClass$i([__decorateParam$i(0,core.Inject(sheetsFormula.RegisterOtherFormulaService)),__decorateParam$i(1,core.Inject(DataValidationCacheService)),__decorateParam$i(2,core.Inject(dataValidation.DataValidationModel))],exports2.DataValidationFormulaService);function getFormulaResult(result){var _a2,_b2;return(_b2=(_a2=result==null?void 0:result[0])==null?void 0:_a2[0])==null?void 0:_b2.v}__name(getFormulaResult,"getFormulaResult");var __defProp$h=Object.defineProperty,__getOwnPropDesc$h=Object.getOwnPropertyDescriptor,__decorateClass$h=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$h(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$h(target,key,result),result},"__decorateClass$h"),__decorateParam$h=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$h");const MARGIN_H$2=6;let CheckboxRender=(_d=class{constructor(_commandService,_formulaService,_themeService){this._commandService=_commandService,this._formulaService=_formulaService,this._themeService=_themeService}_calc(cellInfo,style){var _a2,_b2,_c2;const{vt,ht}=style||{},width=cellInfo.endX-cellInfo.startX-MARGIN_H$2*2,height=cellInfo.endY-cellInfo.startY,size=((_a2=style==null?void 0:style.fs)!=null?_a2:10)*1.6;let widgetLeft=0,widgetTop=0;switch(vt){case core.VerticalAlign.TOP:widgetTop=0;break;case core.VerticalAlign.BOTTOM:widgetTop=0+(height-size);break;default:widgetTop=0+(height-size)/2;break}switch(ht){case core.HorizontalAlign.LEFT:widgetLeft=MARGIN_H$2;break;case core.HorizontalAlign.RIGHT:widgetLeft=MARGIN_H$2+(width-size);break;default:widgetLeft=MARGIN_H$2+(width-size)/2;break}return{left:cellInfo.startX+widgetLeft,top:cellInfo.startY+widgetTop,width:((_b2=style==null?void 0:style.fs)!=null?_b2:10)*1.6,height:((_c2=style==null?void 0:style.fs)!=null?_c2:10)*1.6}}calcCellAutoHeight(info){var _a2;const{style}=info;return((_a2=style==null?void 0:style.fs)!=null?_a2:10)*1.6}async _parseFormula(rule,unitId,subUnitId){var _a2,_b2;const{formula1=CHECKBOX_FORMULA_1,formula2=CHECKBOX_FORMULA_2}=rule,results=await this._formulaService.getRuleFormulaResult(unitId,subUnitId,rule.uid);return{formula1:core.isFormulaString(formula1)?getFormulaResult((_a2=results==null?void 0:results[0])==null?void 0:_a2.result):formula1,formula2:core.isFormulaString(formula2)?getFormulaResult((_b2=results==null?void 0:results[1])==null?void 0:_b2.result):formula2}}drawWith(ctx,info){var _a2,_b2,_c2,_d2,_e2;const{style,data,primaryWithCoord,unitId,subUnitId,worksheet,row,col}=info,cellBounding=primaryWithCoord.isMergedMainCell?primaryWithCoord.mergeInfo:primaryWithCoord,value=getCellValueOrigin(worksheet.getCellRaw(row,col)),rule=(_a2=data.dataValidation)==null?void 0:_a2.rule,validator=(_b2=data.dataValidation)==null?void 0:_b2.validator;if(!rule||!validator)return;const colors=this._themeService.getCurrentTheme();if(!validator.skipDefaultFontRender(rule,value,{unitId,subUnitId}))return;const result=validator.parseFormulaSync(rule,unitId,subUnitId),{formula1}=result,layout=this._calc(cellBounding,style),{a:scaleX,d:scaleY}=ctx.getTransform(),left=engineRender.fixLineWidthByScale(layout.left,scaleX),top=engineRender.fixLineWidthByScale(layout.top,scaleY),transform=engineRender.Transform.create().composeMatrix({left,top,scaleX:1,scaleY:1,angle:0,skewX:0,skewY:0,flipX:!1,flipY:!1}),cellWidth=cellBounding.endX-cellBounding.startX,cellHeight=cellBounding.endY-cellBounding.startY;ctx.save(),ctx.beginPath(),ctx.rect(cellBounding.startX,cellBounding.startY,cellWidth,cellHeight),ctx.clip();const m2=transform.getMatrix();ctx.transform(m2[0],m2[1],m2[2],m2[3],m2[4],m2[5]);const size=((_c2=style==null?void 0:style.fs)!=null?_c2:10)*1.6,checked=String(value)===String(formula1),defaultColor=colors.hyacinth500;engineRender.Checkbox.drawWith(ctx,{checked,width:size,height:size,fill:(_e2=(_d2=style==null?void 0:style.cl)==null?void 0:_d2.rgb)!=null?_e2:defaultColor}),ctx.restore()}isHit(evt,info){const cellBounding=info.primaryWithCoord.isMergedMainCell?info.primaryWithCoord.mergeInfo:info.primaryWithCoord,layout=this._calc(cellBounding,info.style),startY=layout.top,endY=layout.top+layout.height,startX=layout.left,endX=layout.left+layout.width,{x:offsetX,y:offsetY}=evt;return offsetX<=endX&&offsetX>=startX&&offsetY<=endY&&offsetY>=startY}async onPointerDown(info,evt){var _a2,_b2;if(evt.button===2)return;const{primaryWithCoord,unitId,subUnitId,data,worksheet,row,col}=info,value=getCellValueOrigin(worksheet.getCellRaw(row,col)),rule=(_a2=data.dataValidation)==null?void 0:_a2.rule,validator=(_b2=data.dataValidation)==null?void 0:_b2.validator;if(!rule||!validator||!validator.skipDefaultFontRender(rule,value,{unitId,subUnitId}))return;const{formula1,formula2}=await this._parseFormula(rule,unitId,subUnitId),params={range:{startColumn:primaryWithCoord.actualColumn,endColumn:primaryWithCoord.actualColumn,startRow:primaryWithCoord.actualRow,endRow:primaryWithCoord.actualRow},value:{v:String(value)===String(formula1)?formula2:formula1,p:null}};this._commandService.executeCommand(sheets.SetRangeValuesCommand.id,params)}},__name(_d,"CheckboxRender"),_d);CheckboxRender=__decorateClass$h([__decorateParam$h(0,core.ICommandService),__decorateParam$h(1,core.Inject(exports2.DataValidationFormulaService)),__decorateParam$h(2,core.Inject(core.ThemeService))],CheckboxRender);function CustomFormulaInput(props){var _a2;const{unitId,subUnitId,value,onChange,showError,validResult}=props,formula1Res=showError?validResult==null?void 0:validResult.formula1:"";return jsxRuntimeExports.jsx(design.FormLayout,{error:formula1Res,children:jsxRuntimeExports.jsx(ui.TextEditor,{value:(_a2=value==null?void 0:value.formula1)!=null?_a2:"",id:core.createInternalEditorID(`dataValidation-custom-formula-${unitId}-${subUnitId}`),onChange:__name(newValue=>{onChange==null||onChange({...value,formula1:newValue!=null?newValue:""})},"onChange"),onlyInputFormula:!0,openForSheetUnitId:unitId,openForSheetSubUnitId:subUnitId})})}__name(CustomFormulaInput,"CustomFormulaInput");const styles$6={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"},BaseFormulaInput=__name(props=>{const{isTwoFormula=!1,value,onChange,showError,validResult}=props,localeService=core.useDependency(core.LocaleService),formula1Res=showError?validResult==null?void 0:validResult.formula1:"",formula2Res=showError?validResult==null?void 0:validResult.formula2:"";return isTwoFormula?jsxRuntimeExports.jsxs(jsxRuntimeExports.Fragment,{children:[jsxRuntimeExports.jsx(design.FormLayout,{error:formula1Res,children:jsxRuntimeExports.jsx(design.Input,{className:styles$6.dataValidationFormula,placeholder:localeService.t("dataValidation.panel.formulaPlaceholder"),value:value==null?void 0:value.formula1,onChange:__name(newValue=>{onChange==null||onChange({...value,formula1:newValue})},"onChange")})}),jsxRuntimeExports.jsx("div",{className:styles$6.dataValidationFormulaAnd,children:localeService.t("dataValidation.panel.formulaAnd")}),jsxRuntimeExports.jsx(design.FormLayout,{error:formula2Res,children:jsxRuntimeExports.jsx(design.Input,{className:styles$6.dataValidationFormula,placeholder:localeService.t("dataValidation.panel.formulaPlaceholder"),value:value==null?void 0:value.formula2,onChange:__name(newValue=>{onChange==null||onChange({...value,formula2:newValue})},"onChange")})})]}):jsxRuntimeExports.jsx(design.FormLayout,{error:formula1Res,children:jsxRuntimeExports.jsx(design.Input,{className:styles$6.dataValidationFormula,placeholder:localeService.t("dataValidation.panel.formulaPlaceholder"),value:value==null?void 0:value.formula1,onChange:__name(newValue=>{onChange==null||onChange({formula1:newValue})},"onChange")})})},"BaseFormulaInput");var __assign=function(){return __assign=Object.assign||function(t){for(var s,i=1,n2=arguments.length;i<n2;i++){s=arguments[i];for(var p2 in s)Object.prototype.hasOwnProperty.call(s,p2)&&(t[p2]=s[p2])}return t},__assign.apply(this,arguments)},__rest=function(s,e){var t={};for(var p2 in s)Object.prototype.hasOwnProperty.call(s,p2)&&e.indexOf(p2)<0&&(t[p2]=s[p2]);if(s!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,p2=Object.getOwnPropertySymbols(s);i<p2.length;i++)e.indexOf(p2[i])<0&&Object.prototype.propertyIsEnumerable.call(s,p2[i])&&(t[p2[i]]=s[p2[i]]);return t},IconBase=React.forwardRef(function(props,ref){var icon=props.icon,id=props.id,className=props.className,extend=props.extend,restProps=__rest(props,["icon","id","className","extend"]),cls="univerjs-icon univerjs-icon-".concat(id," ").concat(className||"").trim(),idSuffix=React.useRef("_".concat(generateShortUuid()));return render(icon,"".concat(id),{defIds:icon.defIds,idSuffix:idSuffix.current},__assign({ref,className:cls},restProps),extend)});function render(node,id,runtimeProps,rootProps,extend){return React.createElement(node.tag,__assign(__assign({key:id},replaceRuntimeIdsAndExtInAttrs(node,runtimeProps,extend)),rootProps),(replaceRuntimeIdsInDefs(node,runtimeProps).children||[]).map(function(child,index){return render(child,"".concat(id,"-").concat(node.tag,"-").concat(index),runtimeProps,void 0,extend)}))}__name(render,"render");function replaceRuntimeIdsAndExtInAttrs(node,runtimeProps,extend){var attrs=__assign({},node.attrs);extend!=null&&extend.colorChannel1&&attrs.fill==="colorChannel1"&&(attrs.fill=extend.colorChannel1);var defIds=runtimeProps.defIds;return!defIds||defIds.length===0||(node.tag==="use"&&attrs["xlink:href"]&&(attrs["xlink:href"]=attrs["xlink:href"]+runtimeProps.idSuffix),Object.entries(attrs).forEach(function(_a2){var key=_a2[0],value=_a2[1];typeof value=="string"&&(attrs[key]=value.replace(/url\(#(.*)\)/,"url(#$1".concat(runtimeProps.idSuffix,")")))})),attrs}__name(replaceRuntimeIdsAndExtInAttrs,"replaceRuntimeIdsAndExtInAttrs");function replaceRuntimeIdsInDefs(node,runtimeProps){var _a2,defIds=runtimeProps.defIds;return!defIds||defIds.length===0?node:node.tag==="defs"&&(!((_a2=node.children)===null||_a2===void 0)&&_a2.length)?__assign(__assign({},node),{children:node.children.map(function(child){return typeof child.attrs.id=="string"&&defIds&&defIds.indexOf(child.attrs.id)>-1?__assign(__assign({},child),{attrs:__assign(__assign({},child.attrs),{id:child.attrs.id+runtimeProps.idSuffix})}):child})}):node}__name(replaceRuntimeIdsInDefs,"replaceRuntimeIdsInDefs");function generateShortUuid(){return Math.random().toString(36).substring(2,8)}__name(generateShortUuid,"generateShortUuid"),IconBase.displayName="UniverIcon";var element$6={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M14.1544 3.75557C14.3887 3.98988 14.3887 4.36978 14.1544 4.6041L6.51409 12.2444C6.40157 12.3569 6.24896 12.4201 6.08983 12.4201C5.9307 12.4201 5.77808 12.3569 5.66556 12.2444L1.84541 8.42425C1.6111 8.18993 1.6111 7.81003 1.84541 7.57572C2.07973 7.34141 2.45963 7.34141 2.69394 7.57572L6.08983 10.9716L13.3059 3.75557C13.5402 3.52126 13.9201 3.52126 14.1544 3.75557Z",fillRule:"evenodd",clipRule:"evenodd"}}]},CheckMarkSingle=React.forwardRef(function(props,ref){return React.createElement(IconBase,Object.assign({},props,{id:"check-mark-single",ref,icon:element$6}))});CheckMarkSingle.displayName="CheckMarkSingle";var element$5={tag:"svg",attrs:{fill:"none",viewBox:"0 0 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"}}]},DataValidationSingle=React.forwardRef(function(props,ref){return React.createElement(IconBase,Object.assign({},props,{id:"data-validation-single",ref,icon:element$5}))});DataValidationSingle.displayName="DataValidationSingle";var element$4={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M5.3313 1.4667C5.3313 1.13533 5.59993.866699 5.9313.866699H10.069C10.4004.866699 10.669 1.13533 10.669 1.4667 10.669 1.79807 10.4004 2.0667 10.069 2.0667H5.9313C5.59993 2.0667 5.3313 1.79807 5.3313 1.4667zM1.09985 3.64443C1.09985 3.31306 1.36848 3.04443 1.69985 3.04443H14.2999C14.6312 3.04443 14.8999 3.31306 14.8999 3.64443 14.8999 3.9758 14.6312 4.24443 14.2999 4.24443H1.69985C1.36848 4.24443 1.09985 3.9758 1.09985 3.64443zM6.12398 8.30171C6.35829 8.0674 6.73819 8.0674 6.97251 8.30171L8.00007 9.32928 9.02764 8.30171C9.26195 8.0674 9.64185 8.0674 9.87617 8.30171 10.1105 8.53603 10.1105 8.91593 9.87617 9.15024L8.8486 10.1778 9.87617 11.2054C10.1105 11.4397 10.1105 11.8196 9.87617 12.0539 9.64185 12.2882 9.26195 12.2882 9.02764 12.0539L8.00007 11.0263 6.97251 12.0539C6.73819 12.2882 6.35829 12.2882 6.12398 12.0539 5.88966 11.8196 5.88966 11.4397 6.12398 11.2054L7.15154 10.1778 6.12398 9.15024C5.88966 8.91593 5.88966 8.53603 6.12398 8.30171z"}},{tag:"path",attrs:{fill:"currentColor",d:"M4.75332 5.22217C3.86966 5.22217 3.15332 5.93851 3.15332 6.82217V12.5331C3.15332 13.9691 4.31738 15.1332 5.75332 15.1332H10.2465C11.6825 15.1332 12.8465 13.9691 12.8465 12.5331V6.82217C12.8465 5.93851 12.1302 5.22217 11.2465 5.22217H4.75332ZM4.35332 6.82217C4.35332 6.60125 4.53241 6.42217 4.75332 6.42217H11.2465C11.4674 6.42217 11.6465 6.60125 11.6465 6.82217V12.5331C11.6465 13.3063 11.0197 13.9332 10.2465 13.9332H5.75332C4.98012 13.9332 4.35332 13.3063 4.35332 12.5331V6.82217Z",fillRule:"evenodd",clipRule:"evenodd"}}]},DeleteSingle=React.forwardRef(function(props,ref){return React.createElement(IconBase,Object.assign({},props,{id:"delete-single",ref,icon:element$4}))});DeleteSingle.displayName="DeleteSingle";var element$3={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M8.6 1.99991C8.60001 1.66854 8.33138 1.39991 8.00001 1.3999C7.66864 1.3999 7.40001 1.66853 7.4 1.9999L7.39996 7.3999H1.9999C1.66853 7.3999 1.3999 7.66853 1.3999 7.9999C1.3999 8.33127 1.66853 8.5999 1.9999 8.5999H7.39995L7.3999 13.9999C7.3999 14.3313 7.66853 14.5999 7.9999 14.5999C8.33127 14.5999 8.5999 14.3313 8.5999 13.9999L8.59995 8.5999H13.9999C14.3313 8.5999 14.5999 8.33127 14.5999 7.9999C14.5999 7.66853 14.3313 7.3999 13.9999 7.3999H8.59996L8.6 1.99991Z"}}]},IncreaseSingle=React.forwardRef(function(props,ref){return React.createElement(IconBase,Object.assign({},props,{id:"increase-single",ref,icon:element$3}))});IncreaseSingle.displayName="IncreaseSingle";var element$2={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"}}]},MoreDownSingle=React.forwardRef(function(props,ref){return React.createElement(IconBase,Object.assign({},props,{id:"more-down-single",ref,icon:element$2}))});MoreDownSingle.displayName="MoreDownSingle";var element$1={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"}}]},MoreUpSingle=React.forwardRef(function(props,ref){return React.createElement(IconBase,Object.assign({},props,{id:"more-up-single",ref,icon:element$1}))});MoreUpSingle.displayName="MoreUpSingle";var element={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"}}]}]},SequenceSingle=React.forwardRef(function(props,ref){return React.createElement(IconBase,Object.assign({},props,{id:"sequence-single",ref,icon:element}))});SequenceSingle.displayName="SequenceSingle";function serializeListOptions(options){return options.filter(Boolean).join(",")}__name(serializeListOptions,"serializeListOptions");function deserializeListOptions(optionsStr){return optionsStr.split(",").filter(Boolean)}__name(deserializeListOptions,"deserializeListOptions");function getDataValidationCellValue(cellData){const cellValue=getCellValueOrigin(cellData);return cellValue==null?"":cellValue.toString()}__name(getDataValidationCellValue,"getDataValidationCellValue");const DATA_VALIDATION_PLUGIN_NAME="SHEET_DATA_VALIDATION_PLUGIN",DROP_DOWN_DEFAULT_COLOR="#ECECEC";var P=(E=>(E[E.View=0]="View",E[E.Edit=1]="Edit",E[E.ManageCollaborator=2]="ManageCollaborator",E[E.Print=3]="Print",E[E.Duplicate=4]="Duplicate",E[E.Comment=5]="Comment",E[E.Copy=6]="Copy",E[E.Share=7]="Share",E[E.Export=8]="Export",E[E.MoveWorksheet=9]="MoveWorksheet",E[E.DeleteWorksheet=10]="DeleteWorksheet",E[E.HideWorksheet=11]="HideWorksheet",E[E.RenameWorksheet=12]="RenameWorksheet",E[E.CreateWorksheet=13]="CreateWorksheet",E[E.SetWorksheetStyle=14]="SetWorksheetStyle",E[E.EditWorksheetCell=15]="EditWorksheetCell",E[E.InsertHyperlink=16]="InsertHyperlink",E[E.Sort=17]="Sort",E[E.Filter=18]="Filter",E[E.PivotTable=19]="PivotTable",E[E.FloatImg=20]="FloatImg",E[E.History=21]="History",E[E.RwHgtClWdt=22]="RwHgtClWdt",E[E.ViemRwHgtClWdt=23]="ViemRwHgtClWdt",E[E.ViewFilter=24]="ViewFilter",E[E.MoveSheet=25]="MoveSheet",E[E.DeleteSheet=26]="DeleteSheet",E[E.HideSheet=27]="HideSheet",E[E.CopySheet=28]="CopySheet",E[E.RenameSheet=29]="RenameSheet",E[E.CreateSheet=30]="CreateSheet",E[E.SelectProtectedCells=31]="SelectProtectedCells",E[E.SelectUnProtectedCells=32]="SelectUnProtectedCells",E[E.SetCellStyle=33]="SetCellStyle",E[E.SetCellValue=34]="SetCellValue",E[E.SetRowStyle=35]="SetRowStyle",E[E.SetColumnStyle=36]="SetColumnStyle",E[E.InsertRow=37]="InsertRow",E[E.InsertColumn=38]="InsertColumn",E[E.DeleteRow=39]="DeleteRow",E[E.DeleteColumn=40]="DeleteColumn",E[E.EditExtraObject=41]="EditExtraObject",E[E.Delete=42]="Delete",E[E.RecoverHistory=43]="RecoverHistory",E[E.ViewHistory=44]="ViewHistory",E[E.UNRECOGNIZED=-1]="UNRECOGNIZED",E))(P||{}),__defProp$g=Object.defineProperty,__getOwnPropDesc$g=Object.getOwnPropertyDescriptor,__decorateClass$g=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$g(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$g(target,key,result),result},"__decorateClass$g"),__decorateParam$g=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$g");exports2.DataValidationFormulaController=(_e=class extends core.Disposable{constructor(_univerInstanceService,_permissionService,_lexerTreeBuilder){super(),this._univerInstanceService=_univerInstanceService,this._permissionService=_permissionService,this._lexerTreeBuilder=_lexerTreeBuilder}getFormulaRefCheck(formulaString){var _a2,_b2;const sequenceNodes=this._lexerTreeBuilder.sequenceNodesBuilder(formulaString);if(!sequenceNodes)return!0;for(let i=0;i<sequenceNodes.length;i++){const node=sequenceNodes[i];if(typeof node=="string")continue;const{token}=node,sequenceGrid=engineFormula.deserializeRangeWithSheet(token),workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);let targetSheet=workbook.getActiveSheet();const unitId=workbook.getUnitId();if(sequenceGrid.sheetName){if(targetSheet=workbook.getSheetBySheetName(sequenceGrid.sheetName),!targetSheet)return!1;const subUnitId=targetSheet==null?void 0:targetSheet.getSheetId();if(!this._permissionService.getPermissionPoint(new sheets.WorksheetViewPermission(unitId,subUnitId).id))return!1}if(!targetSheet)return!1;const{startRow,endRow,startColumn,endColumn}=sequenceGrid.range;for(let i2=startRow;i2<=endRow;i2++)for(let j=startColumn;j<=endColumn;j++){const permission=(_b2=(_a2=targetSheet.getCell(i2,j))==null?void 0:_a2.selectionProtection)==null?void 0:_b2[0];if((permission==null?void 0:permission[P.View])===!1)return!1}}return!0}},__name(_e,"DataValidationFormulaController"),_e),exports2.DataValidationFormulaController=__decorateClass$g([core.OnLifecycle(core.LifecycleStages.Rendered,exports2.DataValidationFormulaController),__decorateParam$g(0,core.IUniverInstanceService),__decorateParam$g(1,core.IPermissionService),__decorateParam$g(2,core.Inject(engineFormula.LexerTreeBuilder))],exports2.DataValidationFormulaController);const DEFAULT_COLOR_PRESET=["#FFFFFF","#FEE7E7","#FEF0E6","#EFFBD0","#E4F4FE","#E8ECFD","#F1EAFA","#FDE8F3","#E5E5E5","#FDCECE","#FDC49B","#DEF6A2","#9FDAFF","#D0D9FB","#E3D5F6","#FBD0E8","#656565","#FE4B4B","#FF8C51","#8BBB11","#0B9EFB","#3A60F7","#9E6DE3","#F248A6"],ColorSelect=__name(props=>{const{value,onChange,disabled}=props,[open,setOpen]=React.useState(!1);return jsxRuntimeExports.jsx(design.Select,{disabled,open,onDropdownVisibleChange:setOpen,dropdownStyle:{width:112},className:styles$6.dataValidationFormulaColorSelect,value,onChange,labelRender:__name(item=>jsxRuntimeExports.jsx("div",{className:styles$6.dataValidationFormulaColorItem,style:{background:item.value,marginTop:5}}),"labelRender"),dropdownRender:__name(()=>jsxRuntimeExports.jsx("div",{className:styles$6.dataValidationFormulaColorSelectPanel,children:DEFAULT_COLOR_PRESET.map(color=>jsxRuntimeExports.jsx("div",{onClick:__name(()=>{onChange(color),setOpen(!1)},"onClick"),className:styles$6.dataValidationFormulaColorItem,style:{background:color}},color))}),"dropdownRender")})},"ColorSelect"),Template=__name(props=>{const{item,commonProps,style}=props,{onItemChange,onItemDelete}=commonProps;return jsxRuntimeExports.jsxs("div",{className:styles$6.dataValidationFormulaListItem,style,children:[item.isRef?null:jsxRuntimeExports.jsx("div",{className:cs(styles$6.dataValidationFormulaListItemDrag,"draggableHandle"),children:jsxRuntimeExports.jsx(SequenceSingle,{})}),jsxRuntimeExports.jsx(ColorSelect,{value:item.color,onChange:__name(color=>{onItemChange(item.id,item.label,color)},"onChange")}),jsxRuntimeExports.jsx(design.Input,{disabled:item.isRef,value:item.label,onChange:__name(label=>{onItemChange(item.id,label,item.color)},"onChange")}),item.isRef?null:jsxRuntimeExports.jsx("div",{className:styles$6.dataValidationFormulaListItemIcon,children:jsxRuntimeExports.jsx(DeleteSingle,{onClick:__name(()=>onItemDelete(item.id),"onClick")})})]})},"Template");function ListFormulaInput(props){const{value,onChange:_onChange=__name(()=>{},"_onChange"),unitId,subUnitId,validResult,showError,ruleId}=props,{formula1="",formula2=""}=value||{},containerRef=React.useRef(null),[isFormulaStr,setIsFormulaStr]=React.useState(()=>core.isFormulaString(formula1)?"1":"0"),[formulaStr,setFormulaStr]=React.useState(isFormulaStr==="1"?formula1:"="),[formulaStrCopy,setFormulaStrCopy]=React.useState(isFormulaStr==="1"?formula1:"="),localeService=core.useDependency(core.LocaleService),dataValidatorRegistryService=core.useDependency(dataValidation.DataValidatorRegistryService),dataValidationModel=core.useDependency(dataValidation.DataValidationModel),dataValidationFormulaController=core.useDependency(exports2.DataValidationFormulaController),[refColors,setRefColors]=React.useState(()=>formula2.split(",")),listValidator=dataValidatorRegistryService.getValidatorItem(core.DataValidationType.LIST),[refOptions,setRefOptions]=React.useState([]),[localError,setLocalError]=React.useState(""),formula1Res=showError?validResult==null?void 0:validResult.formula1:"",ruleChange$=React.useMemo(()=>dataValidationModel.ruleChange$.pipe(rxjs.debounceTime(16)),[]),ruleChange=ui.useObservable(ruleChange$),onChange=ui.useEvent(_onChange);React.useEffect(()=>{(async()=>{await new Promise(resolve=>{setTimeout(()=>resolve(!0),100)});const rule=dataValidationModel.getRuleById(unitId,subUnitId,ruleId),formula12=rule==null?void 0:rule.formula1;if(core.isFormulaString(formula12)&&listValidator&&rule){const res=await listValidator.getListAsync(rule,unitId,subUnitId);setRefOptions(res)}})()},[dataValidationModel,ruleChange,listValidator,ruleId,subUnitId,unitId]),React.useEffect(()=>{core.isFormulaString(formula1)&&formula1!==formulaStrCopy&&(setFormulaStr(formula1),setFormulaStrCopy(formulaStrCopy))},[formulaStrCopy,formula1]);const[strList,setStrList]=React.useState(()=>{const strOptions=isFormulaStr!=="1"?deserializeListOptions(formula1):[],strColors=formula2.split(",");return strOptions.map((label,i)=>({label,color:strColors[i]||DROP_DOWN_DEFAULT_COLOR,isRef:!1,id:core.Tools.generateRandomId(4)}))}),handleStrItemChange=__name((id,value2,color)=>{const item=strList.find(i=>i.id===id);item&&(item.label=value2,item.color=color,setStrList([...strList]))},"handleStrItemChange"),handleStrItemDelete=__name(id=>{const index=strList.findIndex(i=>i.id===id);index!==-1&&(strList.splice(index,1),setStrList([...strList]))},"handleStrItemDelete"),colorList=formula2.split(","),refFinalList=React.useMemo(()=>refOptions.map((label,i)=>({label,color:colorList[i]||DROP_DOWN_DEFAULT_COLOR,id:`${i}`,isRef:!0})),[colorList,refOptions]),handleRefItemChange=__name((id,value2,color)=>{const newColors=[...refColors];newColors[+id]=color,setRefColors(newColors),onChange({formula1,formula2:newColors.join(",")})},"handleRefItemChange"),handleAdd=__name(()=>{setStrList([...strList,{label:"",color:DROP_DOWN_DEFAULT_COLOR,isRef:!1,id:core.Tools.generateRandomId(4)}])},"handleAdd");React.useEffect(()=>{if(isFormulaStr==="1")return;const labelSet=new Set,finalList=[];strList.map(item=>({labelList:item.label.split(","),item})).forEach(({item,labelList})=>{labelList.forEach(labelItem=>{labelSet.has(labelItem)||(labelSet.add(labelItem),finalList.push({label:labelItem,color:item.color}))})}),onChange({formula1:serializeListOptions(finalList.map(item=>item.label)),formula2:finalList.map(item=>item.color===DROP_DOWN_DEFAULT_COLOR?"":item.color).join(",")})},[strList,onChange,isFormulaStr,formulaStrCopy,refColors]);const updateFormula=React.useMemo(()=>async str=>{if(!core.isFormulaString(str)){onChange==null||onChange({formula1:"",formula2});return}dataValidationFormulaController.getFormulaRefCheck(str)?(onChange==null||onChange({formula1:core.isFormulaString(str)?str:"",formula2}),setLocalError("")):(onChange==null||onChange({formula1:"",formula2}),setFormulaStr("="),setLocalError(localeService.t("dataValidation.validFail.formulaError")))},[formula2,onChange]);return jsxRuntimeExports.jsxs(jsxRuntimeExports.Fragment,{children:[jsxRuntimeExports.jsx(design.FormLayout,{label:localeService.t("dataValidation.list.options"),children:jsxRuntimeExports.jsxs(design.RadioGroup,{value:isFormulaStr,onChange:__name(v=>{setIsFormulaStr(v),setFormulaStr(formulaStrCopy),v==="1"&&onChange({formula1:formulaStrCopy==="="?"":formulaStrCopy,formula2:refColors.join(",")})},"onChange"),children:[jsxRuntimeExports.jsx(design.Radio,{value:"0",children:localeService.t("dataValidation.list.customOptions")}),jsxRuntimeExports.jsx(design.Radio,{value:"1",children:localeService.t("dataValidation.list.refOptions")})]})}),isFormulaStr==="1"?jsxRuntimeExports.jsxs(jsxRuntimeExports.Fragment,{children:[jsxRuntimeExports.jsx(design.FormLayout,{error:formula1Res||localError,children:jsxRuntimeExports.jsx(ui.TextEditor,{id:core.createInternalEditorID(`list-ref-range-${unitId}-${subUnitId}`),value:formulaStr,openForSheetUnitId:unitId,openForSheetSubUnitId:subUnitId,onlyInputFormula:!0,onChange:__name(async newString=>{const str=newString!=null?newString:"";setFormulaStrCopy(str),updateFormula(str)},"onChange")})}),jsxRuntimeExports.jsx(design.FormLayout,{children:jsxRuntimeExports.jsx("div",{ref:containerRef,children:refFinalList.map(item=>jsxRuntimeExports.jsx(Template,{item,commonProps:{onItemChange:handleRefItemChange},style:{marginBottom:12}},item.id))})})]}):jsxRuntimeExports.jsx(design.FormLayout,{error:formula1Res,children:jsxRuntimeExports.jsxs("div",{ref:containerRef,style:{marginTop:"-12px"},children:[jsxRuntimeExports.jsx(design.DraggableList,{list:strList,onListChange:setStrList,rowHeight:32,margin:[0,12],draggableHandle:".draggableHandle",itemRender:__name(item=>jsxRuntimeExports.jsx(Template,{item,commonProps:{onItemChange:handleStrItemChange,onItemDelete:handleStrItemDelete}},item.id),"itemRender"),idKey:"id"}),jsxRuntimeExports.jsxs("a",{className:styles$6.dataValidationFormulaListAdd,onClick:handleAdd,children:[jsxRuntimeExports.jsx(IncreaseSingle,{}),localeService.t("dataValidation.list.add")]})]})})]})}__name(ListFormulaInput,"ListFormulaInput");function CheckboxFormulaInput(props){const{value,onChange,showError,validResult}=props,localeService=core.useDependency(core.LocaleService),formula1Res=showError?validResult==null?void 0:validResult.formula1:"",formula2Res=showError?validResult==null?void 0:validResult.formula2:"",[checked,setChecked]=React.useState(!((value==null?void 0:value.formula1)===void 0&&(value==null?void 0:value.formula2)===void 0));return jsxRuntimeExports.jsxs(jsxRuntimeExports.Fragment,{children:[jsxRuntimeExports.jsx(design.FormLayout,{children:jsxRuntimeExports.jsx(design.Checkbox,{checked,onChange:__name(newValue=>{newValue?setChecked(!0):(setChecked(!1),onChange==null||onChange({...value,formula1:void 0,formula2:void 0}))},"onChange"),children:localeService.t("dataValidation.checkbox.tips")})}),checked?jsxRuntimeExports.jsx(design.FormLayout,{label:localeService.t("dataValidation.checkbox.checked"),error:formula1Res,children:jsxRuntimeExports.jsx(design.Input,{className:styles$6.dataValidationFormula,placeholder:localeService.t("dataValidation.panel.valuePlaceholder"),value:value==null?void 0:value.formula1,onChange:__name(newValue=>{onChange==null||onChange({...value,formula1:newValue||void 0})},"onChange")})}):null,checked?jsxRuntimeExports.jsx(design.FormLayout,{label:localeService.t("dataValidation.checkbox.unchecked"),error:formula2Res,children:jsxRuntimeExports.jsx(design.Input,{className:styles$6.dataValidationFormula,placeholder:localeService.t("dataValidation.panel.valuePlaceholder"),value:value==null?void 0:value.formula2,onChange:__name(newValue=>{onChange==null||onChange({...value,formula2:newValue||void 0})},"onChange")})}):null]})}__name(CheckboxFormulaInput,"CheckboxFormulaInput");const CUSTOM_FORMULA_INPUT_NAME="data-validation.custom-formula-input",BASE_FORMULA_INPUT_NAME="data-validation.formula-input",LIST_FORMULA_INPUT_NAME="data-validation.list-formula-input",CHECKBOX_FORMULA_INPUT_NAME="data-validation.checkbox-formula-input",FORMULA_INPUTS=[[CUSTOM_FORMULA_INPUT_NAME,CustomFormulaInput],[BASE_FORMULA_INPUT_NAME,BaseFormulaInput],[LIST_FORMULA_INPUT_NAME,ListFormulaInput],[CHECKBOX_FORMULA_INPUT_NAME,CheckboxFormulaInput]],CHECKBOX_FORMULA_1=1,CHECKBOX_FORMULA_2=0;function getFailMessage(formula,localeService){return core.Tools.isBlank(formula)?localeService.t("dataValidation.validFail.value"):core.isFormulaString(formula)?localeService.t("dataValidation.validFail.primitive"):""}__name(getFailMessage,"getFailMessage");const _CheckboxValidator=class _CheckboxValidator extends dataValidation.BaseDataValidator{constructor(){super(...arguments);__publicField(this,"id",core.DataValidationType.CHECKBOX);__publicField(this,"title","dataValidation.checkbox.title");__publicField(this,"operators",[]);__publicField(this,"scopes",["sheet"]);__publicField(this,"formulaInput",CHECKBOX_FORMULA_INPUT_NAME);__publicField(this,"canvasRender",this.injector.createInstance(CheckboxRender));__publicField(this,"_formulaService",this.injector.get(exports2.DataValidationFormulaService))}skipDefaultFontRender(rule,cellValue,pos){const{formula1,formula2}=this.parseFormulaSync(rule,pos.unitId,pos.subUnitId),valueStr=`${cellValue!=null?cellValue:""}`;return!valueStr||valueStr===`${formula1}`||valueStr===`${formula2}`}validatorFormula(rule,unitId,subUnitId){const{formula1,formula2}=rule,isEqual=formula1===formula2;if(core.Tools.isBlank(formula1)&&core.Tools.isBlank(formula2))return{success:!0};if(isEqual)return{success:!1,formula1:this.localeService.t("dataValidation.validFail.checkboxEqual"),formula2:this.localeService.t("dataValidation.validFail.checkboxEqual")};const error1=getFailMessage(formula1,this.localeService),error2=getFailMessage(formula2,this.localeService);return{success:!error1&&!error2,formula1:error1,formula2:error2}}async parseFormula(rule,unitId,subUnitId){var _a2,_b2;const{formula1=CHECKBOX_FORMULA_1,formula2=CHECKBOX_FORMULA_2}=rule,results=await this._formulaService.getRuleFormulaResult(unitId,subUnitId,rule.uid);return{formula1:core.isFormulaString(formula1)?getFormulaResult((_a2=results==null?void 0:results[0])==null?void 0:_a2.result):formula1,formula2:core.isFormulaString(formula2)?getFormulaResult((_b2=results==null?void 0:results[1])==null?void 0:_b2.result):formula2}}parseFormulaSync(rule,unitId,subUnitId){var _a2,_b2;const{formula1=CHECKBOX_FORMULA_1,formula2=CHECKBOX_FORMULA_2}=rule,results=this._formulaService.getRuleFormulaResultSync(unitId,subUnitId,rule.uid);return{formula1:core.isFormulaString(formula1)?getFormulaResult((_a2=results==null?void 0:results[0])==null?void 0:_a2.result):formula1,formula2:core.isFormulaString(formula2)?getFormulaResult((_b2=results==null?void 0:results[1])==null?void 0:_b2.result):formula2}}async isValidType(cellInfo,formula,rule){const{value,unitId,subUnitId}=cellInfo,{formula1,formula2}=await this.parseFormula(rule,unitId,subUnitId);return!core.Tools.isDefine(formula1)||!core.Tools.isDefine(formula2)?!0:core.Tools.isDefine(value)&&(String(value)===String(formula1)||String(value)===String(formula2))}generateRuleErrorMessage(rule){return this.localeService.t("dataValidation.checkbox.error")}};__name(_CheckboxValidator,"CheckboxValidator");let CheckboxValidator=_CheckboxValidator;const TWO_FORMULA_OPERATOR_COUNT=[core.DataValidationOperator.BETWEEN,core.DataValidationOperator.NOT_BETWEEN];function excelSerialToUnixTimestamp(excelSerial){return new Date((excelSerial-25569)*86400).getTime()}__name(excelSerialToUnixTimestamp,"excelSerialToUnixTimestamp");const timestamp2SerialTime=__name(timestamp=>timestamp/86400+25569,"timestamp2SerialTime"),styles$5={dataValidationOptionsButton:"univer-data-validation-options-button",dataValidationOptionsButtonIcon:"univer-data-validation-options-button-icon"};function DataValidationOptions(props){var _a2;const localeService=core.useDependency(core.LocaleService),componentManager=core.useDependency(ui.ComponentManager),{value,onChange,extraComponent}=props,[show,setShow]=React.useState(!1),ExtraOptions=extraComponent?componentManager.get(extraComponent):null;return jsxRuntimeExports.jsxs(jsxRuntimeExports.Fragment,{children:[jsxRuntimeExports.jsxs("div",{className:styles$5.dataValidationOptionsButton,onClick:__name(()=>setShow(!show),"onClick"),children:[localeService.t("dataValidation.panel.options"),show?jsxRuntimeExports.jsx(MoreUpSingle,{className:styles$5.dataValidationOptionsButtonIcon}):jsxRuntimeExports.jsx(MoreDownSingle,{className:styles$5.dataValidationOptionsButtonIcon})]}),show&&jsxRuntimeExports.jsxs(jsxRuntimeExports.Fragment,{children:[ExtraOptions?jsxRuntimeExports.jsx(ExtraOptions,{value,onChange}):null,jsxRuntimeExports.jsx(design.FormLayout,{label:localeService.t("dataValidation.panel.invalid"),children:jsxRuntimeExports.jsxs(design.RadioGroup,{value:`${(_a2=value.errorStyle)!=null?_a2:core.DataValidationErrorStyle.WARNING}`,onChange:__name(errorStyle=>onChange({...value,errorStyle:+errorStyle}),"onChange"),children:[jsxRuntimeExports.jsx(design.Radio,{value:`${core.DataValidationErrorStyle.WARNING}`,children:localeService.t("dataValidation.panel.showWarning")}),jsxRuntimeExports.jsx(design.Radio,{value:`${core.DataValidationErrorStyle.STOP}`,children:localeService.t("dataValidation.panel.rejectInput")})]})}),jsxRuntimeExports.jsx(design.FormLayout,{label:localeService.t("dataValidation.panel.messageInfo"),children:jsxRuntimeExports.jsx(design.Checkbox,{checked:value.showInputMessage,onChange:__name(()=>onChange({...value,showInputMessage:!value.showInputMessage}),"onChange"),children:localeService.t("dataValidation.panel.showInfo")})}),value.showInputMessage?jsxRuntimeExports.jsx(design.FormLayout,{children:jsxRuntimeExports.jsx(design.Input,{value:value.error,onChange:__name(error=>onChange({...value,error}),"onChange")})}):null]})]})}__name(DataValidationOptions,"DataValidationOptions");const styles$4={dataValidationDetailFormItem:"univer-data-validation-detail-form-item",dataValidationDetailButtons:"univer-data-validation-detail-buttons",dataValidationDetailButton:"univer-data-validation-detail-button"},debounceExecuteFactory=__name(commandService=>core.debounce(async(id,params,options,callback)=>{const res=await commandService.executeCommand(id,params,options);callback==null||callback(res)},275),"debounceExecuteFactory");function DataValidationDetail(){const[key,setKey]=React.useState(0),dataValidationPanelService=core.useDependency(DataValidationPanelService),activeRuleInfo=ui.useObservable(dataValidationPanelService.activeRule$,dataValidationPanelService.activeRule),{unitId,subUnitId,rule}=activeRuleInfo||{},ruleId=rule.uid,validatorService=core.useDependency(dataValidation.DataValidatorRegistryService),componentManager=core.useDependency(ui.ComponentManager),commandService=core.useDependency(core.ICommandService),dataValidationModel=core.useDependency(dataValidation.DataValidationModel),localeService=core.useDependency(core.LocaleService),[localRule,setLocalRule]=React.useState(rule),validator=validatorService.getValidatorItem(localRule.type),[showError,setShowError]=React.useState(!1),validators=validatorService.getValidatorsByScope(dataValidation.DataValidatorRegistryScope.SHEET),[localRanges,setLocalRanges]=React.useState(()=>localRule.ranges.map(i=>({unitId:"",sheetId:"",range:i}))),debounceExecute=React.useMemo(()=>debounceExecuteFactory(commandService),[commandService]);if(React.useEffect(()=>{commandService.onCommandExecuted(commandInfo=>{(commandInfo.id===core.UndoCommand.id||commandInfo.id===core.RedoCommand.id)&&setTimeout(()=>{const activeRule=dataValidationModel.getRuleById(unitId,subUnitId,ruleId);setKey(k2=>k2+1),activeRule&&(setLocalRule(activeRule),setLocalRanges(activeRule.ranges.map(i=>({unitId:"",sheetId:"",range:i}))))},20)})},[commandService,dataValidationModel,ruleId,subUnitId,unitId]),!validator)return null;const operators=validator.operators,operatorNames=validator.operatorNames,isTwoFormula=localRule.operator?dataValidation.TWO_FORMULA_OPERATOR_COUNT.includes(localRule.operator):!1,handleOk=__name(()=>{validator.validatorFormula(localRule,unitId,subUnitId).success?dataValidationPanelService.setActiveRule(null):setShowError(!0)},"handleOk"),handleUpdateRuleRanges=ui.useEvent(unitRanges=>{if(core.isUnitRangesEqual(unitRanges,localRanges))return;setLocalRanges(unitRanges);const ranges=unitRanges.filter(i=>(!i.unitId||i.unitId===unitId)&&(!i.sheetId||i.sheetId===subUnitId)).map(i=>i.range);if(setLocalRule({...localRule,ranges}),ranges.length===0)return;const params={unitId,subUnitId,ruleId,ranges};debounceExecute(UpdateSheetDataValidationRangeCommand.id,params)}),handleUpdateRuleSetting=__name(setting=>{if(core.shallowEqual(setting,dataValidation.getRuleSetting(localRule)))return;setLocalRule({...localRule,...setting});const params={unitId,subUnitId,ruleId,setting};debounceExecute(UpdateSheetDataValidationSettingCommand.id,params,void 0)},"handleUpdateRuleSetting"),handleDelete=__name(async()=>{await commandService.executeCommand(dataValidation.RemoveDataValidationCommand.id,{ruleId,unitId,subUnitId}),dataValidationPanelService.setActiveRule(null)},"handleDelete"),baseRule={type:localRule.type,operator:localRule.operator,formula1:localRule.formula1,formula2:localRule.formula2,allowBlank:localRule.allowBlank},handleChangeType=__name(newType=>{const validator2=validatorService.getValidatorItem(newType);if(!validator2)return;const operators2=validator2.operators,rule2=dataValidationModel.getRuleById(unitId,subUnitId,ruleId),newRule=newType===(rule2==null?void 0:rule2.type)||newType.includes("list")&&(rule2!=null&&rule2.type.includes("list"))?{...rule2,type:newType}:{...localRule,type:newType,operator:operators2[0],formula1:void 0,formula2:void 0};setLocalRule(newRule),commandService.executeCommand(UpdateSheetDataValidationSettingCommand.id,{unitId,subUnitId,ruleId:localRule.uid,setting:dataValidation.getRuleSetting(newRule)})},"handleChangeType"),FormulaInput=componentManager.get(validator.formulaInput),rangeStr=React.useMemo(()=>localRanges.map(i=>engineFormula.serializeRange(i.range)).join(","),[]),options=dataValidation.getRuleOptions(localRule),handleUpdateRuleOptions=__name(newOptions=>{core.shallowEqual(newOptions,dataValidation.getRuleOptions(localRule))||(setLocalRule({...localRule,...newOptions}),debounceExecute(UpdateSheetDataValidationOptionsCommand.id,{unitId,subUnitId,ruleId,options:newOptions}))},"handleUpdateRuleOptions");return jsxRuntimeExports.jsxs("div",{children:[jsxRuntimeExports.jsx(design.FormLayout,{label:localeService.t("dataValidation.panel.range"),children:jsxRuntimeExports.jsx(ui.RangeSelector,{className:styles$4.dataValidationDetailFormItem,value:rangeStr,id:core.createInternalEditorID("data-validation-detail"),openForSheetUnitId:unitId,openForSheetSubUnitId:subUnitId,onChange:__name(newRange=>{newRange.some(i=>!core.isValidRange(i.range)||i.range.endColumn<i.range.startColumn||i.range.endRow<i.range.startRow)||handleUpdateRuleRanges(newRange)},"onChange")},key)}),jsxRuntimeExports.jsx(design.FormLayout,{label:localeService.t("dataValidation.panel.type"),children:jsxRuntimeExports.jsx(design.Select,{options:validators==null?void 0:validators.map(validator2=>({label:localeService.t(validator2.title),value:validator2.id})),value:localRule.type,onChange:handleChangeType,className:styles$4.dataValidationDetailFormItem})}),operators!=null&&operators.length?jsxRuntimeExports.jsx(design.FormLayout,{label:localeService.t("dataValidation.panel.operator"),children:jsxRuntimeExports.jsx(design.Select,{options:operators.map((op,i)=>({value:`${op}`,label:operatorNames[i]})),value:`${localRule.operator}`,onChange:__name(operator=>{handleUpdateRuleSetting({...baseRule,operator})},"onChange"),className:styles$4.dataValidationDetailFormItem})}):null,FormulaInput?jsxRuntimeExports.jsx(FormulaInput,{isTwoFormula,value:{formula1:localRule.formula1,formula2:localRule.formula2},onChange:__name(value=>{handleUpdateRuleSetting({...baseRule,...value})},"onChange"),showError,validResult:validator.validatorFormula(localRule,unitId,subUnitId),unitId,subUnitId,ruleId},key+localRule.type):null,jsxRuntimeExports.jsx(DataValidationOptions,{value:options,onChange:handleUpdateRuleOptions,extraComponent:validator.optionsInput}),jsxRuntimeExports.jsxs("div",{className:styles$4.dataValidationDetailButtons,children:[jsxRuntimeExports.jsx(design.Button,{className:styles$4.dataValidationDetailButton,onClick:handleDelete,children:localeService.t("dataValidation.panel.removeRule")}),jsxRuntimeExports.jsx(design.Button,{className:styles$4.dataValidationDetailButton,type:"primary",onClick:handleOk,children:localeService.t("dataValidation.panel.done")})]})]})}__name(DataValidationDetail,"DataValidationDetail");const styles$3={dataValidationItemContainer:"univer-data-validation-item-container",dataValidationItemTitle:"univer-data-validation-item-title",dataValidationItemContent:"univer-data-validation-item-content",dataValidationItemIcon:"univer-data-validation-item-icon"},DataValidationItem=__name(props=>{const{rule,onClick,unitId,subUnitId,disable}=props,validatorRegistry=core.useDependency(dataValidation.DataValidatorRegistryService),commandService=core.useDependency(core.ICommandService),markSelectionService=core.useDependency(sheetsUi.IMarkSelectionService),validator=validatorRegistry.getValidatorItem(rule.type),ids=React.useRef(),[isHover,setIsHover]=React.useState(!1),handleDelete=__name(e=>{commandService.executeCommand(dataValidation.RemoveDataValidationCommand.id,{ruleId:rule.uid,unitId,subUnitId}),e.stopPropagation()},"handleDelete");return React.useEffect(()=>()=>{var _a2;ids.current&&((_a2=ids.current)==null||_a2.forEach(id=>{id&&markSelectionService.removeShape(id)}))},[markSelectionService]),jsxRuntimeExports.jsxs("div",{className:styles$3.dataValidationItemContainer,onClick,onMouseEnter:__name(()=>{disable||(setIsHover(!0),ids.current=rule.ranges.map(range=>markSelectionService.addShape({range,style:{hasAutoFill:!1,fill:"rgba(73, 184, 17, 0.05)",strokeWidth:1,stroke:"#49B811",widgets:{}},primary:{startColumn:range.startColumn,endColumn:range.endColumn,startRow:range.startRow,endRow:range.endRow,actualRow:range.startRow,actualColumn:range.startColumn,isMerged:!1,isMergedMainCell:!1}})))},"onMouseEnter"),onMouseLeave:__name(()=>{var _a2;setIsHover(!1),(_a2=ids.current)==null||_a2.forEach(id=>{id&&markSelectionService.removeShape(id)}),ids.current=void 0},"onMouseLeave"),children:[jsxRuntimeExports.jsx("div",{className:styles$3.dataValidationItemTitle,children:validator==null?void 0:validator.generateRuleName(rule)}),jsxRuntimeExports.jsx("div",{className:styles$3.dataValidationItemContent,children:rule.ranges.map(range=>engineFormula.serializeRange(range)).join(",")}),isHover?jsxRuntimeExports.jsx("div",{className:styles$3.dataValidationItemIcon,onClick:handleDelete,children:jsxRuntimeExports.jsx(DeleteSingle,{})}):null]})},"DataValidationItem"),styles$2={dataValidationListButtons:"univer-data-validation-list-buttons",dataValidationListButton:"univer-data-validation-list-button"};function DataValidationList(){const univerInstanceService=core.useDependency(core.IUniverInstanceService),workbook=ui.useObservable(()=>univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET),void 0,void 0,[]);return workbook?jsxRuntimeExports.jsx(DataValidationListWithWorkbook,{workbook}):null}__name(DataValidationList,"DataValidationList");function DataValidationListWithWorkbook(props){const dataValidationModel=core.useDependency(dataValidation.DataValidationModel),univerInstanceService=core.useDependency(core.IUniverInstanceService),commandService=core.useDependency(core.ICommandService),injector=core.useDependency(core.Injector),dataValidationPanelService=core.useDependency(DataValidationPanelService),localeService=core.useDependency(core.LocaleService),[rules,setRules]=React.useState([]),{workbook}=props,worksheet=ui.useObservable(workbook.activeSheet$,void 0,!0),unitId=workbook.getUnitId(),subUnitId=worksheet==null?void 0:worksheet.getSheetId(),manager=dataValidationModel.ensureManager(unitId,subUnitId);React.useEffect(()=>{setRules(manager.getDataValidations());const subscription=manager.dataValidations$.subscribe(currentRules=>{setRules([...currentRules])});return()=>{subscription.unsubscribe()}},[manager]);const handleAddRule=__name(async()=>{const rule=dataValidation.createDefaultNewRule(injector),params={unitId,subUnitId,rule};await commandService.executeCommand(AddSheetDataValidationCommand.id,params),dataValidationPanelService.setActiveRule({unitId,subUnitId,rule})},"handleAddRule"),handleRemoveAll=__name(()=>{commandService.executeCommand(dataValidation.RemoveAllDataValidationCommand.id,{unitId,subUnitId})},"handleRemoveAll"),rulesByPermissionCheck=__name(rules2=>{const worksheet2=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getActiveSheet();return rules2.map(rule=>{const{ranges}=rule;return(ranges==null?void 0:ranges.some(range=>{var _a2,_b2;const{startRow,startColumn,endRow,endColumn}=range;for(let row=startRow;row<=endRow;row++)for(let col=startColumn;col<=endColumn;col++){const permission=(_b2=(_a2=worksheet2==null?void 0:worksheet2.getCell(row,col))==null?void 0:_a2.selectionProtection)==null?void 0:_b2[0];if((permission==null?void 0:permission[P.Edit])===!1||(permission==null?void 0:permission[P.View])===!1)return!0}return!1}))?{...rule,disable:!0}:{...rule}})},"getDvRulesByPermissionCorrect")(rules),hasDisableRule=rulesByPermissionCheck==null?void 0:rulesByPermissionCheck.some(rule=>rule.disable);return jsxRuntimeExports.jsxs("div",{children:[rulesByPermissionCheck==null?void 0:rulesByPermissionCheck.map(rule=>{var _a2;return jsxRuntimeExports.jsx(DataValidationItem,{unitId,subUnitId,onClick:__name(()=>{rule.disable||dataValidationPanelService.setActiveRule({unitId,subUnitId,rule})},"onClick"),rule,disable:(_a2=rule.disable)!=null?_a2:!1},rule.uid)}),jsxRuntimeExports.jsxs("div",{className:styles$2.dataValidationListButtons,children:[rules.length&&!hasDisableRule?jsxRuntimeExports.jsx(design.Button,{className:styles$2.dataValidationListButton,onClick:handleRemoveAll,children:localeService.t("dataValidation.panel.removeAll")}):null,jsxRuntimeExports.jsx(design.Button,{className:styles$2.dataValidationListButton,type:"primary",onClick:handleAddRule,children:localeService.t("dataValidation.panel.add")})]})]})}__name(DataValidationListWithWorkbook,"DataValidationListWithWorkbook");const DataValidationPanel=__name(()=>{const dataValidationPanelService=core.useDependency(DataValidationPanelService),activeRule=ui.useObservable(dataValidationPanelService.activeRule$,dataValidationPanelService.activeRule);return activeRule?jsxRuntimeExports.jsx(DataValidationDetail,{},activeRule.rule.uid):jsxRuntimeExports.jsx(DataValidationList,{})},"DataValidationPanel"),styles$1={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"},SelectList=__name(props=>{const{value,onChange,multiple,options,title,onEdit,style}=props;return jsxRuntimeExports.jsxs("div",{className:styles$1.dvListDropdown,style,children:[jsxRuntimeExports.jsx("div",{className:styles$1.dvListDropdownTitle,children:title}),jsxRuntimeExports.jsx("div",{className:styles$1.dvListDropdownList,children:jsxRuntimeExports.jsx(design.Scrollbar,{children:jsxRuntimeExports.jsx("div",{className:styles$1.dvListDropdownListContainer,children:options.map((item,i)=>{const selected=value.indexOf(item.value)>-1,handleClick=__name(()=>{let set;selected?set=new Set(value.filter(sub=>sub!==item.value)):set=new Set(multiple?[...value,item.value]:[item.value]);const newValue=[];options.forEach(opt=>{set.has(opt.value)&&newValue.push(opt.value)}),onChange(newValue)},"handleClick");return jsxRuntimeExports.jsxs("div",{className:styles$1.dvListDropdownItemContainer,onClick:handleClick,children:[jsxRuntimeExports.jsx("div",{className:styles$1.dvListDropdownItem,style:{background:item.color||DROP_DOWN_DEFAULT_COLOR},children:item.label}),jsxRuntimeExports.jsx("div",{className:styles$1.dvListDropdownSelectedIcon,children:selected?jsxRuntimeExports.jsx(CheckMarkSingle,{}):null})]},i)})})})}),jsxRuntimeExports.jsx("div",{className:styles$1.dvListDropdownSplit}),jsxRuntimeExports.jsx("div",{className:styles$1.dvListDropdownEdit,children:jsxRuntimeExports.jsx("a",{onClick:onEdit,children:"编辑"})})]})},"SelectList");function ListDropDown(props){var _a2,_b2;const{location,hideFn}=props,{worksheet,row,col,unitId,subUnitId}=location,dataValidationModel=core.useDependency(dataValidation.DataValidationModel),commandService=core.useDependency(core.ICommandService),localeService=core.useDependency(core.LocaleService),[localValue,setLocalValue]=React.useState(""),editorBridgeService=core.useDependency(sheetsUi.IEditorBridgeService),ruleChange$=React.useMemo(()=>dataValidationModel.ruleChange$.pipe(rxjs.debounceTime(16)),[]);ui.useObservable(ruleChange$);const anchorRect=design.RectPopup.useContext(),cellWidth=anchorRect.right-anchorRect.left;if(!worksheet)return null;const cellData=worksheet.getCell(row,col),rule=(_a2=cellData==null?void 0:cellData.dataValidation)==null?void 0:_a2.rule,validator=(_b2=cellData==null?void 0:cellData.dataValidation)==null?void 0:_b2.validator,showColor=(rule==null?void 0:rule.renderMode)===core.DataValidationRenderMode.CUSTOM||(rule==null?void 0:rule.renderMode)===void 0;if(!cellData||!rule||!validator)return;const multiple=rule.type===core.DataValidationType.LIST_MULTIPLE,list=validator.getListWithColor(rule,unitId,subUnitId),cellStr=localValue||getDataValidationCellValue(worksheet.getCellRaw(row,col)),value=deserializeListOptions(cellStr),handleEdit=__name(()=>{commandService.executeCommand(OpenValidationPanelOperation.id,{ruleId:rule.uid}),hideFn()},"handleEdit");return jsxRuntimeExports.jsx(SelectList,{style:{minWidth:cellWidth,maxWidth:Math.max(cellWidth,200)},title:multiple?localeService.t("dataValidation.listMultiple.dropdown"):localeService.t("dataValidation.list.dropdown"),value,multiple,onChange:__name(newValue=>{const str=serializeListOptions(newValue),params={unitId,subUnitId,range:{startColumn:col,endColumn:col,startRow:row,endRow:row},value:{v:str,p:null,f:null,si:null,custom:{__link_url:""}}};editorBridgeService.isVisible()&&editorBridgeService.changeVisible({visible:!1,keycode:ui.KeyCode.ESC,eventType:engineRender.DeviceInputEventType.Keyboard,unitId}),commandService.executeCommand(sheets.SetRangeValuesCommand.id,params),setLocalValue(str),multiple||hideFn()},"onChange"),options:list.map(item=>({label:item.label,value:item.label,color:showColor?item.color:"transparent"})),onEdit:handleEdit})}__name(ListDropDown,"ListDropDown");var utc$1={exports:{}};(function(module2,exports3){(function(t,i){module2.exports=i()})(commonjsGlobal,function(){var t="minute",i=/[+-]\d\d(?::?\d\d)?/g,e=/([+-]|\d\d)/g;return function(s,f2,n2){var u=f2.prototype;n2.utc=function(t2){var i2={date:t2,utc:!0,args:arguments};return new f2(i2)},u.utc=function(i2){var e2=n2(this.toDate(),{locale:this.$L,utc:!0});return i2?e2.add(this.utcOffset(),t):e2},u.local=function(){return n2(this.toDate(),{locale:this.$L,utc:!1})};var o=u.parse;u.parse=function(t2){t2.utc&&(this.$u=!0),this.$utils().u(t2.$offset)||(this.$offset=t2.$offset),o.call(this,t2)};var r=u.init;u.init=function(){if(this.$u){var t2=this.$d;this.$y=t2.getUTCFullYear(),this.$M=t2.getUTCMonth(),this.$D=t2.getUTCDate(),this.$W=t2.getUTCDay(),this.$H=t2.getUTCHours(),this.$m=t2.getUTCMinutes(),this.$s=t2.getUTCSeconds(),this.$ms=t2.getUTCMilliseconds()}else r.call(this)};var a=u.utcOffset;u.utcOffset=function(s2,f3){var n3=this.$utils().u;if(n3(s2))return this.$u?0:n3(this.$offset)?a.call(this):this.$offset;if(typeof s2=="string"&&(s2=function(t2){t2===void 0&&(t2="");var s3=t2.match(i);if(!s3)return null;var f4=(""+s3[0]).match(e)||["-",0,0],n4=f4[0],u3=60*+f4[1]+ +f4[2];return u3===0?0:n4==="+"?u3:-u3}(s2),s2===null))return this;var u2=Math.abs(s2)<=16?60*s2:s2,o2=this;if(f3)return o2.$offset=u2,o2.$u=s2===0,o2;if(s2!==0){var r2=this.$u?this.toDate().getTimezoneOffset():-1*this.utcOffset();(o2=this.local().add(u2+r2,t)).$offset=u2,o2.$x.$localOffset=r2}else o2=this.utc();return o2};var h=u.format;u.format=function(t2){var i2=t2||(this.$u?"YYYY-MM-DDTHH:mm:ss[Z]":"");return h.call(this,i2)},u.valueOf=function(){var t2=this.$utils().u(this.$offset)?0:this.$offset+(this.$x.$localOffset||this.$d.getTimezoneOffset());return this.$d.valueOf()-6e4*t2},u.isUTC=function(){return!!this.$u},u.toISOString=function(){return this.toDate().toISOString()},u.toString=function(){return this.toDate().toUTCString()};var l2=u.toDate;u.toDate=function(t2){return t2==="s"&&this.$offset?n2(this.format("YYYY-MM-DD HH:mm:ss:SSS")).toDate():l2.call(this)};var c=u.diff;u.diff=function(t2,i2,e2){if(t2&&this.$u===t2.$u)return c.call(this,t2,i2,e2);var s2=this.local(),f3=n2(t2).local();return c.call(s2,f3,i2,e2)}}})})(utc$1);var utcExports=utc$1.exports;const utc=getDefaultExportFromCjs(utcExports);var __defProp$f=Object.defineProperty,__getOwnPropDesc$f=Object.getOwnPropertyDescriptor,__decorateClass$f=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$f(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$f(target,key,result),result},"__decorateClass$f"),__decorateParam$f=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$f");exports2.DataValidationRejectInputController=(_f=class extends core.Disposable{constructor(_editorBridgeService,_dataValidationModel,_dataValidatorRegistryService,_dialogService,_localeService){super(),this._editorBridgeService=_editorBridgeService,this._dataValidationModel=_dataValidationModel,this._dataValidatorRegistryService=_dataValidatorRegistryService,this._dialogService=_dialogService,this._localeService=_localeService,this._initEditorBridgeInterceptor()}_initEditorBridgeInterceptor(){this._editorBridgeService.interceptor.intercept(this._editorBridgeService.interceptor.getInterceptPoints().AFTER_CELL_EDIT_ASYNC,{handler:__name(async(cellPromise,context,next)=>{const cell=await cellPromise,{worksheet,row,col,unitId,subUnitId}=context,manager=this._dataValidationModel.ensureManager(unitId,subUnitId),ruleId=manager.getRuleIdByLocation(row,col),rule=ruleId?manager.getRuleById(ruleId):void 0;if(!rule||rule.errorStyle!==core.DataValidationErrorStyle.STOP)return next(Promise.resolve(cell));const validator=await this._dataValidatorRegistryService.getValidatorItem(rule.type);if(!validator||await validator.validator({value:getCellValueOrigin(cell),row,column:col,unitId,subUnitId},rule))return next(Promise.resolve(cell));const oldCell=worksheet.getCellRaw(row,col);return this._dialogService.open({width:368,title:{title:this._localeService.t("dataValidation.alert.title")},id:"reject-input-dialog",children:{title:validator.getRuleFinalError(rule)},footer:{title:React.createElement(design.Button,{type:"primary",onClick:__name(()=>this._dialogService.close("reject-input-dialog"),"onClick")},this._localeService.t("dataValidation.alert.ok"))},onClose:__name(()=>{this._dialogService.close("reject-input-dialog")},"onClose")}),next(Promise.resolve(oldCell))},"handler")})}showReject(title){this._dialogService.open({width:368,title:{title:this._localeService.t("dataValidation.alert.title")},id:"reject-input-dialog",children:{title},footer:{title:React.createElement(design.Button,{type:"primary",onClick:__name(()=>this._dialogService.close("reject-input-dialog"),"onClick")},this._localeService.t("dataValidation.alert.ok"))},onClose:__name(()=>{this._dialogService.close("reject-input-dialog")},"onClose")})}},__name(_f,"DataValidationRejectInputController"),_f),exports2.DataValidationRejectInputController=__decorateClass$f([core.OnLifecycle(core.LifecycleStages.Ready,exports2.DataValidationRejectInputController),__decorateParam$f(0,sheetsUi.IEditorBridgeService),__decorateParam$f(1,core.Inject(dataValidation.DataValidationModel)),__decorateParam$f(2,core.Inject(dataValidation.DataValidatorRegistryService)),__decorateParam$f(3,ui.IDialogService),__decorateParam$f(4,core.Inject(core.LocaleService))],exports2.DataValidationRejectInputController);const styles={dvDateDropdown:"univer-dv-date-dropdown",dvDateDropdownBtns:"univer-dv-date-dropdown-btns"};dayjs.extend(utc);const transformDate=__name(value=>{if(value==null||typeof value=="boolean")return;if(typeof value=="number"||!Number.isNaN(+value)){const date2=dayjs.unix(excelSerialToUnixTimestamp(+value)).utc().format().slice(0,-1);return dayjs(date2)}const date=dayjs(value);if(date.isValid())return date},"transformDate");function DateDropdown(props){var _a2,_b2,_c2;const{location,hideFn}=props,{worksheet,row,col,unitId,subUnitId}=location,commandService=core.useDependency(core.ICommandService),rejectInputController=core.useDependency(exports2.DataValidationRejectInputController),cellData=worksheet.getCell(row,col),rule=(_a2=cellData==null?void 0:cellData.dataValidation)==null?void 0:_a2.rule,validator=(_b2=cellData==null?void 0:cellData.dataValidation)==null?void 0:_b2.validator,cellStr=getCellValueOrigin(worksheet.getCellRaw(row,col)),originDate=transformDate(cellStr),[localDate,setLocalDate]=React.useState(originDate),showTime=!!((_c2=rule==null?void 0:rule.bizInfo)!=null&&_c2.showTime),date=localDate&&localDate.isValid()?localDate:dayjs();if(!cellData||!rule||!validator)return;const handleSave=__name(async()=>{if(!localDate)return;const dateStr=`${localDate.format(showTime?"YYYY-MM-DD HH:mm:ss":"YYYY-MM-DD 00:00:00").split(" ").join("T")}Z`,serialTime=timestamp2SerialTime(dayjs(dateStr).unix());rule.errorStyle!==core.DataValidationErrorStyle.STOP||await validator.validator({value:serialTime,unitId,subUnitId,row,column:col},rule)?(commandService.executeCommand(sheets.SetRangeValuesCommand.id,{unitId,subUnitId,range:{startColumn:col,endColumn:col,startRow:row,endRow:row},value:{v:serialTime,t:2,p:null,f:null,si:null,s:{n:{pattern:showTime?"yyyy-MM-dd hh:mm:ss":"yyyy-MM-dd"}}}}),hideFn()):rejectInputController.showReject(validator.getRuleFinalError(rule))},"handleSave");return jsxRuntimeExports.jsxs("div",{className:styles.dvDateDropdown,children:[jsxRuntimeExports.jsx(design.DatePanel,{defaultValue:localDate,pickerValue:localDate!=null?localDate:date,showTime:showTime||void 0,onSelect:__name(async newValue=>{setLocalDate(newValue)},"onSelect"),onPanelChange:__name(value=>{setLocalDate(value)},"onPanelChange")}),jsxRuntimeExports.jsx("div",{className:styles.dvDateDropdownBtns,children:jsxRuntimeExports.jsx(design.Button,{size:"small",type:"primary",onClick:handleSave,disabled:!localDate,children:"确定"})})]})}__name(DateDropdown,"DateDropdown");const LIST_DROPDOWN_KEY="data-validation.list.dropdown",DATE_DROPDOWN_KEY="data-validation.date.dropdown",DateOperatorNameMap={[core.DataValidationOperator.BETWEEN]:"dataValidation.date.operators.between",[core.DataValidationOperator.EQUAL]:"dataValidation.date.operators.equal",[core.DataValidationOperator.GREATER_THAN]:"dataValidation.date.operators.greaterThan",[core.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.date.operators.greaterThanOrEqual",[core.DataValidationOperator.LESS_THAN]:"dataValidation.date.operators.lessThan",[core.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.date.operators.lessThanOrEqual",[core.DataValidationOperator.NOT_BETWEEN]:"dataValidation.date.operators.notBetween",[core.DataValidationOperator.NOT_EQUAL]:"dataValidation.date.operators.notEqual"};core.DataValidationOperator.BETWEEN+"",core.DataValidationOperator.EQUAL+"",core.DataValidationOperator.GREATER_THAN+"",core.DataValidationOperator.GREATER_THAN_OR_EQUAL+"",core.DataValidationOperator.LESS_THAN+"",core.DataValidationOperator.LESS_THAN_OR_EQUAL+"",core.DataValidationOperator.NOT_BETWEEN+"",core.DataValidationOperator.NOT_EQUAL+"";const DateOperatorTitleMap={[core.DataValidationOperator.BETWEEN]:"dataValidation.date.ruleName.between",[core.DataValidationOperator.EQUAL]:"dataValidation.date.ruleName.equal",[core.DataValidationOperator.GREATER_THAN]:"dataValidation.date.ruleName.greaterThan",[core.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.date.ruleName.greaterThanOrEqual",[core.DataValidationOperator.LESS_THAN]:"dataValidation.date.ruleName.lessThan",[core.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.date.ruleName.lessThanOrEqual",[core.DataValidationOperator.NOT_BETWEEN]:"dataValidation.date.ruleName.notBetween",[core.DataValidationOperator.NOT_EQUAL]:"dataValidation.date.ruleName.notEqual"},DateOperatorErrorTitleMap={[core.DataValidationOperator.BETWEEN]:"dataValidation.date.errorMsg.between",[core.DataValidationOperator.EQUAL]:"dataValidation.date.errorMsg.equal",[core.DataValidationOperator.GREATER_THAN]:"dataValidation.date.errorMsg.greaterThan",[core.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.date.errorMsg.greaterThanOrEqual",[core.DataValidationOperator.LESS_THAN]:"dataValidation.date.errorMsg.lessThan",[core.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.date.errorMsg.lessThanOrEqual",[core.DataValidationOperator.NOT_BETWEEN]:"dataValidation.date.errorMsg.notBetween",[core.DataValidationOperator.NOT_EQUAL]:"dataValidation.date.errorMsg.notEqual"},DATE_SHOW_TIME_OPTION="DATE_SHOW_TIME_OPTION";function DateShowTimeOption(props){var _a2;const{value,onChange}=props,localeService=core.useDependency(core.LocaleService);return jsxRuntimeExports.jsx(design.FormLayout,{children:jsxRuntimeExports.jsx(design.Checkbox,{checked:(_a2=value.bizInfo)==null?void 0:_a2.showTime,onChange:__name(showTime=>{onChange({...value,bizInfo:{...value.bizInfo,showTime}})},"onChange"),children:localeService.t("dataValidation.showTime.label")})})}__name(DateShowTimeOption,"DateShowTimeOption"),DateShowTimeOption.componentKey=DATE_SHOW_TIME_OPTION;const FORMULA1$1="{FORMULA1}",FORMULA2$1="{FORMULA2}",transformDate2SerialNumber=__name(value=>{if(value==null||typeof value=="boolean")return;if(typeof value=="number"||!Number.isNaN(+value))return+value;const dateStr=`${dayjs(value).format("YYYY-MM-DD HH:mm:ss").split(" ").join("T")}Z`;return timestamp2SerialTime(dayjs(dateStr).unix())},"transformDate2SerialNumber"),_DateValidator=class _DateValidator extends dataValidation.BaseDataValidator{constructor(){super(...arguments);__publicField(this,"id",core.DataValidationType.DATE);__publicField(this,"title","dataValidation.date.title");__publicField(this,"operators",[core.DataValidationOperator.BETWEEN,core.DataValidationOperator.EQUAL,core.DataValidationOperator.GREATER_THAN,core.DataValidationOperator.GREATER_THAN_OR_EQUAL,core.DataValidationOperator.LESS_THAN,core.DataValidationOperator.LESS_THAN_OR_EQUAL,core.DataValidationOperator.NOT_BETWEEN,core.DataValidationOperator.NOT_EQUAL]);__publicField(this,"scopes",["sheet"]);__publicField(this,"formulaInput",BASE_FORMULA_INPUT_NAME);__publicField(this,"optionsInput",DateShowTimeOption.componentKey);__publicField(this,"dropdown",DATE_DROPDOWN_KEY);__publicField(this,"_formulaService",this.injector.get(exports2.DataValidationFormulaService))}async parseFormula(rule,unitId,subUnitId){var _a2,_b2;const results=await this._formulaService.getRuleFormulaResult(unitId,subUnitId,rule.uid),{formula1,formula2}=rule;return{formula1:transformDate2SerialNumber(core.isFormulaString(formula1)?getFormulaResult((_a2=results==null?void 0:results[0])==null?void 0:_a2.result):formula1),formula2:transformDate2SerialNumber(core.isFormulaString(formula2)?getFormulaResult((_b2=results==null?void 0:results[1])==null?void 0:_b2.result):formula2)}}parseFormulaSync(rule,unitId,subUnitId){var _a2,_b2;const results=this._formulaService.getRuleFormulaResultSync(unitId,subUnitId,rule.uid),{formula1,formula2}=rule;return{formula1:transformDate2SerialNumber(core.isFormulaString(formula1)?getFormulaResult((_a2=results==null?void 0:results[0])==null?void 0:_a2.result):formula1),formula2:transformDate2SerialNumber(core.isFormulaString(formula2)?getFormulaResult((_b2=results==null?void 0:results[1])==null?void 0:_b2.result):formula2)}}async isValidType(info){const{value}=info;return typeof value=="string"?dayjs(value,"YYYY-MM-DD HH:mm:ss",!0).isValid():typeof value=="number"}_validatorSingleFormula(formula){return!core.Tools.isBlank(formula)&&(core.isFormulaString(formula)||!Number.isNaN(+formula)||!!formula&&dayjs(formula).isValid())}validatorFormula(rule,unitId,subUnitId){const operator=rule.operator;if(!operator)return{success:!1};const formula1Success=this._validatorSingleFormula(rule.formula1),errorMsg=this.localeService.t("dataValidation.validFail.date");if(TWO_FORMULA_OPERATOR_COUNT.includes(operator)){const formula2Success=this._validatorSingleFormula(rule.formula2);return{success:formula1Success&&formula2Success,formula1:formula1Success?void 0:errorMsg,formula2:formula2Success?void 0:errorMsg}}return{success:formula1Success,formula1:formula1Success?void 0:errorMsg}}transform(cellInfo,_formula,_rule){const{value}=cellInfo;return{...cellInfo,value:transformDate2SerialNumber(value)}}async validatorIsEqual(cellInfo,formula,rule){const{formula1}=formula,{value:cellValue}=cellInfo;return Number.isNaN(formula1)?!0:cellValue===formula1}async validatorIsNotEqual(cellInfo,formula,_rule){const{formula1}=formula;return Number.isNaN(formula1)?!0:cellInfo.value!==formula1}async validatorIsBetween(cellInfo,formula,_rule){const{formula1,formula2}=formula;if(Number.isNaN(formula1)||Number.isNaN(formula2))return!0;const start=Math.min(formula1,formula2),end=Math.max(formula1,formula2);return cellInfo.value>=start&&cellInfo.value<=end}async validatorIsNotBetween(cellInfo,formula,_rule){const{formula1,formula2}=formula;if(Number.isNaN(formula1)||Number.isNaN(formula2))return!0;const start=Math.min(formula1,formula2),end=Math.max(formula1,formula2);return cellInfo.value<start||cellInfo.value>end}async validatorIsGreaterThan(cellInfo,formula,_rule){const{formula1}=formula;return Number.isNaN(formula1)?!0:cellInfo.value>formula1}async validatorIsGreaterThanOrEqual(cellInfo,formula,_rule){const{formula1}=formula;return Number.isNaN(formula1)?!0:cellInfo.value>=formula1}async validatorIsLessThan(cellInfo,formula,_rule){const{formula1}=formula;return Number.isNaN(formula1)?!0:cellInfo.value<formula1}async validatorIsLessThanOrEqual(cellInfo,formula,_rule){const{formula1}=formula;return Number.isNaN(formula1)?!0:cellInfo.value<=formula1}get operatorNames(){return this.operators.map(operator=>this.localeService.t(DateOperatorNameMap[operator]))}generateRuleName(rule){var _a2,_b2;if(!rule.operator)return this.titleStr;const ruleName=this.localeService.t(DateOperatorTitleMap[rule.operator]).replace(FORMULA1$1,(_a2=rule.formula1)!=null?_a2:"").replace(FORMULA2$1,(_b2=rule.formula2)!=null?_b2:"");return`${this.titleStr} ${ruleName}`}generateRuleErrorMessage(rule){var _a2,_b2;return rule.operator?`${this.localeService.t(DateOperatorErrorTitleMap[rule.operator]).replace(FORMULA1$1,(_a2=rule.formula1)!=null?_a2:"").replace(FORMULA2$1,(_b2=rule.formula2)!=null?_b2:"")}`:this.titleStr}};__name(_DateValidator,"DateValidator");let DateValidator=_DateValidator;var __defProp$e=Object.defineProperty,__getOwnPropDesc$e=Object.getOwnPropertyDescriptor,__decorateClass$e=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$e(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$e(target,key,result),result},"__decorateClass$e"),__decorateParam$e=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$e");const PADDING_H$1=4,ICON_SIZE=6,ICON_PLACE$1=14,MARGIN_H$1=6,MARGIN_V$1=4,DROP_DOWN_ICON_COLOR="#565656",downPath$1=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 convertToDocumentData(text,style){const contentLength=text.length;return{id:"d",body:{dataStream:`${text}${core.DEFAULT_EMPTY_DOCUMENT_VALUE}`,textRuns:[{ts:{fs:11,ff:void 0,it:core.BooleanNumber.FALSE,bl:core.BooleanNumber.FALSE,ul:{s:core.BooleanNumber.FALSE},st:{s:core.BooleanNumber.FALSE},ol:{s:core.BooleanNumber.FALSE},cl:void 0,...style,bg:void 0,bd:void 0},st:0,ed:contentLength}]},documentStyle:{pageSize:{width:Number.POSITIVE_INFINITY,height:Number.POSITIVE_INFINITY}}}}__name(convertToDocumentData,"convertToDocumentData");function createDocSkeleton(text,localeService,style){const documentData=convertToDocumentData(text,style),docModel=new core.DocumentDataModel(documentData),docViewModel=new engineRender.DocumentViewModel(docModel);return{documentSkeleton:engineRender.DocumentSkeleton.create(docViewModel,localeService),docModel,docViewModel}}__name(createDocSkeleton,"createDocSkeleton");function createDocuments(text,localeService,style){const{documentSkeleton,docModel,docViewModel}=createDocSkeleton(text,localeService,style);return{documents:new engineRender.Documents(`DOCUMENTS_${core.Tools.generateRandomId()}`,documentSkeleton,{pageMarginLeft:0,pageMarginTop:0}),documentSkeleton,docModel,docViewModel}}__name(createDocuments,"createDocuments");function calcPadding(cellWidth,cellHeight,fontWidth,fontHeight,vt,ht){let paddingTop=0;switch(vt){case core.VerticalAlign.BOTTOM:paddingTop=cellHeight-MARGIN_V$1*2-fontHeight+MARGIN_V$1;break;case core.VerticalAlign.MIDDLE:paddingTop=(cellHeight-MARGIN_V$1*2-fontHeight)/2+MARGIN_V$1;break;default:paddingTop=MARGIN_V$1;break}let paddingLeft=0;switch(ht){case core.HorizontalAlign.CENTER:paddingLeft=(cellWidth-fontWidth)/2;break;case core.HorizontalAlign.RIGHT:paddingLeft=cellWidth-fontWidth;break}return{paddingLeft,paddingTop}}__name(calcPadding,"calcPadding");let DropdownWidget=(_g=class{constructor(_localeService,_commandService){__publicField(this,"_dropdownInfoMap",new Map);__publicField(this,"zIndex");__publicField(this,"onPointerEnter");__publicField(this,"onPointerLeave");this._localeService=_localeService,this._commandService=_commandService}_ensureMap(subUnitId){let map=this._dropdownInfoMap.get(subUnitId);return map||(map=new Map,this._dropdownInfoMap.set(subUnitId,map)),map}_generateKey(row,col){return`${row}.${col}`}_drawDownIcon(ctx,cellBounding,cellWidth,cellHeight,vt){const left=cellWidth-ICON_PLACE$1+4;let top=9;switch(vt){case core.VerticalAlign.MIDDLE:top=(cellHeight-ICON_PLACE$1)/2+4;break;case core.VerticalAlign.BOTTOM:top=cellHeight-ICON_PLACE$1-1;break}ctx.save(),ctx.translateWithPrecision(cellBounding.startX+left,cellBounding.startY+top),ctx.fillStyle="#565656",ctx.fill(downPath$1),ctx.restore()}drawWith(ctx,info,skeleton){var _a2,_b2;const{primaryWithCoord,row,col,style,data,subUnitId}=info,_cellBounding=primaryWithCoord.isMergedMainCell?primaryWithCoord.mergeInfo:primaryWithCoord,rule=(_a2=data.dataValidation)==null?void 0:_a2.rule,validator=(_b2=data.dataValidation)==null?void 0:_b2.validator,fontRenderExtension=data.fontRenderExtension,{leftOffset=0,rightOffset=0,topOffset=0,downOffset=0}=fontRenderExtension||{};if(!rule||!validator||!validator.skipDefaultFontRender(rule))return;const cellBounding={startX:_cellBounding.startX+leftOffset,endX:_cellBounding.endX-rightOffset,startY:_cellBounding.startY+topOffset,endY:_cellBounding.endY-downOffset},cellWidth=cellBounding.endX-cellBounding.startX,cellHeight=cellBounding.endY-cellBounding.startY,map=this._ensureMap(subUnitId),key=this._generateKey(row,col),list=validator.getListWithColor(rule),value=getCellValueOrigin(data),valueStr=`${value!=null?value:""}`,activeItem=list.find(i=>i.label===valueStr);let{tb,vt,ht}=style||{};if(tb=tb!=null?tb:core.WrapStrategy.WRAP,vt=vt!=null?vt:core.VerticalAlign.BOTTOM,ht=ht!=null?ht:core.HorizontalAlign.LEFT,rule.renderMode===core.DataValidationRenderMode.ARROW){this._drawDownIcon(ctx,cellBounding,cellWidth,cellHeight,vt),ctx.save(),ctx.translateWithPrecision(cellBounding.startX,cellBounding.startY),ctx.beginPath(),ctx.rect(0,0,cellWidth,cellHeight),ctx.clip();const realWidth=cellWidth-ICON_PLACE$1,{documentSkeleton,documents,docModel}=createDocuments(valueStr,this._localeService,style);tb===core.WrapStrategy.WRAP&&docModel.updateDocumentDataPageSize(Math.max(realWidth,1)),documentSkeleton.calculate(),documentSkeleton.getActualSize();const textLayout=engineRender.getDocsSkeletonPageSize(documentSkeleton),{height:fontHeight,width:fontWidth}=textLayout,{paddingTop,paddingLeft}=calcPadding(realWidth,cellHeight,fontWidth,fontHeight,vt,ht);ctx.translate(0,paddingTop),ctx.save(),ctx.translateWithPrecision(PADDING_H$1,0),ctx.beginPath(),ctx.rect(0,0,realWidth,fontHeight),ctx.clip(),documents.render(ctx),ctx.translateWithPrecision(paddingLeft,0),ctx.restore(),ctx.restore(),map.set(key,{left:cellBounding.endX+skeleton.rowHeaderWidth-ICON_PLACE$1,top:cellBounding.startY+skeleton.columnHeaderHeight,width:ICON_PLACE$1,height:cellHeight})}else{ctx.save(),ctx.translateWithPrecision(cellBounding.startX,cellBounding.startY),ctx.beginPath(),ctx.rect(0,0,cellWidth,cellHeight),ctx.clip();const realWidth=cellWidth-MARGIN_H$1*2-PADDING_H$1-ICON_PLACE$1,{documentSkeleton,documents,docModel}=createDocuments(valueStr,this._localeService,style);tb===core.WrapStrategy.WRAP&&docModel.updateDocumentDataPageSize(Math.max(realWidth,1)),documentSkeleton.calculate();const textLayout=engineRender.getDocsSkeletonPageSize(documentSkeleton),{height:fontHeight,width:fontWidth}=textLayout,{paddingTop,paddingLeft}=calcPadding(realWidth,cellHeight,fontWidth,fontHeight,vt,ht);ctx.translate(MARGIN_H$1,paddingTop);const rectWidth=Math.max(cellWidth-MARGIN_H$1*2,1),rectHeight=fontHeight;engineRender.Rect.drawWith(ctx,{width:rectWidth,height:rectHeight,fill:(activeItem==null?void 0:activeItem.color)||DROP_DOWN_DEFAULT_COLOR,radius:8}),ctx.save(),ctx.translateWithPrecision(PADDING_H$1,0),ctx.beginPath(),ctx.rect(0,0,realWidth,fontHeight),ctx.clip(),ctx.translateWithPrecision(paddingLeft,0),documents.render(ctx),ctx.restore(),ctx.translate(realWidth+PADDING_H$1+4,(fontHeight-ICON_SIZE)/2),ctx.fillStyle=DROP_DOWN_ICON_COLOR,ctx.fill(downPath$1),ctx.restore(),map.set(key,{left:cellBounding.startX+MARGIN_H$1+skeleton.rowHeaderWidth,top:cellBounding.startY+paddingTop+skeleton.columnHeaderHeight,width:rectWidth,height:rectHeight})}}calcCellAutoHeight(info){var _a2;const{primaryWithCoord,style,data}=info,_cellBounding=primaryWithCoord.isMergedMainCell?primaryWithCoord.mergeInfo:primaryWithCoord,fontRenderExtension=data.fontRenderExtension,{leftOffset=0,rightOffset=0,topOffset=0,downOffset=0}=fontRenderExtension||{},rule=(_a2=data.dataValidation)==null?void 0:_a2.rule;if(!rule||rule.renderMode===core.DataValidationRenderMode.TEXT)return;const cellBounding={startX:_cellBounding.startX+leftOffset,endX:_cellBounding.endX-rightOffset,startY:_cellBounding.startY+topOffset,endY:_cellBounding.endY-downOffset},cellWidth=cellBounding.endX-cellBounding.startX,value=getCellValueOrigin(data),valueStr=`${value!=null?value:""}`;let{tb}=style||{};if(tb=tb!=null?tb:core.WrapStrategy.WRAP,rule.renderMode===core.DataValidationRenderMode.ARROW){const realWidth=cellWidth-ICON_PLACE$1,{documentSkeleton,docModel}=createDocuments(valueStr,this._localeService,style);tb===core.WrapStrategy.WRAP&&docModel.updateDocumentDataPageSize(Math.max(realWidth,1)),documentSkeleton.calculate(),documentSkeleton.getActualSize();const textLayout=engineRender.getDocsSkeletonPageSize(documentSkeleton),{height:fontHeight}=textLayout;return fontHeight}else{const realWidth=cellWidth-MARGIN_H$1*2-PADDING_H$1-ICON_PLACE$1,{documentSkeleton,docModel}=createDocSkeleton(valueStr,this._localeService,style);tb===core.WrapStrategy.WRAP&&docModel.updateDocumentDataPageSize(Math.max(realWidth,1)),documentSkeleton.calculate();const textLayout=engineRender.getDocsSkeletonPageSize(documentSkeleton),{height:fontHeight}=textLayout;return fontHeight+MARGIN_V$1*2}}isHit(position,info){const{data,subUnitId,row,col}=info,dropdownInfo=this._ensureMap(subUnitId).get(this._generateKey(row,col)),validation=data.dataValidation;if(!validation||!dropdownInfo||validation.rule.renderMode===core.DataValidationRenderMode.TEXT)return!1;const{top,left,width,height}=dropdownInfo,{x,y}=position;return x>=left&&x<=left+width&&y>=top&&y<=top+height}onPointerDown(info,evt){if(evt.button===2)return;const{unitId,subUnitId,row,col}=info,params={unitId,subUnitId,row,column:col};this._commandService.executeCommand(ShowDataValidationDropdown.id,params)}},__name(_g,"DropdownWidget"),__publicField(_g,"padding",{l:MARGIN_H$1+PADDING_H$1,r:ICON_PLACE$1+MARGIN_H$1,t:MARGIN_V$1,b:MARGIN_V$1}),_g);DropdownWidget=__decorateClass$e([__decorateParam$e(0,core.Inject(core.LocaleService)),__decorateParam$e(1,core.ICommandService)],DropdownWidget);const LIST_RENDER_MODE_OPTION_INPUT="LIST_RENDER_MODE_OPTION_INPUT";function ListRenderModeInput(props){var _a2;const{value,onChange}=props,localeService=core.useDependency(core.LocaleService);return jsxRuntimeExports.jsx(design.FormLayout,{label:localeService.t("dataValidation.renderMode.label"),children:jsxRuntimeExports.jsxs(design.RadioGroup,{value:`${(_a2=value.renderMode)!=null?_a2:core.DataValidationRenderMode.CUSTOM}`,onChange:__name(renderMode=>onChange({...value,renderMode:+renderMode}),"onChange"),children:[jsxRuntimeExports.jsx(design.Radio,{value:`${core.DataValidationRenderMode.CUSTOM}`,children:localeService.t("dataValidation.renderMode.chip")}),jsxRuntimeExports.jsx(design.Radio,{value:`${core.DataValidationRenderMode.ARROW}`,children:localeService.t("dataValidation.renderMode.arrow")}),jsxRuntimeExports.jsx(design.Radio,{value:`${core.DataValidationRenderMode.TEXT}`,children:localeService.t("dataValidation.renderMode.text")})]})})}__name(ListRenderModeInput,"ListRenderModeInput"),ListRenderModeInput.componentKey=LIST_RENDER_MODE_OPTION_INPUT;function getRuleFormulaResultSet(result){if(!result)return[];const resultSet=new Set;return result.forEach(row=>{row.forEach(cell=>{var _a2,_b2;const value=getCellValueOrigin(cell);if(value!=null){if(typeof value!="string"&&typeof(cell==null?void 0:cell.s)=="object"&&((_b2=(_a2=cell.s)==null?void 0:_a2.n)!=null&&_b2.pattern)){resultSet.add(engineNumfmt.numfmt.format(cell.s.n.pattern,value));return}resultSet.add(value.toString())}})}),[...resultSet]}__name(getRuleFormulaResultSet,"getRuleFormulaResultSet");const supportedFormula=["if","indirect","choose","offset"];function isValidListFormula(formula,lexer){if(!core.isFormulaString(formula)||engineFormula.isReferenceString(formula.slice(1)))return!0;const nodes=lexer.sequenceNodesBuilder(formula);return nodes&&nodes.some(node=>typeof node=="object"&&node.nodeType===engineFormula.sequenceNodeType.FUNCTION&&supportedFormula.indexOf(node.token.toLowerCase())>-1)}__name(isValidListFormula,"isValidListFormula");function isRuleIntersects(rule,sheetName){const{formula1="",ranges}=rule;if(engineFormula.isReferenceString(formula1.slice(1))){const refRange=engineFormula.deserializeRangeWithSheet(formula1.slice(1));if((!refRange.sheetName||refRange.sheetName===sheetName)&&ranges.some(range=>core.Rectangle.intersects(range,refRange.range)))return!0}return!1}__name(isRuleIntersects,"isRuleIntersects");const _ListValidator=class _ListValidator extends dataValidation.BaseDataValidator{constructor(){super(...arguments);__publicField(this,"formulaService",this.injector.get(exports2.DataValidationFormulaService));__publicField(this,"_lexer",this.injector.get(engineFormula.LexerTreeBuilder));__publicField(this,"_univerInstanceService",this.injector.get(core.IUniverInstanceService));__publicField(this,"id",core.DataValidationType.LIST);__publicField(this,"title","dataValidation.list.title");__publicField(this,"operators",[]);__publicField(this,"scopes",["sheet"]);__publicField(this,"formulaInput",LIST_FORMULA_INPUT_NAME);__publicField(this,"canvasRender",this.injector.createInstance(DropdownWidget));__publicField(this,"dropdown",LIST_DROPDOWN_KEY);__publicField(this,"optionsInput",ListRenderModeInput.componentKey)}skipDefaultFontRender(rule){return rule.renderMode!==core.DataValidationRenderMode.TEXT}validatorFormula(rule,unitId,subUnitId){var _a2,_b2,_c2;const success=!core.Tools.isBlank(rule.formula1),valid=isValidListFormula((_a2=rule.formula1)!=null?_a2:"",this._lexer),sheetName=(_c2=(_b2=this._univerInstanceService.getUnit(unitId,core.UniverInstanceType.UNIVER_SHEET))==null?void 0:_b2.getSheetBySheetId(subUnitId))==null?void 0:_c2.getName(),isIntersects=isRuleIntersects(rule,sheetName!=null?sheetName:"");return{success:!!(success&&valid&&!isIntersects),formula1:success?valid?isIntersects?this.localeService.t("dataValidation.validFail.listIntersects"):void 0:this.localeService.t("dataValidation.validFail.listInvalid"):this.localeService.t("dataValidation.validFail.list")}}parseCellValue(cellValue){const cellString=cellValue.toString();return deserializeListOptions(cellString)}async parseFormula(rule,unitId,subUnitId){var _a2;const{formula1=""}=rule,results=await this.formulaService.getRuleFormulaResult(unitId,subUnitId,rule.uid);return{formula1:core.isFormulaString(formula1)?getRuleFormulaResultSet((_a2=results==null?void 0:results[0])==null?void 0:_a2.result):deserializeListOptions(formula1),formula2:void 0}}async isValidType(cellInfo,formula,rule){const{value}=cellInfo,{formula1=[]}=formula;return this.parseCellValue(value).every(i=>formula1.includes(i))}generateRuleName(){return this.localeService.t("dataValidation.list.name")}generateRuleErrorMessage(){return this.localeService.t("dataValidation.list.error")}getList(rule,currentUnitId,currentSubUnitId){var _a2,_b2,_c2;const{formula1=""}=rule,univerInstanceService=this.injector.get(core.IUniverInstanceService),workbook=(_a2=currentUnitId?univerInstanceService.getUniverSheetInstance(currentUnitId):void 0)!=null?_a2:univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return[];const worksheet=(_b2=currentSubUnitId?workbook.getSheetBySheetId(currentSubUnitId):void 0)!=null?_b2:workbook.getActiveSheet();if(!worksheet)return[];const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),results=this.formulaService.getRuleFormulaResultSync(unitId,subUnitId,rule.uid);return core.isFormulaString(formula1)?getRuleFormulaResultSet((_c2=results==null?void 0:results[0])==null?void 0:_c2.result):deserializeListOptions(formula1)}async getListAsync(rule,currentUnitId,currentSubUnitId){var _a2,_b2,_c2;const{formula1=""}=rule,univerInstanceService=this.injector.get(core.IUniverInstanceService),workbook=(_a2=currentUnitId?univerInstanceService.getUniverSheetInstance(currentUnitId):void 0)!=null?_a2:univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return[];const worksheet=(_b2=currentSubUnitId?workbook.getSheetBySheetId(currentSubUnitId):void 0)!=null?_b2:workbook.getActiveSheet();if(!worksheet)return[];const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),results=await this.formulaService.getRuleFormulaResult(unitId,subUnitId,rule.uid);return core.isFormulaString(formula1)?getRuleFormulaResultSet((_c2=results==null?void 0:results[0])==null?void 0:_c2.result):deserializeListOptions(formula1)}getListWithColor(rule,currentUnitId,currentSubUnitId){const list=this.getList(rule,currentUnitId,currentSubUnitId),colorList=(rule.formula2||"").split(",");return list.map((label,i)=>({label,color:colorList[i]}))}getListWithColorMap(rule,currentUnitId,currentSubUnitId){const list=this.getListWithColor(rule,currentUnitId,currentSubUnitId),map={};return list.forEach(item=>{item.color&&(map[item.label]=item.color)}),map}};__name(_ListValidator,"ListValidator");let ListValidator=_ListValidator;function getCellValueNumber(cellValue){let str=cellValue;return typeof cellValue=="string"?((cellValue.startsWith("¥")||cellValue.startsWith("$"))&&(str=cellValue.slice(1)),+str):+cellValue}__name(getCellValueNumber,"getCellValueNumber");const _DecimalValidator=class _DecimalValidator extends dataValidation.BaseDataValidator{constructor(){super(...arguments);__publicField(this,"_formulaService",this.injector.get(exports2.DataValidationFormulaService));__publicField(this,"id",core.DataValidationType.DECIMAL);__publicField(this,"title","dataValidation.decimal.title");__publicField(this,"operators",[core.DataValidationOperator.BETWEEN,core.DataValidationOperator.EQUAL,core.DataValidationOperator.GREATER_THAN,core.DataValidationOperator.GREATER_THAN_OR_EQUAL,core.DataValidationOperator.LESS_THAN,core.DataValidationOperator.LESS_THAN_OR_EQUAL,core.DataValidationOperator.NOT_BETWEEN,core.DataValidationOperator.NOT_EQUAL]);__publicField(this,"scopes",["sheet"]);__publicField(this,"formulaInput",BASE_FORMULA_INPUT_NAME);__publicField(this,"dropDownInput")}_isFormulaOrNumber(formula){return!core.Tools.isBlank(formula)&&(core.isFormulaString(formula)||!Number.isNaN(+formula))}async isValidType(cellInfo,formula,rule){const{value:cellValue}=cellInfo;return!Number.isNaN(getCellValueNumber(cellValue))}transform(cellInfo,formula,rule){const{value:cellValue}=cellInfo;return{...cellInfo,value:getCellValueNumber(cellValue)}}_parseNumber(formula){return formula==null?Number.NaN:+formula}async parseFormula(rule,unitId,subUnitId){var _a2,_b2,_c2,_d2,_e2,_f2,_g2,_h2;const formulaInfo=await this._formulaService.getRuleFormulaResult(unitId,subUnitId,rule.uid),{formula1,formula2}=rule;return{formula1:this._parseNumber(core.isFormulaString(formula1)?(_d2=(_c2=(_b2=(_a2=formulaInfo==null?void 0:formulaInfo[0])==null?void 0:_a2.result)==null?void 0:_b2[0])==null?void 0:_c2[0])==null?void 0:_d2.v:formula1),formula2:this._parseNumber(core.isFormulaString(formula2)?(_h2=(_g2=(_f2=(_e2=formulaInfo==null?void 0:formulaInfo[1])==null?void 0:_e2.result)==null?void 0:_f2[0])==null?void 0:_g2[0])==null?void 0:_h2.v:formula2)}}validatorFormula(rule,unitId,subUnitId){const operator=rule.operator;if(!operator)return{success:!1};const formula1Success=core.Tools.isDefine(rule.formula1)&&this._isFormulaOrNumber(rule.formula1),formula2Success=core.Tools.isDefine(rule.formula2)&&this._isFormulaOrNumber(rule.formula2),isTwoFormula=TWO_FORMULA_OPERATOR_COUNT.includes(operator),errorMsg=this.localeService.t("dataValidation.validFail.number");return isTwoFormula?{success:formula1Success&&formula2Success,formula1:formula1Success?void 0:errorMsg,formula2:formula2Success?void 0:errorMsg}:{success:formula1Success,formula1:formula1Success?"":errorMsg}}async validatorIsEqual(cellInfo,formula,rule){const{formula1}=formula,{value:cellValue}=cellInfo;return Number.isNaN(formula1)?!0:cellValue===formula1}async validatorIsNotEqual(cellInfo,formula,_rule){const{formula1}=formula;return Number.isNaN(formula1)?!0:cellInfo.value!==formula1}async validatorIsBetween(cellInfo,formula,_rule){const{formula1,formula2}=formula;if(Number.isNaN(formula1)||Number.isNaN(formula2))return!0;const start=Math.min(formula1,formula2),end=Math.max(formula1,formula2);return cellInfo.value>=start&&cellInfo.value<=end}async validatorIsNotBetween(cellInfo,formula,_rule){const{formula1,formula2}=formula;if(Number.isNaN(formula1)||Number.isNaN(formula2))return!0;const start=Math.min(formula1,formula2),end=Math.max(formula1,formula2);return cellInfo.value<start||cellInfo.value>end}async validatorIsGreaterThan(cellInfo,formula,_rule){const{formula1}=formula;return Number.isNaN(formula1)?!0:cellInfo.value>formula1}async validatorIsGreaterThanOrEqual(cellInfo,formula,_rule){const{formula1}=formula;return Number.isNaN(formula1)?!0:cellInfo.value>=formula1}async validatorIsLessThan(cellInfo,formula,_rule){const{formula1}=formula;return Number.isNaN(formula1)?!0:cellInfo.value<formula1}async validatorIsLessThanOrEqual(cellInfo,formula,_rule){const{formula1}=formula;return Number.isNaN(formula1)?!0:cellInfo.value<=formula1}};__name(_DecimalValidator,"DecimalValidator");let DecimalValidator=_DecimalValidator;const FORMULA1="{FORMULA1}",FORMULA2="{FORMULA2}",_TextLengthValidator=class _TextLengthValidator extends dataValidation.BaseDataValidator{constructor(){super(...arguments);__publicField(this,"id",core.DataValidationType.TEXT_LENGTH);__publicField(this,"title","dataValidation.textLength.title");__publicField(this,"operators",[core.DataValidationOperator.BETWEEN,core.DataValidationOperator.EQUAL,core.DataValidationOperator.GREATER_THAN,core.DataValidationOperator.GREATER_THAN_OR_EQUAL,core.DataValidationOperator.LESS_THAN,core.DataValidationOperator.LESS_THAN_OR_EQUAL,core.DataValidationOperator.NOT_BETWEEN,core.DataValidationOperator.NOT_EQUAL]);__publicField(this,"scopes",["sheet"]);__publicField(this,"formulaInput",BASE_FORMULA_INPUT_NAME);__publicField(this,"_formulaService",this.injector.get(exports2.DataValidationFormulaService))}_isFormulaOrInt(formula){return!core.Tools.isBlank(formula)&&(core.isFormulaString(formula)||!Number.isNaN(+formula)&&Number.isInteger(+formula))}validatorFormula(rule,unitId,subUnitId){const operator=rule.operator;if(!operator)return{success:!1};const formula1Success=core.Tools.isDefine(rule.formula1)&&this._isFormulaOrInt(rule.formula1),formula2Success=core.Tools.isDefine(rule.formula2)&&this._isFormulaOrInt(rule.formula2),isTwoFormula=TWO_FORMULA_OPERATOR_COUNT.includes(operator),errorMsg=this.localeService.t("dataValidation.validFail.number");return isTwoFormula?{success:formula1Success&&formula2Success,formula1:formula1Success?void 0:errorMsg,formula2:formula2Success?void 0:errorMsg}:{success:formula1Success,formula1:errorMsg}}_parseNumber(formula){return formula==null?Number.NaN:+formula}_isValidFormula(formula){return!Number.isNaN(formula)}async parseFormula(rule,unitId,subUnitId){var _a2,_b2,_c2,_d2,_e2,_f2,_g2,_h2;const formulaInfo=await this._formulaService.getRuleFormulaResult(unitId,subUnitId,rule.uid),{formula1,formula2}=rule;return{formula1:this._parseNumber(core.isFormulaString(formula1)?(_d2=(_c2=(_b2=(_a2=formulaInfo==null?void 0:formulaInfo[0])==null?void 0:_a2.result)==null?void 0:_b2[0])==null?void 0:_c2[0])==null?void 0:_d2.v:formula1),formula2:this._parseNumber(core.isFormulaString(formula2)?(_h2=(_g2=(_f2=(_e2=formulaInfo==null?void 0:formulaInfo[1])==null?void 0:_e2.result)==null?void 0:_f2[0])==null?void 0:_g2[0])==null?void 0:_h2.v:formula2)}}transform(cellInfo,_formula,_rule){return{...cellInfo,value:cellInfo.value.toString().length}}async isValidType(cellInfo,formula,rule){const{value:cellValue}=cellInfo;return typeof cellValue=="string"||typeof cellValue=="number"}async validatorIsEqual(cellInfo,formula,rule){const{formula1}=formula;return core.Tools.isDefine(formula1)?cellInfo.value===formula1:!1}async validatorIsNotEqual(cellInfo,formula,rule){const{formula1}=formula;return core.Tools.isDefine(formula1)?cellInfo.value!==formula1:!1}async validatorIsBetween(cellInfo,formula,rule){const{formula1,formula2}=formula,{value:cellValue}=cellInfo;if(!this._isValidFormula(formula1)||!this._isValidFormula(formula2))return!1;const max=Math.max(formula1,formula2),min=Math.min(formula1,formula2);return cellValue>=min&&cellValue<=max}async validatorIsNotBetween(cellInfo,formula,rule){const{formula1,formula2}=formula,{value:cellValue}=cellInfo;if(!this._isValidFormula(formula1)||!this._isValidFormula(formula2))return!1;const max=Math.max(formula1,formula2),min=Math.min(formula1,formula2);return cellValue<min||cellValue>max}async validatorIsGreaterThan(cellInfo,formula,rule){const{formula1}=formula,{value:cellValue}=cellInfo;return this._isValidFormula(formula1)?cellValue>formula1:!1}async validatorIsGreaterThanOrEqual(cellInfo,formula,rule){const{formula1}=formula,{value:cellValue}=cellInfo;return this._isValidFormula(formula1)?cellValue>=formula1:!1}async validatorIsLessThan(cellInfo,formula,rule){const{formula1}=formula,{value:cellValue}=cellInfo;return this._isValidFormula(formula1)?cellValue<formula1:!1}async validatorIsLessThanOrEqual(cellInfo,formula,rule){const{formula1}=formula,{value:cellValue}=cellInfo;return this._isValidFormula(formula1)?cellValue<=formula1:!1}generateRuleErrorMessage(rule){var _a2,_b2;return rule.operator?`${this.localeService.t(dataValidation.TextLengthErrorTitleMap[rule.operator]).replace(FORMULA1,(_a2=rule.formula1)!=null?_a2:"").replace(FORMULA2,(_b2=rule.formula2)!=null?_b2:"")}`:this.titleStr}};__name(_TextLengthValidator,"TextLengthValidator");let TextLengthValidator=_TextLengthValidator;function isBlankCell(cellData){var _a2,_b2;return cellData?cellData.p?!((_b2=(_a2=cellData.p.body)==null?void 0:_a2.dataStream)!=null?_b2:"").slice(0,-2).trim():core.Tools.isBlank(cellData.v):!0}__name(isBlankCell,"isBlankCell");function getDataValidationDiffMutations(unitId,subUnitId,diffs,accessor,source="command"){const redoMutations=[],undoMutations=[],manager=accessor.get(dataValidation.DataValidationModel).ensureManager(unitId,subUnitId),univerInstanceService=accessor.get(core.IUniverInstanceService),target=sheets.getSheetCommandTarget(univerInstanceService,{unitId,subUnitId});if(!target)return{redoMutations,undoMutations};const{worksheet}=target,redoMatrix=new core.ObjectMatrix;function setRangesDefaultValue(ranges,defaultValue){ranges.forEach(range=>{core.Range.foreach(range,(row,column)=>{const cellData=worksheet.getCellRaw(row,column),value=getStringCellValue(cellData);(isBlankCell(cellData)||value===defaultValue)&&redoMatrix.setValue(row,column,{v:defaultValue,p:null})})})}__name(setRangesDefaultValue,"setRangesDefaultValue"),diffs.forEach(diff=>{switch(diff.type){case"delete":redoMutations.push({id:dataValidation.RemoveDataValidationMutation.id,params:{unitId,subUnitId,ruleId:diff.rule.uid,source}}),undoMutations.unshift({id:dataValidation.AddDataValidationMutation.id,params:{unitId,subUnitId,rule:diff.rule,index:diff.index,source}});break;case"update":{redoMutations.push({id:dataValidation.UpdateDataValidationMutation.id,params:{unitId,subUnitId,ruleId:diff.ruleId,payload:{type:dataValidation.UpdateRuleType.RANGE,payload:diff.newRanges},source}}),undoMutations.unshift({id:dataValidation.UpdateDataValidationMutation.id,params:{unitId,subUnitId,ruleId:diff.ruleId,payload:{type:dataValidation.UpdateRuleType.RANGE,payload:diff.oldRanges},source}});const rule=manager.getRuleById(diff.ruleId);if(rule&&rule.type===core.DataValidationType.CHECKBOX){const formula=manager.getValidator(core.DataValidationType.CHECKBOX).parseFormulaSync(rule,unitId,subUnitId);setRangesDefaultValue(diff.newRanges,formula.formula2)}break}case"add":{if(redoMutations.push({id:dataValidation.AddDataValidationMutation.id,params:{unitId,subUnitId,rule:diff.rule,source}}),undoMutations.unshift({id:dataValidation.RemoveDataValidationMutation.id,params:{unitId,subUnitId,ruleId:diff.rule.uid,source}}),diff.rule.type===core.DataValidationType.CHECKBOX){const formula=manager.getValidator(core.DataValidationType.CHECKBOX).parseFormulaSync(diff.rule,unitId,subUnitId);setRangesDefaultValue(diff.rule.ranges,formula.formula2)}break}}});const redoSetRangeValues={id:sheets.SetRangeValuesMutation.id,params:{unitId,subUnitId,cellValue:redoMatrix.getData()}},undoSetRangeValues={id:sheets.SetRangeValuesMutation.id,params:sheets.SetRangeValuesUndoMutationFactory(accessor,redoSetRangeValues.params)};return redoMutations.push(redoSetRangeValues),undoMutations.push(undoSetRangeValues),{redoMutations,undoMutations}}__name(getDataValidationDiffMutations,"getDataValidationDiffMutations");const UpdateSheetDataValidationRangeCommand={type:core.CommandType.COMMAND,id:"sheet.command.updateDataValidationRuleRange",async handler(accessor,params){if(!params)return!1;const{unitId,subUnitId,ranges,ruleId}=params,dataValidationModel=accessor.get(dataValidation.DataValidationModel),commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),manager=dataValidationModel.ensureManager(unitId,subUnitId),currentRule=manager.getRuleById(ruleId);if(!currentRule)return!1;const oldRanges=currentRule.ranges,matrix=manager.getRuleObjectMatrix().clone();matrix.updateRange(ruleId,oldRanges,ranges);const diffs=matrix.diff(manager.getDataValidations()),{redoMutations,undoMutations}=getDataValidationDiffMutations(unitId,subUnitId,diffs,accessor);return undoRedoService.pushUndoRedo({undoMutations,redoMutations,unitID:unitId}),await core.sequenceExecuteAsync(redoMutations,commandService),!0}},AddSheetDataValidationCommand={type:core.CommandType.COMMAND,id:"sheet.command.addDataValidation",async handler(accessor,params){if(!params)return!1;const{unitId,subUnitId,rule}=params,dataValidationModel=accessor.get(dataValidation.DataValidationModel),commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),manager=dataValidationModel.ensureManager(unitId,subUnitId),matrix=manager.getRuleObjectMatrix().clone();matrix.addRule(rule);const diffs=matrix.diff(manager.getDataValidations()),mutationParams={unitId,subUnitId,rule},{redoMutations,undoMutations}=getDataValidationDiffMutations(unitId,subUnitId,diffs,accessor);return redoMutations.push({id:dataValidation.AddDataValidationMutation.id,params:mutationParams}),undoMutations.unshift({id:dataValidation.RemoveDataValidationMutation.id,params:{unitId,subUnitId,ruleId:rule.uid}}),undoRedoService.pushUndoRedo({unitID:unitId,redoMutations,undoMutations}),await core.sequenceExecuteAsync(redoMutations,commandService),!0}},AddSheetDataValidationAndOpenCommand={type:core.CommandType.COMMAND,id:"data-validation.command.addRuleAndOpen",async handler(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{workbook,worksheet}=target,rule=dataValidation.createDefaultNewRule(accessor),commandService=accessor.get(core.ICommandService),unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),addParams={rule,unitId,subUnitId};return await commandService.executeCommand(AddSheetDataValidationCommand.id,addParams)?(commandService.executeCommand(OpenValidationPanelOperation.id,{ruleId:rule.uid,isAdd:!0}),!0):!1}},UpdateSheetDataValidationSettingCommand={type:core.CommandType.COMMAND,id:"sheets.command.update-data-validation-setting",handler(accessor,params){if(!params)return!1;const commandService=accessor.get(core.ICommandService),redoUndoService=accessor.get(core.IUndoRedoService),dataValidationModel=accessor.get(dataValidation.DataValidationModel),dataValidatorRegistryService=accessor.get(dataValidation.DataValidatorRegistryService),{unitId,subUnitId,ruleId,setting}=params,validator=dataValidatorRegistryService.getValidatorItem(setting.type);if(!validator)return!1;const rule=dataValidationModel.getRuleById(unitId,subUnitId,ruleId);if(!rule||!validator.validatorFormula({...rule,...setting},unitId,subUnitId).success)return!1;const mutationParams={unitId,subUnitId,ruleId,payload:{type:dataValidation.UpdateRuleType.SETTING,payload:setting}},redoMutations=[{id:dataValidation.UpdateDataValidationMutation.id,params:mutationParams}],undoMutationParams={unitId,subUnitId,ruleId,payload:{type:dataValidation.UpdateRuleType.SETTING,payload:dataValidation.getRuleSetting(rule)}},undoMutations=[{id:dataValidation.UpdateDataValidationMutation.id,params:undoMutationParams}];if(setting.type===core.DataValidationType.CHECKBOX){const ranges=rule.ranges,univerInstanceService=accessor.get(core.IUniverInstanceService),target=sheets.getSheetCommandTarget(univerInstanceService,{unitId,subUnitId});if(target){const redoMatrix=new core.ObjectMatrix,{worksheet}=target,{formula2:oldFormula2=CHECKBOX_FORMULA_2,formula1:oldFormula1=CHECKBOX_FORMULA_1}=rule,{formula2=CHECKBOX_FORMULA_2,formula1=CHECKBOX_FORMULA_1}=setting;ranges.forEach(range=>{core.Range.foreach(range,(row,column)=>{const cellData=worksheet.getCellRaw(row,column),value=getStringCellValue(cellData);isBlankCell(cellData)||value===String(oldFormula2)?redoMatrix.setValue(row,column,{v:formula2,p:null}):value===String(oldFormula1)&&redoMatrix.setValue(row,column,{v:formula1,p:null})})});const redoSetRangeValues={id:sheets.SetRangeValuesMutation.id,params:{unitId,subUnitId,cellValue:redoMatrix.getData()}},undoSetRangeValues={id:sheets.SetRangeValuesMutation.id,params:sheets.SetRangeValuesUndoMutationFactory(accessor,redoSetRangeValues.params)};redoMutations.push(redoSetRangeValues),undoMutations.push(undoSetRangeValues)}}return core.sequenceExecute(redoMutations,commandService).result?(redoUndoService.pushUndoRedo({unitID:unitId,redoMutations,undoMutations}),!0):!1}},UpdateSheetDataValidationOptionsCommand={type:core.CommandType.COMMAND,id:"sheets.command.update-data-validation-options",handler(accessor,params){if(!params)return!1;const commandService=accessor.get(core.ICommandService),redoUndoService=accessor.get(core.IUndoRedoService),dataValidationModel=accessor.get(dataValidation.DataValidationModel),{unitId,subUnitId,ruleId,options}=params,rule=dataValidationModel.getRuleById(unitId,subUnitId,ruleId);if(!rule)return!1;const mutationParams={unitId,subUnitId,ruleId,payload:{type:dataValidation.UpdateRuleType.OPTIONS,payload:options}},redoMutations=[{id:dataValidation.UpdateDataValidationMutation.id,params:mutationParams}],undoMutationParams={unitId,subUnitId,ruleId,payload:{type:dataValidation.UpdateRuleType.OPTIONS,payload:dataValidation.getRuleOptions(rule)}},undoMutations=[{id:dataValidation.UpdateDataValidationMutation.id,params:undoMutationParams}];return redoUndoService.pushUndoRedo({unitID:unitId,redoMutations,undoMutations}),commandService.executeCommand(dataValidation.UpdateDataValidationMutation.id,mutationParams),!0}},DataValidationIcon="data-validation-single",DATA_VALIDATION_MENU_ID="sheet.menu.data-validation";function dataValidationMenuFactory(accessor){return{id:DATA_VALIDATION_MENU_ID,type:ui.MenuItemType.SUBITEMS,positions:[ui.MenuPosition.TOOLBAR_START],group:ui.MenuGroup.TOOLBAR_FORMULAS_INSERT,icon:DataValidationIcon,tooltip:"dataValidation.title",hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET),disabled$:sheetsUi.getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetSetCellStylePermission,sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(dataValidationMenuFactory,"dataValidationMenuFactory");function openDataValidationMenuFactory(_accessor){return{id:OpenValidationPanelOperation.id,title:"dataValidation.panel.title",type:ui.MenuItemType.BUTTON,positions:[DATA_VALIDATION_MENU_ID]}}__name(openDataValidationMenuFactory,"openDataValidationMenuFactory");function addDataValidationMenuFactory(_accessor){return{id:AddSheetDataValidationAndOpenCommand.id,title:"dataValidation.panel.add",type:ui.MenuItemType.BUTTON,positions:[DATA_VALIDATION_MENU_ID]}}__name(addDataValidationMenuFactory,"addDataValidationMenuFactory");var __defProp$d=Object.defineProperty,__getOwnPropDesc$d=Object.getOwnPropertyDescriptor,__decorateClass$d=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$d(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$d(target,key,result),result},"__decorateClass$d"),__decorateParam$d=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$d");const DefaultSheetsDataValidation={},INVALID_MARK={tr:{size:6,color:"#fe4b4b"}};exports2.SheetsDataValidationRenderController=(_h=class extends core.RxDisposable{constructor(_config,_commandService,_menuService,_renderManagerService,_univerInstanceService,_autoHeightController,_componentManager,_dropdownManagerService,_dataValidationModel,_dataValidatorRegistryService,_injector,_sheetInterceptorService,_editorBridgeService){super(),this._config=_config,this._commandService=_commandService,this._menuService=_menuService,this._renderManagerService=_renderManagerService,this._univerInstanceService=_univerInstanceService,this._autoHeightController=_autoHeightController,this._componentManager=_componentManager,this._dropdownManagerService=_dropdownManagerService,this._dataValidationModel=_dataValidationModel,this._dataValidatorRegistryService=_dataValidatorRegistryService,this._injector=_injector,this._sheetInterceptorService=_sheetInterceptorService,this._editorBridgeService=_editorBridgeService,this._initMenu(),this._initSkeletonChange(),this._initDropdown(),this._initViewModelIntercept(),this._initAutoHeight()}_initMenu(){const{menu={}}=this._config;[dataValidationMenuFactory,openDataValidationMenuFactory,addDataValidationMenuFactory].forEach(factory=>{this.disposeWithMe(this._menuService.addMenuItem(factory(this._injector),menu))})}_initDropdown(){this._editorBridgeService&&this.disposeWithMe(this._editorBridgeService.visible$.subscribe(visible=>{if(!visible.visible){this._dropdownManagerService.hideDropdown();return}const state=this._editorBridgeService.getEditCellState();if(state){const{unitId,sheetId,row,column}=state,workbook=this._univerInstanceService.getUniverSheetInstance(unitId);if(!workbook)return;const rule=this._dataValidationModel.ensureManager(unitId,sheetId).getRuleByLocation(row,column);if(!rule)return;const validator=this._dataValidatorRegistryService.getValidatorItem(rule.type);if(!(validator!=null&&validator.dropdown))return;const worksheet=workbook.getActiveSheet();if(!worksheet)return;const activeDropdown=this._dropdownManagerService.activeDropdown,currLoc=activeDropdown==null?void 0:activeDropdown.location;if(currLoc&&currLoc.unitId===unitId&&currLoc.subUnitId===sheetId&&currLoc.row===row&&currLoc.col===column)return;this._dropdownManagerService.showDropdown({location:{unitId,subUnitId:sheetId,row,col:column,workbook,worksheet},componentKey:validator.dropdown,onHide:__name(()=>{},"onHide")},!1)}}))}_initSkeletonChange(){const markSkeletonDirty=__name(()=>{var _a2,_b2,_c2;const workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return;const unitId=workbook.getUnitId(),subUnitId=(_a2=workbook.getActiveSheet())==null?void 0:_a2.getSheetId();if(!subUnitId)return;const skeleton=(_c2=(_b2=this._renderManagerService.getRenderById(unitId))==null?void 0:_b2.with(sheetsUi.SheetSkeletonManagerService).getWorksheetSkeleton(subUnitId))==null?void 0:_c2.skeleton,currentRender=this._renderManagerService.getRenderById(unitId);skeleton==null||skeleton.makeDirty(!0),skeleton==null||skeleton.calculate(),currentRender&&currentRender.mainComponent.makeForceDirty()},"markSkeletonDirty");this.disposeWithMe(this._dataValidationModel.ruleChange$.pipe(rxjs.debounceTime(16)).subscribe(()=>markSkeletonDirty())),this.disposeWithMe(this._dataValidationModel.validStatusChange$.pipe(rxjs.debounceTime(16)).subscribe(()=>markSkeletonDirty()))}_initViewModelIntercept(){this.disposeWithMe(this._sheetInterceptorService.intercept(sheets.INTERCEPTOR_POINT.CELL_CONTENT,{priority:200,handler:__name((cell,pos,next)=>{var _a2,_b2,_c2,_d2,_e2,_f2;const{row,col,unitId,subUnitId,workbook,worksheet}=pos,manager=this._dataValidationModel.ensureManager(unitId,subUnitId);if(!manager)return next(cell);const skeleton=(_b2=(_a2=this._renderManagerService.getRenderById(unitId))==null?void 0:_a2.with(sheetsUi.SheetSkeletonManagerService).getWorksheetSkeleton(subUnitId))==null?void 0:_b2.skeleton;if(!skeleton)return next(cell);const styleMap=pos.workbook.getStyles(),defaultStyle=(typeof(cell==null?void 0:cell.s)=="string"?styleMap.get(cell==null?void 0:cell.s):cell==null?void 0:cell.s)||{},ruleId=manager.getRuleIdByLocation(row,col);if(!ruleId)return next(cell);const rule=manager.getRuleById(ruleId);if(!rule)return next(cell);const cellRaw=worksheet.getCellRaw(pos.row,pos.col),validStatus=this._dataValidationModel.validator(getCellValueOrigin(cellRaw),rule,pos),validator=this._dataValidatorRegistryService.getValidatorItem(rule.type),cellValue=getCellValueOrigin(cell);let extra={};if((rule.type===core.DataValidationType.LIST||rule.type===core.DataValidationType.LIST_MULTIPLE)&&(extra={interceptorStyle:{...cell==null?void 0:cell.interceptorStyle,tb:(_c2=defaultStyle.tb!==core.WrapStrategy.OVERFLOW?defaultStyle.tb:core.WrapStrategy.CLIP)!=null?_c2:core.WrapStrategy.WRAP}}),rule.type===core.DataValidationType.CHECKBOX&&(extra={interceptorStyle:{...cell==null?void 0:cell.interceptorStyle,tb:core.WrapStrategy.CLIP}}),rule.type===core.DataValidationType.LIST&&(rule.renderMode===core.DataValidationRenderMode.ARROW||rule.renderMode===core.DataValidationRenderMode.TEXT)){const colorMap=validator.getListWithColorMap(rule),valueStr=`${(_d2=getCellValueOrigin(cell))!=null?_d2:""}`,color=colorMap[valueStr];color&&(extra={...extra,interceptorStyle:{...extra.interceptorStyle,bg:{rgb:color}}})}return next({...cell,...extra,dataValidation:{ruleId,validStatus,rule,validator},markers:{...cell==null?void 0:cell.markers,...validStatus===core.DataValidationStatus.INVALID?INVALID_MARK:null},customRender:[...(_e2=cell==null?void 0:cell.customRender)!=null?_e2:[],...validator!=null&&validator.canvasRender?[validator.canvasRender]:[]],fontRenderExtension:{...cell==null?void 0:cell.fontRenderExtension,isSkip:validator==null?void 0:validator.skipDefaultFontRender(rule,cellValue,pos)},interceptorStyle:{...cell==null?void 0:cell.interceptorStyle,...extra.interceptorStyle},get interceptorAutoHeight(){var _a3,_b3,_c3,_d3;const mergeCell=skeleton.mergeData.find(range=>{const{startColumn,startRow,endColumn,endRow}=range;return row>=startRow&&col>=startColumn&&row<=endRow&&col<=endColumn}),info={data:{...cell,dataValidation:{ruleId,validStatus,rule,validator}},style:skeleton.getsStyles().getStyleByCell(cell),primaryWithCoord:skeleton.getCellByIndex((_a3=mergeCell==null?void 0:mergeCell.startRow)!=null?_a3:row,(_b3=mergeCell==null?void 0:mergeCell.startColumn)!=null?_b3:col),unitId,subUnitId,row,col,workbook,worksheet};return(_d3=(_c3=validator==null?void 0:validator.canvasRender)==null?void 0:_c3.calcCellAutoHeight)==null?void 0:_d3.call(_c3,info)},coverable:((_f2=cell==null?void 0:cell.coverable)!=null?_f2:!0)&&!(rule.type===core.DataValidationType.LIST||rule.type===core.DataValidationType.LIST_MULTIPLE)})},"handler")}))}_initAutoHeight(){this._dataValidationModel.ruleChange$.pipe(rxjs.filter(change=>change.source==="command"),rxjs.bufferTime(16)).subscribe(infos=>{const ranges=[];if(infos.forEach(info=>{var _a2;(_a2=info.rule)!=null&&_a2.ranges&&ranges.push(...info.rule.ranges)}),ranges.length){const mutations=this._autoHeightController.getUndoRedoParamsOfAutoHeight(ranges);core.sequenceExecute(mutations.redos,this._commandService)}})}},__name(_h,"SheetsDataValidationRenderController"),_h),exports2.SheetsDataValidationRenderController=__decorateClass$d([core.OnLifecycle(core.LifecycleStages.Rendered,exports2.SheetsDataValidationRenderController),__decorateParam$d(1,core.ICommandService),__decorateParam$d(2,ui.IMenuService),__decorateParam$d(3,engineRender.IRenderManagerService),__decorateParam$d(4,core.IUniverInstanceService),__decorateParam$d(5,core.Inject(sheetsUi.AutoHeightController)),__decorateParam$d(6,core.Inject(ui.ComponentManager)),__decorateParam$d(7,core.Inject(DataValidationDropdownManagerService)),__decorateParam$d(8,core.Inject(dataValidation.DataValidationModel)),__decorateParam$d(9,core.Inject(dataValidation.DataValidatorRegistryService)),__decorateParam$d(10,core.Inject(core.Injector)),__decorateParam$d(11,core.Inject(sheets.SheetInterceptorService)),__decorateParam$d(12,core.Optional(sheetsUi.IEditorBridgeService))],exports2.SheetsDataValidationRenderController);let SheetsDataValidationMobileRenderController=(_i=class extends core.RxDisposable{constructor(_config,_commandService,_renderManagerService,_univerInstanceService,_autoHeightController,_dataValidationModel,_dataValidatorRegistryService,_sheetInterceptorService){super(),this._config=_config,this._commandService=_commandService,this._renderManagerService=_renderManagerService,this._univerInstanceService=_univerInstanceService,this._autoHeightController=_autoHeightController,this._dataValidationModel=_dataValidationModel,this._dataValidatorRegistryService=_dataValidatorRegistryService,this._sheetInterceptorService=_sheetInterceptorService,this._initSkeletonChange(),this._initViewModelIntercept(),this._initAutoHeight()}_initSkeletonChange(){const markSkeletonDirty=__name(()=>{var _a2,_b2,_c2;const workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return;const unitId=workbook.getUnitId(),subUnitId=(_a2=workbook.getActiveSheet())==null?void 0:_a2.getSheetId();if(!subUnitId)return;const skeleton=(_c2=(_b2=this._renderManagerService.getRenderById(unitId))==null?void 0:_b2.with(sheetsUi.SheetSkeletonManagerService).getWorksheetSkeleton(subUnitId))==null?void 0:_c2.skeleton,currentRender=this._renderManagerService.getRenderById(unitId);skeleton==null||skeleton.makeDirty(!0),skeleton==null||skeleton.calculate(),currentRender&&currentRender.mainComponent.makeForceDirty()},"markSkeletonDirty");this.disposeWithMe(this._dataValidationModel.ruleChange$.pipe(rxjs.debounceTime(16)).subscribe(()=>markSkeletonDirty())),this.disposeWithMe(this._dataValidationModel.validStatusChange$.pipe(rxjs.debounceTime(16)).subscribe(()=>markSkeletonDirty()))}_initViewModelIntercept(){this.disposeWithMe(this._sheetInterceptorService.intercept(sheets.INTERCEPTOR_POINT.CELL_CONTENT,{priority:200,handler:__name((cell,pos,next)=>{var _a2,_b2,_c2,_d2,_e2;const{row,col,unitId,subUnitId,workbook,worksheet}=pos,manager=this._dataValidationModel.ensureManager(unitId,subUnitId);if(!manager)return next(cell);const skeleton=(_b2=(_a2=this._renderManagerService.getRenderById(unitId))==null?void 0:_a2.with(sheetsUi.SheetSkeletonManagerService).getWorksheetSkeleton(subUnitId))==null?void 0:_b2.skeleton;if(!skeleton)return next(cell);const styleMap=pos.workbook.getStyles(),defaultStyle=(typeof(cell==null?void 0:cell.s)=="string"?styleMap.get(cell==null?void 0:cell.s):cell==null?void 0:cell.s)||{},ruleId=manager.getRuleIdByLocation(row,col);if(!ruleId)return next(cell);const rule=manager.getRuleById(ruleId);if(!rule)return next(cell);const cellRaw=pos.worksheet.getCellRaw(pos.row,pos.col),validStatus=this._dataValidationModel.validator(getCellValueOrigin(cellRaw),rule,pos),validator=this._dataValidatorRegistryService.getValidatorItem(rule.type),cellValue=getCellValueOrigin(cell);let extra={};if((rule.type===core.DataValidationType.LIST||rule.type===core.DataValidationType.LIST_MULTIPLE)&&(extra={interceptorStyle:{...cell==null?void 0:cell.interceptorStyle,tb:(_c2=defaultStyle.tb!==core.WrapStrategy.OVERFLOW?defaultStyle.tb:core.WrapStrategy.CLIP)!=null?_c2:core.WrapStrategy.WRAP}}),rule.type===core.DataValidationType.CHECKBOX&&(extra={interceptorStyle:{...cell==null?void 0:cell.interceptorStyle,tb:core.WrapStrategy.CLIP}}),rule.type===core.DataValidationType.LIST&&(rule.renderMode===core.DataValidationRenderMode.ARROW||rule.renderMode===core.DataValidationRenderMode.TEXT)){const colorMap=validator.getListWithColorMap(rule),valueStr=`${(_d2=getCellValueOrigin(cell))!=null?_d2:""}`,color=colorMap[valueStr];color&&(extra={...extra,interceptorStyle:{...extra.interceptorStyle,bg:{rgb:color}}})}return next({...cell,...extra,dataValidation:{ruleId,validStatus,rule,validator},markers:{...cell==null?void 0:cell.markers,...validStatus===core.DataValidationStatus.INVALID?INVALID_MARK:null},customRender:[...(_e2=cell==null?void 0:cell.customRender)!=null?_e2:[],...validator!=null&&validator.canvasRender?[validator.canvasRender]:[]],fontRenderExtension:{...cell==null?void 0:cell.fontRenderExtension,isSkip:validator==null?void 0:validator.skipDefaultFontRender(rule,cellValue,pos)},interceptorStyle:{...cell==null?void 0:cell.interceptorStyle,...extra.interceptorStyle},get interceptorAutoHeight(){var _a3,_b3,_c3,_d3;const mergeCell=skeleton.mergeData.find(range=>{const{startColumn,startRow,endColumn,endRow}=range;return row>=startRow&&col>=startColumn&&row<=endRow&&col<=endColumn}),info={data:{...cell,dataValidation:{ruleId,validStatus,rule,validator}},style:skeleton.getsStyles().getStyleByCell(cell),primaryWithCoord:skeleton.getCellByIndex((_a3=mergeCell==null?void 0:mergeCell.startRow)!=null?_a3:row,(_b3=mergeCell==null?void 0:mergeCell.startColumn)!=null?_b3:col),unitId,subUnitId,row,col,worksheet,workbook};return(_d3=(_c3=validator==null?void 0:validator.canvasRender)==null?void 0:_c3.calcCellAutoHeight)==null?void 0:_d3.call(_c3,info)}})},"handler")}))}_initAutoHeight(){this._dataValidationModel.ruleChange$.pipe(rxjs.filter(change=>change.source==="command"),rxjs.bufferTime(16)).subscribe(infos=>{const ranges=[];if(infos.forEach(info=>{var _a2;(_a2=info.rule)!=null&&_a2.ranges&&ranges.push(...info.rule.ranges)}),ranges.length){const mutations=this._autoHeightController.getUndoRedoParamsOfAutoHeight(ranges);core.sequenceExecute(mutations.redos,this._commandService)}})}},__name(_i,"SheetsDataValidationMobileRenderController"),_i);SheetsDataValidationMobileRenderController=__decorateClass$d([core.OnLifecycle(core.LifecycleStages.Rendered,SheetsDataValidationMobileRenderController),__decorateParam$d(1,core.ICommandService),__decorateParam$d(2,engineRender.IRenderManagerService),__decorateParam$d(3,core.IUniverInstanceService),__decorateParam$d(4,core.Inject(sheetsUi.AutoHeightController)),__decorateParam$d(5,core.Inject(dataValidation.DataValidationModel)),__decorateParam$d(6,core.Inject(dataValidation.DataValidatorRegistryService)),__decorateParam$d(7,core.Inject(sheets.SheetInterceptorService))],SheetsDataValidationMobileRenderController);var __defProp$c=Object.defineProperty,__getOwnPropDesc$c=Object.getOwnPropertyDescriptor,__decorateClass$c=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$c(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$c(target,key,result),result},"__decorateClass$c"),__decorateParam$c=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$c");exports2.SheetDataValidationService=(_j=class extends core.Disposable{constructor(_dataValidationModel){super();__publicField(this,"_currentManager");__publicField(this,"_currentManager$",new rxjs.Subject);__publicField(this,"currentManager$",this._currentManager$.asObservable());this._dataValidationModel=_dataValidationModel,this.disposeWithMe(()=>{this._currentManager$.complete()})}get currentManager(){return this._currentManager}_ensureManager(unitId,subUnitId){return this._dataValidationModel.ensureManager(unitId,subUnitId)}switchCurrent(unitId,subUnitId){var _a2,_b2;if(unitId===((_a2=this.currentManager)==null?void 0:_a2.unitId)&&subUnitId===((_b2=this._currentManager)==null?void 0:_b2.subUnitId))return;const manager=this._ensureManager(unitId,subUnitId);this._currentManager={manager,unitId,subUnitId},this._currentManager$.next(this._currentManager)}get(unitId,subUnitId){return this._ensureManager(unitId,subUnitId)}},__name(_j,"SheetDataValidationService"),_j),exports2.SheetDataValidationService=__decorateClass$c([__decorateParam$c(0,core.Inject(dataValidation.DataValidationModel))],exports2.SheetDataValidationService);var __defProp$b=Object.defineProperty,__getOwnPropDesc$b=Object.getOwnPropertyDescriptor,__decorateClass$b=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$b(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$b(target,key,result),result},"__decorateClass$b"),__decorateParam$b=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$b");exports2.DataValidationCustomFormulaService=(_k=class extends core.Disposable{constructor(_registerOtherFormulaService,_lexerTreeBuilder,_dataValidationModel,_dataValidationCacheService){super();__publicField(this,"_formulaMap",new Map);__publicField(this,"_ruleFormulaMap",new Map);__publicField(this,"_formulaCellMap",new Map);this._registerOtherFormulaService=_registerOtherFormulaService,this._lexerTreeBuilder=_lexerTreeBuilder,this._dataValidationModel=_dataValidationModel,this._dataValidationCacheService=_dataValidationCacheService,this._initFormulaResultHandler()}_initFormulaResultHandler(){this.disposeWithMe(this._registerOtherFormulaService.formulaResult$.subscribe(resultMap=>{for(const unitId in resultMap){const unitMap=resultMap[unitId];for(const subUnitId in unitMap){const results=unitMap[subUnitId],{formulaCellMap,ruleFormulaMap}=this._ensureMaps(unitId,subUnitId),manager=this._dataValidationModel.ensureManager(unitId,subUnitId);results.forEach(result=>{var _a2,_b2;const ruleInfo=ruleFormulaMap.get((_a2=result.extra)==null?void 0:_a2.ruleId),cellInfo=formulaCellMap.get(result.formulaId),rule=manager.getRuleById((_b2=result.extra)==null?void 0:_b2.ruleId);rule&&ruleInfo&&!ruleInfo.isTransformable&&this._dataValidationCacheService.markRangeDirty(unitId,subUnitId,rule.ranges),cellInfo&&this._dataValidationCacheService.markCellDirty(unitId,subUnitId,cellInfo.row,cellInfo.column)})}}}))}_ensureMaps(unitId,subUnitId){let formulaUnitMap=this._formulaMap.get(unitId),ruleFormulaUnitMap=this._ruleFormulaMap.get(unitId),formulaCellUnitMap=this._formulaCellMap.get(unitId);(!formulaUnitMap||!ruleFormulaUnitMap||!formulaCellUnitMap)&&(formulaUnitMap=new Map,ruleFormulaUnitMap=new Map,formulaCellUnitMap=new Map,this._formulaMap.set(unitId,formulaUnitMap),this._ruleFormulaMap.set(unitId,ruleFormulaUnitMap),this._formulaCellMap.set(unitId,formulaCellUnitMap));let formulaMap=formulaUnitMap.get(subUnitId),ruleFormulaMap=ruleFormulaUnitMap.get(subUnitId),formulaCellMap=formulaCellUnitMap.get(subUnitId);return(!formulaMap||!ruleFormulaMap||!formulaCellMap)&&(formulaMap=new core.ObjectMatrix,formulaUnitMap.set(subUnitId,formulaMap),ruleFormulaMap=new Map,ruleFormulaUnitMap.set(subUnitId,ruleFormulaMap),formulaCellMap=new Map,formulaCellUnitMap.set(subUnitId,formulaCellMap)),{formulaMap,ruleFormulaMap,formulaCellMap}}_registerFormula(unitId,subUnitId,ruleId,formulaString){return this._registerOtherFormulaService.registerFormula(unitId,subUnitId,formulaString,{ruleId})}deleteByRuleId(unitId,subUnitId,ruleId){const{formulaMap,formulaCellMap,ruleFormulaMap}=this._ensureMaps(unitId,subUnitId),rule=this._dataValidationModel.getRuleById(unitId,subUnitId,ruleId),formulaIdList=new Set,formulaInfo=ruleFormulaMap.get(ruleId);!rule||!formulaInfo||(ruleFormulaMap.delete(ruleId),rule.ranges.forEach(range=>{core.Range.foreach(range,(row,col)=>{const value=formulaMap.getValue(row,col);if(value&&value.ruleId===ruleId){const{formulaId}=value;formulaMap.realDeleteValue(row,col),formulaIdList.add(formulaId),formulaCellMap.delete(formulaId)}})}),this._registerOtherFormulaService.deleteFormula(unitId,subUnitId,Array.from(formulaIdList.values())))}_addFormulaByRange(unitId,subUnitId,ruleId,formula,ranges){const{formulaMap,ruleFormulaMap,formulaCellMap}=this._ensureMaps(unitId,subUnitId);if(!formula)return;const isTransformable=engineFormula.isFormulaTransformable(this._lexerTreeBuilder,formula),originRow=ranges[0].startRow,originCol=ranges[0].startColumn;let originFormulaId;isTransformable?ranges.forEach(range=>{core.Range.foreach(range,(row,column)=>{const relativeFormula=engineFormula.transformFormula(this._lexerTreeBuilder,formula,originRow,originCol,row,column),formulaId=this._registerFormula(unitId,subUnitId,ruleId,relativeFormula);formulaMap.setValue(row,column,{formulaId,ruleId}),formulaCellMap.set(formulaId,{row,column})})}):(originFormulaId=this._registerFormula(unitId,subUnitId,ruleId,formula),ranges.forEach(range=>{core.Range.foreach(range,(row,col)=>{formulaMap.setValue(row,col,{formulaId:originFormulaId,ruleId})})})),ruleFormulaMap.set(ruleId,{formula,originCol,originRow,isTransformable,formulaId:originFormulaId})}addRule(unitId,subUnitId,rule){const{ranges,formula1,uid:ruleId,type}=rule;type!==core.DataValidationType.CUSTOM||!formula1||!core.isFormulaString(formula1)||this._addFormulaByRange(unitId,subUnitId,ruleId,formula1,ranges)}updateRuleRanges(unitId,subUnitId,ruleId,oldRanges,newRanges){const{formulaMap,ruleFormulaMap,formulaCellMap}=this._ensureMaps(unitId,subUnitId),info=ruleFormulaMap.get(ruleId);if(!info)return;const{formula,originCol,originRow,isTransformable,formulaId}=info,deleteFormulaIdList=new Set;oldRanges.forEach(range=>{core.Range.foreach(range,(row,col)=>{const value=formulaMap.getValue(row,col);value&&value.ruleId===ruleId&&(value.temp=!0)})}),newRanges.forEach(range=>{core.Range.foreach(range,(row,col)=>{var _a2;const oldValue=(_a2=formulaMap.getValue(row,col))!=null?_a2:{};if(oldValue.ruleId!==ruleId){const oldRuleFormula=ruleFormulaMap.get(oldValue.ruleId);if(oldRuleFormula!=null&&oldRuleFormula.isTransformable&&deleteFormulaIdList.add(oldValue.formulaId),isTransformable){const relativeText=engineFormula.transformFormula(this._lexerTreeBuilder,formula,originRow,originCol,row,col),formulaId2=this._registerFormula(unitId,subUnitId,ruleId,relativeText);formulaMap.setValue(row,col,{ruleId,formulaId:formulaId2}),formulaCellMap.set(formulaId2,{row,column:col})}else formulaMap.setValue(row,col,{ruleId,formulaId})}else oldValue.temp=!1})}),oldRanges.forEach(range=>{core.Range.foreach(range,(row,col)=>{const value=formulaMap.getValue(row,col);value&&value.ruleId===ruleId&&value.temp===!0&&(formulaMap.realDeleteValue(row,col),isTransformable&&deleteFormulaIdList.add(value.formulaId))})}),deleteFormulaIdList.forEach(formulaId2=>{formulaCellMap.delete(formulaId2)}),this._registerOtherFormulaService.deleteFormula(unitId,subUnitId,Array.from(deleteFormulaIdList.values()))}updateRuleFormula(unitId,subUnitId,ruleId,ranges,formula){const{ruleFormulaMap}=this._ensureMaps(unitId,subUnitId),current=ruleFormulaMap.get(ruleId);(!current||current.formula!==formula)&&this._addFormulaByRange(unitId,subUnitId,ruleId,formula,ranges)}getCellFormulaValue(unitId,subUnitId,row,col){const{formulaMap}=this._ensureMaps(unitId,subUnitId),current=formulaMap.getValue(row,col);return current?this._registerOtherFormulaService.getFormulaValue(unitId,subUnitId,current.formulaId):Promise.resolve(void 0)}getRuleFormulaInfo(unitId,subUnitId,ruleId){const{ruleFormulaMap}=this._ensureMaps(unitId,subUnitId);return ruleFormulaMap.get(ruleId)}},__name(_k,"DataValidationCustomFormulaService"),_k),exports2.DataValidationCustomFormulaService=__decorateClass$b([__decorateParam$b(0,core.Inject(sheetsFormula.RegisterOtherFormulaService)),__decorateParam$b(1,core.Inject(engineFormula.LexerTreeBuilder)),__decorateParam$b(2,core.Inject(dataValidation.DataValidationModel)),__decorateParam$b(3,core.Inject(DataValidationCacheService))],exports2.DataValidationCustomFormulaService);const _CustomFormulaValidator=class _CustomFormulaValidator extends dataValidation.BaseDataValidator{constructor(){super(...arguments);__publicField(this,"id",core.DataValidationType.CUSTOM);__publicField(this,"title","dataValidation.custom.title");__publicField(this,"operators",[]);__publicField(this,"scopes",["sheet"]);__publicField(this,"formulaInput",CUSTOM_FORMULA_INPUT_NAME);__publicField(this,"_customFormulaService",this.injector.get(exports2.DataValidationCustomFormulaService))}validatorFormula(rule,unitId,subUnitId){const success=core.isFormulaString(rule.formula1);return{success,formula1:success?"":this.localeService.t("dataValidation.validFail.formula")}}async parseFormula(_rule,_unitId,_subUnitId){return{formula1:void 0,formula2:void 0}}async isValidType(cellInfo,_formula,_rule){const{column,row,unitId,subUnitId}=cellInfo,result=await this._customFormulaService.getCellFormulaValue(unitId,subUnitId,row,column);return!!getFormulaResult(result==null?void 0:result.result)}generateRuleErrorMessage(rule){return this.localeService.t("dataValidation.custom.error")}};__name(_CustomFormulaValidator,"CustomFormulaValidator");let CustomFormulaValidator=_CustomFormulaValidator;const _WholeValidator=class _WholeValidator extends dataValidation.BaseDataValidator{constructor(){super(...arguments);__publicField(this,"_formulaService",this.injector.get(exports2.DataValidationFormulaService));__publicField(this,"id",core.DataValidationType.WHOLE);__publicField(this,"title","dataValidation.whole.title");__publicField(this,"operators",[core.DataValidationOperator.BETWEEN,core.DataValidationOperator.EQUAL,core.DataValidationOperator.GREATER_THAN,core.DataValidationOperator.GREATER_THAN_OR_EQUAL,core.DataValidationOperator.LESS_THAN,core.DataValidationOperator.LESS_THAN_OR_EQUAL,core.DataValidationOperator.NOT_BETWEEN,core.DataValidationOperator.NOT_EQUAL]);__publicField(this,"scopes",["sheet"]);__publicField(this,"formulaInput",BASE_FORMULA_INPUT_NAME);__publicField(this,"dropDownInput")}_isFormulaOrInt(formula){return!core.Tools.isBlank(formula)&&(core.isFormulaString(formula)||!Number.isNaN(+formula)&&Number.isInteger(+formula))}async isValidType(cellInfo,formula,rule){const{value:cellValue}=cellInfo,num=getCellValueNumber(cellValue);return!Number.isNaN(num)&&Number.isInteger(num)}transform(cellInfo,formula,rule){const{value:cellValue}=cellInfo;return{...cellInfo,value:getCellValueNumber(cellValue)}}_parseNumber(formula){return formula==null?Number.NaN:+formula}async parseFormula(rule,unitId,subUnitId){var _a2,_b2,_c2,_d2,_e2,_f2,_g2,_h2;const formulaInfo=await this._formulaService.getRuleFormulaResult(unitId,subUnitId,rule.uid),{formula1,formula2}=rule;return{formula1:this._parseNumber(core.isFormulaString(formula1)?(_d2=(_c2=(_b2=(_a2=formulaInfo==null?void 0:formulaInfo[0])==null?void 0:_a2.result)==null?void 0:_b2[0])==null?void 0:_c2[0])==null?void 0:_d2.v:formula1),formula2:this._parseNumber(core.isFormulaString(formula2)?(_h2=(_g2=(_f2=(_e2=formulaInfo==null?void 0:formulaInfo[1])==null?void 0:_e2.result)==null?void 0:_f2[0])==null?void 0:_g2[0])==null?void 0:_h2.v:formula2)}}validatorFormula(rule,unitId,subUnitId){const operator=rule.operator;if(!operator)return{success:!1};const formula1Success=core.Tools.isDefine(rule.formula1)&&this._isFormulaOrInt(rule.formula1),formula2Success=core.Tools.isDefine(rule.formula2)&&this._isFormulaOrInt(rule.formula2),isTwoFormula=TWO_FORMULA_OPERATOR_COUNT.includes(operator),errorMsg=this.localeService.t("dataValidation.validFail.number");return isTwoFormula?{success:formula1Success&&formula2Success,formula1:formula1Success?void 0:errorMsg,formula2:formula2Success?void 0:errorMsg}:{success:formula1Success,formula1:errorMsg}}async validatorIsEqual(cellInfo,formula,rule){const{formula1}=formula,{value:cellValue}=cellInfo;return Number.isNaN(formula1)?!0:cellValue===formula1}async validatorIsNotEqual(cellInfo,formula,_rule){const{formula1}=formula;return Number.isNaN(formula1)?!0:cellInfo.value!==formula1}async validatorIsBetween(cellInfo,formula,_rule){const{formula1,formula2}=formula;if(Number.isNaN(formula1)||Number.isNaN(formula2))return!0;const start=Math.min(formula1,formula2),end=Math.max(formula1,formula2);return cellInfo.value>=start&&cellInfo.value<=end}async validatorIsNotBetween(cellInfo,formula,_rule){const{formula1,formula2}=formula;if(Number.isNaN(formula1)||Number.isNaN(formula2))return!0;const start=Math.min(formula1,formula2),end=Math.max(formula1,formula2);return cellInfo.value<start||cellInfo.value>end}async validatorIsGreaterThan(cellInfo,formula,_rule){const{formula1}=formula;return Number.isNaN(formula1)?!0:cellInfo.value>formula1}async validatorIsGreaterThanOrEqual(cellInfo,formula,_rule){const{formula1}=formula;return Number.isNaN(formula1)?!0:cellInfo.value>=formula1}async validatorIsLessThan(cellInfo,formula,_rule){const{formula1}=formula;return Number.isNaN(formula1)?!0:cellInfo.value<formula1}async validatorIsLessThanOrEqual(cellInfo,formula,_rule){const{formula1}=formula;return Number.isNaN(formula1)?!0:cellInfo.value<=formula1}};__name(_WholeValidator,"WholeValidator");let WholeValidator=_WholeValidator;const PADDING_H=4,PADDING_V=0,MARGIN_H=4,MARGIN_V=4,CELL_PADDING_H=6,CELL_PADDING_V=6,ICON_PLACE=14;function getDropdownItemSize(text,fontStyle){const bBox=engineRender.FontCache.getTextSize(text,fontStyle),rectWidth=bBox.width+PADDING_H*2,{ba,bd}=bBox,height=ba+bd;return{width:rectWidth,height:height+PADDING_V*2,ba}}__name(getDropdownItemSize,"getDropdownItemSize");function layoutDropdowns(items,fontStyle,cellWidth,cellHeight){const contentWidth=cellWidth-ICON_PLACE-CELL_PADDING_H,contentHeight=cellHeight-CELL_PADDING_V*2,textLayout=items.map(item=>({layout:getDropdownItemSize(item,fontStyle),text:item}));let currentLine;const lines=[];textLayout.forEach(item=>{const{layout}=item,{width,height}=layout;!currentLine||currentLine.width+width+MARGIN_H>contentWidth?(currentLine={width,height,items:[{...item,left:0}]},lines.push(currentLine)):(currentLine.items.push({...item,left:currentLine.width+MARGIN_H}),currentLine.width=currentLine.width+width+MARGIN_H)});let totalHeight=0;return lines.forEach((line,index)=>{index===lines.length-1?totalHeight+=line.height:totalHeight+=line.height+MARGIN_V}),{lines,totalHeight,contentWidth,contentHeight,cellAutoHeight:totalHeight+CELL_PADDING_V*2}}__name(layoutDropdowns,"layoutDropdowns");const RADIUS=8,_Dropdown=class _Dropdown extends engineRender.Shape{static drawWith(ctx,props){const{fontFamily,fontString,fontSize,info,fill,color}=props,{layout,text}=info;ctx.save(),engineRender.Rect.drawWith(ctx,{width:layout.width,height:layout.height,radius:RADIUS,fill:fill||DROP_DOWN_DEFAULT_COLOR}),ctx.translateWithPrecision(PADDING_H,layout.ba),ctx.font=fontString,ctx.fillStyle=color,ctx.fillText(text,0,0),ctx.restore()}};__name(_Dropdown,"Dropdown");let Dropdown=_Dropdown;var __defProp$a=Object.defineProperty,__getOwnPropDesc$a=Object.getOwnPropertyDescriptor,__decorateClass$a=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$a(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$a(target,key,result),result},"__decorateClass$a"),__decorateParam$a=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$a");const downPath=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 DropdownMultipleWidget=(_l=class{constructor(_commandService){__publicField(this,"zIndex");__publicField(this,"_dropdownInfoMap",new Map);this._commandService=_commandService}_ensureMap(subUnitId){let map=this._dropdownInfoMap.get(subUnitId);return map||(map=new Map,this._dropdownInfoMap.set(subUnitId,map)),map}_generateKey(row,col){return`${row}.${col}`}_drawDownIcon(ctx,cellBounding,cellWidth,cellHeight,vt){const left=cellWidth-ICON_PLACE+4;let top=4;switch(vt){case core.VerticalAlign.MIDDLE:top=(cellHeight-ICON_PLACE)/2+4;break;case core.VerticalAlign.BOTTOM:top=cellHeight-ICON_PLACE+4;break}ctx.save(),ctx.translateWithPrecision(cellBounding.startX+left,cellBounding.startY+top),ctx.fillStyle="#565656",ctx.fill(downPath),ctx.restore()}drawWith(ctx,info,skeleton,spreadsheets){var _a2,_b2;const{primaryWithCoord,row,col,style,data,subUnitId}=info,_cellBounding=primaryWithCoord.isMergedMainCell?primaryWithCoord.mergeInfo:primaryWithCoord,fontRenderExtension=data.fontRenderExtension,{leftOffset=0,rightOffset=0,topOffset=0,downOffset=0}=fontRenderExtension||{},validation=data.dataValidation,map=this._ensureMap(subUnitId),key=this._generateKey(row,col);if(!validation)return;const cellBounding={startX:_cellBounding.startX+leftOffset,endX:_cellBounding.endX-rightOffset,startY:_cellBounding.startY+topOffset,endY:_cellBounding.endY-downOffset},cellWidth=cellBounding.endX-cellBounding.startX,cellHeight=cellBounding.endY-cellBounding.startY,{cl}=style||{},color=(_a2=typeof cl=="object"?cl==null?void 0:cl.rgb:cl)!=null?_a2:"#000",fontStyle=engineRender.getFontStyleString(style!=null?style:void 0),{rule,validator:_validator}=validation,validator=_validator,{vt:_vt,ht}=style||{},vt=_vt!=null?_vt:core.VerticalAlign.MIDDLE,cellValue=(_b2=getCellValueOrigin(data))!=null?_b2:"",items=validator.parseCellValue(cellValue),labelColorMap=validator.getListWithColorMap(rule),layout=layoutDropdowns(items,fontStyle,cellWidth,cellHeight);this._drawDownIcon(ctx,cellBounding,cellWidth,cellHeight,vt),ctx.save(),ctx.translateWithPrecision(cellBounding.startX,cellBounding.startY),ctx.beginPath(),ctx.rect(0,0,cellWidth-ICON_PLACE,cellHeight),ctx.clip(),ctx.translateWithPrecision(CELL_PADDING_H,CELL_PADDING_V);let top=0;switch(vt){case core.VerticalAlign.MIDDLE:top=(layout.contentHeight-layout.totalHeight)/2;break;case core.VerticalAlign.BOTTOM:top=layout.contentHeight-layout.totalHeight;break}ctx.translateWithPrecision(0,top),layout.lines.forEach((line,index)=>{ctx.save();const{width,height,items:items2}=line;let left=0;switch(ht){case core.HorizontalAlign.RIGHT:left=layout.contentWidth-width;break;case core.HorizontalAlign.CENTER:left=(layout.contentWidth-width)/2;break}ctx.translate(left,index*(height+MARGIN_V)),items2.forEach(item=>{ctx.save(),ctx.translateWithPrecision(item.left,0),Dropdown.drawWith(ctx,{...fontStyle,info:item,color,fill:labelColorMap[item.text]}),ctx.restore()}),ctx.restore()}),ctx.restore(),map.set(key,{left:cellBounding.startX,top:cellBounding.startY,width:layout.contentWidth+CELL_PADDING_H+ICON_PLACE,height:layout.contentHeight+CELL_PADDING_V*2})}calcCellAutoHeight(info){var _a2;const{primaryWithCoord,style,data}=info,fontRenderExtension=data.fontRenderExtension,{leftOffset=0,rightOffset=0,topOffset=0,downOffset=0}=fontRenderExtension||{},_cellBounding=primaryWithCoord.isMergedMainCell?primaryWithCoord.mergeInfo:primaryWithCoord,cellBounding={startX:_cellBounding.startX+leftOffset,endX:_cellBounding.endX-rightOffset,startY:_cellBounding.startY+topOffset,endY:_cellBounding.endY-downOffset},validation=data.dataValidation;if(!validation)return;const cellWidth=cellBounding.endX-cellBounding.startX,cellHeight=cellBounding.endY-cellBounding.startY,cellValue=(_a2=getCellValueOrigin(data))!=null?_a2:"",{validator:_validator}=validation,items=_validator.parseCellValue(cellValue),fontStyle=engineRender.getFontStyleString(style!=null?style:void 0);return layoutDropdowns(items,fontStyle,cellWidth,cellHeight).cellAutoHeight}isHit(position,info){const{primaryWithCoord}=info,cellBounding=primaryWithCoord.isMergedMainCell?primaryWithCoord.mergeInfo:primaryWithCoord,{endX}=cellBounding,{x}=position;return x>=endX-ICON_PLACE&&x<=endX}onPointerDown(info,evt){if(evt.button===2)return;const{unitId,subUnitId,row,col}=info,params={unitId,subUnitId,row,column:col};this._commandService.executeCommand(ShowDataValidationDropdown.id,params)}},__name(_l,"DropdownMultipleWidget"),_l);DropdownMultipleWidget=__decorateClass$a([__decorateParam$a(0,core.ICommandService)],DropdownMultipleWidget);const _ListMultipleValidator=class _ListMultipleValidator extends ListValidator{constructor(){super(...arguments);__publicField(this,"id",core.DataValidationType.LIST_MULTIPLE);__publicField(this,"title","dataValidation.listMultiple.title");__publicField(this,"canvasRender",this.injector.createInstance(DropdownMultipleWidget))}skipDefaultFontRender(){return!0}};__name(_ListMultipleValidator,"ListMultipleValidator");let ListMultipleValidator=_ListMultipleValidator;var __defProp$9=Object.defineProperty,__getOwnPropDesc$9=Object.getOwnPropertyDescriptor,__decorateClass$9=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$9(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$9(target,key,result),result},"__decorateClass$9"),__decorateParam$9=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$9");exports2.DataValidationController=(_m=class extends core.RxDisposable{constructor(_univerInstanceService,_sheetDataValidationService,_dataValidatorRegistryService,_injector,_componentManger,_selectionManagerService,_sheetInterceptorService,_dataValidationModel){super(),this._univerInstanceService=_univerInstanceService,this._sheetDataValidationService=_sheetDataValidationService,this._dataValidatorRegistryService=_dataValidatorRegistryService,this._injector=_injector,this._componentManger=_componentManger,this._selectionManagerService=_selectionManagerService,this._sheetInterceptorService=_sheetInterceptorService,this._dataValidationModel=_dataValidationModel,this._init()}_init(){this._registerValidators(),this._initInstanceChange(),this._initCommandInterceptor(),this._initComponents()}_registerValidators(){[DecimalValidator,WholeValidator,TextLengthValidator,DateValidator,CheckboxValidator,ListValidator,ListMultipleValidator,CustomFormulaValidator].forEach(Validator=>{const validator=this._injector.createInstance(Validator);this.disposeWithMe(this._dataValidatorRegistryService.register(validator)),this.disposeWithMe({dispose:__name(()=>{this._injector.delete(Validator)},"dispose")})})}_initInstanceChange(){const disposableCollection=new core.DisposableCollection;this.disposeWithMe(this._univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET).subscribe(workbook=>{if(disposableCollection.dispose(),!workbook)return;const worksheet=workbook.getActiveSheet();worksheet&&(this._sheetDataValidationService.switchCurrent(workbook.getUnitId(),worksheet.getSheetId()),disposableCollection.add(core.toDisposable(workbook.activeSheet$.subscribe(worksheet2=>{if(worksheet2){const unitId=workbook.getUnitId(),subUnitId=worksheet2.getSheetId();this._sheetDataValidationService.switchCurrent(unitId,subUnitId)}}))))})),this.disposeWithMe(disposableCollection)}_initCommandInterceptor(){this._sheetInterceptorService.interceptCommand({getMutations:__name(commandInfo=>{var _a2;if(commandInfo.id===sheets.ClearSelectionAllCommand.id){const workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),unitId=workbook.getUnitId(),worksheet=workbook.getActiveSheet();if(!worksheet)throw new Error("No active sheet found");const subUnitId=worksheet.getSheetId(),selections=(_a2=this._selectionManagerService.getCurrentSelections())==null?void 0:_a2.map(s=>s.range),manager=this._dataValidationModel.ensureManager(unitId,subUnitId),ruleMatrix=manager.getRuleObjectMatrix().clone();selections&&ruleMatrix.removeRange(selections);const diffs=ruleMatrix.diff(manager.getDataValidations()),{redoMutations,undoMutations}=getDataValidationDiffMutations(unitId,subUnitId,diffs,this._injector,"patched");return{undos:undoMutations,redos:redoMutations}}return{undos:[],redos:[]}},"getMutations")})}_initComponents(){[[DataValidationIcon,DataValidationSingle],[DATA_VALIDATION_PANEL,DataValidationPanel],[DROP_DOWN_KEY,CellDropdown],[LIST_DROPDOWN_KEY,ListDropDown],[DATE_DROPDOWN_KEY,DateDropdown],[ListRenderModeInput.componentKey,ListRenderModeInput],[DateShowTimeOption.componentKey,DateShowTimeOption],...FORMULA_INPUTS].forEach(([key,component])=>{this.disposeWithMe(this._componentManger.register(key,component))})}},__name(_m,"DataValidationController"),_m),exports2.DataValidationController=__decorateClass$9([core.OnLifecycle(core.LifecycleStages.Rendered,exports2.DataValidationController),__decorateParam$9(0,core.IUniverInstanceService),__decorateParam$9(1,core.Inject(exports2.SheetDataValidationService)),__decorateParam$9(2,core.Inject(dataValidation.DataValidatorRegistryService)),__decorateParam$9(3,core.Inject(core.Injector)),__decorateParam$9(4,core.Inject(ui.ComponentManager)),__decorateParam$9(5,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$9(6,core.Inject(sheets.SheetInterceptorService)),__decorateParam$9(7,core.Inject(dataValidation.DataValidationModel))],exports2.DataValidationController);var __defProp$8=Object.defineProperty,__getOwnPropDesc$8=Object.getOwnPropertyDescriptor,__decorateClass$8=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$8(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$8(target,key,result),result},"__decorateClass$8"),__decorateParam$8=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$8");const ALERT_KEY="SHEET_DATA_VALIDATION_ALERT";exports2.DataValidationAlertController=(_n=class extends core.Disposable{constructor(_hoverManagerService,_cellAlertManagerService,_univerInstanceService,_localeService){super(),this._hoverManagerService=_hoverManagerService,this._cellAlertManagerService=_cellAlertManagerService,this._univerInstanceService=_univerInstanceService,this._localeService=_localeService,this._init()}_init(){this._initCellAlertPopup()}_initCellAlertPopup(){this.disposeWithMe(this._hoverManagerService.currentCell$.pipe(rxjs.debounceTime(100)).subscribe(cellPos=>{var _a2,_b2;if(cellPos){const worksheet=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getActiveSheet();if(!worksheet)return;const cellData=worksheet.getCell(cellPos.location.row,cellPos.location.col);if(((_a2=cellData==null?void 0:cellData.dataValidation)==null?void 0:_a2.validStatus)===core.DataValidationStatus.INVALID){const currentAlert=this._cellAlertManagerService.currentAlert.get(ALERT_KEY),currentLoc=(_b2=currentAlert==null?void 0:currentAlert.alert)==null?void 0:_b2.location;if(currentLoc&&currentLoc.row===cellPos.location.row&&currentLoc.col===cellPos.location.col&&currentLoc.subUnitId===cellPos.location.subUnitId&&currentLoc.unitId===cellPos.location.unitId)return;const validator=cellData.dataValidation.validator,rule=cellData.dataValidation.rule;if(!validator)return;this._cellAlertManagerService.showAlert({type:sheetsUi.CellAlertType.ERROR,title:this._localeService.t("dataValidation.error.title"),message:validator==null?void 0:validator.getRuleFinalError(rule),location:cellPos.location,width:200,height:74,key:ALERT_KEY});return}}this._cellAlertManagerService.removeAlert(ALERT_KEY)}))}},__name(_n,"DataValidationAlertController"),_n),exports2.DataValidationAlertController=__decorateClass$8([core.OnLifecycle(core.LifecycleStages.Rendered,exports2.DataValidationAlertController),__decorateParam$8(0,core.Inject(sheetsUi.HoverManagerService)),__decorateParam$8(1,core.Inject(sheetsUi.CellAlertManagerService)),__decorateParam$8(2,core.IUniverInstanceService),__decorateParam$8(3,core.Inject(core.LocaleService))],exports2.DataValidationAlertController);var __defProp$7=Object.defineProperty,__getOwnPropDesc$7=Object.getOwnPropertyDescriptor,__decorateClass$7=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$7(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$7(target,key,result),result},"__decorateClass$7"),__decorateParam$7=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$7");exports2.DataValidationRefRangeController=(_o=class extends core.Disposable{constructor(_dataValidationModel,_injector,_refRangeService,_dataValidationCustomFormulaService,_dataValidationFormulaService,_formulaRefRangeService){super();__publicField(this,"_disposableMap",new Map);__publicField(this,"registerRule",__name((unitId,subUnitId,rule)=>{this.register(unitId,subUnitId,rule),this.registerFormula(unitId,subUnitId,rule)},"registerRule"));this._dataValidationModel=_dataValidationModel,this._injector=_injector,this._refRangeService=_refRangeService,this._dataValidationCustomFormulaService=_dataValidationCustomFormulaService,this._dataValidationFormulaService=_dataValidationFormulaService,this._formulaRefRangeService=_formulaRefRangeService,this._initRefRange()}_getIdWithUnitId(unitID,subUnitId,ruleId){return`${unitID}_${subUnitId}_${ruleId}`}registerFormula(unitId,subUnitId,rule){var _a2;const ruleId=rule.uid,id=this._getIdWithUnitId(unitId,subUnitId,ruleId),disposeSet=(_a2=this._disposableMap.get(id))!=null?_a2:new Set,handleFormulaChange=__name((type,formulaString)=>{const oldRule=this._dataValidationModel.getRuleById(unitId,subUnitId,ruleId);if(!oldRule)return{redos:[],undos:[]};const oldFormula=oldRule[type];if(!oldFormula||oldFormula===formulaString)return{redos:[],undos:[]};const redoParams={unitId,subUnitId,ruleId:rule.uid,payload:{type:dataValidation.UpdateRuleType.SETTING,payload:{type:oldRule.type,formula1:oldRule.formula1,formula2:oldRule.formula2,[type]:formulaString}}},undoParams={unitId,subUnitId,ruleId:rule.uid,payload:{type:dataValidation.UpdateRuleType.SETTING,payload:{type:oldRule.type,formula1:oldRule.formula1,formula2:oldRule.formula2}}},redos=[{id:dataValidation.UpdateDataValidationMutation.id,params:redoParams}],undos=[{id:dataValidation.UpdateDataValidationMutation.id,params:undoParams}];return{redos,undos}},"handleFormulaChange");if(rule.type===core.DataValidationType.CUSTOM){const currentFormula=this._dataValidationCustomFormulaService.getRuleFormulaInfo(unitId,subUnitId,ruleId);if(currentFormula){const disposable=this._formulaRefRangeService.registerFormula(currentFormula.formula,newFormulaString=>handleFormulaChange("formula1",newFormulaString));disposeSet.add(()=>disposable.dispose())}}if(rule.type!==core.DataValidationType.CUSTOM){const currentFormula=this._dataValidationFormulaService.getRuleFormulaInfo(unitId,subUnitId,ruleId);if(currentFormula){const[formula1,formula2]=currentFormula;if(formula1){const disposable=this._formulaRefRangeService.registerFormula(formula1.text,newFormulaString=>handleFormulaChange("formula1",newFormulaString));disposeSet.add(()=>disposable.dispose())}if(formula2){const disposable=this._formulaRefRangeService.registerFormula(formula2.text,newFormulaString=>handleFormulaChange("formula1",newFormulaString));disposeSet.add(()=>disposable.dispose())}}}}register(unitId,subUnitId,rule){var _a2;const handleRangeChange=__name(commandInfo=>{const oldRanges=[...rule.ranges],resultRanges=oldRanges.map(range=>sheets.handleCommonDefaultRangeChangeWithEffectRefCommands(range,commandInfo)).filter(range=>!!range).flat();if(core.isRangesEqual(resultRanges,oldRanges))return{redos:[],undos:[]};if(resultRanges.length){const redoParams={unitId,subUnitId,ruleId:rule.uid,payload:{type:dataValidation.UpdateRuleType.RANGE,payload:resultRanges},source:"patched"},redos=[{id:dataValidation.UpdateDataValidationMutation.id,params:redoParams}],undos=[{id:dataValidation.UpdateDataValidationMutation.id,params:{unitId,subUnitId,ruleId:rule.uid,payload:{type:dataValidation.UpdateRuleType.RANGE,payload:oldRanges},source:"patched"}}];return{redos,undos}}else{const redoParams={unitId,subUnitId,ruleId:rule.uid},redos=[{id:dataValidation.RemoveDataValidationMutation.id,params:redoParams}],undos=dataValidation.removeDataValidationUndoFactory(this._injector,redoParams);return{redos,undos}}},"handleRangeChange"),disposeList=[];rule.ranges.forEach(range=>{const disposable=this._refRangeService.registerRefRange(range,handleRangeChange,unitId,subUnitId);disposeList.push(()=>disposable.dispose())});const id=this._getIdWithUnitId(unitId,subUnitId,rule.uid),current=(_a2=this._disposableMap.get(id))!=null?_a2:new Set;current.add(()=>disposeList.forEach(dispose=>dispose())),this._disposableMap.set(id,current)}_initRefRange(){this.disposeWithMe(this._dataValidationModel.ruleChange$.subscribe(option=>{const{unitId,subUnitId,rule}=option;switch(option.type){case"add":{const rule2=option.rule;this.registerRule(option.unitId,option.subUnitId,rule2);break}case"remove":{const disposeSet=this._disposableMap.get(this._getIdWithUnitId(unitId,subUnitId,rule.uid));disposeSet&&disposeSet.forEach(dispose=>dispose());break}case"update":{const rule2=option.rule,disposeSet=this._disposableMap.get(this._getIdWithUnitId(unitId,subUnitId,rule2.uid));disposeSet&&disposeSet.forEach(dispose=>dispose()),this.registerRule(option.unitId,option.subUnitId,rule2);break}}})),this.disposeWithMe(core.toDisposable(()=>{this._disposableMap.forEach(item=>{item.forEach(dispose=>dispose())}),this._disposableMap.clear()}))}},__name(_o,"DataValidationRefRangeController"),_o),exports2.DataValidationRefRangeController=__decorateClass$7([core.OnLifecycle(core.LifecycleStages.Ready,exports2.DataValidationRefRangeController),__decorateParam$7(0,core.Inject(dataValidation.DataValidationModel)),__decorateParam$7(1,core.Inject(core.Injector)),__decorateParam$7(2,core.Inject(sheets.RefRangeService)),__decorateParam$7(3,core.Inject(exports2.DataValidationCustomFormulaService)),__decorateParam$7(4,core.Inject(exports2.DataValidationFormulaService)),__decorateParam$7(5,core.Inject(sheetsFormula.FormulaRefRangeService))],exports2.DataValidationRefRangeController);var __defProp$6=Object.defineProperty,__getOwnPropDesc$6=Object.getOwnPropertyDescriptor,__decorateClass$6=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$6(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$6(target,key,result),result},"__decorateClass$6"),__decorateParam$6=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$6");exports2.DataValidationAutoFillController=(_p=class extends core.Disposable{constructor(_autoFillService,_dataValidationModel,_injector){super(),this._autoFillService=_autoFillService,this._dataValidationModel=_dataValidationModel,this._injector=_injector,this._initAutoFill()}_initAutoFill(){const noopReturnFunc=__name(()=>({redos:[],undos:[]}),"noopReturnFunc"),generalApplyFunc=__name(location=>{const{source:sourceRange,target:targetRange,unitId,subUnitId}=location,manager=this._dataValidationModel.ensureManager(unitId,subUnitId),ruleMatrixCopy=manager.getRuleObjectMatrix().clone(),virtualRange=sheetsUi.virtualizeDiscreteRanges([sourceRange,targetRange]),[vSourceRange,vTargetRange]=virtualRange.ranges,{mapFunc}=virtualRange,sourceStartCell={row:vSourceRange.startRow,col:vSourceRange.startColumn};sheetsUi.getAutoFillRepeatRange(vSourceRange,vTargetRange).forEach(repeat=>{const targetStartCell=repeat.repeatStartCell,relativeRange=repeat.relativeRange,sourceRange2={startRow:sourceStartCell.row,startColumn:sourceStartCell.col,endColumn:sourceStartCell.col,endRow:sourceStartCell.row},targetRange2={startRow:targetStartCell.row,startColumn:targetStartCell.col,endColumn:targetStartCell.col,endRow:targetStartCell.row};core.Range.foreach(relativeRange,(row,col)=>{const sourcePositionRange=core.Rectangle.getPositionRange({startRow:row,startColumn:col,endColumn:col,endRow:row},sourceRange2),{row:sourceRow,col:sourceCol}=mapFunc(sourcePositionRange.startRow,sourcePositionRange.startColumn),ruleId=manager.getRuleIdByLocation(sourceRow,sourceCol);if(ruleId){const targetPositionRange=core.Rectangle.getPositionRange({startRow:row,startColumn:col,endColumn:col,endRow:row},targetRange2),{row:targetRow,col:targetCol}=mapFunc(targetPositionRange.startRow,targetPositionRange.startColumn);ruleMatrixCopy.setValue(targetRow,targetCol,ruleId)}})});const diffs=ruleMatrixCopy.diff(manager.getDataValidations()),{redoMutations,undoMutations}=getDataValidationDiffMutations(unitId,subUnitId,diffs,this._injector,"patched");return{undos:undoMutations,redos:redoMutations}},"generalApplyFunc"),disabledDataVallation=[core.DataValidationType.CHECKBOX],hook={id:DATA_VALIDATION_PLUGIN_NAME,onBeforeFillData:__name(location=>{const{source:sourceRange,unitId,subUnitId}=location,manager=this._dataValidationModel.ensureManager(unitId,subUnitId);for(const row of sourceRange.rows)for(const col of sourceRange.cols){const dv=manager.getRuleByLocation(row,col);if(dv&&disabledDataVallation.indexOf(dv.type)>-1){this._autoFillService.setDisableApplyType(sheetsUi.APPLY_TYPE.SERIES,!0);return}}},"onBeforeFillData"),onFillData:__name((location,direction,applyType)=>applyType===sheetsUi.APPLY_TYPE.COPY||applyType===sheetsUi.APPLY_TYPE.ONLY_FORMAT||applyType===sheetsUi.APPLY_TYPE.SERIES?generalApplyFunc(location):noopReturnFunc(),"onFillData"),onAfterFillData:__name(()=>{},"onAfterFillData")};this.disposeWithMe(this._autoFillService.addHook(hook))}},__name(_p,"DataValidationAutoFillController"),_p),exports2.DataValidationAutoFillController=__decorateClass$6([core.OnLifecycle(core.LifecycleStages.Ready,exports2.DataValidationAutoFillController),__decorateParam$6(0,sheetsUi.IAutoFillService),__decorateParam$6(1,core.Inject(dataValidation.DataValidationModel)),__decorateParam$6(2,core.Inject(core.Injector))],exports2.DataValidationAutoFillController);var __defProp$5=Object.defineProperty,__getOwnPropDesc$5=Object.getOwnPropertyDescriptor,__decorateClass$5=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$5(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$5(target,key,result),result},"__decorateClass$5"),__decorateParam$5=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$5");exports2.DataValidationCopyPasteController=(_q=class extends core.Disposable{constructor(_sheetClipboardService,_dataValidationModel,_injector){super();__publicField(this,"_copyInfo");this._sheetClipboardService=_sheetClipboardService,this._dataValidationModel=_dataValidationModel,this._injector=_injector,this._initCopyPaste()}_initCopyPaste(){this._sheetClipboardService.addClipboardHook({id:DATA_VALIDATION_PLUGIN_NAME,onBeforeCopy:__name((unitId,subUnitId,range)=>this._collect(unitId,subUnitId,range),"onBeforeCopy"),onPasteCells:__name((pasteFrom,pasteTo,data,payload)=>{const{copyType=sheetsUi.COPY_TYPE.COPY,pasteType}=payload,{range:copyRange}=pasteFrom||{},{range:pastedRange,unitId,subUnitId}=pasteTo;return this._generateMutations(pastedRange,{copyType,pasteType,copyRange,unitId,subUnitId})},"onPasteCells")})}_collect(unitId,subUnitId,range){const matrix=new core.ObjectMatrix;this._copyInfo={unitId,subUnitId,matrix};const manager=this._dataValidationModel.ensureManager(unitId,subUnitId),accessor={get:this._injector.get.bind(this._injector)},discreteRange=sheetsUi.rangeToDiscreteRange(range,accessor,unitId,subUnitId);if(!discreteRange)return;const{rows,cols}=discreteRange;rows.forEach((row,rowIndex)=>{cols.forEach((col,colIndex)=>{const ruleId=manager.getRuleIdByLocation(row,col);matrix.setValue(rowIndex,colIndex,ruleId!=null?ruleId:"")})})}_generateMutations(pastedRange,copyInfo){if(!this._copyInfo)return{redos:[],undos:[]};if(copyInfo.copyType===sheetsUi.COPY_TYPE.CUT)return this._copyInfo=null,{redos:[],undos:[]};if(!this._copyInfo||!this._copyInfo.matrix.getSizeOf()||!copyInfo.copyRange)return{redos:[],undos:[]};if([sheetsUi.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_COL_WIDTH,sheetsUi.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_VALUE,sheetsUi.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMAT,sheetsUi.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMULA].includes(copyInfo.pasteType))return{redos:[],undos:[]};const{unitId,subUnitId}=this._copyInfo;if(copyInfo.unitId!==unitId||subUnitId!==copyInfo.subUnitId){const originManager=this._dataValidationModel.ensureManager(unitId,subUnitId),manager=this._dataValidationModel.ensureManager(copyInfo.unitId,copyInfo.subUnitId),ruleMatrix=manager.getRuleObjectMatrix().clone(),{ranges:[vCopyRange,vPastedRange],mapFunc}=sheetsUi.virtualizeDiscreteRanges([copyInfo.copyRange,pastedRange]),repeatRange=sheetsUi.getRepeatRange(vCopyRange,vPastedRange,!0),additionRules=new Map;repeatRange.forEach(({startRange})=>{var _a2;(_a2=this._copyInfo)==null||_a2.matrix.forValue((row,col,ruleId)=>{const range=core.Rectangle.getPositionRange({startRow:row,endRow:row,startColumn:col,endColumn:col},startRange),transformedRuleId=`${subUnitId}-${ruleId}`,oldRule=originManager.getRuleById(ruleId);!manager.getRuleById(transformedRuleId)&&oldRule&&additionRules.set(transformedRuleId,{...oldRule,uid:transformedRuleId});const{row:startRow,col:startColumn}=mapFunc(range.startRow,range.startColumn);ruleMatrix.setValue(startRow,startColumn,transformedRuleId)})});const{redoMutations,undoMutations}=getDataValidationDiffMutations(copyInfo.unitId,copyInfo.subUnitId,ruleMatrix.diffWithAddition(manager.getDataValidations(),additionRules.values()),this._injector,"patched");return{redos:redoMutations,undos:undoMutations}}else{const manager=this._dataValidationModel.ensureManager(unitId,subUnitId),ruleMatrix=manager.getRuleObjectMatrix().clone(),{ranges:[vCopyRange,vPastedRange],mapFunc}=sheetsUi.virtualizeDiscreteRanges([copyInfo.copyRange,pastedRange]);sheetsUi.getRepeatRange(vCopyRange,vPastedRange,!0).forEach(({startRange})=>{var _a2;(_a2=this._copyInfo)==null||_a2.matrix.forValue((row,col,ruleId)=>{const range=core.Rectangle.getPositionRange({startRow:row,endRow:row,startColumn:col,endColumn:col},startRange),{row:startRow,col:startColumn}=mapFunc(range.startRow,range.startColumn);ruleMatrix.setValue(startRow,startColumn,ruleId)})});const{redoMutations,undoMutations}=getDataValidationDiffMutations(unitId,subUnitId,ruleMatrix.diff(manager.getDataValidations()),this._injector,"patched");return{redos:redoMutations,undos:undoMutations}}}},__name(_q,"DataValidationCopyPasteController"),_q),exports2.DataValidationCopyPasteController=__decorateClass$5([core.OnLifecycle(core.LifecycleStages.Ready,exports2.DataValidationCopyPasteController),__decorateParam$5(0,sheetsUi.ISheetClipboardService),__decorateParam$5(1,core.Inject(dataValidation.DataValidationModel)),__decorateParam$5(2,core.Inject(core.Injector))],exports2.DataValidationCopyPasteController);const _RuleMatrix=class _RuleMatrix{constructor(value,_worksheet){__publicField(this,"value");this._worksheet=_worksheet,this.value=value}addRule(rule){const ruleId=rule.uid;rule.ranges.forEach(range=>{core.Range.foreach(core.Range.transformRange(range,this._worksheet),(row,col)=>{this.value.setValue(row,col,ruleId)})})}removeRange(ranges){ranges.forEach(range=>{core.Range.foreach(core.Range.transformRange(range,this._worksheet),(row,col)=>{this.value.realDeleteValue(row,col)})})}removeRule(rule){rule.ranges.forEach(range=>{core.Range.foreach(core.Range.transformRange(range,this._worksheet),(row,col)=>{this.value.setValue(row,col,"")})})}updateRange(ruleId,_oldRanges,_newRanges){const tempRuleId=`${ruleId}$`,oldRanges=_oldRanges.map(range=>core.Range.transformRange(range,this._worksheet)),newRanges=_newRanges.map(range=>core.Range.transformRange(range,this._worksheet));oldRanges.forEach(range=>{core.Range.foreach(range,(row,col)=>{this.value.getValue(row,col)===ruleId&&this.value.setValue(row,col,tempRuleId)})}),newRanges.forEach(range=>{core.Range.foreach(range,(row,col)=>{this.value.setValue(row,col,ruleId)})}),oldRanges.forEach(range=>{core.Range.foreach(range,(row,col)=>{this.value.getValue(row,col)===tempRuleId&&this.value.realDeleteValue(row,col)})})}diff(rules){const mutations=[];let deleteIndex=0;return rules.forEach((rule,index)=>{const newRanges=core.queryObjectMatrix(this.value,ruleId=>ruleId===rule.uid),oldRanges=rule.ranges;(newRanges.length!==oldRanges.length||newRanges.some((range,i)=>!core.Rectangle.equals(range,oldRanges[i])))&&mutations.push({type:"update",ruleId:rule.uid,oldRanges,newRanges}),newRanges.length===0&&(mutations.push({type:"delete",rule,index:index-deleteIndex}),deleteIndex++)}),mutations}diffWithAddition(rules,additionRules){const mutations=[];let deleteIndex=0;return rules.forEach((rule,index)=>{const newRanges=core.queryObjectMatrix(this.value,ruleId=>ruleId===rule.uid),oldRanges=rule.ranges;(newRanges.length!==oldRanges.length||newRanges.some((range,i)=>!core.Rectangle.equals(range,oldRanges[i])))&&mutations.push({type:"update",ruleId:rule.uid,oldRanges,newRanges}),newRanges.length===0&&(mutations.push({type:"delete",rule,index:index-deleteIndex}),deleteIndex++)}),Array.from(additionRules).forEach(rule=>{const newRanges=core.queryObjectMatrix(this.value,ruleId=>ruleId===rule.uid);mutations.push({type:"add",rule:{...rule,ranges:newRanges}})}),mutations}clone(){return new _RuleMatrix(new core.ObjectMatrix(this.value.clone()),this._worksheet)}getValue(row,col){return this.value.getValue(row,col)}setValue(row,col,value){return this.value.setValue(row,col,value)}};__name(_RuleMatrix,"RuleMatrix");let RuleMatrix=_RuleMatrix;const _SheetDataValidationManager=class _SheetDataValidationManager extends dataValidation.DataValidationManager{constructor(unitId,subUnitId,_injector){super(unitId,subUnitId);__publicField(this,"_ruleMatrix");__publicField(this,"_dataValidatorRegistryService");__publicField(this,"_dataValidationCacheService");__publicField(this,"_dataValidationFormulaService");__publicField(this,"_dataValidationCustomFormulaService");__publicField(this,"_cache");this._injector=_injector,this._dataValidatorRegistryService=this._injector.get(dataValidation.DataValidatorRegistryService),this._dataValidationCacheService=this._injector.get(DataValidationCacheService),this._dataValidationFormulaService=this._injector.get(exports2.DataValidationFormulaService),this._dataValidationCustomFormulaService=this._injector.get(exports2.DataValidationCustomFormulaService),this._cache=this._dataValidationCacheService.ensureCache(unitId,subUnitId);const worksheet=this._injector.get(core.IUniverInstanceService).getUnit(unitId,core.UniverInstanceType.UNIVER_SHEET).getSheetBySheetId(subUnitId),matrix=new core.ObjectMatrix;this._ruleMatrix=new RuleMatrix(matrix,worksheet)}_addRuleSideEffect(rule){var _a2;const{unitId,subUnitId}=this;(rule.type===core.DataValidationType.LIST||rule.type===core.DataValidationType.LIST_MULTIPLE)&&engineFormula.isReferenceString((_a2=rule.formula1)!=null?_a2:"")&&(rule.formula1=`=${rule.formula1}`),this._ruleMatrix.addRule(rule),this._dataValidationCacheService.addRule(unitId,subUnitId,rule),this._dataValidationFormulaService.addRule(unitId,subUnitId,rule.uid,rule.formula1,rule.formula2),this._dataValidationCustomFormulaService.addRule(unitId,subUnitId,rule)}addRule(rule,index){(Array.isArray(rule)?rule:[rule]).forEach(item=>{this._addRuleSideEffect(item)}),super.addRule(rule,index)}updateRule(ruleId,payload){const oldRule=this.getRuleById(ruleId);if(!oldRule)throw new Error(`Rule not found! id: ${ruleId}`);return payload.type===dataValidation.UpdateRuleType.RANGE?(this._ruleMatrix.updateRange(ruleId,oldRule.ranges,payload.payload),this._dataValidationCacheService.updateRuleRanges(this.unitId,this.subUnitId,ruleId,payload.payload,oldRule.ranges),this._dataValidationCustomFormulaService.updateRuleRanges(this.unitId,this.subUnitId,ruleId,oldRule.ranges,payload.payload)):payload.type===dataValidation.UpdateRuleType.SETTING&&(this._dataValidationCacheService.markRangeDirty(this.unitId,this.subUnitId,oldRule.ranges),this._dataValidationFormulaService.updateRuleFormulaText(this.unitId,this.subUnitId,ruleId,payload.payload.formula1,payload.payload.formula2),this._dataValidationCustomFormulaService.updateRuleFormula(this.unitId,this.subUnitId,ruleId,oldRule.ranges,payload.payload.formula1)),super.updateRule(ruleId,payload)}removeRule(ruleId){const oldRule=this.getRuleById(ruleId);oldRule&&(this._ruleMatrix.removeRule(oldRule),this._dataValidationCacheService.removeRule(this.unitId,this.subUnitId,oldRule)),super.removeRule(ruleId)}getValidator(type){return this._dataValidatorRegistryService.getValidatorItem(type)}getRuleIdByLocation(row,col){return this._ruleMatrix.getValue(row,col)}getRuleByLocation(row,col){const ruleId=this.getRuleIdByLocation(row,col);if(ruleId)return this.getRuleById(ruleId)}validator(cellValue,rule,pos,onCompete){const{col,row,unitId,subUnitId}=pos,ruleId=rule.uid,validator=this.getValidator(rule.type);if(validator){const current=this._cache.getValue(row,col);return!current||current.value!==cellValue?(this._cache.setValue(row,col,{value:cellValue,status:core.DataValidationStatus.VALIDATING,ruleId}),validator.validator({value:cellValue,unitId,subUnitId,row,column:col},rule).then(status=>{const realStatus=status?core.DataValidationStatus.VALID:core.DataValidationStatus.INVALID;this._cache.setValue(row,col,{value:cellValue,status:realStatus,ruleId}),onCompete(realStatus,!0)}),core.DataValidationStatus.VALIDATING):(onCompete(current.status,!1),current.status)}else return onCompete(core.DataValidationStatus.VALID,!1),core.DataValidationStatus.VALID}getRuleErrorMsg(ruleId){const rule=this.getRuleById(ruleId);if(!rule)return"";const validator=this._dataValidatorRegistryService.getValidatorItem(rule.type);return rule.error?rule.error:validator?validator.getRuleFinalError(rule):""}getRuleObjectMatrix(){return this._ruleMatrix}};__name(_SheetDataValidationManager,"SheetDataValidationManager");let SheetDataValidationManager=_SheetDataValidationManager;var __defProp$4=Object.defineProperty,__getOwnPropDesc$4=Object.getOwnPropertyDescriptor,__decorateClass$4=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$4(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$4(target,key,result),result},"__decorateClass$4"),__decorateParam$4=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$4");let DataValidationModelController=(_r=class extends core.Disposable{constructor(_resourceManagerService,_univerInstanceService,_dataValidationModel,_injector){super(),this._resourceManagerService=_resourceManagerService,this._univerInstanceService=_univerInstanceService,this._dataValidationModel=_dataValidationModel,this._injector=_injector,this._initDataValidationDataSource()}_createSheetDataValidationManager(unitId,subUnitId){return new SheetDataValidationManager(unitId,subUnitId,this._injector)}_initDataValidationDataSource(){this._dataValidationModel.setManagerCreator(this._createSheetDataValidationManager.bind(this))}},__name(_r,"DataValidationModelController"),_r);DataValidationModelController=__decorateClass$4([core.OnLifecycle(core.LifecycleStages.Starting,DataValidationModelController),__decorateParam$4(0,core.IResourceManagerService),__decorateParam$4(1,core.IUniverInstanceService),__decorateParam$4(2,core.Inject(dataValidation.DataValidationModel)),__decorateParam$4(3,core.Inject(core.Injector))],DataValidationModelController);var __defProp$3=Object.defineProperty,__getOwnPropDesc$3=Object.getOwnPropertyDescriptor,__decorateClass$3=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$3(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$3(target,key,result),result},"__decorateClass$3"),__decorateParam$3=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$3");let DataValidationPermissionController=(_s=class extends core.Disposable{constructor(_localeService,_commandService,_sheetPermissionInterceptorBaseController){super(),this._localeService=_localeService,this._commandService=_commandService,this._sheetPermissionInterceptorBaseController=_sheetPermissionInterceptorBaseController,this._commandExecutedListener()}_commandExecutedListener(){this.disposeWithMe(this._commandService.beforeCommandExecuted(command=>{command.id===dataValidation.AddDataValidationCommand.id&&(this._sheetPermissionInterceptorBaseController.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission]})||this._sheetPermissionInterceptorBaseController.haveNotPermissionHandle(this._localeService.t("permission.dialog.setStyleErr"))),command.id===UpdateSheetDataValidationRangeCommand.id&&(this._sheetPermissionInterceptorBaseController.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission]},command.params.ranges)||this._sheetPermissionInterceptorBaseController.haveNotPermissionHandle(this._localeService.t("permission.dialog.setStyleErr")))}))}},__name(_s,"DataValidationPermissionController"),_s);DataValidationPermissionController=__decorateClass$3([core.OnLifecycle(core.LifecycleStages.Ready,DataValidationPermissionController),__decorateParam$3(0,core.Inject(core.LocaleService)),__decorateParam$3(1,core.ICommandService),__decorateParam$3(2,core.Inject(sheetsUi.SheetPermissionInterceptorBaseController))],DataValidationPermissionController);var __defProp$2=Object.defineProperty,__getOwnPropDesc$2=Object.getOwnPropertyDescriptor,__decorateClass$2=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$2(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$2(target,key,result),result},"__decorateClass$2"),__decorateParam$2=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$2");exports2.SheetsDataValidationValidatorService=(_t=class{constructor(_univerInstanceService,_dataValidationModel,_dataValidationCacheService){this._univerInstanceService=_univerInstanceService,this._dataValidationModel=_dataValidationModel,this._dataValidationCacheService=_dataValidationCacheService}async validatorCell(unitId,subUnitId,row,col){const workbook=this._univerInstanceService.getUnit(unitId,core.UniverInstanceType.UNIVER_SHEET);if(!workbook)throw new Error(`cannot find current workbook, unitId: ${unitId}`);const worksheet=workbook.getSheetBySheetId(subUnitId);if(!worksheet)throw new Error(`cannot find current worksheet, sheetId: ${subUnitId}`);const cellRaw=worksheet.getCellRaw(row,col),manager=this._dataValidationModel.ensureManager(unitId,subUnitId),rule=manager.getRuleByLocation(row,col);return rule?new Promise(resolve=>{manager.validator(getCellValueOrigin(cellRaw),rule,{unitId,subUnitId,row,col},resolve)}):core.DataValidationStatus.VALID}async validatorWorksheet(unitId,subUnitId){const rules=this._dataValidationModel.ensureManager(unitId,subUnitId).getDataValidations();return await Promise.all(rules.map(rule=>Promise.all(rule.ranges.map(range=>{const promises=[];return core.Range.foreach(range,(row,col)=>{promises.push(this.validatorCell(unitId,subUnitId,row,col))}),promises})))),this._dataValidationCacheService.ensureCache(unitId,subUnitId)}async validatorWorkbook(unitId){const sheetIds=this._dataValidationModel.getSubUnitIds(unitId),results=await Promise.all(sheetIds.map(id=>this.validatorWorksheet(unitId,id))),map={};return results.forEach((result,i)=>{map[sheetIds[i]]=result}),map}},__name(_t,"SheetsDataValidationValidatorService"),_t),exports2.SheetsDataValidationValidatorService=__decorateClass$2([__decorateParam$2(0,core.IUniverInstanceService),__decorateParam$2(1,core.Inject(dataValidation.DataValidationModel)),__decorateParam$2(2,core.Inject(DataValidationCacheService))],exports2.SheetsDataValidationValidatorService);var __defProp$1=Object.defineProperty,__getOwnPropDesc$1=Object.getOwnPropertyDescriptor,__defNormalProp$1=__name((obj,key,value)=>key in obj?__defProp$1(obj,key,{enumerable:!0,configurable:!0,writable:!0,value}):obj[key]=value,"__defNormalProp$1"),__decorateClass$1=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$1(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$1(target,key,result),result},"__decorateClass$1"),__decorateParam$1=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$1"),__publicField$1=__name((obj,key,value)=>__defNormalProp$1(obj,typeof key!="symbol"?key+"":key,value),"__publicField$1");exports2.UniverSheetsDataValidationPlugin=(_u=class extends core.Plugin{constructor(_config={},_injector,_commandService,_localeService){super(),this._config=_config,this._injector=_injector,this._commandService=_commandService,this._localeService=_localeService,this._config=core.Tools.deepMerge({},DefaultSheetsDataValidation,this._config)}onStarting(){[[DataValidationPanelService],[exports2.SheetDataValidationService],[DataValidationCacheService],[exports2.DataValidationFormulaService],[exports2.DataValidationCustomFormulaService],[DataValidationDropdownManagerService],[exports2.SheetsDataValidationValidatorService],[DataValidationModelController],[exports2.DataValidationController],[exports2.SheetsDataValidationRenderController,{useFactory:__name(()=>this._injector.createInstance(exports2.SheetsDataValidationRenderController,this._config),"useFactory")}],[exports2.DataValidationAlertController],[exports2.DataValidationRefRangeController],[DataValidationPermissionController],[exports2.DataValidationAutoFillController],[exports2.DataValidationCopyPasteController],[exports2.DataValidationFormulaController],[exports2.DataValidationRejectInputController]].forEach(dep=>{this._injector.add(dep)}),[AddSheetDataValidationCommand,AddSheetDataValidationAndOpenCommand,UpdateSheetDataValidationRangeCommand,UpdateSheetDataValidationSettingCommand,UpdateSheetDataValidationOptionsCommand,ShowDataValidationDropdown,HideDataValidationDropdown,CloseValidationPanelOperation,OpenValidationPanelOperation,ToggleValidationPanelOperation].forEach(command=>{this._commandService.registerCommand(command)})}},__name(_u,"UniverSheetsDataValidationPlugin"),_u),__publicField$1(exports2.UniverSheetsDataValidationPlugin,"pluginName",DATA_VALIDATION_PLUGIN_NAME),__publicField$1(exports2.UniverSheetsDataValidationPlugin,"type",core.UniverInstanceType.UNIVER_SHEET),exports2.UniverSheetsDataValidationPlugin=__decorateClass$1([core.DependentOn(dataValidation.UniverDataValidationPlugin,sheets.UniverSheetsPlugin,sheetsUi.UniverSheetsUIPlugin),__decorateParam$1(1,core.Inject(core.Injector)),__decorateParam$1(2,core.ICommandService),__decorateParam$1(3,core.Inject(core.LocaleService))],exports2.UniverSheetsDataValidationPlugin);var __defProp2=Object.defineProperty,__getOwnPropDesc=Object.getOwnPropertyDescriptor,__defNormalProp2=__name((obj,key,value)=>key in obj?__defProp2(obj,key,{enumerable:!0,configurable:!0,writable:!0,value}):obj[key]=value,"__defNormalProp"),__decorateClass=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp2(target,key,result),result},"__decorateClass"),__decorateParam=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam"),__publicField2=__name((obj,key,value)=>__defNormalProp2(obj,typeof key!="symbol"?key+"":key,value),"__publicField");exports2.UniverSheetsDataValidationMobilePlugin=(_v=class extends core.Plugin{constructor(_config={},_injector,_commandService,_localeService){super(),this._config=_config,this._injector=_injector,this._commandService=_commandService,this._localeService=_localeService,this._config=core.Tools.deepMerge({},DefaultSheetsDataValidation,this._config)}onStarting(){[[DataValidationPanelService],[exports2.SheetDataValidationService],[DataValidationCacheService],[exports2.DataValidationFormulaService],[exports2.DataValidationCustomFormulaService],[DataValidationDropdownManagerService],[exports2.SheetsDataValidationValidatorService],[DataValidationModelController],[exports2.DataValidationController],[SheetsDataValidationMobileRenderController,{useFactory:__name(()=>this._injector.createInstance(SheetsDataValidationMobileRenderController,this._config),"useFactory")}],[exports2.DataValidationAlertController],[exports2.DataValidationRefRangeController],[DataValidationPermissionController],[exports2.DataValidationCopyPasteController],[exports2.DataValidationFormulaController]].forEach(dep=>{this._injector.add(dep)}),[AddSheetDataValidationCommand,AddSheetDataValidationAndOpenCommand,UpdateSheetDataValidationRangeCommand,ShowDataValidationDropdown,HideDataValidationDropdown,CloseValidationPanelOperation,OpenValidationPanelOperation,ToggleValidationPanelOperation].forEach(command=>{this._commandService.registerCommand(command)})}},__name(_v,"UniverSheetsDataValidationMobilePlugin"),_v),__publicField2(exports2.UniverSheetsDataValidationMobilePlugin,"pluginName",DATA_VALIDATION_PLUGIN_NAME),__publicField2(exports2.UniverSheetsDataValidationMobilePlugin,"type",core.UniverInstanceType.UNIVER_SHEET),exports2.UniverSheetsDataValidationMobilePlugin=__decorateClass([core.DependentOn(dataValidation.UniverDataValidationPlugin,sheets.UniverSheetsPlugin,sheetsUi.UniverSheetsUIPlugin),__decorateParam(1,core.Inject(core.Injector)),__decorateParam(2,core.ICommandService),__decorateParam(3,core.Inject(core.LocaleService))],exports2.UniverSheetsDataValidationMobilePlugin),Object.defineProperty(exports2,"ICommandService",{enumerable:!0,get:__name(()=>core.ICommandService,"get")}),Object.defineProperty(exports2,"LocaleService",{enumerable:!0,get:__name(()=>core.LocaleService,"get")}),Object.defineProperty(exports2,"Plugin",{enumerable:!0,get:__name(()=>core.Plugin,"get")}),exports2.AddSheetDataValidationAndOpenCommand=AddSheetDataValidationAndOpenCommand,exports2.AddSheetDataValidationCommand=AddSheetDataValidationCommand,exports2.CloseValidationPanelOperation=CloseValidationPanelOperation,exports2.DATA_VALIDATION_PLUGIN_NAME=DATA_VALIDATION_PLUGIN_NAME,exports2.DataValidationCacheService=DataValidationCacheService,exports2.HideDataValidationDropdown=HideDataValidationDropdown,exports2.OpenValidationPanelOperation=OpenValidationPanelOperation,exports2.ShowDataValidationDropdown=ShowDataValidationDropdown,exports2.ToggleValidationPanelOperation=ToggleValidationPanelOperation,exports2.UpdateSheetDataValidationRangeCommand=UpdateSheetDataValidationRangeCommand,Object.defineProperty(exports2,Symbol.toStringTag,{value:"Module"})});