@univerjs/preset-sheets-data-validation 0.6.0-alpha.0 → 0.6.0-nightly.202502131606

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.
Files changed (2) hide show
  1. package/lib/umd/index.js +4 -4
  2. package/package.json +6 -6
package/lib/umd/index.js CHANGED
@@ -1,17 +1,17 @@
1
1
  // @univerjs/data-validation/index
2
- (function(l,n){typeof exports=="object"&&typeof module<"u"?n(exports,require("@univerjs/core"),require("rxjs")):typeof define=="function"&&define.amd?define(["exports","@univerjs/core","rxjs"],n):(l=typeof globalThis<"u"?globalThis:l||self,n(l.UniverDataValidation={},l.UniverCore,l.rxjs))})(this,function(l,n,_){"use strict";var la=Object.defineProperty;var ua=(l,n,_)=>n in l?la(l,n,{enumerable:!0,configurable:!0,writable:!0,value:_}):l[n]=_;var c=(l,n,_)=>ua(l,typeof n!="symbol"?n+"":n,_);var O;function D(r){return{type:r.type,operator:r.operator,formula1:r.formula1,formula2:r.formula2,allowBlank:r.allowBlank}}function N(r){return{error:r.error,errorStyle:r.errorStyle,errorTitle:r.errorTitle,imeMode:r.imeMode,prompt:r.prompt,promptTitle:r.promptTitle,showDropDown:r.showDropDown,showErrorMessage:r.showErrorMessage,showInputMessage:r.showInputMessage,renderMode:r.renderMode,bizInfo:r.bizInfo}}var h=(r=>(r[r.SETTING=0]="SETTING",r[r.RANGE=1]="RANGE",r[r.OPTIONS=2]="OPTIONS",r[r.ALL=3]="ALL",r))(h||{}),b=Object.defineProperty,w=Object.getOwnPropertyDescriptor,P=(r,a,i,e)=>{for(var t=e>1?void 0:e?w(a,i):a,o=r.length-1,d;o>=0;o--)(d=r[o])&&(t=(e?d(a,i,t):d(t))||t);return e&&t&&b(a,i,t),t},B=(r,a)=>(i,e)=>a(i,e,r);l.DataValidationModel=class extends n.Disposable{constructor(i){super();c(this,"_model",new Map);c(this,"_ruleChange$",new _.Subject);c(this,"ruleChange$",this._ruleChange$.asObservable());c(this,"ruleChangeDebounce$",this.ruleChange$.pipe(_.debounceTime(20)));this._logService=i,this.disposeWithMe({dispose:()=>{this._ruleChange$.complete()}})}_ensureMap(i,e){this._model.has(i)||this._model.set(i,new Map);const t=this._model.get(i);if(t.has(e))return t.get(e);const o={map:new Map,list:[]};return t.set(e,o),o}_addSubUnitRule(i,e,t){const{map:o,list:d}=i,p=(Array.isArray(e)?e:[e]).filter(u=>!o.has(u.uid));typeof t=="number"&&t<d.length?d.splice(t,0,...p):d.push(...p),p.forEach(u=>{o.set(u.uid,u)})}_removeSubUnitRule(i,e){const{map:t,list:o}=i,d=o.findIndex(s=>s.uid===e);d>-1&&(o.splice(d,1),t.delete(e))}_updateSubUnitRule(i,e,t){const{map:o,list:d}=i,s=o.get(e),p=d.findIndex(m=>e===m.uid);if(!s)throw new Error(`Data validation rule is not found, ruleId: ${e}.`);const u={...s};switch(t.type){case h.RANGE:{u.ranges=t.payload;break}case h.SETTING:{Object.assign(u,D(t.payload));break}case h.OPTIONS:{Object.assign(u,N(t.payload));break}case h.ALL:{Object.assign(u,t.payload);break}}return d[p]=u,o.set(e,u),u}_addRuleSideEffect(i,e,t,o){if(!this._ensureMap(i,e).map.get(t.uid))return{rule:t,type:"add",unitId:i,subUnitId:e,source:o}}addRule(i,e,t,o,d){try{const s=this._ensureMap(i,e),u=(Array.isArray(t)?t:[t]).map(m=>this._addRuleSideEffect(i,e,m,o));this._addSubUnitRule(s,t,d),u.forEach(m=>{m&&this._ruleChange$.next(m)})}catch(s){this._logService.error(s)}}updateRule(i,e,t,o,d){try{const s=this._ensureMap(i,e),p=n.Tools.deepClone(s.map.get(t));if(!p)throw new Error(`Data validation rule is not found, ruleId: ${t}.`);const u=this._updateSubUnitRule(s,t,o);this._ruleChange$.next({rule:u,type:"update",unitId:i,subUnitId:e,source:d,updatePayload:o,oldRule:p})}catch(s){this._logService.error(s)}}removeRule(i,e,t,o){try{const d=this._ensureMap(i,e),s=d.map.get(t);s&&(this._removeSubUnitRule(d,t),this._ruleChange$.next({rule:s,type:"remove",unitId:i,subUnitId:e,source:o}))}catch(d){this._logService.error(d)}}getRuleById(i,e,t){return this._ensureMap(i,e).map.get(t)}getRuleIndex(i,e,t){return this._ensureMap(i,e).list.findIndex(d=>d.uid===t)}getRules(i,e){return[...this._ensureMap(i,e).list]}getUnitRules(i){const e=this._model.get(i);if(!e)return[];const t=[];return e.forEach((o,d)=>{t.push([d,o.list])}),t}deleteUnitRules(i){this._model.delete(i)}getSubUnitIds(i){var e,t;return Array.from((t=(e=this._model.get(i))==null?void 0:e.keys())!=null?t:[])}getAll(){return Array.from(this._model.keys()).map(i=>[i,this.getUnitRules(i)])}},l.DataValidationModel=P([B(0,n.ILogService)],l.DataValidationModel);var j=Object.defineProperty,$=Object.getOwnPropertyDescriptor,q=(r,a,i,e)=>{for(var t=e>1?void 0:e?$(a,i):a,o=r.length-1,d;o>=0;o--)(d=r[o])&&(t=(e?d(a,i,t):d(t))||t);return e&&t&&j(a,i,t),t},M=(r,a)=>(i,e)=>a(i,e,r);const G="SHEET_DATA_VALIDATION_PLUGIN";l.DataValidationResourceController=class extends n.Disposable{constructor(a,i,e){super(),this._resourceManagerService=a,this._univerInstanceService=i,this._dataValidationModel=e,this._initSnapshot()}_initSnapshot(){const a=e=>{const t=this._dataValidationModel.getUnitRules(e),o={};return t?(t.forEach(([d,s])=>{o[d]=s}),JSON.stringify(o)):""},i=e=>{if(!e)return{};try{return JSON.parse(e)}catch{return{}}};this.disposeWithMe(this._resourceManagerService.registerPluginResource({pluginName:G,businesses:[n.UniverInstanceType.UNIVER_SHEET],toJson:e=>a(e),parseJson:e=>i(e),onUnLoad:e=>{this._dataValidationModel.deleteUnitRules(e)},onLoad:(e,t)=>{Object.keys(t).forEach(o=>{t[o].forEach(s=>{this._dataValidationModel.addRule(e,o,s,"patched")})})}}))}},l.DataValidationResourceController=q([M(0,n.IResourceManagerService),M(1,n.IUniverInstanceService),M(2,n.Inject(l.DataValidationModel))],l.DataValidationResourceController);var I=(r=>(r.SHEET="sheet",r))(I||{});class R{constructor(){c(this,"_validatorByScopes",new Map);c(this,"_validatorMap",new Map);c(this,"_validatorsChange$",new _.BehaviorSubject(void 0));c(this,"validatorsChange$",this._validatorsChange$.asObservable())}_addValidatorToScope(a,i){this._validatorByScopes.has(i)||this._validatorByScopes.set(i,[]);const e=this._validatorByScopes.get(i);if(e.findIndex(t=>t.id===a.id)>-1)throw new Error(`Validator item with the same id ${a.id} has already been added!`);e.push(a)}_removeValidatorFromScope(a,i){const e=this._validatorByScopes.get(i);if(!e)return;const t=e.findIndex(o=>o.id===a.id);t>-1&&e.splice(t,1)}register(a){return this._validatorMap.set(a.id,a),Array.isArray(a.scopes)?a.scopes.forEach(i=>{this._addValidatorToScope(a,i)}):this._addValidatorToScope(a,a.scopes),this._validatorsChange$.next(),n.toDisposable(()=>{this._validatorMap.delete(a.id),Array.isArray(a.scopes)?a.scopes.forEach(i=>{this._removeValidatorFromScope(a,i)}):this._removeValidatorFromScope(a,a.scopes),this._validatorsChange$.next()})}getValidatorItem(a){return this._validatorMap.get(a)}getValidatorsByScope(a){return this._validatorByScopes.get(a)}}const f={type:n.CommandType.MUTATION,id:"data-validation.mutation.addRule",handler(r,a){if(!a)return!1;const{unitId:i,subUnitId:e,rule:t,index:o,source:d="command"}=a;return r.get(l.DataValidationModel).addRule(i,e,t,d,o),!0}},E={type:n.CommandType.MUTATION,id:"data-validation.mutation.removeRule",handler(r,a){if(!a)return!1;const{unitId:i,subUnitId:e,ruleId:t,source:o="command"}=a,d=r.get(l.DataValidationModel);return Array.isArray(t)?t.forEach(s=>{d.removeRule(i,e,s,o)}):d.removeRule(i,e,t,o),!0}},g={type:n.CommandType.MUTATION,id:"data-validation.mutation.updateRule",handler(r,a){if(!a)return!1;const{unitId:i,subUnitId:e,ruleId:t,payload:o,source:d="command"}=a;return r.get(l.DataValidationModel).updateRule(i,e,t,o,d),!0}},H={type:n.CommandType.COMMAND,id:"data-validation.command.addRule",async handler(r,a){if(r.get(n.ILogService).error("[Deprecated]: `AddDataValidationCommand` is deprecated, please use `AddSheetDataValidationCommand` in `@univerjs/sheets-data-validation` instead!"),!a)return!1;const{rule:e,unitId:t,subUnitId:o}=a,d=r.get(n.ICommandService),s=r.get(n.IUndoRedoService),p={...a,rule:{...a.rule,ranges:[a.rule.range]}},u=[{id:f.id,params:p}],m=[{id:E.id,params:{unitId:t,subUnitId:o,ruleId:e.uid}}];return s.pushUndoRedo({unitID:t,redoMutations:u,undoMutations:m}),await d.executeCommand(f.id,p),!0}},Q={type:n.CommandType.COMMAND,id:"data-validation.command.removeRule",handler(r,a){if(r.get(n.ILogService).error("[Deprecated]: `RemoveDataValidationCommand` is deprecated, please use `RemoveSheetDataValidationCommand` in `@univerjs/sheets-data-validation` instead!"),!a)return!1;const{unitId:e,subUnitId:t,ruleId:o}=a,d=r.get(n.ICommandService),s=r.get(n.IUndoRedoService),p=r.get(l.DataValidationModel),u=[{id:E.id,params:a}],m=[{id:f.id,params:{unitId:e,subUnitId:t,rule:{...p.getRuleById(e,t,o)},index:p.getRuleIndex(e,t,o)}}];return s.pushUndoRedo({undoMutations:m,redoMutations:u,unitID:a.unitId}),d.executeCommand(E.id,a),!0}},F={type:n.CommandType.COMMAND,id:"data-validation.command.updateDataValidationSetting",handler(r,a){if(r.get(n.ILogService).warn("[Deprecated]: `UpdateDataValidationOptionsCommand` is deprecated, please use `UpdateSheetDataValidationOptionsCommand` in `@univerjs/sheets-data-validation` instead!"),!a)return!1;const e=r.get(n.ICommandService),t=r.get(n.IUndoRedoService),o=r.get(l.DataValidationModel),{unitId:d,subUnitId:s,ruleId:p,options:u}=a,m=o.getRuleById(d,s,p);if(!m)return!1;const V={unitId:d,subUnitId:s,ruleId:p,payload:{type:h.OPTIONS,payload:u}},v=[{id:g.id,params:V}],T={unitId:d,subUnitId:s,ruleId:p,payload:{type:h.OPTIONS,payload:N(m)}},S=[{id:g.id,params:T}];return t.pushUndoRedo({unitID:d,redoMutations:v,undoMutations:S}),e.executeCommand(g.id,V),!0}},W={type:n.CommandType.COMMAND,id:"data-validation.command.updateDataValidationOptions",handler(r,a){if(r.get(n.ILogService).error("[Deprecated]: `UpdateDataValidationSettingCommand` is deprecated, please use `UpdateSheetDataValidationSettingCommand` in `@univerjs/sheets-data-validation` instead!"),!a)return!1;const e=r.get(n.ICommandService),t=r.get(n.IUndoRedoService),o=r.get(l.DataValidationModel),d=r.get(R),{unitId:s,subUnitId:p,ruleId:u,setting:m}=a,V=d.getValidatorItem(m.type);if(!V)return!1;const v=o.getRuleById(s,p,u);if(!v)return!1;const T={...v,...m};if(!V.validatorFormula(T,s,p).success)return!1;const S={unitId:s,subUnitId:p,ruleId:u,payload:{type:h.SETTING,payload:{...m,...V.normalizeFormula(T,s,p)}}},oa=[{id:g.id,params:S}],da={unitId:s,subUnitId:p,ruleId:u,payload:{type:h.SETTING,payload:D(v)}},sa=[{id:g.id,params:da}];return t.pushUndoRedo({unitID:s,redoMutations:oa,undoMutations:sa}),e.executeCommand(g.id,S),!0}},x={type:n.CommandType.COMMAND,id:"data-validation.command.removeAll",handler(r,a){if(r.get(n.ILogService).error("[Deprecated]: `RemoveAllDataValidationCommand` is deprecated, please use `RemoveSheetAllDataValidationCommand` in `@univerjs/sheets-data-validation` instead!"),!a)return!1;const{unitId:e,subUnitId:t}=a,o=r.get(n.ICommandService),d=r.get(l.DataValidationModel),s=r.get(n.IUndoRedoService),p=[...d.getRules(e,t)],u={unitId:e,subUnitId:t,ruleId:p.map(v=>v.uid)},m=[{id:E.id,params:u}],V=[{id:f.id,params:{unitId:e,subUnitId:t,rule:p}}];return s.pushUndoRedo({redoMutations:m,undoMutations:V,unitID:e}),o.executeCommand(E.id,u),!0}},J="data-validation.config",y={};var z=Object.defineProperty,K=Object.getOwnPropertyDescriptor,Y=(r,a,i,e)=>{for(var t=e>1?void 0:e?K(a,i):a,o=r.length-1,d;o>=0;o--)(d=r[o])&&(t=(e?d(a,i,t):d(t))||t);return e&&t&&z(a,i,t),t},A=(r,a)=>(i,e)=>a(i,e,r);const X="UNIVER_DATA_VALIDATION_PLUGIN";l.UniverDataValidationPlugin=(O=class extends n.Plugin{constructor(a=y,i,e,t){super(),this._config=a,this._injector=i,this._commandService=e,this._configService=t;const{...o}=n.merge({},y,this._config);this._configService.setConfig(J,o)}onStarting(){[[l.DataValidationModel],[R],[l.DataValidationResourceController]].forEach(a=>this._injector.add(a)),[H,x,F,W,Q,f,g,E].forEach(a=>{this._commandService.registerCommand(a)})}onReady(){this._injector.get(l.DataValidationResourceController)}},c(O,"pluginName",X),c(O,"type",n.UniverInstanceType.UNIVER_SHEET),O),l.UniverDataValidationPlugin=Y([A(1,n.Inject(n.Injector)),A(2,n.ICommandService),A(3,n.IConfigService)],l.UniverDataValidationPlugin),n.DataValidationOperator.BETWEEN+"",n.DataValidationOperator.EQUAL+"",n.DataValidationOperator.GREATER_THAN+"",n.DataValidationOperator.GREATER_THAN_OR_EQUAL+"",n.DataValidationOperator.LESS_THAN+"",n.DataValidationOperator.LESS_THAN_OR_EQUAL+"",n.DataValidationOperator.NOT_BETWEEN+"",n.DataValidationOperator.NOT_EQUAL+"";const Z={[n.DataValidationOperator.BETWEEN]:"dataValidation.ruleName.between",[n.DataValidationOperator.EQUAL]:"dataValidation.ruleName.equal",[n.DataValidationOperator.GREATER_THAN]:"dataValidation.ruleName.greaterThan",[n.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.ruleName.greaterThanOrEqual",[n.DataValidationOperator.LESS_THAN]:"dataValidation.ruleName.lessThan",[n.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.ruleName.lessThanOrEqual",[n.DataValidationOperator.NOT_BETWEEN]:"dataValidation.ruleName.notBetween",[n.DataValidationOperator.NOT_EQUAL]:"dataValidation.ruleName.notEqual"},k={[n.DataValidationOperator.BETWEEN]:"dataValidation.errorMsg.between",[n.DataValidationOperator.EQUAL]:"dataValidation.errorMsg.equal",[n.DataValidationOperator.GREATER_THAN]:"dataValidation.errorMsg.greaterThan",[n.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.errorMsg.greaterThanOrEqual",[n.DataValidationOperator.LESS_THAN]:"dataValidation.errorMsg.lessThan",[n.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.errorMsg.lessThanOrEqual",[n.DataValidationOperator.NOT_BETWEEN]:"dataValidation.errorMsg.notBetween",[n.DataValidationOperator.NOT_EQUAL]:"dataValidation.errorMsg.notEqual"},aa={[n.DataValidationOperator.BETWEEN]:"dataValidation.textLength.errorMsg.between",[n.DataValidationOperator.EQUAL]:"dataValidation.textLength.errorMsg.equal",[n.DataValidationOperator.GREATER_THAN]:"dataValidation.textLength.errorMsg.greaterThan",[n.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.textLength.errorMsg.greaterThanOrEqual",[n.DataValidationOperator.LESS_THAN]:"dataValidation.textLength.errorMsg.lessThan",[n.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.textLength.errorMsg.lessThanOrEqual",[n.DataValidationOperator.NOT_BETWEEN]:"dataValidation.textLength.errorMsg.notBetween",[n.DataValidationOperator.NOT_EQUAL]:"dataValidation.textLength.errorMsg.notEqual"},ta=[n.DataValidationOperator.BETWEEN,n.DataValidationOperator.NOT_BETWEEN];var ea=Object.defineProperty,ia=Object.getOwnPropertyDescriptor,na=(r,a,i,e)=>{for(var t=e>1?void 0:e?ia(a,i):a,o=r.length-1,d;o>=0;o--)(d=r[o])&&(t=(e?d(a,i,t):d(t))||t);return e&&t&&ea(a,i,t),t},U=(r,a)=>(i,e)=>a(i,e,r);const L="{FORMULA1}",C="{FORMULA2}",ra={[n.DataValidationOperator.BETWEEN]:"dataValidation.operators.between",[n.DataValidationOperator.EQUAL]:"dataValidation.operators.equal",[n.DataValidationOperator.GREATER_THAN]:"dataValidation.operators.greaterThan",[n.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.operators.greaterThanOrEqual",[n.DataValidationOperator.LESS_THAN]:"dataValidation.operators.lessThan",[n.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.operators.lessThanOrEqual",[n.DataValidationOperator.NOT_BETWEEN]:"dataValidation.operators.notBetween",[n.DataValidationOperator.NOT_EQUAL]:"dataValidation.operators.notEqual"};l.BaseDataValidator=class{constructor(a,i){c(this,"offsetFormulaByRange",!0);c(this,"formulaInput");c(this,"canvasRender",null);c(this,"dropdown");c(this,"optionsInput");c(this,"skipDefaultFontRender");this.localeService=a,this.injector=i}get operatorNames(){return this.operators.map(a=>this.localeService.t(ra[a]))}get titleStr(){return this.localeService.t(this.title)}generateRuleName(a){var e,t;if(!a.operator)return this.titleStr;const i=this.localeService.t(Z[a.operator]).replace(L,(e=a.formula1)!=null?e:"").replace(C,(t=a.formula2)!=null?t:"");return`${this.titleStr} ${i}`}generateRuleErrorMessage(a,i){var t,o;return a.operator?`${this.localeService.t(k[a.operator]).replace(L,(t=a.formula1)!=null?t:"").replace(C,(o=a.formula2)!=null?o:"")}`:this.titleStr}getExtraStyle(a,i,e,t,o){}getRuleFinalError(a,i){return a.showErrorMessage&&a.error?a.error:this.generateRuleErrorMessage(a,i)}isEmptyCellValue(a){return a===""||a===void 0||a===null}normalizeFormula(a,i,e){return{formula1:a.formula1,formula2:a.formula2}}async isValidType(a,i,e){return!0}transform(a,i,e){return a}async validatorIsEqual(a,i,e){const{formula1:t}=i,{value:o}=a;return Number.isNaN(t)?!0:o===t}async validatorIsNotEqual(a,i,e){const{formula1:t}=i;return Number.isNaN(t)?!0:a.value!==t}async validatorIsBetween(a,i,e){const{formula1:t,formula2:o}=i;if(Number.isNaN(t)||Number.isNaN(o))return!0;const d=Math.min(t,o),s=Math.max(t,o);return a.value>=d&&a.value<=s}async validatorIsNotBetween(a,i,e){const{formula1:t,formula2:o}=i;if(Number.isNaN(t)||Number.isNaN(o))return!0;const d=Math.min(t,o),s=Math.max(t,o);return a.value<d||a.value>s}async validatorIsGreaterThan(a,i,e){const{formula1:t}=i;return Number.isNaN(t)?!0:a.value>t}async validatorIsGreaterThanOrEqual(a,i,e){const{formula1:t}=i;return Number.isNaN(t)?!0:a.value>=t}async validatorIsLessThan(a,i,e){const{formula1:t}=i;return Number.isNaN(t)?!0:a.value<t}async validatorIsLessThanOrEqual(a,i,e){const{formula1:t}=i;return Number.isNaN(t)?!0:a.value<=t}async validator(a,i){const{value:e,unitId:t,subUnitId:o}=a,d=this.isEmptyCellValue(e),{allowBlank:s=!0,operator:p}=i;if(d)return s;const u=await this.parseFormula(i,t,o,a.row,a.column);if(!u.isFormulaValid||!await this.isValidType(a,u,i))return!1;if(!n.Tools.isDefine(p))return!0;const m=this.transform(a,u,i);switch(p){case n.DataValidationOperator.BETWEEN:return this.validatorIsBetween(m,u,i);case n.DataValidationOperator.EQUAL:return this.validatorIsEqual(m,u,i);case n.DataValidationOperator.GREATER_THAN:return this.validatorIsGreaterThan(m,u,i);case n.DataValidationOperator.GREATER_THAN_OR_EQUAL:return this.validatorIsGreaterThanOrEqual(m,u,i);case n.DataValidationOperator.LESS_THAN:return this.validatorIsLessThan(m,u,i);case n.DataValidationOperator.LESS_THAN_OR_EQUAL:return this.validatorIsLessThanOrEqual(m,u,i);case n.DataValidationOperator.NOT_BETWEEN:return this.validatorIsNotBetween(m,u,i);case n.DataValidationOperator.NOT_EQUAL:return this.validatorIsNotEqual(m,u,i);default:throw new Error("Unknown operator.")}}},l.BaseDataValidator=na([U(0,n.Inject(n.LocaleService)),U(1,n.Inject(n.Injector))],l.BaseDataValidator),l.AddDataValidationMutation=f,l.DataValidatorRegistryScope=I,l.DataValidatorRegistryService=R,l.RemoveDataValidationMutation=E,l.TWO_FORMULA_OPERATOR_COUNT=ta,l.TextLengthErrorTitleMap=aa,l.UpdateDataValidationMutation=g,l.UpdateRuleType=h,l.getRuleOptions=N,l.getRuleSetting=D,Object.defineProperty(l,Symbol.toStringTag,{value:"Module"})});
2
+ (function(l,r){typeof exports=="object"&&typeof module<"u"?r(exports,require("@univerjs/core"),require("rxjs")):typeof define=="function"&&define.amd?define(["exports","@univerjs/core","rxjs"],r):(l=typeof globalThis<"u"?globalThis:l||self,r(l.UniverDataValidation={},l.UniverCore,l.rxjs))})(this,function(l,r,g){"use strict";var na=Object.defineProperty;var oa=(l,r,g)=>r in l?na(l,r,{enumerable:!0,configurable:!0,writable:!0,value:g}):l[r]=g;var c=(l,r,g)=>oa(l,typeof r!="symbol"?r+"":r,g);var T;function D(n){return{type:n.type,operator:n.operator,formula1:n.formula1,formula2:n.formula2,allowBlank:n.allowBlank}}function N(n){return{error:n.error,errorStyle:n.errorStyle,errorTitle:n.errorTitle,imeMode:n.imeMode,prompt:n.prompt,promptTitle:n.promptTitle,showDropDown:n.showDropDown,showErrorMessage:n.showErrorMessage,showInputMessage:n.showInputMessage,renderMode:n.renderMode,bizInfo:n.bizInfo}}var h=(n=>(n[n.SETTING=0]="SETTING",n[n.RANGE=1]="RANGE",n[n.OPTIONS=2]="OPTIONS",n[n.ALL=3]="ALL",n))(h||{}),w=Object.getOwnPropertyDescriptor,b=(n,a,i,e)=>{for(var t=e>1?void 0:e?w(a,i):a,o=n.length-1,d;o>=0;o--)(d=n[o])&&(t=d(t)||t);return t},B=(n,a)=>(i,e)=>a(i,e,n);l.DataValidationModel=class extends r.Disposable{constructor(i){super();c(this,"_model",new Map);c(this,"_ruleChange$",new g.Subject);c(this,"ruleChange$",this._ruleChange$.asObservable());c(this,"ruleChangeDebounce$",this.ruleChange$.pipe(g.debounceTime(20)));this._logService=i,this.disposeWithMe({dispose:()=>{this._ruleChange$.complete()}})}_ensureMap(i,e){this._model.has(i)||this._model.set(i,new Map);const t=this._model.get(i);if(t.has(e))return t.get(e);const o={map:new Map,list:[]};return t.set(e,o),o}_addSubUnitRule(i,e,t){const{map:o,list:d}=i,p=(Array.isArray(e)?e:[e]).filter(u=>!o.has(u.uid));typeof t=="number"&&t<d.length?d.splice(t,0,...p):d.push(...p),p.forEach(u=>{o.set(u.uid,u)})}_removeSubUnitRule(i,e){const{map:t,list:o}=i,d=o.findIndex(s=>s.uid===e);d>-1&&(o.splice(d,1),t.delete(e))}_updateSubUnitRule(i,e,t){const{map:o,list:d}=i,s=o.get(e),p=d.findIndex(m=>e===m.uid);if(!s)throw new Error(`Data validation rule is not found, ruleId: ${e}.`);const u={...s};switch(t.type){case h.RANGE:{u.ranges=t.payload;break}case h.SETTING:{Object.assign(u,D(t.payload));break}case h.OPTIONS:{Object.assign(u,N(t.payload));break}case h.ALL:{Object.assign(u,t.payload);break}}return d[p]=u,o.set(e,u),u}_addRuleSideEffect(i,e,t,o){if(!this._ensureMap(i,e).map.get(t.uid))return{rule:t,type:"add",unitId:i,subUnitId:e,source:o}}addRule(i,e,t,o,d){try{const s=this._ensureMap(i,e),u=(Array.isArray(t)?t:[t]).map(m=>this._addRuleSideEffect(i,e,m,o));this._addSubUnitRule(s,t,d),u.forEach(m=>{m&&this._ruleChange$.next(m)})}catch(s){this._logService.error(s)}}updateRule(i,e,t,o,d){try{const s=this._ensureMap(i,e),p=r.Tools.deepClone(s.map.get(t));if(!p)throw new Error(`Data validation rule is not found, ruleId: ${t}.`);const u=this._updateSubUnitRule(s,t,o);this._ruleChange$.next({rule:u,type:"update",unitId:i,subUnitId:e,source:d,updatePayload:o,oldRule:p})}catch(s){this._logService.error(s)}}removeRule(i,e,t,o){try{const d=this._ensureMap(i,e),s=d.map.get(t);s&&(this._removeSubUnitRule(d,t),this._ruleChange$.next({rule:s,type:"remove",unitId:i,subUnitId:e,source:o}))}catch(d){this._logService.error(d)}}getRuleById(i,e,t){return this._ensureMap(i,e).map.get(t)}getRuleIndex(i,e,t){return this._ensureMap(i,e).list.findIndex(d=>d.uid===t)}getRules(i,e){return[...this._ensureMap(i,e).list]}getUnitRules(i){const e=this._model.get(i);if(!e)return[];const t=[];return e.forEach((o,d)=>{t.push([d,o.list])}),t}deleteUnitRules(i){this._model.delete(i)}getSubUnitIds(i){var e,t;return Array.from((t=(e=this._model.get(i))==null?void 0:e.keys())!=null?t:[])}getAll(){return Array.from(this._model.keys()).map(i=>[i,this.getUnitRules(i)])}},l.DataValidationModel=b([B(0,r.ILogService)],l.DataValidationModel);var P=Object.getOwnPropertyDescriptor,q=(n,a,i,e)=>{for(var t=e>1?void 0:e?P(a,i):a,o=n.length-1,d;o>=0;o--)(d=n[o])&&(t=d(t)||t);return t},M=(n,a)=>(i,e)=>a(i,e,n);const G="SHEET_DATA_VALIDATION_PLUGIN";l.DataValidationResourceController=class extends r.Disposable{constructor(a,i,e){super(),this._resourceManagerService=a,this._univerInstanceService=i,this._dataValidationModel=e,this._initSnapshot()}_initSnapshot(){const a=e=>{const t=this._dataValidationModel.getUnitRules(e),o={};return t?(t.forEach(([d,s])=>{o[d]=s}),JSON.stringify(o)):""},i=e=>{if(!e)return{};try{return JSON.parse(e)}catch{return{}}};this.disposeWithMe(this._resourceManagerService.registerPluginResource({pluginName:G,businesses:[r.UniverInstanceType.UNIVER_SHEET],toJson:e=>a(e),parseJson:e=>i(e),onUnLoad:e=>{this._dataValidationModel.deleteUnitRules(e)},onLoad:(e,t)=>{Object.keys(t).forEach(o=>{t[o].forEach(s=>{this._dataValidationModel.addRule(e,o,s,"patched")})})}}))}},l.DataValidationResourceController=q([M(0,r.IResourceManagerService),M(1,r.IUniverInstanceService),M(2,r.Inject(l.DataValidationModel))],l.DataValidationResourceController);var I=(n=>(n.SHEET="sheet",n))(I||{});class R{constructor(){c(this,"_validatorByScopes",new Map);c(this,"_validatorMap",new Map);c(this,"_validatorsChange$",new g.BehaviorSubject(void 0));c(this,"validatorsChange$",this._validatorsChange$.asObservable())}_addValidatorToScope(a,i){this._validatorByScopes.has(i)||this._validatorByScopes.set(i,[]);const e=this._validatorByScopes.get(i);if(e.findIndex(t=>t.id===a.id)>-1)throw new Error(`Validator item with the same id ${a.id} has already been added!`);e.push(a)}_removeValidatorFromScope(a,i){const e=this._validatorByScopes.get(i);if(!e)return;const t=e.findIndex(o=>o.id===a.id);t>-1&&e.splice(t,1)}register(a){return this._validatorMap.set(a.id,a),Array.isArray(a.scopes)?a.scopes.forEach(i=>{this._addValidatorToScope(a,i)}):this._addValidatorToScope(a,a.scopes),this._validatorsChange$.next(),r.toDisposable(()=>{this._validatorMap.delete(a.id),Array.isArray(a.scopes)?a.scopes.forEach(i=>{this._removeValidatorFromScope(a,i)}):this._removeValidatorFromScope(a,a.scopes),this._validatorsChange$.next()})}getValidatorItem(a){return this._validatorMap.get(a)}getValidatorsByScope(a){return this._validatorByScopes.get(a)}}const O={type:r.CommandType.MUTATION,id:"data-validation.mutation.addRule",handler(n,a){if(!a)return!1;const{unitId:i,subUnitId:e,rule:t,index:o,source:d="command"}=a;return n.get(l.DataValidationModel).addRule(i,e,t,d,o),!0}},v={type:r.CommandType.MUTATION,id:"data-validation.mutation.removeRule",handler(n,a){if(!a)return!1;const{unitId:i,subUnitId:e,ruleId:t,source:o="command"}=a,d=n.get(l.DataValidationModel);return Array.isArray(t)?t.forEach(s=>{d.removeRule(i,e,s,o)}):d.removeRule(i,e,t,o),!0}},_={type:r.CommandType.MUTATION,id:"data-validation.mutation.updateRule",handler(n,a){if(!a)return!1;const{unitId:i,subUnitId:e,ruleId:t,payload:o,source:d="command"}=a;return n.get(l.DataValidationModel).updateRule(i,e,t,o,d),!0}},j={type:r.CommandType.COMMAND,id:"data-validation.command.addRule",async handler(n,a){if(n.get(r.ILogService).error("[Deprecated]: `AddDataValidationCommand` is deprecated, please use `AddSheetDataValidationCommand` in `@univerjs/sheets-data-validation` instead!"),!a)return!1;const{rule:e,unitId:t,subUnitId:o}=a,d=n.get(r.ICommandService),s=n.get(r.IUndoRedoService),p={...a,rule:{...a.rule,ranges:[a.rule.range]}},u=[{id:O.id,params:p}],m=[{id:v.id,params:{unitId:t,subUnitId:o,ruleId:e.uid}}];return s.pushUndoRedo({unitID:t,redoMutations:u,undoMutations:m}),await d.executeCommand(O.id,p),!0}},$={type:r.CommandType.COMMAND,id:"data-validation.command.removeRule",handler(n,a){if(n.get(r.ILogService).error("[Deprecated]: `RemoveDataValidationCommand` is deprecated, please use `RemoveSheetDataValidationCommand` in `@univerjs/sheets-data-validation` instead!"),!a)return!1;const{unitId:e,subUnitId:t,ruleId:o}=a,d=n.get(r.ICommandService),s=n.get(r.IUndoRedoService),p=n.get(l.DataValidationModel),u=[{id:v.id,params:a}],m=[{id:O.id,params:{unitId:e,subUnitId:t,rule:{...p.getRuleById(e,t,o)},index:p.getRuleIndex(e,t,o)}}];return s.pushUndoRedo({undoMutations:m,redoMutations:u,unitID:a.unitId}),d.executeCommand(v.id,a),!0}},H={type:r.CommandType.COMMAND,id:"data-validation.command.updateDataValidationSetting",handler(n,a){if(n.get(r.ILogService).warn("[Deprecated]: `UpdateDataValidationOptionsCommand` is deprecated, please use `UpdateSheetDataValidationOptionsCommand` in `@univerjs/sheets-data-validation` instead!"),!a)return!1;const e=n.get(r.ICommandService),t=n.get(r.IUndoRedoService),o=n.get(l.DataValidationModel),{unitId:d,subUnitId:s,ruleId:p,options:u}=a,m=o.getRuleById(d,s,p);if(!m)return!1;const V={unitId:d,subUnitId:s,ruleId:p,payload:{type:h.OPTIONS,payload:u}},E=[{id:_.id,params:V}],f={unitId:d,subUnitId:s,ruleId:p,payload:{type:h.OPTIONS,payload:N(m)}},S=[{id:_.id,params:f}];return t.pushUndoRedo({unitID:d,redoMutations:E,undoMutations:S}),e.executeCommand(_.id,V),!0}},Q={type:r.CommandType.COMMAND,id:"data-validation.command.updateDataValidationOptions",handler(n,a){if(n.get(r.ILogService).error("[Deprecated]: `UpdateDataValidationSettingCommand` is deprecated, please use `UpdateSheetDataValidationSettingCommand` in `@univerjs/sheets-data-validation` instead!"),!a)return!1;const e=n.get(r.ICommandService),t=n.get(r.IUndoRedoService),o=n.get(l.DataValidationModel),d=n.get(R),{unitId:s,subUnitId:p,ruleId:u,setting:m}=a,V=d.getValidatorItem(m.type);if(!V)return!1;const E=o.getRuleById(s,p,u);if(!E)return!1;const f={...E,...m};if(!V.validatorFormula(f,s,p).success)return!1;const S={unitId:s,subUnitId:p,ruleId:u,payload:{type:h.SETTING,payload:{...m,...V.normalizeFormula(f,s,p)}}},ea=[{id:_.id,params:S}],ia={unitId:s,subUnitId:p,ruleId:u,payload:{type:h.SETTING,payload:D(E)}},ra=[{id:_.id,params:ia}];return t.pushUndoRedo({unitID:s,redoMutations:ea,undoMutations:ra}),e.executeCommand(_.id,S),!0}},F={type:r.CommandType.COMMAND,id:"data-validation.command.removeAll",handler(n,a){if(n.get(r.ILogService).error("[Deprecated]: `RemoveAllDataValidationCommand` is deprecated, please use `RemoveSheetAllDataValidationCommand` in `@univerjs/sheets-data-validation` instead!"),!a)return!1;const{unitId:e,subUnitId:t}=a,o=n.get(r.ICommandService),d=n.get(l.DataValidationModel),s=n.get(r.IUndoRedoService),p=[...d.getRules(e,t)],u={unitId:e,subUnitId:t,ruleId:p.map(E=>E.uid)},m=[{id:v.id,params:u}],V=[{id:O.id,params:{unitId:e,subUnitId:t,rule:p}}];return s.pushUndoRedo({redoMutations:m,undoMutations:V,unitID:e}),o.executeCommand(v.id,u),!0}},W="data-validation.config",y={};var k=Object.getOwnPropertyDescriptor,x=(n,a,i,e)=>{for(var t=e>1?void 0:e?k(a,i):a,o=n.length-1,d;o>=0;o--)(d=n[o])&&(t=d(t)||t);return t},A=(n,a)=>(i,e)=>a(i,e,n);const J="UNIVER_DATA_VALIDATION_PLUGIN";l.UniverDataValidationPlugin=(T=class extends r.Plugin{constructor(a=y,i,e,t){super(),this._config=a,this._injector=i,this._commandService=e,this._configService=t;const{...o}=r.merge({},y,this._config);this._configService.setConfig(W,o)}onStarting(){[[l.DataValidationModel],[R],[l.DataValidationResourceController]].forEach(a=>this._injector.add(a)),[j,F,H,Q,$,O,_,v].forEach(a=>{this._commandService.registerCommand(a)})}onReady(){this._injector.get(l.DataValidationResourceController)}},c(T,"pluginName",J),c(T,"type",r.UniverInstanceType.UNIVER_SHEET),T),l.UniverDataValidationPlugin=x([A(1,r.Inject(r.Injector)),A(2,r.ICommandService),A(3,r.IConfigService)],l.UniverDataValidationPlugin),r.DataValidationOperator.BETWEEN+"",r.DataValidationOperator.EQUAL+"",r.DataValidationOperator.GREATER_THAN+"",r.DataValidationOperator.GREATER_THAN_OR_EQUAL+"",r.DataValidationOperator.LESS_THAN+"",r.DataValidationOperator.LESS_THAN_OR_EQUAL+"",r.DataValidationOperator.NOT_BETWEEN+"",r.DataValidationOperator.NOT_EQUAL+"";const z={[r.DataValidationOperator.BETWEEN]:"dataValidation.ruleName.between",[r.DataValidationOperator.EQUAL]:"dataValidation.ruleName.equal",[r.DataValidationOperator.GREATER_THAN]:"dataValidation.ruleName.greaterThan",[r.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.ruleName.greaterThanOrEqual",[r.DataValidationOperator.LESS_THAN]:"dataValidation.ruleName.lessThan",[r.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.ruleName.lessThanOrEqual",[r.DataValidationOperator.NOT_BETWEEN]:"dataValidation.ruleName.notBetween",[r.DataValidationOperator.NOT_EQUAL]:"dataValidation.ruleName.notEqual"},K={[r.DataValidationOperator.BETWEEN]:"dataValidation.errorMsg.between",[r.DataValidationOperator.EQUAL]:"dataValidation.errorMsg.equal",[r.DataValidationOperator.GREATER_THAN]:"dataValidation.errorMsg.greaterThan",[r.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.errorMsg.greaterThanOrEqual",[r.DataValidationOperator.LESS_THAN]:"dataValidation.errorMsg.lessThan",[r.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.errorMsg.lessThanOrEqual",[r.DataValidationOperator.NOT_BETWEEN]:"dataValidation.errorMsg.notBetween",[r.DataValidationOperator.NOT_EQUAL]:"dataValidation.errorMsg.notEqual"},Y={[r.DataValidationOperator.BETWEEN]:"dataValidation.textLength.errorMsg.between",[r.DataValidationOperator.EQUAL]:"dataValidation.textLength.errorMsg.equal",[r.DataValidationOperator.GREATER_THAN]:"dataValidation.textLength.errorMsg.greaterThan",[r.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.textLength.errorMsg.greaterThanOrEqual",[r.DataValidationOperator.LESS_THAN]:"dataValidation.textLength.errorMsg.lessThan",[r.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.textLength.errorMsg.lessThanOrEqual",[r.DataValidationOperator.NOT_BETWEEN]:"dataValidation.textLength.errorMsg.notBetween",[r.DataValidationOperator.NOT_EQUAL]:"dataValidation.textLength.errorMsg.notEqual"},X=[r.DataValidationOperator.BETWEEN,r.DataValidationOperator.NOT_BETWEEN];var Z=Object.getOwnPropertyDescriptor,aa=(n,a,i,e)=>{for(var t=e>1?void 0:e?Z(a,i):a,o=n.length-1,d;o>=0;o--)(d=n[o])&&(t=d(t)||t);return t},U=(n,a)=>(i,e)=>a(i,e,n);const L="{FORMULA1}",C="{FORMULA2}",ta={[r.DataValidationOperator.BETWEEN]:"dataValidation.operators.between",[r.DataValidationOperator.EQUAL]:"dataValidation.operators.equal",[r.DataValidationOperator.GREATER_THAN]:"dataValidation.operators.greaterThan",[r.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.operators.greaterThanOrEqual",[r.DataValidationOperator.LESS_THAN]:"dataValidation.operators.lessThan",[r.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.operators.lessThanOrEqual",[r.DataValidationOperator.NOT_BETWEEN]:"dataValidation.operators.notBetween",[r.DataValidationOperator.NOT_EQUAL]:"dataValidation.operators.notEqual"};l.BaseDataValidator=class{constructor(a,i){c(this,"offsetFormulaByRange",!0);c(this,"formulaInput");c(this,"canvasRender",null);c(this,"dropdown");c(this,"optionsInput");c(this,"skipDefaultFontRender");this.localeService=a,this.injector=i}get operatorNames(){return this.operators.map(a=>this.localeService.t(ta[a]))}get titleStr(){return this.localeService.t(this.title)}generateRuleName(a){var e,t;if(!a.operator)return this.titleStr;const i=this.localeService.t(z[a.operator]).replace(L,(e=a.formula1)!=null?e:"").replace(C,(t=a.formula2)!=null?t:"");return`${this.titleStr} ${i}`}generateRuleErrorMessage(a,i){var t,o;return a.operator?`${this.localeService.t(K[a.operator]).replace(L,(t=a.formula1)!=null?t:"").replace(C,(o=a.formula2)!=null?o:"")}`:this.titleStr}getExtraStyle(a,i,e,t,o){}getRuleFinalError(a,i){return a.showErrorMessage&&a.error?a.error:this.generateRuleErrorMessage(a,i)}isEmptyCellValue(a){return a===""||a===void 0||a===null}normalizeFormula(a,i,e){return{formula1:a.formula1,formula2:a.formula2}}async isValidType(a,i,e){return!0}transform(a,i,e){return a}async validatorIsEqual(a,i,e){const{formula1:t}=i,{value:o}=a;return Number.isNaN(t)?!0:o===t}async validatorIsNotEqual(a,i,e){const{formula1:t}=i;return Number.isNaN(t)?!0:a.value!==t}async validatorIsBetween(a,i,e){const{formula1:t,formula2:o}=i;if(Number.isNaN(t)||Number.isNaN(o))return!0;const d=Math.min(t,o),s=Math.max(t,o);return a.value>=d&&a.value<=s}async validatorIsNotBetween(a,i,e){const{formula1:t,formula2:o}=i;if(Number.isNaN(t)||Number.isNaN(o))return!0;const d=Math.min(t,o),s=Math.max(t,o);return a.value<d||a.value>s}async validatorIsGreaterThan(a,i,e){const{formula1:t}=i;return Number.isNaN(t)?!0:a.value>t}async validatorIsGreaterThanOrEqual(a,i,e){const{formula1:t}=i;return Number.isNaN(t)?!0:a.value>=t}async validatorIsLessThan(a,i,e){const{formula1:t}=i;return Number.isNaN(t)?!0:a.value<t}async validatorIsLessThanOrEqual(a,i,e){const{formula1:t}=i;return Number.isNaN(t)?!0:a.value<=t}async validator(a,i){const{value:e,unitId:t,subUnitId:o}=a,d=this.isEmptyCellValue(e),{allowBlank:s=!0,operator:p}=i;if(d)return s;const u=await this.parseFormula(i,t,o,a.row,a.column);if(!u.isFormulaValid||!await this.isValidType(a,u,i))return!1;if(!r.Tools.isDefine(p))return!0;const m=this.transform(a,u,i);switch(p){case r.DataValidationOperator.BETWEEN:return this.validatorIsBetween(m,u,i);case r.DataValidationOperator.EQUAL:return this.validatorIsEqual(m,u,i);case r.DataValidationOperator.GREATER_THAN:return this.validatorIsGreaterThan(m,u,i);case r.DataValidationOperator.GREATER_THAN_OR_EQUAL:return this.validatorIsGreaterThanOrEqual(m,u,i);case r.DataValidationOperator.LESS_THAN:return this.validatorIsLessThan(m,u,i);case r.DataValidationOperator.LESS_THAN_OR_EQUAL:return this.validatorIsLessThanOrEqual(m,u,i);case r.DataValidationOperator.NOT_BETWEEN:return this.validatorIsNotBetween(m,u,i);case r.DataValidationOperator.NOT_EQUAL:return this.validatorIsNotEqual(m,u,i);default:throw new Error("Unknown operator.")}}},l.BaseDataValidator=aa([U(0,r.Inject(r.LocaleService)),U(1,r.Inject(r.Injector))],l.BaseDataValidator),l.AddDataValidationMutation=O,l.DataValidatorRegistryScope=I,l.DataValidatorRegistryService=R,l.RemoveDataValidationMutation=v,l.TWO_FORMULA_OPERATOR_COUNT=X,l.TextLengthErrorTitleMap=Y,l.UpdateDataValidationMutation=_,l.UpdateRuleType=h,l.getRuleOptions=N,l.getRuleSetting=D,Object.defineProperty(l,Symbol.toStringTag,{value:"Module"})});
3
3
 
4
4
 
5
5
  // @univerjs/sheets-data-validation/index
6
- (function(m,r){typeof exports=="object"&&typeof module<"u"?r(exports,require("@univerjs/core"),require("@univerjs/data-validation"),require("@univerjs/sheets"),require("rxjs"),require("@univerjs/sheets-formula"),require("@univerjs/engine-formula")):typeof define=="function"&&define.amd?define(["exports","@univerjs/core","@univerjs/data-validation","@univerjs/sheets","rxjs","@univerjs/sheets-formula","@univerjs/engine-formula"],r):(m=typeof globalThis<"u"?globalThis:m||self,r(m.UniverSheetsDataValidation={},m.UniverCore,m.UniverDataValidation,m.UniverSheets,m.rxjs,m.UniverSheetsFormula,m.UniverEngineFormula))})(this,function(m,r,g,D,A,K,T){"use strict";var bt=Object.defineProperty;var Lt=(m,r,g)=>r in m?bt(m,r,{enumerable:!0,configurable:!0,writable:!0,value:g}):m[r]=g;var f=(m,r,g)=>Lt(m,typeof r!="symbol"?r+"":r,g);const ve="SHEET_DATA_VALIDATION_PLUGIN";var $e=Object.defineProperty,He=Object.getOwnPropertyDescriptor,We=(s,o,e,t)=>{for(var a=t>1?void 0:t?He(o,e):o,i=s.length-1,n;i>=0;i--)(n=s[i])&&(a=(t?n(o,e,a):n(a))||a);return t&&a&&$e(o,e,a),a},Re=(s,o)=>(e,t)=>o(e,t,s);m.DataValidationCacheService=class extends r.Disposable{constructor(e,t){super();f(this,"_cacheMatrix",new Map);f(this,"_dirtyRanges$",new A.Subject);f(this,"dirtyRanges$",this._dirtyRanges$.asObservable());this._commandService=e,this._univerInstanceService=t,this._initDirtyRanges(),this._initSheetRemove()}_initDirtyRanges(){this.disposeWithMe(this._commandService.onCommandExecuted(e=>{if(e.id===D.SetRangeValuesMutation.id){const{cellValue:t,unitId:a,subUnitId:i}=e.params;if(t){const n=new r.ObjectMatrix(t).getDataRange();if(n.endRow===-1)return;this.markRangeDirty(a,i,[n])}}}))}_initSheetRemove(){this.disposeWithMe(this._commandService.onCommandExecuted(e=>{var t;if(e.id===D.RemoveSheetMutation.id){const{unitId:a,subUnitId:i}=e.params;(t=this._cacheMatrix.get(a))==null||t.delete(i)}})),this.disposeWithMe(this._univerInstanceService.unitDisposed$.subscribe(e=>{e.type===r.UniverInstanceType.UNIVER_SHEET&&this._cacheMatrix.delete(e.getUnitId())}))}_ensureCache(e,t){let a=this._cacheMatrix.get(e);a||(a=new Map,this._cacheMatrix.set(e,a));let i=a.get(t);return i||(i=new r.ObjectMatrix,a.set(t,i)),i}ensureCache(e,t){return this._ensureCache(e,t)}addRule(e,t,a){this.markRangeDirty(e,t,a.ranges)}removeRule(e,t,a){this._deleteRange(e,t,a.ranges)}markRangeDirty(e,t,a){const i=this._ensureCache(e,t);a.forEach(n=>{r.Range.foreach(n,(l,u)=>{i.setValue(l,u,void 0)})}),this._dirtyRanges$.next({unitId:e,subUnitId:t,ranges:a})}_deleteRange(e,t,a){const i=this._ensureCache(e,t);a.forEach(n=>{r.Range.foreach(n,(l,u)=>{i.realDeleteValue(l,u)})}),this._dirtyRanges$.next({unitId:e,subUnitId:t,ranges:a})}getValue(e,t,a,i){return this._ensureCache(e,t).getValue(a,i)}},m.DataValidationCacheService=We([Re(0,r.Inject(r.ICommandService)),Re(1,r.Inject(r.IUniverInstanceService))],m.DataValidationCacheService);function w(s){var o,e;return(e=(o=s==null?void 0:s[0])==null?void 0:o[0])==null?void 0:e.v}function j(s){var o;return(o=s==null?void 0:s[0])==null?void 0:o[0]}function y(s){return!T.ERROR_TYPE_SET.has(s)}function P(s,o){var t;const e=o.getValidatorItem(s);return(t=e==null?void 0:e.offsetFormulaByRange)!=null?t:!1}var xe=Object.defineProperty,qe=Object.getOwnPropertyDescriptor,Qe=(s,o,e,t)=>{for(var a=t>1?void 0:t?qe(o,e):o,i=s.length-1,n;i>=0;i--)(n=s[i])&&(a=(t?n(o,e,a):n(a))||a);return t&&a&&xe(o,e,a),a},$=(s,o)=>(e,t)=>o(e,t,s);m.DataValidationCustomFormulaService=class extends r.Disposable{constructor(e,t,a,i,n){super();f(this,"_ruleFormulaMap",new Map);f(this,"_ruleFormulaMap2",new Map);this._instanceSrv=e,this._registerOtherFormulaService=t,this._dataValidationModel=a,this._dataValidationCacheService=i,this._validatorRegistryService=n,this._initFormulaResultHandler()}_initFormulaResultHandler(){this.disposeWithMe(this._registerOtherFormulaService.formulaResult$.subscribe(e=>{for(const t in e){const a=e[t];if(this._instanceSrv.getUnitType(t)===r.UniverInstanceType.UNIVER_SHEET)for(const n in a){const l=a[n],{ruleFormulaMap:u}=this._ensureMaps(t,n);l.forEach(d=>{var p,_;const c=u.get((p=d.extra)==null?void 0:p.ruleId),h=this._dataValidationModel.getRuleById(t,n,(_=d.extra)==null?void 0:_.ruleId);h&&c&&this._dataValidationCacheService.markRangeDirty(t,n,h.ranges)})}}}))}_ensureMaps(e,t){let a=this._ruleFormulaMap.get(e),i=this._ruleFormulaMap2.get(e);a||(a=new Map,this._ruleFormulaMap.set(e,a)),i||(i=new Map,this._ruleFormulaMap2.set(e,i));let n=a.get(t);n||(n=new Map,a.set(t,n));let l=i.get(t);return l||(l=new Map,i.set(t,l)),{ruleFormulaMap:n,ruleFormulaMap2:l}}_registerFormula(e,t,a,i,n){return this._registerOtherFormulaService.registerFormulaWithRange(e,t,i,n,{ruleId:a})}deleteByRuleId(e,t,a){const{ruleFormulaMap:i,ruleFormulaMap2:n}=this._ensureMaps(e,t),l=this._dataValidationModel.getRuleById(e,t,a),u=i.get(a);if(!l||!u)return;const d=i.get(a);d&&(i.delete(a),this._registerOtherFormulaService.deleteFormula(e,t,[d.formulaId]));const c=n.get(a);c&&(n.delete(a),this._registerOtherFormulaService.deleteFormula(e,t,[c.formulaId]))}_addFormulaByRange(e,t,a,i,n,l){const{ruleFormulaMap:u,ruleFormulaMap2:d}=this._ensureMaps(e,t),c=l[0].startRow,h=l[0].startColumn;if(i&&r.isFormulaString(i)){const p=this._registerFormula(e,t,a,i,l);u.set(a,{formula:i,originCol:h,originRow:c,formulaId:p})}if(n&&r.isFormulaString(n)){const p=this._registerFormula(e,t,a,n,l);d.set(a,{formula:n,originCol:h,originRow:c,formulaId:p})}}addRule(e,t,a){if(P(a.type,this._validatorRegistryService)){const{ranges:i,formula1:n,formula2:l,uid:u}=a;this._addFormulaByRange(e,t,u,n,l,i)}}async getCellFormulaValue(e,t,a,i,n){var v,R;const{ruleFormulaMap:l}=this._ensureMaps(e,t),u=l.get(a);if(!u)return Promise.resolve(void 0);const d=await this._registerOtherFormulaService.getFormulaValue(e,t,u.formulaId),{originRow:c,originCol:h}=u,p=i-c,_=n-h;return j((R=(v=d==null?void 0:d.result)==null?void 0:v[p])==null?void 0:R[_])}async getCellFormula2Value(e,t,a,i,n){var v,R;const{ruleFormulaMap2:l}=this._ensureMaps(e,t),u=l.get(a);if(!u)return Promise.resolve(void 0);const d=await this._registerOtherFormulaService.getFormulaValue(e,t,u.formulaId),{originRow:c,originCol:h}=u,p=i-c,_=n-h;return j((R=(v=d==null?void 0:d.result)==null?void 0:v[p])==null?void 0:R[_])}getCellFormulaValueSync(e,t,a,i,n){var v,R;const{ruleFormulaMap:l}=this._ensureMaps(e,t),u=l.get(a);if(!u)return;const d=this._registerOtherFormulaService.getFormulaValueSync(e,t,u.formulaId),{originRow:c,originCol:h}=u,p=i-c,_=n-h;return j((R=(v=d==null?void 0:d.result)==null?void 0:v[p])==null?void 0:R[_])}getCellFormula2ValueSync(e,t,a,i,n){var v,R;const{ruleFormulaMap2:l}=this._ensureMaps(e,t),u=l.get(a);if(!u)return;const d=this._registerOtherFormulaService.getFormulaValueSync(e,t,u.formulaId),{originRow:c,originCol:h}=u,p=i-c,_=n-h;return j((R=(v=d==null?void 0:d.result)==null?void 0:v[p])==null?void 0:R[_])}getRuleFormulaInfo(e,t,a){const{ruleFormulaMap:i}=this._ensureMaps(e,t);return i.get(a)}},m.DataValidationCustomFormulaService=Qe([$(0,r.IUniverInstanceService),$(1,r.Inject(K.RegisterOtherFormulaService)),$(2,r.Inject(g.DataValidationModel)),$(3,r.Inject(m.DataValidationCacheService)),$(4,r.Inject(g.DataValidatorRegistryService))],m.DataValidationCustomFormulaService);var Ge=Object.defineProperty,ke=Object.getOwnPropertyDescriptor,Ye=(s,o,e,t)=>{for(var a=t>1?void 0:t?ke(o,e):o,i=s.length-1,n;i>=0;i--)(n=s[i])&&(a=(t?n(o,e,a):n(a))||a);return t&&a&&Ge(o,e,a),a},H=(s,o)=>(e,t)=>o(e,t,s);m.DataValidationFormulaService=class extends r.Disposable{constructor(e,t,a,i,n){super();f(this,"_formulaRuleMap",new Map);this._instanceService=e,this._registerOtherFormulaService=t,this._dataValidationCacheService=a,this._dataValidationModel=i,this._validatorRegistryService=n,this._initFormulaResultHandler()}_initFormulaResultHandler(){this.disposeWithMe(this._registerOtherFormulaService.formulaResult$.subscribe(e=>{for(const t in e){const a=e[t];if(this._instanceService.getUnitType(t)===r.UniverInstanceType.UNIVER_SHEET)for(const n in a){const l=a[n],u=this._ensureRuleFormulaMap(t,n);l.forEach(d=>{var c,h;if(u.get((c=d.extra)==null?void 0:c.ruleId)){const p=this._dataValidationModel.getRuleById(t,n,(h=d.extra)==null?void 0:h.ruleId);p&&this._dataValidationCacheService.markRangeDirty(t,n,p.ranges)}})}}}))}_ensureRuleFormulaMap(e,t){let a=this._formulaRuleMap.get(e);a||(a=new Map,this._formulaRuleMap.set(e,a));let i=a.get(t);return i||(i=new Map,a.set(t,i)),i}_registerSingleFormula(e,t,a,i){const n=[{startColumn:0,endColumn:0,startRow:0,endRow:0}];return this._registerOtherFormulaService.registerFormulaWithRange(e,t,a,n,{ruleId:i})}addRule(e,t,a){if(!P(a.type,this._validatorRegistryService)&&a.type!==r.DataValidationType.CHECKBOX){const{formula1:i,formula2:n,uid:l}=a,u=r.isFormulaString(i),d=r.isFormulaString(n);if(!u&&!d)return;const c=this._ensureRuleFormulaMap(e,t),h=[void 0,void 0];if(u){const p=this._registerSingleFormula(e,t,i,l);h[0]={id:p,text:i}}if(d){const p=this._registerSingleFormula(e,t,n,l);h[1]={id:p,text:n}}c.set(l,h)}}removeRule(e,t,a){const n=this._ensureRuleFormulaMap(e,t).get(a);if(!n)return;const[l,u]=n,d=[l==null?void 0:l.id,u==null?void 0:u.id].filter(Boolean);d.length&&this._registerOtherFormulaService.deleteFormula(e,t,d)}getRuleFormulaResult(e,t,a){const n=this._ensureRuleFormulaMap(e,t).get(a);if(!n)return Promise.resolve(null);const l=async u=>u&&this._registerOtherFormulaService.getFormulaValue(e,t,u.id);return Promise.all([l(n[0]),l(n[1])])}getRuleFormulaResultSync(e,t,a){const n=this._ensureRuleFormulaMap(e,t).get(a);if(n)return n.map(l=>{if(l)return this._registerOtherFormulaService.getFormulaValueSync(e,t,l.id)})}getRuleFormulaInfo(e,t,a){return this._ensureRuleFormulaMap(e,t).get(a)}},m.DataValidationFormulaService=Ye([H(0,r.IUniverInstanceService),H(1,r.Inject(K.RegisterOtherFormulaService)),H(2,r.Inject(m.DataValidationCacheService)),H(3,r.Inject(g.DataValidationModel)),H(4,r.Inject(g.DataValidatorRegistryService))],m.DataValidationFormulaService);function U(s){return r.getOriginCellValue(s)}function Ve(s){var o;return String((o=U(s))!=null?o:"")}class ue{constructor(o,e,t,a,i=!1){f(this,"_map");f(this,"_tree",new r.RBush);f(this,"_dirty",!0);f(this,"_buildTree",()=>{if(!this._dirty||this._disableTree)return;this._tree.clear();const o=[];this._map.forEach((e,t)=>{e.forEach(a=>{o.push({minX:a.startRow,maxX:a.endRow,minY:a.startColumn,maxY:a.endColumn,ruleId:t})})}),this._tree.load(o),this._dirty=!1});f(this,"_debonceBuildTree",r.debounce(this._buildTree,0));this._unitId=e,this._subUnitId=t,this._univerInstanceService=a,this._disableTree=i,this._map=o,this._buildTree()}get _worksheet(){var o;return(o=this._univerInstanceService.getUnit(this._unitId,r.UniverInstanceType.UNIVER_SHEET))==null?void 0:o.getSheetBySheetId(this._subUnitId)}_addRule(o,e){if(!this._worksheet)return;const t=r.Rectangle.mergeRanges(e.map(a=>r.Range.transformRange(a,this._worksheet)));this._map.forEach((a,i)=>{const n=r.Rectangle.subtractMulti(a,t);n.length===0?this._map.delete(i):this._map.set(i,n)}),this._dirty=!0,this._map.set(o,t),this._debonceBuildTree()}addRule(o){this._addRule(o.uid,o.ranges)}removeRange(o){if(!this._worksheet)return;const e=o.map(t=>r.Range.transformRange(t,this._worksheet));this._map.forEach((t,a)=>{const i=r.Rectangle.subtractMulti(t,e);i.length===0?this._map.delete(a):this._map.set(a,i)}),this._dirty=!0,this._debonceBuildTree()}_removeRule(o){this._map.delete(o),this._dirty=!0,this._debonceBuildTree()}removeRule(o){this._removeRule(o.uid)}updateRange(o,e){this._removeRule(o),this._addRule(o,e)}addRangeRules(o){o.forEach(({id:e,ranges:t})=>{if(!t.length)return;let a=this._map.get(e);a?(this._map.set(e,r.Rectangle.mergeRanges([...a,...t])),a=this._map.get(e)):(a=t,this._map.set(e,a)),this._map.forEach((i,n)=>{if(n===e)return;const l=r.Rectangle.subtractMulti(i,t);l.length===0?this._map.delete(n):this._map.set(n,l)})}),this._dirty=!0,this._debonceBuildTree()}diff(o){const e=[];let t=0;return o.forEach((a,i)=>{var u;const n=(u=this._map.get(a.uid))!=null?u:[],l=a.ranges;n.length!==0&&(n.length!==l.length||n.some((d,c)=>!r.Rectangle.equals(d,l[c])))&&e.push({type:"update",ruleId:a.uid,oldRanges:l,newRanges:r.Rectangle.sort(n),rule:a}),n.length===0&&(e.push({type:"delete",rule:a,index:i-t}),t++)}),e}diffWithAddition(o,e){const t=[];let a=0;return o.forEach((i,n)=>{var d;const l=(d=this._map.get(i.uid))!=null?d:[],u=i.ranges;l.length!==0&&(l.length!==u.length||l.some((c,h)=>!r.Rectangle.equals(c,u[h])))&&t.push({type:"update",ruleId:i.uid,oldRanges:u,newRanges:r.Rectangle.sort(l),rule:i}),l.length===0&&(t.push({type:"delete",rule:i,index:n-a}),a++)}),Array.from(e).forEach(i=>{var l;const n=(l=this._map.get(i.uid))!=null?l:[];t.push({type:"add",rule:{...i,ranges:r.Rectangle.sort(n)}})}),t}clone(){return new ue(new Map(r.Tools.deepClone(Array.from(this._map.entries()))),this._unitId,this._subUnitId,this._univerInstanceService,!0)}getValue(o,e){this._dirty&&this._buildTree();const t=this._tree.search({minX:o,maxX:o,minY:e,maxY:e});return t.length>0?t[0].ruleId:void 0}}var Xe=Object.defineProperty,Ke=Object.getOwnPropertyDescriptor,ze=(s,o,e,t)=>{for(var a=t>1?void 0:t?Ke(o,e):o,i=s.length-1,n;i>=0;i--)(n=s[i])&&(a=(t?n(o,e,a):n(a))||a);return t&&a&&Xe(o,e,a),a},N=(s,o)=>(e,t)=>o(e,t,s);m.SheetDataValidationModel=class extends r.Disposable{constructor(e,t,a,i,n,l,u){super();f(this,"_ruleMatrixMap",new Map);f(this,"_validStatusChange$",new A.Subject);f(this,"_ruleChange$",new A.Subject);f(this,"ruleChange$",this._ruleChange$.asObservable());f(this,"validStatusChange$",this._validStatusChange$.asObservable());this._dataValidationModel=e,this._univerInstanceService=t,this._dataValidatorRegistryService=a,this._dataValidationCacheService=i,this._dataValidationFormulaService=n,this._dataValidationCustomFormulaService=l,this._commandService=u,this._initRuleUpdateListener(),this.disposeWithMe(()=>{this._ruleChange$.complete(),this._validStatusChange$.complete()}),this._initUniverInstanceListener()}_initUniverInstanceListener(){this.disposeWithMe(this._univerInstanceService.unitDisposed$.subscribe(e=>{this._ruleMatrixMap.delete(e.getUnitId())})),this.disposeWithMe(this._commandService.onCommandExecuted(e=>{if(e.id===D.RemoveSheetMutation.id){const{unitId:t,subUnitId:a}=e.params,i=this._ruleMatrixMap.get(t);i&&i.delete(a)}}))}_initRuleUpdateListener(){const e=this._dataValidationModel.getAll();for(const[t,a]of e)for(const[i,n]of a)for(const l of n)this._addRule(t,i,l),this._ruleChange$.next({type:"add",unitId:t,subUnitId:i,rule:l,source:"patched"});this.disposeWithMe(this._dataValidationModel.ruleChange$.subscribe(t=>{switch(t.type){case"add":this._addRule(t.unitId,t.subUnitId,t.rule);break;case"update":this._updateRule(t.unitId,t.subUnitId,t.rule.uid,t.oldRule,t.updatePayload);break;case"remove":this._removeRule(t.unitId,t.subUnitId,t.rule);break}this._ruleChange$.next(t)}))}_ensureRuleMatrix(e,t){let a=this._ruleMatrixMap.get(e);a||(a=new Map,this._ruleMatrixMap.set(e,a));let i=a.get(t);return i||(i=new ue(new Map,e,t,this._univerInstanceService),a.set(t,i)),i}_addRuleSideEffect(e,t,a){this._ensureRuleMatrix(e,t).addRule(a),this._dataValidationCacheService.addRule(e,t,a),this._dataValidationFormulaService.addRule(e,t,a),this._dataValidationCustomFormulaService.addRule(e,t,a)}_addRule(e,t,a){(Array.isArray(a)?a:[a]).forEach(n=>{this._addRuleSideEffect(e,t,n)})}_updateRule(e,t,a,i,n){const l=this._ensureRuleMatrix(e,t),u={...i,...n.payload};n.type===g.UpdateRuleType.RANGE?l.updateRange(a,n.payload):n.type===g.UpdateRuleType.ALL&&l.updateRange(a,n.payload.ranges),this._dataValidationCacheService.removeRule(e,t,i),this._dataValidationCacheService.addRule(e,t,u),this._dataValidationFormulaService.removeRule(e,t,i.uid),this._dataValidationFormulaService.addRule(e,t,u),this._dataValidationCustomFormulaService.deleteByRuleId(e,t,a),this._dataValidationCustomFormulaService.addRule(e,t,u)}_removeRule(e,t,a){this._ensureRuleMatrix(e,t).removeRule(a),this._dataValidationCacheService.removeRule(e,t,a),this._dataValidationCustomFormulaService.deleteByRuleId(e,t,a.uid)}getValidator(e){return this._dataValidatorRegistryService.getValidatorItem(e)}getRuleIdByLocation(e,t,a,i){return this._ensureRuleMatrix(e,t).getValue(a,i)}getRuleByLocation(e,t,a,i){const n=this.getRuleIdByLocation(e,t,a,i);if(n)return this._dataValidationModel.getRuleById(e,t,n)}validator(e,t,a){const{col:i,row:n,unitId:l,subUnitId:u,worksheet:d}=t,c=(R,V)=>{a&&a(R,V),V&&this._validStatusChange$.next({unitId:l,subUnitId:u,ruleId:e.uid,status:R,row:n,col:i})},h=d.getCellValueOnly(n,i),p=this.getValidator(e.type),_=d.getCellRaw(n,i),v=U(_);if(p){const R=this._dataValidationCacheService.ensureCache(l,u),V=R.getValue(n,i);return V==null?(R.setValue(n,i,r.DataValidationStatus.VALIDATING),p.validator({value:v,unitId:l,subUnitId:u,row:n,column:i,worksheet:t.worksheet,workbook:t.workbook,interceptValue:U(h),t:_==null?void 0:_.t},e).then(S=>{const M=S?r.DataValidationStatus.VALID:r.DataValidationStatus.INVALID;M===r.DataValidationStatus.VALID?R.realDeleteValue(n,i):R.setValue(n,i,M);const O=R.getValue(n,i);c(M,V!==O)}),r.DataValidationStatus.VALIDATING):(c(V!=null?V:r.DataValidationStatus.VALID,!1),V!=null?V:r.DataValidationStatus.VALID)}else return c(r.DataValidationStatus.VALID,!1),r.DataValidationStatus.VALID}getRuleObjectMatrix(e,t){return this._ensureRuleMatrix(e,t)}getRuleById(e,t,a){return this._dataValidationModel.getRuleById(e,t,a)}getRuleIndex(e,t,a){return this._dataValidationModel.getRuleIndex(e,t,a)}getRules(e,t){return[...this._dataValidationModel.getRules(e,t)]}getUnitRules(e){return this._dataValidationModel.getUnitRules(e)}deleteUnitRules(e){return this._dataValidationModel.deleteUnitRules(e)}getSubUnitIds(e){return this._dataValidationModel.getSubUnitIds(e)}getAll(){return this._dataValidationModel.getAll()}},m.SheetDataValidationModel=ze([N(0,r.Inject(g.DataValidationModel)),N(1,r.IUniverInstanceService),N(2,r.Inject(g.DataValidatorRegistryService)),N(3,r.Inject(m.DataValidationCacheService)),N(4,r.Inject(m.DataValidationFormulaService)),N(5,r.Inject(m.DataValidationCustomFormulaService)),N(6,r.ICommandService)],m.SheetDataValidationModel);const W=1,x=0;function De(s,o){return r.Tools.isBlank(s)?o.t("dataValidation.validFail.value"):r.isFormulaString(s)?o.t("dataValidation.validFail.primitive"):""}const q=s=>r.Tools.isDefine(s)&&String(s).toLowerCase()==="true"?"1":String(s).toLowerCase()==="false"?"0":s;class Me extends g.BaseDataValidator{constructor(){super(...arguments);f(this,"id",r.DataValidationType.CHECKBOX);f(this,"title","dataValidation.checkbox.title");f(this,"operators",[]);f(this,"scopes",["sheet"]);f(this,"offsetFormulaByRange",!1);f(this,"_formulaService",this.injector.get(m.DataValidationFormulaService));f(this,"skipDefaultFontRender",(e,t,a)=>{const{unitId:i,subUnitId:n}=a,{formula1:l,formula2:u}=this.parseFormulaSync(e,i,n),d=`${t!=null?t:""}`;return!d||d===`${l}`||d===`${u}`})}validatorFormula(e,t,a){const{formula1:i,formula2:n}=e,l=i===n;if(r.Tools.isBlank(i)&&r.Tools.isBlank(n))return{success:!0};if(l)return{success:!1,formula1:this.localeService.t("dataValidation.validFail.checkboxEqual"),formula2:this.localeService.t("dataValidation.validFail.checkboxEqual")};const u=De(i,this.localeService),d=De(n,this.localeService);return{success:!u&&!d,formula1:u,formula2:d}}async parseFormula(e,t,a){var h,p,_,v;const{formula1:i=W,formula2:n=x}=e,l=await this._formulaService.getRuleFormulaResult(t,a,e.uid),u=r.isFormulaString(i)?w((p=(h=l==null?void 0:l[0])==null?void 0:h.result)==null?void 0:p[0][0]):i,d=r.isFormulaString(n)?w((v=(_=l==null?void 0:l[1])==null?void 0:_.result)==null?void 0:v[0][0]):n,c=y(String(u))&&y(String(d));return{formula1:q(u),formula2:q(d),originFormula1:u,originFormula2:d,isFormulaValid:c}}getExtraStyle(e,t){return{tb:r.WrapStrategy.CLIP}}parseFormulaSync(e,t,a){var h,p,_,v;const{formula1:i=W,formula2:n=x}=e,l=this._formulaService.getRuleFormulaResultSync(t,a,e.uid),u=r.isFormulaString(i)?w((p=(h=l==null?void 0:l[0])==null?void 0:h.result)==null?void 0:p[0][0]):i,d=r.isFormulaString(n)?w((v=(_=l==null?void 0:l[1])==null?void 0:_.result)==null?void 0:v[0][0]):n,c=y(String(u))&&y(String(d));return{formula1:q(u),formula2:q(d),originFormula1:u,originFormula2:d,isFormulaValid:c}}async isValidType(e,t,a){const{value:i,unitId:n,subUnitId:l}=e,{formula1:u,formula2:d,originFormula1:c,originFormula2:h}=await this.parseFormula(a,n,l);return!r.Tools.isDefine(u)||!r.Tools.isDefine(d)?!0:r.Tools.isDefine(i)&&(String(i)===String(u)||String(i)===String(d)||String(i)===String(c!=null?c:"")||String(i)===String(h!=null?h:""))}generateRuleErrorMessage(e){return this.localeService.t("dataValidation.checkbox.error")}}const Ze={[r.DataValidationOperator.BETWEEN]:"dataValidation.date.operators.between",[r.DataValidationOperator.EQUAL]:"dataValidation.date.operators.equal",[r.DataValidationOperator.GREATER_THAN]:"dataValidation.date.operators.greaterThan",[r.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.date.operators.greaterThanOrEqual",[r.DataValidationOperator.LESS_THAN]:"dataValidation.date.operators.lessThan",[r.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.date.operators.lessThanOrEqual",[r.DataValidationOperator.NOT_BETWEEN]:"dataValidation.date.operators.notBetween",[r.DataValidationOperator.NOT_EQUAL]:"dataValidation.date.operators.notEqual"};r.DataValidationOperator.BETWEEN+"",r.DataValidationOperator.EQUAL+"",r.DataValidationOperator.GREATER_THAN+"",r.DataValidationOperator.GREATER_THAN_OR_EQUAL+"",r.DataValidationOperator.LESS_THAN+"",r.DataValidationOperator.LESS_THAN_OR_EQUAL+"",r.DataValidationOperator.NOT_BETWEEN+"",r.DataValidationOperator.NOT_EQUAL+"";const Je={[r.DataValidationOperator.BETWEEN]:"dataValidation.date.ruleName.between",[r.DataValidationOperator.EQUAL]:"dataValidation.date.ruleName.equal",[r.DataValidationOperator.GREATER_THAN]:"dataValidation.date.ruleName.greaterThan",[r.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.date.ruleName.greaterThanOrEqual",[r.DataValidationOperator.LESS_THAN]:"dataValidation.date.ruleName.lessThan",[r.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.date.ruleName.lessThanOrEqual",[r.DataValidationOperator.NOT_BETWEEN]:"dataValidation.date.ruleName.notBetween",[r.DataValidationOperator.NOT_EQUAL]:"dataValidation.date.ruleName.notEqual"},et={[r.DataValidationOperator.BETWEEN]:"dataValidation.date.errorMsg.between",[r.DataValidationOperator.EQUAL]:"dataValidation.date.errorMsg.equal",[r.DataValidationOperator.GREATER_THAN]:"dataValidation.date.errorMsg.greaterThan",[r.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.date.errorMsg.greaterThanOrEqual",[r.DataValidationOperator.LESS_THAN]:"dataValidation.date.errorMsg.lessThan",[r.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.date.errorMsg.lessThanOrEqual",[r.DataValidationOperator.NOT_BETWEEN]:"dataValidation.date.errorMsg.notBetween",[r.DataValidationOperator.NOT_EQUAL]:"dataValidation.date.errorMsg.notEqual"},z=[r.DataValidationOperator.BETWEEN,r.DataValidationOperator.NOT_BETWEEN],Q="{FORMULA1}",G="{FORMULA2}";function tt(s){return s.filter(Boolean).join(",")}function k(s){return s.split(",").filter(Boolean)}function at(s){const o=U(s);return o==null?"":o.toString()}function Z(s,o,e){const{formula1:t,formula2:a}=o,i=o.ranges[0].startRow,n=o.ranges[0].startColumn,l=e.row-i,u=e.col-n,d=r.isFormulaString(t)?s.moveFormulaRefOffset(t,u,l,!0):t,c=r.isFormulaString(a)?s.moveFormulaRefOffset(a,u,l,!0):a;return{transformedFormula1:d,transformedFormula2:c}}const de=s=>{var e,t;if(s==null||typeof s=="boolean")return;if(typeof s=="number"||!Number.isNaN(+s))return+s;const o=(e=r.numfmt.parseDate(s))==null?void 0:e.v;return r.Tools.isDefine(o)?o:(t=r.numfmt.parseDate(r.dayjs(s).format("YYYY-MM-DD HH:mm:ss")))==null?void 0:t.v};class ye extends g.BaseDataValidator{constructor(){super(...arguments);f(this,"id",r.DataValidationType.DATE);f(this,"title","dataValidation.date.title");f(this,"operators",[r.DataValidationOperator.BETWEEN,r.DataValidationOperator.EQUAL,r.DataValidationOperator.GREATER_THAN,r.DataValidationOperator.GREATER_THAN_OR_EQUAL,r.DataValidationOperator.LESS_THAN,r.DataValidationOperator.LESS_THAN_OR_EQUAL,r.DataValidationOperator.NOT_BETWEEN,r.DataValidationOperator.NOT_EQUAL]);f(this,"scopes",["sheet"]);f(this,"_customFormulaService",this.injector.get(m.DataValidationCustomFormulaService));f(this,"_lexerTreeBuilder",this.injector.get(T.LexerTreeBuilder))}async parseFormula(e,t,a,i,n){const l=await this._customFormulaService.getCellFormulaValue(t,a,e.uid,i,n),u=await this._customFormulaService.getCellFormula2Value(t,a,e.uid,i,n),{formula1:d,formula2:c}=e,h=y(String(l==null?void 0:l.v))&&y(String(u==null?void 0:u.v));return{formula1:de(r.isFormulaString(d)?l==null?void 0:l.v:d),formula2:de(r.isFormulaString(c)?u==null?void 0:u.v:c),isFormulaValid:h}}async isValidType(e){const{interceptValue:t,value:a}=e;return typeof a=="number"&&typeof t=="string"?!0:typeof t=="string"?!!r.numfmt.parseDate(t):!1}_validatorSingleFormula(e){return!r.Tools.isBlank(e)&&(r.isFormulaString(e)||!Number.isNaN(+e)||!!(e&&r.numfmt.parseDate(e)))}validatorFormula(e,t,a){const i=e.operator;if(!i)return{success:!1};const n=this._validatorSingleFormula(e.formula1),l=this.localeService.t("dataValidation.validFail.date");if(z.includes(i)){const d=this._validatorSingleFormula(e.formula2);return{success:n&&d,formula1:n?void 0:l,formula2:d?void 0:l}}return{success:n,formula1:n?void 0:l}}normalizeFormula(e,t,a){const{formula1:i,formula2:n,bizInfo:l}=e,u=d=>{var h;if(!d)return d;let c;if(!Number.isNaN(+d))c=r.numfmt.dateFromSerial(+d);else{const p=(h=r.numfmt.parseDate(d))==null?void 0:h.v;if(p==null)return"";c=r.numfmt.dateFromSerial(p)}return r.dayjs(`${c[0]}/${c[1]}/${c[2]} ${c[3]}:${c[4]}:${c[5]}`).format(l!=null&&l.showTime?"YYYY-MM-DD HH:mm:ss":"YYYY-MM-DD")};return{formula1:r.isFormulaString(i)?i:u(`${i}`),formula2:r.isFormulaString(n)?n:u(`${n}`)}}transform(e,t,a){const{value:i}=e;return{...e,value:de(i)}}get operatorNames(){return this.operators.map(e=>this.localeService.t(Ze[e]))}generateRuleName(e){var a,i;if(!e.operator)return this.titleStr;const t=this.localeService.t(Je[e.operator]).replace(Q,(a=e.formula1)!=null?a:"").replace(G,(i=e.formula2)!=null?i:"");return`${this.titleStr} ${t}`}generateRuleErrorMessage(e,t){if(!e.operator)return this.titleStr;const{transformedFormula1:a,transformedFormula2:i}=Z(this._lexerTreeBuilder,e,t);return`${this.localeService.t(et[e.operator]).replace(Q,a!=null?a:"").replace(G,i!=null?i:"")}`}}r.DataValidationOperator.BETWEEN+"",r.DataValidationOperator.EQUAL+"",r.DataValidationOperator.GREATER_THAN+"",r.DataValidationOperator.GREATER_THAN_OR_EQUAL+"",r.DataValidationOperator.LESS_THAN+"",r.DataValidationOperator.LESS_THAN_OR_EQUAL+"",r.DataValidationOperator.NOT_BETWEEN+"",r.DataValidationOperator.NOT_EQUAL+"",r.DataValidationOperator.BETWEEN+"",r.DataValidationOperator.EQUAL+"",r.DataValidationOperator.GREATER_THAN+"",r.DataValidationOperator.GREATER_THAN_OR_EQUAL+"",r.DataValidationOperator.LESS_THAN+"",r.DataValidationOperator.LESS_THAN_OR_EQUAL+"",r.DataValidationOperator.NOT_BETWEEN+"",r.DataValidationOperator.NOT_EQUAL+"";const Te={[r.DataValidationOperator.BETWEEN]:"dataValidation.errorMsg.between",[r.DataValidationOperator.EQUAL]:"dataValidation.errorMsg.equal",[r.DataValidationOperator.GREATER_THAN]:"dataValidation.errorMsg.greaterThan",[r.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.errorMsg.greaterThanOrEqual",[r.DataValidationOperator.LESS_THAN]:"dataValidation.errorMsg.lessThan",[r.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.errorMsg.lessThanOrEqual",[r.DataValidationOperator.NOT_BETWEEN]:"dataValidation.errorMsg.notBetween",[r.DataValidationOperator.NOT_EQUAL]:"dataValidation.errorMsg.notEqual"};function J(s){let o=s;return typeof s=="string"?((s.startsWith("¥")||s.startsWith("$"))&&(o=s.slice(1)),+o):+s}class it extends g.BaseDataValidator{constructor(){super(...arguments);f(this,"_customFormulaService",this.injector.get(m.DataValidationCustomFormulaService));f(this,"id",r.DataValidationType.DECIMAL);f(this,"_lexerTreeBuilder",this.injector.get(T.LexerTreeBuilder));f(this,"title","dataValidation.decimal.title");f(this,"operators",[r.DataValidationOperator.BETWEEN,r.DataValidationOperator.EQUAL,r.DataValidationOperator.GREATER_THAN,r.DataValidationOperator.GREATER_THAN_OR_EQUAL,r.DataValidationOperator.LESS_THAN,r.DataValidationOperator.LESS_THAN_OR_EQUAL,r.DataValidationOperator.NOT_BETWEEN,r.DataValidationOperator.NOT_EQUAL]);f(this,"scopes",["sheet"])}_isFormulaOrNumber(e){return!r.Tools.isBlank(e)&&(r.isFormulaString(e)||!Number.isNaN(+e))}async isValidType(e,t,a){const{value:i}=e;return!Number.isNaN(J(i))}transform(e,t,a){const{value:i}=e;return{...e,value:J(i)}}_parseNumber(e){return e==null?Number.NaN:+e}async parseFormula(e,t,a,i,n){const l=await this._customFormulaService.getCellFormulaValue(t,a,e.uid,i,n),u=await this._customFormulaService.getCellFormula2Value(t,a,e.uid,i,n),{formula1:d,formula2:c}=e,h=y(String(l==null?void 0:l.v))&&y(String(u==null?void 0:u.v));return{formula1:this._parseNumber(r.isFormulaString(d)?l==null?void 0:l.v:d),formula2:this._parseNumber(r.isFormulaString(c)?u==null?void 0:u.v:c),isFormulaValid:h}}validatorFormula(e,t,a){const i=e.operator;if(!i)return{success:!1};const n=r.Tools.isDefine(e.formula1)&&this._isFormulaOrNumber(e.formula1),l=r.Tools.isDefine(e.formula2)&&this._isFormulaOrNumber(e.formula2),u=z.includes(i),d=this.localeService.t("dataValidation.validFail.number");return u?{success:n&&l,formula1:n?void 0:d,formula2:l?void 0:d}:{success:n,formula1:n?"":d}}generateRuleErrorMessage(e,t){if(!e.operator)return this.titleStr;const{transformedFormula1:a,transformedFormula2:i}=Z(this._lexerTreeBuilder,e,t);return`${this.localeService.t(Te[e.operator]).replace(Q,a!=null?a:"").replace(G,i!=null?i:"")}`}}function ce(s){if(!s)return[];const o=new Set;return s.forEach(e=>{e.forEach(t=>{var i,n;const a=U(t);if(a!=null){if(typeof a!="string"&&typeof(t==null?void 0:t.s)=="object"&&((n=(i=t.s)==null?void 0:i.n)!=null&&n.pattern)){o.add(r.numfmt.format(t.s.n.pattern,a,{throws:!1}));return}y(a.toString())&&o.add(a.toString())}})}),[...o]}const rt=["if","indirect","choose","offset"];function nt(s,o){if(!r.isFormulaString(s)||T.isReferenceString(s.slice(1)))return!0;const t=o.sequenceNodesBuilder(s);return t&&t.some(a=>typeof a=="object"&&a.nodeType===T.sequenceNodeType.FUNCTION&&rt.indexOf(a.token.toLowerCase())>-1)}function st(s,o){const{formula1:e="",ranges:t}=s;if(T.isReferenceString(e.slice(1))){const i=T.deserializeRangeWithSheet(e.slice(1));if((!i.sheetName||i.sheetName===o)&&t.some(n=>r.Rectangle.intersects(n,i.range)))return!0}return!1}class me extends g.BaseDataValidator{constructor(){super(...arguments);f(this,"formulaService",this.injector.get(m.DataValidationFormulaService));f(this,"_lexer",this.injector.get(T.LexerTreeBuilder));f(this,"_univerInstanceService",this.injector.get(r.IUniverInstanceService));f(this,"offsetFormulaByRange",!1);f(this,"id",r.DataValidationType.LIST);f(this,"title","dataValidation.list.title");f(this,"operators",[]);f(this,"scopes",["sheet"]);f(this,"skipDefaultFontRender",e=>e.renderMode!==r.DataValidationRenderMode.TEXT)}validatorFormula(e,t,a){var d,c,h;const i=!r.Tools.isBlank(e.formula1),n=nt((d=e.formula1)!=null?d:"",this._lexer),l=(h=(c=this._univerInstanceService.getUnit(t,r.UniverInstanceType.UNIVER_SHEET))==null?void 0:c.getSheetBySheetId(a))==null?void 0:h.getName(),u=st(e,l!=null?l:"");return{success:!!(i&&n&&!u),formula1:i?n?u?this.localeService.t("dataValidation.validFail.listIntersects"):void 0:this.localeService.t("dataValidation.validFail.listInvalid"):this.localeService.t("dataValidation.validFail.list")}}getExtraStyle(e,t,{style:a}){var n;const i=(n=a.tb!==r.WrapStrategy.OVERFLOW?a.tb:r.WrapStrategy.CLIP)!=null?n:r.WrapStrategy.WRAP;if(e.type===r.DataValidationType.LIST&&(e.renderMode===r.DataValidationRenderMode.ARROW||e.renderMode===r.DataValidationRenderMode.TEXT)){const l=this.getListWithColorMap(e),u=`${t!=null?t:""}`,d=l[u];if(d)return{bg:{rgb:d},tb:i}}return{tb:i}}parseCellValue(e){const t=e.toString();return k(t)}async parseFormula(e,t,a){var u,d;const i=await this.formulaService.getRuleFormulaResult(t,a,e.uid),n=w((d=(u=i==null?void 0:i[0])==null?void 0:u.result)==null?void 0:d[0][0]);return{formula1:void 0,formula2:void 0,isFormulaValid:y(String(n))}}async isValidType(e,t,a){var p,_;const{value:i,unitId:n,subUnitId:l}=e,{formula1:u=""}=a,d=await this.formulaService.getRuleFormulaResult(n,l,a.uid),c=r.isFormulaString(u)?ce((_=(p=d==null?void 0:d[0])==null?void 0:p.result)==null?void 0:_[0][0]):k(u);return this.parseCellValue(i).every(v=>c.includes(v))}generateRuleName(){return this.localeService.t("dataValidation.list.name")}generateRuleErrorMessage(){return this.localeService.t("dataValidation.list.error")}getList(e,t,a){var p,_,v,R;const{formula1:i=""}=e,n=this.injector.get(r.IUniverInstanceService),l=(p=t?n.getUniverSheetInstance(t):void 0)!=null?p:n.getCurrentUnitForType(r.UniverInstanceType.UNIVER_SHEET);if(!l)return[];const u=(_=a?l.getSheetBySheetId(a):void 0)!=null?_:l.getActiveSheet();if(!u)return[];const d=l.getUnitId(),c=u.getSheetId(),h=this.formulaService.getRuleFormulaResultSync(d,c,e.uid);return r.isFormulaString(i)?ce((R=(v=h==null?void 0:h[0])==null?void 0:v.result)==null?void 0:R[0][0]):k(i)}async getListAsync(e,t,a){var p,_,v,R;const{formula1:i=""}=e,n=this.injector.get(r.IUniverInstanceService),l=(p=t?n.getUniverSheetInstance(t):void 0)!=null?p:n.getCurrentUnitForType(r.UniverInstanceType.UNIVER_SHEET);if(!l)return[];const u=(_=a?l.getSheetBySheetId(a):void 0)!=null?_:l.getActiveSheet();if(!u)return[];const d=l.getUnitId(),c=u.getSheetId(),h=await this.formulaService.getRuleFormulaResult(d,c,e.uid);return r.isFormulaString(i)?ce((R=(v=h==null?void 0:h[0])==null?void 0:v.result)==null?void 0:R[0][0]):k(i)}getListWithColor(e,t,a){const i=this.getList(e,t,a),n=(e.formula2||"").split(",");return i.map((l,u)=>({label:l,color:n[u]}))}getListWithColorMap(e,t,a){const i=this.getListWithColor(e,t,a),n={};return i.forEach(l=>{l.color&&(n[l.label]=l.color)}),n}}class ot extends g.BaseDataValidator{constructor(){super(...arguments);f(this,"id",r.DataValidationType.TEXT_LENGTH);f(this,"title","dataValidation.textLength.title");f(this,"_lexerTreeBuilder",this.injector.get(T.LexerTreeBuilder));f(this,"operators",[r.DataValidationOperator.BETWEEN,r.DataValidationOperator.EQUAL,r.DataValidationOperator.GREATER_THAN,r.DataValidationOperator.GREATER_THAN_OR_EQUAL,r.DataValidationOperator.LESS_THAN,r.DataValidationOperator.LESS_THAN_OR_EQUAL,r.DataValidationOperator.NOT_BETWEEN,r.DataValidationOperator.NOT_EQUAL]);f(this,"scopes",["sheet"]);f(this,"_customFormulaService",this.injector.get(m.DataValidationCustomFormulaService))}_isFormulaOrInt(e){return!r.Tools.isBlank(e)&&(r.isFormulaString(e)||!Number.isNaN(+e)&&Number.isInteger(+e))}validatorFormula(e,t,a){const i=e.operator;if(!i)return{success:!1};const n=r.Tools.isDefine(e.formula1)&&this._isFormulaOrInt(e.formula1),l=r.Tools.isDefine(e.formula2)&&this._isFormulaOrInt(e.formula2),u=z.includes(i),d=this.localeService.t("dataValidation.validFail.number");return u?{success:n&&l,formula1:n?void 0:d,formula2:l?void 0:d}:{success:n,formula1:d}}_parseNumber(e){return e==null?Number.NaN:+e}async parseFormula(e,t,a,i,n){const l=await this._customFormulaService.getCellFormulaValue(t,a,e.uid,i,n),u=await this._customFormulaService.getCellFormula2Value(t,a,e.uid,i,n),{formula1:d,formula2:c}=e,h=y(String(l==null?void 0:l.v))&&y(String(u==null?void 0:u.v));return{formula1:this._parseNumber(r.isFormulaString(d)?l==null?void 0:l.v:d),formula2:this._parseNumber(r.isFormulaString(c)?u==null?void 0:u.v:c),isFormulaValid:h}}transform(e,t,a){return{...e,value:e.value.toString().length}}async isValidType(e,t,a){const{value:i}=e;return typeof i=="string"||typeof i=="number"}generateRuleErrorMessage(e,t){if(!e.operator)return this.titleStr;const{transformedFormula1:a,transformedFormula2:i}=Z(this._lexerTreeBuilder,e,t);return`${this.localeService.t(g.TextLengthErrorTitleMap[e.operator]).replace(Q,a!=null?a:"").replace(G,i!=null?i:"")}`}}function Oe(s){var e,t;return s?s.p?!((t=(e=s.p.body)==null?void 0:e.dataStream)!=null?t:"").slice(0,-2).trim():r.Tools.isBlank(s.v):!0}function Y(s,o,e,t,a="command",i=!0){const n=t.get(T.LexerTreeBuilder),l=t.get(g.DataValidatorRegistryService),u=[],d=[],c=t.get(m.SheetDataValidationModel),h=t.get(r.IUniverInstanceService),p=D.getSheetCommandTarget(h,{unitId:s,subUnitId:o});if(!p)return{redoMutations:u,undoMutations:d};const{worksheet:_}=p,v=new r.ObjectMatrix;let R=!1;function V(S,M){i&&S.forEach(O=>{r.Range.foreach(O,(I,E)=>{const F=_.getCellRaw(I,E),B=Ve(F);(Oe(F)||B===M)&&!(F!=null&&F.p)&&(R=!0,v.setValue(I,E,{v:M,p:null}))})})}if(e.forEach(S=>{switch(S.type){case"delete":u.push({id:g.RemoveDataValidationMutation.id,params:{unitId:s,subUnitId:o,ruleId:S.rule.uid,source:a}}),d.unshift({id:g.AddDataValidationMutation.id,params:{unitId:s,subUnitId:o,rule:S.rule,index:S.index,source:a}});break;case"update":{if(P(S.rule.type,l)){const O=S.oldRanges[0].startRow,I=S.oldRanges[0].startColumn,E=S.newRanges[0].startRow,F=S.newRanges[0].startColumn,B=E-O,ne=F-I,se=r.isFormulaString(S.rule.formula1)?n.moveFormulaRefOffset(S.rule.formula1,ne,B):S.rule.formula1,oe=r.isFormulaString(S.rule.formula2)?n.moveFormulaRefOffset(S.rule.formula2,ne,B):S.rule.formula2;se!==S.rule.formula1||oe!==S.rule.formula2||!r.isRangesEqual(S.newRanges,S.oldRanges)?(u.push({id:g.UpdateDataValidationMutation.id,params:{unitId:s,subUnitId:o,ruleId:S.ruleId,payload:{type:g.UpdateRuleType.ALL,payload:{formula1:se,formula2:oe,ranges:S.newRanges}}}}),d.unshift({id:g.UpdateDataValidationMutation.id,params:{unitId:s,subUnitId:o,ruleId:S.ruleId,payload:{type:g.UpdateRuleType.ALL,payload:{formula1:S.rule.formula1,formula2:S.rule.formula2,ranges:S.oldRanges}}}})):(u.push({id:g.UpdateDataValidationMutation.id,params:{unitId:s,subUnitId:o,ruleId:S.ruleId,payload:{type:g.UpdateRuleType.RANGE,payload:S.newRanges},source:a}}),d.unshift({id:g.UpdateDataValidationMutation.id,params:{unitId:s,subUnitId:o,ruleId:S.ruleId,payload:{type:g.UpdateRuleType.RANGE,payload:S.oldRanges},source:a}}))}else u.push({id:g.UpdateDataValidationMutation.id,params:{unitId:s,subUnitId:o,ruleId:S.ruleId,payload:{type:g.UpdateRuleType.RANGE,payload:S.newRanges},source:a}}),d.unshift({id:g.UpdateDataValidationMutation.id,params:{unitId:s,subUnitId:o,ruleId:S.ruleId,payload:{type:g.UpdateRuleType.RANGE,payload:S.oldRanges},source:a}});const M=c.getRuleById(s,o,S.ruleId);if(M&&M.type===r.DataValidationType.CHECKBOX){const I=c.getValidator(r.DataValidationType.CHECKBOX).parseFormulaSync(M,s,o);V(S.newRanges,I.formula2)}break}case"add":{if(u.push({id:g.AddDataValidationMutation.id,params:{unitId:s,subUnitId:o,rule:S.rule,source:a}}),d.unshift({id:g.RemoveDataValidationMutation.id,params:{unitId:s,subUnitId:o,ruleId:S.rule.uid,source:a}}),S.rule.type===r.DataValidationType.CHECKBOX){const O=c.getValidator(r.DataValidationType.CHECKBOX).parseFormulaSync(S.rule,s,o);V(S.rule.ranges,O.originFormula2)}break}}}),R){const S={id:D.SetRangeValuesMutation.id,params:{unitId:s,subUnitId:o,cellValue:v.getData()}},M={id:D.SetRangeValuesMutation.id,params:D.SetRangeValuesUndoMutationFactory(t,S.params)};u.push(S),d.push(M)}return{redoMutations:u,undoMutations:d}}const Ie={type:r.CommandType.COMMAND,id:"sheet.command.updateDataValidationRuleRange",handler(s,o){if(!o)return!1;const{unitId:e,subUnitId:t,ranges:a,ruleId:i}=o,n=s.get(m.SheetDataValidationModel),l=s.get(r.ICommandService),u=s.get(r.IUndoRedoService);if(!n.getRuleById(e,t,i))return!1;const c=n.getRuleObjectMatrix(e,t).clone();c.updateRange(i,a);const h=c.diff(n.getRules(e,t)),{redoMutations:p,undoMutations:_}=Y(e,t,h,s);return u.pushUndoRedo({undoMutations:_,redoMutations:p,unitID:e}),r.sequenceExecute(p,l),!0}},Fe={type:r.CommandType.COMMAND,id:"sheet.command.addDataValidation",handler(s,o){if(!o)return!1;const{unitId:e,subUnitId:t,rule:a}=o,i=s.get(m.SheetDataValidationModel),n=s.get(r.ICommandService),l=s.get(r.IUndoRedoService),u=i.getRuleObjectMatrix(e,t).clone();u.addRule(a);const d=u.diff(i.getRules(e,t)),c=i.getValidator(a.type),h={unitId:e,subUnitId:t,rule:{...a,...c==null?void 0:c.normalizeFormula(a,e,t)}},{redoMutations:p,undoMutations:_}=Y(e,t,d,s);return p.push({id:g.AddDataValidationMutation.id,params:h}),_.unshift({id:g.RemoveDataValidationMutation.id,params:{unitId:e,subUnitId:t,ruleId:a.uid}}),l.pushUndoRedo({unitID:e,redoMutations:p,undoMutations:_}),r.sequenceExecute(p,n),!0}},Ee={type:r.CommandType.COMMAND,id:"sheets.command.update-data-validation-setting",handler(s,o){if(!o)return!1;const e=s.get(r.ICommandService),t=s.get(r.IUndoRedoService),a=s.get(m.SheetDataValidationModel),i=s.get(g.DataValidatorRegistryService),{unitId:n,subUnitId:l,ruleId:u,setting:d}=o,c=i.getValidatorItem(d.type);if(!c)return!1;const h=a.getRuleById(n,l,u);if(!h)return!1;const p={...h,...d};if(!c.validatorFormula(p,n,l).success)return!1;const _={unitId:n,subUnitId:l,ruleId:u,payload:{type:g.UpdateRuleType.SETTING,payload:{...d,...c.normalizeFormula(p,n,l)}}},v=[{id:g.UpdateDataValidationMutation.id,params:_}],R={unitId:n,subUnitId:l,ruleId:u,payload:{type:g.UpdateRuleType.SETTING,payload:g.getRuleSetting(h)}},V=[{id:g.UpdateDataValidationMutation.id,params:R}];if(d.type===r.DataValidationType.CHECKBOX){const M=h.ranges,O=s.get(r.IUniverInstanceService),I=D.getSheetCommandTarget(O,{unitId:n,subUnitId:l});if(I){const E=new r.ObjectMatrix,{worksheet:F}=I,{formula2:B=x,formula1:ne=W}=h,{formula2:se=x,formula1:oe=W}=d;let _e=!1;if(M.forEach(le=>{r.Range.foreach(le,(X,Se)=>{const C=F.getCellRaw(X,Se),Pe=Ve(C);(Oe(C)||Pe===String(B))&&!(C!=null&&C.p)?(E.setValue(X,Se,{v:se,p:null}),_e=!0):Pe===String(ne)&&!(C!=null&&C.p)&&(E.setValue(X,Se,{v:oe,p:null}),_e=!0)})}),_e){const le={id:D.SetRangeValuesMutation.id,params:{unitId:n,subUnitId:l,cellValue:E.getData()}},X={id:D.SetRangeValuesMutation.id,params:D.SetRangeValuesUndoMutationFactory(s,le.params)};v.push(le),V.push(X)}}}return r.sequenceExecute(v,e).result?(t.pushUndoRedo({unitID:n,redoMutations:v,undoMutations:V}),!0):!1}},Ce={type:r.CommandType.COMMAND,id:"sheets.command.update-data-validation-options",handler(s,o){if(!o)return!1;const e=s.get(r.ICommandService),t=s.get(r.IUndoRedoService),a=s.get(m.SheetDataValidationModel),{unitId:i,subUnitId:n,ruleId:l,options:u}=o,d=a.getRuleById(i,n,l);if(!d)return!1;const c={unitId:i,subUnitId:n,ruleId:l,payload:{type:g.UpdateRuleType.OPTIONS,payload:u}},h=[{id:g.UpdateDataValidationMutation.id,params:c}],p={unitId:i,subUnitId:n,ruleId:l,payload:{type:g.UpdateRuleType.OPTIONS,payload:g.getRuleOptions(d)}},_=[{id:g.UpdateDataValidationMutation.id,params:p}];return t.pushUndoRedo({unitID:i,redoMutations:h,undoMutations:_}),e.executeCommand(g.UpdateDataValidationMutation.id,c),!0}},Ne={type:r.CommandType.COMMAND,id:"sheets.command.clear-range-data-validation",handler(s,o){if(!o)return!1;const{unitId:e,subUnitId:t,ranges:a}=o,i=s.get(r.ICommandService),n=s.get(r.IUniverInstanceService),l=D.getSheetCommandTarget(n,{unitId:e,subUnitId:t}),u=s.get(m.SheetDataValidationModel);if(!l)return!1;const d=s.get(r.IUndoRedoService),c=u.getRuleObjectMatrix(e,t).clone();c.removeRange(a);const h=c.diff(u.getRules(e,t)),{redoMutations:p,undoMutations:_}=Y(e,t,h,s);return d.pushUndoRedo({unitID:e,redoMutations:p,undoMutations:_}),r.sequenceExecute(p,i).result}},Ae={type:r.CommandType.COMMAND,id:"sheet.command.remove-all-data-validation",handler(s,o){if(!o)return!1;const{unitId:e,subUnitId:t}=o,a=s.get(r.ICommandService),i=s.get(m.SheetDataValidationModel),n=s.get(r.IUndoRedoService),l=[...i.getRules(e,t)],u={unitId:e,subUnitId:t,ruleId:l.map(h=>h.uid)},d=[{id:g.RemoveDataValidationMutation.id,params:u}],c=[{id:g.AddDataValidationMutation.id,params:{unitId:e,subUnitId:t,rule:l}}];return n.pushUndoRedo({redoMutations:d,undoMutations:c,unitID:e}),a.executeCommand(g.RemoveDataValidationMutation.id,u),!0}},lt=(s,o)=>{const e=s.get(m.SheetDataValidationModel),{unitId:t,subUnitId:a,ruleId:i,source:n}=o;if(Array.isArray(i)){const u=i.map(d=>e.getRuleById(t,a,d)).filter(Boolean);return[{id:g.AddDataValidationMutation.id,params:{unitId:t,subUnitId:a,rule:u,source:n}}]}return[{id:g.AddDataValidationMutation.id,params:{unitId:t,subUnitId:a,rule:{...e.getRuleById(t,a,i)},index:e.getRuleIndex(t,a,i)}}]},we={type:r.CommandType.COMMAND,id:"sheet.command.remove-data-validation-rule",handler(s,o){if(!o)return!1;const{unitId:e,subUnitId:t,ruleId:a}=o,i=s.get(r.ICommandService),n=s.get(r.IUndoRedoService),l=s.get(m.SheetDataValidationModel),u=[{id:g.RemoveDataValidationMutation.id,params:o}],d=[{id:g.AddDataValidationMutation.id,params:{unitId:e,subUnitId:t,rule:{...l.getRuleById(e,t,a)},index:l.getRuleIndex(e,t,a)}}];return n.pushUndoRedo({undoMutations:d,redoMutations:u,unitID:o.unitId}),i.executeCommand(g.RemoveDataValidationMutation.id,o),!0}},ut="sheets-data-validation.config",Ue={};var dt=Object.defineProperty,ct=Object.getOwnPropertyDescriptor,mt=(s,o,e,t)=>{for(var a=t>1?void 0:t?ct(o,e):o,i=s.length-1,n;i>=0;i--)(n=s[i])&&(a=(t?n(o,e,a):n(a))||a);return t&&a&&dt(o,e,a),a},he=(s,o)=>(e,t)=>o(e,t,s);let ee=class extends r.Disposable{constructor(o,e,t){super();f(this,"_disposableMap",new Map);f(this,"registerRule",(o,e,t)=>{P(t.type,this._validatorRegistryService)&&this.register(o,e,t)});this._dataValidationModel=o,this._formulaRefRangeService=e,this._validatorRegistryService=t,this._initRefRange()}_getIdWithUnitId(o,e,t){return`${o}_${e}_${t}`}register(o,e,t){const a=t.ranges,i=t.formula1,n=t.formula2,l=this._formulaRefRangeService.registerRangeFormula(o,e,a,[i!=null?i:"",n!=null?n:""],d=>{if(d.length===0)return{undos:[{id:g.AddDataValidationMutation.id,params:{unitId:o,subUnitId:e,rule:t,source:"patched"}}],redos:[{id:g.RemoveDataValidationMutation.id,params:{unitId:o,subUnitId:e,ruleId:t.uid,source:"patched"}}]};const c=[],h=[],p=d[0];c.push({id:g.UpdateDataValidationMutation.id,params:{unitId:o,subUnitId:e,ruleId:t.uid,payload:{type:g.UpdateRuleType.ALL,payload:{ranges:p.ranges,formula1:p.formulas[0],formula2:p.formulas[1]}},source:"patched"}}),h.push({id:g.UpdateDataValidationMutation.id,params:{unitId:o,subUnitId:e,ruleId:t.uid,payload:{type:g.UpdateRuleType.ALL,payload:{ranges:a,formula1:i,formula2:n}},source:"patched"}});for(let _=1;_<d.length;_++){const v=d[_],R=r.generateRandomId();c.push({id:g.AddDataValidationMutation.id,params:{unitId:o,subUnitId:e,rule:{...t,uid:R,formula1:v.formulas[0],formula2:v.formulas[1],ranges:v.ranges},source:"patched"}}),h.push({id:g.RemoveDataValidationMutation.id,params:{unitId:o,subUnitId:e,ruleId:R,source:"patched"}})}return{undos:h,redos:c}}),u=this._getIdWithUnitId(o,e,t.uid);this._disposableMap.set(u,l)}_initRefRange(){const o=this._dataValidationModel.getAll();for(const[e,t]of o)for(const[a,i]of t)for(const n of i)this.registerRule(e,a,n);this.disposeWithMe(this._dataValidationModel.ruleChange$.subscribe(e=>{const{unitId:t,subUnitId:a,rule:i}=e;switch(e.type){case"add":{const n=e.rule;this.registerRule(e.unitId,e.subUnitId,n);break}case"remove":{const n=this._disposableMap.get(this._getIdWithUnitId(t,a,i.uid));n&&n.dispose();break}case"update":{const n=e.rule,l=this._disposableMap.get(this._getIdWithUnitId(t,a,n.uid));l&&l.dispose(),this.registerRule(e.unitId,e.subUnitId,n);break}}})),this.disposeWithMe(r.toDisposable(()=>{this._disposableMap.forEach(e=>{e.dispose()}),this._disposableMap.clear()}))}};ee=mt([he(0,r.Inject(m.SheetDataValidationModel)),he(1,r.Inject(K.FormulaRefRangeService)),he(2,r.Inject(g.DataValidatorRegistryService))],ee);var be=(s=>(s[s.View=0]="View",s[s.Edit=1]="Edit",s[s.ManageCollaborator=2]="ManageCollaborator",s[s.Print=3]="Print",s[s.Duplicate=4]="Duplicate",s[s.Comment=5]="Comment",s[s.Copy=6]="Copy",s[s.Share=7]="Share",s[s.Export=8]="Export",s[s.MoveWorksheet=9]="MoveWorksheet",s[s.DeleteWorksheet=10]="DeleteWorksheet",s[s.HideWorksheet=11]="HideWorksheet",s[s.RenameWorksheet=12]="RenameWorksheet",s[s.CreateWorksheet=13]="CreateWorksheet",s[s.SetWorksheetStyle=14]="SetWorksheetStyle",s[s.EditWorksheetCell=15]="EditWorksheetCell",s[s.InsertHyperlink=16]="InsertHyperlink",s[s.Sort=17]="Sort",s[s.Filter=18]="Filter",s[s.PivotTable=19]="PivotTable",s[s.FloatImg=20]="FloatImg",s[s.History=21]="History",s[s.RwHgtClWdt=22]="RwHgtClWdt",s[s.ViemRwHgtClWdt=23]="ViemRwHgtClWdt",s[s.ViewFilter=24]="ViewFilter",s[s.MoveSheet=25]="MoveSheet",s[s.DeleteSheet=26]="DeleteSheet",s[s.HideSheet=27]="HideSheet",s[s.CopySheet=28]="CopySheet",s[s.RenameSheet=29]="RenameSheet",s[s.CreateSheet=30]="CreateSheet",s[s.SelectProtectedCells=31]="SelectProtectedCells",s[s.SelectUnProtectedCells=32]="SelectUnProtectedCells",s[s.SetCellStyle=33]="SetCellStyle",s[s.SetCellValue=34]="SetCellValue",s[s.SetRowStyle=35]="SetRowStyle",s[s.SetColumnStyle=36]="SetColumnStyle",s[s.InsertRow=37]="InsertRow",s[s.InsertColumn=38]="InsertColumn",s[s.DeleteRow=39]="DeleteRow",s[s.DeleteColumn=40]="DeleteColumn",s[s.EditExtraObject=41]="EditExtraObject",s[s.Delete=42]="Delete",s[s.RecoverHistory=43]="RecoverHistory",s[s.ViewHistory=44]="ViewHistory",s[s.CreatePermissionObject=45]="CreatePermissionObject",s[s.UNRECOGNIZED=-1]="UNRECOGNIZED",s))(be||{}),ht=Object.defineProperty,pt=Object.getOwnPropertyDescriptor,gt=(s,o,e,t)=>{for(var a=t>1?void 0:t?pt(o,e):o,i=s.length-1,n;i>=0;i--)(n=s[i])&&(a=(t?n(o,e,a):n(a))||a);return t&&a&&ht(o,e,a),a},pe=(s,o)=>(e,t)=>o(e,t,s);m.DataValidationFormulaController=class extends r.Disposable{constructor(o,e,t){super(),this._univerInstanceService=o,this._permissionService=e,this._lexerTreeBuilder=t}getFormulaRefCheck(o){var t,a;const e=this._lexerTreeBuilder.sequenceNodesBuilder(o);if(!e)return!0;for(let i=0;i<e.length;i++){const n=e[i];if(typeof n=="string")continue;const{token:l}=n,u=T.deserializeRangeWithSheetWithCache(l),d=this._univerInstanceService.getCurrentUnitForType(r.UniverInstanceType.UNIVER_SHEET);let c=d.getActiveSheet();const h=d.getUnitId();if(u.sheetName){if(c=d.getSheetBySheetName(u.sheetName),!c)return!1;const V=c==null?void 0:c.getSheetId();if(!this._permissionService.getPermissionPoint(new D.WorksheetViewPermission(h,V).id))return!1}if(!c)return!1;const{startRow:p,endRow:_,startColumn:v,endColumn:R}=u.range;for(let V=p;V<=_;V++)for(let S=v;S<=R;S++){const M=(a=(t=c.getCell(V,S))==null?void 0:t.selectionProtection)==null?void 0:a[0];if((M==null?void 0:M[be.View])===!1)return!1}}return!0}},m.DataValidationFormulaController=gt([pe(0,r.IUniverInstanceService),pe(1,r.IPermissionService),pe(2,r.Inject(T.LexerTreeBuilder))],m.DataValidationFormulaController);var ft=Object.defineProperty,_t=Object.getOwnPropertyDescriptor,St=(s,o,e,t)=>{for(var a=t>1?void 0:t?_t(o,e):o,i=s.length-1,n;i>=0;i--)(n=s[i])&&(a=(t?n(o,e,a):n(a))||a);return t&&a&&ft(o,e,a),a},b=(s,o)=>(e,t)=>o(e,t,s);let te=class extends r.Disposable{constructor(o,e,t,a,i,n){super();f(this,"_disposableMap",new Map);f(this,"registerRule",(o,e,t)=>{P(t.type,this._validatorRegistryService)||(this.register(o,e,t),this.registerFormula(o,e,t))});this._dataValidationModel=o,this._injector=e,this._refRangeService=t,this._dataValidationFormulaService=a,this._formulaRefRangeService=i,this._validatorRegistryService=n,this._initRefRange()}_getIdWithUnitId(o,e,t){return`${o}_${e}_${t}`}registerFormula(o,e,t){var d;const a=t.uid,i=this._getIdWithUnitId(o,e,a),n=(d=this._disposableMap.get(i))!=null?d:new Set,l=(c,h)=>{const p=this._dataValidationModel.getRuleById(o,e,a);if(!p)return{redos:[],undos:[]};const _=p[c];if(!_||_===h)return{redos:[],undos:[]};const v={unitId:o,subUnitId:e,ruleId:t.uid,payload:{type:g.UpdateRuleType.SETTING,payload:{type:p.type,formula1:p.formula1,formula2:p.formula2,[c]:h}},source:"patched"},R={unitId:o,subUnitId:e,ruleId:t.uid,payload:{type:g.UpdateRuleType.SETTING,payload:{type:p.type,formula1:p.formula1,formula2:p.formula2}},source:"patched"},V=[{id:g.UpdateDataValidationMutation.id,params:v}],S=[{id:g.UpdateDataValidationMutation.id,params:R}];return{redos:V,undos:S}},u=this._dataValidationFormulaService.getRuleFormulaInfo(o,e,a);if(u){const[c,h]=u;if(c){const p=this._formulaRefRangeService.registerFormula(o,e,c.text,_=>l("formula1",_));n.add(()=>p.dispose())}if(h){const p=this._formulaRefRangeService.registerFormula(o,e,h.text,_=>l("formula2",_));n.add(()=>p.dispose())}}}register(o,e,t){var u;const a=d=>{const c=[...t.ranges],p=c.map(v=>D.handleCommonDefaultRangeChangeWithEffectRefCommands(v,d)).filter(v=>!!v).flat();if(r.isRangesEqual(p,c))return{redos:[],undos:[]};if(p.length){const v={unitId:o,subUnitId:e,ruleId:t.uid,payload:{type:g.UpdateRuleType.RANGE,payload:p},source:"patched"},R=[{id:g.UpdateDataValidationMutation.id,params:v}],V=[{id:g.UpdateDataValidationMutation.id,params:{unitId:o,subUnitId:e,ruleId:t.uid,payload:{type:g.UpdateRuleType.RANGE,payload:c},source:"patched"}}];return{redos:R,undos:V}}else{const v={unitId:o,subUnitId:e,ruleId:t.uid},R=[{id:g.RemoveDataValidationMutation.id,params:v}],V=lt(this._injector,v);return{redos:R,undos:V}}},i=[];t.ranges.forEach(d=>{const c=this._refRangeService.registerRefRange(d,a,o,e);i.push(()=>c.dispose())});const n=this._getIdWithUnitId(o,e,t.uid),l=(u=this._disposableMap.get(n))!=null?u:new Set;l.add(()=>i.forEach(d=>d())),this._disposableMap.set(n,l)}_initRefRange(){const o=this._dataValidationModel.getAll();for(const[e,t]of o)for(const[a,i]of t)for(const n of i)this.registerRule(e,a,n);this.disposeWithMe(this._dataValidationModel.ruleChange$.subscribe(e=>{const{unitId:t,subUnitId:a,rule:i}=e;switch(e.type){case"add":{const n=e.rule;this.registerRule(e.unitId,e.subUnitId,n);break}case"remove":{const n=this._disposableMap.get(this._getIdWithUnitId(t,a,i.uid));n&&n.forEach(l=>l());break}case"update":{const n=e.rule,l=this._disposableMap.get(this._getIdWithUnitId(t,a,n.uid));l&&l.forEach(u=>u()),this.registerRule(e.unitId,e.subUnitId,n);break}}})),this.disposeWithMe(r.toDisposable(()=>{this._disposableMap.forEach(e=>{e.forEach(t=>t())}),this._disposableMap.clear()}))}};te=St([b(0,r.Inject(m.SheetDataValidationModel)),b(1,r.Inject(r.Injector)),b(2,r.Inject(D.RefRangeService)),b(3,r.Inject(m.DataValidationFormulaService)),b(4,r.Inject(K.FormulaRefRangeService)),b(5,r.Inject(g.DataValidatorRegistryService))],te);var vt=Object.defineProperty,Rt=Object.getOwnPropertyDescriptor,Vt=(s,o,e,t)=>{for(var a=t>1?void 0:t?Rt(o,e):o,i=s.length-1,n;i>=0;i--)(n=s[i])&&(a=(t?n(o,e,a):n(a))||a);return t&&a&&vt(o,e,a),a},ge=(s,o)=>(e,t)=>o(e,t,s);let ae=class extends r.Disposable{constructor(s,o,e){super(),this._sheetInterceptorService=s,this._univerInstanceService=o,this._sheetDataValidationModel=e,this._initSheetChange()}_initSheetChange(){this.disposeWithMe(this._sheetInterceptorService.interceptCommand({getMutations:s=>{var o;if(s.id===D.RemoveSheetCommand.id){const e=s.params,t=e.unitId||this._univerInstanceService.getCurrentUnitForType(r.UniverInstanceType.UNIVER_SHEET).getUnitId(),a=this._univerInstanceService.getUniverSheetInstance(t);if(!a)return{redos:[],undos:[]};const i=e.subUnitId||((o=a.getActiveSheet())==null?void 0:o.getSheetId());if(!i)return{redos:[],undos:[]};const n=this._sheetDataValidationModel.getRules(t,i);if(n.length===0)return{redos:[],undos:[]};const l=n.map(c=>c.uid),u={unitId:t,subUnitId:i,ruleId:l,source:"patched"},d={unitId:t,subUnitId:i,rule:[...n],source:"patched"};return{redos:[{id:g.RemoveDataValidationMutation.id,params:u}],undos:[{id:g.AddDataValidationMutation.id,params:d}]}}return{redos:[],undos:[]}}}))}};ae=Vt([ge(0,r.Inject(D.SheetInterceptorService)),ge(1,r.Inject(r.IUniverInstanceService)),ge(2,r.Inject(m.SheetDataValidationModel))],ae);class Dt extends g.BaseDataValidator{constructor(){super(...arguments);f(this,"id",r.DataValidationType.ANY);f(this,"title","dataValidation.any.title");f(this,"operators",[]);f(this,"scopes",["sheet"]);f(this,"offsetFormulaByRange",!1)}async parseFormula(e,t,a){return{formula1:e.formula1,formula2:e.formula2,isFormulaValid:!0}}validatorFormula(e,t,a){return{success:!0}}async isValidType(e,t,a){return!0}generateRuleErrorMessage(e){return this.localeService.t("dataValidation.any.error")}}class Mt extends g.BaseDataValidator{constructor(){super(...arguments);f(this,"id",r.DataValidationType.CUSTOM);f(this,"title","dataValidation.custom.title");f(this,"operators",[]);f(this,"scopes",["sheet"]);f(this,"_customFormulaService",this.injector.get(m.DataValidationCustomFormulaService));f(this,"_lexerTreeBuilder",this.injector.get(T.LexerTreeBuilder))}validatorFormula(e,t,a){var d;const i=r.isFormulaString(e.formula1),n=(d=e.formula1)!=null?d:"",u=this._lexerTreeBuilder.checkIfAddBracket(n)===0&&n.startsWith(T.operatorToken.EQUALS);return{success:i&&u,formula1:i&&u?"":this.localeService.t("dataValidation.validFail.formula")}}async parseFormula(e,t,a){return{formula1:void 0,formula2:void 0,isFormulaValid:!0}}async isValidType(e,t,a){const{column:i,row:n,unitId:l,subUnitId:u}=e,d=await this._customFormulaService.getCellFormulaValue(l,u,a.uid,n,i),c=d==null?void 0:d.v;return y(String(c))&&r.Tools.isDefine(c)&&c!==""?d.t===r.CellValueType.BOOLEAN?!!c:typeof c=="boolean"?c:typeof c=="number"?!!c:typeof c=="string"?y(c):!!c:!1}generateRuleErrorMessage(e){return this.localeService.t("dataValidation.custom.error")}generateRuleName(e){var t;return this.localeService.t("dataValidation.custom.ruleName").replace("{FORMULA1}",(t=e.formula1)!=null?t:"")}}class Le extends me{constructor(){super(...arguments);f(this,"id",r.DataValidationType.LIST_MULTIPLE);f(this,"title","dataValidation.listMultiple.title");f(this,"offsetFormulaByRange",!1);f(this,"skipDefaultFontRender",()=>!0)}}class yt extends g.BaseDataValidator{constructor(){super(...arguments);f(this,"_customFormulaService",this.injector.get(m.DataValidationCustomFormulaService));f(this,"_lexerTreeBuilder",this.injector.get(T.LexerTreeBuilder));f(this,"id",r.DataValidationType.WHOLE);f(this,"title","dataValidation.whole.title");f(this,"operators",[r.DataValidationOperator.BETWEEN,r.DataValidationOperator.EQUAL,r.DataValidationOperator.GREATER_THAN,r.DataValidationOperator.GREATER_THAN_OR_EQUAL,r.DataValidationOperator.LESS_THAN,r.DataValidationOperator.LESS_THAN_OR_EQUAL,r.DataValidationOperator.NOT_BETWEEN,r.DataValidationOperator.NOT_EQUAL]);f(this,"scopes",["sheet"])}_isFormulaOrInt(e){return!r.Tools.isBlank(e)&&(r.isFormulaString(e)||!Number.isNaN(+e)&&Number.isInteger(+e))}async isValidType(e,t,a){const{value:i}=e,n=J(i);return!Number.isNaN(n)&&Number.isInteger(n)}transform(e,t,a){const{value:i}=e;return{...e,value:J(i)}}_parseNumber(e){return e==null?Number.NaN:+e}async parseFormula(e,t,a,i,n){const l=await this._customFormulaService.getCellFormulaValue(t,a,e.uid,i,n),u=await this._customFormulaService.getCellFormula2Value(t,a,e.uid,i,n),{formula1:d,formula2:c}=e,h=r.isFormulaString(d)?l==null?void 0:l.v:d,p=r.isFormulaString(c)?u==null?void 0:u.v:c,_=y(`${h}`)&&y(`${p}`);return{formula1:this._parseNumber(h),formula2:this._parseNumber(p),isFormulaValid:_}}validatorFormula(e,t,a){const i=e.operator;if(!i)return{success:!1};const n=r.Tools.isDefine(e.formula1)&&this._isFormulaOrInt(e.formula1),l=r.Tools.isDefine(e.formula2)&&this._isFormulaOrInt(e.formula2),u=z.includes(i),d=this.localeService.t("dataValidation.validFail.number");return u?{success:n&&l,formula1:n?void 0:d,formula2:l?void 0:d}:{success:n,formula1:d}}generateRuleErrorMessage(e,t){if(!e.operator)return this.titleStr;const{transformedFormula1:a,transformedFormula2:i}=Z(this._lexerTreeBuilder,e,t);return`${this.localeService.t(Te[e.operator]).replace(Q,a!=null?a:"").replace(G,i!=null?i:"")}`}}var Tt=Object.defineProperty,Ot=Object.getOwnPropertyDescriptor,It=(s,o,e,t)=>{for(var a=t>1?void 0:t?Ot(o,e):o,i=s.length-1,n;i>=0;i--)(n=s[i])&&(a=(t?n(o,e,a):n(a))||a);return t&&a&&Tt(o,e,a),a},L=(s,o)=>(e,t)=>o(e,t,s);let ie=class extends r.RxDisposable{constructor(s,o,e,t,a,i){super(),this._univerInstanceService=s,this._dataValidatorRegistryService=o,this._injector=e,this._selectionManagerService=t,this._sheetInterceptorService=a,this._sheetDataValidationModel=i,this._init()}_init(){this._registerValidators(),this._initCommandInterceptor()}_registerValidators(){[Dt,it,yt,ot,ye,Me,me,Le,Mt].forEach(s=>{const o=this._injector.createInstance(s);this.disposeWithMe(this._dataValidatorRegistryService.register(o)),this.disposeWithMe(r.toDisposable(()=>this._injector.delete(s)))})}_initCommandInterceptor(){this._sheetInterceptorService.interceptCommand({getMutations:s=>{var o;if(s.id===D.ClearSelectionAllCommand.id){const e=this._univerInstanceService.getCurrentUnitForType(r.UniverInstanceType.UNIVER_SHEET),t=e.getUnitId(),a=e.getActiveSheet();if(!a)throw new Error("No active sheet found");const i=a.getSheetId(),n=(o=this._selectionManagerService.getCurrentSelections())==null?void 0:o.map(h=>h.range),l=this._sheetDataValidationModel.getRuleObjectMatrix(t,i).clone();n&&l.removeRange(n);const u=l.diff(this._sheetDataValidationModel.getRules(t,i)),{redoMutations:d,undoMutations:c}=Y(t,i,u,this._injector,"patched");return{undos:c,redos:d}}return{undos:[],redos:[]}}})}};ie=It([L(0,r.IUniverInstanceService),L(1,r.Inject(g.DataValidatorRegistryService)),L(2,r.Inject(r.Injector)),L(3,r.Inject(D.SheetsSelectionsService)),L(4,r.Inject(D.SheetInterceptorService)),L(5,r.Inject(m.SheetDataValidationModel))],ie);var Ft=Object.defineProperty,Et=Object.getOwnPropertyDescriptor,Ct=(s,o,e,t)=>{for(var a=t>1?void 0:t?Et(o,e):o,i=s.length-1,n;i>=0;i--)(n=s[i])&&(a=(t?n(o,e,a):n(a))||a);return t&&a&&Ft(o,e,a),a},re=(s,o)=>(e,t)=>o(e,t,s);m.SheetsDataValidationValidatorService=class extends r.Disposable{constructor(o,e,t,a){super(),this._univerInstanceService=o,this._sheetDataValidationModel=e,this._dataValidationCacheService=t,this._lifecycleService=a,this._initRecalculate()}_initRecalculate(){const o=e=>{if(e.length===0)return;const t=this._univerInstanceService.getCurrentUnitForType(r.UniverInstanceType.UNIVER_SHEET),a=t==null?void 0:t.getActiveSheet(),i={};e.flat().forEach(n=>{i[n.unitId]||(i[n.unitId]={}),i[n.unitId][n.subUnitId]||(i[n.unitId][n.subUnitId]=[]);const l=this._univerInstanceService.getUnit(n.unitId,r.UniverInstanceType.UNIVER_SHEET),u=l==null?void 0:l.getSheetBySheetId(n.subUnitId);u&&i[n.unitId][n.subUnitId].push(...n.ranges.map(d=>r.Range.transformRange(d,u)))}),Object.entries(i).forEach(([n,l])=>{Object.entries(l).forEach(([u,d])=>{(t==null?void 0:t.getUnitId())===n&&(a==null?void 0:a.getSheetId())===u?this.validatorRanges(n,u,d):requestIdleCallback(()=>{this.validatorRanges(n,u,d)})})})};this.disposeWithMe(this._dataValidationCacheService.dirtyRanges$.pipe(A.bufferWhen(()=>this._lifecycleService.lifecycle$.pipe(A.filter(e=>e===r.LifecycleStages.Rendered)))).subscribe(o)),this.disposeWithMe(this._dataValidationCacheService.dirtyRanges$.pipe(A.filter(()=>this._lifecycleService.stage>=r.LifecycleStages.Rendered),r.bufferDebounceTime(20)).subscribe(o))}async _validatorByCell(o,e,t,a){const i=o.getUnitId(),n=e.getSheetId();if(!r.Tools.isDefine(t)||!r.Tools.isDefine(a))throw new Error(`row or col is not defined, row: ${t}, col: ${a}`);const l=this._sheetDataValidationModel.getRuleByLocation(i,n,t,a);return l?new Promise(u=>{this._sheetDataValidationModel.validator(l,{unitId:i,subUnitId:n,row:t,col:a,worksheet:e,workbook:o},d=>{u(d)})}):r.DataValidationStatus.VALID}async validatorCell(o,e,t,a){const i=this._univerInstanceService.getUnit(o,r.UniverInstanceType.UNIVER_SHEET);if(!i)throw new Error(`cannot find current workbook, unitId: ${o}`);const n=i.getSheetBySheetId(e);if(!n)throw new Error(`cannot find current worksheet, sheetId: ${e}`);return this._validatorByCell(i,n,t,a)}validatorRanges(o,e,t){if(!t.length)return Promise.resolve([]);const a=this._univerInstanceService.getUnit(o,r.UniverInstanceType.UNIVER_SHEET);if(!a)throw new Error(`cannot find current workbook, unitId: ${o}`);const i=a.getSheetBySheetId(e);if(!i)throw new Error(`cannot find current worksheet, sheetId: ${e}`);return Promise.all(t.map(n=>{const l=[];return r.Range.foreach(n,(u,d)=>{l.push(this._validatorByCell(a,i,u,d))}),Promise.all(l)}))}async validatorWorksheet(o,e){const t=this._univerInstanceService.getUnit(o,r.UniverInstanceType.UNIVER_SHEET);if(!t)throw new Error(`cannot find current workbook, unitId: ${o}`);const a=t.getSheetBySheetId(e);if(!a)throw new Error(`cannot find current worksheet, sheetId: ${e}`);const i=this._sheetDataValidationModel.getRules(o,e);return await Promise.all(i.map(n=>Promise.all(n.ranges.map(l=>{const u=[];return r.Range.foreach(l,(d,c)=>{u.push(this._validatorByCell(t,a,d,c))}),u})))),this._dataValidationCacheService.ensureCache(o,e)}async validatorWorkbook(o){const e=this._sheetDataValidationModel.getSubUnitIds(o),t=await Promise.all(e.map(i=>this.validatorWorksheet(o,i))),a={};return t.forEach((i,n)=>{a[e[n]]=i}),a}getDataValidations(o,e,t){const a=this._sheetDataValidationModel.getRuleObjectMatrix(o,e),i=new Set;return t.forEach(l=>{r.Range.foreach(l,(u,d)=>{const c=a.getValue(u,d);c&&i.add(c)})}),Array.from(i).map(l=>this._sheetDataValidationModel.getRuleById(o,e,l)).filter(Boolean)}getDataValidation(o,e,t){return this.getDataValidations(o,e,t)[0]}},m.SheetsDataValidationValidatorService=Ct([re(0,r.IUniverInstanceService),re(1,r.Inject(m.SheetDataValidationModel)),re(2,r.Inject(m.DataValidationCacheService)),re(3,r.Inject(r.LifecycleService))],m.SheetsDataValidationValidatorService);var Be=Object.defineProperty,Nt=Object.getOwnPropertyDescriptor,At=(s,o,e)=>o in s?Be(s,o,{enumerable:!0,configurable:!0,writable:!0,value:e}):s[o]=e,wt=(s,o,e,t)=>{for(var a=t>1?void 0:t?Nt(o,e):o,i=s.length-1,n;i>=0;i--)(n=s[i])&&(a=(t?n(o,e,a):n(a))||a);return t&&a&&Be(o,e,a),a},fe=(s,o)=>(e,t)=>o(e,t,s),je=(s,o,e)=>At(s,typeof o!="symbol"?o+"":o,e);m.UniverSheetsDataValidationPlugin=class extends r.Plugin{constructor(o=Ue,e,t,a){super(),this._config=o,this._injector=e,this._commandService=t,this._configService=a;const{...i}=r.merge({},Ue,this._config);this._configService.setConfig(ut,i)}onStarting(){[[m.DataValidationCacheService],[m.DataValidationFormulaService],[m.DataValidationCustomFormulaService],[m.SheetsDataValidationValidatorService],[m.SheetDataValidationModel],[ie],[m.DataValidationFormulaController],[ae],[te],[ee]].forEach(o=>{this._injector.add(o)}),[Fe,Ie,Ee,Ce,we,Ae,Ne].forEach(o=>{this._commandService.registerCommand(o)}),this._injector.get(m.DataValidationCacheService),this._injector.get(m.SheetsDataValidationValidatorService),this._injector.get(ee),this._injector.get(te)}onReady(){this._injector.get(ae)}onRendered(){this._injector.get(ie),this._injector.get(m.DataValidationFormulaController)}},je(m.UniverSheetsDataValidationPlugin,"pluginName",ve),je(m.UniverSheetsDataValidationPlugin,"type",r.UniverInstanceType.UNIVER_SHEET),m.UniverSheetsDataValidationPlugin=wt([r.DependentOn(g.UniverDataValidationPlugin),fe(1,r.Inject(r.Injector)),fe(2,r.ICommandService),fe(3,r.IConfigService)],m.UniverSheetsDataValidationPlugin);function Ut(s){const e=s.get(D.SheetsSelectionsService).getCurrentSelections().map(i=>i.range);return{uid:r.Tools.generateRandomId(6),type:r.DataValidationType.DECIMAL,operator:r.DataValidationOperator.EQUAL,formula1:"100",ranges:e!=null?e:[{startColumn:0,endColumn:0,startRow:0,endRow:0}]}}m.AddSheetDataValidationCommand=Fe,m.CHECKBOX_FORMULA_1=W,m.CHECKBOX_FORMULA_2=x,m.CheckboxValidator=Me,m.ClearRangeDataValidationCommand=Ne,m.DATA_VALIDATION_PLUGIN_NAME=ve,m.DateValidator=ye,m.ListMultipleValidator=Le,m.ListValidator=me,m.RemoveSheetAllDataValidationCommand=Ae,m.RemoveSheetDataValidationCommand=we,m.UpdateSheetDataValidationOptionsCommand=Ce,m.UpdateSheetDataValidationRangeCommand=Ie,m.UpdateSheetDataValidationSettingCommand=Ee,m.createDefaultNewRule=Ut,m.deserializeListOptions=k,m.getCellValueOrigin=U,m.getDataValidationCellValue=at,m.getDataValidationDiffMutations=Y,m.getFormulaCellData=j,m.getFormulaResult=w,m.isLegalFormulaResult=y,m.serializeListOptions=tt,m.transformCheckboxValue=q,Object.defineProperty(m,Symbol.toStringTag,{value:"Module"})});
6
+ (function(m,r){typeof exports=="object"&&typeof module<"u"?r(exports,require("@univerjs/core"),require("@univerjs/data-validation"),require("@univerjs/sheets"),require("rxjs"),require("@univerjs/sheets-formula"),require("@univerjs/engine-formula")):typeof define=="function"&&define.amd?define(["exports","@univerjs/core","@univerjs/data-validation","@univerjs/sheets","rxjs","@univerjs/sheets-formula","@univerjs/engine-formula"],r):(m=typeof globalThis<"u"?globalThis:m||self,r(m.UniverSheetsDataValidation={},m.UniverCore,m.UniverDataValidation,m.UniverSheets,m.rxjs,m.UniverSheetsFormula,m.UniverEngineFormula))})(this,function(m,r,p,D,A,K,T){"use strict";var Tt=Object.defineProperty;var Ot=(m,r,p)=>r in m?Tt(m,r,{enumerable:!0,configurable:!0,writable:!0,value:p}):m[r]=p;var _=(m,r,p)=>Ot(m,typeof r!="symbol"?r+"":r,p);const ve="SHEET_DATA_VALIDATION_PLUGIN";var He=Object.getOwnPropertyDescriptor,Pe=(o,s,e,t)=>{for(var a=t>1?void 0:t?He(s,e):s,i=o.length-1,n;i>=0;i--)(n=o[i])&&(a=n(a)||a);return a},Re=(o,s)=>(e,t)=>s(e,t,o);m.DataValidationCacheService=class extends r.Disposable{constructor(e,t){super();_(this,"_cacheMatrix",new Map);_(this,"_dirtyRanges$",new A.Subject);_(this,"dirtyRanges$",this._dirtyRanges$.asObservable());this._commandService=e,this._univerInstanceService=t,this._initDirtyRanges(),this._initSheetRemove()}_initDirtyRanges(){this.disposeWithMe(this._commandService.onCommandExecuted(e=>{if(e.id===D.SetRangeValuesMutation.id){const{cellValue:t,unitId:a,subUnitId:i}=e.params;if(t){const n=new r.ObjectMatrix(t).getDataRange();if(n.endRow===-1)return;this.markRangeDirty(a,i,[n])}}}))}_initSheetRemove(){this.disposeWithMe(this._commandService.onCommandExecuted(e=>{var t;if(e.id===D.RemoveSheetMutation.id){const{unitId:a,subUnitId:i}=e.params;(t=this._cacheMatrix.get(a))==null||t.delete(i)}})),this.disposeWithMe(this._univerInstanceService.unitDisposed$.subscribe(e=>{e.type===r.UniverInstanceType.UNIVER_SHEET&&this._cacheMatrix.delete(e.getUnitId())}))}_ensureCache(e,t){let a=this._cacheMatrix.get(e);a||(a=new Map,this._cacheMatrix.set(e,a));let i=a.get(t);return i||(i=new r.ObjectMatrix,a.set(t,i)),i}ensureCache(e,t){return this._ensureCache(e,t)}addRule(e,t,a){this.markRangeDirty(e,t,a.ranges)}removeRule(e,t,a){this._deleteRange(e,t,a.ranges)}markRangeDirty(e,t,a){const i=this._ensureCache(e,t);a.forEach(n=>{r.Range.foreach(n,(l,u)=>{i.setValue(l,u,void 0)})}),this._dirtyRanges$.next({unitId:e,subUnitId:t,ranges:a})}_deleteRange(e,t,a){const i=this._ensureCache(e,t);a.forEach(n=>{r.Range.foreach(n,(l,u)=>{i.realDeleteValue(l,u)})}),this._dirtyRanges$.next({unitId:e,subUnitId:t,ranges:a})}getValue(e,t,a,i){return this._ensureCache(e,t).getValue(a,i)}},m.DataValidationCacheService=Pe([Re(0,r.Inject(r.ICommandService)),Re(1,r.Inject(r.IUniverInstanceService))],m.DataValidationCacheService);function w(o){var s,e;return(e=(s=o==null?void 0:o[0])==null?void 0:s[0])==null?void 0:e.v}function j(o){var s;return(s=o==null?void 0:o[0])==null?void 0:s[0]}function y(o){return!T.ERROR_TYPE_SET.has(o)}function H(o,s){var t;const e=s.getValidatorItem(o);return(t=e==null?void 0:e.offsetFormulaByRange)!=null?t:!1}var We=Object.getOwnPropertyDescriptor,$e=(o,s,e,t)=>{for(var a=t>1?void 0:t?We(s,e):s,i=o.length-1,n;i>=0;i--)(n=o[i])&&(a=n(a)||a);return a},P=(o,s)=>(e,t)=>s(e,t,o);m.DataValidationCustomFormulaService=class extends r.Disposable{constructor(e,t,a,i,n){super();_(this,"_ruleFormulaMap",new Map);_(this,"_ruleFormulaMap2",new Map);this._instanceSrv=e,this._registerOtherFormulaService=t,this._dataValidationModel=a,this._dataValidationCacheService=i,this._validatorRegistryService=n,this._initFormulaResultHandler()}_initFormulaResultHandler(){this.disposeWithMe(this._registerOtherFormulaService.formulaResult$.subscribe(e=>{for(const t in e){const a=e[t];if(this._instanceSrv.getUnitType(t)===r.UniverInstanceType.UNIVER_SHEET)for(const n in a){const l=a[n],{ruleFormulaMap:u}=this._ensureMaps(t,n);l.forEach(d=>{var g,S;const c=u.get((g=d.extra)==null?void 0:g.ruleId),h=this._dataValidationModel.getRuleById(t,n,(S=d.extra)==null?void 0:S.ruleId);h&&c&&this._dataValidationCacheService.markRangeDirty(t,n,h.ranges)})}}}))}_ensureMaps(e,t){let a=this._ruleFormulaMap.get(e),i=this._ruleFormulaMap2.get(e);a||(a=new Map,this._ruleFormulaMap.set(e,a)),i||(i=new Map,this._ruleFormulaMap2.set(e,i));let n=a.get(t);n||(n=new Map,a.set(t,n));let l=i.get(t);return l||(l=new Map,i.set(t,l)),{ruleFormulaMap:n,ruleFormulaMap2:l}}_registerFormula(e,t,a,i,n){return this._registerOtherFormulaService.registerFormulaWithRange(e,t,i,n,{ruleId:a})}deleteByRuleId(e,t,a){const{ruleFormulaMap:i,ruleFormulaMap2:n}=this._ensureMaps(e,t),l=this._dataValidationModel.getRuleById(e,t,a),u=i.get(a);if(!l||!u)return;const d=i.get(a);d&&(i.delete(a),this._registerOtherFormulaService.deleteFormula(e,t,[d.formulaId]));const c=n.get(a);c&&(n.delete(a),this._registerOtherFormulaService.deleteFormula(e,t,[c.formulaId]))}_addFormulaByRange(e,t,a,i,n,l){const{ruleFormulaMap:u,ruleFormulaMap2:d}=this._ensureMaps(e,t),c=l[0].startRow,h=l[0].startColumn;if(i&&r.isFormulaString(i)){const g=this._registerFormula(e,t,a,i,l);u.set(a,{formula:i,originCol:h,originRow:c,formulaId:g})}if(n&&r.isFormulaString(n)){const g=this._registerFormula(e,t,a,n,l);d.set(a,{formula:n,originCol:h,originRow:c,formulaId:g})}}addRule(e,t,a){if(H(a.type,this._validatorRegistryService)){const{ranges:i,formula1:n,formula2:l,uid:u}=a;this._addFormulaByRange(e,t,u,n,l,i)}}async getCellFormulaValue(e,t,a,i,n){var v,R;const{ruleFormulaMap:l}=this._ensureMaps(e,t),u=l.get(a);if(!u)return Promise.resolve(void 0);const d=await this._registerOtherFormulaService.getFormulaValue(e,t,u.formulaId),{originRow:c,originCol:h}=u,g=i-c,S=n-h;return j((R=(v=d==null?void 0:d.result)==null?void 0:v[g])==null?void 0:R[S])}async getCellFormula2Value(e,t,a,i,n){var v,R;const{ruleFormulaMap2:l}=this._ensureMaps(e,t),u=l.get(a);if(!u)return Promise.resolve(void 0);const d=await this._registerOtherFormulaService.getFormulaValue(e,t,u.formulaId),{originRow:c,originCol:h}=u,g=i-c,S=n-h;return j((R=(v=d==null?void 0:d.result)==null?void 0:v[g])==null?void 0:R[S])}getCellFormulaValueSync(e,t,a,i,n){var v,R;const{ruleFormulaMap:l}=this._ensureMaps(e,t),u=l.get(a);if(!u)return;const d=this._registerOtherFormulaService.getFormulaValueSync(e,t,u.formulaId),{originRow:c,originCol:h}=u,g=i-c,S=n-h;return j((R=(v=d==null?void 0:d.result)==null?void 0:v[g])==null?void 0:R[S])}getCellFormula2ValueSync(e,t,a,i,n){var v,R;const{ruleFormulaMap2:l}=this._ensureMaps(e,t),u=l.get(a);if(!u)return;const d=this._registerOtherFormulaService.getFormulaValueSync(e,t,u.formulaId),{originRow:c,originCol:h}=u,g=i-c,S=n-h;return j((R=(v=d==null?void 0:d.result)==null?void 0:v[g])==null?void 0:R[S])}getRuleFormulaInfo(e,t,a){const{ruleFormulaMap:i}=this._ensureMaps(e,t);return i.get(a)}},m.DataValidationCustomFormulaService=$e([P(0,r.IUniverInstanceService),P(1,r.Inject(K.RegisterOtherFormulaService)),P(2,r.Inject(p.DataValidationModel)),P(3,r.Inject(m.DataValidationCacheService)),P(4,r.Inject(p.DataValidatorRegistryService))],m.DataValidationCustomFormulaService);var ke=Object.getOwnPropertyDescriptor,xe=(o,s,e,t)=>{for(var a=t>1?void 0:t?ke(s,e):s,i=o.length-1,n;i>=0;i--)(n=o[i])&&(a=n(a)||a);return a},W=(o,s)=>(e,t)=>s(e,t,o);m.DataValidationFormulaService=class extends r.Disposable{constructor(e,t,a,i,n){super();_(this,"_formulaRuleMap",new Map);this._instanceService=e,this._registerOtherFormulaService=t,this._dataValidationCacheService=a,this._dataValidationModel=i,this._validatorRegistryService=n,this._initFormulaResultHandler()}_initFormulaResultHandler(){this.disposeWithMe(this._registerOtherFormulaService.formulaResult$.subscribe(e=>{for(const t in e){const a=e[t];if(this._instanceService.getUnitType(t)===r.UniverInstanceType.UNIVER_SHEET)for(const n in a){const l=a[n],u=this._ensureRuleFormulaMap(t,n);l.forEach(d=>{var c,h;if(u.get((c=d.extra)==null?void 0:c.ruleId)){const g=this._dataValidationModel.getRuleById(t,n,(h=d.extra)==null?void 0:h.ruleId);g&&this._dataValidationCacheService.markRangeDirty(t,n,g.ranges)}})}}}))}_ensureRuleFormulaMap(e,t){let a=this._formulaRuleMap.get(e);a||(a=new Map,this._formulaRuleMap.set(e,a));let i=a.get(t);return i||(i=new Map,a.set(t,i)),i}_registerSingleFormula(e,t,a,i){const n=[{startColumn:0,endColumn:0,startRow:0,endRow:0}];return this._registerOtherFormulaService.registerFormulaWithRange(e,t,a,n,{ruleId:i})}addRule(e,t,a){if(!H(a.type,this._validatorRegistryService)&&a.type!==r.DataValidationType.CHECKBOX){const{formula1:i,formula2:n,uid:l}=a,u=r.isFormulaString(i),d=r.isFormulaString(n);if(!u&&!d)return;const c=this._ensureRuleFormulaMap(e,t),h=[void 0,void 0];if(u){const g=this._registerSingleFormula(e,t,i,l);h[0]={id:g,text:i}}if(d){const g=this._registerSingleFormula(e,t,n,l);h[1]={id:g,text:n}}c.set(l,h)}}removeRule(e,t,a){const n=this._ensureRuleFormulaMap(e,t).get(a);if(!n)return;const[l,u]=n,d=[l==null?void 0:l.id,u==null?void 0:u.id].filter(Boolean);d.length&&this._registerOtherFormulaService.deleteFormula(e,t,d)}getRuleFormulaResult(e,t,a){const n=this._ensureRuleFormulaMap(e,t).get(a);if(!n)return Promise.resolve(null);const l=async u=>u&&this._registerOtherFormulaService.getFormulaValue(e,t,u.id);return Promise.all([l(n[0]),l(n[1])])}getRuleFormulaResultSync(e,t,a){const n=this._ensureRuleFormulaMap(e,t).get(a);if(n)return n.map(l=>{if(l)return this._registerOtherFormulaService.getFormulaValueSync(e,t,l.id)})}getRuleFormulaInfo(e,t,a){return this._ensureRuleFormulaMap(e,t).get(a)}},m.DataValidationFormulaService=xe([W(0,r.IUniverInstanceService),W(1,r.Inject(K.RegisterOtherFormulaService)),W(2,r.Inject(m.DataValidationCacheService)),W(3,r.Inject(p.DataValidationModel)),W(4,r.Inject(p.DataValidatorRegistryService))],m.DataValidationFormulaService);function U(o){return r.getOriginCellValue(o)}function Ve(o){var s;return String((s=U(o))!=null?s:"")}class ue{constructor(s,e,t,a,i=!1){_(this,"_map");_(this,"_tree",new r.RBush);_(this,"_dirty",!0);_(this,"_buildTree",()=>{if(!this._dirty||this._disableTree)return;this._tree.clear();const s=[];this._map.forEach((e,t)=>{e.forEach(a=>{s.push({minX:a.startRow,maxX:a.endRow,minY:a.startColumn,maxY:a.endColumn,ruleId:t})})}),this._tree.load(s),this._dirty=!1});_(this,"_debonceBuildTree",r.debounce(this._buildTree,0));this._unitId=e,this._subUnitId=t,this._univerInstanceService=a,this._disableTree=i,this._map=s,this._buildTree()}get _worksheet(){var s;return(s=this._univerInstanceService.getUnit(this._unitId,r.UniverInstanceType.UNIVER_SHEET))==null?void 0:s.getSheetBySheetId(this._subUnitId)}_addRule(s,e){if(!this._worksheet)return;const t=r.Rectangle.mergeRanges(e.map(a=>r.Range.transformRange(a,this._worksheet)));this._map.forEach((a,i)=>{const n=r.Rectangle.subtractMulti(a,t);n.length===0?this._map.delete(i):this._map.set(i,n)}),this._dirty=!0,this._map.set(s,t),this._debonceBuildTree()}addRule(s){this._addRule(s.uid,s.ranges)}removeRange(s){if(!this._worksheet)return;const e=s.map(t=>r.Range.transformRange(t,this._worksheet));this._map.forEach((t,a)=>{const i=r.Rectangle.subtractMulti(t,e);i.length===0?this._map.delete(a):this._map.set(a,i)}),this._dirty=!0,this._debonceBuildTree()}_removeRule(s){this._map.delete(s),this._dirty=!0,this._debonceBuildTree()}removeRule(s){this._removeRule(s.uid)}updateRange(s,e){this._removeRule(s),this._addRule(s,e)}addRangeRules(s){s.forEach(({id:e,ranges:t})=>{if(!t.length)return;let a=this._map.get(e);a?(this._map.set(e,r.Rectangle.mergeRanges([...a,...t])),a=this._map.get(e)):(a=t,this._map.set(e,a)),this._map.forEach((i,n)=>{if(n===e)return;const l=r.Rectangle.subtractMulti(i,t);l.length===0?this._map.delete(n):this._map.set(n,l)})}),this._dirty=!0,this._debonceBuildTree()}diff(s){const e=[];let t=0;return s.forEach((a,i)=>{var u;const n=(u=this._map.get(a.uid))!=null?u:[],l=a.ranges;n.length!==0&&(n.length!==l.length||n.some((d,c)=>!r.Rectangle.equals(d,l[c])))&&e.push({type:"update",ruleId:a.uid,oldRanges:l,newRanges:r.Rectangle.sort(n),rule:a}),n.length===0&&(e.push({type:"delete",rule:a,index:i-t}),t++)}),e}diffWithAddition(s,e){const t=[];let a=0;return s.forEach((i,n)=>{var d;const l=(d=this._map.get(i.uid))!=null?d:[],u=i.ranges;l.length!==0&&(l.length!==u.length||l.some((c,h)=>!r.Rectangle.equals(c,u[h])))&&t.push({type:"update",ruleId:i.uid,oldRanges:u,newRanges:r.Rectangle.sort(l),rule:i}),l.length===0&&(t.push({type:"delete",rule:i,index:n-a}),a++)}),Array.from(e).forEach(i=>{var l;const n=(l=this._map.get(i.uid))!=null?l:[];t.push({type:"add",rule:{...i,ranges:r.Rectangle.sort(n)}})}),t}clone(){return new ue(new Map(r.Tools.deepClone(Array.from(this._map.entries()))),this._unitId,this._subUnitId,this._univerInstanceService,!0)}getValue(s,e){this._dirty&&this._buildTree();const t=this._tree.search({minX:s,maxX:s,minY:e,maxY:e});return t.length>0?t[0].ruleId:void 0}}var qe=Object.getOwnPropertyDescriptor,Qe=(o,s,e,t)=>{for(var a=t>1?void 0:t?qe(s,e):s,i=o.length-1,n;i>=0;i--)(n=o[i])&&(a=n(a)||a);return a},N=(o,s)=>(e,t)=>s(e,t,o);m.SheetDataValidationModel=class extends r.Disposable{constructor(e,t,a,i,n,l,u){super();_(this,"_ruleMatrixMap",new Map);_(this,"_validStatusChange$",new A.Subject);_(this,"_ruleChange$",new A.Subject);_(this,"ruleChange$",this._ruleChange$.asObservable());_(this,"validStatusChange$",this._validStatusChange$.asObservable());this._dataValidationModel=e,this._univerInstanceService=t,this._dataValidatorRegistryService=a,this._dataValidationCacheService=i,this._dataValidationFormulaService=n,this._dataValidationCustomFormulaService=l,this._commandService=u,this._initRuleUpdateListener(),this.disposeWithMe(()=>{this._ruleChange$.complete(),this._validStatusChange$.complete()}),this._initUniverInstanceListener()}_initUniverInstanceListener(){this.disposeWithMe(this._univerInstanceService.unitDisposed$.subscribe(e=>{this._ruleMatrixMap.delete(e.getUnitId())})),this.disposeWithMe(this._commandService.onCommandExecuted(e=>{if(e.id===D.RemoveSheetMutation.id){const{unitId:t,subUnitId:a}=e.params,i=this._ruleMatrixMap.get(t);i&&i.delete(a)}}))}_initRuleUpdateListener(){const e=this._dataValidationModel.getAll();for(const[t,a]of e)for(const[i,n]of a)for(const l of n)this._addRule(t,i,l),this._ruleChange$.next({type:"add",unitId:t,subUnitId:i,rule:l,source:"patched"});this.disposeWithMe(this._dataValidationModel.ruleChange$.subscribe(t=>{switch(t.type){case"add":this._addRule(t.unitId,t.subUnitId,t.rule);break;case"update":this._updateRule(t.unitId,t.subUnitId,t.rule.uid,t.oldRule,t.updatePayload);break;case"remove":this._removeRule(t.unitId,t.subUnitId,t.rule);break}this._ruleChange$.next(t)}))}_ensureRuleMatrix(e,t){let a=this._ruleMatrixMap.get(e);a||(a=new Map,this._ruleMatrixMap.set(e,a));let i=a.get(t);return i||(i=new ue(new Map,e,t,this._univerInstanceService),a.set(t,i)),i}_addRuleSideEffect(e,t,a){this._ensureRuleMatrix(e,t).addRule(a),this._dataValidationCacheService.addRule(e,t,a),this._dataValidationFormulaService.addRule(e,t,a),this._dataValidationCustomFormulaService.addRule(e,t,a)}_addRule(e,t,a){(Array.isArray(a)?a:[a]).forEach(n=>{this._addRuleSideEffect(e,t,n)})}_updateRule(e,t,a,i,n){const l=this._ensureRuleMatrix(e,t),u={...i,...n.payload};n.type===p.UpdateRuleType.RANGE?l.updateRange(a,n.payload):n.type===p.UpdateRuleType.ALL&&l.updateRange(a,n.payload.ranges),this._dataValidationCacheService.removeRule(e,t,i),this._dataValidationCacheService.addRule(e,t,u),this._dataValidationFormulaService.removeRule(e,t,i.uid),this._dataValidationFormulaService.addRule(e,t,u),this._dataValidationCustomFormulaService.deleteByRuleId(e,t,a),this._dataValidationCustomFormulaService.addRule(e,t,u)}_removeRule(e,t,a){this._ensureRuleMatrix(e,t).removeRule(a),this._dataValidationCacheService.removeRule(e,t,a),this._dataValidationCustomFormulaService.deleteByRuleId(e,t,a.uid)}getValidator(e){return this._dataValidatorRegistryService.getValidatorItem(e)}getRuleIdByLocation(e,t,a,i){return this._ensureRuleMatrix(e,t).getValue(a,i)}getRuleByLocation(e,t,a,i){const n=this.getRuleIdByLocation(e,t,a,i);if(n)return this._dataValidationModel.getRuleById(e,t,n)}validator(e,t,a){const{col:i,row:n,unitId:l,subUnitId:u,worksheet:d}=t,c=(R,V)=>{a&&a(R,V),V&&this._validStatusChange$.next({unitId:l,subUnitId:u,ruleId:e.uid,status:R,row:n,col:i})},h=d.getCellValueOnly(n,i),g=this.getValidator(e.type),S=d.getCellRaw(n,i),v=U(S);if(g){const R=this._dataValidationCacheService.ensureCache(l,u),V=R.getValue(n,i);return V==null?(R.setValue(n,i,r.DataValidationStatus.VALIDATING),g.validator({value:v,unitId:l,subUnitId:u,row:n,column:i,worksheet:t.worksheet,workbook:t.workbook,interceptValue:U(h),t:S==null?void 0:S.t},e).then(f=>{const M=f?r.DataValidationStatus.VALID:r.DataValidationStatus.INVALID;M===r.DataValidationStatus.VALID?R.realDeleteValue(n,i):R.setValue(n,i,M);const O=R.getValue(n,i);c(M,V!==O)}),r.DataValidationStatus.VALIDATING):(c(V!=null?V:r.DataValidationStatus.VALID,!1),V!=null?V:r.DataValidationStatus.VALID)}else return c(r.DataValidationStatus.VALID,!1),r.DataValidationStatus.VALID}getRuleObjectMatrix(e,t){return this._ensureRuleMatrix(e,t)}getRuleById(e,t,a){return this._dataValidationModel.getRuleById(e,t,a)}getRuleIndex(e,t,a){return this._dataValidationModel.getRuleIndex(e,t,a)}getRules(e,t){return[...this._dataValidationModel.getRules(e,t)]}getUnitRules(e){return this._dataValidationModel.getUnitRules(e)}deleteUnitRules(e){return this._dataValidationModel.deleteUnitRules(e)}getSubUnitIds(e){return this._dataValidationModel.getSubUnitIds(e)}getAll(){return this._dataValidationModel.getAll()}},m.SheetDataValidationModel=Qe([N(0,r.Inject(p.DataValidationModel)),N(1,r.IUniverInstanceService),N(2,r.Inject(p.DataValidatorRegistryService)),N(3,r.Inject(m.DataValidationCacheService)),N(4,r.Inject(m.DataValidationFormulaService)),N(5,r.Inject(m.DataValidationCustomFormulaService)),N(6,r.ICommandService)],m.SheetDataValidationModel);const $=1,k=0;function De(o,s){return r.Tools.isBlank(o)?s.t("dataValidation.validFail.value"):r.isFormulaString(o)?s.t("dataValidation.validFail.primitive"):""}const x=o=>r.Tools.isDefine(o)&&String(o).toLowerCase()==="true"?"1":String(o).toLowerCase()==="false"?"0":o;class Me extends p.BaseDataValidator{constructor(){super(...arguments);_(this,"id",r.DataValidationType.CHECKBOX);_(this,"title","dataValidation.checkbox.title");_(this,"operators",[]);_(this,"scopes",["sheet"]);_(this,"offsetFormulaByRange",!1);_(this,"_formulaService",this.injector.get(m.DataValidationFormulaService));_(this,"skipDefaultFontRender",(e,t,a)=>{const{unitId:i,subUnitId:n}=a,{formula1:l,formula2:u}=this.parseFormulaSync(e,i,n),d=`${t!=null?t:""}`;return!d||d===`${l}`||d===`${u}`})}validatorFormula(e,t,a){const{formula1:i,formula2:n}=e,l=i===n;if(r.Tools.isBlank(i)&&r.Tools.isBlank(n))return{success:!0};if(l)return{success:!1,formula1:this.localeService.t("dataValidation.validFail.checkboxEqual"),formula2:this.localeService.t("dataValidation.validFail.checkboxEqual")};const u=De(i,this.localeService),d=De(n,this.localeService);return{success:!u&&!d,formula1:u,formula2:d}}async parseFormula(e,t,a){var h,g,S,v;const{formula1:i=$,formula2:n=k}=e,l=await this._formulaService.getRuleFormulaResult(t,a,e.uid),u=r.isFormulaString(i)?w((g=(h=l==null?void 0:l[0])==null?void 0:h.result)==null?void 0:g[0][0]):i,d=r.isFormulaString(n)?w((v=(S=l==null?void 0:l[1])==null?void 0:S.result)==null?void 0:v[0][0]):n,c=y(String(u))&&y(String(d));return{formula1:x(u),formula2:x(d),originFormula1:u,originFormula2:d,isFormulaValid:c}}getExtraStyle(e,t){return{tb:r.WrapStrategy.CLIP}}parseFormulaSync(e,t,a){var h,g,S,v;const{formula1:i=$,formula2:n=k}=e,l=this._formulaService.getRuleFormulaResultSync(t,a,e.uid),u=r.isFormulaString(i)?w((g=(h=l==null?void 0:l[0])==null?void 0:h.result)==null?void 0:g[0][0]):i,d=r.isFormulaString(n)?w((v=(S=l==null?void 0:l[1])==null?void 0:S.result)==null?void 0:v[0][0]):n,c=y(String(u))&&y(String(d));return{formula1:x(u),formula2:x(d),originFormula1:u,originFormula2:d,isFormulaValid:c}}async isValidType(e,t,a){const{value:i,unitId:n,subUnitId:l}=e,{formula1:u,formula2:d,originFormula1:c,originFormula2:h}=await this.parseFormula(a,n,l);return!r.Tools.isDefine(u)||!r.Tools.isDefine(d)?!0:r.Tools.isDefine(i)&&(String(i)===String(u)||String(i)===String(d)||String(i)===String(c!=null?c:"")||String(i)===String(h!=null?h:""))}generateRuleErrorMessage(e){return this.localeService.t("dataValidation.checkbox.error")}}const Ge={[r.DataValidationOperator.BETWEEN]:"dataValidation.date.operators.between",[r.DataValidationOperator.EQUAL]:"dataValidation.date.operators.equal",[r.DataValidationOperator.GREATER_THAN]:"dataValidation.date.operators.greaterThan",[r.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.date.operators.greaterThanOrEqual",[r.DataValidationOperator.LESS_THAN]:"dataValidation.date.operators.lessThan",[r.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.date.operators.lessThanOrEqual",[r.DataValidationOperator.NOT_BETWEEN]:"dataValidation.date.operators.notBetween",[r.DataValidationOperator.NOT_EQUAL]:"dataValidation.date.operators.notEqual"};r.DataValidationOperator.BETWEEN+"",r.DataValidationOperator.EQUAL+"",r.DataValidationOperator.GREATER_THAN+"",r.DataValidationOperator.GREATER_THAN_OR_EQUAL+"",r.DataValidationOperator.LESS_THAN+"",r.DataValidationOperator.LESS_THAN_OR_EQUAL+"",r.DataValidationOperator.NOT_BETWEEN+"",r.DataValidationOperator.NOT_EQUAL+"";const Ye={[r.DataValidationOperator.BETWEEN]:"dataValidation.date.ruleName.between",[r.DataValidationOperator.EQUAL]:"dataValidation.date.ruleName.equal",[r.DataValidationOperator.GREATER_THAN]:"dataValidation.date.ruleName.greaterThan",[r.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.date.ruleName.greaterThanOrEqual",[r.DataValidationOperator.LESS_THAN]:"dataValidation.date.ruleName.lessThan",[r.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.date.ruleName.lessThanOrEqual",[r.DataValidationOperator.NOT_BETWEEN]:"dataValidation.date.ruleName.notBetween",[r.DataValidationOperator.NOT_EQUAL]:"dataValidation.date.ruleName.notEqual"},Xe={[r.DataValidationOperator.BETWEEN]:"dataValidation.date.errorMsg.between",[r.DataValidationOperator.EQUAL]:"dataValidation.date.errorMsg.equal",[r.DataValidationOperator.GREATER_THAN]:"dataValidation.date.errorMsg.greaterThan",[r.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.date.errorMsg.greaterThanOrEqual",[r.DataValidationOperator.LESS_THAN]:"dataValidation.date.errorMsg.lessThan",[r.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.date.errorMsg.lessThanOrEqual",[r.DataValidationOperator.NOT_BETWEEN]:"dataValidation.date.errorMsg.notBetween",[r.DataValidationOperator.NOT_EQUAL]:"dataValidation.date.errorMsg.notEqual"},z=[r.DataValidationOperator.BETWEEN,r.DataValidationOperator.NOT_BETWEEN],q="{FORMULA1}",Q="{FORMULA2}";function Ke(o){return o.filter(Boolean).join(",")}function G(o){return o.split(",").filter(Boolean)}function ze(o){const s=U(o);return s==null?"":s.toString()}function Z(o,s,e){const{formula1:t,formula2:a}=s,i=s.ranges[0].startRow,n=s.ranges[0].startColumn,l=e.row-i,u=e.col-n,d=r.isFormulaString(t)?o.moveFormulaRefOffset(t,u,l,!0):t,c=r.isFormulaString(a)?o.moveFormulaRefOffset(a,u,l,!0):a;return{transformedFormula1:d,transformedFormula2:c}}const de=o=>{var e,t;if(o==null||typeof o=="boolean")return;if(typeof o=="number"||!Number.isNaN(+o))return+o;const s=(e=r.numfmt.parseDate(o))==null?void 0:e.v;return r.Tools.isDefine(s)?s:(t=r.numfmt.parseDate(r.dayjs(o).format("YYYY-MM-DD HH:mm:ss")))==null?void 0:t.v};class ye extends p.BaseDataValidator{constructor(){super(...arguments);_(this,"id",r.DataValidationType.DATE);_(this,"title","dataValidation.date.title");_(this,"operators",[r.DataValidationOperator.BETWEEN,r.DataValidationOperator.EQUAL,r.DataValidationOperator.GREATER_THAN,r.DataValidationOperator.GREATER_THAN_OR_EQUAL,r.DataValidationOperator.LESS_THAN,r.DataValidationOperator.LESS_THAN_OR_EQUAL,r.DataValidationOperator.NOT_BETWEEN,r.DataValidationOperator.NOT_EQUAL]);_(this,"scopes",["sheet"]);_(this,"_customFormulaService",this.injector.get(m.DataValidationCustomFormulaService));_(this,"_lexerTreeBuilder",this.injector.get(T.LexerTreeBuilder))}async parseFormula(e,t,a,i,n){const l=await this._customFormulaService.getCellFormulaValue(t,a,e.uid,i,n),u=await this._customFormulaService.getCellFormula2Value(t,a,e.uid,i,n),{formula1:d,formula2:c}=e,h=y(String(l==null?void 0:l.v))&&y(String(u==null?void 0:u.v));return{formula1:de(r.isFormulaString(d)?l==null?void 0:l.v:d),formula2:de(r.isFormulaString(c)?u==null?void 0:u.v:c),isFormulaValid:h}}async isValidType(e){const{interceptValue:t,value:a}=e;return typeof a=="number"&&typeof t=="string"?!0:typeof t=="string"?!!r.numfmt.parseDate(t):!1}_validatorSingleFormula(e){return!r.Tools.isBlank(e)&&(r.isFormulaString(e)||!Number.isNaN(+e)||!!(e&&r.numfmt.parseDate(e)))}validatorFormula(e,t,a){const i=e.operator;if(!i)return{success:!1};const n=this._validatorSingleFormula(e.formula1),l=this.localeService.t("dataValidation.validFail.date");if(z.includes(i)){const d=this._validatorSingleFormula(e.formula2);return{success:n&&d,formula1:n?void 0:l,formula2:d?void 0:l}}return{success:n,formula1:n?void 0:l}}normalizeFormula(e,t,a){const{formula1:i,formula2:n,bizInfo:l}=e,u=d=>{var h;if(!d)return d;let c;if(!Number.isNaN(+d))c=r.numfmt.dateFromSerial(+d);else{const g=(h=r.numfmt.parseDate(d))==null?void 0:h.v;if(g==null)return"";c=r.numfmt.dateFromSerial(g)}return r.dayjs(`${c[0]}/${c[1]}/${c[2]} ${c[3]}:${c[4]}:${c[5]}`).format(l!=null&&l.showTime?"YYYY-MM-DD HH:mm:ss":"YYYY-MM-DD")};return{formula1:r.isFormulaString(i)?i:u(`${i}`),formula2:r.isFormulaString(n)?n:u(`${n}`)}}transform(e,t,a){const{value:i}=e;return{...e,value:de(i)}}get operatorNames(){return this.operators.map(e=>this.localeService.t(Ge[e]))}generateRuleName(e){var a,i;if(!e.operator)return this.titleStr;const t=this.localeService.t(Ye[e.operator]).replace(q,(a=e.formula1)!=null?a:"").replace(Q,(i=e.formula2)!=null?i:"");return`${this.titleStr} ${t}`}generateRuleErrorMessage(e,t){if(!e.operator)return this.titleStr;const{transformedFormula1:a,transformedFormula2:i}=Z(this._lexerTreeBuilder,e,t);return`${this.localeService.t(Xe[e.operator]).replace(q,a!=null?a:"").replace(Q,i!=null?i:"")}`}}r.DataValidationOperator.BETWEEN+"",r.DataValidationOperator.EQUAL+"",r.DataValidationOperator.GREATER_THAN+"",r.DataValidationOperator.GREATER_THAN_OR_EQUAL+"",r.DataValidationOperator.LESS_THAN+"",r.DataValidationOperator.LESS_THAN_OR_EQUAL+"",r.DataValidationOperator.NOT_BETWEEN+"",r.DataValidationOperator.NOT_EQUAL+"",r.DataValidationOperator.BETWEEN+"",r.DataValidationOperator.EQUAL+"",r.DataValidationOperator.GREATER_THAN+"",r.DataValidationOperator.GREATER_THAN_OR_EQUAL+"",r.DataValidationOperator.LESS_THAN+"",r.DataValidationOperator.LESS_THAN_OR_EQUAL+"",r.DataValidationOperator.NOT_BETWEEN+"",r.DataValidationOperator.NOT_EQUAL+"";const Te={[r.DataValidationOperator.BETWEEN]:"dataValidation.errorMsg.between",[r.DataValidationOperator.EQUAL]:"dataValidation.errorMsg.equal",[r.DataValidationOperator.GREATER_THAN]:"dataValidation.errorMsg.greaterThan",[r.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.errorMsg.greaterThanOrEqual",[r.DataValidationOperator.LESS_THAN]:"dataValidation.errorMsg.lessThan",[r.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.errorMsg.lessThanOrEqual",[r.DataValidationOperator.NOT_BETWEEN]:"dataValidation.errorMsg.notBetween",[r.DataValidationOperator.NOT_EQUAL]:"dataValidation.errorMsg.notEqual"};function J(o){let s=o;return typeof o=="string"?((o.startsWith("¥")||o.startsWith("$"))&&(s=o.slice(1)),+s):+o}class Ze extends p.BaseDataValidator{constructor(){super(...arguments);_(this,"_customFormulaService",this.injector.get(m.DataValidationCustomFormulaService));_(this,"id",r.DataValidationType.DECIMAL);_(this,"_lexerTreeBuilder",this.injector.get(T.LexerTreeBuilder));_(this,"title","dataValidation.decimal.title");_(this,"operators",[r.DataValidationOperator.BETWEEN,r.DataValidationOperator.EQUAL,r.DataValidationOperator.GREATER_THAN,r.DataValidationOperator.GREATER_THAN_OR_EQUAL,r.DataValidationOperator.LESS_THAN,r.DataValidationOperator.LESS_THAN_OR_EQUAL,r.DataValidationOperator.NOT_BETWEEN,r.DataValidationOperator.NOT_EQUAL]);_(this,"scopes",["sheet"])}_isFormulaOrNumber(e){return!r.Tools.isBlank(e)&&(r.isFormulaString(e)||!Number.isNaN(+e))}async isValidType(e,t,a){const{value:i}=e;return!Number.isNaN(J(i))}transform(e,t,a){const{value:i}=e;return{...e,value:J(i)}}_parseNumber(e){return e==null?Number.NaN:+e}async parseFormula(e,t,a,i,n){const l=await this._customFormulaService.getCellFormulaValue(t,a,e.uid,i,n),u=await this._customFormulaService.getCellFormula2Value(t,a,e.uid,i,n),{formula1:d,formula2:c}=e,h=y(String(l==null?void 0:l.v))&&y(String(u==null?void 0:u.v));return{formula1:this._parseNumber(r.isFormulaString(d)?l==null?void 0:l.v:d),formula2:this._parseNumber(r.isFormulaString(c)?u==null?void 0:u.v:c),isFormulaValid:h}}validatorFormula(e,t,a){const i=e.operator;if(!i)return{success:!1};const n=r.Tools.isDefine(e.formula1)&&this._isFormulaOrNumber(e.formula1),l=r.Tools.isDefine(e.formula2)&&this._isFormulaOrNumber(e.formula2),u=z.includes(i),d=this.localeService.t("dataValidation.validFail.number");return u?{success:n&&l,formula1:n?void 0:d,formula2:l?void 0:d}:{success:n,formula1:n?"":d}}generateRuleErrorMessage(e,t){if(!e.operator)return this.titleStr;const{transformedFormula1:a,transformedFormula2:i}=Z(this._lexerTreeBuilder,e,t);return`${this.localeService.t(Te[e.operator]).replace(q,a!=null?a:"").replace(Q,i!=null?i:"")}`}}function ce(o){if(!o)return[];const s=new Set;return o.forEach(e=>{e.forEach(t=>{var i,n;const a=U(t);if(a!=null){if(typeof a!="string"&&typeof(t==null?void 0:t.s)=="object"&&((n=(i=t.s)==null?void 0:i.n)!=null&&n.pattern)){s.add(r.numfmt.format(t.s.n.pattern,a,{throws:!1}));return}y(a.toString())&&s.add(a.toString())}})}),[...s]}const Je=["if","indirect","choose","offset"];function et(o,s){if(!r.isFormulaString(o)||T.isReferenceString(o.slice(1)))return!0;const t=s.sequenceNodesBuilder(o);return t&&t.some(a=>typeof a=="object"&&a.nodeType===T.sequenceNodeType.FUNCTION&&Je.indexOf(a.token.toLowerCase())>-1)}function tt(o,s){const{formula1:e="",ranges:t}=o;if(T.isReferenceString(e.slice(1))){const i=T.deserializeRangeWithSheet(e.slice(1));if((!i.sheetName||i.sheetName===s)&&t.some(n=>r.Rectangle.intersects(n,i.range)))return!0}return!1}class me extends p.BaseDataValidator{constructor(){super(...arguments);_(this,"formulaService",this.injector.get(m.DataValidationFormulaService));_(this,"_lexer",this.injector.get(T.LexerTreeBuilder));_(this,"_univerInstanceService",this.injector.get(r.IUniverInstanceService));_(this,"offsetFormulaByRange",!1);_(this,"id",r.DataValidationType.LIST);_(this,"title","dataValidation.list.title");_(this,"operators",[]);_(this,"scopes",["sheet"]);_(this,"skipDefaultFontRender",e=>e.renderMode!==r.DataValidationRenderMode.TEXT)}validatorFormula(e,t,a){var d,c,h;const i=!r.Tools.isBlank(e.formula1),n=et((d=e.formula1)!=null?d:"",this._lexer),l=(h=(c=this._univerInstanceService.getUnit(t,r.UniverInstanceType.UNIVER_SHEET))==null?void 0:c.getSheetBySheetId(a))==null?void 0:h.getName(),u=tt(e,l!=null?l:"");return{success:!!(i&&n&&!u),formula1:i?n?u?this.localeService.t("dataValidation.validFail.listIntersects"):void 0:this.localeService.t("dataValidation.validFail.listInvalid"):this.localeService.t("dataValidation.validFail.list")}}getExtraStyle(e,t,{style:a}){var n;const i=(n=a.tb!==r.WrapStrategy.OVERFLOW?a.tb:r.WrapStrategy.CLIP)!=null?n:r.WrapStrategy.WRAP;if(e.type===r.DataValidationType.LIST&&(e.renderMode===r.DataValidationRenderMode.ARROW||e.renderMode===r.DataValidationRenderMode.TEXT)){const l=this.getListWithColorMap(e),u=`${t!=null?t:""}`,d=l[u];if(d)return{bg:{rgb:d},tb:i}}return{tb:i}}parseCellValue(e){const t=e.toString();return G(t)}async parseFormula(e,t,a){var u,d;const i=await this.formulaService.getRuleFormulaResult(t,a,e.uid),n=w((d=(u=i==null?void 0:i[0])==null?void 0:u.result)==null?void 0:d[0][0]);return{formula1:void 0,formula2:void 0,isFormulaValid:y(String(n))}}async isValidType(e,t,a){var g,S;const{value:i,unitId:n,subUnitId:l}=e,{formula1:u=""}=a,d=await this.formulaService.getRuleFormulaResult(n,l,a.uid),c=r.isFormulaString(u)?ce((S=(g=d==null?void 0:d[0])==null?void 0:g.result)==null?void 0:S[0][0]):G(u);return this.parseCellValue(i).every(v=>c.includes(v))}generateRuleName(){return this.localeService.t("dataValidation.list.name")}generateRuleErrorMessage(){return this.localeService.t("dataValidation.list.error")}getList(e,t,a){var g,S,v,R;const{formula1:i=""}=e,n=this.injector.get(r.IUniverInstanceService),l=(g=t?n.getUniverSheetInstance(t):void 0)!=null?g:n.getCurrentUnitForType(r.UniverInstanceType.UNIVER_SHEET);if(!l)return[];const u=(S=a?l.getSheetBySheetId(a):void 0)!=null?S:l.getActiveSheet();if(!u)return[];const d=l.getUnitId(),c=u.getSheetId(),h=this.formulaService.getRuleFormulaResultSync(d,c,e.uid);return r.isFormulaString(i)?ce((R=(v=h==null?void 0:h[0])==null?void 0:v.result)==null?void 0:R[0][0]):G(i)}async getListAsync(e,t,a){var g,S,v,R;const{formula1:i=""}=e,n=this.injector.get(r.IUniverInstanceService),l=(g=t?n.getUniverSheetInstance(t):void 0)!=null?g:n.getCurrentUnitForType(r.UniverInstanceType.UNIVER_SHEET);if(!l)return[];const u=(S=a?l.getSheetBySheetId(a):void 0)!=null?S:l.getActiveSheet();if(!u)return[];const d=l.getUnitId(),c=u.getSheetId(),h=await this.formulaService.getRuleFormulaResult(d,c,e.uid);return r.isFormulaString(i)?ce((R=(v=h==null?void 0:h[0])==null?void 0:v.result)==null?void 0:R[0][0]):G(i)}getListWithColor(e,t,a){const i=this.getList(e,t,a),n=(e.formula2||"").split(",");return i.map((l,u)=>({label:l,color:n[u]}))}getListWithColorMap(e,t,a){const i=this.getListWithColor(e,t,a),n={};return i.forEach(l=>{l.color&&(n[l.label]=l.color)}),n}}class at extends p.BaseDataValidator{constructor(){super(...arguments);_(this,"id",r.DataValidationType.TEXT_LENGTH);_(this,"title","dataValidation.textLength.title");_(this,"_lexerTreeBuilder",this.injector.get(T.LexerTreeBuilder));_(this,"operators",[r.DataValidationOperator.BETWEEN,r.DataValidationOperator.EQUAL,r.DataValidationOperator.GREATER_THAN,r.DataValidationOperator.GREATER_THAN_OR_EQUAL,r.DataValidationOperator.LESS_THAN,r.DataValidationOperator.LESS_THAN_OR_EQUAL,r.DataValidationOperator.NOT_BETWEEN,r.DataValidationOperator.NOT_EQUAL]);_(this,"scopes",["sheet"]);_(this,"_customFormulaService",this.injector.get(m.DataValidationCustomFormulaService))}_isFormulaOrInt(e){return!r.Tools.isBlank(e)&&(r.isFormulaString(e)||!Number.isNaN(+e)&&Number.isInteger(+e))}validatorFormula(e,t,a){const i=e.operator;if(!i)return{success:!1};const n=r.Tools.isDefine(e.formula1)&&this._isFormulaOrInt(e.formula1),l=r.Tools.isDefine(e.formula2)&&this._isFormulaOrInt(e.formula2),u=z.includes(i),d=this.localeService.t("dataValidation.validFail.number");return u?{success:n&&l,formula1:n?void 0:d,formula2:l?void 0:d}:{success:n,formula1:d}}_parseNumber(e){return e==null?Number.NaN:+e}async parseFormula(e,t,a,i,n){const l=await this._customFormulaService.getCellFormulaValue(t,a,e.uid,i,n),u=await this._customFormulaService.getCellFormula2Value(t,a,e.uid,i,n),{formula1:d,formula2:c}=e,h=y(String(l==null?void 0:l.v))&&y(String(u==null?void 0:u.v));return{formula1:this._parseNumber(r.isFormulaString(d)?l==null?void 0:l.v:d),formula2:this._parseNumber(r.isFormulaString(c)?u==null?void 0:u.v:c),isFormulaValid:h}}transform(e,t,a){return{...e,value:e.value.toString().length}}async isValidType(e,t,a){const{value:i}=e;return typeof i=="string"||typeof i=="number"}generateRuleErrorMessage(e,t){if(!e.operator)return this.titleStr;const{transformedFormula1:a,transformedFormula2:i}=Z(this._lexerTreeBuilder,e,t);return`${this.localeService.t(p.TextLengthErrorTitleMap[e.operator]).replace(q,a!=null?a:"").replace(Q,i!=null?i:"")}`}}function Oe(o){var e,t;return o?o.p?!((t=(e=o.p.body)==null?void 0:e.dataStream)!=null?t:"").slice(0,-2).trim():r.Tools.isBlank(o.v):!0}function Y(o,s,e,t,a="command",i=!0){const n=t.get(T.LexerTreeBuilder),l=t.get(p.DataValidatorRegistryService),u=[],d=[],c=t.get(m.SheetDataValidationModel),h=t.get(r.IUniverInstanceService),g=D.getSheetCommandTarget(h,{unitId:o,subUnitId:s});if(!g)return{redoMutations:u,undoMutations:d};const{worksheet:S}=g,v=new r.ObjectMatrix;let R=!1;function V(f,M){i&&f.forEach(O=>{r.Range.foreach(O,(I,E)=>{const F=S.getCellRaw(I,E),B=Ve(F);(Oe(F)||B===M)&&!(F!=null&&F.p)&&(R=!0,v.setValue(I,E,{v:M,p:null}))})})}if(e.forEach(f=>{switch(f.type){case"delete":u.push({id:p.RemoveDataValidationMutation.id,params:{unitId:o,subUnitId:s,ruleId:f.rule.uid,source:a}}),d.unshift({id:p.AddDataValidationMutation.id,params:{unitId:o,subUnitId:s,rule:f.rule,index:f.index,source:a}});break;case"update":{if(H(f.rule.type,l)){const O=f.oldRanges[0].startRow,I=f.oldRanges[0].startColumn,E=f.newRanges[0].startRow,F=f.newRanges[0].startColumn,B=E-O,ne=F-I,oe=r.isFormulaString(f.rule.formula1)?n.moveFormulaRefOffset(f.rule.formula1,ne,B):f.rule.formula1,se=r.isFormulaString(f.rule.formula2)?n.moveFormulaRefOffset(f.rule.formula2,ne,B):f.rule.formula2;oe!==f.rule.formula1||se!==f.rule.formula2||!r.isRangesEqual(f.newRanges,f.oldRanges)?(u.push({id:p.UpdateDataValidationMutation.id,params:{unitId:o,subUnitId:s,ruleId:f.ruleId,payload:{type:p.UpdateRuleType.ALL,payload:{formula1:oe,formula2:se,ranges:f.newRanges}}}}),d.unshift({id:p.UpdateDataValidationMutation.id,params:{unitId:o,subUnitId:s,ruleId:f.ruleId,payload:{type:p.UpdateRuleType.ALL,payload:{formula1:f.rule.formula1,formula2:f.rule.formula2,ranges:f.oldRanges}}}})):(u.push({id:p.UpdateDataValidationMutation.id,params:{unitId:o,subUnitId:s,ruleId:f.ruleId,payload:{type:p.UpdateRuleType.RANGE,payload:f.newRanges},source:a}}),d.unshift({id:p.UpdateDataValidationMutation.id,params:{unitId:o,subUnitId:s,ruleId:f.ruleId,payload:{type:p.UpdateRuleType.RANGE,payload:f.oldRanges},source:a}}))}else u.push({id:p.UpdateDataValidationMutation.id,params:{unitId:o,subUnitId:s,ruleId:f.ruleId,payload:{type:p.UpdateRuleType.RANGE,payload:f.newRanges},source:a}}),d.unshift({id:p.UpdateDataValidationMutation.id,params:{unitId:o,subUnitId:s,ruleId:f.ruleId,payload:{type:p.UpdateRuleType.RANGE,payload:f.oldRanges},source:a}});const M=c.getRuleById(o,s,f.ruleId);if(M&&M.type===r.DataValidationType.CHECKBOX){const I=c.getValidator(r.DataValidationType.CHECKBOX).parseFormulaSync(M,o,s);V(f.newRanges,I.formula2)}break}case"add":{if(u.push({id:p.AddDataValidationMutation.id,params:{unitId:o,subUnitId:s,rule:f.rule,source:a}}),d.unshift({id:p.RemoveDataValidationMutation.id,params:{unitId:o,subUnitId:s,ruleId:f.rule.uid,source:a}}),f.rule.type===r.DataValidationType.CHECKBOX){const O=c.getValidator(r.DataValidationType.CHECKBOX).parseFormulaSync(f.rule,o,s);V(f.rule.ranges,O.originFormula2)}break}}}),R){const f={id:D.SetRangeValuesMutation.id,params:{unitId:o,subUnitId:s,cellValue:v.getData()}},M={id:D.SetRangeValuesMutation.id,params:D.SetRangeValuesUndoMutationFactory(t,f.params)};u.push(f),d.push(M)}return{redoMutations:u,undoMutations:d}}const Ie={type:r.CommandType.COMMAND,id:"sheet.command.updateDataValidationRuleRange",handler(o,s){if(!s)return!1;const{unitId:e,subUnitId:t,ranges:a,ruleId:i}=s,n=o.get(m.SheetDataValidationModel),l=o.get(r.ICommandService),u=o.get(r.IUndoRedoService);if(!n.getRuleById(e,t,i))return!1;const c=n.getRuleObjectMatrix(e,t).clone();c.updateRange(i,a);const h=c.diff(n.getRules(e,t)),{redoMutations:g,undoMutations:S}=Y(e,t,h,o);return u.pushUndoRedo({undoMutations:S,redoMutations:g,unitID:e}),r.sequenceExecute(g,l),!0}},Fe={type:r.CommandType.COMMAND,id:"sheet.command.addDataValidation",handler(o,s){if(!s)return!1;const{unitId:e,subUnitId:t,rule:a}=s,i=o.get(m.SheetDataValidationModel),n=o.get(r.ICommandService),l=o.get(r.IUndoRedoService),u=i.getRuleObjectMatrix(e,t).clone();u.addRule(a);const d=u.diff(i.getRules(e,t)),c=i.getValidator(a.type),h={unitId:e,subUnitId:t,rule:{...a,...c==null?void 0:c.normalizeFormula(a,e,t)}},{redoMutations:g,undoMutations:S}=Y(e,t,d,o);return g.push({id:p.AddDataValidationMutation.id,params:h}),S.unshift({id:p.RemoveDataValidationMutation.id,params:{unitId:e,subUnitId:t,ruleId:a.uid}}),l.pushUndoRedo({unitID:e,redoMutations:g,undoMutations:S}),r.sequenceExecute(g,n),!0}},Ee={type:r.CommandType.COMMAND,id:"sheets.command.update-data-validation-setting",handler(o,s){if(!s)return!1;const e=o.get(r.ICommandService),t=o.get(r.IUndoRedoService),a=o.get(m.SheetDataValidationModel),i=o.get(p.DataValidatorRegistryService),{unitId:n,subUnitId:l,ruleId:u,setting:d}=s,c=i.getValidatorItem(d.type);if(!c)return!1;const h=a.getRuleById(n,l,u);if(!h)return!1;const g={...h,...d};if(!c.validatorFormula(g,n,l).success)return!1;const S={unitId:n,subUnitId:l,ruleId:u,payload:{type:p.UpdateRuleType.SETTING,payload:{...d,...c.normalizeFormula(g,n,l)}}},v=[{id:p.UpdateDataValidationMutation.id,params:S}],R={unitId:n,subUnitId:l,ruleId:u,payload:{type:p.UpdateRuleType.SETTING,payload:p.getRuleSetting(h)}},V=[{id:p.UpdateDataValidationMutation.id,params:R}];if(d.type===r.DataValidationType.CHECKBOX){const M=h.ranges,O=o.get(r.IUniverInstanceService),I=D.getSheetCommandTarget(O,{unitId:n,subUnitId:l});if(I){const E=new r.ObjectMatrix,{worksheet:F}=I,{formula2:B=k,formula1:ne=$}=h,{formula2:oe=k,formula1:se=$}=d;let Se=!1;if(M.forEach(le=>{r.Range.foreach(le,(X,fe)=>{const C=F.getCellRaw(X,fe),je=Ve(C);(Oe(C)||je===String(B))&&!(C!=null&&C.p)?(E.setValue(X,fe,{v:oe,p:null}),Se=!0):je===String(ne)&&!(C!=null&&C.p)&&(E.setValue(X,fe,{v:se,p:null}),Se=!0)})}),Se){const le={id:D.SetRangeValuesMutation.id,params:{unitId:n,subUnitId:l,cellValue:E.getData()}},X={id:D.SetRangeValuesMutation.id,params:D.SetRangeValuesUndoMutationFactory(o,le.params)};v.push(le),V.push(X)}}}return r.sequenceExecute(v,e).result?(t.pushUndoRedo({unitID:n,redoMutations:v,undoMutations:V}),!0):!1}},Ce={type:r.CommandType.COMMAND,id:"sheets.command.update-data-validation-options",handler(o,s){if(!s)return!1;const e=o.get(r.ICommandService),t=o.get(r.IUndoRedoService),a=o.get(m.SheetDataValidationModel),{unitId:i,subUnitId:n,ruleId:l,options:u}=s,d=a.getRuleById(i,n,l);if(!d)return!1;const c={unitId:i,subUnitId:n,ruleId:l,payload:{type:p.UpdateRuleType.OPTIONS,payload:u}},h=[{id:p.UpdateDataValidationMutation.id,params:c}],g={unitId:i,subUnitId:n,ruleId:l,payload:{type:p.UpdateRuleType.OPTIONS,payload:p.getRuleOptions(d)}},S=[{id:p.UpdateDataValidationMutation.id,params:g}];return t.pushUndoRedo({unitID:i,redoMutations:h,undoMutations:S}),e.executeCommand(p.UpdateDataValidationMutation.id,c),!0}},Ne={type:r.CommandType.COMMAND,id:"sheets.command.clear-range-data-validation",handler(o,s){if(!s)return!1;const{unitId:e,subUnitId:t,ranges:a}=s,i=o.get(r.ICommandService),n=o.get(r.IUniverInstanceService),l=D.getSheetCommandTarget(n,{unitId:e,subUnitId:t}),u=o.get(m.SheetDataValidationModel);if(!l)return!1;const d=o.get(r.IUndoRedoService),c=u.getRuleObjectMatrix(e,t).clone();c.removeRange(a);const h=c.diff(u.getRules(e,t)),{redoMutations:g,undoMutations:S}=Y(e,t,h,o);return d.pushUndoRedo({unitID:e,redoMutations:g,undoMutations:S}),r.sequenceExecute(g,i).result}},Ae={type:r.CommandType.COMMAND,id:"sheet.command.remove-all-data-validation",handler(o,s){if(!s)return!1;const{unitId:e,subUnitId:t}=s,a=o.get(r.ICommandService),i=o.get(m.SheetDataValidationModel),n=o.get(r.IUndoRedoService),l=[...i.getRules(e,t)],u={unitId:e,subUnitId:t,ruleId:l.map(h=>h.uid)},d=[{id:p.RemoveDataValidationMutation.id,params:u}],c=[{id:p.AddDataValidationMutation.id,params:{unitId:e,subUnitId:t,rule:l}}];return n.pushUndoRedo({redoMutations:d,undoMutations:c,unitID:e}),a.executeCommand(p.RemoveDataValidationMutation.id,u),!0}},it=(o,s)=>{const e=o.get(m.SheetDataValidationModel),{unitId:t,subUnitId:a,ruleId:i,source:n}=s;if(Array.isArray(i)){const u=i.map(d=>e.getRuleById(t,a,d)).filter(Boolean);return[{id:p.AddDataValidationMutation.id,params:{unitId:t,subUnitId:a,rule:u,source:n}}]}return[{id:p.AddDataValidationMutation.id,params:{unitId:t,subUnitId:a,rule:{...e.getRuleById(t,a,i)},index:e.getRuleIndex(t,a,i)}}]},we={type:r.CommandType.COMMAND,id:"sheet.command.remove-data-validation-rule",handler(o,s){if(!s)return!1;const{unitId:e,subUnitId:t,ruleId:a}=s,i=o.get(r.ICommandService),n=o.get(r.IUndoRedoService),l=o.get(m.SheetDataValidationModel),u=[{id:p.RemoveDataValidationMutation.id,params:s}],d=[{id:p.AddDataValidationMutation.id,params:{unitId:e,subUnitId:t,rule:{...l.getRuleById(e,t,a)},index:l.getRuleIndex(e,t,a)}}];return n.pushUndoRedo({undoMutations:d,redoMutations:u,unitID:s.unitId}),i.executeCommand(p.RemoveDataValidationMutation.id,s),!0}},rt="sheets-data-validation.config",Ue={};var nt=Object.getOwnPropertyDescriptor,ot=(o,s,e,t)=>{for(var a=t>1?void 0:t?nt(s,e):s,i=o.length-1,n;i>=0;i--)(n=o[i])&&(a=n(a)||a);return a},he=(o,s)=>(e,t)=>s(e,t,o);let ee=class extends r.Disposable{constructor(s,e,t){super();_(this,"_disposableMap",new Map);_(this,"registerRule",(s,e,t)=>{H(t.type,this._validatorRegistryService)&&this.register(s,e,t)});this._dataValidationModel=s,this._formulaRefRangeService=e,this._validatorRegistryService=t,this._initRefRange()}_getIdWithUnitId(s,e,t){return`${s}_${e}_${t}`}register(s,e,t){const a=t.ranges,i=t.formula1,n=t.formula2,l=this._formulaRefRangeService.registerRangeFormula(s,e,a,[i!=null?i:"",n!=null?n:""],d=>{if(d.length===0)return{undos:[{id:p.AddDataValidationMutation.id,params:{unitId:s,subUnitId:e,rule:t,source:"patched"}}],redos:[{id:p.RemoveDataValidationMutation.id,params:{unitId:s,subUnitId:e,ruleId:t.uid,source:"patched"}}]};const c=[],h=[],g=d[0];c.push({id:p.UpdateDataValidationMutation.id,params:{unitId:s,subUnitId:e,ruleId:t.uid,payload:{type:p.UpdateRuleType.ALL,payload:{ranges:g.ranges,formula1:g.formulas[0],formula2:g.formulas[1]}},source:"patched"}}),h.push({id:p.UpdateDataValidationMutation.id,params:{unitId:s,subUnitId:e,ruleId:t.uid,payload:{type:p.UpdateRuleType.ALL,payload:{ranges:a,formula1:i,formula2:n}},source:"patched"}});for(let S=1;S<d.length;S++){const v=d[S],R=r.generateRandomId();c.push({id:p.AddDataValidationMutation.id,params:{unitId:s,subUnitId:e,rule:{...t,uid:R,formula1:v.formulas[0],formula2:v.formulas[1],ranges:v.ranges},source:"patched"}}),h.push({id:p.RemoveDataValidationMutation.id,params:{unitId:s,subUnitId:e,ruleId:R,source:"patched"}})}return{undos:h,redos:c}}),u=this._getIdWithUnitId(s,e,t.uid);this._disposableMap.set(u,l)}_initRefRange(){const s=this._dataValidationModel.getAll();for(const[e,t]of s)for(const[a,i]of t)for(const n of i)this.registerRule(e,a,n);this.disposeWithMe(this._dataValidationModel.ruleChange$.subscribe(e=>{const{unitId:t,subUnitId:a,rule:i}=e;switch(e.type){case"add":{const n=e.rule;this.registerRule(e.unitId,e.subUnitId,n);break}case"remove":{const n=this._disposableMap.get(this._getIdWithUnitId(t,a,i.uid));n&&n.dispose();break}case"update":{const n=e.rule,l=this._disposableMap.get(this._getIdWithUnitId(t,a,n.uid));l&&l.dispose(),this.registerRule(e.unitId,e.subUnitId,n);break}}})),this.disposeWithMe(r.toDisposable(()=>{this._disposableMap.forEach(e=>{e.dispose()}),this._disposableMap.clear()}))}};ee=ot([he(0,r.Inject(m.SheetDataValidationModel)),he(1,r.Inject(K.FormulaRefRangeService)),he(2,r.Inject(p.DataValidatorRegistryService))],ee);var be=(o=>(o[o.View=0]="View",o[o.Edit=1]="Edit",o[o.ManageCollaborator=2]="ManageCollaborator",o[o.Print=3]="Print",o[o.Duplicate=4]="Duplicate",o[o.Comment=5]="Comment",o[o.Copy=6]="Copy",o[o.Share=7]="Share",o[o.Export=8]="Export",o[o.MoveWorksheet=9]="MoveWorksheet",o[o.DeleteWorksheet=10]="DeleteWorksheet",o[o.HideWorksheet=11]="HideWorksheet",o[o.RenameWorksheet=12]="RenameWorksheet",o[o.CreateWorksheet=13]="CreateWorksheet",o[o.SetWorksheetStyle=14]="SetWorksheetStyle",o[o.EditWorksheetCell=15]="EditWorksheetCell",o[o.InsertHyperlink=16]="InsertHyperlink",o[o.Sort=17]="Sort",o[o.Filter=18]="Filter",o[o.PivotTable=19]="PivotTable",o[o.FloatImg=20]="FloatImg",o[o.History=21]="History",o[o.RwHgtClWdt=22]="RwHgtClWdt",o[o.ViemRwHgtClWdt=23]="ViemRwHgtClWdt",o[o.ViewFilter=24]="ViewFilter",o[o.MoveSheet=25]="MoveSheet",o[o.DeleteSheet=26]="DeleteSheet",o[o.HideSheet=27]="HideSheet",o[o.CopySheet=28]="CopySheet",o[o.RenameSheet=29]="RenameSheet",o[o.CreateSheet=30]="CreateSheet",o[o.SelectProtectedCells=31]="SelectProtectedCells",o[o.SelectUnProtectedCells=32]="SelectUnProtectedCells",o[o.SetCellStyle=33]="SetCellStyle",o[o.SetCellValue=34]="SetCellValue",o[o.SetRowStyle=35]="SetRowStyle",o[o.SetColumnStyle=36]="SetColumnStyle",o[o.InsertRow=37]="InsertRow",o[o.InsertColumn=38]="InsertColumn",o[o.DeleteRow=39]="DeleteRow",o[o.DeleteColumn=40]="DeleteColumn",o[o.EditExtraObject=41]="EditExtraObject",o[o.Delete=42]="Delete",o[o.RecoverHistory=43]="RecoverHistory",o[o.ViewHistory=44]="ViewHistory",o[o.CreatePermissionObject=45]="CreatePermissionObject",o[o.UNRECOGNIZED=-1]="UNRECOGNIZED",o))(be||{}),st=Object.getOwnPropertyDescriptor,lt=(o,s,e,t)=>{for(var a=t>1?void 0:t?st(s,e):s,i=o.length-1,n;i>=0;i--)(n=o[i])&&(a=n(a)||a);return a},ge=(o,s)=>(e,t)=>s(e,t,o);m.DataValidationFormulaController=class extends r.Disposable{constructor(s,e,t){super(),this._univerInstanceService=s,this._permissionService=e,this._lexerTreeBuilder=t}getFormulaRefCheck(s){var t,a;const e=this._lexerTreeBuilder.sequenceNodesBuilder(s);if(!e)return!0;for(let i=0;i<e.length;i++){const n=e[i];if(typeof n=="string")continue;const{token:l}=n,u=T.deserializeRangeWithSheetWithCache(l),d=this._univerInstanceService.getCurrentUnitForType(r.UniverInstanceType.UNIVER_SHEET);let c=d.getActiveSheet();const h=d.getUnitId();if(u.sheetName){if(c=d.getSheetBySheetName(u.sheetName),!c)return!1;const V=c==null?void 0:c.getSheetId();if(!this._permissionService.getPermissionPoint(new D.WorksheetViewPermission(h,V).id))return!1}if(!c)return!1;const{startRow:g,endRow:S,startColumn:v,endColumn:R}=u.range;for(let V=g;V<=S;V++)for(let f=v;f<=R;f++){const M=(a=(t=c.getCell(V,f))==null?void 0:t.selectionProtection)==null?void 0:a[0];if((M==null?void 0:M[be.View])===!1)return!1}}return!0}},m.DataValidationFormulaController=lt([ge(0,r.IUniverInstanceService),ge(1,r.IPermissionService),ge(2,r.Inject(T.LexerTreeBuilder))],m.DataValidationFormulaController);var ut=Object.getOwnPropertyDescriptor,dt=(o,s,e,t)=>{for(var a=t>1?void 0:t?ut(s,e):s,i=o.length-1,n;i>=0;i--)(n=o[i])&&(a=n(a)||a);return a},b=(o,s)=>(e,t)=>s(e,t,o);let te=class extends r.Disposable{constructor(s,e,t,a,i,n){super();_(this,"_disposableMap",new Map);_(this,"registerRule",(s,e,t)=>{H(t.type,this._validatorRegistryService)||(this.register(s,e,t),this.registerFormula(s,e,t))});this._dataValidationModel=s,this._injector=e,this._refRangeService=t,this._dataValidationFormulaService=a,this._formulaRefRangeService=i,this._validatorRegistryService=n,this._initRefRange()}_getIdWithUnitId(s,e,t){return`${s}_${e}_${t}`}registerFormula(s,e,t){var d;const a=t.uid,i=this._getIdWithUnitId(s,e,a),n=(d=this._disposableMap.get(i))!=null?d:new Set,l=(c,h)=>{const g=this._dataValidationModel.getRuleById(s,e,a);if(!g)return{redos:[],undos:[]};const S=g[c];if(!S||S===h)return{redos:[],undos:[]};const v={unitId:s,subUnitId:e,ruleId:t.uid,payload:{type:p.UpdateRuleType.SETTING,payload:{type:g.type,formula1:g.formula1,formula2:g.formula2,[c]:h}},source:"patched"},R={unitId:s,subUnitId:e,ruleId:t.uid,payload:{type:p.UpdateRuleType.SETTING,payload:{type:g.type,formula1:g.formula1,formula2:g.formula2}},source:"patched"},V=[{id:p.UpdateDataValidationMutation.id,params:v}],f=[{id:p.UpdateDataValidationMutation.id,params:R}];return{redos:V,undos:f}},u=this._dataValidationFormulaService.getRuleFormulaInfo(s,e,a);if(u){const[c,h]=u;if(c){const g=this._formulaRefRangeService.registerFormula(s,e,c.text,S=>l("formula1",S));n.add(()=>g.dispose())}if(h){const g=this._formulaRefRangeService.registerFormula(s,e,h.text,S=>l("formula2",S));n.add(()=>g.dispose())}}}register(s,e,t){var u;const a=d=>{const c=[...t.ranges],g=c.map(v=>D.handleCommonDefaultRangeChangeWithEffectRefCommands(v,d)).filter(v=>!!v).flat();if(r.isRangesEqual(g,c))return{redos:[],undos:[]};if(g.length){const v={unitId:s,subUnitId:e,ruleId:t.uid,payload:{type:p.UpdateRuleType.RANGE,payload:g},source:"patched"},R=[{id:p.UpdateDataValidationMutation.id,params:v}],V=[{id:p.UpdateDataValidationMutation.id,params:{unitId:s,subUnitId:e,ruleId:t.uid,payload:{type:p.UpdateRuleType.RANGE,payload:c},source:"patched"}}];return{redos:R,undos:V}}else{const v={unitId:s,subUnitId:e,ruleId:t.uid},R=[{id:p.RemoveDataValidationMutation.id,params:v}],V=it(this._injector,v);return{redos:R,undos:V}}},i=[];t.ranges.forEach(d=>{const c=this._refRangeService.registerRefRange(d,a,s,e);i.push(()=>c.dispose())});const n=this._getIdWithUnitId(s,e,t.uid),l=(u=this._disposableMap.get(n))!=null?u:new Set;l.add(()=>i.forEach(d=>d())),this._disposableMap.set(n,l)}_initRefRange(){const s=this._dataValidationModel.getAll();for(const[e,t]of s)for(const[a,i]of t)for(const n of i)this.registerRule(e,a,n);this.disposeWithMe(this._dataValidationModel.ruleChange$.subscribe(e=>{const{unitId:t,subUnitId:a,rule:i}=e;switch(e.type){case"add":{const n=e.rule;this.registerRule(e.unitId,e.subUnitId,n);break}case"remove":{const n=this._disposableMap.get(this._getIdWithUnitId(t,a,i.uid));n&&n.forEach(l=>l());break}case"update":{const n=e.rule,l=this._disposableMap.get(this._getIdWithUnitId(t,a,n.uid));l&&l.forEach(u=>u()),this.registerRule(e.unitId,e.subUnitId,n);break}}})),this.disposeWithMe(r.toDisposable(()=>{this._disposableMap.forEach(e=>{e.forEach(t=>t())}),this._disposableMap.clear()}))}};te=dt([b(0,r.Inject(m.SheetDataValidationModel)),b(1,r.Inject(r.Injector)),b(2,r.Inject(D.RefRangeService)),b(3,r.Inject(m.DataValidationFormulaService)),b(4,r.Inject(K.FormulaRefRangeService)),b(5,r.Inject(p.DataValidatorRegistryService))],te);var ct=Object.getOwnPropertyDescriptor,mt=(o,s,e,t)=>{for(var a=t>1?void 0:t?ct(s,e):s,i=o.length-1,n;i>=0;i--)(n=o[i])&&(a=n(a)||a);return a},pe=(o,s)=>(e,t)=>s(e,t,o);let ae=class extends r.Disposable{constructor(o,s,e){super(),this._sheetInterceptorService=o,this._univerInstanceService=s,this._sheetDataValidationModel=e,this._initSheetChange()}_initSheetChange(){this.disposeWithMe(this._sheetInterceptorService.interceptCommand({getMutations:o=>{var s;if(o.id===D.RemoveSheetCommand.id){const e=o.params,t=e.unitId||this._univerInstanceService.getCurrentUnitForType(r.UniverInstanceType.UNIVER_SHEET).getUnitId(),a=this._univerInstanceService.getUniverSheetInstance(t);if(!a)return{redos:[],undos:[]};const i=e.subUnitId||((s=a.getActiveSheet())==null?void 0:s.getSheetId());if(!i)return{redos:[],undos:[]};const n=this._sheetDataValidationModel.getRules(t,i);if(n.length===0)return{redos:[],undos:[]};const l=n.map(c=>c.uid),u={unitId:t,subUnitId:i,ruleId:l,source:"patched"},d={unitId:t,subUnitId:i,rule:[...n],source:"patched"};return{redos:[{id:p.RemoveDataValidationMutation.id,params:u}],undos:[{id:p.AddDataValidationMutation.id,params:d}]}}return{redos:[],undos:[]}}}))}};ae=mt([pe(0,r.Inject(D.SheetInterceptorService)),pe(1,r.Inject(r.IUniverInstanceService)),pe(2,r.Inject(m.SheetDataValidationModel))],ae);class ht extends p.BaseDataValidator{constructor(){super(...arguments);_(this,"id",r.DataValidationType.ANY);_(this,"title","dataValidation.any.title");_(this,"operators",[]);_(this,"scopes",["sheet"]);_(this,"offsetFormulaByRange",!1)}async parseFormula(e,t,a){return{formula1:e.formula1,formula2:e.formula2,isFormulaValid:!0}}validatorFormula(e,t,a){return{success:!0}}async isValidType(e,t,a){return!0}generateRuleErrorMessage(e){return this.localeService.t("dataValidation.any.error")}}class gt extends p.BaseDataValidator{constructor(){super(...arguments);_(this,"id",r.DataValidationType.CUSTOM);_(this,"title","dataValidation.custom.title");_(this,"operators",[]);_(this,"scopes",["sheet"]);_(this,"_customFormulaService",this.injector.get(m.DataValidationCustomFormulaService));_(this,"_lexerTreeBuilder",this.injector.get(T.LexerTreeBuilder))}validatorFormula(e,t,a){var d;const i=r.isFormulaString(e.formula1),n=(d=e.formula1)!=null?d:"",u=this._lexerTreeBuilder.checkIfAddBracket(n)===0&&n.startsWith(T.operatorToken.EQUALS);return{success:i&&u,formula1:i&&u?"":this.localeService.t("dataValidation.validFail.formula")}}async parseFormula(e,t,a){return{formula1:void 0,formula2:void 0,isFormulaValid:!0}}async isValidType(e,t,a){const{column:i,row:n,unitId:l,subUnitId:u}=e,d=await this._customFormulaService.getCellFormulaValue(l,u,a.uid,n,i),c=d==null?void 0:d.v;return y(String(c))&&r.Tools.isDefine(c)&&c!==""?d.t===r.CellValueType.BOOLEAN?!!c:typeof c=="boolean"?c:typeof c=="number"?!!c:typeof c=="string"?y(c):!!c:!1}generateRuleErrorMessage(e){return this.localeService.t("dataValidation.custom.error")}generateRuleName(e){var t;return this.localeService.t("dataValidation.custom.ruleName").replace("{FORMULA1}",(t=e.formula1)!=null?t:"")}}class Le extends me{constructor(){super(...arguments);_(this,"id",r.DataValidationType.LIST_MULTIPLE);_(this,"title","dataValidation.listMultiple.title");_(this,"offsetFormulaByRange",!1);_(this,"skipDefaultFontRender",()=>!0)}}class pt extends p.BaseDataValidator{constructor(){super(...arguments);_(this,"_customFormulaService",this.injector.get(m.DataValidationCustomFormulaService));_(this,"_lexerTreeBuilder",this.injector.get(T.LexerTreeBuilder));_(this,"id",r.DataValidationType.WHOLE);_(this,"title","dataValidation.whole.title");_(this,"operators",[r.DataValidationOperator.BETWEEN,r.DataValidationOperator.EQUAL,r.DataValidationOperator.GREATER_THAN,r.DataValidationOperator.GREATER_THAN_OR_EQUAL,r.DataValidationOperator.LESS_THAN,r.DataValidationOperator.LESS_THAN_OR_EQUAL,r.DataValidationOperator.NOT_BETWEEN,r.DataValidationOperator.NOT_EQUAL]);_(this,"scopes",["sheet"])}_isFormulaOrInt(e){return!r.Tools.isBlank(e)&&(r.isFormulaString(e)||!Number.isNaN(+e)&&Number.isInteger(+e))}async isValidType(e,t,a){const{value:i}=e,n=J(i);return!Number.isNaN(n)&&Number.isInteger(n)}transform(e,t,a){const{value:i}=e;return{...e,value:J(i)}}_parseNumber(e){return e==null?Number.NaN:+e}async parseFormula(e,t,a,i,n){const l=await this._customFormulaService.getCellFormulaValue(t,a,e.uid,i,n),u=await this._customFormulaService.getCellFormula2Value(t,a,e.uid,i,n),{formula1:d,formula2:c}=e,h=r.isFormulaString(d)?l==null?void 0:l.v:d,g=r.isFormulaString(c)?u==null?void 0:u.v:c,S=y(`${h}`)&&y(`${g}`);return{formula1:this._parseNumber(h),formula2:this._parseNumber(g),isFormulaValid:S}}validatorFormula(e,t,a){const i=e.operator;if(!i)return{success:!1};const n=r.Tools.isDefine(e.formula1)&&this._isFormulaOrInt(e.formula1),l=r.Tools.isDefine(e.formula2)&&this._isFormulaOrInt(e.formula2),u=z.includes(i),d=this.localeService.t("dataValidation.validFail.number");return u?{success:n&&l,formula1:n?void 0:d,formula2:l?void 0:d}:{success:n,formula1:d}}generateRuleErrorMessage(e,t){if(!e.operator)return this.titleStr;const{transformedFormula1:a,transformedFormula2:i}=Z(this._lexerTreeBuilder,e,t);return`${this.localeService.t(Te[e.operator]).replace(q,a!=null?a:"").replace(Q,i!=null?i:"")}`}}var _t=Object.getOwnPropertyDescriptor,St=(o,s,e,t)=>{for(var a=t>1?void 0:t?_t(s,e):s,i=o.length-1,n;i>=0;i--)(n=o[i])&&(a=n(a)||a);return a},L=(o,s)=>(e,t)=>s(e,t,o);let ie=class extends r.RxDisposable{constructor(o,s,e,t,a,i){super(),this._univerInstanceService=o,this._dataValidatorRegistryService=s,this._injector=e,this._selectionManagerService=t,this._sheetInterceptorService=a,this._sheetDataValidationModel=i,this._init()}_init(){this._registerValidators(),this._initCommandInterceptor()}_registerValidators(){[ht,Ze,pt,at,ye,Me,me,Le,gt].forEach(o=>{const s=this._injector.createInstance(o);this.disposeWithMe(this._dataValidatorRegistryService.register(s)),this.disposeWithMe(r.toDisposable(()=>this._injector.delete(o)))})}_initCommandInterceptor(){this._sheetInterceptorService.interceptCommand({getMutations:o=>{var s;if(o.id===D.ClearSelectionAllCommand.id){const e=this._univerInstanceService.getCurrentUnitForType(r.UniverInstanceType.UNIVER_SHEET),t=e.getUnitId(),a=e.getActiveSheet();if(!a)throw new Error("No active sheet found");const i=a.getSheetId(),n=(s=this._selectionManagerService.getCurrentSelections())==null?void 0:s.map(h=>h.range),l=this._sheetDataValidationModel.getRuleObjectMatrix(t,i).clone();n&&l.removeRange(n);const u=l.diff(this._sheetDataValidationModel.getRules(t,i)),{redoMutations:d,undoMutations:c}=Y(t,i,u,this._injector,"patched");return{undos:c,redos:d}}return{undos:[],redos:[]}}})}};ie=St([L(0,r.IUniverInstanceService),L(1,r.Inject(p.DataValidatorRegistryService)),L(2,r.Inject(r.Injector)),L(3,r.Inject(D.SheetsSelectionsService)),L(4,r.Inject(D.SheetInterceptorService)),L(5,r.Inject(m.SheetDataValidationModel))],ie);var ft=Object.getOwnPropertyDescriptor,vt=(o,s,e,t)=>{for(var a=t>1?void 0:t?ft(s,e):s,i=o.length-1,n;i>=0;i--)(n=o[i])&&(a=n(a)||a);return a},re=(o,s)=>(e,t)=>s(e,t,o);m.SheetsDataValidationValidatorService=class extends r.Disposable{constructor(s,e,t,a){super(),this._univerInstanceService=s,this._sheetDataValidationModel=e,this._dataValidationCacheService=t,this._lifecycleService=a,this._initRecalculate()}_initRecalculate(){const s=e=>{if(e.length===0)return;const t=this._univerInstanceService.getCurrentUnitForType(r.UniverInstanceType.UNIVER_SHEET),a=t==null?void 0:t.getActiveSheet(),i={};e.flat().forEach(n=>{i[n.unitId]||(i[n.unitId]={}),i[n.unitId][n.subUnitId]||(i[n.unitId][n.subUnitId]=[]);const l=this._univerInstanceService.getUnit(n.unitId,r.UniverInstanceType.UNIVER_SHEET),u=l==null?void 0:l.getSheetBySheetId(n.subUnitId);u&&i[n.unitId][n.subUnitId].push(...n.ranges.map(d=>r.Range.transformRange(d,u)))}),Object.entries(i).forEach(([n,l])=>{Object.entries(l).forEach(([u,d])=>{(t==null?void 0:t.getUnitId())===n&&(a==null?void 0:a.getSheetId())===u?this.validatorRanges(n,u,d):requestIdleCallback(()=>{this.validatorRanges(n,u,d)})})})};this.disposeWithMe(this._dataValidationCacheService.dirtyRanges$.pipe(A.bufferWhen(()=>this._lifecycleService.lifecycle$.pipe(A.filter(e=>e===r.LifecycleStages.Rendered)))).subscribe(s)),this.disposeWithMe(this._dataValidationCacheService.dirtyRanges$.pipe(A.filter(()=>this._lifecycleService.stage>=r.LifecycleStages.Rendered),r.bufferDebounceTime(20)).subscribe(s))}async _validatorByCell(s,e,t,a){const i=s.getUnitId(),n=e.getSheetId();if(!r.Tools.isDefine(t)||!r.Tools.isDefine(a))throw new Error(`row or col is not defined, row: ${t}, col: ${a}`);const l=this._sheetDataValidationModel.getRuleByLocation(i,n,t,a);return l?new Promise(u=>{this._sheetDataValidationModel.validator(l,{unitId:i,subUnitId:n,row:t,col:a,worksheet:e,workbook:s},d=>{u(d)})}):r.DataValidationStatus.VALID}async validatorCell(s,e,t,a){const i=this._univerInstanceService.getUnit(s,r.UniverInstanceType.UNIVER_SHEET);if(!i)throw new Error(`cannot find current workbook, unitId: ${s}`);const n=i.getSheetBySheetId(e);if(!n)throw new Error(`cannot find current worksheet, sheetId: ${e}`);return this._validatorByCell(i,n,t,a)}validatorRanges(s,e,t){if(!t.length)return Promise.resolve([]);const a=this._univerInstanceService.getUnit(s,r.UniverInstanceType.UNIVER_SHEET);if(!a)throw new Error(`cannot find current workbook, unitId: ${s}`);const i=a.getSheetBySheetId(e);if(!i)throw new Error(`cannot find current worksheet, sheetId: ${e}`);return Promise.all(t.map(n=>{const l=[];return r.Range.foreach(n,(u,d)=>{l.push(this._validatorByCell(a,i,u,d))}),Promise.all(l)}))}async validatorWorksheet(s,e){const t=this._univerInstanceService.getUnit(s,r.UniverInstanceType.UNIVER_SHEET);if(!t)throw new Error(`cannot find current workbook, unitId: ${s}`);const a=t.getSheetBySheetId(e);if(!a)throw new Error(`cannot find current worksheet, sheetId: ${e}`);const i=this._sheetDataValidationModel.getRules(s,e);return await Promise.all(i.map(n=>Promise.all(n.ranges.map(l=>{const u=[];return r.Range.foreach(l,(d,c)=>{u.push(this._validatorByCell(t,a,d,c))}),u})))),this._dataValidationCacheService.ensureCache(s,e)}async validatorWorkbook(s){const e=this._sheetDataValidationModel.getSubUnitIds(s),t=await Promise.all(e.map(i=>this.validatorWorksheet(s,i))),a={};return t.forEach((i,n)=>{a[e[n]]=i}),a}getDataValidations(s,e,t){const a=this._sheetDataValidationModel.getRuleObjectMatrix(s,e),i=new Set;return t.forEach(l=>{r.Range.foreach(l,(u,d)=>{const c=a.getValue(u,d);c&&i.add(c)})}),Array.from(i).map(l=>this._sheetDataValidationModel.getRuleById(s,e,l)).filter(Boolean)}getDataValidation(s,e,t){return this.getDataValidations(s,e,t)[0]}},m.SheetsDataValidationValidatorService=vt([re(0,r.IUniverInstanceService),re(1,r.Inject(m.SheetDataValidationModel)),re(2,r.Inject(m.DataValidationCacheService)),re(3,r.Inject(r.LifecycleService))],m.SheetsDataValidationValidatorService);var Rt=Object.defineProperty,Vt=Object.getOwnPropertyDescriptor,Dt=(o,s,e)=>s in o?Rt(o,s,{enumerable:!0,configurable:!0,writable:!0,value:e}):o[s]=e,Mt=(o,s,e,t)=>{for(var a=t>1?void 0:t?Vt(s,e):s,i=o.length-1,n;i>=0;i--)(n=o[i])&&(a=n(a)||a);return a},_e=(o,s)=>(e,t)=>s(e,t,o),Be=(o,s,e)=>Dt(o,typeof s!="symbol"?s+"":s,e);m.UniverSheetsDataValidationPlugin=class extends r.Plugin{constructor(s=Ue,e,t,a){super(),this._config=s,this._injector=e,this._commandService=t,this._configService=a;const{...i}=r.merge({},Ue,this._config);this._configService.setConfig(rt,i)}onStarting(){[[m.DataValidationCacheService],[m.DataValidationFormulaService],[m.DataValidationCustomFormulaService],[m.SheetsDataValidationValidatorService],[m.SheetDataValidationModel],[ie],[m.DataValidationFormulaController],[ae],[te],[ee]].forEach(s=>{this._injector.add(s)}),[Fe,Ie,Ee,Ce,we,Ae,Ne].forEach(s=>{this._commandService.registerCommand(s)}),this._injector.get(m.DataValidationCacheService),this._injector.get(m.SheetsDataValidationValidatorService),this._injector.get(ie),this._injector.get(ee),this._injector.get(te)}onReady(){this._injector.get(ae)}onRendered(){this._injector.get(m.DataValidationFormulaController)}},Be(m.UniverSheetsDataValidationPlugin,"pluginName",ve),Be(m.UniverSheetsDataValidationPlugin,"type",r.UniverInstanceType.UNIVER_SHEET),m.UniverSheetsDataValidationPlugin=Mt([r.DependentOn(p.UniverDataValidationPlugin),_e(1,r.Inject(r.Injector)),_e(2,r.ICommandService),_e(3,r.IConfigService)],m.UniverSheetsDataValidationPlugin);function yt(o){const e=o.get(D.SheetsSelectionsService).getCurrentSelections().map(i=>i.range);return{uid:r.Tools.generateRandomId(6),type:r.DataValidationType.DECIMAL,operator:r.DataValidationOperator.EQUAL,formula1:"100",ranges:e!=null?e:[{startColumn:0,endColumn:0,startRow:0,endRow:0}]}}m.AddSheetDataValidationCommand=Fe,m.CHECKBOX_FORMULA_1=$,m.CHECKBOX_FORMULA_2=k,m.CheckboxValidator=Me,m.ClearRangeDataValidationCommand=Ne,m.DATA_VALIDATION_PLUGIN_NAME=ve,m.DateValidator=ye,m.ListMultipleValidator=Le,m.ListValidator=me,m.RemoveSheetAllDataValidationCommand=Ae,m.RemoveSheetDataValidationCommand=we,m.UpdateSheetDataValidationOptionsCommand=Ce,m.UpdateSheetDataValidationRangeCommand=Ie,m.UpdateSheetDataValidationSettingCommand=Ee,m.createDefaultNewRule=yt,m.deserializeListOptions=G,m.getCellValueOrigin=U,m.getDataValidationCellValue=ze,m.getDataValidationDiffMutations=Y,m.getFormulaCellData=j,m.getFormulaResult=w,m.isLegalFormulaResult=y,m.serializeListOptions=Ke,m.transformCheckboxValue=x,Object.defineProperty(m,Symbol.toStringTag,{value:"Module"})});
7
7
 
8
8
 
9
9
  // @univerjs/sheets-data-validation/facade
10
- (function(u,i){typeof exports=="object"&&typeof module<"u"?i(exports,require("@univerjs/sheets-data-validation"),require("@univerjs/sheets/facade"),require("@univerjs/core"),require("@univerjs/data-validation"),require("@univerjs/engine-formula"),require("rxjs")):typeof define=="function"&&define.amd?define(["exports","@univerjs/sheets-data-validation","@univerjs/sheets/facade","@univerjs/core","@univerjs/data-validation","@univerjs/engine-formula","rxjs"],i):(u=typeof globalThis<"u"?globalThis:u||self,i(u.UniverSheetsDataValidationFacade={},u.UniverSheetsDataValidation,u.UniverSheetsFacade,u.UniverCore,u.UniverDataValidation,u.UniverEngineFormula,u.rxjs))})(this,function(u,i,m,a,D,v,E){"use strict";var U=Object.defineProperty;var A=(u,i,m)=>i in u?U(u,i,{enumerable:!0,configurable:!0,writable:!0,value:m}):u[i]=m;var S=(u,i,m)=>A(u,typeof i!="symbol"?i+"":i,m);class _{constructor(t){S(this,"_rule");this._rule=t!=null?t:{uid:a.generateRandomId(),ranges:void 0,type:a.DataValidationType.CUSTOM}}build(){return new g(this._rule)}copy(){return new _({...this._rule,uid:a.generateRandomId()})}getAllowInvalid(){return this._rule.errorStyle!==a.DataValidationErrorStyle.STOP}getCriteriaType(){return this._rule.type}getCriteriaValues(){return[this._rule.operator,this._rule.formula1,this._rule.formula2]}getHelpText(){return this._rule.error}requireCheckbox(t,e){return this._rule.type=a.DataValidationType.CHECKBOX,this._rule.formula1=t,this._rule.formula2=e,this}requireDateAfter(t){return this._rule.type=a.DataValidationType.DATE,this._rule.formula1=t.toLocaleDateString(),this._rule.operator=a.DataValidationOperator.GREATER_THAN,this}requireDateBefore(t){return this._rule.type=a.DataValidationType.DATE,this._rule.formula1=t.toLocaleDateString(),this._rule.formula2=void 0,this._rule.operator=a.DataValidationOperator.LESS_THAN,this}requireDateBetween(t,e){return this._rule.type=a.DataValidationType.DATE,this._rule.formula1=t.toLocaleDateString(),this._rule.formula2=e.toLocaleDateString(),this._rule.operator=a.DataValidationOperator.BETWEEN,this}requireDateEqualTo(t){return this._rule.type=a.DataValidationType.DATE,this._rule.formula1=t.toLocaleDateString(),this._rule.formula2=void 0,this._rule.operator=a.DataValidationOperator.EQUAL,this}requireDateNotBetween(t,e){return this._rule.type=a.DataValidationType.DATE,this._rule.formula1=t.toLocaleDateString(),this._rule.formula2=e.toLocaleDateString(),this._rule.operator=a.DataValidationOperator.NOT_BETWEEN,this}requireDateOnOrAfter(t){return this._rule.type=a.DataValidationType.DATE,this._rule.formula1=t.toLocaleDateString(),this._rule.formula2=void 0,this._rule.operator=a.DataValidationOperator.GREATER_THAN_OR_EQUAL,this}requireDateOnOrBefore(t){return this._rule.type=a.DataValidationType.DATE,this._rule.formula1=t.toLocaleDateString(),this._rule.formula2=void 0,this._rule.operator=a.DataValidationOperator.LESS_THAN_OR_EQUAL,this}requireFormulaSatisfied(t){return this._rule.type=a.DataValidationType.CUSTOM,this._rule.formula1=t,this._rule.formula2=void 0,this}requireNumberBetween(t,e,r){return this._rule.formula1=`${t}`,this._rule.formula2=`${e}`,this._rule.operator=a.DataValidationOperator.BETWEEN,this._rule.type=r?a.DataValidationType.WHOLE:a.DataValidationType.DECIMAL,this}requireNumberEqualTo(t,e){return this._rule.formula1=`${t}`,this._rule.formula2=void 0,this._rule.operator=a.DataValidationOperator.EQUAL,this._rule.type=e?a.DataValidationType.WHOLE:a.DataValidationType.DECIMAL,this}requireNumberGreaterThan(t,e){return this._rule.formula1=`${t}`,this._rule.formula2=void 0,this._rule.operator=a.DataValidationOperator.GREATER_THAN,this._rule.type=e?a.DataValidationType.WHOLE:a.DataValidationType.DECIMAL,this}requireNumberGreaterThanOrEqualTo(t,e){return this._rule.formula1=`${t}`,this._rule.formula2=void 0,this._rule.operator=a.DataValidationOperator.GREATER_THAN_OR_EQUAL,this._rule.type=e?a.DataValidationType.WHOLE:a.DataValidationType.DECIMAL,this}requireNumberLessThan(t,e){return this._rule.formula1=`${t}`,this._rule.formula2=void 0,this._rule.operator=a.DataValidationOperator.LESS_THAN,this._rule.type=e?a.DataValidationType.WHOLE:a.DataValidationType.DECIMAL,this}requireNumberLessThanOrEqualTo(t,e){return this._rule.formula1=`${t}`,this._rule.formula2=void 0,this._rule.operator=a.DataValidationOperator.LESS_THAN_OR_EQUAL,this._rule.type=e?a.DataValidationType.WHOLE:a.DataValidationType.DECIMAL,this}requireNumberNotBetween(t,e,r){return this._rule.formula1=`${t}`,this._rule.formula2=`${e}`,this._rule.operator=a.DataValidationOperator.NOT_BETWEEN,this._rule.type=r?a.DataValidationType.WHOLE:a.DataValidationType.DECIMAL,this}requireNumberNotEqualTo(t,e){return this._rule.formula1=`${t}`,this._rule.formula2=void 0,this._rule.operator=a.DataValidationOperator.NOT_EQUAL,this._rule.type=e?a.DataValidationType.WHOLE:a.DataValidationType.DECIMAL,this}requireValueInList(t,e,r){return this._rule.type=e?a.DataValidationType.LIST_MULTIPLE:a.DataValidationType.LIST,this._rule.formula1=t.join(","),this._rule.formula2=void 0,this._rule.showDropDown=r!=null?r:!0,this}requireValueInRange(t,e,r){return this._rule.type=e?a.DataValidationType.LIST_MULTIPLE:a.DataValidationType.LIST,this._rule.formula1=`=${v.serializeRangeToRefString({unitId:t.getUnitId(),sheetName:t.getSheetName(),range:t.getRange()})}`,this._rule.formula2=void 0,this._rule.showDropDown=r!=null?r:!0,this}setAllowInvalid(t){return this._rule.errorStyle=t?a.DataValidationErrorStyle.WARNING:a.DataValidationErrorStyle.STOP,this}setAllowBlank(t){return this._rule.allowBlank=t,this}setOptions(t){return Object.assign(this._rule,t),this}}class g{constructor(t,e,r){S(this,"rule");S(this,"_worksheet");S(this,"_injector");this._injector=r,this.rule=t,this._worksheet=e}getAllowInvalid(){return this.rule.errorStyle!==a.DataValidationErrorStyle.STOP}getCriteriaType(){return this.rule.type}getCriteriaValues(){return[this.rule.operator,this.rule.formula1,this.rule.formula2]}getHelpText(){return this.rule.error}copy(){return new _(this.rule)}getApplied(){if(!this._worksheet)return!1;const e=this._injector.get(D.DataValidationModel).getRuleById(this._worksheet.getUnitId(),this._worksheet.getSheetId(),this.rule.uid);return!!(e&&e.ranges.length)}getRanges(){if(!this.getApplied())return[];const t=this._injector.get(a.IUniverInstanceService).getUnit(this._worksheet.getUnitId());return this.rule.ranges.map(e=>this._injector.createInstance(m.FRange,t,this._worksheet,e))}getUnitId(){var t;return(t=this._worksheet)==null?void 0:t.getUnitId()}getSheetId(){var t;return(t=this._worksheet)==null?void 0:t.getSheetId()}setCriteria(t,e,r=!0){if(this.getApplied()&&!this._injector.get(a.ICommandService).syncExecuteCommand(i.UpdateSheetDataValidationSettingCommand.id,{unitId:this.getUnitId(),subUnitId:this.getSheetId(),ruleId:this.rule.uid,setting:{operator:e[0],formula1:e[1],formula2:e[2],type:this.rule.type,allowBlank:r}}))throw new Error("setCriteria failed");return this.rule.operator=e[0],this.rule.formula1=e[1],this.rule.formula2=e[2],this.rule.type=t,this.rule.allowBlank=r,this}setOptions(t){if(this.getApplied()&&!this._injector.get(a.ICommandService).syncExecuteCommand(i.UpdateSheetDataValidationOptionsCommand.id,{unitId:this.getUnitId(),subUnitId:this.getSheetId(),ruleId:this.rule.uid,options:{...D.getRuleOptions(this.rule),...t}}))throw new Error("setOptions failed");return Object.assign(this.rule,t),this}setRanges(t){if(this.getApplied()&&!this._injector.get(a.ICommandService).syncExecuteCommand(i.UpdateSheetDataValidationRangeCommand.id,{unitId:this.getUnitId(),subUnitId:this.getSheetId(),ruleId:this.rule.uid,ranges:t.map(o=>o.getRange())}))throw new Error("setRanges failed");return this.rule.ranges=t.map(e=>e.getRange()),this}delete(){return this.getApplied()?this._injector.get(a.ICommandService).syncExecuteCommand(i.RemoveSheetDataValidationCommand.id,{unitId:this.getUnitId(),subUnitId:this.getSheetId(),ruleId:this.rule.uid}):!1}}class w extends m.FRange{setDataValidation(t){if(!t)return this._commandService.syncExecuteCommand(i.ClearRangeDataValidationCommand.id,{unitId:this._workbook.getUnitId(),subUnitId:this._worksheet.getSheetId(),ranges:[this._range]}),this;const e={unitId:this._workbook.getUnitId(),subUnitId:this._worksheet.getSheetId(),rule:{...t.rule,ranges:[this._range]}};return this._commandService.syncExecuteCommand(i.AddSheetDataValidationCommand.id,e),this}getDataValidation(){const e=this._injector.get(i.SheetsDataValidationValidatorService).getDataValidation(this._workbook.getUnitId(),this._worksheet.getSheetId(),[this._range]);return e&&new g(e,this._worksheet,this._injector)}getDataValidations(){return this._injector.get(i.SheetsDataValidationValidatorService).getDataValidations(this._workbook.getUnitId(),this._worksheet.getSheetId(),[this._range]).map(e=>new g(e,this._worksheet,this._injector))}async getValidatorStatus(){return this._injector.get(i.SheetsDataValidationValidatorService).validatorRanges(this._workbook.getUnitId(),this._worksheet.getSheetId(),[this._range])}}m.FRange.extend(w);class T extends a.FUniver{static newDataValidation(){return new _}newDataValidation(){return new _}_initialize(t){if(!t.has(i.SheetDataValidationModel))return;const e=t.get(i.SheetDataValidationModel),r=t.get(a.ICommandService);this.disposeWithMe(e.ruleChange$.subscribe(o=>{const{unitId:n,subUnitId:s,rule:p,oldRule:l,type:d}=o,h=this.getSheetTarget(n,s);if(!h)return;const{workbook:c,worksheet:V}=h,I=new g(p,V.getSheet(),this._injector);this.fireEvent(this.Event.SheetDataValidationChanged,{origin:o,worksheet:V,workbook:c,changeType:d,oldRule:l,rule:I})})),this.disposeWithMe(e.validStatusChange$.subscribe(o=>{const{unitId:n,subUnitId:s,ruleId:p,status:l,row:d,col:h}=o,c=this.getSheetTarget(n,s);if(!c)return;const{workbook:V,worksheet:I}=c,k=I.getDataValidation(p);k&&this.fireEvent(this.Event.SheetDataValidatorStatusChanged,{workbook:V,worksheet:I,row:d,column:h,rule:k,status:l})})),this.disposeWithMe(r.beforeCommandExecuted(o=>{switch(o.id){case i.AddSheetDataValidationCommand.id:{const n=o.params,s=this.getSheetTarget(n.unitId,n.subUnitId);if(!s)return;const{workbook:p,worksheet:l}=s,d={worksheet:l,workbook:p,rule:n.rule};if(this.fireEvent(this.Event.BeforeSheetDataValidationAdd,d),d.cancel)throw new a.CanceledError;break}case i.UpdateSheetDataValidationSettingCommand.id:{const n=o.params,s=this.getSheetTarget(n.unitId,n.subUnitId);if(!s)return;const{workbook:p,worksheet:l}=s,d=l.getDataValidation(n.ruleId);if(!d)return;const h={worksheet:l,workbook:p,rule:d,ruleId:n.ruleId,newCriteria:n.setting};if(this.fireEvent(this.Event.BeforeSheetDataValidationCriteriaUpdate,h),h.cancel)throw new a.CanceledError;break}case i.UpdateSheetDataValidationRangeCommand.id:{const n=o.params,s=this.getSheetTarget(n.unitId,n.subUnitId);if(!s)return;const{workbook:p,worksheet:l}=s,d=l.getDataValidation(n.ruleId);if(!d)return;const h={worksheet:l,workbook:p,rule:d,ruleId:n.ruleId,newRanges:n.ranges};if(this.fireEvent(this.Event.BeforeSheetDataValidationRangeUpdate,h),h.cancel)throw new a.CanceledError;break}case i.UpdateSheetDataValidationOptionsCommand.id:{const n=o.params,s=this.getSheetTarget(n.unitId,n.subUnitId);if(!s)return;const{workbook:p,worksheet:l}=s,d=l.getDataValidation(n.ruleId);if(!d)return;const h={worksheet:l,workbook:p,rule:d,ruleId:n.ruleId,newOptions:n.options};if(this.fireEvent(this.Event.BeforeSheetDataValidationOptionsUpdate,h),h.cancel)throw new a.CanceledError;break}case i.RemoveSheetDataValidationCommand.id:{const n=o.params,s=this.getSheetTarget(n.unitId,n.subUnitId);if(!s)return;const{workbook:p,worksheet:l}=s,d=l.getDataValidation(n.ruleId);if(!d)return;const h={worksheet:l,workbook:p,rule:d,ruleId:n.ruleId};if(this.fireEvent(this.Event.BeforeSheetDataValidationDelete,h),h.cancel)throw new a.CanceledError;break}case i.RemoveSheetAllDataValidationCommand.id:{const n=o.params,s=this.getSheetTarget(n.unitId,n.subUnitId);if(!s)return;const{workbook:p,worksheet:l}=s,d={worksheet:l,workbook:p,rules:l.getDataValidations()};if(this.fireEvent(this.Event.BeforeSheetDataValidationDeleteAll,d),d.cancel)throw new a.CanceledError;break}}}))}}a.FUniver.extend(T);class b extends m.FWorkbook{_initialize(){Object.defineProperty(this,"_dataValidationModel",{get(){return this._injector.get(i.SheetDataValidationModel)}})}getValidatorStatus(){return this._injector.get(i.SheetsDataValidationValidatorService).validatorWorkbook(this._workbook.getUnitId())}onDataValidationChange(t){return a.toDisposable(this._dataValidationModel.ruleChange$.pipe(E.filter(e=>e.unitId===this._workbook.getUnitId())).subscribe(t))}onDataValidationStatusChange(t){return a.toDisposable(this._dataValidationModel.validStatusChange$.pipe(E.filter(e=>e.unitId===this._workbook.getUnitId())).subscribe(t))}onBeforeAddDataValidation(t){return a.toDisposable(this._commandService.beforeCommandExecuted((e,r)=>{const o=e.params;if(e.id===i.AddSheetDataValidationCommand.id){if(o.unitId!==this._workbook.getUnitId())return;if(t(o,r)===!1)throw new Error("Command is stopped by the hook onBeforeAddDataValidation")}}))}onBeforeUpdateDataValidationCriteria(t){return a.toDisposable(this._commandService.beforeCommandExecuted((e,r)=>{const o=e.params;if(e.id===i.UpdateSheetDataValidationSettingCommand.id){if(o.unitId!==this._workbook.getUnitId())return;if(t(o,r)===!1)throw new Error("Command is stopped by the hook onBeforeUpdateDataValidationCriteria")}}))}onBeforeUpdateDataValidationRange(t){return a.toDisposable(this._commandService.beforeCommandExecuted((e,r)=>{const o=e.params;if(e.id===i.UpdateSheetDataValidationRangeCommand.id){if(o.unitId!==this._workbook.getUnitId())return;if(t(o,r)===!1)throw new Error("Command is stopped by the hook onBeforeUpdateDataValidationRange")}}))}onBeforeUpdateDataValidationOptions(t){return a.toDisposable(this._commandService.beforeCommandExecuted((e,r)=>{const o=e.params;if(e.id===i.UpdateSheetDataValidationOptionsCommand.id){if(o.unitId!==this._workbook.getUnitId())return;if(t(o,r)===!1)throw new Error("Command is stopped by the hook onBeforeUpdateDataValidationOptions")}}))}onBeforeDeleteDataValidation(t){return a.toDisposable(this._commandService.beforeCommandExecuted((e,r)=>{const o=e.params;if(e.id===i.RemoveSheetDataValidationCommand.id){if(o.unitId!==this._workbook.getUnitId())return;if(t(o,r)===!1)throw new Error("Command is stopped by the hook onBeforeDeleteDataValidation")}}))}onBeforeDeleteAllDataValidation(t){return a.toDisposable(this._commandService.beforeCommandExecuted((e,r)=>{const o=e.params;if(e.id===i.RemoveSheetAllDataValidationCommand.id){if(o.unitId!==this._workbook.getUnitId())return;if(t(o,r)===!1)throw new Error("Command is stopped by the hook onBeforeDeleteAllDataValidation")}}))}}m.FWorkbook.extend(b);class y extends m.FWorksheet{getDataValidations(){return this._injector.get(D.DataValidationModel).getRules(this._workbook.getUnitId(),this._worksheet.getSheetId()).map(e=>new g(e,this._worksheet,this._injector))}getValidatorStatus(){return this._injector.get(i.SheetsDataValidationValidatorService).validatorWorksheet(this._workbook.getUnitId(),this._worksheet.getSheetId())}getValidatorStatusAsync(){return this.getValidatorStatus()}getDataValidation(t){const r=this._injector.get(D.DataValidationModel).getRuleById(this._workbook.getUnitId(),this._worksheet.getSheetId(),t);return r?new g(r,this._worksheet,this._injector):null}}m.FWorksheet.extend(y);class C{get SheetDataValidationChanged(){return"SheetDataValidationChanged"}get SheetDataValidatorStatusChanged(){return"SheetDataValidatorStatusChanged"}get BeforeSheetDataValidationAdd(){return"BeforeSheetDataValidationAdd"}get BeforeSheetDataValidationDelete(){return"BeforeSheetDataValidationDelete"}get BeforeSheetDataValidationDeleteAll(){return"BeforeSheetDataValidationDeleteAll"}get BeforeSheetDataValidationCriteriaUpdate(){return"BeforeSheetDataValidationCriteriaUpdate"}get BeforeSheetDataValidationRangeUpdate(){return"BeforeSheetDataValidationRangeUpdate"}get BeforeSheetDataValidationOptionsUpdate(){return"BeforeSheetDataValidationOptionsUpdate"}}a.FEventName.extend(C),u.FDataValidation=g,u.FDataValidationBuilder=_,Object.defineProperty(u,Symbol.toStringTag,{value:"Module"})});
10
+ (function(l,n){typeof exports=="object"&&typeof module<"u"?n(exports,require("@univerjs/sheets-data-validation"),require("@univerjs/sheets/facade"),require("@univerjs/core"),require("@univerjs/data-validation"),require("@univerjs/engine-formula"),require("@univerjs/core/facade"),require("rxjs")):typeof define=="function"&&define.amd?define(["exports","@univerjs/sheets-data-validation","@univerjs/sheets/facade","@univerjs/core","@univerjs/data-validation","@univerjs/engine-formula","@univerjs/core/facade","rxjs"],n):(l=typeof globalThis<"u"?globalThis:l||self,n(l.UniverSheetsDataValidationFacade={},l.UniverSheetsDataValidation,l.UniverSheetsFacade,l.UniverCore,l.UniverDataValidation,l.UniverEngineFormula,l.UniverCoreFacade,l.rxjs))})(this,function(l,n,g,a,D,w,E,I){"use strict";var A=Object.defineProperty;var O=(l,n,g)=>n in l?A(l,n,{enumerable:!0,configurable:!0,writable:!0,value:g}):l[n]=g;var S=(l,n,g)=>O(l,typeof n!="symbol"?n+"":n,g);class _{constructor(t){S(this,"_rule");this._rule=t!=null?t:{uid:a.generateRandomId(),ranges:void 0,type:a.DataValidationType.CUSTOM}}build(){return new p(this._rule)}copy(){return new _({...this._rule,uid:a.generateRandomId()})}getAllowInvalid(){return this._rule.errorStyle!==a.DataValidationErrorStyle.STOP}getCriteriaType(){return this._rule.type}getCriteriaValues(){return[this._rule.operator,this._rule.formula1,this._rule.formula2]}getHelpText(){return this._rule.error}requireCheckbox(t,e){return this._rule.type=a.DataValidationType.CHECKBOX,this._rule.formula1=t,this._rule.formula2=e,this}requireDateAfter(t){return this._rule.type=a.DataValidationType.DATE,this._rule.formula1=t.toLocaleDateString(),this._rule.operator=a.DataValidationOperator.GREATER_THAN,this}requireDateBefore(t){return this._rule.type=a.DataValidationType.DATE,this._rule.formula1=t.toLocaleDateString(),this._rule.formula2=void 0,this._rule.operator=a.DataValidationOperator.LESS_THAN,this}requireDateBetween(t,e){return this._rule.type=a.DataValidationType.DATE,this._rule.formula1=t.toLocaleDateString(),this._rule.formula2=e.toLocaleDateString(),this._rule.operator=a.DataValidationOperator.BETWEEN,this}requireDateEqualTo(t){return this._rule.type=a.DataValidationType.DATE,this._rule.formula1=t.toLocaleDateString(),this._rule.formula2=void 0,this._rule.operator=a.DataValidationOperator.EQUAL,this}requireDateNotBetween(t,e){return this._rule.type=a.DataValidationType.DATE,this._rule.formula1=t.toLocaleDateString(),this._rule.formula2=e.toLocaleDateString(),this._rule.operator=a.DataValidationOperator.NOT_BETWEEN,this}requireDateOnOrAfter(t){return this._rule.type=a.DataValidationType.DATE,this._rule.formula1=t.toLocaleDateString(),this._rule.formula2=void 0,this._rule.operator=a.DataValidationOperator.GREATER_THAN_OR_EQUAL,this}requireDateOnOrBefore(t){return this._rule.type=a.DataValidationType.DATE,this._rule.formula1=t.toLocaleDateString(),this._rule.formula2=void 0,this._rule.operator=a.DataValidationOperator.LESS_THAN_OR_EQUAL,this}requireFormulaSatisfied(t){return this._rule.type=a.DataValidationType.CUSTOM,this._rule.formula1=t,this._rule.formula2=void 0,this}requireNumberBetween(t,e,r){return this._rule.formula1=`${t}`,this._rule.formula2=`${e}`,this._rule.operator=a.DataValidationOperator.BETWEEN,this._rule.type=r?a.DataValidationType.WHOLE:a.DataValidationType.DECIMAL,this}requireNumberEqualTo(t,e){return this._rule.formula1=`${t}`,this._rule.formula2=void 0,this._rule.operator=a.DataValidationOperator.EQUAL,this._rule.type=e?a.DataValidationType.WHOLE:a.DataValidationType.DECIMAL,this}requireNumberGreaterThan(t,e){return this._rule.formula1=`${t}`,this._rule.formula2=void 0,this._rule.operator=a.DataValidationOperator.GREATER_THAN,this._rule.type=e?a.DataValidationType.WHOLE:a.DataValidationType.DECIMAL,this}requireNumberGreaterThanOrEqualTo(t,e){return this._rule.formula1=`${t}`,this._rule.formula2=void 0,this._rule.operator=a.DataValidationOperator.GREATER_THAN_OR_EQUAL,this._rule.type=e?a.DataValidationType.WHOLE:a.DataValidationType.DECIMAL,this}requireNumberLessThan(t,e){return this._rule.formula1=`${t}`,this._rule.formula2=void 0,this._rule.operator=a.DataValidationOperator.LESS_THAN,this._rule.type=e?a.DataValidationType.WHOLE:a.DataValidationType.DECIMAL,this}requireNumberLessThanOrEqualTo(t,e){return this._rule.formula1=`${t}`,this._rule.formula2=void 0,this._rule.operator=a.DataValidationOperator.LESS_THAN_OR_EQUAL,this._rule.type=e?a.DataValidationType.WHOLE:a.DataValidationType.DECIMAL,this}requireNumberNotBetween(t,e,r){return this._rule.formula1=`${t}`,this._rule.formula2=`${e}`,this._rule.operator=a.DataValidationOperator.NOT_BETWEEN,this._rule.type=r?a.DataValidationType.WHOLE:a.DataValidationType.DECIMAL,this}requireNumberNotEqualTo(t,e){return this._rule.formula1=`${t}`,this._rule.formula2=void 0,this._rule.operator=a.DataValidationOperator.NOT_EQUAL,this._rule.type=e?a.DataValidationType.WHOLE:a.DataValidationType.DECIMAL,this}requireValueInList(t,e,r){return this._rule.type=e?a.DataValidationType.LIST_MULTIPLE:a.DataValidationType.LIST,this._rule.formula1=t.join(","),this._rule.formula2=void 0,this._rule.showDropDown=r!=null?r:!0,this}requireValueInRange(t,e,r){return this._rule.type=e?a.DataValidationType.LIST_MULTIPLE:a.DataValidationType.LIST,this._rule.formula1=`=${w.serializeRangeToRefString({unitId:t.getUnitId(),sheetName:t.getSheetName(),range:t.getRange()})}`,this._rule.formula2=void 0,this._rule.showDropDown=r!=null?r:!0,this}setAllowInvalid(t){return this._rule.errorStyle=t?a.DataValidationErrorStyle.WARNING:a.DataValidationErrorStyle.STOP,this}setAllowBlank(t){return this._rule.allowBlank=t,this}setOptions(t){return Object.assign(this._rule,t),this}}class p{constructor(t,e,r){S(this,"rule");S(this,"_worksheet");S(this,"_injector");this._injector=r,this.rule=t,this._worksheet=e}getAllowInvalid(){return this.rule.errorStyle!==a.DataValidationErrorStyle.STOP}getCriteriaType(){return this.rule.type}getCriteriaValues(){return[this.rule.operator,this.rule.formula1,this.rule.formula2]}getHelpText(){return this.rule.error}copy(){return new _(this.rule)}getApplied(){if(!this._worksheet)return!1;const e=this._injector.get(D.DataValidationModel).getRuleById(this._worksheet.getUnitId(),this._worksheet.getSheetId(),this.rule.uid);return!!(e&&e.ranges.length)}getRanges(){if(!this.getApplied())return[];const t=this._injector.get(a.IUniverInstanceService).getUnit(this._worksheet.getUnitId());return this.rule.ranges.map(e=>this._injector.createInstance(g.FRange,t,this._worksheet,e))}getUnitId(){var t;return(t=this._worksheet)==null?void 0:t.getUnitId()}getSheetId(){var t;return(t=this._worksheet)==null?void 0:t.getSheetId()}setCriteria(t,e,r=!0){if(this.getApplied()&&!this._injector.get(a.ICommandService).syncExecuteCommand(n.UpdateSheetDataValidationSettingCommand.id,{unitId:this.getUnitId(),subUnitId:this.getSheetId(),ruleId:this.rule.uid,setting:{operator:e[0],formula1:e[1],formula2:e[2],type:this.rule.type,allowBlank:r}}))throw new Error("setCriteria failed");return this.rule.operator=e[0],this.rule.formula1=e[1],this.rule.formula2=e[2],this.rule.type=t,this.rule.allowBlank=r,this}setOptions(t){if(this.getApplied()&&!this._injector.get(a.ICommandService).syncExecuteCommand(n.UpdateSheetDataValidationOptionsCommand.id,{unitId:this.getUnitId(),subUnitId:this.getSheetId(),ruleId:this.rule.uid,options:{...D.getRuleOptions(this.rule),...t}}))throw new Error("setOptions failed");return Object.assign(this.rule,t),this}setRanges(t){if(this.getApplied()&&!this._injector.get(a.ICommandService).syncExecuteCommand(n.UpdateSheetDataValidationRangeCommand.id,{unitId:this.getUnitId(),subUnitId:this.getSheetId(),ruleId:this.rule.uid,ranges:t.map(i=>i.getRange())}))throw new Error("setRanges failed");return this.rule.ranges=t.map(e=>e.getRange()),this}delete(){return this.getApplied()?this._injector.get(a.ICommandService).syncExecuteCommand(n.RemoveSheetDataValidationCommand.id,{unitId:this.getUnitId(),subUnitId:this.getSheetId(),ruleId:this.rule.uid}):!1}}class C extends g.FRange{setDataValidation(t){if(!t)return this._commandService.syncExecuteCommand(n.ClearRangeDataValidationCommand.id,{unitId:this._workbook.getUnitId(),subUnitId:this._worksheet.getSheetId(),ranges:[this._range]}),this;const e={unitId:this._workbook.getUnitId(),subUnitId:this._worksheet.getSheetId(),rule:{...t.rule,ranges:[this._range]}};return this._commandService.syncExecuteCommand(n.AddSheetDataValidationCommand.id,e),this}getDataValidation(){const e=this._injector.get(n.SheetsDataValidationValidatorService).getDataValidation(this._workbook.getUnitId(),this._worksheet.getSheetId(),[this._range]);return e&&new p(e,this._worksheet,this._injector)}getDataValidations(){return this._injector.get(n.SheetsDataValidationValidatorService).getDataValidations(this._workbook.getUnitId(),this._worksheet.getSheetId(),[this._range]).map(e=>new p(e,this._worksheet,this._injector))}async getValidatorStatus(){return this._injector.get(n.SheetsDataValidationValidatorService).validatorRanges(this._workbook.getUnitId(),this._worksheet.getSheetId(),[this._range])}}g.FRange.extend(C);class T extends E.FUniver{static newDataValidation(){return new _}newDataValidation(){return new _}_initialize(t){if(!t.has(n.SheetDataValidationModel))return;const e=t.get(n.SheetDataValidationModel),r=t.get(a.ICommandService);this.registerEventHandler(this.Event.SheetDataValidationChanged,()=>e.ruleChange$.subscribe(i=>{const{unitId:o,subUnitId:s,rule:m,oldRule:u,type:d}=i,h=this.getSheetTarget(o,s);if(!h)return;const{workbook:c,worksheet:V}=h,v=new p(m,V.getSheet(),this._injector);this.fireEvent(this.Event.SheetDataValidationChanged,{origin:i,worksheet:V,workbook:c,changeType:d,oldRule:u,rule:v})})),this.registerEventHandler(this.Event.SheetDataValidatorStatusChanged,()=>e.validStatusChange$.subscribe(i=>{const{unitId:o,subUnitId:s,ruleId:m,status:u,row:d,col:h}=i,c=this.getSheetTarget(o,s);if(!c)return;const{workbook:V,worksheet:v}=c,k=v.getDataValidation(m);k&&this.fireEvent(this.Event.SheetDataValidatorStatusChanged,{workbook:V,worksheet:v,row:d,column:h,rule:k,status:u})})),this.registerEventHandler(this.Event.BeforeSheetDataValidationAdd,()=>r.beforeCommandExecuted(i=>{if(i.id===n.AddSheetDataValidationCommand.id){const o=i.params,s=this.getSheetTarget(o.unitId,o.subUnitId);if(!s)return;const{workbook:m,worksheet:u}=s,d={worksheet:u,workbook:m,rule:o.rule};if(this.fireEvent(this.Event.BeforeSheetDataValidationAdd,d),d.cancel)throw new a.CanceledError}})),this.registerEventHandler(this.Event.BeforeSheetDataValidationCriteriaUpdate,()=>r.beforeCommandExecuted(i=>{if(i.id===n.UpdateSheetDataValidationSettingCommand.id){const o=i.params,s=this.getSheetTarget(o.unitId,o.subUnitId);if(!s)return;const{workbook:m,worksheet:u}=s,d=u.getDataValidation(o.ruleId);if(!d)return;const h={worksheet:u,workbook:m,rule:d,ruleId:o.ruleId,newCriteria:o.setting};if(this.fireEvent(this.Event.BeforeSheetDataValidationCriteriaUpdate,h),h.cancel)throw new a.CanceledError}})),this.registerEventHandler(this.Event.BeforeSheetDataValidationRangeUpdate,()=>r.beforeCommandExecuted(i=>{if(i.id===n.UpdateSheetDataValidationRangeCommand.id){const o=i.params,s=this.getSheetTarget(o.unitId,o.subUnitId);if(!s)return;const{workbook:m,worksheet:u}=s,d=u.getDataValidation(o.ruleId);if(!d)return;const h={worksheet:u,workbook:m,rule:d,ruleId:o.ruleId,newRanges:o.ranges};if(this.fireEvent(this.Event.BeforeSheetDataValidationRangeUpdate,h),h.cancel)throw new a.CanceledError}})),this.registerEventHandler(this.Event.BeforeSheetDataValidationOptionsUpdate,()=>r.beforeCommandExecuted(i=>{if(i.id===n.UpdateSheetDataValidationOptionsCommand.id){const o=i.params,s=this.getSheetTarget(o.unitId,o.subUnitId);if(!s)return;const{workbook:m,worksheet:u}=s,d=u.getDataValidation(o.ruleId);if(!d)return;const h={worksheet:u,workbook:m,rule:d,ruleId:o.ruleId,newOptions:o.options};if(this.fireEvent(this.Event.BeforeSheetDataValidationOptionsUpdate,h),h.cancel)throw new a.CanceledError}})),this.registerEventHandler(this.Event.BeforeSheetDataValidationDelete,()=>r.beforeCommandExecuted(i=>{if(i.id===n.RemoveSheetDataValidationCommand.id){const o=i.params,s=this.getSheetTarget(o.unitId,o.subUnitId);if(!s)return;const{workbook:m,worksheet:u}=s,d=u.getDataValidation(o.ruleId);if(!d)return;const h={worksheet:u,workbook:m,rule:d,ruleId:o.ruleId};if(this.fireEvent(this.Event.BeforeSheetDataValidationDelete,h),h.cancel)throw new a.CanceledError}})),this.registerEventHandler(this.Event.BeforeSheetDataValidationDeleteAll,()=>r.beforeCommandExecuted(i=>{if(i.id===n.RemoveSheetAllDataValidationCommand.id){const o=i.params,s=this.getSheetTarget(o.unitId,o.subUnitId);if(!s)return;const{workbook:m,worksheet:u}=s,d={worksheet:u,workbook:m,rules:u.getDataValidations()};if(this.fireEvent(this.Event.BeforeSheetDataValidationDeleteAll,d),d.cancel)throw new a.CanceledError}}))}}E.FUniver.extend(T);class U extends g.FWorkbook{_initialize(){Object.defineProperty(this,"_dataValidationModel",{get(){return this._injector.get(n.SheetDataValidationModel)}})}getValidatorStatus(){return this._injector.get(n.SheetsDataValidationValidatorService).validatorWorkbook(this._workbook.getUnitId())}onDataValidationChange(t){return a.toDisposable(this._dataValidationModel.ruleChange$.pipe(I.filter(e=>e.unitId===this._workbook.getUnitId())).subscribe(t))}onDataValidationStatusChange(t){return a.toDisposable(this._dataValidationModel.validStatusChange$.pipe(I.filter(e=>e.unitId===this._workbook.getUnitId())).subscribe(t))}onBeforeAddDataValidation(t){return a.toDisposable(this._commandService.beforeCommandExecuted((e,r)=>{const i=e.params;if(e.id===n.AddSheetDataValidationCommand.id){if(i.unitId!==this._workbook.getUnitId())return;if(t(i,r)===!1)throw new Error("Command is stopped by the hook onBeforeAddDataValidation")}}))}onBeforeUpdateDataValidationCriteria(t){return a.toDisposable(this._commandService.beforeCommandExecuted((e,r)=>{const i=e.params;if(e.id===n.UpdateSheetDataValidationSettingCommand.id){if(i.unitId!==this._workbook.getUnitId())return;if(t(i,r)===!1)throw new Error("Command is stopped by the hook onBeforeUpdateDataValidationCriteria")}}))}onBeforeUpdateDataValidationRange(t){return a.toDisposable(this._commandService.beforeCommandExecuted((e,r)=>{const i=e.params;if(e.id===n.UpdateSheetDataValidationRangeCommand.id){if(i.unitId!==this._workbook.getUnitId())return;if(t(i,r)===!1)throw new Error("Command is stopped by the hook onBeforeUpdateDataValidationRange")}}))}onBeforeUpdateDataValidationOptions(t){return a.toDisposable(this._commandService.beforeCommandExecuted((e,r)=>{const i=e.params;if(e.id===n.UpdateSheetDataValidationOptionsCommand.id){if(i.unitId!==this._workbook.getUnitId())return;if(t(i,r)===!1)throw new Error("Command is stopped by the hook onBeforeUpdateDataValidationOptions")}}))}onBeforeDeleteDataValidation(t){return a.toDisposable(this._commandService.beforeCommandExecuted((e,r)=>{const i=e.params;if(e.id===n.RemoveSheetDataValidationCommand.id){if(i.unitId!==this._workbook.getUnitId())return;if(t(i,r)===!1)throw new Error("Command is stopped by the hook onBeforeDeleteDataValidation")}}))}onBeforeDeleteAllDataValidation(t){return a.toDisposable(this._commandService.beforeCommandExecuted((e,r)=>{const i=e.params;if(e.id===n.RemoveSheetAllDataValidationCommand.id){if(i.unitId!==this._workbook.getUnitId())return;if(t(i,r)===!1)throw new Error("Command is stopped by the hook onBeforeDeleteAllDataValidation")}}))}}g.FWorkbook.extend(U);class y extends g.FWorksheet{getDataValidations(){return this._injector.get(D.DataValidationModel).getRules(this._workbook.getUnitId(),this._worksheet.getSheetId()).map(e=>new p(e,this._worksheet,this._injector))}getValidatorStatus(){return this._injector.get(n.SheetsDataValidationValidatorService).validatorWorksheet(this._workbook.getUnitId(),this._worksheet.getSheetId())}getValidatorStatusAsync(){return this.getValidatorStatus()}getDataValidation(t){const r=this._injector.get(D.DataValidationModel).getRuleById(this._workbook.getUnitId(),this._worksheet.getSheetId(),t);return r?new p(r,this._worksheet,this._injector):null}}g.FWorksheet.extend(y);class b{get SheetDataValidationChanged(){return"SheetDataValidationChanged"}get SheetDataValidatorStatusChanged(){return"SheetDataValidatorStatusChanged"}get BeforeSheetDataValidationAdd(){return"BeforeSheetDataValidationAdd"}get BeforeSheetDataValidationDelete(){return"BeforeSheetDataValidationDelete"}get BeforeSheetDataValidationDeleteAll(){return"BeforeSheetDataValidationDeleteAll"}get BeforeSheetDataValidationCriteriaUpdate(){return"BeforeSheetDataValidationCriteriaUpdate"}get BeforeSheetDataValidationRangeUpdate(){return"BeforeSheetDataValidationRangeUpdate"}get BeforeSheetDataValidationOptionsUpdate(){return"BeforeSheetDataValidationOptionsUpdate"}}E.FEventName.extend(b),l.FDataValidation=p,l.FDataValidationBuilder=_,Object.defineProperty(l,Symbol.toStringTag,{value:"Module"})});
11
11
 
12
12
 
13
13
  // @univerjs/sheets-data-validation-ui/index
14
- (function(Y,u){typeof exports=="object"&&typeof module<"u"?u(exports,require("react/jsx-runtime"),require("@univerjs/core"),require("@univerjs/design"),require("@univerjs/engine-render"),require("@univerjs/sheets"),require("@univerjs/sheets-data-validation"),require("@univerjs/sheets-numfmt"),require("@univerjs/sheets-ui"),require("@univerjs/ui"),require("react"),require("@univerjs/data-validation"),require("@univerjs/docs"),require("rxjs"),require("@univerjs/engine-formula"),require("@univerjs/sheets-formula-ui")):typeof define=="function"&&define.amd?define(["exports","react/jsx-runtime","@univerjs/core","@univerjs/design","@univerjs/engine-render","@univerjs/sheets","@univerjs/sheets-data-validation","@univerjs/sheets-numfmt","@univerjs/sheets-ui","@univerjs/ui","react","@univerjs/data-validation","@univerjs/docs","rxjs","@univerjs/engine-formula","@univerjs/sheets-formula-ui"],u):(Y=typeof globalThis<"u"?globalThis:Y||self,u(Y.UniverSheetsDataValidationUi={},Y.React,Y.UniverCore,Y.UniverDesign,Y.UniverEngineRender,Y.UniverSheets,Y.UniverSheetsDataValidation,Y.UniverSheetsNumfmt,Y.UniverSheetsUi,Y.UniverUi,Y.React,Y.UniverDataValidation,Y.UniverDocs,Y.rxjs,Y.UniverEngineFormula,Y.UniverSheetsFormulaUi))})(this,function(Y,u,o,L,B,X,V,Gt,k,z,E,J,qt,re,et,tt){"use strict";var Ga=Object.defineProperty;var qa=(Y,u,o)=>u in Y?Ga(Y,u,{enumerable:!0,configurable:!0,writable:!0,value:o}):Y[u]=o;var O=(Y,u,o)=>qa(Y,typeof u!="symbol"?u+"":u,o);var Je,Qe;var Zt=Object.defineProperty,Jt=Object.getOwnPropertyDescriptor,Qt=(e,t,a,n)=>{for(var i=n>1?void 0:n?Jt(t,a):t,r=e.length-1,s;r>=0;r--)(s=e[r])&&(i=(n?s(t,a,i):s(i))||i);return n&&i&&Zt(t,a,i),i},Pe=(e,t)=>(a,n)=>t(a,n,e);let Re=class extends o.Disposable{constructor(e,t,a,n,i){super(),this._sheetInterceptorService=e,this._dataValidationModel=t,this._dataValidatorRegistryService=a,this._dialogService=n,this._localeService=i,this._initEditorBridgeInterceptor()}_initEditorBridgeInterceptor(){this._sheetInterceptorService.writeCellInterceptor.intercept(X.AFTER_CELL_EDIT_ASYNC,{handler:async(e,t,a)=>{var C;const n=await e,{worksheet:i,row:r,col:s,unitId:l,subUnitId:d,workbook:p}=t,h=this._dataValidationModel.getRuleIdByLocation(l,d,r,s),f=h?this._dataValidationModel.getRuleById(l,d,h):void 0;if(!f||f.errorStyle!==o.DataValidationErrorStyle.STOP)return a(Promise.resolve(n));const c=await this._dataValidatorRegistryService.getValidatorItem(f.type);if(!c||await c.validator({value:V.getCellValueOrigin(n),interceptValue:V.getCellValueOrigin((C=t==null?void 0:t.origin)!=null?C:n),row:r,column:s,unitId:l,subUnitId:d,worksheet:i,workbook:p,t:n==null?void 0:n.t},f))return a(Promise.resolve(n));const v=i.getCellRaw(r,s);return this._dialogService.open({width:368,title:{title:this._localeService.t("dataValidation.alert.title")},id:"reject-input-dialog",children:{title:c.getRuleFinalError(f,{row:r,col:s,unitId:l,subUnitId:d})},footer:{title:E.createElement(L.Button,{type:"primary",onClick:()=>this._dialogService.close("reject-input-dialog")},this._localeService.t("dataValidation.alert.ok"))},onClose:()=>{this._dialogService.close("reject-input-dialog")}}),a(Promise.resolve(v))}})}showReject(e){this._dialogService.open({width:368,title:{title:this._localeService.t("dataValidation.alert.title")},id:"reject-input-dialog",children:{title:e},footer:{title:E.createElement(L.Button,{type:"primary",onClick:()=>this._dialogService.close("reject-input-dialog")},this._localeService.t("dataValidation.alert.ok"))},onClose:()=>{this._dialogService.close("reject-input-dialog")}})}};Re=Qt([Pe(0,o.Inject(X.SheetInterceptorService)),Pe(1,o.Inject(V.SheetDataValidationModel)),Pe(2,o.Inject(J.DataValidatorRegistryService)),Pe(3,z.IDialogService),Pe(4,o.Inject(o.LocaleService))],Re);const Dt={dvDateDropdown:"univer-dv-date-dropdown",dvDateDropdownBtns:"univer-dv-date-dropdown-btns"},en=e=>{if(e==null||typeof e=="boolean")return;if(typeof e=="number"||!Number.isNaN(+e))return o.dayjs(o.numfmt.format("yyyy-MM-dd HH:mm:ss",Number(e)));const t=o.dayjs(e);if(t.isValid())return t};function tn(e){var m;const{location:t,hideFn:a}=e,{worksheet:n,row:i,col:r,unitId:s,subUnitId:l,workbook:d}=t,p=o.useDependency(o.ICommandService),h=o.useDependency(Re),f=n.getCell(i,r),c=V.getCellValueOrigin(n.getCellRaw(i,r)),S=en(c),[v,C]=E.useState(S),w=v&&v.isValid()?v:o.dayjs(),g=o.useDependency(o.LocaleService),y=o.useDependency(V.SheetDataValidationModel),D=y.getRuleByLocation(s,l,i,r);if(!D)return null;const b=y.getValidator(D.type);if(!f||!b)return;const _=!!((m=D.bizInfo)!=null&&m.showTime),I=async()=>{var U,j,$;if(!w)return;const A=w.format(_?"YYYY-MM-DD HH:mm:ss":"YYYY-MM-DD 00:00:00"),W=(U=o.numfmt.parseDate(A))==null?void 0:U.v,F=d.getStyles().getStyleByCell(f),P=($=(j=F==null?void 0:F.n)==null?void 0:j.pattern)!=null?$:"",N=Gt.getPatternType(P);D.errorStyle!==o.DataValidationErrorStyle.STOP||await b.validator({value:W,unitId:s,subUnitId:l,row:i,column:r,worksheet:n,workbook:d,interceptValue:A.replace("Z","").replace("T"," "),t:o.CellValueType.NUMBER},D)?(a(),await p.executeCommand(k.SetCellEditVisibleOperation.id,{visible:!1,eventType:B.DeviceInputEventType.Keyboard,unitId:s,keycode:z.KeyCode.ESC}),await p.executeCommand(X.SetRangeValuesCommand.id,{unitId:s,subUnitId:l,range:{startColumn:r,endColumn:r,startRow:i,endRow:i},value:{v:W,t:2,p:null,f:null,si:null,s:{n:{pattern:_?N==="datetime"?P:"yyyy-MM-dd hh:mm:ss":N==="date"?P:"yyyy-MM-dd"}}}})):h.showReject(b.getRuleFinalError(D,{row:i,col:r,unitId:s,subUnitId:l}))};return u.jsxs("div",{className:Dt.dvDateDropdown,children:[u.jsx(L.DatePanel,{defaultValue:w,pickerValue:w,showTime:_||void 0,onSelect:async T=>{C(T)},onPanelChange:T=>{C(T)},disabledDate:T=>!o.numfmt.parseDate(T.format("YYYY-MM-DD"))}),u.jsx("div",{className:Dt.dvDateDropdownBtns,children:u.jsx(L.Button,{size:"small",type:"primary",onClick:I,disabled:!w.isValid(),children:g.t("dataValidation.alert.ok")})})]})}var se=function(){return se=Object.assign||function(e){for(var t,a=1,n=arguments.length;a<n;a++){t=arguments[a];for(var i in t)Object.prototype.hasOwnProperty.call(t,i)&&(e[i]=t[i])}return e},se.apply(this,arguments)},nn=function(e,t){var a={};for(var n in e)Object.prototype.hasOwnProperty.call(e,n)&&t.indexOf(n)<0&&(a[n]=e[n]);if(e!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(e);i<n.length;i++)t.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(e,n[i])&&(a[n[i]]=e[n[i]]);return a},ve=E.forwardRef(function(e,t){var a=e.icon,n=e.id,i=e.className,r=e.extend,s=nn(e,["icon","id","className","extend"]),l="univerjs-icon univerjs-icon-".concat(n," ").concat(i||"").trim(),d=E.useRef("_".concat(rn()));return yt(a,"".concat(n),{defIds:a.defIds,idSuffix:d.current},se({ref:t,className:l},s),r)});function yt(e,t,a,n,i){return E.createElement(e.tag,se(se({key:t},an(e,a,i)),n),(on(e,a).children||[]).map(function(r,s){return yt(r,"".concat(t,"-").concat(e.tag,"-").concat(s),a,void 0,i)}))}function an(e,t,a){var n=se({},e.attrs);a!=null&&a.colorChannel1&&n.fill==="colorChannel1"&&(n.fill=a.colorChannel1);var i=t.defIds;return!i||i.length===0||(e.tag==="use"&&n["xlink:href"]&&(n["xlink:href"]=n["xlink:href"]+t.idSuffix),Object.entries(n).forEach(function(r){var s=r[0],l=r[1];typeof l=="string"&&(n[s]=l.replace(/url\(#(.*)\)/,"url(#$1".concat(t.idSuffix,")")))})),n}function on(e,t){var a,n=t.defIds;return!n||n.length===0?e:e.tag==="defs"&&(!((a=e.children)===null||a===void 0)&&a.length)?se(se({},e),{children:e.children.map(function(i){return typeof i.attrs.id=="string"&&n&&n.indexOf(i.attrs.id)>-1?se(se({},i),{attrs:se(se({},i.attrs),{id:i.attrs.id+t.idSuffix})}):i})}):e}function rn(){return Math.random().toString(36).substring(2,8)}ve.displayName="UniverIcon";var sn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M14.1544 3.75557C14.3887 3.98988 14.3887 4.36978 14.1544 4.6041L6.51409 12.2444C6.40157 12.3569 6.24896 12.4201 6.08983 12.4201C5.9307 12.4201 5.77808 12.3569 5.66556 12.2444L1.84541 8.42425C1.6111 8.18993 1.6111 7.81003 1.84541 7.57572C2.07973 7.34141 2.45963 7.34141 2.69394 7.57572L6.08983 10.9716L13.3059 3.75557C13.5402 3.52126 13.9201 3.52126 14.1544 3.75557Z",fillRule:"evenodd",clipRule:"evenodd"}}]},wt=E.forwardRef(function(e,t){return E.createElement(ve,Object.assign({},e,{id:"check-mark-single",ref:t,icon:sn}))});wt.displayName="CheckMarkSingle";var ln={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"}}]},Vt=E.forwardRef(function(e,t){return E.createElement(ve,Object.assign({},e,{id:"data-validation-single",ref:t,icon:ln}))});Vt.displayName="DataValidationSingle";var dn={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"}}]},nt=E.forwardRef(function(e,t){return E.createElement(ve,Object.assign({},e,{id:"delete-single",ref:t,icon:dn}))});nt.displayName="DeleteSingle";var cn={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"}}]},Et=E.forwardRef(function(e,t){return E.createElement(ve,Object.assign({},e,{id:"increase-single",ref:t,icon:cn}))});Et.displayName="IncreaseSingle";var un={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"}}]},Mt=E.forwardRef(function(e,t){return E.createElement(ve,Object.assign({},e,{id:"more-down-single",ref:t,icon:un}))});Mt.displayName="MoreDownSingle";var pn={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"}}]},bt=E.forwardRef(function(e,t){return E.createElement(ve,Object.assign({},e,{id:"more-up-single",ref:t,icon:pn}))});bt.displayName="MoreUpSingle";var hn={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"}}]}]},Lt=E.forwardRef(function(e,t){return E.createElement(ve,Object.assign({},e,{id:"sequence-single",ref:t,icon:hn}))});Lt.displayName="SequenceSingle";var fn=Object.defineProperty,vn=Object.getOwnPropertyDescriptor,mn=(e,t,a,n)=>{for(var i=n>1?void 0:n?vn(t,a):t,r=e.length-1,s;r>=0;r--)(s=e[r])&&(i=(n?s(t,a,i):s(i))||i);return n&&i&&fn(t,a,i),i},Tt=(e,t)=>(a,n)=>t(a,n,e);let ue=class extends o.Disposable{constructor(t,a){super();O(this,"_open$",new re.BehaviorSubject(!1));O(this,"open$",this._open$.pipe(re.distinctUntilChanged()));O(this,"_activeRule");O(this,"_activeRule$",new re.BehaviorSubject(void 0));O(this,"activeRule$",this._activeRule$.asObservable());O(this,"_closeDisposable",null);this._univerInstanceService=t,this._sidebarService=a,this.disposeWithMe(this._univerInstanceService.getCurrentTypeOfUnit$(o.UniverInstanceType.UNIVER_SHEET).pipe(re.filter(n=>!n)).subscribe(()=>{this.close()})),this.disposeWithMe(this._sidebarService.sidebarOptions$.subscribe(n=>{n.id===Ne&&(n.visible||setTimeout(()=>{this._sidebarService.sidebarOptions$.next({visible:!1})}))}))}get activeRule(){return this._activeRule}get isOpen(){return this._open$.getValue()}dispose(){var t;super.dispose(),this._open$.next(!1),this._open$.complete(),this._activeRule$.complete(),(t=this._closeDisposable)==null||t.dispose()}open(){this._open$.next(!0)}close(){var t;this._open$.next(!1),(t=this._closeDisposable)==null||t.dispose()}setCloseDisposable(t){this._closeDisposable=o.toDisposable(()=>{t.dispose(),this._closeDisposable=null})}setActiveRule(t){this._activeRule=t,this._activeRule$.next(t)}};ue=mn([Tt(0,o.IUniverInstanceService),Tt(1,z.ISidebarService)],ue);function gn(){const e=o.useDependency(me),t=z.useObservable(e.activeDropdown$,e.activeDropdown),a=o.useDependency(z.ComponentManager);if(!t)return null;const{location:n,componentKey:i}=t,r=a.get(i),s=`${n.unitId}-${n.subUnitId}-${n.row}-${n.col}`;if(!r)return null;const l=()=>{e.hideDropdown()};return u.jsx(r,{location:n,hideFn:l},s)}const Ot="sheet.ui.dropdown";var Sn=Object.defineProperty,_n=Object.getOwnPropertyDescriptor,In=(e,t,a,n)=>{for(var i=n>1?void 0:n?_n(t,a):t,r=e.length-1,s;r>=0;r--)(s=e[r])&&(i=(n?s(t,a,i):s(i))||i);return n&&i&&Sn(t,a,i),i},Se=(e,t)=>(a,n)=>t(a,n,e);let me=class extends o.Disposable{constructor(t,a,n,i,r,s,l){super();O(this,"_activeDropdown");O(this,"_activeDropdown$",new re.Subject);O(this,"_currentPopup",null);O(this,"activeDropdown$",this._activeDropdown$.asObservable());O(this,"_zenVisible",!1);this._canvasPopupManagerService=t,this._univerInstanceService=a,this._dataValidatorRegistryService=n,this._zenZoneService=i,this._renderManagerService=r,this._dataValidationModel=s,this._sheetsSelectionsService=l,this._init(),this._initSelectionChange(),this.disposeWithMe(()=>{this._activeDropdown$.complete()})}get activeDropdown(){return this._activeDropdown}_init(){this.disposeWithMe(this._zenZoneService.visible$.subscribe(t=>{this._zenVisible=t,t&&this.hideDropdown()}))}_getDropdownByCell(t,a,n,i){const r=t?this._univerInstanceService.getUnit(t,o.UniverInstanceType.UNIVER_SHEET):this._univerInstanceService.getCurrentUnitForType(o.UniverInstanceType.UNIVER_SHEET);if(!r)return;const s=a?r.getSheetBySheetId(a):r.getActiveSheet();if(!s)return;const l=this._dataValidationModel.getRuleByLocation(r.getUnitId(),s.getSheetId(),n,i);if(!l)return;const d=this._dataValidatorRegistryService.getValidatorItem(l.type);return d==null?void 0:d.dropdown}_initSelectionChange(){this.disposeWithMe(this._sheetsSelectionsService.selectionMoveEnd$.subscribe(t=>{t&&t.every(a=>!(a.primary&&this._getDropdownByCell(a.primary.unitId,a.primary.sheetId,a.primary.actualRow,a.primary.actualColumn)))&&this.hideDropdown()}))}showDropdown(t,a=!0){const{location:n}=t,{row:i,col:r,unitId:s,subUnitId:l}=n;if(this._currentPopup&&this._currentPopup.dispose(),this._zenVisible)return;this._activeDropdown=t,this._activeDropdown$.next(this._activeDropdown);const d=this._renderManagerService.getRenderById(o.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),p=this._canvasPopupManagerService.attachPopupToCell(i,r,{componentKey:Ot,onClickOutside:()=>{a&&this.hideDropdown()},offset:[0,3],excludeOutside:[d==null?void 0:d.engine.getCanvasElement()].filter(Boolean)},s,l);if(!p)throw new Error("[DataValidationDropdownManagerService]: cannot show dropdown!");const h=new o.DisposableCollection;h.add(p),h.add({dispose:()=>{var f,c;(c=(f=this._activeDropdown)==null?void 0:f.onHide)==null||c.call(f)}}),this._currentPopup=h}hideDropdown(){this._activeDropdown&&(this._currentPopup&&this._currentPopup.dispose(),this._currentPopup=null,this._activeDropdown=null,this._activeDropdown$.next(null))}showDataValidationDropdown(t,a,n,i,r){const s=this._univerInstanceService.getUnit(t,o.UniverInstanceType.UNIVER_SHEET);if(!s)return;const l=s.getSheetBySheetId(a);if(!l)return;const d=this._dataValidationModel.getRuleByLocation(s.getUnitId(),l.getSheetId(),n,i);if(!d)return;const p=this._dataValidatorRegistryService.getValidatorItem(d.type);if(!p||!p.dropdown){this.hideDropdown();return}this.showDropdown({location:{workbook:s,worksheet:l,row:n,col:i,unitId:t,subUnitId:a},componentKey:p.dropdown,onHide:r})}};me=In([Se(0,o.Inject(k.SheetCanvasPopManagerService)),Se(1,o.IUniverInstanceService),Se(2,o.Inject(J.DataValidatorRegistryService)),Se(3,z.IZenZoneService),Se(4,B.IRenderManagerService),Se(5,o.Inject(V.SheetDataValidationModel)),Se(6,o.Inject(X.SheetsSelectionsService))],me);const Ne="DataValidationPanel",_e={id:"data-validation.operation.open-validation-panel",type:o.CommandType.OPERATION,handler(e,t){if(!t)return!1;const{ruleId:a,isAdd:n}=t,i=e.get(ue),r=e.get(J.DataValidationModel),s=e.get(o.IUniverInstanceService),l=e.get(z.ISidebarService),d=X.getSheetCommandTarget(s);if(!d)return!1;const{unitId:p,subUnitId:h}=d,f=a?r.getRuleById(p,h,a):void 0;i.open(),i.setActiveRule(f&&{unitId:p,subUnitId:h,rule:f});const c=l.open({id:Ne,header:{title:n?"dataValidation.panel.addTitle":"dataValidation.panel.title"},children:{label:Ne},width:312,onClose:()=>i.close()});return i.setCloseDisposable(c),!0}},at={id:"data-validation.operation.close-validation-panel",type:o.CommandType.OPERATION,handler(e){return e.get(ue).close(),!0}},Pt={id:"data-validation.operation.toggle-validation-panel",type:o.CommandType.OPERATION,handler(e){const t=e.get(o.ICommandService),a=e.get(ue);return a.open(),a.isOpen?t.executeCommand(at.id):t.executeCommand(_e.id),!0}},Ue={type:o.CommandType.OPERATION,id:"sheet.operation.show-data-validation-dropdown",handler(e,t){if(!t)return!1;const a=e.get(me),{unitId:n,subUnitId:i,row:r,column:s}=t,l=a.activeDropdown,d=l==null?void 0:l.location;return d&&d.unitId===n&&d.subUnitId===i&&d.row===r&&d.col===s||a.showDataValidationDropdown(n,i,r,s),!0}},Rt={type:o.CommandType.OPERATION,id:"sheet.operation.hide-data-validation-dropdown",handler(e,t){return t?(e.get(me).hideDropdown(),!0):!1}},Ie="#ECECEC",it="sheets-data-validation-ui.config",je={},fe={dvListDropdown:"univer-dv-list-dropdown",dvListDropdownTitle:"univer-dv-list-dropdown-title",dvListDropdownList:"univer-dv-list-dropdown-list",dvListDropdownListContainer:"univer-dv-list-dropdown-list-container",dvListDropdownSelectedIcon:"univer-dv-list-dropdown-selected-icon",dvListDropdownItemContainer:"univer-dv-list-dropdown-item-container",dvListDropdownItem:"univer-dv-list-dropdown-item",dvListDropdownSplit:"univer-dv-list-dropdown-split",dvListDropdownEdit:"univer-dv-list-dropdown-edit"},Cn=e=>{var _,I;const{value:t,onChange:a,multiple:n,options:i,title:r,onEdit:s,style:l,filter:d,location:p}=e,h=o.useDependency(o.LocaleService),f=o.useDependency(o.IConfigService),c=d==null?void 0:d.toLowerCase(),{row:S,col:v,unitId:C,subUnitId:w}=p,g=i.filter(m=>c?m.label.toLowerCase().includes(c):!0),y=(I=(_=f.getConfig(it))==null?void 0:_.showEditOnDropdown)!=null?I:!0,D=o.useDependency(X.SheetPermissionCheckController),b=E.useMemo(()=>D.permissionCheckWithRanges({workbookTypes:[X.WorkbookEditablePermission],rangeTypes:[X.RangeProtectionPermissionEditPoint],worksheetTypes:[X.WorksheetEditPermission]},[{startColumn:v,startRow:S,endColumn:v,endRow:S}],C,w),[D,v,S,C,w]);return u.jsxs("div",{className:fe.dvListDropdown,style:l,children:[u.jsx("div",{className:fe.dvListDropdownTitle,children:r}),u.jsx("div",{className:fe.dvListDropdownList,children:u.jsx(L.Scrollbar,{children:u.jsx("div",{className:fe.dvListDropdownListContainer,children:g.map((m,T)=>{const A=t.indexOf(m.value)>-1,W=()=>{let P;A?P=new Set(t.filter(U=>U!==m.value)):P=new Set(n?[...t,m.value]:[m.value]);const N=[];i.forEach(U=>{P.has(U.value)&&N.push(U.value)}),a(N)},F=m.label.toLocaleLowerCase().indexOf(c);return u.jsxs("div",{className:fe.dvListDropdownItemContainer,onClick:W,children:[u.jsx("div",{className:fe.dvListDropdownItem,style:{background:m.color||Ie},children:c&&m.label.toLowerCase().includes(c)?u.jsxs(u.Fragment,{children:[u.jsx("span",{children:m.label.substring(0,F)}),u.jsx("span",{style:{fontWeight:"bold"},children:m.label.substring(F,F+c.length)}),u.jsx("span",{children:m.label.substring(F+c.length)})]}):m.label}),u.jsx("div",{className:fe.dvListDropdownSelectedIcon,children:A?u.jsx(wt,{}):null})]},T)})})},d)}),y&&b?u.jsxs(u.Fragment,{children:[u.jsx("div",{className:fe.dvListDropdownSplit}),u.jsx("div",{className:fe.dvListDropdownEdit,children:u.jsx("a",{onClick:s,children:h.t("dataValidation.list.edit")})})]}):null]})};function Dn(e){var j,$,q,Z;const{location:t,hideFn:a}=e,{worksheet:n,row:i,col:r,unitId:s,subUnitId:l}=t,d=o.useDependency(J.DataValidationModel),[p,h]=E.useState(""),f=o.useDependency(o.ICommandService),c=o.useDependency(o.LocaleService),[S,v]=E.useState(""),C=o.useDependency(k.IEditorBridgeService),w=o.useDependency(o.IUniverInstanceService),g=E.useMemo(()=>d.ruleChange$.pipe(re.debounceTime(16)),[]),y=o.useDependency(V.SheetDataValidationModel);z.useObservable(g);const D=z.RectPopup.useContext(),b=(($=(j=D.current)==null?void 0:j.right)!=null?$:0)-((Z=(q=D.current)==null?void 0:q.left)!=null?Z:0);if(E.useEffect(()=>{const G=f.onCommandExecuted(ee=>{var te,ae;if(ee.id===qt.RichTextEditingMutation.id){const ie=ee.params,{unitId:le}=ie,oe=w.getUnit(le,o.UniverInstanceType.UNIVER_DOC);if(!oe||!C.isVisible().visible)return;const de=o.BuildTextUtils.transform.getPlainText((ae=(te=oe.getSnapshot().body)==null?void 0:te.dataStream)!=null?ae:"");h(de)}});return()=>{G.dispose()}},[f,C,w]),!n)return null;const _=y.getRuleByLocation(s,l,i,r);if(!_)return null;const I=y.getValidator(_.type);if(!I)return null;const m=n.getCell(i,r),T=(_==null?void 0:_.renderMode)===o.DataValidationRenderMode.CUSTOM||(_==null?void 0:_.renderMode)===void 0;if(!m||!_||!I||I.id.indexOf(o.DataValidationType.LIST)!==0)return;const A=_.type===o.DataValidationType.LIST_MULTIPLE,W=I.getListWithColor(_,s,l),F=S||V.getDataValidationCellValue(n.getCellRaw(i,r)),P=V.deserializeListOptions(F),N=()=>{f.executeCommand(_e.id,{ruleId:_.uid}),a()},U=W.map(G=>({label:G.label,value:G.label,color:T||G.color?G.color:"transparent"}));return u.jsx(Cn,{style:{minWidth:b,maxWidth:Math.max(b,200)},title:A?c.t("dataValidation.listMultiple.dropdown"):c.t("dataValidation.list.dropdown"),value:P,multiple:A,onChange:async G=>{const ee=V.serializeListOptions(G),te={unitId:s,subUnitId:l,range:{startColumn:r,endColumn:r,startRow:i,endRow:i},value:{v:ee,p:null,f:null,si:null}};C.isVisible()&&C.changeVisible({visible:!1,keycode:z.KeyCode.ESC,eventType:B.DeviceInputEventType.Keyboard,unitId:s}),v(ee),A||a(),C.isVisible().visible&&await f.executeCommand(k.SetCellEditVisibleOperation.id,{visible:!1,eventType:B.DeviceInputEventType.Keyboard,unitId:s,keycode:z.KeyCode.ESC}),f.executeCommand(X.SetRangeValuesCommand.id,te)},options:U,onEdit:N,filter:p,location:t})}const ot={dataValidationOptionsButton:"univer-data-validation-options-button",dataValidationOptionsButtonIcon:"univer-data-validation-options-button-icon"};function yn(e){var p;const t=o.useDependency(o.LocaleService),a=o.useDependency(z.ComponentManager),{value:n,onChange:i,extraComponent:r}=e,[s,l]=E.useState(!1),d=r?a.get(r):null;return u.jsxs(u.Fragment,{children:[u.jsxs("div",{className:ot.dataValidationOptionsButton,onClick:()=>l(!s),children:[t.t("dataValidation.panel.options"),s?u.jsx(bt,{className:ot.dataValidationOptionsButtonIcon}):u.jsx(Mt,{className:ot.dataValidationOptionsButtonIcon})]}),s&&u.jsxs(u.Fragment,{children:[d?u.jsx(d,{value:n,onChange:i}):null,u.jsx(L.FormLayout,{label:t.t("dataValidation.panel.invalid"),children:u.jsxs(L.RadioGroup,{value:`${(p=n.errorStyle)!=null?p:o.DataValidationErrorStyle.WARNING}`,onChange:h=>i({...n,errorStyle:+h}),children:[u.jsx(L.Radio,{value:`${o.DataValidationErrorStyle.WARNING}`,children:t.t("dataValidation.panel.showWarning")}),u.jsx(L.Radio,{value:`${o.DataValidationErrorStyle.STOP}`,children:t.t("dataValidation.panel.rejectInput")})]})}),u.jsx(L.FormLayout,{label:t.t("dataValidation.panel.messageInfo"),children:u.jsx(L.Checkbox,{checked:n.showErrorMessage,onChange:()=>i({...n,showErrorMessage:!n.showErrorMessage}),children:t.t("dataValidation.panel.showInfo")})}),n.showErrorMessage?u.jsx(L.FormLayout,{children:u.jsx(L.Input,{value:n.error,onChange:h=>i({...n,error:h})})}):null]})]})}const we={dataValidationDetail:"univer-data-validation-detail",dataValidationDetailFormItem:"univer-data-validation-detail-form-item",dataValidationDetailButtons:"univer-data-validation-detail-buttons",dataValidationDetailButton:"univer-data-validation-detail-button"},wn=e=>o.debounce(async(t,a,n,i)=>{const r=await e.executeCommand(t,a,n);i==null||i(r)},1e3);function Vn(e,t,a){var n,i,r,s;return t?((i=(n=e.getUnit(t))==null?void 0:n.getSheetBySheetName(a))==null?void 0:i.getSheetId())||"":((s=(r=e.getCurrentUnitForType(o.UniverInstanceType.UNIVER_SHEET))==null?void 0:r.getSheetBySheetName(a))==null?void 0:s.getSheetId())||""}function En(){var de;const[e,t]=E.useState(0),a=o.useDependency(ue),n=z.useObservable(a.activeRule$,a.activeRule),{unitId:i,subUnitId:r,rule:s}=n||{},l=s.uid,d=o.useDependency(J.DataValidatorRegistryService),p=o.useDependency(o.IUniverInstanceService),h=o.useDependency(z.ComponentManager),f=o.useDependency(o.ICommandService),c=o.useDependency(J.DataValidationModel),S=o.useDependency(o.LocaleService),[v,C]=E.useState(s),w=d.getValidatorItem(v.type),[g,y]=E.useState(!1),D=d.getValidatorsByScope(J.DataValidatorRegistryScope.SHEET),[b,_]=E.useState(()=>v.ranges.map(R=>({unitId:"",sheetId:"",range:R}))),I=E.useMemo(()=>wn(f),[f]),[m,T]=E.useState(!1),A=E.useRef({}),[W,F]=E.useState(!1),P=o.useDependency(X.SheetsSelectionsService);if(E.useEffect(()=>()=>{const R=P.getCurrentLastSelection();R&&P.setSelections([R])},[P]),E.useEffect(()=>{f.onCommandExecuted(R=>{(R.id===o.UndoCommand.id||R.id===o.RedoCommand.id)&&setTimeout(()=>{const M=c.getRuleById(i,r,l);t(H=>H+1),M&&(C(M),_(M.ranges.map(H=>({unitId:"",sheetId:"",range:H}))))},20)})},[f,c,l,r,i]),!w)return null;const N=w.operators,U=w.operatorNames,j=v.operator?J.TWO_FORMULA_OPERATOR_COUNT.includes(v.operator):!1,$=()=>{!v.ranges.length||m||(w.validatorFormula(v,i,r).success?a.setActiveRule(null):y(!0))},q=z.useEvent(R=>{const M=R.split(",").filter(Boolean).map(et.deserializeRangeWithSheet).map(K=>{const ge=K.sheetName;if(ge){const Ka=Vn(p,K.unitId,ge);return{...K,sheetId:Ka}}return{...K,sheetId:""}});if(o.isUnitRangesEqual(M,b))return;_(M);const H=M.filter(K=>(!K.unitId||K.unitId===i)&&(!K.sheetId||K.sheetId===r)).map(K=>K.range);if(C({...v,ranges:H}),H.length===0)return;const x={unitId:i,subUnitId:r,ruleId:l,ranges:H};I(V.UpdateSheetDataValidationRangeCommand.id,x)}),Z=R=>{if(o.shallowEqual(R,J.getRuleSetting(v)))return;C({...v,...R});const M={unitId:i,subUnitId:r,ruleId:l,setting:R};I(V.UpdateSheetDataValidationSettingCommand.id,M,void 0)},G=async()=>{await f.executeCommand(V.RemoveSheetDataValidationCommand.id,{ruleId:l,unitId:i,subUnitId:r}),a.setActiveRule(null)},ee={type:v.type,operator:v.operator,formula1:v.formula1,formula2:v.formula2,allowBlank:v.allowBlank},te=R=>{const M=d.getValidatorItem(R);if(!M)return;const H=M.operators,x=c.getRuleById(i,r,l),K=R===(x==null?void 0:x.type)||R.includes("list")&&(x!=null&&x.type.includes("list"))?{...x,type:R}:{...v,type:R,operator:H[0],formula1:void 0,formula2:void 0};C(K),f.executeCommand(V.UpdateSheetDataValidationSettingCommand.id,{unitId:i,subUnitId:r,ruleId:v.uid,setting:J.getRuleSetting(K)})},ae=h.get(w.formulaInput),ie=E.useMemo(()=>b.map(R=>et.serializeRange(R.range)).join(","),[]),le=J.getRuleOptions(v),oe=R=>{o.shallowEqual(R,J.getRuleOptions(v))||(C({...v,...R}),I(V.UpdateSheetDataValidationOptionsCommand.id,{unitId:i,subUnitId:r,ruleId:l,options:R}))};return z.useSidebarClick(R=>{var H;const M=(H=A.current)==null?void 0:H.handleOutClick;M&&M(R,()=>F(!1))}),u.jsxs("div",{className:we.dataValidationDetail,children:[u.jsx(L.FormLayout,{label:S.t("dataValidation.panel.range"),error:!v.ranges.length||m?S.t("dataValidation.panel.rangeError"):"",children:u.jsx(tt.RangeSelector,{unitId:i,subUnitId:r,initValue:ie,onChange:q,onFocus:()=>F(!0),isFocus:W,actions:A.current,onVerify:R=>T(!R)})}),u.jsx(L.FormLayout,{label:S.t("dataValidation.panel.type"),children:u.jsx(L.Select,{options:D==null?void 0:D.map(R=>({label:S.t(R.title),value:R.id})),value:v.type,onChange:te,className:we.dataValidationDetailFormItem})}),N!=null&&N.length?u.jsx(L.FormLayout,{label:S.t("dataValidation.panel.operator"),children:u.jsx(L.Select,{options:N.map((R,M)=>({value:`${R}`,label:U[M]})),value:`${v.operator}`,onChange:R=>{Z({...ee,operator:R})},className:we.dataValidationDetailFormItem})}):null,ae?u.jsx(ae,{isTwoFormula:j,value:{formula1:v.formula1,formula2:v.formula2},onChange:R=>{Z({...ee,...R})},showError:g,validResult:w.validatorFormula(v,i,r),unitId:i,subUnitId:r,ruleId:l},e+v.type):null,u.jsx(L.FormLayout,{children:u.jsx(L.Checkbox,{checked:(de=v.allowBlank)!=null?de:!0,onChange:()=>{var R;return Z({...ee,allowBlank:!((R=v.allowBlank)==null||R)})},children:S.t("dataValidation.panel.allowBlank")})}),u.jsx(yn,{value:le,onChange:oe,extraComponent:w.optionsInput}),u.jsxs("div",{className:we.dataValidationDetailButtons,children:[u.jsx(L.Button,{className:we.dataValidationDetailButton,onClick:G,children:S.t("dataValidation.panel.removeRule")}),u.jsx(L.Button,{className:we.dataValidationDetailButton,type:"primary",onClick:$,children:S.t("dataValidation.panel.done")})]})]})}const Be={dataValidationItemContainer:"univer-data-validation-item-container",dataValidationItemTitle:"univer-data-validation-item-title",dataValidationItemContent:"univer-data-validation-item-content",dataValidationItemIcon:"univer-data-validation-item-icon"},Mn=e=>{const{rule:t,onClick:a,unitId:n,subUnitId:i,disable:r}=e,s=o.useDependency(J.DataValidatorRegistryService),l=o.useDependency(o.ICommandService),d=o.useDependency(k.IMarkSelectionService),p=s.getValidatorItem(t.type),h=E.useRef(void 0),[f,c]=E.useState(!1),S=v=>{l.executeCommand(V.RemoveSheetDataValidationCommand.id,{ruleId:t.uid,unitId:n,subUnitId:i}),v.stopPropagation()};return E.useEffect(()=>()=>{var v;h.current&&((v=h.current)==null||v.forEach(C=>{C&&d.removeShape(C)}))},[d]),u.jsxs("div",{className:Be.dataValidationItemContainer,onClick:a,onMouseEnter:()=>{r||(c(!0),h.current=t.ranges.map(v=>d.addShape({range:v,style:{fill:"rgba(73, 184, 17, 0.05)",strokeWidth:1,stroke:"#49B811",widgets:{}},primary:null})))},onMouseLeave:()=>{var v;c(!1),(v=h.current)==null||v.forEach(C=>{C&&d.removeShape(C)}),h.current=void 0},children:[u.jsx("div",{className:Be.dataValidationItemTitle,children:p==null?void 0:p.generateRuleName(t)}),u.jsx("div",{className:Be.dataValidationItemContent,children:t.ranges.map(v=>et.serializeRange(v)).join(",")}),f?u.jsx("div",{className:Be.dataValidationItemIcon,onClick:S,children:u.jsx(nt,{})}):null]})},ke={dataValidationList:"univer-data-validation-list",dataValidationListButtons:"univer-data-validation-list-buttons",dataValidationListButton:"univer-data-validation-list-button"};function bn(){const e=o.useDependency(o.IUniverInstanceService),t=z.useObservable(()=>e.getCurrentTypeOfUnit$(o.UniverInstanceType.UNIVER_SHEET),void 0,void 0,[]);return t?u.jsx(Ln,{workbook:t}):null}function Ln(e){const t=o.useDependency(V.SheetDataValidationModel),a=o.useDependency(o.IUniverInstanceService),n=o.useDependency(o.ICommandService),i=o.useDependency(o.Injector),r=o.useDependency(ue),s=o.useDependency(o.LocaleService),[l,d]=E.useState([]),{workbook:p}=e,h=z.useObservable(p.activeSheet$,void 0,!0),f=p.getUnitId(),c=h==null?void 0:h.getSheetId();E.useEffect(()=>{d(t.getRules(f,c));const y=t.ruleChange$.subscribe(D=>{D.unitId===f&&D.subUnitId===c&&d(t.getRules(f,c))});return()=>{y.unsubscribe()}},[f,c,t]);const S=async()=>{const y=V.createDefaultNewRule(i),D={unitId:f,subUnitId:c,rule:y};await n.executeCommand(V.AddSheetDataValidationCommand.id,D),r.setActiveRule({unitId:f,subUnitId:c,rule:y})},v=()=>{n.executeCommand(V.RemoveSheetAllDataValidationCommand.id,{unitId:f,subUnitId:c})},w=(y=>{const D=a.getCurrentUnitForType(o.UniverInstanceType.UNIVER_SHEET),b=D.getActiveSheet(),_=D.getUnitId(),I=b.getSheetId();return y.map(T=>X.checkRangesEditablePermission(i,_,I,T.ranges)?{...T}:{...T,disable:!0})})(l),g=w==null?void 0:w.some(y=>y.disable);return u.jsxs("div",{className:ke.dataValidationList,children:[w==null?void 0:w.map(y=>{var D;return u.jsx(Mn,{unitId:f,subUnitId:c,onClick:()=>{y.disable||r.setActiveRule({unitId:f,subUnitId:c,rule:y})},rule:y,disable:(D=y.disable)!=null?D:!1},y.uid)}),u.jsxs("div",{className:ke.dataValidationListButtons,children:[l.length&&!g?u.jsx(L.Button,{className:ke.dataValidationListButton,onClick:v,children:s.t("dataValidation.panel.removeAll")}):null,u.jsx(L.Button,{className:ke.dataValidationListButton,type:"primary",onClick:S,children:s.t("dataValidation.panel.add")})]})]})}const Tn=()=>{const e=o.useDependency(ue),t=z.useObservable(e.activeRule$,e.activeRule);return t?u.jsx(En,{},t.rule.uid):u.jsx(bn,{})},We="data-validation.list.dropdown",rt="data-validation.date.dropdown",$e={type:o.CommandType.COMMAND,id:"data-validation.command.addRuleAndOpen",handler(e){const t=e.get(o.IUniverInstanceService),a=X.getSheetCommandTarget(t);if(!a)return!1;const{workbook:n,worksheet:i}=a,r=V.createDefaultNewRule(e),s=e.get(o.ICommandService),l=n.getUnitId(),d=i.getSheetId(),p={rule:r,unitId:l,subUnitId:d};return s.syncExecuteCommand(V.AddSheetDataValidationCommand.id,p)?(s.syncExecuteCommand(_e.id,{ruleId:r.uid,isAdd:!0}),!0):!1}};var On=Object.defineProperty,Pn=Object.getOwnPropertyDescriptor,Rn=(e,t,a,n)=>{for(var i=n>1?void 0:n?Pn(t,a):t,r=e.length-1,s;r>=0;r--)(s=e[r])&&(i=(n?s(t,a,i):s(i))||i);return n&&i&&On(t,a,i),i},Ve=(e,t)=>(a,n)=>t(a,n,e);const Ce="SHEET_DATA_VALIDATION_ALERT";let Ae=class extends o.Disposable{constructor(e,t,a,n,i,r){super(),this._hoverManagerService=e,this._cellAlertManagerService=t,this._univerInstanceService=a,this._localeService=n,this._zenZoneService=i,this._dataValidationModel=r,this._init()}_init(){this._initCellAlertPopup(),this._initZenService()}_initCellAlertPopup(){this.disposeWithMe(this._hoverManagerService.currentCell$.pipe(re.debounceTime(100)).subscribe(e=>{var t;if(e){const a=this._univerInstanceService.getUnit(e.location.unitId,o.UniverInstanceType.UNIVER_SHEET),n=a.getSheetBySheetId(e.location.subUnitId);if(!n)return;const i=this._dataValidationModel.getRuleByLocation(e.location.unitId,e.location.subUnitId,e.location.row,e.location.col);if(!i){this._cellAlertManagerService.removeAlert(Ce);return}if(this._dataValidationModel.validator(i,{...e.location,workbook:a,worksheet:n})===o.DataValidationStatus.INVALID){const s=this._cellAlertManagerService.currentAlert.get(Ce),l=(t=s==null?void 0:s.alert)==null?void 0:t.location;if(l&&l.row===e.location.row&&l.col===e.location.col&&l.subUnitId===e.location.subUnitId&&l.unitId===e.location.unitId){this._cellAlertManagerService.removeAlert(Ce);return}const d=this._dataValidationModel.getValidator(i.type);if(!d){this._cellAlertManagerService.removeAlert(Ce);return}this._cellAlertManagerService.showAlert({type:k.CellAlertType.ERROR,title:this._localeService.t("dataValidation.error.title"),message:d==null?void 0:d.getRuleFinalError(i,e.location),location:e.location,width:200,height:74,key:Ce});return}}this._cellAlertManagerService.removeAlert(Ce)}))}_initZenService(){this.disposeWithMe(this._zenZoneService.visible$.subscribe(e=>{e&&this._cellAlertManagerService.removeAlert(Ce)}))}};Ae=Rn([Ve(0,o.Inject(k.HoverManagerService)),Ve(1,o.Inject(k.CellAlertManagerService)),Ve(2,o.IUniverInstanceService),Ve(3,o.Inject(o.LocaleService)),Ve(4,z.IZenZoneService),Ve(5,o.Inject(V.SheetDataValidationModel))],Ae);var An=Object.defineProperty,Fn=Object.getOwnPropertyDescriptor,Nn=(e,t,a,n)=>{for(var i=n>1?void 0:n?Fn(t,a):t,r=e.length-1,s;r>=0;r--)(s=e[r])&&(i=(n?s(t,a,i):s(i))||i);return n&&i&&An(t,a,i),i},st=(e,t)=>(a,n)=>t(a,n,e);let Ee=class extends o.Disposable{constructor(e,t,a){super(),this._autoFillService=e,this._sheetDataValidationModel=t,this._injector=a,this._initAutoFill()}_initAutoFill(){const e=()=>({redos:[],undos:[]}),t=(n,i)=>{const{source:r,target:s,unitId:l,subUnitId:d}=n,p=this._sheetDataValidationModel.getRuleObjectMatrix(l,d).clone(),h=k.virtualizeDiscreteRanges([r,s]),[f,c]=h.ranges,{mapFunc:S}=h,v={row:f.startRow,col:f.startColumn},C=k.getAutoFillRepeatRange(f,c),w=new o.ObjectMatrix,g=new Set;C.forEach(I=>{const m=I.repeatStartCell,T=I.relativeRange,A={startRow:v.row,startColumn:v.col,endColumn:v.col,endRow:v.row},W={startRow:m.row,startColumn:m.col,endColumn:m.col,endRow:m.row};o.Range.foreach(T,(F,P)=>{const N=o.Rectangle.getPositionRange({startRow:F,startColumn:P,endColumn:P,endRow:F},A),{row:U,col:j}=S(N.startRow,N.startColumn),$=this._sheetDataValidationModel.getRuleIdByLocation(l,d,U,j)||"",q=o.Rectangle.getPositionRange({startRow:F,startColumn:P,endColumn:P,endRow:F},W),{row:Z,col:G}=S(q.startRow,q.startColumn);w.setValue(Z,G,$),g.add($)})});const y=Array.from(g).map(I=>({id:I,ranges:o.queryObjectMatrix(w,m=>m===I)}));p.addRangeRules(y);const D=p.diff(this._sheetDataValidationModel.getRules(l,d)),{redoMutations:b,undoMutations:_}=V.getDataValidationDiffMutations(l,d,D,this._injector,"patched",i===k.APPLY_TYPE.ONLY_FORMAT);return{undos:_,redos:b}},a={id:V.DATA_VALIDATION_PLUGIN_NAME,onBeforeFillData:n=>{const{source:i,unitId:r,subUnitId:s}=n;for(const l of i.rows)for(const d of i.cols){const p=this._sheetDataValidationModel.getRuleByLocation(r,s,l,d);if(p&&p.type===o.DataValidationType.CHECKBOX){this._autoFillService.setDisableApplyType(k.APPLY_TYPE.SERIES,!0);return}}},onFillData:(n,i,r)=>r===k.APPLY_TYPE.COPY||r===k.APPLY_TYPE.ONLY_FORMAT||r===k.APPLY_TYPE.SERIES?t(n,r):e(),onAfterFillData:()=>{}};this.disposeWithMe(this._autoFillService.addHook(a))}};Ee=Nn([st(0,k.IAutoFillService),st(1,o.Inject(V.SheetDataValidationModel)),st(2,o.Inject(o.Injector))],Ee);var Un=Object.defineProperty,jn=Object.getOwnPropertyDescriptor,Bn=(e,t,a,n)=>{for(var i=n>1?void 0:n?jn(t,a):t,r=e.length-1,s;r>=0;r--)(s=e[r])&&(i=(n?s(t,a,i):s(i))||i);return n&&i&&Un(t,a,i),i},lt=(e,t)=>(a,n)=>t(a,n,e);let Me=class extends o.Disposable{constructor(t,a,n){super();O(this,"_copyInfo");this._sheetClipboardService=t,this._sheetDataValidationModel=a,this._injector=n,this._initCopyPaste()}_initCopyPaste(){this._sheetClipboardService.addClipboardHook({id:V.DATA_VALIDATION_PLUGIN_NAME,onBeforeCopy:(t,a,n)=>this._collect(t,a,n),onPasteCells:(t,a,n,i)=>{const{copyType:r=k.COPY_TYPE.COPY,pasteType:s}=i,{range:l}=t||{},{range:d,unitId:p,subUnitId:h}=a;return this._generateMutations(d,{copyType:r,pasteType:s,copyRange:l,unitId:p,subUnitId:h})}})}_collect(t,a,n){const i=new o.ObjectMatrix;this._copyInfo={unitId:t,subUnitId:a,matrix:i};const r=this._injector.invoke(d=>k.rangeToDiscreteRange(n,d,t,a));if(!r)return;const{rows:s,cols:l}=r;s.forEach((d,p)=>{l.forEach((h,f)=>{const c=this._sheetDataValidationModel.getRuleIdByLocation(t,a,d,h);i.setValue(p,f,c!=null?c:"")})})}_generateMutations(t,a){if(!this._copyInfo)return{redos:[],undos:[]};if(a.copyType===k.COPY_TYPE.CUT)return this._copyInfo=null,{redos:[],undos:[]};if(!this._copyInfo||!this._copyInfo.matrix.getSizeOf()||!a.copyRange)return{redos:[],undos:[]};if([k.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_COL_WIDTH,k.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_VALUE,k.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMAT,k.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMULA].includes(a.pasteType))return{redos:[],undos:[]};const{unitId:i,subUnitId:r}=this._copyInfo;if(a.unitId!==i||r!==a.subUnitId){const s=this._sheetDataValidationModel.getRuleObjectMatrix(a.unitId,a.subUnitId).clone(),l=new o.ObjectMatrix,d=new Set,{ranges:[p,h],mapFunc:f}=k.virtualizeDiscreteRanges([a.copyRange,t]),c=k.getRepeatRange(p,h,!0),S=new Map;c.forEach(({startRange:g})=>{var y;(y=this._copyInfo)==null||y.matrix.forValue((D,b,_)=>{const I=o.Rectangle.getPositionRange({startRow:D,endRow:D,startColumn:b,endColumn:b},g),m=`${r}-${_}`,T=this._sheetDataValidationModel.getRuleById(i,r,_);!this._sheetDataValidationModel.getRuleById(a.unitId,a.subUnitId,m)&&T&&S.set(m,{...T,uid:m});const{row:A,col:W}=f(I.startRow,I.startColumn);d.add(m),l.setValue(A,W,m)})});const v=Array.from(d).map(g=>({id:g,ranges:o.queryObjectMatrix(l,y=>y===g)}));s.addRangeRules(v);const{redoMutations:C,undoMutations:w}=V.getDataValidationDiffMutations(a.unitId,a.subUnitId,s.diffWithAddition(this._sheetDataValidationModel.getRules(a.unitId,a.subUnitId),S.values()),this._injector,"patched",!1);return{redos:C,undos:w}}else{const s=this._sheetDataValidationModel.getRuleObjectMatrix(i,r).clone(),l=new o.ObjectMatrix,d=new Set,{ranges:[p,h],mapFunc:f}=k.virtualizeDiscreteRanges([a.copyRange,t]);k.getRepeatRange(p,h,!0).forEach(({startRange:w})=>{var g;(g=this._copyInfo)==null||g.matrix.forValue((y,D,b)=>{const _=o.Rectangle.getPositionRange({startRow:y,endRow:y,startColumn:D,endColumn:D},w),{row:I,col:m}=f(_.startRow,_.startColumn);l.setValue(I,m,b),d.add(b)})});const S=Array.from(d).map(w=>({id:w,ranges:o.queryObjectMatrix(l,g=>g===w)}));s.addRangeRules(S);const{redoMutations:v,undoMutations:C}=V.getDataValidationDiffMutations(i,r,s.diff(this._sheetDataValidationModel.getRules(i,r)),this._injector,"patched",!1);return{redos:v,undos:C}}}};Me=Bn([lt(0,k.ISheetClipboardService),lt(1,o.Inject(V.SheetDataValidationModel)),lt(2,o.Inject(o.Injector))],Me);var kn=Object.defineProperty,Wn=Object.getOwnPropertyDescriptor,$n=(e,t,a,n)=>{for(var i=n>1?void 0:n?Wn(t,a):t,r=e.length-1,s;r>=0;r--)(s=e[r])&&(i=(n?s(t,a,i):s(i))||i);return n&&i&&kn(t,a,i),i},dt=(e,t)=>(a,n)=>t(a,n,e);let be=class extends o.Disposable{constructor(e,t,a){super(),this._localeService=e,this._commandService=t,this._sheetPermissionCheckController=a,this._commandExecutedListener()}_commandExecutedListener(){this.disposeWithMe(this._commandService.beforeCommandExecuted(e=>{e.id===V.AddSheetDataValidationCommand.id&&(this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[X.WorkbookEditablePermission],rangeTypes:[X.RangeProtectionPermissionEditPoint],worksheetTypes:[X.WorksheetEditPermission,X.WorksheetSetCellStylePermission]})||this._sheetPermissionCheckController.blockExecuteWithoutPermission(this._localeService.t("permission.dialog.setStyleErr"))),e.id===V.UpdateSheetDataValidationRangeCommand.id&&(this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[X.WorkbookEditablePermission],rangeTypes:[X.RangeProtectionPermissionEditPoint],worksheetTypes:[X.WorksheetEditPermission,X.WorksheetSetCellStylePermission]},e.params.ranges)||this._sheetPermissionCheckController.blockExecuteWithoutPermission(this._localeService.t("permission.dialog.setStyleErr")))}))}};be=$n([dt(0,o.Inject(o.LocaleService)),dt(1,o.ICommandService),dt(2,o.Inject(X.SheetPermissionCheckController))],be);const At="data-validation-single",Ft="sheet.menu.data-validation";function Hn(e){return{id:Ft,type:z.MenuItemType.SUBITEMS,icon:At,tooltip:"dataValidation.title",hidden$:z.getMenuHiddenObservable(e,o.UniverInstanceType.UNIVER_SHEET),disabled$:k.getCurrentRangeDisable$(e,{workbookTypes:[X.WorkbookEditablePermission],worksheetTypes:[X.WorksheetSetCellStylePermission,X.WorksheetEditPermission],rangeTypes:[X.RangeProtectionPermissionEditPoint]})}}function Yn(e){return{id:_e.id,title:"dataValidation.panel.title",type:z.MenuItemType.BUTTON}}function xn(e){return{id:$e.id,title:"dataValidation.panel.add",type:z.MenuItemType.BUTTON}}const Xn={[z.RibbonStartGroup.FORMULAS_INSERT]:{[Ft]:{order:9,menuItemFactory:Hn,[_e.id]:{order:0,menuItemFactory:Yn},[$e.id]:{order:1,menuItemFactory:xn}}}};var zn=Object.defineProperty,Kn=Object.getOwnPropertyDescriptor,Nt=(e,t,a,n)=>{for(var i=n>1?void 0:n?Kn(t,a):t,r=e.length-1,s;r>=0;r--)(s=e[r])&&(i=(n?s(t,a,i):s(i))||i);return n&&i&&zn(t,a,i),i},Q=(e,t)=>(a,n)=>t(a,n,e);const Ut={tr:{size:6,color:"#fe4b4b"}};let Le=class extends o.RxDisposable{constructor(e,t,a,n,i,r,s,l,d,p,h){super(),this._commandService=e,this._menuManagerService=t,this._renderManagerService=a,this._univerInstanceService=n,this._autoHeightController=i,this._dropdownManagerService=r,this._sheetDataValidationModel=s,this._dataValidatorRegistryService=l,this._sheetInterceptorService=d,this._dataValidationCacheService=p,this._editorBridgeService=h,this._initMenu(),this._initDropdown(),this._initViewModelIntercept(),this._initAutoHeight()}_initMenu(){this._menuManagerService.mergeMenu(Xn)}_initDropdown(){this._editorBridgeService&&this.disposeWithMe(this._editorBridgeService.visible$.subscribe(e=>{var a;if(!e.visible){((a=this._dropdownManagerService.activeDropdown)==null?void 0:a.trigger)==="editor-bridge"&&this._dropdownManagerService.hideDropdown();return}const t=this._editorBridgeService.getEditCellState();if(t){const{unitId:n,sheetId:i,row:r,column:s}=t,l=this._univerInstanceService.getUniverSheetInstance(n);if(!l)return;const d=this._sheetDataValidationModel.getRuleByLocation(n,i,r,s);if(!d)return;const p=this._dataValidatorRegistryService.getValidatorItem(d.type);if(!(p!=null&&p.dropdown))return;const h=l.getActiveSheet();if(!h)return;const f=this._dropdownManagerService.activeDropdown,c=f==null?void 0:f.location;if(c&&c.unitId===n&&c.subUnitId===i&&c.row===r&&c.col===s)return;this._dropdownManagerService.showDropdown({location:{unitId:n,subUnitId:i,row:r,col:s,workbook:l,worksheet:h},componentKey:p.dropdown,onHide:()=>{},trigger:"editor-bridge"},!1)}}))}_initViewModelIntercept(){this.disposeWithMe(this._sheetInterceptorService.intercept(X.INTERCEPTOR_POINT.CELL_CONTENT,{effect:o.InterceptorEffectEnum.Style,priority:X.InterceptCellContentPriority.DATA_VALIDATION,handler:(e,t,a)=>{var g,y,D,b,_;const{row:n,col:i,unitId:r,subUnitId:s,workbook:l,worksheet:d}=t,p=this._sheetDataValidationModel.getRuleIdByLocation(r,s,n,i);if(!p)return a(e);const h=this._sheetDataValidationModel.getRuleById(r,s,p);if(!h)return a(e);const f=(g=this._dataValidationCacheService.getValue(r,s,n,i))!=null?g:o.DataValidationStatus.VALID,c=this._dataValidatorRegistryService.getValidatorItem(h.type),S=t.rawData;let v;const C={get value(){var I;return v!==void 0||(v=(I=V.getCellValueOrigin(S))!=null?I:null),v}},w={get value(){var I;return`${(I=C.value)!=null?I:""}`}};return a({...e,markers:{...e==null?void 0:e.markers,...f===o.DataValidationStatus.INVALID?Ut:null},customRender:[...(y=e==null?void 0:e.customRender)!=null?y:[],...c!=null&&c.canvasRender?[c.canvasRender]:[]],fontRenderExtension:{...e==null?void 0:e.fontRenderExtension,isSkip:((D=e==null?void 0:e.fontRenderExtension)==null?void 0:D.isSkip)||((b=c==null?void 0:c.skipDefaultFontRender)==null?void 0:b.call(c,h,C.value,t))},interceptorStyle:{...e==null?void 0:e.interceptorStyle,...c==null?void 0:c.getExtraStyle(h,w.value,{get style(){const I=l.getStyles();return(typeof(e==null?void 0:e.s)=="string"?I.get(e==null?void 0:e.s):e==null?void 0:e.s)||{}}},n,i)},interceptorAutoHeight:()=>{var A,W,F,P,N,U;const I=(W=(A=this._renderManagerService.getRenderById(r))==null?void 0:A.with(k.SheetSkeletonManagerService).getWorksheetSkeleton(s))==null?void 0:W.skeleton;if(!I)return;const m=I.worksheet.getMergedCell(n,i),T={data:e,style:I.getsStyles().getStyleByCell(e),primaryWithCoord:I.getCellWithCoordByIndex((F=m==null?void 0:m.startRow)!=null?F:n,(P=m==null?void 0:m.startColumn)!=null?P:i),unitId:r,subUnitId:s,row:n,col:i,workbook:l,worksheet:d};return(U=(N=c==null?void 0:c.canvasRender)==null?void 0:N.calcCellAutoHeight)==null?void 0:U.call(N,T)},interceptorAutoWidth:()=>{var A,W,F,P,N,U;const I=(W=(A=this._renderManagerService.getRenderById(r))==null?void 0:A.with(k.SheetSkeletonManagerService).getWorksheetSkeleton(s))==null?void 0:W.skeleton;if(!I)return;const m=I.worksheet.getMergedCell(n,i),T={data:e,style:I.getsStyles().getStyleByCell(e),primaryWithCoord:I.getCellWithCoordByIndex((F=m==null?void 0:m.startRow)!=null?F:n,(P=m==null?void 0:m.startColumn)!=null?P:i),unitId:r,subUnitId:s,row:n,col:i,workbook:l,worksheet:d};return(U=(N=c==null?void 0:c.canvasRender)==null?void 0:N.calcCellAutoWidth)==null?void 0:U.call(N,T)},coverable:((_=e==null?void 0:e.coverable)!=null?_:!0)&&!(h.type===o.DataValidationType.LIST||h.type===o.DataValidationType.LIST_MULTIPLE)})}}))}_initAutoHeight(){this._sheetDataValidationModel.ruleChange$.pipe(re.filter(e=>e.source==="command"),re.bufferTime(100)).subscribe(e=>{if(e.length===0)return;const t=[];if(e.forEach(a=>{var n;(a.rule.type===o.DataValidationType.LIST_MULTIPLE||a.rule.type===o.DataValidationType.LIST)&&(n=a.rule)!=null&&n.ranges&&t.push(...a.rule.ranges)}),t.length){const a=this._autoHeightController.getUndoRedoParamsOfAutoHeight(t);o.sequenceExecute(a.redos,this._commandService)}})}};Le=Nt([Q(0,o.ICommandService),Q(1,z.IMenuManagerService),Q(2,B.IRenderManagerService),Q(3,o.IUniverInstanceService),Q(4,o.Inject(k.AutoHeightController)),Q(5,o.Inject(me)),Q(6,o.Inject(V.SheetDataValidationModel)),Q(7,o.Inject(J.DataValidatorRegistryService)),Q(8,o.Inject(X.SheetInterceptorService)),Q(9,o.Inject(V.DataValidationCacheService)),Q(10,o.Optional(k.IEditorBridgeService))],Le);let jt=class extends o.RxDisposable{constructor(e,t,a,n,i,r,s){super(),this._commandService=e,this._renderManagerService=t,this._autoHeightController=a,this._dataValidatorRegistryService=n,this._sheetInterceptorService=i,this._sheetDataValidationModel=r,this._dataValidationCacheService=s,this._initViewModelIntercept(),this._initAutoHeight()}_initViewModelIntercept(){this.disposeWithMe(this._sheetInterceptorService.intercept(X.INTERCEPTOR_POINT.CELL_CONTENT,{effect:o.InterceptorEffectEnum.Style,priority:X.InterceptCellContentPriority.DATA_VALIDATION,handler:(e,t,a)=>{var w,g,y,D,b;const{row:n,col:i,unitId:r,subUnitId:s,workbook:l,worksheet:d}=t,p=this._sheetDataValidationModel.getRuleIdByLocation(r,s,n,i);if(!p)return a(e);const h=this._sheetDataValidationModel.getRuleById(r,s,p);if(!h)return a(e);const f=(w=this._dataValidationCacheService.getValue(r,s,n,i))!=null?w:o.DataValidationStatus.VALID,c=this._dataValidatorRegistryService.getValidatorItem(h.type),S=d.getCellRaw(n,i),v=V.getCellValueOrigin(S),C=`${v!=null?v:""}`;return a({...e,markers:{...e==null?void 0:e.markers,...f===o.DataValidationStatus.INVALID?Ut:null},customRender:[...(g=e==null?void 0:e.customRender)!=null?g:[],...c!=null&&c.canvasRender?[c.canvasRender]:[]],fontRenderExtension:{...e==null?void 0:e.fontRenderExtension,isSkip:((y=e==null?void 0:e.fontRenderExtension)==null?void 0:y.isSkip)||((D=c==null?void 0:c.skipDefaultFontRender)==null?void 0:D.call(c,h,v,t))},interceptorStyle:{...e==null?void 0:e.interceptorStyle,...c==null?void 0:c.getExtraStyle(h,C,{get style(){const _=l.getStyles();return(typeof(e==null?void 0:e.s)=="string"?_.get(e==null?void 0:e.s):e==null?void 0:e.s)||{}}},n,i)},interceptorAutoHeight:()=>{var T,A,W,F,P,N;const _=(A=(T=this._renderManagerService.getRenderById(r))==null?void 0:T.with(k.SheetSkeletonManagerService).getWorksheetSkeleton(s))==null?void 0:A.skeleton;if(!_)return;const I=_.worksheet.getMergedCell(n,i),m={data:e,style:_.getsStyles().getStyleByCell(e),primaryWithCoord:_.getCellWithCoordByIndex((W=I==null?void 0:I.startRow)!=null?W:n,(F=I==null?void 0:I.startColumn)!=null?F:i),unitId:r,subUnitId:s,row:n,col:i,workbook:l,worksheet:d};return(N=(P=c==null?void 0:c.canvasRender)==null?void 0:P.calcCellAutoHeight)==null?void 0:N.call(P,m)},coverable:((b=e==null?void 0:e.coverable)!=null?b:!0)&&!(h.type===o.DataValidationType.LIST||h.type===o.DataValidationType.LIST_MULTIPLE)})}}))}_initAutoHeight(){this._sheetDataValidationModel.ruleChange$.pipe(re.filter(e=>e.source==="command"),re.bufferTime(16)).subscribe(e=>{const t=[];if(e.forEach(a=>{var n;(n=a.rule)!=null&&n.ranges&&t.push(...a.rule.ranges)}),t.length){const a=this._autoHeightController.getUndoRedoParamsOfAutoHeight(t);o.sequenceExecute(a.redos,this._commandService)}})}};jt=Nt([Q(0,o.ICommandService),Q(1,B.IRenderManagerService),Q(2,o.Inject(k.AutoHeightController)),Q(3,o.Inject(J.DataValidatorRegistryService)),Q(4,o.Inject(X.SheetInterceptorService)),Q(5,o.Inject(V.SheetDataValidationModel)),Q(6,o.Inject(V.DataValidationCacheService))],jt);var Gn=Object.defineProperty,qn=Object.getOwnPropertyDescriptor,Zn=(e,t,a,n)=>{for(var i=n>1?void 0:n?qn(t,a):t,r=e.length-1,s;r>=0;r--)(s=e[r])&&(i=(n?s(t,a,i):s(i))||i);return n&&i&&Gn(t,a,i),i},Bt=(e,t)=>(a,n)=>t(a,n,e);let He=class extends o.Disposable{constructor(e,t,a){super(),this._context=e,this._sheetDataValidationModel=t,this._sheetSkeletonManagerService=a,this._initSkeletonChange()}_initSkeletonChange(){const e=t=>{var n;if(!t.length)return;const a=new Set;t.forEach(i=>{a.add(i.subUnitId)}),a.forEach(i=>{var r;(r=this._sheetSkeletonManagerService.getWorksheetSkeleton(i))==null||r.skeleton.makeDirty(!0)}),(n=this._context.mainComponent)==null||n.makeForceDirty()};this.disposeWithMe(this._sheetDataValidationModel.validStatusChange$.pipe(o.bufferDebounceTime(16)).subscribe(e))}};He=Zn([Bt(1,o.Inject(V.SheetDataValidationModel)),Bt(2,o.Inject(k.SheetSkeletonManagerService))],He);const ne={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"},Jn=e=>{const{isTwoFormula:t=!1,value:a,onChange:n,showError:i,validResult:r}=e,s=o.useDependency(o.LocaleService),l=i?r==null?void 0:r.formula1:"",d=i?r==null?void 0:r.formula2:"";return t?u.jsxs(u.Fragment,{children:[u.jsx(L.FormLayout,{error:l,children:u.jsx(L.Input,{className:ne.dataValidationFormula,placeholder:s.t("dataValidation.panel.formulaPlaceholder"),value:a==null?void 0:a.formula1,onChange:p=>{n==null||n({...a,formula1:p})}})}),u.jsx("div",{className:ne.dataValidationFormulaAnd,children:s.t("dataValidation.panel.formulaAnd")}),u.jsx(L.FormLayout,{error:d,children:u.jsx(L.Input,{className:ne.dataValidationFormula,placeholder:s.t("dataValidation.panel.formulaPlaceholder"),value:a==null?void 0:a.formula2,onChange:p=>{n==null||n({...a,formula2:p})}})})]}):u.jsx(L.FormLayout,{error:l,children:u.jsx(L.Input,{className:ne.dataValidationFormula,placeholder:s.t("dataValidation.panel.formulaPlaceholder"),value:a==null?void 0:a.formula1,onChange:p=>{n==null||n({formula1:p})}})})};function Qn(e){const{value:t,onChange:a,showError:n,validResult:i}=e,r=o.useDependency(o.LocaleService),s=n?i==null?void 0:i.formula1:"",l=n?i==null?void 0:i.formula2:"",[d,p]=E.useState(!((t==null?void 0:t.formula1)===void 0&&(t==null?void 0:t.formula2)===void 0));return u.jsxs(u.Fragment,{children:[u.jsx(L.FormLayout,{children:u.jsx(L.Checkbox,{checked:d,onChange:h=>{h?p(!0):(p(!1),a==null||a({...t,formula1:void 0,formula2:void 0}))},children:r.t("dataValidation.checkbox.tips")})}),d?u.jsx(L.FormLayout,{label:r.t("dataValidation.checkbox.checked"),error:s,children:u.jsx(L.Input,{className:ne.dataValidationFormula,placeholder:r.t("dataValidation.panel.valuePlaceholder"),value:t==null?void 0:t.formula1,onChange:h=>{a==null||a({...t,formula1:h||void 0})}})}):null,d?u.jsx(L.FormLayout,{label:r.t("dataValidation.checkbox.unchecked"),error:l,children:u.jsx(L.Input,{className:ne.dataValidationFormula,placeholder:r.t("dataValidation.panel.valuePlaceholder"),value:t==null?void 0:t.formula2,onChange:h=>{a==null||a({...t,formula2:h||void 0})}})}):null]})}function ea(e){var f;const{unitId:t,subUnitId:a,value:n,onChange:i,showError:r,validResult:s}=e,l=r?s==null?void 0:s.formula1:void 0,d=E.useRef({}),[p,h]=E.useState(!1);return z.useSidebarClick(c=>{var v;const S=(v=d.current)==null?void 0:v.handleOutClick;S&&S(c,()=>h(!1))}),u.jsx(tt.FormulaEditor,{initValue:(f=n==null?void 0:n.formula1)!=null?f:"=",unitId:t,subUnitId:a,isFocus:p,onChange:c=>{const S=(c!=null?c:"").trim();S!==(n==null?void 0:n.formula1)&&(i==null||i({...n,formula1:S}))},errorText:l,onFocus:()=>h(!0),actions:d.current,isSupportAcrossSheet:!0})}function kt(e){var t,a,n="";if(typeof e=="string"||typeof e=="number")n+=e;else if(typeof e=="object")if(Array.isArray(e)){var i=e.length;for(t=0;t<i;t++)e[t]&&(a=kt(e[t]))&&(n&&(n+=" "),n+=a)}else for(a in e)e[a]&&(n&&(n+=" "),n+=a);return n}function ta(){for(var e,t,a=0,n="",i=arguments.length;a<i;a++)(e=arguments[a])&&(t=kt(e))&&(n&&(n+=" "),n+=t);return n}const na=["#FFFFFF","#FEE7E7","#FEF0E6","#EFFBD0","#E4F4FE","#E8ECFD","#F1EAFA","#FDE8F3","#E5E5E5","#FDCECE","#FDC49B","#DEF6A2","#9FDAFF","#D0D9FB","#E3D5F6","#FBD0E8","#656565","#FE4B4B","#FF8C51","#8BBB11","#0B9EFB","#3A60F7","#9E6DE3","#F248A6"],aa=e=>{const{value:t,onChange:a,disabled:n}=e,[i,r]=E.useState(!1);return u.jsx(L.Select,{disabled:n,open:i,onDropdownVisibleChange:r,dropdownStyle:{width:112},style:{width:96,cursor:"pointer"},className:ne.dataValidationFormulaColorSelect,value:t,onChange:a,labelRender:s=>u.jsx("div",{className:ne.dataValidationFormulaColorItem,style:{background:s.value,marginTop:5}}),dropdownRender:()=>u.jsx("div",{className:ne.dataValidationFormulaColorSelectPanel,children:na.map(s=>u.jsx("div",{onClick:()=>{a(s),r(!1)},className:ne.dataValidationFormulaColorItem,style:{background:s}},s))})})},Wt=e=>{const{item:t,commonProps:a,style:n}=e,{onItemChange:i,onItemDelete:r}=a;return u.jsxs("div",{className:ne.dataValidationFormulaListItem,style:n,children:[t.isRef?null:u.jsx("div",{className:ta(ne.dataValidationFormulaListItemDrag,"draggableHandle"),children:u.jsx(Lt,{})}),u.jsx(aa,{value:t.color,onChange:s=>{i(t.id,t.label,s)}}),u.jsx(L.Input,{disabled:t.isRef,value:t.label,onChange:s=>{i(t.id,s,t.color)}}),t.isRef?null:u.jsx("div",{className:ne.dataValidationFormulaListItemIcon,children:u.jsx(nt,{onClick:()=>r(t.id)})})]})};function ia(e){const{value:t,onChange:a=()=>{},unitId:n,subUnitId:i,validResult:r,showError:s,ruleId:l}=e,{formula1:d="",formula2:p=""}=t||{},h=E.useRef(null),[f,c]=E.useState(()=>o.isFormulaString(d)?"1":"0"),[S,v]=E.useState(f==="1"?d:"="),[C,w]=E.useState(f==="1"?d:"="),g=o.useDependency(o.LocaleService),y=o.useDependency(J.DataValidatorRegistryService),D=o.useDependency(J.DataValidationModel),b=o.useDependency(V.DataValidationFormulaController),[_,I]=E.useState(()=>p.split(",")),m=y.getValidatorItem(o.DataValidationType.LIST),[T,A]=E.useState([]),[W,F]=E.useState(""),P=s?r==null?void 0:r.formula1:"",N=E.useMemo(()=>D.ruleChange$.pipe(re.debounceTime(16)),[]),U=z.useObservable(N),j=z.useEvent(a);E.useEffect(()=>{(async()=>{await new Promise(x=>{setTimeout(()=>x(!0),100)});const M=D.getRuleById(n,i,l),H=M==null?void 0:M.formula1;if(o.isFormulaString(H)&&m&&M){const x=await m.getListAsync(M,n,i);A(x)}})()},[D,U,m,l,i,n]),E.useEffect(()=>{o.isFormulaString(d)&&d!==C&&(v(d),w(C))},[C,d]);const[$,q]=E.useState(()=>{const M=f!=="1"?V.deserializeListOptions(d):[],H=p.split(",");return M.map((x,K)=>({label:x,color:H[K]||Ie,isRef:!1,id:o.Tools.generateRandomId(4)}))}),Z=(M,H,x)=>{const K=$.find(ge=>ge.id===M);K&&(K.label=H,K.color=x,q([...$]))},G=M=>{const H=$.findIndex(x=>x.id===M);H!==-1&&($.splice(H,1),q([...$]))},ee=p.split(","),te=E.useMemo(()=>T.map((M,H)=>({label:M,color:ee[H]||Ie,id:`${H}`,isRef:!0})),[ee,T]),ae=(M,H,x)=>{const K=[..._];K[+M]=x,I(K),j({formula1:d,formula2:K.join(",")})},ie=()=>{q([...$,{label:"",color:Ie,isRef:!1,id:o.Tools.generateRandomId(4)}])};E.useEffect(()=>{if(f==="1")return;const M=new Set,H=[];$.map(x=>({labelList:x.label.split(","),item:x})).forEach(({item:x,labelList:K})=>{K.forEach(ge=>{M.has(ge)||(M.add(ge),H.push({label:ge,color:x.color}))})}),j({formula1:V.serializeListOptions(H.map(x=>x.label)),formula2:H.map(x=>x.color===Ie?"":x.color).join(",")})},[$,j,f,C,_]);const le=z.useEvent(async M=>{if(!o.isFormulaString(M)){j==null||j({formula1:"",formula2:p});return}b.getFormulaRefCheck(M)?(j==null||j({formula1:o.isFormulaString(M)?M:"",formula2:p}),F("")):(j==null||j({formula1:"",formula2:p}),v("="),F(g.t("dataValidation.validFail.formulaError")))}),oe=E.useRef({}),[de,R]=E.useState(!1);return z.useSidebarClick(M=>{var x;const H=(x=oe.current)==null?void 0:x.handleOutClick;H&&H(M,()=>R(!1))}),u.jsxs(u.Fragment,{children:[u.jsx(L.FormLayout,{label:g.t("dataValidation.list.options"),children:u.jsxs(L.RadioGroup,{value:f,onChange:M=>{c(M),v(C),M==="1"&&j({formula1:C==="="?"":C,formula2:_.join(",")})},children:[u.jsx(L.Radio,{value:"0",children:g.t("dataValidation.list.customOptions")}),u.jsx(L.Radio,{value:"1",children:g.t("dataValidation.list.refOptions")})]})}),f==="1"?u.jsxs(u.Fragment,{children:[u.jsx(tt.FormulaEditor,{initValue:S,unitId:n,subUnitId:i,isFocus:de,onChange:(M="")=>{const H=(M!=null?M:"").trim();w(H),le(H)},errorText:P||W||void 0,onFocus:()=>R(!0),actions:oe.current,isSupportAcrossSheet:!0}),u.jsx("div",{ref:h,style:{marginTop:"12px"},children:te.map(M=>u.jsx(Wt,{item:M,commonProps:{onItemChange:ae},style:{marginBottom:12}},M.id))})]}):u.jsx(L.FormLayout,{error:P,children:u.jsxs("div",{ref:h,style:{marginTop:"-12px"},children:[u.jsx(L.DraggableList,{list:$,onListChange:q,rowHeight:32,margin:[0,12],draggableHandle:".draggableHandle",itemRender:M=>u.jsx(Wt,{item:M,commonProps:{onItemChange:Z,onItemDelete:G}},M.id),idKey:"id"}),u.jsxs("a",{className:ne.dataValidationFormulaListAdd,onClick:ie,children:[u.jsx(Et,{}),g.t("dataValidation.list.add")]})]})})]})}const $t="data-validation.custom-formula-input",Ye="data-validation.formula-input",ct="data-validation.list-formula-input",Ht="data-validation.checkbox-formula-input",oa=[[$t,ea],[Ye,Jn],[ct,ia],[Ht,Qn]],ra="LIST_RENDER_MODE_OPTION_INPUT";function xe(e){var i;const{value:t,onChange:a}=e,n=o.useDependency(o.LocaleService);return u.jsx(L.FormLayout,{label:n.t("dataValidation.renderMode.label"),children:u.jsxs(L.RadioGroup,{value:`${(i=t.renderMode)!=null?i:o.DataValidationRenderMode.CUSTOM}`,onChange:r=>a({...t,renderMode:+r}),children:[u.jsx(L.Radio,{value:`${o.DataValidationRenderMode.CUSTOM}`,children:n.t("dataValidation.renderMode.chip")}),u.jsx(L.Radio,{value:`${o.DataValidationRenderMode.ARROW}`,children:n.t("dataValidation.renderMode.arrow")}),u.jsx(L.Radio,{value:`${o.DataValidationRenderMode.TEXT}`,children:n.t("dataValidation.renderMode.text")})]})})}xe.componentKey=ra;const sa="DATE_SHOW_TIME_OPTION";function Xe(e){var i;const{value:t,onChange:a}=e,n=o.useDependency(o.LocaleService);return u.jsx(L.FormLayout,{children:u.jsx(L.Checkbox,{checked:(i=t.bizInfo)==null?void 0:i.showTime,onChange:r=>{a({...t,bizInfo:{...t.bizInfo,showTime:r}})},children:n.t("dataValidation.showTime.label")})})}Xe.componentKey=sa;var la=Object.defineProperty,da=Object.getOwnPropertyDescriptor,ca=(e,t,a,n)=>{for(var i=n>1?void 0:n?da(t,a):t,r=e.length-1,s;r>=0;r--)(s=e[r])&&(i=(n?s(t,a,i):s(i))||i);return n&&i&&la(t,a,i),i},Fe=(e,t)=>(a,n)=>t(a,n,e);const ze=6;let ut=class{constructor(e,t,a,n,i){this._commandService=e,this._formulaService=t,this._themeService=a,this._renderManagerService=n,this._dataValidationModel=i}_calc(e,t){var p,h,f;const{vt:a,ht:n}=t||{},i=e.endX-e.startX-ze*2,r=e.endY-e.startY,s=((p=t==null?void 0:t.fs)!=null?p:10)*1.6;let l=0,d=0;switch(a){case o.VerticalAlign.TOP:d=0;break;case o.VerticalAlign.BOTTOM:d=0+(r-s);break;default:d=0+(r-s)/2;break}switch(n){case o.HorizontalAlign.LEFT:l=ze;break;case o.HorizontalAlign.RIGHT:l=ze+(i-s);break;default:l=ze+(i-s)/2;break}return{left:e.startX+l,top:e.startY+d,width:((h=t==null?void 0:t.fs)!=null?h:10)*1.6,height:((f=t==null?void 0:t.fs)!=null?f:10)*1.6}}calcCellAutoHeight(e){var a;const{style:t}=e;return((a=t==null?void 0:t.fs)!=null?a:10)*1.6}calcCellAutoWidth(e){var a;const{style:t}=e;return((a=t==null?void 0:t.fs)!=null?a:10)*1.6}async _parseFormula(e,t,a){var p,h,f,c,S,v,C,w,g;const{formula1:n=V.CHECKBOX_FORMULA_1,formula2:i=V.CHECKBOX_FORMULA_2}=e,r=await this._formulaService.getRuleFormulaResult(t,a,e.uid),s=V.getFormulaResult((f=(h=(p=r==null?void 0:r[0])==null?void 0:p.result)==null?void 0:h[0])==null?void 0:f[0]),l=V.getFormulaResult((v=(S=(c=r==null?void 0:r[1])==null?void 0:c.result)==null?void 0:S[0])==null?void 0:v[0]),d=V.isLegalFormulaResult(String(s))&&V.isLegalFormulaResult(String(l));return{formula1:o.isFormulaString(n)?V.getFormulaResult((g=(w=(C=r==null?void 0:r[0])==null?void 0:C.result)==null?void 0:w[0])==null?void 0:g[0]):n,formula2:o.isFormulaString(i)?l:i,isFormulaValid:d}}drawWith(e,t){var P,N,U,j;const{style:a,primaryWithCoord:n,unitId:i,subUnitId:r,worksheet:s,row:l,col:d}=t,p=n.isMergedMainCell?n.mergeInfo:n,h=V.getCellValueOrigin(s.getCellRaw(l,d)),f=this._dataValidationModel.getRuleByLocation(i,r,l,d);if(!f)return;const c=this._dataValidationModel.getValidator(f.type);if(!c)return;const S=this._themeService.getCurrentTheme();if(!((P=c.skipDefaultFontRender)!=null&&P.call(c,f,h,{unitId:i,subUnitId:r,row:l,column:d})))return;const v=c.parseFormulaSync(f,i,r),{formula1:C}=v,w=this._calc(p,a),{a:g,d:y}=e.getTransform(),D=B.fixLineWidthByScale(w.left,g),b=B.fixLineWidthByScale(w.top,y),_=B.Transform.create().composeMatrix({left:D,top:b,scaleX:1,scaleY:1,angle:0,skewX:0,skewY:0,flipX:!1,flipY:!1}),I=p.endX-p.startX,m=p.endY-p.startY;e.save(),e.beginPath(),e.rect(p.startX,p.startY,I,m),e.clip();const T=_.getMatrix();e.transform(T[0],T[1],T[2],T[3],T[4],T[5]);const A=((N=a==null?void 0:a.fs)!=null?N:10)*1.6,W=String(h)===String(C),F=S.hyacinth500;B.CheckboxShape.drawWith(e,{checked:W,width:A,height:A,fill:(j=(U=a==null?void 0:a.cl)==null?void 0:U.rgb)!=null?j:F}),e.restore()}isHit(e,t){const a=t.primaryWithCoord.isMergedMainCell?t.primaryWithCoord.mergeInfo:t.primaryWithCoord,n=this._calc(a,t.style),i=n.top,r=n.top+n.height,s=n.left,l=n.left+n.width,{x:d,y:p}=e;return d<=l&&d>=s&&p<=r&&p>=i}async onPointerDown(e,t){var v;if(t.button===2)return;const{primaryWithCoord:a,unitId:n,subUnitId:i,worksheet:r,row:s,col:l}=e,d=V.getCellValueOrigin(r.getCellRaw(s,l)),p=this._dataValidationModel.getRuleByLocation(n,i,s,l);if(!p)return;const h=this._dataValidationModel.getValidator(p.type);if(!h||!((v=h.skipDefaultFontRender)!=null&&v.call(h,p,d,{unitId:n,subUnitId:i,row:s,column:l})))return;const{formula1:f,formula2:c}=await this._parseFormula(p,n,i),S={range:{startColumn:a.actualColumn,endColumn:a.actualColumn,startRow:a.actualRow,endRow:a.actualRow},value:{v:String(d)===V.transformCheckboxValue(String(f))?c:f,p:null}};this._commandService.executeCommand(X.SetRangeValuesCommand.id,S)}onPointerEnter(e,t){var a,n;(n=(a=this._renderManagerService.getCurrentTypeOfRenderer(o.UniverInstanceType.UNIVER_SHEET))==null?void 0:a.mainComponent)==null||n.setCursor(B.CURSOR_TYPE.POINTER)}onPointerLeave(e,t){var a,n;(n=(a=this._renderManagerService.getCurrentTypeOfRenderer(o.UniverInstanceType.UNIVER_SHEET))==null?void 0:a.mainComponent)==null||n.setCursor(B.CURSOR_TYPE.DEFAULT)}};ut=ca([Fe(0,o.ICommandService),Fe(1,o.Inject(V.DataValidationFormulaService)),Fe(2,o.Inject(o.ThemeService)),Fe(3,o.Inject(B.IRenderManagerService)),Fe(4,o.Inject(V.SheetDataValidationModel))],ut);var ua=Object.defineProperty,pa=Object.getOwnPropertyDescriptor,ha=(e,t,a,n)=>{for(var i=n>1?void 0:n?pa(t,a):t,r=e.length-1,s;r>=0;r--)(s=e[r])&&(i=(n?s(t,a,i):s(i))||i);return n&&i&&ua(t,a,i),i},fa=(e,t)=>(a,n)=>t(a,n,e);let pe=class{constructor(e){O(this,"canvasRender",null);O(this,"dropdown");O(this,"optionsInput");O(this,"formulaInput",ct);this.injector=e}};pe=ha([fa(0,o.Inject(o.Injector))],pe);class va extends pe{constructor(){super(...arguments);O(this,"id",o.DataValidationType.CHECKBOX);O(this,"canvasRender",this.injector.createInstance(ut));O(this,"formulaInput",Ht)}}class ma extends pe{constructor(){super(...arguments);O(this,"id",o.DataValidationType.CUSTOM);O(this,"formulaInput",$t)}}const ga="data-validation.formula-input";class Sa extends pe{constructor(){super(...arguments);O(this,"id",o.DataValidationType.DATE);O(this,"formulaInput",ga);O(this,"optionsInput",Xe.componentKey);O(this,"dropdown",rt)}}class _a extends pe{constructor(){super(...arguments);O(this,"id",o.DataValidationType.DECIMAL);O(this,"formulaInput",Ye)}}const Yt=4,Ia=0,pt=4,xt=4,ht=6,Ke=6,De=14;function Ca(e,t){const a=B.FontCache.getTextSize(e,t),n=a.width+Yt*2,{ba:i,bd:r}=a,s=i+r;return{width:n,height:s+Ia*2,ba:i}}function ft(e,t,a,n){const i=De+ht*2,r=a-i,s=n-Ke*2,l=e.map(c=>({layout:Ca(c,t),text:c}));let d;const p=[];l.forEach(c=>{const{layout:S}=c,{width:v,height:C}=S;!d||d.width+v+pt>r?(d={width:v,height:C,items:[{...c,left:0}]},p.push(d)):(d.items.push({...c,left:d.width+pt}),d.width=d.width+v+pt)});let h=0,f=0;return p.forEach((c,S)=>{f=Math.max(f,c.width),S===p.length-1?h+=c.height:h+=c.height+xt}),{lines:p,totalHeight:h,contentWidth:r,contentHeight:s,cellAutoHeight:h+Ke*2,calcAutoWidth:f+i}}const Da=8;class ya extends B.Shape{static drawWith(t,a){const{fontString:n,info:i,fill:r,color:s}=a,{layout:l,text:d}=i;t.save(),B.Rect.drawWith(t,{width:l.width,height:l.height,radius:Da,fill:r||Ie}),t.translateWithPrecision(Yt,l.ba),t.font=n,t.fillStyle=s,t.fillText(d,0,0),t.restore()}}var wa=Object.defineProperty,Va=Object.getOwnPropertyDescriptor,Ea=(e,t,a,n)=>{for(var i=n>1?void 0:n?Va(t,a):t,r=e.length-1,s;r>=0;r--)(s=e[r])&&(i=(n?s(t,a,i):s(i))||i);return n&&i&&wa(t,a,i),i},vt=(e,t)=>(a,n)=>t(a,n,e);const Ma=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 mt=class{constructor(e,t,a){O(this,"zIndex");O(this,"_dropdownInfoMap",new Map);this._commandService=e,this._renderManagerService=t,this._dataValidationModel=a}_ensureMap(e){let t=this._dropdownInfoMap.get(e);return t||(t=new Map,this._dropdownInfoMap.set(e,t)),t}_generateKey(e,t){return`${e}.${t}`}_drawDownIcon(e,t,a,n,i){const r=a-De+4;let s=4;switch(i){case o.VerticalAlign.MIDDLE:s=(n-De)/2+4;break;case o.VerticalAlign.BOTTOM:s=n-De+4;break}e.save(),e.translateWithPrecision(t.startX+r,t.startY+s),e.fillStyle="#565656",e.fill(Ma),e.restore()}drawWith(e,t,a,n){var Z,G;const{primaryWithCoord:i,row:r,col:s,style:l,data:d,subUnitId:p}=t,h=i.isMergedMainCell?i.mergeInfo:i,f=d==null?void 0:d.fontRenderExtension,{leftOffset:c=0,rightOffset:S=0,topOffset:v=0,downOffset:C=0}=f||{},w=this._ensureMap(p),g=this._generateKey(r,s),y=this._dataValidationModel.getRuleByLocation(t.unitId,t.subUnitId,r,s);if(!y)return;const D=this._dataValidationModel.getValidator(y.type);if(!D)return;const b={startX:h.startX+c,endX:h.endX-S,startY:h.startY+v,endY:h.endY-C},_=b.endX-b.startX,I=b.endY-b.startY,{cl:m}=l||{},T=(Z=typeof m=="object"?m==null?void 0:m.rgb:m)!=null?Z:"#000",A=B.getFontStyleString(l!=null?l:void 0),{vt:W,ht:F}=l||{},P=W!=null?W:o.VerticalAlign.MIDDLE,N=(G=V.getCellValueOrigin(d))!=null?G:"",U=D.parseCellValue(N),j=D.getListWithColorMap(y),$=ft(U,A,_,I);this._drawDownIcon(e,b,_,I,P),e.save(),e.translateWithPrecision(b.startX,b.startY),e.beginPath(),e.rect(0,0,_-De,I),e.clip(),e.translateWithPrecision(ht,Ke);let q=0;switch(P){case o.VerticalAlign.MIDDLE:q=($.contentHeight-$.totalHeight)/2;break;case o.VerticalAlign.BOTTOM:q=$.contentHeight-$.totalHeight;break}e.translateWithPrecision(0,q),$.lines.forEach((ee,te)=>{e.save();const{width:ae,height:ie,items:le}=ee;let oe=0;switch(F){case o.HorizontalAlign.RIGHT:oe=$.contentWidth-ae;break;case o.HorizontalAlign.CENTER:oe=($.contentWidth-ae)/2;break}e.translate(oe,te*(ie+xt)),le.forEach(de=>{e.save(),e.translateWithPrecision(de.left,0),ya.drawWith(e,{...A,info:de,color:T,fill:j[de.text]}),e.restore()}),e.restore()}),e.restore(),w.set(g,{left:b.startX,top:b.startY,width:$.contentWidth+ht+De,height:$.contentHeight+Ke*2})}calcCellAutoHeight(e){var _;const{primaryWithCoord:t,style:a,data:n,row:i,col:r}=e,s=n==null?void 0:n.fontRenderExtension,{leftOffset:l=0,rightOffset:d=0,topOffset:p=0,downOffset:h=0}=s||{},f=t.isMergedMainCell?t.mergeInfo:t,c={startX:f.startX+l,endX:f.endX-d,startY:f.startY+p,endY:f.endY-h},S=this._dataValidationModel.getRuleByLocation(e.unitId,e.subUnitId,i,r);if(!S)return;const v=this._dataValidationModel.getValidator(S.type);if(!v)return;const C=c.endX-c.startX,w=c.endY-c.startY,g=(_=V.getCellValueOrigin(n))!=null?_:"",y=v.parseCellValue(g),D=B.getFontStyleString(a!=null?a:void 0);return ft(y,D,C,w).cellAutoHeight}calcCellAutoWidth(e){var _;const{primaryWithCoord:t,style:a,data:n,row:i,col:r}=e,s=n==null?void 0:n.fontRenderExtension,{leftOffset:l=0,rightOffset:d=0,topOffset:p=0,downOffset:h=0}=s||{},f=t.isMergedMainCell?t.mergeInfo:t,c={startX:f.startX+l,endX:f.endX-d,startY:f.startY+p,endY:f.endY-h},S=this._dataValidationModel.getRuleByLocation(e.unitId,e.subUnitId,i,r);if(!S)return;const v=this._dataValidationModel.getValidator(S.type);if(!v)return;const C=c.endX-c.startX,w=c.endY-c.startY,g=(_=V.getCellValueOrigin(n))!=null?_:"",y=v.parseCellValue(g),D=B.getFontStyleString(a!=null?a:void 0);return ft(y,D,C,w).calcAutoWidth}isHit(e,t){const{primaryWithCoord:a}=t,n=a.isMergedMainCell?a.mergeInfo:a,{endX:i}=n,{x:r}=e;return r>=i-De&&r<=i}onPointerDown(e,t){if(t.button===2)return;const{unitId:a,subUnitId:n,row:i,col:r}=e,s={unitId:a,subUnitId:n,row:i,column:r};this._commandService.executeCommand(Ue.id,s)}onPointerEnter(e,t){var a,n;(n=(a=this._renderManagerService.getCurrentTypeOfRenderer(o.UniverInstanceType.UNIVER_SHEET))==null?void 0:a.mainComponent)==null||n.setCursor(B.CURSOR_TYPE.POINTER)}onPointerLeave(e,t){var a,n;(n=(a=this._renderManagerService.getCurrentTypeOfRenderer(o.UniverInstanceType.UNIVER_SHEET))==null?void 0:a.mainComponent)==null||n.setCursor(B.CURSOR_TYPE.DEFAULT)}};mt=Ea([vt(0,o.ICommandService),vt(1,o.Inject(B.IRenderManagerService)),vt(2,o.Inject(V.SheetDataValidationModel))],mt);class ba extends pe{constructor(){super(...arguments);O(this,"id",o.DataValidationType.LIST_MULTIPLE);O(this,"canvasRender",this.injector.createInstance(mt));O(this,"dropdown",We)}}var La=Object.defineProperty,Ta=Object.getOwnPropertyDescriptor,Oa=(e,t,a,n)=>{for(var i=n>1?void 0:n?Ta(t,a):t,r=e.length-1,s;r>=0;r--)(s=e[r])&&(i=(n?s(t,a,i):s(i))||i);return n&&i&&La(t,a,i),i},Ge=(e,t)=>(a,n)=>t(a,n,e);const ye=4,qe=4,ce=14,he=6,Te=4,gt=8,Pa="#565656",Xt=new Path2D("M3.32201 4.84556C3.14417 5.05148 2.85583 5.05148 2.67799 4.84556L0.134292 1.90016C-0.152586 1.56798 0.0505937 1 0.456301 1L5.5437 1C5.94941 1 6.15259 1.56798 5.86571 1.90016L3.32201 4.84556Z");function Ra(e,t){const a=e.length;return{id:"d",body:{dataStream:`${e}${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,...t,bg:void 0,bd:void 0},st:0,ed:a}]},documentStyle:{pageSize:{width:Number.POSITIVE_INFINITY,height:Number.POSITIVE_INFINITY}}}}function zt(e,t,a){const n=Ra(e,a),i=new o.DocumentDataModel(n),r=new B.DocumentViewModel(i);return{documentSkeleton:B.DocumentSkeleton.create(r,t),docModel:i,docViewModel:r}}function Ze(e,t,a){const{documentSkeleton:n,docModel:i,docViewModel:r}=zt(e,t,a);return{documents:new B.Documents(`DOCUMENTS_${o.Tools.generateRandomId()}`,n,{pageMarginLeft:0,pageMarginTop:0}),documentSkeleton:n,docModel:i,docViewModel:r}}function Kt(e,t,a,n,i,r,s=!0){let l=0;const d=s?Te:0;switch(i){case o.VerticalAlign.BOTTOM:l=t-n-d;break;case o.VerticalAlign.MIDDLE:l=(t-n)/2;break;default:l=d;break}l=Math.max(Te,l);let p=0;switch(r){case o.HorizontalAlign.CENTER:p=(e-a)/2;break;case o.HorizontalAlign.RIGHT:p=e-a;break}return p=Math.max(he,p),{paddingLeft:p,paddingTop:l}}let St=class{constructor(e,t,a,n){O(this,"_dropdownInfoMap",new Map);O(this,"zIndex");this._localeService=e,this._commandService=t,this._renderManagerService=a,this._dataValidationModel=n}_ensureMap(e){let t=this._dropdownInfoMap.get(e);return t||(t=new Map,this._dropdownInfoMap.set(e,t)),t}_generateKey(e,t){return`${e}.${t}`}_drawDownIcon(e,t,a,n,i,r,s){const{t:l=o.DEFAULT_STYLES.pd.t,b:d=o.DEFAULT_STYLES.pd.b}=s,p=a-ce;let h;switch(r){case o.VerticalAlign.MIDDLE:h=(n-qe)/2;break;case o.VerticalAlign.BOTTOM:h=n-d-i-Te+(i/2-qe/2);break;default:h=l+Te+(i/2-qe/2);break}e.save(),e.translateWithPrecision(t.startX+p,t.startY+h),e.fillStyle="#565656",e.fill(Xt),e.restore()}drawWith(e,t,a){const{primaryWithCoord:n,row:i,col:r,style:s,data:l,subUnitId:d}=t,p=n.isMergedMainCell?n.mergeInfo:n,h=this._dataValidationModel.getRuleByLocation(t.unitId,t.subUnitId,i,r);if(!h)return;const f=this._dataValidationModel.getValidator(h.type);if(!f)return;const c=l==null?void 0:l.fontRenderExtension,{leftOffset:S=0,rightOffset:v=0,topOffset:C=0,downOffset:w=0}=c||{};if(!h||!f||!f||f.id.indexOf(o.DataValidationType.LIST)!==0||!f.skipDefaultFontRender(h))return;const g={startX:p.startX+S,endX:p.endX-v,startY:p.startY+C,endY:p.endY-w},y=g.endX-g.startX,D=g.endY-g.startY,b=this._ensureMap(d),_=this._generateKey(i,r),I=f.getListWithColor(h),m=V.getCellValueOrigin(l),T=`${m!=null?m:""}`,A=I.find(U=>U.label===T);let{tb:W,vt:F,ht:P,pd:N}=s||{};if(W=W!=null?W:o.WrapStrategy.WRAP,F=F!=null?F:o.VerticalAlign.BOTTOM,P=P!=null?P:o.DEFAULT_STYLES.ht,N=N!=null?N:o.DEFAULT_STYLES.pd,h.renderMode===o.DataValidationRenderMode.ARROW){const{l:U=o.DEFAULT_STYLES.pd.l,t:j=o.DEFAULT_STYLES.pd.t,r:$=o.DEFAULT_STYLES.pd.r,b:q=o.DEFAULT_STYLES.pd.b}=N,Z=y-U-$-ce-4,{documentSkeleton:G,documents:ee,docModel:te}=Ze(T,this._localeService,s);W===o.WrapStrategy.WRAP&&te.updateDocumentDataPageSize(Math.max(Z,1)),G.calculate(),G.getActualSize();const ae=B.getDocsSkeletonPageSize(G),{height:ie,width:le}=ae,{paddingTop:oe,paddingLeft:de}=Kt(Z,D-j-q,le,ie,F,P,!0);this._drawDownIcon(e,g,y,D,ie,F,N),e.save(),e.translateWithPrecision(g.startX+U,g.startY+j),e.beginPath(),e.rect(0,0,y-U-$,D-j-q),e.clip(),e.translateWithPrecision(0,oe),e.save(),e.translateWithPrecision(ye,0),e.beginPath(),e.rect(0,0,Z,ie),e.clip(),ee.render(e),e.translateWithPrecision(de,0),e.restore(),e.restore(),b.set(_,{left:g.endX+U+a.rowHeaderWidth-ce,top:g.startY+j+a.columnHeaderHeight,width:ce,height:D-j-q})}else{e.save(),e.translateWithPrecision(g.startX,g.startY),e.beginPath(),e.rect(0,0,y,D),e.clip();const U=y-he*2-ye-ce-4,{documentSkeleton:j,documents:$,docModel:q}=Ze(T,this._localeService,s);W===o.WrapStrategy.WRAP&&q.updateDocumentDataPageSize(Math.max(U,1)),j.calculate();const Z=B.getDocsSkeletonPageSize(j),{height:G,width:ee}=Z,{paddingTop:te,paddingLeft:ae}=Kt(U,D,ee,G,F,P);e.translateWithPrecision(he,te);const ie=Math.max(y-he*2,1),le=G;B.Rect.drawWith(e,{width:ie,height:le,fill:(A==null?void 0:A.color)||Ie,radius:gt}),e.save(),e.translateWithPrecision(ye,0),e.beginPath(),e.rect(0,0,U,G),e.clip(),e.translateWithPrecision(ae,0),$.render(e),e.restore(),e.translateWithPrecision(U+ye+4,(G-qe)/2),e.fillStyle=Pa,e.fill(Xt),e.restore(),b.set(_,{left:g.startX+he+a.rowHeaderWidth,top:g.startY+te+a.columnHeaderHeight,width:ie,height:le})}}calcCellAutoHeight(e){const{primaryWithCoord:t,style:a,data:n,row:i,col:r}=e,s=t.isMergedMainCell?t.mergeInfo:t,l=n==null?void 0:n.fontRenderExtension,{leftOffset:d=0,rightOffset:p=0,topOffset:h=0,downOffset:f=0}=l||{},c=this._dataValidationModel.getRuleByLocation(e.unitId,e.subUnitId,i,r);if(!c||c.renderMode===o.DataValidationRenderMode.TEXT)return;const S={startX:s.startX+d,endX:s.endX-p,startY:s.startY+h,endY:s.endY-f},v=S.endX-S.startX,C=V.getCellValueOrigin(n),w=`${C!=null?C:""}`;let{tb:g,pd:y}=a||{};const{t:D=o.DEFAULT_STYLES.pd.t,b=o.DEFAULT_STYLES.pd.b}=y!=null?y:{};if(g=g!=null?g:o.WrapStrategy.WRAP,c.renderMode===o.DataValidationRenderMode.ARROW){const _=v-ce,{documentSkeleton:I,docModel:m}=Ze(w,this._localeService,a);g===o.WrapStrategy.WRAP&&m.updateDocumentDataPageSize(Math.max(_,1)),I.calculate(),I.getActualSize();const T=B.getDocsSkeletonPageSize(I),{height:A}=T;return A+D+b+Te*2}else{const _=v-he*2-ye-ce,{documentSkeleton:I,docModel:m}=zt(w,this._localeService,a);g===o.WrapStrategy.WRAP&&m.updateDocumentDataPageSize(Math.max(_,1)),I.calculate();const T=B.getDocsSkeletonPageSize(I),{height:A}=T;return A+Te*2}}calcCellAutoWidth(e){const{primaryWithCoord:t,style:a,data:n,row:i,col:r}=e,s=t.isMergedMainCell?t.mergeInfo:t,l=n==null?void 0:n.fontRenderExtension,{leftOffset:d=0,rightOffset:p=0,topOffset:h=0,downOffset:f=0}=l||{},c=this._dataValidationModel.getRuleByLocation(e.unitId,e.subUnitId,i,r);if(!c||c.renderMode===o.DataValidationRenderMode.TEXT)return;const S={startX:s.startX+d,endX:s.endX-p,startY:s.startY+h,endY:s.endY-f},v=S.endX-S.startX,C=V.getCellValueOrigin(n),w=`${C!=null?C:""}`;let{tb:g,pd:y}=a||{};const{l:D=o.DEFAULT_STYLES.pd.l,r:b=o.DEFAULT_STYLES.pd.r}=y!=null?y:{};g=g!=null?g:o.WrapStrategy.WRAP;let _=he*2+ce;switch(c.renderMode){case o.DataValidationRenderMode.ARROW:_=ce+he*2+b+D;break;case o.DataValidationRenderMode.CUSTOM:_=ce+he*2+ye*2+b+D+gt/2+1;break;default:_=ce+he*2+ye*2+b+D+gt/2+1}const I=v-_,{documentSkeleton:m,docModel:T}=Ze(w,this._localeService,a);return g===o.WrapStrategy.WRAP&&T.updateDocumentDataPageSize(Math.max(I,1)),m.calculate(),m.getActualSize(),B.getDocsSkeletonPageSize(m).width+_}isHit(e,t){const{subUnitId:a,row:n,col:i}=t,s=this._ensureMap(a).get(this._generateKey(n,i)),l=this._dataValidationModel.getRuleByLocation(t.unitId,t.subUnitId,n,i);if(!l||!s||l.renderMode===o.DataValidationRenderMode.TEXT)return!1;const{top:d,left:p,width:h,height:f}=s,{x:c,y:S}=e;return c>=p&&c<=p+h&&S>=d&&S<=d+f}onPointerDown(e,t){if(t.button===2)return;const{unitId:a,subUnitId:n,row:i,col:r}=e,s={unitId:a,subUnitId:n,row:i,column:r};this._commandService.executeCommand(Ue.id,s)}onPointerEnter(e,t){var a,n;(n=(a=this._renderManagerService.getCurrentTypeOfRenderer(o.UniverInstanceType.UNIVER_SHEET))==null?void 0:a.mainComponent)==null||n.setCursor(B.CURSOR_TYPE.POINTER)}onPointerLeave(e,t){var a,n;(n=(a=this._renderManagerService.getCurrentTypeOfRenderer(o.UniverInstanceType.UNIVER_SHEET))==null?void 0:a.mainComponent)==null||n.setCursor(B.CURSOR_TYPE.DEFAULT)}};St=Oa([Ge(0,o.Inject(o.LocaleService)),Ge(1,o.ICommandService),Ge(2,o.Inject(B.IRenderManagerService)),Ge(3,o.Inject(V.SheetDataValidationModel))],St);class Aa extends pe{constructor(){super(...arguments);O(this,"id",o.DataValidationType.LIST);O(this,"canvasRender",this.injector.createInstance(St));O(this,"dropdown",We);O(this,"optionsInput",xe.componentKey);O(this,"formulaInput",ct)}}class Fa extends pe{constructor(){super(...arguments);O(this,"id",o.DataValidationType.TEXT_LENGTH);O(this,"formulaInput",Ye)}}class Na extends pe{constructor(){super(...arguments);O(this,"id",o.DataValidationType.WHOLE);O(this,"formulaInput",Ye)}}var Ua=Object.defineProperty,ja=Object.getOwnPropertyDescriptor,Ba=(e,t,a,n)=>{for(var i=n>1?void 0:n?ja(t,a):t,r=e.length-1,s;r>=0;r--)(s=e[r])&&(i=(n?s(t,a,i):s(i))||i);return n&&i&&Ua(t,a,i),i},_t=(e,t)=>(a,n)=>t(a,n,e);let Oe=class extends o.RxDisposable{constructor(e,t,a){super(),this._injector=e,this._componentManger=t,this._dataValidatorRegistryService=a,this._initComponents(),this._registerValidatorViews()}_initComponents(){[[At,Vt],[Ne,Tn],[Ot,gn],[We,Dn],[rt,tn],[xe.componentKey,xe],[Xe.componentKey,Xe],...oa].forEach(([e,t])=>{this.disposeWithMe(this._componentManger.register(e,t))})}_registerValidatorViews(){[_a,Na,Fa,Sa,va,Aa,ba,ma].forEach(e=>{const t=this._injector.createInstance(e),a=this._dataValidatorRegistryService.getValidatorItem(t.id);a&&(a.formulaInput=t.formulaInput,a.canvasRender=t.canvasRender,a.dropdown=t.dropdown,a.optionsInput=t.optionsInput)})}};Oe=Ba([_t(0,o.Inject(o.Injector)),_t(1,o.Inject(z.ComponentManager)),_t(2,o.Inject(J.DataValidatorRegistryService))],Oe);var ka=Object.defineProperty,Wa=Object.getOwnPropertyDescriptor,$a=(e,t,a,n)=>{for(var i=n>1?void 0:n?Wa(t,a):t,r=e.length-1,s;r>=0;r--)(s=e[r])&&(i=(n?s(t,a,i):s(i))||i);return n&&i&&ka(t,a,i),i},It=(e,t)=>(a,n)=>t(a,n,e);const Ha="SHEET_DATA_VALIDATION_UI_PLUGIN";Y.UniverSheetsDataValidationUIPlugin=(Je=class extends o.Plugin{constructor(t=je,a,n,i){super(),this._config=t,this._injector=a,this._commandService=n,this._configService=i;const{menu:r,...s}=o.merge({},je,this._config);r&&this._configService.setConfig("menu",r,{merge:!0}),this._configService.setConfig(it,s)}onStarting(){[[ue],[me],[Ae],[Ee],[Le],[be],[Me],[Re],[Oe]].forEach(t=>{this._injector.add(t)}),[$e,Ue,Rt,at,_e,Pt].forEach(t=>{this._commandService.registerCommand(t)})}onReady(){this._injector.get(Me),this._injector.get(be),this._injector.get(Re),this._injector.get(Ae),this._injector.get(B.IRenderManagerService).registerRenderModule(o.UniverInstanceType.UNIVER_SHEET,[He])}onRendered(){this._injector.get(Oe),this._injector.get(Le)}onSteady(){this._injector.get(Ee)}},O(Je,"pluginName",Ha),O(Je,"type",o.UniverInstanceType.UNIVER_SHEET),Je),Y.UniverSheetsDataValidationUIPlugin=$a([It(1,o.Inject(o.Injector)),It(2,o.ICommandService),It(3,o.IConfigService)],Y.UniverSheetsDataValidationUIPlugin);var Ya=Object.defineProperty,xa=Object.getOwnPropertyDescriptor,Xa=(e,t,a,n)=>{for(var i=n>1?void 0:n?xa(t,a):t,r=e.length-1,s;r>=0;r--)(s=e[r])&&(i=(n?s(t,a,i):s(i))||i);return n&&i&&Ya(t,a,i),i},Ct=(e,t)=>(a,n)=>t(a,n,e);const za="SHEET_DATA_VALIDATION_UI_PLUGIN";Y.UniverSheetsDataValidationMobileUIPlugin=(Qe=class extends o.Plugin{constructor(t=je,a,n,i){super(),this._config=t,this._injector=a,this._commandService=n,this._configService=i;const{menu:r,...s}=o.merge({},je,this._config);r&&this._configService.setConfig("menu",r,{merge:!0}),this._configService.setConfig(it,s)}onStarting(){[[ue],[me],[Ae],[Ee],[Le],[be],[Me],[Oe]].forEach(t=>{this._injector.add(t)}),[$e,Ue,Rt,at,_e,Pt].forEach(t=>{this._commandService.registerCommand(t)})}onReady(){this._injector.get(Me),this._injector.get(be),this._injector.get(B.IRenderManagerService).registerRenderModule(o.UniverInstanceType.UNIVER_SHEET,[He])}onRendered(){this._injector.get(Oe),this._injector.get(Le)}onSteady(){this._injector.get(Ee)}},O(Qe,"pluginName",za),O(Qe,"type",o.UniverInstanceType.UNIVER_SHEET),Qe),Y.UniverSheetsDataValidationMobileUIPlugin=Xa([Ct(1,o.Inject(o.Injector)),Ct(2,o.ICommandService),Ct(3,o.IConfigService)],Y.UniverSheetsDataValidationMobileUIPlugin),Y.DATE_DROPDOWN_KEY=rt,Y.LIST_DROPDOWN_KEY=We,Object.defineProperty(Y,Symbol.toStringTag,{value:"Module"})});
14
+ (function(x,u){typeof exports=="object"&&typeof module<"u"?u(exports,require("react/jsx-runtime"),require("@univerjs/core"),require("@univerjs/design"),require("@univerjs/engine-render"),require("@univerjs/sheets"),require("@univerjs/sheets-data-validation"),require("@univerjs/sheets-numfmt"),require("@univerjs/sheets-ui"),require("@univerjs/ui"),require("react"),require("@univerjs/data-validation"),require("@univerjs/docs"),require("rxjs"),require("@univerjs/engine-formula"),require("@univerjs/sheets-formula-ui")):typeof define=="function"&&define.amd?define(["exports","react/jsx-runtime","@univerjs/core","@univerjs/design","@univerjs/engine-render","@univerjs/sheets","@univerjs/sheets-data-validation","@univerjs/sheets-numfmt","@univerjs/sheets-ui","@univerjs/ui","react","@univerjs/data-validation","@univerjs/docs","rxjs","@univerjs/engine-formula","@univerjs/sheets-formula-ui"],u):(x=typeof globalThis<"u"?globalThis:x||self,u(x.UniverSheetsDataValidationUi={},x.React,x.UniverCore,x.UniverDesign,x.UniverEngineRender,x.UniverSheets,x.UniverSheetsDataValidation,x.UniverSheetsNumfmt,x.UniverSheetsUi,x.UniverUi,x.React,x.UniverDataValidation,x.UniverDocs,x.rxjs,x.UniverEngineFormula,x.UniverSheetsFormulaUi))})(this,function(x,u,r,T,W,z,E,Gt,B,f,M,J,qt,re,et,tt){"use strict";var Ra=Object.defineProperty;var Aa=(x,u,r)=>u in x?Ra(x,u,{enumerable:!0,configurable:!0,writable:!0,value:r}):x[u]=r;var P=(x,u,r)=>Aa(x,typeof u!="symbol"?u+"":u,r);var Je,Qe;var Zt=Object.getOwnPropertyDescriptor,Jt=(e,t,a,n)=>{for(var o=n>1?void 0:n?Zt(t,a):t,i=e.length-1,s;i>=0;i--)(s=e[i])&&(o=s(o)||o);return o},Pe=(e,t)=>(a,n)=>t(a,n,e);let Re=class extends r.Disposable{constructor(e,t,a,n,o){super(),this._sheetInterceptorService=e,this._dataValidationModel=t,this._dataValidatorRegistryService=a,this._dialogService=n,this._localeService=o,this._initEditorBridgeInterceptor()}_initEditorBridgeInterceptor(){this._sheetInterceptorService.writeCellInterceptor.intercept(z.AFTER_CELL_EDIT_ASYNC,{handler:async(e,t,a)=>{var D;const n=await e,{worksheet:o,row:i,col:s,unitId:l,subUnitId:d,workbook:h}=t,p=this._dataValidationModel.getRuleIdByLocation(l,d,i,s),v=p?this._dataValidationModel.getRuleById(l,d,p):void 0;if(!v||v.errorStyle!==r.DataValidationErrorStyle.STOP)return a(Promise.resolve(n));const c=await this._dataValidatorRegistryService.getValidatorItem(v.type);if(!c||await c.validator({value:E.getCellValueOrigin(n),interceptValue:E.getCellValueOrigin((D=t==null?void 0:t.origin)!=null?D:n),row:i,column:s,unitId:l,subUnitId:d,worksheet:o,workbook:h,t:n==null?void 0:n.t},v))return a(Promise.resolve(n));const g=o.getCellRaw(i,s);return this._dialogService.open({width:368,title:{title:this._localeService.t("dataValidation.alert.title")},id:"reject-input-dialog",children:{title:c.getRuleFinalError(v,{row:i,col:s,unitId:l,subUnitId:d})},footer:{title:M.createElement(T.Button,{type:"primary",onClick:()=>this._dialogService.close("reject-input-dialog")},this._localeService.t("dataValidation.alert.ok"))},onClose:()=>{this._dialogService.close("reject-input-dialog")}}),a(Promise.resolve(g))}})}showReject(e){this._dialogService.open({width:368,title:{title:this._localeService.t("dataValidation.alert.title")},id:"reject-input-dialog",children:{title:e},footer:{title:M.createElement(T.Button,{type:"primary",onClick:()=>this._dialogService.close("reject-input-dialog")},this._localeService.t("dataValidation.alert.ok"))},onClose:()=>{this._dialogService.close("reject-input-dialog")}})}};Re=Jt([Pe(0,r.Inject(z.SheetInterceptorService)),Pe(1,r.Inject(E.SheetDataValidationModel)),Pe(2,r.Inject(J.DataValidatorRegistryService)),Pe(3,f.IDialogService),Pe(4,r.Inject(r.LocaleService))],Re);const Dt={dvDateDropdown:"univer-dv-date-dropdown",dvDateDropdownBtns:"univer-dv-date-dropdown-btns"},Qt=e=>{if(e==null||typeof e=="boolean")return;if(typeof e=="number"||!Number.isNaN(+e))return r.dayjs(r.numfmt.format("yyyy-MM-dd HH:mm:ss",Number(e)));const t=r.dayjs(e);if(t.isValid())return t};function en(e){var m;const{location:t,hideFn:a}=e,{worksheet:n,row:o,col:i,unitId:s,subUnitId:l,workbook:d}=t,h=f.useDependency(r.ICommandService),p=f.useDependency(Re),v=n.getCell(o,i),c=E.getCellValueOrigin(n.getCellRaw(o,i)),_=Qt(c),[g,D]=M.useState(_),V=g&&g.isValid()?g:r.dayjs(),S=f.useDependency(r.LocaleService),w=f.useDependency(E.SheetDataValidationModel),y=w.getRuleByLocation(s,l,o,i);if(!y)return null;const L=w.getValidator(y.type);if(!v||!L)return;const I=!!((m=y.bizInfo)!=null&&m.showTime),C=async()=>{var U,j,H;if(!V)return;const F=V.format(I?"YYYY-MM-DD HH:mm:ss":"YYYY-MM-DD 00:00:00"),$=(U=r.numfmt.parseDate(F))==null?void 0:U.v,k=d.getStyles().getStyleByCell(v),R=(H=(j=k==null?void 0:k.n)==null?void 0:j.pattern)!=null?H:"",N=Gt.getPatternType(R);y.errorStyle!==r.DataValidationErrorStyle.STOP||await L.validator({value:$,unitId:s,subUnitId:l,row:o,column:i,worksheet:n,workbook:d,interceptValue:F.replace("Z","").replace("T"," "),t:r.CellValueType.NUMBER},y)?(a(),await h.executeCommand(B.SetCellEditVisibleOperation.id,{visible:!1,eventType:W.DeviceInputEventType.Keyboard,unitId:s,keycode:f.KeyCode.ESC}),await h.executeCommand(z.SetRangeValuesCommand.id,{unitId:s,subUnitId:l,range:{startColumn:i,endColumn:i,startRow:o,endRow:o},value:{v:$,t:2,p:null,f:null,si:null,s:{n:{pattern:I?N==="datetime"?R:"yyyy-MM-dd hh:mm:ss":N==="date"?R:"yyyy-MM-dd"}}}})):p.showReject(L.getRuleFinalError(y,{row:o,col:i,unitId:s,subUnitId:l}))};return u.jsxs("div",{className:Dt.dvDateDropdown,children:[u.jsx(T.DatePanel,{defaultValue:V,pickerValue:V,showTime:I||void 0,onSelect:async O=>{D(O)},onPanelChange:O=>{D(O)},disabledDate:O=>!r.numfmt.parseDate(O.format("YYYY-MM-DD"))}),u.jsx("div",{className:Dt.dvDateDropdownBtns,children:u.jsx(T.Button,{size:"small",type:"primary",onClick:C,disabled:!V.isValid(),children:S.t("dataValidation.alert.ok")})})]})}var se=function(){return se=Object.assign||function(e){for(var t,a=1,n=arguments.length;a<n;a++){t=arguments[a];for(var o in t)Object.prototype.hasOwnProperty.call(t,o)&&(e[o]=t[o])}return e},se.apply(this,arguments)},tn=function(e,t){var a={};for(var n in e)Object.prototype.hasOwnProperty.call(e,n)&&t.indexOf(n)<0&&(a[n]=e[n]);if(e!=null&&typeof Object.getOwnPropertySymbols=="function")for(var o=0,n=Object.getOwnPropertySymbols(e);o<n.length;o++)t.indexOf(n[o])<0&&Object.prototype.propertyIsEnumerable.call(e,n[o])&&(a[n[o]]=e[n[o]]);return a},ge=M.forwardRef(function(e,t){var a=e.icon,n=e.id,o=e.className,i=e.extend,s=tn(e,["icon","id","className","extend"]),l="univerjs-icon univerjs-icon-".concat(n," ").concat(o||"").trim(),d=M.useRef("_".concat(on()));return yt(a,"".concat(n),{defIds:a.defIds,idSuffix:d.current},se({ref:t,className:l},s),i)});function yt(e,t,a,n,o){return M.createElement(e.tag,se(se({key:t},nn(e,a,o)),n),(an(e,a).children||[]).map(function(i,s){return yt(i,"".concat(t,"-").concat(e.tag,"-").concat(s),a,void 0,o)}))}function nn(e,t,a){var n=se({},e.attrs);a!=null&&a.colorChannel1&&n.fill==="colorChannel1"&&(n.fill=a.colorChannel1);var o=t.defIds;return!o||o.length===0||(e.tag==="use"&&n["xlink:href"]&&(n["xlink:href"]=n["xlink:href"]+t.idSuffix),Object.entries(n).forEach(function(i){var s=i[0],l=i[1];typeof l=="string"&&(n[s]=l.replace(/url\(#(.*)\)/,"url(#$1".concat(t.idSuffix,")")))})),n}function an(e,t){var a,n=t.defIds;return!n||n.length===0?e:e.tag==="defs"&&(!((a=e.children)===null||a===void 0)&&a.length)?se(se({},e),{children:e.children.map(function(o){return typeof o.attrs.id=="string"&&n&&n.indexOf(o.attrs.id)>-1?se(se({},o),{attrs:se(se({},o.attrs),{id:o.attrs.id+t.idSuffix})}):o})}):e}function on(){return Math.random().toString(36).substring(2,8)}ge.displayName="UniverIcon";var rn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M14.1544 3.75557C14.3887 3.98988 14.3887 4.36978 14.1544 4.6041L6.51409 12.2444C6.40157 12.3569 6.24896 12.4201 6.08983 12.4201C5.9307 12.4201 5.77808 12.3569 5.66556 12.2444L1.84541 8.42425C1.6111 8.18993 1.6111 7.81003 1.84541 7.57572C2.07973 7.34141 2.45963 7.34141 2.69394 7.57572L6.08983 10.9716L13.3059 3.75557C13.5402 3.52126 13.9201 3.52126 14.1544 3.75557Z",fillRule:"evenodd",clipRule:"evenodd"}}]},wt=M.forwardRef(function(e,t){return M.createElement(ge,Object.assign({},e,{id:"check-mark-single",ref:t,icon:rn}))});wt.displayName="CheckMarkSingle";var sn={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"}}]},Vt=M.forwardRef(function(e,t){return M.createElement(ge,Object.assign({},e,{id:"data-validation-single",ref:t,icon:sn}))});Vt.displayName="DataValidationSingle";var ln={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"}}]},nt=M.forwardRef(function(e,t){return M.createElement(ge,Object.assign({},e,{id:"delete-single",ref:t,icon:ln}))});nt.displayName="DeleteSingle";var dn={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"}}]},Et=M.forwardRef(function(e,t){return M.createElement(ge,Object.assign({},e,{id:"increase-single",ref:t,icon:dn}))});Et.displayName="IncreaseSingle";var cn={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"}}]},Mt=M.forwardRef(function(e,t){return M.createElement(ge,Object.assign({},e,{id:"more-down-single",ref:t,icon:cn}))});Mt.displayName="MoreDownSingle";var un={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"}}]},bt=M.forwardRef(function(e,t){return M.createElement(ge,Object.assign({},e,{id:"more-up-single",ref:t,icon:un}))});bt.displayName="MoreUpSingle";var hn={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"}}]}]},Lt=M.forwardRef(function(e,t){return M.createElement(ge,Object.assign({},e,{id:"sequence-single",ref:t,icon:hn}))});Lt.displayName="SequenceSingle";var pn=Object.getOwnPropertyDescriptor,vn=(e,t,a,n)=>{for(var o=n>1?void 0:n?pn(t,a):t,i=e.length-1,s;i>=0;i--)(s=e[i])&&(o=s(o)||o);return o},Tt=(e,t)=>(a,n)=>t(a,n,e);let ue=class extends r.Disposable{constructor(t,a){super();P(this,"_open$",new re.BehaviorSubject(!1));P(this,"open$",this._open$.pipe(re.distinctUntilChanged()));P(this,"_activeRule");P(this,"_activeRule$",new re.BehaviorSubject(void 0));P(this,"activeRule$",this._activeRule$.asObservable());P(this,"_closeDisposable",null);this._univerInstanceService=t,this._sidebarService=a,this.disposeWithMe(this._univerInstanceService.getCurrentTypeOfUnit$(r.UniverInstanceType.UNIVER_SHEET).pipe(re.filter(n=>!n)).subscribe(()=>{this.close()})),this.disposeWithMe(this._sidebarService.sidebarOptions$.subscribe(n=>{n.id===ke&&(n.visible||setTimeout(()=>{this._sidebarService.sidebarOptions$.next({visible:!1})}))}))}get activeRule(){return this._activeRule}get isOpen(){return this._open$.getValue()}dispose(){var t;super.dispose(),this._open$.next(!1),this._open$.complete(),this._activeRule$.complete(),(t=this._closeDisposable)==null||t.dispose()}open(){this._open$.next(!0)}close(){var t;this._open$.next(!1),(t=this._closeDisposable)==null||t.dispose()}setCloseDisposable(t){this._closeDisposable=r.toDisposable(()=>{t.dispose(),this._closeDisposable=null})}setActiveRule(t){this._activeRule=t,this._activeRule$.next(t)}};ue=vn([Tt(0,r.IUniverInstanceService),Tt(1,f.ISidebarService)],ue);function gn(){const e=f.useDependency(me),t=f.useObservable(e.activeDropdown$,e.activeDropdown),a=f.useDependency(f.ComponentManager);if(!t)return null;const{location:n,componentKey:o}=t,i=a.get(o),s=`${n.unitId}-${n.subUnitId}-${n.row}-${n.col}`;if(!i)return null;const l=()=>{e.hideDropdown()};return u.jsx(i,{location:n,hideFn:l},s)}const Ot="sheet.ui.dropdown";var mn=Object.getOwnPropertyDescriptor,fn=(e,t,a,n)=>{for(var o=n>1?void 0:n?mn(t,a):t,i=e.length-1,s;i>=0;i--)(s=e[i])&&(o=s(o)||o);return o},Se=(e,t)=>(a,n)=>t(a,n,e);let me=class extends r.Disposable{constructor(t,a,n,o,i,s,l){super();P(this,"_activeDropdown");P(this,"_activeDropdown$",new re.Subject);P(this,"_currentPopup",null);P(this,"activeDropdown$",this._activeDropdown$.asObservable());P(this,"_zenVisible",!1);this._canvasPopupManagerService=t,this._univerInstanceService=a,this._dataValidatorRegistryService=n,this._zenZoneService=o,this._renderManagerService=i,this._dataValidationModel=s,this._sheetsSelectionsService=l,this._init(),this._initSelectionChange(),this.disposeWithMe(()=>{this._activeDropdown$.complete()})}get activeDropdown(){return this._activeDropdown}_init(){this.disposeWithMe(this._zenZoneService.visible$.subscribe(t=>{this._zenVisible=t,t&&this.hideDropdown()}))}_getDropdownByCell(t,a,n,o){const i=t?this._univerInstanceService.getUnit(t,r.UniverInstanceType.UNIVER_SHEET):this._univerInstanceService.getCurrentUnitForType(r.UniverInstanceType.UNIVER_SHEET);if(!i)return;const s=a?i.getSheetBySheetId(a):i.getActiveSheet();if(!s)return;const l=this._dataValidationModel.getRuleByLocation(i.getUnitId(),s.getSheetId(),n,o);if(!l)return;const d=this._dataValidatorRegistryService.getValidatorItem(l.type);return d==null?void 0:d.dropdown}_initSelectionChange(){this.disposeWithMe(this._sheetsSelectionsService.selectionMoveEnd$.subscribe(t=>{t&&t.every(a=>!(a.primary&&this._getDropdownByCell(a.primary.unitId,a.primary.sheetId,a.primary.actualRow,a.primary.actualColumn)))&&this.hideDropdown()}))}showDropdown(t,a=!0){const{location:n}=t,{row:o,col:i,unitId:s,subUnitId:l}=n;if(this._currentPopup&&this._currentPopup.dispose(),this._zenVisible)return;this._activeDropdown=t,this._activeDropdown$.next(this._activeDropdown);const d=this._renderManagerService.getRenderById(r.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),h=this._canvasPopupManagerService.attachPopupToCell(o,i,{componentKey:Ot,onClickOutside:()=>{a&&this.hideDropdown()},offset:[0,3],excludeOutside:[d==null?void 0:d.engine.getCanvasElement()].filter(Boolean)},s,l);if(!h)throw new Error("[DataValidationDropdownManagerService]: cannot show dropdown!");const p=new r.DisposableCollection;p.add(h),p.add({dispose:()=>{var v,c;(c=(v=this._activeDropdown)==null?void 0:v.onHide)==null||c.call(v)}}),this._currentPopup=p}hideDropdown(){this._activeDropdown&&(this._currentPopup&&this._currentPopup.dispose(),this._currentPopup=null,this._activeDropdown=null,this._activeDropdown$.next(null))}showDataValidationDropdown(t,a,n,o,i){const s=this._univerInstanceService.getUnit(t,r.UniverInstanceType.UNIVER_SHEET);if(!s)return;const l=s.getSheetBySheetId(a);if(!l)return;const d=this._dataValidationModel.getRuleByLocation(s.getUnitId(),l.getSheetId(),n,o);if(!d)return;const h=this._dataValidatorRegistryService.getValidatorItem(d.type);if(!h||!h.dropdown){this.hideDropdown();return}this.showDropdown({location:{workbook:s,worksheet:l,row:n,col:o,unitId:t,subUnitId:a},componentKey:h.dropdown,onHide:i})}};me=fn([Se(0,r.Inject(B.SheetCanvasPopManagerService)),Se(1,r.IUniverInstanceService),Se(2,r.Inject(J.DataValidatorRegistryService)),Se(3,f.IZenZoneService),Se(4,W.IRenderManagerService),Se(5,r.Inject(E.SheetDataValidationModel)),Se(6,r.Inject(z.SheetsSelectionsService))],me);const ke="DataValidationPanel",_e={id:"data-validation.operation.open-validation-panel",type:r.CommandType.OPERATION,handler(e,t){if(!t)return!1;const{ruleId:a,isAdd:n}=t,o=e.get(ue),i=e.get(J.DataValidationModel),s=e.get(r.IUniverInstanceService),l=e.get(f.ISidebarService),d=z.getSheetCommandTarget(s);if(!d)return!1;const{unitId:h,subUnitId:p}=d,v=a?i.getRuleById(h,p,a):void 0;o.open(),o.setActiveRule(v&&{unitId:h,subUnitId:p,rule:v});const c=l.open({id:ke,header:{title:n?"dataValidation.panel.addTitle":"dataValidation.panel.title"},children:{label:ke},width:312,onClose:()=>o.close()});return o.setCloseDisposable(c),!0}},at={id:"data-validation.operation.close-validation-panel",type:r.CommandType.OPERATION,handler(e){return e.get(ue).close(),!0}},Pt={id:"data-validation.operation.toggle-validation-panel",type:r.CommandType.OPERATION,handler(e){const t=e.get(r.ICommandService),a=e.get(ue);return a.open(),a.isOpen?t.executeCommand(at.id):t.executeCommand(_e.id),!0}},Ne={type:r.CommandType.OPERATION,id:"sheet.operation.show-data-validation-dropdown",handler(e,t){if(!t)return!1;const a=e.get(me),{unitId:n,subUnitId:o,row:i,column:s}=t,l=a.activeDropdown,d=l==null?void 0:l.location;return d&&d.unitId===n&&d.subUnitId===o&&d.row===i&&d.col===s||a.showDataValidationDropdown(n,o,i,s),!0}},Rt={type:r.CommandType.OPERATION,id:"sheet.operation.hide-data-validation-dropdown",handler(e,t){return t?(e.get(me).hideDropdown(),!0):!1}},Ie="#ECECEC",ot="sheets-data-validation-ui.config",Ue={},ve={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=e=>{var I,C;const{value:t,onChange:a,multiple:n,options:o,title:i,onEdit:s,style:l,filter:d,location:h}=e,p=f.useDependency(r.LocaleService),v=f.useDependency(r.IConfigService),c=d==null?void 0:d.toLowerCase(),{row:_,col:g,unitId:D,subUnitId:V}=h,S=o.filter(m=>c?m.label.toLowerCase().includes(c):!0),w=(C=(I=v.getConfig(ot))==null?void 0:I.showEditOnDropdown)!=null?C:!0,y=f.useDependency(z.SheetPermissionCheckController),L=M.useMemo(()=>y.permissionCheckWithRanges({workbookTypes:[z.WorkbookEditablePermission],rangeTypes:[z.RangeProtectionPermissionEditPoint],worksheetTypes:[z.WorksheetEditPermission]},[{startColumn:g,startRow:_,endColumn:g,endRow:_}],D,V),[y,g,_,D,V]);return u.jsxs("div",{className:ve.dvListDropdown,style:l,children:[u.jsx("div",{className:ve.dvListDropdownTitle,children:i}),u.jsx("div",{className:ve.dvListDropdownList,children:u.jsx(T.Scrollbar,{children:u.jsx("div",{className:ve.dvListDropdownListContainer,children:S.map((m,O)=>{const F=t.indexOf(m.value)>-1,$=()=>{let R;F?R=new Set(t.filter(U=>U!==m.value)):R=new Set(n?[...t,m.value]:[m.value]);const N=[];o.forEach(U=>{R.has(U.value)&&N.push(U.value)}),a(N)},k=m.label.toLocaleLowerCase().indexOf(c);return u.jsxs("div",{className:ve.dvListDropdownItemContainer,onClick:$,children:[u.jsx("div",{className:ve.dvListDropdownItem,style:{background:m.color||Ie},children:c&&m.label.toLowerCase().includes(c)?u.jsxs(u.Fragment,{children:[u.jsx("span",{children:m.label.substring(0,k)}),u.jsx("span",{style:{fontWeight:"bold"},children:m.label.substring(k,k+c.length)}),u.jsx("span",{children:m.label.substring(k+c.length)})]}):m.label}),u.jsx("div",{className:ve.dvListDropdownSelectedIcon,children:F?u.jsx(wt,{}):null})]},O)})})},d)}),w&&L?u.jsxs(u.Fragment,{children:[u.jsx("div",{className:ve.dvListDropdownSplit}),u.jsx("div",{className:ve.dvListDropdownEdit,children:u.jsx("a",{onClick:s,children:p.t("dataValidation.list.edit")})})]}):null]})};function _n(e){var j,H,q,Z;const{location:t,hideFn:a}=e,{worksheet:n,row:o,col:i,unitId:s,subUnitId:l}=t,d=f.useDependency(J.DataValidationModel),[h,p]=M.useState(""),v=f.useDependency(r.ICommandService),c=f.useDependency(r.LocaleService),[_,g]=M.useState(""),D=f.useDependency(B.IEditorBridgeService),V=f.useDependency(r.IUniverInstanceService),S=M.useMemo(()=>d.ruleChange$.pipe(re.debounceTime(16)),[]),w=f.useDependency(E.SheetDataValidationModel);f.useObservable(S);const y=f.RectPopup.useContext(),L=((H=(j=y.current)==null?void 0:j.right)!=null?H:0)-((Z=(q=y.current)==null?void 0:q.left)!=null?Z:0);if(M.useEffect(()=>{const G=v.onCommandExecuted(ee=>{var te,ae;if(ee.id===qt.RichTextEditingMutation.id){const oe=ee.params,{unitId:le}=oe,ie=V.getUnit(le,r.UniverInstanceType.UNIVER_DOC);if(!ie||!D.isVisible().visible)return;const de=r.BuildTextUtils.transform.getPlainText((ae=(te=ie.getSnapshot().body)==null?void 0:te.dataStream)!=null?ae:"");p(de)}});return()=>{G.dispose()}},[v,D,V]),!n)return null;const I=w.getRuleByLocation(s,l,o,i);if(!I)return null;const C=w.getValidator(I.type);if(!C)return null;const m=n.getCell(o,i),O=(I==null?void 0:I.renderMode)===r.DataValidationRenderMode.CUSTOM||(I==null?void 0:I.renderMode)===void 0;if(!m||!I||!C||C.id.indexOf(r.DataValidationType.LIST)!==0)return;const F=I.type===r.DataValidationType.LIST_MULTIPLE,$=C.getListWithColor(I,s,l),k=_||E.getDataValidationCellValue(n.getCellRaw(o,i)),R=E.deserializeListOptions(k),N=()=>{v.executeCommand(_e.id,{ruleId:I.uid}),a()},U=$.map(G=>({label:G.label,value:G.label,color:O||G.color?G.color:"transparent"}));return u.jsx(Sn,{style:{minWidth:L,maxWidth:Math.max(L,200)},title:F?c.t("dataValidation.listMultiple.dropdown"):c.t("dataValidation.list.dropdown"),value:R,multiple:F,onChange:async G=>{const ee=E.serializeListOptions(G),te={unitId:s,subUnitId:l,range:{startColumn:i,endColumn:i,startRow:o,endRow:o},value:{v:ee,p:null,f:null,si:null}};D.isVisible()&&v.executeCommand(B.SetCellEditVisibleOperation.id,{visible:!1,eventType:W.DeviceInputEventType.Keyboard,unitId:s,keycode:f.KeyCode.ESC}),g(ee),F||a(),D.isVisible().visible&&await v.executeCommand(B.SetCellEditVisibleOperation.id,{visible:!1,eventType:W.DeviceInputEventType.Keyboard,unitId:s,keycode:f.KeyCode.ESC}),v.executeCommand(z.SetRangeValuesCommand.id,te)},options:U,onEdit:N,filter:h,location:t})}const it={dataValidationOptionsButton:"univer-data-validation-options-button",dataValidationOptionsButtonIcon:"univer-data-validation-options-button-icon"};function In(e){var h;const t=f.useDependency(r.LocaleService),a=f.useDependency(f.ComponentManager),{value:n,onChange:o,extraComponent:i}=e,[s,l]=M.useState(!1),d=i?a.get(i):null;return u.jsxs(u.Fragment,{children:[u.jsxs("div",{className:it.dataValidationOptionsButton,onClick:()=>l(!s),children:[t.t("dataValidation.panel.options"),s?u.jsx(bt,{className:it.dataValidationOptionsButtonIcon}):u.jsx(Mt,{className:it.dataValidationOptionsButtonIcon})]}),s&&u.jsxs(u.Fragment,{children:[d?u.jsx(d,{value:n,onChange:o}):null,u.jsx(T.FormLayout,{label:t.t("dataValidation.panel.invalid"),children:u.jsxs(T.RadioGroup,{value:`${(h=n.errorStyle)!=null?h:r.DataValidationErrorStyle.WARNING}`,onChange:p=>o({...n,errorStyle:+p}),children:[u.jsx(T.Radio,{value:`${r.DataValidationErrorStyle.WARNING}`,children:t.t("dataValidation.panel.showWarning")}),u.jsx(T.Radio,{value:`${r.DataValidationErrorStyle.STOP}`,children:t.t("dataValidation.panel.rejectInput")})]})}),u.jsx(T.FormLayout,{label:t.t("dataValidation.panel.messageInfo"),children:u.jsx(T.Checkbox,{checked:n.showErrorMessage,onChange:()=>o({...n,showErrorMessage:!n.showErrorMessage}),children:t.t("dataValidation.panel.showInfo")})}),n.showErrorMessage?u.jsx(T.FormLayout,{children:u.jsx(T.Input,{value:n.error,onChange:p=>o({...n,error:p})})}):null]})]})}const we={dataValidationDetail:"univer-data-validation-detail",dataValidationDetailFormItem:"univer-data-validation-detail-form-item",dataValidationDetailButtons:"univer-data-validation-detail-buttons",dataValidationDetailButton:"univer-data-validation-detail-button"},Cn=e=>r.debounce(async(t,a,n,o)=>{const i=await e.executeCommand(t,a,n);o==null||o(i)},1e3);function Dn(e,t,a){var n,o,i,s;return t?((o=(n=e.getUnit(t))==null?void 0:n.getSheetBySheetName(a))==null?void 0:o.getSheetId())||"":((s=(i=e.getCurrentUnitForType(r.UniverInstanceType.UNIVER_SHEET))==null?void 0:i.getSheetBySheetName(a))==null?void 0:s.getSheetId())||""}function yn(){var de;const[e,t]=M.useState(0),a=f.useDependency(ue),n=f.useObservable(a.activeRule$,a.activeRule),{unitId:o,subUnitId:i,rule:s}=n||{},l=s.uid,d=f.useDependency(J.DataValidatorRegistryService),h=f.useDependency(r.IUniverInstanceService),p=f.useDependency(f.ComponentManager),v=f.useDependency(r.ICommandService),c=f.useDependency(J.DataValidationModel),_=f.useDependency(r.LocaleService),[g,D]=M.useState(s),V=d.getValidatorItem(g.type),[S,w]=M.useState(!1),y=d.getValidatorsByScope(J.DataValidatorRegistryScope.SHEET),[L,I]=M.useState(()=>g.ranges.map(A=>({unitId:"",sheetId:"",range:A}))),C=M.useMemo(()=>Cn(v),[v]),[m,O]=M.useState(!1),F=M.useRef({}),[$,k]=M.useState(!1),R=f.useDependency(z.SheetsSelectionsService);if(M.useEffect(()=>()=>{const A=R.getCurrentLastSelection();A&&R.setSelections([A])},[R]),M.useEffect(()=>{v.onCommandExecuted(A=>{(A.id===r.UndoCommand.id||A.id===r.RedoCommand.id)&&setTimeout(()=>{const b=c.getRuleById(o,i,l);t(Y=>Y+1),b&&(D(b),I(b.ranges.map(Y=>({unitId:"",sheetId:"",range:Y}))))},20)})},[v,c,l,i,o]),!V)return null;const N=V.operators,U=V.operatorNames,j=g.operator?J.TWO_FORMULA_OPERATOR_COUNT.includes(g.operator):!1,H=()=>{!g.ranges.length||m||(V.validatorFormula(g,o,i).success?a.setActiveRule(null):w(!0))},q=f.useEvent(A=>{const b=A.split(",").filter(Boolean).map(et.deserializeRangeWithSheet).map(K=>{const fe=K.sheetName;if(fe){const Pa=Dn(h,K.unitId,fe);return{...K,sheetId:Pa}}return{...K,sheetId:""}});if(r.isUnitRangesEqual(b,L))return;I(b);const Y=b.filter(K=>(!K.unitId||K.unitId===o)&&(!K.sheetId||K.sheetId===i)).map(K=>K.range);if(D({...g,ranges:Y}),Y.length===0)return;const X={unitId:o,subUnitId:i,ruleId:l,ranges:Y};C(E.UpdateSheetDataValidationRangeCommand.id,X)}),Z=A=>{if(r.shallowEqual(A,J.getRuleSetting(g)))return;D({...g,...A});const b={unitId:o,subUnitId:i,ruleId:l,setting:A};C(E.UpdateSheetDataValidationSettingCommand.id,b,void 0)},G=async()=>{await v.executeCommand(E.RemoveSheetDataValidationCommand.id,{ruleId:l,unitId:o,subUnitId:i}),a.setActiveRule(null)},ee={type:g.type,operator:g.operator,formula1:g.formula1,formula2:g.formula2,allowBlank:g.allowBlank},te=A=>{const b=d.getValidatorItem(A);if(!b)return;const Y=b.operators,X=c.getRuleById(o,i,l),K=A===(X==null?void 0:X.type)||A.includes("list")&&(X!=null&&X.type.includes("list"))?{...X,type:A}:{...g,type:A,operator:Y[0],formula1:void 0,formula2:void 0};D(K),v.executeCommand(E.UpdateSheetDataValidationSettingCommand.id,{unitId:o,subUnitId:i,ruleId:g.uid,setting:J.getRuleSetting(K)})},ae=p.get(V.formulaInput),oe=M.useMemo(()=>L.map(A=>et.serializeRange(A.range)).join(","),[]),le=J.getRuleOptions(g),ie=A=>{r.shallowEqual(A,J.getRuleOptions(g))||(D({...g,...A}),C(E.UpdateSheetDataValidationOptionsCommand.id,{unitId:o,subUnitId:i,ruleId:l,options:A}))};return f.useSidebarClick(A=>{var Y;const b=(Y=F.current)==null?void 0:Y.handleOutClick;b&&b(A,()=>k(!1))}),u.jsxs("div",{className:we.dataValidationDetail,children:[u.jsx(T.FormLayout,{label:_.t("dataValidation.panel.range"),error:!g.ranges.length||m?_.t("dataValidation.panel.rangeError"):"",children:u.jsx(tt.RangeSelector,{unitId:o,subUnitId:i,initValue:oe,onChange:q,onFocus:()=>k(!0),isFocus:$,actions:F.current,onVerify:A=>O(!A)})}),u.jsx(T.FormLayout,{label:_.t("dataValidation.panel.type"),children:u.jsx(T.Select,{options:y==null?void 0:y.map(A=>({label:_.t(A.title),value:A.id})),value:g.type,onChange:te,className:we.dataValidationDetailFormItem})}),N!=null&&N.length?u.jsx(T.FormLayout,{label:_.t("dataValidation.panel.operator"),children:u.jsx(T.Select,{options:N.map((A,b)=>({value:`${A}`,label:U[b]})),value:`${g.operator}`,onChange:A=>{Z({...ee,operator:A})},className:we.dataValidationDetailFormItem})}):null,ae?u.jsx(ae,{isTwoFormula:j,value:{formula1:g.formula1,formula2:g.formula2},onChange:A=>{Z({...ee,...A})},showError:S,validResult:V.validatorFormula(g,o,i),unitId:o,subUnitId:i,ruleId:l},e+g.type):null,u.jsx(T.FormLayout,{children:u.jsx(T.Checkbox,{checked:(de=g.allowBlank)!=null?de:!0,onChange:()=>{var A;return Z({...ee,allowBlank:!((A=g.allowBlank)==null||A)})},children:_.t("dataValidation.panel.allowBlank")})}),u.jsx(In,{value:le,onChange:ie,extraComponent:V.optionsInput}),u.jsxs("div",{className:we.dataValidationDetailButtons,children:[u.jsx(T.Button,{className:we.dataValidationDetailButton,onClick:G,children:_.t("dataValidation.panel.removeRule")}),u.jsx(T.Button,{className:we.dataValidationDetailButton,type:"primary",onClick:H,children:_.t("dataValidation.panel.done")})]})]})}const Be={dataValidationItemContainer:"univer-data-validation-item-container",dataValidationItemTitle:"univer-data-validation-item-title",dataValidationItemContent:"univer-data-validation-item-content",dataValidationItemIcon:"univer-data-validation-item-icon"},wn=e=>{const{rule:t,onClick:a,unitId:n,subUnitId:o,disable:i}=e,s=f.useDependency(J.DataValidatorRegistryService),l=f.useDependency(r.ICommandService),d=f.useDependency(B.IMarkSelectionService),h=s.getValidatorItem(t.type),p=M.useRef(void 0),[v,c]=M.useState(!1),_=g=>{l.executeCommand(E.RemoveSheetDataValidationCommand.id,{ruleId:t.uid,unitId:n,subUnitId:o}),g.stopPropagation()};return M.useEffect(()=>()=>{var g;p.current&&((g=p.current)==null||g.forEach(D=>{D&&d.removeShape(D)}))},[d]),u.jsxs("div",{className:Be.dataValidationItemContainer,onClick:a,onMouseEnter:()=>{i||(c(!0),p.current=t.ranges.map(g=>d.addShape({range:g,style:{fill:"rgba(73, 184, 17, 0.05)",strokeWidth:1,stroke:"#49B811",widgets:{}},primary:null})))},onMouseLeave:()=>{var g;c(!1),(g=p.current)==null||g.forEach(D=>{D&&d.removeShape(D)}),p.current=void 0},children:[u.jsx("div",{className:Be.dataValidationItemTitle,children:h==null?void 0:h.generateRuleName(t)}),u.jsx("div",{className:Be.dataValidationItemContent,children:t.ranges.map(g=>et.serializeRange(g)).join(",")}),v?u.jsx("div",{className:Be.dataValidationItemIcon,onClick:_,children:u.jsx(nt,{})}):null]})},je={dataValidationList:"univer-data-validation-list",dataValidationListButtons:"univer-data-validation-list-buttons",dataValidationListButton:"univer-data-validation-list-button"};function Vn(){const e=f.useDependency(r.IUniverInstanceService),t=f.useObservable(()=>e.getCurrentTypeOfUnit$(r.UniverInstanceType.UNIVER_SHEET),void 0,void 0,[]);return t?u.jsx(En,{workbook:t}):null}function En(e){const t=f.useDependency(E.SheetDataValidationModel),a=f.useDependency(r.IUniverInstanceService),n=f.useDependency(r.ICommandService),o=f.useDependency(r.Injector),i=f.useDependency(ue),s=f.useDependency(r.LocaleService),[l,d]=M.useState([]),{workbook:h}=e,p=f.useObservable(h.activeSheet$,void 0,!0),v=h.getUnitId(),c=p==null?void 0:p.getSheetId();M.useEffect(()=>{d(t.getRules(v,c));const w=t.ruleChange$.subscribe(y=>{y.unitId===v&&y.subUnitId===c&&d(t.getRules(v,c))});return()=>{w.unsubscribe()}},[v,c,t]);const _=async()=>{const w=E.createDefaultNewRule(o),y={unitId:v,subUnitId:c,rule:w};await n.executeCommand(E.AddSheetDataValidationCommand.id,y),i.setActiveRule({unitId:v,subUnitId:c,rule:w})},g=()=>{n.executeCommand(E.RemoveSheetAllDataValidationCommand.id,{unitId:v,subUnitId:c})},V=(w=>{const y=a.getCurrentUnitForType(r.UniverInstanceType.UNIVER_SHEET),L=y.getActiveSheet(),I=y.getUnitId(),C=L.getSheetId();return w.map(O=>z.checkRangesEditablePermission(o,I,C,O.ranges)?{...O}:{...O,disable:!0})})(l),S=V==null?void 0:V.some(w=>w.disable);return u.jsxs("div",{className:je.dataValidationList,children:[V==null?void 0:V.map(w=>{var y;return u.jsx(wn,{unitId:v,subUnitId:c,onClick:()=>{w.disable||i.setActiveRule({unitId:v,subUnitId:c,rule:w})},rule:w,disable:(y=w.disable)!=null?y:!1},w.uid)}),u.jsxs("div",{className:je.dataValidationListButtons,children:[l.length&&!S?u.jsx(T.Button,{className:je.dataValidationListButton,onClick:g,children:s.t("dataValidation.panel.removeAll")}):null,u.jsx(T.Button,{className:je.dataValidationListButton,type:"primary",onClick:_,children:s.t("dataValidation.panel.add")})]})]})}const Mn=()=>{const e=f.useDependency(ue),t=f.useObservable(e.activeRule$,e.activeRule);return t?u.jsx(yn,{},t.rule.uid):u.jsx(Vn,{})},We="data-validation.list.dropdown",rt="data-validation.date.dropdown",$e={type:r.CommandType.COMMAND,id:"data-validation.command.addRuleAndOpen",handler(e){const t=e.get(r.IUniverInstanceService),a=z.getSheetCommandTarget(t);if(!a)return!1;const{workbook:n,worksheet:o}=a,i=E.createDefaultNewRule(e),s=e.get(r.ICommandService),l=n.getUnitId(),d=o.getSheetId(),h={rule:i,unitId:l,subUnitId:d};return s.syncExecuteCommand(E.AddSheetDataValidationCommand.id,h)?(s.syncExecuteCommand(_e.id,{ruleId:i.uid,isAdd:!0}),!0):!1}};var bn=Object.getOwnPropertyDescriptor,Ln=(e,t,a,n)=>{for(var o=n>1?void 0:n?bn(t,a):t,i=e.length-1,s;i>=0;i--)(s=e[i])&&(o=s(o)||o);return o},Ve=(e,t)=>(a,n)=>t(a,n,e);const Ce="SHEET_DATA_VALIDATION_ALERT";let Ae=class extends r.Disposable{constructor(e,t,a,n,o,i){super(),this._hoverManagerService=e,this._cellAlertManagerService=t,this._univerInstanceService=a,this._localeService=n,this._zenZoneService=o,this._dataValidationModel=i,this._init()}_init(){this._initCellAlertPopup(),this._initZenService()}_initCellAlertPopup(){this.disposeWithMe(this._hoverManagerService.currentCell$.pipe(re.debounceTime(100)).subscribe(e=>{var t;if(e){const a=this._univerInstanceService.getUnit(e.location.unitId,r.UniverInstanceType.UNIVER_SHEET),n=a.getSheetBySheetId(e.location.subUnitId);if(!n)return;const o=this._dataValidationModel.getRuleByLocation(e.location.unitId,e.location.subUnitId,e.location.row,e.location.col);if(!o){this._cellAlertManagerService.removeAlert(Ce);return}if(this._dataValidationModel.validator(o,{...e.location,workbook:a,worksheet:n})===r.DataValidationStatus.INVALID){const s=this._cellAlertManagerService.currentAlert.get(Ce),l=(t=s==null?void 0:s.alert)==null?void 0:t.location;if(l&&l.row===e.location.row&&l.col===e.location.col&&l.subUnitId===e.location.subUnitId&&l.unitId===e.location.unitId){this._cellAlertManagerService.removeAlert(Ce);return}const d=this._dataValidationModel.getValidator(o.type);if(!d){this._cellAlertManagerService.removeAlert(Ce);return}this._cellAlertManagerService.showAlert({type:B.CellAlertType.ERROR,title:this._localeService.t("dataValidation.error.title"),message:d==null?void 0:d.getRuleFinalError(o,e.location),location:e.location,width:200,height:74,key:Ce});return}}this._cellAlertManagerService.removeAlert(Ce)}))}_initZenService(){this.disposeWithMe(this._zenZoneService.visible$.subscribe(e=>{e&&this._cellAlertManagerService.removeAlert(Ce)}))}};Ae=Ln([Ve(0,r.Inject(B.HoverManagerService)),Ve(1,r.Inject(B.CellAlertManagerService)),Ve(2,r.IUniverInstanceService),Ve(3,r.Inject(r.LocaleService)),Ve(4,f.IZenZoneService),Ve(5,r.Inject(E.SheetDataValidationModel))],Ae);var Tn=Object.getOwnPropertyDescriptor,On=(e,t,a,n)=>{for(var o=n>1?void 0:n?Tn(t,a):t,i=e.length-1,s;i>=0;i--)(s=e[i])&&(o=s(o)||o);return o},st=(e,t)=>(a,n)=>t(a,n,e);let Ee=class extends r.Disposable{constructor(e,t,a){super(),this._autoFillService=e,this._sheetDataValidationModel=t,this._injector=a,this._initAutoFill()}_initAutoFill(){const e=()=>({redos:[],undos:[]}),t=(n,o)=>{const{source:i,target:s,unitId:l,subUnitId:d}=n,h=this._sheetDataValidationModel.getRuleObjectMatrix(l,d).clone(),p=B.virtualizeDiscreteRanges([i,s]),[v,c]=p.ranges,{mapFunc:_}=p,g={row:v.startRow,col:v.startColumn},D=B.getAutoFillRepeatRange(v,c),V=new r.ObjectMatrix,S=new Set;D.forEach(C=>{const m=C.repeatStartCell,O=C.relativeRange,F={startRow:g.row,startColumn:g.col,endColumn:g.col,endRow:g.row},$={startRow:m.row,startColumn:m.col,endColumn:m.col,endRow:m.row};r.Range.foreach(O,(k,R)=>{const N=r.Rectangle.getPositionRange({startRow:k,startColumn:R,endColumn:R,endRow:k},F),{row:U,col:j}=_(N.startRow,N.startColumn),H=this._sheetDataValidationModel.getRuleIdByLocation(l,d,U,j)||"",q=r.Rectangle.getPositionRange({startRow:k,startColumn:R,endColumn:R,endRow:k},$),{row:Z,col:G}=_(q.startRow,q.startColumn);V.setValue(Z,G,H),S.add(H)})});const w=Array.from(S).map(C=>({id:C,ranges:r.queryObjectMatrix(V,m=>m===C)}));h.addRangeRules(w);const y=h.diff(this._sheetDataValidationModel.getRules(l,d)),{redoMutations:L,undoMutations:I}=E.getDataValidationDiffMutations(l,d,y,this._injector,"patched",o===B.APPLY_TYPE.ONLY_FORMAT);return{undos:I,redos:L}},a={id:E.DATA_VALIDATION_PLUGIN_NAME,onBeforeFillData:n=>{const{source:o,unitId:i,subUnitId:s}=n;for(const l of o.rows)for(const d of o.cols){const h=this._sheetDataValidationModel.getRuleByLocation(i,s,l,d);if(h&&h.type===r.DataValidationType.CHECKBOX){this._autoFillService.setDisableApplyType(B.APPLY_TYPE.SERIES,!0);return}}},onFillData:(n,o,i)=>i===B.APPLY_TYPE.COPY||i===B.APPLY_TYPE.ONLY_FORMAT||i===B.APPLY_TYPE.SERIES?t(n,i):e(),onAfterFillData:()=>{}};this.disposeWithMe(this._autoFillService.addHook(a))}};Ee=On([st(0,B.IAutoFillService),st(1,r.Inject(E.SheetDataValidationModel)),st(2,r.Inject(r.Injector))],Ee);var Pn=Object.getOwnPropertyDescriptor,Rn=(e,t,a,n)=>{for(var o=n>1?void 0:n?Pn(t,a):t,i=e.length-1,s;i>=0;i--)(s=e[i])&&(o=s(o)||o);return o},lt=(e,t)=>(a,n)=>t(a,n,e);let Me=class extends r.Disposable{constructor(t,a,n){super();P(this,"_copyInfo");this._sheetClipboardService=t,this._sheetDataValidationModel=a,this._injector=n,this._initCopyPaste()}_initCopyPaste(){this._sheetClipboardService.addClipboardHook({id:E.DATA_VALIDATION_PLUGIN_NAME,onBeforeCopy:(t,a,n)=>this._collect(t,a,n),onPasteCells:(t,a,n,o)=>{const{copyType:i=B.COPY_TYPE.COPY,pasteType:s}=o,{range:l}=t||{},{range:d,unitId:h,subUnitId:p}=a;return this._generateMutations(d,{copyType:i,pasteType:s,copyRange:l,unitId:h,subUnitId:p})}})}_collect(t,a,n){const o=new r.ObjectMatrix;this._copyInfo={unitId:t,subUnitId:a,matrix:o};const i=this._injector.invoke(d=>B.rangeToDiscreteRange(n,d,t,a));if(!i)return;const{rows:s,cols:l}=i;s.forEach((d,h)=>{l.forEach((p,v)=>{const c=this._sheetDataValidationModel.getRuleIdByLocation(t,a,d,p);o.setValue(h,v,c!=null?c:"")})})}_generateMutations(t,a){if(!this._copyInfo)return{redos:[],undos:[]};if(a.copyType===B.COPY_TYPE.CUT)return this._copyInfo=null,{redos:[],undos:[]};if(!this._copyInfo||!this._copyInfo.matrix.getSizeOf()||!a.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(a.pasteType))return{redos:[],undos:[]};const{unitId:o,subUnitId:i}=this._copyInfo;if(a.unitId!==o||i!==a.subUnitId){const s=this._sheetDataValidationModel.getRuleObjectMatrix(a.unitId,a.subUnitId).clone(),l=new r.ObjectMatrix,d=new Set,{ranges:[h,p],mapFunc:v}=B.virtualizeDiscreteRanges([a.copyRange,t]),c=B.getRepeatRange(h,p,!0),_=new Map;c.forEach(({startRange:S})=>{var w;(w=this._copyInfo)==null||w.matrix.forValue((y,L,I)=>{const C=r.Rectangle.getPositionRange({startRow:y,endRow:y,startColumn:L,endColumn:L},S),m=`${i}-${I}`,O=this._sheetDataValidationModel.getRuleById(o,i,I);!this._sheetDataValidationModel.getRuleById(a.unitId,a.subUnitId,m)&&O&&_.set(m,{...O,uid:m});const{row:F,col:$}=v(C.startRow,C.startColumn);d.add(m),l.setValue(F,$,m)})});const g=Array.from(d).map(S=>({id:S,ranges:r.queryObjectMatrix(l,w=>w===S)}));s.addRangeRules(g);const{redoMutations:D,undoMutations:V}=E.getDataValidationDiffMutations(a.unitId,a.subUnitId,s.diffWithAddition(this._sheetDataValidationModel.getRules(a.unitId,a.subUnitId),_.values()),this._injector,"patched",!1);return{redos:D,undos:V}}else{const s=this._sheetDataValidationModel.getRuleObjectMatrix(o,i).clone(),l=new r.ObjectMatrix,d=new Set,{ranges:[h,p],mapFunc:v}=B.virtualizeDiscreteRanges([a.copyRange,t]);B.getRepeatRange(h,p,!0).forEach(({startRange:V})=>{var S;(S=this._copyInfo)==null||S.matrix.forValue((w,y,L)=>{const I=r.Rectangle.getPositionRange({startRow:w,endRow:w,startColumn:y,endColumn:y},V),{row:C,col:m}=v(I.startRow,I.startColumn);l.setValue(C,m,L),d.add(L)})});const _=Array.from(d).map(V=>({id:V,ranges:r.queryObjectMatrix(l,S=>S===V)}));s.addRangeRules(_);const{redoMutations:g,undoMutations:D}=E.getDataValidationDiffMutations(o,i,s.diff(this._sheetDataValidationModel.getRules(o,i)),this._injector,"patched",!1);return{redos:g,undos:D}}}};Me=Rn([lt(0,B.ISheetClipboardService),lt(1,r.Inject(E.SheetDataValidationModel)),lt(2,r.Inject(r.Injector))],Me);var An=Object.getOwnPropertyDescriptor,Fn=(e,t,a,n)=>{for(var o=n>1?void 0:n?An(t,a):t,i=e.length-1,s;i>=0;i--)(s=e[i])&&(o=s(o)||o);return o},dt=(e,t)=>(a,n)=>t(a,n,e);let be=class extends r.Disposable{constructor(e,t,a){super(),this._localeService=e,this._commandService=t,this._sheetPermissionCheckController=a,this._commandExecutedListener()}_commandExecutedListener(){this.disposeWithMe(this._commandService.beforeCommandExecuted(e=>{e.id===E.AddSheetDataValidationCommand.id&&(this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[z.WorkbookEditablePermission],rangeTypes:[z.RangeProtectionPermissionEditPoint],worksheetTypes:[z.WorksheetEditPermission,z.WorksheetSetCellStylePermission]})||this._sheetPermissionCheckController.blockExecuteWithoutPermission(this._localeService.t("permission.dialog.setStyleErr"))),e.id===E.UpdateSheetDataValidationRangeCommand.id&&(this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[z.WorkbookEditablePermission],rangeTypes:[z.RangeProtectionPermissionEditPoint],worksheetTypes:[z.WorksheetEditPermission,z.WorksheetSetCellStylePermission]},e.params.ranges)||this._sheetPermissionCheckController.blockExecuteWithoutPermission(this._localeService.t("permission.dialog.setStyleErr")))}))}};be=Fn([dt(0,r.Inject(r.LocaleService)),dt(1,r.ICommandService),dt(2,r.Inject(z.SheetPermissionCheckController))],be);const At="data-validation-single",Ft="sheet.menu.data-validation";function kn(e){return{id:Ft,type:f.MenuItemType.SUBITEMS,icon:At,tooltip:"dataValidation.title",hidden$:f.getMenuHiddenObservable(e,r.UniverInstanceType.UNIVER_SHEET),disabled$:B.getCurrentRangeDisable$(e,{workbookTypes:[z.WorkbookEditablePermission],worksheetTypes:[z.WorksheetSetCellStylePermission,z.WorksheetEditPermission],rangeTypes:[z.RangeProtectionPermissionEditPoint]})}}function Nn(e){return{id:_e.id,title:"dataValidation.panel.title",type:f.MenuItemType.BUTTON}}function Un(e){return{id:$e.id,title:"dataValidation.panel.add",type:f.MenuItemType.BUTTON}}const Bn={[f.RibbonStartGroup.FORMULAS_INSERT]:{[Ft]:{order:9,menuItemFactory:kn,[_e.id]:{order:0,menuItemFactory:Nn},[$e.id]:{order:1,menuItemFactory:Un}}}};var jn=Object.getOwnPropertyDescriptor,kt=(e,t,a,n)=>{for(var o=n>1?void 0:n?jn(t,a):t,i=e.length-1,s;i>=0;i--)(s=e[i])&&(o=s(o)||o);return o},Q=(e,t)=>(a,n)=>t(a,n,e);const Nt={tr:{size:6,color:"#fe4b4b"}};let Le=class extends r.RxDisposable{constructor(e,t,a,n,o,i,s,l,d,h,p){super(),this._commandService=e,this._menuManagerService=t,this._renderManagerService=a,this._univerInstanceService=n,this._autoHeightController=o,this._dropdownManagerService=i,this._sheetDataValidationModel=s,this._dataValidatorRegistryService=l,this._sheetInterceptorService=d,this._dataValidationCacheService=h,this._editorBridgeService=p,this._initMenu(),this._initDropdown(),this._initViewModelIntercept(),this._initAutoHeight()}_initMenu(){this._menuManagerService.mergeMenu(Bn)}_initDropdown(){this._editorBridgeService&&this.disposeWithMe(this._editorBridgeService.visible$.subscribe(e=>{var a;if(!e.visible){((a=this._dropdownManagerService.activeDropdown)==null?void 0:a.trigger)==="editor-bridge"&&this._dropdownManagerService.hideDropdown();return}const t=this._editorBridgeService.getEditCellState();if(t){const{unitId:n,sheetId:o,row:i,column:s}=t,l=this._univerInstanceService.getUniverSheetInstance(n);if(!l)return;const d=this._sheetDataValidationModel.getRuleByLocation(n,o,i,s);if(!d)return;const h=this._dataValidatorRegistryService.getValidatorItem(d.type);if(!(h!=null&&h.dropdown))return;const p=l.getActiveSheet();if(!p)return;const v=this._dropdownManagerService.activeDropdown,c=v==null?void 0:v.location;if(c&&c.unitId===n&&c.subUnitId===o&&c.row===i&&c.col===s)return;this._dropdownManagerService.showDropdown({location:{unitId:n,subUnitId:o,row:i,col:s,workbook:l,worksheet:p},componentKey:h.dropdown,onHide:()=>{},trigger:"editor-bridge"},!1)}}))}_initViewModelIntercept(){this.disposeWithMe(this._sheetInterceptorService.intercept(z.INTERCEPTOR_POINT.CELL_CONTENT,{effect:r.InterceptorEffectEnum.Style,priority:z.InterceptCellContentPriority.DATA_VALIDATION,handler:(e,t,a)=>{var S,w,y,L,I;const{row:n,col:o,unitId:i,subUnitId:s,workbook:l,worksheet:d}=t,h=this._sheetDataValidationModel.getRuleIdByLocation(i,s,n,o);if(!h)return a(e);const p=this._sheetDataValidationModel.getRuleById(i,s,h);if(!p)return a(e);const v=(S=this._dataValidationCacheService.getValue(i,s,n,o))!=null?S:r.DataValidationStatus.VALID,c=this._dataValidatorRegistryService.getValidatorItem(p.type),_=t.rawData;let g;const D={get value(){var C;return g!==void 0||(g=(C=E.getCellValueOrigin(_))!=null?C:null),g}},V={get value(){var C;return`${(C=D.value)!=null?C:""}`}};return a({...e,markers:{...e==null?void 0:e.markers,...v===r.DataValidationStatus.INVALID?Nt:null},customRender:[...(w=e==null?void 0:e.customRender)!=null?w:[],...c!=null&&c.canvasRender?[c.canvasRender]:[]],fontRenderExtension:{...e==null?void 0:e.fontRenderExtension,isSkip:((y=e==null?void 0:e.fontRenderExtension)==null?void 0:y.isSkip)||((L=c==null?void 0:c.skipDefaultFontRender)==null?void 0:L.call(c,p,D.value,t))},interceptorStyle:{...e==null?void 0:e.interceptorStyle,...c==null?void 0:c.getExtraStyle(p,V.value,{get style(){const C=l.getStyles();return(typeof(e==null?void 0:e.s)=="string"?C.get(e==null?void 0:e.s):e==null?void 0:e.s)||{}}},n,o)},interceptorAutoHeight:()=>{var F,$,k,R,N,U;const C=($=(F=this._renderManagerService.getRenderById(i))==null?void 0:F.with(B.SheetSkeletonManagerService).getSkeletonParam(s))==null?void 0:$.skeleton;if(!C)return;const m=C.worksheet.getMergedCell(n,o),O={data:e,style:C.getStyles().getStyleByCell(e),primaryWithCoord:C.getCellWithCoordByIndex((k=m==null?void 0:m.startRow)!=null?k:n,(R=m==null?void 0:m.startColumn)!=null?R:o),unitId:i,subUnitId:s,row:n,col:o,workbook:l,worksheet:d};return(U=(N=c==null?void 0:c.canvasRender)==null?void 0:N.calcCellAutoHeight)==null?void 0:U.call(N,O)},interceptorAutoWidth:()=>{var F,$,k,R,N,U;const C=($=(F=this._renderManagerService.getRenderById(i))==null?void 0:F.with(B.SheetSkeletonManagerService).getSkeletonParam(s))==null?void 0:$.skeleton;if(!C)return;const m=C.worksheet.getMergedCell(n,o),O={data:e,style:C.getStyles().getStyleByCell(e),primaryWithCoord:C.getCellWithCoordByIndex((k=m==null?void 0:m.startRow)!=null?k:n,(R=m==null?void 0:m.startColumn)!=null?R:o),unitId:i,subUnitId:s,row:n,col:o,workbook:l,worksheet:d};return(U=(N=c==null?void 0:c.canvasRender)==null?void 0:N.calcCellAutoWidth)==null?void 0:U.call(N,O)},coverable:((I=e==null?void 0:e.coverable)!=null?I:!0)&&!(p.type===r.DataValidationType.LIST||p.type===r.DataValidationType.LIST_MULTIPLE)})}}))}_initAutoHeight(){this._sheetDataValidationModel.ruleChange$.pipe(re.filter(e=>e.source==="command"),re.bufferTime(100)).subscribe(e=>{if(e.length===0)return;const t=[];if(e.forEach(a=>{var n;(a.rule.type===r.DataValidationType.LIST_MULTIPLE||a.rule.type===r.DataValidationType.LIST)&&(n=a.rule)!=null&&n.ranges&&t.push(...a.rule.ranges)}),t.length){const a=this._autoHeightController.getUndoRedoParamsOfAutoHeight(t);r.sequenceExecute(a.redos,this._commandService)}})}};Le=kt([Q(0,r.ICommandService),Q(1,f.IMenuManagerService),Q(2,W.IRenderManagerService),Q(3,r.IUniverInstanceService),Q(4,r.Inject(B.AutoHeightController)),Q(5,r.Inject(me)),Q(6,r.Inject(E.SheetDataValidationModel)),Q(7,r.Inject(J.DataValidatorRegistryService)),Q(8,r.Inject(z.SheetInterceptorService)),Q(9,r.Inject(E.DataValidationCacheService)),Q(10,r.Optional(B.IEditorBridgeService))],Le);let Ut=class extends r.RxDisposable{constructor(e,t,a,n,o,i,s){super(),this._commandService=e,this._renderManagerService=t,this._autoHeightController=a,this._dataValidatorRegistryService=n,this._sheetInterceptorService=o,this._sheetDataValidationModel=i,this._dataValidationCacheService=s,this._initViewModelIntercept(),this._initAutoHeight()}_initViewModelIntercept(){this.disposeWithMe(this._sheetInterceptorService.intercept(z.INTERCEPTOR_POINT.CELL_CONTENT,{effect:r.InterceptorEffectEnum.Style,priority:z.InterceptCellContentPriority.DATA_VALIDATION,handler:(e,t,a)=>{var V,S,w,y,L;const{row:n,col:o,unitId:i,subUnitId:s,workbook:l,worksheet:d}=t,h=this._sheetDataValidationModel.getRuleIdByLocation(i,s,n,o);if(!h)return a(e);const p=this._sheetDataValidationModel.getRuleById(i,s,h);if(!p)return a(e);const v=(V=this._dataValidationCacheService.getValue(i,s,n,o))!=null?V:r.DataValidationStatus.VALID,c=this._dataValidatorRegistryService.getValidatorItem(p.type),_=d.getCellRaw(n,o),g=E.getCellValueOrigin(_),D=`${g!=null?g:""}`;return a({...e,markers:{...e==null?void 0:e.markers,...v===r.DataValidationStatus.INVALID?Nt:null},customRender:[...(S=e==null?void 0:e.customRender)!=null?S:[],...c!=null&&c.canvasRender?[c.canvasRender]:[]],fontRenderExtension:{...e==null?void 0:e.fontRenderExtension,isSkip:((w=e==null?void 0:e.fontRenderExtension)==null?void 0:w.isSkip)||((y=c==null?void 0:c.skipDefaultFontRender)==null?void 0:y.call(c,p,g,t))},interceptorStyle:{...e==null?void 0:e.interceptorStyle,...c==null?void 0:c.getExtraStyle(p,D,{get style(){const I=l.getStyles();return(typeof(e==null?void 0:e.s)=="string"?I.get(e==null?void 0:e.s):e==null?void 0:e.s)||{}}},n,o)},interceptorAutoHeight:()=>{var O,F,$,k,R,N;const I=(F=(O=this._renderManagerService.getRenderById(i))==null?void 0:O.with(B.SheetSkeletonManagerService).getSkeletonParam(s))==null?void 0:F.skeleton;if(!I)return;const C=I.worksheet.getMergedCell(n,o),m={data:e,style:I.getStyles().getStyleByCell(e),primaryWithCoord:I.getCellWithCoordByIndex(($=C==null?void 0:C.startRow)!=null?$:n,(k=C==null?void 0:C.startColumn)!=null?k:o),unitId:i,subUnitId:s,row:n,col:o,workbook:l,worksheet:d};return(N=(R=c==null?void 0:c.canvasRender)==null?void 0:R.calcCellAutoHeight)==null?void 0:N.call(R,m)},coverable:((L=e==null?void 0:e.coverable)!=null?L:!0)&&!(p.type===r.DataValidationType.LIST||p.type===r.DataValidationType.LIST_MULTIPLE)})}}))}_initAutoHeight(){this._sheetDataValidationModel.ruleChange$.pipe(re.filter(e=>e.source==="command"),re.bufferTime(16)).subscribe(e=>{const t=[];if(e.forEach(a=>{var n;(n=a.rule)!=null&&n.ranges&&t.push(...a.rule.ranges)}),t.length){const a=this._autoHeightController.getUndoRedoParamsOfAutoHeight(t);r.sequenceExecute(a.redos,this._commandService)}})}};Ut=kt([Q(0,r.ICommandService),Q(1,W.IRenderManagerService),Q(2,r.Inject(B.AutoHeightController)),Q(3,r.Inject(J.DataValidatorRegistryService)),Q(4,r.Inject(z.SheetInterceptorService)),Q(5,r.Inject(E.SheetDataValidationModel)),Q(6,r.Inject(E.DataValidationCacheService))],Ut);var Wn=Object.getOwnPropertyDescriptor,$n=(e,t,a,n)=>{for(var o=n>1?void 0:n?Wn(t,a):t,i=e.length-1,s;i>=0;i--)(s=e[i])&&(o=s(o)||o);return o},Bt=(e,t)=>(a,n)=>t(a,n,e);let He=class extends r.Disposable{constructor(e,t,a){super(),this._context=e,this._sheetDataValidationModel=t,this._sheetSkeletonManagerService=a,this._initSkeletonChange()}_initSkeletonChange(){const e=t=>{var n;if(!t.length)return;const a=new Set;t.forEach(o=>{a.add(o.subUnitId)}),a.forEach(o=>{var i;(i=this._sheetSkeletonManagerService.getSkeletonParam(o))==null||i.skeleton.makeDirty(!0)}),(n=this._context.mainComponent)==null||n.makeForceDirty()};this.disposeWithMe(this._sheetDataValidationModel.validStatusChange$.pipe(r.bufferDebounceTime(16)).subscribe(e))}};He=$n([Bt(1,r.Inject(E.SheetDataValidationModel)),Bt(2,r.Inject(B.SheetSkeletonManagerService))],He);const ne={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"},Hn=e=>{const{isTwoFormula:t=!1,value:a,onChange:n,showError:o,validResult:i}=e,s=f.useDependency(r.LocaleService),l=o?i==null?void 0:i.formula1:"",d=o?i==null?void 0:i.formula2:"";return t?u.jsxs(u.Fragment,{children:[u.jsx(T.FormLayout,{error:l,children:u.jsx(T.Input,{className:ne.dataValidationFormula,placeholder:s.t("dataValidation.panel.formulaPlaceholder"),value:a==null?void 0:a.formula1,onChange:h=>{n==null||n({...a,formula1:h})}})}),u.jsx("div",{className:ne.dataValidationFormulaAnd,children:s.t("dataValidation.panel.formulaAnd")}),u.jsx(T.FormLayout,{error:d,children:u.jsx(T.Input,{className:ne.dataValidationFormula,placeholder:s.t("dataValidation.panel.formulaPlaceholder"),value:a==null?void 0:a.formula2,onChange:h=>{n==null||n({...a,formula2:h})}})})]}):u.jsx(T.FormLayout,{error:l,children:u.jsx(T.Input,{className:ne.dataValidationFormula,placeholder:s.t("dataValidation.panel.formulaPlaceholder"),value:a==null?void 0:a.formula1,onChange:h=>{n==null||n({formula1:h})}})})};function Yn(e){const{value:t,onChange:a,showError:n,validResult:o}=e,i=f.useDependency(r.LocaleService),s=n?o==null?void 0:o.formula1:"",l=n?o==null?void 0:o.formula2:"",[d,h]=M.useState(!((t==null?void 0:t.formula1)===void 0&&(t==null?void 0:t.formula2)===void 0));return u.jsxs(u.Fragment,{children:[u.jsx(T.FormLayout,{children:u.jsx(T.Checkbox,{checked:d,onChange:p=>{p?h(!0):(h(!1),a==null||a({...t,formula1:void 0,formula2:void 0}))},children:i.t("dataValidation.checkbox.tips")})}),d?u.jsx(T.FormLayout,{label:i.t("dataValidation.checkbox.checked"),error:s,children:u.jsx(T.Input,{className:ne.dataValidationFormula,placeholder:i.t("dataValidation.panel.valuePlaceholder"),value:t==null?void 0:t.formula1,onChange:p=>{a==null||a({...t,formula1:p||void 0})}})}):null,d?u.jsx(T.FormLayout,{label:i.t("dataValidation.checkbox.unchecked"),error:l,children:u.jsx(T.Input,{className:ne.dataValidationFormula,placeholder:i.t("dataValidation.panel.valuePlaceholder"),value:t==null?void 0:t.formula2,onChange:p=>{a==null||a({...t,formula2:p||void 0})}})}):null]})}function xn(e){var v;const{unitId:t,subUnitId:a,value:n,onChange:o,showError:i,validResult:s}=e,l=i?s==null?void 0:s.formula1:void 0,d=M.useRef({}),[h,p]=M.useState(!1);return f.useSidebarClick(c=>{var g;const _=(g=d.current)==null?void 0:g.handleOutClick;_&&_(c,()=>p(!1))}),u.jsx(tt.FormulaEditor,{initValue:(v=n==null?void 0:n.formula1)!=null?v:"=",unitId:t,subUnitId:a,isFocus:h,onChange:c=>{const _=(c!=null?c:"").trim();_!==(n==null?void 0:n.formula1)&&(o==null||o({...n,formula1:_}))},errorText:l,onFocus:()=>p(!0),actions:d.current,isSupportAcrossSheet:!0})}function jt(e){var t,a,n="";if(typeof e=="string"||typeof e=="number")n+=e;else if(typeof e=="object")if(Array.isArray(e)){var o=e.length;for(t=0;t<o;t++)e[t]&&(a=jt(e[t]))&&(n&&(n+=" "),n+=a)}else for(a in e)e[a]&&(n&&(n+=" "),n+=a);return n}function Xn(){for(var e,t,a=0,n="",o=arguments.length;a<o;a++)(e=arguments[a])&&(t=jt(e))&&(n&&(n+=" "),n+=t);return n}const zn=["#FFFFFF","#FEE7E7","#FEF0E6","#EFFBD0","#E4F4FE","#E8ECFD","#F1EAFA","#FDE8F3","#E5E5E5","#FDCECE","#FDC49B","#DEF6A2","#9FDAFF","#D0D9FB","#E3D5F6","#FBD0E8","#656565","#FE4B4B","#FF8C51","#8BBB11","#0B9EFB","#3A60F7","#9E6DE3","#F248A6"],Kn=e=>{const{value:t,onChange:a,disabled:n}=e,[o,i]=M.useState(!1);return u.jsx(T.Select,{disabled:n,open:o,onDropdownVisibleChange:i,dropdownStyle:{width:112},style:{width:96,cursor:"pointer"},className:ne.dataValidationFormulaColorSelect,value:t,onChange:a,labelRender:s=>u.jsx("div",{className:ne.dataValidationFormulaColorItem,style:{background:s.value,marginTop:5}}),dropdownRender:()=>u.jsx("div",{className:ne.dataValidationFormulaColorSelectPanel,children:zn.map(s=>u.jsx("div",{onClick:()=>{a(s),i(!1)},className:ne.dataValidationFormulaColorItem,style:{background:s}},s))})})},Wt=e=>{const{item:t,commonProps:a,style:n}=e,{onItemChange:o,onItemDelete:i}=a;return u.jsxs("div",{className:ne.dataValidationFormulaListItem,style:n,children:[t.isRef?null:u.jsx("div",{className:Xn(ne.dataValidationFormulaListItemDrag,"draggableHandle"),children:u.jsx(Lt,{})}),u.jsx(Kn,{value:t.color,onChange:s=>{o(t.id,t.label,s)}}),u.jsx(T.Input,{disabled:t.isRef,value:t.label,onChange:s=>{o(t.id,s,t.color)}}),t.isRef?null:u.jsx("div",{className:ne.dataValidationFormulaListItemIcon,children:u.jsx(nt,{onClick:()=>i(t.id)})})]})};function Gn(e){const{value:t,onChange:a=()=>{},unitId:n,subUnitId:o,validResult:i,showError:s,ruleId:l}=e,{formula1:d="",formula2:h=""}=t||{},p=M.useRef(null),[v,c]=M.useState(()=>r.isFormulaString(d)?"1":"0"),[_,g]=M.useState(v==="1"?d:"="),[D,V]=M.useState(v==="1"?d:"="),S=f.useDependency(r.LocaleService),w=f.useDependency(J.DataValidatorRegistryService),y=f.useDependency(J.DataValidationModel),L=f.useDependency(E.DataValidationFormulaController),[I,C]=M.useState(()=>h.split(",")),m=w.getValidatorItem(r.DataValidationType.LIST),[O,F]=M.useState([]),[$,k]=M.useState(""),R=s?i==null?void 0:i.formula1:"",N=M.useMemo(()=>y.ruleChange$.pipe(re.debounceTime(16)),[]),U=f.useObservable(N),j=f.useEvent(a);M.useEffect(()=>{(async()=>{await new Promise(X=>{setTimeout(()=>X(!0),100)});const b=y.getRuleById(n,o,l),Y=b==null?void 0:b.formula1;if(r.isFormulaString(Y)&&m&&b){const X=await m.getListAsync(b,n,o);F(X)}})()},[y,U,m,l,o,n]),M.useEffect(()=>{r.isFormulaString(d)&&d!==D&&(g(d),V(D))},[D,d]);const[H,q]=M.useState(()=>{const b=v!=="1"?E.deserializeListOptions(d):[],Y=h.split(",");return b.map((X,K)=>({label:X,color:Y[K]||Ie,isRef:!1,id:r.Tools.generateRandomId(4)}))}),Z=(b,Y,X)=>{const K=H.find(fe=>fe.id===b);K&&(K.label=Y,K.color=X,q([...H]))},G=b=>{const Y=H.findIndex(X=>X.id===b);Y!==-1&&(H.splice(Y,1),q([...H]))},ee=h.split(","),te=M.useMemo(()=>O.map((b,Y)=>({label:b,color:ee[Y]||Ie,id:`${Y}`,isRef:!0})),[ee,O]),ae=(b,Y,X)=>{const K=[...I];K[+b]=X,C(K),j({formula1:d,formula2:K.join(",")})},oe=()=>{q([...H,{label:"",color:Ie,isRef:!1,id:r.Tools.generateRandomId(4)}])};M.useEffect(()=>{if(v==="1")return;const b=new Set,Y=[];H.map(X=>({labelList:X.label.split(","),item:X})).forEach(({item:X,labelList:K})=>{K.forEach(fe=>{b.has(fe)||(b.add(fe),Y.push({label:fe,color:X.color}))})}),j({formula1:E.serializeListOptions(Y.map(X=>X.label)),formula2:Y.map(X=>X.color===Ie?"":X.color).join(",")})},[H,j,v,D,I]);const le=f.useEvent(async b=>{if(!r.isFormulaString(b)){j==null||j({formula1:"",formula2:h});return}L.getFormulaRefCheck(b)?(j==null||j({formula1:r.isFormulaString(b)?b:"",formula2:h}),k("")):(j==null||j({formula1:"",formula2:h}),g("="),k(S.t("dataValidation.validFail.formulaError")))}),ie=M.useRef({}),[de,A]=M.useState(!1);return f.useSidebarClick(b=>{var X;const Y=(X=ie.current)==null?void 0:X.handleOutClick;Y&&Y(b,()=>A(!1))}),u.jsxs(u.Fragment,{children:[u.jsx(T.FormLayout,{label:S.t("dataValidation.list.options"),children:u.jsxs(T.RadioGroup,{value:v,onChange:b=>{c(b),g(D),b==="1"&&j({formula1:D==="="?"":D,formula2:I.join(",")})},children:[u.jsx(T.Radio,{value:"0",children:S.t("dataValidation.list.customOptions")}),u.jsx(T.Radio,{value:"1",children:S.t("dataValidation.list.refOptions")})]})}),v==="1"?u.jsxs(u.Fragment,{children:[u.jsx(tt.FormulaEditor,{initValue:_,unitId:n,subUnitId:o,isFocus:de,onChange:(b="")=>{const Y=(b!=null?b:"").trim();V(Y),le(Y)},errorText:R||$||void 0,onFocus:()=>A(!0),actions:ie.current,isSupportAcrossSheet:!0}),u.jsx("div",{ref:p,style:{marginTop:"12px"},children:te.map(b=>u.jsx(Wt,{item:b,commonProps:{onItemChange:ae},style:{marginBottom:12}},b.id))})]}):u.jsx(T.FormLayout,{error:R,children:u.jsxs("div",{ref:p,style:{marginTop:"-12px"},children:[u.jsx(T.DraggableList,{list:H,onListChange:q,rowHeight:32,margin:[0,12],draggableHandle:".draggableHandle",itemRender:b=>u.jsx(Wt,{item:b,commonProps:{onItemChange:Z,onItemDelete:G}},b.id),idKey:"id"}),u.jsxs("a",{className:ne.dataValidationFormulaListAdd,onClick:oe,children:[u.jsx(Et,{}),S.t("dataValidation.list.add")]})]})})]})}const $t="data-validation.custom-formula-input",Ye="data-validation.formula-input",ct="data-validation.list-formula-input",Ht="data-validation.checkbox-formula-input",qn=[[$t,xn],[Ye,Hn],[ct,Gn],[Ht,Yn]],Zn="LIST_RENDER_MODE_OPTION_INPUT";function xe(e){var o;const{value:t,onChange:a}=e,n=f.useDependency(r.LocaleService);return u.jsx(T.FormLayout,{label:n.t("dataValidation.renderMode.label"),children:u.jsxs(T.RadioGroup,{value:`${(o=t.renderMode)!=null?o:r.DataValidationRenderMode.CUSTOM}`,onChange:i=>a({...t,renderMode:+i}),children:[u.jsx(T.Radio,{value:`${r.DataValidationRenderMode.CUSTOM}`,children:n.t("dataValidation.renderMode.chip")}),u.jsx(T.Radio,{value:`${r.DataValidationRenderMode.ARROW}`,children:n.t("dataValidation.renderMode.arrow")}),u.jsx(T.Radio,{value:`${r.DataValidationRenderMode.TEXT}`,children:n.t("dataValidation.renderMode.text")})]})})}xe.componentKey=Zn;const Jn="DATE_SHOW_TIME_OPTION";function Xe(e){var o;const{value:t,onChange:a}=e,n=f.useDependency(r.LocaleService);return u.jsx(T.FormLayout,{children:u.jsx(T.Checkbox,{checked:(o=t.bizInfo)==null?void 0:o.showTime,onChange:i=>{a({...t,bizInfo:{...t.bizInfo,showTime:i}})},children:n.t("dataValidation.showTime.label")})})}Xe.componentKey=Jn;var Qn=Object.getOwnPropertyDescriptor,ea=(e,t,a,n)=>{for(var o=n>1?void 0:n?Qn(t,a):t,i=e.length-1,s;i>=0;i--)(s=e[i])&&(o=s(o)||o);return o},Fe=(e,t)=>(a,n)=>t(a,n,e);const ze=6;let ut=class{constructor(e,t,a,n,o){this._commandService=e,this._formulaService=t,this._themeService=a,this._renderManagerService=n,this._dataValidationModel=o}_calc(e,t){var h,p,v;const{vt:a,ht:n}=t||{},o=e.endX-e.startX-ze*2,i=e.endY-e.startY,s=((h=t==null?void 0:t.fs)!=null?h:10)*1.6;let l=0,d=0;switch(a){case r.VerticalAlign.TOP:d=0;break;case r.VerticalAlign.BOTTOM:d=0+(i-s);break;default:d=0+(i-s)/2;break}switch(n){case r.HorizontalAlign.LEFT:l=ze;break;case r.HorizontalAlign.RIGHT:l=ze+(o-s);break;default:l=ze+(o-s)/2;break}return{left:e.startX+l,top:e.startY+d,width:((p=t==null?void 0:t.fs)!=null?p:10)*1.6,height:((v=t==null?void 0:t.fs)!=null?v:10)*1.6}}calcCellAutoHeight(e){var a;const{style:t}=e;return((a=t==null?void 0:t.fs)!=null?a:10)*1.6}calcCellAutoWidth(e){var a;const{style:t}=e;return((a=t==null?void 0:t.fs)!=null?a:10)*1.6}async _parseFormula(e,t,a){var h,p,v,c,_,g,D,V,S;const{formula1:n=E.CHECKBOX_FORMULA_1,formula2:o=E.CHECKBOX_FORMULA_2}=e,i=await this._formulaService.getRuleFormulaResult(t,a,e.uid),s=E.getFormulaResult((v=(p=(h=i==null?void 0:i[0])==null?void 0:h.result)==null?void 0:p[0])==null?void 0:v[0]),l=E.getFormulaResult((g=(_=(c=i==null?void 0:i[1])==null?void 0:c.result)==null?void 0:_[0])==null?void 0:g[0]),d=E.isLegalFormulaResult(String(s))&&E.isLegalFormulaResult(String(l));return{formula1:r.isFormulaString(n)?E.getFormulaResult((S=(V=(D=i==null?void 0:i[0])==null?void 0:D.result)==null?void 0:V[0])==null?void 0:S[0]):n,formula2:r.isFormulaString(o)?l:o,isFormulaValid:d}}drawWith(e,t){var R,N,U,j;const{style:a,primaryWithCoord:n,unitId:o,subUnitId:i,worksheet:s,row:l,col:d}=t,h=n.isMergedMainCell?n.mergeInfo:n,p=E.getCellValueOrigin(s.getCellRaw(l,d)),v=this._dataValidationModel.getRuleByLocation(o,i,l,d);if(!v)return;const c=this._dataValidationModel.getValidator(v.type);if(!c)return;const _=this._themeService.getCurrentTheme();if(!((R=c.skipDefaultFontRender)!=null&&R.call(c,v,p,{unitId:o,subUnitId:i,row:l,column:d})))return;const g=c.parseFormulaSync(v,o,i),{formula1:D}=g,V=this._calc(h,a),{a:S,d:w}=e.getTransform(),y=W.fixLineWidthByScale(V.left,S),L=W.fixLineWidthByScale(V.top,w),I=W.Transform.create().composeMatrix({left:y,top:L,scaleX:1,scaleY:1,angle:0,skewX:0,skewY:0,flipX:!1,flipY:!1}),C=h.endX-h.startX,m=h.endY-h.startY;e.save(),e.beginPath(),e.rect(h.startX,h.startY,C,m),e.clip();const O=I.getMatrix();e.transform(O[0],O[1],O[2],O[3],O[4],O[5]);const F=((N=a==null?void 0:a.fs)!=null?N:10)*1.6,$=String(p)===String(D),k=_.hyacinth500;W.CheckboxShape.drawWith(e,{checked:$,width:F,height:F,fill:(j=(U=a==null?void 0:a.cl)==null?void 0:U.rgb)!=null?j:k}),e.restore()}isHit(e,t){const a=t.primaryWithCoord.isMergedMainCell?t.primaryWithCoord.mergeInfo:t.primaryWithCoord,n=this._calc(a,t.style),o=n.top,i=n.top+n.height,s=n.left,l=n.left+n.width,{x:d,y:h}=e;return d<=l&&d>=s&&h<=i&&h>=o}async onPointerDown(e,t){var g;if(t.button===2)return;const{primaryWithCoord:a,unitId:n,subUnitId:o,worksheet:i,row:s,col:l}=e,d=E.getCellValueOrigin(i.getCellRaw(s,l)),h=this._dataValidationModel.getRuleByLocation(n,o,s,l);if(!h)return;const p=this._dataValidationModel.getValidator(h.type);if(!p||!((g=p.skipDefaultFontRender)!=null&&g.call(p,h,d,{unitId:n,subUnitId:o,row:s,column:l})))return;const{formula1:v,formula2:c}=await this._parseFormula(h,n,o),_={range:{startColumn:a.actualColumn,endColumn:a.actualColumn,startRow:a.actualRow,endRow:a.actualRow},value:{v:String(d)===E.transformCheckboxValue(String(v))?c:v,p:null}};this._commandService.executeCommand(z.SetRangeValuesCommand.id,_)}onPointerEnter(e,t){var a,n;(n=(a=this._renderManagerService.getCurrentTypeOfRenderer(r.UniverInstanceType.UNIVER_SHEET))==null?void 0:a.mainComponent)==null||n.setCursor(W.CURSOR_TYPE.POINTER)}onPointerLeave(e,t){var a,n;(n=(a=this._renderManagerService.getCurrentTypeOfRenderer(r.UniverInstanceType.UNIVER_SHEET))==null?void 0:a.mainComponent)==null||n.setCursor(W.CURSOR_TYPE.DEFAULT)}};ut=ea([Fe(0,r.ICommandService),Fe(1,r.Inject(E.DataValidationFormulaService)),Fe(2,r.Inject(r.ThemeService)),Fe(3,r.Inject(W.IRenderManagerService)),Fe(4,r.Inject(E.SheetDataValidationModel))],ut);var ta=Object.getOwnPropertyDescriptor,na=(e,t,a,n)=>{for(var o=n>1?void 0:n?ta(t,a):t,i=e.length-1,s;i>=0;i--)(s=e[i])&&(o=s(o)||o);return o},aa=(e,t)=>(a,n)=>t(a,n,e);let he=class{constructor(e){P(this,"canvasRender",null);P(this,"dropdown");P(this,"optionsInput");P(this,"formulaInput",ct);this.injector=e}};he=na([aa(0,r.Inject(r.Injector))],he);class oa extends he{constructor(){super(...arguments);P(this,"id",r.DataValidationType.CHECKBOX);P(this,"canvasRender",this.injector.createInstance(ut));P(this,"formulaInput",Ht)}}class ia extends he{constructor(){super(...arguments);P(this,"id",r.DataValidationType.CUSTOM);P(this,"formulaInput",$t)}}const ra="data-validation.formula-input";class sa extends he{constructor(){super(...arguments);P(this,"id",r.DataValidationType.DATE);P(this,"formulaInput",ra);P(this,"optionsInput",Xe.componentKey);P(this,"dropdown",rt)}}class la extends he{constructor(){super(...arguments);P(this,"id",r.DataValidationType.DECIMAL);P(this,"formulaInput",Ye)}}const Yt=4,da=0,ht=4,xt=4,pt=6,Ke=6,De=14;function ca(e,t){const a=W.FontCache.getTextSize(e,t),n=a.width+Yt*2,{ba:o,bd:i}=a,s=o+i;return{width:n,height:s+da*2,ba:o}}function vt(e,t,a,n){const o=De+pt*2,i=a-o,s=n-Ke*2,l=e.map(c=>({layout:ca(c,t),text:c}));let d;const h=[];l.forEach(c=>{const{layout:_}=c,{width:g,height:D}=_;!d||d.width+g+ht>i?(d={width:g,height:D,items:[{...c,left:0}]},h.push(d)):(d.items.push({...c,left:d.width+ht}),d.width=d.width+g+ht)});let p=0,v=0;return h.forEach((c,_)=>{v=Math.max(v,c.width),_===h.length-1?p+=c.height:p+=c.height+xt}),{lines:h,totalHeight:p,contentWidth:i,contentHeight:s,cellAutoHeight:p+Ke*2,calcAutoWidth:v+o}}const ua=8;class ha extends W.Shape{static drawWith(t,a){const{fontString:n,info:o,fill:i,color:s}=a,{layout:l,text:d}=o;t.save(),W.Rect.drawWith(t,{width:l.width,height:l.height,radius:ua,fill:i||Ie}),t.translateWithPrecision(Yt,l.ba),t.font=n,t.fillStyle=s,t.fillText(d,0,0),t.restore()}}var pa=Object.getOwnPropertyDescriptor,va=(e,t,a,n)=>{for(var o=n>1?void 0:n?pa(t,a):t,i=e.length-1,s;i>=0;i--)(s=e[i])&&(o=s(o)||o);return o},gt=(e,t)=>(a,n)=>t(a,n,e);const ga=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 mt=class{constructor(e,t,a){P(this,"zIndex");P(this,"_dropdownInfoMap",new Map);this._commandService=e,this._renderManagerService=t,this._dataValidationModel=a}_ensureMap(e){let t=this._dropdownInfoMap.get(e);return t||(t=new Map,this._dropdownInfoMap.set(e,t)),t}_generateKey(e,t){return`${e}.${t}`}_drawDownIcon(e,t,a,n,o){const i=a-De+4;let s=4;switch(o){case r.VerticalAlign.MIDDLE:s=(n-De)/2+4;break;case r.VerticalAlign.BOTTOM:s=n-De+4;break}e.save(),e.translateWithPrecision(t.startX+i,t.startY+s),e.fillStyle="#565656",e.fill(ga),e.restore()}drawWith(e,t,a,n){var Z,G;const{primaryWithCoord:o,row:i,col:s,style:l,data:d,subUnitId:h}=t,p=o.isMergedMainCell?o.mergeInfo:o,v=d==null?void 0:d.fontRenderExtension,{leftOffset:c=0,rightOffset:_=0,topOffset:g=0,downOffset:D=0}=v||{},V=this._ensureMap(h),S=this._generateKey(i,s),w=this._dataValidationModel.getRuleByLocation(t.unitId,t.subUnitId,i,s);if(!w)return;const y=this._dataValidationModel.getValidator(w.type);if(!y)return;const L={startX:p.startX+c,endX:p.endX-_,startY:p.startY+g,endY:p.endY-D},I=L.endX-L.startX,C=L.endY-L.startY,{cl:m}=l||{},O=(Z=typeof m=="object"?m==null?void 0:m.rgb:m)!=null?Z:"#000",F=W.getFontStyleString(l!=null?l:void 0),{vt:$,ht:k}=l||{},R=$!=null?$:r.VerticalAlign.MIDDLE,N=(G=E.getCellValueOrigin(d))!=null?G:"",U=y.parseCellValue(N),j=y.getListWithColorMap(w),H=vt(U,F,I,C);this._drawDownIcon(e,L,I,C,R),e.save(),e.translateWithPrecision(L.startX,L.startY),e.beginPath(),e.rect(0,0,I-De,C),e.clip(),e.translateWithPrecision(pt,Ke);let q=0;switch(R){case r.VerticalAlign.MIDDLE:q=(H.contentHeight-H.totalHeight)/2;break;case r.VerticalAlign.BOTTOM:q=H.contentHeight-H.totalHeight;break}e.translateWithPrecision(0,q),H.lines.forEach((ee,te)=>{e.save();const{width:ae,height:oe,items:le}=ee;let ie=0;switch(k){case r.HorizontalAlign.RIGHT:ie=H.contentWidth-ae;break;case r.HorizontalAlign.CENTER:ie=(H.contentWidth-ae)/2;break}e.translate(ie,te*(oe+xt)),le.forEach(de=>{e.save(),e.translateWithPrecision(de.left,0),ha.drawWith(e,{...F,info:de,color:O,fill:j[de.text]}),e.restore()}),e.restore()}),e.restore(),V.set(S,{left:L.startX,top:L.startY,width:H.contentWidth+pt+De,height:H.contentHeight+Ke*2})}calcCellAutoHeight(e){var I;const{primaryWithCoord:t,style:a,data:n,row:o,col:i}=e,s=n==null?void 0:n.fontRenderExtension,{leftOffset:l=0,rightOffset:d=0,topOffset:h=0,downOffset:p=0}=s||{},v=t.isMergedMainCell?t.mergeInfo:t,c={startX:v.startX+l,endX:v.endX-d,startY:v.startY+h,endY:v.endY-p},_=this._dataValidationModel.getRuleByLocation(e.unitId,e.subUnitId,o,i);if(!_)return;const g=this._dataValidationModel.getValidator(_.type);if(!g)return;const D=c.endX-c.startX,V=c.endY-c.startY,S=(I=E.getCellValueOrigin(n))!=null?I:"",w=g.parseCellValue(S),y=W.getFontStyleString(a!=null?a:void 0);return vt(w,y,D,V).cellAutoHeight}calcCellAutoWidth(e){var I;const{primaryWithCoord:t,style:a,data:n,row:o,col:i}=e,s=n==null?void 0:n.fontRenderExtension,{leftOffset:l=0,rightOffset:d=0,topOffset:h=0,downOffset:p=0}=s||{},v=t.isMergedMainCell?t.mergeInfo:t,c={startX:v.startX+l,endX:v.endX-d,startY:v.startY+h,endY:v.endY-p},_=this._dataValidationModel.getRuleByLocation(e.unitId,e.subUnitId,o,i);if(!_)return;const g=this._dataValidationModel.getValidator(_.type);if(!g)return;const D=c.endX-c.startX,V=c.endY-c.startY,S=(I=E.getCellValueOrigin(n))!=null?I:"",w=g.parseCellValue(S),y=W.getFontStyleString(a!=null?a:void 0);return vt(w,y,D,V).calcAutoWidth}isHit(e,t){const{primaryWithCoord:a}=t,n=a.isMergedMainCell?a.mergeInfo:a,{endX:o}=n,{x:i}=e;return i>=o-De&&i<=o}onPointerDown(e,t){if(t.button===2)return;const{unitId:a,subUnitId:n,row:o,col:i}=e,s={unitId:a,subUnitId:n,row:o,column:i};this._commandService.executeCommand(Ne.id,s)}onPointerEnter(e,t){var a,n;(n=(a=this._renderManagerService.getCurrentTypeOfRenderer(r.UniverInstanceType.UNIVER_SHEET))==null?void 0:a.mainComponent)==null||n.setCursor(W.CURSOR_TYPE.POINTER)}onPointerLeave(e,t){var a,n;(n=(a=this._renderManagerService.getCurrentTypeOfRenderer(r.UniverInstanceType.UNIVER_SHEET))==null?void 0:a.mainComponent)==null||n.setCursor(W.CURSOR_TYPE.DEFAULT)}};mt=va([gt(0,r.ICommandService),gt(1,r.Inject(W.IRenderManagerService)),gt(2,r.Inject(E.SheetDataValidationModel))],mt);class ma extends he{constructor(){super(...arguments);P(this,"id",r.DataValidationType.LIST_MULTIPLE);P(this,"canvasRender",this.injector.createInstance(mt));P(this,"dropdown",We)}}var fa=Object.getOwnPropertyDescriptor,Sa=(e,t,a,n)=>{for(var o=n>1?void 0:n?fa(t,a):t,i=e.length-1,s;i>=0;i--)(s=e[i])&&(o=s(o)||o);return o},Ge=(e,t)=>(a,n)=>t(a,n,e);const ye=4,qe=4,ce=14,pe=6,Te=4,ft=8,_a="#565656",Xt=new Path2D("M3.32201 4.84556C3.14417 5.05148 2.85583 5.05148 2.67799 4.84556L0.134292 1.90016C-0.152586 1.56798 0.0505937 1 0.456301 1L5.5437 1C5.94941 1 6.15259 1.56798 5.86571 1.90016L3.32201 4.84556Z");function Ia(e,t){const a=e.length;return{id:"d",body:{dataStream:`${e}${r.DEFAULT_EMPTY_DOCUMENT_VALUE}`,textRuns:[{ts:{fs:11,ff:void 0,it:r.BooleanNumber.FALSE,bl:r.BooleanNumber.FALSE,ul:{s:r.BooleanNumber.FALSE},st:{s:r.BooleanNumber.FALSE},ol:{s:r.BooleanNumber.FALSE},cl:void 0,...t,bg:void 0,bd:void 0},st:0,ed:a}]},documentStyle:{pageSize:{width:Number.POSITIVE_INFINITY,height:Number.POSITIVE_INFINITY}}}}function zt(e,t,a){const n=Ia(e,a),o=new r.DocumentDataModel(n),i=new W.DocumentViewModel(o);return{documentSkeleton:W.DocumentSkeleton.create(i,t),docModel:o,docViewModel:i}}function Ze(e,t,a){const{documentSkeleton:n,docModel:o,docViewModel:i}=zt(e,t,a);return{documents:new W.Documents(`DOCUMENTS_${r.Tools.generateRandomId()}`,n,{pageMarginLeft:0,pageMarginTop:0}),documentSkeleton:n,docModel:o,docViewModel:i}}function Kt(e,t,a,n,o,i,s=!0){let l=0;const d=s?Te:0;switch(o){case r.VerticalAlign.BOTTOM:l=t-n-d;break;case r.VerticalAlign.MIDDLE:l=(t-n)/2;break;default:l=d;break}l=Math.max(Te,l);let h=0;switch(i){case r.HorizontalAlign.CENTER:h=(e-a)/2;break;case r.HorizontalAlign.RIGHT:h=e-a;break}return h=Math.max(pe,h),{paddingLeft:h,paddingTop:l}}let St=class{constructor(e,t,a,n){P(this,"_dropdownInfoMap",new Map);P(this,"zIndex");this._localeService=e,this._commandService=t,this._renderManagerService=a,this._dataValidationModel=n}_ensureMap(e){let t=this._dropdownInfoMap.get(e);return t||(t=new Map,this._dropdownInfoMap.set(e,t)),t}_generateKey(e,t){return`${e}.${t}`}_drawDownIcon(e,t,a,n,o,i,s){const{t:l=r.DEFAULT_STYLES.pd.t,b:d=r.DEFAULT_STYLES.pd.b}=s,h=a-ce;let p;switch(i){case r.VerticalAlign.MIDDLE:p=(n-qe)/2;break;case r.VerticalAlign.BOTTOM:p=n-d-o-Te+(o/2-qe/2);break;default:p=l+Te+(o/2-qe/2);break}e.save(),e.translateWithPrecision(t.startX+h,t.startY+p),e.fillStyle="#565656",e.fill(Xt),e.restore()}drawWith(e,t,a){const{primaryWithCoord:n,row:o,col:i,style:s,data:l,subUnitId:d}=t,h=n.isMergedMainCell?n.mergeInfo:n,p=this._dataValidationModel.getRuleByLocation(t.unitId,t.subUnitId,o,i);if(!p)return;const v=this._dataValidationModel.getValidator(p.type);if(!v)return;const c=l==null?void 0:l.fontRenderExtension,{leftOffset:_=0,rightOffset:g=0,topOffset:D=0,downOffset:V=0}=c||{};if(!p||!v||!v||v.id.indexOf(r.DataValidationType.LIST)!==0||!v.skipDefaultFontRender(p))return;const S={startX:h.startX+_,endX:h.endX-g,startY:h.startY+D,endY:h.endY-V},w=S.endX-S.startX,y=S.endY-S.startY,L=this._ensureMap(d),I=this._generateKey(o,i),C=v.getListWithColor(p),m=E.getCellValueOrigin(l),O=`${m!=null?m:""}`,F=C.find(U=>U.label===O);let{tb:$,vt:k,ht:R,pd:N}=s||{};if($=$!=null?$:r.WrapStrategy.WRAP,k=k!=null?k:r.VerticalAlign.BOTTOM,R=R!=null?R:r.DEFAULT_STYLES.ht,N=N!=null?N:r.DEFAULT_STYLES.pd,p.renderMode===r.DataValidationRenderMode.ARROW){const{l:U=r.DEFAULT_STYLES.pd.l,t:j=r.DEFAULT_STYLES.pd.t,r:H=r.DEFAULT_STYLES.pd.r,b:q=r.DEFAULT_STYLES.pd.b}=N,Z=w-U-H-ce-4,{documentSkeleton:G,documents:ee,docModel:te}=Ze(O,this._localeService,s);$===r.WrapStrategy.WRAP&&te.updateDocumentDataPageSize(Math.max(Z,1)),G.calculate(),G.getActualSize();const ae=W.getDocsSkeletonPageSize(G),{height:oe,width:le}=ae,{paddingTop:ie,paddingLeft:de}=Kt(Z,y-j-q,le,oe,k,R,!0);this._drawDownIcon(e,S,w,y,oe,k,N),e.save(),e.translateWithPrecision(S.startX+U,S.startY+j),e.beginPath(),e.rect(0,0,w-U-H,y-j-q),e.clip(),e.translateWithPrecision(0,ie),e.save(),e.translateWithPrecision(ye,0),e.beginPath(),e.rect(0,0,Z,oe),e.clip(),ee.render(e),e.translateWithPrecision(de,0),e.restore(),e.restore(),L.set(I,{left:S.endX+U+a.rowHeaderWidth-ce,top:S.startY+j+a.columnHeaderHeight,width:ce,height:y-j-q})}else{e.save(),e.translateWithPrecision(S.startX,S.startY),e.beginPath(),e.rect(0,0,w,y),e.clip();const U=w-pe*2-ye-ce-4,{documentSkeleton:j,documents:H,docModel:q}=Ze(O,this._localeService,s);$===r.WrapStrategy.WRAP&&q.updateDocumentDataPageSize(Math.max(U,1)),j.calculate();const Z=W.getDocsSkeletonPageSize(j),{height:G,width:ee}=Z,{paddingTop:te,paddingLeft:ae}=Kt(U,y,ee,G,k,R);e.translateWithPrecision(pe,te);const oe=Math.max(w-pe*2,1),le=G;W.Rect.drawWith(e,{width:oe,height:le,fill:(F==null?void 0:F.color)||Ie,radius:ft}),e.save(),e.translateWithPrecision(ye,0),e.beginPath(),e.rect(0,0,U,G),e.clip(),e.translateWithPrecision(ae,0),H.render(e),e.restore(),e.translateWithPrecision(U+ye+4,(G-qe)/2),e.fillStyle=_a,e.fill(Xt),e.restore(),L.set(I,{left:S.startX+pe+a.rowHeaderWidth,top:S.startY+te+a.columnHeaderHeight,width:oe,height:le})}}calcCellAutoHeight(e){const{primaryWithCoord:t,style:a,data:n,row:o,col:i}=e,s=t.isMergedMainCell?t.mergeInfo:t,l=n==null?void 0:n.fontRenderExtension,{leftOffset:d=0,rightOffset:h=0,topOffset:p=0,downOffset:v=0}=l||{},c=this._dataValidationModel.getRuleByLocation(e.unitId,e.subUnitId,o,i);if(!c||c.renderMode===r.DataValidationRenderMode.TEXT)return;const _={startX:s.startX+d,endX:s.endX-h,startY:s.startY+p,endY:s.endY-v},g=_.endX-_.startX,D=E.getCellValueOrigin(n),V=`${D!=null?D:""}`;let{tb:S,pd:w}=a||{};const{t:y=r.DEFAULT_STYLES.pd.t,b:L=r.DEFAULT_STYLES.pd.b}=w!=null?w:{};if(S=S!=null?S:r.WrapStrategy.WRAP,c.renderMode===r.DataValidationRenderMode.ARROW){const I=g-ce,{documentSkeleton:C,docModel:m}=Ze(V,this._localeService,a);S===r.WrapStrategy.WRAP&&m.updateDocumentDataPageSize(Math.max(I,1)),C.calculate(),C.getActualSize();const O=W.getDocsSkeletonPageSize(C),{height:F}=O;return F+y+L+Te*2}else{const I=g-pe*2-ye-ce,{documentSkeleton:C,docModel:m}=zt(V,this._localeService,a);S===r.WrapStrategy.WRAP&&m.updateDocumentDataPageSize(Math.max(I,1)),C.calculate();const O=W.getDocsSkeletonPageSize(C),{height:F}=O;return F+Te*2}}calcCellAutoWidth(e){const{primaryWithCoord:t,style:a,data:n,row:o,col:i}=e,s=t.isMergedMainCell?t.mergeInfo:t,l=n==null?void 0:n.fontRenderExtension,{leftOffset:d=0,rightOffset:h=0,topOffset:p=0,downOffset:v=0}=l||{},c=this._dataValidationModel.getRuleByLocation(e.unitId,e.subUnitId,o,i);if(!c||c.renderMode===r.DataValidationRenderMode.TEXT)return;const _={startX:s.startX+d,endX:s.endX-h,startY:s.startY+p,endY:s.endY-v},g=_.endX-_.startX,D=E.getCellValueOrigin(n),V=`${D!=null?D:""}`;let{tb:S,pd:w}=a||{};const{l:y=r.DEFAULT_STYLES.pd.l,r:L=r.DEFAULT_STYLES.pd.r}=w!=null?w:{};S=S!=null?S:r.WrapStrategy.WRAP;let I=pe*2+ce;switch(c.renderMode){case r.DataValidationRenderMode.ARROW:I=ce+pe*2+L+y;break;case r.DataValidationRenderMode.CUSTOM:I=ce+pe*2+ye*2+L+y+ft/2+1;break;default:I=ce+pe*2+ye*2+L+y+ft/2+1}const C=g-I,{documentSkeleton:m,docModel:O}=Ze(V,this._localeService,a);return S===r.WrapStrategy.WRAP&&O.updateDocumentDataPageSize(Math.max(C,1)),m.calculate(),m.getActualSize(),W.getDocsSkeletonPageSize(m).width+I}isHit(e,t){const{subUnitId:a,row:n,col:o}=t,s=this._ensureMap(a).get(this._generateKey(n,o)),l=this._dataValidationModel.getRuleByLocation(t.unitId,t.subUnitId,n,o);if(!l||!s||l.renderMode===r.DataValidationRenderMode.TEXT)return!1;const{top:d,left:h,width:p,height:v}=s,{x:c,y:_}=e;return c>=h&&c<=h+p&&_>=d&&_<=d+v}onPointerDown(e,t){if(t.button===2)return;const{unitId:a,subUnitId:n,row:o,col:i}=e,s={unitId:a,subUnitId:n,row:o,column:i};this._commandService.executeCommand(Ne.id,s)}onPointerEnter(e,t){var a,n;(n=(a=this._renderManagerService.getCurrentTypeOfRenderer(r.UniverInstanceType.UNIVER_SHEET))==null?void 0:a.mainComponent)==null||n.setCursor(W.CURSOR_TYPE.POINTER)}onPointerLeave(e,t){var a,n;(n=(a=this._renderManagerService.getCurrentTypeOfRenderer(r.UniverInstanceType.UNIVER_SHEET))==null?void 0:a.mainComponent)==null||n.setCursor(W.CURSOR_TYPE.DEFAULT)}};St=Sa([Ge(0,r.Inject(r.LocaleService)),Ge(1,r.ICommandService),Ge(2,r.Inject(W.IRenderManagerService)),Ge(3,r.Inject(E.SheetDataValidationModel))],St);class Ca extends he{constructor(){super(...arguments);P(this,"id",r.DataValidationType.LIST);P(this,"canvasRender",this.injector.createInstance(St));P(this,"dropdown",We);P(this,"optionsInput",xe.componentKey);P(this,"formulaInput",ct)}}class Da extends he{constructor(){super(...arguments);P(this,"id",r.DataValidationType.TEXT_LENGTH);P(this,"formulaInput",Ye)}}class ya extends he{constructor(){super(...arguments);P(this,"id",r.DataValidationType.WHOLE);P(this,"formulaInput",Ye)}}var wa=Object.getOwnPropertyDescriptor,Va=(e,t,a,n)=>{for(var o=n>1?void 0:n?wa(t,a):t,i=e.length-1,s;i>=0;i--)(s=e[i])&&(o=s(o)||o);return o},_t=(e,t)=>(a,n)=>t(a,n,e);let Oe=class extends r.RxDisposable{constructor(e,t,a){super(),this._injector=e,this._componentManger=t,this._dataValidatorRegistryService=a,this._initComponents(),this._registerValidatorViews()}_initComponents(){[[At,Vt],[ke,Mn],[Ot,gn],[We,_n],[rt,en],[xe.componentKey,xe],[Xe.componentKey,Xe],...qn].forEach(([e,t])=>{this.disposeWithMe(this._componentManger.register(e,t))})}_registerValidatorViews(){[la,ya,Da,sa,oa,Ca,ma,ia].forEach(e=>{const t=this._injector.createInstance(e),a=this._dataValidatorRegistryService.getValidatorItem(t.id);a&&(a.formulaInput=t.formulaInput,a.canvasRender=t.canvasRender,a.dropdown=t.dropdown,a.optionsInput=t.optionsInput)})}};Oe=Va([_t(0,r.Inject(r.Injector)),_t(1,r.Inject(f.ComponentManager)),_t(2,r.Inject(J.DataValidatorRegistryService))],Oe);var Ea=Object.getOwnPropertyDescriptor,Ma=(e,t,a,n)=>{for(var o=n>1?void 0:n?Ea(t,a):t,i=e.length-1,s;i>=0;i--)(s=e[i])&&(o=s(o)||o);return o},It=(e,t)=>(a,n)=>t(a,n,e);const ba="SHEET_DATA_VALIDATION_UI_PLUGIN";x.UniverSheetsDataValidationUIPlugin=(Je=class extends r.Plugin{constructor(t=Ue,a,n,o){super(),this._config=t,this._injector=a,this._commandService=n,this._configService=o;const{menu:i,...s}=r.merge({},Ue,this._config);i&&this._configService.setConfig("menu",i,{merge:!0}),this._configService.setConfig(ot,s)}onStarting(){[[ue],[me],[Ae],[Ee],[Le],[be],[Me],[Re],[Oe]].forEach(t=>{this._injector.add(t)}),[$e,Ne,Rt,at,_e,Pt].forEach(t=>{this._commandService.registerCommand(t)})}onReady(){this._injector.get(Me),this._injector.get(be),this._injector.get(Re),this._injector.get(Ae),this._injector.get(W.IRenderManagerService).registerRenderModule(r.UniverInstanceType.UNIVER_SHEET,[He])}onRendered(){this._injector.get(Oe),this._injector.get(Le)}onSteady(){this._injector.get(Ee)}},P(Je,"pluginName",ba),P(Je,"type",r.UniverInstanceType.UNIVER_SHEET),Je),x.UniverSheetsDataValidationUIPlugin=Ma([It(1,r.Inject(r.Injector)),It(2,r.ICommandService),It(3,r.IConfigService)],x.UniverSheetsDataValidationUIPlugin);var La=Object.getOwnPropertyDescriptor,Ta=(e,t,a,n)=>{for(var o=n>1?void 0:n?La(t,a):t,i=e.length-1,s;i>=0;i--)(s=e[i])&&(o=s(o)||o);return o},Ct=(e,t)=>(a,n)=>t(a,n,e);const Oa="SHEET_DATA_VALIDATION_UI_PLUGIN";x.UniverSheetsDataValidationMobileUIPlugin=(Qe=class extends r.Plugin{constructor(t=Ue,a,n,o){super(),this._config=t,this._injector=a,this._commandService=n,this._configService=o;const{menu:i,...s}=r.merge({},Ue,this._config);i&&this._configService.setConfig("menu",i,{merge:!0}),this._configService.setConfig(ot,s)}onStarting(){[[ue],[me],[Ae],[Ee],[Le],[be],[Me],[Oe]].forEach(t=>{this._injector.add(t)}),[$e,Ne,Rt,at,_e,Pt].forEach(t=>{this._commandService.registerCommand(t)})}onReady(){this._injector.get(Me),this._injector.get(be),this._injector.get(W.IRenderManagerService).registerRenderModule(r.UniverInstanceType.UNIVER_SHEET,[He])}onRendered(){this._injector.get(Oe),this._injector.get(Le)}onSteady(){this._injector.get(Ee)}},P(Qe,"pluginName",Oa),P(Qe,"type",r.UniverInstanceType.UNIVER_SHEET),Qe),x.UniverSheetsDataValidationMobileUIPlugin=Ta([Ct(1,r.Inject(r.Injector)),Ct(2,r.ICommandService),Ct(3,r.IConfigService)],x.UniverSheetsDataValidationMobileUIPlugin),x.DATE_DROPDOWN_KEY=rt,x.LIST_DROPDOWN_KEY=We,Object.defineProperty(x,Symbol.toStringTag,{value:"Module"})});
15
15
 
16
16
 
17
17
  // index
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@univerjs/preset-sheets-data-validation",
3
- "version": "0.6.0-alpha.0",
3
+ "version": "0.6.0-nightly.202502131606",
4
4
  "private": false,
5
5
  "description": "",
6
6
  "author": "DreamNum <developer@univer.ai>",
@@ -57,14 +57,14 @@
57
57
  "rxjs": ">=7.0.0"
58
58
  },
59
59
  "dependencies": {
60
- "@univerjs/data-validation": "0.6.0-alpha.0",
61
- "@univerjs/sheets-data-validation": "0.6.0-alpha.0",
62
- "@univerjs/sheets-data-validation-ui": "0.6.0-alpha.0"
60
+ "@univerjs/data-validation": "0.6.0-nightly.202502131606",
61
+ "@univerjs/sheets-data-validation": "0.6.0-nightly.202502131606",
62
+ "@univerjs/sheets-data-validation-ui": "0.6.0-nightly.202502131606"
63
63
  },
64
64
  "devDependencies": {
65
- "@univerjs/core": "0.6.0-alpha.0",
65
+ "@univerjs/core": "0.6.0-nightly.202502131606",
66
66
  "typescript": "^5.7.2",
67
- "@univerjs-infra/shared": "0.6.0-alpha.0"
67
+ "@univerjs-infra/shared": "0.6.0-nightly.202502131606"
68
68
  },
69
69
  "scripts": {
70
70
  "prebuild:preset": "tsx prepare.ts",