@univerjs/sheets-data-validation 0.2.3 → 0.2.4-alpha.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/cjs/index.js +2 -2
- package/lib/es/index.js +986 -971
- package/lib/types/commands/commands/data-validation.command.d.ts +1 -2
- package/lib/types/controllers/dv-auto-fill.controller.d.ts +1 -2
- package/lib/types/controllers/dv-copy-paste.controller.d.ts +1 -2
- package/lib/types/controllers/dv-model.controller.d.ts +1 -2
- package/lib/types/controllers/dv-ref-range.controller.d.ts +1 -2
- package/lib/types/controllers/dv-render.controller.d.ts +1 -2
- package/lib/types/controllers/dv.controller.d.ts +1 -2
- package/lib/types/controllers/dv.menu.d.ts +1 -1
- package/lib/types/mobile-plugin.d.ts +1 -2
- package/lib/types/models/sheet-data-validation-manager.d.ts +1 -2
- package/lib/types/plugin.d.ts +1 -2
- package/lib/types/services/data-validation-panel.service.d.ts +1 -2
- package/lib/types/services/dropdown-manager.service.d.ts +2 -2
- package/lib/types/services/dv.service.d.ts +2 -2
- package/lib/umd/index.js +2 -2
- package/package.json +26 -28
package/lib/cjs/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
"use strict";var
|
|
1
|
+
"use strict";var ga=Object.defineProperty;var va=(o,r,e)=>r in o?ga(o,r,{enumerable:!0,configurable:!0,writable:!0,value:e}):o[r]=e;var R=(o,r,e)=>va(o,typeof r!="symbol"?r+"":r,e);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const i=require("@univerjs/core"),D=require("@univerjs/data-validation"),x=require("@univerjs/sheets"),j=require("@univerjs/sheets-ui"),k=require("@univerjs/ui"),z=require("@univerjs/engine-render"),ve=require("rxjs"),T=require("react"),Vt=require("@univerjs/sheets-formula"),w=require("@univerjs/design"),Sa=require("clsx"),ae=require("@univerjs/engine-formula"),se=require("dayjs"),_a=require("@univerjs/engine-numfmt");function J(o){if(o===null)return"";if(o!=null&&o.p){const r=o==null?void 0:o.p.body;if(r==null)return"";const e=r.dataStream;return e.substring(e.length-2,e.length)===i.DEFAULT_EMPTY_DOCUMENT_VALUE?e.substring(0,e.length-2):e}return o==null?void 0:o.v}function At(o){var r;return String((r=J(o))!=null?r:"")}var Va=typeof globalThis<"u"?globalThis:typeof window<"u"?window:typeof global<"u"?global:typeof self<"u"?self:{};function Ra(o){return o&&o.__esModule&&Object.prototype.hasOwnProperty.call(o,"default")?o.default:o}var jt={exports:{}},ze={};/**
|
|
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 Bt(o,r,e){var t,a={},n=null,i=null;e!==void 0&&(n=""+e),r.key!==void 0&&(n=""+r.key),r.ref!==void 0&&(i=r.ref);for(t in r)wa.call(r,t)&&!Ta.hasOwnProperty(t)&&(a[t]=r[t]);if(o&&o.defaultProps)for(t in r=o.defaultProps,r)a[t]===void 0&&(a[t]=r[t]);return{$$typeof:ya,type:o,key:n,ref:i,props:a,_owner:Oa.current}}Qe.Fragment=Ma;Qe.jsx=Bt;Qe.jsxs=Bt;Ut.exports=Qe;var v=Ut.exports;function Ea(){const o=H.useDependency(fe),r=q.useObservable(o.activeDropdown$,o.activeDropdown),e=H.useDependency(q.ComponentManager);if(!r)return null;const{location:t,componentKey:a}=r,n=e.get(a),i=`${t.unitId}-${t.subUnitId}-${t.row}-${t.col}`;if(!n)return null;const l=()=>{o.hideDropdown()};return v.jsx(n,{location:t,hideFn:l},i)}const $t="sheet.ui.dropdown";var ba=Object.defineProperty,Fa=Object.getOwnPropertyDescriptor,Na=(o,r,e,t)=>{for(var a=t>1?void 0:t?Fa(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&ba(r,e,a),a},Ce=(o,r)=>(e,t)=>r(e,t,o);let fe=class extends s.Disposable{constructor(r,e,t,a,n,i){super();R(this,"_activeDropdown");R(this,"_activeDropdown$",new _e.Subject);R(this,"_currentPopup",null);R(this,"activeDropdown$",this._activeDropdown$.asObservable());R(this,"_zenVisible",!1);this._canvasPopupManagerService=r,this._univerInstanceService=e,this._dataValidatorRegistryService=t,this._zenZoneService=a,this._renderManagerService=n,this._dataValidationModel=i,this._init()}get activeDropdown(){return this._activeDropdown}_init(){this.disposeWithMe(this._zenZoneService.visible$.subscribe(r=>{this._zenVisible=r,r&&this.hideDropdown()}))}showDropdown(r){const{location:e}=r,{row:t,col:a}=e;if(this._currentPopup&&this._currentPopup.dispose(),this._zenVisible)return;this._activeDropdown=r,this._activeDropdown$.next(this._activeDropdown);const n=this._renderManagerService.getRenderById(s.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),i=this._canvasPopupManagerService.attachPopupToCell(t,a,{componentKey:$t,onClickOutside:()=>{this.hideDropdown()},offset:[0,3],excludeOutside:[n==null?void 0:n.engine.getCanvasElement()].filter(Boolean)});if(!i)throw new Error("[DataValidationDropdownManagerService]: cannot show dropdown!");const l=new s.DisposableCollection;l.add(i),l.add({dispose:()=>{var d,c;(c=(d=this._activeDropdown)==null?void 0:d.onHide)==null||c.call(d)}}),this._currentPopup=l}hideDropdown(){this._activeDropdown&&(this._currentPopup&&this._currentPopup.dispose(),this._currentPopup=null,this._activeDropdown=null,this._activeDropdown$.next(null))}showDataValidationDropdown(r,e,t,a,n){const i=this._univerInstanceService.getUniverSheetInstance(r);if(!i)return;const l=i.getSheetBySheetId(e);if(!l)return;const c=this._dataValidationModel.ensureManager(r,e).getRuleByLocation(t,a);if(!c)return;const u=this._dataValidatorRegistryService.getValidatorItem(c.type);if(!u||!u.dropdown){this.hideDropdown();return}this.showDropdown({location:{workbook:i,worksheet:l,row:t,col:a,unitId:r,subUnitId:e},componentKey:u.dropdown,onHide:n})}};fe=Na([Ce(0,y.Inject(x.SheetCanvasPopManagerService)),Ce(1,s.IUniverInstanceService),Ce(2,y.Inject(D.DataValidatorRegistryService)),Ce(3,q.IZenZoneService),Ce(4,K.IRenderManagerService),Ce(5,y.Inject(D.DataValidationModel))],fe);var La=Object.defineProperty,Pa=Object.getOwnPropertyDescriptor,Aa=(o,r,e,t)=>{for(var a=t>1?void 0:t?Pa(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&La(r,e,a),a},Ot=(o,r)=>(e,t)=>r(e,t,o);let ce=class extends s.Disposable{constructor(r,e){super();R(this,"_open$",new _e.BehaviorSubject(!1));R(this,"open$",this._open$.pipe(_e.distinctUntilChanged()));R(this,"_activeRule");R(this,"_activeRule$",new _e.BehaviorSubject(void 0));R(this,"activeRule$",this._activeRule$.asObservable());R(this,"_closeDisposable",null);this._univerInstanceService=r,this._sidebarService=e,this.disposeWithMe(this._univerInstanceService.getCurrentTypeOfUnit$(s.UniverInstanceType.UNIVER_SHEET).pipe(_e.filter(t=>!t)).subscribe(()=>{this.close()}))}get activeRule(){return this._activeRule}get isOpen(){return this._open$.getValue()}dispose(){var r;super.dispose(),this._open$.next(!1),this._open$.complete(),(r=this._closeDisposable)==null||r.dispose()}open(){this._open$.next(!0)}close(){var r;this._open$.next(!1),(r=this._closeDisposable)==null||r.dispose()}setCloseDisposable(r){this._closeDisposable=s.toDisposable(()=>{r.dispose(),this._closeDisposable=null})}setActiveRule(r){this._activeRule=r,this._activeRule$.next(r)}};ce=Aa([Ot(0,s.IUniverInstanceService),Ot(1,q.ISidebarService)],ce);const Wt="DataValidationPanel",Re={id:"data-validation.operation.open-validation-panel",type:s.CommandType.OPERATION,handler(o,r){if(!r)return!1;const{ruleId:e,isAdd:t}=r,a=o.get(ce),n=o.get(D.DataValidationModel),i=o.get(s.IUniverInstanceService),l=o.get(q.ISidebarService),d=U.getSheetCommandTarget(i);if(!d)return!1;const{unitId:c,subUnitId:u}=d,m=e?n.getRuleById(c,u,e):void 0;a.open(),a.setActiveRule(m&&{unitId:c,subUnitId:u,rule:m});const f=l.open({header:{title:t?"dataValidation.panel.addTitle":"dataValidation.panel.title"},children:{label:Wt},width:312,onClose:()=>a.close()});return a.setCloseDisposable(f),!0}},Ze={id:"data-validation.operation.close-validation-panel",type:s.CommandType.OPERATION,handler(o){return o.get(ce).close(),!0}},Ct={id:"data-validation.operation.toggle-validation-panel",type:s.CommandType.OPERATION,handler(o){const r=o.get(s.ICommandService),e=o.get(ce);return e.open(),e.isOpen?r.executeCommand(Ze.id):r.executeCommand(Re.id),!0}},Ae={type:s.CommandType.OPERATION,id:"sheet.operation.show-data-validation-dropdown",handler(o,r){if(!r)return!1;const e=o.get(fe),{unitId:t,subUnitId:a,row:n,column:i}=r,l=e.activeDropdown,d=l==null?void 0:l.location;return d&&d.unitId===t&&d.subUnitId===a&&d.row===n&&d.col===i||e.showDataValidationDropdown(t,a,n,i),!0}},It={type:s.CommandType.OPERATION,id:"sheet.operation.hide-data-validation-dropdown",handler(o,r){return r?(o.get(fe).hideDropdown(),!0):!1}};class De{constructor(){R(this,"_cacheMatrix",new Map)}_ensureCache(r,e){let t=this._cacheMatrix.get(r);t||(t=new Map,this._cacheMatrix.set(r,t));let a=t.get(e);return a||(a=new s.ObjectMatrix,t.set(e,a)),a}ensureCache(r,e){return this._ensureCache(r,e)}addRule(r,e,t){this.markRangeDirty(r,e,t.ranges)}removeRule(r,e,t){this._deleteRange(r,e,t.ranges)}updateRuleRanges(r,e,t,a,n){const i=this._ensureCache(r,e);n.forEach(l=>{s.Range.foreach(l,(d,c)=>{const u=i.getValue(d,c);u&&(u.temp=!0)})}),a.forEach(l=>{s.Range.foreach(l,(d,c)=>{const u=i.getValue(d,c);u&&u.ruleId===t?u.temp=!1:i.setValue(d,c,void 0)})}),n.forEach(l=>{s.Range.foreach(l,(d,c)=>{const u=i.getValue(d,c);u&&u.temp===!0&&i.realDeleteValue(d,c)})})}markRangeDirty(r,e,t){const a=this._ensureCache(r,e);t.forEach(n=>{s.Range.foreach(n,(i,l)=>{a.setValue(i,l,void 0)})})}markCellDirty(r,e,t,a){this._ensureCache(r,e).setValue(t,a,void 0)}_deleteRange(r,e,t){const a=this._ensureCache(r,e);t.forEach(n=>{s.Range.foreach(n,(i,l)=>{a.realDeleteValue(i,l)})})}getValue(r,e,t,a){return this._ensureCache(r,e).getValue(t,a)}setValue(r,e,t,a,n){return this._ensureCache(r,e).setValue(t,a,n)}}var ja=Object.defineProperty,xa=Object.getOwnPropertyDescriptor,Ua=(o,r,e,t)=>{for(var a=t>1?void 0:t?xa(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&ja(r,e,a),a},tt=(o,r)=>(e,t)=>r(e,t,o);exports.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 n in a){const i=a[n],l=this._ensureRuleFormulaMap(t,n),d=this._dataValidationModel.ensureManager(t,n);i.forEach(c=>{var u,m;if(l.get((u=c.extra)==null?void 0:u.ruleId)){const f=d.getRuleById((m=c.extra)==null?void 0:m.ruleId);f&&this._dataValidationCacheService.markRangeDirty(t,n,f.ranges)}})}}}))}_ensureRuleFormulaMap(e,t){let a=this._formulaRuleMap.get(e);a||(a=new Map,this._formulaRuleMap.set(e,a));let n=a.get(t);return n||(n=new Map,a.set(t,n)),n}addRule(e,t,a,n,i){const l=s.isFormulaString(n),d=s.isFormulaString(i);if(!l&&!d)return;const c=this._ensureRuleFormulaMap(e,t),u=[void 0,void 0];if(l){const m=this._registerOtherFormulaService.registerFormula(e,t,n,{ruleId:a});u[0]={id:m,text:n}}if(d){const m=this._registerOtherFormulaService.registerFormula(e,t,i,{ruleId:a});u[1]={id:m,text:i}}c.set(a,u)}removeRule(e,t,a){const i=this._ensureRuleFormulaMap(e,t).get(a);if(!i)return;const[l,d]=i,c=[l==null?void 0:l.id,d==null?void 0:d.id].filter(Boolean);c.length&&this._registerOtherFormulaService.deleteFormula(e,t,c)}updateRuleFormulaText(e,t,a,n,i){const d=this._ensureRuleFormulaMap(e,t).get(a);if(!d){this.addRule(e,t,a,n,i);return}const[c,u]=d;if((c==null?void 0:c.text)!==n)if(c&&this._registerOtherFormulaService.deleteFormula(e,t,[c.id]),s.isFormulaString(n)){const m=this._registerOtherFormulaService.registerFormula(e,t,n,{ruleId:a});d[0]={text:n,id:m}}else d[0]=void 0;if((u==null?void 0:u.text)!==i)if(u&&this._registerOtherFormulaService.deleteFormula(e,t,[u.id]),s.isFormulaString(i)){const m=this._registerOtherFormulaService.registerFormula(e,t,i,{ruleId:a});d[1]={text:i,id:m}}else d[1]=void 0}getRuleFormulaResult(e,t,a){const i=this._ensureRuleFormulaMap(e,t).get(a);if(!i)return Promise.resolve(null);const l=async d=>d&&this._registerOtherFormulaService.getFormulaValue(e,t,d.id);return Promise.all([l(i[0]),l(i[1])])}getRuleFormulaResultSync(e,t,a){const i=this._ensureRuleFormulaMap(e,t).get(a);if(i)return i.map(l=>{if(l)return this._registerOtherFormulaService.getFormulaValueSync(e,t,l.id)})}getRuleFormulaInfo(e,t,a){return this._ensureRuleFormulaMap(e,t).get(a)}};exports.DataValidationFormulaService=Ua([tt(0,y.Inject(Dt.RegisterOtherFormulaService)),tt(1,y.Inject(De)),tt(2,y.Inject(D.DataValidationModel))],exports.DataValidationFormulaService);function ie(o){var r,e;return(e=(r=o==null?void 0:o[0])==null?void 0:r[0])==null?void 0:e.v}var Ba=Object.defineProperty,$a=Object.getOwnPropertyDescriptor,Wa=(o,r,e,t)=>{for(var a=t>1?void 0:t?$a(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&Ba(r,e,a),a},at=(o,r)=>(e,t)=>r(e,t,o);const $e=6;let vt=class{constructor(o,r,e){this._commandService=o,this._formulaService=r,this._themeService=e}_calc(o,r){var c,u,m;const{vt:e,ht:t}=r||{},a=o.endX-o.startX-$e*2,n=o.endY-o.startY,i=((c=r==null?void 0:r.fs)!=null?c:10)*1.6;let l=0,d=0;switch(e){case s.VerticalAlign.TOP:d=0;break;case s.VerticalAlign.BOTTOM:d=0+(n-i);break;default:d=0+(n-i)/2;break}switch(t){case s.HorizontalAlign.LEFT:l=$e;break;case s.HorizontalAlign.RIGHT:l=$e+(a-i);break;default:l=$e+(a-i)/2;break}return{left:o.startX+l,top:o.startY+d,width:((u=r==null?void 0:r.fs)!=null?u:10)*1.6,height:((m=r==null?void 0:r.fs)!=null?m:10)*1.6}}calcCellAutoHeight(o){var e;const{style:r}=o;return((e=r==null?void 0:r.fs)!=null?e:10)*1.6}async _parseFormula(o,r,e){var i,l;const{formula1:t=Le,formula2:a=Pe}=o,n=await this._formulaService.getRuleFormulaResult(r,e,o.uid);return{formula1:s.isFormulaString(t)?ie((i=n==null?void 0:n[0])==null?void 0:i.result):t,formula2:s.isFormulaString(a)?ie((l=n==null?void 0:n[1])==null?void 0:l.result):a}}drawWith(o,r){var B,b,$,k,A;const{style:e,data:t,primaryWithCoord:a,unitId:n,subUnitId:i}=r,l=a.isMergedMainCell?a.mergeInfo:a,d=te(t),c=(B=t.dataValidation)==null?void 0:B.rule,u=(b=t.dataValidation)==null?void 0:b.validator;if(!c||!u)return;const m=this._themeService.getCurrentTheme();if(!u.skipDefaultFontRender(c,d,{unitId:n,subUnitId:i}))return;const f=u.parseFormulaSync(c,n,i),{formula1:p}=f,g=this._calc(l,e),{a:h,d:_}=o.getTransform(),S=K.fixLineWidthByScale(g.left,h),C=K.fixLineWidthByScale(g.top,_),V=K.Transform.create().composeMatrix({left:S,top:C,scaleX:1,scaleY:1,angle:0,skewX:0,skewY:0,flipX:!1,flipY:!1}),I=l.endX-l.startX,w=l.endY-l.startY;o.save(),o.beginPath(),o.rect(l.startX,l.startY,I,w),o.clip();const T=V.getMatrix();o.transform(T[0],T[1],T[2],T[3],T[4],T[5]);const F=(($=e==null?void 0:e.fs)!=null?$:10)*1.6,j=String(d)===String(p),P=m.hyacinth500;K.Checkbox.drawWith(o,{checked:j,width:F,height:F,fill:(A=(k=e==null?void 0:e.cl)==null?void 0:k.rgb)!=null?A:P}),o.restore()}isHit(o,r){const e=r.primaryWithCoord.isMergedMainCell?r.primaryWithCoord.mergeInfo:r.primaryWithCoord,t=this._calc(e,r.style),a=t.top,n=t.top+t.height,i=t.left,l=t.left+t.width,{x:d,y:c}=o;return d<=l&&d>=i&&c<=n&&c>=a}async onPointerDown(o,r){var f,p;if(r.button===2)return;const{primaryWithCoord:e,unitId:t,subUnitId:a,data:n}=o,i=te(n),l=(f=n.dataValidation)==null?void 0:f.rule,d=(p=n.dataValidation)==null?void 0:p.validator;if(!l||!d||!d.skipDefaultFontRender(l,i,{unitId:t,subUnitId:a}))return;const{formula1:c,formula2:u}=await this._parseFormula(l,t,a),m={range:{startColumn:e.actualColumn,endColumn:e.actualColumn,startRow:e.actualRow,endRow:e.actualRow},value:{v:String(i)===String(c)?u:c,p:null}};this._commandService.executeCommand(U.SetRangeValuesCommand.id,m)}};vt=Wa([at(0,s.ICommandService),at(1,y.Inject(exports.DataValidationFormulaService)),at(2,y.Inject(s.ThemeService))],vt);function Ha(o){var d;const{unitId:r,subUnitId:e,value:t,onChange:a,showError:n,validResult:i}=o,l=n?i==null?void 0:i.formula1:"";return v.jsx(O.FormLayout,{error:l,children:v.jsx(q.TextEditor,{value:(d=t==null?void 0:t.formula1)!=null?d:"",id:s.createInternalEditorID(`dataValidation-custom-formula-${r}-${e}`),onChange:c=>{a==null||a({...t,formula1:c!=null?c:""})},onlyInputFormula:!0,openForSheetUnitId:r,openForSheetSubUnitId:e})})}const ka="univer-data-validation-formula",Ya="univer-data-validation-formula-and",qa="univer-data-validation-formula-list-item",Xa="univer-data-validation-formula-list-item-icon",Ga="univer-data-validation-formula-list-item-drag",za="univer-data-validation-formula-list-add",Ka="univer-data-validation-formula-color-select",Qa="univer-data-validation-formula-color-select-panel",Za="univer-data-validation-formula-color-item",re={dataValidationFormula:ka,dataValidationFormulaAnd:Ya,dataValidationFormulaListItem:qa,dataValidationFormulaListItemIcon:Xa,dataValidationFormulaListItemDrag:Ga,dataValidationFormulaListAdd:za,dataValidationFormulaColorSelect:Ka,dataValidationFormulaColorSelectPanel:Qa,dataValidationFormulaColorItem:Za},Ja=o=>{const{isTwoFormula:r=!1,value:e,onChange:t,showError:a,validResult:n}=o,i=H.useDependency(s.LocaleService),l=a?n==null?void 0:n.formula1:"",d=a?n==null?void 0:n.formula2:"";return r?v.jsxs(v.Fragment,{children:[v.jsx(O.FormLayout,{error:l,children:v.jsx(O.Input,{className:re.dataValidationFormula,placeholder:i.t("dataValidation.panel.formulaPlaceholder"),value:e==null?void 0:e.formula1,onChange:c=>{t==null||t({...e,formula1:c})}})}),v.jsx("div",{className:re.dataValidationFormulaAnd,children:i.t("dataValidation.panel.formulaAnd")}),v.jsx(O.FormLayout,{error:d,children:v.jsx(O.Input,{className:re.dataValidationFormula,placeholder:i.t("dataValidation.panel.formulaPlaceholder"),value:e==null?void 0:e.formula2,onChange:c=>{t==null||t({...e,formula2:c})}})})]}):v.jsx(O.FormLayout,{error:l,children:v.jsx(O.Input,{className:re.dataValidationFormula,placeholder:i.t("dataValidation.panel.formulaPlaceholder"),value:e==null?void 0:e.formula1,onChange:c=>{t==null||t({formula1:c})}})})};var ne=function(){return ne=Object.assign||function(o){for(var r,e=1,t=arguments.length;e<t;e++){r=arguments[e];for(var a in r)Object.prototype.hasOwnProperty.call(r,a)&&(o[a]=r[a])}return o},ne.apply(this,arguments)},er=function(o,r){var e={};for(var t in o)Object.prototype.hasOwnProperty.call(o,t)&&r.indexOf(t)<0&&(e[t]=o[t]);if(o!=null&&typeof Object.getOwnPropertySymbols=="function")for(var a=0,t=Object.getOwnPropertySymbols(o);a<t.length;a++)r.indexOf(t[a])<0&&Object.prototype.propertyIsEnumerable.call(o,t[a])&&(e[t[a]]=o[t[a]]);return e},ge=E.forwardRef(function(o,r){var e=o.icon,t=o.id,a=o.className,n=o.extend,i=er(o,["icon","id","className","extend"]),l="univerjs-icon univerjs-icon-".concat(t," ").concat(a||"").trim(),d=E.useRef("_".concat(rr()));return Ht(e,"".concat(t),{defIds:e.defIds,idSuffix:d.current},ne({ref:r,className:l},i),n)});function Ht(o,r,e,t,a){return E.createElement(o.tag,ne(ne({key:r},tr(o,e,a)),t),(ar(o,e).children||[]).map(function(n,i){return Ht(n,"".concat(r,"-").concat(o.tag,"-").concat(i),e,void 0,a)}))}function tr(o,r,e){var t=ne({},o.attrs);e!=null&&e.colorChannel1&&t.fill==="colorChannel1"&&(t.fill=e.colorChannel1);var a=r.defIds;return!a||a.length===0||(o.tag==="use"&&t["xlink:href"]&&(t["xlink:href"]=t["xlink:href"]+r.idSuffix),Object.entries(t).forEach(function(n){var i=n[0],l=n[1];typeof l=="string"&&(t[i]=l.replace(/url\(#(.*)\)/,"url(#$1".concat(r.idSuffix,")")))})),t}function ar(o,r){var e,t=r.defIds;return!t||t.length===0?o:o.tag==="defs"&&(!((e=o.children)===null||e===void 0)&&e.length)?ne(ne({},o),{children:o.children.map(function(a){return typeof a.attrs.id=="string"&&t&&t.indexOf(a.attrs.id)>-1?ne(ne({},a),{attrs:ne(ne({},a.attrs),{id:a.attrs.id+r.idSuffix})}):a})}):o}function rr(){return Math.random().toString(36).substring(2,8)}ge.displayName="UniverIcon";var or={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"}}]},kt=E.forwardRef(function(o,r){return E.createElement(ge,Object.assign({},o,{id:"check-mark-single",ref:r,icon:or}))});kt.displayName="CheckMarkSingle";var nr={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"}}]},Yt=E.forwardRef(function(o,r){return E.createElement(ge,Object.assign({},o,{id:"data-validation-single",ref:r,icon:nr}))});Yt.displayName="DataValidationSingle";var ir={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"}}]},yt=E.forwardRef(function(o,r){return E.createElement(ge,Object.assign({},o,{id:"delete-single",ref:r,icon:ir}))});yt.displayName="DeleteSingle";var sr={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"}}]},qt=E.forwardRef(function(o,r){return E.createElement(ge,Object.assign({},o,{id:"increase-single",ref:r,icon:sr}))});qt.displayName="IncreaseSingle";var lr={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"}}]},Xt=E.forwardRef(function(o,r){return E.createElement(ge,Object.assign({},o,{id:"more-down-single",ref:r,icon:lr}))});Xt.displayName="MoreDownSingle";var dr={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"}}]},Gt=E.forwardRef(function(o,r){return E.createElement(ge,Object.assign({},o,{id:"more-up-single",ref:r,icon:dr}))});Gt.displayName="MoreUpSingle";var cr={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"}}]}]},zt=E.forwardRef(function(o,r){return E.createElement(ge,Object.assign({},o,{id:"sequence-single",ref:r,icon:cr}))});zt.displayName="SequenceSingle";function Kt(o){return o.filter(Boolean).join(",")}function we(o){return o.split(",").filter(Boolean)}function ur(o){const r=te(o);return r==null?"":r.toString()}const je="SHEET_DATA_VALIDATION_PLUGIN",Ve="#ECECEC";var qe=(o=>(o[o.View=0]="View",o[o.Edit=1]="Edit",o[o.ManageCollaborator=2]="ManageCollaborator",o[o.Print=3]="Print",o[o.Duplicate=4]="Duplicate",o[o.Comment=5]="Comment",o[o.Copy=6]="Copy",o[o.Share=7]="Share",o[o.Export=8]="Export",o[o.MoveWorksheet=9]="MoveWorksheet",o[o.DeleteWorksheet=10]="DeleteWorksheet",o[o.HideWorksheet=11]="HideWorksheet",o[o.RenameWorksheet=12]="RenameWorksheet",o[o.CreateWorksheet=13]="CreateWorksheet",o[o.SetWorksheetStyle=14]="SetWorksheetStyle",o[o.EditWorksheetCell=15]="EditWorksheetCell",o[o.InsertHyperlink=16]="InsertHyperlink",o[o.Sort=17]="Sort",o[o.Filter=18]="Filter",o[o.PivotTable=19]="PivotTable",o[o.FloatImg=20]="FloatImg",o[o.History=21]="History",o[o.RwHgtClWdt=22]="RwHgtClWdt",o[o.ViemRwHgtClWdt=23]="ViemRwHgtClWdt",o[o.ViewFilter=24]="ViewFilter",o[o.MoveSheet=25]="MoveSheet",o[o.DeleteSheet=26]="DeleteSheet",o[o.HideSheet=27]="HideSheet",o[o.CopySheet=28]="CopySheet",o[o.RenameSheet=29]="RenameSheet",o[o.CreateSheet=30]="CreateSheet",o[o.SelectProtectedCells=31]="SelectProtectedCells",o[o.SelectUnProtectedCells=32]="SelectUnProtectedCells",o[o.SetCellStyle=33]="SetCellStyle",o[o.SetCellValue=34]="SetCellValue",o[o.SetRowStyle=35]="SetRowStyle",o[o.SetColumnStyle=36]="SetColumnStyle",o[o.InsertRow=37]="InsertRow",o[o.InsertColumn=38]="InsertColumn",o[o.DeleteRow=39]="DeleteRow",o[o.DeleteColumn=40]="DeleteColumn",o[o.EditExtraObject=41]="EditExtraObject",o[o.Delete=42]="Delete",o[o.UNRECOGNIZED=-1]="UNRECOGNIZED",o))(qe||{}),hr=Object.defineProperty,mr=Object.getOwnPropertyDescriptor,pr=(o,r,e,t)=>{for(var a=t>1?void 0:t?mr(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&hr(r,e,a),a},rt=(o,r)=>(e,t)=>r(e,t,o);exports.DataValidationFormulaController=class extends s.Disposable{constructor(r,e,t){super(),this._univerInstanceService=r,this._permissionService=e,this._lexerTreeBuilder=t}getFormulaRefCheck(r){var t,a;const e=this._lexerTreeBuilder.sequenceNodesBuilder(r);if(!e)return!0;for(let n=0;n<e.length;n++){const i=e[n];if(typeof i=="string")continue;const{token:l}=i,d=oe.deserializeRangeWithSheet(l),c=this._univerInstanceService.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET);let u=c.getActiveSheet();const m=c.getUnitId();if(d.sheetName){if(u=c.getSheetBySheetName(d.sheetName),!u)return!1;const _=u==null?void 0:u.getSheetId();if(!this._permissionService.getPermissionPoint(new U.WorksheetViewPermission(m,_).id))return!1}if(!u)return!1;const{startRow:f,endRow:p,startColumn:g,endColumn:h}=d.range;for(let _=f;_<=p;_++)for(let S=g;S<=h;S++){const C=(a=(t=u.getCell(_,S))==null?void 0:t.selectionProtection)==null?void 0:a[0];if((C==null?void 0:C[qe.View])===!1)return!1}}return!0}};exports.DataValidationFormulaController=pr([s.OnLifecycle(s.LifecycleStages.Rendered,exports.DataValidationFormulaController),rt(0,s.IUniverInstanceService),rt(1,s.IPermissionService),rt(2,y.Inject(oe.LexerTreeBuilder))],exports.DataValidationFormulaController);const fr=["#FFFFFF","#FEE7E7","#FEF0E6","#EFFBD0","#E4F4FE","#E8ECFD","#F1EAFA","#FDE8F3","#E5E5E5","#FDCECE","#FDC49B","#DEF6A2","#9FDAFF","#D0D9FB","#E3D5F6","#FBD0E8","#656565","#FE4B4B","#FF8C51","#8BBB11","#0B9EFB","#3A60F7","#9E6DE3","#F248A6"],gr=o=>{const{value:r,onChange:e,disabled:t}=o,[a,n]=E.useState(!1);return v.jsx(O.Select,{disabled:t,open:a,onDropdownVisibleChange:n,dropdownStyle:{width:112},className:re.dataValidationFormulaColorSelect,value:r,onChange:e,labelRender:i=>v.jsx("div",{className:re.dataValidationFormulaColorItem,style:{background:i.value,marginTop:5}}),dropdownRender:()=>v.jsx("div",{className:re.dataValidationFormulaColorSelectPanel,children:fr.map(i=>v.jsx("div",{onClick:()=>{e(i),n(!1)},className:re.dataValidationFormulaColorItem,style:{background:i}},i))})})},Tt=o=>{const{item:r,commonProps:e,style:t}=o,{onItemChange:a,onItemDelete:n}=e;return v.jsxs("div",{className:re.dataValidationFormulaListItem,style:t,children:[r.isRef?null:v.jsx("div",{className:Va(re.dataValidationFormulaListItemDrag,"draggableHandle"),children:v.jsx(zt,{})}),v.jsx(gr,{value:r.color,onChange:i=>{a(r.id,r.label,i)}}),v.jsx(O.Input,{disabled:r.isRef,value:r.label,onChange:i=>{a(r.id,i,r.color)}}),r.isRef?null:v.jsx("div",{className:re.dataValidationFormulaListItemIcon,children:v.jsx(yt,{onClick:()=>n(r.id)})})]})};function vr(o){const{value:r,onChange:e=()=>{},unitId:t,subUnitId:a,validResult:n,showError:i,ruleId:l}=o,{formula1:d="",formula2:c=""}=r||{},u=E.useRef(null),[m,f]=E.useState(()=>s.isFormulaString(d)?"1":"0"),[p,g]=E.useState(m==="1"?d:"="),[h,_]=E.useState(m==="1"?d:"="),S=H.useDependency(s.LocaleService),C=H.useDependency(D.DataValidatorRegistryService),V=H.useDependency(D.DataValidationModel),I=H.useDependency(exports.DataValidationFormulaController),[w,T]=E.useState(()=>c.split(",")),F=C.getValidatorItem(s.DataValidationType.LIST),[j,P]=E.useState([]),[B,b]=E.useState(""),$=i?n==null?void 0:n.formula1:"",k=q.useObservable(V.ruleChange$),A=q.useEvent(e);E.useEffect(()=>{(async()=>{await new Promise(z=>{setTimeout(()=>z(!0),100)});const N=V.getRuleById(t,a,l),G=N==null?void 0:N.formula1;if(s.isFormulaString(G)&&F&&N){const z=await F.getListAsync(N,t,a);P(z)}})()},[V,k,F,l,a,t]),E.useEffect(()=>{s.isFormulaString(d)&&d!==h&&(g(d),_(h))},[h,d]);const[L,Y]=E.useState(()=>{const N=m!=="1"?we(d):[],G=c.split(",");return N.map((z,ae)=>({label:z,color:G[ae]||Ve,isRef:!1,id:s.Tools.generateRandomId(4)}))}),Z=(N,G,z)=>{const ae=L.find(ue=>ue.id===N);ae&&(ae.label=G,ae.color=z,Y([...L]))},X=N=>{const G=L.findIndex(z=>z.id===N);G!==-1&&(L.splice(G,1),Y([...L]))},M=c.split(","),W=E.useMemo(()=>j.map((N,G)=>({label:N,color:M[G]||Ve,id:`${G}`,isRef:!0})),[M,j]),ee=(N,G,z)=>{const ae=[...w];ae[+N]=z,T(ae),A({formula1:d,formula2:ae.join(",")})},Q=()=>{Y([...L,{label:"",color:Ve,isRef:!1,id:s.Tools.generateRandomId(4)}])};E.useEffect(()=>{if(m==="1")return;const N=new Set,G=[];L.map(z=>({labelList:z.label.split(","),item:z})).forEach(({item:z,labelList:ae})=>{ae.forEach(ue=>{N.has(ue)||(N.add(ue),G.push({label:ue,color:z.color}))})}),A({formula1:Kt(G.map(z=>z.label)),formula2:G.map(z=>z.color===Ve?"":z.color).join(",")})},[L,A,m,h,w]);const se=E.useMemo(()=>async N=>{if(!s.isFormulaString(N)){A==null||A({formula1:"",formula2:c});return}I.getFormulaRefCheck(N)?(A==null||A({formula1:s.isFormulaString(N)?N:"",formula2:c}),b("")):(A==null||A({formula1:"",formula2:c}),g("="),b(S.t("dataValidation.validFail.formulaError")))},[c,A]);return v.jsxs(v.Fragment,{children:[v.jsx(O.FormLayout,{label:S.t("dataValidation.list.options"),children:v.jsxs(O.RadioGroup,{value:m,onChange:N=>{f(N),g(h),N==="1"&&A({formula1:h==="="?"":h,formula2:w.join(",")})},children:[v.jsx(O.Radio,{value:"0",children:S.t("dataValidation.list.customOptions")}),v.jsx(O.Radio,{value:"1",children:S.t("dataValidation.list.refOptions")})]})}),m==="1"?v.jsxs(v.Fragment,{children:[v.jsx(O.FormLayout,{error:$||B,children:v.jsx(q.TextEditor,{id:s.createInternalEditorID(`list-ref-range-${t}-${a}`),value:p,openForSheetUnitId:t,openForSheetSubUnitId:a,onlyInputFormula:!0,onChange:async N=>{const G=N!=null?N:"";_(G),se(G)}})}),v.jsx(O.FormLayout,{children:v.jsx("div",{ref:u,children:W.map(N=>v.jsx(Tt,{item:N,commonProps:{onItemChange:ee},style:{marginBottom:12}},N.id))})})]}):v.jsx(O.FormLayout,{error:$,children:v.jsxs("div",{ref:u,style:{marginTop:"-12px"},children:[v.jsx(O.DraggableList,{list:L,onListChange:Y,rowHeight:32,margin:[0,12],draggableHandle:".draggableHandle",itemRender:N=>v.jsx(Tt,{item:N,commonProps:{onItemChange:Z,onItemDelete:X}},N.id),idKey:"id"}),v.jsxs("a",{className:re.dataValidationFormulaListAdd,onClick:Q,children:[v.jsx(qt,{}),S.t("dataValidation.list.add")]})]})})]})}function Sr(o){const{value:r,onChange:e,showError:t,validResult:a}=o,n=H.useDependency(s.LocaleService),i=t?a==null?void 0:a.formula1:"",l=t?a==null?void 0:a.formula2:"",[d,c]=E.useState(!((r==null?void 0:r.formula1)===void 0&&(r==null?void 0:r.formula2)===void 0));return v.jsxs(v.Fragment,{children:[v.jsx(O.FormLayout,{children:v.jsx(O.Checkbox,{checked:d,onChange:u=>{u?c(!0):(c(!1),e==null||e({...r,formula1:void 0,formula2:void 0}))},children:n.t("dataValidation.checkbox.tips")})}),d?v.jsx(O.FormLayout,{label:n.t("dataValidation.checkbox.checked"),error:i,children:v.jsx(O.Input,{className:re.dataValidationFormula,placeholder:n.t("dataValidation.panel.valuePlaceholder"),value:r==null?void 0:r.formula1,onChange:u=>{e==null||e({...r,formula1:u||void 0})}})}):null,d?v.jsx(O.FormLayout,{label:n.t("dataValidation.checkbox.unchecked"),error:l,children:v.jsx(O.Input,{className:re.dataValidationFormula,placeholder:n.t("dataValidation.panel.valuePlaceholder"),value:r==null?void 0:r.formula2,onChange:u=>{e==null||e({...r,formula2:u||void 0})}})}):null]})}const Qt="data-validation.custom-formula-input",xe="data-validation.formula-input",Zt="data-validation.list-formula-input",Jt="data-validation.checkbox-formula-input",_r=[[Qt,Ha],[xe,Ja],[Zt,vr],[Jt,Sr]],Le=1,Pe=0;function Et(o,r){return s.Tools.isBlank(o)?r.t("dataValidation.validFail.value"):s.isFormulaString(o)?r.t("dataValidation.validFail.primitive"):""}class Vr extends D.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",Jt);R(this,"canvasRender",this.injector.createInstance(vt));R(this,"_formulaService",this.injector.get(exports.DataValidationFormulaService))}skipDefaultFontRender(e,t,a){const{formula1:n,formula2:i}=this.parseFormulaSync(e,a.unitId,a.subUnitId),l=`${t!=null?t:""}`;return!l||l===`${n}`||l===`${i}`}validatorFormula(e,t,a){const{formula1:n,formula2:i}=e,l=n===i;if(s.Tools.isBlank(n)&&s.Tools.isBlank(i))return{success:!0};if(l)return{success:!1,formula1:this.localeService.t("dataValidation.validFail.checkboxEqual"),formula2:this.localeService.t("dataValidation.validFail.checkboxEqual")};const d=Et(n,this.localeService),c=Et(i,this.localeService);return{success:!d&&!c,formula1:d,formula2:c}}async parseFormula(e,t,a){var d,c;const{formula1:n=Le,formula2:i=Pe}=e,l=await this._formulaService.getRuleFormulaResult(t,a,e.uid);return{formula1:s.isFormulaString(n)?ie((d=l==null?void 0:l[0])==null?void 0:d.result):n,formula2:s.isFormulaString(i)?ie((c=l==null?void 0:l[1])==null?void 0:c.result):i}}parseFormulaSync(e,t,a){var d,c;const{formula1:n=Le,formula2:i=Pe}=e,l=this._formulaService.getRuleFormulaResultSync(t,a,e.uid);return{formula1:s.isFormulaString(n)?ie((d=l==null?void 0:l[0])==null?void 0:d.result):n,formula2:s.isFormulaString(i)?ie((c=l==null?void 0:l[1])==null?void 0:c.result):i}}async isValidType(e,t,a){const{value:n,unitId:i,subUnitId:l}=e,{formula1:d,formula2:c}=await this.parseFormula(a,i,l);return!s.Tools.isDefine(d)||!s.Tools.isDefine(c)?!0:s.Tools.isDefine(n)&&(String(n)===String(d)||String(n)===String(c))}generateRuleErrorMessage(e){return this.localeService.t("dataValidation.checkbox.error")}}const Je=[s.DataValidationOperator.BETWEEN,s.DataValidationOperator.NOT_BETWEEN];function Rr(o){return new Date((o-25569)*86400).getTime()}const ea=o=>o/86400+25569,Dr="univer-data-validation-options-button",Cr="univer-data-validation-options-button-icon",ot={dataValidationOptionsButton:Dr,dataValidationOptionsButtonIcon:Cr};function Ir(o){var c;const r=H.useDependency(s.LocaleService),e=H.useDependency(q.ComponentManager),{value:t,onChange:a,extraComponent:n}=o,[i,l]=E.useState(!1),d=n?e.get(n):null;return v.jsxs(v.Fragment,{children:[v.jsxs("div",{className:ot.dataValidationOptionsButton,onClick:()=>l(!i),children:[r.t("dataValidation.panel.options"),i?v.jsx(Gt,{className:ot.dataValidationOptionsButtonIcon}):v.jsx(Xt,{className:ot.dataValidationOptionsButtonIcon})]}),i&&v.jsxs(v.Fragment,{children:[d?v.jsx(d,{value:t,onChange:a}):null,v.jsx(O.FormLayout,{label:r.t("dataValidation.panel.invalid"),children:v.jsxs(O.RadioGroup,{value:`${(c=t.errorStyle)!=null?c:s.DataValidationErrorStyle.WARNING}`,onChange:u=>a({...t,errorStyle:+u}),children:[v.jsx(O.Radio,{value:`${s.DataValidationErrorStyle.WARNING}`,children:r.t("dataValidation.panel.showWarning")}),v.jsx(O.Radio,{value:`${s.DataValidationErrorStyle.STOP}`,children:r.t("dataValidation.panel.rejectInput")})]})}),v.jsx(O.FormLayout,{label:r.t("dataValidation.panel.messageInfo"),children:v.jsx(O.Checkbox,{checked:t.showInputMessage,onChange:()=>a({...t,showInputMessage:!t.showInputMessage}),children:r.t("dataValidation.panel.showInfo")})}),t.showInputMessage?v.jsx(O.FormLayout,{children:v.jsx(O.Input,{value:t.error,onChange:u=>a({...t,error:u})})}):null]})]})}const yr="univer-data-validation-detail-form-item",Mr="univer-data-validation-detail-buttons",wr="univer-data-validation-detail-button",Ie={dataValidationDetailFormItem:yr,dataValidationDetailButtons:Mr,dataValidationDetailButton:wr},Or=o=>s.debounce(async(r,e,t,a)=>{const n=await o.executeCommand(r,e,t);a==null||a(n)},275);function Tr(){const[o,r]=E.useState(0),e=H.useDependency(ce),t=q.useObservable(e.activeRule$,e.activeRule),{unitId:a,subUnitId:n,rule:i}=t||{},l=i.uid,d=H.useDependency(D.DataValidatorRegistryService),c=H.useDependency(q.ComponentManager),u=H.useDependency(s.ICommandService),m=H.useDependency(D.DataValidationModel),f=H.useDependency(s.LocaleService),[p,g]=E.useState(i),h=d.getValidatorItem(p.type),[_,S]=E.useState(!1),C=d.getValidatorsByScope(D.DataValidatorRegistryScope.SHEET),[V,I]=E.useState(()=>p.ranges.map(M=>({unitId:"",sheetId:"",range:M}))),w=E.useMemo(()=>Or(u),[u]);if(E.useEffect(()=>{u.onCommandExecuted(M=>{(M.id===s.UndoCommand.id||M.id===s.RedoCommand.id)&&setTimeout(()=>{const W=m.getRuleById(a,n,l);r(ee=>ee+1),W&&(g(W),I(W.ranges.map(ee=>({unitId:"",sheetId:"",range:ee}))))},20)})},[u,m,l,n,a]),!h)return null;const T=h.operators,F=h.operatorNames,j=p.operator?D.TWO_FORMULA_OPERATOR_COUNT.includes(p.operator):!1,P=()=>{h.validatorFormula(p,a,n).success?e.setActiveRule(null):S(!0)},B=q.useEvent(M=>{if(s.isUnitRangesEqual(M,V))return;I(M);const W=M.filter(Q=>(!Q.unitId||Q.unitId===a)&&(!Q.sheetId||Q.sheetId===n)).map(Q=>Q.range);if(g({...p,ranges:W}),W.length===0)return;const ee={unitId:a,subUnitId:n,ruleId:l,ranges:W};w(Ue.id,ee)}),b=M=>{if(s.shallowEqual(M,D.getRuleSetting(p)))return;g({...p,...M});const W={unitId:a,subUnitId:n,ruleId:l,setting:M};w(_t.id,W,void 0)},$=async()=>{await u.executeCommand(D.RemoveDataValidationCommand.id,{ruleId:l,unitId:a,subUnitId:n}),e.setActiveRule(null)},k={type:p.type,operator:p.operator,formula1:p.formula1,formula2:p.formula2,allowBlank:p.allowBlank},A=M=>{const W=d.getValidatorItem(M);if(!W)return;const ee=W.operators,Q=m.getRuleById(a,n,l),se=M===(Q==null?void 0:Q.type)?{...Q}:{...p,type:M,operator:ee[0],formula1:void 0,formula2:void 0};g(se),u.executeCommand(_t.id,{unitId:a,subUnitId:n,ruleId:p.uid,setting:D.getRuleSetting(se)})},L=c.get(h.formulaInput),Y=E.useMemo(()=>V.map(M=>oe.serializeRange(M.range)).join(","),[]),Z=D.getRuleOptions(p),X=M=>{s.shallowEqual(M,D.getRuleOptions(p))||(g({...p,...M}),w(sa.id,{unitId:a,subUnitId:n,ruleId:l,options:M}))};return v.jsxs("div",{children:[v.jsx(O.FormLayout,{label:f.t("dataValidation.panel.range"),children:v.jsx(q.RangeSelector,{className:Ie.dataValidationDetailFormItem,value:Y,id:s.createInternalEditorID("data-validation-detail"),openForSheetUnitId:a,openForSheetSubUnitId:n,onChange:M=>{M.some(W=>!s.isValidRange(W.range)||W.range.endColumn<W.range.startColumn||W.range.endRow<W.range.startRow)||B(M)}},o)}),v.jsx(O.FormLayout,{label:f.t("dataValidation.panel.type"),children:v.jsx(O.Select,{options:C==null?void 0:C.map(M=>({label:f.t(M.title),value:M.id})),value:p.type,onChange:A,className:Ie.dataValidationDetailFormItem})}),T!=null&&T.length?v.jsx(O.FormLayout,{label:f.t("dataValidation.panel.operator"),children:v.jsx(O.Select,{options:T.map((M,W)=>({value:`${M}`,label:F[W]})),value:`${p.operator}`,onChange:M=>{b({...k,operator:M})},className:Ie.dataValidationDetailFormItem})}):null,L?v.jsx(L,{isTwoFormula:j,value:{formula1:p.formula1,formula2:p.formula2},onChange:M=>{b({...k,...M})},showError:_,validResult:h.validatorFormula(p,a,n),unitId:a,subUnitId:n,ruleId:l},o):null,v.jsx(Ir,{value:Z,onChange:X,extraComponent:h.optionsInput}),v.jsxs("div",{className:Ie.dataValidationDetailButtons,children:[v.jsx(O.Button,{className:Ie.dataValidationDetailButton,onClick:$,children:f.t("dataValidation.panel.removeRule")}),v.jsx(O.Button,{className:Ie.dataValidationDetailButton,type:"primary",onClick:P,children:f.t("dataValidation.panel.done")})]})]})}const Er="univer-data-validation-item-container",br="univer-data-validation-item-title",Fr="univer-data-validation-item-content",Nr="univer-data-validation-item-icon",We={dataValidationItemContainer:Er,dataValidationItemTitle:br,dataValidationItemContent:Fr,dataValidationItemIcon:Nr},Lr=o=>{const{rule:r,onClick:e,unitId:t,subUnitId:a,disable:n}=o,i=H.useDependency(D.DataValidatorRegistryService),l=H.useDependency(s.ICommandService),d=H.useDependency(x.IMarkSelectionService),c=i.getValidatorItem(r.type),u=E.useRef(),[m,f]=E.useState(!1),p=g=>{l.executeCommand(D.RemoveDataValidationCommand.id,{ruleId:r.uid,unitId:t,subUnitId:a}),g.stopPropagation()};return E.useEffect(()=>()=>{var g;u.current&&((g=u.current)==null||g.forEach(h=>{h&&d.removeShape(h)}))},[d]),v.jsxs("div",{className:We.dataValidationItemContainer,onClick:e,onMouseEnter:()=>{n||(f(!0),u.current=r.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;f(!1),(g=u.current)==null||g.forEach(h=>{h&&d.removeShape(h)}),u.current=void 0},children:[v.jsx("div",{className:We.dataValidationItemTitle,children:c==null?void 0:c.generateRuleName(r)}),v.jsx("div",{className:We.dataValidationItemContent,children:r.ranges.map(g=>oe.serializeRange(g)).join(",")}),m?v.jsx("div",{className:We.dataValidationItemIcon,onClick:p,children:v.jsx(yt,{})}):null]})},Pr="univer-data-validation-list-buttons",Ar="univer-data-validation-list-button",nt={dataValidationListButtons:Pr,dataValidationListButton:Ar};function jr(){const o=H.useDependency(s.IUniverInstanceService),r=q.useObservable(()=>o.getCurrentTypeOfUnit$(s.UniverInstanceType.UNIVER_SHEET),void 0,void 0,[]);return r?v.jsx(xr,{workbook:r}):null}function xr(o){const r=H.useDependency(D.DataValidationModel),e=H.useDependency(s.IUniverInstanceService),t=H.useDependency(s.ICommandService),a=H.useDependency(y.Injector),n=H.useDependency(ce),i=H.useDependency(s.LocaleService),[l,d]=E.useState([]),{workbook:c}=o,u=q.useObservable(c.activeSheet$,void 0,!0),m=c.getUnitId(),f=u==null?void 0:u.getSheetId(),p=r.ensureManager(m,f);E.useEffect(()=>{d(p.getDataValidations());const V=p.dataValidations$.subscribe(I=>{d([...I])});return()=>{V.unsubscribe()}},[p]);const g=async()=>{const V=D.createDefaultNewRule(a),I={unitId:m,subUnitId:f,rule:V};await t.executeCommand(Be.id,I),n.setActiveRule({unitId:m,subUnitId:f,rule:V})},h=()=>{t.executeCommand(D.RemoveAllDataValidationCommand.id,{unitId:m,subUnitId:f})},S=(V=>{const w=e.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET).getActiveSheet();return V.map(F=>{const{ranges:j}=F;return(j==null?void 0:j.some(B=>{var L,Y;const{startRow:b,startColumn:$,endRow:k,endColumn:A}=B;for(let Z=b;Z<=k;Z++)for(let X=$;X<=A;X++){const M=(Y=(L=w==null?void 0:w.getCell(Z,X))==null?void 0:L.selectionProtection)==null?void 0:Y[0];if((M==null?void 0:M[qe.Edit])===!1||(M==null?void 0:M[qe.View])===!1)return!0}return!1}))?{...F,disable:!0}:{...F}})})(l),C=S==null?void 0:S.some(V=>V.disable);return v.jsxs("div",{children:[S==null?void 0:S.map(V=>{var I;return v.jsx(Lr,{unitId:m,subUnitId:f,onClick:()=>{V.disable||n.setActiveRule({unitId:m,subUnitId:f,rule:V})},rule:V,disable:(I=V.disable)!=null?I:!1},V.uid)}),v.jsxs("div",{className:nt.dataValidationListButtons,children:[l.length&&!C?v.jsx(O.Button,{className:nt.dataValidationListButton,onClick:h,children:i.t("dataValidation.panel.removeAll")}):null,v.jsx(O.Button,{className:nt.dataValidationListButton,type:"primary",onClick:g,children:i.t("dataValidation.panel.add")})]})]})}const Ur=()=>{const o=H.useDependency(ce),r=q.useObservable(o.activeRule$,o.activeRule);return r?v.jsx(Tr,{},r.rule.uid):v.jsx(jr,{})},Br="univer-dv-list-dropdown",$r="univer-dv-list-dropdown-title",Wr="univer-dv-list-dropdown-list",Hr="univer-dv-list-dropdown-list-container",kr="univer-dv-list-dropdown-selected-icon",Yr="univer-dv-list-dropdown-item-container",qr="univer-dv-list-dropdown-item",Xr="univer-dv-list-dropdown-split",Gr="univer-dv-list-dropdown-edit",he={dvListDropdown:Br,dvListDropdownTitle:$r,dvListDropdownList:Wr,dvListDropdownListContainer:Hr,dvListDropdownSelectedIcon:kr,dvListDropdownItemContainer:Yr,dvListDropdownItem:qr,dvListDropdownSplit:Xr,dvListDropdownEdit:Gr},zr=o=>{const{value:r,onChange:e,multiple:t,options:a,title:n,onEdit:i,style:l}=o;return v.jsxs("div",{className:he.dvListDropdown,style:l,children:[v.jsx("div",{className:he.dvListDropdownTitle,children:n}),v.jsx("div",{className:he.dvListDropdownList,children:v.jsx(O.Scrollbar,{children:v.jsx("div",{className:he.dvListDropdownListContainer,children:a.map((d,c)=>{const u=r.indexOf(d.value)>-1,m=()=>{let f;u?f=new Set(r.filter(g=>g!==d.value)):f=new Set(t?[...r,d.value]:[d.value]);const p=[];a.forEach(g=>{f.has(g.value)&&p.push(g.value)}),e(p)};return v.jsxs("div",{className:he.dvListDropdownItemContainer,onClick:m,children:[v.jsx("div",{className:he.dvListDropdownItem,style:{background:d.color||Ve},children:d.label}),v.jsx("div",{className:he.dvListDropdownSelectedIcon,children:u?v.jsx(kt,{}):null})]},c)})})})}),v.jsx("div",{className:he.dvListDropdownSplit}),v.jsx("div",{className:he.dvListDropdownEdit,children:v.jsx("a",{onClick:i,children:"编辑"})})]})};function Kr(o){var P,B;const{location:r,hideFn:e}=o,{worksheet:t,row:a,col:n,unitId:i,subUnitId:l}=r,d=H.useDependency(D.DataValidationModel),c=H.useDependency(s.ICommandService),u=H.useDependency(s.LocaleService),[m,f]=E.useState(""),p=H.useDependency(x.IEditorBridgeService);q.useObservable(d.ruleChange$);const g=O.RectPopup.useContext(),h=g.right-g.left;if(!t)return null;const _=t.getCell(a,n),S=(P=_==null?void 0:_.dataValidation)==null?void 0:P.rule,C=(B=_==null?void 0:_.dataValidation)==null?void 0:B.validator,V=(S==null?void 0:S.renderMode)===s.DataValidationRenderMode.CUSTOM||(S==null?void 0:S.renderMode)===void 0;if(!_||!S||!C)return;const I=S.type===s.DataValidationType.LIST_MULTIPLE,w=C.getListWithColor(S,i,l),T=m||ur(_),F=we(T),j=()=>{c.executeCommand(Re.id,{ruleId:S.uid}),e()};return v.jsx(zr,{style:{minWidth:h,maxWidth:Math.max(h,200)},title:I?u.t("dataValidation.listMultiple.dropdown"):u.t("dataValidation.list.dropdown"),value:F,multiple:I,onChange:b=>{const $=Kt(b),k={unitId:i,subUnitId:l,range:{startColumn:n,endColumn:n,startRow:a,endRow:a},value:{v:$,p:null,f:null,si:null}};p.isVisible()&&p.changeVisible({visible:!1,keycode:q.KeyCode.ESC,eventType:K.DeviceInputEventType.Keyboard}),c.executeCommand(U.SetRangeValuesCommand.id,k),f($),I||e()},options:w.map(b=>({label:b.label,value:b.label,color:V?b.color:"transparent"})),onEdit:j})}var ta={exports:{}};(function(o,r){(function(e,t){o.exports=t()})(Da,function(){var e="minute",t=/[+-]\d\d(?::?\d\d)?/g,a=/([+-]|\d\d)/g;return function(n,i,l){var d=i.prototype;l.utc=function(h){var _={date:h,utc:!0,args:arguments};return new i(_)},d.utc=function(h){var _=l(this.toDate(),{locale:this.$L,utc:!0});return h?_.add(this.utcOffset(),e):_},d.local=function(){return l(this.toDate(),{locale:this.$L,utc:!1})};var c=d.parse;d.parse=function(h){h.utc&&(this.$u=!0),this.$utils().u(h.$offset)||(this.$offset=h.$offset),c.call(this,h)};var u=d.init;d.init=function(){if(this.$u){var h=this.$d;this.$y=h.getUTCFullYear(),this.$M=h.getUTCMonth(),this.$D=h.getUTCDate(),this.$W=h.getUTCDay(),this.$H=h.getUTCHours(),this.$m=h.getUTCMinutes(),this.$s=h.getUTCSeconds(),this.$ms=h.getUTCMilliseconds()}else u.call(this)};var m=d.utcOffset;d.utcOffset=function(h,_){var S=this.$utils().u;if(S(h))return this.$u?0:S(this.$offset)?m.call(this):this.$offset;if(typeof h=="string"&&(h=function(w){w===void 0&&(w="");var T=w.match(t);if(!T)return null;var F=(""+T[0]).match(a)||["-",0,0],j=F[0],P=60*+F[1]+ +F[2];return P===0?0:j==="+"?P:-P}(h),h===null))return this;var C=Math.abs(h)<=16?60*h:h,V=this;if(_)return V.$offset=C,V.$u=h===0,V;if(h!==0){var I=this.$u?this.toDate().getTimezoneOffset():-1*this.utcOffset();(V=this.local().add(C+I,e)).$offset=C,V.$x.$localOffset=I}else V=this.utc();return V};var f=d.format;d.format=function(h){var _=h||(this.$u?"YYYY-MM-DDTHH:mm:ss[Z]":"");return f.call(this,_)},d.valueOf=function(){var h=this.$utils().u(this.$offset)?0:this.$offset+(this.$x.$localOffset||this.$d.getTimezoneOffset());return this.$d.valueOf()-6e4*h},d.isUTC=function(){return!!this.$u},d.toISOString=function(){return this.toDate().toISOString()},d.toString=function(){return this.toDate().toUTCString()};var p=d.toDate;d.toDate=function(h){return h==="s"&&this.$offset?l(this.format("YYYY-MM-DD HH:mm:ss:SSS")).toDate():p.call(this)};var g=d.diff;d.diff=function(h,_,S){if(h&&this.$u===h.$u)return g.call(this,h,_,S);var C=this.local(),V=l(h).local();return g.call(C,V,_,S)}}})})(ta);var Qr=ta.exports;const Zr=Ca(Qr);var Jr=Object.defineProperty,eo=Object.getOwnPropertyDescriptor,to=(o,r,e,t)=>{for(var a=t>1?void 0:t?eo(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&Jr(r,e,a),a},Te=(o,r)=>(e,t)=>r(e,t,o);exports.DataValidationRejectInputController=class extends s.Disposable{constructor(r,e,t,a,n){super(),this._editorBridgeService=r,this._dataValidationModel=e,this._dataValidatorRegistryService=t,this._dialogService=a,this._localeService=n,this._initEditorBridgeInterceptor()}_initEditorBridgeInterceptor(){this._editorBridgeService.interceptor.intercept(this._editorBridgeService.interceptor.getInterceptPoints().AFTER_CELL_EDIT_ASYNC,{handler:async(r,e,t)=>{const a=await r,{worksheet:n,row:i,col:l,unitId:d,subUnitId:c}=e,u=this._dataValidationModel.ensureManager(d,c),m=u.getRuleIdByLocation(i,l),f=m?u.getRuleById(m):void 0;if(!f||f.errorStyle!==s.DataValidationErrorStyle.STOP)return t(Promise.resolve(a));const p=await this._dataValidatorRegistryService.getValidatorItem(f.type);if(!p||await p.validator({value:te(a),row:i,column:l,unitId:d,subUnitId:c},f))return t(Promise.resolve(a));const h=n.getCellRaw(i,l);return this._dialogService.open({width:368,title:{title:this._localeService.t("dataValidation.alert.title")},id:"reject-input-dialog",children:{title:p.getRuleFinalError(f)},footer:{title:E.createElement(O.Button,{type:"primary",onClick:()=>this._dialogService.close("reject-input-dialog")},this._localeService.t("dataValidation.alert.ok"))},onClose:()=>{this._dialogService.close("reject-input-dialog")}}),t(Promise.resolve(h))}})}showReject(r){this._dialogService.open({width:368,title:{title:this._localeService.t("dataValidation.alert.title")},id:"reject-input-dialog",children:{title:r},footer:{title:E.createElement(O.Button,{type:"primary",onClick:()=>this._dialogService.close("reject-input-dialog")},this._localeService.t("dataValidation.alert.ok"))},onClose:()=>{this._dialogService.close("reject-input-dialog")}})}};exports.DataValidationRejectInputController=to([s.OnLifecycle(s.LifecycleStages.Ready,exports.DataValidationRejectInputController),Te(0,x.IEditorBridgeService),Te(1,y.Inject(D.DataValidationModel)),Te(2,y.Inject(D.DataValidatorRegistryService)),Te(3,q.IDialogService),Te(4,y.Inject(s.LocaleService))],exports.DataValidationRejectInputController);const ao="univer-dv-date-dropdown",ro="univer-dv-date-dropdown-btns",bt={dvDateDropdown:ao,dvDateDropdownBtns:ro};de.extend(Zr);const oo=o=>{if(!(o==null||typeof o=="boolean")){if(typeof o=="number"||!Number.isNaN(+o)){const r=de.unix(Rr(+o)).utc().format().slice(0,-1);return de(r)}return de(o)}};function no(o){var I,w,T;const{location:r,hideFn:e}=o,{worksheet:t,row:a,col:n,unitId:i,subUnitId:l}=r,d=H.useDependency(s.ICommandService),c=H.useDependency(exports.DataValidationRejectInputController),u=t.getCell(a,n),m=(I=u==null?void 0:u.dataValidation)==null?void 0:I.rule,f=(w=u==null?void 0:u.dataValidation)==null?void 0:w.validator,p=te(u),g=oo(p),[h,_]=E.useState(g),S=!!((T=m==null?void 0:m.bizInfo)!=null&&T.showTime),C=h&&h.isValid()?h:de();if(!u||!m||!f)return;const V=async()=>{if(!h)return;const j=`${h.format(S?"YYYY-MM-DD HH:mm:ss":"YYYY-MM-DD 00:00:00").split(" ").join("T")}Z`,P=ea(de(j).unix());m.errorStyle!==s.DataValidationErrorStyle.STOP||await f.validator({value:P,unitId:i,subUnitId:l,row:a,column:n},m)?(d.executeCommand(U.SetRangeValuesCommand.id,{unitId:i,subUnitId:l,range:{startColumn:n,endColumn:n,startRow:a,endRow:a},value:{v:P,t:2,p:null,f:null,si:null,s:{n:{pattern:S?"yyyy-MM-dd hh:mm:ss":"yyyy-MM-dd"}}}}),e()):c.showReject(f.getRuleFinalError(m))};return v.jsxs("div",{className:bt.dvDateDropdown,children:[v.jsx(O.DatePanel,{defaultValue:h,pickerValue:h!=null?h:C,showTime:S||void 0,onSelect:async F=>{_(F)},onPanelChange:F=>{_(F)}}),v.jsx("div",{className:bt.dvDateDropdownBtns,children:v.jsx(O.Button,{size:"small",type:"primary",onClick:V,disabled:!h,children:"确定"})})]})}const aa="data-validation.list.dropdown",ra="data-validation.date.dropdown",io={[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 so={[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"},lo={[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"},co="DATE_SHOW_TIME_OPTION";function Xe(o){var a;const{value:r,onChange:e}=o,t=H.useDependency(s.LocaleService);return v.jsx(O.FormLayout,{children:v.jsx(O.Checkbox,{checked:(a=r.bizInfo)==null?void 0:a.showTime,onChange:n=>{e({...r,bizInfo:{...r.bizInfo,showTime:n}})},children:t.t("dataValidation.showTime.label")})})}Xe.componentKey=co;const Ft="{FORMULA1}",Nt="{FORMULA2}",Ee=o=>{if(o==null||typeof o=="boolean")return;if(typeof o=="number"||!Number.isNaN(+o))return+o;const r=`${de(o).format("YYYY-MM-DD HH:mm:ss").split(" ").join("T")}Z`;return ea(de(r).unix())};class uo extends D.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",xe);R(this,"optionsInput",Xe.componentKey);R(this,"dropdown",ra);R(this,"_formulaService",this.injector.get(exports.DataValidationFormulaService))}async parseFormula(e,t,a){var d,c;const n=await this._formulaService.getRuleFormulaResult(t,a,e.uid),{formula1:i,formula2:l}=e;return{formula1:Ee(s.isFormulaString(i)?ie((d=n==null?void 0:n[0])==null?void 0:d.result):i),formula2:Ee(s.isFormulaString(l)?ie((c=n==null?void 0:n[1])==null?void 0:c.result):l)}}parseFormulaSync(e,t,a){var d,c;const n=this._formulaService.getRuleFormulaResultSync(t,a,e.uid),{formula1:i,formula2:l}=e;return{formula1:Ee(s.isFormulaString(i)?ie((d=n==null?void 0:n[0])==null?void 0:d.result):i),formula2:Ee(s.isFormulaString(l)?ie((c=n==null?void 0:n[1])==null?void 0:c.result):l)}}async isValidType(e){const{value:t}=e;return typeof t=="string"?de(t).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 n=e.operator;if(!n)return{success:!1};const i=this._validatorSingleFormula(e.formula1),l=this.localeService.t("dataValidation.validFail.date");if(Je.includes(n)){const c=this._validatorSingleFormula(e.formula2);return{success:i&&c,formula1:i?void 0:l,formula2:c?void 0:l}}return{success:i,formula1:i?void 0:l}}transform(e,t,a){const{value:n}=e;return{...e,value:Ee(n)}}async validatorIsEqual(e,t,a){const{formula1:n}=t,{value:i}=e;return Number.isNaN(n)?!0:i===n}async validatorIsNotEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value!==n}async validatorIsBetween(e,t,a){const{formula1:n,formula2:i}=t;if(Number.isNaN(n)||Number.isNaN(i))return!0;const l=Math.min(n,i),d=Math.max(n,i);return e.value>=l&&e.value<=d}async validatorIsNotBetween(e,t,a){const{formula1:n,formula2:i}=t;if(Number.isNaN(n)||Number.isNaN(i))return!0;const l=Math.min(n,i),d=Math.max(n,i);return e.value<l||e.value>d}async validatorIsGreaterThan(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value>n}async validatorIsGreaterThanOrEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value>=n}async validatorIsLessThan(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value<n}async validatorIsLessThanOrEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value<=n}get operatorNames(){return this.operators.map(e=>this.localeService.t(io[e]))}generateRuleName(e){var a,n;if(!e.operator)return this.titleStr;const t=this.localeService.t(so[e.operator]).replace(Ft,(a=e.formula1)!=null?a:"").replace(Nt,(n=e.formula2)!=null?n:"");return`${this.titleStr} ${t}`}generateRuleErrorMessage(e){var a,n;return e.operator?`${this.localeService.t(lo[e.operator]).replace(Ft,(a=e.formula1)!=null?a:"").replace(Nt,(n=e.formula2)!=null?n:"")}`:this.titleStr}}var ho=Object.defineProperty,mo=Object.getOwnPropertyDescriptor,po=(o,r,e,t)=>{for(var a=t>1?void 0:t?mo(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&ho(r,e,a),a},Lt=(o,r)=>(e,t)=>r(e,t,o);const ye=4,fo=6,le=14,ve=6,pe=4,go="#565656",Pt=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 vo(o,r){const e=o.length;return{id:"d",body:{dataStream:`${o}${s.DEFAULT_EMPTY_DOCUMENT_VALUE}`,textRuns:[{ts:{fs:11,ff:void 0,it:s.BooleanNumber.FALSE,bl:s.BooleanNumber.FALSE,ul:{s:s.BooleanNumber.FALSE},st:{s:s.BooleanNumber.FALSE},ol:{s:s.BooleanNumber.FALSE},cl:void 0,...r,bg:void 0,bd:void 0},st:0,ed:e}]},documentStyle:{pageSize:{width:Number.POSITIVE_INFINITY,height:Number.POSITIVE_INFINITY}}}}function oa(o,r,e){const t=vo(o,e),a=new s.DocumentDataModel(t),n=new K.DocumentViewModel(a);return{documentSkeleton:K.DocumentSkeleton.create(n,r),docModel:a,docViewModel:n}}function it(o,r,e){const{documentSkeleton:t,docModel:a,docViewModel:n}=oa(o,r,e);return{documents:new K.Documents(`DOCUMENTS_${s.Tools.generateRandomId()}`,t,{pageMarginLeft:0,pageMarginTop:0}),documentSkeleton:t,docModel:a,docViewModel:n}}function At(o,r,e,t,a,n){let i=0;switch(a){case s.VerticalAlign.BOTTOM:i=r-pe*2-t+pe;break;case s.VerticalAlign.MIDDLE:i=(r-pe*2-t)/2+pe;break;default:i=pe;break}let l=0;switch(n){case s.HorizontalAlign.CENTER:l=(o-e)/2;break;case s.HorizontalAlign.RIGHT:l=o-e;break}return{paddingLeft:l,paddingTop:i}}var gt;let St=(gt=class{constructor(o,r){R(this,"_dropdownInfoMap",new Map);R(this,"zIndex");R(this,"onPointerEnter");R(this,"onPointerLeave");this._localeService=o,this._commandService=r}_ensureMap(o){let r=this._dropdownInfoMap.get(o);return r||(r=new Map,this._dropdownInfoMap.set(o,r)),r}_generateKey(o,r){return`${o}.${r}`}_drawDownIcon(o,r,e,t,a){const n=e-le+4;let i=9;switch(a){case s.VerticalAlign.MIDDLE:i=(t-le)/2+4;break;case s.VerticalAlign.BOTTOM:i=t-le-1;break}o.save(),o.translateWithPrecision(r.startX+n,r.startY+i),o.fillStyle="#565656",o.fill(Pt),o.restore()}drawWith(o,r,e){var k,A;const{primaryWithCoord:t,row:a,col:n,style:i,data:l,subUnitId:d}=r,c=t.isMergedMainCell?t.mergeInfo:t,u=(k=l.dataValidation)==null?void 0:k.rule,m=(A=l.dataValidation)==null?void 0:A.validator,f=l.fontRenderExtension,{leftOffset:p=0,rightOffset:g=0,topOffset:h=0,downOffset:_=0}=f||{};if(!u||!m||!m.skipDefaultFontRender(u))return;const S={startX:c.startX+p,endX:c.endX-g,startY:c.startY+h,endY:c.endY-_},C=S.endX-S.startX,V=S.endY-S.startY,I=this._ensureMap(d),w=this._generateKey(a,n),T=m.getListWithColor(u),F=te(l),j=`${F!=null?F:""}`,P=T.find(L=>L.label===j);let{tb:B,vt:b,ht:$}=i||{};if(B=B!=null?B:s.WrapStrategy.WRAP,b=b!=null?b:s.VerticalAlign.BOTTOM,$=$!=null?$:s.HorizontalAlign.LEFT,u.renderMode===s.DataValidationRenderMode.ARROW){this._drawDownIcon(o,S,C,V,b),o.save(),o.translateWithPrecision(S.startX,S.startY),o.beginPath(),o.rect(0,0,C,V),o.clip();const L=C-le,{documentSkeleton:Y,documents:Z,docModel:X}=it(j,this._localeService,i);B===s.WrapStrategy.WRAP&&X.updateDocumentDataPageSize(Math.max(L,1)),Y.calculate(),Y.getActualSize();const M=K.getDocsSkeletonPageSize(Y),{height:W,width:ee}=M,{paddingTop:Q,paddingLeft:se}=At(L,V,ee,W,b,$);o.translate(0,Q),o.save(),o.translateWithPrecision(ye,0),o.beginPath(),o.rect(0,0,L,W),o.clip(),Z.render(o),o.translateWithPrecision(se,0),o.restore(),o.restore(),I.set(w,{left:S.endX+e.rowHeaderWidth-le,top:S.startY+e.columnHeaderHeight,width:le,height:V})}else{o.save(),o.translateWithPrecision(S.startX,S.startY),o.beginPath(),o.rect(0,0,C,V),o.clip();const L=C-ve*2-ye-le,{documentSkeleton:Y,documents:Z,docModel:X}=it(j,this._localeService,i);B===s.WrapStrategy.WRAP&&X.updateDocumentDataPageSize(Math.max(L,1)),Y.calculate();const M=K.getDocsSkeletonPageSize(Y),{height:W,width:ee}=M,{paddingTop:Q,paddingLeft:se}=At(L,V,ee,W,b,$);o.translate(ve,Q);const N=Math.max(C-ve*2,1),G=W;K.Rect.drawWith(o,{width:N,height:G,fill:(P==null?void 0:P.color)||Ve,radius:8}),o.save(),o.translateWithPrecision(ye,0),o.beginPath(),o.rect(0,0,L,W),o.clip(),o.translateWithPrecision(se,0),Z.render(o),o.restore(),o.translate(L+ye+4,(W-fo)/2),o.fillStyle=go,o.fill(Pt),o.restore(),I.set(w,{left:S.startX+ve+e.rowHeaderWidth,top:S.startY+Q+e.columnHeaderHeight,width:N,height:G})}}calcCellAutoHeight(o){var _;const{primaryWithCoord:r,style:e,data:t}=o,a=r.isMergedMainCell?r.mergeInfo:r,n=t.fontRenderExtension,{leftOffset:i=0,rightOffset:l=0,topOffset:d=0,downOffset:c=0}=n||{},u=(_=t.dataValidation)==null?void 0:_.rule;if(!u||u.renderMode===s.DataValidationRenderMode.TEXT)return;const m={startX:a.startX+i,endX:a.endX-l,startY:a.startY+d,endY:a.endY-c},f=m.endX-m.startX,p=te(t),g=`${p!=null?p:""}`;let{tb:h}=e||{};if(h=h!=null?h:s.WrapStrategy.WRAP,u.renderMode===s.DataValidationRenderMode.ARROW){const S=f-le,{documentSkeleton:C,docModel:V}=it(g,this._localeService,e);h===s.WrapStrategy.WRAP&&V.updateDocumentDataPageSize(Math.max(S,1)),C.calculate(),C.getActualSize();const I=K.getDocsSkeletonPageSize(C),{height:w}=I;return w}else{const S=f-ve*2-ye-le,{documentSkeleton:C,docModel:V}=oa(g,this._localeService,e);h===s.WrapStrategy.WRAP&&V.updateDocumentDataPageSize(Math.max(S,1)),C.calculate();const I=K.getDocsSkeletonPageSize(C),{height:w}=I;return w+pe*2}}isHit(o,r){const{data:e,subUnitId:t,row:a,col:n}=r,l=this._ensureMap(t).get(this._generateKey(a,n)),d=e.dataValidation;if(!d||!l||d.rule.renderMode===s.DataValidationRenderMode.TEXT)return!1;const{top:c,left:u,width:m,height:f}=l,{x:p,y:g}=o;return p>=u&&p<=u+m&&g>=c&&g<=c+f}onPointerDown(o,r){if(r.button===2)return;const{unitId:e,subUnitId:t,row:a,col:n}=o,i={unitId:e,subUnitId:t,row:a,column:n};this._commandService.executeCommand(Ae.id,i)}},R(gt,"padding",{l:ve+ye,r:le+ve,t:pe,b:pe}),gt);St=po([Lt(0,y.Inject(s.LocaleService)),Lt(1,s.ICommandService)],St);const So="LIST_RENDER_MODE_OPTION_INPUT";function Ge(o){var a;const{value:r,onChange:e}=o,t=H.useDependency(s.LocaleService);return v.jsx(O.FormLayout,{label:t.t("dataValidation.renderMode.label"),children:v.jsxs(O.RadioGroup,{value:`${(a=r.renderMode)!=null?a:s.DataValidationRenderMode.CUSTOM}`,onChange:n=>e({...r,renderMode:+n}),children:[v.jsx(O.Radio,{value:`${s.DataValidationRenderMode.CUSTOM}`,children:t.t("dataValidation.renderMode.chip")}),v.jsx(O.Radio,{value:`${s.DataValidationRenderMode.ARROW}`,children:t.t("dataValidation.renderMode.arrow")}),v.jsx(O.Radio,{value:`${s.DataValidationRenderMode.TEXT}`,children:t.t("dataValidation.renderMode.text")})]})})}Ge.componentKey=So;function st(o){if(!o)return[];const r=new Set;return o.forEach(e=>{e.forEach(t=>{var n,i;const a=te(t);if(a!=null){if(typeof a!="string"&&typeof(t==null?void 0:t.s)=="object"&&((i=(n=t.s)==null?void 0:n.n)!=null&&i.pattern)){r.add(Ra.format(t.s.n.pattern,a));return}r.add(a.toString())}})}),[...r]}const _o=["if","indirect","choose","offset"];function Vo(o,r){if(!s.isFormulaString(o)||oe.isReferenceString(o.slice(1)))return!0;const t=r.sequenceNodesBuilder(o);return t&&t.some(a=>typeof a=="object"&&a.nodeType===oe.sequenceNodeType.FUNCTION&&_o.indexOf(a.token.toLowerCase())>-1)}function Ro(o,r){const{formula1:e="",ranges:t}=o;if(oe.isReferenceString(e.slice(1))){const n=oe.deserializeRangeWithSheet(e.slice(1));if((!n.sheetName||n.sheetName===r)&&t.some(i=>s.Rectangle.intersects(i,n.range)))return!0}return!1}class na extends D.BaseDataValidator{constructor(){super(...arguments);R(this,"formulaService",this.injector.get(exports.DataValidationFormulaService));R(this,"_lexer",this.injector.get(oe.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",Zt);R(this,"canvasRender",this.injector.createInstance(St));R(this,"dropdown",aa);R(this,"optionsInput",Ge.componentKey)}skipDefaultFontRender(e){return e.renderMode!==s.DataValidationRenderMode.TEXT}validatorFormula(e,t,a){var c,u,m;const n=!s.Tools.isBlank(e.formula1),i=Vo((c=e.formula1)!=null?c:"",this._lexer),l=(m=(u=this._univerInstanceService.getUnit(t,s.UniverInstanceType.UNIVER_SHEET))==null?void 0:u.getSheetBySheetId(a))==null?void 0:m.getName(),d=Ro(e,l!=null?l:"");return{success:!!(n&&i&&!d),formula1:n?i?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 we(t)}async parseFormula(e,t,a){var l;const{formula1:n=""}=e,i=await this.formulaService.getRuleFormulaResult(t,a,e.uid);return{formula1:s.isFormulaString(n)?st((l=i==null?void 0:i[0])==null?void 0:l.result):we(n),formula2:void 0}}async isValidType(e,t,a){const{value:n}=e,{formula1:i=[]}=t;return this.parseCellValue(n).every(d=>i.includes(d))}generateRuleName(){return this.localeService.t("dataValidation.list.name")}generateRuleErrorMessage(){return this.localeService.t("dataValidation.list.error")}getList(e,t,a){var f,p,g;const{formula1:n=""}=e,i=this.injector.get(s.IUniverInstanceService),l=(f=t?i.getUniverSheetInstance(t):void 0)!=null?f:i.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET);if(!l)return[];const d=(p=a?l.getSheetBySheetId(a):void 0)!=null?p:l.getActiveSheet();if(!d)return[];const c=l.getUnitId(),u=d.getSheetId(),m=this.formulaService.getRuleFormulaResultSync(c,u,e.uid);return s.isFormulaString(n)?st((g=m==null?void 0:m[0])==null?void 0:g.result):we(n)}async getListAsync(e,t,a){var f,p,g;const{formula1:n=""}=e,i=this.injector.get(s.IUniverInstanceService),l=(f=t?i.getUniverSheetInstance(t):void 0)!=null?f:i.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET);if(!l)return[];const d=(p=a?l.getSheetBySheetId(a):void 0)!=null?p:l.getActiveSheet();if(!d)return[];const c=l.getUnitId(),u=d.getSheetId(),m=await this.formulaService.getRuleFormulaResult(c,u,e.uid);return s.isFormulaString(n)?st((g=m==null?void 0:m[0])==null?void 0:g.result):we(n)}getListWithColor(e,t,a){const n=this.getList(e,t,a),i=(e.formula2||"").split(",");return n.map((l,d)=>({label:l,color:i[d]}))}getListWithColorMap(e,t,a){const n=this.getListWithColor(e,t,a),i={};return n.forEach(l=>{l.color&&(i[l.label]=l.color)}),i}}function ze(o){let r=o;return typeof o=="string"?((o.startsWith("¥")||o.startsWith("$"))&&(r=o.slice(1)),+r):+o}class Do extends D.BaseDataValidator{constructor(){super(...arguments);R(this,"_formulaService",this.injector.get(exports.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",xe);R(this,"dropDownInput")}_isFormulaOrNumber(e){return!s.Tools.isBlank(e)&&(s.isFormulaString(e)||!Number.isNaN(+e))}async isValidType(e,t,a){const{value:n}=e;return!Number.isNaN(ze(n))}transform(e,t,a){const{value:n}=e;return{...e,value:ze(n)}}_parseNumber(e){return e==null?Number.NaN:+e}async parseFormula(e,t,a){var c,u,m,f,p,g,h,_;const n=await this._formulaService.getRuleFormulaResult(t,a,e.uid),{formula1:i,formula2:l}=e;return{formula1:this._parseNumber(s.isFormulaString(i)?(f=(m=(u=(c=n==null?void 0:n[0])==null?void 0:c.result)==null?void 0:u[0])==null?void 0:m[0])==null?void 0:f.v:i),formula2:this._parseNumber(s.isFormulaString(l)?(_=(h=(g=(p=n==null?void 0:n[1])==null?void 0:p.result)==null?void 0:g[0])==null?void 0:h[0])==null?void 0:_.v:l)}}validatorFormula(e,t,a){const n=e.operator;if(!n)return{success:!1};const i=s.Tools.isDefine(e.formula1)&&this._isFormulaOrNumber(e.formula1),l=s.Tools.isDefine(e.formula2)&&this._isFormulaOrNumber(e.formula2),d=Je.includes(n),c=this.localeService.t("dataValidation.validFail.number");return d?{success:i&&l,formula1:i?void 0:c,formula2:l?void 0:c}:{success:i,formula1:i?"":c}}async validatorIsEqual(e,t,a){const{formula1:n}=t,{value:i}=e;return Number.isNaN(n)?!0:i===n}async validatorIsNotEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value!==n}async validatorIsBetween(e,t,a){const{formula1:n,formula2:i}=t;if(Number.isNaN(n)||Number.isNaN(i))return!0;const l=Math.min(n,i),d=Math.max(n,i);return e.value>=l&&e.value<=d}async validatorIsNotBetween(e,t,a){const{formula1:n,formula2:i}=t;if(Number.isNaN(n)||Number.isNaN(i))return!0;const l=Math.min(n,i),d=Math.max(n,i);return e.value<l||e.value>d}async validatorIsGreaterThan(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value>n}async validatorIsGreaterThanOrEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value>=n}async validatorIsLessThan(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value<n}async validatorIsLessThanOrEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value<=n}}const Co="{FORMULA1}",Io="{FORMULA2}";class yo extends D.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",xe);R(this,"_formulaService",this.injector.get(exports.DataValidationFormulaService))}_isFormulaOrInt(e){return!s.Tools.isBlank(e)&&(s.isFormulaString(e)||!Number.isNaN(+e)&&Number.isInteger(+e))}validatorFormula(e,t,a){const n=e.operator;if(!n)return{success:!1};const i=s.Tools.isDefine(e.formula1)&&this._isFormulaOrInt(e.formula1),l=s.Tools.isDefine(e.formula2)&&this._isFormulaOrInt(e.formula2),d=Je.includes(n),c=this.localeService.t("dataValidation.validFail.number");return d?{success:i&&l,formula1:i?void 0:c,formula2:l?void 0:c}:{success:i,formula1:c}}_parseNumber(e){return e==null?Number.NaN:+e}_isValidFormula(e){return!Number.isNaN(e)}async parseFormula(e,t,a){var d,c,u,m,f,p,g,h;const n=await this._formulaService.getRuleFormulaResult(t,a,e.uid),{formula1:i,formula2:l}=e;return{formula1:this._parseNumber(s.isFormulaString(i)?(m=(u=(c=(d=n==null?void 0:n[0])==null?void 0:d.result)==null?void 0:c[0])==null?void 0:u[0])==null?void 0:m.v:i),formula2:this._parseNumber(s.isFormulaString(l)?(h=(g=(p=(f=n==null?void 0:n[1])==null?void 0:f.result)==null?void 0:p[0])==null?void 0:g[0])==null?void 0:h.v:l)}}transform(e,t,a){return{...e,value:e.value.toString().length}}async isValidType(e,t,a){const{value:n}=e;return typeof n=="string"||typeof n=="number"}async validatorIsEqual(e,t,a){const{formula1:n}=t;return s.Tools.isDefine(n)?e.value===n:!1}async validatorIsNotEqual(e,t,a){const{formula1:n}=t;return s.Tools.isDefine(n)?e.value!==n:!1}async validatorIsBetween(e,t,a){const{formula1:n,formula2:i}=t,{value:l}=e;if(!this._isValidFormula(n)||!this._isValidFormula(i))return!1;const d=Math.max(n,i),c=Math.min(n,i);return l>=c&&l<=d}async validatorIsNotBetween(e,t,a){const{formula1:n,formula2:i}=t,{value:l}=e;if(!this._isValidFormula(n)||!this._isValidFormula(i))return!1;const d=Math.max(n,i),c=Math.min(n,i);return l<c||l>d}async validatorIsGreaterThan(e,t,a){const{formula1:n}=t,{value:i}=e;return this._isValidFormula(n)?i>n:!1}async validatorIsGreaterThanOrEqual(e,t,a){const{formula1:n}=t,{value:i}=e;return this._isValidFormula(n)?i>=n:!1}async validatorIsLessThan(e,t,a){const{formula1:n}=t,{value:i}=e;return this._isValidFormula(n)?i<n:!1}async validatorIsLessThanOrEqual(e,t,a){const{formula1:n}=t,{value:i}=e;return this._isValidFormula(n)?i<=n:!1}generateRuleErrorMessage(e){var a,n;return e.operator?`${this.localeService.t(D.TextLengthErrorTitleMap[e.operator]).replace(Co,(a=e.formula1)!=null?a:"").replace(Io,(n=e.formula2)!=null?n:"")}`:this.titleStr}}function ia(o){var e,t;return o?o.p?!((t=(e=o.p.body)==null?void 0:e.dataStream)!=null?t:"").slice(0,-2).trim():s.Tools.isBlank(o.v):!0}function Oe(o,r,e,t){const a=[],n=[],l=t.get(D.DataValidationModel).ensureManager(o,r),d=t.get(s.IUniverInstanceService),c=U.getSheetCommandTarget(d,{unitId:o,subUnitId:r});if(!c)return{redoMutations:a,undoMutations:n};const{worksheet:u}=c,m=new s.ObjectMatrix;function f(h,_){h.forEach(S=>{s.Range.foreach(S,(C,V)=>{const I=u.getCellRaw(C,V),w=xt(I);(ia(I)||w===_)&&m.setValue(C,V,{v:_,p:null})})})}e.forEach(h=>{switch(h.type){case"delete":a.push({id:D.RemoveDataValidationMutation.id,params:{unitId:o,subUnitId:r,ruleId:h.rule.uid}}),n.unshift({id:D.AddDataValidationMutation.id,params:{unitId:o,subUnitId:r,rule:h.rule,index:h.index}});break;case"update":{a.push({id:D.UpdateDataValidationMutation.id,params:{unitId:o,subUnitId:r,ruleId:h.ruleId,payload:{type:D.UpdateRuleType.RANGE,payload:h.newRanges}}}),n.unshift({id:D.UpdateDataValidationMutation.id,params:{unitId:o,subUnitId:r,ruleId:h.ruleId,payload:{type:D.UpdateRuleType.RANGE,payload:h.oldRanges}}});const _=l.getRuleById(h.ruleId);if(_&&_.type===s.DataValidationType.CHECKBOX){const C=l.getValidator(s.DataValidationType.CHECKBOX).parseFormulaSync(_,o,r);f(h.newRanges,C.formula2)}break}case"add":{if(a.push({id:D.AddDataValidationMutation.id,params:{unitId:o,subUnitId:r,rule:h.rule}}),n.unshift({id:D.RemoveDataValidationMutation.id,params:{unitId:o,subUnitId:r,ruleId:h.rule.uid}}),h.rule.type===s.DataValidationType.CHECKBOX){const S=l.getValidator(s.DataValidationType.CHECKBOX).parseFormulaSync(h.rule,o,r);f(h.rule.ranges,S.formula2)}break}}});const p={id:U.SetRangeValuesMutation.id,params:{unitId:o,subUnitId:r,cellValue:m.getData()}},g={id:U.SetRangeValuesMutation.id,params:U.SetRangeValuesUndoMutationFactory(t,p.params)};return a.push(p),n.push(g),{redoMutations:a,undoMutations:n}}const Ue={type:s.CommandType.COMMAND,id:"sheet.command.updateDataValidationRuleRange",async handler(o,r){if(!r)return!1;const{unitId:e,subUnitId:t,ranges:a,ruleId:n}=r,i=o.get(D.DataValidationModel),l=o.get(s.ICommandService),d=o.get(s.IUndoRedoService),c=i.ensureManager(e,t),u=c.getRuleById(n);if(!u)return!1;const m=u.ranges,f=c.getRuleObjectMatrix().clone();f.updateRange(n,m,a);const p=f.diff(c.getDataValidations()),{redoMutations:g,undoMutations:h}=Oe(e,t,p,o);return d.pushUndoRedo({undoMutations:h,redoMutations:g,unitID:e}),await s.sequenceExecuteAsync(g,l),!0}},Be={type:s.CommandType.COMMAND,id:"sheet.command.addDataValidation",async handler(o,r){if(!r)return!1;const{unitId:e,subUnitId:t,rule:a}=r,n=o.get(D.DataValidationModel),i=o.get(s.ICommandService),l=o.get(s.IUndoRedoService),d=n.ensureManager(e,t),c=d.getRuleObjectMatrix().clone();c.addRule(a);const u=c.diff(d.getDataValidations()),m={unitId:e,subUnitId:t,rule:a},{redoMutations:f,undoMutations:p}=Oe(e,t,u,o);return f.push({id:D.AddDataValidationMutation.id,params:m}),p.unshift({id:D.RemoveDataValidationMutation.id,params:{unitId:e,subUnitId:t,ruleId:a.uid}}),l.pushUndoRedo({unitID:e,redoMutations:f,undoMutations:p}),await s.sequenceExecuteAsync(f,i),!0}},et={type:s.CommandType.COMMAND,id:"data-validation.command.addRuleAndOpen",async handler(o){const r=o.get(s.IUniverInstanceService),e=U.getSheetCommandTarget(r);if(!e)return!1;const{workbook:t,worksheet:a}=e,n=D.createDefaultNewRule(o),i=o.get(s.ICommandService),l=t.getUnitId(),d=a.getSheetId(),c={rule:n,unitId:l,subUnitId:d};return await i.executeCommand(Be.id,c)?(i.executeCommand(Re.id,{ruleId:n.uid,isAdd:!0}),!0):!1}},_t={type:s.CommandType.COMMAND,id:"sheets.command.update-data-validation-setting",handler(o,r){if(!r)return!1;const e=o.get(s.ICommandService),t=o.get(s.IUndoRedoService),a=o.get(D.DataValidationModel),n=o.get(D.DataValidatorRegistryService),{unitId:i,subUnitId:l,ruleId:d,setting:c}=r,u=n.getValidatorItem(c.type);if(!u)return!1;const m=a.getRuleById(i,l,d);if(!m||!u.validatorFormula({...m,...c},i,l).success)return!1;const f={unitId:i,subUnitId:l,ruleId:d,payload:{type:D.UpdateRuleType.SETTING,payload:c}},p=[{id:D.UpdateDataValidationMutation.id,params:f}],g={unitId:i,subUnitId:l,ruleId:d,payload:{type:D.UpdateRuleType.SETTING,payload:D.getRuleSetting(m)}},h=[{id:D.UpdateDataValidationMutation.id,params:g}];if(c.type===s.DataValidationType.CHECKBOX){const S=m.ranges,C=o.get(s.IUniverInstanceService),V=U.getSheetCommandTarget(C,{unitId:i,subUnitId:l});if(V){const I=new s.ObjectMatrix,{worksheet:w}=V,{formula2:T=Pe,formula1:F=Le}=m,{formula2:j=Pe,formula1:P=Le}=c;S.forEach($=>{s.Range.foreach($,(k,A)=>{const L=w.getCellRaw(k,A),Y=xt(L);ia(L)||Y===String(T)?I.setValue(k,A,{v:j,p:null}):Y===String(F)&&I.setValue(k,A,{v:P,p:null})})});const B={id:U.SetRangeValuesMutation.id,params:{unitId:i,subUnitId:l,cellValue:I.getData()}},b={id:U.SetRangeValuesMutation.id,params:U.SetRangeValuesUndoMutationFactory(o,B.params)};p.push(B),h.push(b)}}return s.sequenceExecute(p,e).result?(t.pushUndoRedo({unitID:i,redoMutations:p,undoMutations:h}),!0):!1}},sa={type:s.CommandType.COMMAND,id:"sheets.command.update-data-validation-options",handler(o,r){if(!r)return!1;const e=o.get(s.ICommandService),t=o.get(s.IUndoRedoService),a=o.get(D.DataValidationModel),{unitId:n,subUnitId:i,ruleId:l,options:d}=r,c=a.getRuleById(n,i,l);if(!c)return!1;const u={unitId:n,subUnitId:i,ruleId:l,payload:{type:D.UpdateRuleType.OPTIONS,payload:d}},m=[{id:D.UpdateDataValidationMutation.id,params:u}],f={unitId:n,subUnitId:i,ruleId:l,payload:{type:D.UpdateRuleType.OPTIONS,payload:D.getRuleOptions(c)}},p=[{id:D.UpdateDataValidationMutation.id,params:f}];return t.pushUndoRedo({unitID:n,redoMutations:m,undoMutations:p}),e.executeCommand(D.UpdateDataValidationMutation.id,u),!0}},la="data-validation-single",Mt="sheet.menu.data-validation";function Mo(o){return{id:Mt,type:q.MenuItemType.SUBITEMS,positions:[q.MenuPosition.TOOLBAR_START],group:q.MenuGroup.TOOLBAR_FORMULAS_INSERT,icon:la,tooltip:"dataValidation.title",hidden$:q.getMenuHiddenObservable(o,s.UniverInstanceType.UNIVER_SHEET),disabled$:x.getCurrentRangeDisable$(o,{workbookTypes:[U.WorkbookEditablePermission],worksheetTypes:[U.WorksheetSetCellStylePermission,U.WorksheetEditPermission],rangeTypes:[U.RangeProtectionPermissionEditPoint]})}}function wo(o){return{id:Re.id,title:"dataValidation.panel.title",type:q.MenuItemType.BUTTON,positions:[Mt]}}function Oo(o){return{id:et.id,title:"dataValidation.panel.add",type:q.MenuItemType.BUTTON,positions:[Mt]}}var To=Object.defineProperty,Eo=Object.getOwnPropertyDescriptor,da=(o,r,e,t)=>{for(var a=t>1?void 0:t?Eo(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&To(r,e,a),a},J=(o,r)=>(e,t)=>r(e,t,o);const ca={},ua={tr:{size:6,color:"#fe4b4b"}};exports.SheetsDataValidationRenderController=class extends s.RxDisposable{constructor(r,e,t,a,n,i,l,d,c,u,m,f,p){super(),this._config=r,this._commandService=e,this._menuService=t,this._renderManagerService=a,this._univerInstanceService=n,this._autoHeightController=i,this._componentManager=l,this._dropdownManagerService=d,this._dataValidationModel=c,this._dataValidatorRegistryService=u,this._injector=m,this._sheetInterceptorService=f,this._editorBridgeService=p,this._initMenu(),this._initSkeletonChange(),this._initDropdown(),this._initViewModelIntercept(),this._initAutoHeight()}_initMenu(){const{menu:r={}}=this._config;[Mo,wo,Oo].forEach(e=>{this.disposeWithMe(this._menuService.addMenuItem(e(this._injector),r))})}_initDropdown(){this._editorBridgeService&&this.disposeWithMe(this._editorBridgeService.visible$.subscribe(r=>{if(!r.visible)return;const e=this._editorBridgeService.getEditCellState();if(e){const{unitId:t,sheetId:a,row:n,column:i}=e,l=this._univerInstanceService.getUniverSheetInstance(t);if(!l)return;const c=this._dataValidationModel.ensureManager(t,a).getRuleByLocation(n,i);if(!c)return;const u=this._dataValidatorRegistryService.getValidatorItem(c.type);if(!(u!=null&&u.dropdown))return;const m=l.getActiveSheet();if(!m)return;const f=this._dropdownManagerService.activeDropdown,p=f==null?void 0:f.location;if(p&&p.unitId===t&&p.subUnitId===a&&p.row===n&&p.col===i)return;this._dropdownManagerService.showDropdown({location:{unitId:t,subUnitId:a,row:n,col:i,workbook:l,worksheet:m},componentKey:u.dropdown,onHide:()=>{}})}}))}_initSkeletonChange(){const r=()=>{var l,d,c;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 n=(c=(d=this._renderManagerService.getRenderById(t))==null?void 0:d.with(x.SheetSkeletonManagerService).getWorksheetSkeleton(a))==null?void 0:c.skeleton,i=this._renderManagerService.getRenderById(t);n==null||n.makeDirty(!0),n==null||n.calculate(),i&&i.mainComponent.makeForceDirty()};this.disposeWithMe(this._dataValidationModel.ruleChange$.subscribe(()=>r())),this.disposeWithMe(this._dataValidationModel.validStatusChange$.subscribe(()=>r()))}_initViewModelIntercept(){this.disposeWithMe(this._sheetInterceptorService.intercept(U.INTERCEPTOR_POINT.CELL_CONTENT,{priority:200,handler:(r,e,t)=>{var w,T,F,j,P,B;const{row:a,col:n,unitId:i,subUnitId:l,workbook:d,worksheet:c}=e,u=this._dataValidationModel.ensureManager(i,l);if(!u)return t(r);const m=(T=(w=this._renderManagerService.getRenderById(i))==null?void 0:w.with(x.SheetSkeletonManagerService).getWorksheetSkeleton(l))==null?void 0:T.skeleton;if(!m)return t(r);const f=e.workbook.getStyles(),p=(typeof(r==null?void 0:r.s)=="string"?f.get(r==null?void 0:r.s):r==null?void 0:r.s)||{},g=u.getRuleIdByLocation(a,n);if(!g)return t(r);const h=u.getRuleById(g);if(!h)return t(r);const _=c.getCellRaw(e.row,e.col),S=this._dataValidationModel.validator(te(_),h,e),C=this._dataValidatorRegistryService.getValidatorItem(h.type),V=te(r);let I={};if((h.type===s.DataValidationType.LIST||h.type===s.DataValidationType.LIST_MULTIPLE)&&(I={interceptorStyle:{...r==null?void 0:r.interceptorStyle,tb:(F=p.tb!==s.WrapStrategy.OVERFLOW?p.tb:s.WrapStrategy.CLIP)!=null?F:s.WrapStrategy.WRAP}}),h.type===s.DataValidationType.CHECKBOX&&(I={interceptorStyle:{...r==null?void 0:r.interceptorStyle,tb:s.WrapStrategy.CLIP}}),h.type===s.DataValidationType.LIST&&(h.renderMode===s.DataValidationRenderMode.ARROW||h.renderMode===s.DataValidationRenderMode.TEXT)){const b=C.getListWithColorMap(h),$=`${(j=te(r))!=null?j:""}`,k=b[$];k&&(I={...I,interceptorStyle:{...I.interceptorStyle,bg:{rgb:k}}})}return t({...r,...I,dataValidation:{ruleId:g,validStatus:S,rule:h,validator:C},markers:{...r==null?void 0:r.markers,...S===s.DataValidationStatus.INVALID?ua:null},customRender:[...(P=r==null?void 0:r.customRender)!=null?P:[],...C!=null&&C.canvasRender?[C.canvasRender]:[]],fontRenderExtension:{...r==null?void 0:r.fontRenderExtension,isSkip:C==null?void 0:C.skipDefaultFontRender(h,V,e)},interceptorStyle:{...r==null?void 0:r.interceptorStyle,...I.interceptorStyle},get interceptorAutoHeight(){var k,A,L,Y;const b=m.mergeData.find(Z=>{const{startColumn:X,startRow:M,endColumn:W,endRow:ee}=Z;return a>=M&&n>=X&&a<=ee&&n<=W}),$={data:{...r,dataValidation:{ruleId:g,validStatus:S,rule:h,validator:C}},style:m.getsStyles().getStyleByCell(r),primaryWithCoord:m.getCellByIndex((k=b==null?void 0:b.startRow)!=null?k:a,(A=b==null?void 0:b.startColumn)!=null?A:n),unitId:i,subUnitId:l,row:a,col:n,workbook:d,worksheet:c};return(Y=(L=C==null?void 0:C.canvasRender)==null?void 0:L.calcCellAutoHeight)==null?void 0:Y.call(L,$)},coverable:((B=r==null?void 0:r.coverable)!=null?B:!0)&&!(h.type===s.DataValidationType.LIST||h.type===s.DataValidationType.LIST_MULTIPLE)})}}))}_initAutoHeight(){this._dataValidationModel.ruleChange$.subscribe(r=>{var e;if((e=r.rule)!=null&&e.ranges){const t=this._autoHeightController.getUndoRedoParamsOfAutoHeight(r.rule.ranges);s.sequenceExecute(t.redos,this._commandService)}})}};exports.SheetsDataValidationRenderController=da([s.OnLifecycle(s.LifecycleStages.Rendered,exports.SheetsDataValidationRenderController),J(1,s.ICommandService),J(2,q.IMenuService),J(3,K.IRenderManagerService),J(4,s.IUniverInstanceService),J(5,y.Inject(x.AutoHeightController)),J(6,y.Inject(q.ComponentManager)),J(7,y.Inject(fe)),J(8,y.Inject(D.DataValidationModel)),J(9,y.Inject(D.DataValidatorRegistryService)),J(10,y.Inject(y.Injector)),J(11,y.Inject(U.SheetInterceptorService)),J(12,y.Optional(x.IEditorBridgeService))],exports.SheetsDataValidationRenderController);let be=class extends s.RxDisposable{constructor(o,r,e,t,a,n,i,l){super(),this._config=o,this._commandService=r,this._renderManagerService=e,this._univerInstanceService=t,this._autoHeightController=a,this._dataValidationModel=n,this._dataValidatorRegistryService=i,this._sheetInterceptorService=l,this._initSkeletonChange(),this._initViewModelIntercept(),this._initAutoHeight()}_initSkeletonChange(){const o=()=>{var i,l,d;const r=this._univerInstanceService.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET);if(!r)return;const e=r.getUnitId(),t=(i=r.getActiveSheet())==null?void 0:i.getSheetId();if(!t)return;const a=(d=(l=this._renderManagerService.getRenderById(e))==null?void 0:l.with(x.SheetSkeletonManagerService).getWorksheetSkeleton(t))==null?void 0:d.skeleton,n=this._renderManagerService.getRenderById(e);a==null||a.makeDirty(!0),a==null||a.calculate(),n&&n.mainComponent.makeForceDirty()};this.disposeWithMe(this._dataValidationModel.ruleChange$.subscribe(()=>o())),this.disposeWithMe(this._dataValidationModel.validStatusChange$.subscribe(()=>o()))}_initViewModelIntercept(){this.disposeWithMe(this._sheetInterceptorService.intercept(U.INTERCEPTOR_POINT.CELL_CONTENT,{priority:200,handler:(o,r,e)=>{var I,w,T,F,j;const{row:t,col:a,unitId:n,subUnitId:i,workbook:l,worksheet:d}=r,c=this._dataValidationModel.ensureManager(n,i);if(!c)return e(o);const u=(w=(I=this._renderManagerService.getRenderById(n))==null?void 0:I.with(x.SheetSkeletonManagerService).getWorksheetSkeleton(i))==null?void 0:w.skeleton;if(!u)return e(o);const m=r.workbook.getStyles(),f=(typeof(o==null?void 0:o.s)=="string"?m.get(o==null?void 0:o.s):o==null?void 0:o.s)||{},p=c.getRuleIdByLocation(t,a);if(!p)return e(o);const g=c.getRuleById(p);if(!g)return e(o);const h=r.worksheet.getCellRaw(r.row,r.col),_=this._dataValidationModel.validator(te(h),g,r),S=this._dataValidatorRegistryService.getValidatorItem(g.type),C=te(o);let V={};if((g.type===s.DataValidationType.LIST||g.type===s.DataValidationType.LIST_MULTIPLE)&&(V={interceptorStyle:{...o==null?void 0:o.interceptorStyle,tb:(T=f.tb!==s.WrapStrategy.OVERFLOW?f.tb:s.WrapStrategy.CLIP)!=null?T:s.WrapStrategy.WRAP}}),g.type===s.DataValidationType.CHECKBOX&&(V={interceptorStyle:{...o==null?void 0:o.interceptorStyle,tb:s.WrapStrategy.CLIP}}),g.type===s.DataValidationType.LIST&&(g.renderMode===s.DataValidationRenderMode.ARROW||g.renderMode===s.DataValidationRenderMode.TEXT)){const P=S.getListWithColorMap(g),B=`${(F=te(o))!=null?F:""}`,b=P[B];b&&(V={...V,interceptorStyle:{...V.interceptorStyle,bg:{rgb:b}}})}return e({...o,...V,dataValidation:{ruleId:p,validStatus:_,rule:g,validator:S},markers:{...o==null?void 0:o.markers,..._===s.DataValidationStatus.INVALID?ua:null},customRender:[...(j=o==null?void 0:o.customRender)!=null?j:[],...S!=null&&S.canvasRender?[S.canvasRender]:[]],fontRenderExtension:{...o==null?void 0:o.fontRenderExtension,isSkip:S==null?void 0:S.skipDefaultFontRender(g,C,r)},interceptorStyle:{...o==null?void 0:o.interceptorStyle,...V.interceptorStyle},get interceptorAutoHeight(){var b,$,k,A;const P=u.mergeData.find(L=>{const{startColumn:Y,startRow:Z,endColumn:X,endRow:M}=L;return t>=Z&&a>=Y&&t<=M&&a<=X}),B={data:{...o,dataValidation:{ruleId:p,validStatus:_,rule:g,validator:S}},style:u.getsStyles().getStyleByCell(o),primaryWithCoord:u.getCellByIndex((b=P==null?void 0:P.startRow)!=null?b:t,($=P==null?void 0:P.startColumn)!=null?$:a),unitId:n,subUnitId:i,row:t,col:a,worksheet:d,workbook:l};return(A=(k=S==null?void 0:S.canvasRender)==null?void 0:k.calcCellAutoHeight)==null?void 0:A.call(k,B)}})}}))}_initAutoHeight(){this._dataValidationModel.ruleChange$.subscribe(o=>{var r;if((r=o.rule)!=null&&r.ranges){const e=this._autoHeightController.getUndoRedoParamsOfAutoHeight(o.rule.ranges);s.sequenceExecute(e.redos,this._commandService)}})}};be=da([s.OnLifecycle(s.LifecycleStages.Rendered,be),J(1,s.ICommandService),J(2,K.IRenderManagerService),J(3,s.IUniverInstanceService),J(4,y.Inject(x.AutoHeightController)),J(5,y.Inject(D.DataValidationModel)),J(6,y.Inject(D.DataValidatorRegistryService)),J(7,y.Inject(U.SheetInterceptorService))],be);var bo=Object.defineProperty,Fo=Object.getOwnPropertyDescriptor,No=(o,r,e,t)=>{for(var a=t>1?void 0:t?Fo(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&bo(r,e,a),a},Lo=(o,r)=>(e,t)=>r(e,t,o);exports.SheetDataValidationService=class{constructor(r){R(this,"_currentManager");R(this,"_currentManager$",new _e.Subject);R(this,"currentManager$",this._currentManager$.asObservable());this._dataValidationModel=r}get currentManager(){return this._currentManager}_ensureManager(r,e){return this._dataValidationModel.ensureManager(r,e)}switchCurrent(r,e){var a,n;if(r===((a=this.currentManager)==null?void 0:a.unitId)&&e===((n=this._currentManager)==null?void 0:n.subUnitId))return;const t=this._ensureManager(r,e);this._currentManager={manager:t,unitId:r,subUnitId:e},this._currentManager$.next(this._currentManager)}get(r,e){return this._ensureManager(r,e)}};exports.SheetDataValidationService=No([Lo(0,y.Inject(D.DataValidationModel))],exports.SheetDataValidationService);var Po=Object.defineProperty,Ao=Object.getOwnPropertyDescriptor,jo=(o,r,e,t)=>{for(var a=t>1?void 0:t?Ao(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&Po(r,e,a),a},He=(o,r)=>(e,t)=>r(e,t,o);exports.DataValidationCustomFormulaService=class extends s.Disposable{constructor(e,t,a,n){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=n,this._initFormulaResultHandler()}_initFormulaResultHandler(){this.disposeWithMe(this._registerOtherFormulaService.formulaResult$.subscribe(e=>{for(const t in e){const a=e[t];for(const n in a){const i=a[n],{formulaCellMap:l,ruleFormulaMap:d}=this._ensureMaps(t,n),c=this._dataValidationModel.ensureManager(t,n);i.forEach(u=>{var g,h;const m=d.get((g=u.extra)==null?void 0:g.ruleId),f=l.get(u.formulaId),p=c.getRuleById((h=u.extra)==null?void 0:h.ruleId);p&&m&&!m.isTransformable&&this._dataValidationCacheService.markRangeDirty(t,n,p.ranges),f&&this._dataValidationCacheService.markCellDirty(t,n,f.row,f.column)})}}}))}_ensureMaps(e,t){let a=this._formulaMap.get(e),n=this._ruleFormulaMap.get(e),i=this._formulaCellMap.get(e);(!a||!n||!i)&&(a=new Map,n=new Map,i=new Map,this._formulaMap.set(e,a),this._ruleFormulaMap.set(e,n),this._formulaCellMap.set(e,i));let l=a.get(t),d=n.get(t),c=i.get(t);return(!l||!d||!c)&&(l=new s.ObjectMatrix,a.set(t,l),d=new Map,n.set(t,d),c=new Map,i.set(t,c)),{formulaMap:l,ruleFormulaMap:d,formulaCellMap:c}}_registerFormula(e,t,a,n){return this._registerOtherFormulaService.registerFormula(e,t,n,{ruleId:a})}deleteByRuleId(e,t,a){const{formulaMap:n,formulaCellMap:i,ruleFormulaMap:l}=this._ensureMaps(e,t),d=this._dataValidationModel.getRuleById(e,t,a),c=new Set,u=l.get(a);!d||!u||(l.delete(a),d.ranges.forEach(m=>{s.Range.foreach(m,(f,p)=>{const g=n.getValue(f,p);if(g&&g.ruleId===a){const{formulaId:h}=g;n.realDeleteValue(f,p),c.add(h),i.delete(h)}})}),this._registerOtherFormulaService.deleteFormula(e,t,Array.from(c.values())))}_addFormulaByRange(e,t,a,n,i){const{formulaMap:l,ruleFormulaMap:d,formulaCellMap:c}=this._ensureMaps(e,t);if(!n)return;const u=oe.isFormulaTransformable(this._lexerTreeBuilder,n),m=i[0].startRow,f=i[0].startColumn;let p;u?i.forEach(g=>{s.Range.foreach(g,(h,_)=>{const S=oe.transformFormula(this._lexerTreeBuilder,n,m,f,h,_),C=this._registerFormula(e,t,a,S);l.setValue(h,_,{formulaId:C,ruleId:a}),c.set(C,{row:h,column:_})})}):(p=this._registerFormula(e,t,a,n),i.forEach(g=>{s.Range.foreach(g,(h,_)=>{l.setValue(h,_,{formulaId:p,ruleId:a})})})),d.set(a,{formula:n,originCol:f,originRow:m,isTransformable:u,formulaId:p})}addRule(e,t,a){const{ranges:n,formula1:i,uid:l,type:d}=a;d!==s.DataValidationType.CUSTOM||!i||!s.isFormulaString(i)||this._addFormulaByRange(e,t,l,i,n)}updateRuleRanges(e,t,a,n,i){const{formulaMap:l,ruleFormulaMap:d,formulaCellMap:c}=this._ensureMaps(e,t),u=d.get(a);if(!u)return;const{formula:m,originCol:f,originRow:p,isTransformable:g,formulaId:h}=u,_=new Set;n.forEach(S=>{s.Range.foreach(S,(C,V)=>{const I=l.getValue(C,V);I&&I.ruleId===a&&(I.temp=!0)})}),i.forEach(S=>{s.Range.foreach(S,(C,V)=>{var w;const I=(w=l.getValue(C,V))!=null?w:{};if(I.ruleId!==a){const T=d.get(I.ruleId);if(T!=null&&T.isTransformable&&_.add(I.formulaId),g){const F=oe.transformFormula(this._lexerTreeBuilder,m,p,f,C,V),j=this._registerFormula(e,t,a,F);l.setValue(C,V,{ruleId:a,formulaId:j}),c.set(j,{row:C,column:V})}else l.setValue(C,V,{ruleId:a,formulaId:h})}else I.temp=!1})}),n.forEach(S=>{s.Range.foreach(S,(C,V)=>{const I=l.getValue(C,V);I&&I.ruleId===a&&I.temp===!0&&(l.realDeleteValue(C,V),g&&_.add(I.formulaId))})}),_.forEach(S=>{c.delete(S)}),this._registerOtherFormulaService.deleteFormula(e,t,Array.from(_.values()))}updateRuleFormula(e,t,a,n,i){const{ruleFormulaMap:l}=this._ensureMaps(e,t),d=l.get(a);(!d||d.formula!==i)&&this._addFormulaByRange(e,t,a,i,n)}getCellFormulaValue(e,t,a,n){const{formulaMap:i}=this._ensureMaps(e,t),l=i.getValue(a,n);return l?this._registerOtherFormulaService.getFormulaValue(e,t,l.formulaId):Promise.resolve(void 0)}getRuleFormulaInfo(e,t,a){const{ruleFormulaMap:n}=this._ensureMaps(e,t);return n.get(a)}};exports.DataValidationCustomFormulaService=jo([He(0,y.Inject(Dt.RegisterOtherFormulaService)),He(1,y.Inject(oe.LexerTreeBuilder)),He(2,y.Inject(D.DataValidationModel)),He(3,y.Inject(De))],exports.DataValidationCustomFormulaService);class xo extends D.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",Qt);R(this,"_customFormulaService",this.injector.get(exports.DataValidationCustomFormulaService))}validatorFormula(e,t,a){const n=s.isFormulaString(e.formula1);return{success:n,formula1:n?"":this.localeService.t("dataValidation.validFail.formula")}}async parseFormula(e,t,a){return{formula1:void 0,formula2:void 0}}async isValidType(e,t,a){const{column:n,row:i,unitId:l,subUnitId:d}=e,c=await this._customFormulaService.getCellFormulaValue(l,d,i,n);return!!ie(c==null?void 0:c.result)}generateRuleErrorMessage(e){return this.localeService.t("dataValidation.custom.error")}}class Uo extends D.BaseDataValidator{constructor(){super(...arguments);R(this,"_formulaService",this.injector.get(exports.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",xe);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:n}=e,i=ze(n);return!Number.isNaN(i)&&Number.isInteger(i)}transform(e,t,a){const{value:n}=e;return{...e,value:ze(n)}}_parseNumber(e){return e==null?Number.NaN:+e}async parseFormula(e,t,a){var c,u,m,f,p,g,h,_;const n=await this._formulaService.getRuleFormulaResult(t,a,e.uid),{formula1:i,formula2:l}=e;return{formula1:this._parseNumber(s.isFormulaString(i)?(f=(m=(u=(c=n==null?void 0:n[0])==null?void 0:c.result)==null?void 0:u[0])==null?void 0:m[0])==null?void 0:f.v:i),formula2:this._parseNumber(s.isFormulaString(l)?(_=(h=(g=(p=n==null?void 0:n[1])==null?void 0:p.result)==null?void 0:g[0])==null?void 0:h[0])==null?void 0:_.v:l)}}validatorFormula(e,t,a){const n=e.operator;if(!n)return{success:!1};const i=s.Tools.isDefine(e.formula1)&&this._isFormulaOrInt(e.formula1),l=s.Tools.isDefine(e.formula2)&&this._isFormulaOrInt(e.formula2),d=Je.includes(n),c=this.localeService.t("dataValidation.validFail.number");return d?{success:i&&l,formula1:i?void 0:c,formula2:l?void 0:c}:{success:i,formula1:c}}async validatorIsEqual(e,t,a){const{formula1:n}=t,{value:i}=e;return Number.isNaN(n)?!0:i===n}async validatorIsNotEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value!==n}async validatorIsBetween(e,t,a){const{formula1:n,formula2:i}=t;if(Number.isNaN(n)||Number.isNaN(i))return!0;const l=Math.min(n,i),d=Math.max(n,i);return e.value>=l&&e.value<=d}async validatorIsNotBetween(e,t,a){const{formula1:n,formula2:i}=t;if(Number.isNaN(n)||Number.isNaN(i))return!0;const l=Math.min(n,i),d=Math.max(n,i);return e.value<l||e.value>d}async validatorIsGreaterThan(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value>n}async validatorIsGreaterThanOrEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value>=n}async validatorIsLessThan(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value<n}async validatorIsLessThanOrEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value<=n}}const ha=4,Bo=0,lt=4,ma=4,Vt=6,Ke=6,Se=14;function $o(o,r){const e=K.FontCache.getTextSize(o,r),t=e.width+ha*2,{ba:a,bd:n}=e,i=a+n;return{width:t,height:i+Bo*2,ba:a}}function jt(o,r,e,t){const a=e-Se-Vt,n=t-Ke*2,i=o.map(u=>({layout:$o(u,r),text:u}));let l;const d=[];i.forEach(u=>{const{layout:m}=u,{width:f,height:p}=m;!l||l.width+f+lt>a?(l={width:f,height:p,items:[{...u,left:0}]},d.push(l)):(l.items.push({...u,left:l.width+lt}),l.width=l.width+f+lt)});let c=0;return d.forEach((u,m)=>{m===d.length-1?c+=u.height:c+=u.height+ma}),{lines:d,totalHeight:c,contentWidth:a,contentHeight:n,cellAutoHeight:c+Ke*2}}const Wo=8;class Ho extends K.Shape{static drawWith(r,e){const{fontFamily:t,fontString:a,fontSize:n,info:i,fill:l,color:d}=e,{layout:c,text:u}=i;r.save(),K.Rect.drawWith(r,{width:c.width,height:c.height,radius:Wo,fill:l||Ve}),r.translateWithPrecision(ha,c.ba),r.font=a,r.fillStyle=d,r.fillText(u,0,0),r.restore()}}var ko=Object.defineProperty,Yo=Object.getOwnPropertyDescriptor,qo=(o,r,e,t)=>{for(var a=t>1?void 0:t?Yo(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&ko(r,e,a),a},Xo=(o,r)=>(e,t)=>r(e,t,o);const Go=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 Rt=class{constructor(o){R(this,"zIndex");R(this,"_dropdownInfoMap",new Map);this._commandService=o}_ensureMap(o){let r=this._dropdownInfoMap.get(o);return r||(r=new Map,this._dropdownInfoMap.set(o,r)),r}_generateKey(o,r){return`${o}.${r}`}_drawDownIcon(o,r,e,t,a){const n=e-Se+4;let i=4;switch(a){case s.VerticalAlign.MIDDLE:i=(t-Se)/2+4;break;case s.VerticalAlign.BOTTOM:i=t-Se+4;break}o.save(),o.translateWithPrecision(r.startX+n,r.startY+i),o.fillStyle="#565656",o.fill(Go),o.restore()}drawWith(o,r,e,t){var W,ee;const{primaryWithCoord:a,row:n,col:i,style:l,data:d,subUnitId:c}=r,u=a.isMergedMainCell?a.mergeInfo:a,m=d.fontRenderExtension,{leftOffset:f=0,rightOffset:p=0,topOffset:g=0,downOffset:h=0}=m||{},_=d.dataValidation,S=this._ensureMap(c),C=this._generateKey(n,i);if(!_)return;const V={startX:u.startX+f,endX:u.endX-p,startY:u.startY+g,endY:u.endY-h},I=V.endX-V.startX,w=V.endY-V.startY,{cl:T}=l||{},F=(W=typeof T=="object"?T==null?void 0:T.rgb:T)!=null?W:"#000",j=K.getFontStyleString(l!=null?l:void 0),{rule:P,validator:B}=_,b=B,{vt:$,ht:k}=l||{},A=$!=null?$:s.VerticalAlign.MIDDLE,L=(ee=te(d))!=null?ee:"",Y=b.parseCellValue(L),Z=b.getListWithColorMap(P),X=jt(Y,j,I,w);this._drawDownIcon(o,V,I,w,A),o.save(),o.translateWithPrecision(V.startX,V.startY),o.beginPath(),o.rect(0,0,I-Se,w),o.clip(),o.translateWithPrecision(Vt,Ke);let M=0;switch(A){case s.VerticalAlign.MIDDLE:M=(X.contentHeight-X.totalHeight)/2;break;case s.VerticalAlign.BOTTOM:M=X.contentHeight-X.totalHeight;break}o.translateWithPrecision(0,M),X.lines.forEach((Q,se)=>{o.save();const{width:N,height:G,items:z}=Q;let ae=0;switch(k){case s.HorizontalAlign.RIGHT:ae=X.contentWidth-N;break;case s.HorizontalAlign.CENTER:ae=(X.contentWidth-N)/2;break}o.translate(ae,se*(G+ma)),z.forEach(ue=>{o.save(),o.translateWithPrecision(ue.left,0),Ho.drawWith(o,{...j,info:ue,color:F,fill:Z[ue.text]}),o.restore()}),o.restore()}),o.restore(),S.set(C,{left:V.startX,top:V.startY,width:X.contentWidth+Vt+Se,height:X.contentHeight+Ke*2})}calcCellAutoHeight(o){var I;const{primaryWithCoord:r,style:e,data:t}=o,a=t.fontRenderExtension,{leftOffset:n=0,rightOffset:i=0,topOffset:l=0,downOffset:d=0}=a||{},c=r.isMergedMainCell?r.mergeInfo:r,u={startX:c.startX+n,endX:c.endX-i,startY:c.startY+l,endY:c.endY-d},m=t.dataValidation;if(!m)return;const f=u.endX-u.startX,p=u.endY-u.startY,g=(I=te(t))!=null?I:"",{validator:h}=m,S=h.parseCellValue(g),C=K.getFontStyleString(e!=null?e:void 0);return jt(S,C,f,p).cellAutoHeight}isHit(o,r){const{primaryWithCoord:e}=r,t=e.isMergedMainCell?e.mergeInfo:e,{endX:a}=t,{x:n}=o;return n>=a-Se&&n<=a}onPointerDown(o,r){if(r.button===2)return;const{unitId:e,subUnitId:t,row:a,col:n}=o,i={unitId:e,subUnitId:t,row:a,column:n};this._commandService.executeCommand(Ae.id,i)}};Rt=qo([Xo(0,s.ICommandService)],Rt);class zo extends na{constructor(){super(...arguments);R(this,"id",s.DataValidationType.LIST_MULTIPLE);R(this,"title","dataValidation.listMultiple.title");R(this,"canvasRender",this.injector.createInstance(Rt))}skipDefaultFontRender(){return!0}}var Ko=Object.defineProperty,Qo=Object.getOwnPropertyDescriptor,Zo=(o,r,e,t)=>{for(var a=t>1?void 0:t?Qo(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&Ko(r,e,a),a},me=(o,r)=>(e,t)=>r(e,t,o);exports.DataValidationController=class extends s.RxDisposable{constructor(r,e,t,a,n,i,l,d){super(),this._univerInstanceService=r,this._sheetDataValidationService=e,this._dataValidatorRegistryService=t,this._injector=a,this._componentManger=n,this._selectionManagerService=i,this._sheetInterceptorService=l,this._dataValidationModel=d,this._init()}_init(){this._registerValidators(),this._initInstanceChange(),this._initCommandInterceptor(),this._initComponents()}_registerValidators(){[Do,Uo,yo,uo,Vr,na,zo,xo].forEach(r=>{const e=this._injector.createInstance(r);this.disposeWithMe(this._dataValidatorRegistryService.register(e)),this.disposeWithMe({dispose:()=>{this._injector.delete(r)}})})}_initInstanceChange(){const r=new s.DisposableCollection;this.disposeWithMe(this._univerInstanceService.getCurrentTypeOfUnit$(s.UniverInstanceType.UNIVER_SHEET).subscribe(e=>{if(r.dispose(),!e)return;const t=e.getActiveSheet();t&&(this._sheetDataValidationService.switchCurrent(e.getUnitId(),t.getSheetId()),r.add(s.toDisposable(e.activeSheet$.subscribe(a=>{if(a){const n=e.getUnitId(),i=a.getSheetId();this._sheetDataValidationService.switchCurrent(n,i)}}))))})),this.disposeWithMe(r)}_initCommandInterceptor(){this._sheetInterceptorService.interceptCommand({getMutations:r=>{var e;if(r.id===U.ClearSelectionAllCommand.id){const t=this._univerInstanceService.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET),a=t.getUnitId(),n=t.getActiveSheet();if(!n)throw new Error("No active sheet found");const i=n.getSheetId(),l=(e=this._selectionManagerService.getCurrentSelections())==null?void 0:e.map(p=>p.range),d=this._dataValidationModel.ensureManager(a,i),c=d.getRuleObjectMatrix().clone();l&&c.removeRange(l);const u=c.diff(d.getDataValidations()),{redoMutations:m,undoMutations:f}=Oe(a,i,u,this._injector);return{undos:f,redos:m}}return{undos:[],redos:[]}}})}_initComponents(){[[la,Yt],[Wt,Ur],[$t,Ea],[aa,Kr],[ra,no],[Ge.componentKey,Ge],[Xe.componentKey,Xe],..._r].forEach(([r,e])=>{this.disposeWithMe(this._componentManger.register(r,e))})}};exports.DataValidationController=Zo([s.OnLifecycle(s.LifecycleStages.Rendered,exports.DataValidationController),me(0,s.IUniverInstanceService),me(1,y.Inject(exports.SheetDataValidationService)),me(2,y.Inject(D.DataValidatorRegistryService)),me(3,y.Inject(y.Injector)),me(4,y.Inject(q.ComponentManager)),me(5,y.Inject(U.SheetsSelectionsService)),me(6,y.Inject(U.SheetInterceptorService)),me(7,y.Inject(D.DataValidationModel))],exports.DataValidationController);var Jo=Object.defineProperty,en=Object.getOwnPropertyDescriptor,tn=(o,r,e,t)=>{for(var a=t>1?void 0:t?en(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&Jo(r,e,a),a},ke=(o,r)=>(e,t)=>r(e,t,o);const dt="SHEET_DATA_VALIDATION_ALERT";exports.DataValidationAlertController=class extends s.Disposable{constructor(r,e,t,a){super(),this._hoverManagerService=r,this._cellAlertManagerService=e,this._univerInstanceService=t,this._localeService=a,this._init()}_init(){this._initCellAlertPopup()}_initCellAlertPopup(){this.disposeWithMe(this._hoverManagerService.currentCell$.pipe(_e.debounceTime(100)).subscribe(r=>{var e,t;if(r){const n=this._univerInstanceService.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET).getActiveSheet();if(!n)return;const i=n.getCell(r.location.row,r.location.col);if(((e=i==null?void 0:i.dataValidation)==null?void 0:e.validStatus)===s.DataValidationStatus.INVALID){const l=this._cellAlertManagerService.currentAlert.get(dt),d=(t=l==null?void 0:l.alert)==null?void 0:t.location;if(d&&d.row===r.location.row&&d.col===r.location.col&&d.subUnitId===r.location.subUnitId&&d.unitId===r.location.unitId)return;const c=i.dataValidation.validator,u=i.dataValidation.rule;if(!c)return;this._cellAlertManagerService.showAlert({type:x.CellAlertType.ERROR,title:this._localeService.t("dataValidation.error.title"),message:c==null?void 0:c.getRuleFinalError(u),location:r.location,width:200,height:74,key:dt});return}}this._cellAlertManagerService.removeAlert(dt)}))}};exports.DataValidationAlertController=tn([s.OnLifecycle(s.LifecycleStages.Rendered,exports.DataValidationAlertController),ke(0,y.Inject(x.HoverManagerService)),ke(1,y.Inject(x.CellAlertManagerService)),ke(2,s.IUniverInstanceService),ke(3,y.Inject(s.LocaleService))],exports.DataValidationAlertController);var an=Object.defineProperty,rn=Object.getOwnPropertyDescriptor,on=(o,r,e,t)=>{for(var a=t>1?void 0:t?rn(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&an(r,e,a),a},Me=(o,r)=>(e,t)=>r(e,t,o);exports.DataValidationRefRangeController=class extends s.Disposable{constructor(e,t,a,n,i,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=n,this._dataValidationFormulaService=i,this._formulaRefRangeService=l,this._initRefRange()}_getIdWithUnitId(e,t,a){return`${e}_${t}_${a}`}registerFormula(e,t,a){var c;const n=a.uid,i=this._getIdWithUnitId(e,t,n),l=(c=this._disposableMap.get(i))!=null?c:new Set,d=(u,m)=>{const f=this._dataValidationModel.getRuleById(e,t,n);if(!f)return{redos:[],undos:[]};const p=f[u];if(!p||p===m)return{redos:[],undos:[]};const g={unitId:e,subUnitId:t,ruleId:a.uid,payload:{type:D.UpdateRuleType.SETTING,payload:{type:f.type,formula1:f.formula1,formula2:f.formula2,[u]:m}}},h={unitId:e,subUnitId:t,ruleId:a.uid,payload:{type:D.UpdateRuleType.SETTING,payload:{type:f.type,formula1:f.formula1,formula2:f.formula2}}},_=[{id:D.UpdateDataValidationMutation.id,params:g}],S=[{id:D.UpdateDataValidationMutation.id,params:h}];return{redos:_,undos:S}};if(a.type===s.DataValidationType.CUSTOM){const u=this._dataValidationCustomFormulaService.getRuleFormulaInfo(e,t,n);if(u){const m=this._formulaRefRangeService.registerFormula(u.formula,f=>d("formula1",f));l.add(()=>m.dispose())}}if(a.type!==s.DataValidationType.CUSTOM){const u=this._dataValidationFormulaService.getRuleFormulaInfo(e,t,n);if(u){const[m,f]=u;if(m){const p=this._formulaRefRangeService.registerFormula(m.text,g=>d("formula1",g));l.add(()=>p.dispose())}if(f){const p=this._formulaRefRangeService.registerFormula(f.text,g=>d("formula1",g));l.add(()=>p.dispose())}}}}register(e,t,a){var c;const n=u=>{const m=[...a.ranges],p=m.map(h=>U.handleCommonDefaultRangeChangeWithEffectRefCommands(h,u)).filter(h=>!!h).flat();if(s.isRangesEqual(p,m))return{redos:[],undos:[]};if(p.length){const h={unitId:e,subUnitId:t,ruleId:a.uid,payload:{type:D.UpdateRuleType.RANGE,payload:p}},_=[{id:D.UpdateDataValidationMutation.id,params:h}],S=[{id:D.UpdateDataValidationMutation.id,params:{unitId:e,subUnitId:t,ruleId:a.uid,payload:{type:D.UpdateRuleType.RANGE,payload:m}}}];return{redos:_,undos:S}}else{const h={unitId:e,subUnitId:t,ruleId:a.uid},_=[{id:D.RemoveDataValidationMutation.id,params:h}],S=D.removeDataValidationUndoFactory(this._injector,h);return{redos:_,undos:S}}},i=[];a.ranges.forEach(u=>{const m=this._refRangeService.registerRefRange(u,n,e,t);i.push(()=>m.dispose())});const l=this._getIdWithUnitId(e,t,a.uid),d=(c=this._disposableMap.get(l))!=null?c:new Set;d.add(()=>i.forEach(u=>u())),this._disposableMap.set(l,d)}_initRefRange(){this.disposeWithMe(this._dataValidationModel.ruleChange$.subscribe(e=>{const{unitId:t,subUnitId:a,rule:n}=e;switch(e.type){case"add":{const i=e.rule;this.registerRule(e.unitId,e.subUnitId,i);break}case"remove":{const i=this._disposableMap.get(this._getIdWithUnitId(t,a,n.uid));i&&i.forEach(l=>l());break}case"update":{const i=e.rule,l=this._disposableMap.get(this._getIdWithUnitId(t,a,i.uid));l&&l.forEach(d=>d()),this.registerRule(e.unitId,e.subUnitId,i);break}}})),this.disposeWithMe(s.toDisposable(()=>{this._disposableMap.forEach(e=>{e.forEach(t=>t())}),this._disposableMap.clear()}))}};exports.DataValidationRefRangeController=on([s.OnLifecycle(s.LifecycleStages.Ready,exports.DataValidationRefRangeController),Me(0,y.Inject(D.DataValidationModel)),Me(1,y.Inject(y.Injector)),Me(2,y.Inject(U.RefRangeService)),Me(3,y.Inject(exports.DataValidationCustomFormulaService)),Me(4,y.Inject(exports.DataValidationFormulaService)),Me(5,y.Inject(Dt.FormulaRefRangeService))],exports.DataValidationRefRangeController);var nn=Object.defineProperty,sn=Object.getOwnPropertyDescriptor,ln=(o,r,e,t)=>{for(var a=t>1?void 0:t?sn(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&nn(r,e,a),a},ct=(o,r)=>(e,t)=>r(e,t,o);exports.DataValidationAutoFillController=class extends s.Disposable{constructor(r,e,t){super(),this._autoFillService=r,this._dataValidationModel=e,this._injector=t,this._initAutoFill()}_initAutoFill(){const r=()=>({redos:[],undos:[]}),e=n=>{const{source:i,target:l,unitId:d,subUnitId:c}=n,u=this._dataValidationModel.ensureManager(d,c),m=u.getRuleObjectMatrix().clone(),f=x.virtualizeDiscreteRanges([i,l]),[p,g]=f.ranges,{mapFunc:h}=f,_={row:p.startRow,col:p.startColumn};x.getAutoFillRepeatRange(p,g).forEach(w=>{const T=w.repeatStartCell,F=w.relativeRange,j={startRow:_.row,startColumn:_.col,endColumn:_.col,endRow:_.row},P={startRow:T.row,startColumn:T.col,endColumn:T.col,endRow:T.row};s.Range.foreach(F,(B,b)=>{const $=s.Rectangle.getPositionRange({startRow:B,startColumn:b,endColumn:b,endRow:B},j),{row:k,col:A}=h($.startRow,$.startColumn),L=u.getRuleIdByLocation(k,A);if(L){const Y=s.Rectangle.getPositionRange({startRow:B,startColumn:b,endColumn:b,endRow:B},P),{row:Z,col:X}=h(Y.startRow,Y.startColumn);m.setValue(Z,X,L)}})});const C=m.diff(u.getDataValidations()),{redoMutations:V,undoMutations:I}=Oe(d,c,C,this._injector);return{undos:I,redos:V}},t=[s.DataValidationType.CHECKBOX],a={id:je,onBeforeFillData:n=>{const{source:i,unitId:l,subUnitId:d}=n,c=this._dataValidationModel.ensureManager(l,d);for(const u of i.rows)for(const m of i.cols){const f=c.getRuleByLocation(u,m);if(f&&t.indexOf(f.type)>-1){this._autoFillService.setDisableApplyType(x.APPLY_TYPE.SERIES,!0);return}}},onFillData:(n,i,l)=>l===x.APPLY_TYPE.COPY||l===x.APPLY_TYPE.ONLY_FORMAT||l===x.APPLY_TYPE.SERIES?e(n):r(),onAfterFillData:()=>{}};this.disposeWithMe(this._autoFillService.addHook(a))}};exports.DataValidationAutoFillController=ln([s.OnLifecycle(s.LifecycleStages.Ready,exports.DataValidationAutoFillController),ct(0,x.IAutoFillService),ct(1,y.Inject(D.DataValidationModel)),ct(2,y.Inject(y.Injector))],exports.DataValidationAutoFillController);var dn=Object.defineProperty,cn=Object.getOwnPropertyDescriptor,un=(o,r,e,t)=>{for(var a=t>1?void 0:t?cn(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&dn(r,e,a),a},ut=(o,r)=>(e,t)=>r(e,t,o);exports.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:je,onBeforeCopy:(e,t,a)=>this._collect(e,t,a),onPasteCells:(e,t,a,n)=>{const{copyType:i=x.COPY_TYPE.COPY,pasteType:l}=n,{range:d}=e||{},{range:c,unitId:u,subUnitId:m}=t;return this._generateMutations(c,{copyType:i,pasteType:l,copyRange:d,unitId:u,subUnitId:m})}})}_collect(e,t,a){const n=new s.ObjectMatrix;this._copyInfo={unitId:e,subUnitId:t,matrix:n};const i=this._dataValidationModel.ensureManager(e,t),l={get:this._injector.get.bind(this._injector)},d=x.rangeToDiscreteRange(a,l,e,t);if(!d)return;const{rows:c,cols:u}=d;c.forEach((m,f)=>{u.forEach((p,g)=>{const h=i.getRuleIdByLocation(m,p);n.setValue(f,g,h!=null?h:"")})})}_generateMutations(e,t){if(!this._copyInfo)return{redos:[],undos:[]};if(t.copyType===x.COPY_TYPE.CUT)return this._copyInfo=null,{redos:[],undos:[]};if(!this._copyInfo||!this._copyInfo.matrix.getSizeOf()||!t.copyRange)return{redos:[],undos:[]};if([x.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_COL_WIDTH,x.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_VALUE,x.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMAT,x.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMULA].includes(t.pasteType))return{redos:[],undos:[]};const{unitId:a,subUnitId:n}=this._copyInfo;if(t.unitId!==a||n!==t.subUnitId){const i=this._dataValidationModel.ensureManager(a,n),l=this._dataValidationModel.ensureManager(t.unitId,t.subUnitId),d=l.getRuleObjectMatrix().clone(),{ranges:[c,u],mapFunc:m}=x.virtualizeDiscreteRanges([t.copyRange,e]),f=x.getRepeatRange(c,u,!0),p=new Map;f.forEach(({startRange:_})=>{var S;(S=this._copyInfo)==null||S.matrix.forValue((C,V,I)=>{const w=s.Rectangle.getPositionRange({startRow:C,endRow:C,startColumn:V,endColumn:V},_),T=`${n}-${I}`,F=i.getRuleById(I);!l.getRuleById(T)&&F&&p.set(T,{...F,uid:T});const{row:j,col:P}=m(w.startRow,w.startColumn);d.setValue(j,P,T)})});const{redoMutations:g,undoMutations:h}=Oe(t.unitId,t.subUnitId,d.diffWithAddition(l.getDataValidations(),p.values()),this._injector);return{redos:g,undos:h}}else{const i=this._dataValidationModel.ensureManager(a,n),l=i.getRuleObjectMatrix().clone(),{ranges:[d,c],mapFunc:u}=x.virtualizeDiscreteRanges([t.copyRange,e]);x.getRepeatRange(d,c,!0).forEach(({startRange:g})=>{var h;(h=this._copyInfo)==null||h.matrix.forValue((_,S,C)=>{const V=s.Rectangle.getPositionRange({startRow:_,endRow:_,startColumn:S,endColumn:S},g),{row:I,col:w}=u(V.startRow,V.startColumn);l.setValue(I,w,C)})});const{redoMutations:f,undoMutations:p}=Oe(a,n,l.diff(i.getDataValidations()),this._injector);return{redos:f,undos:p}}}};exports.DataValidationCopyPasteController=un([s.OnLifecycle(s.LifecycleStages.Ready,exports.DataValidationCopyPasteController),ut(0,x.ISheetClipboardService),ut(1,y.Inject(D.DataValidationModel)),ut(2,y.Inject(y.Injector))],exports.DataValidationCopyPasteController);class wt{constructor(r,e){R(this,"value");this._worksheet=e,this.value=r}addRule(r){const e=r.uid;r.ranges.forEach(t=>{s.Range.foreach(s.Range.transformRange(t,this._worksheet),(a,n)=>{this.value.setValue(a,n,e)})})}removeRange(r){r.forEach(e=>{s.Range.foreach(s.Range.transformRange(e,this._worksheet),(t,a)=>{this.value.realDeleteValue(t,a)})})}removeRule(r){r.ranges.forEach(e=>{s.Range.foreach(s.Range.transformRange(e,this._worksheet),(t,a)=>{this.value.setValue(t,a,"")})})}updateRange(r,e,t){const a=`${r}$`,n=e.map(l=>s.Range.transformRange(l,this._worksheet)),i=t.map(l=>s.Range.transformRange(l,this._worksheet));n.forEach(l=>{s.Range.foreach(l,(d,c)=>{this.value.getValue(d,c)===r&&this.value.setValue(d,c,a)})}),i.forEach(l=>{s.Range.foreach(l,(d,c)=>{this.value.setValue(d,c,r)})}),n.forEach(l=>{s.Range.foreach(l,(d,c)=>{this.value.getValue(d,c)===a&&this.value.realDeleteValue(d,c)})})}diff(r){const e=[];let t=0;return r.forEach((a,n)=>{const i=s.queryObjectMatrix(this.value,d=>d===a.uid),l=a.ranges;(i.length!==l.length||i.some((d,c)=>!s.Rectangle.equals(d,l[c])))&&e.push({type:"update",ruleId:a.uid,oldRanges:l,newRanges:i}),i.length===0&&(e.push({type:"delete",rule:a,index:n-t}),t++)}),e}diffWithAddition(r,e){const t=[];let a=0;return r.forEach((n,i)=>{const l=s.queryObjectMatrix(this.value,c=>c===n.uid),d=n.ranges;(l.length!==d.length||l.some((c,u)=>!s.Rectangle.equals(c,d[u])))&&t.push({type:"update",ruleId:n.uid,oldRanges:d,newRanges:l}),l.length===0&&(t.push({type:"delete",rule:n,index:i-a}),a++)}),Array.from(e).forEach(n=>{const i=s.queryObjectMatrix(this.value,l=>l===n.uid);t.push({type:"add",rule:{...n,ranges:i}})}),t}clone(){return new wt(new s.ObjectMatrix(this.value.clone()),this._worksheet)}getValue(r,e){return this.value.getValue(r,e)}setValue(r,e,t){return this.value.setValue(r,e,t)}}class hn extends D.DataValidationManager{constructor(e,t,a,n){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=n,this._dataValidatorRegistryService=this._injector.get(D.DataValidatorRegistryService),this._dataValidationCacheService=this._injector.get(De),this._dataValidationFormulaService=this._injector.get(exports.DataValidationFormulaService),this._dataValidationCustomFormulaService=this._injector.get(exports.DataValidationCustomFormulaService),this._dataValidationRefRangeController=this._injector.get(exports.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(c=>{const u=c.uid;c.ranges.forEach(m=>{s.Range.foreach(m,(f,p)=>{d.setValue(f,p,u)})})}),a==null||a.forEach(c=>{this._dataValidationRefRangeController.register(e,t,c)}),this._ruleMatrix=new wt(d,l)}_addRuleSideEffect(e){var n;const{unitId:t,subUnitId:a}=this;(e.type===s.DataValidationType.LIST||e.type===s.DataValidationType.LIST_MULTIPLE)&&oe.isReferenceString((n=e.formula1)!=null?n:"")&&(e.formula1=`=${e.formula1}`),this._ruleMatrix.addRule(e),this._dataValidationCacheService.addRule(t,a,e),this._dataValidationFormulaService.addRule(t,a,e.uid,e.formula1,e.formula2),this._dataValidationCustomFormulaService.addRule(t,a,e)}addRule(e,t){(Array.isArray(e)?e:[e]).forEach(n=>{this._addRuleSideEffect(n)}),super.addRule(e,t)}updateRule(e,t){const a=this.getRuleById(e);if(!a)throw new Error(`Rule not found! id: ${e}`);return t.type===D.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===D.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,n){const{col:i,row:l,unitId:d,subUnitId:c}=a,u=t.uid,m=this.getValidator(t.type);if(m){const f=this._cache.getValue(l,i);return!f||f.value!==e?(this._cache.setValue(l,i,{value:e,status:s.DataValidationStatus.VALIDATING,ruleId:u}),m.validator({value:e,unitId:d,subUnitId:c,row:l,column:i},t).then(p=>{const g=p?s.DataValidationStatus.VALID:s.DataValidationStatus.INVALID;this._cache.setValue(l,i,{value:e,status:g,ruleId:u}),n(g,!0)}),s.DataValidationStatus.VALIDATING):(n(f.status,!1),f.status)}else return n(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 mn=Object.defineProperty,pn=Object.getOwnPropertyDescriptor,fn=(o,r,e,t)=>{for(var a=t>1?void 0:t?pn(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&mn(r,e,a),a},Ye=(o,r)=>(e,t)=>r(e,t,o);let Fe=class extends s.Disposable{constructor(o,r,e,t){super(),this._resourceManagerService=o,this._univerInstanceService=r,this._dataValidationModel=e,this._injector=t,this._initDataValidationDataSource()}_createSheetDataValidationManager(o,r){return new hn(o,r,[],this._injector)}_initDataValidationDataSource(){this._dataValidationModel.setManagerCreator(this._createSheetDataValidationManager.bind(this))}};Fe=fn([s.OnLifecycle(s.LifecycleStages.Starting,Fe),Ye(0,s.IResourceManagerService),Ye(1,s.IUniverInstanceService),Ye(2,y.Inject(D.DataValidationModel)),Ye(3,y.Inject(y.Injector))],Fe);var gn=Object.defineProperty,vn=Object.getOwnPropertyDescriptor,Sn=(o,r,e,t)=>{for(var a=t>1?void 0:t?vn(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&gn(r,e,a),a},ht=(o,r)=>(e,t)=>r(e,t,o);let Ne=class extends s.Disposable{constructor(o,r,e){super(),this._localeService=o,this._commandService=r,this._sheetPermissionInterceptorBaseController=e,this._commandExecutedListener()}_commandExecutedListener(){this.disposeWithMe(this._commandService.beforeCommandExecuted(o=>{o.id===D.AddDataValidationCommand.id&&(this._sheetPermissionInterceptorBaseController.permissionCheckWithRanges({workbookTypes:[U.WorkbookEditablePermission],rangeTypes:[U.RangeProtectionPermissionEditPoint],worksheetTypes:[U.WorksheetEditPermission,U.WorksheetSetCellStylePermission]})||this._sheetPermissionInterceptorBaseController.haveNotPermissionHandle(this._localeService.t("permission.dialog.setStyleErr"))),o.id===Ue.id&&(this._sheetPermissionInterceptorBaseController.permissionCheckWithRanges({workbookTypes:[U.WorkbookEditablePermission],rangeTypes:[U.RangeProtectionPermissionEditPoint],worksheetTypes:[U.WorksheetEditPermission,U.WorksheetSetCellStylePermission]},o.params.ranges)||this._sheetPermissionInterceptorBaseController.haveNotPermissionHandle(this._localeService.t("permission.dialog.setStyleErr")))}))}};Ne=Sn([s.OnLifecycle(s.LifecycleStages.Ready,Ne),ht(0,y.Inject(s.LocaleService)),ht(1,s.ICommandService),ht(2,y.Inject(x.SheetPermissionInterceptorBaseController))],Ne);var _n=Object.defineProperty,Vn=Object.getOwnPropertyDescriptor,Rn=(o,r,e,t)=>{for(var a=t>1?void 0:t?Vn(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&_n(r,e,a),a},mt=(o,r)=>(e,t)=>r(e,t,o);exports.SheetsDataValidationValidatorService=class{constructor(r,e,t){this._univerInstanceService=r,this._dataValidationModel=e,this._dataValidationCacheService=t}async validatorCell(r,e,t,a){const n=this._univerInstanceService.getUnit(r,s.UniverInstanceType.UNIVER_SHEET);if(!n)throw new Error(`cannot find current workbook, unitId: ${r}`);const i=n.getSheetBySheetId(e);if(!i)throw new Error(`cannot find current worksheet, sheetId: ${e}`);const l=i.getCellRaw(t,a),d=this._dataValidationModel.ensureManager(r,e),c=d.getRuleByLocation(t,a);return c?new Promise(u=>{d.validator(te(l),c,{unitId:r,subUnitId:e,row:t,col:a},u)}):s.DataValidationStatus.VALID}async validatorWorksheet(r,e){const a=this._dataValidationModel.ensureManager(r,e).getDataValidations();return await Promise.all(a.map(n=>Promise.all(n.ranges.map(i=>{const l=[];return s.Range.foreach(i,(d,c)=>{l.push(this.validatorCell(r,e,d,c))}),l})))),this._dataValidationCacheService.ensureCache(r,e)}async validatorWorkbook(r){const e=this._dataValidationModel.getSubUnitIds(r),t=await Promise.all(e.map(n=>this.validatorWorksheet(r,n))),a={};return t.forEach((n,i)=>{a[e[i]]=n}),a}};exports.SheetsDataValidationValidatorService=Rn([mt(0,s.IUniverInstanceService),mt(1,y.Inject(D.DataValidationModel)),mt(2,y.Inject(De))],exports.SheetsDataValidationValidatorService);var pa=Object.defineProperty,Dn=Object.getOwnPropertyDescriptor,Cn=(o,r,e)=>r in o?pa(o,r,{enumerable:!0,configurable:!0,writable:!0,value:e}):o[r]=e,In=(o,r,e,t)=>{for(var a=t>1?void 0:t?Dn(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&pa(r,e,a),a},pt=(o,r)=>(e,t)=>r(e,t,o),fa=(o,r,e)=>Cn(o,typeof r!="symbol"?r+"":r,e);exports.UniverSheetsDataValidationPlugin=class extends s.Plugin{constructor(r={},e,t,a){super(),this._config=r,this._injector=e,this._commandService=t,this._localeService=a,this._config=s.Tools.deepMerge({},ca,this._config)}onStarting(r){[[ce],[exports.SheetDataValidationService],[De],[exports.DataValidationFormulaService],[exports.DataValidationCustomFormulaService],[fe],[exports.SheetsDataValidationValidatorService],[Fe],[exports.DataValidationController],[exports.SheetsDataValidationRenderController,{useFactory:()=>this._injector.createInstance(exports.SheetsDataValidationRenderController,this._config)}],[exports.DataValidationAlertController],[exports.DataValidationRefRangeController],[Ne],[exports.DataValidationAutoFillController],[exports.DataValidationCopyPasteController],[exports.DataValidationFormulaController],[exports.DataValidationRejectInputController]].forEach(e=>{r.add(e)}),[Be,et,Ue,_t,sa,Ae,It,Ze,Re,Ct].forEach(e=>{this._commandService.registerCommand(e)})}};fa(exports.UniverSheetsDataValidationPlugin,"pluginName",je);fa(exports.UniverSheetsDataValidationPlugin,"type",s.UniverInstanceType.UNIVER_SHEET);exports.UniverSheetsDataValidationPlugin=In([s.DependentOn(D.UniverDataValidationPlugin,U.UniverSheetsPlugin,x.UniverSheetsUIPlugin),pt(1,y.Inject(y.Injector)),pt(2,s.ICommandService),pt(3,y.Inject(s.LocaleService))],exports.UniverSheetsDataValidationPlugin);var ga=Object.defineProperty,yn=Object.getOwnPropertyDescriptor,Mn=(o,r,e)=>r in o?ga(o,r,{enumerable:!0,configurable:!0,writable:!0,value:e}):o[r]=e,wn=(o,r,e,t)=>{for(var a=t>1?void 0:t?yn(r,e):r,n=o.length-1,i;n>=0;n--)(i=o[n])&&(a=(t?i(r,e,a):i(a))||a);return t&&a&&ga(r,e,a),a},ft=(o,r)=>(e,t)=>r(e,t,o),va=(o,r,e)=>Mn(o,typeof r!="symbol"?r+"":r,e);exports.UniverSheetsDataValidationMobilePlugin=class extends s.Plugin{constructor(r={},e,t,a){super(),this._config=r,this._injector=e,this._commandService=t,this._localeService=a,this._config=s.Tools.deepMerge({},ca,this._config)}onStarting(r){[[ce],[exports.SheetDataValidationService],[De],[exports.DataValidationFormulaService],[exports.DataValidationCustomFormulaService],[fe],[exports.SheetsDataValidationValidatorService],[Fe],[exports.DataValidationController],[be,{useFactory:()=>this._injector.createInstance(be,this._config)}],[exports.DataValidationAlertController],[exports.DataValidationRefRangeController],[Ne],[exports.DataValidationCopyPasteController],[exports.DataValidationFormulaController]].forEach(e=>{r.add(e)}),[Be,et,Ue,Ae,It,Ze,Re,Ct].forEach(e=>{this._commandService.registerCommand(e)})}};va(exports.UniverSheetsDataValidationMobilePlugin,"pluginName",je);va(exports.UniverSheetsDataValidationMobilePlugin,"type",s.UniverInstanceType.UNIVER_SHEET);exports.UniverSheetsDataValidationMobilePlugin=wn([s.DependentOn(D.UniverDataValidationPlugin,U.UniverSheetsPlugin,x.UniverSheetsUIPlugin),ft(1,y.Inject(y.Injector)),ft(2,s.ICommandService),ft(3,y.Inject(s.LocaleService))],exports.UniverSheetsDataValidationMobilePlugin);Object.defineProperty(exports,"ICommandService",{enumerable:!0,get:()=>s.ICommandService});Object.defineProperty(exports,"LocaleService",{enumerable:!0,get:()=>s.LocaleService});Object.defineProperty(exports,"Plugin",{enumerable:!0,get:()=>s.Plugin});exports.AddSheetDataValidationAndOpenCommand=et;exports.AddSheetDataValidationCommand=Be;exports.CloseValidationPanelOperation=Ze;exports.DATA_VALIDATION_PLUGIN_NAME=je;exports.DataValidationCacheService=De;exports.HideDataValidationDropdown=It;exports.OpenValidationPanelOperation=Re;exports.ShowDataValidationDropdown=Ae;exports.ToggleValidationPanelOperation=Ct;exports.UpdateSheetDataValidationRangeCommand=Ue;
|
|
9
|
+
*/var Da=T,Ca=Symbol.for("react.element"),Ia=Symbol.for("react.fragment"),ya=Object.prototype.hasOwnProperty,Ma=Da.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,wa={key:!0,ref:!0,__self:!0,__source:!0};function xt(o,r,e){var t,a={},n=null,s=null;e!==void 0&&(n=""+e),r.key!==void 0&&(n=""+r.key),r.ref!==void 0&&(s=r.ref);for(t in r)ya.call(r,t)&&!wa.hasOwnProperty(t)&&(a[t]=r[t]);if(o&&o.defaultProps)for(t in r=o.defaultProps,r)a[t]===void 0&&(a[t]=r[t]);return{$$typeof:Ca,type:o,key:n,ref:s,props:a,_owner:Ma.current}}ze.Fragment=Ia;ze.jsx=xt;ze.jsxs=xt;jt.exports=ze;var v=jt.exports;function Oa(){const o=i.useDependency(me),r=k.useObservable(o.activeDropdown$,o.activeDropdown),e=i.useDependency(k.ComponentManager);if(!r)return null;const{location:t,componentKey:a}=r,n=e.get(a),s=`${t.unitId}-${t.subUnitId}-${t.row}-${t.col}`;if(!n)return null;const l=()=>{o.hideDropdown()};return v.jsx(n,{location:t,hideFn:l},s)}const Ut="sheet.ui.dropdown";var Ta=Object.defineProperty,Ea=Object.getOwnPropertyDescriptor,ba=(o,r,e,t)=>{for(var a=t>1?void 0:t?Ea(r,e):r,n=o.length-1,s;n>=0;n--)(s=o[n])&&(a=(t?s(r,e,a):s(a))||a);return t&&a&&Ta(r,e,a),a},Re=(o,r)=>(e,t)=>r(e,t,o);let me=class extends i.Disposable{constructor(r,e,t,a,n,s){super();R(this,"_activeDropdown");R(this,"_activeDropdown$",new ve.Subject);R(this,"_currentPopup",null);R(this,"activeDropdown$",this._activeDropdown$.asObservable());R(this,"_zenVisible",!1);this._canvasPopupManagerService=r,this._univerInstanceService=e,this._dataValidatorRegistryService=t,this._zenZoneService=a,this._renderManagerService=n,this._dataValidationModel=s,this._init(),this.disposeWithMe(()=>{this._activeDropdown$.complete()})}get activeDropdown(){return this._activeDropdown}_init(){this.disposeWithMe(this._zenZoneService.visible$.subscribe(r=>{this._zenVisible=r,r&&this.hideDropdown()}))}showDropdown(r,e=!0){const{location:t}=r,{row:a,col:n}=t;if(this._currentPopup&&this._currentPopup.dispose(),this._zenVisible)return;this._activeDropdown=r,this._activeDropdown$.next(this._activeDropdown);const s=this._renderManagerService.getRenderById(i.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),l=this._canvasPopupManagerService.attachPopupToCell(a,n,{componentKey:Ut,onClickOutside:()=>{e&&this.hideDropdown()},offset:[0,3],excludeOutside:[s==null?void 0:s.engine.getCanvasElement()].filter(Boolean)});if(!l)throw new Error("[DataValidationDropdownManagerService]: cannot show dropdown!");const d=new i.DisposableCollection;d.add(l),d.add({dispose:()=>{var c,u;(u=(c=this._activeDropdown)==null?void 0:c.onHide)==null||u.call(c)}}),this._currentPopup=d}hideDropdown(){this._activeDropdown&&(this._currentPopup&&this._currentPopup.dispose(),this._currentPopup=null,this._activeDropdown=null,this._activeDropdown$.next(null))}showDataValidationDropdown(r,e,t,a,n){const s=this._univerInstanceService.getUniverSheetInstance(r);if(!s)return;const l=s.getSheetBySheetId(e);if(!l)return;const c=this._dataValidationModel.ensureManager(r,e).getRuleByLocation(t,a);if(!c)return;const u=this._dataValidatorRegistryService.getValidatorItem(c.type);if(!u||!u.dropdown){this.hideDropdown();return}this.showDropdown({location:{workbook:s,worksheet:l,row:t,col:a,unitId:r,subUnitId:e},componentKey:u.dropdown,onHide:n})}};me=ba([Re(0,i.Inject(j.SheetCanvasPopManagerService)),Re(1,i.IUniverInstanceService),Re(2,i.Inject(D.DataValidatorRegistryService)),Re(3,k.IZenZoneService),Re(4,z.IRenderManagerService),Re(5,i.Inject(D.DataValidationModel))],me);var Fa=Object.defineProperty,Na=Object.getOwnPropertyDescriptor,La=(o,r,e,t)=>{for(var a=t>1?void 0:t?Na(r,e):r,n=o.length-1,s;n>=0;n--)(s=o[n])&&(a=(t?s(r,e,a):s(a))||a);return t&&a&&Fa(r,e,a),a},Mt=(o,r)=>(e,t)=>r(e,t,o);let le=class extends i.Disposable{constructor(r,e){super();R(this,"_open$",new ve.BehaviorSubject(!1));R(this,"open$",this._open$.pipe(ve.distinctUntilChanged()));R(this,"_activeRule");R(this,"_activeRule$",new ve.BehaviorSubject(void 0));R(this,"activeRule$",this._activeRule$.asObservable());R(this,"_closeDisposable",null);this._univerInstanceService=r,this._sidebarService=e,this.disposeWithMe(this._univerInstanceService.getCurrentTypeOfUnit$(i.UniverInstanceType.UNIVER_SHEET).pipe(ve.filter(t=>!t)).subscribe(()=>{this.close()}))}get activeRule(){return this._activeRule}get isOpen(){return this._open$.getValue()}dispose(){var r;super.dispose(),this._open$.next(!1),this._open$.complete(),this._activeRule$.complete(),(r=this._closeDisposable)==null||r.dispose()}open(){this._open$.next(!0)}close(){var r;this._open$.next(!1),(r=this._closeDisposable)==null||r.dispose()}setCloseDisposable(r){this._closeDisposable=i.toDisposable(()=>{r.dispose(),this._closeDisposable=null})}setActiveRule(r){this._activeRule=r,this._activeRule$.next(r)}};le=La([Mt(0,i.IUniverInstanceService),Mt(1,k.ISidebarService)],le);const $t="DataValidationPanel",_e={id:"data-validation.operation.open-validation-panel",type:i.CommandType.OPERATION,handler(o,r){if(!r)return!1;const{ruleId:e,isAdd:t}=r,a=o.get(le),n=o.get(D.DataValidationModel),s=o.get(i.IUniverInstanceService),l=o.get(k.ISidebarService),d=x.getSheetCommandTarget(s);if(!d)return!1;const{unitId:c,subUnitId:u}=d,m=e?n.getRuleById(c,u,e):void 0;a.open(),a.setActiveRule(m&&{unitId:c,subUnitId:u,rule:m});const f=l.open({header:{title:t?"dataValidation.panel.addTitle":"dataValidation.panel.title"},children:{label:$t},width:312,onClose:()=>a.close()});return a.setCloseDisposable(f),!0}},Ke={id:"data-validation.operation.close-validation-panel",type:i.CommandType.OPERATION,handler(o){return o.get(le).close(),!0}},Rt={id:"data-validation.operation.toggle-validation-panel",type:i.CommandType.OPERATION,handler(o){const r=o.get(i.ICommandService),e=o.get(le);return e.open(),e.isOpen?r.executeCommand(Ke.id):r.executeCommand(_e.id),!0}},Le={type:i.CommandType.OPERATION,id:"sheet.operation.show-data-validation-dropdown",handler(o,r){if(!r)return!1;const e=o.get(me),{unitId:t,subUnitId:a,row:n,column:s}=r,l=e.activeDropdown,d=l==null?void 0:l.location;return d&&d.unitId===t&&d.subUnitId===a&&d.row===n&&d.col===s||e.showDataValidationDropdown(t,a,n,s),!0}},Dt={type:i.CommandType.OPERATION,id:"sheet.operation.hide-data-validation-dropdown",handler(o,r){return r?(o.get(me).hideDropdown(),!0):!1}};class Ve{constructor(){R(this,"_cacheMatrix",new Map)}_ensureCache(r,e){let t=this._cacheMatrix.get(r);t||(t=new Map,this._cacheMatrix.set(r,t));let a=t.get(e);return a||(a=new i.ObjectMatrix,t.set(e,a)),a}ensureCache(r,e){return this._ensureCache(r,e)}addRule(r,e,t){this.markRangeDirty(r,e,t.ranges)}removeRule(r,e,t){this._deleteRange(r,e,t.ranges)}updateRuleRanges(r,e,t,a,n){const s=this._ensureCache(r,e);n.forEach(l=>{i.Range.foreach(l,(d,c)=>{const u=s.getValue(d,c);u&&(u.temp=!0)})}),a.forEach(l=>{i.Range.foreach(l,(d,c)=>{const u=s.getValue(d,c);u&&u.ruleId===t?u.temp=!1:s.setValue(d,c,void 0)})}),n.forEach(l=>{i.Range.foreach(l,(d,c)=>{const u=s.getValue(d,c);u&&u.temp===!0&&s.realDeleteValue(d,c)})})}markRangeDirty(r,e,t){const a=this._ensureCache(r,e);t.forEach(n=>{i.Range.foreach(n,(s,l)=>{a.setValue(s,l,void 0)})})}markCellDirty(r,e,t,a){this._ensureCache(r,e).setValue(t,a,void 0)}_deleteRange(r,e,t){const a=this._ensureCache(r,e);t.forEach(n=>{i.Range.foreach(n,(s,l)=>{a.realDeleteValue(s,l)})})}getValue(r,e,t,a){return this._ensureCache(r,e).getValue(t,a)}setValue(r,e,t,a,n){return this._ensureCache(r,e).setValue(t,a,n)}}var Pa=Object.defineProperty,Aa=Object.getOwnPropertyDescriptor,ja=(o,r,e,t)=>{for(var a=t>1?void 0:t?Aa(r,e):r,n=o.length-1,s;n>=0;n--)(s=o[n])&&(a=(t?s(r,e,a):s(a))||a);return t&&a&&Pa(r,e,a),a},Je=(o,r)=>(e,t)=>r(e,t,o);exports.DataValidationFormulaService=class extends i.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 n in a){const s=a[n],l=this._ensureRuleFormulaMap(t,n),d=this._dataValidationModel.ensureManager(t,n);s.forEach(c=>{var u,m;if(l.get((u=c.extra)==null?void 0:u.ruleId)){const f=d.getRuleById((m=c.extra)==null?void 0:m.ruleId);f&&this._dataValidationCacheService.markRangeDirty(t,n,f.ranges)}})}}}))}_ensureRuleFormulaMap(e,t){let a=this._formulaRuleMap.get(e);a||(a=new Map,this._formulaRuleMap.set(e,a));let n=a.get(t);return n||(n=new Map,a.set(t,n)),n}addRule(e,t,a,n,s){const l=i.isFormulaString(n),d=i.isFormulaString(s);if(!l&&!d)return;const c=this._ensureRuleFormulaMap(e,t),u=[void 0,void 0];if(l){const m=this._registerOtherFormulaService.registerFormula(e,t,n,{ruleId:a});u[0]={id:m,text:n}}if(d){const m=this._registerOtherFormulaService.registerFormula(e,t,s,{ruleId:a});u[1]={id:m,text:s}}c.set(a,u)}removeRule(e,t,a){const s=this._ensureRuleFormulaMap(e,t).get(a);if(!s)return;const[l,d]=s,c=[l==null?void 0:l.id,d==null?void 0:d.id].filter(Boolean);c.length&&this._registerOtherFormulaService.deleteFormula(e,t,c)}updateRuleFormulaText(e,t,a,n,s){const d=this._ensureRuleFormulaMap(e,t).get(a);if(!d){this.addRule(e,t,a,n,s);return}const[c,u]=d;if((c==null?void 0:c.text)!==n)if(c&&this._registerOtherFormulaService.deleteFormula(e,t,[c.id]),i.isFormulaString(n)){const m=this._registerOtherFormulaService.registerFormula(e,t,n,{ruleId:a});d[0]={text:n,id:m}}else d[0]=void 0;if((u==null?void 0:u.text)!==s)if(u&&this._registerOtherFormulaService.deleteFormula(e,t,[u.id]),i.isFormulaString(s)){const m=this._registerOtherFormulaService.registerFormula(e,t,s,{ruleId:a});d[1]={text:s,id:m}}else d[1]=void 0}getRuleFormulaResult(e,t,a){const s=this._ensureRuleFormulaMap(e,t).get(a);if(!s)return Promise.resolve(null);const l=async d=>d&&this._registerOtherFormulaService.getFormulaValue(e,t,d.id);return Promise.all([l(s[0]),l(s[1])])}getRuleFormulaResultSync(e,t,a){const s=this._ensureRuleFormulaMap(e,t).get(a);if(s)return s.map(l=>{if(l)return this._registerOtherFormulaService.getFormulaValueSync(e,t,l.id)})}getRuleFormulaInfo(e,t,a){return this._ensureRuleFormulaMap(e,t).get(a)}};exports.DataValidationFormulaService=ja([Je(0,i.Inject(Vt.RegisterOtherFormulaService)),Je(1,i.Inject(Ve)),Je(2,i.Inject(D.DataValidationModel))],exports.DataValidationFormulaService);function oe(o){var r,e;return(e=(r=o==null?void 0:o[0])==null?void 0:r[0])==null?void 0:e.v}var xa=Object.defineProperty,Ua=Object.getOwnPropertyDescriptor,$a=(o,r,e,t)=>{for(var a=t>1?void 0:t?Ua(r,e):r,n=o.length-1,s;n>=0;n--)(s=o[n])&&(a=(t?s(r,e,a):s(a))||a);return t&&a&&xa(r,e,a),a},et=(o,r)=>(e,t)=>r(e,t,o);const Ue=6;let ft=class{constructor(o,r,e){this._commandService=o,this._formulaService=r,this._themeService=e}_calc(o,r){var c,u,m;const{vt:e,ht:t}=r||{},a=o.endX-o.startX-Ue*2,n=o.endY-o.startY,s=((c=r==null?void 0:r.fs)!=null?c:10)*1.6;let l=0,d=0;switch(e){case i.VerticalAlign.TOP:d=0;break;case i.VerticalAlign.BOTTOM:d=0+(n-s);break;default:d=0+(n-s)/2;break}switch(t){case i.HorizontalAlign.LEFT:l=Ue;break;case i.HorizontalAlign.RIGHT:l=Ue+(a-s);break;default:l=Ue+(a-s)/2;break}return{left:o.startX+l,top:o.startY+d,width:((u=r==null?void 0:r.fs)!=null?u:10)*1.6,height:((m=r==null?void 0:r.fs)!=null?m:10)*1.6}}calcCellAutoHeight(o){var e;const{style:r}=o;return((e=r==null?void 0:r.fs)!=null?e:10)*1.6}async _parseFormula(o,r,e){var s,l;const{formula1:t=Fe,formula2:a=Ne}=o,n=await this._formulaService.getRuleFormulaResult(r,e,o.uid);return{formula1:i.isFormulaString(t)?oe((s=n==null?void 0:n[0])==null?void 0:s.result):t,formula2:i.isFormulaString(a)?oe((l=n==null?void 0:n[1])==null?void 0:l.result):a}}drawWith(o,r){var U,E,$,W,P;const{style:e,data:t,primaryWithCoord:a,unitId:n,subUnitId:s}=r,l=a.isMergedMainCell?a.mergeInfo:a,d=J(t),c=(U=t.dataValidation)==null?void 0:U.rule,u=(E=t.dataValidation)==null?void 0:E.validator;if(!c||!u)return;const m=this._themeService.getCurrentTheme();if(!u.skipDefaultFontRender(c,d,{unitId:n,subUnitId:s}))return;const f=u.parseFormulaSync(c,n,s),{formula1:p}=f,g=this._calc(l,e),{a:h,d:_}=o.getTransform(),S=z.fixLineWidthByScale(g.left,h),C=z.fixLineWidthByScale(g.top,_),V=z.Transform.create().composeMatrix({left:S,top:C,scaleX:1,scaleY:1,angle:0,skewX:0,skewY:0,flipX:!1,flipY:!1}),I=l.endX-l.startX,M=l.endY-l.startY;o.save(),o.beginPath(),o.rect(l.startX,l.startY,I,M),o.clip();const O=V.getMatrix();o.transform(O[0],O[1],O[2],O[3],O[4],O[5]);const b=(($=e==null?void 0:e.fs)!=null?$:10)*1.6,A=String(d)===String(p),L=m.hyacinth500;z.Checkbox.drawWith(o,{checked:A,width:b,height:b,fill:(P=(W=e==null?void 0:e.cl)==null?void 0:W.rgb)!=null?P:L}),o.restore()}isHit(o,r){const e=r.primaryWithCoord.isMergedMainCell?r.primaryWithCoord.mergeInfo:r.primaryWithCoord,t=this._calc(e,r.style),a=t.top,n=t.top+t.height,s=t.left,l=t.left+t.width,{x:d,y:c}=o;return d<=l&&d>=s&&c<=n&&c>=a}async onPointerDown(o,r){var f,p;if(r.button===2)return;const{primaryWithCoord:e,unitId:t,subUnitId:a,data:n}=o,s=J(n),l=(f=n.dataValidation)==null?void 0:f.rule,d=(p=n.dataValidation)==null?void 0:p.validator;if(!l||!d||!d.skipDefaultFontRender(l,s,{unitId:t,subUnitId:a}))return;const{formula1:c,formula2:u}=await this._parseFormula(l,t,a),m={range:{startColumn:e.actualColumn,endColumn:e.actualColumn,startRow:e.actualRow,endRow:e.actualRow},value:{v:String(s)===String(c)?u:c,p:null}};this._commandService.executeCommand(x.SetRangeValuesCommand.id,m)}};ft=$a([et(0,i.ICommandService),et(1,i.Inject(exports.DataValidationFormulaService)),et(2,i.Inject(i.ThemeService))],ft);function Ba(o){var d;const{unitId:r,subUnitId:e,value:t,onChange:a,showError:n,validResult:s}=o,l=n?s==null?void 0:s.formula1:"";return v.jsx(w.FormLayout,{error:l,children:v.jsx(k.TextEditor,{value:(d=t==null?void 0:t.formula1)!=null?d:"",id:i.createInternalEditorID(`dataValidation-custom-formula-${r}-${e}`),onChange:c=>{a==null||a({...t,formula1:c!=null?c:""})},onlyInputFormula:!0,openForSheetUnitId:r,openForSheetSubUnitId:e})})}const Wa="univer-data-validation-formula",Ha="univer-data-validation-formula-and",ka="univer-data-validation-formula-list-item",Ya="univer-data-validation-formula-list-item-icon",qa="univer-data-validation-formula-list-item-drag",Xa="univer-data-validation-formula-list-add",Ga="univer-data-validation-formula-color-select",za="univer-data-validation-formula-color-select-panel",Ka="univer-data-validation-formula-color-item",te={dataValidationFormula:Wa,dataValidationFormulaAnd:Ha,dataValidationFormulaListItem:ka,dataValidationFormulaListItemIcon:Ya,dataValidationFormulaListItemDrag:qa,dataValidationFormulaListAdd:Xa,dataValidationFormulaColorSelect:Ga,dataValidationFormulaColorSelectPanel:za,dataValidationFormulaColorItem:Ka},Qa=o=>{const{isTwoFormula:r=!1,value:e,onChange:t,showError:a,validResult:n}=o,s=i.useDependency(i.LocaleService),l=a?n==null?void 0:n.formula1:"",d=a?n==null?void 0:n.formula2:"";return r?v.jsxs(v.Fragment,{children:[v.jsx(w.FormLayout,{error:l,children:v.jsx(w.Input,{className:te.dataValidationFormula,placeholder:s.t("dataValidation.panel.formulaPlaceholder"),value:e==null?void 0:e.formula1,onChange:c=>{t==null||t({...e,formula1:c})}})}),v.jsx("div",{className:te.dataValidationFormulaAnd,children:s.t("dataValidation.panel.formulaAnd")}),v.jsx(w.FormLayout,{error:d,children:v.jsx(w.Input,{className:te.dataValidationFormula,placeholder:s.t("dataValidation.panel.formulaPlaceholder"),value:e==null?void 0:e.formula2,onChange:c=>{t==null||t({...e,formula2:c})}})})]}):v.jsx(w.FormLayout,{error:l,children:v.jsx(w.Input,{className:te.dataValidationFormula,placeholder:s.t("dataValidation.panel.formulaPlaceholder"),value:e==null?void 0:e.formula1,onChange:c=>{t==null||t({formula1:c})}})})};var re=function(){return re=Object.assign||function(o){for(var r,e=1,t=arguments.length;e<t;e++){r=arguments[e];for(var a in r)Object.prototype.hasOwnProperty.call(r,a)&&(o[a]=r[a])}return o},re.apply(this,arguments)},Za=function(o,r){var e={};for(var t in o)Object.prototype.hasOwnProperty.call(o,t)&&r.indexOf(t)<0&&(e[t]=o[t]);if(o!=null&&typeof Object.getOwnPropertySymbols=="function")for(var a=0,t=Object.getOwnPropertySymbols(o);a<t.length;a++)r.indexOf(t[a])<0&&Object.prototype.propertyIsEnumerable.call(o,t[a])&&(e[t[a]]=o[t[a]]);return e},pe=T.forwardRef(function(o,r){var e=o.icon,t=o.id,a=o.className,n=o.extend,s=Za(o,["icon","id","className","extend"]),l="univerjs-icon univerjs-icon-".concat(t," ").concat(a||"").trim(),d=T.useRef("_".concat(tr()));return Bt(e,"".concat(t),{defIds:e.defIds,idSuffix:d.current},re({ref:r,className:l},s),n)});function Bt(o,r,e,t,a){return T.createElement(o.tag,re(re({key:r},Ja(o,e,a)),t),(er(o,e).children||[]).map(function(n,s){return Bt(n,"".concat(r,"-").concat(o.tag,"-").concat(s),e,void 0,a)}))}function Ja(o,r,e){var t=re({},o.attrs);e!=null&&e.colorChannel1&&t.fill==="colorChannel1"&&(t.fill=e.colorChannel1);var a=r.defIds;return!a||a.length===0||(o.tag==="use"&&t["xlink:href"]&&(t["xlink:href"]=t["xlink:href"]+r.idSuffix),Object.entries(t).forEach(function(n){var s=n[0],l=n[1];typeof l=="string"&&(t[s]=l.replace(/url\(#(.*)\)/,"url(#$1".concat(r.idSuffix,")")))})),t}function er(o,r){var e,t=r.defIds;return!t||t.length===0?o:o.tag==="defs"&&(!((e=o.children)===null||e===void 0)&&e.length)?re(re({},o),{children:o.children.map(function(a){return typeof a.attrs.id=="string"&&t&&t.indexOf(a.attrs.id)>-1?re(re({},a),{attrs:re(re({},a.attrs),{id:a.attrs.id+r.idSuffix})}):a})}):o}function tr(){return Math.random().toString(36).substring(2,8)}pe.displayName="UniverIcon";var ar={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"}}]},Wt=T.forwardRef(function(o,r){return T.createElement(pe,Object.assign({},o,{id:"check-mark-single",ref:r,icon:ar}))});Wt.displayName="CheckMarkSingle";var rr={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"}}]},Ht=T.forwardRef(function(o,r){return T.createElement(pe,Object.assign({},o,{id:"data-validation-single",ref:r,icon:rr}))});Ht.displayName="DataValidationSingle";var or={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"}}]},Ct=T.forwardRef(function(o,r){return T.createElement(pe,Object.assign({},o,{id:"delete-single",ref:r,icon:or}))});Ct.displayName="DeleteSingle";var nr={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"}}]},kt=T.forwardRef(function(o,r){return T.createElement(pe,Object.assign({},o,{id:"increase-single",ref:r,icon:nr}))});kt.displayName="IncreaseSingle";var ir={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"}}]},Yt=T.forwardRef(function(o,r){return T.createElement(pe,Object.assign({},o,{id:"more-down-single",ref:r,icon:ir}))});Yt.displayName="MoreDownSingle";var sr={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"}}]},qt=T.forwardRef(function(o,r){return T.createElement(pe,Object.assign({},o,{id:"more-up-single",ref:r,icon:sr}))});qt.displayName="MoreUpSingle";var lr={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"}}]}]},Xt=T.forwardRef(function(o,r){return T.createElement(pe,Object.assign({},o,{id:"sequence-single",ref:r,icon:lr}))});Xt.displayName="SequenceSingle";function Gt(o){return o.filter(Boolean).join(",")}function ye(o){return o.split(",").filter(Boolean)}function dr(o){const r=J(o);return r==null?"":r.toString()}const Pe="SHEET_DATA_VALIDATION_PLUGIN",Se="#ECECEC";var ke=(o=>(o[o.View=0]="View",o[o.Edit=1]="Edit",o[o.ManageCollaborator=2]="ManageCollaborator",o[o.Print=3]="Print",o[o.Duplicate=4]="Duplicate",o[o.Comment=5]="Comment",o[o.Copy=6]="Copy",o[o.Share=7]="Share",o[o.Export=8]="Export",o[o.MoveWorksheet=9]="MoveWorksheet",o[o.DeleteWorksheet=10]="DeleteWorksheet",o[o.HideWorksheet=11]="HideWorksheet",o[o.RenameWorksheet=12]="RenameWorksheet",o[o.CreateWorksheet=13]="CreateWorksheet",o[o.SetWorksheetStyle=14]="SetWorksheetStyle",o[o.EditWorksheetCell=15]="EditWorksheetCell",o[o.InsertHyperlink=16]="InsertHyperlink",o[o.Sort=17]="Sort",o[o.Filter=18]="Filter",o[o.PivotTable=19]="PivotTable",o[o.FloatImg=20]="FloatImg",o[o.History=21]="History",o[o.RwHgtClWdt=22]="RwHgtClWdt",o[o.ViemRwHgtClWdt=23]="ViemRwHgtClWdt",o[o.ViewFilter=24]="ViewFilter",o[o.MoveSheet=25]="MoveSheet",o[o.DeleteSheet=26]="DeleteSheet",o[o.HideSheet=27]="HideSheet",o[o.CopySheet=28]="CopySheet",o[o.RenameSheet=29]="RenameSheet",o[o.CreateSheet=30]="CreateSheet",o[o.SelectProtectedCells=31]="SelectProtectedCells",o[o.SelectUnProtectedCells=32]="SelectUnProtectedCells",o[o.SetCellStyle=33]="SetCellStyle",o[o.SetCellValue=34]="SetCellValue",o[o.SetRowStyle=35]="SetRowStyle",o[o.SetColumnStyle=36]="SetColumnStyle",o[o.InsertRow=37]="InsertRow",o[o.InsertColumn=38]="InsertColumn",o[o.DeleteRow=39]="DeleteRow",o[o.DeleteColumn=40]="DeleteColumn",o[o.EditExtraObject=41]="EditExtraObject",o[o.Delete=42]="Delete",o[o.RecoverHistory=43]="RecoverHistory",o[o.ViewHistory=44]="ViewHistory",o[o.UNRECOGNIZED=-1]="UNRECOGNIZED",o))(ke||{}),cr=Object.defineProperty,ur=Object.getOwnPropertyDescriptor,hr=(o,r,e,t)=>{for(var a=t>1?void 0:t?ur(r,e):r,n=o.length-1,s;n>=0;n--)(s=o[n])&&(a=(t?s(r,e,a):s(a))||a);return t&&a&&cr(r,e,a),a},tt=(o,r)=>(e,t)=>r(e,t,o);exports.DataValidationFormulaController=class extends i.Disposable{constructor(r,e,t){super(),this._univerInstanceService=r,this._permissionService=e,this._lexerTreeBuilder=t}getFormulaRefCheck(r){var t,a;const e=this._lexerTreeBuilder.sequenceNodesBuilder(r);if(!e)return!0;for(let n=0;n<e.length;n++){const s=e[n];if(typeof s=="string")continue;const{token:l}=s,d=ae.deserializeRangeWithSheet(l),c=this._univerInstanceService.getCurrentUnitForType(i.UniverInstanceType.UNIVER_SHEET);let u=c.getActiveSheet();const m=c.getUnitId();if(d.sheetName){if(u=c.getSheetBySheetName(d.sheetName),!u)return!1;const _=u==null?void 0:u.getSheetId();if(!this._permissionService.getPermissionPoint(new x.WorksheetViewPermission(m,_).id))return!1}if(!u)return!1;const{startRow:f,endRow:p,startColumn:g,endColumn:h}=d.range;for(let _=f;_<=p;_++)for(let S=g;S<=h;S++){const C=(a=(t=u.getCell(_,S))==null?void 0:t.selectionProtection)==null?void 0:a[0];if((C==null?void 0:C[ke.View])===!1)return!1}}return!0}};exports.DataValidationFormulaController=hr([i.OnLifecycle(i.LifecycleStages.Rendered,exports.DataValidationFormulaController),tt(0,i.IUniverInstanceService),tt(1,i.IPermissionService),tt(2,i.Inject(ae.LexerTreeBuilder))],exports.DataValidationFormulaController);const mr=["#FFFFFF","#FEE7E7","#FEF0E6","#EFFBD0","#E4F4FE","#E8ECFD","#F1EAFA","#FDE8F3","#E5E5E5","#FDCECE","#FDC49B","#DEF6A2","#9FDAFF","#D0D9FB","#E3D5F6","#FBD0E8","#656565","#FE4B4B","#FF8C51","#8BBB11","#0B9EFB","#3A60F7","#9E6DE3","#F248A6"],pr=o=>{const{value:r,onChange:e,disabled:t}=o,[a,n]=T.useState(!1);return v.jsx(w.Select,{disabled:t,open:a,onDropdownVisibleChange:n,dropdownStyle:{width:112},className:te.dataValidationFormulaColorSelect,value:r,onChange:e,labelRender:s=>v.jsx("div",{className:te.dataValidationFormulaColorItem,style:{background:s.value,marginTop:5}}),dropdownRender:()=>v.jsx("div",{className:te.dataValidationFormulaColorSelectPanel,children:mr.map(s=>v.jsx("div",{onClick:()=>{e(s),n(!1)},className:te.dataValidationFormulaColorItem,style:{background:s}},s))})})},wt=o=>{const{item:r,commonProps:e,style:t}=o,{onItemChange:a,onItemDelete:n}=e;return v.jsxs("div",{className:te.dataValidationFormulaListItem,style:t,children:[r.isRef?null:v.jsx("div",{className:Sa(te.dataValidationFormulaListItemDrag,"draggableHandle"),children:v.jsx(Xt,{})}),v.jsx(pr,{value:r.color,onChange:s=>{a(r.id,r.label,s)}}),v.jsx(w.Input,{disabled:r.isRef,value:r.label,onChange:s=>{a(r.id,s,r.color)}}),r.isRef?null:v.jsx("div",{className:te.dataValidationFormulaListItemIcon,children:v.jsx(Ct,{onClick:()=>n(r.id)})})]})};function fr(o){const{value:r,onChange:e=()=>{},unitId:t,subUnitId:a,validResult:n,showError:s,ruleId:l}=o,{formula1:d="",formula2:c=""}=r||{},u=T.useRef(null),[m,f]=T.useState(()=>i.isFormulaString(d)?"1":"0"),[p,g]=T.useState(m==="1"?d:"="),[h,_]=T.useState(m==="1"?d:"="),S=i.useDependency(i.LocaleService),C=i.useDependency(D.DataValidatorRegistryService),V=i.useDependency(D.DataValidationModel),I=i.useDependency(exports.DataValidationFormulaController),[M,O]=T.useState(()=>c.split(",")),b=C.getValidatorItem(i.DataValidationType.LIST),[A,L]=T.useState([]),[U,E]=T.useState(""),$=s?n==null?void 0:n.formula1:"",W=k.useObservable(V.ruleChange$),P=k.useEvent(e);T.useEffect(()=>{(async()=>{await new Promise(G=>{setTimeout(()=>G(!0),100)});const F=V.getRuleById(t,a,l),q=F==null?void 0:F.formula1;if(i.isFormulaString(q)&&b&&F){const G=await b.getListAsync(F,t,a);L(G)}})()},[V,W,b,l,a,t]),T.useEffect(()=>{i.isFormulaString(d)&&d!==h&&(g(d),_(h))},[h,d]);const[N,H]=T.useState(()=>{const F=m!=="1"?ye(d):[],q=c.split(",");return F.map((G,ee)=>({label:G,color:q[ee]||Se,isRef:!1,id:i.Tools.generateRandomId(4)}))}),K=(F,q,G)=>{const ee=N.find(de=>de.id===F);ee&&(ee.label=q,ee.color=G,H([...N]))},Y=F=>{const q=N.findIndex(G=>G.id===F);q!==-1&&(N.splice(q,1),H([...N]))},y=c.split(","),B=T.useMemo(()=>A.map((F,q)=>({label:F,color:y[q]||Se,id:`${q}`,isRef:!0})),[y,A]),Z=(F,q,G)=>{const ee=[...M];ee[+F]=G,O(ee),P({formula1:d,formula2:ee.join(",")})},X=()=>{H([...N,{label:"",color:Se,isRef:!1,id:i.Tools.generateRandomId(4)}])};T.useEffect(()=>{if(m==="1")return;const F=new Set,q=[];N.map(G=>({labelList:G.label.split(","),item:G})).forEach(({item:G,labelList:ee})=>{ee.forEach(de=>{F.has(de)||(F.add(de),q.push({label:de,color:G.color}))})}),P({formula1:Gt(q.map(G=>G.label)),formula2:q.map(G=>G.color===Se?"":G.color).join(",")})},[N,P,m,h,M]);const ne=T.useMemo(()=>async F=>{if(!i.isFormulaString(F)){P==null||P({formula1:"",formula2:c});return}I.getFormulaRefCheck(F)?(P==null||P({formula1:i.isFormulaString(F)?F:"",formula2:c}),E("")):(P==null||P({formula1:"",formula2:c}),g("="),E(S.t("dataValidation.validFail.formulaError")))},[c,P]);return v.jsxs(v.Fragment,{children:[v.jsx(w.FormLayout,{label:S.t("dataValidation.list.options"),children:v.jsxs(w.RadioGroup,{value:m,onChange:F=>{f(F),g(h),F==="1"&&P({formula1:h==="="?"":h,formula2:M.join(",")})},children:[v.jsx(w.Radio,{value:"0",children:S.t("dataValidation.list.customOptions")}),v.jsx(w.Radio,{value:"1",children:S.t("dataValidation.list.refOptions")})]})}),m==="1"?v.jsxs(v.Fragment,{children:[v.jsx(w.FormLayout,{error:$||U,children:v.jsx(k.TextEditor,{id:i.createInternalEditorID(`list-ref-range-${t}-${a}`),value:p,openForSheetUnitId:t,openForSheetSubUnitId:a,onlyInputFormula:!0,onChange:async F=>{const q=F!=null?F:"";_(q),ne(q)}})}),v.jsx(w.FormLayout,{children:v.jsx("div",{ref:u,children:B.map(F=>v.jsx(wt,{item:F,commonProps:{onItemChange:Z},style:{marginBottom:12}},F.id))})})]}):v.jsx(w.FormLayout,{error:$,children:v.jsxs("div",{ref:u,style:{marginTop:"-12px"},children:[v.jsx(w.DraggableList,{list:N,onListChange:H,rowHeight:32,margin:[0,12],draggableHandle:".draggableHandle",itemRender:F=>v.jsx(wt,{item:F,commonProps:{onItemChange:K,onItemDelete:Y}},F.id),idKey:"id"}),v.jsxs("a",{className:te.dataValidationFormulaListAdd,onClick:X,children:[v.jsx(kt,{}),S.t("dataValidation.list.add")]})]})})]})}function gr(o){const{value:r,onChange:e,showError:t,validResult:a}=o,n=i.useDependency(i.LocaleService),s=t?a==null?void 0:a.formula1:"",l=t?a==null?void 0:a.formula2:"",[d,c]=T.useState(!((r==null?void 0:r.formula1)===void 0&&(r==null?void 0:r.formula2)===void 0));return v.jsxs(v.Fragment,{children:[v.jsx(w.FormLayout,{children:v.jsx(w.Checkbox,{checked:d,onChange:u=>{u?c(!0):(c(!1),e==null||e({...r,formula1:void 0,formula2:void 0}))},children:n.t("dataValidation.checkbox.tips")})}),d?v.jsx(w.FormLayout,{label:n.t("dataValidation.checkbox.checked"),error:s,children:v.jsx(w.Input,{className:te.dataValidationFormula,placeholder:n.t("dataValidation.panel.valuePlaceholder"),value:r==null?void 0:r.formula1,onChange:u=>{e==null||e({...r,formula1:u||void 0})}})}):null,d?v.jsx(w.FormLayout,{label:n.t("dataValidation.checkbox.unchecked"),error:l,children:v.jsx(w.Input,{className:te.dataValidationFormula,placeholder:n.t("dataValidation.panel.valuePlaceholder"),value:r==null?void 0:r.formula2,onChange:u=>{e==null||e({...r,formula2:u||void 0})}})}):null]})}const zt="data-validation.custom-formula-input",Ae="data-validation.formula-input",Kt="data-validation.list-formula-input",Qt="data-validation.checkbox-formula-input",vr=[[zt,Ba],[Ae,Qa],[Kt,fr],[Qt,gr]],Fe=1,Ne=0;function Ot(o,r){return i.Tools.isBlank(o)?r.t("dataValidation.validFail.value"):i.isFormulaString(o)?r.t("dataValidation.validFail.primitive"):""}class Sr extends D.BaseDataValidator{constructor(){super(...arguments);R(this,"id",i.DataValidationType.CHECKBOX);R(this,"title","dataValidation.checkbox.title");R(this,"operators",[]);R(this,"scopes",["sheet"]);R(this,"formulaInput",Qt);R(this,"canvasRender",this.injector.createInstance(ft));R(this,"_formulaService",this.injector.get(exports.DataValidationFormulaService))}skipDefaultFontRender(e,t,a){const{formula1:n,formula2:s}=this.parseFormulaSync(e,a.unitId,a.subUnitId),l=`${t!=null?t:""}`;return!l||l===`${n}`||l===`${s}`}validatorFormula(e,t,a){const{formula1:n,formula2:s}=e,l=n===s;if(i.Tools.isBlank(n)&&i.Tools.isBlank(s))return{success:!0};if(l)return{success:!1,formula1:this.localeService.t("dataValidation.validFail.checkboxEqual"),formula2:this.localeService.t("dataValidation.validFail.checkboxEqual")};const d=Ot(n,this.localeService),c=Ot(s,this.localeService);return{success:!d&&!c,formula1:d,formula2:c}}async parseFormula(e,t,a){var d,c;const{formula1:n=Fe,formula2:s=Ne}=e,l=await this._formulaService.getRuleFormulaResult(t,a,e.uid);return{formula1:i.isFormulaString(n)?oe((d=l==null?void 0:l[0])==null?void 0:d.result):n,formula2:i.isFormulaString(s)?oe((c=l==null?void 0:l[1])==null?void 0:c.result):s}}parseFormulaSync(e,t,a){var d,c;const{formula1:n=Fe,formula2:s=Ne}=e,l=this._formulaService.getRuleFormulaResultSync(t,a,e.uid);return{formula1:i.isFormulaString(n)?oe((d=l==null?void 0:l[0])==null?void 0:d.result):n,formula2:i.isFormulaString(s)?oe((c=l==null?void 0:l[1])==null?void 0:c.result):s}}async isValidType(e,t,a){const{value:n,unitId:s,subUnitId:l}=e,{formula1:d,formula2:c}=await this.parseFormula(a,s,l);return!i.Tools.isDefine(d)||!i.Tools.isDefine(c)?!0:i.Tools.isDefine(n)&&(String(n)===String(d)||String(n)===String(c))}generateRuleErrorMessage(e){return this.localeService.t("dataValidation.checkbox.error")}}const Qe=[i.DataValidationOperator.BETWEEN,i.DataValidationOperator.NOT_BETWEEN];function _r(o){return new Date((o-25569)*86400).getTime()}const Zt=o=>o/86400+25569,Vr="univer-data-validation-options-button",Rr="univer-data-validation-options-button-icon",at={dataValidationOptionsButton:Vr,dataValidationOptionsButtonIcon:Rr};function Dr(o){var c;const r=i.useDependency(i.LocaleService),e=i.useDependency(k.ComponentManager),{value:t,onChange:a,extraComponent:n}=o,[s,l]=T.useState(!1),d=n?e.get(n):null;return v.jsxs(v.Fragment,{children:[v.jsxs("div",{className:at.dataValidationOptionsButton,onClick:()=>l(!s),children:[r.t("dataValidation.panel.options"),s?v.jsx(qt,{className:at.dataValidationOptionsButtonIcon}):v.jsx(Yt,{className:at.dataValidationOptionsButtonIcon})]}),s&&v.jsxs(v.Fragment,{children:[d?v.jsx(d,{value:t,onChange:a}):null,v.jsx(w.FormLayout,{label:r.t("dataValidation.panel.invalid"),children:v.jsxs(w.RadioGroup,{value:`${(c=t.errorStyle)!=null?c:i.DataValidationErrorStyle.WARNING}`,onChange:u=>a({...t,errorStyle:+u}),children:[v.jsx(w.Radio,{value:`${i.DataValidationErrorStyle.WARNING}`,children:r.t("dataValidation.panel.showWarning")}),v.jsx(w.Radio,{value:`${i.DataValidationErrorStyle.STOP}`,children:r.t("dataValidation.panel.rejectInput")})]})}),v.jsx(w.FormLayout,{label:r.t("dataValidation.panel.messageInfo"),children:v.jsx(w.Checkbox,{checked:t.showInputMessage,onChange:()=>a({...t,showInputMessage:!t.showInputMessage}),children:r.t("dataValidation.panel.showInfo")})}),t.showInputMessage?v.jsx(w.FormLayout,{children:v.jsx(w.Input,{value:t.error,onChange:u=>a({...t,error:u})})}):null]})]})}const Cr="univer-data-validation-detail-form-item",Ir="univer-data-validation-detail-buttons",yr="univer-data-validation-detail-button",De={dataValidationDetailFormItem:Cr,dataValidationDetailButtons:Ir,dataValidationDetailButton:yr},Mr=o=>i.debounce(async(r,e,t,a)=>{const n=await o.executeCommand(r,e,t);a==null||a(n)},275);function wr(){const[o,r]=T.useState(0),e=i.useDependency(le),t=k.useObservable(e.activeRule$,e.activeRule),{unitId:a,subUnitId:n,rule:s}=t||{},l=s.uid,d=i.useDependency(D.DataValidatorRegistryService),c=i.useDependency(k.ComponentManager),u=i.useDependency(i.ICommandService),m=i.useDependency(D.DataValidationModel),f=i.useDependency(i.LocaleService),[p,g]=T.useState(s),h=d.getValidatorItem(p.type),[_,S]=T.useState(!1),C=d.getValidatorsByScope(D.DataValidatorRegistryScope.SHEET),[V,I]=T.useState(()=>p.ranges.map(y=>({unitId:"",sheetId:"",range:y}))),M=T.useMemo(()=>Mr(u),[u]);if(T.useEffect(()=>{u.onCommandExecuted(y=>{(y.id===i.UndoCommand.id||y.id===i.RedoCommand.id)&&setTimeout(()=>{const B=m.getRuleById(a,n,l);r(Z=>Z+1),B&&(g(B),I(B.ranges.map(Z=>({unitId:"",sheetId:"",range:Z}))))},20)})},[u,m,l,n,a]),!h)return null;const O=h.operators,b=h.operatorNames,A=p.operator?D.TWO_FORMULA_OPERATOR_COUNT.includes(p.operator):!1,L=()=>{h.validatorFormula(p,a,n).success?e.setActiveRule(null):S(!0)},U=k.useEvent(y=>{if(i.isUnitRangesEqual(y,V))return;I(y);const B=y.filter(X=>(!X.unitId||X.unitId===a)&&(!X.sheetId||X.sheetId===n)).map(X=>X.range);if(g({...p,ranges:B}),B.length===0)return;const Z={unitId:a,subUnitId:n,ruleId:l,ranges:B};M(je.id,Z)}),E=y=>{if(i.shallowEqual(y,D.getRuleSetting(p)))return;g({...p,...y});const B={unitId:a,subUnitId:n,ruleId:l,setting:y};M(vt.id,B,void 0)},$=async()=>{await u.executeCommand(D.RemoveDataValidationCommand.id,{ruleId:l,unitId:a,subUnitId:n}),e.setActiveRule(null)},W={type:p.type,operator:p.operator,formula1:p.formula1,formula2:p.formula2,allowBlank:p.allowBlank},P=y=>{const B=d.getValidatorItem(y);if(!B)return;const Z=B.operators,X=m.getRuleById(a,n,l),ne=y===(X==null?void 0:X.type)||y.includes("list")&&(X!=null&&X.type.includes("list"))?{...X,type:y}:{...p,type:y,operator:Z[0],formula1:void 0,formula2:void 0};g(ne),u.executeCommand(vt.id,{unitId:a,subUnitId:n,ruleId:p.uid,setting:D.getRuleSetting(ne)})},N=c.get(h.formulaInput),H=T.useMemo(()=>V.map(y=>ae.serializeRange(y.range)).join(","),[]),K=D.getRuleOptions(p),Y=y=>{i.shallowEqual(y,D.getRuleOptions(p))||(g({...p,...y}),M(na.id,{unitId:a,subUnitId:n,ruleId:l,options:y}))};return v.jsxs("div",{children:[v.jsx(w.FormLayout,{label:f.t("dataValidation.panel.range"),children:v.jsx(k.RangeSelector,{className:De.dataValidationDetailFormItem,value:H,id:i.createInternalEditorID("data-validation-detail"),openForSheetUnitId:a,openForSheetSubUnitId:n,onChange:y=>{y.some(B=>!i.isValidRange(B.range)||B.range.endColumn<B.range.startColumn||B.range.endRow<B.range.startRow)||U(y)}},o)}),v.jsx(w.FormLayout,{label:f.t("dataValidation.panel.type"),children:v.jsx(w.Select,{options:C==null?void 0:C.map(y=>({label:f.t(y.title),value:y.id})),value:p.type,onChange:P,className:De.dataValidationDetailFormItem})}),O!=null&&O.length?v.jsx(w.FormLayout,{label:f.t("dataValidation.panel.operator"),children:v.jsx(w.Select,{options:O.map((y,B)=>({value:`${y}`,label:b[B]})),value:`${p.operator}`,onChange:y=>{E({...W,operator:y})},className:De.dataValidationDetailFormItem})}):null,N?v.jsx(N,{isTwoFormula:A,value:{formula1:p.formula1,formula2:p.formula2},onChange:y=>{E({...W,...y})},showError:_,validResult:h.validatorFormula(p,a,n),unitId:a,subUnitId:n,ruleId:l},o+p.type):null,v.jsx(Dr,{value:K,onChange:Y,extraComponent:h.optionsInput}),v.jsxs("div",{className:De.dataValidationDetailButtons,children:[v.jsx(w.Button,{className:De.dataValidationDetailButton,onClick:$,children:f.t("dataValidation.panel.removeRule")}),v.jsx(w.Button,{className:De.dataValidationDetailButton,type:"primary",onClick:L,children:f.t("dataValidation.panel.done")})]})]})}const Or="univer-data-validation-item-container",Tr="univer-data-validation-item-title",Er="univer-data-validation-item-content",br="univer-data-validation-item-icon",$e={dataValidationItemContainer:Or,dataValidationItemTitle:Tr,dataValidationItemContent:Er,dataValidationItemIcon:br},Fr=o=>{const{rule:r,onClick:e,unitId:t,subUnitId:a,disable:n}=o,s=i.useDependency(D.DataValidatorRegistryService),l=i.useDependency(i.ICommandService),d=i.useDependency(j.IMarkSelectionService),c=s.getValidatorItem(r.type),u=T.useRef(),[m,f]=T.useState(!1),p=g=>{l.executeCommand(D.RemoveDataValidationCommand.id,{ruleId:r.uid,unitId:t,subUnitId:a}),g.stopPropagation()};return T.useEffect(()=>()=>{var g;u.current&&((g=u.current)==null||g.forEach(h=>{h&&d.removeShape(h)}))},[d]),v.jsxs("div",{className:$e.dataValidationItemContainer,onClick:e,onMouseEnter:()=>{n||(f(!0),u.current=r.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;f(!1),(g=u.current)==null||g.forEach(h=>{h&&d.removeShape(h)}),u.current=void 0},children:[v.jsx("div",{className:$e.dataValidationItemTitle,children:c==null?void 0:c.generateRuleName(r)}),v.jsx("div",{className:$e.dataValidationItemContent,children:r.ranges.map(g=>ae.serializeRange(g)).join(",")}),m?v.jsx("div",{className:$e.dataValidationItemIcon,onClick:p,children:v.jsx(Ct,{})}):null]})},Nr="univer-data-validation-list-buttons",Lr="univer-data-validation-list-button",rt={dataValidationListButtons:Nr,dataValidationListButton:Lr};function Pr(){const o=i.useDependency(i.IUniverInstanceService),r=k.useObservable(()=>o.getCurrentTypeOfUnit$(i.UniverInstanceType.UNIVER_SHEET),void 0,void 0,[]);return r?v.jsx(Ar,{workbook:r}):null}function Ar(o){const r=i.useDependency(D.DataValidationModel),e=i.useDependency(i.IUniverInstanceService),t=i.useDependency(i.ICommandService),a=i.useDependency(i.Injector),n=i.useDependency(le),s=i.useDependency(i.LocaleService),[l,d]=T.useState([]),{workbook:c}=o,u=k.useObservable(c.activeSheet$,void 0,!0),m=c.getUnitId(),f=u==null?void 0:u.getSheetId(),p=r.ensureManager(m,f);T.useEffect(()=>{d(p.getDataValidations());const V=p.dataValidations$.subscribe(I=>{d([...I])});return()=>{V.unsubscribe()}},[p]);const g=async()=>{const V=D.createDefaultNewRule(a),I={unitId:m,subUnitId:f,rule:V};await t.executeCommand(xe.id,I),n.setActiveRule({unitId:m,subUnitId:f,rule:V})},h=()=>{t.executeCommand(D.RemoveAllDataValidationCommand.id,{unitId:m,subUnitId:f})},S=(V=>{const M=e.getCurrentUnitForType(i.UniverInstanceType.UNIVER_SHEET).getActiveSheet();return V.map(b=>{const{ranges:A}=b;return(A==null?void 0:A.some(U=>{var N,H;const{startRow:E,startColumn:$,endRow:W,endColumn:P}=U;for(let K=E;K<=W;K++)for(let Y=$;Y<=P;Y++){const y=(H=(N=M==null?void 0:M.getCell(K,Y))==null?void 0:N.selectionProtection)==null?void 0:H[0];if((y==null?void 0:y[ke.Edit])===!1||(y==null?void 0:y[ke.View])===!1)return!0}return!1}))?{...b,disable:!0}:{...b}})})(l),C=S==null?void 0:S.some(V=>V.disable);return v.jsxs("div",{children:[S==null?void 0:S.map(V=>{var I;return v.jsx(Fr,{unitId:m,subUnitId:f,onClick:()=>{V.disable||n.setActiveRule({unitId:m,subUnitId:f,rule:V})},rule:V,disable:(I=V.disable)!=null?I:!1},V.uid)}),v.jsxs("div",{className:rt.dataValidationListButtons,children:[l.length&&!C?v.jsx(w.Button,{className:rt.dataValidationListButton,onClick:h,children:s.t("dataValidation.panel.removeAll")}):null,v.jsx(w.Button,{className:rt.dataValidationListButton,type:"primary",onClick:g,children:s.t("dataValidation.panel.add")})]})]})}const jr=()=>{const o=i.useDependency(le),r=k.useObservable(o.activeRule$,o.activeRule);return r?v.jsx(wr,{},r.rule.uid):v.jsx(Pr,{})},xr="univer-dv-list-dropdown",Ur="univer-dv-list-dropdown-title",$r="univer-dv-list-dropdown-list",Br="univer-dv-list-dropdown-list-container",Wr="univer-dv-list-dropdown-selected-icon",Hr="univer-dv-list-dropdown-item-container",kr="univer-dv-list-dropdown-item",Yr="univer-dv-list-dropdown-split",qr="univer-dv-list-dropdown-edit",ce={dvListDropdown:xr,dvListDropdownTitle:Ur,dvListDropdownList:$r,dvListDropdownListContainer:Br,dvListDropdownSelectedIcon:Wr,dvListDropdownItemContainer:Hr,dvListDropdownItem:kr,dvListDropdownSplit:Yr,dvListDropdownEdit:qr},Xr=o=>{const{value:r,onChange:e,multiple:t,options:a,title:n,onEdit:s,style:l}=o;return v.jsxs("div",{className:ce.dvListDropdown,style:l,children:[v.jsx("div",{className:ce.dvListDropdownTitle,children:n}),v.jsx("div",{className:ce.dvListDropdownList,children:v.jsx(w.Scrollbar,{children:v.jsx("div",{className:ce.dvListDropdownListContainer,children:a.map((d,c)=>{const u=r.indexOf(d.value)>-1,m=()=>{let f;u?f=new Set(r.filter(g=>g!==d.value)):f=new Set(t?[...r,d.value]:[d.value]);const p=[];a.forEach(g=>{f.has(g.value)&&p.push(g.value)}),e(p)};return v.jsxs("div",{className:ce.dvListDropdownItemContainer,onClick:m,children:[v.jsx("div",{className:ce.dvListDropdownItem,style:{background:d.color||Se},children:d.label}),v.jsx("div",{className:ce.dvListDropdownSelectedIcon,children:u?v.jsx(Wt,{}):null})]},c)})})})}),v.jsx("div",{className:ce.dvListDropdownSplit}),v.jsx("div",{className:ce.dvListDropdownEdit,children:v.jsx("a",{onClick:s,children:"编辑"})})]})};function Gr(o){var L,U;const{location:r,hideFn:e}=o,{worksheet:t,row:a,col:n,unitId:s,subUnitId:l}=r,d=i.useDependency(D.DataValidationModel),c=i.useDependency(i.ICommandService),u=i.useDependency(i.LocaleService),[m,f]=T.useState(""),p=i.useDependency(j.IEditorBridgeService);k.useObservable(d.ruleChange$);const g=w.RectPopup.useContext(),h=g.right-g.left;if(!t)return null;const _=t.getCell(a,n),S=(L=_==null?void 0:_.dataValidation)==null?void 0:L.rule,C=(U=_==null?void 0:_.dataValidation)==null?void 0:U.validator,V=(S==null?void 0:S.renderMode)===i.DataValidationRenderMode.CUSTOM||(S==null?void 0:S.renderMode)===void 0;if(!_||!S||!C)return;const I=S.type===i.DataValidationType.LIST_MULTIPLE,M=C.getListWithColor(S,s,l),O=m||dr(_),b=ye(O),A=()=>{c.executeCommand(_e.id,{ruleId:S.uid}),e()};return v.jsx(Xr,{style:{minWidth:h,maxWidth:Math.max(h,200)},title:I?u.t("dataValidation.listMultiple.dropdown"):u.t("dataValidation.list.dropdown"),value:b,multiple:I,onChange:E=>{const $=Gt(E),W={unitId:s,subUnitId:l,range:{startColumn:n,endColumn:n,startRow:a,endRow:a},value:{v:$,p:null,f:null,si:null,custom:{__link_url:""}}};p.isVisible()&&p.changeVisible({visible:!1,keycode:k.KeyCode.ESC,eventType:z.DeviceInputEventType.Keyboard,unitId:s}),c.executeCommand(x.SetRangeValuesCommand.id,W),f($),I||e()},options:M.map(E=>({label:E.label,value:E.label,color:V?E.color:"transparent"})),onEdit:A})}var Jt={exports:{}};(function(o,r){(function(e,t){o.exports=t()})(Va,function(){var e="minute",t=/[+-]\d\d(?::?\d\d)?/g,a=/([+-]|\d\d)/g;return function(n,s,l){var d=s.prototype;l.utc=function(h){var _={date:h,utc:!0,args:arguments};return new s(_)},d.utc=function(h){var _=l(this.toDate(),{locale:this.$L,utc:!0});return h?_.add(this.utcOffset(),e):_},d.local=function(){return l(this.toDate(),{locale:this.$L,utc:!1})};var c=d.parse;d.parse=function(h){h.utc&&(this.$u=!0),this.$utils().u(h.$offset)||(this.$offset=h.$offset),c.call(this,h)};var u=d.init;d.init=function(){if(this.$u){var h=this.$d;this.$y=h.getUTCFullYear(),this.$M=h.getUTCMonth(),this.$D=h.getUTCDate(),this.$W=h.getUTCDay(),this.$H=h.getUTCHours(),this.$m=h.getUTCMinutes(),this.$s=h.getUTCSeconds(),this.$ms=h.getUTCMilliseconds()}else u.call(this)};var m=d.utcOffset;d.utcOffset=function(h,_){var S=this.$utils().u;if(S(h))return this.$u?0:S(this.$offset)?m.call(this):this.$offset;if(typeof h=="string"&&(h=function(M){M===void 0&&(M="");var O=M.match(t);if(!O)return null;var b=(""+O[0]).match(a)||["-",0,0],A=b[0],L=60*+b[1]+ +b[2];return L===0?0:A==="+"?L:-L}(h),h===null))return this;var C=Math.abs(h)<=16?60*h:h,V=this;if(_)return V.$offset=C,V.$u=h===0,V;if(h!==0){var I=this.$u?this.toDate().getTimezoneOffset():-1*this.utcOffset();(V=this.local().add(C+I,e)).$offset=C,V.$x.$localOffset=I}else V=this.utc();return V};var f=d.format;d.format=function(h){var _=h||(this.$u?"YYYY-MM-DDTHH:mm:ss[Z]":"");return f.call(this,_)},d.valueOf=function(){var h=this.$utils().u(this.$offset)?0:this.$offset+(this.$x.$localOffset||this.$d.getTimezoneOffset());return this.$d.valueOf()-6e4*h},d.isUTC=function(){return!!this.$u},d.toISOString=function(){return this.toDate().toISOString()},d.toString=function(){return this.toDate().toUTCString()};var p=d.toDate;d.toDate=function(h){return h==="s"&&this.$offset?l(this.format("YYYY-MM-DD HH:mm:ss:SSS")).toDate():p.call(this)};var g=d.diff;d.diff=function(h,_,S){if(h&&this.$u===h.$u)return g.call(this,h,_,S);var C=this.local(),V=l(h).local();return g.call(C,V,_,S)}}})})(Jt);var zr=Jt.exports;const Kr=Ra(zr);var Qr=Object.defineProperty,Zr=Object.getOwnPropertyDescriptor,Jr=(o,r,e,t)=>{for(var a=t>1?void 0:t?Zr(r,e):r,n=o.length-1,s;n>=0;n--)(s=o[n])&&(a=(t?s(r,e,a):s(a))||a);return t&&a&&Qr(r,e,a),a},we=(o,r)=>(e,t)=>r(e,t,o);exports.DataValidationRejectInputController=class extends i.Disposable{constructor(r,e,t,a,n){super(),this._editorBridgeService=r,this._dataValidationModel=e,this._dataValidatorRegistryService=t,this._dialogService=a,this._localeService=n,this._initEditorBridgeInterceptor()}_initEditorBridgeInterceptor(){this._editorBridgeService.interceptor.intercept(this._editorBridgeService.interceptor.getInterceptPoints().AFTER_CELL_EDIT_ASYNC,{handler:async(r,e,t)=>{const a=await r,{worksheet:n,row:s,col:l,unitId:d,subUnitId:c}=e,u=this._dataValidationModel.ensureManager(d,c),m=u.getRuleIdByLocation(s,l),f=m?u.getRuleById(m):void 0;if(!f||f.errorStyle!==i.DataValidationErrorStyle.STOP)return t(Promise.resolve(a));const p=await this._dataValidatorRegistryService.getValidatorItem(f.type);if(!p||await p.validator({value:J(a),row:s,column:l,unitId:d,subUnitId:c},f))return t(Promise.resolve(a));const h=n.getCellRaw(s,l);return this._dialogService.open({width:368,title:{title:this._localeService.t("dataValidation.alert.title")},id:"reject-input-dialog",children:{title:p.getRuleFinalError(f)},footer:{title:T.createElement(w.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(h))}})}showReject(r){this._dialogService.open({width:368,title:{title:this._localeService.t("dataValidation.alert.title")},id:"reject-input-dialog",children:{title:r},footer:{title:T.createElement(w.Button,{type:"primary",onClick:()=>this._dialogService.close("reject-input-dialog")},this._localeService.t("dataValidation.alert.ok"))},onClose:()=>{this._dialogService.close("reject-input-dialog")}})}};exports.DataValidationRejectInputController=Jr([i.OnLifecycle(i.LifecycleStages.Ready,exports.DataValidationRejectInputController),we(0,j.IEditorBridgeService),we(1,i.Inject(D.DataValidationModel)),we(2,i.Inject(D.DataValidatorRegistryService)),we(3,k.IDialogService),we(4,i.Inject(i.LocaleService))],exports.DataValidationRejectInputController);const eo="univer-dv-date-dropdown",to="univer-dv-date-dropdown-btns",Tt={dvDateDropdown:eo,dvDateDropdownBtns:to};se.extend(Kr);const ao=o=>{if(o==null||typeof o=="boolean")return;if(typeof o=="number"||!Number.isNaN(+o)){const e=se.unix(_r(+o)).utc().format().slice(0,-1);return se(e)}const r=se(o);if(r.isValid())return r};function ro(o){var I,M,O;const{location:r,hideFn:e}=o,{worksheet:t,row:a,col:n,unitId:s,subUnitId:l}=r,d=i.useDependency(i.ICommandService),c=i.useDependency(exports.DataValidationRejectInputController),u=t.getCell(a,n),m=(I=u==null?void 0:u.dataValidation)==null?void 0:I.rule,f=(M=u==null?void 0:u.dataValidation)==null?void 0:M.validator,p=J(u),g=ao(p),[h,_]=T.useState(g),S=!!((O=m==null?void 0:m.bizInfo)!=null&&O.showTime),C=h&&h.isValid()?h:se();if(!u||!m||!f)return;const V=async()=>{if(!h)return;const A=`${h.format(S?"YYYY-MM-DD HH:mm:ss":"YYYY-MM-DD 00:00:00").split(" ").join("T")}Z`,L=Zt(se(A).unix());m.errorStyle!==i.DataValidationErrorStyle.STOP||await f.validator({value:L,unitId:s,subUnitId:l,row:a,column:n},m)?(d.executeCommand(x.SetRangeValuesCommand.id,{unitId:s,subUnitId:l,range:{startColumn:n,endColumn:n,startRow:a,endRow:a},value:{v:L,t:2,p:null,f:null,si:null,s:{n:{pattern:S?"yyyy-MM-dd hh:mm:ss":"yyyy-MM-dd"}}}}),e()):c.showReject(f.getRuleFinalError(m))};return v.jsxs("div",{className:Tt.dvDateDropdown,children:[v.jsx(w.DatePanel,{defaultValue:h,pickerValue:h!=null?h:C,showTime:S||void 0,onSelect:async b=>{_(b)},onPanelChange:b=>{_(b)}}),v.jsx("div",{className:Tt.dvDateDropdownBtns,children:v.jsx(w.Button,{size:"small",type:"primary",onClick:V,disabled:!h,children:"确定"})})]})}const ea="data-validation.list.dropdown",ta="data-validation.date.dropdown",oo={[i.DataValidationOperator.BETWEEN]:"dataValidation.date.operators.between",[i.DataValidationOperator.EQUAL]:"dataValidation.date.operators.equal",[i.DataValidationOperator.GREATER_THAN]:"dataValidation.date.operators.greaterThan",[i.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.date.operators.greaterThanOrEqual",[i.DataValidationOperator.LESS_THAN]:"dataValidation.date.operators.lessThan",[i.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.date.operators.lessThanOrEqual",[i.DataValidationOperator.NOT_BETWEEN]:"dataValidation.date.operators.notBetween",[i.DataValidationOperator.NOT_EQUAL]:"dataValidation.date.operators.notEqual"};i.DataValidationOperator.BETWEEN+"",i.DataValidationOperator.EQUAL+"",i.DataValidationOperator.GREATER_THAN+"",i.DataValidationOperator.GREATER_THAN_OR_EQUAL+"",i.DataValidationOperator.LESS_THAN+"",i.DataValidationOperator.LESS_THAN_OR_EQUAL+"",i.DataValidationOperator.NOT_BETWEEN+"",i.DataValidationOperator.NOT_EQUAL+"";const no={[i.DataValidationOperator.BETWEEN]:"dataValidation.date.ruleName.between",[i.DataValidationOperator.EQUAL]:"dataValidation.date.ruleName.equal",[i.DataValidationOperator.GREATER_THAN]:"dataValidation.date.ruleName.greaterThan",[i.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.date.ruleName.greaterThanOrEqual",[i.DataValidationOperator.LESS_THAN]:"dataValidation.date.ruleName.lessThan",[i.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.date.ruleName.lessThanOrEqual",[i.DataValidationOperator.NOT_BETWEEN]:"dataValidation.date.ruleName.notBetween",[i.DataValidationOperator.NOT_EQUAL]:"dataValidation.date.ruleName.notEqual"},io={[i.DataValidationOperator.BETWEEN]:"dataValidation.date.errorMsg.between",[i.DataValidationOperator.EQUAL]:"dataValidation.date.errorMsg.equal",[i.DataValidationOperator.GREATER_THAN]:"dataValidation.date.errorMsg.greaterThan",[i.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.date.errorMsg.greaterThanOrEqual",[i.DataValidationOperator.LESS_THAN]:"dataValidation.date.errorMsg.lessThan",[i.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.date.errorMsg.lessThanOrEqual",[i.DataValidationOperator.NOT_BETWEEN]:"dataValidation.date.errorMsg.notBetween",[i.DataValidationOperator.NOT_EQUAL]:"dataValidation.date.errorMsg.notEqual"},so="DATE_SHOW_TIME_OPTION";function Ye(o){var a;const{value:r,onChange:e}=o,t=i.useDependency(i.LocaleService);return v.jsx(w.FormLayout,{children:v.jsx(w.Checkbox,{checked:(a=r.bizInfo)==null?void 0:a.showTime,onChange:n=>{e({...r,bizInfo:{...r.bizInfo,showTime:n}})},children:t.t("dataValidation.showTime.label")})})}Ye.componentKey=so;const Et="{FORMULA1}",bt="{FORMULA2}",Oe=o=>{if(o==null||typeof o=="boolean")return;if(typeof o=="number"||!Number.isNaN(+o))return+o;const r=`${se(o).format("YYYY-MM-DD HH:mm:ss").split(" ").join("T")}Z`;return Zt(se(r).unix())};class lo extends D.BaseDataValidator{constructor(){super(...arguments);R(this,"id",i.DataValidationType.DATE);R(this,"title","dataValidation.date.title");R(this,"operators",[i.DataValidationOperator.BETWEEN,i.DataValidationOperator.EQUAL,i.DataValidationOperator.GREATER_THAN,i.DataValidationOperator.GREATER_THAN_OR_EQUAL,i.DataValidationOperator.LESS_THAN,i.DataValidationOperator.LESS_THAN_OR_EQUAL,i.DataValidationOperator.NOT_BETWEEN,i.DataValidationOperator.NOT_EQUAL]);R(this,"scopes",["sheet"]);R(this,"formulaInput",Ae);R(this,"optionsInput",Ye.componentKey);R(this,"dropdown",ta);R(this,"_formulaService",this.injector.get(exports.DataValidationFormulaService))}async parseFormula(e,t,a){var d,c;const n=await this._formulaService.getRuleFormulaResult(t,a,e.uid),{formula1:s,formula2:l}=e;return{formula1:Oe(i.isFormulaString(s)?oe((d=n==null?void 0:n[0])==null?void 0:d.result):s),formula2:Oe(i.isFormulaString(l)?oe((c=n==null?void 0:n[1])==null?void 0:c.result):l)}}parseFormulaSync(e,t,a){var d,c;const n=this._formulaService.getRuleFormulaResultSync(t,a,e.uid),{formula1:s,formula2:l}=e;return{formula1:Oe(i.isFormulaString(s)?oe((d=n==null?void 0:n[0])==null?void 0:d.result):s),formula2:Oe(i.isFormulaString(l)?oe((c=n==null?void 0:n[1])==null?void 0:c.result):l)}}async isValidType(e){const{value:t}=e;return typeof t=="string"?se(t,"YYYY-MM-DD HH:mm:ss",!0).isValid():typeof t=="number"}_validatorSingleFormula(e){return!i.Tools.isBlank(e)&&(i.isFormulaString(e)||!Number.isNaN(+e)||!!e&&se(e).isValid())}validatorFormula(e,t,a){const n=e.operator;if(!n)return{success:!1};const s=this._validatorSingleFormula(e.formula1),l=this.localeService.t("dataValidation.validFail.date");if(Qe.includes(n)){const c=this._validatorSingleFormula(e.formula2);return{success:s&&c,formula1:s?void 0:l,formula2:c?void 0:l}}return{success:s,formula1:s?void 0:l}}transform(e,t,a){const{value:n}=e;return{...e,value:Oe(n)}}async validatorIsEqual(e,t,a){const{formula1:n}=t,{value:s}=e;return Number.isNaN(n)?!0:s===n}async validatorIsNotEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value!==n}async validatorIsBetween(e,t,a){const{formula1:n,formula2:s}=t;if(Number.isNaN(n)||Number.isNaN(s))return!0;const l=Math.min(n,s),d=Math.max(n,s);return e.value>=l&&e.value<=d}async validatorIsNotBetween(e,t,a){const{formula1:n,formula2:s}=t;if(Number.isNaN(n)||Number.isNaN(s))return!0;const l=Math.min(n,s),d=Math.max(n,s);return e.value<l||e.value>d}async validatorIsGreaterThan(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value>n}async validatorIsGreaterThanOrEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value>=n}async validatorIsLessThan(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value<n}async validatorIsLessThanOrEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value<=n}get operatorNames(){return this.operators.map(e=>this.localeService.t(oo[e]))}generateRuleName(e){var a,n;if(!e.operator)return this.titleStr;const t=this.localeService.t(no[e.operator]).replace(Et,(a=e.formula1)!=null?a:"").replace(bt,(n=e.formula2)!=null?n:"");return`${this.titleStr} ${t}`}generateRuleErrorMessage(e){var a,n;return e.operator?`${this.localeService.t(io[e.operator]).replace(Et,(a=e.formula1)!=null?a:"").replace(bt,(n=e.formula2)!=null?n:"")}`:this.titleStr}}var co=Object.defineProperty,uo=Object.getOwnPropertyDescriptor,ho=(o,r,e,t)=>{for(var a=t>1?void 0:t?uo(r,e):r,n=o.length-1,s;n>=0;n--)(s=o[n])&&(a=(t?s(r,e,a):s(a))||a);return t&&a&&co(r,e,a),a},Ft=(o,r)=>(e,t)=>r(e,t,o);const Ce=4,mo=6,ie=14,fe=6,he=4,po="#565656",Nt=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 fo(o,r){const e=o.length;return{id:"d",body:{dataStream:`${o}${i.DEFAULT_EMPTY_DOCUMENT_VALUE}`,textRuns:[{ts:{fs:11,ff:void 0,it:i.BooleanNumber.FALSE,bl:i.BooleanNumber.FALSE,ul:{s:i.BooleanNumber.FALSE},st:{s:i.BooleanNumber.FALSE},ol:{s:i.BooleanNumber.FALSE},cl:void 0,...r,bg:void 0,bd:void 0},st:0,ed:e}]},documentStyle:{pageSize:{width:Number.POSITIVE_INFINITY,height:Number.POSITIVE_INFINITY}}}}function aa(o,r,e){const t=fo(o,e),a=new i.DocumentDataModel(t),n=new z.DocumentViewModel(a);return{documentSkeleton:z.DocumentSkeleton.create(n,r),docModel:a,docViewModel:n}}function ot(o,r,e){const{documentSkeleton:t,docModel:a,docViewModel:n}=aa(o,r,e);return{documents:new z.Documents(`DOCUMENTS_${i.Tools.generateRandomId()}`,t,{pageMarginLeft:0,pageMarginTop:0}),documentSkeleton:t,docModel:a,docViewModel:n}}function Lt(o,r,e,t,a,n){let s=0;switch(a){case i.VerticalAlign.BOTTOM:s=r-he*2-t+he;break;case i.VerticalAlign.MIDDLE:s=(r-he*2-t)/2+he;break;default:s=he;break}let l=0;switch(n){case i.HorizontalAlign.CENTER:l=(o-e)/2;break;case i.HorizontalAlign.RIGHT:l=o-e;break}return{paddingLeft:l,paddingTop:s}}var pt;let gt=(pt=class{constructor(o,r){R(this,"_dropdownInfoMap",new Map);R(this,"zIndex");R(this,"onPointerEnter");R(this,"onPointerLeave");this._localeService=o,this._commandService=r}_ensureMap(o){let r=this._dropdownInfoMap.get(o);return r||(r=new Map,this._dropdownInfoMap.set(o,r)),r}_generateKey(o,r){return`${o}.${r}`}_drawDownIcon(o,r,e,t,a){const n=e-ie+4;let s=9;switch(a){case i.VerticalAlign.MIDDLE:s=(t-ie)/2+4;break;case i.VerticalAlign.BOTTOM:s=t-ie-1;break}o.save(),o.translateWithPrecision(r.startX+n,r.startY+s),o.fillStyle="#565656",o.fill(Nt),o.restore()}drawWith(o,r,e){var W,P;const{primaryWithCoord:t,row:a,col:n,style:s,data:l,subUnitId:d}=r,c=t.isMergedMainCell?t.mergeInfo:t,u=(W=l.dataValidation)==null?void 0:W.rule,m=(P=l.dataValidation)==null?void 0:P.validator,f=l.fontRenderExtension,{leftOffset:p=0,rightOffset:g=0,topOffset:h=0,downOffset:_=0}=f||{};if(!u||!m||!m.skipDefaultFontRender(u))return;const S={startX:c.startX+p,endX:c.endX-g,startY:c.startY+h,endY:c.endY-_},C=S.endX-S.startX,V=S.endY-S.startY,I=this._ensureMap(d),M=this._generateKey(a,n),O=m.getListWithColor(u),b=J(l),A=`${b!=null?b:""}`,L=O.find(N=>N.label===A);let{tb:U,vt:E,ht:$}=s||{};if(U=U!=null?U:i.WrapStrategy.WRAP,E=E!=null?E:i.VerticalAlign.BOTTOM,$=$!=null?$:i.HorizontalAlign.LEFT,u.renderMode===i.DataValidationRenderMode.ARROW){this._drawDownIcon(o,S,C,V,E),o.save(),o.translateWithPrecision(S.startX,S.startY),o.beginPath(),o.rect(0,0,C,V),o.clip();const N=C-ie,{documentSkeleton:H,documents:K,docModel:Y}=ot(A,this._localeService,s);U===i.WrapStrategy.WRAP&&Y.updateDocumentDataPageSize(Math.max(N,1)),H.calculate(),H.getActualSize();const y=z.getDocsSkeletonPageSize(H),{height:B,width:Z}=y,{paddingTop:X,paddingLeft:ne}=Lt(N,V,Z,B,E,$);o.translate(0,X),o.save(),o.translateWithPrecision(Ce,0),o.beginPath(),o.rect(0,0,N,B),o.clip(),K.render(o),o.translateWithPrecision(ne,0),o.restore(),o.restore(),I.set(M,{left:S.endX+e.rowHeaderWidth-ie,top:S.startY+e.columnHeaderHeight,width:ie,height:V})}else{o.save(),o.translateWithPrecision(S.startX,S.startY),o.beginPath(),o.rect(0,0,C,V),o.clip();const N=C-fe*2-Ce-ie,{documentSkeleton:H,documents:K,docModel:Y}=ot(A,this._localeService,s);U===i.WrapStrategy.WRAP&&Y.updateDocumentDataPageSize(Math.max(N,1)),H.calculate();const y=z.getDocsSkeletonPageSize(H),{height:B,width:Z}=y,{paddingTop:X,paddingLeft:ne}=Lt(N,V,Z,B,E,$);o.translate(fe,X);const F=Math.max(C-fe*2,1),q=B;z.Rect.drawWith(o,{width:F,height:q,fill:(L==null?void 0:L.color)||Se,radius:8}),o.save(),o.translateWithPrecision(Ce,0),o.beginPath(),o.rect(0,0,N,B),o.clip(),o.translateWithPrecision(ne,0),K.render(o),o.restore(),o.translate(N+Ce+4,(B-mo)/2),o.fillStyle=po,o.fill(Nt),o.restore(),I.set(M,{left:S.startX+fe+e.rowHeaderWidth,top:S.startY+X+e.columnHeaderHeight,width:F,height:q})}}calcCellAutoHeight(o){var _;const{primaryWithCoord:r,style:e,data:t}=o,a=r.isMergedMainCell?r.mergeInfo:r,n=t.fontRenderExtension,{leftOffset:s=0,rightOffset:l=0,topOffset:d=0,downOffset:c=0}=n||{},u=(_=t.dataValidation)==null?void 0:_.rule;if(!u||u.renderMode===i.DataValidationRenderMode.TEXT)return;const m={startX:a.startX+s,endX:a.endX-l,startY:a.startY+d,endY:a.endY-c},f=m.endX-m.startX,p=J(t),g=`${p!=null?p:""}`;let{tb:h}=e||{};if(h=h!=null?h:i.WrapStrategy.WRAP,u.renderMode===i.DataValidationRenderMode.ARROW){const S=f-ie,{documentSkeleton:C,docModel:V}=ot(g,this._localeService,e);h===i.WrapStrategy.WRAP&&V.updateDocumentDataPageSize(Math.max(S,1)),C.calculate(),C.getActualSize();const I=z.getDocsSkeletonPageSize(C),{height:M}=I;return M}else{const S=f-fe*2-Ce-ie,{documentSkeleton:C,docModel:V}=aa(g,this._localeService,e);h===i.WrapStrategy.WRAP&&V.updateDocumentDataPageSize(Math.max(S,1)),C.calculate();const I=z.getDocsSkeletonPageSize(C),{height:M}=I;return M+he*2}}isHit(o,r){const{data:e,subUnitId:t,row:a,col:n}=r,l=this._ensureMap(t).get(this._generateKey(a,n)),d=e.dataValidation;if(!d||!l||d.rule.renderMode===i.DataValidationRenderMode.TEXT)return!1;const{top:c,left:u,width:m,height:f}=l,{x:p,y:g}=o;return p>=u&&p<=u+m&&g>=c&&g<=c+f}onPointerDown(o,r){if(r.button===2)return;const{unitId:e,subUnitId:t,row:a,col:n}=o,s={unitId:e,subUnitId:t,row:a,column:n};this._commandService.executeCommand(Le.id,s)}},R(pt,"padding",{l:fe+Ce,r:ie+fe,t:he,b:he}),pt);gt=ho([Ft(0,i.Inject(i.LocaleService)),Ft(1,i.ICommandService)],gt);const go="LIST_RENDER_MODE_OPTION_INPUT";function qe(o){var a;const{value:r,onChange:e}=o,t=i.useDependency(i.LocaleService);return v.jsx(w.FormLayout,{label:t.t("dataValidation.renderMode.label"),children:v.jsxs(w.RadioGroup,{value:`${(a=r.renderMode)!=null?a:i.DataValidationRenderMode.CUSTOM}`,onChange:n=>e({...r,renderMode:+n}),children:[v.jsx(w.Radio,{value:`${i.DataValidationRenderMode.CUSTOM}`,children:t.t("dataValidation.renderMode.chip")}),v.jsx(w.Radio,{value:`${i.DataValidationRenderMode.ARROW}`,children:t.t("dataValidation.renderMode.arrow")}),v.jsx(w.Radio,{value:`${i.DataValidationRenderMode.TEXT}`,children:t.t("dataValidation.renderMode.text")})]})})}qe.componentKey=go;function nt(o){if(!o)return[];const r=new Set;return o.forEach(e=>{e.forEach(t=>{var n,s;const a=J(t);if(a!=null){if(typeof a!="string"&&typeof(t==null?void 0:t.s)=="object"&&((s=(n=t.s)==null?void 0:n.n)!=null&&s.pattern)){r.add(_a.format(t.s.n.pattern,a));return}r.add(a.toString())}})}),[...r]}const vo=["if","indirect","choose","offset"];function So(o,r){if(!i.isFormulaString(o)||ae.isReferenceString(o.slice(1)))return!0;const t=r.sequenceNodesBuilder(o);return t&&t.some(a=>typeof a=="object"&&a.nodeType===ae.sequenceNodeType.FUNCTION&&vo.indexOf(a.token.toLowerCase())>-1)}function _o(o,r){const{formula1:e="",ranges:t}=o;if(ae.isReferenceString(e.slice(1))){const n=ae.deserializeRangeWithSheet(e.slice(1));if((!n.sheetName||n.sheetName===r)&&t.some(s=>i.Rectangle.intersects(s,n.range)))return!0}return!1}class ra extends D.BaseDataValidator{constructor(){super(...arguments);R(this,"formulaService",this.injector.get(exports.DataValidationFormulaService));R(this,"_lexer",this.injector.get(ae.LexerTreeBuilder));R(this,"_univerInstanceService",this.injector.get(i.IUniverInstanceService));R(this,"id",i.DataValidationType.LIST);R(this,"title","dataValidation.list.title");R(this,"operators",[]);R(this,"scopes",["sheet"]);R(this,"formulaInput",Kt);R(this,"canvasRender",this.injector.createInstance(gt));R(this,"dropdown",ea);R(this,"optionsInput",qe.componentKey)}skipDefaultFontRender(e){return e.renderMode!==i.DataValidationRenderMode.TEXT}validatorFormula(e,t,a){var c,u,m;const n=!i.Tools.isBlank(e.formula1),s=So((c=e.formula1)!=null?c:"",this._lexer),l=(m=(u=this._univerInstanceService.getUnit(t,i.UniverInstanceType.UNIVER_SHEET))==null?void 0:u.getSheetBySheetId(a))==null?void 0:m.getName(),d=_o(e,l!=null?l:"");return{success:!!(n&&s&&!d),formula1:n?s?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:n=""}=e,s=await this.formulaService.getRuleFormulaResult(t,a,e.uid);return{formula1:i.isFormulaString(n)?nt((l=s==null?void 0:s[0])==null?void 0:l.result):ye(n),formula2:void 0}}async isValidType(e,t,a){const{value:n}=e,{formula1:s=[]}=t;return this.parseCellValue(n).every(d=>s.includes(d))}generateRuleName(){return this.localeService.t("dataValidation.list.name")}generateRuleErrorMessage(){return this.localeService.t("dataValidation.list.error")}getList(e,t,a){var f,p,g;const{formula1:n=""}=e,s=this.injector.get(i.IUniverInstanceService),l=(f=t?s.getUniverSheetInstance(t):void 0)!=null?f:s.getCurrentUnitForType(i.UniverInstanceType.UNIVER_SHEET);if(!l)return[];const d=(p=a?l.getSheetBySheetId(a):void 0)!=null?p:l.getActiveSheet();if(!d)return[];const c=l.getUnitId(),u=d.getSheetId(),m=this.formulaService.getRuleFormulaResultSync(c,u,e.uid);return i.isFormulaString(n)?nt((g=m==null?void 0:m[0])==null?void 0:g.result):ye(n)}async getListAsync(e,t,a){var f,p,g;const{formula1:n=""}=e,s=this.injector.get(i.IUniverInstanceService),l=(f=t?s.getUniverSheetInstance(t):void 0)!=null?f:s.getCurrentUnitForType(i.UniverInstanceType.UNIVER_SHEET);if(!l)return[];const d=(p=a?l.getSheetBySheetId(a):void 0)!=null?p:l.getActiveSheet();if(!d)return[];const c=l.getUnitId(),u=d.getSheetId(),m=await this.formulaService.getRuleFormulaResult(c,u,e.uid);return i.isFormulaString(n)?nt((g=m==null?void 0:m[0])==null?void 0:g.result):ye(n)}getListWithColor(e,t,a){const n=this.getList(e,t,a),s=(e.formula2||"").split(",");return n.map((l,d)=>({label:l,color:s[d]}))}getListWithColorMap(e,t,a){const n=this.getListWithColor(e,t,a),s={};return n.forEach(l=>{l.color&&(s[l.label]=l.color)}),s}}function Xe(o){let r=o;return typeof o=="string"?((o.startsWith("¥")||o.startsWith("$"))&&(r=o.slice(1)),+r):+o}class Vo extends D.BaseDataValidator{constructor(){super(...arguments);R(this,"_formulaService",this.injector.get(exports.DataValidationFormulaService));R(this,"id",i.DataValidationType.DECIMAL);R(this,"title","dataValidation.decimal.title");R(this,"operators",[i.DataValidationOperator.BETWEEN,i.DataValidationOperator.EQUAL,i.DataValidationOperator.GREATER_THAN,i.DataValidationOperator.GREATER_THAN_OR_EQUAL,i.DataValidationOperator.LESS_THAN,i.DataValidationOperator.LESS_THAN_OR_EQUAL,i.DataValidationOperator.NOT_BETWEEN,i.DataValidationOperator.NOT_EQUAL]);R(this,"scopes",["sheet"]);R(this,"formulaInput",Ae);R(this,"dropDownInput")}_isFormulaOrNumber(e){return!i.Tools.isBlank(e)&&(i.isFormulaString(e)||!Number.isNaN(+e))}async isValidType(e,t,a){const{value:n}=e;return!Number.isNaN(Xe(n))}transform(e,t,a){const{value:n}=e;return{...e,value:Xe(n)}}_parseNumber(e){return e==null?Number.NaN:+e}async parseFormula(e,t,a){var c,u,m,f,p,g,h,_;const n=await this._formulaService.getRuleFormulaResult(t,a,e.uid),{formula1:s,formula2:l}=e;return{formula1:this._parseNumber(i.isFormulaString(s)?(f=(m=(u=(c=n==null?void 0:n[0])==null?void 0:c.result)==null?void 0:u[0])==null?void 0:m[0])==null?void 0:f.v:s),formula2:this._parseNumber(i.isFormulaString(l)?(_=(h=(g=(p=n==null?void 0:n[1])==null?void 0:p.result)==null?void 0:g[0])==null?void 0:h[0])==null?void 0:_.v:l)}}validatorFormula(e,t,a){const n=e.operator;if(!n)return{success:!1};const s=i.Tools.isDefine(e.formula1)&&this._isFormulaOrNumber(e.formula1),l=i.Tools.isDefine(e.formula2)&&this._isFormulaOrNumber(e.formula2),d=Qe.includes(n),c=this.localeService.t("dataValidation.validFail.number");return d?{success:s&&l,formula1:s?void 0:c,formula2:l?void 0:c}:{success:s,formula1:s?"":c}}async validatorIsEqual(e,t,a){const{formula1:n}=t,{value:s}=e;return Number.isNaN(n)?!0:s===n}async validatorIsNotEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value!==n}async validatorIsBetween(e,t,a){const{formula1:n,formula2:s}=t;if(Number.isNaN(n)||Number.isNaN(s))return!0;const l=Math.min(n,s),d=Math.max(n,s);return e.value>=l&&e.value<=d}async validatorIsNotBetween(e,t,a){const{formula1:n,formula2:s}=t;if(Number.isNaN(n)||Number.isNaN(s))return!0;const l=Math.min(n,s),d=Math.max(n,s);return e.value<l||e.value>d}async validatorIsGreaterThan(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value>n}async validatorIsGreaterThanOrEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value>=n}async validatorIsLessThan(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value<n}async validatorIsLessThanOrEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value<=n}}const Ro="{FORMULA1}",Do="{FORMULA2}";class Co extends D.BaseDataValidator{constructor(){super(...arguments);R(this,"id",i.DataValidationType.TEXT_LENGTH);R(this,"title","dataValidation.textLength.title");R(this,"operators",[i.DataValidationOperator.BETWEEN,i.DataValidationOperator.EQUAL,i.DataValidationOperator.GREATER_THAN,i.DataValidationOperator.GREATER_THAN_OR_EQUAL,i.DataValidationOperator.LESS_THAN,i.DataValidationOperator.LESS_THAN_OR_EQUAL,i.DataValidationOperator.NOT_BETWEEN,i.DataValidationOperator.NOT_EQUAL]);R(this,"scopes",["sheet"]);R(this,"formulaInput",Ae);R(this,"_formulaService",this.injector.get(exports.DataValidationFormulaService))}_isFormulaOrInt(e){return!i.Tools.isBlank(e)&&(i.isFormulaString(e)||!Number.isNaN(+e)&&Number.isInteger(+e))}validatorFormula(e,t,a){const n=e.operator;if(!n)return{success:!1};const s=i.Tools.isDefine(e.formula1)&&this._isFormulaOrInt(e.formula1),l=i.Tools.isDefine(e.formula2)&&this._isFormulaOrInt(e.formula2),d=Qe.includes(n),c=this.localeService.t("dataValidation.validFail.number");return d?{success:s&&l,formula1:s?void 0:c,formula2:l?void 0:c}:{success:s,formula1:c}}_parseNumber(e){return e==null?Number.NaN:+e}_isValidFormula(e){return!Number.isNaN(e)}async parseFormula(e,t,a){var d,c,u,m,f,p,g,h;const n=await this._formulaService.getRuleFormulaResult(t,a,e.uid),{formula1:s,formula2:l}=e;return{formula1:this._parseNumber(i.isFormulaString(s)?(m=(u=(c=(d=n==null?void 0:n[0])==null?void 0:d.result)==null?void 0:c[0])==null?void 0:u[0])==null?void 0:m.v:s),formula2:this._parseNumber(i.isFormulaString(l)?(h=(g=(p=(f=n==null?void 0:n[1])==null?void 0:f.result)==null?void 0:p[0])==null?void 0:g[0])==null?void 0:h.v:l)}}transform(e,t,a){return{...e,value:e.value.toString().length}}async isValidType(e,t,a){const{value:n}=e;return typeof n=="string"||typeof n=="number"}async validatorIsEqual(e,t,a){const{formula1:n}=t;return i.Tools.isDefine(n)?e.value===n:!1}async validatorIsNotEqual(e,t,a){const{formula1:n}=t;return i.Tools.isDefine(n)?e.value!==n:!1}async validatorIsBetween(e,t,a){const{formula1:n,formula2:s}=t,{value:l}=e;if(!this._isValidFormula(n)||!this._isValidFormula(s))return!1;const d=Math.max(n,s),c=Math.min(n,s);return l>=c&&l<=d}async validatorIsNotBetween(e,t,a){const{formula1:n,formula2:s}=t,{value:l}=e;if(!this._isValidFormula(n)||!this._isValidFormula(s))return!1;const d=Math.max(n,s),c=Math.min(n,s);return l<c||l>d}async validatorIsGreaterThan(e,t,a){const{formula1:n}=t,{value:s}=e;return this._isValidFormula(n)?s>n:!1}async validatorIsGreaterThanOrEqual(e,t,a){const{formula1:n}=t,{value:s}=e;return this._isValidFormula(n)?s>=n:!1}async validatorIsLessThan(e,t,a){const{formula1:n}=t,{value:s}=e;return this._isValidFormula(n)?s<n:!1}async validatorIsLessThanOrEqual(e,t,a){const{formula1:n}=t,{value:s}=e;return this._isValidFormula(n)?s<=n:!1}generateRuleErrorMessage(e){var a,n;return e.operator?`${this.localeService.t(D.TextLengthErrorTitleMap[e.operator]).replace(Ro,(a=e.formula1)!=null?a:"").replace(Do,(n=e.formula2)!=null?n:"")}`:this.titleStr}}function oa(o){var e,t;return o?o.p?!((t=(e=o.p.body)==null?void 0:e.dataStream)!=null?t:"").slice(0,-2).trim():i.Tools.isBlank(o.v):!0}function Me(o,r,e,t){const a=[],n=[],l=t.get(D.DataValidationModel).ensureManager(o,r),d=t.get(i.IUniverInstanceService),c=x.getSheetCommandTarget(d,{unitId:o,subUnitId:r});if(!c)return{redoMutations:a,undoMutations:n};const{worksheet:u}=c,m=new i.ObjectMatrix;function f(h,_){h.forEach(S=>{i.Range.foreach(S,(C,V)=>{const I=u.getCellRaw(C,V),M=At(I);(oa(I)||M===_)&&m.setValue(C,V,{v:_,p:null})})})}e.forEach(h=>{switch(h.type){case"delete":a.push({id:D.RemoveDataValidationMutation.id,params:{unitId:o,subUnitId:r,ruleId:h.rule.uid}}),n.unshift({id:D.AddDataValidationMutation.id,params:{unitId:o,subUnitId:r,rule:h.rule,index:h.index}});break;case"update":{a.push({id:D.UpdateDataValidationMutation.id,params:{unitId:o,subUnitId:r,ruleId:h.ruleId,payload:{type:D.UpdateRuleType.RANGE,payload:h.newRanges}}}),n.unshift({id:D.UpdateDataValidationMutation.id,params:{unitId:o,subUnitId:r,ruleId:h.ruleId,payload:{type:D.UpdateRuleType.RANGE,payload:h.oldRanges}}});const _=l.getRuleById(h.ruleId);if(_&&_.type===i.DataValidationType.CHECKBOX){const C=l.getValidator(i.DataValidationType.CHECKBOX).parseFormulaSync(_,o,r);f(h.newRanges,C.formula2)}break}case"add":{if(a.push({id:D.AddDataValidationMutation.id,params:{unitId:o,subUnitId:r,rule:h.rule}}),n.unshift({id:D.RemoveDataValidationMutation.id,params:{unitId:o,subUnitId:r,ruleId:h.rule.uid}}),h.rule.type===i.DataValidationType.CHECKBOX){const S=l.getValidator(i.DataValidationType.CHECKBOX).parseFormulaSync(h.rule,o,r);f(h.rule.ranges,S.formula2)}break}}});const p={id:x.SetRangeValuesMutation.id,params:{unitId:o,subUnitId:r,cellValue:m.getData()}},g={id:x.SetRangeValuesMutation.id,params:x.SetRangeValuesUndoMutationFactory(t,p.params)};return a.push(p),n.push(g),{redoMutations:a,undoMutations:n}}const je={type:i.CommandType.COMMAND,id:"sheet.command.updateDataValidationRuleRange",async handler(o,r){if(!r)return!1;const{unitId:e,subUnitId:t,ranges:a,ruleId:n}=r,s=o.get(D.DataValidationModel),l=o.get(i.ICommandService),d=o.get(i.IUndoRedoService),c=s.ensureManager(e,t),u=c.getRuleById(n);if(!u)return!1;const m=u.ranges,f=c.getRuleObjectMatrix().clone();f.updateRange(n,m,a);const p=f.diff(c.getDataValidations()),{redoMutations:g,undoMutations:h}=Me(e,t,p,o);return d.pushUndoRedo({undoMutations:h,redoMutations:g,unitID:e}),await i.sequenceExecuteAsync(g,l),!0}},xe={type:i.CommandType.COMMAND,id:"sheet.command.addDataValidation",async handler(o,r){if(!r)return!1;const{unitId:e,subUnitId:t,rule:a}=r,n=o.get(D.DataValidationModel),s=o.get(i.ICommandService),l=o.get(i.IUndoRedoService),d=n.ensureManager(e,t),c=d.getRuleObjectMatrix().clone();c.addRule(a);const u=c.diff(d.getDataValidations()),m={unitId:e,subUnitId:t,rule:a},{redoMutations:f,undoMutations:p}=Me(e,t,u,o);return f.push({id:D.AddDataValidationMutation.id,params:m}),p.unshift({id:D.RemoveDataValidationMutation.id,params:{unitId:e,subUnitId:t,ruleId:a.uid}}),l.pushUndoRedo({unitID:e,redoMutations:f,undoMutations:p}),await i.sequenceExecuteAsync(f,s),!0}},Ze={type:i.CommandType.COMMAND,id:"data-validation.command.addRuleAndOpen",async handler(o){const r=o.get(i.IUniverInstanceService),e=x.getSheetCommandTarget(r);if(!e)return!1;const{workbook:t,worksheet:a}=e,n=D.createDefaultNewRule(o),s=o.get(i.ICommandService),l=t.getUnitId(),d=a.getSheetId(),c={rule:n,unitId:l,subUnitId:d};return await s.executeCommand(xe.id,c)?(s.executeCommand(_e.id,{ruleId:n.uid,isAdd:!0}),!0):!1}},vt={type:i.CommandType.COMMAND,id:"sheets.command.update-data-validation-setting",handler(o,r){if(!r)return!1;const e=o.get(i.ICommandService),t=o.get(i.IUndoRedoService),a=o.get(D.DataValidationModel),n=o.get(D.DataValidatorRegistryService),{unitId:s,subUnitId:l,ruleId:d,setting:c}=r,u=n.getValidatorItem(c.type);if(!u)return!1;const m=a.getRuleById(s,l,d);if(!m||!u.validatorFormula({...m,...c},s,l).success)return!1;const f={unitId:s,subUnitId:l,ruleId:d,payload:{type:D.UpdateRuleType.SETTING,payload:c}},p=[{id:D.UpdateDataValidationMutation.id,params:f}],g={unitId:s,subUnitId:l,ruleId:d,payload:{type:D.UpdateRuleType.SETTING,payload:D.getRuleSetting(m)}},h=[{id:D.UpdateDataValidationMutation.id,params:g}];if(c.type===i.DataValidationType.CHECKBOX){const S=m.ranges,C=o.get(i.IUniverInstanceService),V=x.getSheetCommandTarget(C,{unitId:s,subUnitId:l});if(V){const I=new i.ObjectMatrix,{worksheet:M}=V,{formula2:O=Ne,formula1:b=Fe}=m,{formula2:A=Ne,formula1:L=Fe}=c;S.forEach($=>{i.Range.foreach($,(W,P)=>{const N=M.getCellRaw(W,P),H=At(N);oa(N)||H===String(O)?I.setValue(W,P,{v:A,p:null}):H===String(b)&&I.setValue(W,P,{v:L,p:null})})});const U={id:x.SetRangeValuesMutation.id,params:{unitId:s,subUnitId:l,cellValue:I.getData()}},E={id:x.SetRangeValuesMutation.id,params:x.SetRangeValuesUndoMutationFactory(o,U.params)};p.push(U),h.push(E)}}return i.sequenceExecute(p,e).result?(t.pushUndoRedo({unitID:s,redoMutations:p,undoMutations:h}),!0):!1}},na={type:i.CommandType.COMMAND,id:"sheets.command.update-data-validation-options",handler(o,r){if(!r)return!1;const e=o.get(i.ICommandService),t=o.get(i.IUndoRedoService),a=o.get(D.DataValidationModel),{unitId:n,subUnitId:s,ruleId:l,options:d}=r,c=a.getRuleById(n,s,l);if(!c)return!1;const u={unitId:n,subUnitId:s,ruleId:l,payload:{type:D.UpdateRuleType.OPTIONS,payload:d}},m=[{id:D.UpdateDataValidationMutation.id,params:u}],f={unitId:n,subUnitId:s,ruleId:l,payload:{type:D.UpdateRuleType.OPTIONS,payload:D.getRuleOptions(c)}},p=[{id:D.UpdateDataValidationMutation.id,params:f}];return t.pushUndoRedo({unitID:n,redoMutations:m,undoMutations:p}),e.executeCommand(D.UpdateDataValidationMutation.id,u),!0}},ia="data-validation-single",It="sheet.menu.data-validation";function Io(o){return{id:It,type:k.MenuItemType.SUBITEMS,positions:[k.MenuPosition.TOOLBAR_START],group:k.MenuGroup.TOOLBAR_FORMULAS_INSERT,icon:ia,tooltip:"dataValidation.title",hidden$:k.getMenuHiddenObservable(o,i.UniverInstanceType.UNIVER_SHEET),disabled$:j.getCurrentRangeDisable$(o,{workbookTypes:[x.WorkbookEditablePermission],worksheetTypes:[x.WorksheetSetCellStylePermission,x.WorksheetEditPermission],rangeTypes:[x.RangeProtectionPermissionEditPoint]})}}function yo(o){return{id:_e.id,title:"dataValidation.panel.title",type:k.MenuItemType.BUTTON,positions:[It]}}function Mo(o){return{id:Ze.id,title:"dataValidation.panel.add",type:k.MenuItemType.BUTTON,positions:[It]}}var wo=Object.defineProperty,Oo=Object.getOwnPropertyDescriptor,sa=(o,r,e,t)=>{for(var a=t>1?void 0:t?Oo(r,e):r,n=o.length-1,s;n>=0;n--)(s=o[n])&&(a=(t?s(r,e,a):s(a))||a);return t&&a&&wo(r,e,a),a},Q=(o,r)=>(e,t)=>r(e,t,o);const la={},da={tr:{size:6,color:"#fe4b4b"}};exports.SheetsDataValidationRenderController=class extends i.RxDisposable{constructor(r,e,t,a,n,s,l,d,c,u,m,f,p){super(),this._config=r,this._commandService=e,this._menuService=t,this._renderManagerService=a,this._univerInstanceService=n,this._autoHeightController=s,this._componentManager=l,this._dropdownManagerService=d,this._dataValidationModel=c,this._dataValidatorRegistryService=u,this._injector=m,this._sheetInterceptorService=f,this._editorBridgeService=p,this._initMenu(),this._initSkeletonChange(),this._initDropdown(),this._initViewModelIntercept(),this._initAutoHeight()}_initMenu(){const{menu:r={}}=this._config;[Io,yo,Mo].forEach(e=>{this.disposeWithMe(this._menuService.addMenuItem(e(this._injector),r))})}_initDropdown(){this._editorBridgeService&&this.disposeWithMe(this._editorBridgeService.visible$.subscribe(r=>{if(!r.visible){this._dropdownManagerService.hideDropdown();return}const e=this._editorBridgeService.getEditCellState();if(e){const{unitId:t,sheetId:a,row:n,column:s}=e,l=this._univerInstanceService.getUniverSheetInstance(t);if(!l)return;const c=this._dataValidationModel.ensureManager(t,a).getRuleByLocation(n,s);if(!c)return;const u=this._dataValidatorRegistryService.getValidatorItem(c.type);if(!(u!=null&&u.dropdown))return;const m=l.getActiveSheet();if(!m)return;const f=this._dropdownManagerService.activeDropdown,p=f==null?void 0:f.location;if(p&&p.unitId===t&&p.subUnitId===a&&p.row===n&&p.col===s)return;this._dropdownManagerService.showDropdown({location:{unitId:t,subUnitId:a,row:n,col:s,workbook:l,worksheet:m},componentKey:u.dropdown,onHide:()=>{}},!1)}}))}_initSkeletonChange(){const r=()=>{var l,d,c;const e=this._univerInstanceService.getCurrentUnitForType(i.UniverInstanceType.UNIVER_SHEET);if(!e)return;const t=e.getUnitId(),a=(l=e.getActiveSheet())==null?void 0:l.getSheetId();if(!a)return;const n=(c=(d=this._renderManagerService.getRenderById(t))==null?void 0:d.with(j.SheetSkeletonManagerService).getWorksheetSkeleton(a))==null?void 0:c.skeleton,s=this._renderManagerService.getRenderById(t);n==null||n.makeDirty(!0),n==null||n.calculate(),s&&s.mainComponent.makeForceDirty()};this.disposeWithMe(this._dataValidationModel.ruleChange$.subscribe(()=>r())),this.disposeWithMe(this._dataValidationModel.validStatusChange$.subscribe(()=>r()))}_initViewModelIntercept(){this.disposeWithMe(this._sheetInterceptorService.intercept(x.INTERCEPTOR_POINT.CELL_CONTENT,{priority:200,handler:(r,e,t)=>{var M,O,b,A,L,U;const{row:a,col:n,unitId:s,subUnitId:l,workbook:d,worksheet:c}=e,u=this._dataValidationModel.ensureManager(s,l);if(!u)return t(r);const m=(O=(M=this._renderManagerService.getRenderById(s))==null?void 0:M.with(j.SheetSkeletonManagerService).getWorksheetSkeleton(l))==null?void 0:O.skeleton;if(!m)return t(r);const f=e.workbook.getStyles(),p=(typeof(r==null?void 0:r.s)=="string"?f.get(r==null?void 0:r.s):r==null?void 0:r.s)||{},g=u.getRuleIdByLocation(a,n);if(!g)return t(r);const h=u.getRuleById(g);if(!h)return t(r);const _=c.getCellRaw(e.row,e.col),S=this._dataValidationModel.validator(J(_),h,e),C=this._dataValidatorRegistryService.getValidatorItem(h.type),V=J(r);let I={};if((h.type===i.DataValidationType.LIST||h.type===i.DataValidationType.LIST_MULTIPLE)&&(I={interceptorStyle:{...r==null?void 0:r.interceptorStyle,tb:(b=p.tb!==i.WrapStrategy.OVERFLOW?p.tb:i.WrapStrategy.CLIP)!=null?b:i.WrapStrategy.WRAP}}),h.type===i.DataValidationType.CHECKBOX&&(I={interceptorStyle:{...r==null?void 0:r.interceptorStyle,tb:i.WrapStrategy.CLIP}}),h.type===i.DataValidationType.LIST&&(h.renderMode===i.DataValidationRenderMode.ARROW||h.renderMode===i.DataValidationRenderMode.TEXT)){const E=C.getListWithColorMap(h),$=`${(A=J(r))!=null?A:""}`,W=E[$];W&&(I={...I,interceptorStyle:{...I.interceptorStyle,bg:{rgb:W}}})}return t({...r,...I,dataValidation:{ruleId:g,validStatus:S,rule:h,validator:C},markers:{...r==null?void 0:r.markers,...S===i.DataValidationStatus.INVALID?da:null},customRender:[...(L=r==null?void 0:r.customRender)!=null?L:[],...C!=null&&C.canvasRender?[C.canvasRender]:[]],fontRenderExtension:{...r==null?void 0:r.fontRenderExtension,isSkip:C==null?void 0:C.skipDefaultFontRender(h,V,e)},interceptorStyle:{...r==null?void 0:r.interceptorStyle,...I.interceptorStyle},get interceptorAutoHeight(){var W,P,N,H;const E=m.mergeData.find(K=>{const{startColumn:Y,startRow:y,endColumn:B,endRow:Z}=K;return a>=y&&n>=Y&&a<=Z&&n<=B}),$={data:{...r,dataValidation:{ruleId:g,validStatus:S,rule:h,validator:C}},style:m.getsStyles().getStyleByCell(r),primaryWithCoord:m.getCellByIndex((W=E==null?void 0:E.startRow)!=null?W:a,(P=E==null?void 0:E.startColumn)!=null?P:n),unitId:s,subUnitId:l,row:a,col:n,workbook:d,worksheet:c};return(H=(N=C==null?void 0:C.canvasRender)==null?void 0:N.calcCellAutoHeight)==null?void 0:H.call(N,$)},coverable:((U=r==null?void 0:r.coverable)!=null?U:!0)&&!(h.type===i.DataValidationType.LIST||h.type===i.DataValidationType.LIST_MULTIPLE)})}}))}_initAutoHeight(){this._dataValidationModel.ruleChange$.subscribe(r=>{var e;if((e=r.rule)!=null&&e.ranges){const t=this._autoHeightController.getUndoRedoParamsOfAutoHeight(r.rule.ranges);i.sequenceExecute(t.redos,this._commandService)}})}};exports.SheetsDataValidationRenderController=sa([i.OnLifecycle(i.LifecycleStages.Rendered,exports.SheetsDataValidationRenderController),Q(1,i.ICommandService),Q(2,k.IMenuService),Q(3,z.IRenderManagerService),Q(4,i.IUniverInstanceService),Q(5,i.Inject(j.AutoHeightController)),Q(6,i.Inject(k.ComponentManager)),Q(7,i.Inject(me)),Q(8,i.Inject(D.DataValidationModel)),Q(9,i.Inject(D.DataValidatorRegistryService)),Q(10,i.Inject(i.Injector)),Q(11,i.Inject(x.SheetInterceptorService)),Q(12,i.Optional(j.IEditorBridgeService))],exports.SheetsDataValidationRenderController);let Te=class extends i.RxDisposable{constructor(o,r,e,t,a,n,s,l){super(),this._config=o,this._commandService=r,this._renderManagerService=e,this._univerInstanceService=t,this._autoHeightController=a,this._dataValidationModel=n,this._dataValidatorRegistryService=s,this._sheetInterceptorService=l,this._initSkeletonChange(),this._initViewModelIntercept(),this._initAutoHeight()}_initSkeletonChange(){const o=()=>{var s,l,d;const r=this._univerInstanceService.getCurrentUnitForType(i.UniverInstanceType.UNIVER_SHEET);if(!r)return;const e=r.getUnitId(),t=(s=r.getActiveSheet())==null?void 0:s.getSheetId();if(!t)return;const a=(d=(l=this._renderManagerService.getRenderById(e))==null?void 0:l.with(j.SheetSkeletonManagerService).getWorksheetSkeleton(t))==null?void 0:d.skeleton,n=this._renderManagerService.getRenderById(e);a==null||a.makeDirty(!0),a==null||a.calculate(),n&&n.mainComponent.makeForceDirty()};this.disposeWithMe(this._dataValidationModel.ruleChange$.subscribe(()=>o())),this.disposeWithMe(this._dataValidationModel.validStatusChange$.subscribe(()=>o()))}_initViewModelIntercept(){this.disposeWithMe(this._sheetInterceptorService.intercept(x.INTERCEPTOR_POINT.CELL_CONTENT,{priority:200,handler:(o,r,e)=>{var I,M,O,b,A;const{row:t,col:a,unitId:n,subUnitId:s,workbook:l,worksheet:d}=r,c=this._dataValidationModel.ensureManager(n,s);if(!c)return e(o);const u=(M=(I=this._renderManagerService.getRenderById(n))==null?void 0:I.with(j.SheetSkeletonManagerService).getWorksheetSkeleton(s))==null?void 0:M.skeleton;if(!u)return e(o);const m=r.workbook.getStyles(),f=(typeof(o==null?void 0:o.s)=="string"?m.get(o==null?void 0:o.s):o==null?void 0:o.s)||{},p=c.getRuleIdByLocation(t,a);if(!p)return e(o);const g=c.getRuleById(p);if(!g)return e(o);const h=r.worksheet.getCellRaw(r.row,r.col),_=this._dataValidationModel.validator(J(h),g,r),S=this._dataValidatorRegistryService.getValidatorItem(g.type),C=J(o);let V={};if((g.type===i.DataValidationType.LIST||g.type===i.DataValidationType.LIST_MULTIPLE)&&(V={interceptorStyle:{...o==null?void 0:o.interceptorStyle,tb:(O=f.tb!==i.WrapStrategy.OVERFLOW?f.tb:i.WrapStrategy.CLIP)!=null?O:i.WrapStrategy.WRAP}}),g.type===i.DataValidationType.CHECKBOX&&(V={interceptorStyle:{...o==null?void 0:o.interceptorStyle,tb:i.WrapStrategy.CLIP}}),g.type===i.DataValidationType.LIST&&(g.renderMode===i.DataValidationRenderMode.ARROW||g.renderMode===i.DataValidationRenderMode.TEXT)){const L=S.getListWithColorMap(g),U=`${(b=J(o))!=null?b:""}`,E=L[U];E&&(V={...V,interceptorStyle:{...V.interceptorStyle,bg:{rgb:E}}})}return e({...o,...V,dataValidation:{ruleId:p,validStatus:_,rule:g,validator:S},markers:{...o==null?void 0:o.markers,..._===i.DataValidationStatus.INVALID?da:null},customRender:[...(A=o==null?void 0:o.customRender)!=null?A:[],...S!=null&&S.canvasRender?[S.canvasRender]:[]],fontRenderExtension:{...o==null?void 0:o.fontRenderExtension,isSkip:S==null?void 0:S.skipDefaultFontRender(g,C,r)},interceptorStyle:{...o==null?void 0:o.interceptorStyle,...V.interceptorStyle},get interceptorAutoHeight(){var E,$,W,P;const L=u.mergeData.find(N=>{const{startColumn:H,startRow:K,endColumn:Y,endRow:y}=N;return t>=K&&a>=H&&t<=y&&a<=Y}),U={data:{...o,dataValidation:{ruleId:p,validStatus:_,rule:g,validator:S}},style:u.getsStyles().getStyleByCell(o),primaryWithCoord:u.getCellByIndex((E=L==null?void 0:L.startRow)!=null?E:t,($=L==null?void 0:L.startColumn)!=null?$:a),unitId:n,subUnitId:s,row:t,col:a,worksheet:d,workbook:l};return(P=(W=S==null?void 0:S.canvasRender)==null?void 0:W.calcCellAutoHeight)==null?void 0:P.call(W,U)}})}}))}_initAutoHeight(){this._dataValidationModel.ruleChange$.subscribe(o=>{var r;if((r=o.rule)!=null&&r.ranges){const e=this._autoHeightController.getUndoRedoParamsOfAutoHeight(o.rule.ranges);i.sequenceExecute(e.redos,this._commandService)}})}};Te=sa([i.OnLifecycle(i.LifecycleStages.Rendered,Te),Q(1,i.ICommandService),Q(2,z.IRenderManagerService),Q(3,i.IUniverInstanceService),Q(4,i.Inject(j.AutoHeightController)),Q(5,i.Inject(D.DataValidationModel)),Q(6,i.Inject(D.DataValidatorRegistryService)),Q(7,i.Inject(x.SheetInterceptorService))],Te);var To=Object.defineProperty,Eo=Object.getOwnPropertyDescriptor,bo=(o,r,e,t)=>{for(var a=t>1?void 0:t?Eo(r,e):r,n=o.length-1,s;n>=0;n--)(s=o[n])&&(a=(t?s(r,e,a):s(a))||a);return t&&a&&To(r,e,a),a},Fo=(o,r)=>(e,t)=>r(e,t,o);exports.SheetDataValidationService=class extends i.Disposable{constructor(e){super();R(this,"_currentManager");R(this,"_currentManager$",new ve.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 n,s;if(e===((n=this.currentManager)==null?void 0:n.unitId)&&t===((s=this._currentManager)==null?void 0:s.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)}};exports.SheetDataValidationService=bo([Fo(0,i.Inject(D.DataValidationModel))],exports.SheetDataValidationService);var No=Object.defineProperty,Lo=Object.getOwnPropertyDescriptor,Po=(o,r,e,t)=>{for(var a=t>1?void 0:t?Lo(r,e):r,n=o.length-1,s;n>=0;n--)(s=o[n])&&(a=(t?s(r,e,a):s(a))||a);return t&&a&&No(r,e,a),a},Be=(o,r)=>(e,t)=>r(e,t,o);exports.DataValidationCustomFormulaService=class extends i.Disposable{constructor(e,t,a,n){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=n,this._initFormulaResultHandler()}_initFormulaResultHandler(){this.disposeWithMe(this._registerOtherFormulaService.formulaResult$.subscribe(e=>{for(const t in e){const a=e[t];for(const n in a){const s=a[n],{formulaCellMap:l,ruleFormulaMap:d}=this._ensureMaps(t,n),c=this._dataValidationModel.ensureManager(t,n);s.forEach(u=>{var g,h;const m=d.get((g=u.extra)==null?void 0:g.ruleId),f=l.get(u.formulaId),p=c.getRuleById((h=u.extra)==null?void 0:h.ruleId);p&&m&&!m.isTransformable&&this._dataValidationCacheService.markRangeDirty(t,n,p.ranges),f&&this._dataValidationCacheService.markCellDirty(t,n,f.row,f.column)})}}}))}_ensureMaps(e,t){let a=this._formulaMap.get(e),n=this._ruleFormulaMap.get(e),s=this._formulaCellMap.get(e);(!a||!n||!s)&&(a=new Map,n=new Map,s=new Map,this._formulaMap.set(e,a),this._ruleFormulaMap.set(e,n),this._formulaCellMap.set(e,s));let l=a.get(t),d=n.get(t),c=s.get(t);return(!l||!d||!c)&&(l=new i.ObjectMatrix,a.set(t,l),d=new Map,n.set(t,d),c=new Map,s.set(t,c)),{formulaMap:l,ruleFormulaMap:d,formulaCellMap:c}}_registerFormula(e,t,a,n){return this._registerOtherFormulaService.registerFormula(e,t,n,{ruleId:a})}deleteByRuleId(e,t,a){const{formulaMap:n,formulaCellMap:s,ruleFormulaMap:l}=this._ensureMaps(e,t),d=this._dataValidationModel.getRuleById(e,t,a),c=new Set,u=l.get(a);!d||!u||(l.delete(a),d.ranges.forEach(m=>{i.Range.foreach(m,(f,p)=>{const g=n.getValue(f,p);if(g&&g.ruleId===a){const{formulaId:h}=g;n.realDeleteValue(f,p),c.add(h),s.delete(h)}})}),this._registerOtherFormulaService.deleteFormula(e,t,Array.from(c.values())))}_addFormulaByRange(e,t,a,n,s){const{formulaMap:l,ruleFormulaMap:d,formulaCellMap:c}=this._ensureMaps(e,t);if(!n)return;const u=ae.isFormulaTransformable(this._lexerTreeBuilder,n),m=s[0].startRow,f=s[0].startColumn;let p;u?s.forEach(g=>{i.Range.foreach(g,(h,_)=>{const S=ae.transformFormula(this._lexerTreeBuilder,n,m,f,h,_),C=this._registerFormula(e,t,a,S);l.setValue(h,_,{formulaId:C,ruleId:a}),c.set(C,{row:h,column:_})})}):(p=this._registerFormula(e,t,a,n),s.forEach(g=>{i.Range.foreach(g,(h,_)=>{l.setValue(h,_,{formulaId:p,ruleId:a})})})),d.set(a,{formula:n,originCol:f,originRow:m,isTransformable:u,formulaId:p})}addRule(e,t,a){const{ranges:n,formula1:s,uid:l,type:d}=a;d!==i.DataValidationType.CUSTOM||!s||!i.isFormulaString(s)||this._addFormulaByRange(e,t,l,s,n)}updateRuleRanges(e,t,a,n,s){const{formulaMap:l,ruleFormulaMap:d,formulaCellMap:c}=this._ensureMaps(e,t),u=d.get(a);if(!u)return;const{formula:m,originCol:f,originRow:p,isTransformable:g,formulaId:h}=u,_=new Set;n.forEach(S=>{i.Range.foreach(S,(C,V)=>{const I=l.getValue(C,V);I&&I.ruleId===a&&(I.temp=!0)})}),s.forEach(S=>{i.Range.foreach(S,(C,V)=>{var M;const I=(M=l.getValue(C,V))!=null?M:{};if(I.ruleId!==a){const O=d.get(I.ruleId);if(O!=null&&O.isTransformable&&_.add(I.formulaId),g){const b=ae.transformFormula(this._lexerTreeBuilder,m,p,f,C,V),A=this._registerFormula(e,t,a,b);l.setValue(C,V,{ruleId:a,formulaId:A}),c.set(A,{row:C,column:V})}else l.setValue(C,V,{ruleId:a,formulaId:h})}else I.temp=!1})}),n.forEach(S=>{i.Range.foreach(S,(C,V)=>{const I=l.getValue(C,V);I&&I.ruleId===a&&I.temp===!0&&(l.realDeleteValue(C,V),g&&_.add(I.formulaId))})}),_.forEach(S=>{c.delete(S)}),this._registerOtherFormulaService.deleteFormula(e,t,Array.from(_.values()))}updateRuleFormula(e,t,a,n,s){const{ruleFormulaMap:l}=this._ensureMaps(e,t),d=l.get(a);(!d||d.formula!==s)&&this._addFormulaByRange(e,t,a,s,n)}getCellFormulaValue(e,t,a,n){const{formulaMap:s}=this._ensureMaps(e,t),l=s.getValue(a,n);return l?this._registerOtherFormulaService.getFormulaValue(e,t,l.formulaId):Promise.resolve(void 0)}getRuleFormulaInfo(e,t,a){const{ruleFormulaMap:n}=this._ensureMaps(e,t);return n.get(a)}};exports.DataValidationCustomFormulaService=Po([Be(0,i.Inject(Vt.RegisterOtherFormulaService)),Be(1,i.Inject(ae.LexerTreeBuilder)),Be(2,i.Inject(D.DataValidationModel)),Be(3,i.Inject(Ve))],exports.DataValidationCustomFormulaService);class Ao extends D.BaseDataValidator{constructor(){super(...arguments);R(this,"id",i.DataValidationType.CUSTOM);R(this,"title","dataValidation.custom.title");R(this,"operators",[]);R(this,"scopes",["sheet"]);R(this,"formulaInput",zt);R(this,"_customFormulaService",this.injector.get(exports.DataValidationCustomFormulaService))}validatorFormula(e,t,a){const n=i.isFormulaString(e.formula1);return{success:n,formula1:n?"":this.localeService.t("dataValidation.validFail.formula")}}async parseFormula(e,t,a){return{formula1:void 0,formula2:void 0}}async isValidType(e,t,a){const{column:n,row:s,unitId:l,subUnitId:d}=e,c=await this._customFormulaService.getCellFormulaValue(l,d,s,n);return!!oe(c==null?void 0:c.result)}generateRuleErrorMessage(e){return this.localeService.t("dataValidation.custom.error")}}class jo extends D.BaseDataValidator{constructor(){super(...arguments);R(this,"_formulaService",this.injector.get(exports.DataValidationFormulaService));R(this,"id",i.DataValidationType.WHOLE);R(this,"title","dataValidation.whole.title");R(this,"operators",[i.DataValidationOperator.BETWEEN,i.DataValidationOperator.EQUAL,i.DataValidationOperator.GREATER_THAN,i.DataValidationOperator.GREATER_THAN_OR_EQUAL,i.DataValidationOperator.LESS_THAN,i.DataValidationOperator.LESS_THAN_OR_EQUAL,i.DataValidationOperator.NOT_BETWEEN,i.DataValidationOperator.NOT_EQUAL]);R(this,"scopes",["sheet"]);R(this,"formulaInput",Ae);R(this,"dropDownInput")}_isFormulaOrInt(e){return!i.Tools.isBlank(e)&&(i.isFormulaString(e)||!Number.isNaN(+e)&&Number.isInteger(+e))}async isValidType(e,t,a){const{value:n}=e,s=Xe(n);return!Number.isNaN(s)&&Number.isInteger(s)}transform(e,t,a){const{value:n}=e;return{...e,value:Xe(n)}}_parseNumber(e){return e==null?Number.NaN:+e}async parseFormula(e,t,a){var c,u,m,f,p,g,h,_;const n=await this._formulaService.getRuleFormulaResult(t,a,e.uid),{formula1:s,formula2:l}=e;return{formula1:this._parseNumber(i.isFormulaString(s)?(f=(m=(u=(c=n==null?void 0:n[0])==null?void 0:c.result)==null?void 0:u[0])==null?void 0:m[0])==null?void 0:f.v:s),formula2:this._parseNumber(i.isFormulaString(l)?(_=(h=(g=(p=n==null?void 0:n[1])==null?void 0:p.result)==null?void 0:g[0])==null?void 0:h[0])==null?void 0:_.v:l)}}validatorFormula(e,t,a){const n=e.operator;if(!n)return{success:!1};const s=i.Tools.isDefine(e.formula1)&&this._isFormulaOrInt(e.formula1),l=i.Tools.isDefine(e.formula2)&&this._isFormulaOrInt(e.formula2),d=Qe.includes(n),c=this.localeService.t("dataValidation.validFail.number");return d?{success:s&&l,formula1:s?void 0:c,formula2:l?void 0:c}:{success:s,formula1:c}}async validatorIsEqual(e,t,a){const{formula1:n}=t,{value:s}=e;return Number.isNaN(n)?!0:s===n}async validatorIsNotEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value!==n}async validatorIsBetween(e,t,a){const{formula1:n,formula2:s}=t;if(Number.isNaN(n)||Number.isNaN(s))return!0;const l=Math.min(n,s),d=Math.max(n,s);return e.value>=l&&e.value<=d}async validatorIsNotBetween(e,t,a){const{formula1:n,formula2:s}=t;if(Number.isNaN(n)||Number.isNaN(s))return!0;const l=Math.min(n,s),d=Math.max(n,s);return e.value<l||e.value>d}async validatorIsGreaterThan(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value>n}async validatorIsGreaterThanOrEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value>=n}async validatorIsLessThan(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value<n}async validatorIsLessThanOrEqual(e,t,a){const{formula1:n}=t;return Number.isNaN(n)?!0:e.value<=n}}const ca=4,xo=0,it=4,ua=4,St=6,Ge=6,ge=14;function Uo(o,r){const e=z.FontCache.getTextSize(o,r),t=e.width+ca*2,{ba:a,bd:n}=e,s=a+n;return{width:t,height:s+xo*2,ba:a}}function Pt(o,r,e,t){const a=e-ge-St,n=t-Ge*2,s=o.map(u=>({layout:Uo(u,r),text:u}));let l;const d=[];s.forEach(u=>{const{layout:m}=u,{width:f,height:p}=m;!l||l.width+f+it>a?(l={width:f,height:p,items:[{...u,left:0}]},d.push(l)):(l.items.push({...u,left:l.width+it}),l.width=l.width+f+it)});let c=0;return d.forEach((u,m)=>{m===d.length-1?c+=u.height:c+=u.height+ua}),{lines:d,totalHeight:c,contentWidth:a,contentHeight:n,cellAutoHeight:c+Ge*2}}const $o=8;class Bo extends z.Shape{static drawWith(r,e){const{fontFamily:t,fontString:a,fontSize:n,info:s,fill:l,color:d}=e,{layout:c,text:u}=s;r.save(),z.Rect.drawWith(r,{width:c.width,height:c.height,radius:$o,fill:l||Se}),r.translateWithPrecision(ca,c.ba),r.font=a,r.fillStyle=d,r.fillText(u,0,0),r.restore()}}var Wo=Object.defineProperty,Ho=Object.getOwnPropertyDescriptor,ko=(o,r,e,t)=>{for(var a=t>1?void 0:t?Ho(r,e):r,n=o.length-1,s;n>=0;n--)(s=o[n])&&(a=(t?s(r,e,a):s(a))||a);return t&&a&&Wo(r,e,a),a},Yo=(o,r)=>(e,t)=>r(e,t,o);const qo=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 _t=class{constructor(o){R(this,"zIndex");R(this,"_dropdownInfoMap",new Map);this._commandService=o}_ensureMap(o){let r=this._dropdownInfoMap.get(o);return r||(r=new Map,this._dropdownInfoMap.set(o,r)),r}_generateKey(o,r){return`${o}.${r}`}_drawDownIcon(o,r,e,t,a){const n=e-ge+4;let s=4;switch(a){case i.VerticalAlign.MIDDLE:s=(t-ge)/2+4;break;case i.VerticalAlign.BOTTOM:s=t-ge+4;break}o.save(),o.translateWithPrecision(r.startX+n,r.startY+s),o.fillStyle="#565656",o.fill(qo),o.restore()}drawWith(o,r,e,t){var B,Z;const{primaryWithCoord:a,row:n,col:s,style:l,data:d,subUnitId:c}=r,u=a.isMergedMainCell?a.mergeInfo:a,m=d.fontRenderExtension,{leftOffset:f=0,rightOffset:p=0,topOffset:g=0,downOffset:h=0}=m||{},_=d.dataValidation,S=this._ensureMap(c),C=this._generateKey(n,s);if(!_)return;const V={startX:u.startX+f,endX:u.endX-p,startY:u.startY+g,endY:u.endY-h},I=V.endX-V.startX,M=V.endY-V.startY,{cl:O}=l||{},b=(B=typeof O=="object"?O==null?void 0:O.rgb:O)!=null?B:"#000",A=z.getFontStyleString(l!=null?l:void 0),{rule:L,validator:U}=_,E=U,{vt:$,ht:W}=l||{},P=$!=null?$:i.VerticalAlign.MIDDLE,N=(Z=J(d))!=null?Z:"",H=E.parseCellValue(N),K=E.getListWithColorMap(L),Y=Pt(H,A,I,M);this._drawDownIcon(o,V,I,M,P),o.save(),o.translateWithPrecision(V.startX,V.startY),o.beginPath(),o.rect(0,0,I-ge,M),o.clip(),o.translateWithPrecision(St,Ge);let y=0;switch(P){case i.VerticalAlign.MIDDLE:y=(Y.contentHeight-Y.totalHeight)/2;break;case i.VerticalAlign.BOTTOM:y=Y.contentHeight-Y.totalHeight;break}o.translateWithPrecision(0,y),Y.lines.forEach((X,ne)=>{o.save();const{width:F,height:q,items:G}=X;let ee=0;switch(W){case i.HorizontalAlign.RIGHT:ee=Y.contentWidth-F;break;case i.HorizontalAlign.CENTER:ee=(Y.contentWidth-F)/2;break}o.translate(ee,ne*(q+ua)),G.forEach(de=>{o.save(),o.translateWithPrecision(de.left,0),Bo.drawWith(o,{...A,info:de,color:b,fill:K[de.text]}),o.restore()}),o.restore()}),o.restore(),S.set(C,{left:V.startX,top:V.startY,width:Y.contentWidth+St+ge,height:Y.contentHeight+Ge*2})}calcCellAutoHeight(o){var I;const{primaryWithCoord:r,style:e,data:t}=o,a=t.fontRenderExtension,{leftOffset:n=0,rightOffset:s=0,topOffset:l=0,downOffset:d=0}=a||{},c=r.isMergedMainCell?r.mergeInfo:r,u={startX:c.startX+n,endX:c.endX-s,startY:c.startY+l,endY:c.endY-d},m=t.dataValidation;if(!m)return;const f=u.endX-u.startX,p=u.endY-u.startY,g=(I=J(t))!=null?I:"",{validator:h}=m,S=h.parseCellValue(g),C=z.getFontStyleString(e!=null?e:void 0);return Pt(S,C,f,p).cellAutoHeight}isHit(o,r){const{primaryWithCoord:e}=r,t=e.isMergedMainCell?e.mergeInfo:e,{endX:a}=t,{x:n}=o;return n>=a-ge&&n<=a}onPointerDown(o,r){if(r.button===2)return;const{unitId:e,subUnitId:t,row:a,col:n}=o,s={unitId:e,subUnitId:t,row:a,column:n};this._commandService.executeCommand(Le.id,s)}};_t=ko([Yo(0,i.ICommandService)],_t);class Xo extends ra{constructor(){super(...arguments);R(this,"id",i.DataValidationType.LIST_MULTIPLE);R(this,"title","dataValidation.listMultiple.title");R(this,"canvasRender",this.injector.createInstance(_t))}skipDefaultFontRender(){return!0}}var Go=Object.defineProperty,zo=Object.getOwnPropertyDescriptor,Ko=(o,r,e,t)=>{for(var a=t>1?void 0:t?zo(r,e):r,n=o.length-1,s;n>=0;n--)(s=o[n])&&(a=(t?s(r,e,a):s(a))||a);return t&&a&&Go(r,e,a),a},ue=(o,r)=>(e,t)=>r(e,t,o);exports.DataValidationController=class extends i.RxDisposable{constructor(r,e,t,a,n,s,l,d){super(),this._univerInstanceService=r,this._sheetDataValidationService=e,this._dataValidatorRegistryService=t,this._injector=a,this._componentManger=n,this._selectionManagerService=s,this._sheetInterceptorService=l,this._dataValidationModel=d,this._init()}_init(){this._registerValidators(),this._initInstanceChange(),this._initCommandInterceptor(),this._initComponents()}_registerValidators(){[Vo,jo,Co,lo,Sr,ra,Xo,Ao].forEach(r=>{const e=this._injector.createInstance(r);this.disposeWithMe(this._dataValidatorRegistryService.register(e)),this.disposeWithMe({dispose:()=>{this._injector.delete(r)}})})}_initInstanceChange(){const r=new i.DisposableCollection;this.disposeWithMe(this._univerInstanceService.getCurrentTypeOfUnit$(i.UniverInstanceType.UNIVER_SHEET).subscribe(e=>{if(r.dispose(),!e)return;const t=e.getActiveSheet();t&&(this._sheetDataValidationService.switchCurrent(e.getUnitId(),t.getSheetId()),r.add(i.toDisposable(e.activeSheet$.subscribe(a=>{if(a){const n=e.getUnitId(),s=a.getSheetId();this._sheetDataValidationService.switchCurrent(n,s)}}))))})),this.disposeWithMe(r)}_initCommandInterceptor(){this._sheetInterceptorService.interceptCommand({getMutations:r=>{var e;if(r.id===x.ClearSelectionAllCommand.id){const t=this._univerInstanceService.getCurrentUnitForType(i.UniverInstanceType.UNIVER_SHEET),a=t.getUnitId(),n=t.getActiveSheet();if(!n)throw new Error("No active sheet found");const s=n.getSheetId(),l=(e=this._selectionManagerService.getCurrentSelections())==null?void 0:e.map(p=>p.range),d=this._dataValidationModel.ensureManager(a,s),c=d.getRuleObjectMatrix().clone();l&&c.removeRange(l);const u=c.diff(d.getDataValidations()),{redoMutations:m,undoMutations:f}=Me(a,s,u,this._injector);return{undos:f,redos:m}}return{undos:[],redos:[]}}})}_initComponents(){[[ia,Ht],[$t,jr],[Ut,Oa],[ea,Gr],[ta,ro],[qe.componentKey,qe],[Ye.componentKey,Ye],...vr].forEach(([r,e])=>{this.disposeWithMe(this._componentManger.register(r,e))})}};exports.DataValidationController=Ko([i.OnLifecycle(i.LifecycleStages.Rendered,exports.DataValidationController),ue(0,i.IUniverInstanceService),ue(1,i.Inject(exports.SheetDataValidationService)),ue(2,i.Inject(D.DataValidatorRegistryService)),ue(3,i.Inject(i.Injector)),ue(4,i.Inject(k.ComponentManager)),ue(5,i.Inject(x.SheetsSelectionsService)),ue(6,i.Inject(x.SheetInterceptorService)),ue(7,i.Inject(D.DataValidationModel))],exports.DataValidationController);var Qo=Object.defineProperty,Zo=Object.getOwnPropertyDescriptor,Jo=(o,r,e,t)=>{for(var a=t>1?void 0:t?Zo(r,e):r,n=o.length-1,s;n>=0;n--)(s=o[n])&&(a=(t?s(r,e,a):s(a))||a);return t&&a&&Qo(r,e,a),a},We=(o,r)=>(e,t)=>r(e,t,o);const st="SHEET_DATA_VALIDATION_ALERT";exports.DataValidationAlertController=class extends i.Disposable{constructor(r,e,t,a){super(),this._hoverManagerService=r,this._cellAlertManagerService=e,this._univerInstanceService=t,this._localeService=a,this._init()}_init(){this._initCellAlertPopup()}_initCellAlertPopup(){this.disposeWithMe(this._hoverManagerService.currentCell$.pipe(ve.debounceTime(100)).subscribe(r=>{var e,t;if(r){const n=this._univerInstanceService.getCurrentUnitForType(i.UniverInstanceType.UNIVER_SHEET).getActiveSheet();if(!n)return;const s=n.getCell(r.location.row,r.location.col);if(((e=s==null?void 0:s.dataValidation)==null?void 0:e.validStatus)===i.DataValidationStatus.INVALID){const l=this._cellAlertManagerService.currentAlert.get(st),d=(t=l==null?void 0:l.alert)==null?void 0:t.location;if(d&&d.row===r.location.row&&d.col===r.location.col&&d.subUnitId===r.location.subUnitId&&d.unitId===r.location.unitId)return;const c=s.dataValidation.validator,u=s.dataValidation.rule;if(!c)return;this._cellAlertManagerService.showAlert({type:j.CellAlertType.ERROR,title:this._localeService.t("dataValidation.error.title"),message:c==null?void 0:c.getRuleFinalError(u),location:r.location,width:200,height:74,key:st});return}}this._cellAlertManagerService.removeAlert(st)}))}};exports.DataValidationAlertController=Jo([i.OnLifecycle(i.LifecycleStages.Rendered,exports.DataValidationAlertController),We(0,i.Inject(j.HoverManagerService)),We(1,i.Inject(j.CellAlertManagerService)),We(2,i.IUniverInstanceService),We(3,i.Inject(i.LocaleService))],exports.DataValidationAlertController);var en=Object.defineProperty,tn=Object.getOwnPropertyDescriptor,an=(o,r,e,t)=>{for(var a=t>1?void 0:t?tn(r,e):r,n=o.length-1,s;n>=0;n--)(s=o[n])&&(a=(t?s(r,e,a):s(a))||a);return t&&a&&en(r,e,a),a},Ie=(o,r)=>(e,t)=>r(e,t,o);exports.DataValidationRefRangeController=class extends i.Disposable{constructor(e,t,a,n,s,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=n,this._dataValidationFormulaService=s,this._formulaRefRangeService=l,this._initRefRange()}_getIdWithUnitId(e,t,a){return`${e}_${t}_${a}`}registerFormula(e,t,a){var c;const n=a.uid,s=this._getIdWithUnitId(e,t,n),l=(c=this._disposableMap.get(s))!=null?c:new Set,d=(u,m)=>{const f=this._dataValidationModel.getRuleById(e,t,n);if(!f)return{redos:[],undos:[]};const p=f[u];if(!p||p===m)return{redos:[],undos:[]};const g={unitId:e,subUnitId:t,ruleId:a.uid,payload:{type:D.UpdateRuleType.SETTING,payload:{type:f.type,formula1:f.formula1,formula2:f.formula2,[u]:m}}},h={unitId:e,subUnitId:t,ruleId:a.uid,payload:{type:D.UpdateRuleType.SETTING,payload:{type:f.type,formula1:f.formula1,formula2:f.formula2}}},_=[{id:D.UpdateDataValidationMutation.id,params:g}],S=[{id:D.UpdateDataValidationMutation.id,params:h}];return{redos:_,undos:S}};if(a.type===i.DataValidationType.CUSTOM){const u=this._dataValidationCustomFormulaService.getRuleFormulaInfo(e,t,n);if(u){const m=this._formulaRefRangeService.registerFormula(u.formula,f=>d("formula1",f));l.add(()=>m.dispose())}}if(a.type!==i.DataValidationType.CUSTOM){const u=this._dataValidationFormulaService.getRuleFormulaInfo(e,t,n);if(u){const[m,f]=u;if(m){const p=this._formulaRefRangeService.registerFormula(m.text,g=>d("formula1",g));l.add(()=>p.dispose())}if(f){const p=this._formulaRefRangeService.registerFormula(f.text,g=>d("formula1",g));l.add(()=>p.dispose())}}}}register(e,t,a){var c;const n=u=>{const m=[...a.ranges],p=m.map(h=>x.handleCommonDefaultRangeChangeWithEffectRefCommands(h,u)).filter(h=>!!h).flat();if(i.isRangesEqual(p,m))return{redos:[],undos:[]};if(p.length){const h={unitId:e,subUnitId:t,ruleId:a.uid,payload:{type:D.UpdateRuleType.RANGE,payload:p}},_=[{id:D.UpdateDataValidationMutation.id,params:h}],S=[{id:D.UpdateDataValidationMutation.id,params:{unitId:e,subUnitId:t,ruleId:a.uid,payload:{type:D.UpdateRuleType.RANGE,payload:m}}}];return{redos:_,undos:S}}else{const h={unitId:e,subUnitId:t,ruleId:a.uid},_=[{id:D.RemoveDataValidationMutation.id,params:h}],S=D.removeDataValidationUndoFactory(this._injector,h);return{redos:_,undos:S}}},s=[];a.ranges.forEach(u=>{const m=this._refRangeService.registerRefRange(u,n,e,t);s.push(()=>m.dispose())});const l=this._getIdWithUnitId(e,t,a.uid),d=(c=this._disposableMap.get(l))!=null?c:new Set;d.add(()=>s.forEach(u=>u())),this._disposableMap.set(l,d)}_initRefRange(){this.disposeWithMe(this._dataValidationModel.ruleChange$.subscribe(e=>{const{unitId:t,subUnitId:a,rule:n}=e;switch(e.type){case"add":{const s=e.rule;this.registerRule(e.unitId,e.subUnitId,s);break}case"remove":{const s=this._disposableMap.get(this._getIdWithUnitId(t,a,n.uid));s&&s.forEach(l=>l());break}case"update":{const s=e.rule,l=this._disposableMap.get(this._getIdWithUnitId(t,a,s.uid));l&&l.forEach(d=>d()),this.registerRule(e.unitId,e.subUnitId,s);break}}})),this.disposeWithMe(i.toDisposable(()=>{this._disposableMap.forEach(e=>{e.forEach(t=>t())}),this._disposableMap.clear()}))}};exports.DataValidationRefRangeController=an([i.OnLifecycle(i.LifecycleStages.Ready,exports.DataValidationRefRangeController),Ie(0,i.Inject(D.DataValidationModel)),Ie(1,i.Inject(i.Injector)),Ie(2,i.Inject(x.RefRangeService)),Ie(3,i.Inject(exports.DataValidationCustomFormulaService)),Ie(4,i.Inject(exports.DataValidationFormulaService)),Ie(5,i.Inject(Vt.FormulaRefRangeService))],exports.DataValidationRefRangeController);var rn=Object.defineProperty,on=Object.getOwnPropertyDescriptor,nn=(o,r,e,t)=>{for(var a=t>1?void 0:t?on(r,e):r,n=o.length-1,s;n>=0;n--)(s=o[n])&&(a=(t?s(r,e,a):s(a))||a);return t&&a&&rn(r,e,a),a},lt=(o,r)=>(e,t)=>r(e,t,o);exports.DataValidationAutoFillController=class extends i.Disposable{constructor(r,e,t){super(),this._autoFillService=r,this._dataValidationModel=e,this._injector=t,this._initAutoFill()}_initAutoFill(){const r=()=>({redos:[],undos:[]}),e=n=>{const{source:s,target:l,unitId:d,subUnitId:c}=n,u=this._dataValidationModel.ensureManager(d,c),m=u.getRuleObjectMatrix().clone(),f=j.virtualizeDiscreteRanges([s,l]),[p,g]=f.ranges,{mapFunc:h}=f,_={row:p.startRow,col:p.startColumn};j.getAutoFillRepeatRange(p,g).forEach(M=>{const O=M.repeatStartCell,b=M.relativeRange,A={startRow:_.row,startColumn:_.col,endColumn:_.col,endRow:_.row},L={startRow:O.row,startColumn:O.col,endColumn:O.col,endRow:O.row};i.Range.foreach(b,(U,E)=>{const $=i.Rectangle.getPositionRange({startRow:U,startColumn:E,endColumn:E,endRow:U},A),{row:W,col:P}=h($.startRow,$.startColumn),N=u.getRuleIdByLocation(W,P);if(N){const H=i.Rectangle.getPositionRange({startRow:U,startColumn:E,endColumn:E,endRow:U},L),{row:K,col:Y}=h(H.startRow,H.startColumn);m.setValue(K,Y,N)}})});const C=m.diff(u.getDataValidations()),{redoMutations:V,undoMutations:I}=Me(d,c,C,this._injector);return{undos:I,redos:V}},t=[i.DataValidationType.CHECKBOX],a={id:Pe,onBeforeFillData:n=>{const{source:s,unitId:l,subUnitId:d}=n,c=this._dataValidationModel.ensureManager(l,d);for(const u of s.rows)for(const m of s.cols){const f=c.getRuleByLocation(u,m);if(f&&t.indexOf(f.type)>-1){this._autoFillService.setDisableApplyType(j.APPLY_TYPE.SERIES,!0);return}}},onFillData:(n,s,l)=>l===j.APPLY_TYPE.COPY||l===j.APPLY_TYPE.ONLY_FORMAT||l===j.APPLY_TYPE.SERIES?e(n):r(),onAfterFillData:()=>{}};this.disposeWithMe(this._autoFillService.addHook(a))}};exports.DataValidationAutoFillController=nn([i.OnLifecycle(i.LifecycleStages.Ready,exports.DataValidationAutoFillController),lt(0,j.IAutoFillService),lt(1,i.Inject(D.DataValidationModel)),lt(2,i.Inject(i.Injector))],exports.DataValidationAutoFillController);var sn=Object.defineProperty,ln=Object.getOwnPropertyDescriptor,dn=(o,r,e,t)=>{for(var a=t>1?void 0:t?ln(r,e):r,n=o.length-1,s;n>=0;n--)(s=o[n])&&(a=(t?s(r,e,a):s(a))||a);return t&&a&&sn(r,e,a),a},dt=(o,r)=>(e,t)=>r(e,t,o);exports.DataValidationCopyPasteController=class extends i.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:Pe,onBeforeCopy:(e,t,a)=>this._collect(e,t,a),onPasteCells:(e,t,a,n)=>{const{copyType:s=j.COPY_TYPE.COPY,pasteType:l}=n,{range:d}=e||{},{range:c,unitId:u,subUnitId:m}=t;return this._generateMutations(c,{copyType:s,pasteType:l,copyRange:d,unitId:u,subUnitId:m})}})}_collect(e,t,a){const n=new i.ObjectMatrix;this._copyInfo={unitId:e,subUnitId:t,matrix:n};const s=this._dataValidationModel.ensureManager(e,t),l={get:this._injector.get.bind(this._injector)},d=j.rangeToDiscreteRange(a,l,e,t);if(!d)return;const{rows:c,cols:u}=d;c.forEach((m,f)=>{u.forEach((p,g)=>{const h=s.getRuleIdByLocation(m,p);n.setValue(f,g,h!=null?h:"")})})}_generateMutations(e,t){if(!this._copyInfo)return{redos:[],undos:[]};if(t.copyType===j.COPY_TYPE.CUT)return this._copyInfo=null,{redos:[],undos:[]};if(!this._copyInfo||!this._copyInfo.matrix.getSizeOf()||!t.copyRange)return{redos:[],undos:[]};if([j.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_COL_WIDTH,j.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_VALUE,j.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMAT,j.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMULA].includes(t.pasteType))return{redos:[],undos:[]};const{unitId:a,subUnitId:n}=this._copyInfo;if(t.unitId!==a||n!==t.subUnitId){const s=this._dataValidationModel.ensureManager(a,n),l=this._dataValidationModel.ensureManager(t.unitId,t.subUnitId),d=l.getRuleObjectMatrix().clone(),{ranges:[c,u],mapFunc:m}=j.virtualizeDiscreteRanges([t.copyRange,e]),f=j.getRepeatRange(c,u,!0),p=new Map;f.forEach(({startRange:_})=>{var S;(S=this._copyInfo)==null||S.matrix.forValue((C,V,I)=>{const M=i.Rectangle.getPositionRange({startRow:C,endRow:C,startColumn:V,endColumn:V},_),O=`${n}-${I}`,b=s.getRuleById(I);!l.getRuleById(O)&&b&&p.set(O,{...b,uid:O});const{row:A,col:L}=m(M.startRow,M.startColumn);d.setValue(A,L,O)})});const{redoMutations:g,undoMutations:h}=Me(t.unitId,t.subUnitId,d.diffWithAddition(l.getDataValidations(),p.values()),this._injector);return{redos:g,undos:h}}else{const s=this._dataValidationModel.ensureManager(a,n),l=s.getRuleObjectMatrix().clone(),{ranges:[d,c],mapFunc:u}=j.virtualizeDiscreteRanges([t.copyRange,e]);j.getRepeatRange(d,c,!0).forEach(({startRange:g})=>{var h;(h=this._copyInfo)==null||h.matrix.forValue((_,S,C)=>{const V=i.Rectangle.getPositionRange({startRow:_,endRow:_,startColumn:S,endColumn:S},g),{row:I,col:M}=u(V.startRow,V.startColumn);l.setValue(I,M,C)})});const{redoMutations:f,undoMutations:p}=Me(a,n,l.diff(s.getDataValidations()),this._injector);return{redos:f,undos:p}}}};exports.DataValidationCopyPasteController=dn([i.OnLifecycle(i.LifecycleStages.Ready,exports.DataValidationCopyPasteController),dt(0,j.ISheetClipboardService),dt(1,i.Inject(D.DataValidationModel)),dt(2,i.Inject(i.Injector))],exports.DataValidationCopyPasteController);class yt{constructor(r,e){R(this,"value");this._worksheet=e,this.value=r}addRule(r){const e=r.uid;r.ranges.forEach(t=>{i.Range.foreach(i.Range.transformRange(t,this._worksheet),(a,n)=>{this.value.setValue(a,n,e)})})}removeRange(r){r.forEach(e=>{i.Range.foreach(i.Range.transformRange(e,this._worksheet),(t,a)=>{this.value.realDeleteValue(t,a)})})}removeRule(r){r.ranges.forEach(e=>{i.Range.foreach(i.Range.transformRange(e,this._worksheet),(t,a)=>{this.value.setValue(t,a,"")})})}updateRange(r,e,t){const a=`${r}$`,n=e.map(l=>i.Range.transformRange(l,this._worksheet)),s=t.map(l=>i.Range.transformRange(l,this._worksheet));n.forEach(l=>{i.Range.foreach(l,(d,c)=>{this.value.getValue(d,c)===r&&this.value.setValue(d,c,a)})}),s.forEach(l=>{i.Range.foreach(l,(d,c)=>{this.value.setValue(d,c,r)})}),n.forEach(l=>{i.Range.foreach(l,(d,c)=>{this.value.getValue(d,c)===a&&this.value.realDeleteValue(d,c)})})}diff(r){const e=[];let t=0;return r.forEach((a,n)=>{const s=i.queryObjectMatrix(this.value,d=>d===a.uid),l=a.ranges;(s.length!==l.length||s.some((d,c)=>!i.Rectangle.equals(d,l[c])))&&e.push({type:"update",ruleId:a.uid,oldRanges:l,newRanges:s}),s.length===0&&(e.push({type:"delete",rule:a,index:n-t}),t++)}),e}diffWithAddition(r,e){const t=[];let a=0;return r.forEach((n,s)=>{const l=i.queryObjectMatrix(this.value,c=>c===n.uid),d=n.ranges;(l.length!==d.length||l.some((c,u)=>!i.Rectangle.equals(c,d[u])))&&t.push({type:"update",ruleId:n.uid,oldRanges:d,newRanges:l}),l.length===0&&(t.push({type:"delete",rule:n,index:s-a}),a++)}),Array.from(e).forEach(n=>{const s=i.queryObjectMatrix(this.value,l=>l===n.uid);t.push({type:"add",rule:{...n,ranges:s}})}),t}clone(){return new yt(new i.ObjectMatrix(this.value.clone()),this._worksheet)}getValue(r,e){return this.value.getValue(r,e)}setValue(r,e,t){return this.value.setValue(r,e,t)}}class cn extends D.DataValidationManager{constructor(e,t,a,n){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=n,this._dataValidatorRegistryService=this._injector.get(D.DataValidatorRegistryService),this._dataValidationCacheService=this._injector.get(Ve),this._dataValidationFormulaService=this._injector.get(exports.DataValidationFormulaService),this._dataValidationCustomFormulaService=this._injector.get(exports.DataValidationCustomFormulaService),this._dataValidationRefRangeController=this._injector.get(exports.DataValidationRefRangeController),this._cache=this._dataValidationCacheService.ensureCache(e,t);const l=this._injector.get(i.IUniverInstanceService).getUnit(e,i.UniverInstanceType.UNIVER_SHEET).getSheetBySheetId(t),d=new i.ObjectMatrix;a==null||a.forEach(c=>{const u=c.uid;c.ranges.forEach(m=>{i.Range.foreach(m,(f,p)=>{d.setValue(f,p,u)})})}),a==null||a.forEach(c=>{this._dataValidationRefRangeController.register(e,t,c)}),this._ruleMatrix=new yt(d,l)}_addRuleSideEffect(e){var n;const{unitId:t,subUnitId:a}=this;(e.type===i.DataValidationType.LIST||e.type===i.DataValidationType.LIST_MULTIPLE)&&ae.isReferenceString((n=e.formula1)!=null?n:"")&&(e.formula1=`=${e.formula1}`),this._ruleMatrix.addRule(e),this._dataValidationCacheService.addRule(t,a,e),this._dataValidationFormulaService.addRule(t,a,e.uid,e.formula1,e.formula2),this._dataValidationCustomFormulaService.addRule(t,a,e)}addRule(e,t){(Array.isArray(e)?e:[e]).forEach(n=>{this._addRuleSideEffect(n)}),super.addRule(e,t)}updateRule(e,t){const a=this.getRuleById(e);if(!a)throw new Error(`Rule not found! id: ${e}`);return t.type===D.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===D.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,n){const{col:s,row:l,unitId:d,subUnitId:c}=a,u=t.uid,m=this.getValidator(t.type);if(m){const f=this._cache.getValue(l,s);return!f||f.value!==e?(this._cache.setValue(l,s,{value:e,status:i.DataValidationStatus.VALIDATING,ruleId:u}),m.validator({value:e,unitId:d,subUnitId:c,row:l,column:s},t).then(p=>{const g=p?i.DataValidationStatus.VALID:i.DataValidationStatus.INVALID;this._cache.setValue(l,s,{value:e,status:g,ruleId:u}),n(g,!0)}),i.DataValidationStatus.VALIDATING):(n(f.status,!1),f.status)}else return n(i.DataValidationStatus.VALID,!1),i.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 un=Object.defineProperty,hn=Object.getOwnPropertyDescriptor,mn=(o,r,e,t)=>{for(var a=t>1?void 0:t?hn(r,e):r,n=o.length-1,s;n>=0;n--)(s=o[n])&&(a=(t?s(r,e,a):s(a))||a);return t&&a&&un(r,e,a),a},He=(o,r)=>(e,t)=>r(e,t,o);let Ee=class extends i.Disposable{constructor(o,r,e,t){super(),this._resourceManagerService=o,this._univerInstanceService=r,this._dataValidationModel=e,this._injector=t,this._initDataValidationDataSource()}_createSheetDataValidationManager(o,r){return new cn(o,r,[],this._injector)}_initDataValidationDataSource(){this._dataValidationModel.setManagerCreator(this._createSheetDataValidationManager.bind(this))}};Ee=mn([i.OnLifecycle(i.LifecycleStages.Starting,Ee),He(0,i.IResourceManagerService),He(1,i.IUniverInstanceService),He(2,i.Inject(D.DataValidationModel)),He(3,i.Inject(i.Injector))],Ee);var pn=Object.defineProperty,fn=Object.getOwnPropertyDescriptor,gn=(o,r,e,t)=>{for(var a=t>1?void 0:t?fn(r,e):r,n=o.length-1,s;n>=0;n--)(s=o[n])&&(a=(t?s(r,e,a):s(a))||a);return t&&a&&pn(r,e,a),a},ct=(o,r)=>(e,t)=>r(e,t,o);let be=class extends i.Disposable{constructor(o,r,e){super(),this._localeService=o,this._commandService=r,this._sheetPermissionInterceptorBaseController=e,this._commandExecutedListener()}_commandExecutedListener(){this.disposeWithMe(this._commandService.beforeCommandExecuted(o=>{o.id===D.AddDataValidationCommand.id&&(this._sheetPermissionInterceptorBaseController.permissionCheckWithRanges({workbookTypes:[x.WorkbookEditablePermission],rangeTypes:[x.RangeProtectionPermissionEditPoint],worksheetTypes:[x.WorksheetEditPermission,x.WorksheetSetCellStylePermission]})||this._sheetPermissionInterceptorBaseController.haveNotPermissionHandle(this._localeService.t("permission.dialog.setStyleErr"))),o.id===je.id&&(this._sheetPermissionInterceptorBaseController.permissionCheckWithRanges({workbookTypes:[x.WorkbookEditablePermission],rangeTypes:[x.RangeProtectionPermissionEditPoint],worksheetTypes:[x.WorksheetEditPermission,x.WorksheetSetCellStylePermission]},o.params.ranges)||this._sheetPermissionInterceptorBaseController.haveNotPermissionHandle(this._localeService.t("permission.dialog.setStyleErr")))}))}};be=gn([i.OnLifecycle(i.LifecycleStages.Ready,be),ct(0,i.Inject(i.LocaleService)),ct(1,i.ICommandService),ct(2,i.Inject(j.SheetPermissionInterceptorBaseController))],be);var vn=Object.defineProperty,Sn=Object.getOwnPropertyDescriptor,_n=(o,r,e,t)=>{for(var a=t>1?void 0:t?Sn(r,e):r,n=o.length-1,s;n>=0;n--)(s=o[n])&&(a=(t?s(r,e,a):s(a))||a);return t&&a&&vn(r,e,a),a},ut=(o,r)=>(e,t)=>r(e,t,o);exports.SheetsDataValidationValidatorService=class{constructor(r,e,t){this._univerInstanceService=r,this._dataValidationModel=e,this._dataValidationCacheService=t}async validatorCell(r,e,t,a){const n=this._univerInstanceService.getUnit(r,i.UniverInstanceType.UNIVER_SHEET);if(!n)throw new Error(`cannot find current workbook, unitId: ${r}`);const s=n.getSheetBySheetId(e);if(!s)throw new Error(`cannot find current worksheet, sheetId: ${e}`);const l=s.getCellRaw(t,a),d=this._dataValidationModel.ensureManager(r,e),c=d.getRuleByLocation(t,a);return c?new Promise(u=>{d.validator(J(l),c,{unitId:r,subUnitId:e,row:t,col:a},u)}):i.DataValidationStatus.VALID}async validatorWorksheet(r,e){const a=this._dataValidationModel.ensureManager(r,e).getDataValidations();return await Promise.all(a.map(n=>Promise.all(n.ranges.map(s=>{const l=[];return i.Range.foreach(s,(d,c)=>{l.push(this.validatorCell(r,e,d,c))}),l})))),this._dataValidationCacheService.ensureCache(r,e)}async validatorWorkbook(r){const e=this._dataValidationModel.getSubUnitIds(r),t=await Promise.all(e.map(n=>this.validatorWorksheet(r,n))),a={};return t.forEach((n,s)=>{a[e[s]]=n}),a}};exports.SheetsDataValidationValidatorService=_n([ut(0,i.IUniverInstanceService),ut(1,i.Inject(D.DataValidationModel)),ut(2,i.Inject(Ve))],exports.SheetsDataValidationValidatorService);var ha=Object.defineProperty,Vn=Object.getOwnPropertyDescriptor,Rn=(o,r,e)=>r in o?ha(o,r,{enumerable:!0,configurable:!0,writable:!0,value:e}):o[r]=e,Dn=(o,r,e,t)=>{for(var a=t>1?void 0:t?Vn(r,e):r,n=o.length-1,s;n>=0;n--)(s=o[n])&&(a=(t?s(r,e,a):s(a))||a);return t&&a&&ha(r,e,a),a},ht=(o,r)=>(e,t)=>r(e,t,o),ma=(o,r,e)=>Rn(o,typeof r!="symbol"?r+"":r,e);exports.UniverSheetsDataValidationPlugin=class extends i.Plugin{constructor(r={},e,t,a){super(),this._config=r,this._injector=e,this._commandService=t,this._localeService=a,this._config=i.Tools.deepMerge({},la,this._config)}onStarting(r){[[le],[exports.SheetDataValidationService],[Ve],[exports.DataValidationFormulaService],[exports.DataValidationCustomFormulaService],[me],[exports.SheetsDataValidationValidatorService],[Ee],[exports.DataValidationController],[exports.SheetsDataValidationRenderController,{useFactory:()=>this._injector.createInstance(exports.SheetsDataValidationRenderController,this._config)}],[exports.DataValidationAlertController],[exports.DataValidationRefRangeController],[be],[exports.DataValidationAutoFillController],[exports.DataValidationCopyPasteController],[exports.DataValidationFormulaController],[exports.DataValidationRejectInputController]].forEach(e=>{r.add(e)}),[xe,Ze,je,vt,na,Le,Dt,Ke,_e,Rt].forEach(e=>{this._commandService.registerCommand(e)})}};ma(exports.UniverSheetsDataValidationPlugin,"pluginName",Pe);ma(exports.UniverSheetsDataValidationPlugin,"type",i.UniverInstanceType.UNIVER_SHEET);exports.UniverSheetsDataValidationPlugin=Dn([i.DependentOn(D.UniverDataValidationPlugin,x.UniverSheetsPlugin,j.UniverSheetsUIPlugin),ht(1,i.Inject(i.Injector)),ht(2,i.ICommandService),ht(3,i.Inject(i.LocaleService))],exports.UniverSheetsDataValidationPlugin);var pa=Object.defineProperty,Cn=Object.getOwnPropertyDescriptor,In=(o,r,e)=>r in o?pa(o,r,{enumerable:!0,configurable:!0,writable:!0,value:e}):o[r]=e,yn=(o,r,e,t)=>{for(var a=t>1?void 0:t?Cn(r,e):r,n=o.length-1,s;n>=0;n--)(s=o[n])&&(a=(t?s(r,e,a):s(a))||a);return t&&a&&pa(r,e,a),a},mt=(o,r)=>(e,t)=>r(e,t,o),fa=(o,r,e)=>In(o,typeof r!="symbol"?r+"":r,e);exports.UniverSheetsDataValidationMobilePlugin=class extends i.Plugin{constructor(r={},e,t,a){super(),this._config=r,this._injector=e,this._commandService=t,this._localeService=a,this._config=i.Tools.deepMerge({},la,this._config)}onStarting(r){[[le],[exports.SheetDataValidationService],[Ve],[exports.DataValidationFormulaService],[exports.DataValidationCustomFormulaService],[me],[exports.SheetsDataValidationValidatorService],[Ee],[exports.DataValidationController],[Te,{useFactory:()=>this._injector.createInstance(Te,this._config)}],[exports.DataValidationAlertController],[exports.DataValidationRefRangeController],[be],[exports.DataValidationCopyPasteController],[exports.DataValidationFormulaController]].forEach(e=>{r.add(e)}),[xe,Ze,je,Le,Dt,Ke,_e,Rt].forEach(e=>{this._commandService.registerCommand(e)})}};fa(exports.UniverSheetsDataValidationMobilePlugin,"pluginName",Pe);fa(exports.UniverSheetsDataValidationMobilePlugin,"type",i.UniverInstanceType.UNIVER_SHEET);exports.UniverSheetsDataValidationMobilePlugin=yn([i.DependentOn(D.UniverDataValidationPlugin,x.UniverSheetsPlugin,j.UniverSheetsUIPlugin),mt(1,i.Inject(i.Injector)),mt(2,i.ICommandService),mt(3,i.Inject(i.LocaleService))],exports.UniverSheetsDataValidationMobilePlugin);Object.defineProperty(exports,"ICommandService",{enumerable:!0,get:()=>i.ICommandService});Object.defineProperty(exports,"LocaleService",{enumerable:!0,get:()=>i.LocaleService});Object.defineProperty(exports,"Plugin",{enumerable:!0,get:()=>i.Plugin});exports.AddSheetDataValidationAndOpenCommand=Ze;exports.AddSheetDataValidationCommand=xe;exports.CloseValidationPanelOperation=Ke;exports.DATA_VALIDATION_PLUGIN_NAME=Pe;exports.DataValidationCacheService=Ve;exports.HideDataValidationDropdown=Dt;exports.OpenValidationPanelOperation=_e;exports.ShowDataValidationDropdown=Le;exports.ToggleValidationPanelOperation=Rt;exports.UpdateSheetDataValidationRangeCommand=je;
|