@univerjs/sheets-data-validation 0.2.2 → 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/README.md +12 -4
- package/lib/cjs/index.js +2 -2
- package/lib/es/index.js +2675 -2559
- package/lib/index.css +1 -1
- package/lib/locale/en-US.json +3 -0
- package/lib/locale/ru-RU.json +3 -0
- package/lib/locale/vi-VN.json +165 -0
- package/lib/locale/zh-CN.json +3 -0
- package/lib/locale/zh-TW.json +165 -0
- 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 -3
- package/lib/types/controllers/dv.controller.d.ts +4 -4
- package/lib/types/controllers/dv.menu.d.ts +1 -1
- package/lib/types/locale/vi-VN.d.ts +4 -0
- package/lib/types/locale/zh-CN.d.ts +3 -0
- package/lib/types/locale/zh-TW.d.ts +4 -0
- 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/types/utils/date.d.ts +2 -2
- package/lib/types/validators/date-validator.d.ts +17 -15
- package/lib/types/views/date-dropdown/index.d.ts +1 -1
- package/lib/types/views/show-time/index.d.ts +11 -0
- package/lib/umd/index.js +2 -2
- package/package.json +26 -26
package/lib/umd/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
(function(g,
|
|
1
|
+
(function(g,o){typeof exports=="object"&&typeof module<"u"?o(exports,require("@univerjs/core"),require("@univerjs/data-validation"),require("@univerjs/sheets"),require("@univerjs/sheets-ui"),require("@univerjs/ui"),require("@univerjs/engine-render"),require("rxjs"),require("react"),require("@univerjs/sheets-formula"),require("@univerjs/design"),require("clsx"),require("@univerjs/engine-formula"),require("dayjs"),require("@univerjs/engine-numfmt")):typeof define=="function"&&define.amd?define(["exports","@univerjs/core","@univerjs/data-validation","@univerjs/sheets","@univerjs/sheets-ui","@univerjs/ui","@univerjs/engine-render","rxjs","react","@univerjs/sheets-formula","@univerjs/design","clsx","@univerjs/engine-formula","dayjs","@univerjs/engine-numfmt"],o):(g=typeof globalThis<"u"?globalThis:g||self,o(g.UniverSheetsDataValidation={},g.UniverCore,g.UniverDataValidation,g.UniverSheets,g.UniverSheetsUi,g.UniverUi,g.UniverEngineRender,g.rxjs,g.React,g.UniverSheetsFormula,g.UniverDesign,g.clsx,g.UniverEngineFormula,g.dayjs,g.UniverEngineNumfmt))})(this,function(g,o,D,U,B,k,K,vt,E,te,O,ga,at,ot,Sa){"use strict";var Xi=Object.defineProperty;var Gi=(g,o,D)=>o in g?Xi(g,o,{enumerable:!0,configurable:!0,writable:!0,value:D}):g[o]=D;var I=(g,o,D)=>Gi(g,typeof o!="symbol"?o+"":o,D);var Me;function J(i){if(i===null)return"";if(i!=null&&i.p){const n=i==null?void 0:i.p.body;if(n==null)return"";const t=n.dataStream;return t.substring(t.length-2,t.length)===o.DEFAULT_EMPTY_DOCUMENT_VALUE?t.substring(0,t.length-2):t}return i==null?void 0:i.v}function we(i){var n;return String((n=J(i))!=null?n:"")}var _a=typeof globalThis<"u"?globalThis:typeof window<"u"?window:typeof global<"u"?global:typeof self<"u"?self:{};function Da(i){return i&&i.__esModule&&Object.prototype.hasOwnProperty.call(i,"default")?i.default:i}var Oe={exports:{}},$t={};/**
|
|
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 Sa=T,_a=Symbol.for("react.element"),Va=Symbol.for("react.fragment"),Da=Object.prototype.hasOwnProperty,Ra=Sa.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,Ia={key:!0,ref:!0,__self:!0,__source:!0};function Et(i,n,e){var t,a={},r=null,o=null;e!==void 0&&(r=""+e),n.key!==void 0&&(r=""+n.key),n.ref!==void 0&&(o=n.ref);for(t in n)Da.call(n,t)&&!Ia.hasOwnProperty(t)&&(a[t]=n[t]);if(i&&i.defaultProps)for(t in n=i.defaultProps,n)a[t]===void 0&&(a[t]=n[t]);return{$$typeof:_a,type:i,key:r,ref:o,props:a,_owner:Ra.current}}He.Fragment=Va,He.jsx=Et,He.jsxs=Et,Tt.exports=He;var S=Tt.exports;function Ca(){const i=x.useDependency(he),n=X.useObservable(i.activeDropdown$,i.activeDropdown),e=x.useDependency(X.ComponentManager);if(!n)return null;const{location:t,componentKey:a}=n,r=e.get(a),o=`${t.unitId}-${t.subUnitId}-${t.row}-${t.col}`;if(!r)return null;const l=()=>{i.hideDropdown()};return S.jsx(r,{location:t,hideFn:l},o)}const Ft="sheet.ui.dropdown";var ya=Object.defineProperty,Ma=Object.getOwnPropertyDescriptor,wa=(i,n,e,t)=>{for(var a=t>1?void 0:t?Ma(n,e):n,r=i.length-1,o;r>=0;r--)(o=i[r])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&ya(n,e,a),a},Ce=(i,n)=>(e,t)=>n(e,t,i);let he=class extends s.Disposable{constructor(n,e,t,a,r,o){super();V(this,"_activeDropdown");V(this,"_activeDropdown$",new ge.Subject);V(this,"_currentPopup",null);V(this,"activeDropdown$",this._activeDropdown$.asObservable());V(this,"_zenVisible",!1);this._canvasPopupManagerService=n,this._univerInstanceService=e,this._dataValidatorRegistryService=t,this._zenZoneService=a,this._renderManagerService=r,this._dataValidationModel=o,this._init()}get activeDropdown(){return this._activeDropdown}_init(){this.disposeWithMe(this._zenZoneService.visible$.subscribe(n=>{this._zenVisible=n,n&&this.hideDropdown()}))}showDropdown(n){const{location:e}=n,{row:t,col:a}=e;if(this._currentPopup&&this._currentPopup.dispose(),this._zenVisible)return;this._activeDropdown=n,this._activeDropdown$.next(this._activeDropdown);const r=this._renderManagerService.getRenderById(s.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),o=this._canvasPopupManagerService.attachPopupToCell(t,a,{componentKey:Ft,onClickOutside:()=>{this.hideDropdown()},offset:[0,3],excludeOutside:[r==null?void 0:r.engine.getCanvasElement()].filter(Boolean)});if(!o)throw new Error("[DataValidationDropdownManagerService]: cannot show dropdown!");const l=new s.DisposableCollection;l.add(o),l.add({dispose:()=>{var d,u;(u=(d=this._activeDropdown)==null?void 0:d.onHide)==null||u.call(d)}}),this._currentPopup=l}hideDropdown(){this._activeDropdown&&(this._currentPopup&&this._currentPopup.dispose(),this._currentPopup=null,this._activeDropdown=null,this._activeDropdown$.next(null))}showDataValidationDropdown(n,e,t,a,r){const o=this._univerInstanceService.getUniverSheetInstance(n);if(!o)return;const l=o.getSheetBySheetId(e);if(!l)return;const u=this._dataValidationModel.ensureManager(n,e).getRuleByLocation(t,a);if(!u)return;const c=this._dataValidatorRegistryService.getValidatorItem(u.type);if(!c||!c.dropdown){this.hideDropdown();return}this.showDropdown({location:{workbook:o,worksheet:l,row:t,col:a,unitId:n,subUnitId:e},componentKey:c.dropdown,onHide:r})}};he=wa([Ce(0,y.Inject(U.SheetCanvasPopManagerService)),Ce(1,s.IUniverInstanceService),Ce(2,y.Inject(D.DataValidatorRegistryService)),Ce(3,X.IZenZoneService),Ce(4,Q.IRenderManagerService),Ce(5,y.Inject(D.DataValidationModel))],he);var Oa=Object.defineProperty,Ta=Object.getOwnPropertyDescriptor,Ea=(i,n,e,t)=>{for(var a=t>1?void 0:t?Ta(n,e):n,r=i.length-1,o;r>=0;r--)(o=i[r])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&Oa(n,e,a),a},bt=(i,n)=>(e,t)=>n(e,t,i);let se=class extends s.Disposable{constructor(n,e){super();V(this,"_open$",new ge.BehaviorSubject(!1));V(this,"open$",this._open$.pipe(ge.distinctUntilChanged()));V(this,"_activeRule");V(this,"_activeRule$",new ge.BehaviorSubject(void 0));V(this,"activeRule$",this._activeRule$.asObservable());V(this,"_closeDisposable",null);this._univerInstanceService=n,this._sidebarService=e,this.disposeWithMe(this._univerInstanceService.getCurrentTypeOfUnit$(s.UniverInstanceType.UNIVER_SHEET).pipe(ge.filter(t=>!t)).subscribe(()=>{this.close()}))}get activeRule(){return this._activeRule}get isOpen(){return this._open$.getValue()}dispose(){var n;super.dispose(),this._open$.next(!1),this._open$.complete(),(n=this._closeDisposable)==null||n.dispose()}open(){this._open$.next(!0)}close(){var n;this._open$.next(!1),(n=this._closeDisposable)==null||n.dispose()}setCloseDisposable(n){this._closeDisposable=s.toDisposable(()=>{n.dispose(),this._closeDisposable=null})}setActiveRule(n){this._activeRule=n,this._activeRule$.next(n)}};se=Ea([bt(0,s.IUniverInstanceService),bt(1,X.ISidebarService)],se);const Lt="DataValidationPanel",_e={id:"data-validation.operation.open-validation-panel",type:s.CommandType.OPERATION,handler(i,n){if(!n)return!1;const{ruleId:e,isAdd:t}=n,a=i.get(se),r=i.get(D.DataValidationModel),o=i.get(s.IUniverInstanceService),l=i.get(X.ISidebarService),d=j.getSheetCommandTarget(o);if(!d)return!1;const{unitId:u,subUnitId:c}=d,m=e?r.getRuleById(u,c,e):void 0;a.open(),a.setActiveRule(m&&{unitId:u,subUnitId:c,rule:m});const h=l.open({header:{title:t?"dataValidation.panel.addTitle":"dataValidation.panel.title"},children:{label:Lt},width:312,onClose:()=>a.close()});return a.setCloseDisposable(h),!0}},xe={id:"data-validation.operation.close-validation-panel",type:s.CommandType.OPERATION,handler(i){return i.get(se).close(),!0}},at={id:"data-validation.operation.toggle-validation-panel",type:s.CommandType.OPERATION,handler(i){const n=i.get(s.ICommandService),e=i.get(se);return e.open(),e.isOpen?n.executeCommand(xe.id):n.executeCommand(_e.id),!0}},Ee={type:s.CommandType.OPERATION,id:"sheet.operation.show-data-validation-dropdown",handler(i,n){if(!n)return!1;const e=i.get(he),{unitId:t,subUnitId:a,row:r,column:o}=n,l=e.activeDropdown,d=l==null?void 0:l.location;return d&&d.unitId===t&&d.subUnitId===a&&d.row===r&&d.col===o||e.showDataValidationDropdown(t,a,r,o),!0}},nt={type:s.CommandType.OPERATION,id:"sheet.operation.hide-data-validation-dropdown",handler(i,n){return n?(i.get(he).hideDropdown(),!0):!1}};class Ve{constructor(){V(this,"_cacheMatrix",new Map)}_ensureCache(n,e){let t=this._cacheMatrix.get(n);t||(t=new Map,this._cacheMatrix.set(n,t));let a=t.get(e);return a||(a=new s.ObjectMatrix,t.set(e,a)),a}ensureCache(n,e){return this._ensureCache(n,e)}addRule(n,e,t){this.markRangeDirty(n,e,t.ranges)}removeRule(n,e,t){this._deleteRange(n,e,t.ranges)}updateRuleRanges(n,e,t,a,r){const o=this._ensureCache(n,e);r.forEach(l=>{s.Range.foreach(l,(d,u)=>{const c=o.getValue(d,u);c&&(c.temp=!0)})}),a.forEach(l=>{s.Range.foreach(l,(d,u)=>{const c=o.getValue(d,u);c&&c.ruleId===t?c.temp=!1:o.setValue(d,u,void 0)})}),r.forEach(l=>{s.Range.foreach(l,(d,u)=>{const c=o.getValue(d,u);c&&c.temp===!0&&o.realDeleteValue(d,u)})})}markRangeDirty(n,e,t){const a=this._ensureCache(n,e);t.forEach(r=>{s.Range.foreach(r,(o,l)=>{a.setValue(o,l,void 0)})})}markCellDirty(n,e,t,a){this._ensureCache(n,e).setValue(t,a,void 0)}_deleteRange(n,e,t){const a=this._ensureCache(n,e);t.forEach(r=>{s.Range.foreach(r,(o,l)=>{a.realDeleteValue(o,l)})})}getValue(n,e,t,a){return this._ensureCache(n,e).getValue(t,a)}setValue(n,e,t,a,r){return this._ensureCache(n,e).setValue(t,a,r)}}var Fa=Object.defineProperty,ba=Object.getOwnPropertyDescriptor,La=(i,n,e,t)=>{for(var a=t>1?void 0:t?ba(n,e):n,r=i.length-1,o;r>=0;r--)(o=i[r])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&Fa(n,e,a),a},rt=(i,n)=>(e,t)=>n(e,t,i);g.DataValidationFormulaService=class extends s.Disposable{constructor(e,t,a){super();V(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 r in a){const o=a[r],l=this._ensureRuleFormulaMap(t,r),d=this._dataValidationModel.ensureManager(t,r);o.forEach(u=>{var c,m;if(l.get((c=u.extra)==null?void 0:c.ruleId)){const h=d.getRuleById((m=u.extra)==null?void 0:m.ruleId);h&&this._dataValidationCacheService.markRangeDirty(t,r,h.ranges)}})}}}))}_ensureRuleFormulaMap(e,t){let a=this._formulaRuleMap.get(e);a||(a=new Map,this._formulaRuleMap.set(e,a));let r=a.get(t);return r||(r=new Map,a.set(t,r)),r}addRule(e,t,a,r,o){const l=s.isFormulaString(r),d=s.isFormulaString(o);if(!l&&!d)return;const u=this._ensureRuleFormulaMap(e,t),c=[void 0,void 0];if(l){const m=this._registerOtherFormulaService.registerFormula(e,t,r,{ruleId:a});c[0]={id:m,text:r}}if(d){const m=this._registerOtherFormulaService.registerFormula(e,t,o,{ruleId:a});c[1]={id:m,text:o}}u.set(a,c)}removeRule(e,t,a){const o=this._ensureRuleFormulaMap(e,t).get(a);if(!o)return;const[l,d]=o,u=[l==null?void 0:l.id,d==null?void 0:d.id].filter(Boolean);u.length&&this._registerOtherFormulaService.deleteFormula(e,t,u)}updateRuleFormulaText(e,t,a,r,o){const d=this._ensureRuleFormulaMap(e,t).get(a);if(!d){this.addRule(e,t,a,r,o);return}const[u,c]=d;if((u==null?void 0:u.text)!==r)if(u&&this._registerOtherFormulaService.deleteFormula(e,t,[u.id]),s.isFormulaString(r)){const m=this._registerOtherFormulaService.registerFormula(e,t,r,{ruleId:a});d[0]={text:r,id:m}}else d[0]=void 0;if((c==null?void 0:c.text)!==o)if(c&&this._registerOtherFormulaService.deleteFormula(e,t,[c.id]),s.isFormulaString(o)){const m=this._registerOtherFormulaService.registerFormula(e,t,o,{ruleId:a});d[1]={text:o,id:m}}else d[1]=void 0}getRuleFormulaResult(e,t,a){const o=this._ensureRuleFormulaMap(e,t).get(a);if(!o)return Promise.resolve(null);const l=async d=>d&&this._registerOtherFormulaService.getFormulaValue(e,t,d.id);return Promise.all([l(o[0]),l(o[1])])}getRuleFormulaResultSync(e,t,a){const o=this._ensureRuleFormulaMap(e,t).get(a);if(o)return o.map(l=>{if(l)return this._registerOtherFormulaService.getFormulaValueSync(e,t,l.id)})}getRuleFormulaInfo(e,t,a){return this._ensureRuleFormulaMap(e,t).get(a)}},g.DataValidationFormulaService=La([rt(0,y.Inject(tt.RegisterOtherFormulaService)),rt(1,y.Inject(Ve)),rt(2,y.Inject(D.DataValidationModel))],g.DataValidationFormulaService);function ue(i){var n,e;return(e=(n=i==null?void 0:i[0])==null?void 0:n[0])==null?void 0:e.v}function te(i){if(i===null)return"";if(i!=null&&i.p){const n=i==null?void 0:i.p.body;if(n==null)return"";const e=n.dataStream;return e.substring(e.length-2,e.length)===s.DEFAULT_EMPTY_DOCUMENT_VALUE?e.substring(0,e.length-2):e}return i==null?void 0:i.v}function Nt(i){var n;return String((n=te(i))!=null?n:"")}var Na=Object.defineProperty,Pa=Object.getOwnPropertyDescriptor,Aa=(i,n,e,t)=>{for(var a=t>1?void 0:t?Pa(n,e):n,r=i.length-1,o;r>=0;r--)(o=i[r])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&Na(n,e,a),a},it=(i,n)=>(e,t)=>n(e,t,i);const ke=6;let ot=class{constructor(i,n,e){this._commandService=i,this._formulaService=n,this._themeService=e}_calc(i,n){var u,c,m;const{vt:e,ht:t}=n||{},a=i.endX-i.startX-ke*2,r=i.endY-i.startY,o=((u=n==null?void 0:n.fs)!=null?u:10)*1.6;let l=0,d=0;switch(e){case s.VerticalAlign.TOP:d=0;break;case s.VerticalAlign.BOTTOM:d=0+(r-o);break;default:d=0+(r-o)/2;break}switch(t){case s.HorizontalAlign.LEFT:l=ke;break;case s.HorizontalAlign.RIGHT:l=ke+(a-o);break;default:l=ke+(a-o)/2;break}return{left:i.startX+l,top:i.startY+d,width:((c=n==null?void 0:n.fs)!=null?c:10)*1.6,height:((m=n==null?void 0:n.fs)!=null?m:10)*1.6}}calcCellAutoHeight(i){var e;const{style:n}=i;return((e=n==null?void 0:n.fs)!=null?e:10)*1.6}async _parseFormula(i,n,e){var o,l;const{formula1:t=Le,formula2:a=Ne}=i,r=await this._formulaService.getRuleFormulaResult(n,e,i.uid);return{formula1:s.isFormulaString(t)?ue((o=r==null?void 0:r[0])==null?void 0:o.result):t,formula2:s.isFormulaString(a)?ue((l=r==null?void 0:r[1])==null?void 0:l.result):a}}drawWith(i,n){var A,b,H,Y,P;const{style:e,data:t,primaryWithCoord:a,unitId:r,subUnitId:o}=n,l=a.isMergedMainCell?a.mergeInfo:a,d=te(t),u=(A=t.dataValidation)==null?void 0:A.rule,c=(b=t.dataValidation)==null?void 0:b.validator;if(!u||!c)return;const m=this._themeService.getCurrentTheme();if(!c.skipDefaultFontRender(u,d,{unitId:r,subUnitId:o}))return;const h=c.parseFormulaSync(u,r,o),{formula1:p}=h,v=this._calc(l,e),{a:f,d:I}=i.getTransform(),_=Q.fixLineWidthByScale(v.left,f),C=Q.fixLineWidthByScale(v.top,I),R=Q.Transform.create().composeMatrix({left:_,top:C,scaleX:1,scaleY:1,angle:0,skewX:0,skewY:0,flipX:!1,flipY:!1}),M=l.endX-l.startX,O=l.endY-l.startY;i.save(),i.beginPath(),i.rect(l.startX,l.startY,M,O),i.clip();const F=R.getMatrix();i.transform(F[0],F[1],F[2],F[3],F[4],F[5]);const B=((H=e==null?void 0:e.fs)!=null?H:10)*1.6,$=String(d)===String(p),k=m.hyacinth500;Q.Checkbox.drawWith(i,{checked:$,width:B,height:B,fill:(P=(Y=e==null?void 0:e.cl)==null?void 0:Y.rgb)!=null?P:k}),i.restore()}isHit(i,n){const e=n.primaryWithCoord.isMergedMainCell?n.primaryWithCoord.mergeInfo:n.primaryWithCoord,t=this._calc(e,n.style),a=t.top,r=t.top+t.height,o=t.left,l=t.left+t.width,{x:d,y:u}=i;return d<=l&&d>=o&&u<=r&&u>=a}async onPointerDown(i,n){var h,p;if(n.button===2)return;const{primaryWithCoord:e,unitId:t,subUnitId:a,data:r}=i,o=te(r),l=(h=r.dataValidation)==null?void 0:h.rule,d=(p=r.dataValidation)==null?void 0:p.validator;if(!l||!d||!d.skipDefaultFontRender(l,o,{unitId:t,subUnitId:a}))return;const{formula1:u,formula2:c}=await this._parseFormula(l,t,a),m={range:{startColumn:e.actualColumn,endColumn:e.actualColumn,startRow:e.actualRow,endRow:e.actualRow},value:{v:String(o)===String(u)?c:u,p:null}};this._commandService.executeCommand(j.SetRangeValuesCommand.id,m)}};ot=Aa([it(0,s.ICommandService),it(1,y.Inject(g.DataValidationFormulaService)),it(2,y.Inject(s.ThemeService))],ot);function ja(i){var d;const{unitId:n,subUnitId:e,value:t,onChange:a,showError:r,validResult:o}=i,l=r?o==null?void 0:o.formula1:"";return S.jsx(E.FormLayout,{error:l,children:S.jsx(X.TextEditor,{value:(d=t==null?void 0:t.formula1)!=null?d:"",id:s.createInternalEditorID(`dataValidation-custom-formula-${n}-${e}`),onChange:u=>{a==null||a({...t,formula1:u!=null?u:""})},onlyInputFormula:!0,openForSheetUnitId:n,openForSheetSubUnitId:e})})}const ie={dataValidationFormula:"univer-data-validation-formula",dataValidationFormulaAnd:"univer-data-validation-formula-and",dataValidationFormulaListItem:"univer-data-validation-formula-list-item",dataValidationFormulaListItemIcon:"univer-data-validation-formula-list-item-icon",dataValidationFormulaListItemDrag:"univer-data-validation-formula-list-item-drag",dataValidationFormulaListAdd:"univer-data-validation-formula-list-add",dataValidationFormulaColorSelect:"univer-data-validation-formula-color-select",dataValidationFormulaColorSelectPanel:"univer-data-validation-formula-color-select-panel",dataValidationFormulaColorItem:"univer-data-validation-formula-color-item"},Ua=i=>{const{isTwoFormula:n=!1,value:e,onChange:t,showError:a,validResult:r}=i,o=x.useDependency(s.LocaleService),l=a?r==null?void 0:r.formula1:"",d=a?r==null?void 0:r.formula2:"";return n?S.jsxs(S.Fragment,{children:[S.jsx(E.FormLayout,{error:l,children:S.jsx(E.Input,{className:ie.dataValidationFormula,placeholder:o.t("dataValidation.panel.formulaPlaceholder"),value:e==null?void 0:e.formula1,onChange:u=>{t==null||t({...e,formula1:u})}})}),S.jsx("div",{className:ie.dataValidationFormulaAnd,children:o.t("dataValidation.panel.formulaAnd")}),S.jsx(E.FormLayout,{error:d,children:S.jsx(E.Input,{className:ie.dataValidationFormula,placeholder:o.t("dataValidation.panel.formulaPlaceholder"),value:e==null?void 0:e.formula2,onChange:u=>{t==null||t({...e,formula2:u})}})})]}):S.jsx(E.FormLayout,{error:l,children:S.jsx(E.Input,{className:ie.dataValidationFormula,placeholder:o.t("dataValidation.panel.formulaPlaceholder"),value:e==null?void 0:e.formula1,onChange:u=>{t==null||t({formula1:u})}})})};var oe=function(){return oe=Object.assign||function(i){for(var n,e=1,t=arguments.length;e<t;e++){n=arguments[e];for(var a in n)Object.prototype.hasOwnProperty.call(n,a)&&(i[a]=n[a])}return i},oe.apply(this,arguments)},Ba=function(i,n){var e={};for(var t in i)Object.prototype.hasOwnProperty.call(i,t)&&n.indexOf(t)<0&&(e[t]=i[t]);if(i!=null&&typeof Object.getOwnPropertySymbols=="function")for(var a=0,t=Object.getOwnPropertySymbols(i);a<t.length;a++)n.indexOf(t[a])<0&&Object.prototype.propertyIsEnumerable.call(i,t[a])&&(e[t[a]]=i[t[a]]);return e},pe=T.forwardRef(function(i,n){var e=i.icon,t=i.id,a=i.className,r=i.extend,o=Ba(i,["icon","id","className","extend"]),l="univerjs-icon univerjs-icon-".concat(t," ").concat(a||"").trim(),d=T.useRef("_".concat(Ha()));return Pt(e,"".concat(t),{defIds:e.defIds,idSuffix:d.current},oe({ref:n,className:l},o),r)});function Pt(i,n,e,t,a){return T.createElement(i.tag,oe(oe({key:n},$a(i,e,a)),t),(Wa(i,e).children||[]).map(function(r,o){return Pt(r,"".concat(n,"-").concat(i.tag,"-").concat(o),e,void 0,a)}))}function $a(i,n,e){var t=oe({},i.attrs);e!=null&&e.colorChannel1&&t.fill==="colorChannel1"&&(t.fill=e.colorChannel1);var a=n.defIds;return!a||a.length===0||(i.tag==="use"&&t["xlink:href"]&&(t["xlink:href"]=t["xlink:href"]+n.idSuffix),Object.entries(t).forEach(function(r){var o=r[0],l=r[1];typeof l=="string"&&(t[o]=l.replace(/url\(#(.*)\)/,"url(#$1".concat(n.idSuffix,")")))})),t}function Wa(i,n){var e,t=n.defIds;return!t||t.length===0?i:i.tag==="defs"&&(!((e=i.children)===null||e===void 0)&&e.length)?oe(oe({},i),{children:i.children.map(function(a){return typeof a.attrs.id=="string"&&t&&t.indexOf(a.attrs.id)>-1?oe(oe({},a),{attrs:oe(oe({},a.attrs),{id:a.attrs.id+n.idSuffix})}):a})}):i}function Ha(){return Math.random().toString(36).substring(2,8)}pe.displayName="UniverIcon";var xa={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"}}]},At=T.forwardRef(function(i,n){return T.createElement(pe,Object.assign({},i,{id:"check-mark-single",ref:n,icon:xa}))});At.displayName="CheckMarkSingle";var ka={tag:"svg",attrs:{fill:"none",viewBox:"0 0 17 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M1.4917 3.07803C1.4917 2.19437 2.20804 1.47803 3.0917 1.47803H5.6917C6.57536 1.47803 7.2917 2.19437 7.2917 3.07803V5.67803C7.2917 6.56168 6.57535 7.27803 5.6917 7.27803H3.0917C2.20804 7.27803 1.4917 6.56168 1.4917 5.67803V3.07803ZM3.0917 2.67803C2.87078 2.67803 2.6917 2.85711 2.6917 3.07803V5.67803C2.6917 5.89894 2.87079 6.07803 3.0917 6.07803H5.6917C5.91261 6.07803 6.0917 5.89894 6.0917 5.67803V3.07803C6.0917 2.85711 5.91261 2.67803 5.6917 2.67803H3.0917Z",fillRule:"evenodd",clipRule:"evenodd"}},{tag:"path",attrs:{fill:"currentColor",d:"M14.6175 2.45279C14.8518 2.68711 14.8518 3.06701 14.6175 3.30132L11.6151 6.30365C11.3957 6.52307 11.0451 6.53897 10.8067 6.34031L8.80915 4.67566C8.55458 4.46352 8.52019 4.08518 8.73233 3.83062 8.94447 3.57605 9.32281 3.54166 9.57737 3.7538L11.154 5.06767 13.769 2.45278C14.0033 2.21847 14.3832 2.21848 14.6175 2.45279zM14.1175 9.19746C14.3518 9.43178 14.3518 9.81168 14.1175 10.046L12.5418 11.6217 14.1175 13.1975C14.3518 13.4318 14.3518 13.8117 14.1175 14.046 13.8832 14.2803 13.5033 14.2803 13.269 14.046L11.6933 12.4703 10.1175 14.046C9.88321 14.2803 9.50331 14.2803 9.269 14.046 9.03468 13.8117 9.03468 13.4318 9.269 13.1975L10.8447 11.6217 9.269 10.046C9.03468 9.81168 9.03468 9.43178 9.269 9.19746 9.50331 8.96315 9.88321 8.96315 10.1175 9.19746L11.6933 10.7732 13.269 9.19746C13.5033 8.96315 13.8832 8.96315 14.1175 9.19746z"}},{tag:"path",attrs:{fill:"currentColor",d:"M3.0917 8.72168C2.20804 8.72168 1.4917 9.43802 1.4917 10.3217V12.9217C1.4917 13.8053 2.20804 14.5217 3.0917 14.5217H5.6917C6.57535 14.5217 7.2917 13.8053 7.2917 12.9217V10.3217C7.2917 9.43802 6.57536 8.72168 5.6917 8.72168H3.0917ZM2.6917 10.3217C2.6917 10.1008 2.87078 9.92168 3.0917 9.92168H5.6917C5.91261 9.92168 6.0917 10.1008 6.0917 10.3217V12.9217C6.0917 13.1426 5.91261 13.3217 5.6917 13.3217H3.0917C2.87079 13.3217 2.6917 13.1426 2.6917 12.9217V10.3217Z",fillRule:"evenodd",clipRule:"evenodd"}}]},jt=T.forwardRef(function(i,n){return T.createElement(pe,Object.assign({},i,{id:"data-validation-single",ref:n,icon:ka}))});jt.displayName="DataValidationSingle";var Ya={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M5.3313 1.4667C5.3313 1.13533 5.59993.866699 5.9313.866699H10.069C10.4004.866699 10.669 1.13533 10.669 1.4667 10.669 1.79807 10.4004 2.0667 10.069 2.0667H5.9313C5.59993 2.0667 5.3313 1.79807 5.3313 1.4667zM1.09985 3.64443C1.09985 3.31306 1.36848 3.04443 1.69985 3.04443H14.2999C14.6312 3.04443 14.8999 3.31306 14.8999 3.64443 14.8999 3.9758 14.6312 4.24443 14.2999 4.24443H1.69985C1.36848 4.24443 1.09985 3.9758 1.09985 3.64443zM6.12398 8.30171C6.35829 8.0674 6.73819 8.0674 6.97251 8.30171L8.00007 9.32928 9.02764 8.30171C9.26195 8.0674 9.64185 8.0674 9.87617 8.30171 10.1105 8.53603 10.1105 8.91593 9.87617 9.15024L8.8486 10.1778 9.87617 11.2054C10.1105 11.4397 10.1105 11.8196 9.87617 12.0539 9.64185 12.2882 9.26195 12.2882 9.02764 12.0539L8.00007 11.0263 6.97251 12.0539C6.73819 12.2882 6.35829 12.2882 6.12398 12.0539 5.88966 11.8196 5.88966 11.4397 6.12398 11.2054L7.15154 10.1778 6.12398 9.15024C5.88966 8.91593 5.88966 8.53603 6.12398 8.30171z"}},{tag:"path",attrs:{fill:"currentColor",d:"M4.75332 5.22217C3.86966 5.22217 3.15332 5.93851 3.15332 6.82217V12.5331C3.15332 13.9691 4.31738 15.1332 5.75332 15.1332H10.2465C11.6825 15.1332 12.8465 13.9691 12.8465 12.5331V6.82217C12.8465 5.93851 12.1302 5.22217 11.2465 5.22217H4.75332ZM4.35332 6.82217C4.35332 6.60125 4.53241 6.42217 4.75332 6.42217H11.2465C11.4674 6.42217 11.6465 6.60125 11.6465 6.82217V12.5331C11.6465 13.3063 11.0197 13.9332 10.2465 13.9332H5.75332C4.98012 13.9332 4.35332 13.3063 4.35332 12.5331V6.82217Z",fillRule:"evenodd",clipRule:"evenodd"}}]},st=T.forwardRef(function(i,n){return T.createElement(pe,Object.assign({},i,{id:"delete-single",ref:n,icon:Ya}))});st.displayName="DeleteSingle";var qa={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"}}]},Ut=T.forwardRef(function(i,n){return T.createElement(pe,Object.assign({},i,{id:"increase-single",ref:n,icon:qa}))});Ut.displayName="IncreaseSingle";var Xa={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M11.3536 6.14645C11.5488 6.34171 11.5488 6.65829 11.3536 6.85355L8.35355 9.85355C8.15829 10.0488 7.84171 10.0488 7.64645 9.85355L4.64645 6.85355C4.45118 6.65829 4.45118 6.34171 4.64645 6.14645C4.84171 5.95118 5.15829 5.95118 5.35355 6.14645L8 8.79289L10.6464 6.14645C10.8417 5.95118 11.1583 5.95118 11.3536 6.14645Z",fillRule:"evenodd",clipRule:"evenodd"}}]},Bt=T.forwardRef(function(i,n){return T.createElement(pe,Object.assign({},i,{id:"more-down-single",ref:n,icon:Xa}))});Bt.displayName="MoreDownSingle";var Ga={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"}}]},$t=T.forwardRef(function(i,n){return T.createElement(pe,Object.assign({},i,{id:"more-up-single",ref:n,icon:Ga}))});$t.displayName="MoreUpSingle";var za={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"}}]}]},Wt=T.forwardRef(function(i,n){return T.createElement(pe,Object.assign({},i,{id:"sequence-single",ref:n,icon:za}))});Wt.displayName="SequenceSingle";function Ht(i){return i.filter(Boolean).join(",")}function ye(i){return i.split(",").filter(Boolean)}function Ka(i){const n=te(i);return n==null?"":n.toString()}const Fe="SHEET_DATA_VALIDATION_PLUGIN",De="#ECECEC";var Ye=(i=>(i[i.View=0]="View",i[i.Edit=1]="Edit",i[i.ManageCollaborator=2]="ManageCollaborator",i[i.Print=3]="Print",i[i.Duplicate=4]="Duplicate",i[i.Comment=5]="Comment",i[i.Copy=6]="Copy",i[i.Share=7]="Share",i[i.Export=8]="Export",i[i.MoveWorksheet=9]="MoveWorksheet",i[i.DeleteWorksheet=10]="DeleteWorksheet",i[i.HideWorksheet=11]="HideWorksheet",i[i.RenameWorksheet=12]="RenameWorksheet",i[i.CreateWorksheet=13]="CreateWorksheet",i[i.SetWorksheetStyle=14]="SetWorksheetStyle",i[i.EditWorksheetCell=15]="EditWorksheetCell",i[i.InsertHyperlink=16]="InsertHyperlink",i[i.Sort=17]="Sort",i[i.Filter=18]="Filter",i[i.PivotTable=19]="PivotTable",i[i.FloatImg=20]="FloatImg",i[i.History=21]="History",i[i.RwHgtClWdt=22]="RwHgtClWdt",i[i.ViemRwHgtClWdt=23]="ViemRwHgtClWdt",i[i.ViewFilter=24]="ViewFilter",i[i.MoveSheet=25]="MoveSheet",i[i.DeleteSheet=26]="DeleteSheet",i[i.HideSheet=27]="HideSheet",i[i.CopySheet=28]="CopySheet",i[i.RenameSheet=29]="RenameSheet",i[i.CreateSheet=30]="CreateSheet",i[i.SelectProtectedCells=31]="SelectProtectedCells",i[i.SelectUnProtectedCells=32]="SelectUnProtectedCells",i[i.SetCellStyle=33]="SetCellStyle",i[i.SetCellValue=34]="SetCellValue",i[i.SetRowStyle=35]="SetRowStyle",i[i.SetColumnStyle=36]="SetColumnStyle",i[i.InsertRow=37]="InsertRow",i[i.InsertColumn=38]="InsertColumn",i[i.DeleteRow=39]="DeleteRow",i[i.DeleteColumn=40]="DeleteColumn",i[i.EditExtraObject=41]="EditExtraObject",i[i.Delete=42]="Delete",i[i.UNRECOGNIZED=-1]="UNRECOGNIZED",i))(Ye||{}),Qa=Object.defineProperty,Za=Object.getOwnPropertyDescriptor,Ja=(i,n,e,t)=>{for(var a=t>1?void 0:t?Za(n,e):n,r=i.length-1,o;r>=0;r--)(o=i[r])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&Qa(n,e,a),a},lt=(i,n)=>(e,t)=>n(e,t,i);g.DataValidationFormulaController=class extends s.Disposable{constructor(n,e,t){super(),this._univerInstanceService=n,this._permissionService=e,this._lexerTreeBuilder=t}getFormulaRefCheck(n){var t,a;const e=this._lexerTreeBuilder.sequenceNodesBuilder(n);if(!e)return!0;for(let r=0;r<e.length;r++){const o=e[r];if(typeof o=="string")continue;const{token:l}=o,d=re.deserializeRangeWithSheet(l),u=this._univerInstanceService.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET);let c=u.getActiveSheet();const m=u.getUnitId();if(d.sheetName){if(c=u.getSheetBySheetName(d.sheetName),!c)return!1;const I=c==null?void 0:c.getSheetId();if(!this._permissionService.getPermissionPoint(new j.WorksheetViewPermission(m,I).id))return!1}if(!c)return!1;const{startRow:h,endRow:p,startColumn:v,endColumn:f}=d.range;for(let I=h;I<=p;I++)for(let _=v;_<=f;_++){const C=(a=(t=c.getCell(I,_))==null?void 0:t.selectionProtection)==null?void 0:a[0];if((C==null?void 0:C[Ye.View])===!1)return!1}}return!0}},g.DataValidationFormulaController=Ja([s.OnLifecycle(s.LifecycleStages.Rendered,g.DataValidationFormulaController),lt(0,s.IUniverInstanceService),lt(1,s.IPermissionService),lt(2,y.Inject(re.LexerTreeBuilder))],g.DataValidationFormulaController);const en=["#FFFFFF","#FEE7E7","#FEF0E6","#EFFBD0","#E4F4FE","#E8ECFD","#F1EAFA","#FDE8F3","#E5E5E5","#FDCECE","#FDC49B","#DEF6A2","#9FDAFF","#D0D9FB","#E3D5F6","#FBD0E8","#656565","#FE4B4B","#FF8C51","#8BBB11","#0B9EFB","#3A60F7","#9E6DE3","#F248A6"],tn=i=>{const{value:n,onChange:e,disabled:t}=i,[a,r]=T.useState(!1);return S.jsx(E.Select,{disabled:t,open:a,onDropdownVisibleChange:r,dropdownStyle:{width:112},className:ie.dataValidationFormulaColorSelect,value:n,onChange:e,labelRender:o=>S.jsx("div",{className:ie.dataValidationFormulaColorItem,style:{background:o.value,marginTop:5}}),dropdownRender:()=>S.jsx("div",{className:ie.dataValidationFormulaColorSelectPanel,children:en.map(o=>S.jsx("div",{onClick:()=>{e(o),r(!1)},className:ie.dataValidationFormulaColorItem,style:{background:o}},o))})})},xt=i=>{const{item:n,commonProps:e,style:t}=i,{onItemChange:a,onItemDelete:r}=e;return S.jsxs("div",{className:ie.dataValidationFormulaListItem,style:t,children:[n.isRef?null:S.jsx("div",{className:ga(ie.dataValidationFormulaListItemDrag,"draggableHandle"),children:S.jsx(Wt,{})}),S.jsx(tn,{value:n.color,onChange:o=>{a(n.id,n.label,o)}}),S.jsx(E.Input,{disabled:n.isRef,value:n.label,onChange:o=>{a(n.id,o,n.color)}}),n.isRef?null:S.jsx("div",{className:ie.dataValidationFormulaListItemIcon,children:S.jsx(st,{onClick:()=>r(n.id)})})]})};function an(i){const{value:n,onChange:e=()=>{},unitId:t,subUnitId:a,validResult:r,showError:o,ruleId:l}=i,{formula1:d="",formula2:u=""}=n||{},c=T.useRef(null),[m,h]=T.useState(()=>s.isFormulaString(d)?"1":"0"),[p,v]=T.useState(m==="1"?d:"="),[f,I]=T.useState(m==="1"?d:"="),_=x.useDependency(s.LocaleService),C=x.useDependency(D.DataValidatorRegistryService),R=x.useDependency(D.DataValidationModel),M=x.useDependency(g.DataValidationFormulaController),[O,F]=T.useState(()=>u.split(",")),B=C.getValidatorItem(s.DataValidationType.LIST),[$,k]=T.useState([]),[A,b]=T.useState(""),H=o?r==null?void 0:r.formula1:"",Y=X.useObservable(R.ruleChange$),P=X.useEvent(e);T.useEffect(()=>{(async()=>{await new Promise(K=>{setTimeout(()=>K(!0),100)});const L=R.getRuleById(t,a,l),z=L==null?void 0:L.formula1;if(s.isFormulaString(z)&&B&&L){const K=await B.getListAsync(L,t,a);k(K)}})()},[R,Y,B,l,a,t]),T.useEffect(()=>{s.isFormulaString(d)&&d!==f&&(v(d),I(f))},[f,d]);const[N,q]=T.useState(()=>{const L=m!=="1"?ye(d):[],z=u.split(",");return L.map((K,ne)=>({label:K,color:z[ne]||De,isRef:!1,id:s.Tools.generateRandomId(4)}))}),ee=(L,z,K)=>{const ne=N.find(me=>me.id===L);ne&&(ne.label=z,ne.color=K,q([...N]))},G=L=>{const z=N.findIndex(K=>K.id===L);z!==-1&&(N.splice(z,1),q([...N]))},w=u.split(","),W=T.useMemo(()=>$.map((L,z)=>({label:L,color:w[z]||De,id:`${z}`,isRef:!0})),[w,$]),ae=(L,z,K)=>{const ne=[...O];ne[+L]=K,F(ne),P({formula1:d,formula2:ne.join(",")})},Z=()=>{q([...N,{label:"",color:De,isRef:!1,id:s.Tools.generateRandomId(4)}])};T.useEffect(()=>{if(m==="1")return;const L=new Set,z=[];N.map(K=>({labelList:K.label.split(","),item:K})).forEach(({item:K,labelList:ne})=>{ne.forEach(me=>{L.has(me)||(L.add(me),z.push({label:me,color:K.color}))})}),P({formula1:Ht(z.map(K=>K.label)),formula2:z.map(K=>K.color===De?"":K.color).join(",")})},[N,P,m,f,O]);const de=T.useMemo(()=>async L=>{if(!s.isFormulaString(L)){P==null||P({formula1:"",formula2:u});return}M.getFormulaRefCheck(L)?(P==null||P({formula1:s.isFormulaString(L)?L:"",formula2:u}),b("")):(P==null||P({formula1:"",formula2:u}),v("="),b(_.t("dataValidation.validFail.formulaError")))},[u,P]);return S.jsxs(S.Fragment,{children:[S.jsx(E.FormLayout,{label:_.t("dataValidation.list.options"),children:S.jsxs(E.RadioGroup,{value:m,onChange:L=>{h(L),v(f),L==="1"&&P({formula1:f==="="?"":f,formula2:O.join(",")})},children:[S.jsx(E.Radio,{value:"0",children:_.t("dataValidation.list.customOptions")}),S.jsx(E.Radio,{value:"1",children:_.t("dataValidation.list.refOptions")})]})}),m==="1"?S.jsxs(S.Fragment,{children:[S.jsx(E.FormLayout,{error:H||A,children:S.jsx(X.TextEditor,{id:s.createInternalEditorID(`list-ref-range-${t}-${a}`),value:p,openForSheetUnitId:t,openForSheetSubUnitId:a,onlyInputFormula:!0,onChange:async L=>{const z=L!=null?L:"";I(z),de(z)}})}),S.jsx(E.FormLayout,{children:S.jsx("div",{ref:c,children:W.map(L=>S.jsx(xt,{item:L,commonProps:{onItemChange:ae},style:{marginBottom:12}},L.id))})})]}):S.jsx(E.FormLayout,{error:H,children:S.jsxs("div",{ref:c,style:{marginTop:"-12px"},children:[S.jsx(E.DraggableList,{list:N,onListChange:q,rowHeight:32,margin:[0,12],draggableHandle:".draggableHandle",itemRender:L=>S.jsx(xt,{item:L,commonProps:{onItemChange:ee,onItemDelete:G}},L.id),idKey:"id"}),S.jsxs("a",{className:ie.dataValidationFormulaListAdd,onClick:Z,children:[S.jsx(Ut,{}),_.t("dataValidation.list.add")]})]})})]})}function nn(i){const{value:n,onChange:e,showError:t,validResult:a}=i,r=x.useDependency(s.LocaleService),o=t?a==null?void 0:a.formula1:"",l=t?a==null?void 0:a.formula2:"",[d,u]=T.useState(!((n==null?void 0:n.formula1)===void 0&&(n==null?void 0:n.formula2)===void 0));return S.jsxs(S.Fragment,{children:[S.jsx(E.FormLayout,{children:S.jsx(E.Checkbox,{checked:d,onChange:c=>{c?u(!0):(u(!1),e==null||e({...n,formula1:void 0,formula2:void 0}))},children:r.t("dataValidation.checkbox.tips")})}),d?S.jsx(E.FormLayout,{label:r.t("dataValidation.checkbox.checked"),error:o,children:S.jsx(E.Input,{className:ie.dataValidationFormula,placeholder:r.t("dataValidation.panel.valuePlaceholder"),value:n==null?void 0:n.formula1,onChange:c=>{e==null||e({...n,formula1:c||void 0})}})}):null,d?S.jsx(E.FormLayout,{label:r.t("dataValidation.checkbox.unchecked"),error:l,children:S.jsx(E.Input,{className:ie.dataValidationFormula,placeholder:r.t("dataValidation.panel.valuePlaceholder"),value:n==null?void 0:n.formula2,onChange:c=>{e==null||e({...n,formula2:c||void 0})}})}):null]})}const kt="data-validation.custom-formula-input",be="data-validation.formula-input",Yt="data-validation.list-formula-input",qt="data-validation.checkbox-formula-input",rn=[[kt,ja],[be,Ua],[Yt,an],[qt,nn]],Le=1,Ne=0;function Xt(i,n){return s.Tools.isBlank(i)?n.t("dataValidation.validFail.value"):s.isFormulaString(i)?n.t("dataValidation.validFail.primitive"):""}class on extends D.BaseDataValidator{constructor(){super(...arguments);V(this,"id",s.DataValidationType.CHECKBOX);V(this,"title","dataValidation.checkbox.title");V(this,"operators",[]);V(this,"scopes",["sheet"]);V(this,"formulaInput",qt);V(this,"canvasRender",this.injector.createInstance(ot));V(this,"_formulaService",this.injector.get(g.DataValidationFormulaService))}skipDefaultFontRender(e,t,a){const{formula1:r,formula2:o}=this.parseFormulaSync(e,a.unitId,a.subUnitId),l=`${t!=null?t:""}`;return!l||l===`${r}`||l===`${o}`}validatorFormula(e,t,a){const{formula1:r,formula2:o}=e,l=r===o;if(s.Tools.isBlank(r)&&s.Tools.isBlank(o))return{success:!0};if(l)return{success:!1,formula1:this.localeService.t("dataValidation.validFail.checkboxEqual"),formula2:this.localeService.t("dataValidation.validFail.checkboxEqual")};const d=Xt(r,this.localeService),u=Xt(o,this.localeService);return{success:!d&&!u,formula1:d,formula2:u}}async parseFormula(e,t,a){var d,u;const{formula1:r=Le,formula2:o=Ne}=e,l=await this._formulaService.getRuleFormulaResult(t,a,e.uid);return{formula1:s.isFormulaString(r)?ue((d=l==null?void 0:l[0])==null?void 0:d.result):r,formula2:s.isFormulaString(o)?ue((u=l==null?void 0:l[1])==null?void 0:u.result):o}}parseFormulaSync(e,t,a){var d,u;const{formula1:r=Le,formula2:o=Ne}=e,l=this._formulaService.getRuleFormulaResultSync(t,a,e.uid);return{formula1:s.isFormulaString(r)?ue((d=l==null?void 0:l[0])==null?void 0:d.result):r,formula2:s.isFormulaString(o)?ue((u=l==null?void 0:l[1])==null?void 0:u.result):o}}async isValidType(e,t,a){const{value:r,unitId:o,subUnitId:l}=e,{formula1:d,formula2:u}=await this.parseFormula(a,o,l);return!s.Tools.isDefine(d)||!s.Tools.isDefine(u)?!0:s.Tools.isDefine(r)&&(String(r)===String(d)||String(r)===String(u))}generateRuleErrorMessage(e){return this.localeService.t("dataValidation.checkbox.error")}}const Pe=[s.DataValidationOperator.BETWEEN,s.DataValidationOperator.NOT_BETWEEN],dt=86400;function sn(i,n=!0){if(n&&i>=0){if(i===0)return[1900,1,0];if(i===60)return[1900,2,29];if(i<60)return[1900,i<32?1:2,(i-1)%31+1]}let e=i+68569+2415019;const t=Math.floor(4*e/146097);e=e-Math.floor((146097*t+3)/4);const a=Math.floor(4e3*(e+1)/1461001);e=e-Math.floor(1461*a/4)+31;const r=Math.floor(80*e/2447),o=e-Math.floor(2447*r/80);e=Math.floor(r/11);const l=r+2-12*e;return[100*(t-49)+a+e|0,l|0,o|0]}const ln=i=>{let n=i|0;const e=dt*(i-n);let t=Math.floor(e);e-t>.9999&&(t+=1,t===dt&&(t=0,n+=1));const a=t<0?dt+t:t,[r,o,l]=sn(i,!0),d=Math.floor(a/60/60)%60,u=Math.floor(a/60)%60,c=Math.floor(a)%60,m=new Date(0);return m.setUTCFullYear(r,o-1,l),m.setUTCHours(d,u,c),m.getTime()},dn={[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 un={[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"},cn={[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"},Gt="{FORMULA1}",zt="{FORMULA2}",Kt=i=>Se(i).isValid(),qe=i=>{if(!(i==null||typeof i=="boolean"))return typeof i=="number"||!Number.isNaN(+i)?Se(ln(+i)):Se(i)};class mn extends D.BaseDataValidator{constructor(){super(...arguments);V(this,"id",s.DataValidationType.DATE);V(this,"title","dataValidation.date.title");V(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]);V(this,"scopes",["sheet"]);V(this,"formulaInput",be);V(this,"dropdown",ia);V(this,"_formulaService",this.injector.get(g.DataValidationFormulaService));V(this,"transformDate",qe)}async parseFormula(e,t,a){var d,u;const r=await this._formulaService.getRuleFormulaResult(t,a,e.uid),{formula1:o,formula2:l}=e;return{formula1:qe(s.isFormulaString(o)?ue((d=r==null?void 0:r[0])==null?void 0:d.result):o),formula2:qe(s.isFormulaString(l)?ue((u=r==null?void 0:r[1])==null?void 0:u.result):l)}}async isValidType(e){const{value:t}=e;return typeof t=="string"?Se(t).isValid():typeof t=="number"}_validatorSingleFormula(e){return!s.Tools.isBlank(e)&&(s.isFormulaString(e)||!Number.isNaN(+e)||!!e&&Se(e).isValid())}validatorFormula(e,t,a){const r=e.operator;if(!r)return{success:!1};const o=this._validatorSingleFormula(e.formula1),l=this.localeService.t("dataValidation.validFail.date");if(Pe.includes(r)){const u=this._validatorSingleFormula(e.formula2);return{success:o&&u,formula1:o?void 0:l,formula2:u?void 0:l}}return{success:o,formula1:o?void 0:l}}transform(e,t,a){const{value:r}=e;return{...e,value:qe(r)}}async validatorIsEqual(e,t,a){const{value:r}=e,{formula1:o}=t;return o?r.isSame(o):!0}async validatorIsNotEqual(e,t){const{value:a}=e,{formula1:r}=t;return r?!a.isSame(r):!0}async validatorIsBetween(e,t){const{value:a}=e,{formula1:r,formula2:o}=t;if(!r||!o)return!1;const l=r.isAfter(o)?o:r,d=l===r?o:r;return(a.isAfter(l)||a.isSame(l))&&(a.isBefore(d)||a.isSame(d))}async validatorIsNotBetween(e,t){const{value:a}=e,{formula1:r,formula2:o}=t;if(!r||!o)return!1;const l=r.isAfter(o)?o:r,d=l===r?o:r;return a.isBefore(l)||a.isAfter(d)}async validatorIsGreaterThan(e,t){const{value:a}=e,{formula1:r}=t;return r?a.isAfter(r):!0}async validatorIsGreaterThanOrEqual(e,t){const{value:a}=e,{formula1:r}=t;return r?a.isAfter(r)||a.isSame(r):!0}async validatorIsLessThan(e,t){const{value:a}=e,{formula1:r}=t;return r?a.isBefore(r)||a.isSame(r):!0}async validatorIsLessThanOrEqual(e,t){const{value:a}=e,{formula1:r}=t;return r?a.isBefore(r)||a.isSame(r):!0}validatorFormulaValue(e){if(!s.Tools.isDefine(e.operator))return;if(Pe.includes(e.operator)){if(s.Tools.isBlank(e.formula1)||s.Tools.isBlank(e.formula2))return"";if(!Kt(e.formula1)||!Kt(e.formula2))return""}else if(s.Tools.isBlank(e.formula1))return""}get operatorNames(){return this.operators.map(e=>this.localeService.t(dn[e]))}generateRuleName(e){var a,r;if(!e.operator)return this.titleStr;const t=this.localeService.t(un[e.operator]).replace(Gt,(a=e.formula1)!=null?a:"").replace(zt,(r=e.formula2)!=null?r:"");return`${this.titleStr} ${t}`}generateRuleErrorMessage(e){var a,r;return e.operator?`${this.localeService.t(cn[e.operator]).replace(Gt,(a=e.formula1)!=null?a:"").replace(zt,(r=e.formula2)!=null?r:"")}`:this.titleStr}}var hn=Object.defineProperty,pn=Object.getOwnPropertyDescriptor,fn=(i,n,e,t)=>{for(var a=t>1?void 0:t?pn(n,e):n,r=i.length-1,o;r>=0;r--)(o=i[r])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&hn(n,e,a),a},Qt=(i,n)=>(e,t)=>n(e,t,i);const Me=4,vn=6,le=14,Re=6,fe=4,gn="#565656",Zt=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 Sn(i,n){const e=i.length;return{id:"d",body:{dataStream:`${i}${s.DEFAULT_EMPTY_DOCUMENT_VALUE}`,textRuns:[{ts:{fs:11,ff:void 0,it:s.BooleanNumber.FALSE,bl:s.BooleanNumber.FALSE,ul:{s:s.BooleanNumber.FALSE},st:{s:s.BooleanNumber.FALSE},ol:{s:s.BooleanNumber.FALSE},cl:void 0,...n,bg:void 0,bd:void 0},st:0,ed:e}]},documentStyle:{pageSize:{width:Number.POSITIVE_INFINITY,height:Number.POSITIVE_INFINITY}}}}function Jt(i,n,e){const t=Sn(i,e),a=new s.DocumentDataModel(t),r=new Q.DocumentViewModel(a);return{documentSkeleton:Q.DocumentSkeleton.create(r,n),docModel:a,docViewModel:r}}function ut(i,n,e){const{documentSkeleton:t,docModel:a,docViewModel:r}=Jt(i,n,e);return{documents:new Q.Documents(`DOCUMENTS_${s.Tools.generateRandomId()}`,t,{pageMarginLeft:0,pageMarginTop:0}),documentSkeleton:t,docModel:a,docViewModel:r}}function ea(i,n,e,t,a,r){let o=0;switch(a){case s.VerticalAlign.BOTTOM:o=n-fe*2-t+fe;break;case s.VerticalAlign.MIDDLE:o=(n-fe*2-t)/2+fe;break;default:o=fe;break}let l=0;switch(r){case s.HorizontalAlign.CENTER:l=(i-e)/2;break;case s.HorizontalAlign.RIGHT:l=i-e;break}return{paddingLeft:l,paddingTop:o}}let ct=(Ot=class{constructor(i,n){V(this,"_dropdownInfoMap",new Map);V(this,"zIndex");V(this,"onPointerEnter");V(this,"onPointerLeave");this._localeService=i,this._commandService=n}_ensureMap(i){let n=this._dropdownInfoMap.get(i);return n||(n=new Map,this._dropdownInfoMap.set(i,n)),n}_generateKey(i,n){return`${i}.${n}`}_drawDownIcon(i,n,e,t,a){const r=e-le+4;let o=9;switch(a){case s.VerticalAlign.MIDDLE:o=(t-le)/2+4;break;case s.VerticalAlign.BOTTOM:o=t-le-1;break}i.save(),i.translateWithPrecision(n.startX+r,n.startY+o),i.fillStyle="#565656",i.fill(Zt),i.restore()}drawWith(i,n,e){var Y,P;const{primaryWithCoord:t,row:a,col:r,style:o,data:l,subUnitId:d}=n,u=t.isMergedMainCell?t.mergeInfo:t,c=(Y=l.dataValidation)==null?void 0:Y.rule,m=(P=l.dataValidation)==null?void 0:P.validator,h=l.fontRenderExtension,{leftOffset:p=0,rightOffset:v=0,topOffset:f=0,downOffset:I=0}=h||{};if(!c||!m||!m.skipDefaultFontRender(c))return;const _={startX:u.startX+p,endX:u.endX-v,startY:u.startY+f,endY:u.endY-I},C=_.endX-_.startX,R=_.endY-_.startY,M=this._ensureMap(d),O=this._generateKey(a,r),F=m.getListWithColor(c),B=te(l),$=`${B!=null?B:""}`,k=F.find(N=>N.label===$);let{tb:A,vt:b,ht:H}=o||{};if(A=A!=null?A:s.WrapStrategy.WRAP,b=b!=null?b:s.VerticalAlign.BOTTOM,H=H!=null?H:s.HorizontalAlign.LEFT,c.renderMode===s.DataValidationRenderMode.ARROW){this._drawDownIcon(i,_,C,R,b),i.save(),i.translateWithPrecision(_.startX,_.startY),i.beginPath(),i.rect(0,0,C,R),i.clip();const N=C-le,{documentSkeleton:q,documents:ee,docModel:G}=ut($,this._localeService,o);A===s.WrapStrategy.WRAP&&G.updateDocumentDataPageSize(Math.max(N,1)),q.calculate(),q.getActualSize();const w=Q.getDocsSkeletonPageSize(q),{height:W,width:ae}=w,{paddingTop:Z,paddingLeft:de}=ea(N,R,ae,W,b,H);i.translate(0,Z),i.save(),i.translateWithPrecision(Me,0),i.beginPath(),i.rect(0,0,N,W),i.clip(),ee.render(i),i.translateWithPrecision(de,0),i.restore(),i.restore(),M.set(O,{left:_.endX+e.rowHeaderWidth-le,top:_.startY+e.columnHeaderHeight,width:le,height:R})}else{i.save(),i.translateWithPrecision(_.startX,_.startY),i.beginPath(),i.rect(0,0,C,R),i.clip();const N=C-Re*2-Me-le,{documentSkeleton:q,documents:ee,docModel:G}=ut($,this._localeService,o);A===s.WrapStrategy.WRAP&&G.updateDocumentDataPageSize(Math.max(N,1)),q.calculate();const w=Q.getDocsSkeletonPageSize(q),{height:W,width:ae}=w,{paddingTop:Z,paddingLeft:de}=ea(N,R,ae,W,b,H);i.translate(Re,Z);const L=Math.max(C-Re*2,1),z=W;Q.Rect.drawWith(i,{width:L,height:z,fill:(k==null?void 0:k.color)||De,radius:8}),i.save(),i.translateWithPrecision(Me,0),i.beginPath(),i.rect(0,0,N,W),i.clip(),i.translateWithPrecision(de,0),ee.render(i),i.restore(),i.translate(N+Me+4,(W-vn)/2),i.fillStyle=gn,i.fill(Zt),i.restore(),M.set(O,{left:_.startX+Re+e.rowHeaderWidth,top:_.startY+Z+e.columnHeaderHeight,width:L,height:z})}}calcCellAutoHeight(i){var I;const{primaryWithCoord:n,style:e,data:t}=i,a=n.isMergedMainCell?n.mergeInfo:n,r=t.fontRenderExtension,{leftOffset:o=0,rightOffset:l=0,topOffset:d=0,downOffset:u=0}=r||{},c=(I=t.dataValidation)==null?void 0:I.rule;if(!c||c.renderMode===s.DataValidationRenderMode.TEXT)return;const m={startX:a.startX+o,endX:a.endX-l,startY:a.startY+d,endY:a.endY-u},h=m.endX-m.startX,p=te(t),v=`${p!=null?p:""}`;let{tb:f}=e||{};if(f=f!=null?f:s.WrapStrategy.WRAP,c.renderMode===s.DataValidationRenderMode.ARROW){const _=h-le,{documentSkeleton:C,docModel:R}=ut(v,this._localeService,e);f===s.WrapStrategy.WRAP&&R.updateDocumentDataPageSize(Math.max(_,1)),C.calculate(),C.getActualSize();const M=Q.getDocsSkeletonPageSize(C),{height:O}=M;return O}else{const _=h-Re*2-Me-le,{documentSkeleton:C,docModel:R}=Jt(v,this._localeService,e);f===s.WrapStrategy.WRAP&&R.updateDocumentDataPageSize(Math.max(_,1)),C.calculate();const M=Q.getDocsSkeletonPageSize(C),{height:O}=M;return O+fe*2}}isHit(i,n){const{data:e,subUnitId:t,row:a,col:r}=n,l=this._ensureMap(t).get(this._generateKey(a,r)),d=e.dataValidation;if(!d||!l||d.rule.renderMode===s.DataValidationRenderMode.TEXT)return!1;const{top:u,left:c,width:m,height:h}=l,{x:p,y:v}=i;return p>=c&&p<=c+m&&v>=u&&v<=u+h}onPointerDown(i,n){if(n.button===2)return;const{unitId:e,subUnitId:t,row:a,col:r}=i,o={unitId:e,subUnitId:t,row:a,column:r};this._commandService.executeCommand(Ee.id,o)}},V(Ot,"padding",{l:Re+Me,r:le+Re,t:fe,b:fe}),Ot);ct=fn([Qt(0,y.Inject(s.LocaleService)),Qt(1,s.ICommandService)],ct);const _n="LIST_RENDER_MODE_OPTION_INPUT";function Xe(i){var a;const{value:n,onChange:e}=i,t=x.useDependency(s.LocaleService);return S.jsx(E.FormLayout,{label:t.t("dataValidation.renderMode.label"),children:S.jsxs(E.RadioGroup,{value:`${(a=n.renderMode)!=null?a:s.DataValidationRenderMode.CUSTOM}`,onChange:r=>e({...n,renderMode:+r}),children:[S.jsx(E.Radio,{value:`${s.DataValidationRenderMode.CUSTOM}`,children:t.t("dataValidation.renderMode.chip")}),S.jsx(E.Radio,{value:`${s.DataValidationRenderMode.ARROW}`,children:t.t("dataValidation.renderMode.arrow")}),S.jsx(E.Radio,{value:`${s.DataValidationRenderMode.TEXT}`,children:t.t("dataValidation.renderMode.text")})]})})}Xe.componentKey=_n;function mt(i){if(!i)return[];const n=new Set;return i.forEach(e=>{e.forEach(t=>{const a=te(t);a!=null&&n.add(a.toString())})}),[...n]}const Vn=["if","indirect","choose","offset"];function Dn(i,n){if(!s.isFormulaString(i)||re.isReferenceString(i.slice(1)))return!0;const t=n.sequenceNodesBuilder(i);return t&&t.some(a=>typeof a=="object"&&a.nodeType===re.sequenceNodeType.FUNCTION&&Vn.indexOf(a.token.toLowerCase())>-1)}function Rn(i,n){const{formula1:e="",ranges:t}=i;if(re.isReferenceString(e.slice(1))){const r=re.deserializeRangeWithSheet(e.slice(1));if((!r.sheetName||r.sheetName===n)&&t.some(o=>s.Rectangle.intersects(o,r.range)))return!0}return!1}class ta extends D.BaseDataValidator{constructor(){super(...arguments);V(this,"formulaService",this.injector.get(g.DataValidationFormulaService));V(this,"_lexer",this.injector.get(re.LexerTreeBuilder));V(this,"_univerInstanceService",this.injector.get(s.IUniverInstanceService));V(this,"id",s.DataValidationType.LIST);V(this,"title","dataValidation.list.title");V(this,"operators",[]);V(this,"scopes",["sheet"]);V(this,"formulaInput",Yt);V(this,"canvasRender",this.injector.createInstance(ct));V(this,"dropdown",ra);V(this,"optionsInput",Xe.componentKey)}skipDefaultFontRender(e){return e.renderMode!==s.DataValidationRenderMode.TEXT}validatorFormula(e,t,a){var u,c,m;const r=!s.Tools.isBlank(e.formula1),o=Dn((u=e.formula1)!=null?u:"",this._lexer),l=(m=(c=this._univerInstanceService.getUnit(t,s.UniverInstanceType.UNIVER_SHEET))==null?void 0:c.getSheetBySheetId(a))==null?void 0:m.getName(),d=Rn(e,l!=null?l:"");return{success:!!(r&&o&&!d),formula1:r?o?d?this.localeService.t("dataValidation.validFail.listIntersects"):void 0:this.localeService.t("dataValidation.validFail.listInvalid"):this.localeService.t("dataValidation.validFail.list")}}parseCellValue(e){const t=e.toString();return ye(t)}async parseFormula(e,t,a){var l;const{formula1:r=""}=e,o=await this.formulaService.getRuleFormulaResult(t,a,e.uid);return{formula1:s.isFormulaString(r)?mt((l=o==null?void 0:o[0])==null?void 0:l.result):ye(r),formula2:void 0}}async isValidType(e,t,a){const{value:r}=e,{formula1:o=[]}=t;return this.parseCellValue(r).every(d=>o.includes(d))}generateRuleName(){return this.localeService.t("dataValidation.list.name")}generateRuleErrorMessage(){return this.localeService.t("dataValidation.list.error")}getList(e,t,a){var h,p,v;const{formula1:r=""}=e,o=this.injector.get(s.IUniverInstanceService),l=(h=t?o.getUniverSheetInstance(t):void 0)!=null?h:o.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 u=l.getUnitId(),c=d.getSheetId(),m=this.formulaService.getRuleFormulaResultSync(u,c,e.uid);return s.isFormulaString(r)?mt((v=m==null?void 0:m[0])==null?void 0:v.result):ye(r)}async getListAsync(e,t,a){var h,p,v;const{formula1:r=""}=e,o=this.injector.get(s.IUniverInstanceService),l=(h=t?o.getUniverSheetInstance(t):void 0)!=null?h:o.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 u=l.getUnitId(),c=d.getSheetId(),m=await this.formulaService.getRuleFormulaResult(u,c,e.uid);return s.isFormulaString(r)?mt((v=m==null?void 0:m[0])==null?void 0:v.result):ye(r)}getListWithColor(e,t,a){const r=this.getList(e,t,a),o=(e.formula2||"").split(",");return r.map((l,d)=>({label:l,color:o[d]}))}getListWithColorMap(e,t,a){const r=this.getListWithColor(e,t,a),o={};return r.forEach(l=>{l.color&&(o[l.label]=l.color)}),o}}function Ge(i){let n=i;return typeof i=="string"?((i.startsWith("¥")||i.startsWith("$"))&&(n=i.slice(1)),+n):+i}class In extends D.BaseDataValidator{constructor(){super(...arguments);V(this,"_formulaService",this.injector.get(g.DataValidationFormulaService));V(this,"id",s.DataValidationType.DECIMAL);V(this,"title","dataValidation.decimal.title");V(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]);V(this,"scopes",["sheet"]);V(this,"formulaInput",be);V(this,"dropDownInput")}_isFormulaOrNumber(e){return!s.Tools.isBlank(e)&&(s.isFormulaString(e)||!Number.isNaN(+e))}async isValidType(e,t,a){const{value:r}=e;return!Number.isNaN(Ge(r))}transform(e,t,a){const{value:r}=e;return{...e,value:Ge(r)}}_parseNumber(e){return e==null?Number.NaN:+e}async parseFormula(e,t,a){var u,c,m,h,p,v,f,I;const r=await this._formulaService.getRuleFormulaResult(t,a,e.uid),{formula1:o,formula2:l}=e;return{formula1:this._parseNumber(s.isFormulaString(o)?(h=(m=(c=(u=r==null?void 0:r[0])==null?void 0:u.result)==null?void 0:c[0])==null?void 0:m[0])==null?void 0:h.v:o),formula2:this._parseNumber(s.isFormulaString(l)?(I=(f=(v=(p=r==null?void 0:r[1])==null?void 0:p.result)==null?void 0:v[0])==null?void 0:f[0])==null?void 0:I.v:l)}}validatorFormula(e,t,a){const r=e.operator;if(!r)return{success:!1};const o=s.Tools.isDefine(e.formula1)&&this._isFormulaOrNumber(e.formula1),l=s.Tools.isDefine(e.formula2)&&this._isFormulaOrNumber(e.formula2),d=Pe.includes(r),u=this.localeService.t("dataValidation.validFail.number");return d?{success:o&&l,formula1:o?void 0:u,formula2:l?void 0:u}:{success:o,formula1:o?"":u}}async validatorIsEqual(e,t,a){const{formula1:r}=t,{value:o}=e;return Number.isNaN(r)?!0:o===r}async validatorIsNotEqual(e,t,a){const{formula1:r}=t;return Number.isNaN(r)?!0:e.value!==r}async validatorIsBetween(e,t,a){const{formula1:r,formula2:o}=t;if(Number.isNaN(r)||Number.isNaN(o))return!0;const l=Math.min(r,o),d=Math.max(r,o);return e.value>=l&&e.value<=d}async validatorIsNotBetween(e,t,a){const{formula1:r,formula2:o}=t;if(Number.isNaN(r)||Number.isNaN(o))return!0;const l=Math.min(r,o),d=Math.max(r,o);return e.value<l||e.value>d}async validatorIsGreaterThan(e,t,a){const{formula1:r}=t;return Number.isNaN(r)?!0:e.value>r}async validatorIsGreaterThanOrEqual(e,t,a){const{formula1:r}=t;return Number.isNaN(r)?!0:e.value>=r}async validatorIsLessThan(e,t,a){const{formula1:r}=t;return Number.isNaN(r)?!0:e.value<r}async validatorIsLessThanOrEqual(e,t,a){const{formula1:r}=t;return Number.isNaN(r)?!0:e.value<=r}}const Cn="{FORMULA1}",yn="{FORMULA2}";class Mn extends D.BaseDataValidator{constructor(){super(...arguments);V(this,"id",s.DataValidationType.TEXT_LENGTH);V(this,"title","dataValidation.textLength.title");V(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]);V(this,"scopes",["sheet"]);V(this,"formulaInput",be);V(this,"_formulaService",this.injector.get(g.DataValidationFormulaService))}_isFormulaOrInt(e){return!s.Tools.isBlank(e)&&(s.isFormulaString(e)||!Number.isNaN(+e)&&Number.isInteger(+e))}validatorFormula(e,t,a){const r=e.operator;if(!r)return{success:!1};const o=s.Tools.isDefine(e.formula1)&&this._isFormulaOrInt(e.formula1),l=s.Tools.isDefine(e.formula2)&&this._isFormulaOrInt(e.formula2),d=Pe.includes(r),u=this.localeService.t("dataValidation.validFail.number");return d?{success:o&&l,formula1:o?void 0:u,formula2:l?void 0:u}:{success:o,formula1:u}}_parseNumber(e){return e==null?Number.NaN:+e}_isValidFormula(e){return!Number.isNaN(e)}async parseFormula(e,t,a){var d,u,c,m,h,p,v,f;const r=await this._formulaService.getRuleFormulaResult(t,a,e.uid),{formula1:o,formula2:l}=e;return{formula1:this._parseNumber(s.isFormulaString(o)?(m=(c=(u=(d=r==null?void 0:r[0])==null?void 0:d.result)==null?void 0:u[0])==null?void 0:c[0])==null?void 0:m.v:o),formula2:this._parseNumber(s.isFormulaString(l)?(f=(v=(p=(h=r==null?void 0:r[1])==null?void 0:h.result)==null?void 0:p[0])==null?void 0:v[0])==null?void 0:f.v:l)}}transform(e,t,a){return{...e,value:e.value.toString().length}}async isValidType(e,t,a){const{value:r}=e;return typeof r=="string"||typeof r=="number"}async validatorIsEqual(e,t,a){const{formula1:r}=t;return s.Tools.isDefine(r)?e.value===r:!1}async validatorIsNotEqual(e,t,a){const{formula1:r}=t;return s.Tools.isDefine(r)?e.value!==r:!1}async validatorIsBetween(e,t,a){const{formula1:r,formula2:o}=t,{value:l}=e;if(!this._isValidFormula(r)||!this._isValidFormula(o))return!1;const d=Math.max(r,o),u=Math.min(r,o);return l>=u&&l<=d}async validatorIsNotBetween(e,t,a){const{formula1:r,formula2:o}=t,{value:l}=e;if(!this._isValidFormula(r)||!this._isValidFormula(o))return!1;const d=Math.max(r,o),u=Math.min(r,o);return l<u||l>d}async validatorIsGreaterThan(e,t,a){const{formula1:r}=t,{value:o}=e;return this._isValidFormula(r)?o>r:!1}async validatorIsGreaterThanOrEqual(e,t,a){const{formula1:r}=t,{value:o}=e;return this._isValidFormula(r)?o>=r:!1}async validatorIsLessThan(e,t,a){const{formula1:r}=t,{value:o}=e;return this._isValidFormula(r)?o<r:!1}async validatorIsLessThanOrEqual(e,t,a){const{formula1:r}=t,{value:o}=e;return this._isValidFormula(r)?o<=r:!1}generateRuleErrorMessage(e){var a,r;return e.operator?`${this.localeService.t(D.TextLengthErrorTitleMap[e.operator]).replace(Cn,(a=e.formula1)!=null?a:"").replace(yn,(r=e.formula2)!=null?r:"")}`:this.titleStr}}function aa(i){var e,t;return i?i.p?!((t=(e=i.p.body)==null?void 0:e.dataStream)!=null?t:"").slice(0,-2).trim():s.Tools.isBlank(i.v):!0}function we(i,n,e,t){const a=[],r=[],l=t.get(D.DataValidationModel).ensureManager(i,n),d=t.get(s.IUniverInstanceService),u=j.getSheetCommandTarget(d,{unitId:i,subUnitId:n});if(!u)return{redoMutations:a,undoMutations:r};const{worksheet:c}=u,m=new s.ObjectMatrix;function h(f,I){f.forEach(_=>{s.Range.foreach(_,(C,R)=>{const M=c.getCellRaw(C,R),O=Nt(M);(aa(M)||O===I)&&m.setValue(C,R,{v:I,p:null})})})}e.forEach(f=>{switch(f.type){case"delete":a.push({id:D.RemoveDataValidationMutation.id,params:{unitId:i,subUnitId:n,ruleId:f.rule.uid}}),r.unshift({id:D.AddDataValidationMutation.id,params:{unitId:i,subUnitId:n,rule:f.rule,index:f.index}});break;case"update":{a.push({id:D.UpdateDataValidationMutation.id,params:{unitId:i,subUnitId:n,ruleId:f.ruleId,payload:{type:D.UpdateRuleType.RANGE,payload:f.newRanges}}}),r.unshift({id:D.UpdateDataValidationMutation.id,params:{unitId:i,subUnitId:n,ruleId:f.ruleId,payload:{type:D.UpdateRuleType.RANGE,payload:f.oldRanges}}});const I=l.getRuleById(f.ruleId);if(I&&I.type===s.DataValidationType.CHECKBOX){const C=l.getValidator(s.DataValidationType.CHECKBOX).parseFormulaSync(I,i,n);h(f.newRanges,C.formula2)}break}case"add":{if(a.push({id:D.AddDataValidationMutation.id,params:{unitId:i,subUnitId:n,rule:f.rule}}),r.unshift({id:D.RemoveDataValidationMutation.id,params:{unitId:i,subUnitId:n,ruleId:f.rule.uid}}),f.rule.type===s.DataValidationType.CHECKBOX){const _=l.getValidator(s.DataValidationType.CHECKBOX).parseFormulaSync(f.rule,i,n);h(f.rule.ranges,_.formula2)}break}}});const p={id:j.SetRangeValuesMutation.id,params:{unitId:i,subUnitId:n,cellValue:m.getData()}},v={id:j.SetRangeValuesMutation.id,params:j.SetRangeValuesUndoMutationFactory(t,p.params)};return a.push(p),r.push(v),{redoMutations:a,undoMutations:r}}const Ae={type:s.CommandType.COMMAND,id:"sheet.command.updateDataValidationRuleRange",async handler(i,n){if(!n)return!1;const{unitId:e,subUnitId:t,ranges:a,ruleId:r}=n,o=i.get(D.DataValidationModel),l=i.get(s.ICommandService),d=i.get(s.IUndoRedoService),u=o.ensureManager(e,t),c=u.getRuleById(r);if(!c)return!1;const m=c.ranges,h=u.getRuleObjectMatrix().clone();h.updateRange(r,m,a);const p=h.diff(u.getDataValidations()),{redoMutations:v,undoMutations:f}=we(e,t,p,i);return d.pushUndoRedo({undoMutations:f,redoMutations:v,unitID:e}),await s.sequenceExecuteAsync(v,l),!0}},je={type:s.CommandType.COMMAND,id:"sheet.command.addDataValidation",async handler(i,n){if(!n)return!1;const{unitId:e,subUnitId:t,rule:a}=n,r=i.get(D.DataValidationModel),o=i.get(s.ICommandService),l=i.get(s.IUndoRedoService),d=r.ensureManager(e,t),u=d.getRuleObjectMatrix().clone();u.addRule(a);const c=u.diff(d.getDataValidations()),m={unitId:e,subUnitId:t,rule:a},{redoMutations:h,undoMutations:p}=we(e,t,c,i);return h.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:h,undoMutations:p}),await s.sequenceExecuteAsync(h,o),!0}},ze={type:s.CommandType.COMMAND,id:"data-validation.command.addRuleAndOpen",async handler(i){const n=i.get(s.IUniverInstanceService),e=j.getSheetCommandTarget(n);if(!e)return!1;const{workbook:t,worksheet:a}=e,r=D.createDefaultNewRule(i),o=i.get(s.ICommandService),l=t.getUnitId(),d=a.getSheetId(),u={rule:r,unitId:l,subUnitId:d};return await o.executeCommand(je.id,u)?(o.executeCommand(_e.id,{ruleId:r.uid,isAdd:!0}),!0):!1}},ht={type:s.CommandType.COMMAND,id:"sheets.command.update-data-validation-setting",handler(i,n){if(!n)return!1;const e=i.get(s.ICommandService),t=i.get(s.IUndoRedoService),a=i.get(D.DataValidationModel),r=i.get(D.DataValidatorRegistryService),{unitId:o,subUnitId:l,ruleId:d,setting:u}=n,c=r.getValidatorItem(u.type);if(!c)return!1;const m=a.getRuleById(o,l,d);if(!m||!c.validatorFormula({...m,...u},o,l).success)return!1;const h={unitId:o,subUnitId:l,ruleId:d,payload:{type:D.UpdateRuleType.SETTING,payload:u}},p=[{id:D.UpdateDataValidationMutation.id,params:h}],v={unitId:o,subUnitId:l,ruleId:d,payload:{type:D.UpdateRuleType.SETTING,payload:D.getRuleSetting(m)}},f=[{id:D.UpdateDataValidationMutation.id,params:v}];if(u.type===s.DataValidationType.CHECKBOX){const _=m.ranges,C=i.get(s.IUniverInstanceService),R=j.getSheetCommandTarget(C,{unitId:o,subUnitId:l});if(R){const M=new s.ObjectMatrix,{worksheet:O}=R,{formula2:F=Ne,formula1:B=Le}=m,{formula2:$=Ne,formula1:k=Le}=u;_.forEach(H=>{s.Range.foreach(H,(Y,P)=>{const N=O.getCellRaw(Y,P),q=Nt(N);aa(N)||q===String(F)?M.setValue(Y,P,{v:$,p:null}):q===String(B)&&M.setValue(Y,P,{v:k,p:null})})});const A={id:j.SetRangeValuesMutation.id,params:{unitId:o,subUnitId:l,cellValue:M.getData()}},b={id:j.SetRangeValuesMutation.id,params:j.SetRangeValuesUndoMutationFactory(i,A.params)};p.push(A),f.push(b)}}return s.sequenceExecute(p,e).result?(t.pushUndoRedo({unitID:o,redoMutations:p,undoMutations:f}),!0):!1}},na={type:s.CommandType.COMMAND,id:"sheets.command.update-data-validation-options",handler(i,n){if(!n)return!1;const e=i.get(s.ICommandService),t=i.get(s.IUndoRedoService),a=i.get(D.DataValidationModel),{unitId:r,subUnitId:o,ruleId:l,options:d}=n,u=a.getRuleById(r,o,l);if(!u)return!1;const c={unitId:r,subUnitId:o,ruleId:l,payload:{type:D.UpdateRuleType.OPTIONS,payload:d}},m=[{id:D.UpdateDataValidationMutation.id,params:c}],h={unitId:r,subUnitId:o,ruleId:l,payload:{type:D.UpdateRuleType.OPTIONS,payload:D.getRuleOptions(u)}},p=[{id:D.UpdateDataValidationMutation.id,params:h}];return t.pushUndoRedo({unitID:r,redoMutations:m,undoMutations:p}),e.executeCommand(D.UpdateDataValidationMutation.id,c),!0}},pt={dataValidationOptionsButton:"univer-data-validation-options-button",dataValidationOptionsButtonIcon:"univer-data-validation-options-button-icon"};function wn(i){var u;const n=x.useDependency(s.LocaleService),e=x.useDependency(X.ComponentManager),{value:t,onChange:a,extraComponent:r}=i,[o,l]=T.useState(!1),d=r?e.get(r):null;return S.jsxs(S.Fragment,{children:[S.jsxs("div",{className:pt.dataValidationOptionsButton,onClick:()=>l(!o),children:[n.t("dataValidation.panel.options"),o?S.jsx($t,{className:pt.dataValidationOptionsButtonIcon}):S.jsx(Bt,{className:pt.dataValidationOptionsButtonIcon})]}),o&&S.jsxs(S.Fragment,{children:[d?S.jsx(d,{value:t,onChange:a}):null,S.jsx(E.FormLayout,{label:n.t("dataValidation.panel.invalid"),children:S.jsxs(E.RadioGroup,{value:`${(u=t.errorStyle)!=null?u:s.DataValidationErrorStyle.WARNING}`,onChange:c=>a({...t,errorStyle:+c}),children:[S.jsx(E.Radio,{value:`${s.DataValidationErrorStyle.WARNING}`,children:n.t("dataValidation.panel.showWarning")}),S.jsx(E.Radio,{value:`${s.DataValidationErrorStyle.STOP}`,children:n.t("dataValidation.panel.rejectInput")})]})}),S.jsx(E.FormLayout,{label:n.t("dataValidation.panel.messageInfo"),children:S.jsx(E.Checkbox,{checked:t.showInputMessage,onChange:()=>a({...t,showInputMessage:!t.showInputMessage}),children:n.t("dataValidation.panel.showInfo")})}),t.showInputMessage?S.jsx(E.FormLayout,{children:S.jsx(E.Input,{value:t.error,onChange:c=>a({...t,error:c})})}):null]})]})}const Oe={dataValidationDetailFormItem:"univer-data-validation-detail-form-item",dataValidationDetailButtons:"univer-data-validation-detail-buttons",dataValidationDetailButton:"univer-data-validation-detail-button"},On=i=>s.debounce(async(n,e,t,a)=>{const r=await i.executeCommand(n,e,t);a==null||a(r)},275);function Tn(){const[i,n]=T.useState(0),e=x.useDependency(se),t=X.useObservable(e.activeRule$,e.activeRule),{unitId:a,subUnitId:r,rule:o}=t||{},l=o.uid,d=x.useDependency(D.DataValidatorRegistryService),u=x.useDependency(X.ComponentManager),c=x.useDependency(s.ICommandService),m=x.useDependency(D.DataValidationModel),h=x.useDependency(s.LocaleService),[p,v]=T.useState(o),f=d.getValidatorItem(p.type),[I,_]=T.useState(!1),C=d.getValidatorsByScope(D.DataValidatorRegistryScope.SHEET),[R,M]=T.useState(()=>p.ranges.map(w=>({unitId:"",sheetId:"",range:w}))),O=T.useMemo(()=>On(c),[c]);if(T.useEffect(()=>{c.onCommandExecuted(w=>{(w.id===s.UndoCommand.id||w.id===s.RedoCommand.id)&&setTimeout(()=>{const W=m.getRuleById(a,r,l);n(ae=>ae+1),W&&(v(W),M(W.ranges.map(ae=>({unitId:"",sheetId:"",range:ae}))))},20)})},[c,m,l,r,a]),!f)return null;const F=f.operators,B=f.operatorNames,$=p.operator?D.TWO_FORMULA_OPERATOR_COUNT.includes(p.operator):!1,k=()=>{f.validatorFormula(p,a,r).success?e.setActiveRule(null):_(!0)},A=X.useEvent(w=>{if(s.isUnitRangesEqual(w,R))return;M(w);const W=w.filter(Z=>(!Z.unitId||Z.unitId===a)&&(!Z.sheetId||Z.sheetId===r)).map(Z=>Z.range);if(v({...p,ranges:W}),W.length===0)return;const ae={unitId:a,subUnitId:r,ruleId:l,ranges:W};O(Ae.id,ae)}),b=w=>{if(s.shallowEqual(w,D.getRuleSetting(p)))return;v({...p,...w});const W={unitId:a,subUnitId:r,ruleId:l,setting:w};O(ht.id,W,void 0)},H=async()=>{await c.executeCommand(D.RemoveDataValidationCommand.id,{ruleId:l,unitId:a,subUnitId:r}),e.setActiveRule(null)},Y={type:p.type,operator:p.operator,formula1:p.formula1,formula2:p.formula2,allowBlank:p.allowBlank},P=w=>{const W=d.getValidatorItem(w);if(!W)return;const ae=W.operators,Z=m.getRuleById(a,r,l),de=w===(Z==null?void 0:Z.type)?{...Z}:{...p,type:w,operator:ae[0],formula1:void 0,formula2:void 0};v(de),c.executeCommand(ht.id,{unitId:a,subUnitId:r,ruleId:p.uid,setting:D.getRuleSetting(de)})},N=u.get(f.formulaInput),q=T.useMemo(()=>R.map(w=>re.serializeRange(w.range)).join(","),[]),ee=D.getRuleOptions(p),G=w=>{s.shallowEqual(w,D.getRuleOptions(p))||(v({...p,...w}),O(na.id,{unitId:a,subUnitId:r,ruleId:l,options:w}))};return S.jsxs("div",{children:[S.jsx(E.FormLayout,{label:h.t("dataValidation.panel.range"),children:S.jsx(X.RangeSelector,{className:Oe.dataValidationDetailFormItem,value:q,id:s.createInternalEditorID("data-validation-detail"),openForSheetUnitId:a,openForSheetSubUnitId:r,onChange:w=>{w.some(W=>!s.isValidRange(W.range)||W.range.endColumn<W.range.startColumn||W.range.endRow<W.range.startRow)||A(w)}},i)}),S.jsx(E.FormLayout,{label:h.t("dataValidation.panel.type"),children:S.jsx(E.Select,{options:C==null?void 0:C.map(w=>({label:h.t(w.title),value:w.id})),value:p.type,onChange:P,className:Oe.dataValidationDetailFormItem})}),F!=null&&F.length?S.jsx(E.FormLayout,{label:h.t("dataValidation.panel.operator"),children:S.jsx(E.Select,{options:F.map((w,W)=>({value:`${w}`,label:B[W]})),value:`${p.operator}`,onChange:w=>{b({...Y,operator:w})},className:Oe.dataValidationDetailFormItem})}):null,N?S.jsx(N,{isTwoFormula:$,value:{formula1:p.formula1,formula2:p.formula2},onChange:w=>{b({...Y,...w})},showError:I,validResult:f.validatorFormula(p,a,r),unitId:a,subUnitId:r,ruleId:l},i):null,S.jsx(wn,{value:ee,onChange:G,extraComponent:f.optionsInput}),S.jsxs("div",{className:Oe.dataValidationDetailButtons,children:[S.jsx(E.Button,{className:Oe.dataValidationDetailButton,onClick:H,children:h.t("dataValidation.panel.removeRule")}),S.jsx(E.Button,{className:Oe.dataValidationDetailButton,type:"primary",onClick:k,children:h.t("dataValidation.panel.done")})]})]})}const Ke={dataValidationItemContainer:"univer-data-validation-item-container",dataValidationItemTitle:"univer-data-validation-item-title",dataValidationItemContent:"univer-data-validation-item-content",dataValidationItemIcon:"univer-data-validation-item-icon"},En=i=>{const{rule:n,onClick:e,unitId:t,subUnitId:a,disable:r}=i,o=x.useDependency(D.DataValidatorRegistryService),l=x.useDependency(s.ICommandService),d=x.useDependency(U.IMarkSelectionService),u=o.getValidatorItem(n.type),c=T.useRef(),[m,h]=T.useState(!1),p=v=>{l.executeCommand(D.RemoveDataValidationCommand.id,{ruleId:n.uid,unitId:t,subUnitId:a}),v.stopPropagation()};return T.useEffect(()=>()=>{var v;c.current&&((v=c.current)==null||v.forEach(f=>{f&&d.removeShape(f)}))},[d]),S.jsxs("div",{className:Ke.dataValidationItemContainer,onClick:e,onMouseEnter:()=>{r||(h(!0),c.current=n.ranges.map(v=>d.addShape({range:v,style:{hasAutoFill:!1,fill:"rgba(73, 184, 17, 0.05)",strokeWidth:1,stroke:"#49B811",widgets:{}},primary:{startColumn:v.startColumn,endColumn:v.endColumn,startRow:v.startRow,endRow:v.endRow,actualRow:v.startRow,actualColumn:v.startColumn,isMerged:!1,isMergedMainCell:!1}})))},onMouseLeave:()=>{var v;h(!1),(v=c.current)==null||v.forEach(f=>{f&&d.removeShape(f)}),c.current=void 0},children:[S.jsx("div",{className:Ke.dataValidationItemTitle,children:u==null?void 0:u.generateRuleName(n)}),S.jsx("div",{className:Ke.dataValidationItemContent,children:n.ranges.map(v=>re.serializeRange(v)).join(",")}),m?S.jsx("div",{className:Ke.dataValidationItemIcon,onClick:p,children:S.jsx(st,{})}):null]})},ft={dataValidationListButtons:"univer-data-validation-list-buttons",dataValidationListButton:"univer-data-validation-list-button"};function Fn(){const i=x.useDependency(s.IUniverInstanceService),n=X.useObservable(()=>i.getCurrentTypeOfUnit$(s.UniverInstanceType.UNIVER_SHEET),void 0,void 0,[]);return n?S.jsx(bn,{workbook:n}):null}function bn(i){const n=x.useDependency(D.DataValidationModel),e=x.useDependency(s.IUniverInstanceService),t=x.useDependency(s.ICommandService),a=x.useDependency(y.Injector),r=x.useDependency(se),o=x.useDependency(s.LocaleService),[l,d]=T.useState([]),{workbook:u}=i,c=X.useObservable(u.activeSheet$,void 0,!0),m=u.getUnitId(),h=c==null?void 0:c.getSheetId(),p=n.ensureManager(m,h);T.useEffect(()=>{d(p.getDataValidations());const R=p.dataValidations$.subscribe(M=>{d([...M])});return()=>{R.unsubscribe()}},[p]);const v=async()=>{const R=D.createDefaultNewRule(a),M={unitId:m,subUnitId:h,rule:R};await t.executeCommand(je.id,M),r.setActiveRule({unitId:m,subUnitId:h,rule:R})},f=()=>{t.executeCommand(D.RemoveAllDataValidationCommand.id,{unitId:m,subUnitId:h})},_=(R=>{const O=e.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET).getActiveSheet();return R.map(B=>{const{ranges:$}=B;return($==null?void 0:$.some(A=>{var N,q;const{startRow:b,startColumn:H,endRow:Y,endColumn:P}=A;for(let ee=b;ee<=Y;ee++)for(let G=H;G<=P;G++){const w=(q=(N=O==null?void 0:O.getCell(ee,G))==null?void 0:N.selectionProtection)==null?void 0:q[0];if((w==null?void 0:w[Ye.Edit])===!1||(w==null?void 0:w[Ye.View])===!1)return!0}return!1}))?{...B,disable:!0}:{...B}})})(l),C=_==null?void 0:_.some(R=>R.disable);return S.jsxs("div",{children:[_==null?void 0:_.map(R=>{var M;return S.jsx(En,{unitId:m,subUnitId:h,onClick:()=>{R.disable||r.setActiveRule({unitId:m,subUnitId:h,rule:R})},rule:R,disable:(M=R.disable)!=null?M:!1},R.uid)}),S.jsxs("div",{className:ft.dataValidationListButtons,children:[l.length&&!C?S.jsx(E.Button,{className:ft.dataValidationListButton,onClick:f,children:o.t("dataValidation.panel.removeAll")}):null,S.jsx(E.Button,{className:ft.dataValidationListButton,type:"primary",onClick:v,children:o.t("dataValidation.panel.add")})]})]})}const Ln=()=>{const i=x.useDependency(se),n=X.useObservable(i.activeRule$,i.activeRule);return n?S.jsx(Tn,{},n.rule.uid):S.jsx(Fn,{})},ce={dvListDropdown:"univer-dv-list-dropdown",dvListDropdownTitle:"univer-dv-list-dropdown-title",dvListDropdownList:"univer-dv-list-dropdown-list",dvListDropdownListContainer:"univer-dv-list-dropdown-list-container",dvListDropdownSelectedIcon:"univer-dv-list-dropdown-selected-icon",dvListDropdownItemContainer:"univer-dv-list-dropdown-item-container",dvListDropdownItem:"univer-dv-list-dropdown-item",dvListDropdownSplit:"univer-dv-list-dropdown-split",dvListDropdownEdit:"univer-dv-list-dropdown-edit"},Nn=i=>{const{value:n,onChange:e,multiple:t,options:a,title:r,onEdit:o,style:l}=i;return S.jsxs("div",{className:ce.dvListDropdown,style:l,children:[S.jsx("div",{className:ce.dvListDropdownTitle,children:r}),S.jsx("div",{className:ce.dvListDropdownList,children:S.jsx(E.Scrollbar,{children:S.jsx("div",{className:ce.dvListDropdownListContainer,children:a.map((d,u)=>{const c=n.indexOf(d.value)>-1,m=()=>{let h;c?h=new Set(n.filter(v=>v!==d.value)):h=new Set(t?[...n,d.value]:[d.value]);const p=[];a.forEach(v=>{h.has(v.value)&&p.push(v.value)}),e(p)};return S.jsxs("div",{className:ce.dvListDropdownItemContainer,onClick:m,children:[S.jsx("div",{className:ce.dvListDropdownItem,style:{background:d.color||De},children:d.label}),S.jsx("div",{className:ce.dvListDropdownSelectedIcon,children:c?S.jsx(At,{}):null})]},u)})})})}),S.jsx("div",{className:ce.dvListDropdownSplit}),S.jsx("div",{className:ce.dvListDropdownEdit,children:S.jsx("a",{onClick:o,children:"编辑"})})]})};function Pn(i){var $,k;const{location:n,hideFn:e}=i,{worksheet:t,row:a,col:r,unitId:o,subUnitId:l}=n,d=x.useDependency(s.ICommandService),u=x.useDependency(s.LocaleService),[c,m]=T.useState(""),h=x.useDependency(U.IEditorBridgeService),p=E.RectPopup.useContext(),v=p.right-p.left;if(!t)return null;const f=t.getCell(a,r),I=($=f==null?void 0:f.dataValidation)==null?void 0:$.rule,_=(k=f==null?void 0:f.dataValidation)==null?void 0:k.validator,C=(I==null?void 0:I.renderMode)===s.DataValidationRenderMode.CUSTOM||(I==null?void 0:I.renderMode)===void 0;if(!f||!I||!_)return;const R=I.type===s.DataValidationType.LIST_MULTIPLE,M=_.getListWithColor(I,o,l),O=c||Ka(f),F=ye(O),B=()=>{d.executeCommand(_e.id,{ruleId:I.uid}),e()};return S.jsx(Nn,{style:{minWidth:v,maxWidth:Math.max(v,200)},title:R?u.t("dataValidation.listMultiple.dropdown"):u.t("dataValidation.list.dropdown"),value:F,multiple:R,onChange:A=>{const b=Ht(A),H={unitId:o,subUnitId:l,range:{startColumn:r,endColumn:r,startRow:a,endRow:a},value:{v:b,p:null,f:null,si:null}};h.isVisible()&&h.changeVisible({visible:!1,keycode:X.KeyCode.ESC,eventType:Q.DeviceInputEventType.Keyboard}),d.executeCommand(j.SetRangeValuesCommand.id,H),m(b),R||e()},options:M.map(A=>({label:A.label,value:A.label,color:C?A.color:"transparent"})),onEdit:B})}var An=Object.defineProperty,jn=Object.getOwnPropertyDescriptor,Un=(i,n,e,t)=>{for(var a=t>1?void 0:t?jn(n,e):n,r=i.length-1,o;r>=0;r--)(o=i[r])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&An(n,e,a),a},Ue=(i,n)=>(e,t)=>n(e,t,i);g.DataValidationRejectInputController=class extends s.Disposable{constructor(n,e,t,a,r){super(),this._editorBridgeService=n,this._dataValidationModel=e,this._dataValidatorRegistryService=t,this._dialogService=a,this._localeService=r,this._initEditorBridgeInterceptor()}_initEditorBridgeInterceptor(){this._editorBridgeService.interceptor.intercept(this._editorBridgeService.interceptor.getInterceptPoints().AFTER_CELL_EDIT_ASYNC,{handler:async(n,e,t)=>{const a=await n,{worksheet:r,row:o,col:l,unitId:d,subUnitId:u}=e,c=this._dataValidationModel.ensureManager(d,u),m=c.getRuleIdByLocation(o,l),h=m?c.getRuleById(m):void 0;if(!h||h.errorStyle!==s.DataValidationErrorStyle.STOP)return t(Promise.resolve(a));const p=await this._dataValidatorRegistryService.getValidatorItem(h.type);if(!p||await p.validator({value:te(a),row:o,column:l,unitId:d,subUnitId:u},h))return t(Promise.resolve(a));const f=r.getCellRaw(o,l);return this._dialogService.open({width:368,title:{title:this._localeService.t("dataValidation.alert.title")},id:"reject-input-dialog",children:{title:p.getRuleFinalError(h)},footer:{title:T.createElement(E.Button,{type:"primary",onClick:()=>this._dialogService.close("reject-input-dialog")},this._localeService.t("dataValidation.alert.ok"))},onClose:()=>{this._dialogService.close("reject-input-dialog")}}),t(Promise.resolve(f))}})}showReject(n){this._dialogService.open({width:368,title:{title:this._localeService.t("dataValidation.alert.title")},id:"reject-input-dialog",children:{title:n},footer:{title:T.createElement(E.Button,{type:"primary",onClick:()=>this._dialogService.close("reject-input-dialog")},this._localeService.t("dataValidation.alert.ok"))},onClose:()=>{this._dialogService.close("reject-input-dialog")}})}},g.DataValidationRejectInputController=Un([s.OnLifecycle(s.LifecycleStages.Ready,g.DataValidationRejectInputController),Ue(0,U.IEditorBridgeService),Ue(1,y.Inject(D.DataValidationModel)),Ue(2,y.Inject(D.DataValidatorRegistryService)),Ue(3,X.IDialogService),Ue(4,y.Inject(s.LocaleService))],g.DataValidationRejectInputController);const Bn={dvDateDropdown:"univer-dv-date-dropdown"};function $n(i){var C,R,M;const{location:n,hideFn:e}=i,{worksheet:t,row:a,col:r,unitId:o,subUnitId:l}=n,d=x.useDependency(s.ICommandService),u=x.useDependency(g.DataValidationRejectInputController),[c,m]=T.useState();if(!t)return null;const h=t.getCell(a,r),p=(C=h==null?void 0:h.dataValidation)==null?void 0:C.rule,v=(R=h==null?void 0:h.dataValidation)==null?void 0:R.validator;if(!h||!p||!v)return;const f=te(h),I=(M=v.transformDate(f))!=null?M:Se(),_=I.isValid()?I:Se();return S.jsx("div",{className:Bn.dvDateDropdown,children:S.jsx(E.DatePanel,{pickerValue:c!=null?c:_,onSelect:async O=>{const F=O.format("YYYY/MM/DD");p.errorStyle!==s.DataValidationErrorStyle.STOP||await v.validator({value:F,unitId:o,subUnitId:l,row:a,column:r},p)?d.executeCommand(j.SetRangeValuesCommand.id,{unitId:o,subUnitId:l,range:{startColumn:r,endColumn:r,startRow:a,endRow:a},value:{v:F,p:null,f:null,si:null}}):u.showReject(v.getRuleFinalError(p)),e()},onPanelChange:O=>{m(O)}})})}const ra="data-validation.list.dropdown",ia="data-validation.date.dropdown",oa="data-validation-single",vt="sheet.menu.data-validation";function Wn(i){return{id:vt,type:X.MenuItemType.SUBITEMS,positions:[X.MenuPosition.TOOLBAR_START],group:X.MenuGroup.TOOLBAR_FORMULAS_INSERT,icon:oa,tooltip:"dataValidation.title",hidden$:X.getMenuHiddenObservable(i,s.UniverInstanceType.UNIVER_SHEET),disabled$:U.getCurrentRangeDisable$(i,{workbookTypes:[j.WorkbookEditablePermission],worksheetTypes:[j.WorksheetSetCellStylePermission,j.WorksheetEditPermission],rangeTypes:[j.RangeProtectionPermissionEditPoint]})}}function Hn(i){return{id:_e.id,title:"dataValidation.panel.title",type:X.MenuItemType.BUTTON,positions:[vt]}}function xn(i){return{id:ze.id,title:"dataValidation.panel.add",type:X.MenuItemType.BUTTON,positions:[vt]}}var kn=Object.defineProperty,Yn=Object.getOwnPropertyDescriptor,sa=(i,n,e,t)=>{for(var a=t>1?void 0:t?Yn(n,e):n,r=i.length-1,o;r>=0;r--)(o=i[r])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&kn(n,e,a),a},J=(i,n)=>(e,t)=>n(e,t,i);const la={},da={tr:{size:6,color:"#fe4b4b"}};g.SheetsDataValidationRenderController=class extends s.RxDisposable{constructor(n,e,t,a,r,o,l,d,u,c,m,h,p){super(),this._config=n,this._commandService=e,this._menuService=t,this._renderManagerService=a,this._univerInstanceService=r,this._autoHeightController=o,this._componentManager=l,this._dropdownManagerService=d,this._dataValidationModel=u,this._dataValidatorRegistryService=c,this._injector=m,this._sheetInterceptorService=h,this._editorBridgeService=p,this._initComponents(),this._initMenu(),this._initSkeletonChange(),this._initDropdown(),this._initViewModelIntercept(),this._initAutoHeight()}_initMenu(){const{menu:n={}}=this._config;[Wn,Hn,xn].forEach(e=>{this.disposeWithMe(this._menuService.addMenuItem(e(this._injector),n))})}_initComponents(){[[Lt,Ln],[Ft,Ca],[ra,Pn],[ia,$n],[Xe.componentKey,Xe],...rn].forEach(([n,e])=>{this.disposeWithMe(this._componentManager.register(n,e))})}_initDropdown(){this._editorBridgeService&&this.disposeWithMe(this._editorBridgeService.visible$.subscribe(n=>{if(!n.visible)return;const e=this._editorBridgeService.getEditCellState();if(e){const{unitId:t,sheetId:a,row:r,column:o}=e,l=this._univerInstanceService.getUniverSheetInstance(t);if(!l)return;const u=this._dataValidationModel.ensureManager(t,a).getRuleByLocation(r,o);if(!u)return;const c=this._dataValidatorRegistryService.getValidatorItem(u.type);if(!(c!=null&&c.dropdown))return;const m=l.getActiveSheet();if(!m)return;const h=this._dropdownManagerService.activeDropdown,p=h==null?void 0:h.location;if(p&&p.unitId===t&&p.subUnitId===a&&p.row===r&&p.col===o)return;this._dropdownManagerService.showDropdown({location:{unitId:t,subUnitId:a,row:r,col:o,workbook:l,worksheet:m},componentKey:c.dropdown,onHide:()=>{}})}}))}_initSkeletonChange(){const n=()=>{var l,d,u;const e=this._univerInstanceService.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET);if(!e)return;const t=e.getUnitId(),a=(l=e.getActiveSheet())==null?void 0:l.getSheetId();if(!a)return;const r=(u=(d=this._renderManagerService.getRenderById(t))==null?void 0:d.with(U.SheetSkeletonManagerService).getUnitSkeleton(t,a))==null?void 0:u.skeleton,o=this._renderManagerService.getRenderById(t);r==null||r.makeDirty(!0),r==null||r.calculate(),o&&o.mainComponent.makeForceDirty()};this.disposeWithMe(this._dataValidationModel.ruleChange$.subscribe(()=>n())),this.disposeWithMe(this._dataValidationModel.validStatusChange$.subscribe(()=>n()))}_initViewModelIntercept(){this.disposeWithMe(this._sheetInterceptorService.intercept(j.INTERCEPTOR_POINT.CELL_CONTENT,{priority:200,handler:(n,e,t)=>{var O,F,B,$,k,A;const{row:a,col:r,unitId:o,subUnitId:l,workbook:d,worksheet:u}=e,c=this._dataValidationModel.ensureManager(o,l);if(!c)return t(n);const m=(F=(O=this._renderManagerService.getRenderById(o))==null?void 0:O.with(U.SheetSkeletonManagerService).getUnitSkeleton(o,l))==null?void 0:F.skeleton;if(!m)return t(n);const h=e.workbook.getStyles(),p=(typeof(n==null?void 0:n.s)=="string"?h.get(n==null?void 0:n.s):n==null?void 0:n.s)||{},v=c.getRuleIdByLocation(a,r);if(!v)return t(n);const f=c.getRuleById(v);if(!f)return t(n);const I=u.getCellRaw(e.row,e.col),_=this._dataValidationModel.validator(te(I),f,e),C=this._dataValidatorRegistryService.getValidatorItem(f.type),R=te(n);let M={};if((f.type===s.DataValidationType.LIST||f.type===s.DataValidationType.LIST_MULTIPLE)&&(M={interceptorStyle:{...n==null?void 0:n.interceptorStyle,tb:(B=p.tb!==s.WrapStrategy.OVERFLOW?p.tb:s.WrapStrategy.CLIP)!=null?B:s.WrapStrategy.WRAP}}),f.type===s.DataValidationType.CHECKBOX&&(M={interceptorStyle:{...n==null?void 0:n.interceptorStyle,tb:s.WrapStrategy.CLIP}}),f.type===s.DataValidationType.LIST&&(f.renderMode===s.DataValidationRenderMode.ARROW||f.renderMode===s.DataValidationRenderMode.TEXT)){const b=C.getListWithColorMap(f),H=`${($=te(n))!=null?$:""}`,Y=b[H];Y&&(M={...M,interceptorStyle:{...M.interceptorStyle,bg:{rgb:Y}}})}return t({...n,...M,dataValidation:{ruleId:v,validStatus:_,rule:f,validator:C},markers:{...n==null?void 0:n.markers,..._===s.DataValidationStatus.INVALID?da:null},customRender:[...(k=n==null?void 0:n.customRender)!=null?k:[],...C!=null&&C.canvasRender?[C.canvasRender]:[]],fontRenderExtension:{...n==null?void 0:n.fontRenderExtension,isSkip:C==null?void 0:C.skipDefaultFontRender(f,R,e)},interceptorStyle:{...n==null?void 0:n.interceptorStyle,...M.interceptorStyle},get interceptorAutoHeight(){var Y,P,N,q;const b=m.mergeData.find(ee=>{const{startColumn:G,startRow:w,endColumn:W,endRow:ae}=ee;return a>=w&&r>=G&&a<=ae&&r<=W}),H={data:{...n,dataValidation:{ruleId:v,validStatus:_,rule:f,validator:C}},style:m.getsStyles().getStyleByCell(n),primaryWithCoord:m.getCellByIndex((Y=b==null?void 0:b.startRow)!=null?Y:a,(P=b==null?void 0:b.startColumn)!=null?P:r),unitId:o,subUnitId:l,row:a,col:r,workbook:d,worksheet:u};return(q=(N=C==null?void 0:C.canvasRender)==null?void 0:N.calcCellAutoHeight)==null?void 0:q.call(N,H)},coverable:((A=n==null?void 0:n.coverable)!=null?A:!0)&&!(f.type===s.DataValidationType.LIST||f.type===s.DataValidationType.LIST_MULTIPLE)})}}))}_initAutoHeight(){this._dataValidationModel.ruleChange$.subscribe(n=>{var e;if((e=n.rule)!=null&&e.ranges){const t=this._autoHeightController.getUndoRedoParamsOfAutoHeight(n.rule.ranges);s.sequenceExecute(t.redos,this._commandService)}})}},g.SheetsDataValidationRenderController=sa([s.OnLifecycle(s.LifecycleStages.Rendered,g.SheetsDataValidationRenderController),J(1,s.ICommandService),J(2,X.IMenuService),J(3,Q.IRenderManagerService),J(4,s.IUniverInstanceService),J(5,y.Inject(U.AutoHeightController)),J(6,y.Inject(X.ComponentManager)),J(7,y.Inject(he)),J(8,y.Inject(D.DataValidationModel)),J(9,y.Inject(D.DataValidatorRegistryService)),J(10,y.Inject(y.Injector)),J(11,y.Inject(j.SheetInterceptorService)),J(12,y.Optional(U.IEditorBridgeService))],g.SheetsDataValidationRenderController);let Be=class extends s.RxDisposable{constructor(i,n,e,t,a,r,o,l){super(),this._config=i,this._commandService=n,this._renderManagerService=e,this._univerInstanceService=t,this._autoHeightController=a,this._dataValidationModel=r,this._dataValidatorRegistryService=o,this._sheetInterceptorService=l,this._initSkeletonChange(),this._initViewModelIntercept(),this._initAutoHeight()}_initSkeletonChange(){const i=()=>{var o,l,d;const n=this._univerInstanceService.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET);if(!n)return;const e=n.getUnitId(),t=(o=n.getActiveSheet())==null?void 0:o.getSheetId();if(!t)return;const a=(d=(l=this._renderManagerService.getRenderById(e))==null?void 0:l.with(U.SheetSkeletonManagerService).getUnitSkeleton(e,t))==null?void 0:d.skeleton,r=this._renderManagerService.getRenderById(e);a==null||a.makeDirty(!0),a==null||a.calculate(),r&&r.mainComponent.makeForceDirty()};this.disposeWithMe(this._dataValidationModel.ruleChange$.subscribe(()=>i())),this.disposeWithMe(this._dataValidationModel.validStatusChange$.subscribe(()=>i()))}_initViewModelIntercept(){this.disposeWithMe(this._sheetInterceptorService.intercept(j.INTERCEPTOR_POINT.CELL_CONTENT,{priority:200,handler:(i,n,e)=>{var M,O,F,B,$;const{row:t,col:a,unitId:r,subUnitId:o,workbook:l,worksheet:d}=n,u=this._dataValidationModel.ensureManager(r,o);if(!u)return e(i);const c=(O=(M=this._renderManagerService.getRenderById(r))==null?void 0:M.with(U.SheetSkeletonManagerService).getUnitSkeleton(r,o))==null?void 0:O.skeleton;if(!c)return e(i);const m=n.workbook.getStyles(),h=(typeof(i==null?void 0:i.s)=="string"?m.get(i==null?void 0:i.s):i==null?void 0:i.s)||{},p=u.getRuleIdByLocation(t,a);if(!p)return e(i);const v=u.getRuleById(p);if(!v)return e(i);const f=n.worksheet.getCellRaw(n.row,n.col),I=this._dataValidationModel.validator(te(f),v,n),_=this._dataValidatorRegistryService.getValidatorItem(v.type),C=te(i);let R={};if((v.type===s.DataValidationType.LIST||v.type===s.DataValidationType.LIST_MULTIPLE)&&(R={interceptorStyle:{...i==null?void 0:i.interceptorStyle,tb:(F=h.tb!==s.WrapStrategy.OVERFLOW?h.tb:s.WrapStrategy.CLIP)!=null?F:s.WrapStrategy.WRAP}}),v.type===s.DataValidationType.CHECKBOX&&(R={interceptorStyle:{...i==null?void 0:i.interceptorStyle,tb:s.WrapStrategy.CLIP}}),v.type===s.DataValidationType.LIST&&(v.renderMode===s.DataValidationRenderMode.ARROW||v.renderMode===s.DataValidationRenderMode.TEXT)){const k=_.getListWithColorMap(v),A=`${(B=te(i))!=null?B:""}`,b=k[A];b&&(R={...R,interceptorStyle:{...R.interceptorStyle,bg:{rgb:b}}})}return e({...i,...R,dataValidation:{ruleId:p,validStatus:I,rule:v,validator:_},markers:{...i==null?void 0:i.markers,...I===s.DataValidationStatus.INVALID?da:null},customRender:[...($=i==null?void 0:i.customRender)!=null?$:[],..._!=null&&_.canvasRender?[_.canvasRender]:[]],fontRenderExtension:{...i==null?void 0:i.fontRenderExtension,isSkip:_==null?void 0:_.skipDefaultFontRender(v,C,n)},interceptorStyle:{...i==null?void 0:i.interceptorStyle,...R.interceptorStyle},get interceptorAutoHeight(){var b,H,Y,P;const k=c.mergeData.find(N=>{const{startColumn:q,startRow:ee,endColumn:G,endRow:w}=N;return t>=ee&&a>=q&&t<=w&&a<=G}),A={data:{...i,dataValidation:{ruleId:p,validStatus:I,rule:v,validator:_}},style:c.getsStyles().getStyleByCell(i),primaryWithCoord:c.getCellByIndex((b=k==null?void 0:k.startRow)!=null?b:t,(H=k==null?void 0:k.startColumn)!=null?H:a),unitId:r,subUnitId:o,row:t,col:a,worksheet:d,workbook:l};return(P=(Y=_==null?void 0:_.canvasRender)==null?void 0:Y.calcCellAutoHeight)==null?void 0:P.call(Y,A)}})}}))}_initAutoHeight(){this._dataValidationModel.ruleChange$.subscribe(i=>{var n;if((n=i.rule)!=null&&n.ranges){const e=this._autoHeightController.getUndoRedoParamsOfAutoHeight(i.rule.ranges);s.sequenceExecute(e.redos,this._commandService)}})}};Be=sa([s.OnLifecycle(s.LifecycleStages.Rendered,Be),J(1,s.ICommandService),J(2,Q.IRenderManagerService),J(3,s.IUniverInstanceService),J(4,y.Inject(U.AutoHeightController)),J(5,y.Inject(D.DataValidationModel)),J(6,y.Inject(D.DataValidatorRegistryService)),J(7,y.Inject(j.SheetInterceptorService))],Be);var qn=Object.defineProperty,Xn=Object.getOwnPropertyDescriptor,Gn=(i,n,e,t)=>{for(var a=t>1?void 0:t?Xn(n,e):n,r=i.length-1,o;r>=0;r--)(o=i[r])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&qn(n,e,a),a},zn=(i,n)=>(e,t)=>n(e,t,i);g.SheetDataValidationService=class{constructor(n){V(this,"_currentManager");V(this,"_currentManager$",new ge.Subject);V(this,"currentManager$",this._currentManager$.asObservable());this._dataValidationModel=n}get currentManager(){return this._currentManager}_ensureManager(n,e){return this._dataValidationModel.ensureManager(n,e)}switchCurrent(n,e){var a,r;if(n===((a=this.currentManager)==null?void 0:a.unitId)&&e===((r=this._currentManager)==null?void 0:r.subUnitId))return;const t=this._ensureManager(n,e);this._currentManager={manager:t,unitId:n,subUnitId:e},this._currentManager$.next(this._currentManager)}get(n,e){return this._ensureManager(n,e)}},g.SheetDataValidationService=Gn([zn(0,y.Inject(D.DataValidationModel))],g.SheetDataValidationService);var Kn=Object.defineProperty,Qn=Object.getOwnPropertyDescriptor,Zn=(i,n,e,t)=>{for(var a=t>1?void 0:t?Qn(n,e):n,r=i.length-1,o;r>=0;r--)(o=i[r])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&Kn(n,e,a),a},Qe=(i,n)=>(e,t)=>n(e,t,i);g.DataValidationCustomFormulaService=class extends s.Disposable{constructor(e,t,a,r){super();V(this,"_formulaMap",new Map);V(this,"_ruleFormulaMap",new Map);V(this,"_formulaCellMap",new Map);this._registerOtherFormulaService=e,this._lexerTreeBuilder=t,this._dataValidationModel=a,this._dataValidationCacheService=r,this._initFormulaResultHandler()}_initFormulaResultHandler(){this.disposeWithMe(this._registerOtherFormulaService.formulaResult$.subscribe(e=>{for(const t in e){const a=e[t];for(const r in a){const o=a[r],{formulaCellMap:l,ruleFormulaMap:d}=this._ensureMaps(t,r),u=this._dataValidationModel.ensureManager(t,r);o.forEach(c=>{var v,f;const m=d.get((v=c.extra)==null?void 0:v.ruleId),h=l.get(c.formulaId),p=u.getRuleById((f=c.extra)==null?void 0:f.ruleId);p&&m&&!m.isTransformable&&this._dataValidationCacheService.markRangeDirty(t,r,p.ranges),h&&this._dataValidationCacheService.markCellDirty(t,r,h.row,h.column)})}}}))}_ensureMaps(e,t){let a=this._formulaMap.get(e),r=this._ruleFormulaMap.get(e),o=this._formulaCellMap.get(e);(!a||!r||!o)&&(a=new Map,r=new Map,o=new Map,this._formulaMap.set(e,a),this._ruleFormulaMap.set(e,r),this._formulaCellMap.set(e,o));let l=a.get(t),d=r.get(t),u=o.get(t);return(!l||!d||!u)&&(l=new s.ObjectMatrix,a.set(t,l),d=new Map,r.set(t,d),u=new Map,o.set(t,u)),{formulaMap:l,ruleFormulaMap:d,formulaCellMap:u}}_registerFormula(e,t,a,r){return this._registerOtherFormulaService.registerFormula(e,t,r,{ruleId:a})}deleteByRuleId(e,t,a){const{formulaMap:r,formulaCellMap:o,ruleFormulaMap:l}=this._ensureMaps(e,t),d=this._dataValidationModel.getRuleById(e,t,a),u=new Set,c=l.get(a);!d||!c||(l.delete(a),d.ranges.forEach(m=>{s.Range.foreach(m,(h,p)=>{const v=r.getValue(h,p);if(v&&v.ruleId===a){const{formulaId:f}=v;r.realDeleteValue(h,p),u.add(f),o.delete(f)}})}),this._registerOtherFormulaService.deleteFormula(e,t,Array.from(u.values())))}_addFormulaByRange(e,t,a,r,o){const{formulaMap:l,ruleFormulaMap:d,formulaCellMap:u}=this._ensureMaps(e,t);if(!r)return;const c=re.isFormulaTransformable(this._lexerTreeBuilder,r),m=o[0].startRow,h=o[0].startColumn;let p;c?o.forEach(v=>{s.Range.foreach(v,(f,I)=>{const _=re.transformFormula(this._lexerTreeBuilder,r,m,h,f,I),C=this._registerFormula(e,t,a,_);l.setValue(f,I,{formulaId:C,ruleId:a}),u.set(C,{row:f,column:I})})}):(p=this._registerFormula(e,t,a,r),o.forEach(v=>{s.Range.foreach(v,(f,I)=>{l.setValue(f,I,{formulaId:p,ruleId:a})})})),d.set(a,{formula:r,originCol:h,originRow:m,isTransformable:c,formulaId:p})}addRule(e,t,a){const{ranges:r,formula1:o,uid:l,type:d}=a;d!==s.DataValidationType.CUSTOM||!o||!s.isFormulaString(o)||this._addFormulaByRange(e,t,l,o,r)}updateRuleRanges(e,t,a,r,o){const{formulaMap:l,ruleFormulaMap:d,formulaCellMap:u}=this._ensureMaps(e,t),c=d.get(a);if(!c)return;const{formula:m,originCol:h,originRow:p,isTransformable:v,formulaId:f}=c,I=new Set;r.forEach(_=>{s.Range.foreach(_,(C,R)=>{const M=l.getValue(C,R);M&&M.ruleId===a&&(M.temp=!0)})}),o.forEach(_=>{s.Range.foreach(_,(C,R)=>{var O;const M=(O=l.getValue(C,R))!=null?O:{};if(M.ruleId!==a){const F=d.get(M.ruleId);if(F!=null&&F.isTransformable&&I.add(M.formulaId),v){const B=re.transformFormula(this._lexerTreeBuilder,m,p,h,C,R),$=this._registerFormula(e,t,a,B);l.setValue(C,R,{ruleId:a,formulaId:$}),u.set($,{row:C,column:R})}else l.setValue(C,R,{ruleId:a,formulaId:f})}else M.temp=!1})}),r.forEach(_=>{s.Range.foreach(_,(C,R)=>{const M=l.getValue(C,R);M&&M.ruleId===a&&M.temp===!0&&(l.realDeleteValue(C,R),v&&I.add(M.formulaId))})}),I.forEach(_=>{u.delete(_)}),this._registerOtherFormulaService.deleteFormula(e,t,Array.from(I.values()))}updateRuleFormula(e,t,a,r,o){const{ruleFormulaMap:l}=this._ensureMaps(e,t),d=l.get(a);(!d||d.formula!==o)&&this._addFormulaByRange(e,t,a,o,r)}getCellFormulaValue(e,t,a,r){const{formulaMap:o}=this._ensureMaps(e,t),l=o.getValue(a,r);return l?this._registerOtherFormulaService.getFormulaValue(e,t,l.formulaId):Promise.resolve(void 0)}getRuleFormulaInfo(e,t,a){const{ruleFormulaMap:r}=this._ensureMaps(e,t);return r.get(a)}},g.DataValidationCustomFormulaService=Zn([Qe(0,y.Inject(tt.RegisterOtherFormulaService)),Qe(1,y.Inject(re.LexerTreeBuilder)),Qe(2,y.Inject(D.DataValidationModel)),Qe(3,y.Inject(Ve))],g.DataValidationCustomFormulaService);class Jn extends D.BaseDataValidator{constructor(){super(...arguments);V(this,"id",s.DataValidationType.CUSTOM);V(this,"title","dataValidation.custom.title");V(this,"operators",[]);V(this,"scopes",["sheet"]);V(this,"formulaInput",kt);V(this,"_customFormulaService",this.injector.get(g.DataValidationCustomFormulaService))}validatorFormula(e,t,a){const r=s.isFormulaString(e.formula1);return{success:r,formula1:r?"":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:r,row:o,unitId:l,subUnitId:d}=e,u=await this._customFormulaService.getCellFormulaValue(l,d,o,r);return!!ue(u==null?void 0:u.result)}generateRuleErrorMessage(e){return this.localeService.t("dataValidation.custom.error")}}class er extends D.BaseDataValidator{constructor(){super(...arguments);V(this,"_formulaService",this.injector.get(g.DataValidationFormulaService));V(this,"id",s.DataValidationType.WHOLE);V(this,"title","dataValidation.whole.title");V(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]);V(this,"scopes",["sheet"]);V(this,"formulaInput",be);V(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:r}=e,o=Ge(r);return!Number.isNaN(o)&&Number.isInteger(o)}transform(e,t,a){const{value:r}=e;return{...e,value:Ge(r)}}_parseNumber(e){return e==null?Number.NaN:+e}async parseFormula(e,t,a){var u,c,m,h,p,v,f,I;const r=await this._formulaService.getRuleFormulaResult(t,a,e.uid),{formula1:o,formula2:l}=e;return{formula1:this._parseNumber(s.isFormulaString(o)?(h=(m=(c=(u=r==null?void 0:r[0])==null?void 0:u.result)==null?void 0:c[0])==null?void 0:m[0])==null?void 0:h.v:o),formula2:this._parseNumber(s.isFormulaString(l)?(I=(f=(v=(p=r==null?void 0:r[1])==null?void 0:p.result)==null?void 0:v[0])==null?void 0:f[0])==null?void 0:I.v:l)}}validatorFormula(e,t,a){const r=e.operator;if(!r)return{success:!1};const o=s.Tools.isDefine(e.formula1)&&this._isFormulaOrInt(e.formula1),l=s.Tools.isDefine(e.formula2)&&this._isFormulaOrInt(e.formula2),d=Pe.includes(r),u=this.localeService.t("dataValidation.validFail.number");return d?{success:o&&l,formula1:o?void 0:u,formula2:l?void 0:u}:{success:o,formula1:u}}async validatorIsEqual(e,t,a){const{formula1:r}=t,{value:o}=e;return Number.isNaN(r)?!0:o===r}async validatorIsNotEqual(e,t,a){const{formula1:r}=t;return Number.isNaN(r)?!0:e.value!==r}async validatorIsBetween(e,t,a){const{formula1:r,formula2:o}=t;if(Number.isNaN(r)||Number.isNaN(o))return!0;const l=Math.min(r,o),d=Math.max(r,o);return e.value>=l&&e.value<=d}async validatorIsNotBetween(e,t,a){const{formula1:r,formula2:o}=t;if(Number.isNaN(r)||Number.isNaN(o))return!0;const l=Math.min(r,o),d=Math.max(r,o);return e.value<l||e.value>d}async validatorIsGreaterThan(e,t,a){const{formula1:r}=t;return Number.isNaN(r)?!0:e.value>r}async validatorIsGreaterThanOrEqual(e,t,a){const{formula1:r}=t;return Number.isNaN(r)?!0:e.value>=r}async validatorIsLessThan(e,t,a){const{formula1:r}=t;return Number.isNaN(r)?!0:e.value<r}async validatorIsLessThanOrEqual(e,t,a){const{formula1:r}=t;return Number.isNaN(r)?!0:e.value<=r}}const ua=4,tr=0,gt=4,ca=4,St=6,Ze=6,Ie=14;function ar(i,n){const e=Q.FontCache.getTextSize(i,n),t=e.width+ua*2,{ba:a,bd:r}=e,o=a+r;return{width:t,height:o+tr*2,ba:a}}function ma(i,n,e,t){const a=e-Ie-St,r=t-Ze*2,o=i.map(c=>({layout:ar(c,n),text:c}));let l;const d=[];o.forEach(c=>{const{layout:m}=c,{width:h,height:p}=m;!l||l.width+h+gt>a?(l={width:h,height:p,items:[{...c,left:0}]},d.push(l)):(l.items.push({...c,left:l.width+gt}),l.width=l.width+h+gt)});let u=0;return d.forEach((c,m)=>{m===d.length-1?u+=c.height:u+=c.height+ca}),{lines:d,totalHeight:u,contentWidth:a,contentHeight:r,cellAutoHeight:u+Ze*2}}const nr=8;class rr extends Q.Shape{static drawWith(n,e){const{fontFamily:t,fontString:a,fontSize:r,info:o,fill:l,color:d}=e,{layout:u,text:c}=o;n.save(),Q.Rect.drawWith(n,{width:u.width,height:u.height,radius:nr,fill:l||De}),n.translateWithPrecision(ua,u.ba),n.font=a,n.fillStyle=d,n.fillText(c,0,0),n.restore()}}var ir=Object.defineProperty,or=Object.getOwnPropertyDescriptor,sr=(i,n,e,t)=>{for(var a=t>1?void 0:t?or(n,e):n,r=i.length-1,o;r>=0;r--)(o=i[r])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&ir(n,e,a),a},lr=(i,n)=>(e,t)=>n(e,t,i);const dr=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(i){V(this,"zIndex");V(this,"_dropdownInfoMap",new Map);this._commandService=i}_ensureMap(i){let n=this._dropdownInfoMap.get(i);return n||(n=new Map,this._dropdownInfoMap.set(i,n)),n}_generateKey(i,n){return`${i}.${n}`}_drawDownIcon(i,n,e,t,a){const r=e-Ie+4;let o=4;switch(a){case s.VerticalAlign.MIDDLE:o=(t-Ie)/2+4;break;case s.VerticalAlign.BOTTOM:o=t-Ie+4;break}i.save(),i.translateWithPrecision(n.startX+r,n.startY+o),i.fillStyle="#565656",i.fill(dr),i.restore()}drawWith(i,n,e,t){var W,ae;const{primaryWithCoord:a,row:r,col:o,style:l,data:d,subUnitId:u}=n,c=a.isMergedMainCell?a.mergeInfo:a,m=d.fontRenderExtension,{leftOffset:h=0,rightOffset:p=0,topOffset:v=0,downOffset:f=0}=m||{},I=d.dataValidation,_=this._ensureMap(u),C=this._generateKey(r,o);if(!I)return;const R={startX:c.startX+h,endX:c.endX-p,startY:c.startY+v,endY:c.endY-f},M=R.endX-R.startX,O=R.endY-R.startY,{cl:F}=l||{},B=(W=typeof F=="object"?F==null?void 0:F.rgb:F)!=null?W:"#000",$=Q.getFontStyleString(l!=null?l:void 0),{rule:k,validator:A}=I,b=A,{vt:H,ht:Y}=l||{},P=H!=null?H:s.VerticalAlign.MIDDLE,N=(ae=te(d))!=null?ae:"",q=b.parseCellValue(N),ee=b.getListWithColorMap(k),G=ma(q,$,M,O);this._drawDownIcon(i,R,M,O,P),i.save(),i.translateWithPrecision(R.startX,R.startY),i.beginPath(),i.rect(0,0,M-Ie,O),i.clip(),i.translateWithPrecision(St,Ze);let w=0;switch(P){case s.VerticalAlign.MIDDLE:w=(G.contentHeight-G.totalHeight)/2;break;case s.VerticalAlign.BOTTOM:w=G.contentHeight-G.totalHeight;break}i.translateWithPrecision(0,w),G.lines.forEach((Z,de)=>{i.save();const{width:L,height:z,items:K}=Z;let ne=0;switch(Y){case s.HorizontalAlign.RIGHT:ne=G.contentWidth-L;break;case s.HorizontalAlign.CENTER:ne=(G.contentWidth-L)/2;break}i.translate(ne,de*(z+ca)),K.forEach(me=>{i.save(),i.translateWithPrecision(me.left,0),rr.drawWith(i,{...$,info:me,color:B,fill:ee[me.text]}),i.restore()}),i.restore()}),i.restore(),_.set(C,{left:R.startX,top:R.startY,width:G.contentWidth+St+Ie,height:G.contentHeight+Ze*2})}calcCellAutoHeight(i){var M;const{primaryWithCoord:n,style:e,data:t}=i,a=t.fontRenderExtension,{leftOffset:r=0,rightOffset:o=0,topOffset:l=0,downOffset:d=0}=a||{},u=n.isMergedMainCell?n.mergeInfo:n,c={startX:u.startX+r,endX:u.endX-o,startY:u.startY+l,endY:u.endY-d},m=t.dataValidation;if(!m)return;const h=c.endX-c.startX,p=c.endY-c.startY,v=(M=te(t))!=null?M:"",{validator:f}=m,_=f.parseCellValue(v),C=Q.getFontStyleString(e!=null?e:void 0);return ma(_,C,h,p).cellAutoHeight}isHit(i,n){const{primaryWithCoord:e}=n,t=e.isMergedMainCell?e.mergeInfo:e,{endX:a}=t,{x:r}=i;return r>=a-Ie&&r<=a}onPointerDown(i,n){if(n.button===2)return;const{unitId:e,subUnitId:t,row:a,col:r}=i,o={unitId:e,subUnitId:t,row:a,column:r};this._commandService.executeCommand(Ee.id,o)}};_t=sr([lr(0,s.ICommandService)],_t);class ur extends ta{constructor(){super(...arguments);V(this,"id",s.DataValidationType.LIST_MULTIPLE);V(this,"title","dataValidation.listMultiple.title");V(this,"canvasRender",this.injector.createInstance(_t))}skipDefaultFontRender(){return!0}}var cr=Object.defineProperty,mr=Object.getOwnPropertyDescriptor,hr=(i,n,e,t)=>{for(var a=t>1?void 0:t?mr(n,e):n,r=i.length-1,o;r>=0;r--)(o=i[r])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&cr(n,e,a),a},ve=(i,n)=>(e,t)=>n(e,t,i);g.DataValidationController=class extends s.RxDisposable{constructor(n,e,t,a,r,o,l,d){super(),this._univerInstanceService=n,this._sheetDataValidationService=e,this._dataValidatorRegistryService=t,this._injector=a,this._componentManger=r,this._selectionManagerService=o,this._sheetInterceptorService=l,this._dataValidationModel=d,this._init()}_init(){this._registerValidators(),this._initInstanceChange(),this._componentManger.register(oa,jt),this._initCommandInterceptor()}_registerValidators(){[In,er,Mn,mn,on,ta,ur,Jn].forEach(n=>{const e=this._injector.createInstance(n);this.disposeWithMe(this._dataValidatorRegistryService.register(e)),this.disposeWithMe({dispose:()=>{this._injector.delete(n)}})})}_initInstanceChange(){const n=new s.DisposableCollection;this._univerInstanceService.getCurrentTypeOfUnit$(s.UniverInstanceType.UNIVER_SHEET).subscribe(e=>{if(n.dispose(),!e)return;const t=e.getActiveSheet();t&&(this._sheetDataValidationService.switchCurrent(e.getUnitId(),t.getSheetId()),n.add(s.toDisposable(e.activeSheet$.subscribe(a=>{if(a){const r=e.getUnitId(),o=a.getSheetId();this._sheetDataValidationService.switchCurrent(r,o)}}))))}),this.disposeWithMe(n)}_initCommandInterceptor(){this._sheetInterceptorService.interceptCommand({getMutations:n=>{if(n.id===j.ClearSelectionAllCommand.id){const e=this._univerInstanceService.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET),t=e.getUnitId(),a=e.getActiveSheet();if(!a)throw new Error("No active sheet found");const r=a.getSheetId(),o=this._selectionManagerService.getSelectionRanges(),l=this._dataValidationModel.ensureManager(t,r),d=l.getRuleObjectMatrix().clone();o&&d.removeRange(o);const u=d.diff(l.getDataValidations()),{redoMutations:c,undoMutations:m}=we(t,r,u,this._injector);return{undos:m,redos:c}}return{undos:[],redos:[]}}})}},g.DataValidationController=hr([s.OnLifecycle(s.LifecycleStages.Rendered,g.DataValidationController),ve(0,s.IUniverInstanceService),ve(1,y.Inject(g.SheetDataValidationService)),ve(2,y.Inject(D.DataValidatorRegistryService)),ve(3,y.Inject(y.Injector)),ve(4,y.Inject(X.ComponentManager)),ve(5,y.Inject(j.SelectionManagerService)),ve(6,y.Inject(j.SheetInterceptorService)),ve(7,y.Inject(D.DataValidationModel))],g.DataValidationController);var pr=Object.defineProperty,fr=Object.getOwnPropertyDescriptor,vr=(i,n,e,t)=>{for(var a=t>1?void 0:t?fr(n,e):n,r=i.length-1,o;r>=0;r--)(o=i[r])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&pr(n,e,a),a},Je=(i,n)=>(e,t)=>n(e,t,i);const Vt="SHEET_DATA_VALIDATION_ALERT";g.DataValidationAlertController=class extends s.Disposable{constructor(n,e,t,a){super(),this._hoverManagerService=n,this._cellAlertManagerService=e,this._univerInstanceService=t,this._localeService=a,this._init()}_init(){this._initCellAlertPopup()}_initCellAlertPopup(){this.disposeWithMe(this._hoverManagerService.currentCell$.pipe(ge.debounceTime(100)).subscribe(n=>{var e,t;if(n){const r=this._univerInstanceService.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET).getActiveSheet();if(!r)return;const o=r.getCell(n.location.row,n.location.col);if(((e=o==null?void 0:o.dataValidation)==null?void 0:e.validStatus)===s.DataValidationStatus.INVALID){const l=this._cellAlertManagerService.currentAlert.get(Vt),d=(t=l==null?void 0:l.alert)==null?void 0:t.location;if(d&&d.row===n.location.row&&d.col===n.location.col&&d.subUnitId===n.location.subUnitId&&d.unitId===n.location.unitId)return;const u=o.dataValidation.validator,c=o.dataValidation.rule;if(!u)return;this._cellAlertManagerService.showAlert({type:U.CellAlertType.ERROR,title:this._localeService.t("dataValidation.error.title"),message:u==null?void 0:u.getRuleFinalError(c),location:n.location,width:200,height:74,key:Vt});return}}this._cellAlertManagerService.removeAlert(Vt)}))}},g.DataValidationAlertController=vr([s.OnLifecycle(s.LifecycleStages.Rendered,g.DataValidationAlertController),Je(0,y.Inject(U.HoverManagerService)),Je(1,y.Inject(U.CellAlertManagerService)),Je(2,s.IUniverInstanceService),Je(3,y.Inject(s.LocaleService))],g.DataValidationAlertController);var gr=Object.defineProperty,Sr=Object.getOwnPropertyDescriptor,_r=(i,n,e,t)=>{for(var a=t>1?void 0:t?Sr(n,e):n,r=i.length-1,o;r>=0;r--)(o=i[r])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&gr(n,e,a),a},Te=(i,n)=>(e,t)=>n(e,t,i);g.DataValidationRefRangeController=class extends s.Disposable{constructor(e,t,a,r,o,l){super();V(this,"_disposableMap",new Map);V(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=r,this._dataValidationFormulaService=o,this._formulaRefRangeService=l,this._initRefRange()}_getIdWithUnitId(e,t,a){return`${e}_${t}_${a}`}registerFormula(e,t,a){var u;const r=a.uid,o=this._getIdWithUnitId(e,t,r),l=(u=this._disposableMap.get(o))!=null?u:new Set,d=(c,m)=>{const h=this._dataValidationModel.getRuleById(e,t,r);if(!h)return{redos:[],undos:[]};const p=h[c];if(!p||p===m)return{redos:[],undos:[]};const v={unitId:e,subUnitId:t,ruleId:a.uid,payload:{type:D.UpdateRuleType.SETTING,payload:{type:h.type,formula1:h.formula1,formula2:h.formula2,[c]:m}}},f={unitId:e,subUnitId:t,ruleId:a.uid,payload:{type:D.UpdateRuleType.SETTING,payload:{type:h.type,formula1:h.formula1,formula2:h.formula2}}},I=[{id:D.UpdateDataValidationMutation.id,params:v}],_=[{id:D.UpdateDataValidationMutation.id,params:f}];return{redos:I,undos:_}};if(a.type===s.DataValidationType.CUSTOM){const c=this._dataValidationCustomFormulaService.getRuleFormulaInfo(e,t,r);if(c){const m=this._formulaRefRangeService.registerFormula(c.formula,h=>d("formula1",h));l.add(()=>m.dispose())}}if(a.type!==s.DataValidationType.CUSTOM){const c=this._dataValidationFormulaService.getRuleFormulaInfo(e,t,r);if(c){const[m,h]=c;if(m){const p=this._formulaRefRangeService.registerFormula(m.text,v=>d("formula1",v));l.add(()=>p.dispose())}if(h){const p=this._formulaRefRangeService.registerFormula(h.text,v=>d("formula1",v));l.add(()=>p.dispose())}}}}register(e,t,a){var u;const r=c=>{const m=[...a.ranges],p=m.map(f=>j.handleCommonDefaultRangeChangeWithEffectRefCommands(f,c)).filter(f=>!!f).flat();if(s.isRangesEqual(p,m))return{redos:[],undos:[]};if(p.length){const f={unitId:e,subUnitId:t,ruleId:a.uid,payload:{type:D.UpdateRuleType.RANGE,payload:p}},I=[{id:D.UpdateDataValidationMutation.id,params:f}],_=[{id:D.UpdateDataValidationMutation.id,params:{unitId:e,subUnitId:t,ruleId:a.uid,payload:{type:D.UpdateRuleType.RANGE,payload:m}}}];return{redos:I,undos:_}}else{const f={unitId:e,subUnitId:t,ruleId:a.uid},I=[{id:D.RemoveDataValidationMutation.id,params:f}],_=D.removeDataValidationUndoFactory(this._injector,f);return{redos:I,undos:_}}},o=[];a.ranges.forEach(c=>{const m=this._refRangeService.registerRefRange(c,r,e,t);o.push(()=>m.dispose())});const l=this._getIdWithUnitId(e,t,a.uid),d=(u=this._disposableMap.get(l))!=null?u:new Set;d.add(()=>o.forEach(c=>c())),this._disposableMap.set(l,d)}_initRefRange(){this.disposeWithMe(this._dataValidationModel.ruleChange$.subscribe(e=>{const{unitId:t,subUnitId:a,rule:r}=e;switch(e.type){case"add":{const o=e.rule;this.registerRule(e.unitId,e.subUnitId,o);break}case"remove":{const o=this._disposableMap.get(this._getIdWithUnitId(t,a,r.uid));o&&o.forEach(l=>l());break}case"update":{const o=e.rule,l=this._disposableMap.get(this._getIdWithUnitId(t,a,o.uid));l&&l.forEach(d=>d()),this.registerRule(e.unitId,e.subUnitId,o);break}}})),this.disposeWithMe(s.toDisposable(()=>{this._disposableMap.forEach(e=>{e.forEach(t=>t())}),this._disposableMap.clear()}))}},g.DataValidationRefRangeController=_r([s.OnLifecycle(s.LifecycleStages.Ready,g.DataValidationRefRangeController),Te(0,y.Inject(D.DataValidationModel)),Te(1,y.Inject(y.Injector)),Te(2,y.Inject(j.RefRangeService)),Te(3,y.Inject(g.DataValidationCustomFormulaService)),Te(4,y.Inject(g.DataValidationFormulaService)),Te(5,y.Inject(tt.FormulaRefRangeService))],g.DataValidationRefRangeController);var Vr=Object.defineProperty,Dr=Object.getOwnPropertyDescriptor,Rr=(i,n,e,t)=>{for(var a=t>1?void 0:t?Dr(n,e):n,r=i.length-1,o;r>=0;r--)(o=i[r])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&Vr(n,e,a),a},Dt=(i,n)=>(e,t)=>n(e,t,i);g.DataValidationAutoFillController=class extends s.Disposable{constructor(n,e,t){super(),this._autoFillService=n,this._dataValidationModel=e,this._injector=t,this._initAutoFill()}_initAutoFill(){const n=()=>({redos:[],undos:[]}),e=r=>{const{source:o,target:l,unitId:d,subUnitId:u}=r,c=this._dataValidationModel.ensureManager(d,u),m=c.getRuleObjectMatrix().clone(),h=U.virtualizeDiscreteRanges([o,l]),[p,v]=h.ranges,{mapFunc:f}=h,I={row:p.startRow,col:p.startColumn};U.getAutoFillRepeatRange(p,v).forEach(O=>{const F=O.repeatStartCell,B=O.relativeRange,$={startRow:I.row,startColumn:I.col,endColumn:I.col,endRow:I.row},k={startRow:F.row,startColumn:F.col,endColumn:F.col,endRow:F.row};s.Range.foreach(B,(A,b)=>{const H=s.Rectangle.getPositionRange({startRow:A,startColumn:b,endColumn:b,endRow:A},$),{row:Y,col:P}=f(H.startRow,H.startColumn),N=c.getRuleIdByLocation(Y,P);if(N){const q=s.Rectangle.getPositionRange({startRow:A,startColumn:b,endColumn:b,endRow:A},k),{row:ee,col:G}=f(q.startRow,q.startColumn);m.setValue(ee,G,N)}})});const C=m.diff(c.getDataValidations()),{redoMutations:R,undoMutations:M}=we(d,u,C,this._injector);return{undos:M,redos:R}},t=[s.DataValidationType.CHECKBOX],a={id:Fe,onBeforeFillData:r=>{const{source:o,unitId:l,subUnitId:d}=r,u=this._dataValidationModel.ensureManager(l,d);for(const c of o.rows)for(const m of o.cols){const h=u.getRuleByLocation(c,m);if(h&&t.indexOf(h.type)>-1){this._autoFillService.setDisableApplyType(U.APPLY_TYPE.SERIES,!0);return}}},onFillData:(r,o,l)=>l===U.APPLY_TYPE.COPY||l===U.APPLY_TYPE.ONLY_FORMAT||l===U.APPLY_TYPE.SERIES?e(r):n(),onAfterFillData:()=>{}};this.disposeWithMe(this._autoFillService.addHook(a))}},g.DataValidationAutoFillController=Rr([s.OnLifecycle(s.LifecycleStages.Ready,g.DataValidationAutoFillController),Dt(0,U.IAutoFillService),Dt(1,y.Inject(D.DataValidationModel)),Dt(2,y.Inject(y.Injector))],g.DataValidationAutoFillController);var Ir=Object.defineProperty,Cr=Object.getOwnPropertyDescriptor,yr=(i,n,e,t)=>{for(var a=t>1?void 0:t?Cr(n,e):n,r=i.length-1,o;r>=0;r--)(o=i[r])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&Ir(n,e,a),a},Rt=(i,n)=>(e,t)=>n(e,t,i);g.DataValidationCopyPasteController=class extends s.Disposable{constructor(e,t,a){super();V(this,"_copyInfo");this._sheetClipboardService=e,this._dataValidationModel=t,this._injector=a,this._initCopyPaste()}_initCopyPaste(){this._sheetClipboardService.addClipboardHook({id:Fe,onBeforeCopy:(e,t,a)=>this._collect(e,t,a),onPasteCells:(e,t,a,r)=>{const{copyType:o=U.COPY_TYPE.COPY,pasteType:l}=r,{range:d}=e||{},{range:u,unitId:c,subUnitId:m}=t;return this._generateMutations(u,{copyType:o,pasteType:l,copyRange:d,unitId:c,subUnitId:m})}})}_collect(e,t,a){const r=new s.ObjectMatrix;this._copyInfo={unitId:e,subUnitId:t,matrix:r};const o=this._dataValidationModel.ensureManager(e,t),l={get:this._injector.get.bind(this._injector)},d=U.rangeToDiscreteRange(a,l,e,t);if(!d)return;const{rows:u,cols:c}=d;u.forEach((m,h)=>{c.forEach((p,v)=>{const f=o.getRuleIdByLocation(m,p);r.setValue(h,v,f!=null?f:"")})})}_generateMutations(e,t){if(!this._copyInfo)return{redos:[],undos:[]};if(t.copyType===U.COPY_TYPE.CUT)return this._copyInfo=null,{redos:[],undos:[]};if(!this._copyInfo||!this._copyInfo.matrix.getSizeOf()||!t.copyRange)return{redos:[],undos:[]};if([U.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_COL_WIDTH,U.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_VALUE,U.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMAT,U.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMULA].includes(t.pasteType))return{redos:[],undos:[]};const{unitId:a,subUnitId:r}=this._copyInfo;if(t.unitId!==a||r!==t.subUnitId){const o=this._dataValidationModel.ensureManager(a,r),l=this._dataValidationModel.ensureManager(t.unitId,t.subUnitId),d=l.getRuleObjectMatrix().clone(),{ranges:[u,c],mapFunc:m}=U.virtualizeDiscreteRanges([t.copyRange,e]),h=U.getRepeatRange(u,c,!0),p=new Map;h.forEach(({startRange:I})=>{var _;(_=this._copyInfo)==null||_.matrix.forValue((C,R,M)=>{const O=s.Rectangle.getPositionRange({startRow:C,endRow:C,startColumn:R,endColumn:R},I),F=`${r}-${M}`,B=o.getRuleById(M);!l.getRuleById(F)&&B&&p.set(F,{...B,uid:F});const{row:$,col:k}=m(O.startRow,O.startColumn);d.setValue($,k,F)})});const{redoMutations:v,undoMutations:f}=we(t.unitId,t.subUnitId,d.diffWithAddition(l.getDataValidations(),p.values()),this._injector);return{redos:v,undos:f}}else{const o=this._dataValidationModel.ensureManager(a,r),l=o.getRuleObjectMatrix().clone(),{ranges:[d,u],mapFunc:c}=U.virtualizeDiscreteRanges([t.copyRange,e]);U.getRepeatRange(d,u,!0).forEach(({startRange:v})=>{var f;(f=this._copyInfo)==null||f.matrix.forValue((I,_,C)=>{const R=s.Rectangle.getPositionRange({startRow:I,endRow:I,startColumn:_,endColumn:_},v),{row:M,col:O}=c(R.startRow,R.startColumn);l.setValue(M,O,C)})});const{redoMutations:h,undoMutations:p}=we(a,r,l.diff(o.getDataValidations()),this._injector);return{redos:h,undos:p}}}},g.DataValidationCopyPasteController=yr([s.OnLifecycle(s.LifecycleStages.Ready,g.DataValidationCopyPasteController),Rt(0,U.ISheetClipboardService),Rt(1,y.Inject(D.DataValidationModel)),Rt(2,y.Inject(y.Injector))],g.DataValidationCopyPasteController);class It{constructor(n,e){V(this,"value");this._worksheet=e,this.value=n}addRule(n){const e=n.uid;n.ranges.forEach(t=>{s.Range.foreach(s.Range.transformRange(t,this._worksheet),(a,r)=>{this.value.setValue(a,r,e)})})}removeRange(n){n.forEach(e=>{s.Range.foreach(s.Range.transformRange(e,this._worksheet),(t,a)=>{this.value.realDeleteValue(t,a)})})}removeRule(n){n.ranges.forEach(e=>{s.Range.foreach(s.Range.transformRange(e,this._worksheet),(t,a)=>{this.value.setValue(t,a,"")})})}updateRange(n,e,t){const a=`${n}$`,r=e.map(l=>s.Range.transformRange(l,this._worksheet)),o=t.map(l=>s.Range.transformRange(l,this._worksheet));r.forEach(l=>{s.Range.foreach(l,(d,u)=>{this.value.getValue(d,u)===n&&this.value.setValue(d,u,a)})}),o.forEach(l=>{s.Range.foreach(l,(d,u)=>{this.value.setValue(d,u,n)})}),r.forEach(l=>{s.Range.foreach(l,(d,u)=>{this.value.getValue(d,u)===a&&this.value.realDeleteValue(d,u)})})}diff(n){const e=[];let t=0;return n.forEach((a,r)=>{const o=s.queryObjectMatrix(this.value,d=>d===a.uid),l=a.ranges;(o.length!==l.length||o.some((d,u)=>!s.Rectangle.equals(d,l[u])))&&e.push({type:"update",ruleId:a.uid,oldRanges:l,newRanges:o}),o.length===0&&(e.push({type:"delete",rule:a,index:r-t}),t++)}),e}diffWithAddition(n,e){const t=[];let a=0;return n.forEach((r,o)=>{const l=s.queryObjectMatrix(this.value,u=>u===r.uid),d=r.ranges;(l.length!==d.length||l.some((u,c)=>!s.Rectangle.equals(u,d[c])))&&t.push({type:"update",ruleId:r.uid,oldRanges:d,newRanges:l}),l.length===0&&(t.push({type:"delete",rule:r,index:o-a}),a++)}),Array.from(e).forEach(r=>{const o=s.queryObjectMatrix(this.value,l=>l===r.uid);t.push({type:"add",rule:{...r,ranges:o}})}),t}clone(){return new It(new s.ObjectMatrix(this.value.clone()),this._worksheet)}getValue(n,e){return this.value.getValue(n,e)}setValue(n,e,t){return this.value.setValue(n,e,t)}}class Mr extends D.DataValidationManager{constructor(e,t,a,r){super(e,t,a);V(this,"_ruleMatrix");V(this,"_dataValidatorRegistryService");V(this,"_dataValidationCacheService");V(this,"_dataValidationFormulaService");V(this,"_dataValidationCustomFormulaService");V(this,"_cache");V(this,"_dataValidationRefRangeController");this._injector=r,this._dataValidatorRegistryService=this._injector.get(D.DataValidatorRegistryService),this._dataValidationCacheService=this._injector.get(Ve),this._dataValidationFormulaService=this._injector.get(g.DataValidationFormulaService),this._dataValidationCustomFormulaService=this._injector.get(g.DataValidationCustomFormulaService),this._dataValidationRefRangeController=this._injector.get(g.DataValidationRefRangeController),this._cache=this._dataValidationCacheService.ensureCache(e,t);const l=this._injector.get(s.IUniverInstanceService).getUnit(e,s.UniverInstanceType.UNIVER_SHEET).getSheetBySheetId(t),d=new s.ObjectMatrix;a==null||a.forEach(u=>{const c=u.uid;u.ranges.forEach(m=>{s.Range.foreach(m,(h,p)=>{d.setValue(h,p,c)})})}),a==null||a.forEach(u=>{this._dataValidationRefRangeController.register(e,t,u)}),this._ruleMatrix=new It(d,l)}_addRuleSideEffect(e){var r;const{unitId:t,subUnitId:a}=this;(e.type===s.DataValidationType.LIST||e.type===s.DataValidationType.LIST_MULTIPLE)&&re.isReferenceString((r=e.formula1)!=null?r:"")&&(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(r=>{this._addRuleSideEffect(r)}),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,r){const{col:o,row:l,unitId:d,subUnitId:u}=a,c=t.uid,m=this.getValidator(t.type);if(m){const h=this._cache.getValue(l,o);return!h||h.value!==e?(this._cache.setValue(l,o,{value:e,status:s.DataValidationStatus.VALIDATING,ruleId:c}),m.validator({value:e,unitId:d,subUnitId:u,row:l,column:o},t).then(p=>{const v=p?s.DataValidationStatus.VALID:s.DataValidationStatus.INVALID;this._cache.setValue(l,o,{value:e,status:v,ruleId:c}),r(v,!0)}),s.DataValidationStatus.VALIDATING):(r(h.status,!1),h.status)}else return r(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 wr=Object.defineProperty,Or=Object.getOwnPropertyDescriptor,Tr=(i,n,e,t)=>{for(var a=t>1?void 0:t?Or(n,e):n,r=i.length-1,o;r>=0;r--)(o=i[r])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&wr(n,e,a),a},et=(i,n)=>(e,t)=>n(e,t,i);let $e=class extends s.Disposable{constructor(i,n,e,t){super(),this._resourceManagerService=i,this._univerInstanceService=n,this._dataValidationModel=e,this._injector=t,this._initDataValidationDataSource()}_createSheetDataValidationManager(i,n){return new Mr(i,n,[],this._injector)}_initDataValidationDataSource(){this._dataValidationModel.setManagerCreator(this._createSheetDataValidationManager.bind(this))}};$e=Tr([s.OnLifecycle(s.LifecycleStages.Starting,$e),et(0,s.IResourceManagerService),et(1,s.IUniverInstanceService),et(2,y.Inject(D.DataValidationModel)),et(3,y.Inject(y.Injector))],$e);var Er=Object.defineProperty,Fr=Object.getOwnPropertyDescriptor,br=(i,n,e,t)=>{for(var a=t>1?void 0:t?Fr(n,e):n,r=i.length-1,o;r>=0;r--)(o=i[r])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&Er(n,e,a),a},Ct=(i,n)=>(e,t)=>n(e,t,i);let We=class extends s.Disposable{constructor(i,n,e){super(),this._localeService=i,this._commandService=n,this._sheetPermissionInterceptorBaseController=e,this._commandExecutedListener()}_commandExecutedListener(){this.disposeWithMe(this._commandService.beforeCommandExecuted(i=>{i.id===D.AddDataValidationCommand.id&&(this._sheetPermissionInterceptorBaseController.permissionCheckWithRanges({workbookTypes:[j.WorkbookEditablePermission],rangeTypes:[j.RangeProtectionPermissionEditPoint],worksheetTypes:[j.WorksheetEditPermission,j.WorksheetSetCellStylePermission]})||this._sheetPermissionInterceptorBaseController.haveNotPermissionHandle(this._localeService.t("permission.dialog.setStyleErr"))),i.id===Ae.id&&(this._sheetPermissionInterceptorBaseController.permissionCheckWithRanges({workbookTypes:[j.WorkbookEditablePermission],rangeTypes:[j.RangeProtectionPermissionEditPoint],worksheetTypes:[j.WorksheetEditPermission,j.WorksheetSetCellStylePermission]},i.params.ranges)||this._sheetPermissionInterceptorBaseController.haveNotPermissionHandle(this._localeService.t("permission.dialog.setStyleErr")))}))}};We=br([s.OnLifecycle(s.LifecycleStages.Ready,We),Ct(0,y.Inject(s.LocaleService)),Ct(1,s.ICommandService),Ct(2,y.Inject(U.SheetPermissionInterceptorBaseController))],We);var Lr=Object.defineProperty,Nr=Object.getOwnPropertyDescriptor,Pr=(i,n,e,t)=>{for(var a=t>1?void 0:t?Nr(n,e):n,r=i.length-1,o;r>=0;r--)(o=i[r])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&Lr(n,e,a),a},yt=(i,n)=>(e,t)=>n(e,t,i);g.SheetsDataValidationValidatorService=class{constructor(n,e,t){this._univerInstanceService=n,this._dataValidationModel=e,this._dataValidationCacheService=t}async validatorCell(n,e,t,a){const r=this._univerInstanceService.getUnit(n,s.UniverInstanceType.UNIVER_SHEET);if(!r)throw new Error(`cannot find current workbook, unitId: ${n}`);const o=r.getSheetBySheetId(e);if(!o)throw new Error(`cannot find current worksheet, sheetId: ${e}`);const l=o.getCellRaw(t,a),d=this._dataValidationModel.ensureManager(n,e),u=d.getRuleByLocation(t,a);return u?new Promise(c=>{d.validator(te(l),u,{unitId:n,subUnitId:e,row:t,col:a},c)}):s.DataValidationStatus.VALID}async validatorWorksheet(n,e){const a=this._dataValidationModel.ensureManager(n,e).getDataValidations();return await Promise.all(a.map(r=>Promise.all(r.ranges.map(o=>{const l=[];return s.Range.foreach(o,(d,u)=>{l.push(this.validatorCell(n,e,d,u))}),l})))),this._dataValidationCacheService.ensureCache(n,e)}async validatorWorkbook(n){const e=this._dataValidationModel.getSubUnitIds(n),t=await Promise.all(e.map(r=>this.validatorWorksheet(n,r))),a={};return t.forEach((r,o)=>{a[e[o]]=r}),a}},g.SheetsDataValidationValidatorService=Pr([yt(0,s.IUniverInstanceService),yt(1,y.Inject(D.DataValidationModel)),yt(2,y.Inject(Ve))],g.SheetsDataValidationValidatorService);var ha=Object.defineProperty,Ar=Object.getOwnPropertyDescriptor,jr=(i,n,e)=>n in i?ha(i,n,{enumerable:!0,configurable:!0,writable:!0,value:e}):i[n]=e,Ur=(i,n,e,t)=>{for(var a=t>1?void 0:t?Ar(n,e):n,r=i.length-1,o;r>=0;r--)(o=i[r])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&ha(n,e,a),a},Mt=(i,n)=>(e,t)=>n(e,t,i),pa=(i,n,e)=>jr(i,typeof n!="symbol"?n+"":n,e);g.UniverSheetsDataValidationPlugin=class extends s.Plugin{constructor(n={},e,t,a){super(),this._config=n,this._injector=e,this._commandService=t,this._localeService=a,this._config=s.Tools.deepMerge({},la,this._config)}onStarting(n){[[se],[g.SheetDataValidationService],[Ve],[g.DataValidationFormulaService],[g.DataValidationCustomFormulaService],[he],[g.SheetsDataValidationValidatorService],[$e],[g.DataValidationController],[g.SheetsDataValidationRenderController,{useFactory:()=>this._injector.createInstance(g.SheetsDataValidationRenderController,this._config)}],[g.DataValidationAlertController],[g.DataValidationRefRangeController],[We],[g.DataValidationAutoFillController],[g.DataValidationCopyPasteController],[g.DataValidationFormulaController],[g.DataValidationRejectInputController]].forEach(e=>{n.add(e)}),[je,ze,Ae,ht,na,Ee,nt,xe,_e,at].forEach(e=>{this._commandService.registerCommand(e)})}},pa(g.UniverSheetsDataValidationPlugin,"pluginName",Fe),pa(g.UniverSheetsDataValidationPlugin,"type",s.UniverInstanceType.UNIVER_SHEET),g.UniverSheetsDataValidationPlugin=Ur([s.DependentOn(D.UniverDataValidationPlugin,j.UniverSheetsPlugin,U.UniverSheetsUIPlugin),Mt(1,y.Inject(y.Injector)),Mt(2,s.ICommandService),Mt(3,y.Inject(s.LocaleService))],g.UniverSheetsDataValidationPlugin);var fa=Object.defineProperty,Br=Object.getOwnPropertyDescriptor,$r=(i,n,e)=>n in i?fa(i,n,{enumerable:!0,configurable:!0,writable:!0,value:e}):i[n]=e,Wr=(i,n,e,t)=>{for(var a=t>1?void 0:t?Br(n,e):n,r=i.length-1,o;r>=0;r--)(o=i[r])&&(a=(t?o(n,e,a):o(a))||a);return t&&a&&fa(n,e,a),a},wt=(i,n)=>(e,t)=>n(e,t,i),va=(i,n,e)=>$r(i,typeof n!="symbol"?n+"":n,e);g.UniverSheetsDataValidationMobilePlugin=class extends s.Plugin{constructor(n={},e,t,a){super(),this._config=n,this._injector=e,this._commandService=t,this._localeService=a,this._config=s.Tools.deepMerge({},la,this._config)}onStarting(n){[[se],[g.SheetDataValidationService],[Ve],[g.DataValidationFormulaService],[g.DataValidationCustomFormulaService],[he],[g.SheetsDataValidationValidatorService],[$e],[g.DataValidationController],[Be,{useFactory:()=>this._injector.createInstance(Be,this._config)}],[g.DataValidationAlertController],[g.DataValidationRefRangeController],[We],[g.DataValidationCopyPasteController],[g.DataValidationFormulaController]].forEach(e=>{n.add(e)}),[je,ze,Ae,Ee,nt,xe,_e,at].forEach(e=>{this._commandService.registerCommand(e)})}},va(g.UniverSheetsDataValidationMobilePlugin,"pluginName",Fe),va(g.UniverSheetsDataValidationMobilePlugin,"type",s.UniverInstanceType.UNIVER_SHEET),g.UniverSheetsDataValidationMobilePlugin=Wr([s.DependentOn(D.UniverDataValidationPlugin,j.UniverSheetsPlugin,U.UniverSheetsUIPlugin),wt(1,y.Inject(y.Injector)),wt(2,s.ICommandService),wt(3,y.Inject(s.LocaleService))],g.UniverSheetsDataValidationMobilePlugin),Object.defineProperty(g,"ICommandService",{enumerable:!0,get:()=>s.ICommandService}),Object.defineProperty(g,"LocaleService",{enumerable:!0,get:()=>s.LocaleService}),Object.defineProperty(g,"Plugin",{enumerable:!0,get:()=>s.Plugin}),g.AddSheetDataValidationAndOpenCommand=ze,g.AddSheetDataValidationCommand=je,g.CloseValidationPanelOperation=xe,g.DATA_VALIDATION_PLUGIN_NAME=Fe,g.DataValidationCacheService=Ve,g.HideDataValidationDropdown=nt,g.OpenValidationPanelOperation=_e,g.ShowDataValidationDropdown=Ee,g.ToggleValidationPanelOperation=at,g.UpdateSheetDataValidationRangeCommand=Ae,Object.defineProperty(g,Symbol.toStringTag,{value:"Module"})});
|
|
9
|
+
*/var Va=E,Ra=Symbol.for("react.element"),Ia=Symbol.for("react.fragment"),Ca=Object.prototype.hasOwnProperty,ya=Va.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,Ma={key:!0,ref:!0,__self:!0,__source:!0};function Te(i,n,t){var e,a={},r=null,s=null;t!==void 0&&(r=""+t),n.key!==void 0&&(r=""+n.key),n.ref!==void 0&&(s=n.ref);for(e in n)Ca.call(n,e)&&!Ma.hasOwnProperty(e)&&(a[e]=n[e]);if(i&&i.defaultProps)for(e in n=i.defaultProps,n)a[e]===void 0&&(a[e]=n[e]);return{$$typeof:Ra,type:i,key:r,ref:s,props:a,_owner:ya.current}}$t.Fragment=Ia,$t.jsx=Te,$t.jsxs=Te,Oe.exports=$t;var S=Oe.exports;function wa(){const i=o.useDependency(mt),n=k.useObservable(i.activeDropdown$,i.activeDropdown),t=o.useDependency(k.ComponentManager);if(!n)return null;const{location:e,componentKey:a}=n,r=t.get(a),s=`${e.unitId}-${e.subUnitId}-${e.row}-${e.col}`;if(!r)return null;const l=()=>{i.hideDropdown()};return S.jsx(r,{location:e,hideFn:l},s)}const Ee="sheet.ui.dropdown";var Oa=Object.defineProperty,Ta=Object.getOwnPropertyDescriptor,Ea=(i,n,t,e)=>{for(var a=e>1?void 0:e?Ta(n,t):n,r=i.length-1,s;r>=0;r--)(s=i[r])&&(a=(e?s(n,t,a):s(a))||a);return e&&a&&Oa(n,t,a),a},Rt=(i,n)=>(t,e)=>n(t,e,i);let mt=class extends o.Disposable{constructor(n,t,e,a,r,s){super();I(this,"_activeDropdown");I(this,"_activeDropdown$",new vt.Subject);I(this,"_currentPopup",null);I(this,"activeDropdown$",this._activeDropdown$.asObservable());I(this,"_zenVisible",!1);this._canvasPopupManagerService=n,this._univerInstanceService=t,this._dataValidatorRegistryService=e,this._zenZoneService=a,this._renderManagerService=r,this._dataValidationModel=s,this._init(),this.disposeWithMe(()=>{this._activeDropdown$.complete()})}get activeDropdown(){return this._activeDropdown}_init(){this.disposeWithMe(this._zenZoneService.visible$.subscribe(n=>{this._zenVisible=n,n&&this.hideDropdown()}))}showDropdown(n,t=!0){const{location:e}=n,{row:a,col:r}=e;if(this._currentPopup&&this._currentPopup.dispose(),this._zenVisible)return;this._activeDropdown=n,this._activeDropdown$.next(this._activeDropdown);const s=this._renderManagerService.getRenderById(o.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),l=this._canvasPopupManagerService.attachPopupToCell(a,r,{componentKey:Ee,onClickOutside:()=>{t&&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 o.DisposableCollection;d.add(l),d.add({dispose:()=>{var u,c;(c=(u=this._activeDropdown)==null?void 0:u.onHide)==null||c.call(u)}}),this._currentPopup=d}hideDropdown(){this._activeDropdown&&(this._currentPopup&&this._currentPopup.dispose(),this._currentPopup=null,this._activeDropdown=null,this._activeDropdown$.next(null))}showDataValidationDropdown(n,t,e,a,r){const s=this._univerInstanceService.getUniverSheetInstance(n);if(!s)return;const l=s.getSheetBySheetId(t);if(!l)return;const u=this._dataValidationModel.ensureManager(n,t).getRuleByLocation(e,a);if(!u)return;const c=this._dataValidatorRegistryService.getValidatorItem(u.type);if(!c||!c.dropdown){this.hideDropdown();return}this.showDropdown({location:{workbook:s,worksheet:l,row:e,col:a,unitId:n,subUnitId:t},componentKey:c.dropdown,onHide:r})}};mt=Ea([Rt(0,o.Inject(B.SheetCanvasPopManagerService)),Rt(1,o.IUniverInstanceService),Rt(2,o.Inject(D.DataValidatorRegistryService)),Rt(3,k.IZenZoneService),Rt(4,K.IRenderManagerService),Rt(5,o.Inject(D.DataValidationModel))],mt);var ba=Object.defineProperty,Fa=Object.getOwnPropertyDescriptor,Na=(i,n,t,e)=>{for(var a=e>1?void 0:e?Fa(n,t):n,r=i.length-1,s;r>=0;r--)(s=i[r])&&(a=(e?s(n,t,a):s(a))||a);return e&&a&&ba(n,t,a),a},be=(i,n)=>(t,e)=>n(t,e,i);let st=class extends o.Disposable{constructor(n,t){super();I(this,"_open$",new vt.BehaviorSubject(!1));I(this,"open$",this._open$.pipe(vt.distinctUntilChanged()));I(this,"_activeRule");I(this,"_activeRule$",new vt.BehaviorSubject(void 0));I(this,"activeRule$",this._activeRule$.asObservable());I(this,"_closeDisposable",null);this._univerInstanceService=n,this._sidebarService=t,this.disposeWithMe(this._univerInstanceService.getCurrentTypeOfUnit$(o.UniverInstanceType.UNIVER_SHEET).pipe(vt.filter(e=>!e)).subscribe(()=>{this.close()}))}get activeRule(){return this._activeRule}get isOpen(){return this._open$.getValue()}dispose(){var n;super.dispose(),this._open$.next(!1),this._open$.complete(),this._activeRule$.complete(),(n=this._closeDisposable)==null||n.dispose()}open(){this._open$.next(!0)}close(){var n;this._open$.next(!1),(n=this._closeDisposable)==null||n.dispose()}setCloseDisposable(n){this._closeDisposable=o.toDisposable(()=>{n.dispose(),this._closeDisposable=null})}setActiveRule(n){this._activeRule=n,this._activeRule$.next(n)}};st=Na([be(0,o.IUniverInstanceService),be(1,k.ISidebarService)],st);const Fe="DataValidationPanel",gt={id:"data-validation.operation.open-validation-panel",type:o.CommandType.OPERATION,handler(i,n){if(!n)return!1;const{ruleId:t,isAdd:e}=n,a=i.get(st),r=i.get(D.DataValidationModel),s=i.get(o.IUniverInstanceService),l=i.get(k.ISidebarService),d=U.getSheetCommandTarget(s);if(!d)return!1;const{unitId:u,subUnitId:c}=d,h=t?r.getRuleById(u,c,t):void 0;a.open(),a.setActiveRule(h&&{unitId:u,subUnitId:c,rule:h});const p=l.open({header:{title:e?"dataValidation.panel.addTitle":"dataValidation.panel.title"},children:{label:Fe},width:312,onClose:()=>a.close()});return a.setCloseDisposable(p),!0}},Wt={id:"data-validation.operation.close-validation-panel",type:o.CommandType.OPERATION,handler(i){return i.get(st).close(),!0}},ee={id:"data-validation.operation.toggle-validation-panel",type:o.CommandType.OPERATION,handler(i){const n=i.get(o.ICommandService),t=i.get(st);return t.open(),t.isOpen?n.executeCommand(Wt.id):n.executeCommand(gt.id),!0}},Ot={type:o.CommandType.OPERATION,id:"sheet.operation.show-data-validation-dropdown",handler(i,n){if(!n)return!1;const t=i.get(mt),{unitId:e,subUnitId:a,row:r,column:s}=n,l=t.activeDropdown,d=l==null?void 0:l.location;return d&&d.unitId===e&&d.subUnitId===a&&d.row===r&&d.col===s||t.showDataValidationDropdown(e,a,r,s),!0}},ae={type:o.CommandType.OPERATION,id:"sheet.operation.hide-data-validation-dropdown",handler(i,n){return n?(i.get(mt).hideDropdown(),!0):!1}};class St{constructor(){I(this,"_cacheMatrix",new Map)}_ensureCache(n,t){let e=this._cacheMatrix.get(n);e||(e=new Map,this._cacheMatrix.set(n,e));let a=e.get(t);return a||(a=new o.ObjectMatrix,e.set(t,a)),a}ensureCache(n,t){return this._ensureCache(n,t)}addRule(n,t,e){this.markRangeDirty(n,t,e.ranges)}removeRule(n,t,e){this._deleteRange(n,t,e.ranges)}updateRuleRanges(n,t,e,a,r){const s=this._ensureCache(n,t);r.forEach(l=>{o.Range.foreach(l,(d,u)=>{const c=s.getValue(d,u);c&&(c.temp=!0)})}),a.forEach(l=>{o.Range.foreach(l,(d,u)=>{const c=s.getValue(d,u);c&&c.ruleId===e?c.temp=!1:s.setValue(d,u,void 0)})}),r.forEach(l=>{o.Range.foreach(l,(d,u)=>{const c=s.getValue(d,u);c&&c.temp===!0&&s.realDeleteValue(d,u)})})}markRangeDirty(n,t,e){const a=this._ensureCache(n,t);e.forEach(r=>{o.Range.foreach(r,(s,l)=>{a.setValue(s,l,void 0)})})}markCellDirty(n,t,e,a){this._ensureCache(n,t).setValue(e,a,void 0)}_deleteRange(n,t,e){const a=this._ensureCache(n,t);e.forEach(r=>{o.Range.foreach(r,(s,l)=>{a.realDeleteValue(s,l)})})}getValue(n,t,e,a){return this._ensureCache(n,t).getValue(e,a)}setValue(n,t,e,a,r){return this._ensureCache(n,t).setValue(e,a,r)}}var La=Object.defineProperty,Pa=Object.getOwnPropertyDescriptor,Aa=(i,n,t,e)=>{for(var a=e>1?void 0:e?Pa(n,t):n,r=i.length-1,s;r>=0;r--)(s=i[r])&&(a=(e?s(n,t,a):s(a))||a);return e&&a&&La(n,t,a),a},ne=(i,n)=>(t,e)=>n(t,e,i);g.DataValidationFormulaService=class extends o.Disposable{constructor(t,e,a){super();I(this,"_formulaRuleMap",new Map);this._registerOtherFormulaService=t,this._dataValidationCacheService=e,this._dataValidationModel=a,this._initFormulaResultHandler()}_initFormulaResultHandler(){this.disposeWithMe(this._registerOtherFormulaService.formulaResult$.subscribe(t=>{for(const e in t){const a=t[e];for(const r in a){const s=a[r],l=this._ensureRuleFormulaMap(e,r),d=this._dataValidationModel.ensureManager(e,r);s.forEach(u=>{var c,h;if(l.get((c=u.extra)==null?void 0:c.ruleId)){const p=d.getRuleById((h=u.extra)==null?void 0:h.ruleId);p&&this._dataValidationCacheService.markRangeDirty(e,r,p.ranges)}})}}}))}_ensureRuleFormulaMap(t,e){let a=this._formulaRuleMap.get(t);a||(a=new Map,this._formulaRuleMap.set(t,a));let r=a.get(e);return r||(r=new Map,a.set(e,r)),r}addRule(t,e,a,r,s){const l=o.isFormulaString(r),d=o.isFormulaString(s);if(!l&&!d)return;const u=this._ensureRuleFormulaMap(t,e),c=[void 0,void 0];if(l){const h=this._registerOtherFormulaService.registerFormula(t,e,r,{ruleId:a});c[0]={id:h,text:r}}if(d){const h=this._registerOtherFormulaService.registerFormula(t,e,s,{ruleId:a});c[1]={id:h,text:s}}u.set(a,c)}removeRule(t,e,a){const s=this._ensureRuleFormulaMap(t,e).get(a);if(!s)return;const[l,d]=s,u=[l==null?void 0:l.id,d==null?void 0:d.id].filter(Boolean);u.length&&this._registerOtherFormulaService.deleteFormula(t,e,u)}updateRuleFormulaText(t,e,a,r,s){const d=this._ensureRuleFormulaMap(t,e).get(a);if(!d){this.addRule(t,e,a,r,s);return}const[u,c]=d;if((u==null?void 0:u.text)!==r)if(u&&this._registerOtherFormulaService.deleteFormula(t,e,[u.id]),o.isFormulaString(r)){const h=this._registerOtherFormulaService.registerFormula(t,e,r,{ruleId:a});d[0]={text:r,id:h}}else d[0]=void 0;if((c==null?void 0:c.text)!==s)if(c&&this._registerOtherFormulaService.deleteFormula(t,e,[c.id]),o.isFormulaString(s)){const h=this._registerOtherFormulaService.registerFormula(t,e,s,{ruleId:a});d[1]={text:s,id:h}}else d[1]=void 0}getRuleFormulaResult(t,e,a){const s=this._ensureRuleFormulaMap(t,e).get(a);if(!s)return Promise.resolve(null);const l=async d=>d&&this._registerOtherFormulaService.getFormulaValue(t,e,d.id);return Promise.all([l(s[0]),l(s[1])])}getRuleFormulaResultSync(t,e,a){const s=this._ensureRuleFormulaMap(t,e).get(a);if(s)return s.map(l=>{if(l)return this._registerOtherFormulaService.getFormulaValueSync(t,e,l.id)})}getRuleFormulaInfo(t,e,a){return this._ensureRuleFormulaMap(t,e).get(a)}},g.DataValidationFormulaService=Aa([ne(0,o.Inject(te.RegisterOtherFormulaService)),ne(1,o.Inject(St)),ne(2,o.Inject(D.DataValidationModel))],g.DataValidationFormulaService);function rt(i){var n,t;return(t=(n=i==null?void 0:i[0])==null?void 0:n[0])==null?void 0:t.v}var ja=Object.defineProperty,Ua=Object.getOwnPropertyDescriptor,Ba=(i,n,t,e)=>{for(var a=e>1?void 0:e?Ua(n,t):n,r=i.length-1,s;r>=0;r--)(s=i[r])&&(a=(e?s(n,t,a):s(a))||a);return e&&a&&ja(n,t,a),a},ie=(i,n)=>(t,e)=>n(t,e,i);const Ht=6;let re=class{constructor(i,n,t){this._commandService=i,this._formulaService=n,this._themeService=t}_calc(i,n){var u,c,h;const{vt:t,ht:e}=n||{},a=i.endX-i.startX-Ht*2,r=i.endY-i.startY,s=((u=n==null?void 0:n.fs)!=null?u:10)*1.6;let l=0,d=0;switch(t){case o.VerticalAlign.TOP:d=0;break;case o.VerticalAlign.BOTTOM:d=0+(r-s);break;default:d=0+(r-s)/2;break}switch(e){case o.HorizontalAlign.LEFT:l=Ht;break;case o.HorizontalAlign.RIGHT:l=Ht+(a-s);break;default:l=Ht+(a-s)/2;break}return{left:i.startX+l,top:i.startY+d,width:((c=n==null?void 0:n.fs)!=null?c:10)*1.6,height:((h=n==null?void 0:n.fs)!=null?h:10)*1.6}}calcCellAutoHeight(i){var t;const{style:n}=i;return((t=n==null?void 0:n.fs)!=null?t:10)*1.6}async _parseFormula(i,n,t){var s,l;const{formula1:e=bt,formula2:a=Ft}=i,r=await this._formulaService.getRuleFormulaResult(n,t,i.uid);return{formula1:o.isFormulaString(e)?rt((s=r==null?void 0:r[0])==null?void 0:s.result):e,formula2:o.isFormulaString(a)?rt((l=r==null?void 0:r[1])==null?void 0:l.result):a}}drawWith(i,n){var $,b,W,x,A;const{style:t,data:e,primaryWithCoord:a,unitId:r,subUnitId:s}=n,l=a.isMergedMainCell?a.mergeInfo:a,d=J(e),u=($=e.dataValidation)==null?void 0:$.rule,c=(b=e.dataValidation)==null?void 0:b.validator;if(!u||!c)return;const h=this._themeService.getCurrentTheme();if(!c.skipDefaultFontRender(u,d,{unitId:r,subUnitId:s}))return;const p=c.parseFormulaSync(u,r,s),{formula1:f}=p,v=this._calc(l,t),{a:m,d:V}=i.getTransform(),_=K.fixLineWidthByScale(v.left,m),C=K.fixLineWidthByScale(v.top,V),R=K.Transform.create().composeMatrix({left:_,top:C,scaleX:1,scaleY:1,angle:0,skewX:0,skewY:0,flipX:!1,flipY:!1}),y=l.endX-l.startX,w=l.endY-l.startY;i.save(),i.beginPath(),i.rect(l.startX,l.startY,y,w),i.clip();const T=R.getMatrix();i.transform(T[0],T[1],T[2],T[3],T[4],T[5]);const F=((W=t==null?void 0:t.fs)!=null?W:10)*1.6,j=String(d)===String(f),P=h.hyacinth500;K.Checkbox.drawWith(i,{checked:j,width:F,height:F,fill:(A=(x=t==null?void 0:t.cl)==null?void 0:x.rgb)!=null?A:P}),i.restore()}isHit(i,n){const t=n.primaryWithCoord.isMergedMainCell?n.primaryWithCoord.mergeInfo:n.primaryWithCoord,e=this._calc(t,n.style),a=e.top,r=e.top+e.height,s=e.left,l=e.left+e.width,{x:d,y:u}=i;return d<=l&&d>=s&&u<=r&&u>=a}async onPointerDown(i,n){var p,f;if(n.button===2)return;const{primaryWithCoord:t,unitId:e,subUnitId:a,data:r}=i,s=J(r),l=(p=r.dataValidation)==null?void 0:p.rule,d=(f=r.dataValidation)==null?void 0:f.validator;if(!l||!d||!d.skipDefaultFontRender(l,s,{unitId:e,subUnitId:a}))return;const{formula1:u,formula2:c}=await this._parseFormula(l,e,a),h={range:{startColumn:t.actualColumn,endColumn:t.actualColumn,startRow:t.actualRow,endRow:t.actualRow},value:{v:String(s)===String(u)?c:u,p:null}};this._commandService.executeCommand(U.SetRangeValuesCommand.id,h)}};re=Ba([ie(0,o.ICommandService),ie(1,o.Inject(g.DataValidationFormulaService)),ie(2,o.Inject(o.ThemeService))],re);function $a(i){var d;const{unitId:n,subUnitId:t,value:e,onChange:a,showError:r,validResult:s}=i,l=r?s==null?void 0:s.formula1:"";return S.jsx(O.FormLayout,{error:l,children:S.jsx(k.TextEditor,{value:(d=e==null?void 0:e.formula1)!=null?d:"",id:o.createInternalEditorID(`dataValidation-custom-formula-${n}-${t}`),onChange:u=>{a==null||a({...e,formula1:u!=null?u:""})},onlyInputFormula:!0,openForSheetUnitId:n,openForSheetSubUnitId:t})})}const nt={dataValidationFormula:"univer-data-validation-formula",dataValidationFormulaAnd:"univer-data-validation-formula-and",dataValidationFormulaListItem:"univer-data-validation-formula-list-item",dataValidationFormulaListItemIcon:"univer-data-validation-formula-list-item-icon",dataValidationFormulaListItemDrag:"univer-data-validation-formula-list-item-drag",dataValidationFormulaListAdd:"univer-data-validation-formula-list-add",dataValidationFormulaColorSelect:"univer-data-validation-formula-color-select",dataValidationFormulaColorSelectPanel:"univer-data-validation-formula-color-select-panel",dataValidationFormulaColorItem:"univer-data-validation-formula-color-item"},Wa=i=>{const{isTwoFormula:n=!1,value:t,onChange:e,showError:a,validResult:r}=i,s=o.useDependency(o.LocaleService),l=a?r==null?void 0:r.formula1:"",d=a?r==null?void 0:r.formula2:"";return n?S.jsxs(S.Fragment,{children:[S.jsx(O.FormLayout,{error:l,children:S.jsx(O.Input,{className:nt.dataValidationFormula,placeholder:s.t("dataValidation.panel.formulaPlaceholder"),value:t==null?void 0:t.formula1,onChange:u=>{e==null||e({...t,formula1:u})}})}),S.jsx("div",{className:nt.dataValidationFormulaAnd,children:s.t("dataValidation.panel.formulaAnd")}),S.jsx(O.FormLayout,{error:d,children:S.jsx(O.Input,{className:nt.dataValidationFormula,placeholder:s.t("dataValidation.panel.formulaPlaceholder"),value:t==null?void 0:t.formula2,onChange:u=>{e==null||e({...t,formula2:u})}})})]}):S.jsx(O.FormLayout,{error:l,children:S.jsx(O.Input,{className:nt.dataValidationFormula,placeholder:s.t("dataValidation.panel.formulaPlaceholder"),value:t==null?void 0:t.formula1,onChange:u=>{e==null||e({formula1:u})}})})};var it=function(){return it=Object.assign||function(i){for(var n,t=1,e=arguments.length;t<e;t++){n=arguments[t];for(var a in n)Object.prototype.hasOwnProperty.call(n,a)&&(i[a]=n[a])}return i},it.apply(this,arguments)},Ha=function(i,n){var t={};for(var e in i)Object.prototype.hasOwnProperty.call(i,e)&&n.indexOf(e)<0&&(t[e]=i[e]);if(i!=null&&typeof Object.getOwnPropertySymbols=="function")for(var a=0,e=Object.getOwnPropertySymbols(i);a<e.length;a++)n.indexOf(e[a])<0&&Object.prototype.propertyIsEnumerable.call(i,e[a])&&(t[e[a]]=i[e[a]]);return t},ht=E.forwardRef(function(i,n){var t=i.icon,e=i.id,a=i.className,r=i.extend,s=Ha(i,["icon","id","className","extend"]),l="univerjs-icon univerjs-icon-".concat(e," ").concat(a||"").trim(),d=E.useRef("_".concat(Ya()));return Ne(t,"".concat(e),{defIds:t.defIds,idSuffix:d.current},it({ref:n,className:l},s),r)});function Ne(i,n,t,e,a){return E.createElement(i.tag,it(it({key:n},xa(i,t,a)),e),(ka(i,t).children||[]).map(function(r,s){return Ne(r,"".concat(n,"-").concat(i.tag,"-").concat(s),t,void 0,a)}))}function xa(i,n,t){var e=it({},i.attrs);t!=null&&t.colorChannel1&&e.fill==="colorChannel1"&&(e.fill=t.colorChannel1);var a=n.defIds;return!a||a.length===0||(i.tag==="use"&&e["xlink:href"]&&(e["xlink:href"]=e["xlink:href"]+n.idSuffix),Object.entries(e).forEach(function(r){var s=r[0],l=r[1];typeof l=="string"&&(e[s]=l.replace(/url\(#(.*)\)/,"url(#$1".concat(n.idSuffix,")")))})),e}function ka(i,n){var t,e=n.defIds;return!e||e.length===0?i:i.tag==="defs"&&(!((t=i.children)===null||t===void 0)&&t.length)?it(it({},i),{children:i.children.map(function(a){return typeof a.attrs.id=="string"&&e&&e.indexOf(a.attrs.id)>-1?it(it({},a),{attrs:it(it({},a.attrs),{id:a.attrs.id+n.idSuffix})}):a})}):i}function Ya(){return Math.random().toString(36).substring(2,8)}ht.displayName="UniverIcon";var qa={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"}}]},Le=E.forwardRef(function(i,n){return E.createElement(ht,Object.assign({},i,{id:"check-mark-single",ref:n,icon:qa}))});Le.displayName="CheckMarkSingle";var Xa={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"}}]},Pe=E.forwardRef(function(i,n){return E.createElement(ht,Object.assign({},i,{id:"data-validation-single",ref:n,icon:Xa}))});Pe.displayName="DataValidationSingle";var Ga={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"}}]},oe=E.forwardRef(function(i,n){return E.createElement(ht,Object.assign({},i,{id:"delete-single",ref:n,icon:Ga}))});oe.displayName="DeleteSingle";var za={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M8.6 1.99991C8.60001 1.66854 8.33138 1.39991 8.00001 1.3999C7.66864 1.3999 7.40001 1.66853 7.4 1.9999L7.39996 7.3999H1.9999C1.66853 7.3999 1.3999 7.66853 1.3999 7.9999C1.3999 8.33127 1.66853 8.5999 1.9999 8.5999H7.39995L7.3999 13.9999C7.3999 14.3313 7.66853 14.5999 7.9999 14.5999C8.33127 14.5999 8.5999 14.3313 8.5999 13.9999L8.59995 8.5999H13.9999C14.3313 8.5999 14.5999 8.33127 14.5999 7.9999C14.5999 7.66853 14.3313 7.3999 13.9999 7.3999H8.59996L8.6 1.99991Z"}}]},Ae=E.forwardRef(function(i,n){return E.createElement(ht,Object.assign({},i,{id:"increase-single",ref:n,icon:za}))});Ae.displayName="IncreaseSingle";var Ka={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"}}]},je=E.forwardRef(function(i,n){return E.createElement(ht,Object.assign({},i,{id:"more-down-single",ref:n,icon:Ka}))});je.displayName="MoreDownSingle";var Qa={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"}}]},Ue=E.forwardRef(function(i,n){return E.createElement(ht,Object.assign({},i,{id:"more-up-single",ref:n,icon:Qa}))});Ue.displayName="MoreUpSingle";var Za={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"}}]}]},Be=E.forwardRef(function(i,n){return E.createElement(ht,Object.assign({},i,{id:"sequence-single",ref:n,icon:Za}))});Be.displayName="SequenceSingle";function $e(i){return i.filter(Boolean).join(",")}function It(i){return i.split(",").filter(Boolean)}function Ja(i){const n=J(i);return n==null?"":n.toString()}const Tt="SHEET_DATA_VALIDATION_PLUGIN",_t="#ECECEC";var xt=(i=>(i[i.View=0]="View",i[i.Edit=1]="Edit",i[i.ManageCollaborator=2]="ManageCollaborator",i[i.Print=3]="Print",i[i.Duplicate=4]="Duplicate",i[i.Comment=5]="Comment",i[i.Copy=6]="Copy",i[i.Share=7]="Share",i[i.Export=8]="Export",i[i.MoveWorksheet=9]="MoveWorksheet",i[i.DeleteWorksheet=10]="DeleteWorksheet",i[i.HideWorksheet=11]="HideWorksheet",i[i.RenameWorksheet=12]="RenameWorksheet",i[i.CreateWorksheet=13]="CreateWorksheet",i[i.SetWorksheetStyle=14]="SetWorksheetStyle",i[i.EditWorksheetCell=15]="EditWorksheetCell",i[i.InsertHyperlink=16]="InsertHyperlink",i[i.Sort=17]="Sort",i[i.Filter=18]="Filter",i[i.PivotTable=19]="PivotTable",i[i.FloatImg=20]="FloatImg",i[i.History=21]="History",i[i.RwHgtClWdt=22]="RwHgtClWdt",i[i.ViemRwHgtClWdt=23]="ViemRwHgtClWdt",i[i.ViewFilter=24]="ViewFilter",i[i.MoveSheet=25]="MoveSheet",i[i.DeleteSheet=26]="DeleteSheet",i[i.HideSheet=27]="HideSheet",i[i.CopySheet=28]="CopySheet",i[i.RenameSheet=29]="RenameSheet",i[i.CreateSheet=30]="CreateSheet",i[i.SelectProtectedCells=31]="SelectProtectedCells",i[i.SelectUnProtectedCells=32]="SelectUnProtectedCells",i[i.SetCellStyle=33]="SetCellStyle",i[i.SetCellValue=34]="SetCellValue",i[i.SetRowStyle=35]="SetRowStyle",i[i.SetColumnStyle=36]="SetColumnStyle",i[i.InsertRow=37]="InsertRow",i[i.InsertColumn=38]="InsertColumn",i[i.DeleteRow=39]="DeleteRow",i[i.DeleteColumn=40]="DeleteColumn",i[i.EditExtraObject=41]="EditExtraObject",i[i.Delete=42]="Delete",i[i.RecoverHistory=43]="RecoverHistory",i[i.ViewHistory=44]="ViewHistory",i[i.UNRECOGNIZED=-1]="UNRECOGNIZED",i))(xt||{}),tn=Object.defineProperty,en=Object.getOwnPropertyDescriptor,an=(i,n,t,e)=>{for(var a=e>1?void 0:e?en(n,t):n,r=i.length-1,s;r>=0;r--)(s=i[r])&&(a=(e?s(n,t,a):s(a))||a);return e&&a&&tn(n,t,a),a},se=(i,n)=>(t,e)=>n(t,e,i);g.DataValidationFormulaController=class extends o.Disposable{constructor(n,t,e){super(),this._univerInstanceService=n,this._permissionService=t,this._lexerTreeBuilder=e}getFormulaRefCheck(n){var e,a;const t=this._lexerTreeBuilder.sequenceNodesBuilder(n);if(!t)return!0;for(let r=0;r<t.length;r++){const s=t[r];if(typeof s=="string")continue;const{token:l}=s,d=at.deserializeRangeWithSheet(l),u=this._univerInstanceService.getCurrentUnitForType(o.UniverInstanceType.UNIVER_SHEET);let c=u.getActiveSheet();const h=u.getUnitId();if(d.sheetName){if(c=u.getSheetBySheetName(d.sheetName),!c)return!1;const V=c==null?void 0:c.getSheetId();if(!this._permissionService.getPermissionPoint(new U.WorksheetViewPermission(h,V).id))return!1}if(!c)return!1;const{startRow:p,endRow:f,startColumn:v,endColumn:m}=d.range;for(let V=p;V<=f;V++)for(let _=v;_<=m;_++){const C=(a=(e=c.getCell(V,_))==null?void 0:e.selectionProtection)==null?void 0:a[0];if((C==null?void 0:C[xt.View])===!1)return!1}}return!0}},g.DataValidationFormulaController=an([o.OnLifecycle(o.LifecycleStages.Rendered,g.DataValidationFormulaController),se(0,o.IUniverInstanceService),se(1,o.IPermissionService),se(2,o.Inject(at.LexerTreeBuilder))],g.DataValidationFormulaController);const nn=["#FFFFFF","#FEE7E7","#FEF0E6","#EFFBD0","#E4F4FE","#E8ECFD","#F1EAFA","#FDE8F3","#E5E5E5","#FDCECE","#FDC49B","#DEF6A2","#9FDAFF","#D0D9FB","#E3D5F6","#FBD0E8","#656565","#FE4B4B","#FF8C51","#8BBB11","#0B9EFB","#3A60F7","#9E6DE3","#F248A6"],rn=i=>{const{value:n,onChange:t,disabled:e}=i,[a,r]=E.useState(!1);return S.jsx(O.Select,{disabled:e,open:a,onDropdownVisibleChange:r,dropdownStyle:{width:112},className:nt.dataValidationFormulaColorSelect,value:n,onChange:t,labelRender:s=>S.jsx("div",{className:nt.dataValidationFormulaColorItem,style:{background:s.value,marginTop:5}}),dropdownRender:()=>S.jsx("div",{className:nt.dataValidationFormulaColorSelectPanel,children:nn.map(s=>S.jsx("div",{onClick:()=>{t(s),r(!1)},className:nt.dataValidationFormulaColorItem,style:{background:s}},s))})})},We=i=>{const{item:n,commonProps:t,style:e}=i,{onItemChange:a,onItemDelete:r}=t;return S.jsxs("div",{className:nt.dataValidationFormulaListItem,style:e,children:[n.isRef?null:S.jsx("div",{className:ga(nt.dataValidationFormulaListItemDrag,"draggableHandle"),children:S.jsx(Be,{})}),S.jsx(rn,{value:n.color,onChange:s=>{a(n.id,n.label,s)}}),S.jsx(O.Input,{disabled:n.isRef,value:n.label,onChange:s=>{a(n.id,s,n.color)}}),n.isRef?null:S.jsx("div",{className:nt.dataValidationFormulaListItemIcon,children:S.jsx(oe,{onClick:()=>r(n.id)})})]})};function on(i){const{value:n,onChange:t=()=>{},unitId:e,subUnitId:a,validResult:r,showError:s,ruleId:l}=i,{formula1:d="",formula2:u=""}=n||{},c=E.useRef(null),[h,p]=E.useState(()=>o.isFormulaString(d)?"1":"0"),[f,v]=E.useState(h==="1"?d:"="),[m,V]=E.useState(h==="1"?d:"="),_=o.useDependency(o.LocaleService),C=o.useDependency(D.DataValidatorRegistryService),R=o.useDependency(D.DataValidationModel),y=o.useDependency(g.DataValidationFormulaController),[w,T]=E.useState(()=>u.split(",")),F=C.getValidatorItem(o.DataValidationType.LIST),[j,P]=E.useState([]),[$,b]=E.useState(""),W=s?r==null?void 0:r.formula1:"",x=k.useObservable(R.ruleChange$),A=k.useEvent(t);E.useEffect(()=>{(async()=>{await new Promise(z=>{setTimeout(()=>z(!0),100)});const N=R.getRuleById(e,a,l),X=N==null?void 0:N.formula1;if(o.isFormulaString(X)&&F&&N){const z=await F.getListAsync(N,e,a);P(z)}})()},[R,x,F,l,a,e]),E.useEffect(()=>{o.isFormulaString(d)&&d!==m&&(v(d),V(m))},[m,d]);const[L,Y]=E.useState(()=>{const N=h!=="1"?It(d):[],X=u.split(",");return N.map((z,et)=>({label:z,color:X[et]||_t,isRef:!1,id:o.Tools.generateRandomId(4)}))}),Z=(N,X,z)=>{const et=L.find(ct=>ct.id===N);et&&(et.label=X,et.color=z,Y([...L]))},q=N=>{const X=L.findIndex(z=>z.id===N);X!==-1&&(L.splice(X,1),Y([...L]))},M=u.split(","),H=E.useMemo(()=>j.map((N,X)=>({label:N,color:M[X]||_t,id:`${X}`,isRef:!0})),[M,j]),tt=(N,X,z)=>{const et=[...w];et[+N]=z,T(et),A({formula1:d,formula2:et.join(",")})},G=()=>{Y([...L,{label:"",color:_t,isRef:!1,id:o.Tools.generateRandomId(4)}])};E.useEffect(()=>{if(h==="1")return;const N=new Set,X=[];L.map(z=>({labelList:z.label.split(","),item:z})).forEach(({item:z,labelList:et})=>{et.forEach(ct=>{N.has(ct)||(N.add(ct),X.push({label:ct,color:z.color}))})}),A({formula1:$e(X.map(z=>z.label)),formula2:X.map(z=>z.color===_t?"":z.color).join(",")})},[L,A,h,m,w]);const dt=E.useMemo(()=>async N=>{if(!o.isFormulaString(N)){A==null||A({formula1:"",formula2:u});return}y.getFormulaRefCheck(N)?(A==null||A({formula1:o.isFormulaString(N)?N:"",formula2:u}),b("")):(A==null||A({formula1:"",formula2:u}),v("="),b(_.t("dataValidation.validFail.formulaError")))},[u,A]);return S.jsxs(S.Fragment,{children:[S.jsx(O.FormLayout,{label:_.t("dataValidation.list.options"),children:S.jsxs(O.RadioGroup,{value:h,onChange:N=>{p(N),v(m),N==="1"&&A({formula1:m==="="?"":m,formula2:w.join(",")})},children:[S.jsx(O.Radio,{value:"0",children:_.t("dataValidation.list.customOptions")}),S.jsx(O.Radio,{value:"1",children:_.t("dataValidation.list.refOptions")})]})}),h==="1"?S.jsxs(S.Fragment,{children:[S.jsx(O.FormLayout,{error:W||$,children:S.jsx(k.TextEditor,{id:o.createInternalEditorID(`list-ref-range-${e}-${a}`),value:f,openForSheetUnitId:e,openForSheetSubUnitId:a,onlyInputFormula:!0,onChange:async N=>{const X=N!=null?N:"";V(X),dt(X)}})}),S.jsx(O.FormLayout,{children:S.jsx("div",{ref:c,children:H.map(N=>S.jsx(We,{item:N,commonProps:{onItemChange:tt},style:{marginBottom:12}},N.id))})})]}):S.jsx(O.FormLayout,{error:W,children:S.jsxs("div",{ref:c,style:{marginTop:"-12px"},children:[S.jsx(O.DraggableList,{list:L,onListChange:Y,rowHeight:32,margin:[0,12],draggableHandle:".draggableHandle",itemRender:N=>S.jsx(We,{item:N,commonProps:{onItemChange:Z,onItemDelete:q}},N.id),idKey:"id"}),S.jsxs("a",{className:nt.dataValidationFormulaListAdd,onClick:G,children:[S.jsx(Ae,{}),_.t("dataValidation.list.add")]})]})})]})}function sn(i){const{value:n,onChange:t,showError:e,validResult:a}=i,r=o.useDependency(o.LocaleService),s=e?a==null?void 0:a.formula1:"",l=e?a==null?void 0:a.formula2:"",[d,u]=E.useState(!((n==null?void 0:n.formula1)===void 0&&(n==null?void 0:n.formula2)===void 0));return S.jsxs(S.Fragment,{children:[S.jsx(O.FormLayout,{children:S.jsx(O.Checkbox,{checked:d,onChange:c=>{c?u(!0):(u(!1),t==null||t({...n,formula1:void 0,formula2:void 0}))},children:r.t("dataValidation.checkbox.tips")})}),d?S.jsx(O.FormLayout,{label:r.t("dataValidation.checkbox.checked"),error:s,children:S.jsx(O.Input,{className:nt.dataValidationFormula,placeholder:r.t("dataValidation.panel.valuePlaceholder"),value:n==null?void 0:n.formula1,onChange:c=>{t==null||t({...n,formula1:c||void 0})}})}):null,d?S.jsx(O.FormLayout,{label:r.t("dataValidation.checkbox.unchecked"),error:l,children:S.jsx(O.Input,{className:nt.dataValidationFormula,placeholder:r.t("dataValidation.panel.valuePlaceholder"),value:n==null?void 0:n.formula2,onChange:c=>{t==null||t({...n,formula2:c||void 0})}})}):null]})}const He="data-validation.custom-formula-input",Et="data-validation.formula-input",xe="data-validation.list-formula-input",ke="data-validation.checkbox-formula-input",ln=[[He,$a],[Et,Wa],[xe,on],[ke,sn]],bt=1,Ft=0;function Ye(i,n){return o.Tools.isBlank(i)?n.t("dataValidation.validFail.value"):o.isFormulaString(i)?n.t("dataValidation.validFail.primitive"):""}class dn extends D.BaseDataValidator{constructor(){super(...arguments);I(this,"id",o.DataValidationType.CHECKBOX);I(this,"title","dataValidation.checkbox.title");I(this,"operators",[]);I(this,"scopes",["sheet"]);I(this,"formulaInput",ke);I(this,"canvasRender",this.injector.createInstance(re));I(this,"_formulaService",this.injector.get(g.DataValidationFormulaService))}skipDefaultFontRender(t,e,a){const{formula1:r,formula2:s}=this.parseFormulaSync(t,a.unitId,a.subUnitId),l=`${e!=null?e:""}`;return!l||l===`${r}`||l===`${s}`}validatorFormula(t,e,a){const{formula1:r,formula2:s}=t,l=r===s;if(o.Tools.isBlank(r)&&o.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=Ye(r,this.localeService),u=Ye(s,this.localeService);return{success:!d&&!u,formula1:d,formula2:u}}async parseFormula(t,e,a){var d,u;const{formula1:r=bt,formula2:s=Ft}=t,l=await this._formulaService.getRuleFormulaResult(e,a,t.uid);return{formula1:o.isFormulaString(r)?rt((d=l==null?void 0:l[0])==null?void 0:d.result):r,formula2:o.isFormulaString(s)?rt((u=l==null?void 0:l[1])==null?void 0:u.result):s}}parseFormulaSync(t,e,a){var d,u;const{formula1:r=bt,formula2:s=Ft}=t,l=this._formulaService.getRuleFormulaResultSync(e,a,t.uid);return{formula1:o.isFormulaString(r)?rt((d=l==null?void 0:l[0])==null?void 0:d.result):r,formula2:o.isFormulaString(s)?rt((u=l==null?void 0:l[1])==null?void 0:u.result):s}}async isValidType(t,e,a){const{value:r,unitId:s,subUnitId:l}=t,{formula1:d,formula2:u}=await this.parseFormula(a,s,l);return!o.Tools.isDefine(d)||!o.Tools.isDefine(u)?!0:o.Tools.isDefine(r)&&(String(r)===String(d)||String(r)===String(u))}generateRuleErrorMessage(t){return this.localeService.t("dataValidation.checkbox.error")}}const kt=[o.DataValidationOperator.BETWEEN,o.DataValidationOperator.NOT_BETWEEN];function un(i){return new Date((i-25569)*86400).getTime()}const qe=i=>i/86400+25569,le={dataValidationOptionsButton:"univer-data-validation-options-button",dataValidationOptionsButtonIcon:"univer-data-validation-options-button-icon"};function cn(i){var u;const n=o.useDependency(o.LocaleService),t=o.useDependency(k.ComponentManager),{value:e,onChange:a,extraComponent:r}=i,[s,l]=E.useState(!1),d=r?t.get(r):null;return S.jsxs(S.Fragment,{children:[S.jsxs("div",{className:le.dataValidationOptionsButton,onClick:()=>l(!s),children:[n.t("dataValidation.panel.options"),s?S.jsx(Ue,{className:le.dataValidationOptionsButtonIcon}):S.jsx(je,{className:le.dataValidationOptionsButtonIcon})]}),s&&S.jsxs(S.Fragment,{children:[d?S.jsx(d,{value:e,onChange:a}):null,S.jsx(O.FormLayout,{label:n.t("dataValidation.panel.invalid"),children:S.jsxs(O.RadioGroup,{value:`${(u=e.errorStyle)!=null?u:o.DataValidationErrorStyle.WARNING}`,onChange:c=>a({...e,errorStyle:+c}),children:[S.jsx(O.Radio,{value:`${o.DataValidationErrorStyle.WARNING}`,children:n.t("dataValidation.panel.showWarning")}),S.jsx(O.Radio,{value:`${o.DataValidationErrorStyle.STOP}`,children:n.t("dataValidation.panel.rejectInput")})]})}),S.jsx(O.FormLayout,{label:n.t("dataValidation.panel.messageInfo"),children:S.jsx(O.Checkbox,{checked:e.showInputMessage,onChange:()=>a({...e,showInputMessage:!e.showInputMessage}),children:n.t("dataValidation.panel.showInfo")})}),e.showInputMessage?S.jsx(O.FormLayout,{children:S.jsx(O.Input,{value:e.error,onChange:c=>a({...e,error:c})})}):null]})]})}const Ct={dataValidationDetailFormItem:"univer-data-validation-detail-form-item",dataValidationDetailButtons:"univer-data-validation-detail-buttons",dataValidationDetailButton:"univer-data-validation-detail-button"},mn=i=>o.debounce(async(n,t,e,a)=>{const r=await i.executeCommand(n,t,e);a==null||a(r)},275);function hn(){const[i,n]=E.useState(0),t=o.useDependency(st),e=k.useObservable(t.activeRule$,t.activeRule),{unitId:a,subUnitId:r,rule:s}=e||{},l=s.uid,d=o.useDependency(D.DataValidatorRegistryService),u=o.useDependency(k.ComponentManager),c=o.useDependency(o.ICommandService),h=o.useDependency(D.DataValidationModel),p=o.useDependency(o.LocaleService),[f,v]=E.useState(s),m=d.getValidatorItem(f.type),[V,_]=E.useState(!1),C=d.getValidatorsByScope(D.DataValidatorRegistryScope.SHEET),[R,y]=E.useState(()=>f.ranges.map(M=>({unitId:"",sheetId:"",range:M}))),w=E.useMemo(()=>mn(c),[c]);if(E.useEffect(()=>{c.onCommandExecuted(M=>{(M.id===o.UndoCommand.id||M.id===o.RedoCommand.id)&&setTimeout(()=>{const H=h.getRuleById(a,r,l);n(tt=>tt+1),H&&(v(H),y(H.ranges.map(tt=>({unitId:"",sheetId:"",range:tt}))))},20)})},[c,h,l,r,a]),!m)return null;const T=m.operators,F=m.operatorNames,j=f.operator?D.TWO_FORMULA_OPERATOR_COUNT.includes(f.operator):!1,P=()=>{m.validatorFormula(f,a,r).success?t.setActiveRule(null):_(!0)},$=k.useEvent(M=>{if(o.isUnitRangesEqual(M,R))return;y(M);const H=M.filter(G=>(!G.unitId||G.unitId===a)&&(!G.sheetId||G.sheetId===r)).map(G=>G.range);if(v({...f,ranges:H}),H.length===0)return;const tt={unitId:a,subUnitId:r,ruleId:l,ranges:H};w(Pt.id,tt)}),b=M=>{if(o.shallowEqual(M,D.getRuleSetting(f)))return;v({...f,...M});const H={unitId:a,subUnitId:r,ruleId:l,setting:M};w(he.id,H,void 0)},W=async()=>{await c.executeCommand(D.RemoveDataValidationCommand.id,{ruleId:l,unitId:a,subUnitId:r}),t.setActiveRule(null)},x={type:f.type,operator:f.operator,formula1:f.formula1,formula2:f.formula2,allowBlank:f.allowBlank},A=M=>{const H=d.getValidatorItem(M);if(!H)return;const tt=H.operators,G=h.getRuleById(a,r,l),dt=M===(G==null?void 0:G.type)||M.includes("list")&&(G!=null&&G.type.includes("list"))?{...G,type:M}:{...f,type:M,operator:tt[0],formula1:void 0,formula2:void 0};v(dt),c.executeCommand(he.id,{unitId:a,subUnitId:r,ruleId:f.uid,setting:D.getRuleSetting(dt)})},L=u.get(m.formulaInput),Y=E.useMemo(()=>R.map(M=>at.serializeRange(M.range)).join(","),[]),Z=D.getRuleOptions(f),q=M=>{o.shallowEqual(M,D.getRuleOptions(f))||(v({...f,...M}),w(ra.id,{unitId:a,subUnitId:r,ruleId:l,options:M}))};return S.jsxs("div",{children:[S.jsx(O.FormLayout,{label:p.t("dataValidation.panel.range"),children:S.jsx(k.RangeSelector,{className:Ct.dataValidationDetailFormItem,value:Y,id:o.createInternalEditorID("data-validation-detail"),openForSheetUnitId:a,openForSheetSubUnitId:r,onChange:M=>{M.some(H=>!o.isValidRange(H.range)||H.range.endColumn<H.range.startColumn||H.range.endRow<H.range.startRow)||$(M)}},i)}),S.jsx(O.FormLayout,{label:p.t("dataValidation.panel.type"),children:S.jsx(O.Select,{options:C==null?void 0:C.map(M=>({label:p.t(M.title),value:M.id})),value:f.type,onChange:A,className:Ct.dataValidationDetailFormItem})}),T!=null&&T.length?S.jsx(O.FormLayout,{label:p.t("dataValidation.panel.operator"),children:S.jsx(O.Select,{options:T.map((M,H)=>({value:`${M}`,label:F[H]})),value:`${f.operator}`,onChange:M=>{b({...x,operator:M})},className:Ct.dataValidationDetailFormItem})}):null,L?S.jsx(L,{isTwoFormula:j,value:{formula1:f.formula1,formula2:f.formula2},onChange:M=>{b({...x,...M})},showError:V,validResult:m.validatorFormula(f,a,r),unitId:a,subUnitId:r,ruleId:l},i+f.type):null,S.jsx(cn,{value:Z,onChange:q,extraComponent:m.optionsInput}),S.jsxs("div",{className:Ct.dataValidationDetailButtons,children:[S.jsx(O.Button,{className:Ct.dataValidationDetailButton,onClick:W,children:p.t("dataValidation.panel.removeRule")}),S.jsx(O.Button,{className:Ct.dataValidationDetailButton,type:"primary",onClick:P,children:p.t("dataValidation.panel.done")})]})]})}const Yt={dataValidationItemContainer:"univer-data-validation-item-container",dataValidationItemTitle:"univer-data-validation-item-title",dataValidationItemContent:"univer-data-validation-item-content",dataValidationItemIcon:"univer-data-validation-item-icon"},fn=i=>{const{rule:n,onClick:t,unitId:e,subUnitId:a,disable:r}=i,s=o.useDependency(D.DataValidatorRegistryService),l=o.useDependency(o.ICommandService),d=o.useDependency(B.IMarkSelectionService),u=s.getValidatorItem(n.type),c=E.useRef(),[h,p]=E.useState(!1),f=v=>{l.executeCommand(D.RemoveDataValidationCommand.id,{ruleId:n.uid,unitId:e,subUnitId:a}),v.stopPropagation()};return E.useEffect(()=>()=>{var v;c.current&&((v=c.current)==null||v.forEach(m=>{m&&d.removeShape(m)}))},[d]),S.jsxs("div",{className:Yt.dataValidationItemContainer,onClick:t,onMouseEnter:()=>{r||(p(!0),c.current=n.ranges.map(v=>d.addShape({range:v,style:{hasAutoFill:!1,fill:"rgba(73, 184, 17, 0.05)",strokeWidth:1,stroke:"#49B811",widgets:{}},primary:{startColumn:v.startColumn,endColumn:v.endColumn,startRow:v.startRow,endRow:v.endRow,actualRow:v.startRow,actualColumn:v.startColumn,isMerged:!1,isMergedMainCell:!1}})))},onMouseLeave:()=>{var v;p(!1),(v=c.current)==null||v.forEach(m=>{m&&d.removeShape(m)}),c.current=void 0},children:[S.jsx("div",{className:Yt.dataValidationItemTitle,children:u==null?void 0:u.generateRuleName(n)}),S.jsx("div",{className:Yt.dataValidationItemContent,children:n.ranges.map(v=>at.serializeRange(v)).join(",")}),h?S.jsx("div",{className:Yt.dataValidationItemIcon,onClick:f,children:S.jsx(oe,{})}):null]})},de={dataValidationListButtons:"univer-data-validation-list-buttons",dataValidationListButton:"univer-data-validation-list-button"};function pn(){const i=o.useDependency(o.IUniverInstanceService),n=k.useObservable(()=>i.getCurrentTypeOfUnit$(o.UniverInstanceType.UNIVER_SHEET),void 0,void 0,[]);return n?S.jsx(vn,{workbook:n}):null}function vn(i){const n=o.useDependency(D.DataValidationModel),t=o.useDependency(o.IUniverInstanceService),e=o.useDependency(o.ICommandService),a=o.useDependency(o.Injector),r=o.useDependency(st),s=o.useDependency(o.LocaleService),[l,d]=E.useState([]),{workbook:u}=i,c=k.useObservable(u.activeSheet$,void 0,!0),h=u.getUnitId(),p=c==null?void 0:c.getSheetId(),f=n.ensureManager(h,p);E.useEffect(()=>{d(f.getDataValidations());const R=f.dataValidations$.subscribe(y=>{d([...y])});return()=>{R.unsubscribe()}},[f]);const v=async()=>{const R=D.createDefaultNewRule(a),y={unitId:h,subUnitId:p,rule:R};await e.executeCommand(At.id,y),r.setActiveRule({unitId:h,subUnitId:p,rule:R})},m=()=>{e.executeCommand(D.RemoveAllDataValidationCommand.id,{unitId:h,subUnitId:p})},_=(R=>{const w=t.getCurrentUnitForType(o.UniverInstanceType.UNIVER_SHEET).getActiveSheet();return R.map(F=>{const{ranges:j}=F;return(j==null?void 0:j.some($=>{var L,Y;const{startRow:b,startColumn:W,endRow:x,endColumn:A}=$;for(let Z=b;Z<=x;Z++)for(let q=W;q<=A;q++){const M=(Y=(L=w==null?void 0:w.getCell(Z,q))==null?void 0:L.selectionProtection)==null?void 0:Y[0];if((M==null?void 0:M[xt.Edit])===!1||(M==null?void 0:M[xt.View])===!1)return!0}return!1}))?{...F,disable:!0}:{...F}})})(l),C=_==null?void 0:_.some(R=>R.disable);return S.jsxs("div",{children:[_==null?void 0:_.map(R=>{var y;return S.jsx(fn,{unitId:h,subUnitId:p,onClick:()=>{R.disable||r.setActiveRule({unitId:h,subUnitId:p,rule:R})},rule:R,disable:(y=R.disable)!=null?y:!1},R.uid)}),S.jsxs("div",{className:de.dataValidationListButtons,children:[l.length&&!C?S.jsx(O.Button,{className:de.dataValidationListButton,onClick:m,children:s.t("dataValidation.panel.removeAll")}):null,S.jsx(O.Button,{className:de.dataValidationListButton,type:"primary",onClick:v,children:s.t("dataValidation.panel.add")})]})]})}const gn=()=>{const i=o.useDependency(st),n=k.useObservable(i.activeRule$,i.activeRule);return n?S.jsx(hn,{},n.rule.uid):S.jsx(pn,{})},ut={dvListDropdown:"univer-dv-list-dropdown",dvListDropdownTitle:"univer-dv-list-dropdown-title",dvListDropdownList:"univer-dv-list-dropdown-list",dvListDropdownListContainer:"univer-dv-list-dropdown-list-container",dvListDropdownSelectedIcon:"univer-dv-list-dropdown-selected-icon",dvListDropdownItemContainer:"univer-dv-list-dropdown-item-container",dvListDropdownItem:"univer-dv-list-dropdown-item",dvListDropdownSplit:"univer-dv-list-dropdown-split",dvListDropdownEdit:"univer-dv-list-dropdown-edit"},Sn=i=>{const{value:n,onChange:t,multiple:e,options:a,title:r,onEdit:s,style:l}=i;return S.jsxs("div",{className:ut.dvListDropdown,style:l,children:[S.jsx("div",{className:ut.dvListDropdownTitle,children:r}),S.jsx("div",{className:ut.dvListDropdownList,children:S.jsx(O.Scrollbar,{children:S.jsx("div",{className:ut.dvListDropdownListContainer,children:a.map((d,u)=>{const c=n.indexOf(d.value)>-1,h=()=>{let p;c?p=new Set(n.filter(v=>v!==d.value)):p=new Set(e?[...n,d.value]:[d.value]);const f=[];a.forEach(v=>{p.has(v.value)&&f.push(v.value)}),t(f)};return S.jsxs("div",{className:ut.dvListDropdownItemContainer,onClick:h,children:[S.jsx("div",{className:ut.dvListDropdownItem,style:{background:d.color||_t},children:d.label}),S.jsx("div",{className:ut.dvListDropdownSelectedIcon,children:c?S.jsx(Le,{}):null})]},u)})})})}),S.jsx("div",{className:ut.dvListDropdownSplit}),S.jsx("div",{className:ut.dvListDropdownEdit,children:S.jsx("a",{onClick:s,children:"编辑"})})]})};function _n(i){var P,$;const{location:n,hideFn:t}=i,{worksheet:e,row:a,col:r,unitId:s,subUnitId:l}=n,d=o.useDependency(D.DataValidationModel),u=o.useDependency(o.ICommandService),c=o.useDependency(o.LocaleService),[h,p]=E.useState(""),f=o.useDependency(B.IEditorBridgeService);k.useObservable(d.ruleChange$);const v=O.RectPopup.useContext(),m=v.right-v.left;if(!e)return null;const V=e.getCell(a,r),_=(P=V==null?void 0:V.dataValidation)==null?void 0:P.rule,C=($=V==null?void 0:V.dataValidation)==null?void 0:$.validator,R=(_==null?void 0:_.renderMode)===o.DataValidationRenderMode.CUSTOM||(_==null?void 0:_.renderMode)===void 0;if(!V||!_||!C)return;const y=_.type===o.DataValidationType.LIST_MULTIPLE,w=C.getListWithColor(_,s,l),T=h||Ja(V),F=It(T),j=()=>{u.executeCommand(gt.id,{ruleId:_.uid}),t()};return S.jsx(Sn,{style:{minWidth:m,maxWidth:Math.max(m,200)},title:y?c.t("dataValidation.listMultiple.dropdown"):c.t("dataValidation.list.dropdown"),value:F,multiple:y,onChange:b=>{const W=$e(b),x={unitId:s,subUnitId:l,range:{startColumn:r,endColumn:r,startRow:a,endRow:a},value:{v:W,p:null,f:null,si:null,custom:{__link_url:""}}};f.isVisible()&&f.changeVisible({visible:!1,keycode:k.KeyCode.ESC,eventType:K.DeviceInputEventType.Keyboard,unitId:s}),u.executeCommand(U.SetRangeValuesCommand.id,x),p(W),y||t()},options:w.map(b=>({label:b.label,value:b.label,color:R?b.color:"transparent"})),onEdit:j})}var Xe={exports:{}};(function(i,n){(function(t,e){i.exports=e()})(_a,function(){var t="minute",e=/[+-]\d\d(?::?\d\d)?/g,a=/([+-]|\d\d)/g;return function(r,s,l){var d=s.prototype;l.utc=function(m){var V={date:m,utc:!0,args:arguments};return new s(V)},d.utc=function(m){var V=l(this.toDate(),{locale:this.$L,utc:!0});return m?V.add(this.utcOffset(),t):V},d.local=function(){return l(this.toDate(),{locale:this.$L,utc:!1})};var u=d.parse;d.parse=function(m){m.utc&&(this.$u=!0),this.$utils().u(m.$offset)||(this.$offset=m.$offset),u.call(this,m)};var c=d.init;d.init=function(){if(this.$u){var m=this.$d;this.$y=m.getUTCFullYear(),this.$M=m.getUTCMonth(),this.$D=m.getUTCDate(),this.$W=m.getUTCDay(),this.$H=m.getUTCHours(),this.$m=m.getUTCMinutes(),this.$s=m.getUTCSeconds(),this.$ms=m.getUTCMilliseconds()}else c.call(this)};var h=d.utcOffset;d.utcOffset=function(m,V){var _=this.$utils().u;if(_(m))return this.$u?0:_(this.$offset)?h.call(this):this.$offset;if(typeof m=="string"&&(m=function(w){w===void 0&&(w="");var T=w.match(e);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}(m),m===null))return this;var C=Math.abs(m)<=16?60*m:m,R=this;if(V)return R.$offset=C,R.$u=m===0,R;if(m!==0){var y=this.$u?this.toDate().getTimezoneOffset():-1*this.utcOffset();(R=this.local().add(C+y,t)).$offset=C,R.$x.$localOffset=y}else R=this.utc();return R};var p=d.format;d.format=function(m){var V=m||(this.$u?"YYYY-MM-DDTHH:mm:ss[Z]":"");return p.call(this,V)},d.valueOf=function(){var m=this.$utils().u(this.$offset)?0:this.$offset+(this.$x.$localOffset||this.$d.getTimezoneOffset());return this.$d.valueOf()-6e4*m},d.isUTC=function(){return!!this.$u},d.toISOString=function(){return this.toDate().toISOString()},d.toString=function(){return this.toDate().toUTCString()};var f=d.toDate;d.toDate=function(m){return m==="s"&&this.$offset?l(this.format("YYYY-MM-DD HH:mm:ss:SSS")).toDate():f.call(this)};var v=d.diff;d.diff=function(m,V,_){if(m&&this.$u===m.$u)return v.call(this,m,V,_);var C=this.local(),R=l(m).local();return v.call(C,R,V,_)}}})})(Xe);var Dn=Xe.exports;const Vn=Da(Dn);var Rn=Object.defineProperty,In=Object.getOwnPropertyDescriptor,Cn=(i,n,t,e)=>{for(var a=e>1?void 0:e?In(n,t):n,r=i.length-1,s;r>=0;r--)(s=i[r])&&(a=(e?s(n,t,a):s(a))||a);return e&&a&&Rn(n,t,a),a},Nt=(i,n)=>(t,e)=>n(t,e,i);g.DataValidationRejectInputController=class extends o.Disposable{constructor(n,t,e,a,r){super(),this._editorBridgeService=n,this._dataValidationModel=t,this._dataValidatorRegistryService=e,this._dialogService=a,this._localeService=r,this._initEditorBridgeInterceptor()}_initEditorBridgeInterceptor(){this._editorBridgeService.interceptor.intercept(this._editorBridgeService.interceptor.getInterceptPoints().AFTER_CELL_EDIT_ASYNC,{handler:async(n,t,e)=>{const a=await n,{worksheet:r,row:s,col:l,unitId:d,subUnitId:u}=t,c=this._dataValidationModel.ensureManager(d,u),h=c.getRuleIdByLocation(s,l),p=h?c.getRuleById(h):void 0;if(!p||p.errorStyle!==o.DataValidationErrorStyle.STOP)return e(Promise.resolve(a));const f=await this._dataValidatorRegistryService.getValidatorItem(p.type);if(!f||await f.validator({value:J(a),row:s,column:l,unitId:d,subUnitId:u},p))return e(Promise.resolve(a));const m=r.getCellRaw(s,l);return this._dialogService.open({width:368,title:{title:this._localeService.t("dataValidation.alert.title")},id:"reject-input-dialog",children:{title:f.getRuleFinalError(p)},footer:{title:E.createElement(O.Button,{type:"primary",onClick:()=>this._dialogService.close("reject-input-dialog")},this._localeService.t("dataValidation.alert.ok"))},onClose:()=>{this._dialogService.close("reject-input-dialog")}}),e(Promise.resolve(m))}})}showReject(n){this._dialogService.open({width:368,title:{title:this._localeService.t("dataValidation.alert.title")},id:"reject-input-dialog",children:{title:n},footer:{title:E.createElement(O.Button,{type:"primary",onClick:()=>this._dialogService.close("reject-input-dialog")},this._localeService.t("dataValidation.alert.ok"))},onClose:()=>{this._dialogService.close("reject-input-dialog")}})}},g.DataValidationRejectInputController=Cn([o.OnLifecycle(o.LifecycleStages.Ready,g.DataValidationRejectInputController),Nt(0,B.IEditorBridgeService),Nt(1,o.Inject(D.DataValidationModel)),Nt(2,o.Inject(D.DataValidatorRegistryService)),Nt(3,k.IDialogService),Nt(4,o.Inject(o.LocaleService))],g.DataValidationRejectInputController);const Ge={dvDateDropdown:"univer-dv-date-dropdown",dvDateDropdownBtns:"univer-dv-date-dropdown-btns"};ot.extend(Vn);const yn=i=>{if(i==null||typeof i=="boolean")return;if(typeof i=="number"||!Number.isNaN(+i)){const t=ot.unix(un(+i)).utc().format().slice(0,-1);return ot(t)}const n=ot(i);if(n.isValid())return n};function Mn(i){var y,w,T;const{location:n,hideFn:t}=i,{worksheet:e,row:a,col:r,unitId:s,subUnitId:l}=n,d=o.useDependency(o.ICommandService),u=o.useDependency(g.DataValidationRejectInputController),c=e.getCell(a,r),h=(y=c==null?void 0:c.dataValidation)==null?void 0:y.rule,p=(w=c==null?void 0:c.dataValidation)==null?void 0:w.validator,f=J(c),v=yn(f),[m,V]=E.useState(v),_=!!((T=h==null?void 0:h.bizInfo)!=null&&T.showTime),C=m&&m.isValid()?m:ot();if(!c||!h||!p)return;const R=async()=>{if(!m)return;const j=`${m.format(_?"YYYY-MM-DD HH:mm:ss":"YYYY-MM-DD 00:00:00").split(" ").join("T")}Z`,P=qe(ot(j).unix());h.errorStyle!==o.DataValidationErrorStyle.STOP||await p.validator({value:P,unitId:s,subUnitId:l,row:a,column:r},h)?(d.executeCommand(U.SetRangeValuesCommand.id,{unitId:s,subUnitId:l,range:{startColumn:r,endColumn:r,startRow:a,endRow:a},value:{v:P,t:2,p:null,f:null,si:null,s:{n:{pattern:_?"yyyy-MM-dd hh:mm:ss":"yyyy-MM-dd"}}}}),t()):u.showReject(p.getRuleFinalError(h))};return S.jsxs("div",{className:Ge.dvDateDropdown,children:[S.jsx(O.DatePanel,{defaultValue:m,pickerValue:m!=null?m:C,showTime:_||void 0,onSelect:async F=>{V(F)},onPanelChange:F=>{V(F)}}),S.jsx("div",{className:Ge.dvDateDropdownBtns,children:S.jsx(O.Button,{size:"small",type:"primary",onClick:R,disabled:!m,children:"确定"})})]})}const ze="data-validation.list.dropdown",Ke="data-validation.date.dropdown",wn={[o.DataValidationOperator.BETWEEN]:"dataValidation.date.operators.between",[o.DataValidationOperator.EQUAL]:"dataValidation.date.operators.equal",[o.DataValidationOperator.GREATER_THAN]:"dataValidation.date.operators.greaterThan",[o.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.date.operators.greaterThanOrEqual",[o.DataValidationOperator.LESS_THAN]:"dataValidation.date.operators.lessThan",[o.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.date.operators.lessThanOrEqual",[o.DataValidationOperator.NOT_BETWEEN]:"dataValidation.date.operators.notBetween",[o.DataValidationOperator.NOT_EQUAL]:"dataValidation.date.operators.notEqual"};o.DataValidationOperator.BETWEEN+"",o.DataValidationOperator.EQUAL+"",o.DataValidationOperator.GREATER_THAN+"",o.DataValidationOperator.GREATER_THAN_OR_EQUAL+"",o.DataValidationOperator.LESS_THAN+"",o.DataValidationOperator.LESS_THAN_OR_EQUAL+"",o.DataValidationOperator.NOT_BETWEEN+"",o.DataValidationOperator.NOT_EQUAL+"";const On={[o.DataValidationOperator.BETWEEN]:"dataValidation.date.ruleName.between",[o.DataValidationOperator.EQUAL]:"dataValidation.date.ruleName.equal",[o.DataValidationOperator.GREATER_THAN]:"dataValidation.date.ruleName.greaterThan",[o.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.date.ruleName.greaterThanOrEqual",[o.DataValidationOperator.LESS_THAN]:"dataValidation.date.ruleName.lessThan",[o.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.date.ruleName.lessThanOrEqual",[o.DataValidationOperator.NOT_BETWEEN]:"dataValidation.date.ruleName.notBetween",[o.DataValidationOperator.NOT_EQUAL]:"dataValidation.date.ruleName.notEqual"},Tn={[o.DataValidationOperator.BETWEEN]:"dataValidation.date.errorMsg.between",[o.DataValidationOperator.EQUAL]:"dataValidation.date.errorMsg.equal",[o.DataValidationOperator.GREATER_THAN]:"dataValidation.date.errorMsg.greaterThan",[o.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.date.errorMsg.greaterThanOrEqual",[o.DataValidationOperator.LESS_THAN]:"dataValidation.date.errorMsg.lessThan",[o.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.date.errorMsg.lessThanOrEqual",[o.DataValidationOperator.NOT_BETWEEN]:"dataValidation.date.errorMsg.notBetween",[o.DataValidationOperator.NOT_EQUAL]:"dataValidation.date.errorMsg.notEqual"},En="DATE_SHOW_TIME_OPTION";function qt(i){var a;const{value:n,onChange:t}=i,e=o.useDependency(o.LocaleService);return S.jsx(O.FormLayout,{children:S.jsx(O.Checkbox,{checked:(a=n.bizInfo)==null?void 0:a.showTime,onChange:r=>{t({...n,bizInfo:{...n.bizInfo,showTime:r}})},children:e.t("dataValidation.showTime.label")})})}qt.componentKey=En;const Qe="{FORMULA1}",Ze="{FORMULA2}",Lt=i=>{if(i==null||typeof i=="boolean")return;if(typeof i=="number"||!Number.isNaN(+i))return+i;const n=`${ot(i).format("YYYY-MM-DD HH:mm:ss").split(" ").join("T")}Z`;return qe(ot(n).unix())};class bn extends D.BaseDataValidator{constructor(){super(...arguments);I(this,"id",o.DataValidationType.DATE);I(this,"title","dataValidation.date.title");I(this,"operators",[o.DataValidationOperator.BETWEEN,o.DataValidationOperator.EQUAL,o.DataValidationOperator.GREATER_THAN,o.DataValidationOperator.GREATER_THAN_OR_EQUAL,o.DataValidationOperator.LESS_THAN,o.DataValidationOperator.LESS_THAN_OR_EQUAL,o.DataValidationOperator.NOT_BETWEEN,o.DataValidationOperator.NOT_EQUAL]);I(this,"scopes",["sheet"]);I(this,"formulaInput",Et);I(this,"optionsInput",qt.componentKey);I(this,"dropdown",Ke);I(this,"_formulaService",this.injector.get(g.DataValidationFormulaService))}async parseFormula(t,e,a){var d,u;const r=await this._formulaService.getRuleFormulaResult(e,a,t.uid),{formula1:s,formula2:l}=t;return{formula1:Lt(o.isFormulaString(s)?rt((d=r==null?void 0:r[0])==null?void 0:d.result):s),formula2:Lt(o.isFormulaString(l)?rt((u=r==null?void 0:r[1])==null?void 0:u.result):l)}}parseFormulaSync(t,e,a){var d,u;const r=this._formulaService.getRuleFormulaResultSync(e,a,t.uid),{formula1:s,formula2:l}=t;return{formula1:Lt(o.isFormulaString(s)?rt((d=r==null?void 0:r[0])==null?void 0:d.result):s),formula2:Lt(o.isFormulaString(l)?rt((u=r==null?void 0:r[1])==null?void 0:u.result):l)}}async isValidType(t){const{value:e}=t;return typeof e=="string"?ot(e,"YYYY-MM-DD HH:mm:ss",!0).isValid():typeof e=="number"}_validatorSingleFormula(t){return!o.Tools.isBlank(t)&&(o.isFormulaString(t)||!Number.isNaN(+t)||!!t&&ot(t).isValid())}validatorFormula(t,e,a){const r=t.operator;if(!r)return{success:!1};const s=this._validatorSingleFormula(t.formula1),l=this.localeService.t("dataValidation.validFail.date");if(kt.includes(r)){const u=this._validatorSingleFormula(t.formula2);return{success:s&&u,formula1:s?void 0:l,formula2:u?void 0:l}}return{success:s,formula1:s?void 0:l}}transform(t,e,a){const{value:r}=t;return{...t,value:Lt(r)}}async validatorIsEqual(t,e,a){const{formula1:r}=e,{value:s}=t;return Number.isNaN(r)?!0:s===r}async validatorIsNotEqual(t,e,a){const{formula1:r}=e;return Number.isNaN(r)?!0:t.value!==r}async validatorIsBetween(t,e,a){const{formula1:r,formula2:s}=e;if(Number.isNaN(r)||Number.isNaN(s))return!0;const l=Math.min(r,s),d=Math.max(r,s);return t.value>=l&&t.value<=d}async validatorIsNotBetween(t,e,a){const{formula1:r,formula2:s}=e;if(Number.isNaN(r)||Number.isNaN(s))return!0;const l=Math.min(r,s),d=Math.max(r,s);return t.value<l||t.value>d}async validatorIsGreaterThan(t,e,a){const{formula1:r}=e;return Number.isNaN(r)?!0:t.value>r}async validatorIsGreaterThanOrEqual(t,e,a){const{formula1:r}=e;return Number.isNaN(r)?!0:t.value>=r}async validatorIsLessThan(t,e,a){const{formula1:r}=e;return Number.isNaN(r)?!0:t.value<r}async validatorIsLessThanOrEqual(t,e,a){const{formula1:r}=e;return Number.isNaN(r)?!0:t.value<=r}get operatorNames(){return this.operators.map(t=>this.localeService.t(wn[t]))}generateRuleName(t){var a,r;if(!t.operator)return this.titleStr;const e=this.localeService.t(On[t.operator]).replace(Qe,(a=t.formula1)!=null?a:"").replace(Ze,(r=t.formula2)!=null?r:"");return`${this.titleStr} ${e}`}generateRuleErrorMessage(t){var a,r;return t.operator?`${this.localeService.t(Tn[t.operator]).replace(Qe,(a=t.formula1)!=null?a:"").replace(Ze,(r=t.formula2)!=null?r:"")}`:this.titleStr}}var Fn=Object.defineProperty,Nn=Object.getOwnPropertyDescriptor,Ln=(i,n,t,e)=>{for(var a=e>1?void 0:e?Nn(n,t):n,r=i.length-1,s;r>=0;r--)(s=i[r])&&(a=(e?s(n,t,a):s(a))||a);return e&&a&&Fn(n,t,a),a},Je=(i,n)=>(t,e)=>n(t,e,i);const yt=4,Pn=6,lt=14,Dt=6,ft=4,An="#565656",ta=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 jn(i,n){const t=i.length;return{id:"d",body:{dataStream:`${i}${o.DEFAULT_EMPTY_DOCUMENT_VALUE}`,textRuns:[{ts:{fs:11,ff:void 0,it:o.BooleanNumber.FALSE,bl:o.BooleanNumber.FALSE,ul:{s:o.BooleanNumber.FALSE},st:{s:o.BooleanNumber.FALSE},ol:{s:o.BooleanNumber.FALSE},cl:void 0,...n,bg:void 0,bd:void 0},st:0,ed:t}]},documentStyle:{pageSize:{width:Number.POSITIVE_INFINITY,height:Number.POSITIVE_INFINITY}}}}function ea(i,n,t){const e=jn(i,t),a=new o.DocumentDataModel(e),r=new K.DocumentViewModel(a);return{documentSkeleton:K.DocumentSkeleton.create(r,n),docModel:a,docViewModel:r}}function ue(i,n,t){const{documentSkeleton:e,docModel:a,docViewModel:r}=ea(i,n,t);return{documents:new K.Documents(`DOCUMENTS_${o.Tools.generateRandomId()}`,e,{pageMarginLeft:0,pageMarginTop:0}),documentSkeleton:e,docModel:a,docViewModel:r}}function aa(i,n,t,e,a,r){let s=0;switch(a){case o.VerticalAlign.BOTTOM:s=n-ft*2-e+ft;break;case o.VerticalAlign.MIDDLE:s=(n-ft*2-e)/2+ft;break;default:s=ft;break}let l=0;switch(r){case o.HorizontalAlign.CENTER:l=(i-t)/2;break;case o.HorizontalAlign.RIGHT:l=i-t;break}return{paddingLeft:l,paddingTop:s}}let ce=(Me=class{constructor(i,n){I(this,"_dropdownInfoMap",new Map);I(this,"zIndex");I(this,"onPointerEnter");I(this,"onPointerLeave");this._localeService=i,this._commandService=n}_ensureMap(i){let n=this._dropdownInfoMap.get(i);return n||(n=new Map,this._dropdownInfoMap.set(i,n)),n}_generateKey(i,n){return`${i}.${n}`}_drawDownIcon(i,n,t,e,a){const r=t-lt+4;let s=9;switch(a){case o.VerticalAlign.MIDDLE:s=(e-lt)/2+4;break;case o.VerticalAlign.BOTTOM:s=e-lt-1;break}i.save(),i.translateWithPrecision(n.startX+r,n.startY+s),i.fillStyle="#565656",i.fill(ta),i.restore()}drawWith(i,n,t){var x,A;const{primaryWithCoord:e,row:a,col:r,style:s,data:l,subUnitId:d}=n,u=e.isMergedMainCell?e.mergeInfo:e,c=(x=l.dataValidation)==null?void 0:x.rule,h=(A=l.dataValidation)==null?void 0:A.validator,p=l.fontRenderExtension,{leftOffset:f=0,rightOffset:v=0,topOffset:m=0,downOffset:V=0}=p||{};if(!c||!h||!h.skipDefaultFontRender(c))return;const _={startX:u.startX+f,endX:u.endX-v,startY:u.startY+m,endY:u.endY-V},C=_.endX-_.startX,R=_.endY-_.startY,y=this._ensureMap(d),w=this._generateKey(a,r),T=h.getListWithColor(c),F=J(l),j=`${F!=null?F:""}`,P=T.find(L=>L.label===j);let{tb:$,vt:b,ht:W}=s||{};if($=$!=null?$:o.WrapStrategy.WRAP,b=b!=null?b:o.VerticalAlign.BOTTOM,W=W!=null?W:o.HorizontalAlign.LEFT,c.renderMode===o.DataValidationRenderMode.ARROW){this._drawDownIcon(i,_,C,R,b),i.save(),i.translateWithPrecision(_.startX,_.startY),i.beginPath(),i.rect(0,0,C,R),i.clip();const L=C-lt,{documentSkeleton:Y,documents:Z,docModel:q}=ue(j,this._localeService,s);$===o.WrapStrategy.WRAP&&q.updateDocumentDataPageSize(Math.max(L,1)),Y.calculate(),Y.getActualSize();const M=K.getDocsSkeletonPageSize(Y),{height:H,width:tt}=M,{paddingTop:G,paddingLeft:dt}=aa(L,R,tt,H,b,W);i.translate(0,G),i.save(),i.translateWithPrecision(yt,0),i.beginPath(),i.rect(0,0,L,H),i.clip(),Z.render(i),i.translateWithPrecision(dt,0),i.restore(),i.restore(),y.set(w,{left:_.endX+t.rowHeaderWidth-lt,top:_.startY+t.columnHeaderHeight,width:lt,height:R})}else{i.save(),i.translateWithPrecision(_.startX,_.startY),i.beginPath(),i.rect(0,0,C,R),i.clip();const L=C-Dt*2-yt-lt,{documentSkeleton:Y,documents:Z,docModel:q}=ue(j,this._localeService,s);$===o.WrapStrategy.WRAP&&q.updateDocumentDataPageSize(Math.max(L,1)),Y.calculate();const M=K.getDocsSkeletonPageSize(Y),{height:H,width:tt}=M,{paddingTop:G,paddingLeft:dt}=aa(L,R,tt,H,b,W);i.translate(Dt,G);const N=Math.max(C-Dt*2,1),X=H;K.Rect.drawWith(i,{width:N,height:X,fill:(P==null?void 0:P.color)||_t,radius:8}),i.save(),i.translateWithPrecision(yt,0),i.beginPath(),i.rect(0,0,L,H),i.clip(),i.translateWithPrecision(dt,0),Z.render(i),i.restore(),i.translate(L+yt+4,(H-Pn)/2),i.fillStyle=An,i.fill(ta),i.restore(),y.set(w,{left:_.startX+Dt+t.rowHeaderWidth,top:_.startY+G+t.columnHeaderHeight,width:N,height:X})}}calcCellAutoHeight(i){var V;const{primaryWithCoord:n,style:t,data:e}=i,a=n.isMergedMainCell?n.mergeInfo:n,r=e.fontRenderExtension,{leftOffset:s=0,rightOffset:l=0,topOffset:d=0,downOffset:u=0}=r||{},c=(V=e.dataValidation)==null?void 0:V.rule;if(!c||c.renderMode===o.DataValidationRenderMode.TEXT)return;const h={startX:a.startX+s,endX:a.endX-l,startY:a.startY+d,endY:a.endY-u},p=h.endX-h.startX,f=J(e),v=`${f!=null?f:""}`;let{tb:m}=t||{};if(m=m!=null?m:o.WrapStrategy.WRAP,c.renderMode===o.DataValidationRenderMode.ARROW){const _=p-lt,{documentSkeleton:C,docModel:R}=ue(v,this._localeService,t);m===o.WrapStrategy.WRAP&&R.updateDocumentDataPageSize(Math.max(_,1)),C.calculate(),C.getActualSize();const y=K.getDocsSkeletonPageSize(C),{height:w}=y;return w}else{const _=p-Dt*2-yt-lt,{documentSkeleton:C,docModel:R}=ea(v,this._localeService,t);m===o.WrapStrategy.WRAP&&R.updateDocumentDataPageSize(Math.max(_,1)),C.calculate();const y=K.getDocsSkeletonPageSize(C),{height:w}=y;return w+ft*2}}isHit(i,n){const{data:t,subUnitId:e,row:a,col:r}=n,l=this._ensureMap(e).get(this._generateKey(a,r)),d=t.dataValidation;if(!d||!l||d.rule.renderMode===o.DataValidationRenderMode.TEXT)return!1;const{top:u,left:c,width:h,height:p}=l,{x:f,y:v}=i;return f>=c&&f<=c+h&&v>=u&&v<=u+p}onPointerDown(i,n){if(n.button===2)return;const{unitId:t,subUnitId:e,row:a,col:r}=i,s={unitId:t,subUnitId:e,row:a,column:r};this._commandService.executeCommand(Ot.id,s)}},I(Me,"padding",{l:Dt+yt,r:lt+Dt,t:ft,b:ft}),Me);ce=Ln([Je(0,o.Inject(o.LocaleService)),Je(1,o.ICommandService)],ce);const Un="LIST_RENDER_MODE_OPTION_INPUT";function Xt(i){var a;const{value:n,onChange:t}=i,e=o.useDependency(o.LocaleService);return S.jsx(O.FormLayout,{label:e.t("dataValidation.renderMode.label"),children:S.jsxs(O.RadioGroup,{value:`${(a=n.renderMode)!=null?a:o.DataValidationRenderMode.CUSTOM}`,onChange:r=>t({...n,renderMode:+r}),children:[S.jsx(O.Radio,{value:`${o.DataValidationRenderMode.CUSTOM}`,children:e.t("dataValidation.renderMode.chip")}),S.jsx(O.Radio,{value:`${o.DataValidationRenderMode.ARROW}`,children:e.t("dataValidation.renderMode.arrow")}),S.jsx(O.Radio,{value:`${o.DataValidationRenderMode.TEXT}`,children:e.t("dataValidation.renderMode.text")})]})})}Xt.componentKey=Un;function me(i){if(!i)return[];const n=new Set;return i.forEach(t=>{t.forEach(e=>{var r,s;const a=J(e);if(a!=null){if(typeof a!="string"&&typeof(e==null?void 0:e.s)=="object"&&((s=(r=e.s)==null?void 0:r.n)!=null&&s.pattern)){n.add(Sa.format(e.s.n.pattern,a));return}n.add(a.toString())}})}),[...n]}const Bn=["if","indirect","choose","offset"];function $n(i,n){if(!o.isFormulaString(i)||at.isReferenceString(i.slice(1)))return!0;const e=n.sequenceNodesBuilder(i);return e&&e.some(a=>typeof a=="object"&&a.nodeType===at.sequenceNodeType.FUNCTION&&Bn.indexOf(a.token.toLowerCase())>-1)}function Wn(i,n){const{formula1:t="",ranges:e}=i;if(at.isReferenceString(t.slice(1))){const r=at.deserializeRangeWithSheet(t.slice(1));if((!r.sheetName||r.sheetName===n)&&e.some(s=>o.Rectangle.intersects(s,r.range)))return!0}return!1}class na extends D.BaseDataValidator{constructor(){super(...arguments);I(this,"formulaService",this.injector.get(g.DataValidationFormulaService));I(this,"_lexer",this.injector.get(at.LexerTreeBuilder));I(this,"_univerInstanceService",this.injector.get(o.IUniverInstanceService));I(this,"id",o.DataValidationType.LIST);I(this,"title","dataValidation.list.title");I(this,"operators",[]);I(this,"scopes",["sheet"]);I(this,"formulaInput",xe);I(this,"canvasRender",this.injector.createInstance(ce));I(this,"dropdown",ze);I(this,"optionsInput",Xt.componentKey)}skipDefaultFontRender(t){return t.renderMode!==o.DataValidationRenderMode.TEXT}validatorFormula(t,e,a){var u,c,h;const r=!o.Tools.isBlank(t.formula1),s=$n((u=t.formula1)!=null?u:"",this._lexer),l=(h=(c=this._univerInstanceService.getUnit(e,o.UniverInstanceType.UNIVER_SHEET))==null?void 0:c.getSheetBySheetId(a))==null?void 0:h.getName(),d=Wn(t,l!=null?l:"");return{success:!!(r&&s&&!d),formula1:r?s?d?this.localeService.t("dataValidation.validFail.listIntersects"):void 0:this.localeService.t("dataValidation.validFail.listInvalid"):this.localeService.t("dataValidation.validFail.list")}}parseCellValue(t){const e=t.toString();return It(e)}async parseFormula(t,e,a){var l;const{formula1:r=""}=t,s=await this.formulaService.getRuleFormulaResult(e,a,t.uid);return{formula1:o.isFormulaString(r)?me((l=s==null?void 0:s[0])==null?void 0:l.result):It(r),formula2:void 0}}async isValidType(t,e,a){const{value:r}=t,{formula1:s=[]}=e;return this.parseCellValue(r).every(d=>s.includes(d))}generateRuleName(){return this.localeService.t("dataValidation.list.name")}generateRuleErrorMessage(){return this.localeService.t("dataValidation.list.error")}getList(t,e,a){var p,f,v;const{formula1:r=""}=t,s=this.injector.get(o.IUniverInstanceService),l=(p=e?s.getUniverSheetInstance(e):void 0)!=null?p:s.getCurrentUnitForType(o.UniverInstanceType.UNIVER_SHEET);if(!l)return[];const d=(f=a?l.getSheetBySheetId(a):void 0)!=null?f:l.getActiveSheet();if(!d)return[];const u=l.getUnitId(),c=d.getSheetId(),h=this.formulaService.getRuleFormulaResultSync(u,c,t.uid);return o.isFormulaString(r)?me((v=h==null?void 0:h[0])==null?void 0:v.result):It(r)}async getListAsync(t,e,a){var p,f,v;const{formula1:r=""}=t,s=this.injector.get(o.IUniverInstanceService),l=(p=e?s.getUniverSheetInstance(e):void 0)!=null?p:s.getCurrentUnitForType(o.UniverInstanceType.UNIVER_SHEET);if(!l)return[];const d=(f=a?l.getSheetBySheetId(a):void 0)!=null?f:l.getActiveSheet();if(!d)return[];const u=l.getUnitId(),c=d.getSheetId(),h=await this.formulaService.getRuleFormulaResult(u,c,t.uid);return o.isFormulaString(r)?me((v=h==null?void 0:h[0])==null?void 0:v.result):It(r)}getListWithColor(t,e,a){const r=this.getList(t,e,a),s=(t.formula2||"").split(",");return r.map((l,d)=>({label:l,color:s[d]}))}getListWithColorMap(t,e,a){const r=this.getListWithColor(t,e,a),s={};return r.forEach(l=>{l.color&&(s[l.label]=l.color)}),s}}function Gt(i){let n=i;return typeof i=="string"?((i.startsWith("¥")||i.startsWith("$"))&&(n=i.slice(1)),+n):+i}class Hn extends D.BaseDataValidator{constructor(){super(...arguments);I(this,"_formulaService",this.injector.get(g.DataValidationFormulaService));I(this,"id",o.DataValidationType.DECIMAL);I(this,"title","dataValidation.decimal.title");I(this,"operators",[o.DataValidationOperator.BETWEEN,o.DataValidationOperator.EQUAL,o.DataValidationOperator.GREATER_THAN,o.DataValidationOperator.GREATER_THAN_OR_EQUAL,o.DataValidationOperator.LESS_THAN,o.DataValidationOperator.LESS_THAN_OR_EQUAL,o.DataValidationOperator.NOT_BETWEEN,o.DataValidationOperator.NOT_EQUAL]);I(this,"scopes",["sheet"]);I(this,"formulaInput",Et);I(this,"dropDownInput")}_isFormulaOrNumber(t){return!o.Tools.isBlank(t)&&(o.isFormulaString(t)||!Number.isNaN(+t))}async isValidType(t,e,a){const{value:r}=t;return!Number.isNaN(Gt(r))}transform(t,e,a){const{value:r}=t;return{...t,value:Gt(r)}}_parseNumber(t){return t==null?Number.NaN:+t}async parseFormula(t,e,a){var u,c,h,p,f,v,m,V;const r=await this._formulaService.getRuleFormulaResult(e,a,t.uid),{formula1:s,formula2:l}=t;return{formula1:this._parseNumber(o.isFormulaString(s)?(p=(h=(c=(u=r==null?void 0:r[0])==null?void 0:u.result)==null?void 0:c[0])==null?void 0:h[0])==null?void 0:p.v:s),formula2:this._parseNumber(o.isFormulaString(l)?(V=(m=(v=(f=r==null?void 0:r[1])==null?void 0:f.result)==null?void 0:v[0])==null?void 0:m[0])==null?void 0:V.v:l)}}validatorFormula(t,e,a){const r=t.operator;if(!r)return{success:!1};const s=o.Tools.isDefine(t.formula1)&&this._isFormulaOrNumber(t.formula1),l=o.Tools.isDefine(t.formula2)&&this._isFormulaOrNumber(t.formula2),d=kt.includes(r),u=this.localeService.t("dataValidation.validFail.number");return d?{success:s&&l,formula1:s?void 0:u,formula2:l?void 0:u}:{success:s,formula1:s?"":u}}async validatorIsEqual(t,e,a){const{formula1:r}=e,{value:s}=t;return Number.isNaN(r)?!0:s===r}async validatorIsNotEqual(t,e,a){const{formula1:r}=e;return Number.isNaN(r)?!0:t.value!==r}async validatorIsBetween(t,e,a){const{formula1:r,formula2:s}=e;if(Number.isNaN(r)||Number.isNaN(s))return!0;const l=Math.min(r,s),d=Math.max(r,s);return t.value>=l&&t.value<=d}async validatorIsNotBetween(t,e,a){const{formula1:r,formula2:s}=e;if(Number.isNaN(r)||Number.isNaN(s))return!0;const l=Math.min(r,s),d=Math.max(r,s);return t.value<l||t.value>d}async validatorIsGreaterThan(t,e,a){const{formula1:r}=e;return Number.isNaN(r)?!0:t.value>r}async validatorIsGreaterThanOrEqual(t,e,a){const{formula1:r}=e;return Number.isNaN(r)?!0:t.value>=r}async validatorIsLessThan(t,e,a){const{formula1:r}=e;return Number.isNaN(r)?!0:t.value<r}async validatorIsLessThanOrEqual(t,e,a){const{formula1:r}=e;return Number.isNaN(r)?!0:t.value<=r}}const xn="{FORMULA1}",kn="{FORMULA2}";class Yn extends D.BaseDataValidator{constructor(){super(...arguments);I(this,"id",o.DataValidationType.TEXT_LENGTH);I(this,"title","dataValidation.textLength.title");I(this,"operators",[o.DataValidationOperator.BETWEEN,o.DataValidationOperator.EQUAL,o.DataValidationOperator.GREATER_THAN,o.DataValidationOperator.GREATER_THAN_OR_EQUAL,o.DataValidationOperator.LESS_THAN,o.DataValidationOperator.LESS_THAN_OR_EQUAL,o.DataValidationOperator.NOT_BETWEEN,o.DataValidationOperator.NOT_EQUAL]);I(this,"scopes",["sheet"]);I(this,"formulaInput",Et);I(this,"_formulaService",this.injector.get(g.DataValidationFormulaService))}_isFormulaOrInt(t){return!o.Tools.isBlank(t)&&(o.isFormulaString(t)||!Number.isNaN(+t)&&Number.isInteger(+t))}validatorFormula(t,e,a){const r=t.operator;if(!r)return{success:!1};const s=o.Tools.isDefine(t.formula1)&&this._isFormulaOrInt(t.formula1),l=o.Tools.isDefine(t.formula2)&&this._isFormulaOrInt(t.formula2),d=kt.includes(r),u=this.localeService.t("dataValidation.validFail.number");return d?{success:s&&l,formula1:s?void 0:u,formula2:l?void 0:u}:{success:s,formula1:u}}_parseNumber(t){return t==null?Number.NaN:+t}_isValidFormula(t){return!Number.isNaN(t)}async parseFormula(t,e,a){var d,u,c,h,p,f,v,m;const r=await this._formulaService.getRuleFormulaResult(e,a,t.uid),{formula1:s,formula2:l}=t;return{formula1:this._parseNumber(o.isFormulaString(s)?(h=(c=(u=(d=r==null?void 0:r[0])==null?void 0:d.result)==null?void 0:u[0])==null?void 0:c[0])==null?void 0:h.v:s),formula2:this._parseNumber(o.isFormulaString(l)?(m=(v=(f=(p=r==null?void 0:r[1])==null?void 0:p.result)==null?void 0:f[0])==null?void 0:v[0])==null?void 0:m.v:l)}}transform(t,e,a){return{...t,value:t.value.toString().length}}async isValidType(t,e,a){const{value:r}=t;return typeof r=="string"||typeof r=="number"}async validatorIsEqual(t,e,a){const{formula1:r}=e;return o.Tools.isDefine(r)?t.value===r:!1}async validatorIsNotEqual(t,e,a){const{formula1:r}=e;return o.Tools.isDefine(r)?t.value!==r:!1}async validatorIsBetween(t,e,a){const{formula1:r,formula2:s}=e,{value:l}=t;if(!this._isValidFormula(r)||!this._isValidFormula(s))return!1;const d=Math.max(r,s),u=Math.min(r,s);return l>=u&&l<=d}async validatorIsNotBetween(t,e,a){const{formula1:r,formula2:s}=e,{value:l}=t;if(!this._isValidFormula(r)||!this._isValidFormula(s))return!1;const d=Math.max(r,s),u=Math.min(r,s);return l<u||l>d}async validatorIsGreaterThan(t,e,a){const{formula1:r}=e,{value:s}=t;return this._isValidFormula(r)?s>r:!1}async validatorIsGreaterThanOrEqual(t,e,a){const{formula1:r}=e,{value:s}=t;return this._isValidFormula(r)?s>=r:!1}async validatorIsLessThan(t,e,a){const{formula1:r}=e,{value:s}=t;return this._isValidFormula(r)?s<r:!1}async validatorIsLessThanOrEqual(t,e,a){const{formula1:r}=e,{value:s}=t;return this._isValidFormula(r)?s<=r:!1}generateRuleErrorMessage(t){var a,r;return t.operator?`${this.localeService.t(D.TextLengthErrorTitleMap[t.operator]).replace(xn,(a=t.formula1)!=null?a:"").replace(kn,(r=t.formula2)!=null?r:"")}`:this.titleStr}}function ia(i){var t,e;return i?i.p?!((e=(t=i.p.body)==null?void 0:t.dataStream)!=null?e:"").slice(0,-2).trim():o.Tools.isBlank(i.v):!0}function Mt(i,n,t,e){const a=[],r=[],l=e.get(D.DataValidationModel).ensureManager(i,n),d=e.get(o.IUniverInstanceService),u=U.getSheetCommandTarget(d,{unitId:i,subUnitId:n});if(!u)return{redoMutations:a,undoMutations:r};const{worksheet:c}=u,h=new o.ObjectMatrix;function p(m,V){m.forEach(_=>{o.Range.foreach(_,(C,R)=>{const y=c.getCellRaw(C,R),w=we(y);(ia(y)||w===V)&&h.setValue(C,R,{v:V,p:null})})})}t.forEach(m=>{switch(m.type){case"delete":a.push({id:D.RemoveDataValidationMutation.id,params:{unitId:i,subUnitId:n,ruleId:m.rule.uid}}),r.unshift({id:D.AddDataValidationMutation.id,params:{unitId:i,subUnitId:n,rule:m.rule,index:m.index}});break;case"update":{a.push({id:D.UpdateDataValidationMutation.id,params:{unitId:i,subUnitId:n,ruleId:m.ruleId,payload:{type:D.UpdateRuleType.RANGE,payload:m.newRanges}}}),r.unshift({id:D.UpdateDataValidationMutation.id,params:{unitId:i,subUnitId:n,ruleId:m.ruleId,payload:{type:D.UpdateRuleType.RANGE,payload:m.oldRanges}}});const V=l.getRuleById(m.ruleId);if(V&&V.type===o.DataValidationType.CHECKBOX){const C=l.getValidator(o.DataValidationType.CHECKBOX).parseFormulaSync(V,i,n);p(m.newRanges,C.formula2)}break}case"add":{if(a.push({id:D.AddDataValidationMutation.id,params:{unitId:i,subUnitId:n,rule:m.rule}}),r.unshift({id:D.RemoveDataValidationMutation.id,params:{unitId:i,subUnitId:n,ruleId:m.rule.uid}}),m.rule.type===o.DataValidationType.CHECKBOX){const _=l.getValidator(o.DataValidationType.CHECKBOX).parseFormulaSync(m.rule,i,n);p(m.rule.ranges,_.formula2)}break}}});const f={id:U.SetRangeValuesMutation.id,params:{unitId:i,subUnitId:n,cellValue:h.getData()}},v={id:U.SetRangeValuesMutation.id,params:U.SetRangeValuesUndoMutationFactory(e,f.params)};return a.push(f),r.push(v),{redoMutations:a,undoMutations:r}}const Pt={type:o.CommandType.COMMAND,id:"sheet.command.updateDataValidationRuleRange",async handler(i,n){if(!n)return!1;const{unitId:t,subUnitId:e,ranges:a,ruleId:r}=n,s=i.get(D.DataValidationModel),l=i.get(o.ICommandService),d=i.get(o.IUndoRedoService),u=s.ensureManager(t,e),c=u.getRuleById(r);if(!c)return!1;const h=c.ranges,p=u.getRuleObjectMatrix().clone();p.updateRange(r,h,a);const f=p.diff(u.getDataValidations()),{redoMutations:v,undoMutations:m}=Mt(t,e,f,i);return d.pushUndoRedo({undoMutations:m,redoMutations:v,unitID:t}),await o.sequenceExecuteAsync(v,l),!0}},At={type:o.CommandType.COMMAND,id:"sheet.command.addDataValidation",async handler(i,n){if(!n)return!1;const{unitId:t,subUnitId:e,rule:a}=n,r=i.get(D.DataValidationModel),s=i.get(o.ICommandService),l=i.get(o.IUndoRedoService),d=r.ensureManager(t,e),u=d.getRuleObjectMatrix().clone();u.addRule(a);const c=u.diff(d.getDataValidations()),h={unitId:t,subUnitId:e,rule:a},{redoMutations:p,undoMutations:f}=Mt(t,e,c,i);return p.push({id:D.AddDataValidationMutation.id,params:h}),f.unshift({id:D.RemoveDataValidationMutation.id,params:{unitId:t,subUnitId:e,ruleId:a.uid}}),l.pushUndoRedo({unitID:t,redoMutations:p,undoMutations:f}),await o.sequenceExecuteAsync(p,s),!0}},zt={type:o.CommandType.COMMAND,id:"data-validation.command.addRuleAndOpen",async handler(i){const n=i.get(o.IUniverInstanceService),t=U.getSheetCommandTarget(n);if(!t)return!1;const{workbook:e,worksheet:a}=t,r=D.createDefaultNewRule(i),s=i.get(o.ICommandService),l=e.getUnitId(),d=a.getSheetId(),u={rule:r,unitId:l,subUnitId:d};return await s.executeCommand(At.id,u)?(s.executeCommand(gt.id,{ruleId:r.uid,isAdd:!0}),!0):!1}},he={type:o.CommandType.COMMAND,id:"sheets.command.update-data-validation-setting",handler(i,n){if(!n)return!1;const t=i.get(o.ICommandService),e=i.get(o.IUndoRedoService),a=i.get(D.DataValidationModel),r=i.get(D.DataValidatorRegistryService),{unitId:s,subUnitId:l,ruleId:d,setting:u}=n,c=r.getValidatorItem(u.type);if(!c)return!1;const h=a.getRuleById(s,l,d);if(!h||!c.validatorFormula({...h,...u},s,l).success)return!1;const p={unitId:s,subUnitId:l,ruleId:d,payload:{type:D.UpdateRuleType.SETTING,payload:u}},f=[{id:D.UpdateDataValidationMutation.id,params:p}],v={unitId:s,subUnitId:l,ruleId:d,payload:{type:D.UpdateRuleType.SETTING,payload:D.getRuleSetting(h)}},m=[{id:D.UpdateDataValidationMutation.id,params:v}];if(u.type===o.DataValidationType.CHECKBOX){const _=h.ranges,C=i.get(o.IUniverInstanceService),R=U.getSheetCommandTarget(C,{unitId:s,subUnitId:l});if(R){const y=new o.ObjectMatrix,{worksheet:w}=R,{formula2:T=Ft,formula1:F=bt}=h,{formula2:j=Ft,formula1:P=bt}=u;_.forEach(W=>{o.Range.foreach(W,(x,A)=>{const L=w.getCellRaw(x,A),Y=we(L);ia(L)||Y===String(T)?y.setValue(x,A,{v:j,p:null}):Y===String(F)&&y.setValue(x,A,{v:P,p:null})})});const $={id:U.SetRangeValuesMutation.id,params:{unitId:s,subUnitId:l,cellValue:y.getData()}},b={id:U.SetRangeValuesMutation.id,params:U.SetRangeValuesUndoMutationFactory(i,$.params)};f.push($),m.push(b)}}return o.sequenceExecute(f,t).result?(e.pushUndoRedo({unitID:s,redoMutations:f,undoMutations:m}),!0):!1}},ra={type:o.CommandType.COMMAND,id:"sheets.command.update-data-validation-options",handler(i,n){if(!n)return!1;const t=i.get(o.ICommandService),e=i.get(o.IUndoRedoService),a=i.get(D.DataValidationModel),{unitId:r,subUnitId:s,ruleId:l,options:d}=n,u=a.getRuleById(r,s,l);if(!u)return!1;const c={unitId:r,subUnitId:s,ruleId:l,payload:{type:D.UpdateRuleType.OPTIONS,payload:d}},h=[{id:D.UpdateDataValidationMutation.id,params:c}],p={unitId:r,subUnitId:s,ruleId:l,payload:{type:D.UpdateRuleType.OPTIONS,payload:D.getRuleOptions(u)}},f=[{id:D.UpdateDataValidationMutation.id,params:p}];return e.pushUndoRedo({unitID:r,redoMutations:h,undoMutations:f}),t.executeCommand(D.UpdateDataValidationMutation.id,c),!0}},oa="data-validation-single",fe="sheet.menu.data-validation";function qn(i){return{id:fe,type:k.MenuItemType.SUBITEMS,positions:[k.MenuPosition.TOOLBAR_START],group:k.MenuGroup.TOOLBAR_FORMULAS_INSERT,icon:oa,tooltip:"dataValidation.title",hidden$:k.getMenuHiddenObservable(i,o.UniverInstanceType.UNIVER_SHEET),disabled$:B.getCurrentRangeDisable$(i,{workbookTypes:[U.WorkbookEditablePermission],worksheetTypes:[U.WorksheetSetCellStylePermission,U.WorksheetEditPermission],rangeTypes:[U.RangeProtectionPermissionEditPoint]})}}function Xn(i){return{id:gt.id,title:"dataValidation.panel.title",type:k.MenuItemType.BUTTON,positions:[fe]}}function Gn(i){return{id:zt.id,title:"dataValidation.panel.add",type:k.MenuItemType.BUTTON,positions:[fe]}}var zn=Object.defineProperty,Kn=Object.getOwnPropertyDescriptor,sa=(i,n,t,e)=>{for(var a=e>1?void 0:e?Kn(n,t):n,r=i.length-1,s;r>=0;r--)(s=i[r])&&(a=(e?s(n,t,a):s(a))||a);return e&&a&&zn(n,t,a),a},Q=(i,n)=>(t,e)=>n(t,e,i);const la={},da={tr:{size:6,color:"#fe4b4b"}};g.SheetsDataValidationRenderController=class extends o.RxDisposable{constructor(n,t,e,a,r,s,l,d,u,c,h,p,f){super(),this._config=n,this._commandService=t,this._menuService=e,this._renderManagerService=a,this._univerInstanceService=r,this._autoHeightController=s,this._componentManager=l,this._dropdownManagerService=d,this._dataValidationModel=u,this._dataValidatorRegistryService=c,this._injector=h,this._sheetInterceptorService=p,this._editorBridgeService=f,this._initMenu(),this._initSkeletonChange(),this._initDropdown(),this._initViewModelIntercept(),this._initAutoHeight()}_initMenu(){const{menu:n={}}=this._config;[qn,Xn,Gn].forEach(t=>{this.disposeWithMe(this._menuService.addMenuItem(t(this._injector),n))})}_initDropdown(){this._editorBridgeService&&this.disposeWithMe(this._editorBridgeService.visible$.subscribe(n=>{if(!n.visible){this._dropdownManagerService.hideDropdown();return}const t=this._editorBridgeService.getEditCellState();if(t){const{unitId:e,sheetId:a,row:r,column:s}=t,l=this._univerInstanceService.getUniverSheetInstance(e);if(!l)return;const u=this._dataValidationModel.ensureManager(e,a).getRuleByLocation(r,s);if(!u)return;const c=this._dataValidatorRegistryService.getValidatorItem(u.type);if(!(c!=null&&c.dropdown))return;const h=l.getActiveSheet();if(!h)return;const p=this._dropdownManagerService.activeDropdown,f=p==null?void 0:p.location;if(f&&f.unitId===e&&f.subUnitId===a&&f.row===r&&f.col===s)return;this._dropdownManagerService.showDropdown({location:{unitId:e,subUnitId:a,row:r,col:s,workbook:l,worksheet:h},componentKey:c.dropdown,onHide:()=>{}},!1)}}))}_initSkeletonChange(){const n=()=>{var l,d,u;const t=this._univerInstanceService.getCurrentUnitForType(o.UniverInstanceType.UNIVER_SHEET);if(!t)return;const e=t.getUnitId(),a=(l=t.getActiveSheet())==null?void 0:l.getSheetId();if(!a)return;const r=(u=(d=this._renderManagerService.getRenderById(e))==null?void 0:d.with(B.SheetSkeletonManagerService).getWorksheetSkeleton(a))==null?void 0:u.skeleton,s=this._renderManagerService.getRenderById(e);r==null||r.makeDirty(!0),r==null||r.calculate(),s&&s.mainComponent.makeForceDirty()};this.disposeWithMe(this._dataValidationModel.ruleChange$.subscribe(()=>n())),this.disposeWithMe(this._dataValidationModel.validStatusChange$.subscribe(()=>n()))}_initViewModelIntercept(){this.disposeWithMe(this._sheetInterceptorService.intercept(U.INTERCEPTOR_POINT.CELL_CONTENT,{priority:200,handler:(n,t,e)=>{var w,T,F,j,P,$;const{row:a,col:r,unitId:s,subUnitId:l,workbook:d,worksheet:u}=t,c=this._dataValidationModel.ensureManager(s,l);if(!c)return e(n);const h=(T=(w=this._renderManagerService.getRenderById(s))==null?void 0:w.with(B.SheetSkeletonManagerService).getWorksheetSkeleton(l))==null?void 0:T.skeleton;if(!h)return e(n);const p=t.workbook.getStyles(),f=(typeof(n==null?void 0:n.s)=="string"?p.get(n==null?void 0:n.s):n==null?void 0:n.s)||{},v=c.getRuleIdByLocation(a,r);if(!v)return e(n);const m=c.getRuleById(v);if(!m)return e(n);const V=u.getCellRaw(t.row,t.col),_=this._dataValidationModel.validator(J(V),m,t),C=this._dataValidatorRegistryService.getValidatorItem(m.type),R=J(n);let y={};if((m.type===o.DataValidationType.LIST||m.type===o.DataValidationType.LIST_MULTIPLE)&&(y={interceptorStyle:{...n==null?void 0:n.interceptorStyle,tb:(F=f.tb!==o.WrapStrategy.OVERFLOW?f.tb:o.WrapStrategy.CLIP)!=null?F:o.WrapStrategy.WRAP}}),m.type===o.DataValidationType.CHECKBOX&&(y={interceptorStyle:{...n==null?void 0:n.interceptorStyle,tb:o.WrapStrategy.CLIP}}),m.type===o.DataValidationType.LIST&&(m.renderMode===o.DataValidationRenderMode.ARROW||m.renderMode===o.DataValidationRenderMode.TEXT)){const b=C.getListWithColorMap(m),W=`${(j=J(n))!=null?j:""}`,x=b[W];x&&(y={...y,interceptorStyle:{...y.interceptorStyle,bg:{rgb:x}}})}return e({...n,...y,dataValidation:{ruleId:v,validStatus:_,rule:m,validator:C},markers:{...n==null?void 0:n.markers,..._===o.DataValidationStatus.INVALID?da:null},customRender:[...(P=n==null?void 0:n.customRender)!=null?P:[],...C!=null&&C.canvasRender?[C.canvasRender]:[]],fontRenderExtension:{...n==null?void 0:n.fontRenderExtension,isSkip:C==null?void 0:C.skipDefaultFontRender(m,R,t)},interceptorStyle:{...n==null?void 0:n.interceptorStyle,...y.interceptorStyle},get interceptorAutoHeight(){var x,A,L,Y;const b=h.mergeData.find(Z=>{const{startColumn:q,startRow:M,endColumn:H,endRow:tt}=Z;return a>=M&&r>=q&&a<=tt&&r<=H}),W={data:{...n,dataValidation:{ruleId:v,validStatus:_,rule:m,validator:C}},style:h.getsStyles().getStyleByCell(n),primaryWithCoord:h.getCellByIndex((x=b==null?void 0:b.startRow)!=null?x:a,(A=b==null?void 0:b.startColumn)!=null?A:r),unitId:s,subUnitId:l,row:a,col:r,workbook:d,worksheet:u};return(Y=(L=C==null?void 0:C.canvasRender)==null?void 0:L.calcCellAutoHeight)==null?void 0:Y.call(L,W)},coverable:(($=n==null?void 0:n.coverable)!=null?$:!0)&&!(m.type===o.DataValidationType.LIST||m.type===o.DataValidationType.LIST_MULTIPLE)})}}))}_initAutoHeight(){this._dataValidationModel.ruleChange$.subscribe(n=>{var t;if((t=n.rule)!=null&&t.ranges){const e=this._autoHeightController.getUndoRedoParamsOfAutoHeight(n.rule.ranges);o.sequenceExecute(e.redos,this._commandService)}})}},g.SheetsDataValidationRenderController=sa([o.OnLifecycle(o.LifecycleStages.Rendered,g.SheetsDataValidationRenderController),Q(1,o.ICommandService),Q(2,k.IMenuService),Q(3,K.IRenderManagerService),Q(4,o.IUniverInstanceService),Q(5,o.Inject(B.AutoHeightController)),Q(6,o.Inject(k.ComponentManager)),Q(7,o.Inject(mt)),Q(8,o.Inject(D.DataValidationModel)),Q(9,o.Inject(D.DataValidatorRegistryService)),Q(10,o.Inject(o.Injector)),Q(11,o.Inject(U.SheetInterceptorService)),Q(12,o.Optional(B.IEditorBridgeService))],g.SheetsDataValidationRenderController);let jt=class extends o.RxDisposable{constructor(i,n,t,e,a,r,s,l){super(),this._config=i,this._commandService=n,this._renderManagerService=t,this._univerInstanceService=e,this._autoHeightController=a,this._dataValidationModel=r,this._dataValidatorRegistryService=s,this._sheetInterceptorService=l,this._initSkeletonChange(),this._initViewModelIntercept(),this._initAutoHeight()}_initSkeletonChange(){const i=()=>{var s,l,d;const n=this._univerInstanceService.getCurrentUnitForType(o.UniverInstanceType.UNIVER_SHEET);if(!n)return;const t=n.getUnitId(),e=(s=n.getActiveSheet())==null?void 0:s.getSheetId();if(!e)return;const a=(d=(l=this._renderManagerService.getRenderById(t))==null?void 0:l.with(B.SheetSkeletonManagerService).getWorksheetSkeleton(e))==null?void 0:d.skeleton,r=this._renderManagerService.getRenderById(t);a==null||a.makeDirty(!0),a==null||a.calculate(),r&&r.mainComponent.makeForceDirty()};this.disposeWithMe(this._dataValidationModel.ruleChange$.subscribe(()=>i())),this.disposeWithMe(this._dataValidationModel.validStatusChange$.subscribe(()=>i()))}_initViewModelIntercept(){this.disposeWithMe(this._sheetInterceptorService.intercept(U.INTERCEPTOR_POINT.CELL_CONTENT,{priority:200,handler:(i,n,t)=>{var y,w,T,F,j;const{row:e,col:a,unitId:r,subUnitId:s,workbook:l,worksheet:d}=n,u=this._dataValidationModel.ensureManager(r,s);if(!u)return t(i);const c=(w=(y=this._renderManagerService.getRenderById(r))==null?void 0:y.with(B.SheetSkeletonManagerService).getWorksheetSkeleton(s))==null?void 0:w.skeleton;if(!c)return t(i);const h=n.workbook.getStyles(),p=(typeof(i==null?void 0:i.s)=="string"?h.get(i==null?void 0:i.s):i==null?void 0:i.s)||{},f=u.getRuleIdByLocation(e,a);if(!f)return t(i);const v=u.getRuleById(f);if(!v)return t(i);const m=n.worksheet.getCellRaw(n.row,n.col),V=this._dataValidationModel.validator(J(m),v,n),_=this._dataValidatorRegistryService.getValidatorItem(v.type),C=J(i);let R={};if((v.type===o.DataValidationType.LIST||v.type===o.DataValidationType.LIST_MULTIPLE)&&(R={interceptorStyle:{...i==null?void 0:i.interceptorStyle,tb:(T=p.tb!==o.WrapStrategy.OVERFLOW?p.tb:o.WrapStrategy.CLIP)!=null?T:o.WrapStrategy.WRAP}}),v.type===o.DataValidationType.CHECKBOX&&(R={interceptorStyle:{...i==null?void 0:i.interceptorStyle,tb:o.WrapStrategy.CLIP}}),v.type===o.DataValidationType.LIST&&(v.renderMode===o.DataValidationRenderMode.ARROW||v.renderMode===o.DataValidationRenderMode.TEXT)){const P=_.getListWithColorMap(v),$=`${(F=J(i))!=null?F:""}`,b=P[$];b&&(R={...R,interceptorStyle:{...R.interceptorStyle,bg:{rgb:b}}})}return t({...i,...R,dataValidation:{ruleId:f,validStatus:V,rule:v,validator:_},markers:{...i==null?void 0:i.markers,...V===o.DataValidationStatus.INVALID?da:null},customRender:[...(j=i==null?void 0:i.customRender)!=null?j:[],..._!=null&&_.canvasRender?[_.canvasRender]:[]],fontRenderExtension:{...i==null?void 0:i.fontRenderExtension,isSkip:_==null?void 0:_.skipDefaultFontRender(v,C,n)},interceptorStyle:{...i==null?void 0:i.interceptorStyle,...R.interceptorStyle},get interceptorAutoHeight(){var b,W,x,A;const P=c.mergeData.find(L=>{const{startColumn:Y,startRow:Z,endColumn:q,endRow:M}=L;return e>=Z&&a>=Y&&e<=M&&a<=q}),$={data:{...i,dataValidation:{ruleId:f,validStatus:V,rule:v,validator:_}},style:c.getsStyles().getStyleByCell(i),primaryWithCoord:c.getCellByIndex((b=P==null?void 0:P.startRow)!=null?b:e,(W=P==null?void 0:P.startColumn)!=null?W:a),unitId:r,subUnitId:s,row:e,col:a,worksheet:d,workbook:l};return(A=(x=_==null?void 0:_.canvasRender)==null?void 0:x.calcCellAutoHeight)==null?void 0:A.call(x,$)}})}}))}_initAutoHeight(){this._dataValidationModel.ruleChange$.subscribe(i=>{var n;if((n=i.rule)!=null&&n.ranges){const t=this._autoHeightController.getUndoRedoParamsOfAutoHeight(i.rule.ranges);o.sequenceExecute(t.redos,this._commandService)}})}};jt=sa([o.OnLifecycle(o.LifecycleStages.Rendered,jt),Q(1,o.ICommandService),Q(2,K.IRenderManagerService),Q(3,o.IUniverInstanceService),Q(4,o.Inject(B.AutoHeightController)),Q(5,o.Inject(D.DataValidationModel)),Q(6,o.Inject(D.DataValidatorRegistryService)),Q(7,o.Inject(U.SheetInterceptorService))],jt);var Qn=Object.defineProperty,Zn=Object.getOwnPropertyDescriptor,Jn=(i,n,t,e)=>{for(var a=e>1?void 0:e?Zn(n,t):n,r=i.length-1,s;r>=0;r--)(s=i[r])&&(a=(e?s(n,t,a):s(a))||a);return e&&a&&Qn(n,t,a),a},ti=(i,n)=>(t,e)=>n(t,e,i);g.SheetDataValidationService=class extends o.Disposable{constructor(t){super();I(this,"_currentManager");I(this,"_currentManager$",new vt.Subject);I(this,"currentManager$",this._currentManager$.asObservable());this._dataValidationModel=t,this.disposeWithMe(()=>{this._currentManager$.complete()})}get currentManager(){return this._currentManager}_ensureManager(t,e){return this._dataValidationModel.ensureManager(t,e)}switchCurrent(t,e){var r,s;if(t===((r=this.currentManager)==null?void 0:r.unitId)&&e===((s=this._currentManager)==null?void 0:s.subUnitId))return;const a=this._ensureManager(t,e);this._currentManager={manager:a,unitId:t,subUnitId:e},this._currentManager$.next(this._currentManager)}get(t,e){return this._ensureManager(t,e)}},g.SheetDataValidationService=Jn([ti(0,o.Inject(D.DataValidationModel))],g.SheetDataValidationService);var ei=Object.defineProperty,ai=Object.getOwnPropertyDescriptor,ni=(i,n,t,e)=>{for(var a=e>1?void 0:e?ai(n,t):n,r=i.length-1,s;r>=0;r--)(s=i[r])&&(a=(e?s(n,t,a):s(a))||a);return e&&a&&ei(n,t,a),a},Kt=(i,n)=>(t,e)=>n(t,e,i);g.DataValidationCustomFormulaService=class extends o.Disposable{constructor(t,e,a,r){super();I(this,"_formulaMap",new Map);I(this,"_ruleFormulaMap",new Map);I(this,"_formulaCellMap",new Map);this._registerOtherFormulaService=t,this._lexerTreeBuilder=e,this._dataValidationModel=a,this._dataValidationCacheService=r,this._initFormulaResultHandler()}_initFormulaResultHandler(){this.disposeWithMe(this._registerOtherFormulaService.formulaResult$.subscribe(t=>{for(const e in t){const a=t[e];for(const r in a){const s=a[r],{formulaCellMap:l,ruleFormulaMap:d}=this._ensureMaps(e,r),u=this._dataValidationModel.ensureManager(e,r);s.forEach(c=>{var v,m;const h=d.get((v=c.extra)==null?void 0:v.ruleId),p=l.get(c.formulaId),f=u.getRuleById((m=c.extra)==null?void 0:m.ruleId);f&&h&&!h.isTransformable&&this._dataValidationCacheService.markRangeDirty(e,r,f.ranges),p&&this._dataValidationCacheService.markCellDirty(e,r,p.row,p.column)})}}}))}_ensureMaps(t,e){let a=this._formulaMap.get(t),r=this._ruleFormulaMap.get(t),s=this._formulaCellMap.get(t);(!a||!r||!s)&&(a=new Map,r=new Map,s=new Map,this._formulaMap.set(t,a),this._ruleFormulaMap.set(t,r),this._formulaCellMap.set(t,s));let l=a.get(e),d=r.get(e),u=s.get(e);return(!l||!d||!u)&&(l=new o.ObjectMatrix,a.set(e,l),d=new Map,r.set(e,d),u=new Map,s.set(e,u)),{formulaMap:l,ruleFormulaMap:d,formulaCellMap:u}}_registerFormula(t,e,a,r){return this._registerOtherFormulaService.registerFormula(t,e,r,{ruleId:a})}deleteByRuleId(t,e,a){const{formulaMap:r,formulaCellMap:s,ruleFormulaMap:l}=this._ensureMaps(t,e),d=this._dataValidationModel.getRuleById(t,e,a),u=new Set,c=l.get(a);!d||!c||(l.delete(a),d.ranges.forEach(h=>{o.Range.foreach(h,(p,f)=>{const v=r.getValue(p,f);if(v&&v.ruleId===a){const{formulaId:m}=v;r.realDeleteValue(p,f),u.add(m),s.delete(m)}})}),this._registerOtherFormulaService.deleteFormula(t,e,Array.from(u.values())))}_addFormulaByRange(t,e,a,r,s){const{formulaMap:l,ruleFormulaMap:d,formulaCellMap:u}=this._ensureMaps(t,e);if(!r)return;const c=at.isFormulaTransformable(this._lexerTreeBuilder,r),h=s[0].startRow,p=s[0].startColumn;let f;c?s.forEach(v=>{o.Range.foreach(v,(m,V)=>{const _=at.transformFormula(this._lexerTreeBuilder,r,h,p,m,V),C=this._registerFormula(t,e,a,_);l.setValue(m,V,{formulaId:C,ruleId:a}),u.set(C,{row:m,column:V})})}):(f=this._registerFormula(t,e,a,r),s.forEach(v=>{o.Range.foreach(v,(m,V)=>{l.setValue(m,V,{formulaId:f,ruleId:a})})})),d.set(a,{formula:r,originCol:p,originRow:h,isTransformable:c,formulaId:f})}addRule(t,e,a){const{ranges:r,formula1:s,uid:l,type:d}=a;d!==o.DataValidationType.CUSTOM||!s||!o.isFormulaString(s)||this._addFormulaByRange(t,e,l,s,r)}updateRuleRanges(t,e,a,r,s){const{formulaMap:l,ruleFormulaMap:d,formulaCellMap:u}=this._ensureMaps(t,e),c=d.get(a);if(!c)return;const{formula:h,originCol:p,originRow:f,isTransformable:v,formulaId:m}=c,V=new Set;r.forEach(_=>{o.Range.foreach(_,(C,R)=>{const y=l.getValue(C,R);y&&y.ruleId===a&&(y.temp=!0)})}),s.forEach(_=>{o.Range.foreach(_,(C,R)=>{var w;const y=(w=l.getValue(C,R))!=null?w:{};if(y.ruleId!==a){const T=d.get(y.ruleId);if(T!=null&&T.isTransformable&&V.add(y.formulaId),v){const F=at.transformFormula(this._lexerTreeBuilder,h,f,p,C,R),j=this._registerFormula(t,e,a,F);l.setValue(C,R,{ruleId:a,formulaId:j}),u.set(j,{row:C,column:R})}else l.setValue(C,R,{ruleId:a,formulaId:m})}else y.temp=!1})}),r.forEach(_=>{o.Range.foreach(_,(C,R)=>{const y=l.getValue(C,R);y&&y.ruleId===a&&y.temp===!0&&(l.realDeleteValue(C,R),v&&V.add(y.formulaId))})}),V.forEach(_=>{u.delete(_)}),this._registerOtherFormulaService.deleteFormula(t,e,Array.from(V.values()))}updateRuleFormula(t,e,a,r,s){const{ruleFormulaMap:l}=this._ensureMaps(t,e),d=l.get(a);(!d||d.formula!==s)&&this._addFormulaByRange(t,e,a,s,r)}getCellFormulaValue(t,e,a,r){const{formulaMap:s}=this._ensureMaps(t,e),l=s.getValue(a,r);return l?this._registerOtherFormulaService.getFormulaValue(t,e,l.formulaId):Promise.resolve(void 0)}getRuleFormulaInfo(t,e,a){const{ruleFormulaMap:r}=this._ensureMaps(t,e);return r.get(a)}},g.DataValidationCustomFormulaService=ni([Kt(0,o.Inject(te.RegisterOtherFormulaService)),Kt(1,o.Inject(at.LexerTreeBuilder)),Kt(2,o.Inject(D.DataValidationModel)),Kt(3,o.Inject(St))],g.DataValidationCustomFormulaService);class ii extends D.BaseDataValidator{constructor(){super(...arguments);I(this,"id",o.DataValidationType.CUSTOM);I(this,"title","dataValidation.custom.title");I(this,"operators",[]);I(this,"scopes",["sheet"]);I(this,"formulaInput",He);I(this,"_customFormulaService",this.injector.get(g.DataValidationCustomFormulaService))}validatorFormula(t,e,a){const r=o.isFormulaString(t.formula1);return{success:r,formula1:r?"":this.localeService.t("dataValidation.validFail.formula")}}async parseFormula(t,e,a){return{formula1:void 0,formula2:void 0}}async isValidType(t,e,a){const{column:r,row:s,unitId:l,subUnitId:d}=t,u=await this._customFormulaService.getCellFormulaValue(l,d,s,r);return!!rt(u==null?void 0:u.result)}generateRuleErrorMessage(t){return this.localeService.t("dataValidation.custom.error")}}class ri extends D.BaseDataValidator{constructor(){super(...arguments);I(this,"_formulaService",this.injector.get(g.DataValidationFormulaService));I(this,"id",o.DataValidationType.WHOLE);I(this,"title","dataValidation.whole.title");I(this,"operators",[o.DataValidationOperator.BETWEEN,o.DataValidationOperator.EQUAL,o.DataValidationOperator.GREATER_THAN,o.DataValidationOperator.GREATER_THAN_OR_EQUAL,o.DataValidationOperator.LESS_THAN,o.DataValidationOperator.LESS_THAN_OR_EQUAL,o.DataValidationOperator.NOT_BETWEEN,o.DataValidationOperator.NOT_EQUAL]);I(this,"scopes",["sheet"]);I(this,"formulaInput",Et);I(this,"dropDownInput")}_isFormulaOrInt(t){return!o.Tools.isBlank(t)&&(o.isFormulaString(t)||!Number.isNaN(+t)&&Number.isInteger(+t))}async isValidType(t,e,a){const{value:r}=t,s=Gt(r);return!Number.isNaN(s)&&Number.isInteger(s)}transform(t,e,a){const{value:r}=t;return{...t,value:Gt(r)}}_parseNumber(t){return t==null?Number.NaN:+t}async parseFormula(t,e,a){var u,c,h,p,f,v,m,V;const r=await this._formulaService.getRuleFormulaResult(e,a,t.uid),{formula1:s,formula2:l}=t;return{formula1:this._parseNumber(o.isFormulaString(s)?(p=(h=(c=(u=r==null?void 0:r[0])==null?void 0:u.result)==null?void 0:c[0])==null?void 0:h[0])==null?void 0:p.v:s),formula2:this._parseNumber(o.isFormulaString(l)?(V=(m=(v=(f=r==null?void 0:r[1])==null?void 0:f.result)==null?void 0:v[0])==null?void 0:m[0])==null?void 0:V.v:l)}}validatorFormula(t,e,a){const r=t.operator;if(!r)return{success:!1};const s=o.Tools.isDefine(t.formula1)&&this._isFormulaOrInt(t.formula1),l=o.Tools.isDefine(t.formula2)&&this._isFormulaOrInt(t.formula2),d=kt.includes(r),u=this.localeService.t("dataValidation.validFail.number");return d?{success:s&&l,formula1:s?void 0:u,formula2:l?void 0:u}:{success:s,formula1:u}}async validatorIsEqual(t,e,a){const{formula1:r}=e,{value:s}=t;return Number.isNaN(r)?!0:s===r}async validatorIsNotEqual(t,e,a){const{formula1:r}=e;return Number.isNaN(r)?!0:t.value!==r}async validatorIsBetween(t,e,a){const{formula1:r,formula2:s}=e;if(Number.isNaN(r)||Number.isNaN(s))return!0;const l=Math.min(r,s),d=Math.max(r,s);return t.value>=l&&t.value<=d}async validatorIsNotBetween(t,e,a){const{formula1:r,formula2:s}=e;if(Number.isNaN(r)||Number.isNaN(s))return!0;const l=Math.min(r,s),d=Math.max(r,s);return t.value<l||t.value>d}async validatorIsGreaterThan(t,e,a){const{formula1:r}=e;return Number.isNaN(r)?!0:t.value>r}async validatorIsGreaterThanOrEqual(t,e,a){const{formula1:r}=e;return Number.isNaN(r)?!0:t.value>=r}async validatorIsLessThan(t,e,a){const{formula1:r}=e;return Number.isNaN(r)?!0:t.value<r}async validatorIsLessThanOrEqual(t,e,a){const{formula1:r}=e;return Number.isNaN(r)?!0:t.value<=r}}const ua=4,oi=0,pe=4,ca=4,ve=6,Qt=6,Vt=14;function si(i,n){const t=K.FontCache.getTextSize(i,n),e=t.width+ua*2,{ba:a,bd:r}=t,s=a+r;return{width:e,height:s+oi*2,ba:a}}function ma(i,n,t,e){const a=t-Vt-ve,r=e-Qt*2,s=i.map(c=>({layout:si(c,n),text:c}));let l;const d=[];s.forEach(c=>{const{layout:h}=c,{width:p,height:f}=h;!l||l.width+p+pe>a?(l={width:p,height:f,items:[{...c,left:0}]},d.push(l)):(l.items.push({...c,left:l.width+pe}),l.width=l.width+p+pe)});let u=0;return d.forEach((c,h)=>{h===d.length-1?u+=c.height:u+=c.height+ca}),{lines:d,totalHeight:u,contentWidth:a,contentHeight:r,cellAutoHeight:u+Qt*2}}const li=8;class di extends K.Shape{static drawWith(n,t){const{fontFamily:e,fontString:a,fontSize:r,info:s,fill:l,color:d}=t,{layout:u,text:c}=s;n.save(),K.Rect.drawWith(n,{width:u.width,height:u.height,radius:li,fill:l||_t}),n.translateWithPrecision(ua,u.ba),n.font=a,n.fillStyle=d,n.fillText(c,0,0),n.restore()}}var ui=Object.defineProperty,ci=Object.getOwnPropertyDescriptor,mi=(i,n,t,e)=>{for(var a=e>1?void 0:e?ci(n,t):n,r=i.length-1,s;r>=0;r--)(s=i[r])&&(a=(e?s(n,t,a):s(a))||a);return e&&a&&ui(n,t,a),a},hi=(i,n)=>(t,e)=>n(t,e,i);const fi=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 ge=class{constructor(i){I(this,"zIndex");I(this,"_dropdownInfoMap",new Map);this._commandService=i}_ensureMap(i){let n=this._dropdownInfoMap.get(i);return n||(n=new Map,this._dropdownInfoMap.set(i,n)),n}_generateKey(i,n){return`${i}.${n}`}_drawDownIcon(i,n,t,e,a){const r=t-Vt+4;let s=4;switch(a){case o.VerticalAlign.MIDDLE:s=(e-Vt)/2+4;break;case o.VerticalAlign.BOTTOM:s=e-Vt+4;break}i.save(),i.translateWithPrecision(n.startX+r,n.startY+s),i.fillStyle="#565656",i.fill(fi),i.restore()}drawWith(i,n,t,e){var H,tt;const{primaryWithCoord:a,row:r,col:s,style:l,data:d,subUnitId:u}=n,c=a.isMergedMainCell?a.mergeInfo:a,h=d.fontRenderExtension,{leftOffset:p=0,rightOffset:f=0,topOffset:v=0,downOffset:m=0}=h||{},V=d.dataValidation,_=this._ensureMap(u),C=this._generateKey(r,s);if(!V)return;const R={startX:c.startX+p,endX:c.endX-f,startY:c.startY+v,endY:c.endY-m},y=R.endX-R.startX,w=R.endY-R.startY,{cl:T}=l||{},F=(H=typeof T=="object"?T==null?void 0:T.rgb:T)!=null?H:"#000",j=K.getFontStyleString(l!=null?l:void 0),{rule:P,validator:$}=V,b=$,{vt:W,ht:x}=l||{},A=W!=null?W:o.VerticalAlign.MIDDLE,L=(tt=J(d))!=null?tt:"",Y=b.parseCellValue(L),Z=b.getListWithColorMap(P),q=ma(Y,j,y,w);this._drawDownIcon(i,R,y,w,A),i.save(),i.translateWithPrecision(R.startX,R.startY),i.beginPath(),i.rect(0,0,y-Vt,w),i.clip(),i.translateWithPrecision(ve,Qt);let M=0;switch(A){case o.VerticalAlign.MIDDLE:M=(q.contentHeight-q.totalHeight)/2;break;case o.VerticalAlign.BOTTOM:M=q.contentHeight-q.totalHeight;break}i.translateWithPrecision(0,M),q.lines.forEach((G,dt)=>{i.save();const{width:N,height:X,items:z}=G;let et=0;switch(x){case o.HorizontalAlign.RIGHT:et=q.contentWidth-N;break;case o.HorizontalAlign.CENTER:et=(q.contentWidth-N)/2;break}i.translate(et,dt*(X+ca)),z.forEach(ct=>{i.save(),i.translateWithPrecision(ct.left,0),di.drawWith(i,{...j,info:ct,color:F,fill:Z[ct.text]}),i.restore()}),i.restore()}),i.restore(),_.set(C,{left:R.startX,top:R.startY,width:q.contentWidth+ve+Vt,height:q.contentHeight+Qt*2})}calcCellAutoHeight(i){var y;const{primaryWithCoord:n,style:t,data:e}=i,a=e.fontRenderExtension,{leftOffset:r=0,rightOffset:s=0,topOffset:l=0,downOffset:d=0}=a||{},u=n.isMergedMainCell?n.mergeInfo:n,c={startX:u.startX+r,endX:u.endX-s,startY:u.startY+l,endY:u.endY-d},h=e.dataValidation;if(!h)return;const p=c.endX-c.startX,f=c.endY-c.startY,v=(y=J(e))!=null?y:"",{validator:m}=h,_=m.parseCellValue(v),C=K.getFontStyleString(t!=null?t:void 0);return ma(_,C,p,f).cellAutoHeight}isHit(i,n){const{primaryWithCoord:t}=n,e=t.isMergedMainCell?t.mergeInfo:t,{endX:a}=e,{x:r}=i;return r>=a-Vt&&r<=a}onPointerDown(i,n){if(n.button===2)return;const{unitId:t,subUnitId:e,row:a,col:r}=i,s={unitId:t,subUnitId:e,row:a,column:r};this._commandService.executeCommand(Ot.id,s)}};ge=mi([hi(0,o.ICommandService)],ge);class pi extends na{constructor(){super(...arguments);I(this,"id",o.DataValidationType.LIST_MULTIPLE);I(this,"title","dataValidation.listMultiple.title");I(this,"canvasRender",this.injector.createInstance(ge))}skipDefaultFontRender(){return!0}}var vi=Object.defineProperty,gi=Object.getOwnPropertyDescriptor,Si=(i,n,t,e)=>{for(var a=e>1?void 0:e?gi(n,t):n,r=i.length-1,s;r>=0;r--)(s=i[r])&&(a=(e?s(n,t,a):s(a))||a);return e&&a&&vi(n,t,a),a},pt=(i,n)=>(t,e)=>n(t,e,i);g.DataValidationController=class extends o.RxDisposable{constructor(n,t,e,a,r,s,l,d){super(),this._univerInstanceService=n,this._sheetDataValidationService=t,this._dataValidatorRegistryService=e,this._injector=a,this._componentManger=r,this._selectionManagerService=s,this._sheetInterceptorService=l,this._dataValidationModel=d,this._init()}_init(){this._registerValidators(),this._initInstanceChange(),this._initCommandInterceptor(),this._initComponents()}_registerValidators(){[Hn,ri,Yn,bn,dn,na,pi,ii].forEach(n=>{const t=this._injector.createInstance(n);this.disposeWithMe(this._dataValidatorRegistryService.register(t)),this.disposeWithMe({dispose:()=>{this._injector.delete(n)}})})}_initInstanceChange(){const n=new o.DisposableCollection;this.disposeWithMe(this._univerInstanceService.getCurrentTypeOfUnit$(o.UniverInstanceType.UNIVER_SHEET).subscribe(t=>{if(n.dispose(),!t)return;const e=t.getActiveSheet();e&&(this._sheetDataValidationService.switchCurrent(t.getUnitId(),e.getSheetId()),n.add(o.toDisposable(t.activeSheet$.subscribe(a=>{if(a){const r=t.getUnitId(),s=a.getSheetId();this._sheetDataValidationService.switchCurrent(r,s)}}))))})),this.disposeWithMe(n)}_initCommandInterceptor(){this._sheetInterceptorService.interceptCommand({getMutations:n=>{var t;if(n.id===U.ClearSelectionAllCommand.id){const e=this._univerInstanceService.getCurrentUnitForType(o.UniverInstanceType.UNIVER_SHEET),a=e.getUnitId(),r=e.getActiveSheet();if(!r)throw new Error("No active sheet found");const s=r.getSheetId(),l=(t=this._selectionManagerService.getCurrentSelections())==null?void 0:t.map(f=>f.range),d=this._dataValidationModel.ensureManager(a,s),u=d.getRuleObjectMatrix().clone();l&&u.removeRange(l);const c=u.diff(d.getDataValidations()),{redoMutations:h,undoMutations:p}=Mt(a,s,c,this._injector);return{undos:p,redos:h}}return{undos:[],redos:[]}}})}_initComponents(){[[oa,Pe],[Fe,gn],[Ee,wa],[ze,_n],[Ke,Mn],[Xt.componentKey,Xt],[qt.componentKey,qt],...ln].forEach(([n,t])=>{this.disposeWithMe(this._componentManger.register(n,t))})}},g.DataValidationController=Si([o.OnLifecycle(o.LifecycleStages.Rendered,g.DataValidationController),pt(0,o.IUniverInstanceService),pt(1,o.Inject(g.SheetDataValidationService)),pt(2,o.Inject(D.DataValidatorRegistryService)),pt(3,o.Inject(o.Injector)),pt(4,o.Inject(k.ComponentManager)),pt(5,o.Inject(U.SheetsSelectionsService)),pt(6,o.Inject(U.SheetInterceptorService)),pt(7,o.Inject(D.DataValidationModel))],g.DataValidationController);var _i=Object.defineProperty,Di=Object.getOwnPropertyDescriptor,Vi=(i,n,t,e)=>{for(var a=e>1?void 0:e?Di(n,t):n,r=i.length-1,s;r>=0;r--)(s=i[r])&&(a=(e?s(n,t,a):s(a))||a);return e&&a&&_i(n,t,a),a},Zt=(i,n)=>(t,e)=>n(t,e,i);const Se="SHEET_DATA_VALIDATION_ALERT";g.DataValidationAlertController=class extends o.Disposable{constructor(n,t,e,a){super(),this._hoverManagerService=n,this._cellAlertManagerService=t,this._univerInstanceService=e,this._localeService=a,this._init()}_init(){this._initCellAlertPopup()}_initCellAlertPopup(){this.disposeWithMe(this._hoverManagerService.currentCell$.pipe(vt.debounceTime(100)).subscribe(n=>{var t,e;if(n){const r=this._univerInstanceService.getCurrentUnitForType(o.UniverInstanceType.UNIVER_SHEET).getActiveSheet();if(!r)return;const s=r.getCell(n.location.row,n.location.col);if(((t=s==null?void 0:s.dataValidation)==null?void 0:t.validStatus)===o.DataValidationStatus.INVALID){const l=this._cellAlertManagerService.currentAlert.get(Se),d=(e=l==null?void 0:l.alert)==null?void 0:e.location;if(d&&d.row===n.location.row&&d.col===n.location.col&&d.subUnitId===n.location.subUnitId&&d.unitId===n.location.unitId)return;const u=s.dataValidation.validator,c=s.dataValidation.rule;if(!u)return;this._cellAlertManagerService.showAlert({type:B.CellAlertType.ERROR,title:this._localeService.t("dataValidation.error.title"),message:u==null?void 0:u.getRuleFinalError(c),location:n.location,width:200,height:74,key:Se});return}}this._cellAlertManagerService.removeAlert(Se)}))}},g.DataValidationAlertController=Vi([o.OnLifecycle(o.LifecycleStages.Rendered,g.DataValidationAlertController),Zt(0,o.Inject(B.HoverManagerService)),Zt(1,o.Inject(B.CellAlertManagerService)),Zt(2,o.IUniverInstanceService),Zt(3,o.Inject(o.LocaleService))],g.DataValidationAlertController);var Ri=Object.defineProperty,Ii=Object.getOwnPropertyDescriptor,Ci=(i,n,t,e)=>{for(var a=e>1?void 0:e?Ii(n,t):n,r=i.length-1,s;r>=0;r--)(s=i[r])&&(a=(e?s(n,t,a):s(a))||a);return e&&a&&Ri(n,t,a),a},wt=(i,n)=>(t,e)=>n(t,e,i);g.DataValidationRefRangeController=class extends o.Disposable{constructor(t,e,a,r,s,l){super();I(this,"_disposableMap",new Map);I(this,"registerRule",(t,e,a)=>{this.register(t,e,a),this.registerFormula(t,e,a)});this._dataValidationModel=t,this._injector=e,this._refRangeService=a,this._dataValidationCustomFormulaService=r,this._dataValidationFormulaService=s,this._formulaRefRangeService=l,this._initRefRange()}_getIdWithUnitId(t,e,a){return`${t}_${e}_${a}`}registerFormula(t,e,a){var u;const r=a.uid,s=this._getIdWithUnitId(t,e,r),l=(u=this._disposableMap.get(s))!=null?u:new Set,d=(c,h)=>{const p=this._dataValidationModel.getRuleById(t,e,r);if(!p)return{redos:[],undos:[]};const f=p[c];if(!f||f===h)return{redos:[],undos:[]};const v={unitId:t,subUnitId:e,ruleId:a.uid,payload:{type:D.UpdateRuleType.SETTING,payload:{type:p.type,formula1:p.formula1,formula2:p.formula2,[c]:h}}},m={unitId:t,subUnitId:e,ruleId:a.uid,payload:{type:D.UpdateRuleType.SETTING,payload:{type:p.type,formula1:p.formula1,formula2:p.formula2}}},V=[{id:D.UpdateDataValidationMutation.id,params:v}],_=[{id:D.UpdateDataValidationMutation.id,params:m}];return{redos:V,undos:_}};if(a.type===o.DataValidationType.CUSTOM){const c=this._dataValidationCustomFormulaService.getRuleFormulaInfo(t,e,r);if(c){const h=this._formulaRefRangeService.registerFormula(c.formula,p=>d("formula1",p));l.add(()=>h.dispose())}}if(a.type!==o.DataValidationType.CUSTOM){const c=this._dataValidationFormulaService.getRuleFormulaInfo(t,e,r);if(c){const[h,p]=c;if(h){const f=this._formulaRefRangeService.registerFormula(h.text,v=>d("formula1",v));l.add(()=>f.dispose())}if(p){const f=this._formulaRefRangeService.registerFormula(p.text,v=>d("formula1",v));l.add(()=>f.dispose())}}}}register(t,e,a){var u;const r=c=>{const h=[...a.ranges],f=h.map(m=>U.handleCommonDefaultRangeChangeWithEffectRefCommands(m,c)).filter(m=>!!m).flat();if(o.isRangesEqual(f,h))return{redos:[],undos:[]};if(f.length){const m={unitId:t,subUnitId:e,ruleId:a.uid,payload:{type:D.UpdateRuleType.RANGE,payload:f}},V=[{id:D.UpdateDataValidationMutation.id,params:m}],_=[{id:D.UpdateDataValidationMutation.id,params:{unitId:t,subUnitId:e,ruleId:a.uid,payload:{type:D.UpdateRuleType.RANGE,payload:h}}}];return{redos:V,undos:_}}else{const m={unitId:t,subUnitId:e,ruleId:a.uid},V=[{id:D.RemoveDataValidationMutation.id,params:m}],_=D.removeDataValidationUndoFactory(this._injector,m);return{redos:V,undos:_}}},s=[];a.ranges.forEach(c=>{const h=this._refRangeService.registerRefRange(c,r,t,e);s.push(()=>h.dispose())});const l=this._getIdWithUnitId(t,e,a.uid),d=(u=this._disposableMap.get(l))!=null?u:new Set;d.add(()=>s.forEach(c=>c())),this._disposableMap.set(l,d)}_initRefRange(){this.disposeWithMe(this._dataValidationModel.ruleChange$.subscribe(t=>{const{unitId:e,subUnitId:a,rule:r}=t;switch(t.type){case"add":{const s=t.rule;this.registerRule(t.unitId,t.subUnitId,s);break}case"remove":{const s=this._disposableMap.get(this._getIdWithUnitId(e,a,r.uid));s&&s.forEach(l=>l());break}case"update":{const s=t.rule,l=this._disposableMap.get(this._getIdWithUnitId(e,a,s.uid));l&&l.forEach(d=>d()),this.registerRule(t.unitId,t.subUnitId,s);break}}})),this.disposeWithMe(o.toDisposable(()=>{this._disposableMap.forEach(t=>{t.forEach(e=>e())}),this._disposableMap.clear()}))}},g.DataValidationRefRangeController=Ci([o.OnLifecycle(o.LifecycleStages.Ready,g.DataValidationRefRangeController),wt(0,o.Inject(D.DataValidationModel)),wt(1,o.Inject(o.Injector)),wt(2,o.Inject(U.RefRangeService)),wt(3,o.Inject(g.DataValidationCustomFormulaService)),wt(4,o.Inject(g.DataValidationFormulaService)),wt(5,o.Inject(te.FormulaRefRangeService))],g.DataValidationRefRangeController);var yi=Object.defineProperty,Mi=Object.getOwnPropertyDescriptor,wi=(i,n,t,e)=>{for(var a=e>1?void 0:e?Mi(n,t):n,r=i.length-1,s;r>=0;r--)(s=i[r])&&(a=(e?s(n,t,a):s(a))||a);return e&&a&&yi(n,t,a),a},_e=(i,n)=>(t,e)=>n(t,e,i);g.DataValidationAutoFillController=class extends o.Disposable{constructor(n,t,e){super(),this._autoFillService=n,this._dataValidationModel=t,this._injector=e,this._initAutoFill()}_initAutoFill(){const n=()=>({redos:[],undos:[]}),t=r=>{const{source:s,target:l,unitId:d,subUnitId:u}=r,c=this._dataValidationModel.ensureManager(d,u),h=c.getRuleObjectMatrix().clone(),p=B.virtualizeDiscreteRanges([s,l]),[f,v]=p.ranges,{mapFunc:m}=p,V={row:f.startRow,col:f.startColumn};B.getAutoFillRepeatRange(f,v).forEach(w=>{const T=w.repeatStartCell,F=w.relativeRange,j={startRow:V.row,startColumn:V.col,endColumn:V.col,endRow:V.row},P={startRow:T.row,startColumn:T.col,endColumn:T.col,endRow:T.row};o.Range.foreach(F,($,b)=>{const W=o.Rectangle.getPositionRange({startRow:$,startColumn:b,endColumn:b,endRow:$},j),{row:x,col:A}=m(W.startRow,W.startColumn),L=c.getRuleIdByLocation(x,A);if(L){const Y=o.Rectangle.getPositionRange({startRow:$,startColumn:b,endColumn:b,endRow:$},P),{row:Z,col:q}=m(Y.startRow,Y.startColumn);h.setValue(Z,q,L)}})});const C=h.diff(c.getDataValidations()),{redoMutations:R,undoMutations:y}=Mt(d,u,C,this._injector);return{undos:y,redos:R}},e=[o.DataValidationType.CHECKBOX],a={id:Tt,onBeforeFillData:r=>{const{source:s,unitId:l,subUnitId:d}=r,u=this._dataValidationModel.ensureManager(l,d);for(const c of s.rows)for(const h of s.cols){const p=u.getRuleByLocation(c,h);if(p&&e.indexOf(p.type)>-1){this._autoFillService.setDisableApplyType(B.APPLY_TYPE.SERIES,!0);return}}},onFillData:(r,s,l)=>l===B.APPLY_TYPE.COPY||l===B.APPLY_TYPE.ONLY_FORMAT||l===B.APPLY_TYPE.SERIES?t(r):n(),onAfterFillData:()=>{}};this.disposeWithMe(this._autoFillService.addHook(a))}},g.DataValidationAutoFillController=wi([o.OnLifecycle(o.LifecycleStages.Ready,g.DataValidationAutoFillController),_e(0,B.IAutoFillService),_e(1,o.Inject(D.DataValidationModel)),_e(2,o.Inject(o.Injector))],g.DataValidationAutoFillController);var Oi=Object.defineProperty,Ti=Object.getOwnPropertyDescriptor,Ei=(i,n,t,e)=>{for(var a=e>1?void 0:e?Ti(n,t):n,r=i.length-1,s;r>=0;r--)(s=i[r])&&(a=(e?s(n,t,a):s(a))||a);return e&&a&&Oi(n,t,a),a},De=(i,n)=>(t,e)=>n(t,e,i);g.DataValidationCopyPasteController=class extends o.Disposable{constructor(t,e,a){super();I(this,"_copyInfo");this._sheetClipboardService=t,this._dataValidationModel=e,this._injector=a,this._initCopyPaste()}_initCopyPaste(){this._sheetClipboardService.addClipboardHook({id:Tt,onBeforeCopy:(t,e,a)=>this._collect(t,e,a),onPasteCells:(t,e,a,r)=>{const{copyType:s=B.COPY_TYPE.COPY,pasteType:l}=r,{range:d}=t||{},{range:u,unitId:c,subUnitId:h}=e;return this._generateMutations(u,{copyType:s,pasteType:l,copyRange:d,unitId:c,subUnitId:h})}})}_collect(t,e,a){const r=new o.ObjectMatrix;this._copyInfo={unitId:t,subUnitId:e,matrix:r};const s=this._dataValidationModel.ensureManager(t,e),l={get:this._injector.get.bind(this._injector)},d=B.rangeToDiscreteRange(a,l,t,e);if(!d)return;const{rows:u,cols:c}=d;u.forEach((h,p)=>{c.forEach((f,v)=>{const m=s.getRuleIdByLocation(h,f);r.setValue(p,v,m!=null?m:"")})})}_generateMutations(t,e){if(!this._copyInfo)return{redos:[],undos:[]};if(e.copyType===B.COPY_TYPE.CUT)return this._copyInfo=null,{redos:[],undos:[]};if(!this._copyInfo||!this._copyInfo.matrix.getSizeOf()||!e.copyRange)return{redos:[],undos:[]};if([B.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_COL_WIDTH,B.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_VALUE,B.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMAT,B.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMULA].includes(e.pasteType))return{redos:[],undos:[]};const{unitId:a,subUnitId:r}=this._copyInfo;if(e.unitId!==a||r!==e.subUnitId){const s=this._dataValidationModel.ensureManager(a,r),l=this._dataValidationModel.ensureManager(e.unitId,e.subUnitId),d=l.getRuleObjectMatrix().clone(),{ranges:[u,c],mapFunc:h}=B.virtualizeDiscreteRanges([e.copyRange,t]),p=B.getRepeatRange(u,c,!0),f=new Map;p.forEach(({startRange:V})=>{var _;(_=this._copyInfo)==null||_.matrix.forValue((C,R,y)=>{const w=o.Rectangle.getPositionRange({startRow:C,endRow:C,startColumn:R,endColumn:R},V),T=`${r}-${y}`,F=s.getRuleById(y);!l.getRuleById(T)&&F&&f.set(T,{...F,uid:T});const{row:j,col:P}=h(w.startRow,w.startColumn);d.setValue(j,P,T)})});const{redoMutations:v,undoMutations:m}=Mt(e.unitId,e.subUnitId,d.diffWithAddition(l.getDataValidations(),f.values()),this._injector);return{redos:v,undos:m}}else{const s=this._dataValidationModel.ensureManager(a,r),l=s.getRuleObjectMatrix().clone(),{ranges:[d,u],mapFunc:c}=B.virtualizeDiscreteRanges([e.copyRange,t]);B.getRepeatRange(d,u,!0).forEach(({startRange:v})=>{var m;(m=this._copyInfo)==null||m.matrix.forValue((V,_,C)=>{const R=o.Rectangle.getPositionRange({startRow:V,endRow:V,startColumn:_,endColumn:_},v),{row:y,col:w}=c(R.startRow,R.startColumn);l.setValue(y,w,C)})});const{redoMutations:p,undoMutations:f}=Mt(a,r,l.diff(s.getDataValidations()),this._injector);return{redos:p,undos:f}}}},g.DataValidationCopyPasteController=Ei([o.OnLifecycle(o.LifecycleStages.Ready,g.DataValidationCopyPasteController),De(0,B.ISheetClipboardService),De(1,o.Inject(D.DataValidationModel)),De(2,o.Inject(o.Injector))],g.DataValidationCopyPasteController);class Ve{constructor(n,t){I(this,"value");this._worksheet=t,this.value=n}addRule(n){const t=n.uid;n.ranges.forEach(e=>{o.Range.foreach(o.Range.transformRange(e,this._worksheet),(a,r)=>{this.value.setValue(a,r,t)})})}removeRange(n){n.forEach(t=>{o.Range.foreach(o.Range.transformRange(t,this._worksheet),(e,a)=>{this.value.realDeleteValue(e,a)})})}removeRule(n){n.ranges.forEach(t=>{o.Range.foreach(o.Range.transformRange(t,this._worksheet),(e,a)=>{this.value.setValue(e,a,"")})})}updateRange(n,t,e){const a=`${n}$`,r=t.map(l=>o.Range.transformRange(l,this._worksheet)),s=e.map(l=>o.Range.transformRange(l,this._worksheet));r.forEach(l=>{o.Range.foreach(l,(d,u)=>{this.value.getValue(d,u)===n&&this.value.setValue(d,u,a)})}),s.forEach(l=>{o.Range.foreach(l,(d,u)=>{this.value.setValue(d,u,n)})}),r.forEach(l=>{o.Range.foreach(l,(d,u)=>{this.value.getValue(d,u)===a&&this.value.realDeleteValue(d,u)})})}diff(n){const t=[];let e=0;return n.forEach((a,r)=>{const s=o.queryObjectMatrix(this.value,d=>d===a.uid),l=a.ranges;(s.length!==l.length||s.some((d,u)=>!o.Rectangle.equals(d,l[u])))&&t.push({type:"update",ruleId:a.uid,oldRanges:l,newRanges:s}),s.length===0&&(t.push({type:"delete",rule:a,index:r-e}),e++)}),t}diffWithAddition(n,t){const e=[];let a=0;return n.forEach((r,s)=>{const l=o.queryObjectMatrix(this.value,u=>u===r.uid),d=r.ranges;(l.length!==d.length||l.some((u,c)=>!o.Rectangle.equals(u,d[c])))&&e.push({type:"update",ruleId:r.uid,oldRanges:d,newRanges:l}),l.length===0&&(e.push({type:"delete",rule:r,index:s-a}),a++)}),Array.from(t).forEach(r=>{const s=o.queryObjectMatrix(this.value,l=>l===r.uid);e.push({type:"add",rule:{...r,ranges:s}})}),e}clone(){return new Ve(new o.ObjectMatrix(this.value.clone()),this._worksheet)}getValue(n,t){return this.value.getValue(n,t)}setValue(n,t,e){return this.value.setValue(n,t,e)}}class bi extends D.DataValidationManager{constructor(t,e,a,r){super(t,e,a);I(this,"_ruleMatrix");I(this,"_dataValidatorRegistryService");I(this,"_dataValidationCacheService");I(this,"_dataValidationFormulaService");I(this,"_dataValidationCustomFormulaService");I(this,"_cache");I(this,"_dataValidationRefRangeController");this._injector=r,this._dataValidatorRegistryService=this._injector.get(D.DataValidatorRegistryService),this._dataValidationCacheService=this._injector.get(St),this._dataValidationFormulaService=this._injector.get(g.DataValidationFormulaService),this._dataValidationCustomFormulaService=this._injector.get(g.DataValidationCustomFormulaService),this._dataValidationRefRangeController=this._injector.get(g.DataValidationRefRangeController),this._cache=this._dataValidationCacheService.ensureCache(t,e);const l=this._injector.get(o.IUniverInstanceService).getUnit(t,o.UniverInstanceType.UNIVER_SHEET).getSheetBySheetId(e),d=new o.ObjectMatrix;a==null||a.forEach(u=>{const c=u.uid;u.ranges.forEach(h=>{o.Range.foreach(h,(p,f)=>{d.setValue(p,f,c)})})}),a==null||a.forEach(u=>{this._dataValidationRefRangeController.register(t,e,u)}),this._ruleMatrix=new Ve(d,l)}_addRuleSideEffect(t){var r;const{unitId:e,subUnitId:a}=this;(t.type===o.DataValidationType.LIST||t.type===o.DataValidationType.LIST_MULTIPLE)&&at.isReferenceString((r=t.formula1)!=null?r:"")&&(t.formula1=`=${t.formula1}`),this._ruleMatrix.addRule(t),this._dataValidationCacheService.addRule(e,a,t),this._dataValidationFormulaService.addRule(e,a,t.uid,t.formula1,t.formula2),this._dataValidationCustomFormulaService.addRule(e,a,t)}addRule(t,e){(Array.isArray(t)?t:[t]).forEach(r=>{this._addRuleSideEffect(r)}),super.addRule(t,e)}updateRule(t,e){const a=this.getRuleById(t);if(!a)throw new Error(`Rule not found! id: ${t}`);return e.type===D.UpdateRuleType.RANGE?(this._ruleMatrix.updateRange(t,a.ranges,e.payload),this._dataValidationCacheService.updateRuleRanges(this.unitId,this.subUnitId,t,e.payload,a.ranges),this._dataValidationCustomFormulaService.updateRuleRanges(this.unitId,this.subUnitId,t,a.ranges,e.payload)):e.type===D.UpdateRuleType.SETTING&&(this._dataValidationCacheService.markRangeDirty(this.unitId,this.subUnitId,a.ranges),this._dataValidationFormulaService.updateRuleFormulaText(this.unitId,this.subUnitId,t,e.payload.formula1,e.payload.formula2),this._dataValidationCustomFormulaService.updateRuleFormula(this.unitId,this.subUnitId,t,a.ranges,e.payload.formula1)),super.updateRule(t,e)}removeRule(t){const e=this.getRuleById(t);e&&(this._ruleMatrix.removeRule(e),this._dataValidationCacheService.removeRule(this.unitId,this.subUnitId,e)),super.removeRule(t)}getValidator(t){return this._dataValidatorRegistryService.getValidatorItem(t)}getRuleIdByLocation(t,e){return this._ruleMatrix.getValue(t,e)}getRuleByLocation(t,e){const a=this.getRuleIdByLocation(t,e);if(a)return this.getRuleById(a)}validator(t,e,a,r){const{col:s,row:l,unitId:d,subUnitId:u}=a,c=e.uid,h=this.getValidator(e.type);if(h){const p=this._cache.getValue(l,s);return!p||p.value!==t?(this._cache.setValue(l,s,{value:t,status:o.DataValidationStatus.VALIDATING,ruleId:c}),h.validator({value:t,unitId:d,subUnitId:u,row:l,column:s},e).then(f=>{const v=f?o.DataValidationStatus.VALID:o.DataValidationStatus.INVALID;this._cache.setValue(l,s,{value:t,status:v,ruleId:c}),r(v,!0)}),o.DataValidationStatus.VALIDATING):(r(p.status,!1),p.status)}else return r(o.DataValidationStatus.VALID,!1),o.DataValidationStatus.VALID}getRuleErrorMsg(t){const e=this.getRuleById(t);if(!e)return"";const a=this._dataValidatorRegistryService.getValidatorItem(e.type);return e.error?e.error:a?a.getRuleFinalError(e):""}getRuleObjectMatrix(){return this._ruleMatrix}}var Fi=Object.defineProperty,Ni=Object.getOwnPropertyDescriptor,Li=(i,n,t,e)=>{for(var a=e>1?void 0:e?Ni(n,t):n,r=i.length-1,s;r>=0;r--)(s=i[r])&&(a=(e?s(n,t,a):s(a))||a);return e&&a&&Fi(n,t,a),a},Jt=(i,n)=>(t,e)=>n(t,e,i);let Ut=class extends o.Disposable{constructor(i,n,t,e){super(),this._resourceManagerService=i,this._univerInstanceService=n,this._dataValidationModel=t,this._injector=e,this._initDataValidationDataSource()}_createSheetDataValidationManager(i,n){return new bi(i,n,[],this._injector)}_initDataValidationDataSource(){this._dataValidationModel.setManagerCreator(this._createSheetDataValidationManager.bind(this))}};Ut=Li([o.OnLifecycle(o.LifecycleStages.Starting,Ut),Jt(0,o.IResourceManagerService),Jt(1,o.IUniverInstanceService),Jt(2,o.Inject(D.DataValidationModel)),Jt(3,o.Inject(o.Injector))],Ut);var Pi=Object.defineProperty,Ai=Object.getOwnPropertyDescriptor,ji=(i,n,t,e)=>{for(var a=e>1?void 0:e?Ai(n,t):n,r=i.length-1,s;r>=0;r--)(s=i[r])&&(a=(e?s(n,t,a):s(a))||a);return e&&a&&Pi(n,t,a),a},Re=(i,n)=>(t,e)=>n(t,e,i);let Bt=class extends o.Disposable{constructor(i,n,t){super(),this._localeService=i,this._commandService=n,this._sheetPermissionInterceptorBaseController=t,this._commandExecutedListener()}_commandExecutedListener(){this.disposeWithMe(this._commandService.beforeCommandExecuted(i=>{i.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"))),i.id===Pt.id&&(this._sheetPermissionInterceptorBaseController.permissionCheckWithRanges({workbookTypes:[U.WorkbookEditablePermission],rangeTypes:[U.RangeProtectionPermissionEditPoint],worksheetTypes:[U.WorksheetEditPermission,U.WorksheetSetCellStylePermission]},i.params.ranges)||this._sheetPermissionInterceptorBaseController.haveNotPermissionHandle(this._localeService.t("permission.dialog.setStyleErr")))}))}};Bt=ji([o.OnLifecycle(o.LifecycleStages.Ready,Bt),Re(0,o.Inject(o.LocaleService)),Re(1,o.ICommandService),Re(2,o.Inject(B.SheetPermissionInterceptorBaseController))],Bt);var Ui=Object.defineProperty,Bi=Object.getOwnPropertyDescriptor,$i=(i,n,t,e)=>{for(var a=e>1?void 0:e?Bi(n,t):n,r=i.length-1,s;r>=0;r--)(s=i[r])&&(a=(e?s(n,t,a):s(a))||a);return e&&a&&Ui(n,t,a),a},Ie=(i,n)=>(t,e)=>n(t,e,i);g.SheetsDataValidationValidatorService=class{constructor(n,t,e){this._univerInstanceService=n,this._dataValidationModel=t,this._dataValidationCacheService=e}async validatorCell(n,t,e,a){const r=this._univerInstanceService.getUnit(n,o.UniverInstanceType.UNIVER_SHEET);if(!r)throw new Error(`cannot find current workbook, unitId: ${n}`);const s=r.getSheetBySheetId(t);if(!s)throw new Error(`cannot find current worksheet, sheetId: ${t}`);const l=s.getCellRaw(e,a),d=this._dataValidationModel.ensureManager(n,t),u=d.getRuleByLocation(e,a);return u?new Promise(c=>{d.validator(J(l),u,{unitId:n,subUnitId:t,row:e,col:a},c)}):o.DataValidationStatus.VALID}async validatorWorksheet(n,t){const a=this._dataValidationModel.ensureManager(n,t).getDataValidations();return await Promise.all(a.map(r=>Promise.all(r.ranges.map(s=>{const l=[];return o.Range.foreach(s,(d,u)=>{l.push(this.validatorCell(n,t,d,u))}),l})))),this._dataValidationCacheService.ensureCache(n,t)}async validatorWorkbook(n){const t=this._dataValidationModel.getSubUnitIds(n),e=await Promise.all(t.map(r=>this.validatorWorksheet(n,r))),a={};return e.forEach((r,s)=>{a[t[s]]=r}),a}},g.SheetsDataValidationValidatorService=$i([Ie(0,o.IUniverInstanceService),Ie(1,o.Inject(D.DataValidationModel)),Ie(2,o.Inject(St))],g.SheetsDataValidationValidatorService);var ha=Object.defineProperty,Wi=Object.getOwnPropertyDescriptor,Hi=(i,n,t)=>n in i?ha(i,n,{enumerable:!0,configurable:!0,writable:!0,value:t}):i[n]=t,xi=(i,n,t,e)=>{for(var a=e>1?void 0:e?Wi(n,t):n,r=i.length-1,s;r>=0;r--)(s=i[r])&&(a=(e?s(n,t,a):s(a))||a);return e&&a&&ha(n,t,a),a},Ce=(i,n)=>(t,e)=>n(t,e,i),fa=(i,n,t)=>Hi(i,typeof n!="symbol"?n+"":n,t);g.UniverSheetsDataValidationPlugin=class extends o.Plugin{constructor(n={},t,e,a){super(),this._config=n,this._injector=t,this._commandService=e,this._localeService=a,this._config=o.Tools.deepMerge({},la,this._config)}onStarting(n){[[st],[g.SheetDataValidationService],[St],[g.DataValidationFormulaService],[g.DataValidationCustomFormulaService],[mt],[g.SheetsDataValidationValidatorService],[Ut],[g.DataValidationController],[g.SheetsDataValidationRenderController,{useFactory:()=>this._injector.createInstance(g.SheetsDataValidationRenderController,this._config)}],[g.DataValidationAlertController],[g.DataValidationRefRangeController],[Bt],[g.DataValidationAutoFillController],[g.DataValidationCopyPasteController],[g.DataValidationFormulaController],[g.DataValidationRejectInputController]].forEach(t=>{n.add(t)}),[At,zt,Pt,he,ra,Ot,ae,Wt,gt,ee].forEach(t=>{this._commandService.registerCommand(t)})}},fa(g.UniverSheetsDataValidationPlugin,"pluginName",Tt),fa(g.UniverSheetsDataValidationPlugin,"type",o.UniverInstanceType.UNIVER_SHEET),g.UniverSheetsDataValidationPlugin=xi([o.DependentOn(D.UniverDataValidationPlugin,U.UniverSheetsPlugin,B.UniverSheetsUIPlugin),Ce(1,o.Inject(o.Injector)),Ce(2,o.ICommandService),Ce(3,o.Inject(o.LocaleService))],g.UniverSheetsDataValidationPlugin);var pa=Object.defineProperty,ki=Object.getOwnPropertyDescriptor,Yi=(i,n,t)=>n in i?pa(i,n,{enumerable:!0,configurable:!0,writable:!0,value:t}):i[n]=t,qi=(i,n,t,e)=>{for(var a=e>1?void 0:e?ki(n,t):n,r=i.length-1,s;r>=0;r--)(s=i[r])&&(a=(e?s(n,t,a):s(a))||a);return e&&a&&pa(n,t,a),a},ye=(i,n)=>(t,e)=>n(t,e,i),va=(i,n,t)=>Yi(i,typeof n!="symbol"?n+"":n,t);g.UniverSheetsDataValidationMobilePlugin=class extends o.Plugin{constructor(n={},t,e,a){super(),this._config=n,this._injector=t,this._commandService=e,this._localeService=a,this._config=o.Tools.deepMerge({},la,this._config)}onStarting(n){[[st],[g.SheetDataValidationService],[St],[g.DataValidationFormulaService],[g.DataValidationCustomFormulaService],[mt],[g.SheetsDataValidationValidatorService],[Ut],[g.DataValidationController],[jt,{useFactory:()=>this._injector.createInstance(jt,this._config)}],[g.DataValidationAlertController],[g.DataValidationRefRangeController],[Bt],[g.DataValidationCopyPasteController],[g.DataValidationFormulaController]].forEach(t=>{n.add(t)}),[At,zt,Pt,Ot,ae,Wt,gt,ee].forEach(t=>{this._commandService.registerCommand(t)})}},va(g.UniverSheetsDataValidationMobilePlugin,"pluginName",Tt),va(g.UniverSheetsDataValidationMobilePlugin,"type",o.UniverInstanceType.UNIVER_SHEET),g.UniverSheetsDataValidationMobilePlugin=qi([o.DependentOn(D.UniverDataValidationPlugin,U.UniverSheetsPlugin,B.UniverSheetsUIPlugin),ye(1,o.Inject(o.Injector)),ye(2,o.ICommandService),ye(3,o.Inject(o.LocaleService))],g.UniverSheetsDataValidationMobilePlugin),Object.defineProperty(g,"ICommandService",{enumerable:!0,get:()=>o.ICommandService}),Object.defineProperty(g,"LocaleService",{enumerable:!0,get:()=>o.LocaleService}),Object.defineProperty(g,"Plugin",{enumerable:!0,get:()=>o.Plugin}),g.AddSheetDataValidationAndOpenCommand=zt,g.AddSheetDataValidationCommand=At,g.CloseValidationPanelOperation=Wt,g.DATA_VALIDATION_PLUGIN_NAME=Tt,g.DataValidationCacheService=St,g.HideDataValidationDropdown=ae,g.OpenValidationPanelOperation=gt,g.ShowDataValidationDropdown=Ot,g.ToggleValidationPanelOperation=ee,g.UpdateSheetDataValidationRangeCommand=Pt,Object.defineProperty(g,Symbol.toStringTag,{value:"Module"})});
|