@univerjs/preset-sheets-data-validation 0.5.3 → 0.5.4

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.
@@ -1,4 +1,5 @@
1
1
  import { IPreset } from './types';
2
2
  import '@univerjs/sheets-data-validation/facade';
3
3
  import '@univerjs/sheets-data-validation-ui/lib/index.css';
4
+ export type * from '@univerjs/sheets-data-validation/facade';
4
5
  export declare function UniverSheetsDataValidationPreset(): IPreset;
package/lib/umd/index.js CHANGED
@@ -1,17 +1,17 @@
1
1
  // @univerjs/data-validation/index
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,_){"use strict";var la=Object.defineProperty;var ua=(l,r,_)=>r in l?la(l,r,{enumerable:!0,configurable:!0,writable:!0,value:_}):l[r]=_;var c=(l,r,_)=>ua(l,typeof r!="symbol"?r+"":r,_);var O;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||{}),b=Object.defineProperty,w=Object.getOwnPropertyDescriptor,P=(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=(e?d(a,i,t):d(t))||t);return e&&t&&b(a,i,t),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 _.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=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=P([B(0,r.ILogService)],l.DataValidationModel);var j=Object.defineProperty,$=Object.getOwnPropertyDescriptor,q=(n,a,i,e)=>{for(var t=e>1?void 0:e?$(a,i):a,o=n.length-1,d;o>=0;o--)(d=n[o])&&(t=(e?d(a,i,t):d(t))||t);return e&&t&&j(a,i,t),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 _.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 f={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}},g={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}},H={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:f.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(f.id,p),!0}},Q={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: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(V.id,a),!0}},F={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: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:E,undoMutations:S}),e.executeCommand(g.id,v),!0}},W={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 T={...E,...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(E)}},sa=[{id:g.id,params:da}];return t.pushUndoRedo({unitID:s,redoMutations:oa,undoMutations:sa}),e.executeCommand(g.id,S),!0}},x={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:f.id,params:{unitId:e,subUnitId:t,rule:p}}];return s.pushUndoRedo({redoMutations:m,undoMutations:v,unitID:e}),o.executeCommand(V.id,u),!0}},J="data-validation.config",y={};var z=Object.defineProperty,K=Object.getOwnPropertyDescriptor,Y=(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=(e?d(a,i,t):d(t))||t);return e&&t&&z(a,i,t),t},A=(n,a)=>(i,e)=>a(i,e,n);const X="UNIVER_DATA_VALIDATION_PLUGIN";l.UniverDataValidationPlugin=(O=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(J,o)}onStarting(){[[l.DataValidationModel],[R],[l.DataValidationResourceController]].forEach(a=>this._injector.add(a)),[H,x,F,W,Q,f,g,V].forEach(a=>{this._commandService.registerCommand(a)})}onReady(){this._injector.get(l.DataValidationResourceController)}},c(O,"pluginName",X),c(O,"type",r.UniverInstanceType.UNIVER_SHEET),O),l.UniverDataValidationPlugin=Y([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"},aa={[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"},ta=[r.DataValidationOperator.BETWEEN,r.DataValidationOperator.NOT_BETWEEN];var ea=Object.defineProperty,ia=Object.getOwnPropertyDescriptor,ra=(n,a,i,e)=>{for(var t=e>1?void 0:e?ia(a,i):a,o=n.length-1,d;o>=0;o--)(d=n[o])&&(t=(e?d(a,i,t):d(t))||t);return e&&t&&ea(a,i,t),t},U=(n,a)=>(i,e)=>a(i,e,n);const L="{FORMULA1}",C="{FORMULA2}",na={[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(na[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=ra([U(0,r.Inject(r.LocaleService)),U(1,r.Inject(r.Injector))],l.BaseDataValidator),l.AddDataValidationMutation=f,l.DataValidatorRegistryScope=I,l.DataValidatorRegistryService=R,l.RemoveDataValidationMutation=V,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,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"})});
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 _=(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=(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=(t?n(s,e,a):n(a))||a);return t&&a&&$e(s,e,a),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=We([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 P(o,s){var t;const e=s.getValidatorItem(o);return(t=e==null?void 0:e.offsetFormulaByRange)!=null?t:!1}var xe=Object.defineProperty,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=(t?n(s,e,a):n(a))||a);return t&&a&&xe(s,e,a),a},$=(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 p,f;const c=u.get((p=d.extra)==null?void 0:p.ruleId),h=this._dataValidationModel.getRuleById(t,n,(f=d.extra)==null?void 0:f.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,f=n-h;return j((R=(v=d==null?void 0:d.result)==null?void 0:v[p])==null?void 0:R[f])}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,f=n-h;return j((R=(v=d==null?void 0:d.result)==null?void 0:v[p])==null?void 0:R[f])}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,f=n-h;return j((R=(v=d==null?void 0:d.result)==null?void 0:v[p])==null?void 0:R[f])}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,f=n-h;return j((R=(v=d==null?void 0:d.result)==null?void 0:v[p])==null?void 0:R[f])}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=(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=(t?n(s,e,a):n(a))||a);return t&&a&&Ge(s,e,a),a},H=(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 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(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 Xe=Object.defineProperty,Ke=Object.getOwnPropertyDescriptor,ze=(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=(t?n(s,e,a):n(a))||a);return t&&a&&Xe(s,e,a),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===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),f=d.getCellRaw(n,i),v=U(f);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:f==null?void 0:f.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(o,s){return r.Tools.isBlank(o)?s.t("dataValidation.validFail.value"):r.isFormulaString(o)?s.t("dataValidation.validFail.primitive"):""}const q=o=>r.Tools.isDefine(o)&&String(o).toLowerCase()==="true"?"1":String(o).toLowerCase()==="false"?"0":o;class Me extends g.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,p,f,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=(f=l==null?void 0:l[1])==null?void 0:f.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,f,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=(f=l==null?void 0:l[1])==null?void 0:f.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(o){return o.filter(Boolean).join(",")}function k(o){return o.split(",").filter(Boolean)}function at(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 g.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 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(o){let s=o;return typeof o=="string"?((o.startsWith("¥")||o.startsWith("$"))&&(s=o.slice(1)),+s):+o}class it extends g.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(G,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 rt=["if","indirect","choose","offset"];function nt(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&&rt.indexOf(a.token.toLowerCase())>-1)}function ot(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 g.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=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=ot(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,f;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((f=(p=d==null?void 0:d[0])==null?void 0:p.result)==null?void 0:f[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,f,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=(f=a?l.getSheetBySheetId(a):void 0)!=null?f: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,f,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=(f=a?l.getSheetBySheetId(a):void 0)!=null?f: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 st extends g.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(g.TextLengthErrorTitleMap[e.operator]).replace(Q,a!=null?a:"").replace(G,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(g.DataValidatorRegistryService),u=[],d=[],c=t.get(m.SheetDataValidationModel),h=t.get(r.IUniverInstanceService),p=D.getSheetCommandTarget(h,{unitId:o,subUnitId:s});if(!p)return{redoMutations:u,undoMutations:d};const{worksheet:f}=p,v=new r.ObjectMatrix;let R=!1;function V(S,M){i&&S.forEach(O=>{r.Range.foreach(O,(I,C)=>{const F=f.getCellRaw(I,C),B=Ve(F);(Oe(F)||B===M)&&!(F!=null&&F.p)&&(R=!0,v.setValue(I,C,{v:M,p:null}))})})}if(e.forEach(S=>{switch(S.type){case"delete":u.push({id:g.RemoveDataValidationMutation.id,params:{unitId:o,subUnitId:s,ruleId:S.rule.uid,source:a}}),d.unshift({id:g.AddDataValidationMutation.id,params:{unitId:o,subUnitId:s,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,C=S.newRanges[0].startRow,F=S.newRanges[0].startColumn,B=C-O,ne=F-I,oe=r.isFormulaString(S.rule.formula1)?n.moveFormulaRefOffset(S.rule.formula1,ne,B):S.rule.formula1,se=r.isFormulaString(S.rule.formula2)?n.moveFormulaRefOffset(S.rule.formula2,ne,B):S.rule.formula2;oe!==S.rule.formula1||se!==S.rule.formula2||!r.isRangesEqual(S.newRanges,S.oldRanges)?(u.push({id:g.UpdateDataValidationMutation.id,params:{unitId:o,subUnitId:s,ruleId:S.ruleId,payload:{type:g.UpdateRuleType.ALL,payload:{formula1:oe,formula2:se,ranges:S.newRanges}}}}),d.unshift({id:g.UpdateDataValidationMutation.id,params:{unitId:o,subUnitId:s,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:o,subUnitId:s,ruleId:S.ruleId,payload:{type:g.UpdateRuleType.RANGE,payload:S.newRanges},source:a}}),d.unshift({id:g.UpdateDataValidationMutation.id,params:{unitId:o,subUnitId:s,ruleId:S.ruleId,payload:{type:g.UpdateRuleType.RANGE,payload:S.oldRanges},source:a}}))}else u.push({id:g.UpdateDataValidationMutation.id,params:{unitId:o,subUnitId:s,ruleId:S.ruleId,payload:{type:g.UpdateRuleType.RANGE,payload:S.newRanges},source:a}}),d.unshift({id:g.UpdateDataValidationMutation.id,params:{unitId:o,subUnitId:s,ruleId:S.ruleId,payload:{type:g.UpdateRuleType.RANGE,payload:S.oldRanges},source:a}});const M=c.getRuleById(o,s,S.ruleId);if(M&&M.type===r.DataValidationType.CHECKBOX){const I=c.getValidator(r.DataValidationType.CHECKBOX).parseFormulaSync(M,o,s);V(S.newRanges,I.formula2)}break}case"add":{if(u.push({id:g.AddDataValidationMutation.id,params:{unitId:o,subUnitId:s,rule:S.rule,source:a}}),d.unshift({id:g.RemoveDataValidationMutation.id,params:{unitId:o,subUnitId:s,ruleId:S.rule.uid,source:a}}),S.rule.type===r.DataValidationType.CHECKBOX){const O=c.getValidator(r.DataValidationType.CHECKBOX).parseFormulaSync(S.rule,o,s);V(S.rule.ranges,O.originFormula2)}break}}}),R){const S={id:D.SetRangeValuesMutation.id,params:{unitId:o,subUnitId:s,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(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:p,undoMutations:f}=Y(e,t,h,o);return u.pushUndoRedo({undoMutations:f,redoMutations:p,unitID:e}),r.sequenceExecute(p,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:p,undoMutations:f}=Y(e,t,d,o);return p.push({id:g.AddDataValidationMutation.id,params:h}),f.unshift({id:g.RemoveDataValidationMutation.id,params:{unitId:e,subUnitId:t,ruleId:a.uid}}),l.pushUndoRedo({unitID:e,redoMutations:p,undoMutations:f}),r.sequenceExecute(p,n),!0}},Ce={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(g.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 p={...h,...d};if(!c.validatorFormula(p,n,l).success)return!1;const f={unitId:n,subUnitId:l,ruleId:u,payload:{type:g.UpdateRuleType.SETTING,payload:{...d,...c.normalizeFormula(p,n,l)}}},v=[{id:g.UpdateDataValidationMutation.id,params:f}],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=o.get(r.IUniverInstanceService),I=D.getSheetCommandTarget(O,{unitId:n,subUnitId:l});if(I){const C=new r.ObjectMatrix,{worksheet:F}=I,{formula2:B=x,formula1:ne=W}=h,{formula2:oe=x,formula1:se=W}=d;let fe=!1;if(M.forEach(le=>{r.Range.foreach(le,(X,Se)=>{const E=F.getCellRaw(X,Se),Pe=Ve(E);(Oe(E)||Pe===String(B))&&!(E!=null&&E.p)?(C.setValue(X,Se,{v:oe,p:null}),fe=!0):Pe===String(ne)&&!(E!=null&&E.p)&&(C.setValue(X,Se,{v:se,p:null}),fe=!0)})}),fe){const le={id:D.SetRangeValuesMutation.id,params:{unitId:n,subUnitId:l,cellValue:C.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}},Ee={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: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)}},f=[{id:g.UpdateDataValidationMutation.id,params:p}];return t.pushUndoRedo({unitID:i,redoMutations:h,undoMutations:f}),e.executeCommand(g.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:p,undoMutations:f}=Y(e,t,h,o);return d.pushUndoRedo({unitID:e,redoMutations:p,undoMutations:f}),r.sequenceExecute(p,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: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=(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: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(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:g.RemoveDataValidationMutation.id,params:s}],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:s.unitId}),i.executeCommand(g.RemoveDataValidationMutation.id,s),!0}},ut="sheets-data-validation.config",Ue={};var dt=Object.defineProperty,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=(t?n(s,e,a):n(a))||a);return t&&a&&dt(s,e,a),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)=>{P(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:g.AddDataValidationMutation.id,params:{unitId:s,subUnitId:e,rule:t,source:"patched"}}],redos:[{id:g.RemoveDataValidationMutation.id,params:{unitId:s,subUnitId:e,ruleId:t.uid,source:"patched"}}]};const c=[],h=[],p=d[0];c.push({id:g.UpdateDataValidationMutation.id,params:{unitId:s,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:s,subUnitId:e,ruleId:t.uid,payload:{type:g.UpdateRuleType.ALL,payload:{ranges:a,formula1:i,formula2:n}},source:"patched"}});for(let f=1;f<d.length;f++){const v=d[f],R=r.generateRandomId();c.push({id:g.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:g.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=mt([he(0,r.Inject(m.SheetDataValidationModel)),he(1,r.Inject(K.FormulaRefRangeService)),he(2,r.Inject(g.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||{}),ht=Object.defineProperty,pt=Object.getOwnPropertyDescriptor,gt=(o,s,e,t)=>{for(var a=t>1?void 0:t?pt(s,e):s,i=o.length-1,n;i>=0;i--)(n=o[i])&&(a=(t?n(s,e,a):n(a))||a);return t&&a&&ht(s,e,a),a},pe=(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:p,endRow:f,startColumn:v,endColumn:R}=u.range;for(let V=p;V<=f;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 _t=Object.defineProperty,ft=Object.getOwnPropertyDescriptor,St=(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=(t?n(s,e,a):n(a))||a);return t&&a&&_t(s,e,a),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)=>{P(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 p=this._dataValidationModel.getRuleById(s,e,a);if(!p)return{redos:[],undos:[]};const f=p[c];if(!f||f===h)return{redos:[],undos:[]};const v={unitId:s,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:s,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(s,e,a);if(u){const[c,h]=u;if(c){const p=this._formulaRefRangeService.registerFormula(s,e,c.text,f=>l("formula1",f));n.add(()=>p.dispose())}if(h){const p=this._formulaRefRangeService.registerFormula(s,e,h.text,f=>l("formula2",f));n.add(()=>p.dispose())}}}register(s,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:s,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:s,subUnitId:e,ruleId:t.uid,payload:{type:g.UpdateRuleType.RANGE,payload:c},source:"patched"}}];return{redos:R,undos:V}}else{const v={unitId:s,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,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=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=(o,s,e,t)=>{for(var a=t>1?void 0:t?Rt(s,e):s,i=o.length-1,n;i>=0;i--)(n=o[i])&&(a=(t?n(s,e,a):n(a))||a);return t&&a&&vt(s,e,a),a},ge=(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: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);_(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 Mt extends g.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))}validatorFormula(e,t,a){const i=r.isFormulaString(e.formula1);return{success:i,formula1:i?"":this.localeService.t("dataValidation.validFail.formula")}}async parseFormula(e,t,a){return{formula1:void 0,formula2:void 0,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 yt extends g.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,p=r.isFormulaString(c)?u==null?void 0:u.v:c,f=y(`${h}`)&&y(`${p}`);return{formula1:this._parseNumber(h),formula2:this._parseNumber(p),isFormulaValid:f}}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=(o,s,e,t)=>{for(var a=t>1?void 0:t?Ot(s,e):s,i=o.length-1,n;i>=0;i--)(n=o[i])&&(a=(t?n(s,e,a):n(a))||a);return t&&a&&Tt(s,e,a),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(){[Dt,it,yt,st,ye,Me,me,Le,Mt].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=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,Ct=Object.getOwnPropertyDescriptor,Et=(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=(t?n(s,e,a):n(a))||a);return t&&a&&Ft(s,e,a),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))}),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=Et([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=(o,s,e)=>s in o?Be(o,s,{enumerable:!0,configurable:!0,writable:!0,value:e}):o[s]=e,wt=(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=(t?n(s,e,a):n(a))||a);return t&&a&&Be(s,e,a),a},_e=(o,s)=>(e,t)=>s(e,t,o),je=(o,s,e)=>At(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(ut,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,Ce,Ee,we,Ae,Ne].forEach(s=>{this._commandService.registerCommand(s)}),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),_e(1,r.Inject(r.Injector)),_e(2,r.ICommandService),_e(3,r.IConfigService)],m.UniverSheetsDataValidationPlugin);function Ut(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=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=Ee,m.UpdateSheetDataValidationRangeCommand=Ie,m.UpdateSheetDataValidationSettingCommand=Ce,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,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,C)=>{const F=_.getCellRaw(I,C),B=Ve(F);(Oe(F)||B===M)&&!(F!=null&&F.p)&&(R=!0,v.setValue(I,C,{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,C=S.newRanges[0].startRow,F=S.newRanges[0].startColumn,B=C-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}},Ce={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 C=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 E=F.getCellRaw(X,Se),Pe=Ve(E);(Oe(E)||Pe===String(B))&&!(E!=null&&E.p)?(C.setValue(X,Se,{v:se,p:null}),_e=!0):Pe===String(ne)&&!(E!=null&&E.p)&&(C.setValue(X,Se,{v:oe,p:null}),_e=!0)})}),_e){const le={id:D.SetRangeValuesMutation.id,params:{unitId:n,subUnitId:l,cellValue:C.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}},Ee={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))}validatorFormula(e,t,a){const i=r.isFormulaString(e.formula1);return{success:i,formula1:i?"":this.localeService.t("dataValidation.validFail.formula")}}async parseFormula(e,t,a){return{formula1:void 0,formula2:void 0,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,Ct=Object.getOwnPropertyDescriptor,Et=(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&&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))}),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=Et([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,Ce,Ee,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=Ee,m.UpdateSheetDataValidationRangeCommand=Ie,m.UpdateSheetDataValidationSettingCommand=Ce,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"})});
7
7
 
8
8
 
9
9
  // @univerjs/sheets-data-validation/facade
10
- (function(n,a){typeof exports=="object"&&typeof module<"u"?a(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"],a):(n=typeof globalThis<"u"?globalThis:n||self,a(n.UniverSheetsDataValidationFacade={},n.UniverSheetsDataValidation,n.UniverSheetsFacade,n.UniverCore,n.UniverDataValidation,n.UniverEngineFormula,n.rxjs))})(this,function(n,a,s,i,_,p,m){"use strict";var V=Object.defineProperty;var E=(n,a,s)=>a in n?V(n,a,{enumerable:!0,configurable:!0,writable:!0,value:s}):n[a]=s;var d=(n,a,s)=>E(n,typeof a!="symbol"?a+"":a,s);class l{constructor(t){d(this,"_rule");this._rule=t!=null?t:{uid:i.generateRandomId(),ranges:void 0,type:i.DataValidationType.CUSTOM}}build(){return new u(this._rule)}copy(){return new l({...this._rule,uid:i.generateRandomId()})}getAllowInvalid(){return this._rule.errorStyle!==i.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=i.DataValidationType.CHECKBOX,this._rule.formula1=t,this._rule.formula2=e,this}requireDateAfter(t){return this._rule.type=i.DataValidationType.DATE,this._rule.formula1=t.toLocaleDateString(),this._rule.operator=i.DataValidationOperator.GREATER_THAN,this}requireDateBefore(t){return this._rule.type=i.DataValidationType.DATE,this._rule.formula1=t.toLocaleDateString(),this._rule.formula2=void 0,this._rule.operator=i.DataValidationOperator.LESS_THAN,this}requireDateBetween(t,e){return this._rule.type=i.DataValidationType.DATE,this._rule.formula1=t.toLocaleDateString(),this._rule.formula2=e.toLocaleDateString(),this._rule.operator=i.DataValidationOperator.BETWEEN,this}requireDateEqualTo(t){return this._rule.type=i.DataValidationType.DATE,this._rule.formula1=t.toLocaleDateString(),this._rule.formula2=void 0,this._rule.operator=i.DataValidationOperator.EQUAL,this}requireDateNotBetween(t,e){return this._rule.type=i.DataValidationType.DATE,this._rule.formula1=t.toLocaleDateString(),this._rule.formula2=e.toLocaleDateString(),this._rule.operator=i.DataValidationOperator.NOT_BETWEEN,this}requireDateOnOrAfter(t){return this._rule.type=i.DataValidationType.DATE,this._rule.formula1=t.toLocaleDateString(),this._rule.formula2=void 0,this._rule.operator=i.DataValidationOperator.GREATER_THAN_OR_EQUAL,this}requireDateOnOrBefore(t){return this._rule.type=i.DataValidationType.DATE,this._rule.formula1=t.toLocaleDateString(),this._rule.formula2=void 0,this._rule.operator=i.DataValidationOperator.LESS_THAN_OR_EQUAL,this}requireFormulaSatisfied(t){return this._rule.type=i.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=i.DataValidationOperator.BETWEEN,this._rule.type=r?i.DataValidationType.WHOLE:i.DataValidationType.DECIMAL,this}requireNumberEqualTo(t,e){return this._rule.formula1=`${t}`,this._rule.formula2=void 0,this._rule.operator=i.DataValidationOperator.EQUAL,this._rule.type=e?i.DataValidationType.WHOLE:i.DataValidationType.DECIMAL,this}requireNumberGreaterThan(t,e){return this._rule.formula1=`${t}`,this._rule.formula2=void 0,this._rule.operator=i.DataValidationOperator.GREATER_THAN,this._rule.type=e?i.DataValidationType.WHOLE:i.DataValidationType.DECIMAL,this}requireNumberGreaterThanOrEqualTo(t,e){return this._rule.formula1=`${t}`,this._rule.formula2=void 0,this._rule.operator=i.DataValidationOperator.GREATER_THAN_OR_EQUAL,this._rule.type=e?i.DataValidationType.WHOLE:i.DataValidationType.DECIMAL,this}requireNumberLessThan(t,e){return this._rule.formula1=`${t}`,this._rule.formula2=void 0,this._rule.operator=i.DataValidationOperator.LESS_THAN,this._rule.type=e?i.DataValidationType.WHOLE:i.DataValidationType.DECIMAL,this}requireNumberLessThanOrEqualTo(t,e){return this._rule.formula1=`${t}`,this._rule.formula2=void 0,this._rule.operator=i.DataValidationOperator.LESS_THAN_OR_EQUAL,this._rule.type=e?i.DataValidationType.WHOLE:i.DataValidationType.DECIMAL,this}requireNumberNotBetween(t,e,r){return this._rule.formula1=`${t}`,this._rule.formula2=`${e}`,this._rule.operator=i.DataValidationOperator.NOT_BETWEEN,this._rule.type=r?i.DataValidationType.WHOLE:i.DataValidationType.DECIMAL,this}requireNumberNotEqualTo(t,e){return this._rule.formula1=`${t}`,this._rule.formula2=void 0,this._rule.operator=i.DataValidationOperator.NOT_EQUAL,this._rule.type=e?i.DataValidationType.WHOLE:i.DataValidationType.DECIMAL,this}requireValueInList(t,e,r){return this._rule.type=e?i.DataValidationType.LIST_MULTIPLE:i.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?i.DataValidationType.LIST_MULTIPLE:i.DataValidationType.LIST,this._rule.formula1=`=${p.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?i.DataValidationErrorStyle.WARNING:i.DataValidationErrorStyle.STOP,this}setHelpText(t){return this._rule.error=t,this._rule.showErrorMessage=!0,this}withCriteriaValues(t,e){return this._rule.type=t,this._rule.operator=e[0],this._rule.formula1=e[1],this._rule.formula2=e[2],this}setAllowBlank(t){return this._rule.allowBlank=t,this}setOptions(t){return Object.assign(this._rule,t),this}}class u{constructor(t,e,r){d(this,"rule");d(this,"_worksheet");d(this,"_injector");this._injector=r,this.rule=t,this._worksheet=e}getAllowInvalid(){return this.rule.errorStyle!==i.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 l(this.rule)}getApplied(){if(!this._worksheet)return!1;const e=this._injector.get(_.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(i.IUniverInstanceService).getUnit(this._worksheet.getUnitId());return this.rule.ranges.map(e=>this._injector.createInstance(s.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(i.ICommandService).syncExecuteCommand(a.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(i.ICommandService).syncExecuteCommand(a.UpdateSheetDataValidationOptionsCommand.id,{unitId:this.getUnitId(),subUnitId:this.getSheetId(),ruleId:this.rule.uid,options:{..._.getRuleOptions(this.rule),...t}}))throw new Error("setOptions failed");return Object.assign(this.rule,t),this}setRanges(t){if(this.getApplied()&&!this._injector.get(i.ICommandService).syncExecuteCommand(a.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(i.ICommandService).syncExecuteCommand(a.RemoveSheetDataValidationCommand.id,{unitId:this.getUnitId(),subUnitId:this.getSheetId(),ruleId:this.rule.uid}):!1}}class g extends s.FRange{setDataValidation(t){if(!t)return this._commandService.syncExecuteCommand(a.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(a.AddSheetDataValidationCommand.id,e),this}getDataValidation(){const e=this._injector.get(a.SheetsDataValidationValidatorService).getDataValidation(this._workbook.getUnitId(),this._worksheet.getSheetId(),[this._range]);return e&&new u(e,this._worksheet,this._injector)}getDataValidations(){return this._injector.get(a.SheetsDataValidationValidatorService).getDataValidations(this._workbook.getUnitId(),this._worksheet.getSheetId(),[this._range]).map(e=>new u(e,this._worksheet,this._injector))}async getValidatorStatus(){return this._injector.get(a.SheetsDataValidationValidatorService).validatorRanges(this._workbook.getUnitId(),this._worksheet.getSheetId(),[this._range])}}s.FRange.extend(g);class D{static newDataValidation(){return new l}newDataValidation(){return new l}}i.FUniver.extend(D);class f extends s.FWorkbook{_initialize(){Object.defineProperty(this,"_dataValidationModel",{get(){return this._injector.get(a.SheetDataValidationModel)}})}getValidatorStatus(){return this._injector.get(a.SheetsDataValidationValidatorService).validatorWorkbook(this._workbook.getUnitId())}onDataValidationChange(t){return i.toDisposable(this._dataValidationModel.ruleChange$.pipe(m.filter(e=>e.unitId===this._workbook.getUnitId())).subscribe(t))}onDataValidationStatusChange(t){return i.toDisposable(this._dataValidationModel.validStatusChange$.pipe(m.filter(e=>e.unitId===this._workbook.getUnitId())).subscribe(t))}onBeforeAddDataValidation(t){return i.toDisposable(this._commandService.beforeCommandExecuted((e,r)=>{const o=e.params;if(e.id===a.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 i.toDisposable(this._commandService.beforeCommandExecuted((e,r)=>{const o=e.params;if(e.id===a.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 i.toDisposable(this._commandService.beforeCommandExecuted((e,r)=>{const o=e.params;if(e.id===a.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 i.toDisposable(this._commandService.beforeCommandExecuted((e,r)=>{const o=e.params;if(e.id===a.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 i.toDisposable(this._commandService.beforeCommandExecuted((e,r)=>{const o=e.params;if(e.id===a.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 i.toDisposable(this._commandService.beforeCommandExecuted((e,r)=>{const o=e.params;if(e.id===a.RemoveSheetAllDataValidationCommand.id){if(o.unitId!==this._workbook.getUnitId())return;if(t(o,r)===!1)throw new Error("Command is stopped by the hook onBeforeDeleteAllDataValidation")}}))}}s.FWorkbook.extend(f);class S extends s.FWorksheet{getDataValidations(){return this._injector.get(_.DataValidationModel).getRules(this._workbook.getUnitId(),this._worksheet.getSheetId()).map(e=>new u(e,this._worksheet,this._injector))}getValidatorStatus(){return this._injector.get(a.SheetsDataValidationValidatorService).validatorWorksheet(this._workbook.getUnitId(),this._worksheet.getSheetId())}}s.FWorksheet.extend(S),n.FDataValidation=u,n.FDataValidationBuilder=l,Object.defineProperty(n,Symbol.toStringTag,{value:"Module"})});
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}setHelpText(t){return this._rule.error=t,this._rule.showErrorMessage=!0,this}withCriteriaValues(t,e){return this._rule.type=t,this._rule.operator=e[0],this._rule.formula1=e[1],this._rule.formula2=e[2],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:d,type:l}=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:l,oldRule:d,rule:I})})),this.disposeWithMe(e.validStatusChange$.subscribe(o=>{const{unitId:n,subUnitId:s,ruleId:p,status:d,row:l,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:l,column:h,rule:k,status:d})})),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:d}=s,l={worksheet:d,workbook:p,rule:n.rule};if(this.fireEvent(this.Event.BeforeSheetDataValidationAdd,l),l.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:d}=s,l=d.getDataValidation(n.ruleId);if(!l)return;const h={worksheet:d,workbook:p,rule:l,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:d}=s,l=d.getDataValidation(n.ruleId);if(!l)return;const h={worksheet:d,workbook:p,rule:l,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:d}=s,l=d.getDataValidation(n.ruleId);if(!l)return;const h={worksheet:d,workbook:p,rule:l,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:d}=s,l=d.getDataValidation(n.ruleId);if(!l)return;const h={worksheet:d,workbook:p,rule:l,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:d}=s,l={worksheet:d,workbook:p,rules:d.getDataValidations()};if(this.fireEvent(this.Event.BeforeSheetDataValidationDeleteAll,l),l.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())}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"})});
11
11
 
12
12
 
13
13
  // @univerjs/sheets-data-validation-ui/index
14
- (function(Y,f){typeof exports=="object"&&typeof module<"u"?f(exports,require("react"),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("@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","@univerjs/core","@univerjs/design","@univerjs/engine-render","@univerjs/sheets","@univerjs/sheets-data-validation","@univerjs/sheets-numfmt","@univerjs/sheets-ui","@univerjs/ui","@univerjs/data-validation","@univerjs/docs","rxjs","@univerjs/engine-formula","@univerjs/sheets-formula-ui"],f):(Y=typeof globalThis<"u"?globalThis:Y||self,f(Y.UniverSheetsDataValidationUi={},Y.React,Y.UniverCore,Y.UniverDesign,Y.UniverEngineRender,Y.UniverSheets,Y.UniverSheetsDataValidation,Y.UniverSheetsNumfmt,Y.UniverSheetsUi,Y.UniverUi,Y.UniverDataValidation,Y.UniverDocs,Y.rxjs,Y.UniverEngineFormula,Y.UniverSheetsFormulaUi))})(this,function(Y,f,o,b,B,X,E,Qt,x,z,J,en,re,tt,nt){"use strict";var ti=Object.defineProperty;var ni=(Y,f,o)=>f in Y?ti(Y,f,{enumerable:!0,configurable:!0,writable:!0,value:o}):Y[f]=o;var L=(Y,f,o)=>ni(Y,typeof f!="symbol"?f+"":f,o);var Qe,et;var at={exports:{}},Te={};/**
14
+ (function(Y,g){typeof exports=="object"&&typeof module<"u"?g(exports,require("react"),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("@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","@univerjs/core","@univerjs/design","@univerjs/engine-render","@univerjs/sheets","@univerjs/sheets-data-validation","@univerjs/sheets-numfmt","@univerjs/sheets-ui","@univerjs/ui","@univerjs/data-validation","@univerjs/docs","rxjs","@univerjs/engine-formula","@univerjs/sheets-formula-ui"],g):(Y=typeof globalThis<"u"?globalThis:Y||self,g(Y.UniverSheetsDataValidationUi={},Y.React,Y.UniverCore,Y.UniverDesign,Y.UniverEngineRender,Y.UniverSheets,Y.UniverSheetsDataValidation,Y.UniverSheetsNumfmt,Y.UniverSheetsUi,Y.UniverUi,Y.UniverDataValidation,Y.UniverDocs,Y.rxjs,Y.UniverEngineFormula,Y.UniverSheetsFormulaUi))})(this,function(Y,g,o,b,U,X,E,Qt,B,z,J,en,re,tt,nt){"use strict";var ti=Object.defineProperty;var ni=(Y,g,o)=>g in Y?ti(Y,g,{enumerable:!0,configurable:!0,writable:!0,value:o}):Y[g]=o;var L=(Y,g,o)=>ni(Y,typeof g!="symbol"?g+"":g,o);var Qe,et;var at={exports:{}},Te={};/**
15
15
  * @license React
16
16
  * react-jsx-runtime.production.min.js
17
17
  *
@@ -19,7 +19,7 @@
19
19
  *
20
20
  * This source code is licensed under the MIT license found in the
21
21
  * LICENSE file in the root directory of this source tree.
22
- */var wt;function tn(){if(wt)return Te;wt=1;var e=f,t=Symbol.for("react.element"),a=Symbol.for("react.fragment"),n=Object.prototype.hasOwnProperty,i=e.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,r={key:!0,ref:!0,__self:!0,__source:!0};function s(d,l,u){var p,m={},c=null,g=null;u!==void 0&&(c=""+u),l.key!==void 0&&(c=""+l.key),l.ref!==void 0&&(g=l.ref);for(p in l)n.call(l,p)&&!r.hasOwnProperty(p)&&(m[p]=l[p]);if(d&&d.defaultProps)for(p in l=d.defaultProps,l)m[p]===void 0&&(m[p]=l[p]);return{$$typeof:t,type:d,key:c,ref:g,props:m,_owner:i.current}}return Te.Fragment=a,Te.jsx=s,Te.jsxs=s,Te}var Vt;function nn(){return Vt||(Vt=1,at.exports=tn()),at.exports}var h=nn(),an=Object.defineProperty,on=Object.getOwnPropertyDescriptor,rn=(e,t,a,n)=>{for(var i=n>1?void 0:n?on(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},Pe=(e,t)=>(a,n)=>t(a,n,e);let je=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 I;const n=await e,{worksheet:i,row:r,col:s,unitId:d,subUnitId:l,workbook:u}=t,p=this._dataValidationModel.getRuleIdByLocation(d,l,r,s),m=p?this._dataValidationModel.getRuleById(d,l,p):void 0;if(!m||m.errorStyle!==o.DataValidationErrorStyle.STOP)return a(Promise.resolve(n));const c=await this._dataValidatorRegistryService.getValidatorItem(m.type);if(!c||await c.validator({value:E.getCellValueOrigin(n),interceptValue:E.getCellValueOrigin((I=t==null?void 0:t.origin)!=null?I:n),row:r,column:s,unitId:d,subUnitId:l,worksheet:i,workbook:u,t:n==null?void 0:n.t},m))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(m,{row:r,col:s,unitId:d,subUnitId:l})},footer:{title:f.createElement(b.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:f.createElement(b.Button,{type:"primary",onClick:()=>this._dialogService.close("reject-input-dialog")},this._localeService.t("dataValidation.alert.ok"))},onClose:()=>{this._dialogService.close("reject-input-dialog")}})}};je=rn([Pe(0,o.Inject(X.SheetInterceptorService)),Pe(1,o.Inject(E.SheetDataValidationModel)),Pe(2,o.Inject(J.DataValidatorRegistryService)),Pe(3,z.IDialogService),Pe(4,o.Inject(o.LocaleService))],je);const Et={dvDateDropdown:"univer-dv-date-dropdown",dvDateDropdownBtns:"univer-dv-date-dropdown-btns"},sn=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 ln(e){var _;const{location:t,hideFn:a}=e,{worksheet:n,row:i,col:r,unitId:s,subUnitId:d,workbook:l}=t,u=o.useDependency(o.ICommandService),p=o.useDependency(je),m=n.getCell(i,r),c=E.getCellValueOrigin(n.getCellRaw(i,r)),g=sn(c),[v,I]=f.useState(g),w=v&&v.isValid()?v:o.dayjs(),C=o.useDependency(o.LocaleService),V=o.useDependency(E.SheetDataValidationModel),y=V.getRuleByLocation(s,d,i,r);if(!y)return null;const M=V.getValidator(y.type);if(!m||!M)return;const D=!!((_=y.bizInfo)!=null&&_.showTime),S=async()=>{var N,U,k;if(!w)return;const j=w.format(D?"YYYY-MM-DD HH:mm:ss":"YYYY-MM-DD 00:00:00"),$=(N=o.numfmt.parseDate(j))==null?void 0:N.v,A=l.getStyles().getStyleByCell(m),T=(k=(U=A==null?void 0:A.n)==null?void 0:U.pattern)!=null?k:"",F=Qt.getPatternType(T);y.errorStyle!==o.DataValidationErrorStyle.STOP||await M.validator({value:$,unitId:s,subUnitId:d,row:i,column:r,worksheet:n,workbook:l,interceptValue:j.replace("Z","").replace("T"," "),t:o.CellValueType.NUMBER},y)?(a(),await u.executeCommand(x.SetCellEditVisibleOperation.id,{visible:!1,eventType:B.DeviceInputEventType.Keyboard,unitId:s,keycode:z.KeyCode.ESC}),await u.executeCommand(X.SetRangeValuesCommand.id,{unitId:s,subUnitId:d,range:{startColumn:r,endColumn:r,startRow:i,endRow:i},value:{v:$,t:2,p:null,f:null,si:null,s:{n:{pattern:D?F==="datetime"?T:"yyyy-MM-dd hh:mm:ss":F==="date"?T:"yyyy-MM-dd"}}}})):p.showReject(M.getRuleFinalError(y,{row:i,col:r,unitId:s,subUnitId:d}))};return h.jsxs("div",{className:Et.dvDateDropdown,children:[h.jsx(b.DatePanel,{defaultValue:w,pickerValue:w,showTime:D||void 0,onSelect:async O=>{I(O)},onPanelChange:O=>{I(O)},disabledDate:O=>!o.numfmt.parseDate(O.format("YYYY-MM-DD"))}),h.jsx("div",{className:Et.dvDateDropdownBtns,children:h.jsx(b.Button,{size:"small",type:"primary",onClick:S,disabled:!w.isValid(),children:C.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)},dn=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=f.forwardRef(function(e,t){var a=e.icon,n=e.id,i=e.className,r=e.extend,s=dn(e,["icon","id","className","extend"]),d="univerjs-icon univerjs-icon-".concat(n," ").concat(i||"").trim(),l=f.useRef("_".concat(pn()));return Rt(a,"".concat(n),{defIds:a.defIds,idSuffix:l.current},se({ref:t,className:d},s),r)});function Rt(e,t,a,n,i){return f.createElement(e.tag,se(se({key:t},cn(e,a,i)),n),(un(e,a).children||[]).map(function(r,s){return Rt(r,"".concat(t,"-").concat(e.tag,"-").concat(s),a,void 0,i)}))}function cn(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],d=r[1];typeof d=="string"&&(n[s]=d.replace(/url\(#(.*)\)/,"url(#$1".concat(t.idSuffix,")")))})),n}function un(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 pn(){return Math.random().toString(36).substring(2,8)}ve.displayName="UniverIcon";var hn={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"}}]},Mt=f.forwardRef(function(e,t){return f.createElement(ve,Object.assign({},e,{id:"check-mark-single",ref:t,icon:hn}))});Mt.displayName="CheckMarkSingle";var mn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 17 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M1.4917 3.07803C1.4917 2.19437 2.20804 1.47803 3.0917 1.47803H5.6917C6.57536 1.47803 7.2917 2.19437 7.2917 3.07803V5.67803C7.2917 6.56168 6.57535 7.27803 5.6917 7.27803H3.0917C2.20804 7.27803 1.4917 6.56168 1.4917 5.67803V3.07803ZM3.0917 2.67803C2.87078 2.67803 2.6917 2.85711 2.6917 3.07803V5.67803C2.6917 5.89894 2.87079 6.07803 3.0917 6.07803H5.6917C5.91261 6.07803 6.0917 5.89894 6.0917 5.67803V3.07803C6.0917 2.85711 5.91261 2.67803 5.6917 2.67803H3.0917Z",fillRule:"evenodd",clipRule:"evenodd"}},{tag:"path",attrs:{fill:"currentColor",d:"M14.6175 2.45279C14.8518 2.68711 14.8518 3.06701 14.6175 3.30132L11.6151 6.30365C11.3957 6.52307 11.0451 6.53897 10.8067 6.34031L8.80915 4.67566C8.55458 4.46352 8.52019 4.08518 8.73233 3.83062 8.94447 3.57605 9.32281 3.54166 9.57737 3.7538L11.154 5.06767 13.769 2.45278C14.0033 2.21847 14.3832 2.21848 14.6175 2.45279zM14.1175 9.19746C14.3518 9.43178 14.3518 9.81168 14.1175 10.046L12.5418 11.6217 14.1175 13.1975C14.3518 13.4318 14.3518 13.8117 14.1175 14.046 13.8832 14.2803 13.5033 14.2803 13.269 14.046L11.6933 12.4703 10.1175 14.046C9.88321 14.2803 9.50331 14.2803 9.269 14.046 9.03468 13.8117 9.03468 13.4318 9.269 13.1975L10.8447 11.6217 9.269 10.046C9.03468 9.81168 9.03468 9.43178 9.269 9.19746 9.50331 8.96315 9.88321 8.96315 10.1175 9.19746L11.6933 10.7732 13.269 9.19746C13.5033 8.96315 13.8832 8.96315 14.1175 9.19746z"}},{tag:"path",attrs:{fill:"currentColor",d:"M3.0917 8.72168C2.20804 8.72168 1.4917 9.43802 1.4917 10.3217V12.9217C1.4917 13.8053 2.20804 14.5217 3.0917 14.5217H5.6917C6.57535 14.5217 7.2917 13.8053 7.2917 12.9217V10.3217C7.2917 9.43802 6.57536 8.72168 5.6917 8.72168H3.0917ZM2.6917 10.3217C2.6917 10.1008 2.87078 9.92168 3.0917 9.92168H5.6917C5.91261 9.92168 6.0917 10.1008 6.0917 10.3217V12.9217C6.0917 13.1426 5.91261 13.3217 5.6917 13.3217H3.0917C2.87079 13.3217 2.6917 13.1426 2.6917 12.9217V10.3217Z",fillRule:"evenodd",clipRule:"evenodd"}}]},bt=f.forwardRef(function(e,t){return f.createElement(ve,Object.assign({},e,{id:"data-validation-single",ref:t,icon:mn}))});bt.displayName="DataValidationSingle";var vn={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"}}]},it=f.forwardRef(function(e,t){return f.createElement(ve,Object.assign({},e,{id:"delete-single",ref:t,icon:vn}))});it.displayName="DeleteSingle";var fn={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"}}]},Ot=f.forwardRef(function(e,t){return f.createElement(ve,Object.assign({},e,{id:"increase-single",ref:t,icon:fn}))});Ot.displayName="IncreaseSingle";var gn={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"}}]},Lt=f.forwardRef(function(e,t){return f.createElement(ve,Object.assign({},e,{id:"more-down-single",ref:t,icon:gn}))});Lt.displayName="MoreDownSingle";var Sn={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"}}]},Tt=f.forwardRef(function(e,t){return f.createElement(ve,Object.assign({},e,{id:"more-up-single",ref:t,icon:Sn}))});Tt.displayName="MoreUpSingle";var _n={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"}}]}]},Pt=f.forwardRef(function(e,t){return f.createElement(ve,Object.assign({},e,{id:"sequence-single",ref:t,icon:_n}))});Pt.displayName="SequenceSingle";var In=Object.defineProperty,Cn=Object.getOwnPropertyDescriptor,Dn=(e,t,a,n)=>{for(var i=n>1?void 0:n?Cn(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&&In(t,a,i),i},jt=(e,t)=>(a,n)=>t(a,n,e);let ue=class extends o.Disposable{constructor(t,a){super();L(this,"_open$",new re.BehaviorSubject(!1));L(this,"open$",this._open$.pipe(re.distinctUntilChanged()));L(this,"_activeRule");L(this,"_activeRule$",new re.BehaviorSubject(void 0));L(this,"activeRule$",this._activeRule$.asObservable());L(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===xe&&(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=Dn([jt(0,o.IUniverInstanceService),jt(1,z.ISidebarService)],ue);function yn(){const e=o.useDependency(fe),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 d=()=>{e.hideDropdown()};return h.jsx(r,{location:n,hideFn:d},s)}const At="sheet.ui.dropdown";var wn=Object.defineProperty,Vn=Object.getOwnPropertyDescriptor,En=(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&&wn(t,a,i),i},Se=(e,t)=>(a,n)=>t(a,n,e);let fe=class extends o.Disposable{constructor(t,a,n,i,r,s,d){super();L(this,"_activeDropdown");L(this,"_activeDropdown$",new re.Subject);L(this,"_currentPopup",null);L(this,"activeDropdown$",this._activeDropdown$.asObservable());L(this,"_zenVisible",!1);this._canvasPopupManagerService=t,this._univerInstanceService=a,this._dataValidatorRegistryService=n,this._zenZoneService=i,this._renderManagerService=r,this._dataValidationModel=s,this._sheetsSelectionsService=d,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 d=this._dataValidationModel.getRuleByLocation(r.getUnitId(),s.getSheetId(),n,i);if(!d)return;const l=this._dataValidatorRegistryService.getValidatorItem(d.type);return l==null?void 0:l.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:d}=n;if(this._currentPopup&&this._currentPopup.dispose(),this._zenVisible)return;this._activeDropdown=t,this._activeDropdown$.next(this._activeDropdown);const l=this._renderManagerService.getRenderById(o.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),u=this._canvasPopupManagerService.attachPopupToCell(i,r,{componentKey:At,onClickOutside:()=>{a&&this.hideDropdown()},offset:[0,3],excludeOutside:[l==null?void 0:l.engine.getCanvasElement()].filter(Boolean)},s,d);if(!u)throw new Error("[DataValidationDropdownManagerService]: cannot show dropdown!");const p=new o.DisposableCollection;p.add(u),p.add({dispose:()=>{var m,c;(c=(m=this._activeDropdown)==null?void 0:m.onHide)==null||c.call(m)}}),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,i,r){const s=this._univerInstanceService.getUnit(t,o.UniverInstanceType.UNIVER_SHEET);if(!s)return;const d=s.getSheetBySheetId(a);if(!d)return;const l=this._dataValidationModel.getRuleByLocation(s.getUnitId(),d.getSheetId(),n,i);if(!l)return;const u=this._dataValidatorRegistryService.getValidatorItem(l.type);if(!u||!u.dropdown){this.hideDropdown();return}this.showDropdown({location:{workbook:s,worksheet:d,row:n,col:i,unitId:t,subUnitId:a},componentKey:u.dropdown,onHide:r})}};fe=En([Se(0,o.Inject(x.SheetCanvasPopManagerService)),Se(1,o.IUniverInstanceService),Se(2,o.Inject(J.DataValidatorRegistryService)),Se(3,z.IZenZoneService),Se(4,B.IRenderManagerService),Se(5,o.Inject(E.SheetDataValidationModel)),Se(6,o.Inject(X.SheetsSelectionsService))],fe);const xe="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),d=e.get(z.ISidebarService),l=X.getSheetCommandTarget(s);if(!l)return!1;const{unitId:u,subUnitId:p}=l,m=a?r.getRuleById(u,p,a):void 0;i.open(),i.setActiveRule(m&&{unitId:u,subUnitId:p,rule:m});const c=d.open({id:xe,header:{title:n?"dataValidation.panel.addTitle":"dataValidation.panel.title"},children:{label:xe},width:312,onClose:()=>i.close()});return i.setCloseDisposable(c),!0}},ot={id:"data-validation.operation.close-validation-panel",type:o.CommandType.OPERATION,handler(e){return e.get(ue).close(),!0}},Ft={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(ot.id):t.executeCommand(_e.id),!0}},Ne={type:o.CommandType.OPERATION,id:"sheet.operation.show-data-validation-dropdown",handler(e,t){if(!t)return!1;const a=e.get(fe),{unitId:n,subUnitId:i,row:r,column:s}=t,d=a.activeDropdown,l=d==null?void 0:d.location;return l&&l.unitId===n&&l.subUnitId===i&&l.row===r&&l.col===s||a.showDataValidationDropdown(n,i,r,s),!0}},xt={type:o.CommandType.OPERATION,id:"sheet.operation.hide-data-validation-dropdown",handler(e,t){return t?(e.get(fe).hideDropdown(),!0):!1}},Ie="#ECECEC",rt="sheets-data-validation-ui.config",Ue={},me={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"},Rn=e=>{var D,S;const{value:t,onChange:a,multiple:n,options:i,title:r,onEdit:s,style:d,filter:l,location:u}=e,p=o.useDependency(o.LocaleService),m=o.useDependency(o.IConfigService),c=l==null?void 0:l.toLowerCase(),{row:g,col:v,unitId:I,subUnitId:w}=u,C=i.filter(_=>c?_.label.toLowerCase().includes(c):!0),V=(S=(D=m.getConfig(rt))==null?void 0:D.showEditOnDropdown)!=null?S:!0,y=o.useDependency(x.SheetPermissionInterceptorBaseController),M=f.useMemo(()=>y.permissionCheckWithRanges({workbookTypes:[X.WorkbookEditablePermission],rangeTypes:[X.RangeProtectionPermissionEditPoint],worksheetTypes:[X.WorksheetEditPermission]},[{startColumn:v,startRow:g,endColumn:v,endRow:g}],I,w),[y,v,g,I,w]);return h.jsxs("div",{className:me.dvListDropdown,style:d,children:[h.jsx("div",{className:me.dvListDropdownTitle,children:r}),h.jsx("div",{className:me.dvListDropdownList,children:h.jsx(b.Scrollbar,{children:h.jsx("div",{className:me.dvListDropdownListContainer,children:C.map((_,O)=>{const j=t.indexOf(_.value)>-1,$=()=>{let T;j?T=new Set(t.filter(N=>N!==_.value)):T=new Set(n?[...t,_.value]:[_.value]);const F=[];i.forEach(N=>{T.has(N.value)&&F.push(N.value)}),a(F)},A=_.label.toLocaleLowerCase().indexOf(c);return h.jsxs("div",{className:me.dvListDropdownItemContainer,onClick:$,children:[h.jsx("div",{className:me.dvListDropdownItem,style:{background:_.color||Ie},children:c&&_.label.toLowerCase().includes(c)?h.jsxs(h.Fragment,{children:[h.jsx("span",{children:_.label.substring(0,A)}),h.jsx("span",{style:{fontWeight:"bold"},children:_.label.substring(A,A+c.length)}),h.jsx("span",{children:_.label.substring(A+c.length)})]}):_.label}),h.jsx("div",{className:me.dvListDropdownSelectedIcon,children:j?h.jsx(Mt,{}):null})]},O)})})},l)}),V&&M?h.jsxs(h.Fragment,{children:[h.jsx("div",{className:me.dvListDropdownSplit}),h.jsx("div",{className:me.dvListDropdownEdit,children:h.jsx("a",{onClick:s,children:p.t("dataValidation.list.edit")})})]}):null]})};function Mn(e){var U,k,G,Z;const{location:t,hideFn:a}=e,{worksheet:n,row:i,col:r,unitId:s,subUnitId:d}=t,l=o.useDependency(J.DataValidationModel),[u,p]=f.useState(""),m=o.useDependency(o.ICommandService),c=o.useDependency(o.LocaleService),[g,v]=f.useState(""),I=o.useDependency(x.IEditorBridgeService),w=o.useDependency(o.IUniverInstanceService),C=f.useMemo(()=>l.ruleChange$.pipe(re.debounceTime(16)),[]),V=o.useDependency(E.SheetDataValidationModel);z.useObservable(C);const y=z.RectPopup.useContext(),M=((k=(U=y.current)==null?void 0:U.right)!=null?k:0)-((Z=(G=y.current)==null?void 0:G.left)!=null?Z:0);if(f.useEffect(()=>{const q=m.onCommandExecuted(ee=>{var te,ae;if(ee.id===en.RichTextEditingMutation.id){const ie=ee.params,{unitId:le}=ie,oe=w.getUnit(le,o.UniverInstanceType.UNIVER_DOC);if(!oe)return;const de=o.BuildTextUtils.transform.getPlainText((ae=(te=oe.getSnapshot().body)==null?void 0:te.dataStream)!=null?ae:"");p(de)}});return()=>{q.dispose()}},[m,w]),!n)return null;const D=V.getRuleByLocation(s,d,i,r);if(!D)return null;const S=V.getValidator(D.type);if(!S)return null;const _=n.getCell(i,r),O=(D==null?void 0:D.renderMode)===o.DataValidationRenderMode.CUSTOM||(D==null?void 0:D.renderMode)===void 0;if(!_||!D||!S||S.id.indexOf(o.DataValidationType.LIST)!==0)return;const j=D.type===o.DataValidationType.LIST_MULTIPLE,$=S.getListWithColor(D,s,d),A=g||E.getDataValidationCellValue(n.getCellRaw(i,r)),T=E.deserializeListOptions(A),F=()=>{m.executeCommand(_e.id,{ruleId:D.uid}),a()},N=$.map(q=>({label:q.label,value:q.label,color:O||q.color?q.color:"transparent"}));return h.jsx(Rn,{style:{minWidth:M,maxWidth:Math.max(M,200)},title:j?c.t("dataValidation.listMultiple.dropdown"):c.t("dataValidation.list.dropdown"),value:T,multiple:j,onChange:async q=>{const ee=E.serializeListOptions(q),te={unitId:s,subUnitId:d,range:{startColumn:r,endColumn:r,startRow:i,endRow:i},value:{v:ee,p:null,f:null,si:null}};I.isVisible()&&I.changeVisible({visible:!1,keycode:z.KeyCode.ESC,eventType:B.DeviceInputEventType.Keyboard,unitId:s}),v(ee),j||a(),I.isVisible().visible&&await m.executeCommand(x.SetCellEditVisibleOperation.id,{visible:!1,eventType:B.DeviceInputEventType.Keyboard,unitId:s,keycode:z.KeyCode.ESC}),m.executeCommand(X.SetRangeValuesCommand.id,te)},options:N,onEdit:F,filter:u,location:t})}const st={dataValidationOptionsButton:"univer-data-validation-options-button",dataValidationOptionsButtonIcon:"univer-data-validation-options-button-icon"};function bn(e){var u;const t=o.useDependency(o.LocaleService),a=o.useDependency(z.ComponentManager),{value:n,onChange:i,extraComponent:r}=e,[s,d]=f.useState(!1),l=r?a.get(r):null;return h.jsxs(h.Fragment,{children:[h.jsxs("div",{className:st.dataValidationOptionsButton,onClick:()=>d(!s),children:[t.t("dataValidation.panel.options"),s?h.jsx(Tt,{className:st.dataValidationOptionsButtonIcon}):h.jsx(Lt,{className:st.dataValidationOptionsButtonIcon})]}),s&&h.jsxs(h.Fragment,{children:[l?h.jsx(l,{value:n,onChange:i}):null,h.jsx(b.FormLayout,{label:t.t("dataValidation.panel.invalid"),children:h.jsxs(b.RadioGroup,{value:`${(u=n.errorStyle)!=null?u:o.DataValidationErrorStyle.WARNING}`,onChange:p=>i({...n,errorStyle:+p}),children:[h.jsx(b.Radio,{value:`${o.DataValidationErrorStyle.WARNING}`,children:t.t("dataValidation.panel.showWarning")}),h.jsx(b.Radio,{value:`${o.DataValidationErrorStyle.STOP}`,children:t.t("dataValidation.panel.rejectInput")})]})}),h.jsx(b.FormLayout,{label:t.t("dataValidation.panel.messageInfo"),children:h.jsx(b.Checkbox,{checked:n.showErrorMessage,onChange:()=>i({...n,showErrorMessage:!n.showErrorMessage}),children:t.t("dataValidation.panel.showInfo")})}),n.showErrorMessage?h.jsx(b.FormLayout,{children:h.jsx(b.Input,{value:n.error,onChange:p=>i({...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"},On=e=>o.debounce(async(t,a,n,i)=>{const r=await e.executeCommand(t,a,n);i==null||i(r)},1e3);function Ln(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 Tn(){var de;const[e,t]=f.useState(0),a=o.useDependency(ue),n=z.useObservable(a.activeRule$,a.activeRule),{unitId:i,subUnitId:r,rule:s}=n||{},d=s.uid,l=o.useDependency(J.DataValidatorRegistryService),u=o.useDependency(o.IUniverInstanceService),p=o.useDependency(z.ComponentManager),m=o.useDependency(o.ICommandService),c=o.useDependency(J.DataValidationModel),g=o.useDependency(o.LocaleService),[v,I]=f.useState(s),w=l.getValidatorItem(v.type),[C,V]=f.useState(!1),y=l.getValidatorsByScope(J.DataValidatorRegistryScope.SHEET),[M,D]=f.useState(()=>v.ranges.map(P=>({unitId:"",sheetId:"",range:P}))),S=f.useMemo(()=>On(m),[m]),[_,O]=f.useState(!1),j=f.useRef({}),[$,A]=f.useState(!1),T=o.useDependency(X.SheetsSelectionsService);if(f.useEffect(()=>()=>{const P=T.getCurrentLastSelection();P&&T.setSelections([P])},[T]),f.useEffect(()=>{m.onCommandExecuted(P=>{(P.id===o.UndoCommand.id||P.id===o.RedoCommand.id)&&setTimeout(()=>{const R=c.getRuleById(i,r,d);t(W=>W+1),R&&(I(R),D(R.ranges.map(W=>({unitId:"",sheetId:"",range:W}))))},20)})},[m,c,d,r,i]),!w)return null;const F=w.operators,N=w.operatorNames,U=v.operator?J.TWO_FORMULA_OPERATOR_COUNT.includes(v.operator):!1,k=()=>{!v.ranges.length||_||(w.validatorFormula(v,i,r).success?a.setActiveRule(null):V(!0))},G=z.useEvent(P=>{const R=P.split(",").filter(Boolean).map(tt.deserializeRangeWithSheet).map(K=>{const ge=K.sheetName;if(ge){const ei=Ln(u,K.unitId,ge);return{...K,sheetId:ei}}return{...K,sheetId:""}});if(o.isUnitRangesEqual(R,M))return;D(R);const W=R.filter(K=>(!K.unitId||K.unitId===i)&&(!K.sheetId||K.sheetId===r)).map(K=>K.range);if(I({...v,ranges:W}),W.length===0)return;const H={unitId:i,subUnitId:r,ruleId:d,ranges:W};S(E.UpdateSheetDataValidationRangeCommand.id,H)}),Z=P=>{if(o.shallowEqual(P,J.getRuleSetting(v)))return;I({...v,...P});const R={unitId:i,subUnitId:r,ruleId:d,setting:P};S(E.UpdateSheetDataValidationSettingCommand.id,R,void 0)},q=async()=>{await m.executeCommand(E.RemoveSheetDataValidationCommand.id,{ruleId:d,unitId:i,subUnitId:r}),a.setActiveRule(null)},ee={type:v.type,operator:v.operator,formula1:v.formula1,formula2:v.formula2,allowBlank:v.allowBlank},te=P=>{const R=l.getValidatorItem(P);if(!R)return;const W=R.operators,H=c.getRuleById(i,r,d),K=P===(H==null?void 0:H.type)||P.includes("list")&&(H!=null&&H.type.includes("list"))?{...H,type:P}:{...v,type:P,operator:W[0],formula1:void 0,formula2:void 0};I(K),m.executeCommand(E.UpdateSheetDataValidationSettingCommand.id,{unitId:i,subUnitId:r,ruleId:v.uid,setting:J.getRuleSetting(K)})},ae=p.get(w.formulaInput),ie=f.useMemo(()=>M.map(P=>tt.serializeRange(P.range)).join(","),[]),le=J.getRuleOptions(v),oe=P=>{o.shallowEqual(P,J.getRuleOptions(v))||(I({...v,...P}),S(E.UpdateSheetDataValidationOptionsCommand.id,{unitId:i,subUnitId:r,ruleId:d,options:P}))};return z.useSidebarClick(P=>{var W;const R=(W=j.current)==null?void 0:W.handleOutClick;R&&R(P,()=>A(!1))}),h.jsxs("div",{className:we.dataValidationDetail,children:[h.jsx(b.FormLayout,{label:g.t("dataValidation.panel.range"),error:!v.ranges.length||_?g.t("dataValidation.panel.rangeError"):"",children:h.jsx(nt.RangeSelector,{unitId:i,subUnitId:r,initValue:ie,onChange:G,onFocus:()=>A(!0),isFocus:$,actions:j.current,onVerify:P=>O(!P)})}),h.jsx(b.FormLayout,{label:g.t("dataValidation.panel.type"),children:h.jsx(b.Select,{options:y==null?void 0:y.map(P=>({label:g.t(P.title),value:P.id})),value:v.type,onChange:te,className:we.dataValidationDetailFormItem})}),F!=null&&F.length?h.jsx(b.FormLayout,{label:g.t("dataValidation.panel.operator"),children:h.jsx(b.Select,{options:F.map((P,R)=>({value:`${P}`,label:N[R]})),value:`${v.operator}`,onChange:P=>{Z({...ee,operator:P})},className:we.dataValidationDetailFormItem})}):null,ae?h.jsx(ae,{isTwoFormula:U,value:{formula1:v.formula1,formula2:v.formula2},onChange:P=>{Z({...ee,...P})},showError:C,validResult:w.validatorFormula(v,i,r),unitId:i,subUnitId:r,ruleId:d},e+v.type):null,h.jsx(b.FormLayout,{children:h.jsx(b.Checkbox,{checked:(de=v.allowBlank)!=null?de:!0,onChange:()=>{var P;return Z({...ee,allowBlank:!((P=v.allowBlank)==null||P)})},children:g.t("dataValidation.panel.allowBlank")})}),h.jsx(bn,{value:le,onChange:oe,extraComponent:w.optionsInput}),h.jsxs("div",{className:we.dataValidationDetailButtons,children:[h.jsx(b.Button,{className:we.dataValidationDetailButton,onClick:q,children:g.t("dataValidation.panel.removeRule")}),h.jsx(b.Button,{className:we.dataValidationDetailButton,type:"primary",onClick:k,children:g.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"},Pn=e=>{const{rule:t,onClick:a,unitId:n,subUnitId:i,disable:r}=e,s=o.useDependency(J.DataValidatorRegistryService),d=o.useDependency(o.ICommandService),l=o.useDependency(x.IMarkSelectionService),u=s.getValidatorItem(t.type),p=f.useRef(),[m,c]=f.useState(!1),g=v=>{d.executeCommand(E.RemoveSheetDataValidationCommand.id,{ruleId:t.uid,unitId:n,subUnitId:i}),v.stopPropagation()};return f.useEffect(()=>()=>{var v;p.current&&((v=p.current)==null||v.forEach(I=>{I&&l.removeShape(I)}))},[l]),h.jsxs("div",{className:Be.dataValidationItemContainer,onClick:a,onMouseEnter:()=>{r||(c(!0),p.current=t.ranges.map(v=>l.addShape({range:v,style:{fill:"rgba(73, 184, 17, 0.05)",strokeWidth:1,stroke:"#49B811",widgets:{}},primary:null})))},onMouseLeave:()=>{var v;c(!1),(v=p.current)==null||v.forEach(I=>{I&&l.removeShape(I)}),p.current=void 0},children:[h.jsx("div",{className:Be.dataValidationItemTitle,children:u==null?void 0:u.generateRuleName(t)}),h.jsx("div",{className:Be.dataValidationItemContent,children:t.ranges.map(v=>tt.serializeRange(v)).join(",")}),m?h.jsx("div",{className:Be.dataValidationItemIcon,onClick:g,children:h.jsx(it,{})}):null]})},ke={dataValidationList:"univer-data-validation-list",dataValidationListButtons:"univer-data-validation-list-buttons",dataValidationListButton:"univer-data-validation-list-button"};function jn(){const e=o.useDependency(o.IUniverInstanceService),t=z.useObservable(()=>e.getCurrentTypeOfUnit$(o.UniverInstanceType.UNIVER_SHEET),void 0,void 0,[]);return t?h.jsx(An,{workbook:t}):null}function An(e){const t=o.useDependency(E.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),[d,l]=f.useState([]),{workbook:u}=e,p=z.useObservable(u.activeSheet$,void 0,!0),m=u.getUnitId(),c=p==null?void 0:p.getSheetId();f.useEffect(()=>{l(t.getRules(m,c));const V=t.ruleChange$.subscribe(y=>{y.unitId===m&&y.subUnitId===c&&l(t.getRules(m,c))});return()=>{V.unsubscribe()}},[m,c,t]);const g=async()=>{const V=E.createDefaultNewRule(i),y={unitId:m,subUnitId:c,rule:V};await n.executeCommand(E.AddSheetDataValidationCommand.id,y),r.setActiveRule({unitId:m,subUnitId:c,rule:V})},v=()=>{n.executeCommand(E.RemoveSheetAllDataValidationCommand.id,{unitId:m,subUnitId:c})},w=(V=>{const y=a.getCurrentUnitForType(o.UniverInstanceType.UNIVER_SHEET),M=y.getActiveSheet(),D=y.getUnitId(),S=M.getSheetId();return V.map(O=>X.checkRangesEditablePermission(i,D,S,O.ranges)?{...O}:{...O,disable:!0})})(d),C=w==null?void 0:w.some(V=>V.disable);return h.jsxs("div",{className:ke.dataValidationList,children:[w==null?void 0:w.map(V=>{var y;return h.jsx(Pn,{unitId:m,subUnitId:c,onClick:()=>{V.disable||r.setActiveRule({unitId:m,subUnitId:c,rule:V})},rule:V,disable:(y=V.disable)!=null?y:!1},V.uid)}),h.jsxs("div",{className:ke.dataValidationListButtons,children:[d.length&&!C?h.jsx(b.Button,{className:ke.dataValidationListButton,onClick:v,children:s.t("dataValidation.panel.removeAll")}):null,h.jsx(b.Button,{className:ke.dataValidationListButton,type:"primary",onClick:g,children:s.t("dataValidation.panel.add")})]})]})}const Fn=()=>{const e=o.useDependency(ue),t=z.useObservable(e.activeRule$,e.activeRule);return t?h.jsx(Tn,{},t.rule.uid):h.jsx(jn,{})},We="data-validation.list.dropdown",lt="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=E.createDefaultNewRule(e),s=e.get(o.ICommandService),d=n.getUnitId(),l=i.getSheetId(),u={rule:r,unitId:d,subUnitId:l};return s.syncExecuteCommand(E.AddSheetDataValidationCommand.id,u)?(s.syncExecuteCommand(_e.id,{ruleId:r.uid,isAdd:!0}),!0):!1}};var xn=Object.defineProperty,Nn=Object.getOwnPropertyDescriptor,Un=(e,t,a,n)=>{for(var i=n>1?void 0:n?Nn(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&&xn(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),d=(t=s==null?void 0:s.alert)==null?void 0:t.location;if(d&&d.row===e.location.row&&d.col===e.location.col&&d.subUnitId===e.location.subUnitId&&d.unitId===e.location.unitId){this._cellAlertManagerService.removeAlert(Ce);return}const l=this._dataValidationModel.getValidator(i.type);if(!l){this._cellAlertManagerService.removeAlert(Ce);return}this._cellAlertManagerService.showAlert({type:x.CellAlertType.ERROR,title:this._localeService.t("dataValidation.error.title"),message:l==null?void 0:l.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=Un([Ve(0,o.Inject(x.HoverManagerService)),Ve(1,o.Inject(x.CellAlertManagerService)),Ve(2,o.IUniverInstanceService),Ve(3,o.Inject(o.LocaleService)),Ve(4,z.IZenZoneService),Ve(5,o.Inject(E.SheetDataValidationModel))],Ae);var Bn=Object.defineProperty,kn=Object.getOwnPropertyDescriptor,Wn=(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&&Bn(t,a,i),i},dt=(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:d,subUnitId:l}=n,u=this._sheetDataValidationModel.getRuleObjectMatrix(d,l).clone(),p=x.virtualizeDiscreteRanges([r,s]),[m,c]=p.ranges,{mapFunc:g}=p,v={row:m.startRow,col:m.startColumn},I=x.getAutoFillRepeatRange(m,c),w=new o.ObjectMatrix,C=new Set;I.forEach(S=>{const _=S.repeatStartCell,O=S.relativeRange,j={startRow:v.row,startColumn:v.col,endColumn:v.col,endRow:v.row},$={startRow:_.row,startColumn:_.col,endColumn:_.col,endRow:_.row};o.Range.foreach(O,(A,T)=>{const F=o.Rectangle.getPositionRange({startRow:A,startColumn:T,endColumn:T,endRow:A},j),{row:N,col:U}=g(F.startRow,F.startColumn),k=this._sheetDataValidationModel.getRuleIdByLocation(d,l,N,U)||"",G=o.Rectangle.getPositionRange({startRow:A,startColumn:T,endColumn:T,endRow:A},$),{row:Z,col:q}=g(G.startRow,G.startColumn);w.setValue(Z,q,k),C.add(k)})});const V=Array.from(C).map(S=>({id:S,ranges:o.queryObjectMatrix(w,_=>_===S)}));u.addRangeRules(V);const y=u.diff(this._sheetDataValidationModel.getRules(d,l)),{redoMutations:M,undoMutations:D}=E.getDataValidationDiffMutations(d,l,y,this._injector,"patched",i===x.APPLY_TYPE.ONLY_FORMAT);return{undos:D,redos:M}},a={id:E.DATA_VALIDATION_PLUGIN_NAME,onBeforeFillData:n=>{const{source:i,unitId:r,subUnitId:s}=n;for(const d of i.rows)for(const l of i.cols){const u=this._sheetDataValidationModel.getRuleByLocation(r,s,d,l);if(u&&u.type===o.DataValidationType.CHECKBOX){this._autoFillService.setDisableApplyType(x.APPLY_TYPE.SERIES,!0);return}}},onFillData:(n,i,r)=>r===x.APPLY_TYPE.COPY||r===x.APPLY_TYPE.ONLY_FORMAT||r===x.APPLY_TYPE.SERIES?t(n,r):e(),onAfterFillData:()=>{}};this.disposeWithMe(this._autoFillService.addHook(a))}};Ee=Wn([dt(0,x.IAutoFillService),dt(1,o.Inject(E.SheetDataValidationModel)),dt(2,o.Inject(o.Injector))],Ee);var $n=Object.defineProperty,Hn=Object.getOwnPropertyDescriptor,Yn=(e,t,a,n)=>{for(var i=n>1?void 0:n?Hn(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&&$n(t,a,i),i},ct=(e,t)=>(a,n)=>t(a,n,e);let Re=class extends o.Disposable{constructor(t,a,n){super();L(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,i)=>{const{copyType:r=x.COPY_TYPE.COPY,pasteType:s}=i,{range:d}=t||{},{range:l,unitId:u,subUnitId:p}=a;return this._generateMutations(l,{copyType:r,pasteType:s,copyRange:d,unitId:u,subUnitId:p})}})}_collect(t,a,n){const i=new o.ObjectMatrix;this._copyInfo={unitId:t,subUnitId:a,matrix:i};const r=this._injector.invoke(l=>x.rangeToDiscreteRange(n,l,t,a));if(!r)return;const{rows:s,cols:d}=r;s.forEach((l,u)=>{d.forEach((p,m)=>{const c=this._sheetDataValidationModel.getRuleIdByLocation(t,a,l,p);i.setValue(u,m,c!=null?c:"")})})}_generateMutations(t,a){if(!this._copyInfo)return{redos:[],undos:[]};if(a.copyType===x.COPY_TYPE.CUT)return this._copyInfo=null,{redos:[],undos:[]};if(!this._copyInfo||!this._copyInfo.matrix.getSizeOf()||!a.copyRange)return{redos:[],undos:[]};if([x.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_COL_WIDTH,x.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_VALUE,x.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMAT,x.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMULA].includes(a.pasteType))return{redos:[],undos:[]};const{unitId:n,subUnitId:i}=this._copyInfo;if(a.unitId!==n||i!==a.subUnitId){const r=this._sheetDataValidationModel.getRuleObjectMatrix(a.unitId,a.subUnitId).clone(),s=new o.ObjectMatrix,d=new Set,{ranges:[l,u],mapFunc:p}=x.virtualizeDiscreteRanges([a.copyRange,t]),m=x.getRepeatRange(l,u,!0),c=new Map;m.forEach(({startRange:w})=>{var C;(C=this._copyInfo)==null||C.matrix.forValue((V,y,M)=>{const D=o.Rectangle.getPositionRange({startRow:V,endRow:V,startColumn:y,endColumn:y},w),S=`${i}-${M}`,_=this._sheetDataValidationModel.getRuleById(n,i,M);!this._sheetDataValidationModel.getRuleById(a.unitId,a.subUnitId,S)&&_&&c.set(S,{..._,uid:S});const{row:O,col:j}=p(D.startRow,D.startColumn);d.add(S),s.setValue(O,j,S)})});const g=Array.from(d).map(w=>({id:w,ranges:o.queryObjectMatrix(s,C=>C===w)}));r.addRangeRules(g);const{redoMutations:v,undoMutations:I}=E.getDataValidationDiffMutations(a.unitId,a.subUnitId,r.diffWithAddition(this._sheetDataValidationModel.getRules(a.unitId,a.subUnitId),c.values()),this._injector,"patched",!1);return{redos:v,undos:I}}else{const r=this._sheetDataValidationModel.getRuleObjectMatrix(n,i).clone(),s=new o.ObjectMatrix,d=new Set,{ranges:[l,u],mapFunc:p}=x.virtualizeDiscreteRanges([a.copyRange,t]);x.getRepeatRange(l,u,!0).forEach(({startRange:I})=>{var w;(w=this._copyInfo)==null||w.matrix.forValue((C,V,y)=>{const M=o.Rectangle.getPositionRange({startRow:C,endRow:C,startColumn:V,endColumn:V},I),{row:D,col:S}=p(M.startRow,M.startColumn);s.setValue(D,S,y),d.add(y)})});const c=Array.from(d).map(I=>({id:I,ranges:o.queryObjectMatrix(s,w=>w===I)}));r.addRangeRules(c);const{redoMutations:g,undoMutations:v}=E.getDataValidationDiffMutations(n,i,r.diff(this._sheetDataValidationModel.getRules(n,i)),this._injector,"patched",!1);return{redos:g,undos:v}}}};Re=Yn([ct(0,x.ISheetClipboardService),ct(1,o.Inject(E.SheetDataValidationModel)),ct(2,o.Inject(o.Injector))],Re);var Xn=Object.defineProperty,zn=Object.getOwnPropertyDescriptor,Kn=(e,t,a,n)=>{for(var i=n>1?void 0:n?zn(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&&Xn(t,a,i),i},ut=(e,t)=>(a,n)=>t(a,n,e);let Me=class extends o.Disposable{constructor(e,t,a){super(),this._localeService=e,this._commandService=t,this._sheetPermissionInterceptorBaseController=a,this._commandExecutedListener()}_commandExecutedListener(){this.disposeWithMe(this._commandService.beforeCommandExecuted(e=>{e.id===E.AddSheetDataValidationCommand.id&&(this._sheetPermissionInterceptorBaseController.permissionCheckWithRanges({workbookTypes:[X.WorkbookEditablePermission],rangeTypes:[X.RangeProtectionPermissionEditPoint],worksheetTypes:[X.WorksheetEditPermission,X.WorksheetSetCellStylePermission]})||this._sheetPermissionInterceptorBaseController.haveNotPermissionHandle(this._localeService.t("permission.dialog.setStyleErr"))),e.id===E.UpdateSheetDataValidationRangeCommand.id&&(this._sheetPermissionInterceptorBaseController.permissionCheckWithRanges({workbookTypes:[X.WorkbookEditablePermission],rangeTypes:[X.RangeProtectionPermissionEditPoint],worksheetTypes:[X.WorksheetEditPermission,X.WorksheetSetCellStylePermission]},e.params.ranges)||this._sheetPermissionInterceptorBaseController.haveNotPermissionHandle(this._localeService.t("permission.dialog.setStyleErr")))}))}};Me=Kn([ut(0,o.Inject(o.LocaleService)),ut(1,o.ICommandService),ut(2,o.Inject(x.SheetPermissionInterceptorBaseController))],Me);const Nt="data-validation-single",Ut="sheet.menu.data-validation";function qn(e){return{id:Ut,type:z.MenuItemType.SUBITEMS,icon:Nt,tooltip:"dataValidation.title",hidden$:z.getMenuHiddenObservable(e,o.UniverInstanceType.UNIVER_SHEET),disabled$:x.getCurrentRangeDisable$(e,{workbookTypes:[X.WorkbookEditablePermission],worksheetTypes:[X.WorksheetSetCellStylePermission,X.WorksheetEditPermission],rangeTypes:[X.RangeProtectionPermissionEditPoint]})}}function Gn(e){return{id:_e.id,title:"dataValidation.panel.title",type:z.MenuItemType.BUTTON}}function Zn(e){return{id:$e.id,title:"dataValidation.panel.add",type:z.MenuItemType.BUTTON}}const Jn={[z.RibbonStartGroup.FORMULAS_INSERT]:{[Ut]:{order:9,menuItemFactory:qn,[_e.id]:{order:0,menuItemFactory:Gn},[$e.id]:{order:1,menuItemFactory:Zn}}}};var Qn=Object.defineProperty,ea=Object.getOwnPropertyDescriptor,Bt=(e,t,a,n)=>{for(var i=n>1?void 0:n?ea(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&&Qn(t,a,i),i},Q=(e,t)=>(a,n)=>t(a,n,e);const kt={tr:{size:6,color:"#fe4b4b"}};let be=class extends o.RxDisposable{constructor(e,t,a,n,i,r,s,d,l,u,p){super(),this._commandService=e,this._menuManagerService=t,this._renderManagerService=a,this._univerInstanceService=n,this._autoHeightController=i,this._dropdownManagerService=r,this._sheetDataValidationModel=s,this._dataValidatorRegistryService=d,this._sheetInterceptorService=l,this._dataValidationCacheService=u,this._editorBridgeService=p,this._initMenu(),this._initDropdown(),this._initViewModelIntercept(),this._initAutoHeight()}_initMenu(){this._menuManagerService.mergeMenu(Jn)}_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,d=this._univerInstanceService.getUniverSheetInstance(n);if(!d)return;const l=this._sheetDataValidationModel.getRuleByLocation(n,i,r,s);if(!l)return;const u=this._dataValidatorRegistryService.getValidatorItem(l.type);if(!(u!=null&&u.dropdown))return;const p=d.getActiveSheet();if(!p)return;const m=this._dropdownManagerService.activeDropdown,c=m==null?void 0:m.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:d,worksheet:p},componentKey:u.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 C,V,y,M,D;const{row:n,col:i,unitId:r,subUnitId:s,workbook:d,worksheet:l}=t,u=this._sheetDataValidationModel.getRuleIdByLocation(r,s,n,i);if(!u)return a(e);const p=this._sheetDataValidationModel.getRuleById(r,s,u);if(!p)return a(e);const m=(C=this._dataValidationCacheService.getValue(r,s,n,i))!=null?C:o.DataValidationStatus.VALID,c=this._dataValidatorRegistryService.getValidatorItem(p.type),g=t.rawData;let v;const I={get value(){var S;return v!==void 0||(v=(S=E.getCellValueOrigin(g))!=null?S:null),v}},w={get value(){var S;return`${(S=I.value)!=null?S:""}`}};return a({...e,markers:{...e==null?void 0:e.markers,...m===o.DataValidationStatus.INVALID?kt:null},customRender:[...(V=e==null?void 0:e.customRender)!=null?V:[],...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)||((M=c==null?void 0:c.skipDefaultFontRender)==null?void 0:M.call(c,p,I.value,t))},interceptorStyle:{...e==null?void 0:e.interceptorStyle,...c==null?void 0:c.getExtraStyle(p,w.value,{get style(){const S=d.getStyles();return(typeof(e==null?void 0:e.s)=="string"?S.get(e==null?void 0:e.s):e==null?void 0:e.s)||{}}},n,i)},interceptorAutoHeight:()=>{var j,$,A,T,F,N;const S=($=(j=this._renderManagerService.getRenderById(r))==null?void 0:j.with(x.SheetSkeletonManagerService).getWorksheetSkeleton(s))==null?void 0:$.skeleton;if(!S)return;const _=S.worksheet.getMergedCell(n,i),O={data:e,style:S.getsStyles().getStyleByCell(e),primaryWithCoord:S.getCellWithCoordByIndex((A=_==null?void 0:_.startRow)!=null?A:n,(T=_==null?void 0:_.startColumn)!=null?T:i),unitId:r,subUnitId:s,row:n,col:i,workbook:d,worksheet:l};return(N=(F=c==null?void 0:c.canvasRender)==null?void 0:F.calcCellAutoHeight)==null?void 0:N.call(F,O)},interceptorAutoWidth:()=>{var j,$,A,T,F,N;const S=($=(j=this._renderManagerService.getRenderById(r))==null?void 0:j.with(x.SheetSkeletonManagerService).getWorksheetSkeleton(s))==null?void 0:$.skeleton;if(!S)return;const _=S.worksheet.getMergedCell(n,i),O={data:e,style:S.getsStyles().getStyleByCell(e),primaryWithCoord:S.getCellWithCoordByIndex((A=_==null?void 0:_.startRow)!=null?A:n,(T=_==null?void 0:_.startColumn)!=null?T:i),unitId:r,subUnitId:s,row:n,col:i,workbook:d,worksheet:l};return(N=(F=c==null?void 0:c.canvasRender)==null?void 0:F.calcCellAutoWidth)==null?void 0:N.call(F,O)},coverable:((D=e==null?void 0:e.coverable)!=null?D:!0)&&!(p.type===o.DataValidationType.LIST||p.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)}})}};be=Bt([Q(0,o.ICommandService),Q(1,z.IMenuManagerService),Q(2,B.IRenderManagerService),Q(3,o.IUniverInstanceService),Q(4,o.Inject(x.AutoHeightController)),Q(5,o.Inject(fe)),Q(6,o.Inject(E.SheetDataValidationModel)),Q(7,o.Inject(J.DataValidatorRegistryService)),Q(8,o.Inject(X.SheetInterceptorService)),Q(9,o.Inject(E.DataValidationCacheService)),Q(10,o.Optional(x.IEditorBridgeService))],be);let Wt=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,C,V,y,M;const{row:n,col:i,unitId:r,subUnitId:s,workbook:d,worksheet:l}=t,u=this._sheetDataValidationModel.getRuleIdByLocation(r,s,n,i);if(!u)return a(e);const p=this._sheetDataValidationModel.getRuleById(r,s,u);if(!p)return a(e);const m=(w=this._dataValidationCacheService.getValue(r,s,n,i))!=null?w:o.DataValidationStatus.VALID,c=this._dataValidatorRegistryService.getValidatorItem(p.type),g=l.getCellRaw(n,i),v=E.getCellValueOrigin(g),I=`${v!=null?v:""}`;return a({...e,markers:{...e==null?void 0:e.markers,...m===o.DataValidationStatus.INVALID?kt:null},customRender:[...(C=e==null?void 0:e.customRender)!=null?C:[],...c!=null&&c.canvasRender?[c.canvasRender]:[]],fontRenderExtension:{...e==null?void 0:e.fontRenderExtension,isSkip:((V=e==null?void 0:e.fontRenderExtension)==null?void 0:V.isSkip)||((y=c==null?void 0:c.skipDefaultFontRender)==null?void 0:y.call(c,p,v,t))},interceptorStyle:{...e==null?void 0:e.interceptorStyle,...c==null?void 0:c.getExtraStyle(p,I,{get style(){const D=d.getStyles();return(typeof(e==null?void 0:e.s)=="string"?D.get(e==null?void 0:e.s):e==null?void 0:e.s)||{}}},n,i)},interceptorAutoHeight:()=>{var O,j,$,A,T,F;const D=(j=(O=this._renderManagerService.getRenderById(r))==null?void 0:O.with(x.SheetSkeletonManagerService).getWorksheetSkeleton(s))==null?void 0:j.skeleton;if(!D)return;const S=D.worksheet.getMergedCell(n,i),_={data:e,style:D.getsStyles().getStyleByCell(e),primaryWithCoord:D.getCellWithCoordByIndex(($=S==null?void 0:S.startRow)!=null?$:n,(A=S==null?void 0:S.startColumn)!=null?A:i),unitId:r,subUnitId:s,row:n,col:i,workbook:d,worksheet:l};return(F=(T=c==null?void 0:c.canvasRender)==null?void 0:T.calcCellAutoHeight)==null?void 0:F.call(T,_)},coverable:((M=e==null?void 0:e.coverable)!=null?M:!0)&&!(p.type===o.DataValidationType.LIST||p.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)}})}};Wt=Bt([Q(0,o.ICommandService),Q(1,B.IRenderManagerService),Q(2,o.Inject(x.AutoHeightController)),Q(3,o.Inject(J.DataValidatorRegistryService)),Q(4,o.Inject(X.SheetInterceptorService)),Q(5,o.Inject(E.SheetDataValidationModel)),Q(6,o.Inject(E.DataValidationCacheService))],Wt);var ta=Object.defineProperty,na=Object.getOwnPropertyDescriptor,aa=(e,t,a,n)=>{for(var i=n>1?void 0:n?na(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&&ta(t,a,i),i},$t=(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=aa([$t(1,o.Inject(E.SheetDataValidationModel)),$t(2,o.Inject(x.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"},ia=e=>{const{isTwoFormula:t=!1,value:a,onChange:n,showError:i,validResult:r}=e,s=o.useDependency(o.LocaleService),d=i?r==null?void 0:r.formula1:"",l=i?r==null?void 0:r.formula2:"";return t?h.jsxs(h.Fragment,{children:[h.jsx(b.FormLayout,{error:d,children:h.jsx(b.Input,{className:ne.dataValidationFormula,placeholder:s.t("dataValidation.panel.formulaPlaceholder"),value:a==null?void 0:a.formula1,onChange:u=>{n==null||n({...a,formula1:u})}})}),h.jsx("div",{className:ne.dataValidationFormulaAnd,children:s.t("dataValidation.panel.formulaAnd")}),h.jsx(b.FormLayout,{error:l,children:h.jsx(b.Input,{className:ne.dataValidationFormula,placeholder:s.t("dataValidation.panel.formulaPlaceholder"),value:a==null?void 0:a.formula2,onChange:u=>{n==null||n({...a,formula2:u})}})})]}):h.jsx(b.FormLayout,{error:d,children:h.jsx(b.Input,{className:ne.dataValidationFormula,placeholder:s.t("dataValidation.panel.formulaPlaceholder"),value:a==null?void 0:a.formula1,onChange:u=>{n==null||n({formula1:u})}})})};function oa(e){const{value:t,onChange:a,showError:n,validResult:i}=e,r=o.useDependency(o.LocaleService),s=n?i==null?void 0:i.formula1:"",d=n?i==null?void 0:i.formula2:"",[l,u]=f.useState(!((t==null?void 0:t.formula1)===void 0&&(t==null?void 0:t.formula2)===void 0));return h.jsxs(h.Fragment,{children:[h.jsx(b.FormLayout,{children:h.jsx(b.Checkbox,{checked:l,onChange:p=>{p?u(!0):(u(!1),a==null||a({...t,formula1:void 0,formula2:void 0}))},children:r.t("dataValidation.checkbox.tips")})}),l?h.jsx(b.FormLayout,{label:r.t("dataValidation.checkbox.checked"),error:s,children:h.jsx(b.Input,{className:ne.dataValidationFormula,placeholder:r.t("dataValidation.panel.valuePlaceholder"),value:t==null?void 0:t.formula1,onChange:p=>{a==null||a({...t,formula1:p||void 0})}})}):null,l?h.jsx(b.FormLayout,{label:r.t("dataValidation.checkbox.unchecked"),error:d,children:h.jsx(b.Input,{className:ne.dataValidationFormula,placeholder:r.t("dataValidation.panel.valuePlaceholder"),value:t==null?void 0:t.formula2,onChange:p=>{a==null||a({...t,formula2:p||void 0})}})}):null]})}function ra(e){var m;const{unitId:t,subUnitId:a,value:n,onChange:i,showError:r,validResult:s}=e,d=r?s==null?void 0:s.formula1:void 0,l=f.useRef({}),[u,p]=f.useState(!1);return z.useSidebarClick(c=>{var v;const g=(v=l.current)==null?void 0:v.handleOutClick;g&&g(c,()=>p(!1))}),h.jsx(nt.FormulaEditor,{initValue:(m=n==null?void 0:n.formula1)!=null?m:"",unitId:t,subUnitId:a,isFocus:u,onChange:c=>{const g=(c!=null?c:"").trim();g!==(n==null?void 0:n.formula1)&&(i==null||i({...n,formula1:g}))},errorText:d,onFocus:()=>p(!0),actions:l.current,isSupportAcrossSheet:!0})}function Ht(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=Ht(e[t]))&&(n&&(n+=" "),n+=a)}else for(a in e)e[a]&&(n&&(n+=" "),n+=a);return n}function sa(){for(var e,t,a=0,n="",i=arguments.length;a<i;a++)(e=arguments[a])&&(t=Ht(e))&&(n&&(n+=" "),n+=t);return n}const la=["#FFFFFF","#FEE7E7","#FEF0E6","#EFFBD0","#E4F4FE","#E8ECFD","#F1EAFA","#FDE8F3","#E5E5E5","#FDCECE","#FDC49B","#DEF6A2","#9FDAFF","#D0D9FB","#E3D5F6","#FBD0E8","#656565","#FE4B4B","#FF8C51","#8BBB11","#0B9EFB","#3A60F7","#9E6DE3","#F248A6"],da=e=>{const{value:t,onChange:a,disabled:n}=e,[i,r]=f.useState(!1);return h.jsx(b.Select,{disabled:n,open:i,onDropdownVisibleChange:r,dropdownStyle:{width:112},style:{width:96,cursor:"pointer"},className:ne.dataValidationFormulaColorSelect,value:t,onChange:a,labelRender:s=>h.jsx("div",{className:ne.dataValidationFormulaColorItem,style:{background:s.value,marginTop:5}}),dropdownRender:()=>h.jsx("div",{className:ne.dataValidationFormulaColorSelectPanel,children:la.map(s=>h.jsx("div",{onClick:()=>{a(s),r(!1)},className:ne.dataValidationFormulaColorItem,style:{background:s}},s))})})},Yt=e=>{const{item:t,commonProps:a,style:n}=e,{onItemChange:i,onItemDelete:r}=a;return h.jsxs("div",{className:ne.dataValidationFormulaListItem,style:n,children:[t.isRef?null:h.jsx("div",{className:sa(ne.dataValidationFormulaListItemDrag,"draggableHandle"),children:h.jsx(Pt,{})}),h.jsx(da,{value:t.color,onChange:s=>{i(t.id,t.label,s)}}),h.jsx(b.Input,{disabled:t.isRef,value:t.label,onChange:s=>{i(t.id,s,t.color)}}),t.isRef?null:h.jsx("div",{className:ne.dataValidationFormulaListItemIcon,children:h.jsx(it,{onClick:()=>r(t.id)})})]})};function ca(e){const{value:t,onChange:a=()=>{},unitId:n,subUnitId:i,validResult:r,showError:s,ruleId:d}=e,{formula1:l="",formula2:u=""}=t||{},p=f.useRef(null),[m,c]=f.useState(()=>o.isFormulaString(l)?"1":"0"),[g,v]=f.useState(m==="1"?l:"="),[I,w]=f.useState(m==="1"?l:"="),C=o.useDependency(o.LocaleService),V=o.useDependency(J.DataValidatorRegistryService),y=o.useDependency(J.DataValidationModel),M=o.useDependency(E.DataValidationFormulaController),[D,S]=f.useState(()=>u.split(",")),_=V.getValidatorItem(o.DataValidationType.LIST),[O,j]=f.useState([]),[$,A]=f.useState(""),T=s?r==null?void 0:r.formula1:"",F=f.useMemo(()=>y.ruleChange$.pipe(re.debounceTime(16)),[]),N=z.useObservable(F),U=z.useEvent(a);f.useEffect(()=>{(async()=>{await new Promise(H=>{setTimeout(()=>H(!0),100)});const R=y.getRuleById(n,i,d),W=R==null?void 0:R.formula1;if(o.isFormulaString(W)&&_&&R){const H=await _.getListAsync(R,n,i);j(H)}})()},[y,N,_,d,i,n]),f.useEffect(()=>{o.isFormulaString(l)&&l!==I&&(v(l),w(I))},[I,l]);const[k,G]=f.useState(()=>{const R=m!=="1"?E.deserializeListOptions(l):[],W=u.split(",");return R.map((H,K)=>({label:H,color:W[K]||Ie,isRef:!1,id:o.Tools.generateRandomId(4)}))}),Z=(R,W,H)=>{const K=k.find(ge=>ge.id===R);K&&(K.label=W,K.color=H,G([...k]))},q=R=>{const W=k.findIndex(H=>H.id===R);W!==-1&&(k.splice(W,1),G([...k]))},ee=u.split(","),te=f.useMemo(()=>O.map((R,W)=>({label:R,color:ee[W]||Ie,id:`${W}`,isRef:!0})),[ee,O]),ae=(R,W,H)=>{const K=[...D];K[+R]=H,S(K),U({formula1:l,formula2:K.join(",")})},ie=()=>{G([...k,{label:"",color:Ie,isRef:!1,id:o.Tools.generateRandomId(4)}])};f.useEffect(()=>{if(m==="1")return;const R=new Set,W=[];k.map(H=>({labelList:H.label.split(","),item:H})).forEach(({item:H,labelList:K})=>{K.forEach(ge=>{R.has(ge)||(R.add(ge),W.push({label:ge,color:H.color}))})}),U({formula1:E.serializeListOptions(W.map(H=>H.label)),formula2:W.map(H=>H.color===Ie?"":H.color).join(",")})},[k,U,m,I,D]);const le=f.useMemo(()=>async R=>{if(!o.isFormulaString(R)){U==null||U({formula1:"",formula2:u});return}M.getFormulaRefCheck(R)?(U==null||U({formula1:o.isFormulaString(R)?R:"",formula2:u}),A("")):(U==null||U({formula1:"",formula2:u}),v("="),A(C.t("dataValidation.validFail.formulaError")))},[u,U]),oe=f.useRef({}),[de,P]=f.useState(!1);return z.useSidebarClick(R=>{var H;const W=(H=oe.current)==null?void 0:H.handleOutClick;W&&W(R,()=>P(!1))}),h.jsxs(h.Fragment,{children:[h.jsx(b.FormLayout,{label:C.t("dataValidation.list.options"),children:h.jsxs(b.RadioGroup,{value:m,onChange:R=>{c(R),v(I),R==="1"&&U({formula1:I==="="?"":I,formula2:D.join(",")})},children:[h.jsx(b.Radio,{value:"0",children:C.t("dataValidation.list.customOptions")}),h.jsx(b.Radio,{value:"1",children:C.t("dataValidation.list.refOptions")})]})}),m==="1"?h.jsxs(h.Fragment,{children:[h.jsx(nt.FormulaEditor,{initValue:g,unitId:n,subUnitId:i,isFocus:de,onChange:(R="")=>{const W=(R!=null?R:"").trim();w(W),le(W)},errorText:T||$||void 0,onFocus:()=>P(!0),actions:oe.current,isSupportAcrossSheet:!0}),h.jsx("div",{ref:p,style:{marginTop:"12px"},children:te.map(R=>h.jsx(Yt,{item:R,commonProps:{onItemChange:ae},style:{marginBottom:12}},R.id))})]}):h.jsx(b.FormLayout,{error:T,children:h.jsxs("div",{ref:p,style:{marginTop:"-12px"},children:[h.jsx(b.DraggableList,{list:k,onListChange:G,rowHeight:32,margin:[0,12],draggableHandle:".draggableHandle",itemRender:R=>h.jsx(Yt,{item:R,commonProps:{onItemChange:Z,onItemDelete:q}},R.id),idKey:"id"}),h.jsxs("a",{className:ne.dataValidationFormulaListAdd,onClick:ie,children:[h.jsx(Ot,{}),C.t("dataValidation.list.add")]})]})})]})}const Xt="data-validation.custom-formula-input",Ye="data-validation.formula-input",pt="data-validation.list-formula-input",zt="data-validation.checkbox-formula-input",ua=[[Xt,ra],[Ye,ia],[pt,ca],[zt,oa]],pa="LIST_RENDER_MODE_OPTION_INPUT";function Xe(e){var i;const{value:t,onChange:a}=e,n=o.useDependency(o.LocaleService);return h.jsx(b.FormLayout,{label:n.t("dataValidation.renderMode.label"),children:h.jsxs(b.RadioGroup,{value:`${(i=t.renderMode)!=null?i:o.DataValidationRenderMode.CUSTOM}`,onChange:r=>a({...t,renderMode:+r}),children:[h.jsx(b.Radio,{value:`${o.DataValidationRenderMode.CUSTOM}`,children:n.t("dataValidation.renderMode.chip")}),h.jsx(b.Radio,{value:`${o.DataValidationRenderMode.ARROW}`,children:n.t("dataValidation.renderMode.arrow")}),h.jsx(b.Radio,{value:`${o.DataValidationRenderMode.TEXT}`,children:n.t("dataValidation.renderMode.text")})]})})}Xe.componentKey=pa;const ha="DATE_SHOW_TIME_OPTION";function ze(e){var i;const{value:t,onChange:a}=e,n=o.useDependency(o.LocaleService);return h.jsx(b.FormLayout,{children:h.jsx(b.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")})})}ze.componentKey=ha;var ma=Object.defineProperty,va=Object.getOwnPropertyDescriptor,fa=(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&&ma(t,a,i),i},Fe=(e,t)=>(a,n)=>t(a,n,e);const Ke=6;let ht=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 u,p,m;const{vt:a,ht:n}=t||{},i=e.endX-e.startX-Ke*2,r=e.endY-e.startY,s=((u=t==null?void 0:t.fs)!=null?u:10)*1.6;let d=0,l=0;switch(a){case o.VerticalAlign.TOP:l=0;break;case o.VerticalAlign.BOTTOM:l=0+(r-s);break;default:l=0+(r-s)/2;break}switch(n){case o.HorizontalAlign.LEFT:d=Ke;break;case o.HorizontalAlign.RIGHT:d=Ke+(i-s);break;default:d=Ke+(i-s)/2;break}return{left:e.startX+d,top:e.startY+l,width:((p=t==null?void 0:t.fs)!=null?p:10)*1.6,height:((m=t==null?void 0:t.fs)!=null?m: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 u,p,m,c,g,v,I,w,C;const{formula1:n=E.CHECKBOX_FORMULA_1,formula2:i=E.CHECKBOX_FORMULA_2}=e,r=await this._formulaService.getRuleFormulaResult(t,a,e.uid),s=E.getFormulaResult((m=(p=(u=r==null?void 0:r[0])==null?void 0:u.result)==null?void 0:p[0])==null?void 0:m[0]),d=E.getFormulaResult((v=(g=(c=r==null?void 0:r[1])==null?void 0:c.result)==null?void 0:g[0])==null?void 0:v[0]),l=E.isLegalFormulaResult(String(s))&&E.isLegalFormulaResult(String(d));return{formula1:o.isFormulaString(n)?E.getFormulaResult((C=(w=(I=r==null?void 0:r[0])==null?void 0:I.result)==null?void 0:w[0])==null?void 0:C[0]):n,formula2:o.isFormulaString(i)?d:i,isFormulaValid:l}}drawWith(e,t){var T,F,N,U;const{style:a,primaryWithCoord:n,unitId:i,subUnitId:r,worksheet:s,row:d,col:l}=t,u=n.isMergedMainCell?n.mergeInfo:n,p=E.getCellValueOrigin(s.getCellRaw(d,l)),m=this._dataValidationModel.getRuleByLocation(i,r,d,l);if(!m)return;const c=this._dataValidationModel.getValidator(m.type);if(!c)return;const g=this._themeService.getCurrentTheme();if(!((T=c.skipDefaultFontRender)!=null&&T.call(c,m,p,{unitId:i,subUnitId:r,row:d,column:l})))return;const v=c.parseFormulaSync(m,i,r),{formula1:I}=v,w=this._calc(u,a),{a:C,d:V}=e.getTransform(),y=B.fixLineWidthByScale(w.left,C),M=B.fixLineWidthByScale(w.top,V),D=B.Transform.create().composeMatrix({left:y,top:M,scaleX:1,scaleY:1,angle:0,skewX:0,skewY:0,flipX:!1,flipY:!1}),S=u.endX-u.startX,_=u.endY-u.startY;e.save(),e.beginPath(),e.rect(u.startX,u.startY,S,_),e.clip();const O=D.getMatrix();e.transform(O[0],O[1],O[2],O[3],O[4],O[5]);const j=((F=a==null?void 0:a.fs)!=null?F:10)*1.6,$=String(p)===String(I),A=g.hyacinth500;B.CheckboxShape.drawWith(e,{checked:$,width:j,height:j,fill:(U=(N=a==null?void 0:a.cl)==null?void 0:N.rgb)!=null?U:A}),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,d=n.left+n.width,{x:l,y:u}=e;return l<=d&&l>=s&&u<=r&&u>=i}async onPointerDown(e,t){var v;if(t.button===2)return;const{primaryWithCoord:a,unitId:n,subUnitId:i,worksheet:r,row:s,col:d}=e,l=E.getCellValueOrigin(r.getCellRaw(s,d)),u=this._dataValidationModel.getRuleByLocation(n,i,s,d);if(!u)return;const p=this._dataValidationModel.getValidator(u.type);if(!p||!((v=p.skipDefaultFontRender)!=null&&v.call(p,u,l,{unitId:n,subUnitId:i,row:s,column:d})))return;const{formula1:m,formula2:c}=await this._parseFormula(u,n,i),g={range:{startColumn:a.actualColumn,endColumn:a.actualColumn,startRow:a.actualRow,endRow:a.actualRow},value:{v:String(l)===E.transformCheckboxValue(String(m))?c:m,p:null}};this._commandService.executeCommand(X.SetRangeValuesCommand.id,g)}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)}};ht=fa([Fe(0,o.ICommandService),Fe(1,o.Inject(E.DataValidationFormulaService)),Fe(2,o.Inject(o.ThemeService)),Fe(3,o.Inject(B.IRenderManagerService)),Fe(4,o.Inject(E.SheetDataValidationModel))],ht);var ga=Object.defineProperty,Sa=Object.getOwnPropertyDescriptor,_a=(e,t,a,n)=>{for(var i=n>1?void 0:n?Sa(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&&ga(t,a,i),i},Ia=(e,t)=>(a,n)=>t(a,n,e);let pe=class{constructor(e){L(this,"canvasRender",null);L(this,"dropdown");L(this,"optionsInput");L(this,"formulaInput",pt);this.injector=e}};pe=_a([Ia(0,o.Inject(o.Injector))],pe);class Ca extends pe{constructor(){super(...arguments);L(this,"id",o.DataValidationType.CHECKBOX);L(this,"canvasRender",this.injector.createInstance(ht));L(this,"formulaInput",zt)}}class Da extends pe{constructor(){super(...arguments);L(this,"id",o.DataValidationType.CUSTOM);L(this,"formulaInput",Xt)}}const ya="data-validation.formula-input";class wa extends pe{constructor(){super(...arguments);L(this,"id",o.DataValidationType.DATE);L(this,"formulaInput",ya);L(this,"optionsInput",ze.componentKey);L(this,"dropdown",lt)}}class Va extends pe{constructor(){super(...arguments);L(this,"id",o.DataValidationType.DECIMAL);L(this,"formulaInput",Ye)}}const Kt=4,Ea=0,mt=4,qt=4,vt=6,qe=6,De=14;function Ra(e,t){const a=B.FontCache.getTextSize(e,t),n=a.width+Kt*2,{ba:i,bd:r}=a,s=i+r;return{width:n,height:s+Ea*2,ba:i}}function ft(e,t,a,n){const i=De+vt*2,r=a-i,s=n-qe*2,d=e.map(c=>({layout:Ra(c,t),text:c}));let l;const u=[];d.forEach(c=>{const{layout:g}=c,{width:v,height:I}=g;!l||l.width+v+mt>r?(l={width:v,height:I,items:[{...c,left:0}]},u.push(l)):(l.items.push({...c,left:l.width+mt}),l.width=l.width+v+mt)});let p=0,m=0;return u.forEach((c,g)=>{m=Math.max(m,c.width),g===u.length-1?p+=c.height:p+=c.height+qt}),{lines:u,totalHeight:p,contentWidth:r,contentHeight:s,cellAutoHeight:p+qe*2,calcAutoWidth:m+i}}const Ma=8;class ba extends B.Shape{static drawWith(t,a){const{fontString:n,info:i,fill:r,color:s}=a,{layout:d,text:l}=i;t.save(),B.Rect.drawWith(t,{width:d.width,height:d.height,radius:Ma,fill:r||Ie}),t.translateWithPrecision(Kt,d.ba),t.font=n,t.fillStyle=s,t.fillText(l,0,0),t.restore()}}var Oa=Object.defineProperty,La=Object.getOwnPropertyDescriptor,Ta=(e,t,a,n)=>{for(var i=n>1?void 0:n?La(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&&Oa(t,a,i),i},gt=(e,t)=>(a,n)=>t(a,n,e);const Pa=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 St=class{constructor(e,t,a){L(this,"zIndex");L(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(Pa),e.restore()}drawWith(e,t,a,n){var Z,q;const{primaryWithCoord:i,row:r,col:s,style:d,data:l,subUnitId:u}=t,p=i.isMergedMainCell?i.mergeInfo:i,m=l==null?void 0:l.fontRenderExtension,{leftOffset:c=0,rightOffset:g=0,topOffset:v=0,downOffset:I=0}=m||{},w=this._ensureMap(u),C=this._generateKey(r,s),V=this._dataValidationModel.getRuleByLocation(t.unitId,t.subUnitId,r,s);if(!V)return;const y=this._dataValidationModel.getValidator(V.type);if(!y)return;const M={startX:p.startX+c,endX:p.endX-g,startY:p.startY+v,endY:p.endY-I},D=M.endX-M.startX,S=M.endY-M.startY,{cl:_}=d||{},O=(Z=typeof _=="object"?_==null?void 0:_.rgb:_)!=null?Z:"#000",j=B.getFontStyleString(d!=null?d:void 0),{vt:$,ht:A}=d||{},T=$!=null?$:o.VerticalAlign.MIDDLE,F=(q=E.getCellValueOrigin(l))!=null?q:"",N=y.parseCellValue(F),U=y.getListWithColorMap(V),k=ft(N,j,D,S);this._drawDownIcon(e,M,D,S,T),e.save(),e.translateWithPrecision(M.startX,M.startY),e.beginPath(),e.rect(0,0,D-De,S),e.clip(),e.translateWithPrecision(vt,qe);let G=0;switch(T){case o.VerticalAlign.MIDDLE:G=(k.contentHeight-k.totalHeight)/2;break;case o.VerticalAlign.BOTTOM:G=k.contentHeight-k.totalHeight;break}e.translateWithPrecision(0,G),k.lines.forEach((ee,te)=>{e.save();const{width:ae,height:ie,items:le}=ee;let oe=0;switch(A){case o.HorizontalAlign.RIGHT:oe=k.contentWidth-ae;break;case o.HorizontalAlign.CENTER:oe=(k.contentWidth-ae)/2;break}e.translate(oe,te*(ie+qt)),le.forEach(de=>{e.save(),e.translateWithPrecision(de.left,0),ba.drawWith(e,{...j,info:de,color:O,fill:U[de.text]}),e.restore()}),e.restore()}),e.restore(),w.set(C,{left:M.startX,top:M.startY,width:k.contentWidth+vt+De,height:k.contentHeight+qe*2})}calcCellAutoHeight(e){var D;const{primaryWithCoord:t,style:a,data:n,row:i,col:r}=e,s=n==null?void 0:n.fontRenderExtension,{leftOffset:d=0,rightOffset:l=0,topOffset:u=0,downOffset:p=0}=s||{},m=t.isMergedMainCell?t.mergeInfo:t,c={startX:m.startX+d,endX:m.endX-l,startY:m.startY+u,endY:m.endY-p},g=this._dataValidationModel.getRuleByLocation(e.unitId,e.subUnitId,i,r);if(!g)return;const v=this._dataValidationModel.getValidator(g.type);if(!v)return;const I=c.endX-c.startX,w=c.endY-c.startY,C=(D=E.getCellValueOrigin(n))!=null?D:"",V=v.parseCellValue(C),y=B.getFontStyleString(a!=null?a:void 0);return ft(V,y,I,w).cellAutoHeight}calcCellAutoWidth(e){var D;const{primaryWithCoord:t,style:a,data:n,row:i,col:r}=e,s=n==null?void 0:n.fontRenderExtension,{leftOffset:d=0,rightOffset:l=0,topOffset:u=0,downOffset:p=0}=s||{},m=t.isMergedMainCell?t.mergeInfo:t,c={startX:m.startX+d,endX:m.endX-l,startY:m.startY+u,endY:m.endY-p},g=this._dataValidationModel.getRuleByLocation(e.unitId,e.subUnitId,i,r);if(!g)return;const v=this._dataValidationModel.getValidator(g.type);if(!v)return;const I=c.endX-c.startX,w=c.endY-c.startY,C=(D=E.getCellValueOrigin(n))!=null?D:"",V=v.parseCellValue(C),y=B.getFontStyleString(a!=null?a:void 0);return ft(V,y,I,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(Ne.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=Ta([gt(0,o.ICommandService),gt(1,o.Inject(B.IRenderManagerService)),gt(2,o.Inject(E.SheetDataValidationModel))],St);class ja extends pe{constructor(){super(...arguments);L(this,"id",o.DataValidationType.LIST_MULTIPLE);L(this,"canvasRender",this.injector.createInstance(St));L(this,"dropdown",We)}}var Aa=Object.defineProperty,Fa=Object.getOwnPropertyDescriptor,xa=(e,t,a,n)=>{for(var i=n>1?void 0:n?Fa(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&&Aa(t,a,i),i},Ge=(e,t)=>(a,n)=>t(a,n,e);const ye=4,Ze=4,ce=14,he=6,Oe=4,_t=8,Na="#565656",Gt=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 Ua(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=Ua(e,a),i=new o.DocumentDataModel(n),r=new B.DocumentViewModel(i);return{documentSkeleton:B.DocumentSkeleton.create(r,t),docModel:i,docViewModel:r}}function Je(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 Jt(e,t,a,n,i,r,s=!0){let d=0;const l=s?Oe:0;switch(i){case o.VerticalAlign.BOTTOM:d=t-n-l;break;case o.VerticalAlign.MIDDLE:d=(t-n)/2;break;default:d=l;break}d=Math.max(Oe,d);let u=0;switch(r){case o.HorizontalAlign.CENTER:u=(e-a)/2;break;case o.HorizontalAlign.RIGHT:u=e-a;break}return u=Math.max(he,u),{paddingLeft:u,paddingTop:d}}let It=class{constructor(e,t,a,n){L(this,"_dropdownInfoMap",new Map);L(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:d=o.DEFAULT_STYLES.pd.t,b:l=o.DEFAULT_STYLES.pd.b}=s,u=a-ce;let p;switch(r){case o.VerticalAlign.MIDDLE:p=(n-Ze)/2;break;case o.VerticalAlign.BOTTOM:p=n-l-i-Oe+(i/2-Ze/2);break;default:p=d+Oe+(i/2-Ze/2);break}e.save(),e.translateWithPrecision(t.startX+u,t.startY+p),e.fillStyle="#565656",e.fill(Gt),e.restore()}drawWith(e,t,a){const{primaryWithCoord:n,row:i,col:r,style:s,data:d,subUnitId:l}=t,u=n.isMergedMainCell?n.mergeInfo:n,p=this._dataValidationModel.getRuleByLocation(t.unitId,t.subUnitId,i,r);if(!p)return;const m=this._dataValidationModel.getValidator(p.type);if(!m)return;const c=d==null?void 0:d.fontRenderExtension,{leftOffset:g=0,rightOffset:v=0,topOffset:I=0,downOffset:w=0}=c||{};if(!p||!m||!m||m.id.indexOf(o.DataValidationType.LIST)!==0||!m.skipDefaultFontRender(p))return;const C={startX:u.startX+g,endX:u.endX-v,startY:u.startY+I,endY:u.endY-w},V=C.endX-C.startX,y=C.endY-C.startY,M=this._ensureMap(l),D=this._generateKey(i,r),S=m.getListWithColor(p),_=E.getCellValueOrigin(d),O=`${_!=null?_:""}`,j=S.find(N=>N.label===O);let{tb:$,vt:A,ht:T,pd:F}=s||{};if($=$!=null?$:o.WrapStrategy.WRAP,A=A!=null?A:o.VerticalAlign.BOTTOM,T=T!=null?T:o.DEFAULT_STYLES.ht,F=F!=null?F:o.DEFAULT_STYLES.pd,p.renderMode===o.DataValidationRenderMode.ARROW){const{l:N=o.DEFAULT_STYLES.pd.l,t:U=o.DEFAULT_STYLES.pd.t,r:k=o.DEFAULT_STYLES.pd.r,b:G=o.DEFAULT_STYLES.pd.b}=F,Z=V-N-k-ce-4,{documentSkeleton:q,documents:ee,docModel:te}=Je(O,this._localeService,s);$===o.WrapStrategy.WRAP&&te.updateDocumentDataPageSize(Math.max(Z,1)),q.calculate(),q.getActualSize();const ae=B.getDocsSkeletonPageSize(q),{height:ie,width:le}=ae,{paddingTop:oe,paddingLeft:de}=Jt(Z,y-U-G,le,ie,A,T,!0);this._drawDownIcon(e,C,V,y,ie,A,F),e.save(),e.translateWithPrecision(C.startX+N,C.startY+U),e.beginPath(),e.rect(0,0,V-N-k,y-U-G),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(),M.set(D,{left:C.endX+N+a.rowHeaderWidth-ce,top:C.startY+U+a.columnHeaderHeight,width:ce,height:y-U-G})}else{e.save(),e.translateWithPrecision(C.startX,C.startY),e.beginPath(),e.rect(0,0,V,y),e.clip();const N=V-he*2-ye-ce-4,{documentSkeleton:U,documents:k,docModel:G}=Je(O,this._localeService,s);$===o.WrapStrategy.WRAP&&G.updateDocumentDataPageSize(Math.max(N,1)),U.calculate();const Z=B.getDocsSkeletonPageSize(U),{height:q,width:ee}=Z,{paddingTop:te,paddingLeft:ae}=Jt(N,y,ee,q,A,T);e.translateWithPrecision(he,te);const ie=Math.max(V-he*2,1),le=q;B.Rect.drawWith(e,{width:ie,height:le,fill:(j==null?void 0:j.color)||Ie,radius:_t}),e.save(),e.translateWithPrecision(ye,0),e.beginPath(),e.rect(0,0,N,q),e.clip(),e.translateWithPrecision(ae,0),k.render(e),e.restore(),e.translateWithPrecision(N+ye+4,(q-Ze)/2),e.fillStyle=Na,e.fill(Gt),e.restore(),M.set(D,{left:C.startX+he+a.rowHeaderWidth,top:C.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,d=n==null?void 0:n.fontRenderExtension,{leftOffset:l=0,rightOffset:u=0,topOffset:p=0,downOffset:m=0}=d||{},c=this._dataValidationModel.getRuleByLocation(e.unitId,e.subUnitId,i,r);if(!c||c.renderMode===o.DataValidationRenderMode.TEXT)return;const g={startX:s.startX+l,endX:s.endX-u,startY:s.startY+p,endY:s.endY-m},v=g.endX-g.startX,I=E.getCellValueOrigin(n),w=`${I!=null?I:""}`;let{tb:C,pd:V}=a||{};const{t:y=o.DEFAULT_STYLES.pd.t,b:M=o.DEFAULT_STYLES.pd.b}=V!=null?V:{};if(C=C!=null?C:o.WrapStrategy.WRAP,c.renderMode===o.DataValidationRenderMode.ARROW){const D=v-ce,{documentSkeleton:S,docModel:_}=Je(w,this._localeService,a);C===o.WrapStrategy.WRAP&&_.updateDocumentDataPageSize(Math.max(D,1)),S.calculate(),S.getActualSize();const O=B.getDocsSkeletonPageSize(S),{height:j}=O;return j+y+M+Oe*2}else{const D=v-he*2-ye-ce,{documentSkeleton:S,docModel:_}=Zt(w,this._localeService,a);C===o.WrapStrategy.WRAP&&_.updateDocumentDataPageSize(Math.max(D,1)),S.calculate();const O=B.getDocsSkeletonPageSize(S),{height:j}=O;return j+Oe*2}}calcCellAutoWidth(e){const{primaryWithCoord:t,style:a,data:n,row:i,col:r}=e,s=t.isMergedMainCell?t.mergeInfo:t,d=n==null?void 0:n.fontRenderExtension,{leftOffset:l=0,rightOffset:u=0,topOffset:p=0,downOffset:m=0}=d||{},c=this._dataValidationModel.getRuleByLocation(e.unitId,e.subUnitId,i,r);if(!c||c.renderMode===o.DataValidationRenderMode.TEXT)return;const g={startX:s.startX+l,endX:s.endX-u,startY:s.startY+p,endY:s.endY-m},v=g.endX-g.startX,I=E.getCellValueOrigin(n),w=`${I!=null?I:""}`;let{tb:C,pd:V}=a||{};const{l:y=o.DEFAULT_STYLES.pd.l,r:M=o.DEFAULT_STYLES.pd.r}=V!=null?V:{};C=C!=null?C:o.WrapStrategy.WRAP;let D=he*2+ce;switch(c.renderMode){case o.DataValidationRenderMode.ARROW:D=ce+he*2+M+y;break;case o.DataValidationRenderMode.CUSTOM:D=ce+he*2+ye*2+M+y+_t/2+1;break;default:D=ce+he*2+ye*2+M+y+_t/2+1}const S=v-D,{documentSkeleton:_,docModel:O}=Je(w,this._localeService,a);return C===o.WrapStrategy.WRAP&&O.updateDocumentDataPageSize(Math.max(S,1)),_.calculate(),_.getActualSize(),B.getDocsSkeletonPageSize(_).width+D}isHit(e,t){const{subUnitId:a,row:n,col:i}=t,s=this._ensureMap(a).get(this._generateKey(n,i)),d=this._dataValidationModel.getRuleByLocation(t.unitId,t.subUnitId,n,i);if(!d||!s||d.renderMode===o.DataValidationRenderMode.TEXT)return!1;const{top:l,left:u,width:p,height:m}=s,{x:c,y:g}=e;return c>=u&&c<=u+p&&g>=l&&g<=l+m}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(Ne.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)}};It=xa([Ge(0,o.Inject(o.LocaleService)),Ge(1,o.ICommandService),Ge(2,o.Inject(B.IRenderManagerService)),Ge(3,o.Inject(E.SheetDataValidationModel))],It);class Ba extends pe{constructor(){super(...arguments);L(this,"id",o.DataValidationType.LIST);L(this,"canvasRender",this.injector.createInstance(It));L(this,"dropdown",We);L(this,"optionsInput",Xe.componentKey);L(this,"formulaInput",pt)}}class ka extends pe{constructor(){super(...arguments);L(this,"id",o.DataValidationType.TEXT_LENGTH);L(this,"formulaInput",Ye)}}class Wa extends pe{constructor(){super(...arguments);L(this,"id",o.DataValidationType.WHOLE);L(this,"formulaInput",Ye)}}var $a=Object.defineProperty,Ha=Object.getOwnPropertyDescriptor,Ya=(e,t,a,n)=>{for(var i=n>1?void 0:n?Ha(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&&$a(t,a,i),i},Ct=(e,t)=>(a,n)=>t(a,n,e);let Le=class extends o.RxDisposable{constructor(e,t,a){super(),this._injector=e,this._componentManger=t,this._dataValidatorRegistryService=a,this._initComponents(),this._registerValidatorViews()}_initComponents(){[[Nt,bt],[xe,Fn],[At,yn],[We,Mn],[lt,ln],[Xe.componentKey,Xe],[ze.componentKey,ze],...ua].forEach(([e,t])=>{this.disposeWithMe(this._componentManger.register(e,t))})}_registerValidatorViews(){[Va,Wa,ka,wa,Ca,Ba,ja,Da].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)})}};Le=Ya([Ct(0,o.Inject(o.Injector)),Ct(1,o.Inject(z.ComponentManager)),Ct(2,o.Inject(J.DataValidatorRegistryService))],Le);var Xa=Object.defineProperty,za=Object.getOwnPropertyDescriptor,Ka=(e,t,a,n)=>{for(var i=n>1?void 0:n?za(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&&Xa(t,a,i),i},Dt=(e,t)=>(a,n)=>t(a,n,e);const qa="SHEET_DATA_VALIDATION_UI_PLUGIN";Y.UniverSheetsDataValidationUIPlugin=(Qe=class extends o.Plugin{constructor(t=Ue,a,n,i){super(),this._config=t,this._injector=a,this._commandService=n,this._configService=i;const{menu:r,...s}=o.merge({},Ue,this._config);r&&this._configService.setConfig("menu",r,{merge:!0}),this._configService.setConfig(rt,s)}onStarting(){[[ue],[fe],[Ae],[Ee],[be],[Me],[Re],[je],[Le]].forEach(t=>{this._injector.add(t)}),[$e,Ne,xt,ot,_e,Ft].forEach(t=>{this._commandService.registerCommand(t)})}onReady(){this._injector.get(Re),this._injector.get(Me),this._injector.get(je),this._injector.get(Ae),this._injector.get(B.IRenderManagerService).registerRenderModule(o.UniverInstanceType.UNIVER_SHEET,[He])}onRendered(){this._injector.get(Le),this._injector.get(be)}onSteady(){this._injector.get(Ee)}},L(Qe,"pluginName",qa),L(Qe,"type",o.UniverInstanceType.UNIVER_SHEET),Qe),Y.UniverSheetsDataValidationUIPlugin=Ka([Dt(1,o.Inject(o.Injector)),Dt(2,o.ICommandService),Dt(3,o.IConfigService)],Y.UniverSheetsDataValidationUIPlugin);var Ga=Object.defineProperty,Za=Object.getOwnPropertyDescriptor,Ja=(e,t,a,n)=>{for(var i=n>1?void 0:n?Za(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&&Ga(t,a,i),i},yt=(e,t)=>(a,n)=>t(a,n,e);const Qa="SHEET_DATA_VALIDATION_UI_PLUGIN";Y.UniverSheetsDataValidationMobileUIPlugin=(et=class extends o.Plugin{constructor(t=Ue,a,n,i){super(),this._config=t,this._injector=a,this._commandService=n,this._configService=i;const{menu:r,...s}=o.merge({},Ue,this._config);r&&this._configService.setConfig("menu",r,{merge:!0}),this._configService.setConfig(rt,s)}onStarting(){[[ue],[fe],[Ae],[Ee],[be],[Me],[Re],[Le]].forEach(t=>{this._injector.add(t)}),[$e,Ne,xt,ot,_e,Ft].forEach(t=>{this._commandService.registerCommand(t)})}onReady(){this._injector.get(Re),this._injector.get(Me),this._injector.get(B.IRenderManagerService).registerRenderModule(o.UniverInstanceType.UNIVER_SHEET,[He])}onRendered(){this._injector.get(Le),this._injector.get(be)}onSteady(){this._injector.get(Ee)}},L(et,"pluginName",Qa),L(et,"type",o.UniverInstanceType.UNIVER_SHEET),et),Y.UniverSheetsDataValidationMobileUIPlugin=Ja([yt(1,o.Inject(o.Injector)),yt(2,o.ICommandService),yt(3,o.IConfigService)],Y.UniverSheetsDataValidationMobileUIPlugin),Y.DATE_DROPDOWN_KEY=lt,Y.LIST_DROPDOWN_KEY=We,Object.defineProperty(Y,Symbol.toStringTag,{value:"Module"})});
22
+ */var wt;function tn(){if(wt)return Te;wt=1;var e=g,t=Symbol.for("react.element"),a=Symbol.for("react.fragment"),n=Object.prototype.hasOwnProperty,i=e.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,r={key:!0,ref:!0,__self:!0,__source:!0};function s(d,l,u){var p,m={},c=null,S=null;u!==void 0&&(c=""+u),l.key!==void 0&&(c=""+l.key),l.ref!==void 0&&(S=l.ref);for(p in l)n.call(l,p)&&!r.hasOwnProperty(p)&&(m[p]=l[p]);if(d&&d.defaultProps)for(p in l=d.defaultProps,l)m[p]===void 0&&(m[p]=l[p]);return{$$typeof:t,type:d,key:c,ref:S,props:m,_owner:i.current}}return Te.Fragment=a,Te.jsx=s,Te.jsxs=s,Te}var Vt;function nn(){return Vt||(Vt=1,at.exports=tn()),at.exports}var h=nn(),an=Object.defineProperty,on=Object.getOwnPropertyDescriptor,rn=(e,t,a,n)=>{for(var i=n>1?void 0:n?on(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},Pe=(e,t)=>(a,n)=>t(a,n,e);let je=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 y;const n=await e,{worksheet:i,row:r,col:s,unitId:d,subUnitId:l,workbook:u}=t,p=this._dataValidationModel.getRuleIdByLocation(d,l,r,s),m=p?this._dataValidationModel.getRuleById(d,l,p):void 0;if(!m||m.errorStyle!==o.DataValidationErrorStyle.STOP)return a(Promise.resolve(n));const c=await this._dataValidatorRegistryService.getValidatorItem(m.type);if(!c||await c.validator({value:E.getCellValueOrigin(n),interceptValue:E.getCellValueOrigin((y=t==null?void 0:t.origin)!=null?y:n),row:r,column:s,unitId:d,subUnitId:l,worksheet:i,workbook:u,t:n==null?void 0:n.t},m))return a(Promise.resolve(n));const f=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(m,{row:r,col:s,unitId:d,subUnitId:l})},footer:{title:g.createElement(b.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(f))}})}showReject(e){this._dialogService.open({width:368,title:{title:this._localeService.t("dataValidation.alert.title")},id:"reject-input-dialog",children:{title:e},footer:{title:g.createElement(b.Button,{type:"primary",onClick:()=>this._dialogService.close("reject-input-dialog")},this._localeService.t("dataValidation.alert.ok"))},onClose:()=>{this._dialogService.close("reject-input-dialog")}})}};je=rn([Pe(0,o.Inject(X.SheetInterceptorService)),Pe(1,o.Inject(E.SheetDataValidationModel)),Pe(2,o.Inject(J.DataValidatorRegistryService)),Pe(3,z.IDialogService),Pe(4,o.Inject(o.LocaleService))],je);const Et={dvDateDropdown:"univer-dv-date-dropdown",dvDateDropdownBtns:"univer-dv-date-dropdown-btns"},sn=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 ln(e){var v;const{location:t,hideFn:a}=e,{worksheet:n,row:i,col:r,unitId:s,subUnitId:d,workbook:l}=t,u=o.useDependency(o.ICommandService),p=o.useDependency(je),m=n.getCell(i,r),c=E.getCellValueOrigin(n.getCellRaw(i,r)),S=sn(c),[f,y]=g.useState(S),V=f&&f.isValid()?f:o.dayjs(),_=o.useDependency(o.LocaleService),w=o.useDependency(E.SheetDataValidationModel),D=w.getRuleByLocation(s,d,i,r);if(!D)return null;const M=w.getValidator(D.type);if(!m||!M)return;const I=!!((v=D.bizInfo)!=null&&v.showTime),C=async()=>{var x,N,W;if(!V)return;const j=V.format(I?"YYYY-MM-DD HH:mm:ss":"YYYY-MM-DD 00:00:00"),k=(x=o.numfmt.parseDate(j))==null?void 0:x.v,A=l.getStyles().getStyleByCell(m),T=(W=(N=A==null?void 0:A.n)==null?void 0:N.pattern)!=null?W:"",F=Qt.getPatternType(T);D.errorStyle!==o.DataValidationErrorStyle.STOP||await M.validator({value:k,unitId:s,subUnitId:d,row:i,column:r,worksheet:n,workbook:l,interceptValue:j.replace("Z","").replace("T"," "),t:o.CellValueType.NUMBER},D)?(a(),await u.executeCommand(B.SetCellEditVisibleOperation.id,{visible:!1,eventType:U.DeviceInputEventType.Keyboard,unitId:s,keycode:z.KeyCode.ESC}),await u.executeCommand(X.SetRangeValuesCommand.id,{unitId:s,subUnitId:d,range:{startColumn:r,endColumn:r,startRow:i,endRow:i},value:{v:k,t:2,p:null,f:null,si:null,s:{n:{pattern:I?F==="datetime"?T:"yyyy-MM-dd hh:mm:ss":F==="date"?T:"yyyy-MM-dd"}}}})):p.showReject(M.getRuleFinalError(D,{row:i,col:r,unitId:s,subUnitId:d}))};return h.jsxs("div",{className:Et.dvDateDropdown,children:[h.jsx(b.DatePanel,{defaultValue:V,pickerValue:V,showTime:I||void 0,onSelect:async O=>{y(O)},onPanelChange:O=>{y(O)},disabledDate:O=>!o.numfmt.parseDate(O.format("YYYY-MM-DD"))}),h.jsx("div",{className:Et.dvDateDropdownBtns,children:h.jsx(b.Button,{size:"small",type:"primary",onClick:C,disabled:!V.isValid(),children:_.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)},dn=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},fe=g.forwardRef(function(e,t){var a=e.icon,n=e.id,i=e.className,r=e.extend,s=dn(e,["icon","id","className","extend"]),d="univerjs-icon univerjs-icon-".concat(n," ").concat(i||"").trim(),l=g.useRef("_".concat(pn()));return Rt(a,"".concat(n),{defIds:a.defIds,idSuffix:l.current},se({ref:t,className:d},s),r)});function Rt(e,t,a,n,i){return g.createElement(e.tag,se(se({key:t},cn(e,a,i)),n),(un(e,a).children||[]).map(function(r,s){return Rt(r,"".concat(t,"-").concat(e.tag,"-").concat(s),a,void 0,i)}))}function cn(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],d=r[1];typeof d=="string"&&(n[s]=d.replace(/url\(#(.*)\)/,"url(#$1".concat(t.idSuffix,")")))})),n}function un(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 pn(){return Math.random().toString(36).substring(2,8)}fe.displayName="UniverIcon";var hn={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"}}]},Mt=g.forwardRef(function(e,t){return g.createElement(fe,Object.assign({},e,{id:"check-mark-single",ref:t,icon:hn}))});Mt.displayName="CheckMarkSingle";var mn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 17 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M1.4917 3.07803C1.4917 2.19437 2.20804 1.47803 3.0917 1.47803H5.6917C6.57536 1.47803 7.2917 2.19437 7.2917 3.07803V5.67803C7.2917 6.56168 6.57535 7.27803 5.6917 7.27803H3.0917C2.20804 7.27803 1.4917 6.56168 1.4917 5.67803V3.07803ZM3.0917 2.67803C2.87078 2.67803 2.6917 2.85711 2.6917 3.07803V5.67803C2.6917 5.89894 2.87079 6.07803 3.0917 6.07803H5.6917C5.91261 6.07803 6.0917 5.89894 6.0917 5.67803V3.07803C6.0917 2.85711 5.91261 2.67803 5.6917 2.67803H3.0917Z",fillRule:"evenodd",clipRule:"evenodd"}},{tag:"path",attrs:{fill:"currentColor",d:"M14.6175 2.45279C14.8518 2.68711 14.8518 3.06701 14.6175 3.30132L11.6151 6.30365C11.3957 6.52307 11.0451 6.53897 10.8067 6.34031L8.80915 4.67566C8.55458 4.46352 8.52019 4.08518 8.73233 3.83062 8.94447 3.57605 9.32281 3.54166 9.57737 3.7538L11.154 5.06767 13.769 2.45278C14.0033 2.21847 14.3832 2.21848 14.6175 2.45279zM14.1175 9.19746C14.3518 9.43178 14.3518 9.81168 14.1175 10.046L12.5418 11.6217 14.1175 13.1975C14.3518 13.4318 14.3518 13.8117 14.1175 14.046 13.8832 14.2803 13.5033 14.2803 13.269 14.046L11.6933 12.4703 10.1175 14.046C9.88321 14.2803 9.50331 14.2803 9.269 14.046 9.03468 13.8117 9.03468 13.4318 9.269 13.1975L10.8447 11.6217 9.269 10.046C9.03468 9.81168 9.03468 9.43178 9.269 9.19746 9.50331 8.96315 9.88321 8.96315 10.1175 9.19746L11.6933 10.7732 13.269 9.19746C13.5033 8.96315 13.8832 8.96315 14.1175 9.19746z"}},{tag:"path",attrs:{fill:"currentColor",d:"M3.0917 8.72168C2.20804 8.72168 1.4917 9.43802 1.4917 10.3217V12.9217C1.4917 13.8053 2.20804 14.5217 3.0917 14.5217H5.6917C6.57535 14.5217 7.2917 13.8053 7.2917 12.9217V10.3217C7.2917 9.43802 6.57536 8.72168 5.6917 8.72168H3.0917ZM2.6917 10.3217C2.6917 10.1008 2.87078 9.92168 3.0917 9.92168H5.6917C5.91261 9.92168 6.0917 10.1008 6.0917 10.3217V12.9217C6.0917 13.1426 5.91261 13.3217 5.6917 13.3217H3.0917C2.87079 13.3217 2.6917 13.1426 2.6917 12.9217V10.3217Z",fillRule:"evenodd",clipRule:"evenodd"}}]},bt=g.forwardRef(function(e,t){return g.createElement(fe,Object.assign({},e,{id:"data-validation-single",ref:t,icon:mn}))});bt.displayName="DataValidationSingle";var fn={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"}}]},it=g.forwardRef(function(e,t){return g.createElement(fe,Object.assign({},e,{id:"delete-single",ref:t,icon:fn}))});it.displayName="DeleteSingle";var vn={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"}}]},Ot=g.forwardRef(function(e,t){return g.createElement(fe,Object.assign({},e,{id:"increase-single",ref:t,icon:vn}))});Ot.displayName="IncreaseSingle";var gn={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"}}]},Lt=g.forwardRef(function(e,t){return g.createElement(fe,Object.assign({},e,{id:"more-down-single",ref:t,icon:gn}))});Lt.displayName="MoreDownSingle";var Sn={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"}}]},Tt=g.forwardRef(function(e,t){return g.createElement(fe,Object.assign({},e,{id:"more-up-single",ref:t,icon:Sn}))});Tt.displayName="MoreUpSingle";var _n={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"}}]}]},Pt=g.forwardRef(function(e,t){return g.createElement(fe,Object.assign({},e,{id:"sequence-single",ref:t,icon:_n}))});Pt.displayName="SequenceSingle";var In=Object.defineProperty,Cn=Object.getOwnPropertyDescriptor,Dn=(e,t,a,n)=>{for(var i=n>1?void 0:n?Cn(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&&In(t,a,i),i},jt=(e,t)=>(a,n)=>t(a,n,e);let ue=class extends o.Disposable{constructor(t,a){super();L(this,"_open$",new re.BehaviorSubject(!1));L(this,"open$",this._open$.pipe(re.distinctUntilChanged()));L(this,"_activeRule");L(this,"_activeRule$",new re.BehaviorSubject(void 0));L(this,"activeRule$",this._activeRule$.asObservable());L(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===xe&&(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=Dn([jt(0,o.IUniverInstanceService),jt(1,z.ISidebarService)],ue);function yn(){const e=o.useDependency(ve),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 d=()=>{e.hideDropdown()};return h.jsx(r,{location:n,hideFn:d},s)}const At="sheet.ui.dropdown";var wn=Object.defineProperty,Vn=Object.getOwnPropertyDescriptor,En=(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&&wn(t,a,i),i},Se=(e,t)=>(a,n)=>t(a,n,e);let ve=class extends o.Disposable{constructor(t,a,n,i,r,s,d){super();L(this,"_activeDropdown");L(this,"_activeDropdown$",new re.Subject);L(this,"_currentPopup",null);L(this,"activeDropdown$",this._activeDropdown$.asObservable());L(this,"_zenVisible",!1);this._canvasPopupManagerService=t,this._univerInstanceService=a,this._dataValidatorRegistryService=n,this._zenZoneService=i,this._renderManagerService=r,this._dataValidationModel=s,this._sheetsSelectionsService=d,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 d=this._dataValidationModel.getRuleByLocation(r.getUnitId(),s.getSheetId(),n,i);if(!d)return;const l=this._dataValidatorRegistryService.getValidatorItem(d.type);return l==null?void 0:l.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:d}=n;if(this._currentPopup&&this._currentPopup.dispose(),this._zenVisible)return;this._activeDropdown=t,this._activeDropdown$.next(this._activeDropdown);const l=this._renderManagerService.getRenderById(o.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),u=this._canvasPopupManagerService.attachPopupToCell(i,r,{componentKey:At,onClickOutside:()=>{a&&this.hideDropdown()},offset:[0,3],excludeOutside:[l==null?void 0:l.engine.getCanvasElement()].filter(Boolean)},s,d);if(!u)throw new Error("[DataValidationDropdownManagerService]: cannot show dropdown!");const p=new o.DisposableCollection;p.add(u),p.add({dispose:()=>{var m,c;(c=(m=this._activeDropdown)==null?void 0:m.onHide)==null||c.call(m)}}),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,i,r){const s=this._univerInstanceService.getUnit(t,o.UniverInstanceType.UNIVER_SHEET);if(!s)return;const d=s.getSheetBySheetId(a);if(!d)return;const l=this._dataValidationModel.getRuleByLocation(s.getUnitId(),d.getSheetId(),n,i);if(!l)return;const u=this._dataValidatorRegistryService.getValidatorItem(l.type);if(!u||!u.dropdown){this.hideDropdown();return}this.showDropdown({location:{workbook:s,worksheet:d,row:n,col:i,unitId:t,subUnitId:a},componentKey:u.dropdown,onHide:r})}};ve=En([Se(0,o.Inject(B.SheetCanvasPopManagerService)),Se(1,o.IUniverInstanceService),Se(2,o.Inject(J.DataValidatorRegistryService)),Se(3,z.IZenZoneService),Se(4,U.IRenderManagerService),Se(5,o.Inject(E.SheetDataValidationModel)),Se(6,o.Inject(X.SheetsSelectionsService))],ve);const xe="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),d=e.get(z.ISidebarService),l=X.getSheetCommandTarget(s);if(!l)return!1;const{unitId:u,subUnitId:p}=l,m=a?r.getRuleById(u,p,a):void 0;i.open(),i.setActiveRule(m&&{unitId:u,subUnitId:p,rule:m});const c=d.open({id:xe,header:{title:n?"dataValidation.panel.addTitle":"dataValidation.panel.title"},children:{label:xe},width:312,onClose:()=>i.close()});return i.setCloseDisposable(c),!0}},ot={id:"data-validation.operation.close-validation-panel",type:o.CommandType.OPERATION,handler(e){return e.get(ue).close(),!0}},Ft={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(ot.id):t.executeCommand(_e.id),!0}},Ne={type:o.CommandType.OPERATION,id:"sheet.operation.show-data-validation-dropdown",handler(e,t){if(!t)return!1;const a=e.get(ve),{unitId:n,subUnitId:i,row:r,column:s}=t,d=a.activeDropdown,l=d==null?void 0:d.location;return l&&l.unitId===n&&l.subUnitId===i&&l.row===r&&l.col===s||a.showDataValidationDropdown(n,i,r,s),!0}},xt={type:o.CommandType.OPERATION,id:"sheet.operation.hide-data-validation-dropdown",handler(e,t){return t?(e.get(ve).hideDropdown(),!0):!1}},Ie="#ECECEC",rt="sheets-data-validation-ui.config",Ue={},me={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"},Rn=e=>{var I,C;const{value:t,onChange:a,multiple:n,options:i,title:r,onEdit:s,style:d,filter:l,location:u}=e,p=o.useDependency(o.LocaleService),m=o.useDependency(o.IConfigService),c=l==null?void 0:l.toLowerCase(),{row:S,col:f,unitId:y,subUnitId:V}=u,_=i.filter(v=>c?v.label.toLowerCase().includes(c):!0),w=(C=(I=m.getConfig(rt))==null?void 0:I.showEditOnDropdown)!=null?C:!0,D=o.useDependency(X.SheetPermissionCheckController),M=g.useMemo(()=>D.permissionCheckWithRanges({workbookTypes:[X.WorkbookEditablePermission],rangeTypes:[X.RangeProtectionPermissionEditPoint],worksheetTypes:[X.WorksheetEditPermission]},[{startColumn:f,startRow:S,endColumn:f,endRow:S}],y,V),[D,f,S,y,V]);return h.jsxs("div",{className:me.dvListDropdown,style:d,children:[h.jsx("div",{className:me.dvListDropdownTitle,children:r}),h.jsx("div",{className:me.dvListDropdownList,children:h.jsx(b.Scrollbar,{children:h.jsx("div",{className:me.dvListDropdownListContainer,children:_.map((v,O)=>{const j=t.indexOf(v.value)>-1,k=()=>{let T;j?T=new Set(t.filter(x=>x!==v.value)):T=new Set(n?[...t,v.value]:[v.value]);const F=[];i.forEach(x=>{T.has(x.value)&&F.push(x.value)}),a(F)},A=v.label.toLocaleLowerCase().indexOf(c);return h.jsxs("div",{className:me.dvListDropdownItemContainer,onClick:k,children:[h.jsx("div",{className:me.dvListDropdownItem,style:{background:v.color||Ie},children:c&&v.label.toLowerCase().includes(c)?h.jsxs(h.Fragment,{children:[h.jsx("span",{children:v.label.substring(0,A)}),h.jsx("span",{style:{fontWeight:"bold"},children:v.label.substring(A,A+c.length)}),h.jsx("span",{children:v.label.substring(A+c.length)})]}):v.label}),h.jsx("div",{className:me.dvListDropdownSelectedIcon,children:j?h.jsx(Mt,{}):null})]},O)})})},l)}),w&&M?h.jsxs(h.Fragment,{children:[h.jsx("div",{className:me.dvListDropdownSplit}),h.jsx("div",{className:me.dvListDropdownEdit,children:h.jsx("a",{onClick:s,children:p.t("dataValidation.list.edit")})})]}):null]})};function Mn(e){var N,W,G,Z;const{location:t,hideFn:a}=e,{worksheet:n,row:i,col:r,unitId:s,subUnitId:d}=t,l=o.useDependency(J.DataValidationModel),[u,p]=g.useState(""),m=o.useDependency(o.ICommandService),c=o.useDependency(o.LocaleService),[S,f]=g.useState(""),y=o.useDependency(B.IEditorBridgeService),V=o.useDependency(o.IUniverInstanceService),_=g.useMemo(()=>l.ruleChange$.pipe(re.debounceTime(16)),[]),w=o.useDependency(E.SheetDataValidationModel);z.useObservable(_);const D=z.RectPopup.useContext(),M=((W=(N=D.current)==null?void 0:N.right)!=null?W:0)-((Z=(G=D.current)==null?void 0:G.left)!=null?Z:0);if(g.useEffect(()=>{const q=m.onCommandExecuted(ee=>{var te,ae;if(ee.id===en.RichTextEditingMutation.id){const ie=ee.params,{unitId:le}=ie,oe=V.getUnit(le,o.UniverInstanceType.UNIVER_DOC);if(!oe)return;const de=o.BuildTextUtils.transform.getPlainText((ae=(te=oe.getSnapshot().body)==null?void 0:te.dataStream)!=null?ae:"");p(de)}});return()=>{q.dispose()}},[m,V]),!n)return null;const I=w.getRuleByLocation(s,d,i,r);if(!I)return null;const C=w.getValidator(I.type);if(!C)return null;const v=n.getCell(i,r),O=(I==null?void 0:I.renderMode)===o.DataValidationRenderMode.CUSTOM||(I==null?void 0:I.renderMode)===void 0;if(!v||!I||!C||C.id.indexOf(o.DataValidationType.LIST)!==0)return;const j=I.type===o.DataValidationType.LIST_MULTIPLE,k=C.getListWithColor(I,s,d),A=S||E.getDataValidationCellValue(n.getCellRaw(i,r)),T=E.deserializeListOptions(A),F=()=>{m.executeCommand(_e.id,{ruleId:I.uid}),a()},x=k.map(q=>({label:q.label,value:q.label,color:O||q.color?q.color:"transparent"}));return h.jsx(Rn,{style:{minWidth:M,maxWidth:Math.max(M,200)},title:j?c.t("dataValidation.listMultiple.dropdown"):c.t("dataValidation.list.dropdown"),value:T,multiple:j,onChange:async q=>{const ee=E.serializeListOptions(q),te={unitId:s,subUnitId:d,range:{startColumn:r,endColumn:r,startRow:i,endRow:i},value:{v:ee,p:null,f:null,si:null}};y.isVisible()&&y.changeVisible({visible:!1,keycode:z.KeyCode.ESC,eventType:U.DeviceInputEventType.Keyboard,unitId:s}),f(ee),j||a(),y.isVisible().visible&&await m.executeCommand(B.SetCellEditVisibleOperation.id,{visible:!1,eventType:U.DeviceInputEventType.Keyboard,unitId:s,keycode:z.KeyCode.ESC}),m.executeCommand(X.SetRangeValuesCommand.id,te)},options:x,onEdit:F,filter:u,location:t})}const st={dataValidationOptionsButton:"univer-data-validation-options-button",dataValidationOptionsButtonIcon:"univer-data-validation-options-button-icon"};function bn(e){var u;const t=o.useDependency(o.LocaleService),a=o.useDependency(z.ComponentManager),{value:n,onChange:i,extraComponent:r}=e,[s,d]=g.useState(!1),l=r?a.get(r):null;return h.jsxs(h.Fragment,{children:[h.jsxs("div",{className:st.dataValidationOptionsButton,onClick:()=>d(!s),children:[t.t("dataValidation.panel.options"),s?h.jsx(Tt,{className:st.dataValidationOptionsButtonIcon}):h.jsx(Lt,{className:st.dataValidationOptionsButtonIcon})]}),s&&h.jsxs(h.Fragment,{children:[l?h.jsx(l,{value:n,onChange:i}):null,h.jsx(b.FormLayout,{label:t.t("dataValidation.panel.invalid"),children:h.jsxs(b.RadioGroup,{value:`${(u=n.errorStyle)!=null?u:o.DataValidationErrorStyle.WARNING}`,onChange:p=>i({...n,errorStyle:+p}),children:[h.jsx(b.Radio,{value:`${o.DataValidationErrorStyle.WARNING}`,children:t.t("dataValidation.panel.showWarning")}),h.jsx(b.Radio,{value:`${o.DataValidationErrorStyle.STOP}`,children:t.t("dataValidation.panel.rejectInput")})]})}),h.jsx(b.FormLayout,{label:t.t("dataValidation.panel.messageInfo"),children:h.jsx(b.Checkbox,{checked:n.showErrorMessage,onChange:()=>i({...n,showErrorMessage:!n.showErrorMessage}),children:t.t("dataValidation.panel.showInfo")})}),n.showErrorMessage?h.jsx(b.FormLayout,{children:h.jsx(b.Input,{value:n.error,onChange:p=>i({...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"},On=e=>o.debounce(async(t,a,n,i)=>{const r=await e.executeCommand(t,a,n);i==null||i(r)},1e3);function Ln(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 Tn(){var de;const[e,t]=g.useState(0),a=o.useDependency(ue),n=z.useObservable(a.activeRule$,a.activeRule),{unitId:i,subUnitId:r,rule:s}=n||{},d=s.uid,l=o.useDependency(J.DataValidatorRegistryService),u=o.useDependency(o.IUniverInstanceService),p=o.useDependency(z.ComponentManager),m=o.useDependency(o.ICommandService),c=o.useDependency(J.DataValidationModel),S=o.useDependency(o.LocaleService),[f,y]=g.useState(s),V=l.getValidatorItem(f.type),[_,w]=g.useState(!1),D=l.getValidatorsByScope(J.DataValidatorRegistryScope.SHEET),[M,I]=g.useState(()=>f.ranges.map(P=>({unitId:"",sheetId:"",range:P}))),C=g.useMemo(()=>On(m),[m]),[v,O]=g.useState(!1),j=g.useRef({}),[k,A]=g.useState(!1),T=o.useDependency(X.SheetsSelectionsService);if(g.useEffect(()=>()=>{const P=T.getCurrentLastSelection();P&&T.setSelections([P])},[T]),g.useEffect(()=>{m.onCommandExecuted(P=>{(P.id===o.UndoCommand.id||P.id===o.RedoCommand.id)&&setTimeout(()=>{const R=c.getRuleById(i,r,d);t($=>$+1),R&&(y(R),I(R.ranges.map($=>({unitId:"",sheetId:"",range:$}))))},20)})},[m,c,d,r,i]),!V)return null;const F=V.operators,x=V.operatorNames,N=f.operator?J.TWO_FORMULA_OPERATOR_COUNT.includes(f.operator):!1,W=()=>{!f.ranges.length||v||(V.validatorFormula(f,i,r).success?a.setActiveRule(null):w(!0))},G=z.useEvent(P=>{const R=P.split(",").filter(Boolean).map(tt.deserializeRangeWithSheet).map(K=>{const ge=K.sheetName;if(ge){const ei=Ln(u,K.unitId,ge);return{...K,sheetId:ei}}return{...K,sheetId:""}});if(o.isUnitRangesEqual(R,M))return;I(R);const $=R.filter(K=>(!K.unitId||K.unitId===i)&&(!K.sheetId||K.sheetId===r)).map(K=>K.range);if(y({...f,ranges:$}),$.length===0)return;const H={unitId:i,subUnitId:r,ruleId:d,ranges:$};C(E.UpdateSheetDataValidationRangeCommand.id,H)}),Z=P=>{if(o.shallowEqual(P,J.getRuleSetting(f)))return;y({...f,...P});const R={unitId:i,subUnitId:r,ruleId:d,setting:P};C(E.UpdateSheetDataValidationSettingCommand.id,R,void 0)},q=async()=>{await m.executeCommand(E.RemoveSheetDataValidationCommand.id,{ruleId:d,unitId:i,subUnitId:r}),a.setActiveRule(null)},ee={type:f.type,operator:f.operator,formula1:f.formula1,formula2:f.formula2,allowBlank:f.allowBlank},te=P=>{const R=l.getValidatorItem(P);if(!R)return;const $=R.operators,H=c.getRuleById(i,r,d),K=P===(H==null?void 0:H.type)||P.includes("list")&&(H!=null&&H.type.includes("list"))?{...H,type:P}:{...f,type:P,operator:$[0],formula1:void 0,formula2:void 0};y(K),m.executeCommand(E.UpdateSheetDataValidationSettingCommand.id,{unitId:i,subUnitId:r,ruleId:f.uid,setting:J.getRuleSetting(K)})},ae=p.get(V.formulaInput),ie=g.useMemo(()=>M.map(P=>tt.serializeRange(P.range)).join(","),[]),le=J.getRuleOptions(f),oe=P=>{o.shallowEqual(P,J.getRuleOptions(f))||(y({...f,...P}),C(E.UpdateSheetDataValidationOptionsCommand.id,{unitId:i,subUnitId:r,ruleId:d,options:P}))};return z.useSidebarClick(P=>{var $;const R=($=j.current)==null?void 0:$.handleOutClick;R&&R(P,()=>A(!1))}),h.jsxs("div",{className:we.dataValidationDetail,children:[h.jsx(b.FormLayout,{label:S.t("dataValidation.panel.range"),error:!f.ranges.length||v?S.t("dataValidation.panel.rangeError"):"",children:h.jsx(nt.RangeSelector,{unitId:i,subUnitId:r,initValue:ie,onChange:G,onFocus:()=>A(!0),isFocus:k,actions:j.current,onVerify:P=>O(!P)})}),h.jsx(b.FormLayout,{label:S.t("dataValidation.panel.type"),children:h.jsx(b.Select,{options:D==null?void 0:D.map(P=>({label:S.t(P.title),value:P.id})),value:f.type,onChange:te,className:we.dataValidationDetailFormItem})}),F!=null&&F.length?h.jsx(b.FormLayout,{label:S.t("dataValidation.panel.operator"),children:h.jsx(b.Select,{options:F.map((P,R)=>({value:`${P}`,label:x[R]})),value:`${f.operator}`,onChange:P=>{Z({...ee,operator:P})},className:we.dataValidationDetailFormItem})}):null,ae?h.jsx(ae,{isTwoFormula:N,value:{formula1:f.formula1,formula2:f.formula2},onChange:P=>{Z({...ee,...P})},showError:_,validResult:V.validatorFormula(f,i,r),unitId:i,subUnitId:r,ruleId:d},e+f.type):null,h.jsx(b.FormLayout,{children:h.jsx(b.Checkbox,{checked:(de=f.allowBlank)!=null?de:!0,onChange:()=>{var P;return Z({...ee,allowBlank:!((P=f.allowBlank)==null||P)})},children:S.t("dataValidation.panel.allowBlank")})}),h.jsx(bn,{value:le,onChange:oe,extraComponent:V.optionsInput}),h.jsxs("div",{className:we.dataValidationDetailButtons,children:[h.jsx(b.Button,{className:we.dataValidationDetailButton,onClick:q,children:S.t("dataValidation.panel.removeRule")}),h.jsx(b.Button,{className:we.dataValidationDetailButton,type:"primary",onClick:W,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"},Pn=e=>{const{rule:t,onClick:a,unitId:n,subUnitId:i,disable:r}=e,s=o.useDependency(J.DataValidatorRegistryService),d=o.useDependency(o.ICommandService),l=o.useDependency(B.IMarkSelectionService),u=s.getValidatorItem(t.type),p=g.useRef(),[m,c]=g.useState(!1),S=f=>{d.executeCommand(E.RemoveSheetDataValidationCommand.id,{ruleId:t.uid,unitId:n,subUnitId:i}),f.stopPropagation()};return g.useEffect(()=>()=>{var f;p.current&&((f=p.current)==null||f.forEach(y=>{y&&l.removeShape(y)}))},[l]),h.jsxs("div",{className:Be.dataValidationItemContainer,onClick:a,onMouseEnter:()=>{r||(c(!0),p.current=t.ranges.map(f=>l.addShape({range:f,style:{fill:"rgba(73, 184, 17, 0.05)",strokeWidth:1,stroke:"#49B811",widgets:{}},primary:null})))},onMouseLeave:()=>{var f;c(!1),(f=p.current)==null||f.forEach(y=>{y&&l.removeShape(y)}),p.current=void 0},children:[h.jsx("div",{className:Be.dataValidationItemTitle,children:u==null?void 0:u.generateRuleName(t)}),h.jsx("div",{className:Be.dataValidationItemContent,children:t.ranges.map(f=>tt.serializeRange(f)).join(",")}),m?h.jsx("div",{className:Be.dataValidationItemIcon,onClick:S,children:h.jsx(it,{})}):null]})},ke={dataValidationList:"univer-data-validation-list",dataValidationListButtons:"univer-data-validation-list-buttons",dataValidationListButton:"univer-data-validation-list-button"};function jn(){const e=o.useDependency(o.IUniverInstanceService),t=z.useObservable(()=>e.getCurrentTypeOfUnit$(o.UniverInstanceType.UNIVER_SHEET),void 0,void 0,[]);return t?h.jsx(An,{workbook:t}):null}function An(e){const t=o.useDependency(E.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),[d,l]=g.useState([]),{workbook:u}=e,p=z.useObservable(u.activeSheet$,void 0,!0),m=u.getUnitId(),c=p==null?void 0:p.getSheetId();g.useEffect(()=>{l(t.getRules(m,c));const w=t.ruleChange$.subscribe(D=>{D.unitId===m&&D.subUnitId===c&&l(t.getRules(m,c))});return()=>{w.unsubscribe()}},[m,c,t]);const S=async()=>{const w=E.createDefaultNewRule(i),D={unitId:m,subUnitId:c,rule:w};await n.executeCommand(E.AddSheetDataValidationCommand.id,D),r.setActiveRule({unitId:m,subUnitId:c,rule:w})},f=()=>{n.executeCommand(E.RemoveSheetAllDataValidationCommand.id,{unitId:m,subUnitId:c})},V=(w=>{const D=a.getCurrentUnitForType(o.UniverInstanceType.UNIVER_SHEET),M=D.getActiveSheet(),I=D.getUnitId(),C=M.getSheetId();return w.map(O=>X.checkRangesEditablePermission(i,I,C,O.ranges)?{...O}:{...O,disable:!0})})(d),_=V==null?void 0:V.some(w=>w.disable);return h.jsxs("div",{className:ke.dataValidationList,children:[V==null?void 0:V.map(w=>{var D;return h.jsx(Pn,{unitId:m,subUnitId:c,onClick:()=>{w.disable||r.setActiveRule({unitId:m,subUnitId:c,rule:w})},rule:w,disable:(D=w.disable)!=null?D:!1},w.uid)}),h.jsxs("div",{className:ke.dataValidationListButtons,children:[d.length&&!_?h.jsx(b.Button,{className:ke.dataValidationListButton,onClick:f,children:s.t("dataValidation.panel.removeAll")}):null,h.jsx(b.Button,{className:ke.dataValidationListButton,type:"primary",onClick:S,children:s.t("dataValidation.panel.add")})]})]})}const Fn=()=>{const e=o.useDependency(ue),t=z.useObservable(e.activeRule$,e.activeRule);return t?h.jsx(Tn,{},t.rule.uid):h.jsx(jn,{})},We="data-validation.list.dropdown",lt="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=E.createDefaultNewRule(e),s=e.get(o.ICommandService),d=n.getUnitId(),l=i.getSheetId(),u={rule:r,unitId:d,subUnitId:l};return s.syncExecuteCommand(E.AddSheetDataValidationCommand.id,u)?(s.syncExecuteCommand(_e.id,{ruleId:r.uid,isAdd:!0}),!0):!1}};var xn=Object.defineProperty,Nn=Object.getOwnPropertyDescriptor,Un=(e,t,a,n)=>{for(var i=n>1?void 0:n?Nn(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&&xn(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),d=(t=s==null?void 0:s.alert)==null?void 0:t.location;if(d&&d.row===e.location.row&&d.col===e.location.col&&d.subUnitId===e.location.subUnitId&&d.unitId===e.location.unitId){this._cellAlertManagerService.removeAlert(Ce);return}const l=this._dataValidationModel.getValidator(i.type);if(!l){this._cellAlertManagerService.removeAlert(Ce);return}this._cellAlertManagerService.showAlert({type:B.CellAlertType.ERROR,title:this._localeService.t("dataValidation.error.title"),message:l==null?void 0:l.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=Un([Ve(0,o.Inject(B.HoverManagerService)),Ve(1,o.Inject(B.CellAlertManagerService)),Ve(2,o.IUniverInstanceService),Ve(3,o.Inject(o.LocaleService)),Ve(4,z.IZenZoneService),Ve(5,o.Inject(E.SheetDataValidationModel))],Ae);var Bn=Object.defineProperty,kn=Object.getOwnPropertyDescriptor,Wn=(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&&Bn(t,a,i),i},dt=(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:d,subUnitId:l}=n,u=this._sheetDataValidationModel.getRuleObjectMatrix(d,l).clone(),p=B.virtualizeDiscreteRanges([r,s]),[m,c]=p.ranges,{mapFunc:S}=p,f={row:m.startRow,col:m.startColumn},y=B.getAutoFillRepeatRange(m,c),V=new o.ObjectMatrix,_=new Set;y.forEach(C=>{const v=C.repeatStartCell,O=C.relativeRange,j={startRow:f.row,startColumn:f.col,endColumn:f.col,endRow:f.row},k={startRow:v.row,startColumn:v.col,endColumn:v.col,endRow:v.row};o.Range.foreach(O,(A,T)=>{const F=o.Rectangle.getPositionRange({startRow:A,startColumn:T,endColumn:T,endRow:A},j),{row:x,col:N}=S(F.startRow,F.startColumn),W=this._sheetDataValidationModel.getRuleIdByLocation(d,l,x,N)||"",G=o.Rectangle.getPositionRange({startRow:A,startColumn:T,endColumn:T,endRow:A},k),{row:Z,col:q}=S(G.startRow,G.startColumn);V.setValue(Z,q,W),_.add(W)})});const w=Array.from(_).map(C=>({id:C,ranges:o.queryObjectMatrix(V,v=>v===C)}));u.addRangeRules(w);const D=u.diff(this._sheetDataValidationModel.getRules(d,l)),{redoMutations:M,undoMutations:I}=E.getDataValidationDiffMutations(d,l,D,this._injector,"patched",i===B.APPLY_TYPE.ONLY_FORMAT);return{undos:I,redos:M}},a={id:E.DATA_VALIDATION_PLUGIN_NAME,onBeforeFillData:n=>{const{source:i,unitId:r,subUnitId:s}=n;for(const d of i.rows)for(const l of i.cols){const u=this._sheetDataValidationModel.getRuleByLocation(r,s,d,l);if(u&&u.type===o.DataValidationType.CHECKBOX){this._autoFillService.setDisableApplyType(B.APPLY_TYPE.SERIES,!0);return}}},onFillData:(n,i,r)=>r===B.APPLY_TYPE.COPY||r===B.APPLY_TYPE.ONLY_FORMAT||r===B.APPLY_TYPE.SERIES?t(n,r):e(),onAfterFillData:()=>{}};this.disposeWithMe(this._autoFillService.addHook(a))}};Ee=Wn([dt(0,B.IAutoFillService),dt(1,o.Inject(E.SheetDataValidationModel)),dt(2,o.Inject(o.Injector))],Ee);var $n=Object.defineProperty,Hn=Object.getOwnPropertyDescriptor,Yn=(e,t,a,n)=>{for(var i=n>1?void 0:n?Hn(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&&$n(t,a,i),i},ct=(e,t)=>(a,n)=>t(a,n,e);let Re=class extends o.Disposable{constructor(t,a,n){super();L(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,i)=>{const{copyType:r=B.COPY_TYPE.COPY,pasteType:s}=i,{range:d}=t||{},{range:l,unitId:u,subUnitId:p}=a;return this._generateMutations(l,{copyType:r,pasteType:s,copyRange:d,unitId:u,subUnitId:p})}})}_collect(t,a,n){const i=new o.ObjectMatrix;this._copyInfo={unitId:t,subUnitId:a,matrix:i};const r=this._injector.invoke(l=>B.rangeToDiscreteRange(n,l,t,a));if(!r)return;const{rows:s,cols:d}=r;s.forEach((l,u)=>{d.forEach((p,m)=>{const c=this._sheetDataValidationModel.getRuleIdByLocation(t,a,l,p);i.setValue(u,m,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:i,subUnitId:r}=this._copyInfo;if(a.unitId!==i||r!==a.subUnitId){const s=this._sheetDataValidationModel.getRuleObjectMatrix(a.unitId,a.subUnitId).clone(),d=new o.ObjectMatrix,l=new Set,{ranges:[u,p],mapFunc:m}=B.virtualizeDiscreteRanges([a.copyRange,t]),c=B.getRepeatRange(u,p,!0),S=new Map;c.forEach(({startRange:_})=>{var w;(w=this._copyInfo)==null||w.matrix.forValue((D,M,I)=>{const C=o.Rectangle.getPositionRange({startRow:D,endRow:D,startColumn:M,endColumn:M},_),v=`${r}-${I}`,O=this._sheetDataValidationModel.getRuleById(i,r,I);!this._sheetDataValidationModel.getRuleById(a.unitId,a.subUnitId,v)&&O&&S.set(v,{...O,uid:v});const{row:j,col:k}=m(C.startRow,C.startColumn);l.add(v),d.setValue(j,k,v)})});const f=Array.from(l).map(_=>({id:_,ranges:o.queryObjectMatrix(d,w=>w===_)}));s.addRangeRules(f);const{redoMutations:y,undoMutations:V}=E.getDataValidationDiffMutations(a.unitId,a.subUnitId,s.diffWithAddition(this._sheetDataValidationModel.getRules(a.unitId,a.subUnitId),S.values()),this._injector,"patched",!1);return{redos:y,undos:V}}else{const s=this._sheetDataValidationModel.getRuleObjectMatrix(i,r).clone(),d=new o.ObjectMatrix,l=new Set,{ranges:[u,p],mapFunc:m}=B.virtualizeDiscreteRanges([a.copyRange,t]);B.getRepeatRange(u,p,!0).forEach(({startRange:V})=>{var _;(_=this._copyInfo)==null||_.matrix.forValue((w,D,M)=>{const I=o.Rectangle.getPositionRange({startRow:w,endRow:w,startColumn:D,endColumn:D},V),{row:C,col:v}=m(I.startRow,I.startColumn);d.setValue(C,v,M),l.add(M)})});const S=Array.from(l).map(V=>({id:V,ranges:o.queryObjectMatrix(d,_=>_===V)}));s.addRangeRules(S);const{redoMutations:f,undoMutations:y}=E.getDataValidationDiffMutations(i,r,s.diff(this._sheetDataValidationModel.getRules(i,r)),this._injector,"patched",!1);return{redos:f,undos:y}}}};Re=Yn([ct(0,B.ISheetClipboardService),ct(1,o.Inject(E.SheetDataValidationModel)),ct(2,o.Inject(o.Injector))],Re);var Xn=Object.defineProperty,zn=Object.getOwnPropertyDescriptor,Kn=(e,t,a,n)=>{for(var i=n>1?void 0:n?zn(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&&Xn(t,a,i),i},ut=(e,t)=>(a,n)=>t(a,n,e);let Me=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===E.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===E.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")))}))}};Me=Kn([ut(0,o.Inject(o.LocaleService)),ut(1,o.ICommandService),ut(2,o.Inject(X.SheetPermissionCheckController))],Me);const Nt="data-validation-single",Ut="sheet.menu.data-validation";function qn(e){return{id:Ut,type:z.MenuItemType.SUBITEMS,icon:Nt,tooltip:"dataValidation.title",hidden$:z.getMenuHiddenObservable(e,o.UniverInstanceType.UNIVER_SHEET),disabled$:B.getCurrentRangeDisable$(e,{workbookTypes:[X.WorkbookEditablePermission],worksheetTypes:[X.WorksheetSetCellStylePermission,X.WorksheetEditPermission],rangeTypes:[X.RangeProtectionPermissionEditPoint]})}}function Gn(e){return{id:_e.id,title:"dataValidation.panel.title",type:z.MenuItemType.BUTTON}}function Zn(e){return{id:$e.id,title:"dataValidation.panel.add",type:z.MenuItemType.BUTTON}}const Jn={[z.RibbonStartGroup.FORMULAS_INSERT]:{[Ut]:{order:9,menuItemFactory:qn,[_e.id]:{order:0,menuItemFactory:Gn},[$e.id]:{order:1,menuItemFactory:Zn}}}};var Qn=Object.defineProperty,ea=Object.getOwnPropertyDescriptor,Bt=(e,t,a,n)=>{for(var i=n>1?void 0:n?ea(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&&Qn(t,a,i),i},Q=(e,t)=>(a,n)=>t(a,n,e);const kt={tr:{size:6,color:"#fe4b4b"}};let be=class extends o.RxDisposable{constructor(e,t,a,n,i,r,s,d,l,u,p){super(),this._commandService=e,this._menuManagerService=t,this._renderManagerService=a,this._univerInstanceService=n,this._autoHeightController=i,this._dropdownManagerService=r,this._sheetDataValidationModel=s,this._dataValidatorRegistryService=d,this._sheetInterceptorService=l,this._dataValidationCacheService=u,this._editorBridgeService=p,this._initMenu(),this._initDropdown(),this._initViewModelIntercept(),this._initAutoHeight()}_initMenu(){this._menuManagerService.mergeMenu(Jn)}_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,d=this._univerInstanceService.getUniverSheetInstance(n);if(!d)return;const l=this._sheetDataValidationModel.getRuleByLocation(n,i,r,s);if(!l)return;const u=this._dataValidatorRegistryService.getValidatorItem(l.type);if(!(u!=null&&u.dropdown))return;const p=d.getActiveSheet();if(!p)return;const m=this._dropdownManagerService.activeDropdown,c=m==null?void 0:m.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:d,worksheet:p},componentKey:u.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 _,w,D,M,I;const{row:n,col:i,unitId:r,subUnitId:s,workbook:d,worksheet:l}=t,u=this._sheetDataValidationModel.getRuleIdByLocation(r,s,n,i);if(!u)return a(e);const p=this._sheetDataValidationModel.getRuleById(r,s,u);if(!p)return a(e);const m=(_=this._dataValidationCacheService.getValue(r,s,n,i))!=null?_:o.DataValidationStatus.VALID,c=this._dataValidatorRegistryService.getValidatorItem(p.type),S=t.rawData;let f;const y={get value(){var C;return f!==void 0||(f=(C=E.getCellValueOrigin(S))!=null?C:null),f}},V={get value(){var C;return`${(C=y.value)!=null?C:""}`}};return a({...e,markers:{...e==null?void 0:e.markers,...m===o.DataValidationStatus.INVALID?kt: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:((D=e==null?void 0:e.fontRenderExtension)==null?void 0:D.isSkip)||((M=c==null?void 0:c.skipDefaultFontRender)==null?void 0:M.call(c,p,y.value,t))},interceptorStyle:{...e==null?void 0:e.interceptorStyle,...c==null?void 0:c.getExtraStyle(p,V.value,{get style(){const C=d.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,i)},interceptorAutoHeight:()=>{var j,k,A,T,F,x;const C=(k=(j=this._renderManagerService.getRenderById(r))==null?void 0:j.with(B.SheetSkeletonManagerService).getWorksheetSkeleton(s))==null?void 0:k.skeleton;if(!C)return;const v=C.worksheet.getMergedCell(n,i),O={data:e,style:C.getsStyles().getStyleByCell(e),primaryWithCoord:C.getCellWithCoordByIndex((A=v==null?void 0:v.startRow)!=null?A:n,(T=v==null?void 0:v.startColumn)!=null?T:i),unitId:r,subUnitId:s,row:n,col:i,workbook:d,worksheet:l};return(x=(F=c==null?void 0:c.canvasRender)==null?void 0:F.calcCellAutoHeight)==null?void 0:x.call(F,O)},interceptorAutoWidth:()=>{var j,k,A,T,F,x;const C=(k=(j=this._renderManagerService.getRenderById(r))==null?void 0:j.with(B.SheetSkeletonManagerService).getWorksheetSkeleton(s))==null?void 0:k.skeleton;if(!C)return;const v=C.worksheet.getMergedCell(n,i),O={data:e,style:C.getsStyles().getStyleByCell(e),primaryWithCoord:C.getCellWithCoordByIndex((A=v==null?void 0:v.startRow)!=null?A:n,(T=v==null?void 0:v.startColumn)!=null?T:i),unitId:r,subUnitId:s,row:n,col:i,workbook:d,worksheet:l};return(x=(F=c==null?void 0:c.canvasRender)==null?void 0:F.calcCellAutoWidth)==null?void 0:x.call(F,O)},coverable:((I=e==null?void 0:e.coverable)!=null?I:!0)&&!(p.type===o.DataValidationType.LIST||p.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)}})}};be=Bt([Q(0,o.ICommandService),Q(1,z.IMenuManagerService),Q(2,U.IRenderManagerService),Q(3,o.IUniverInstanceService),Q(4,o.Inject(B.AutoHeightController)),Q(5,o.Inject(ve)),Q(6,o.Inject(E.SheetDataValidationModel)),Q(7,o.Inject(J.DataValidatorRegistryService)),Q(8,o.Inject(X.SheetInterceptorService)),Q(9,o.Inject(E.DataValidationCacheService)),Q(10,o.Optional(B.IEditorBridgeService))],be);let Wt=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 V,_,w,D,M;const{row:n,col:i,unitId:r,subUnitId:s,workbook:d,worksheet:l}=t,u=this._sheetDataValidationModel.getRuleIdByLocation(r,s,n,i);if(!u)return a(e);const p=this._sheetDataValidationModel.getRuleById(r,s,u);if(!p)return a(e);const m=(V=this._dataValidationCacheService.getValue(r,s,n,i))!=null?V:o.DataValidationStatus.VALID,c=this._dataValidatorRegistryService.getValidatorItem(p.type),S=l.getCellRaw(n,i),f=E.getCellValueOrigin(S),y=`${f!=null?f:""}`;return a({...e,markers:{...e==null?void 0:e.markers,...m===o.DataValidationStatus.INVALID?kt:null},customRender:[...(_=e==null?void 0:e.customRender)!=null?_:[],...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)||((D=c==null?void 0:c.skipDefaultFontRender)==null?void 0:D.call(c,p,f,t))},interceptorStyle:{...e==null?void 0:e.interceptorStyle,...c==null?void 0:c.getExtraStyle(p,y,{get style(){const I=d.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 O,j,k,A,T,F;const I=(j=(O=this._renderManagerService.getRenderById(r))==null?void 0:O.with(B.SheetSkeletonManagerService).getWorksheetSkeleton(s))==null?void 0:j.skeleton;if(!I)return;const C=I.worksheet.getMergedCell(n,i),v={data:e,style:I.getsStyles().getStyleByCell(e),primaryWithCoord:I.getCellWithCoordByIndex((k=C==null?void 0:C.startRow)!=null?k:n,(A=C==null?void 0:C.startColumn)!=null?A:i),unitId:r,subUnitId:s,row:n,col:i,workbook:d,worksheet:l};return(F=(T=c==null?void 0:c.canvasRender)==null?void 0:T.calcCellAutoHeight)==null?void 0:F.call(T,v)},coverable:((M=e==null?void 0:e.coverable)!=null?M:!0)&&!(p.type===o.DataValidationType.LIST||p.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)}})}};Wt=Bt([Q(0,o.ICommandService),Q(1,U.IRenderManagerService),Q(2,o.Inject(B.AutoHeightController)),Q(3,o.Inject(J.DataValidatorRegistryService)),Q(4,o.Inject(X.SheetInterceptorService)),Q(5,o.Inject(E.SheetDataValidationModel)),Q(6,o.Inject(E.DataValidationCacheService))],Wt);var ta=Object.defineProperty,na=Object.getOwnPropertyDescriptor,aa=(e,t,a,n)=>{for(var i=n>1?void 0:n?na(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&&ta(t,a,i),i},$t=(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=aa([$t(1,o.Inject(E.SheetDataValidationModel)),$t(2,o.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"},ia=e=>{const{isTwoFormula:t=!1,value:a,onChange:n,showError:i,validResult:r}=e,s=o.useDependency(o.LocaleService),d=i?r==null?void 0:r.formula1:"",l=i?r==null?void 0:r.formula2:"";return t?h.jsxs(h.Fragment,{children:[h.jsx(b.FormLayout,{error:d,children:h.jsx(b.Input,{className:ne.dataValidationFormula,placeholder:s.t("dataValidation.panel.formulaPlaceholder"),value:a==null?void 0:a.formula1,onChange:u=>{n==null||n({...a,formula1:u})}})}),h.jsx("div",{className:ne.dataValidationFormulaAnd,children:s.t("dataValidation.panel.formulaAnd")}),h.jsx(b.FormLayout,{error:l,children:h.jsx(b.Input,{className:ne.dataValidationFormula,placeholder:s.t("dataValidation.panel.formulaPlaceholder"),value:a==null?void 0:a.formula2,onChange:u=>{n==null||n({...a,formula2:u})}})})]}):h.jsx(b.FormLayout,{error:d,children:h.jsx(b.Input,{className:ne.dataValidationFormula,placeholder:s.t("dataValidation.panel.formulaPlaceholder"),value:a==null?void 0:a.formula1,onChange:u=>{n==null||n({formula1:u})}})})};function oa(e){const{value:t,onChange:a,showError:n,validResult:i}=e,r=o.useDependency(o.LocaleService),s=n?i==null?void 0:i.formula1:"",d=n?i==null?void 0:i.formula2:"",[l,u]=g.useState(!((t==null?void 0:t.formula1)===void 0&&(t==null?void 0:t.formula2)===void 0));return h.jsxs(h.Fragment,{children:[h.jsx(b.FormLayout,{children:h.jsx(b.Checkbox,{checked:l,onChange:p=>{p?u(!0):(u(!1),a==null||a({...t,formula1:void 0,formula2:void 0}))},children:r.t("dataValidation.checkbox.tips")})}),l?h.jsx(b.FormLayout,{label:r.t("dataValidation.checkbox.checked"),error:s,children:h.jsx(b.Input,{className:ne.dataValidationFormula,placeholder:r.t("dataValidation.panel.valuePlaceholder"),value:t==null?void 0:t.formula1,onChange:p=>{a==null||a({...t,formula1:p||void 0})}})}):null,l?h.jsx(b.FormLayout,{label:r.t("dataValidation.checkbox.unchecked"),error:d,children:h.jsx(b.Input,{className:ne.dataValidationFormula,placeholder:r.t("dataValidation.panel.valuePlaceholder"),value:t==null?void 0:t.formula2,onChange:p=>{a==null||a({...t,formula2:p||void 0})}})}):null]})}function ra(e){var m;const{unitId:t,subUnitId:a,value:n,onChange:i,showError:r,validResult:s}=e,d=r?s==null?void 0:s.formula1:void 0,l=g.useRef({}),[u,p]=g.useState(!1);return z.useSidebarClick(c=>{var f;const S=(f=l.current)==null?void 0:f.handleOutClick;S&&S(c,()=>p(!1))}),h.jsx(nt.FormulaEditor,{initValue:(m=n==null?void 0:n.formula1)!=null?m:"",unitId:t,subUnitId:a,isFocus:u,onChange:c=>{const S=(c!=null?c:"").trim();S!==(n==null?void 0:n.formula1)&&(i==null||i({...n,formula1:S}))},errorText:d,onFocus:()=>p(!0),actions:l.current,isSupportAcrossSheet:!0})}function Ht(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=Ht(e[t]))&&(n&&(n+=" "),n+=a)}else for(a in e)e[a]&&(n&&(n+=" "),n+=a);return n}function sa(){for(var e,t,a=0,n="",i=arguments.length;a<i;a++)(e=arguments[a])&&(t=Ht(e))&&(n&&(n+=" "),n+=t);return n}const la=["#FFFFFF","#FEE7E7","#FEF0E6","#EFFBD0","#E4F4FE","#E8ECFD","#F1EAFA","#FDE8F3","#E5E5E5","#FDCECE","#FDC49B","#DEF6A2","#9FDAFF","#D0D9FB","#E3D5F6","#FBD0E8","#656565","#FE4B4B","#FF8C51","#8BBB11","#0B9EFB","#3A60F7","#9E6DE3","#F248A6"],da=e=>{const{value:t,onChange:a,disabled:n}=e,[i,r]=g.useState(!1);return h.jsx(b.Select,{disabled:n,open:i,onDropdownVisibleChange:r,dropdownStyle:{width:112},style:{width:96,cursor:"pointer"},className:ne.dataValidationFormulaColorSelect,value:t,onChange:a,labelRender:s=>h.jsx("div",{className:ne.dataValidationFormulaColorItem,style:{background:s.value,marginTop:5}}),dropdownRender:()=>h.jsx("div",{className:ne.dataValidationFormulaColorSelectPanel,children:la.map(s=>h.jsx("div",{onClick:()=>{a(s),r(!1)},className:ne.dataValidationFormulaColorItem,style:{background:s}},s))})})},Yt=e=>{const{item:t,commonProps:a,style:n}=e,{onItemChange:i,onItemDelete:r}=a;return h.jsxs("div",{className:ne.dataValidationFormulaListItem,style:n,children:[t.isRef?null:h.jsx("div",{className:sa(ne.dataValidationFormulaListItemDrag,"draggableHandle"),children:h.jsx(Pt,{})}),h.jsx(da,{value:t.color,onChange:s=>{i(t.id,t.label,s)}}),h.jsx(b.Input,{disabled:t.isRef,value:t.label,onChange:s=>{i(t.id,s,t.color)}}),t.isRef?null:h.jsx("div",{className:ne.dataValidationFormulaListItemIcon,children:h.jsx(it,{onClick:()=>r(t.id)})})]})};function ca(e){const{value:t,onChange:a=()=>{},unitId:n,subUnitId:i,validResult:r,showError:s,ruleId:d}=e,{formula1:l="",formula2:u=""}=t||{},p=g.useRef(null),[m,c]=g.useState(()=>o.isFormulaString(l)?"1":"0"),[S,f]=g.useState(m==="1"?l:"="),[y,V]=g.useState(m==="1"?l:"="),_=o.useDependency(o.LocaleService),w=o.useDependency(J.DataValidatorRegistryService),D=o.useDependency(J.DataValidationModel),M=o.useDependency(E.DataValidationFormulaController),[I,C]=g.useState(()=>u.split(",")),v=w.getValidatorItem(o.DataValidationType.LIST),[O,j]=g.useState([]),[k,A]=g.useState(""),T=s?r==null?void 0:r.formula1:"",F=g.useMemo(()=>D.ruleChange$.pipe(re.debounceTime(16)),[]),x=z.useObservable(F),N=z.useEvent(a);g.useEffect(()=>{(async()=>{await new Promise(H=>{setTimeout(()=>H(!0),100)});const R=D.getRuleById(n,i,d),$=R==null?void 0:R.formula1;if(o.isFormulaString($)&&v&&R){const H=await v.getListAsync(R,n,i);j(H)}})()},[D,x,v,d,i,n]),g.useEffect(()=>{o.isFormulaString(l)&&l!==y&&(f(l),V(y))},[y,l]);const[W,G]=g.useState(()=>{const R=m!=="1"?E.deserializeListOptions(l):[],$=u.split(",");return R.map((H,K)=>({label:H,color:$[K]||Ie,isRef:!1,id:o.Tools.generateRandomId(4)}))}),Z=(R,$,H)=>{const K=W.find(ge=>ge.id===R);K&&(K.label=$,K.color=H,G([...W]))},q=R=>{const $=W.findIndex(H=>H.id===R);$!==-1&&(W.splice($,1),G([...W]))},ee=u.split(","),te=g.useMemo(()=>O.map((R,$)=>({label:R,color:ee[$]||Ie,id:`${$}`,isRef:!0})),[ee,O]),ae=(R,$,H)=>{const K=[...I];K[+R]=H,C(K),N({formula1:l,formula2:K.join(",")})},ie=()=>{G([...W,{label:"",color:Ie,isRef:!1,id:o.Tools.generateRandomId(4)}])};g.useEffect(()=>{if(m==="1")return;const R=new Set,$=[];W.map(H=>({labelList:H.label.split(","),item:H})).forEach(({item:H,labelList:K})=>{K.forEach(ge=>{R.has(ge)||(R.add(ge),$.push({label:ge,color:H.color}))})}),N({formula1:E.serializeListOptions($.map(H=>H.label)),formula2:$.map(H=>H.color===Ie?"":H.color).join(",")})},[W,N,m,y,I]);const le=g.useMemo(()=>async R=>{if(!o.isFormulaString(R)){N==null||N({formula1:"",formula2:u});return}M.getFormulaRefCheck(R)?(N==null||N({formula1:o.isFormulaString(R)?R:"",formula2:u}),A("")):(N==null||N({formula1:"",formula2:u}),f("="),A(_.t("dataValidation.validFail.formulaError")))},[u,N]),oe=g.useRef({}),[de,P]=g.useState(!1);return z.useSidebarClick(R=>{var H;const $=(H=oe.current)==null?void 0:H.handleOutClick;$&&$(R,()=>P(!1))}),h.jsxs(h.Fragment,{children:[h.jsx(b.FormLayout,{label:_.t("dataValidation.list.options"),children:h.jsxs(b.RadioGroup,{value:m,onChange:R=>{c(R),f(y),R==="1"&&N({formula1:y==="="?"":y,formula2:I.join(",")})},children:[h.jsx(b.Radio,{value:"0",children:_.t("dataValidation.list.customOptions")}),h.jsx(b.Radio,{value:"1",children:_.t("dataValidation.list.refOptions")})]})}),m==="1"?h.jsxs(h.Fragment,{children:[h.jsx(nt.FormulaEditor,{initValue:S,unitId:n,subUnitId:i,isFocus:de,onChange:(R="")=>{const $=(R!=null?R:"").trim();V($),le($)},errorText:T||k||void 0,onFocus:()=>P(!0),actions:oe.current,isSupportAcrossSheet:!0}),h.jsx("div",{ref:p,style:{marginTop:"12px"},children:te.map(R=>h.jsx(Yt,{item:R,commonProps:{onItemChange:ae},style:{marginBottom:12}},R.id))})]}):h.jsx(b.FormLayout,{error:T,children:h.jsxs("div",{ref:p,style:{marginTop:"-12px"},children:[h.jsx(b.DraggableList,{list:W,onListChange:G,rowHeight:32,margin:[0,12],draggableHandle:".draggableHandle",itemRender:R=>h.jsx(Yt,{item:R,commonProps:{onItemChange:Z,onItemDelete:q}},R.id),idKey:"id"}),h.jsxs("a",{className:ne.dataValidationFormulaListAdd,onClick:ie,children:[h.jsx(Ot,{}),_.t("dataValidation.list.add")]})]})})]})}const Xt="data-validation.custom-formula-input",Ye="data-validation.formula-input",pt="data-validation.list-formula-input",zt="data-validation.checkbox-formula-input",ua=[[Xt,ra],[Ye,ia],[pt,ca],[zt,oa]],pa="LIST_RENDER_MODE_OPTION_INPUT";function Xe(e){var i;const{value:t,onChange:a}=e,n=o.useDependency(o.LocaleService);return h.jsx(b.FormLayout,{label:n.t("dataValidation.renderMode.label"),children:h.jsxs(b.RadioGroup,{value:`${(i=t.renderMode)!=null?i:o.DataValidationRenderMode.CUSTOM}`,onChange:r=>a({...t,renderMode:+r}),children:[h.jsx(b.Radio,{value:`${o.DataValidationRenderMode.CUSTOM}`,children:n.t("dataValidation.renderMode.chip")}),h.jsx(b.Radio,{value:`${o.DataValidationRenderMode.ARROW}`,children:n.t("dataValidation.renderMode.arrow")}),h.jsx(b.Radio,{value:`${o.DataValidationRenderMode.TEXT}`,children:n.t("dataValidation.renderMode.text")})]})})}Xe.componentKey=pa;const ha="DATE_SHOW_TIME_OPTION";function ze(e){var i;const{value:t,onChange:a}=e,n=o.useDependency(o.LocaleService);return h.jsx(b.FormLayout,{children:h.jsx(b.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")})})}ze.componentKey=ha;var ma=Object.defineProperty,fa=Object.getOwnPropertyDescriptor,va=(e,t,a,n)=>{for(var i=n>1?void 0:n?fa(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&&ma(t,a,i),i},Fe=(e,t)=>(a,n)=>t(a,n,e);const Ke=6;let ht=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 u,p,m;const{vt:a,ht:n}=t||{},i=e.endX-e.startX-Ke*2,r=e.endY-e.startY,s=((u=t==null?void 0:t.fs)!=null?u:10)*1.6;let d=0,l=0;switch(a){case o.VerticalAlign.TOP:l=0;break;case o.VerticalAlign.BOTTOM:l=0+(r-s);break;default:l=0+(r-s)/2;break}switch(n){case o.HorizontalAlign.LEFT:d=Ke;break;case o.HorizontalAlign.RIGHT:d=Ke+(i-s);break;default:d=Ke+(i-s)/2;break}return{left:e.startX+d,top:e.startY+l,width:((p=t==null?void 0:t.fs)!=null?p:10)*1.6,height:((m=t==null?void 0:t.fs)!=null?m: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 u,p,m,c,S,f,y,V,_;const{formula1:n=E.CHECKBOX_FORMULA_1,formula2:i=E.CHECKBOX_FORMULA_2}=e,r=await this._formulaService.getRuleFormulaResult(t,a,e.uid),s=E.getFormulaResult((m=(p=(u=r==null?void 0:r[0])==null?void 0:u.result)==null?void 0:p[0])==null?void 0:m[0]),d=E.getFormulaResult((f=(S=(c=r==null?void 0:r[1])==null?void 0:c.result)==null?void 0:S[0])==null?void 0:f[0]),l=E.isLegalFormulaResult(String(s))&&E.isLegalFormulaResult(String(d));return{formula1:o.isFormulaString(n)?E.getFormulaResult((_=(V=(y=r==null?void 0:r[0])==null?void 0:y.result)==null?void 0:V[0])==null?void 0:_[0]):n,formula2:o.isFormulaString(i)?d:i,isFormulaValid:l}}drawWith(e,t){var T,F,x,N;const{style:a,primaryWithCoord:n,unitId:i,subUnitId:r,worksheet:s,row:d,col:l}=t,u=n.isMergedMainCell?n.mergeInfo:n,p=E.getCellValueOrigin(s.getCellRaw(d,l)),m=this._dataValidationModel.getRuleByLocation(i,r,d,l);if(!m)return;const c=this._dataValidationModel.getValidator(m.type);if(!c)return;const S=this._themeService.getCurrentTheme();if(!((T=c.skipDefaultFontRender)!=null&&T.call(c,m,p,{unitId:i,subUnitId:r,row:d,column:l})))return;const f=c.parseFormulaSync(m,i,r),{formula1:y}=f,V=this._calc(u,a),{a:_,d:w}=e.getTransform(),D=U.fixLineWidthByScale(V.left,_),M=U.fixLineWidthByScale(V.top,w),I=U.Transform.create().composeMatrix({left:D,top:M,scaleX:1,scaleY:1,angle:0,skewX:0,skewY:0,flipX:!1,flipY:!1}),C=u.endX-u.startX,v=u.endY-u.startY;e.save(),e.beginPath(),e.rect(u.startX,u.startY,C,v),e.clip();const O=I.getMatrix();e.transform(O[0],O[1],O[2],O[3],O[4],O[5]);const j=((F=a==null?void 0:a.fs)!=null?F:10)*1.6,k=String(p)===String(y),A=S.hyacinth500;U.CheckboxShape.drawWith(e,{checked:k,width:j,height:j,fill:(N=(x=a==null?void 0:a.cl)==null?void 0:x.rgb)!=null?N:A}),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,d=n.left+n.width,{x:l,y:u}=e;return l<=d&&l>=s&&u<=r&&u>=i}async onPointerDown(e,t){var f;if(t.button===2)return;const{primaryWithCoord:a,unitId:n,subUnitId:i,worksheet:r,row:s,col:d}=e,l=E.getCellValueOrigin(r.getCellRaw(s,d)),u=this._dataValidationModel.getRuleByLocation(n,i,s,d);if(!u)return;const p=this._dataValidationModel.getValidator(u.type);if(!p||!((f=p.skipDefaultFontRender)!=null&&f.call(p,u,l,{unitId:n,subUnitId:i,row:s,column:d})))return;const{formula1:m,formula2:c}=await this._parseFormula(u,n,i),S={range:{startColumn:a.actualColumn,endColumn:a.actualColumn,startRow:a.actualRow,endRow:a.actualRow},value:{v:String(l)===E.transformCheckboxValue(String(m))?c:m,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(U.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(U.CURSOR_TYPE.DEFAULT)}};ht=va([Fe(0,o.ICommandService),Fe(1,o.Inject(E.DataValidationFormulaService)),Fe(2,o.Inject(o.ThemeService)),Fe(3,o.Inject(U.IRenderManagerService)),Fe(4,o.Inject(E.SheetDataValidationModel))],ht);var ga=Object.defineProperty,Sa=Object.getOwnPropertyDescriptor,_a=(e,t,a,n)=>{for(var i=n>1?void 0:n?Sa(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&&ga(t,a,i),i},Ia=(e,t)=>(a,n)=>t(a,n,e);let pe=class{constructor(e){L(this,"canvasRender",null);L(this,"dropdown");L(this,"optionsInput");L(this,"formulaInput",pt);this.injector=e}};pe=_a([Ia(0,o.Inject(o.Injector))],pe);class Ca extends pe{constructor(){super(...arguments);L(this,"id",o.DataValidationType.CHECKBOX);L(this,"canvasRender",this.injector.createInstance(ht));L(this,"formulaInput",zt)}}class Da extends pe{constructor(){super(...arguments);L(this,"id",o.DataValidationType.CUSTOM);L(this,"formulaInput",Xt)}}const ya="data-validation.formula-input";class wa extends pe{constructor(){super(...arguments);L(this,"id",o.DataValidationType.DATE);L(this,"formulaInput",ya);L(this,"optionsInput",ze.componentKey);L(this,"dropdown",lt)}}class Va extends pe{constructor(){super(...arguments);L(this,"id",o.DataValidationType.DECIMAL);L(this,"formulaInput",Ye)}}const Kt=4,Ea=0,mt=4,qt=4,ft=6,qe=6,De=14;function Ra(e,t){const a=U.FontCache.getTextSize(e,t),n=a.width+Kt*2,{ba:i,bd:r}=a,s=i+r;return{width:n,height:s+Ea*2,ba:i}}function vt(e,t,a,n){const i=De+ft*2,r=a-i,s=n-qe*2,d=e.map(c=>({layout:Ra(c,t),text:c}));let l;const u=[];d.forEach(c=>{const{layout:S}=c,{width:f,height:y}=S;!l||l.width+f+mt>r?(l={width:f,height:y,items:[{...c,left:0}]},u.push(l)):(l.items.push({...c,left:l.width+mt}),l.width=l.width+f+mt)});let p=0,m=0;return u.forEach((c,S)=>{m=Math.max(m,c.width),S===u.length-1?p+=c.height:p+=c.height+qt}),{lines:u,totalHeight:p,contentWidth:r,contentHeight:s,cellAutoHeight:p+qe*2,calcAutoWidth:m+i}}const Ma=8;class ba extends U.Shape{static drawWith(t,a){const{fontString:n,info:i,fill:r,color:s}=a,{layout:d,text:l}=i;t.save(),U.Rect.drawWith(t,{width:d.width,height:d.height,radius:Ma,fill:r||Ie}),t.translateWithPrecision(Kt,d.ba),t.font=n,t.fillStyle=s,t.fillText(l,0,0),t.restore()}}var Oa=Object.defineProperty,La=Object.getOwnPropertyDescriptor,Ta=(e,t,a,n)=>{for(var i=n>1?void 0:n?La(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&&Oa(t,a,i),i},gt=(e,t)=>(a,n)=>t(a,n,e);const Pa=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 St=class{constructor(e,t,a){L(this,"zIndex");L(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(Pa),e.restore()}drawWith(e,t,a,n){var Z,q;const{primaryWithCoord:i,row:r,col:s,style:d,data:l,subUnitId:u}=t,p=i.isMergedMainCell?i.mergeInfo:i,m=l==null?void 0:l.fontRenderExtension,{leftOffset:c=0,rightOffset:S=0,topOffset:f=0,downOffset:y=0}=m||{},V=this._ensureMap(u),_=this._generateKey(r,s),w=this._dataValidationModel.getRuleByLocation(t.unitId,t.subUnitId,r,s);if(!w)return;const D=this._dataValidationModel.getValidator(w.type);if(!D)return;const M={startX:p.startX+c,endX:p.endX-S,startY:p.startY+f,endY:p.endY-y},I=M.endX-M.startX,C=M.endY-M.startY,{cl:v}=d||{},O=(Z=typeof v=="object"?v==null?void 0:v.rgb:v)!=null?Z:"#000",j=U.getFontStyleString(d!=null?d:void 0),{vt:k,ht:A}=d||{},T=k!=null?k:o.VerticalAlign.MIDDLE,F=(q=E.getCellValueOrigin(l))!=null?q:"",x=D.parseCellValue(F),N=D.getListWithColorMap(w),W=vt(x,j,I,C);this._drawDownIcon(e,M,I,C,T),e.save(),e.translateWithPrecision(M.startX,M.startY),e.beginPath(),e.rect(0,0,I-De,C),e.clip(),e.translateWithPrecision(ft,qe);let G=0;switch(T){case o.VerticalAlign.MIDDLE:G=(W.contentHeight-W.totalHeight)/2;break;case o.VerticalAlign.BOTTOM:G=W.contentHeight-W.totalHeight;break}e.translateWithPrecision(0,G),W.lines.forEach((ee,te)=>{e.save();const{width:ae,height:ie,items:le}=ee;let oe=0;switch(A){case o.HorizontalAlign.RIGHT:oe=W.contentWidth-ae;break;case o.HorizontalAlign.CENTER:oe=(W.contentWidth-ae)/2;break}e.translate(oe,te*(ie+qt)),le.forEach(de=>{e.save(),e.translateWithPrecision(de.left,0),ba.drawWith(e,{...j,info:de,color:O,fill:N[de.text]}),e.restore()}),e.restore()}),e.restore(),V.set(_,{left:M.startX,top:M.startY,width:W.contentWidth+ft+De,height:W.contentHeight+qe*2})}calcCellAutoHeight(e){var I;const{primaryWithCoord:t,style:a,data:n,row:i,col:r}=e,s=n==null?void 0:n.fontRenderExtension,{leftOffset:d=0,rightOffset:l=0,topOffset:u=0,downOffset:p=0}=s||{},m=t.isMergedMainCell?t.mergeInfo:t,c={startX:m.startX+d,endX:m.endX-l,startY:m.startY+u,endY:m.endY-p},S=this._dataValidationModel.getRuleByLocation(e.unitId,e.subUnitId,i,r);if(!S)return;const f=this._dataValidationModel.getValidator(S.type);if(!f)return;const y=c.endX-c.startX,V=c.endY-c.startY,_=(I=E.getCellValueOrigin(n))!=null?I:"",w=f.parseCellValue(_),D=U.getFontStyleString(a!=null?a:void 0);return vt(w,D,y,V).cellAutoHeight}calcCellAutoWidth(e){var I;const{primaryWithCoord:t,style:a,data:n,row:i,col:r}=e,s=n==null?void 0:n.fontRenderExtension,{leftOffset:d=0,rightOffset:l=0,topOffset:u=0,downOffset:p=0}=s||{},m=t.isMergedMainCell?t.mergeInfo:t,c={startX:m.startX+d,endX:m.endX-l,startY:m.startY+u,endY:m.endY-p},S=this._dataValidationModel.getRuleByLocation(e.unitId,e.subUnitId,i,r);if(!S)return;const f=this._dataValidationModel.getValidator(S.type);if(!f)return;const y=c.endX-c.startX,V=c.endY-c.startY,_=(I=E.getCellValueOrigin(n))!=null?I:"",w=f.parseCellValue(_),D=U.getFontStyleString(a!=null?a:void 0);return vt(w,D,y,V).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(Ne.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(U.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(U.CURSOR_TYPE.DEFAULT)}};St=Ta([gt(0,o.ICommandService),gt(1,o.Inject(U.IRenderManagerService)),gt(2,o.Inject(E.SheetDataValidationModel))],St);class ja extends pe{constructor(){super(...arguments);L(this,"id",o.DataValidationType.LIST_MULTIPLE);L(this,"canvasRender",this.injector.createInstance(St));L(this,"dropdown",We)}}var Aa=Object.defineProperty,Fa=Object.getOwnPropertyDescriptor,xa=(e,t,a,n)=>{for(var i=n>1?void 0:n?Fa(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&&Aa(t,a,i),i},Ge=(e,t)=>(a,n)=>t(a,n,e);const ye=4,Ze=4,ce=14,he=6,Oe=4,_t=8,Na="#565656",Gt=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 Ua(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=Ua(e,a),i=new o.DocumentDataModel(n),r=new U.DocumentViewModel(i);return{documentSkeleton:U.DocumentSkeleton.create(r,t),docModel:i,docViewModel:r}}function Je(e,t,a){const{documentSkeleton:n,docModel:i,docViewModel:r}=Zt(e,t,a);return{documents:new U.Documents(`DOCUMENTS_${o.Tools.generateRandomId()}`,n,{pageMarginLeft:0,pageMarginTop:0}),documentSkeleton:n,docModel:i,docViewModel:r}}function Jt(e,t,a,n,i,r,s=!0){let d=0;const l=s?Oe:0;switch(i){case o.VerticalAlign.BOTTOM:d=t-n-l;break;case o.VerticalAlign.MIDDLE:d=(t-n)/2;break;default:d=l;break}d=Math.max(Oe,d);let u=0;switch(r){case o.HorizontalAlign.CENTER:u=(e-a)/2;break;case o.HorizontalAlign.RIGHT:u=e-a;break}return u=Math.max(he,u),{paddingLeft:u,paddingTop:d}}let It=class{constructor(e,t,a,n){L(this,"_dropdownInfoMap",new Map);L(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:d=o.DEFAULT_STYLES.pd.t,b:l=o.DEFAULT_STYLES.pd.b}=s,u=a-ce;let p;switch(r){case o.VerticalAlign.MIDDLE:p=(n-Ze)/2;break;case o.VerticalAlign.BOTTOM:p=n-l-i-Oe+(i/2-Ze/2);break;default:p=d+Oe+(i/2-Ze/2);break}e.save(),e.translateWithPrecision(t.startX+u,t.startY+p),e.fillStyle="#565656",e.fill(Gt),e.restore()}drawWith(e,t,a){const{primaryWithCoord:n,row:i,col:r,style:s,data:d,subUnitId:l}=t,u=n.isMergedMainCell?n.mergeInfo:n,p=this._dataValidationModel.getRuleByLocation(t.unitId,t.subUnitId,i,r);if(!p)return;const m=this._dataValidationModel.getValidator(p.type);if(!m)return;const c=d==null?void 0:d.fontRenderExtension,{leftOffset:S=0,rightOffset:f=0,topOffset:y=0,downOffset:V=0}=c||{};if(!p||!m||!m||m.id.indexOf(o.DataValidationType.LIST)!==0||!m.skipDefaultFontRender(p))return;const _={startX:u.startX+S,endX:u.endX-f,startY:u.startY+y,endY:u.endY-V},w=_.endX-_.startX,D=_.endY-_.startY,M=this._ensureMap(l),I=this._generateKey(i,r),C=m.getListWithColor(p),v=E.getCellValueOrigin(d),O=`${v!=null?v:""}`,j=C.find(x=>x.label===O);let{tb:k,vt:A,ht:T,pd:F}=s||{};if(k=k!=null?k:o.WrapStrategy.WRAP,A=A!=null?A:o.VerticalAlign.BOTTOM,T=T!=null?T:o.DEFAULT_STYLES.ht,F=F!=null?F:o.DEFAULT_STYLES.pd,p.renderMode===o.DataValidationRenderMode.ARROW){const{l:x=o.DEFAULT_STYLES.pd.l,t:N=o.DEFAULT_STYLES.pd.t,r:W=o.DEFAULT_STYLES.pd.r,b:G=o.DEFAULT_STYLES.pd.b}=F,Z=w-x-W-ce-4,{documentSkeleton:q,documents:ee,docModel:te}=Je(O,this._localeService,s);k===o.WrapStrategy.WRAP&&te.updateDocumentDataPageSize(Math.max(Z,1)),q.calculate(),q.getActualSize();const ae=U.getDocsSkeletonPageSize(q),{height:ie,width:le}=ae,{paddingTop:oe,paddingLeft:de}=Jt(Z,D-N-G,le,ie,A,T,!0);this._drawDownIcon(e,_,w,D,ie,A,F),e.save(),e.translateWithPrecision(_.startX+x,_.startY+N),e.beginPath(),e.rect(0,0,w-x-W,D-N-G),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(),M.set(I,{left:_.endX+x+a.rowHeaderWidth-ce,top:_.startY+N+a.columnHeaderHeight,width:ce,height:D-N-G})}else{e.save(),e.translateWithPrecision(_.startX,_.startY),e.beginPath(),e.rect(0,0,w,D),e.clip();const x=w-he*2-ye-ce-4,{documentSkeleton:N,documents:W,docModel:G}=Je(O,this._localeService,s);k===o.WrapStrategy.WRAP&&G.updateDocumentDataPageSize(Math.max(x,1)),N.calculate();const Z=U.getDocsSkeletonPageSize(N),{height:q,width:ee}=Z,{paddingTop:te,paddingLeft:ae}=Jt(x,D,ee,q,A,T);e.translateWithPrecision(he,te);const ie=Math.max(w-he*2,1),le=q;U.Rect.drawWith(e,{width:ie,height:le,fill:(j==null?void 0:j.color)||Ie,radius:_t}),e.save(),e.translateWithPrecision(ye,0),e.beginPath(),e.rect(0,0,x,q),e.clip(),e.translateWithPrecision(ae,0),W.render(e),e.restore(),e.translateWithPrecision(x+ye+4,(q-Ze)/2),e.fillStyle=Na,e.fill(Gt),e.restore(),M.set(I,{left:_.startX+he+a.rowHeaderWidth,top:_.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,d=n==null?void 0:n.fontRenderExtension,{leftOffset:l=0,rightOffset:u=0,topOffset:p=0,downOffset:m=0}=d||{},c=this._dataValidationModel.getRuleByLocation(e.unitId,e.subUnitId,i,r);if(!c||c.renderMode===o.DataValidationRenderMode.TEXT)return;const S={startX:s.startX+l,endX:s.endX-u,startY:s.startY+p,endY:s.endY-m},f=S.endX-S.startX,y=E.getCellValueOrigin(n),V=`${y!=null?y:""}`;let{tb:_,pd:w}=a||{};const{t:D=o.DEFAULT_STYLES.pd.t,b:M=o.DEFAULT_STYLES.pd.b}=w!=null?w:{};if(_=_!=null?_:o.WrapStrategy.WRAP,c.renderMode===o.DataValidationRenderMode.ARROW){const I=f-ce,{documentSkeleton:C,docModel:v}=Je(V,this._localeService,a);_===o.WrapStrategy.WRAP&&v.updateDocumentDataPageSize(Math.max(I,1)),C.calculate(),C.getActualSize();const O=U.getDocsSkeletonPageSize(C),{height:j}=O;return j+D+M+Oe*2}else{const I=f-he*2-ye-ce,{documentSkeleton:C,docModel:v}=Zt(V,this._localeService,a);_===o.WrapStrategy.WRAP&&v.updateDocumentDataPageSize(Math.max(I,1)),C.calculate();const O=U.getDocsSkeletonPageSize(C),{height:j}=O;return j+Oe*2}}calcCellAutoWidth(e){const{primaryWithCoord:t,style:a,data:n,row:i,col:r}=e,s=t.isMergedMainCell?t.mergeInfo:t,d=n==null?void 0:n.fontRenderExtension,{leftOffset:l=0,rightOffset:u=0,topOffset:p=0,downOffset:m=0}=d||{},c=this._dataValidationModel.getRuleByLocation(e.unitId,e.subUnitId,i,r);if(!c||c.renderMode===o.DataValidationRenderMode.TEXT)return;const S={startX:s.startX+l,endX:s.endX-u,startY:s.startY+p,endY:s.endY-m},f=S.endX-S.startX,y=E.getCellValueOrigin(n),V=`${y!=null?y:""}`;let{tb:_,pd:w}=a||{};const{l:D=o.DEFAULT_STYLES.pd.l,r:M=o.DEFAULT_STYLES.pd.r}=w!=null?w:{};_=_!=null?_:o.WrapStrategy.WRAP;let I=he*2+ce;switch(c.renderMode){case o.DataValidationRenderMode.ARROW:I=ce+he*2+M+D;break;case o.DataValidationRenderMode.CUSTOM:I=ce+he*2+ye*2+M+D+_t/2+1;break;default:I=ce+he*2+ye*2+M+D+_t/2+1}const C=f-I,{documentSkeleton:v,docModel:O}=Je(V,this._localeService,a);return _===o.WrapStrategy.WRAP&&O.updateDocumentDataPageSize(Math.max(C,1)),v.calculate(),v.getActualSize(),U.getDocsSkeletonPageSize(v).width+I}isHit(e,t){const{subUnitId:a,row:n,col:i}=t,s=this._ensureMap(a).get(this._generateKey(n,i)),d=this._dataValidationModel.getRuleByLocation(t.unitId,t.subUnitId,n,i);if(!d||!s||d.renderMode===o.DataValidationRenderMode.TEXT)return!1;const{top:l,left:u,width:p,height:m}=s,{x:c,y:S}=e;return c>=u&&c<=u+p&&S>=l&&S<=l+m}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(Ne.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(U.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(U.CURSOR_TYPE.DEFAULT)}};It=xa([Ge(0,o.Inject(o.LocaleService)),Ge(1,o.ICommandService),Ge(2,o.Inject(U.IRenderManagerService)),Ge(3,o.Inject(E.SheetDataValidationModel))],It);class Ba extends pe{constructor(){super(...arguments);L(this,"id",o.DataValidationType.LIST);L(this,"canvasRender",this.injector.createInstance(It));L(this,"dropdown",We);L(this,"optionsInput",Xe.componentKey);L(this,"formulaInput",pt)}}class ka extends pe{constructor(){super(...arguments);L(this,"id",o.DataValidationType.TEXT_LENGTH);L(this,"formulaInput",Ye)}}class Wa extends pe{constructor(){super(...arguments);L(this,"id",o.DataValidationType.WHOLE);L(this,"formulaInput",Ye)}}var $a=Object.defineProperty,Ha=Object.getOwnPropertyDescriptor,Ya=(e,t,a,n)=>{for(var i=n>1?void 0:n?Ha(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&&$a(t,a,i),i},Ct=(e,t)=>(a,n)=>t(a,n,e);let Le=class extends o.RxDisposable{constructor(e,t,a){super(),this._injector=e,this._componentManger=t,this._dataValidatorRegistryService=a,this._initComponents(),this._registerValidatorViews()}_initComponents(){[[Nt,bt],[xe,Fn],[At,yn],[We,Mn],[lt,ln],[Xe.componentKey,Xe],[ze.componentKey,ze],...ua].forEach(([e,t])=>{this.disposeWithMe(this._componentManger.register(e,t))})}_registerValidatorViews(){[Va,Wa,ka,wa,Ca,Ba,ja,Da].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)})}};Le=Ya([Ct(0,o.Inject(o.Injector)),Ct(1,o.Inject(z.ComponentManager)),Ct(2,o.Inject(J.DataValidatorRegistryService))],Le);var Xa=Object.defineProperty,za=Object.getOwnPropertyDescriptor,Ka=(e,t,a,n)=>{for(var i=n>1?void 0:n?za(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&&Xa(t,a,i),i},Dt=(e,t)=>(a,n)=>t(a,n,e);const qa="SHEET_DATA_VALIDATION_UI_PLUGIN";Y.UniverSheetsDataValidationUIPlugin=(Qe=class extends o.Plugin{constructor(t=Ue,a,n,i){super(),this._config=t,this._injector=a,this._commandService=n,this._configService=i;const{menu:r,...s}=o.merge({},Ue,this._config);r&&this._configService.setConfig("menu",r,{merge:!0}),this._configService.setConfig(rt,s)}onStarting(){[[ue],[ve],[Ae],[Ee],[be],[Me],[Re],[je],[Le]].forEach(t=>{this._injector.add(t)}),[$e,Ne,xt,ot,_e,Ft].forEach(t=>{this._commandService.registerCommand(t)})}onReady(){this._injector.get(Re),this._injector.get(Me),this._injector.get(je),this._injector.get(Ae),this._injector.get(U.IRenderManagerService).registerRenderModule(o.UniverInstanceType.UNIVER_SHEET,[He])}onRendered(){this._injector.get(Le),this._injector.get(be)}onSteady(){this._injector.get(Ee)}},L(Qe,"pluginName",qa),L(Qe,"type",o.UniverInstanceType.UNIVER_SHEET),Qe),Y.UniverSheetsDataValidationUIPlugin=Ka([Dt(1,o.Inject(o.Injector)),Dt(2,o.ICommandService),Dt(3,o.IConfigService)],Y.UniverSheetsDataValidationUIPlugin);var Ga=Object.defineProperty,Za=Object.getOwnPropertyDescriptor,Ja=(e,t,a,n)=>{for(var i=n>1?void 0:n?Za(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&&Ga(t,a,i),i},yt=(e,t)=>(a,n)=>t(a,n,e);const Qa="SHEET_DATA_VALIDATION_UI_PLUGIN";Y.UniverSheetsDataValidationMobileUIPlugin=(et=class extends o.Plugin{constructor(t=Ue,a,n,i){super(),this._config=t,this._injector=a,this._commandService=n,this._configService=i;const{menu:r,...s}=o.merge({},Ue,this._config);r&&this._configService.setConfig("menu",r,{merge:!0}),this._configService.setConfig(rt,s)}onStarting(){[[ue],[ve],[Ae],[Ee],[be],[Me],[Re],[Le]].forEach(t=>{this._injector.add(t)}),[$e,Ne,xt,ot,_e,Ft].forEach(t=>{this._commandService.registerCommand(t)})}onReady(){this._injector.get(Re),this._injector.get(Me),this._injector.get(U.IRenderManagerService).registerRenderModule(o.UniverInstanceType.UNIVER_SHEET,[He])}onRendered(){this._injector.get(Le),this._injector.get(be)}onSteady(){this._injector.get(Ee)}},L(et,"pluginName",Qa),L(et,"type",o.UniverInstanceType.UNIVER_SHEET),et),Y.UniverSheetsDataValidationMobileUIPlugin=Ja([yt(1,o.Inject(o.Injector)),yt(2,o.ICommandService),yt(3,o.IConfigService)],Y.UniverSheetsDataValidationMobileUIPlugin),Y.DATE_DROPDOWN_KEY=lt,Y.LIST_DROPDOWN_KEY=We,Object.defineProperty(Y,Symbol.toStringTag,{value:"Module"})});
23
23
 
24
24
 
25
25
  // index
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@univerjs/preset-sheets-data-validation",
3
- "version": "0.5.3",
3
+ "version": "0.5.4",
4
4
  "private": false,
5
5
  "description": "",
6
6
  "author": "DreamNum <developer@univer.ai>",
@@ -57,18 +57,19 @@
57
57
  "rxjs": ">=7.0.0"
58
58
  },
59
59
  "dependencies": {
60
- "@univerjs/data-validation": "0.5.3",
61
- "@univerjs/sheets-data-validation": "0.5.3",
62
- "@univerjs/sheets-data-validation-ui": "0.5.3"
60
+ "@univerjs/data-validation": "0.5.4",
61
+ "@univerjs/sheets-data-validation": "0.5.4",
62
+ "@univerjs/sheets-data-validation-ui": "0.5.4"
63
63
  },
64
64
  "devDependencies": {
65
- "@univerjs/core": "0.5.3",
65
+ "@univerjs/core": "0.5.4",
66
66
  "typescript": "^5.7.2",
67
- "@univerjs-infra/shared": "0.5.3"
67
+ "@univerjs-infra/shared": "0.5.4"
68
68
  },
69
69
  "scripts": {
70
70
  "prebuild:preset": "tsx prepare.ts",
71
- "build:preset": "tsx build.ts"
71
+ "build:preset": "tsx build.ts",
72
+ "lint:types": "tsc --noEmit"
72
73
  },
73
74
  "module": "./lib/es/index.js"
74
75
  }