@univerjs/preset-sheets-data-validation 0.5.0 → 0.5.1-nightly.202412271606
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/cjs/index.js +1 -1
- package/lib/cjs/locales/fr-FR.js +1 -0
- package/lib/es/index.js +12 -9
- package/lib/es/locales/fr-FR.js +9 -0
- package/lib/index.css +1 -1
- package/lib/types/index.d.ts +4 -4
- package/lib/types/locales/fr-FR.d.ts +2 -0
- package/lib/types/umd.d.ts +4 -0
- package/lib/umd/index.js +5 -5
- package/lib/umd/locales/fr-FR.js +6 -0
- package/package.json +11 -8
package/lib/cjs/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("@univerjs/data-validation"),
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("@univerjs/data-validation"),a=require("@univerjs/sheets-data-validation"),r=require("@univerjs/sheets-data-validation-ui");require("@univerjs/sheets-data-validation/facade");function i(){return{plugins:[t.UniverDataValidationPlugin,a.UniverSheetsDataValidationPlugin,r.UniverSheetsDataValidationUIPlugin].filter(e=>!!e)}}exports.UniverSheetsDataValidationPreset=i;Object.keys(t).forEach(e=>{e!=="default"&&!Object.prototype.hasOwnProperty.call(exports,e)&&Object.defineProperty(exports,e,{enumerable:!0,get:()=>t[e]})});Object.keys(a).forEach(e=>{e!=="default"&&!Object.prototype.hasOwnProperty.call(exports,e)&&Object.defineProperty(exports,e,{enumerable:!0,get:()=>a[e]})});Object.keys(r).forEach(e=>{e!=="default"&&!Object.prototype.hasOwnProperty.call(exports,e)&&Object.defineProperty(exports,e,{enumerable:!0,get:()=>r[e]})});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";const e=require("@univerjs/core"),r=require("@univerjs/sheets-data-validation-ui/locale/fr-FR"),s=e.Tools.deepMerge({},r);module.exports=s;
|
package/lib/es/index.js
CHANGED
|
@@ -1,16 +1,19 @@
|
|
|
1
|
-
import { UniverDataValidationPlugin as
|
|
2
|
-
|
|
3
|
-
import {
|
|
1
|
+
import { UniverDataValidationPlugin as i } from "@univerjs/data-validation";
|
|
2
|
+
export * from "@univerjs/data-validation";
|
|
3
|
+
import { UniverSheetsDataValidationPlugin as r } from "@univerjs/sheets-data-validation";
|
|
4
|
+
export * from "@univerjs/sheets-data-validation";
|
|
5
|
+
import { UniverSheetsDataValidationUIPlugin as o } from "@univerjs/sheets-data-validation-ui";
|
|
6
|
+
export * from "@univerjs/sheets-data-validation-ui";
|
|
4
7
|
import "@univerjs/sheets-data-validation/facade";
|
|
5
|
-
function
|
|
8
|
+
function l() {
|
|
6
9
|
return {
|
|
7
10
|
plugins: [
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
].filter((
|
|
11
|
+
i,
|
|
12
|
+
r,
|
|
13
|
+
o
|
|
14
|
+
].filter((t) => !!t)
|
|
12
15
|
};
|
|
13
16
|
}
|
|
14
17
|
export {
|
|
15
|
-
|
|
18
|
+
l as UniverSheetsDataValidationPreset
|
|
16
19
|
};
|
package/lib/index.css
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
.univer-dv-date-dropdown{background:#fff;border-radius:var(--border-radius-base);box-shadow:var(--box-shadow-lg);padding:var(--padding-sm)}.univer-dv-date-dropdown-btns{display:flex;justify-content:flex-end;border-top:1px solid rgb(var(--border-color));padding-top:var(--padding-sm)}.univer-dv-list-dropdown{border-radius:var(--border-radius-lg);border:1px solid rgb(var(--border-color));background:rgba(var(--color-white));box-shadow:var(--box-shadow-base);box-sizing:border-box;padding-bottom:var(--padding-xs)}.univer-dv-list-dropdown-title{padding:var(--padding-sm) 14px;color:rgb(var(--text-color));font-size:12px;line-height:1.5;flex-shrink:0;flex-grow:0}.univer-dv-list-dropdown-list{max-height:200px}.univer-dv-list-dropdown-list-container{padding:0 var(--padding-sm)}.univer-dv-list-dropdown-selected-icon{width:16px;height:16px;font-size:16px;color:rgba(var(--blue-500));flex-shrink:0;flex-grow:0;margin-left:12px}.univer-dv-list-dropdown-item-container{display:flex;flex-direction:row;align-items:center;justify-content:space-between;padding:var(--padding-xs) 6px;border-radius:6px;margin-top:4px;cursor:pointer}.univer-dv-list-dropdown-item-container:hover{background-color:rgba(var(--grey-50))}.univer-dv-list-dropdown-item{padding:0 4px;font-size:12px;font-style:normal;font-weight:400;line-height:16px;border-radius:8px;height:16px;width:fit-content;flex:0 1 auto;text-overflow:ellipsis;overflow:hidden;color:rgba(var(--color-black));white-space:nowrap}.univer-dv-list-dropdown-split{height:1px;margin:4px 0;background:rgba(var(--grey-200));flex-shrink:0;flex-grow:0}.univer-dv-list-dropdown-edit{padding:0 var(--padding-xs);flex-shrink:0;flex-grow:0}.univer-dv-list-dropdown-edit a{padding:3px 6px;font-size:12px;line-height:1.5;cursor:pointer;border-radius:6px;display:block}.univer-dv-list-dropdown-edit a:hover{background:#f5f5f5}.univer-data-validation-options-button{cursor:pointer;margin-bottom:12px;font-size:var(--font-size-sm);color:rgba(var(--color-black));display:flex;align-items:center}.univer-data-validation-options-button-icon{font-size:8px;margin-left:4px}.univer-data-validation-detail{padding:var(--padding-base) 0}.univer-data-validation-detail-form-item{width:100%}.univer-data-validation-detail-buttons{margin-top:20px;display:flex;flex-direction:row;justify-content:flex-end}.univer-data-validation-detail-button{margin-left:12px}.univer-data-validation-item-container{border-radius:var(--border-radius-base);background-color:rgba(var(--bg-color-secondary));padding:var(--padding-sm);padding-right:36px;margin-left:-8px;margin-right:-8px;box-sizing:border-box;display:flex;flex-direction:column;justify-content:space-between;cursor:pointer;position:relative;border-radius:6px;width:287px;overflow:hidden}.univer-data-validation-item-container:hover{background-color:rgba(var(--grey-50))}.univer-data-validation-item-title{font-size:var(--font-size-sm);color:rgba(var(--color-black));line-height:22px;font-weight:500;overflow:hidden;text-overflow:ellipsis}.univer-data-validation-item-content{color:rgba(var(--text-color-secondary));font-size:var(--font-size-xs);line-height:18px;overflow:hidden;text-overflow:ellipsis}.univer-data-validation-item-icon{position:absolute;top:19px;right:8px;width:20px;height:20px;display:flex;justify-content:center;align-items:center;border-radius:4px}.univer-data-validation-item-icon:hover{background:rgba(var(--grey-200))}.univer-data-validation-list{padding:var(--padding-base) 0}.univer-data-validation-list-buttons{margin-top:20px;display:flex;flex-direction:row;justify-content:flex-end}.univer-data-validation-list-button{margin-left:12px}.univer-data-validation-formula{width:100%}.univer-data-validation-formula-and{margin-top:-4px;font-size:var(--font-size-sm);color:rgba(var(--grey-400))}.univer-data-validation-formula-list-item{display:flex;padding-bottom:2px;align-items:center}.univer-data-validation-formula-list-item-icon{font-size:16px;cursor:pointer;margin-left:4px;border-radius:4px}.univer-data-validation-formula-list-item-icon:hover{background:rgba(var(--grey-100))}.univer-data-validation-formula-list-item-drag{cursor:move}.univer-data-validation-formula-list-add{color:#274fee;font-size:13px;font-weight:400;cursor:pointer;display:flex;flex-direction:row;align-items:center;border-radius:4px;padding:4px 8px;width:fit-content}.univer-data-validation-formula-list-add svg{margin-right:4px}.univer-data-validation-formula-list-add:hover{background:#274fee0d}.univer-data-validation-formula-color-select{width:92px;margin-left:4px;margin-right:8px}.univer-data-validation-formula-color-select-panel{width:112px;display:flex;flex-direction:row;justify-content:space-between;padding:12px 4px 4px 12px;flex-wrap:wrap;box-sizing:border-box}.univer-data-validation-formula-color-select-panel .univer-data-validation-formula-color-item{margin-bottom:8px;margin-right:8px;box-sizing:border-box;cursor:pointer}.univer-data-validation-formula-color-item{border-radius:3px;border:1px solid rgba(var(--grey-400));width:16px;height:16px;box-sizing:border-box;font-size:16px}
|
|
1
|
+
*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(63 131 248 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(63 131 248 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*{scrollbar-color:initial;scrollbar-width:initial}@keyframes enter{0%{opacity:var(--tw-enter-opacity, 1);transform:translate3d(var(--tw-enter-translate-x, 0),var(--tw-enter-translate-y, 0),0) scale3d(var(--tw-enter-scale, 1),var(--tw-enter-scale, 1),var(--tw-enter-scale, 1)) rotate(var(--tw-enter-rotate, 0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity, 1);transform:translate3d(var(--tw-exit-translate-x, 0),var(--tw-exit-translate-y, 0),0) scale3d(var(--tw-exit-scale, 1),var(--tw-exit-scale, 1),var(--tw-exit-scale, 1)) rotate(var(--tw-exit-rotate, 0))}}.univer-dv-date-dropdown{background:#fff;border-radius:var(--border-radius-base);box-shadow:var(--box-shadow-lg);padding:var(--padding-sm)}.univer-dv-date-dropdown-btns{display:flex;justify-content:flex-end;border-top:1px solid rgb(var(--border-color));padding-top:var(--padding-sm)}.univer-dv-list-dropdown{border-radius:var(--border-radius-lg);border:1px solid rgb(var(--border-color));background:rgba(var(--color-white));box-shadow:var(--box-shadow-base);box-sizing:border-box;padding-bottom:var(--padding-xs)}.univer-dv-list-dropdown-title{padding:var(--padding-sm) 14px;color:rgb(var(--text-color));font-size:12px;line-height:1.5;flex-shrink:0;flex-grow:0}.univer-dv-list-dropdown-list{max-height:200px}.univer-dv-list-dropdown-list-container{padding:0 var(--padding-sm)}.univer-dv-list-dropdown-selected-icon{width:16px;height:16px;font-size:16px;color:rgba(var(--blue-500));flex-shrink:0;flex-grow:0;margin-left:12px}.univer-dv-list-dropdown-item-container{display:flex;flex-direction:row;align-items:center;justify-content:space-between;padding:var(--padding-xs) 6px;border-radius:6px;margin-top:4px;cursor:pointer}.univer-dv-list-dropdown-item-container:hover{background-color:rgba(var(--grey-50))}.univer-dv-list-dropdown-item{padding:0 4px;font-size:12px;font-style:normal;font-weight:400;line-height:16px;border-radius:8px;height:16px;width:-moz-fit-content;width:fit-content;flex:0 1 auto;text-overflow:ellipsis;overflow:hidden;color:rgba(var(--color-black));white-space:nowrap}.univer-dv-list-dropdown-split{height:1px;margin:4px 0;background:rgba(var(--grey-200));flex-shrink:0;flex-grow:0}.univer-dv-list-dropdown-edit{padding:0 var(--padding-xs);flex-shrink:0;flex-grow:0}.univer-dv-list-dropdown-edit a{padding:3px 6px;font-size:12px;line-height:1.5;cursor:pointer;border-radius:6px;display:block}.univer-dv-list-dropdown-edit a:hover{background:#f5f5f5}.univer-data-validation-options-button{cursor:pointer;margin-bottom:12px;font-size:var(--font-size-sm);color:rgba(var(--color-black));display:flex;align-items:center}.univer-data-validation-options-button-icon{font-size:8px;margin-left:4px}.univer-data-validation-detail{padding:var(--padding-base) 0}.univer-data-validation-detail-form-item{width:100%}.univer-data-validation-detail-buttons{margin-top:20px;display:flex;flex-direction:row;justify-content:flex-end}.univer-data-validation-detail-button{margin-left:12px}.univer-data-validation-item-container{border-radius:var(--border-radius-base);background-color:rgba(var(--bg-color-secondary));padding:var(--padding-sm);padding-right:36px;margin-left:-8px;margin-right:-8px;box-sizing:border-box;display:flex;flex-direction:column;justify-content:space-between;cursor:pointer;position:relative;border-radius:6px;width:287px;overflow:hidden}.univer-data-validation-item-container:hover{background-color:rgba(var(--grey-50))}.univer-data-validation-item-title{font-size:var(--font-size-sm);color:rgba(var(--color-black));line-height:22px;font-weight:500;overflow:hidden;text-overflow:ellipsis}.univer-data-validation-item-content{color:rgba(var(--text-color-secondary));font-size:var(--font-size-xs);line-height:18px;overflow:hidden;text-overflow:ellipsis}.univer-data-validation-item-icon{position:absolute;top:19px;right:8px;width:20px;height:20px;display:flex;justify-content:center;align-items:center;border-radius:4px}.univer-data-validation-item-icon:hover{background:rgba(var(--grey-200))}.univer-data-validation-list{padding:var(--padding-base) 0}.univer-data-validation-list-buttons{margin-top:20px;display:flex;flex-direction:row;justify-content:flex-end}.univer-data-validation-list-button{margin-left:12px}.univer-data-validation-formula{width:100%}.univer-data-validation-formula-and{margin-top:-4px;font-size:var(--font-size-sm);color:rgba(var(--grey-400))}.univer-data-validation-formula-list-item{display:flex;padding-bottom:2px;align-items:center}.univer-data-validation-formula-list-item-icon{font-size:16px;cursor:pointer;margin-left:4px;border-radius:4px}.univer-data-validation-formula-list-item-icon:hover{background:rgba(var(--grey-100))}.univer-data-validation-formula-list-item-drag{cursor:move}.univer-data-validation-formula-list-add{color:#274fee;font-size:13px;font-weight:400;cursor:pointer;display:flex;flex-direction:row;align-items:center;border-radius:4px;padding:4px 8px;width:-moz-fit-content;width:fit-content}.univer-data-validation-formula-list-add svg{margin-right:4px}.univer-data-validation-formula-list-add:hover{background:#274fee0d}.univer-data-validation-formula-color-select{width:92px;margin-left:4px;margin-right:8px}.univer-data-validation-formula-color-select-panel{width:112px;display:flex;flex-direction:row;justify-content:space-between;padding:12px 4px 4px 12px;flex-wrap:wrap;box-sizing:border-box}.univer-data-validation-formula-color-select-panel .univer-data-validation-formula-color-item{margin-bottom:8px;margin-right:8px;box-sizing:border-box;cursor:pointer}.univer-data-validation-formula-color-item{border-radius:3px;border:1px solid rgba(var(--grey-400));width:16px;height:16px;box-sizing:border-box;font-size:16px}
|
package/lib/types/index.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
export
|
|
1
|
+
export * from './umd';
|
|
2
|
+
export * from '@univerjs/data-validation';
|
|
3
|
+
export * from '@univerjs/sheets-data-validation';
|
|
4
|
+
export * from '@univerjs/sheets-data-validation-ui';
|
package/lib/umd/index.js
CHANGED
|
@@ -1,17 +1,17 @@
|
|
|
1
1
|
// @univerjs/data-validation/index
|
|
2
|
-
(function(l,n){typeof exports=="object"&&typeof module<"u"?n(exports,require("@univerjs/core"),require("rxjs")):typeof define=="function"&&define.amd?define(["exports","@univerjs/core","rxjs"],n):(l=typeof globalThis<"u"?globalThis:l||self,n(l.UniverDataValidation={},l.UniverCore,l.rxjs))})(this,function(l,n,g){"use strict";var sa=Object.defineProperty;var ua=(l,n,g)=>n in l?sa(l,n,{enumerable:!0,configurable:!0,writable:!0,value:g}):l[n]=g;var m=(l,n,g)=>ua(l,typeof n!="symbol"?n+"":n,g);var O;function D(r){return{type:r.type,operator:r.operator,formula1:r.formula1,formula2:r.formula2,allowBlank:r.allowBlank}}function M(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||{}),C=Object.defineProperty,w=Object.getOwnPropertyDescriptor,b=(r,a,e,t)=>{for(var i=t>1?void 0:t?w(a,e):a,o=r.length-1,d;o>=0;o--)(d=r[o])&&(i=(t?d(a,e,i):d(i))||i);return t&&i&&C(a,e,i),i},P=(r,a)=>(e,t)=>a(e,t,r);l.DataValidationModel=class extends n.Disposable{constructor(e){super();m(this,"_model",new Map);m(this,"_ruleChange$",new g.Subject);m(this,"ruleChange$",this._ruleChange$.asObservable());m(this,"ruleChangeDebounce$",this.ruleChange$.pipe(g.debounceTime(20)));this._logService=e,this.disposeWithMe({dispose:()=>{this._ruleChange$.complete()}})}_ensureMap(e,t){this._model.has(e)||this._model.set(e,new Map);const i=this._model.get(e);if(i.has(t))return i.get(t);const o={map:new Map,list:[]};return i.set(t,o),o}_addSubUnitRule(e,t,i){const{map:o,list:d}=e,p=(Array.isArray(t)?t:[t]).filter(u=>!o.has(u.uid));typeof i=="number"&&i<d.length?d.splice(i,0,...p):d.push(...p),p.forEach(u=>{o.set(u.uid,u)})}_removeSubUnitRule(e,t){const{map:i,list:o}=e,d=o.findIndex(s=>s.uid===t);d>-1&&(o.splice(d,1),i.delete(t))}_updateSubUnitRule(e,t,i){const{map:o,list:d}=e,s=o.get(t),p=d.findIndex(c=>t===c.uid);if(!s)throw new Error(`Data validation rule is not found, ruleId: ${t}.`);const u={...s};switch(i.type){case h.RANGE:{u.ranges=i.payload;break}case h.SETTING:{Object.assign(u,D(i.payload));break}case h.OPTIONS:{Object.assign(u,M(i.payload));break}case h.ALL:{Object.assign(u,i.payload);break}}return d[p]=u,o.set(t,u),u}_addRuleSideEffect(e,t,i,o){if(!this._ensureMap(e,t).map.get(i.uid))return{rule:i,type:"add",unitId:e,subUnitId:t,source:o}}addRule(e,t,i,o,d){try{const s=this._ensureMap(e,t),u=(Array.isArray(i)?i:[i]).map(c=>this._addRuleSideEffect(e,t,c,o));this._addSubUnitRule(s,i,d),u.forEach(c=>{c&&this._ruleChange$.next(c)})}catch(s){this._logService.error(s)}}updateRule(e,t,i,o,d){try{const s=this._ensureMap(e,t),p=n.Tools.deepClone(s.map.get(i));if(!p)throw new Error(`Data validation rule is not found, ruleId: ${i}.`);const u=this._updateSubUnitRule(s,i,o);this._ruleChange$.next({rule:u,type:"update",unitId:e,subUnitId:t,source:d,updatePayload:o,oldRule:p})}catch(s){this._logService.error(s)}}removeRule(e,t,i,o){try{const d=this._ensureMap(e,t),s=d.map.get(i);s&&(this._removeSubUnitRule(d,i),this._ruleChange$.next({rule:s,type:"remove",unitId:e,subUnitId:t,source:o}))}catch(d){this._logService.error(d)}}getRuleById(e,t,i){return this._ensureMap(e,t).map.get(i)}getRuleIndex(e,t,i){return this._ensureMap(e,t).list.findIndex(d=>d.uid===i)}getRules(e,t){return[...this._ensureMap(e,t).list]}getUnitRules(e){const t=this._model.get(e);if(!t)return[];const i=[];return t.forEach((o,d)=>{i.push([d,o.list])}),i}deleteUnitRules(e){this._model.delete(e)}getSubUnitIds(e){var t,i;return Array.from((i=(t=this._model.get(e))==null?void 0:t.keys())!=null?i:[])}getAll(){return Array.from(this._model.keys()).map(e=>[e,this.getUnitRules(e)])}},l.DataValidationModel=b([P(0,n.ILogService)],l.DataValidationModel);var B=Object.defineProperty,j=Object.getOwnPropertyDescriptor,$=(r,a,e,t)=>{for(var i=t>1?void 0:t?j(a,e):a,o=r.length-1,d;o>=0;o--)(d=r[o])&&(i=(t?d(a,e,i):d(i))||i);return t&&i&&B(a,e,i),i},R=(r,a)=>(e,t)=>a(e,t,r);const q="SHEET_DATA_VALIDATION_PLUGIN";l.DataValidationResourceController=class extends n.Disposable{constructor(a,e,t){super(),this._resourceManagerService=a,this._univerInstanceService=e,this._dataValidationModel=t,this._initSnapshot()}_initSnapshot(){const a=t=>{const i=this._dataValidationModel.getUnitRules(t),o={};return i?(i.forEach(([d,s])=>{o[d]=s}),JSON.stringify(o)):""},e=t=>{if(!t)return{};try{return JSON.parse(t)}catch{return{}}};this.disposeWithMe(this._resourceManagerService.registerPluginResource({pluginName:q,businesses:[n.UniverInstanceType.UNIVER_SHEET],toJson:t=>a(t),parseJson:t=>e(t),onUnLoad:t=>{this._dataValidationModel.deleteUnitRules(t)},onLoad:(t,i)=>{Object.keys(i).forEach(o=>{i[o].forEach(s=>{this._dataValidationModel.addRule(t,o,s,"patched")})})}}))}},l.DataValidationResourceController=$([R(0,n.IResourceManagerService),R(1,n.IUniverInstanceService),R(2,n.Inject(l.DataValidationModel))],l.DataValidationResourceController);var N=(r=>(r.SHEET="sheet",r))(N||{});class A{constructor(){m(this,"_validatorByScopes",new Map);m(this,"_validatorMap",new Map);m(this,"_validatorsChange$",new g.BehaviorSubject(void 0));m(this,"validatorsChange$",this._validatorsChange$.asObservable())}_addValidatorToScope(a,e){this._validatorByScopes.has(e)||this._validatorByScopes.set(e,[]);const t=this._validatorByScopes.get(e);if(t.findIndex(i=>i.id===a.id)>-1)throw new Error(`Validator item with the same id ${a.id} has already been added!`);t.push(a)}_removeValidatorFromScope(a,e){const t=this._validatorByScopes.get(e);if(!t)return;const i=t.findIndex(o=>o.id===a.id);i>-1&&t.splice(i,1)}register(a){return this._validatorMap.set(a.id,a),Array.isArray(a.scopes)?a.scopes.forEach(e=>{this._addValidatorToScope(a,e)}):this._addValidatorToScope(a,a.scopes),this._validatorsChange$.next(),n.toDisposable(()=>{this._validatorMap.delete(a.id),Array.isArray(a.scopes)?a.scopes.forEach(e=>{this._removeValidatorFromScope(a,e)}):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:e,subUnitId:t,rule:i,index:o,source:d="command"}=a;return r.get(l.DataValidationModel).addRule(e,t,i,d,o),!0}},E={type:n.CommandType.MUTATION,id:"data-validation.mutation.removeRule",handler(r,a){if(!a)return!1;const{unitId:e,subUnitId:t,ruleId:i,source:o="command"}=a,d=r.get(l.DataValidationModel);return Array.isArray(i)?i.forEach(s=>{d.removeRule(e,t,s,o)}):d.removeRule(e,t,i,o),!0}},_={type:n.CommandType.MUTATION,id:"data-validation.mutation.updateRule",handler(r,a){if(!a)return!1;const{unitId:e,subUnitId:t,ruleId:i,payload:o,source:d="command"}=a;return r.get(l.DataValidationModel).updateRule(e,t,i,o,d),!0}},G={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:t,unitId:i,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}],c=[{id:E.id,params:{unitId:i,subUnitId:o,ruleId:t.uid}}];return s.pushUndoRedo({unitID:i,redoMutations:u,undoMutations:c}),await d.executeCommand(f.id,p),!0}},H={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:t,subUnitId:i,ruleId:o}=a,d=r.get(n.ICommandService),s=r.get(n.IUndoRedoService),p=r.get(l.DataValidationModel),u=[{id:E.id,params:a}],c=[{id:f.id,params:{unitId:t,subUnitId:i,rule:{...p.getRuleById(t,i,o)},index:p.getRuleIndex(t,i,o)}}];return s.pushUndoRedo({undoMutations:c,redoMutations:u,unitID:a.unitId}),d.executeCommand(E.id,a),!0}},Q={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 t=r.get(n.ICommandService),i=r.get(n.IUndoRedoService),o=r.get(l.DataValidationModel),{unitId:d,subUnitId:s,ruleId:p,options:u}=a,c=o.getRuleById(d,s,p);if(!c)return!1;const V={unitId:d,subUnitId:s,ruleId:p,payload:{type:h.OPTIONS,payload:u}},v=[{id:_.id,params:V}],T={unitId:d,subUnitId:s,ruleId:p,payload:{type:h.OPTIONS,payload:M(c)}},S=[{id:_.id,params:T}];return i.pushUndoRedo({unitID:d,redoMutations:v,undoMutations:S}),t.executeCommand(_.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 t=r.get(n.ICommandService),i=r.get(n.IUndoRedoService),o=r.get(l.DataValidationModel),d=r.get(A),{unitId:s,subUnitId:p,ruleId:u,setting:c}=a,V=d.getValidatorItem(c.type);if(!V)return!1;const v=o.getRuleById(s,p,u);if(!v)return!1;const T={...v,...c};if(!V.validatorFormula(T,s,p).success)return!1;const S={unitId:s,subUnitId:p,ruleId:u,payload:{type:h.SETTING,payload:{...c,...V.normalizeFormula(T,s,p)}}},oa=[{id:_.id,params:S}],da={unitId:s,subUnitId:p,ruleId:u,payload:{type:h.SETTING,payload:D(v)}},la=[{id:_.id,params:da}];return i.pushUndoRedo({unitID:s,redoMutations:oa,undoMutations:la}),t.executeCommand(_.id,S),!0}},F={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:t,subUnitId:i}=a,o=r.get(n.ICommandService),d=r.get(l.DataValidationModel),s=r.get(n.IUndoRedoService),p=[...d.getRules(t,i)],u={unitId:t,subUnitId:i,ruleId:p.map(v=>v.uid)},c=[{id:E.id,params:u}],V=[{id:f.id,params:{unitId:t,subUnitId:i,rule:p}}];return s.pushUndoRedo({redoMutations:c,undoMutations:V,unitID:t}),o.executeCommand(E.id,u),!0}},x="data-validation.config",J={};var z=Object.defineProperty,K=Object.getOwnPropertyDescriptor,Y=(r,a,e,t)=>{for(var i=t>1?void 0:t?K(a,e):a,o=r.length-1,d;o>=0;o--)(d=r[o])&&(i=(t?d(a,e,i):d(i))||i);return t&&i&&z(a,e,i),i},I=(r,a)=>(e,t)=>a(e,t,r);const X="UNIVER_DATA_VALIDATION_PLUGIN";l.UniverDataValidationPlugin=(O=class extends n.Plugin{constructor(a=J,e,t,i){super(),this._config=a,this._injector=e,this._commandService=t,this._configService=i;const{...o}=this._config;this._configService.setConfig(x,o)}onStarting(){[[l.DataValidationModel],[A],[l.DataValidationResourceController]].forEach(a=>this._injector.add(a)),[G,F,Q,W,H,f,_,E].forEach(a=>{this._commandService.registerCommand(a)})}onReady(){this._injector.get(l.DataValidationResourceController)}},m(O,"pluginName",X),m(O,"type",n.UniverInstanceType.UNIVER_SHEET),O),l.UniverDataValidationPlugin=Y([I(1,n.Inject(n.Injector)),I(2,n.ICommandService),I(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,e,t)=>{for(var i=t>1?void 0:t?ia(a,e):a,o=r.length-1,d;o>=0;o--)(d=r[o])&&(i=(t?d(a,e,i):d(i))||i);return t&&i&&ea(a,e,i),i},y=(r,a)=>(e,t)=>a(e,t,r);const U="{FORMULA1}",L="{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,e){m(this,"formulaInput");m(this,"canvasRender",null);m(this,"dropdown");m(this,"optionsInput");m(this,"skipDefaultFontRender");this.localeService=a,this.injector=e}get operatorNames(){return this.operators.map(a=>this.localeService.t(ra[a]))}get titleStr(){return this.localeService.t(this.title)}generateRuleName(a){var t,i;if(!a.operator)return this.titleStr;const e=this.localeService.t(Z[a.operator]).replace(U,(t=a.formula1)!=null?t:"").replace(L,(i=a.formula2)!=null?i:"");return`${this.titleStr} ${e}`}generateRuleErrorMessage(a,e){var i,o;return a.operator?`${this.localeService.t(k[a.operator]).replace(U,(i=a.formula1)!=null?i:"").replace(L,(o=a.formula2)!=null?o:"")}`:this.titleStr}getExtraStyle(a,e,t,i,o){}getRuleFinalError(a,e){return a.showErrorMessage&&a.error?a.error:this.generateRuleErrorMessage(a,e)}isEmptyCellValue(a){return a===""||a===void 0||a===null}normalizeFormula(a,e,t){return{formula1:a.formula1,formula2:a.formula2}}async isValidType(a,e,t){return!0}transform(a,e,t){return a}async validatorIsEqual(a,e,t){return!0}async validatorIsNotEqual(a,e,t){return!0}async validatorIsBetween(a,e,t){return!0}async validatorIsNotBetween(a,e,t){return!0}async validatorIsGreaterThan(a,e,t){return!0}async validatorIsGreaterThanOrEqual(a,e,t){return!0}async validatorIsLessThan(a,e,t){return!0}async validatorIsLessThanOrEqual(a,e,t){return!0}async validator(a,e){const{value:t,unitId:i,subUnitId:o}=a,d=this.isEmptyCellValue(t),{allowBlank:s=!0,operator:p}=e;if(d)return s;const u=await this.parseFormula(e,i,o,a.row,a.column);if(!u.isFormulaValid||!await this.isValidType(a,u,e))return!1;if(!n.Tools.isDefine(p))return!0;const c=this.transform(a,u,e);switch(p){case n.DataValidationOperator.BETWEEN:return this.validatorIsBetween(c,u,e);case n.DataValidationOperator.EQUAL:return this.validatorIsEqual(c,u,e);case n.DataValidationOperator.GREATER_THAN:return this.validatorIsGreaterThan(c,u,e);case n.DataValidationOperator.GREATER_THAN_OR_EQUAL:return this.validatorIsGreaterThanOrEqual(c,u,e);case n.DataValidationOperator.LESS_THAN:return this.validatorIsLessThan(c,u,e);case n.DataValidationOperator.LESS_THAN_OR_EQUAL:return this.validatorIsLessThanOrEqual(c,u,e);case n.DataValidationOperator.NOT_BETWEEN:return this.validatorIsNotBetween(c,u,e);case n.DataValidationOperator.NOT_EQUAL:return this.validatorIsNotEqual(c,u,e);default:throw new Error("Unknown operator.")}}},l.BaseDataValidator=na([y(0,n.Inject(n.LocaleService)),y(1,n.Inject(n.Injector))],l.BaseDataValidator),l.AddDataValidationMutation=f,l.DataValidatorRegistryScope=N,l.DataValidatorRegistryService=A,l.RemoveDataValidationMutation=E,l.TWO_FORMULA_OPERATOR_COUNT=ta,l.TextLengthErrorTitleMap=aa,l.UpdateDataValidationMutation=_,l.UpdateRuleType=h,l.getRuleOptions=M,l.getRuleSetting=D,Object.defineProperty(l,Symbol.toStringTag,{value:"Module"})});
|
|
2
|
+
(function(l,r){typeof exports=="object"&&typeof module<"u"?r(exports,require("@univerjs/core"),require("rxjs")):typeof define=="function"&&define.amd?define(["exports","@univerjs/core","rxjs"],r):(l=typeof globalThis<"u"?globalThis:l||self,r(l.UniverDataValidation={},l.UniverCore,l.rxjs))})(this,function(l,r,_){"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"})});
|
|
3
3
|
|
|
4
4
|
|
|
5
5
|
// @univerjs/sheets-data-validation/index
|
|
6
|
-
(function(h,s){typeof exports=="object"&&typeof module<"u"?s(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"],s):(h=typeof globalThis<"u"?globalThis:h||self,s(h.UniverSheetsDataValidation={},h.UniverCore,h.UniverDataValidation,h.UniverSheets,h.rxjs,h.UniverSheetsFormula,h.UniverEngineFormula))})(this,function(h,s,p,D,b,Y,O){"use strict";var Wt=Object.defineProperty;var xt=(h,s,p)=>s in h?Wt(h,s,{enumerable:!0,configurable:!0,writable:!0,value:p}):h[s]=p;var _=(h,s,p)=>xt(h,typeof s!="symbol"?s+"":s,p);const Se="SHEET_DATA_VALIDATION_PLUGIN";var $e=Object.defineProperty,We=Object.getOwnPropertyDescriptor,xe=(o,i,e,t)=>{for(var a=t>1?void 0:t?We(i,e):i,r=o.length-1,n;r>=0;r--)(n=o[r])&&(a=(t?n(i,e,a):n(a))||a);return t&&a&&$e(i,e,a),a},ke=(o,i)=>(e,t)=>i(e,t,o);h.DataValidationCacheService=class extends s.Disposable{constructor(e){super();_(this,"_cacheMatrix",new Map);_(this,"_dirtyRanges$",new b.Subject);_(this,"dirtyRanges$",this._dirtyRanges$.asObservable());this._commandService=e,this._initDirtyRanges()}_initDirtyRanges(){this.disposeWithMe(this._commandService.onCommandExecuted(e=>{if(e.id===D.SetRangeValuesMutation.id){const{cellValue:t,unitId:a,subUnitId:r}=e.params;if(t){const n=new s.ObjectMatrix(t).getDataRange();if(n.endRow===-1)return;this.markRangeDirty(a,r,[n])}}}))}_ensureCache(e,t){let a=this._cacheMatrix.get(e);a||(a=new Map,this._cacheMatrix.set(e,a));let r=a.get(t);return r||(r=new s.ObjectMatrix,a.set(t,r)),r}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 r=this._ensureCache(e,t);a.forEach(n=>{s.Range.foreach(n,(l,u)=>{r.setValue(l,u,void 0)})}),this._dirtyRanges$.next({unitId:e,subUnitId:t,ranges:a})}markCellDirty(e,t,a,r){this._ensureCache(e,t).setValue(a,r,void 0),this._dirtyRanges$.next({unitId:e,subUnitId:t,ranges:[{startRow:a,startColumn:r,endRow:a,endColumn:r}]})}_deleteRange(e,t,a){const r=this._ensureCache(e,t);a.forEach(n=>{s.Range.foreach(n,(l,u)=>{r.realDeleteValue(l,u)})}),this._dirtyRanges$.next({unitId:e,subUnitId:t,ranges:a})}getValue(e,t,a,r){return this._ensureCache(e,t).getValue(a,r)}setValue(e,t,a,r,n){return this._ensureCache(e,t).setValue(a,r,n)}},h.DataValidationCacheService=xe([ke(0,s.Inject(s.ICommandService))],h.DataValidationCacheService);function A(o){var i,e;return(e=(i=o==null?void 0:o[0])==null?void 0:i[0])==null?void 0:e.v}function j(o){var i;return(i=o==null?void 0:o[0])==null?void 0:i[0]}function y(o){return!O.ERROR_TYPE_SET.has(o)}function H(o){return o!==s.DataValidationType.LIST&&o!==s.DataValidationType.LIST_MULTIPLE&&o!==s.DataValidationType.CHECKBOX&&o!==s.DataValidationType.ANY}var qe=Object.defineProperty,Ge=Object.getOwnPropertyDescriptor,Qe=(o,i,e,t)=>{for(var a=t>1?void 0:t?Ge(i,e):i,r=o.length-1,n;r>=0;r--)(n=o[r])&&(a=(t?n(i,e,a):n(a))||a);return t&&a&&qe(i,e,a),a},X=(o,i)=>(e,t)=>i(e,t,o);h.DataValidationCustomFormulaService=class extends s.Disposable{constructor(e,t,a,r){super();_(this,"_ruleFormulaMap",new Map);_(this,"_ruleFormulaMap2",new Map);this._instanceSrv=e,this._registerOtherFormulaService=t,this._dataValidationModel=a,this._dataValidationCacheService=r,this._initFormulaResultHandler()}_initFormulaResultHandler(){this.disposeWithMe(this._registerOtherFormulaService.formulaResult$.subscribe(e=>{for(const t in e){const a=e[t];if(this._instanceSrv.getUnitType(t)===s.UniverInstanceType.UNIVER_SHEET)for(const n in a){const l=a[n],{ruleFormulaMap:u}=this._ensureMaps(t,n);l.forEach(d=>{var f,v;const c=u.get((f=d.extra)==null?void 0:f.ruleId),m=this._dataValidationModel.getRuleById(t,n,(v=d.extra)==null?void 0:v.ruleId);m&&c&&this._dataValidationCacheService.markRangeDirty(t,n,m.ranges)})}}}))}_ensureMaps(e,t){let a=this._ruleFormulaMap.get(e),r=this._ruleFormulaMap2.get(e);a||(a=new Map,this._ruleFormulaMap.set(e,a)),r||(r=new Map,this._ruleFormulaMap2.set(e,r));let n=a.get(t);n||(n=new Map,a.set(t,n));let l=r.get(t);return l||(l=new Map,r.set(t,l)),{ruleFormulaMap:n,ruleFormulaMap2:l}}_registerFormula(e,t,a,r,n){return this._registerOtherFormulaService.registerFormulaWithRange(e,t,r,n,{ruleId:a})}deleteByRuleId(e,t,a){const{ruleFormulaMap:r,ruleFormulaMap2:n}=this._ensureMaps(e,t),l=this._dataValidationModel.getRuleById(e,t,a),u=r.get(a);if(!l||!u)return;const d=r.get(a);d&&(r.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,r,n,l){const{ruleFormulaMap:u,ruleFormulaMap2:d}=this._ensureMaps(e,t),c=l[0].startRow,m=l[0].startColumn;if(r&&s.isFormulaString(r)){const f=this._registerFormula(e,t,a,r,l);u.set(a,{formula:r,originCol:m,originRow:c,formulaId:f})}if(n&&s.isFormulaString(n)){const f=this._registerFormula(e,t,a,n,l);d.set(a,{formula:n,originCol:m,originRow:c,formulaId:f})}}addRule(e,t,a){if(H(a.type)){const{ranges:r,formula1:n,formula2:l,uid:u}=a;this._addFormulaByRange(e,t,u,n,l,r)}}async getCellFormulaValue(e,t,a,r,n){var S,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:m}=u,f=r-c,v=n-m;return j((R=(S=d==null?void 0:d.result)==null?void 0:S[f])==null?void 0:R[v])}async getCellFormula2Value(e,t,a,r,n){var S,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:m}=u,f=r-c,v=n-m;return j((R=(S=d==null?void 0:d.result)==null?void 0:S[f])==null?void 0:R[v])}getCellFormulaValueSync(e,t,a,r,n){var S,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:m}=u,f=r-c,v=n-m;return j((R=(S=d==null?void 0:d.result)==null?void 0:S[f])==null?void 0:R[v])}getCellFormula2ValueSync(e,t,a,r,n){var S,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:m}=u,f=r-c,v=n-m;return j((R=(S=d==null?void 0:d.result)==null?void 0:S[f])==null?void 0:R[v])}getRuleFormulaInfo(e,t,a){const{ruleFormulaMap:r}=this._ensureMaps(e,t);return r.get(a)}},h.DataValidationCustomFormulaService=Qe([X(0,s.IUniverInstanceService),X(1,s.Inject(Y.RegisterOtherFormulaService)),X(2,s.Inject(p.DataValidationModel)),X(3,s.Inject(h.DataValidationCacheService))],h.DataValidationCustomFormulaService);var Ye=Object.defineProperty,Xe=Object.getOwnPropertyDescriptor,Ke=(o,i,e,t)=>{for(var a=t>1?void 0:t?Xe(i,e):i,r=o.length-1,n;r>=0;r--)(n=o[r])&&(a=(t?n(i,e,a):n(a))||a);return t&&a&&Ye(i,e,a),a},K=(o,i)=>(e,t)=>i(e,t,o);h.DataValidationFormulaService=class extends s.Disposable{constructor(e,t,a,r){super();_(this,"_formulaRuleMap",new Map);this._instanceService=e,this._registerOtherFormulaService=t,this._dataValidationCacheService=a,this._dataValidationModel=r,this._initFormulaResultHandler()}_initFormulaResultHandler(){this.disposeWithMe(this._registerOtherFormulaService.formulaResult$.subscribe(e=>{for(const t in e){const a=e[t];if(this._instanceService.getUnitType(t)===s.UniverInstanceType.UNIVER_SHEET)for(const n in a){const l=a[n],u=this._ensureRuleFormulaMap(t,n);l.forEach(d=>{var c,m;if(u.get((c=d.extra)==null?void 0:c.ruleId)){const f=this._dataValidationModel.getRuleById(t,n,(m=d.extra)==null?void 0:m.ruleId);f&&this._dataValidationCacheService.markRangeDirty(t,n,f.ranges)}})}}}))}_ensureRuleFormulaMap(e,t){let a=this._formulaRuleMap.get(e);a||(a=new Map,this._formulaRuleMap.set(e,a));let r=a.get(t);return r||(r=new Map,a.set(t,r)),r}_registerSingleFormula(e,t,a,r){const n=[{startColumn:0,endColumn:0,startRow:0,endRow:0}];return this._registerOtherFormulaService.registerFormulaWithRange(e,t,a,n,{ruleId:r})}addRule(e,t,a){if(!H(a.type)&&a.type!==s.DataValidationType.CHECKBOX){const{formula1:r,formula2:n,uid:l}=a,u=s.isFormulaString(r),d=s.isFormulaString(n);if(!u&&!d)return;const c=this._ensureRuleFormulaMap(e,t),m=[void 0,void 0];if(u){const f=this._registerSingleFormula(e,t,r,l);m[0]={id:f,text:r}}if(d){const f=this._registerSingleFormula(e,t,n,l);m[1]={id:f,text:n}}c.set(l,m)}}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)}},h.DataValidationFormulaService=Ke([K(0,s.IUniverInstanceService),K(1,s.Inject(Y.RegisterOtherFormulaService)),K(2,s.Inject(h.DataValidationCacheService)),K(3,s.Inject(p.DataValidationModel))],h.DataValidationFormulaService);function U(o){return s.getOriginCellValue(o)}function Re(o){var i;return String((i=U(o))!=null?i:"")}const ze=class ve{constructor(i,e){this.low=i,this.high=e}clone(){return new ve(this.low,this.high)}get max(){return this.clone()}less_than(i){return this.low<i.low||this.low===i.low&&this.high<i.high}equal_to(i){return this.low===i.low&&this.high===i.high}intersect(i){return!this.not_intersect(i)}not_intersect(i){return this.high<i.low||i.high<this.low}merge(i){return new ve(this.low===void 0?i.low:this.low<i.low?this.low:i.low,this.high===void 0?i.high:this.high>i.high?this.high:i.high)}output(){return[this.low,this.high]}static comparable_max(i,e){return i.merge(e)}static comparable_less_than(i,e){return i<e}},T=0,V=1;class F{constructor(i=void 0,e=void 0,t=null,a=null,r=null,n=V){if(this.left=t,this.right=a,this.parent=r,this.color=n,this.item={key:i,value:e},i&&i instanceof Array&&i.length===2&&!Number.isNaN(i[0])&&!Number.isNaN(i[1])){let[l,u]=i;l>u&&([l,u]=[u,l]),this.item.key=new ze(l,u)}this.max=this.item.key?this.item.key.max:void 0}isNil(){return this.item.key===void 0&&this.item.value===void 0&&this.left===null&&this.right===null&&this.color===V}_value_less_than(i){return this.item.value&&i.item.value&&this.item.value.less_than?this.item.value.less_than(i.item.value):this.item.value<i.item.value}less_than(i){return this.item.value===this.item.key&&i.item.value===i.item.key?this.item.key.less_than(i.item.key):this.item.key.less_than(i.item.key)||this.item.key.equal_to(i.item.key)&&this._value_less_than(i)}_value_equal(i){return this.item.value&&i.item.value&&this.item.value.equal_to?this.item.value.equal_to(i.item.value):this.item.value===i.item.value}equal_to(i){return this.item.value===this.item.key&&i.item.value===i.item.key?this.item.key.equal_to(i.item.key):this.item.key.equal_to(i.item.key)&&this._value_equal(i)}intersect(i){return this.item.key.intersect(i.item.key)}copy_data(i){this.item.key=i.item.key,this.item.value=i.item.value}update_max(){if(this.max=this.item.key?this.item.key.max:void 0,this.right&&this.right.max){const i=this.item.key.constructor.comparable_max;this.max=i(this.max,this.right.max)}if(this.left&&this.left.max){const i=this.item.key.constructor.comparable_max;this.max=i(this.max,this.left.max)}}not_intersect_left_subtree(i){const e=this.item.key.constructor.comparable_less_than;let t=this.left.max.high!==void 0?this.left.max.high:this.left.max;return e(t,i.item.key.low)}not_intersect_right_subtree(i){const e=this.item.key.constructor.comparable_less_than;let t=this.right.max.low!==void 0?this.right.max.low:this.right.item.key.low;return e(i.item.key.high,t)}}class le{constructor(){this.root=null,this.nil_node=new F}get size(){let i=0;return this.tree_walk(this.root,()=>i++),i}get keys(){let i=[];return this.tree_walk(this.root,e=>i.push(e.item.key.output?e.item.key.output():e.item.key)),i}get values(){let i=[];return this.tree_walk(this.root,e=>i.push(e.item.value)),i}get items(){let i=[];return this.tree_walk(this.root,e=>i.push({key:e.item.key.output?e.item.key.output():e.item.key,value:e.item.value})),i}isEmpty(){return this.root==null||this.root===this.nil_node}clear(){this.root=null}insert(i,e=i){if(i===void 0)return;let t=new F(i,e,this.nil_node,this.nil_node,null,T);return this.tree_insert(t),this.recalc_max(t),t}exist(i,e=i){let t=new F(i,e);return!!this.tree_search(this.root,t)}remove(i,e=i){let t=new F(i,e),a=this.tree_search(this.root,t);return a&&this.tree_delete(a),a}search(i,e=(t,a)=>t===a?a.output():t){let t=new F(i),a=[];return this.tree_search_interval(this.root,t,a),a.map(r=>e(r.item.value,r.item.key))}intersect_any(i){let e=new F(i);return this.tree_find_any_interval(this.root,e)}forEach(i){this.tree_walk(this.root,e=>i(e.item.key,e.item.value))}map(i){const e=new le;return this.tree_walk(this.root,t=>e.insert(t.item.key,i(t.item.value,t.item.key))),e}*iterate(i,e=(t,a)=>t===a?a.output():t){let t;for(i?t=this.tree_search_nearest_forward(this.root,new F(i)):this.root&&(t=this.local_minimum(this.root));t;)yield e(t.item.value,t.item.key),t=this.tree_successor(t)}recalc_max(i){let e=i;for(;e.parent!=null;)e.parent.update_max(),e=e.parent}tree_insert(i){let e=this.root,t=null;if(this.root==null||this.root===this.nil_node)this.root=i;else{for(;e!==this.nil_node;)t=e,i.less_than(e)?e=e.left:e=e.right;i.parent=t,i.less_than(t)?t.left=i:t.right=i}this.insert_fixup(i)}insert_fixup(i){let e,t;for(e=i;e!==this.root&&e.parent.color===T;)e.parent===e.parent.parent.left?(t=e.parent.parent.right,t.color===T?(e.parent.color=V,t.color=V,e.parent.parent.color=T,e=e.parent.parent):(e===e.parent.right&&(e=e.parent,this.rotate_left(e)),e.parent.color=V,e.parent.parent.color=T,this.rotate_right(e.parent.parent))):(t=e.parent.parent.left,t.color===T?(e.parent.color=V,t.color=V,e.parent.parent.color=T,e=e.parent.parent):(e===e.parent.left&&(e=e.parent,this.rotate_right(e)),e.parent.color=V,e.parent.parent.color=T,this.rotate_left(e.parent.parent)));this.root.color=V}tree_delete(i){let e,t;i.left===this.nil_node||i.right===this.nil_node?e=i:e=this.tree_successor(i),e.left!==this.nil_node?t=e.left:t=e.right,t.parent=e.parent,e===this.root?this.root=t:(e===e.parent.left?e.parent.left=t:e.parent.right=t,e.parent.update_max()),this.recalc_max(t),e!==i&&(i.copy_data(e),i.update_max(),this.recalc_max(i)),e.color===V&&this.delete_fixup(t)}delete_fixup(i){let e=i,t;for(;e!==this.root&&e.parent!=null&&e.color===V;)e===e.parent.left?(t=e.parent.right,t.color===T&&(t.color=V,e.parent.color=T,this.rotate_left(e.parent),t=e.parent.right),t.left.color===V&&t.right.color===V?(t.color=T,e=e.parent):(t.right.color===V&&(t.color=T,t.left.color=V,this.rotate_right(t),t=e.parent.right),t.color=e.parent.color,e.parent.color=V,t.right.color=V,this.rotate_left(e.parent),e=this.root)):(t=e.parent.left,t.color===T&&(t.color=V,e.parent.color=T,this.rotate_right(e.parent),t=e.parent.left),t.left.color===V&&t.right.color===V?(t.color=T,e=e.parent):(t.left.color===V&&(t.color=T,t.right.color=V,this.rotate_left(t),t=e.parent.left),t.color=e.parent.color,e.parent.color=V,t.left.color=V,this.rotate_right(e.parent),e=this.root));e.color=V}tree_search(i,e){if(!(i==null||i===this.nil_node))return e.equal_to(i)?i:e.less_than(i)?this.tree_search(i.left,e):this.tree_search(i.right,e)}tree_search_nearest_forward(i,e){let t,a=i;for(;a&&a!==this.nil_node;)a.less_than(e)?a.intersect(e)?(t=a,a=a.left):a=a.right:((!t||a.less_than(t))&&(t=a),a=a.left);return t||null}tree_search_interval(i,e,t){i!=null&&i!==this.nil_node&&(i.left!==this.nil_node&&!i.not_intersect_left_subtree(e)&&this.tree_search_interval(i.left,e,t),i.intersect(e)&&t.push(i),i.right!==this.nil_node&&!i.not_intersect_right_subtree(e)&&this.tree_search_interval(i.right,e,t))}tree_find_any_interval(i,e){let t=!1;return i!=null&&i!==this.nil_node&&(i.left!==this.nil_node&&!i.not_intersect_left_subtree(e)&&(t=this.tree_find_any_interval(i.left,e)),t||(t=i.intersect(e)),!t&&i.right!==this.nil_node&&!i.not_intersect_right_subtree(e)&&(t=this.tree_find_any_interval(i.right,e))),t}local_minimum(i){let e=i;for(;e.left!=null&&e.left!==this.nil_node;)e=e.left;return e}local_maximum(i){let e=i;for(;e.right!=null&&e.right!==this.nil_node;)e=e.right;return e}tree_successor(i){let e,t,a;if(i.right!==this.nil_node)e=this.local_minimum(i.right);else{for(t=i,a=i.parent;a!=null&&a.right===t;)t=a,a=a.parent;e=a}return e}rotate_left(i){let e=i.right;i.right=e.left,e.left!==this.nil_node&&(e.left.parent=i),e.parent=i.parent,i===this.root?this.root=e:i===i.parent.left?i.parent.left=e:i.parent.right=e,e.left=i,i.parent=e,i!=null&&i!==this.nil_node&&i.update_max(),e=i.parent,e!=null&&e!==this.nil_node&&e.update_max()}rotate_right(i){let e=i.left;i.left=e.right,e.right!==this.nil_node&&(e.right.parent=i),e.parent=i.parent,i===this.root?this.root=e:i===i.parent.left?i.parent.left=e:i.parent.right=e,e.right=i,i.parent=e,i!==null&&i!==this.nil_node&&i.update_max(),e=i.parent,e!=null&&e!==this.nil_node&&e.update_max()}tree_walk(i,e){i!=null&&i!==this.nil_node&&(this.tree_walk(i.left,e),e(i),this.tree_walk(i.right,e))}testRedBlackProperty(){let i=!0;return this.tree_walk(this.root,function(e){e.color===T&&(e.left.color===V&&e.right.color===V||(i=!1))}),i}testBlackHeightProperty(i){let e=0,t=0,a=0;if(i.color===V&&e++,i.left!==this.nil_node?t=this.testBlackHeightProperty(i.left):t=1,i.right!==this.nil_node?a=this.testBlackHeightProperty(i.right):a=1,t!==a)throw new Error("Red-black height property violated");return e+=t,e}}class ue{constructor(i,e,t,a,r=!1){_(this,"_map");_(this,"_tree",new Map);_(this,"_dirty",!0);_(this,"_buildTree",()=>{if(!this._dirty||this._disableTree)return;const i=new Map;this._map.forEach((t,a)=>{t.forEach(r=>{for(let n=r.startColumn;n<=r.endColumn;n++){let l=i.get(n);l||(l=[],i.set(n,l)),l.push({startRow:r.startRow,endRow:r.endRow,ruleId:a})}})});const e=new Map;i.forEach((t,a)=>{const r=new le;t.forEach(n=>{r.insert([n.startRow,n.endRow],n.ruleId)}),e.set(a,r)}),this._tree=e,this._dirty=!1});_(this,"_debonceBuildTree",s.debounce(this._buildTree,0));this._unitId=e,this._subUnitId=t,this._univerInstanceService=a,this._disableTree=r,this._map=i,this._buildTree()}get _worksheet(){var i;return(i=this._univerInstanceService.getUnit(this._unitId,s.UniverInstanceType.UNIVER_SHEET))==null?void 0:i.getSheetBySheetId(this._subUnitId)}addRule(i){if(!this._worksheet)return;const e=i.uid,t=i.ranges.map(a=>s.Range.transformRange(a,this._worksheet));this._map.forEach((a,r)=>{const n=s.Rectangle.subtractMulti(a,t);n.length===0?this._map.delete(r):this._map.set(r,n)}),this._dirty=!0,this._map.set(e,t),this._debonceBuildTree()}removeRange(i){if(!this._worksheet)return;const e=i.map(t=>s.Range.transformRange(t,this._worksheet));this._map.forEach((t,a)=>{const r=s.Rectangle.subtractMulti(t,e);r.length===0?this._map.delete(a):this._map.set(a,r)}),this._dirty=!0,this._debonceBuildTree()}removeRule(i){this._map.delete(i.uid),this._dirty=!0,this._debonceBuildTree()}updateRange(i,e){if(!this._worksheet)return;this._map.delete(i);const t=e.map(a=>s.Range.transformRange(a,this._worksheet));this._map.forEach((a,r)=>{const n=s.Rectangle.subtractMulti(a,t);n.length===0?this._map.delete(r):this._map.set(r,n)}),this._map.set(i,t),this._dirty=!0,this._debonceBuildTree()}addRangeRules(i){i.forEach(({id:e,ranges:t})=>{if(!t.length)return;let a=this._map.get(e);a?(this._map.set(e,s.Rectangle.mergeRanges([...a,...t])),a=this._map.get(e)):(a=t,this._map.set(e,a)),this._map.forEach((r,n)=>{if(n===e)return;const l=s.Rectangle.subtractMulti(r,t);l.length===0?this._map.delete(n):this._map.set(n,l)})}),this._dirty=!0,this._debonceBuildTree()}diff(i){const e=[];let t=0;return i.forEach((a,r)=>{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)=>!s.Rectangle.equals(d,l[c])))&&e.push({type:"update",ruleId:a.uid,oldRanges:l,newRanges:s.Rectangle.sort(n),rule:a}),n.length===0&&(e.push({type:"delete",rule:a,index:r-t}),t++)}),e}diffWithAddition(i,e){const t=[];let a=0;return i.forEach((r,n)=>{var d;const l=(d=this._map.get(r.uid))!=null?d:[],u=r.ranges;l.length!==0&&(l.length!==u.length||l.some((c,m)=>!s.Rectangle.equals(c,u[m])))&&t.push({type:"update",ruleId:r.uid,oldRanges:u,newRanges:s.Rectangle.sort(l),rule:r}),l.length===0&&(t.push({type:"delete",rule:r,index:n-a}),a++)}),Array.from(e).forEach(r=>{var l;const n=(l=this._map.get(r.uid))!=null?l:[];t.push({type:"add",rule:{...r,ranges:s.Rectangle.sort(n)}})}),t}clone(){return new ue(new Map(s.Tools.deepClone(Array.from(this._map.entries()))),this._unitId,this._subUnitId,this._univerInstanceService,!0)}getValue(i,e){this._dirty&&this._buildTree();const t=this._tree.get(e);if(!t)return;const a=t.search([i,i]);return a.length>0?a[0]:void 0}}var Ze=Object.defineProperty,Je=Object.getOwnPropertyDescriptor,et=(o,i,e,t)=>{for(var a=t>1?void 0:t?Je(i,e):i,r=o.length-1,n;r>=0;r--)(n=o[r])&&(a=(t?n(i,e,a):n(a))||a);return t&&a&&Ze(i,e,a),a},C=(o,i)=>(e,t)=>i(e,t,o);h.SheetDataValidationModel=class extends s.Disposable{constructor(e,t,a,r,n,l,u){super();_(this,"_ruleMatrixMap",new Map);_(this,"_validStatusChange$",new b.Subject);_(this,"_ruleChange$",new b.Subject);_(this,"ruleChange$",this._ruleChange$.asObservable());_(this,"validStatusChange$",this._validStatusChange$.asObservable());this._dataValidationModel=e,this._univerInstanceService=t,this._dataValidatorRegistryService=a,this._dataValidationCacheService=r,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,r=this._ruleMatrixMap.get(t);r&&r.delete(a)}}))}_initRuleUpdateListener(){const e=this._dataValidationModel.getAll();for(const[t,a]of e)for(const[r,n]of a)for(const l of n)this._addRule(t,r,l),this._ruleChange$.next({type:"add",unitId:t,subUnitId:r,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 r=a.get(t);return r||(r=new ue(new Map,e,t,this._univerInstanceService),a.set(t,r)),r}_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,r,n){const l=this._ensureRuleMatrix(e,t),u={...r,...n.payload};n.type===p.UpdateRuleType.RANGE?l.updateRange(a,n.payload):n.type===p.UpdateRuleType.ALL&&l.updateRange(a,n.payload.ranges),this._dataValidationCacheService.removeRule(e,t,r),this._dataValidationCacheService.addRule(e,t,u),this._dataValidationFormulaService.removeRule(e,t,r.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,r){return this._ensureRuleMatrix(e,t).getValue(a,r)}getRuleByLocation(e,t,a,r){const n=this.getRuleIdByLocation(e,t,a,r);if(n)return this._dataValidationModel.getRuleById(e,t,n)}validator(e,t,a){const{col:r,row:n,unitId:l,subUnitId:u,worksheet:d}=t,c=(R,g)=>{a&&a(R,g),g&&this._validStatusChange$.next({unitId:l,subUnitId:u,ruleId:e.uid,status:R,row:n,col:r})},m=d.getCellValueOnly(n,r),f=this.getValidator(e.type),v=d.getCellRaw(n,r),S=U(v);if(f){const R=this._dataValidationCacheService.ensureCache(l,u),g=R.getValue(n,r);return g==null?(R.setValue(n,r,s.DataValidationStatus.VALIDATING),f.validator({value:S,unitId:l,subUnitId:u,row:n,column:r,worksheet:t.worksheet,workbook:t.workbook,interceptValue:U(m),t:v==null?void 0:v.t},e).then(M=>{const N=M?s.DataValidationStatus.VALID:s.DataValidationStatus.INVALID;N===s.DataValidationStatus.VALID?R.realDeleteValue(n,r):R.setValue(n,r,N);const I=R.getValue(n,r);c(N,g!==I)}),s.DataValidationStatus.VALIDATING):(c(g!=null?g:s.DataValidationStatus.VALID,!1),g!=null?g:s.DataValidationStatus.VALID)}else return c(s.DataValidationStatus.VALID,!1),s.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()}},h.SheetDataValidationModel=et([C(0,s.Inject(p.DataValidationModel)),C(1,s.IUniverInstanceService),C(2,s.Inject(p.DataValidatorRegistryService)),C(3,s.Inject(h.DataValidationCacheService)),C(4,s.Inject(h.DataValidationFormulaService)),C(5,s.Inject(h.DataValidationCustomFormulaService)),C(6,s.ICommandService)],h.SheetDataValidationModel);const $=1,W=0;function Ve(o,i){return s.Tools.isBlank(o)?i.t("dataValidation.validFail.value"):s.isFormulaString(o)?i.t("dataValidation.validFail.primitive"):""}const x=o=>s.Tools.isDefine(o)&&String(o).toLowerCase()==="true"?"1":String(o).toLowerCase()==="false"?"0":o;class De extends p.BaseDataValidator{constructor(){super(...arguments);_(this,"id",s.DataValidationType.CHECKBOX);_(this,"title","dataValidation.checkbox.title");_(this,"operators",[]);_(this,"scopes",["sheet"]);_(this,"_formulaService",this.injector.get(h.DataValidationFormulaService));_(this,"skipDefaultFontRender",(e,t,a)=>{const{unitId:r,subUnitId:n}=a,{formula1:l,formula2:u}=this.parseFormulaSync(e,r,n),d=`${t!=null?t:""}`;return!d||d===`${l}`||d===`${u}`})}validatorFormula(e,t,a){const{formula1:r,formula2:n}=e,l=r===n;if(s.Tools.isBlank(r)&&s.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=Ve(r,this.localeService),d=Ve(n,this.localeService);return{success:!u&&!d,formula1:u,formula2:d}}async parseFormula(e,t,a){var m,f,v,S;const{formula1:r=$,formula2:n=W}=e,l=await this._formulaService.getRuleFormulaResult(t,a,e.uid),u=s.isFormulaString(r)?A((f=(m=l==null?void 0:l[0])==null?void 0:m.result)==null?void 0:f[0][0]):r,d=s.isFormulaString(n)?A((S=(v=l==null?void 0:l[1])==null?void 0:v.result)==null?void 0:S[0][0]):n,c=y(String(u))&&y(String(d));return{formula1:x(u),formula2:x(d),originFormula1:u,originFormula2:d,isFormulaValid:c}}getExtraStyle(e,t){return{tb:s.WrapStrategy.CLIP}}parseFormulaSync(e,t,a){var m,f,v,S;const{formula1:r=$,formula2:n=W}=e,l=this._formulaService.getRuleFormulaResultSync(t,a,e.uid),u=s.isFormulaString(r)?A((f=(m=l==null?void 0:l[0])==null?void 0:m.result)==null?void 0:f[0][0]):r,d=s.isFormulaString(n)?A((S=(v=l==null?void 0:l[1])==null?void 0:v.result)==null?void 0:S[0][0]):n,c=y(String(u))&&y(String(d));return{formula1:x(u),formula2:x(d),originFormula1:u,originFormula2:d,isFormulaValid:c}}async isValidType(e,t,a){const{value:r,unitId:n,subUnitId:l}=e,{formula1:u,formula2:d,originFormula1:c,originFormula2:m}=await this.parseFormula(a,n,l);return!s.Tools.isDefine(u)||!s.Tools.isDefine(d)?!0:s.Tools.isDefine(r)&&(String(r)===String(u)||String(r)===String(d)||String(r)===String(c!=null?c:"")||String(r)===String(m!=null?m:""))}generateRuleErrorMessage(e){return this.localeService.t("dataValidation.checkbox.error")}}const tt={[s.DataValidationOperator.BETWEEN]:"dataValidation.date.operators.between",[s.DataValidationOperator.EQUAL]:"dataValidation.date.operators.equal",[s.DataValidationOperator.GREATER_THAN]:"dataValidation.date.operators.greaterThan",[s.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.date.operators.greaterThanOrEqual",[s.DataValidationOperator.LESS_THAN]:"dataValidation.date.operators.lessThan",[s.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.date.operators.lessThanOrEqual",[s.DataValidationOperator.NOT_BETWEEN]:"dataValidation.date.operators.notBetween",[s.DataValidationOperator.NOT_EQUAL]:"dataValidation.date.operators.notEqual"};s.DataValidationOperator.BETWEEN+"",s.DataValidationOperator.EQUAL+"",s.DataValidationOperator.GREATER_THAN+"",s.DataValidationOperator.GREATER_THAN_OR_EQUAL+"",s.DataValidationOperator.LESS_THAN+"",s.DataValidationOperator.LESS_THAN_OR_EQUAL+"",s.DataValidationOperator.NOT_BETWEEN+"",s.DataValidationOperator.NOT_EQUAL+"";const at={[s.DataValidationOperator.BETWEEN]:"dataValidation.date.ruleName.between",[s.DataValidationOperator.EQUAL]:"dataValidation.date.ruleName.equal",[s.DataValidationOperator.GREATER_THAN]:"dataValidation.date.ruleName.greaterThan",[s.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.date.ruleName.greaterThanOrEqual",[s.DataValidationOperator.LESS_THAN]:"dataValidation.date.ruleName.lessThan",[s.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.date.ruleName.lessThanOrEqual",[s.DataValidationOperator.NOT_BETWEEN]:"dataValidation.date.ruleName.notBetween",[s.DataValidationOperator.NOT_EQUAL]:"dataValidation.date.ruleName.notEqual"},it={[s.DataValidationOperator.BETWEEN]:"dataValidation.date.errorMsg.between",[s.DataValidationOperator.EQUAL]:"dataValidation.date.errorMsg.equal",[s.DataValidationOperator.GREATER_THAN]:"dataValidation.date.errorMsg.greaterThan",[s.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.date.errorMsg.greaterThanOrEqual",[s.DataValidationOperator.LESS_THAN]:"dataValidation.date.errorMsg.lessThan",[s.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.date.errorMsg.lessThanOrEqual",[s.DataValidationOperator.NOT_BETWEEN]:"dataValidation.date.errorMsg.notBetween",[s.DataValidationOperator.NOT_EQUAL]:"dataValidation.date.errorMsg.notEqual"},z=[s.DataValidationOperator.BETWEEN,s.DataValidationOperator.NOT_BETWEEN],k="{FORMULA1}",q="{FORMULA2}";function rt(o){return o.filter(Boolean).join(",")}function G(o){return o.split(",").filter(Boolean)}function nt(o){const i=U(o);return i==null?"":i.toString()}function Z(o,i,e){const{formula1:t,formula2:a}=i,r=i.ranges[0].startRow,n=i.ranges[0].startColumn,l=e.row-r,u=e.col-n,d=s.isFormulaString(t)?o.moveFormulaRefOffset(t,u,l,!0):t,c=s.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 i=(e=s.numfmt.parseDate(o))==null?void 0:e.v;return s.Tools.isDefine(i)?i:(t=s.numfmt.parseDate(s.dayjs(o).format("YYYY-MM-DD HH:mm:ss")))==null?void 0:t.v};class Me extends p.BaseDataValidator{constructor(){super(...arguments);_(this,"id",s.DataValidationType.DATE);_(this,"title","dataValidation.date.title");_(this,"operators",[s.DataValidationOperator.BETWEEN,s.DataValidationOperator.EQUAL,s.DataValidationOperator.GREATER_THAN,s.DataValidationOperator.GREATER_THAN_OR_EQUAL,s.DataValidationOperator.LESS_THAN,s.DataValidationOperator.LESS_THAN_OR_EQUAL,s.DataValidationOperator.NOT_BETWEEN,s.DataValidationOperator.NOT_EQUAL]);_(this,"scopes",["sheet"]);_(this,"_customFormulaService",this.injector.get(h.DataValidationCustomFormulaService));_(this,"_lexerTreeBuilder",this.injector.get(O.LexerTreeBuilder))}async parseFormula(e,t,a,r,n){const l=await this._customFormulaService.getCellFormulaValue(t,a,e.uid,r,n),u=await this._customFormulaService.getCellFormula2Value(t,a,e.uid,r,n),{formula1:d,formula2:c}=e,m=y(String(l==null?void 0:l.v))&&y(String(u==null?void 0:u.v));return{formula1:de(s.isFormulaString(d)?l==null?void 0:l.v:d),formula2:de(s.isFormulaString(c)?u==null?void 0:u.v:c),isFormulaValid:m}}async isValidType(e){const{interceptValue:t,value:a}=e;return typeof a=="number"&&typeof t=="string"?!0:typeof t=="string"?!!s.numfmt.parseDate(t):!1}_validatorSingleFormula(e){return!s.Tools.isBlank(e)&&(s.isFormulaString(e)||!Number.isNaN(+e)||!!(e&&s.numfmt.parseDate(e)))}validatorFormula(e,t,a){const r=e.operator;if(!r)return{success:!1};const n=this._validatorSingleFormula(e.formula1),l=this.localeService.t("dataValidation.validFail.date");if(z.includes(r)){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:r,formula2:n,bizInfo:l}=e,u=d=>{var m;if(!d)return d;let c;if(!Number.isNaN(+d))c=s.numfmt.dateFromSerial(+d);else{const f=(m=s.numfmt.parseDate(d))==null?void 0:m.v;if(f==null)return"";c=s.numfmt.dateFromSerial(f)}return s.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:s.isFormulaString(r)?r:u(`${r}`),formula2:s.isFormulaString(n)?n:u(`${n}`)}}transform(e,t,a){const{value:r}=e;return{...e,value:de(r)}}async validatorIsEqual(e,t,a){const{formula1:r}=t,{value:n}=e;return Number.isNaN(r)?!0:n===r}async validatorIsNotEqual(e,t,a){const{formula1:r}=t;return Number.isNaN(r)?!0:e.value!==r}async validatorIsBetween(e,t,a){const{formula1:r,formula2:n}=t;if(Number.isNaN(r)||Number.isNaN(n))return!0;const l=Math.min(r,n),u=Math.max(r,n);return e.value>=l&&e.value<=u}async validatorIsNotBetween(e,t,a){const{formula1:r,formula2:n}=t;if(Number.isNaN(r)||Number.isNaN(n))return!0;const l=Math.min(r,n),u=Math.max(r,n);return e.value<l||e.value>u}async validatorIsGreaterThan(e,t,a){const{formula1:r}=t;return Number.isNaN(r)?!0:e.value>r}async validatorIsGreaterThanOrEqual(e,t,a){const{formula1:r}=t;return Number.isNaN(r)?!0:e.value>=r}async validatorIsLessThan(e,t,a){const{formula1:r}=t;return Number.isNaN(r)?!0:e.value<r}async validatorIsLessThanOrEqual(e,t,a){const{formula1:r}=t;return Number.isNaN(r)?!0:e.value<=r}get operatorNames(){return this.operators.map(e=>this.localeService.t(tt[e]))}generateRuleName(e){var a,r;if(!e.operator)return this.titleStr;const t=this.localeService.t(at[e.operator]).replace(k,(a=e.formula1)!=null?a:"").replace(q,(r=e.formula2)!=null?r:"");return`${this.titleStr} ${t}`}generateRuleErrorMessage(e,t){if(!e.operator)return this.titleStr;const{transformedFormula1:a,transformedFormula2:r}=Z(this._lexerTreeBuilder,e,t);return`${this.localeService.t(it[e.operator]).replace(k,a!=null?a:"").replace(q,r!=null?r:"")}`}}s.DataValidationOperator.BETWEEN+"",s.DataValidationOperator.EQUAL+"",s.DataValidationOperator.GREATER_THAN+"",s.DataValidationOperator.GREATER_THAN_OR_EQUAL+"",s.DataValidationOperator.LESS_THAN+"",s.DataValidationOperator.LESS_THAN_OR_EQUAL+"",s.DataValidationOperator.NOT_BETWEEN+"",s.DataValidationOperator.NOT_EQUAL+"",s.DataValidationOperator.BETWEEN+"",s.DataValidationOperator.EQUAL+"",s.DataValidationOperator.GREATER_THAN+"",s.DataValidationOperator.GREATER_THAN_OR_EQUAL+"",s.DataValidationOperator.LESS_THAN+"",s.DataValidationOperator.LESS_THAN_OR_EQUAL+"",s.DataValidationOperator.NOT_BETWEEN+"",s.DataValidationOperator.NOT_EQUAL+"";const ye={[s.DataValidationOperator.BETWEEN]:"dataValidation.errorMsg.between",[s.DataValidationOperator.EQUAL]:"dataValidation.errorMsg.equal",[s.DataValidationOperator.GREATER_THAN]:"dataValidation.errorMsg.greaterThan",[s.DataValidationOperator.GREATER_THAN_OR_EQUAL]:"dataValidation.errorMsg.greaterThanOrEqual",[s.DataValidationOperator.LESS_THAN]:"dataValidation.errorMsg.lessThan",[s.DataValidationOperator.LESS_THAN_OR_EQUAL]:"dataValidation.errorMsg.lessThanOrEqual",[s.DataValidationOperator.NOT_BETWEEN]:"dataValidation.errorMsg.notBetween",[s.DataValidationOperator.NOT_EQUAL]:"dataValidation.errorMsg.notEqual"};function J(o){let i=o;return typeof o=="string"?((o.startsWith("¥")||o.startsWith("$"))&&(i=o.slice(1)),+i):+o}class st extends p.BaseDataValidator{constructor(){super(...arguments);_(this,"_customFormulaService",this.injector.get(h.DataValidationCustomFormulaService));_(this,"id",s.DataValidationType.DECIMAL);_(this,"_lexerTreeBuilder",this.injector.get(O.LexerTreeBuilder));_(this,"title","dataValidation.decimal.title");_(this,"operators",[s.DataValidationOperator.BETWEEN,s.DataValidationOperator.EQUAL,s.DataValidationOperator.GREATER_THAN,s.DataValidationOperator.GREATER_THAN_OR_EQUAL,s.DataValidationOperator.LESS_THAN,s.DataValidationOperator.LESS_THAN_OR_EQUAL,s.DataValidationOperator.NOT_BETWEEN,s.DataValidationOperator.NOT_EQUAL]);_(this,"scopes",["sheet"])}_isFormulaOrNumber(e){return!s.Tools.isBlank(e)&&(s.isFormulaString(e)||!Number.isNaN(+e))}async isValidType(e,t,a){const{value:r}=e;return!Number.isNaN(J(r))}transform(e,t,a){const{value:r}=e;return{...e,value:J(r)}}_parseNumber(e){return e==null?Number.NaN:+e}async parseFormula(e,t,a,r,n){const l=await this._customFormulaService.getCellFormulaValue(t,a,e.uid,r,n),u=await this._customFormulaService.getCellFormula2Value(t,a,e.uid,r,n),{formula1:d,formula2:c}=e,m=y(String(l==null?void 0:l.v))&&y(String(u==null?void 0:u.v));return{formula1:this._parseNumber(s.isFormulaString(d)?l==null?void 0:l.v:d),formula2:this._parseNumber(s.isFormulaString(c)?u==null?void 0:u.v:c),isFormulaValid:m}}validatorFormula(e,t,a){const r=e.operator;if(!r)return{success:!1};const n=s.Tools.isDefine(e.formula1)&&this._isFormulaOrNumber(e.formula1),l=s.Tools.isDefine(e.formula2)&&this._isFormulaOrNumber(e.formula2),u=z.includes(r),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}}async validatorIsEqual(e,t,a){const{formula1:r}=t,{value:n}=e;return Number.isNaN(r)?!0:n===r}async validatorIsNotEqual(e,t,a){const{formula1:r}=t;return Number.isNaN(r)?!0:e.value!==r}async validatorIsBetween(e,t,a){const{formula1:r,formula2:n}=t;if(Number.isNaN(r)||Number.isNaN(n))return!0;const l=Math.min(r,n),u=Math.max(r,n);return e.value>=l&&e.value<=u}async validatorIsNotBetween(e,t,a){const{formula1:r,formula2:n}=t;if(Number.isNaN(r)||Number.isNaN(n))return!0;const l=Math.min(r,n),u=Math.max(r,n);return e.value<l||e.value>u}async validatorIsGreaterThan(e,t,a){const{formula1:r}=t;return Number.isNaN(r)?!0:e.value>r}async validatorIsGreaterThanOrEqual(e,t,a){const{formula1:r}=t;return Number.isNaN(r)?!0:e.value>=r}async validatorIsLessThan(e,t,a){const{formula1:r}=t;return Number.isNaN(r)?!0:e.value<r}async validatorIsLessThanOrEqual(e,t,a){const{formula1:r}=t;return Number.isNaN(r)?!0:e.value<=r}generateRuleErrorMessage(e,t){if(!e.operator)return this.titleStr;const{transformedFormula1:a,transformedFormula2:r}=Z(this._lexerTreeBuilder,e,t);return`${this.localeService.t(ye[e.operator]).replace(k,a!=null?a:"").replace(q,r!=null?r:"")}`}}function ce(o){if(!o)return[];const i=new Set;return o.forEach(e=>{e.forEach(t=>{var r,n;const a=U(t);if(a!=null){if(typeof a!="string"&&typeof(t==null?void 0:t.s)=="object"&&((n=(r=t.s)==null?void 0:r.n)!=null&&n.pattern)){i.add(s.numfmt.format(t.s.n.pattern,a,{throws:!1}));return}y(a.toString())&&i.add(a.toString())}})}),[...i]}const ot=["if","indirect","choose","offset"];function lt(o,i){if(!s.isFormulaString(o)||O.isReferenceString(o.slice(1)))return!0;const t=i.sequenceNodesBuilder(o);return t&&t.some(a=>typeof a=="object"&&a.nodeType===O.sequenceNodeType.FUNCTION&&ot.indexOf(a.token.toLowerCase())>-1)}function ut(o,i){const{formula1:e="",ranges:t}=o;if(O.isReferenceString(e.slice(1))){const r=O.deserializeRangeWithSheet(e.slice(1));if((!r.sheetName||r.sheetName===i)&&t.some(n=>s.Rectangle.intersects(n,r.range)))return!0}return!1}class he extends p.BaseDataValidator{constructor(){super(...arguments);_(this,"formulaService",this.injector.get(h.DataValidationFormulaService));_(this,"_lexer",this.injector.get(O.LexerTreeBuilder));_(this,"_univerInstanceService",this.injector.get(s.IUniverInstanceService));_(this,"id",s.DataValidationType.LIST);_(this,"title","dataValidation.list.title");_(this,"operators",[]);_(this,"scopes",["sheet"]);_(this,"skipDefaultFontRender",e=>e.renderMode!==s.DataValidationRenderMode.TEXT)}validatorFormula(e,t,a){var d,c,m;const r=!s.Tools.isBlank(e.formula1),n=lt((d=e.formula1)!=null?d:"",this._lexer),l=(m=(c=this._univerInstanceService.getUnit(t,s.UniverInstanceType.UNIVER_SHEET))==null?void 0:c.getSheetBySheetId(a))==null?void 0:m.getName(),u=ut(e,l!=null?l:"");return{success:!!(r&&n&&!u),formula1:r?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 r=(n=a.tb!==s.WrapStrategy.OVERFLOW?a.tb:s.WrapStrategy.CLIP)!=null?n:s.WrapStrategy.WRAP;if(e.type===s.DataValidationType.LIST&&(e.renderMode===s.DataValidationRenderMode.ARROW||e.renderMode===s.DataValidationRenderMode.TEXT)){const l=this.getListWithColorMap(e),u=`${t!=null?t:""}`,d=l[u];if(d)return{bg:{rgb:d},tb:r}}return{tb:r}}parseCellValue(e){const t=e.toString();return G(t)}async parseFormula(e,t,a){var d,c,m,f;const{formula1:r=""}=e,n=await this.formulaService.getRuleFormulaResult(t,a,e.uid),l=A((c=(d=n==null?void 0:n[0])==null?void 0:d.result)==null?void 0:c[0][0]),u=y(String(l));return{formula1:s.isFormulaString(r)?ce((f=(m=n==null?void 0:n[0])==null?void 0:m.result)==null?void 0:f[0][0]):G(r),formula2:void 0,isFormulaValid:u}}async isValidType(e,t,a){const{value:r}=e,{formula1:n=[]}=t;return this.parseCellValue(r).every(u=>n.includes(u))}generateRuleName(){return this.localeService.t("dataValidation.list.name")}generateRuleErrorMessage(){return this.localeService.t("dataValidation.list.error")}getList(e,t,a){var f,v,S,R;const{formula1:r=""}=e,n=this.injector.get(s.IUniverInstanceService),l=(f=t?n.getUniverSheetInstance(t):void 0)!=null?f:n.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET);if(!l)return[];const u=(v=a?l.getSheetBySheetId(a):void 0)!=null?v:l.getActiveSheet();if(!u)return[];const d=l.getUnitId(),c=u.getSheetId(),m=this.formulaService.getRuleFormulaResultSync(d,c,e.uid);return s.isFormulaString(r)?ce((R=(S=m==null?void 0:m[0])==null?void 0:S.result)==null?void 0:R[0][0]):G(r)}async getListAsync(e,t,a){var f,v,S,R;const{formula1:r=""}=e,n=this.injector.get(s.IUniverInstanceService),l=(f=t?n.getUniverSheetInstance(t):void 0)!=null?f:n.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET);if(!l)return[];const u=(v=a?l.getSheetBySheetId(a):void 0)!=null?v:l.getActiveSheet();if(!u)return[];const d=l.getUnitId(),c=u.getSheetId(),m=await this.formulaService.getRuleFormulaResult(d,c,e.uid);return s.isFormulaString(r)?ce((R=(S=m==null?void 0:m[0])==null?void 0:S.result)==null?void 0:R[0][0]):G(r)}getListWithColor(e,t,a){const r=this.getList(e,t,a),n=(e.formula2||"").split(",");return r.map((l,u)=>({label:l,color:n[u]}))}getListWithColorMap(e,t,a){const r=this.getListWithColor(e,t,a),n={};return r.forEach(l=>{l.color&&(n[l.label]=l.color)}),n}}class dt extends p.BaseDataValidator{constructor(){super(...arguments);_(this,"id",s.DataValidationType.TEXT_LENGTH);_(this,"title","dataValidation.textLength.title");_(this,"_lexerTreeBuilder",this.injector.get(O.LexerTreeBuilder));_(this,"operators",[s.DataValidationOperator.BETWEEN,s.DataValidationOperator.EQUAL,s.DataValidationOperator.GREATER_THAN,s.DataValidationOperator.GREATER_THAN_OR_EQUAL,s.DataValidationOperator.LESS_THAN,s.DataValidationOperator.LESS_THAN_OR_EQUAL,s.DataValidationOperator.NOT_BETWEEN,s.DataValidationOperator.NOT_EQUAL]);_(this,"scopes",["sheet"]);_(this,"_customFormulaService",this.injector.get(h.DataValidationCustomFormulaService))}_isFormulaOrInt(e){return!s.Tools.isBlank(e)&&(s.isFormulaString(e)||!Number.isNaN(+e)&&Number.isInteger(+e))}validatorFormula(e,t,a){const r=e.operator;if(!r)return{success:!1};const n=s.Tools.isDefine(e.formula1)&&this._isFormulaOrInt(e.formula1),l=s.Tools.isDefine(e.formula2)&&this._isFormulaOrInt(e.formula2),u=z.includes(r),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}_isValidFormula(e){return!Number.isNaN(e)}async parseFormula(e,t,a,r,n){const l=await this._customFormulaService.getCellFormulaValue(t,a,e.uid,r,n),u=await this._customFormulaService.getCellFormula2Value(t,a,e.uid,r,n),{formula1:d,formula2:c}=e,m=y(String(l==null?void 0:l.v))&&y(String(u==null?void 0:u.v));return{formula1:this._parseNumber(s.isFormulaString(d)?l==null?void 0:l.v:d),formula2:this._parseNumber(s.isFormulaString(c)?u==null?void 0:u.v:c),isFormulaValid:m}}transform(e,t,a){return{...e,value:e.value.toString().length}}async isValidType(e,t,a){const{value:r}=e;return typeof r=="string"||typeof r=="number"}async validatorIsEqual(e,t,a){const{formula1:r}=t;return s.Tools.isDefine(r)?e.value===r:!1}async validatorIsNotEqual(e,t,a){const{formula1:r}=t;return s.Tools.isDefine(r)?e.value!==r:!1}async validatorIsBetween(e,t,a){const{formula1:r,formula2:n}=t,{value:l}=e;if(!this._isValidFormula(r)||!this._isValidFormula(n))return!1;const u=Math.max(r,n),d=Math.min(r,n);return l>=d&&l<=u}async validatorIsNotBetween(e,t,a){const{formula1:r,formula2:n}=t,{value:l}=e;if(!this._isValidFormula(r)||!this._isValidFormula(n))return!1;const u=Math.max(r,n),d=Math.min(r,n);return l<d||l>u}async validatorIsGreaterThan(e,t,a){const{formula1:r}=t,{value:n}=e;return this._isValidFormula(r)?n>r:!1}async validatorIsGreaterThanOrEqual(e,t,a){const{formula1:r}=t,{value:n}=e;return this._isValidFormula(r)?n>=r:!1}async validatorIsLessThan(e,t,a){const{formula1:r}=t,{value:n}=e;return this._isValidFormula(r)?n<r:!1}async validatorIsLessThanOrEqual(e,t,a){const{formula1:r}=t,{value:n}=e;return this._isValidFormula(r)?n<=r:!1}generateRuleErrorMessage(e,t){if(!e.operator)return this.titleStr;const{transformedFormula1:a,transformedFormula2:r}=Z(this._lexerTreeBuilder,e,t);return`${this.localeService.t(p.TextLengthErrorTitleMap[e.operator]).replace(k,a!=null?a:"").replace(q,r!=null?r:"")}`}}function Te(o){var e,t;return o?o.p?!((t=(e=o.p.body)==null?void 0:e.dataStream)!=null?t:"").slice(0,-2).trim():s.Tools.isBlank(o.v):!0}function Q(o,i,e,t,a="command",r=!0){const n=t.get(O.LexerTreeBuilder),l=[],u=[],d=t.get(h.SheetDataValidationModel),c=t.get(s.IUniverInstanceService),m=D.getSheetCommandTarget(c,{unitId:o,subUnitId:i});if(!m)return{redoMutations:l,undoMutations:u};const{worksheet:f}=m,v=new s.ObjectMatrix;let S=!1;function R(g,M){r&&g.forEach(N=>{s.Range.foreach(N,(I,w)=>{const E=f.getCellRaw(I,w),P=Re(E);(Te(E)||P===M)&&(S=!0,v.setValue(I,w,{v:M,p:null}))})})}if(e.forEach(g=>{switch(g.type){case"delete":l.push({id:p.RemoveDataValidationMutation.id,params:{unitId:o,subUnitId:i,ruleId:g.rule.uid,source:a}}),u.unshift({id:p.AddDataValidationMutation.id,params:{unitId:o,subUnitId:i,rule:g.rule,index:g.index,source:a}});break;case"update":{if(H(g.rule.type)){const N=g.oldRanges[0].startRow,I=g.oldRanges[0].startColumn,w=g.newRanges[0].startRow,E=g.newRanges[0].startColumn,P=w-N,ne=E-I,se=s.isFormulaString(g.rule.formula1)?n.moveFormulaRefOffset(g.rule.formula1,ne,P):g.rule.formula1,oe=s.isFormulaString(g.rule.formula2)?n.moveFormulaRefOffset(g.rule.formula2,ne,P):g.rule.formula2;(se!==g.rule.formula1||oe!==g.rule.formula2||!s.isRangesEqual(g.newRanges,g.oldRanges))&&(l.push({id:p.UpdateDataValidationMutation.id,params:{unitId:o,subUnitId:i,ruleId:g.ruleId,payload:{type:p.UpdateRuleType.ALL,payload:{formula1:se,formula2:oe,ranges:g.newRanges}}}}),u.unshift({id:p.UpdateDataValidationMutation.id,params:{unitId:o,subUnitId:i,ruleId:g.ruleId,payload:{type:p.UpdateRuleType.ALL,payload:{formula1:g.rule.formula1,formula2:g.rule.formula2,ranges:g.oldRanges}}}}))}else l.push({id:p.UpdateDataValidationMutation.id,params:{unitId:o,subUnitId:i,ruleId:g.ruleId,payload:{type:p.UpdateRuleType.RANGE,payload:g.newRanges},source:a}}),u.unshift({id:p.UpdateDataValidationMutation.id,params:{unitId:o,subUnitId:i,ruleId:g.ruleId,payload:{type:p.UpdateRuleType.RANGE,payload:g.oldRanges},source:a}});const M=d.getRuleById(o,i,g.ruleId);if(M&&M.type===s.DataValidationType.CHECKBOX){const I=d.getValidator(s.DataValidationType.CHECKBOX).parseFormulaSync(M,o,i);R(g.newRanges,I.formula2)}break}case"add":{if(l.push({id:p.AddDataValidationMutation.id,params:{unitId:o,subUnitId:i,rule:g.rule,source:a}}),u.unshift({id:p.RemoveDataValidationMutation.id,params:{unitId:o,subUnitId:i,ruleId:g.rule.uid,source:a}}),g.rule.type===s.DataValidationType.CHECKBOX){const N=d.getValidator(s.DataValidationType.CHECKBOX).parseFormulaSync(g.rule,o,i);R(g.rule.ranges,N.originFormula2)}break}}}),S){const g={id:D.SetRangeValuesMutation.id,params:{unitId:o,subUnitId:i,cellValue:v.getData()}},M={id:D.SetRangeValuesMutation.id,params:D.SetRangeValuesUndoMutationFactory(t,g.params)};l.push(g),u.push(M)}return{redoMutations:l,undoMutations:u}}const Ne={type:s.CommandType.COMMAND,id:"sheet.command.updateDataValidationRuleRange",handler(o,i){if(!i)return!1;const{unitId:e,subUnitId:t,ranges:a,ruleId:r}=i,n=o.get(h.SheetDataValidationModel),l=o.get(s.ICommandService),u=o.get(s.IUndoRedoService);if(!n.getRuleById(e,t,r))return!1;const c=n.getRuleObjectMatrix(e,t).clone();c.updateRange(r,a);const m=c.diff(n.getRules(e,t)),{redoMutations:f,undoMutations:v}=Q(e,t,m,o);return u.pushUndoRedo({undoMutations:v,redoMutations:f,unitID:e}),s.sequenceExecute(f,l),!0}},Oe={type:s.CommandType.COMMAND,id:"sheet.command.addDataValidation",handler(o,i){if(!i)return!1;const{unitId:e,subUnitId:t,rule:a}=i,r=o.get(h.SheetDataValidationModel),n=o.get(s.ICommandService),l=o.get(s.IUndoRedoService),u=r.getRuleObjectMatrix(e,t).clone();u.addRule(a);const d=u.diff(r.getRules(e,t)),c=r.getValidator(a.type),m={unitId:e,subUnitId:t,rule:{...a,...c==null?void 0:c.normalizeFormula(a,e,t)}},{redoMutations:f,undoMutations:v}=Q(e,t,d,o);return f.push({id:p.AddDataValidationMutation.id,params:m}),v.unshift({id:p.RemoveDataValidationMutation.id,params:{unitId:e,subUnitId:t,ruleId:a.uid}}),l.pushUndoRedo({unitID:e,redoMutations:f,undoMutations:v}),s.sequenceExecute(f,n),!0}},Ie={type:s.CommandType.COMMAND,id:"sheets.command.update-data-validation-setting",handler(o,i){if(!i)return!1;const e=o.get(s.ICommandService),t=o.get(s.IUndoRedoService),a=o.get(h.SheetDataValidationModel),r=o.get(p.DataValidatorRegistryService),{unitId:n,subUnitId:l,ruleId:u,setting:d}=i,c=r.getValidatorItem(d.type);if(!c)return!1;const m=a.getRuleById(n,l,u);if(!m)return!1;const f={...m,...d};if(!c.validatorFormula(f,n,l).success)return!1;const v={unitId:n,subUnitId:l,ruleId:u,payload:{type:p.UpdateRuleType.SETTING,payload:{...d,...c.normalizeFormula(f,n,l)}}},S=[{id:p.UpdateDataValidationMutation.id,params:v}],R={unitId:n,subUnitId:l,ruleId:u,payload:{type:p.UpdateRuleType.SETTING,payload:p.getRuleSetting(m)}},g=[{id:p.UpdateDataValidationMutation.id,params:R}];if(d.type===s.DataValidationType.CHECKBOX){const N=m.ranges,I=o.get(s.IUniverInstanceService),w=D.getSheetCommandTarget(I,{unitId:n,subUnitId:l});if(w){const E=new s.ObjectMatrix,{worksheet:P}=w,{formula2:ne=W,formula1:se=$}=m,{formula2:oe=W,formula1:jt=$}=d;N.forEach($t=>{s.Range.foreach($t,(_e,ge)=>{const je=P.getCellRaw(_e,ge),He=Re(je);Te(je)||He===String(ne)?E.setValue(_e,ge,{v:oe,p:null}):He===String(se)&&E.setValue(_e,ge,{v:jt,p:null})})});const Pe={id:D.SetRangeValuesMutation.id,params:{unitId:n,subUnitId:l,cellValue:E.getData()}},Ht={id:D.SetRangeValuesMutation.id,params:D.SetRangeValuesUndoMutationFactory(o,Pe.params)};S.push(Pe),g.push(Ht)}}return s.sequenceExecute(S,e).result?(t.pushUndoRedo({unitID:n,redoMutations:S,undoMutations:g}),!0):!1}},Ee={type:s.CommandType.COMMAND,id:"sheets.command.update-data-validation-options",handler(o,i){if(!i)return!1;const e=o.get(s.ICommandService),t=o.get(s.IUndoRedoService),a=o.get(h.SheetDataValidationModel),{unitId:r,subUnitId:n,ruleId:l,options:u}=i,d=a.getRuleById(r,n,l);if(!d)return!1;const c={unitId:r,subUnitId:n,ruleId:l,payload:{type:p.UpdateRuleType.OPTIONS,payload:u}},m=[{id:p.UpdateDataValidationMutation.id,params:c}],f={unitId:r,subUnitId:n,ruleId:l,payload:{type:p.UpdateRuleType.OPTIONS,payload:p.getRuleOptions(d)}},v=[{id:p.UpdateDataValidationMutation.id,params:f}];return t.pushUndoRedo({unitID:r,redoMutations:m,undoMutations:v}),e.executeCommand(p.UpdateDataValidationMutation.id,c),!0}},Fe={type:s.CommandType.COMMAND,id:"sheets.command.clear-range-data-validation",handler(o,i){if(!i)return!1;const{unitId:e,subUnitId:t,ranges:a}=i,r=o.get(s.ICommandService),n=o.get(s.IUniverInstanceService),l=D.getSheetCommandTarget(n,{unitId:e,subUnitId:t}),u=o.get(h.SheetDataValidationModel);if(!l)return!1;const d=o.get(s.IUndoRedoService),c=u.getRuleObjectMatrix(e,t).clone();c.removeRange(a);const m=c.diff(u.getRules(e,t)),{redoMutations:f,undoMutations:v}=Q(e,t,m,o);return d.pushUndoRedo({unitID:e,redoMutations:f,undoMutations:v}),s.sequenceExecute(f,r).result}},Ce={type:s.CommandType.COMMAND,id:"sheet.command.remove-all-data-validation",handler(o,i){if(!i)return!1;const{unitId:e,subUnitId:t}=i,a=o.get(s.ICommandService),r=o.get(h.SheetDataValidationModel),n=o.get(s.IUndoRedoService),l=[...r.getRules(e,t)],u={unitId:e,subUnitId:t,ruleId:l.map(m=>m.uid)},d=[{id:p.RemoveDataValidationMutation.id,params:u}],c=[{id:p.AddDataValidationMutation.id,params:{unitId:e,subUnitId:t,rule:l}}];return n.pushUndoRedo({redoMutations:d,undoMutations:c,unitID:e}),a.executeCommand(p.RemoveDataValidationMutation.id,u),!0}},ct=(o,i)=>{const e=o.get(h.SheetDataValidationModel),{unitId:t,subUnitId:a,ruleId:r,source:n}=i;if(Array.isArray(r)){const u=r.map(d=>e.getRuleById(t,a,d)).filter(Boolean);return[{id:p.AddDataValidationMutation.id,params:{unitId:t,subUnitId:a,rule:u,source:n}}]}return[{id:p.AddDataValidationMutation.id,params:{unitId:t,subUnitId:a,rule:{...e.getRuleById(t,a,r)},index:e.getRuleIndex(t,a,r)}}]},we={type:s.CommandType.COMMAND,id:"sheet.command.remove-data-validation-rule",handler(o,i){if(!i)return!1;const{unitId:e,subUnitId:t,ruleId:a}=i,r=o.get(s.ICommandService),n=o.get(s.IUndoRedoService),l=o.get(h.SheetDataValidationModel),u=[{id:p.RemoveDataValidationMutation.id,params:i}],d=[{id:p.AddDataValidationMutation.id,params:{unitId:e,subUnitId:t,rule:{...l.getRuleById(e,t,a)},index:l.getRuleIndex(e,t,a)}}];return n.pushUndoRedo({undoMutations:d,redoMutations:u,unitID:i.unitId}),r.executeCommand(p.RemoveDataValidationMutation.id,i),!0}},ht="sheets-data-validation.config",mt={};class ft extends p.BaseDataValidator{constructor(){super(...arguments);_(this,"id",s.DataValidationType.ANY);_(this,"title","dataValidation.any.title");_(this,"operators",[]);_(this,"scopes",["sheet"])}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 pt extends p.BaseDataValidator{constructor(){super(...arguments);_(this,"id",s.DataValidationType.CUSTOM);_(this,"title","dataValidation.custom.title");_(this,"operators",[]);_(this,"scopes",["sheet"]);_(this,"_customFormulaService",this.injector.get(h.DataValidationCustomFormulaService))}validatorFormula(e,t,a){const r=s.isFormulaString(e.formula1);return{success:r,formula1:r?"":this.localeService.t("dataValidation.validFail.formula")}}async parseFormula(e,t,a){return{formula1:void 0,formula2:void 0,isFormulaValid:!0}}async isValidType(e,t,a){const{column:r,row:n,unitId:l,subUnitId:u}=e,d=await this._customFormulaService.getCellFormulaValue(l,u,a.uid,n,r),c=d==null?void 0:d.v;return y(String(c))&&s.Tools.isDefine(c)&&c!==""?d.t===s.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 be extends he{constructor(){super(...arguments);_(this,"id",s.DataValidationType.LIST_MULTIPLE);_(this,"title","dataValidation.listMultiple.title");_(this,"skipDefaultFontRender",()=>!0)}}class _t extends p.BaseDataValidator{constructor(){super(...arguments);_(this,"_customFormulaService",this.injector.get(h.DataValidationCustomFormulaService));_(this,"_lexerTreeBuilder",this.injector.get(O.LexerTreeBuilder));_(this,"id",s.DataValidationType.WHOLE);_(this,"title","dataValidation.whole.title");_(this,"operators",[s.DataValidationOperator.BETWEEN,s.DataValidationOperator.EQUAL,s.DataValidationOperator.GREATER_THAN,s.DataValidationOperator.GREATER_THAN_OR_EQUAL,s.DataValidationOperator.LESS_THAN,s.DataValidationOperator.LESS_THAN_OR_EQUAL,s.DataValidationOperator.NOT_BETWEEN,s.DataValidationOperator.NOT_EQUAL]);_(this,"scopes",["sheet"])}_isFormulaOrInt(e){return!s.Tools.isBlank(e)&&(s.isFormulaString(e)||!Number.isNaN(+e)&&Number.isInteger(+e))}async isValidType(e,t,a){const{value:r}=e,n=J(r);return!Number.isNaN(n)&&Number.isInteger(n)}transform(e,t,a){const{value:r}=e;return{...e,value:J(r)}}_parseNumber(e){return e==null?Number.NaN:+e}async parseFormula(e,t,a,r,n){const l=await this._customFormulaService.getCellFormulaValue(t,a,e.uid,r,n),u=await this._customFormulaService.getCellFormula2Value(t,a,e.uid,r,n),{formula1:d,formula2:c}=e,m=s.isFormulaString(d)?l==null?void 0:l.v:d,f=s.isFormulaString(c)?u==null?void 0:u.v:c,v=y(`${m}`)&&y(`${f}`);return{formula1:this._parseNumber(m),formula2:this._parseNumber(f),isFormulaValid:v}}validatorFormula(e,t,a){const r=e.operator;if(!r)return{success:!1};const n=s.Tools.isDefine(e.formula1)&&this._isFormulaOrInt(e.formula1),l=s.Tools.isDefine(e.formula2)&&this._isFormulaOrInt(e.formula2),u=z.includes(r),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}}async validatorIsEqual(e,t,a){const{formula1:r}=t,{value:n}=e;return Number.isNaN(r)?!0:n===r}async validatorIsNotEqual(e,t,a){const{formula1:r}=t;return Number.isNaN(r)?!0:e.value!==r}async validatorIsBetween(e,t,a){const{formula1:r,formula2:n}=t;if(Number.isNaN(r)||Number.isNaN(n))return!0;const l=Math.min(r,n),u=Math.max(r,n);return e.value>=l&&e.value<=u}async validatorIsNotBetween(e,t,a){const{formula1:r,formula2:n}=t;if(Number.isNaN(r)||Number.isNaN(n))return!0;const l=Math.min(r,n),u=Math.max(r,n);return e.value<l||e.value>u}async validatorIsGreaterThan(e,t,a){const{formula1:r}=t;return Number.isNaN(r)?!0:e.value>r}async validatorIsGreaterThanOrEqual(e,t,a){const{formula1:r}=t;return Number.isNaN(r)?!0:e.value>=r}async validatorIsLessThan(e,t,a){const{formula1:r}=t;return Number.isNaN(r)?!0:e.value<r}async validatorIsLessThanOrEqual(e,t,a){const{formula1:r}=t;return Number.isNaN(r)?!0:e.value<=r}generateRuleErrorMessage(e,t){if(!e.operator)return this.titleStr;const{transformedFormula1:a,transformedFormula2:r}=Z(this._lexerTreeBuilder,e,t);return`${this.localeService.t(ye[e.operator]).replace(k,a!=null?a:"").replace(q,r!=null?r:"")}`}}var gt=Object.defineProperty,vt=Object.getOwnPropertyDescriptor,St=(o,i,e,t)=>{for(var a=t>1?void 0:t?vt(i,e):i,r=o.length-1,n;r>=0;r--)(n=o[r])&&(a=(t?n(i,e,a):n(a))||a);return t&&a&>(i,e,a),a},L=(o,i)=>(e,t)=>i(e,t,o);let ee=class extends s.RxDisposable{constructor(o,i,e,t,a,r){super(),this._univerInstanceService=o,this._dataValidatorRegistryService=i,this._injector=e,this._selectionManagerService=t,this._sheetInterceptorService=a,this._sheetDataValidationModel=r,this._init()}_init(){this._registerValidators(),this._initCommandInterceptor()}_registerValidators(){[ft,st,_t,dt,Me,De,he,be,pt].forEach(o=>{const i=this._injector.createInstance(o);this.disposeWithMe(this._dataValidatorRegistryService.register(i)),this.disposeWithMe(s.toDisposable(()=>this._injector.delete(o)))})}_initCommandInterceptor(){this._sheetInterceptorService.interceptCommand({getMutations:o=>{var i;if(o.id===D.ClearSelectionAllCommand.id){const e=this._univerInstanceService.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET),t=e.getUnitId(),a=e.getActiveSheet();if(!a)throw new Error("No active sheet found");const r=a.getSheetId(),n=(i=this._selectionManagerService.getCurrentSelections())==null?void 0:i.map(m=>m.range),l=this._sheetDataValidationModel.getRuleObjectMatrix(t,r).clone();n&&l.removeRange(n);const u=l.diff(this._sheetDataValidationModel.getRules(t,r)),{redoMutations:d,undoMutations:c}=Q(t,r,u,this._injector,"patched");return{undos:c,redos:d}}return{undos:[],redos:[]}}})}};ee=St([L(0,s.IUniverInstanceService),L(1,s.Inject(p.DataValidatorRegistryService)),L(2,s.Inject(s.Injector)),L(3,s.Inject(D.SheetsSelectionsService)),L(4,s.Inject(D.SheetInterceptorService)),L(5,s.Inject(h.SheetDataValidationModel))],ee);var Ae=(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))(Ae||{}),Rt=Object.defineProperty,Vt=Object.getOwnPropertyDescriptor,Dt=(o,i,e,t)=>{for(var a=t>1?void 0:t?Vt(i,e):i,r=o.length-1,n;r>=0;r--)(n=o[r])&&(a=(t?n(i,e,a):n(a))||a);return t&&a&&Rt(i,e,a),a},me=(o,i)=>(e,t)=>i(e,t,o);h.DataValidationFormulaController=class extends s.Disposable{constructor(i,e,t){super(),this._univerInstanceService=i,this._permissionService=e,this._lexerTreeBuilder=t}getFormulaRefCheck(i){var t,a;const e=this._lexerTreeBuilder.sequenceNodesBuilder(i);if(!e)return!0;for(let r=0;r<e.length;r++){const n=e[r];if(typeof n=="string")continue;const{token:l}=n,u=O.deserializeRangeWithSheetWithCache(l),d=this._univerInstanceService.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET);let c=d.getActiveSheet();const m=d.getUnitId();if(u.sheetName){if(c=d.getSheetBySheetName(u.sheetName),!c)return!1;const g=c==null?void 0:c.getSheetId();if(!this._permissionService.getPermissionPoint(new D.WorksheetViewPermission(m,g).id))return!1}if(!c)return!1;const{startRow:f,endRow:v,startColumn:S,endColumn:R}=u.range;for(let g=f;g<=v;g++)for(let M=S;M<=R;M++){const N=(a=(t=c.getCell(g,M))==null?void 0:t.selectionProtection)==null?void 0:a[0];if((N==null?void 0:N[Ae.View])===!1)return!1}}return!0}},h.DataValidationFormulaController=Dt([me(0,s.IUniverInstanceService),me(1,s.IPermissionService),me(2,s.Inject(O.LexerTreeBuilder))],h.DataValidationFormulaController);var Mt=Object.defineProperty,yt=Object.getOwnPropertyDescriptor,Tt=(o,i,e,t)=>{for(var a=t>1?void 0:t?yt(i,e):i,r=o.length-1,n;r>=0;r--)(n=o[r])&&(a=(t?n(i,e,a):n(a))||a);return t&&a&&Mt(i,e,a),a},Ue=(o,i)=>(e,t)=>i(e,t,o);let te=class extends s.Disposable{constructor(i,e){super();_(this,"_disposableMap",new Map);_(this,"registerRule",(i,e,t)=>{H(t.type)&&this.register(i,e,t)});this._dataValidationModel=i,this._formulaRefRangeService=e,this._initRefRange()}_getIdWithUnitId(i,e,t){return`${i}_${e}_${t}`}register(i,e,t){const a=t.ranges,r=t.formula1,n=t.formula2,l=this._formulaRefRangeService.registerRangeFormula(i,e,a,[r!=null?r:"",n!=null?n:""],d=>{if(d.length===0)return{undos:[{id:p.AddDataValidationMutation.id,params:{unitId:i,subUnitId:e,rule:t}}],redos:[{id:p.RemoveDataValidationMutation.id,params:{unitId:i,subUnitId:e,ruleId:t.uid}}]};const c=[],m=[],f=d[0];c.push({id:p.UpdateDataValidationMutation.id,params:{unitId:i,subUnitId:e,ruleId:t.uid,payload:{type:p.UpdateRuleType.ALL,payload:{ranges:f.ranges,formula1:f.formulas[0],formula2:f.formulas[1]}}}}),m.push({id:p.UpdateDataValidationMutation.id,params:{unitId:i,subUnitId:e,ruleId:t.uid,payload:{type:p.UpdateRuleType.ALL,payload:{ranges:a,formula1:r,formula2:n}}}});for(let v=1;v<d.length;v++){const S=d[v],R=s.generateRandomId();c.push({id:p.AddDataValidationMutation.id,params:{unitId:i,subUnitId:e,rule:{...t,uid:R,formula1:S.formulas[0],formula2:S.formulas[1],ranges:S.ranges}}}),m.push({id:p.RemoveDataValidationMutation.id,params:{unitId:i,subUnitId:e,ruleId:R}})}return{undos:m,redos:c}}),u=this._getIdWithUnitId(i,e,t.uid);this._disposableMap.set(u,l)}_initRefRange(){const i=this._dataValidationModel.getAll();for(const[e,t]of i)for(const[a,r]of t)for(const n of r)this.registerRule(e,a,n);this.disposeWithMe(this._dataValidationModel.ruleChange$.subscribe(e=>{const{unitId:t,subUnitId:a,rule:r}=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,r.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(s.toDisposable(()=>{this._disposableMap.forEach(e=>{e.dispose()}),this._disposableMap.clear()}))}};te=Tt([Ue(0,s.Inject(h.SheetDataValidationModel)),Ue(1,s.Inject(Y.FormulaRefRangeService))],te);var Nt=Object.defineProperty,Ot=Object.getOwnPropertyDescriptor,It=(o,i,e,t)=>{for(var a=t>1?void 0:t?Ot(i,e):i,r=o.length-1,n;r>=0;r--)(n=o[r])&&(a=(t?n(i,e,a):n(a))||a);return t&&a&&Nt(i,e,a),a},B=(o,i)=>(e,t)=>i(e,t,o);let ae=class extends s.Disposable{constructor(i,e,t,a,r,n){super();_(this,"_disposableMap",new Map);_(this,"registerRule",(i,e,t)=>{H(t.type)||(this.register(i,e,t),this.registerFormula(i,e,t))});this._dataValidationModel=i,this._injector=e,this._refRangeService=t,this._dataValidationCustomFormulaService=a,this._dataValidationFormulaService=r,this._formulaRefRangeService=n,this._initRefRange()}_getIdWithUnitId(i,e,t){return`${i}_${e}_${t}`}registerFormula(i,e,t){var d;const a=t.uid,r=this._getIdWithUnitId(i,e,a),n=(d=this._disposableMap.get(r))!=null?d:new Set,l=(c,m)=>{const f=this._dataValidationModel.getRuleById(i,e,a);if(!f)return{redos:[],undos:[]};const v=f[c];if(!v||v===m)return{redos:[],undos:[]};const S={unitId:i,subUnitId:e,ruleId:t.uid,payload:{type:p.UpdateRuleType.SETTING,payload:{type:f.type,formula1:f.formula1,formula2:f.formula2,[c]:m}}},R={unitId:i,subUnitId:e,ruleId:t.uid,payload:{type:p.UpdateRuleType.SETTING,payload:{type:f.type,formula1:f.formula1,formula2:f.formula2}}},g=[{id:p.UpdateDataValidationMutation.id,params:S}],M=[{id:p.UpdateDataValidationMutation.id,params:R}];return{redos:g,undos:M}},u=this._dataValidationFormulaService.getRuleFormulaInfo(i,e,a);if(u){const[c,m]=u;if(c){const f=this._formulaRefRangeService.registerFormula(i,e,c.text,v=>l("formula1",v));n.add(()=>f.dispose())}if(m){const f=this._formulaRefRangeService.registerFormula(i,e,m.text,v=>l("formula2",v));n.add(()=>f.dispose())}}}register(i,e,t){var u;const a=d=>{const c=[...t.ranges],f=c.map(S=>D.handleCommonDefaultRangeChangeWithEffectRefCommands(S,d)).filter(S=>!!S).flat();if(s.isRangesEqual(f,c))return{redos:[],undos:[]};if(f.length){const S={unitId:i,subUnitId:e,ruleId:t.uid,payload:{type:p.UpdateRuleType.RANGE,payload:f},source:"patched"},R=[{id:p.UpdateDataValidationMutation.id,params:S}],g=[{id:p.UpdateDataValidationMutation.id,params:{unitId:i,subUnitId:e,ruleId:t.uid,payload:{type:p.UpdateRuleType.RANGE,payload:c},source:"patched"}}];return{redos:R,undos:g}}else{const S={unitId:i,subUnitId:e,ruleId:t.uid},R=[{id:p.RemoveDataValidationMutation.id,params:S}],g=ct(this._injector,S);return{redos:R,undos:g}}},r=[];t.ranges.forEach(d=>{const c=this._refRangeService.registerRefRange(d,a,i,e);r.push(()=>c.dispose())});const n=this._getIdWithUnitId(i,e,t.uid),l=(u=this._disposableMap.get(n))!=null?u:new Set;l.add(()=>r.forEach(d=>d())),this._disposableMap.set(n,l)}_initRefRange(){const i=this._dataValidationModel.getAll();for(const[e,t]of i)for(const[a,r]of t)for(const n of r)this.registerRule(e,a,n);this.disposeWithMe(this._dataValidationModel.ruleChange$.subscribe(e=>{const{unitId:t,subUnitId:a,rule:r}=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,r.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(s.toDisposable(()=>{this._disposableMap.forEach(e=>{e.forEach(t=>t())}),this._disposableMap.clear()}))}};ae=It([B(0,s.Inject(h.SheetDataValidationModel)),B(1,s.Inject(s.Injector)),B(2,s.Inject(D.RefRangeService)),B(3,s.Inject(h.DataValidationCustomFormulaService)),B(4,s.Inject(h.DataValidationFormulaService)),B(5,s.Inject(Y.FormulaRefRangeService))],ae);var Et=Object.defineProperty,Ft=Object.getOwnPropertyDescriptor,Ct=(o,i,e,t)=>{for(var a=t>1?void 0:t?Ft(i,e):i,r=o.length-1,n;r>=0;r--)(n=o[r])&&(a=(t?n(i,e,a):n(a))||a);return t&&a&&Et(i,e,a),a},fe=(o,i)=>(e,t)=>i(e,t,o);let ie=class extends s.Disposable{constructor(o,i,e){super(),this._sheetInterceptorService=o,this._univerInstanceService=i,this._sheetDataValidationModel=e,this._initSheetChange()}_initSheetChange(){this.disposeWithMe(this._sheetInterceptorService.interceptCommand({getMutations:o=>{var i;if(o.id===D.RemoveSheetCommand.id){const e=o.params,t=e.unitId||this._univerInstanceService.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET).getUnitId(),a=this._univerInstanceService.getUniverSheetInstance(t);if(!a)return{redos:[],undos:[]};const r=e.subUnitId||((i=a.getActiveSheet())==null?void 0:i.getSheetId());if(!r)return{redos:[],undos:[]};const n=this._sheetDataValidationModel.getRules(t,r);if(n.length===0)return{redos:[],undos:[]};const l=n.map(c=>c.uid),u={unitId:t,subUnitId:r,ruleId:l,source:"patched"},d={unitId:t,subUnitId:r,rule:[...n],source:"patched"};return{redos:[{id:p.RemoveDataValidationMutation.id,params:u}],undos:[{id:p.AddDataValidationMutation.id,params:d}]}}return{redos:[],undos:[]}}}))}};ie=Ct([fe(0,s.Inject(D.SheetInterceptorService)),fe(1,s.Inject(s.IUniverInstanceService)),fe(2,s.Inject(h.SheetDataValidationModel))],ie);var wt=Object.defineProperty,bt=Object.getOwnPropertyDescriptor,At=(o,i,e,t)=>{for(var a=t>1?void 0:t?bt(i,e):i,r=o.length-1,n;r>=0;r--)(n=o[r])&&(a=(t?n(i,e,a):n(a))||a);return t&&a&&wt(i,e,a),a},re=(o,i)=>(e,t)=>i(e,t,o);h.SheetsDataValidationValidatorService=class extends s.Disposable{constructor(i,e,t,a){super(),this._univerInstanceService=i,this._sheetDataValidationModel=e,this._dataValidationCacheService=t,this._lifecycleService=a,this._initRecalculate()}_initRecalculate(){const i=e=>{if(e.length===0)return;const t=this._univerInstanceService.getCurrentUnitForType(s.UniverInstanceType.UNIVER_SHEET),a=t==null?void 0:t.getActiveSheet(),r={};e.flat().forEach(n=>{r[n.unitId]||(r[n.unitId]={}),r[n.unitId][n.subUnitId]||(r[n.unitId][n.subUnitId]=[]);const l=this._univerInstanceService.getUnit(n.unitId,s.UniverInstanceType.UNIVER_SHEET),u=l==null?void 0:l.getSheetBySheetId(n.subUnitId);u&&r[n.unitId][n.subUnitId].push(...n.ranges.map(d=>s.Range.transformRange(d,u)))}),Object.entries(r).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(b.bufferWhen(()=>this._lifecycleService.lifecycle$.pipe(b.filter(e=>e===s.LifecycleStages.Rendered)))).subscribe(i)),this.disposeWithMe(this._dataValidationCacheService.dirtyRanges$.pipe(b.filter(()=>this._lifecycleService.stage>=s.LifecycleStages.Rendered),s.bufferDebounceTime(20)).subscribe(i))}async _validatorByCell(i,e,t,a){const r=i.getUnitId(),n=e.getSheetId();if(!s.Tools.isDefine(t)||!s.Tools.isDefine(a))throw new Error(`row or col is not defined, row: ${t}, col: ${a}`);const l=this._sheetDataValidationModel.getRuleByLocation(r,n,t,a);return l?new Promise(u=>{this._sheetDataValidationModel.validator(l,{unitId:r,subUnitId:n,row:t,col:a,worksheet:e,workbook:i},d=>{u(d)})}):s.DataValidationStatus.VALID}async validatorCell(i,e,t,a){const r=this._univerInstanceService.getUnit(i,s.UniverInstanceType.UNIVER_SHEET);if(!r)throw new Error(`cannot find current workbook, unitId: ${i}`);const n=r.getSheetBySheetId(e);if(!n)throw new Error(`cannot find current worksheet, sheetId: ${e}`);return this._validatorByCell(r,n,t,a)}validatorRanges(i,e,t){const a=this._univerInstanceService.getUnit(i,s.UniverInstanceType.UNIVER_SHEET);if(!a)throw new Error(`cannot find current workbook, unitId: ${i}`);const r=a.getSheetBySheetId(e);if(!r)throw new Error(`cannot find current worksheet, sheetId: ${e}`);return Promise.all(t.map(n=>{const l=[];return s.Range.foreach(n,(u,d)=>{l.push(this._validatorByCell(a,r,u,d))}),l}))}async validatorWorksheet(i,e){const t=this._univerInstanceService.getUnit(i,s.UniverInstanceType.UNIVER_SHEET);if(!t)throw new Error(`cannot find current workbook, unitId: ${i}`);const a=t.getSheetBySheetId(e);if(!a)throw new Error(`cannot find current worksheet, sheetId: ${e}`);const r=this._sheetDataValidationModel.getRules(i,e);return await Promise.all(r.map(n=>Promise.all(n.ranges.map(l=>{const u=[];return s.Range.foreach(l,(d,c)=>{u.push(this._validatorByCell(t,a,d,c))}),u})))),this._dataValidationCacheService.ensureCache(i,e)}async validatorWorkbook(i){const e=this._sheetDataValidationModel.getSubUnitIds(i),t=await Promise.all(e.map(r=>this.validatorWorksheet(i,r))),a={};return t.forEach((r,n)=>{a[e[n]]=r}),a}getDataValidations(i,e,t){const a=this._sheetDataValidationModel.getRuleObjectMatrix(i,e),r=new Set;return t.forEach(l=>{s.Range.foreach(l,(u,d)=>{const c=a.getValue(u,d);c&&r.add(c)})}),Array.from(r).map(l=>this._sheetDataValidationModel.getRuleById(i,e,l)).filter(Boolean)}getDataValidation(i,e,t){return this.getDataValidations(i,e,t)[0]}},h.SheetsDataValidationValidatorService=At([re(0,s.IUniverInstanceService),re(1,s.Inject(h.SheetDataValidationModel)),re(2,s.Inject(h.DataValidationCacheService)),re(3,s.Inject(s.LifecycleService))],h.SheetsDataValidationValidatorService);var Le=Object.defineProperty,Ut=Object.getOwnPropertyDescriptor,Lt=(o,i,e)=>i in o?Le(o,i,{enumerable:!0,configurable:!0,writable:!0,value:e}):o[i]=e,Bt=(o,i,e,t)=>{for(var a=t>1?void 0:t?Ut(i,e):i,r=o.length-1,n;r>=0;r--)(n=o[r])&&(a=(t?n(i,e,a):n(a))||a);return t&&a&&Le(i,e,a),a},pe=(o,i)=>(e,t)=>i(e,t,o),Be=(o,i,e)=>Lt(o,typeof i!="symbol"?i+"":i,e);h.UniverSheetsDataValidationPlugin=class extends s.Plugin{constructor(i=mt,e,t,a){super(),this._config=i,this._injector=e,this._commandService=t,this._configService=a;const{...r}=this._config;this._configService.setConfig(ht,r)}onStarting(){[[h.DataValidationCacheService],[h.DataValidationFormulaService],[h.DataValidationCustomFormulaService],[h.SheetsDataValidationValidatorService],[h.SheetDataValidationModel],[ee],[h.DataValidationFormulaController],[ie],[ae],[te]].forEach(i=>{this._injector.add(i)}),[Oe,Ne,Ie,Ee,we,Ce,Fe].forEach(i=>{this._commandService.registerCommand(i)}),this._injector.get(h.DataValidationCacheService),this._injector.get(h.SheetsDataValidationValidatorService),this._injector.get(te),this._injector.get(ae)}onReady(){this._injector.get(ie)}onRendered(){this._injector.get(ee),this._injector.get(h.DataValidationFormulaController)}},Be(h.UniverSheetsDataValidationPlugin,"pluginName",Se),Be(h.UniverSheetsDataValidationPlugin,"type",s.UniverInstanceType.UNIVER_SHEET),h.UniverSheetsDataValidationPlugin=Bt([s.DependentOn(p.UniverDataValidationPlugin),pe(1,s.Inject(s.Injector)),pe(2,s.ICommandService),pe(3,s.IConfigService)],h.UniverSheetsDataValidationPlugin);function Pt(o){const e=o.get(D.SheetsSelectionsService).getCurrentSelections().map(r=>r.range);return{uid:s.Tools.generateRandomId(6),type:s.DataValidationType.DECIMAL,operator:s.DataValidationOperator.EQUAL,formula1:"100",ranges:e!=null?e:[{startColumn:0,endColumn:0,startRow:0,endRow:0}]}}h.AddSheetDataValidationCommand=Oe,h.CHECKBOX_FORMULA_1=$,h.CHECKBOX_FORMULA_2=W,h.CheckboxValidator=De,h.ClearRangeDataValidationCommand=Fe,h.DATA_VALIDATION_PLUGIN_NAME=Se,h.DateValidator=Me,h.ListMultipleValidator=be,h.ListValidator=he,h.RemoveSheetAllDataValidationCommand=Ce,h.RemoveSheetDataValidationCommand=we,h.UpdateSheetDataValidationOptionsCommand=Ee,h.UpdateSheetDataValidationRangeCommand=Ne,h.UpdateSheetDataValidationSettingCommand=Ie,h.createDefaultNewRule=Pt,h.deserializeListOptions=G,h.getCellValueOrigin=U,h.getDataValidationCellValue=nt,h.getDataValidationDiffMutations=Q,h.getFormulaCellData=j,h.getFormulaResult=A,h.isLegalFormulaResult=y,h.serializeListOptions=rt,h.transformCheckboxValue=x,Object.defineProperty(h,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 _=(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=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"})});
|
|
7
7
|
|
|
8
8
|
|
|
9
9
|
// @univerjs/sheets-data-validation/facade
|
|
10
|
-
(function(n,s){typeof exports=="object"&&typeof module<"u"?s(exports,require("@univerjs/sheets/facade"),require("@univerjs/sheets-data-validation"),require("@univerjs/core"),require("@univerjs/data-validation"),require("@univerjs/engine-formula"),require("rxjs")):typeof define=="function"&&define.amd?define(["exports","@univerjs/sheets/facade","@univerjs/sheets-data-validation","@univerjs/core","@univerjs/data-validation","@univerjs/engine-formula","rxjs"],s):(n=typeof globalThis<"u"?globalThis:n||self,s(n.UniverSheetsDataValidationFacade={},n.UniverSheetsFacade,n.UniverSheetsDataValidation,n.UniverCore,n.UniverDataValidation,n.UniverEngineFormula,n.rxjs))})(this,function(n,s,r,i,m,g,_){"use strict";var v=Object.defineProperty;var y=(n,s,r)=>s in n?v(n,s,{enumerable:!0,configurable:!0,writable:!0,value:r}):n[s]=r;var h=(n,s,r)=>y(n,typeof s!="symbol"?s+"":s,r);class l{constructor(t){h(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,a){return this._rule.formula1=`${t}`,this._rule.formula2=`${e}`,this._rule.operator=i.DataValidationOperator.BETWEEN,this._rule.type=a?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,a){return this._rule.formula1=`${t}`,this._rule.formula2=`${e}`,this._rule.operator=i.DataValidationOperator.NOT_BETWEEN,this._rule.type=a?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,a){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=a!=null?a:!0,this}requireValueInRange(t,e,a){return this._rule.type=e?i.DataValidationType.LIST_MULTIPLE:i.DataValidationType.LIST,this._rule.formula1=`=${g.serializeRangeToRefString({unitId:t.getUnitId(),sheetName:t.getSheetName(),range:t.getRange()})}`,this._rule.formula2=void 0,this._rule.showDropDown=a!=null?a:!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}setOptions(t){return Object.assign(this._rule,t),this}}class u{constructor(t,e){h(this,"rule");h(this,"_worksheet");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._worksheet.getInject().get(m.DataValidationModel).getRuleById(this._worksheet.getWorkbook().getUnitId(),this._worksheet.getSheetId(),this.rule.uid);return!!(e&&e.ranges.length)}getRanges(){var o;if(!this.getAllowInvalid())return[];const t=(o=this._worksheet)==null?void 0:o.getWorkbook(),e=this.getSheetId();if(!e)return[];const a=t==null?void 0:t.getSheetBySheetId(e);return!t||!a?[]:this.rule.ranges.map(I=>{var p;return(p=this._worksheet)==null?void 0:p.getInject().createInstance(s.FRange,t,a,I)})}getUnitId(){var t;return(t=this._worksheet)==null?void 0:t.getWorkbook().getUnitId()}getSheetId(){var t;return(t=this._worksheet)==null?void 0:t.getSheetId()}setCriteria(t,e){return this.getApplied()&&!this._worksheet.getInject().get(i.ICommandService).syncExecuteCommand(r.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}})?!1:(this.rule.operator=e[0],this.rule.formula1=e[1],this.rule.formula2=e[2],this.rule.type=t,!0)}setOptions(t){return this.getApplied()&&!this._worksheet.getInject().get(i.ICommandService).syncExecuteCommand(r.UpdateSheetDataValidationOptionsCommand.id,{unitId:this.getUnitId(),subUnitId:this.getSheetId(),ruleId:this.rule.uid,options:{...m.getRuleOptions(this.rule),...t}})?!1:(Object.assign(this.rule,t),!0)}setRanges(t){return this.getApplied()&&!this._worksheet.getInject().get(i.ICommandService).syncExecuteCommand(r.UpdateSheetDataValidationRangeCommand.id,{unitId:this.getUnitId(),subUnitId:this.getSheetId(),ruleId:this.rule.uid,ranges:t.map(o=>o.getRange())})?!1:(this.rule.ranges=t,!0)}delete(){return this.getApplied()?this._worksheet.getInject().get(i.ICommandService).syncExecuteCommand(r.RemoveSheetDataValidationCommand.id,{unitId:this.getUnitId(),subUnitId:this.getSheetId(),ruleId:this.rule.uid}):!1}}class f extends s.FRange{async setDataValidation(t){if(!t)return this._commandService.executeCommand(r.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 await this._commandService.executeCommand(r.AddSheetDataValidationCommand.id,e),this}getDataValidation(){const e=this._injector.get(r.SheetsDataValidationValidatorService).getDataValidation(this._workbook.getUnitId(),this._worksheet.getSheetId(),[this._range]);return e&&new u(e)}getDataValidations(){return this._injector.get(r.SheetsDataValidationValidatorService).getDataValidations(this._workbook.getUnitId(),this._worksheet.getSheetId(),[this._range]).map(e=>new u(e))}async getValidatorStatus(){return this._injector.get(r.SheetsDataValidationValidatorService).validatorRanges(this._workbook.getUnitId(),this._worksheet.getSheetId(),[this._range])}}s.FRange.extend(f);class D{static newDataValidation(){return new l}}i.FUniver.extend(D);class S extends s.FWorkbook{_initialize(){Object.defineProperty(this,"_dataValidationModel",{get(){return this._injector.get(r.SheetDataValidationModel)}})}getValidatorStatus(){return this._injector.get(r.SheetsDataValidationValidatorService).validatorWorkbook(this._workbook.getUnitId())}onDataValidationChange(t){return i.toDisposable(this._dataValidationModel.ruleChange$.pipe(_.filter(e=>e.unitId===this._workbook.getUnitId())).subscribe(t))}onDataValidationStatusChange(t){return i.toDisposable(this._dataValidationModel.validStatusChange$.pipe(_.filter(e=>e.unitId===this._workbook.getUnitId())).subscribe(t))}onBeforeAddDataValidation(t){return i.toDisposable(this._commandService.beforeCommandExecuted((e,a)=>{const o=e.params;if(e.id===r.AddSheetDataValidationCommand.id){if(o.unitId!==this._workbook.getUnitId())return;if(t(o,a)===!1)throw new Error("Command is stopped by the hook onBeforeAddDataValidation")}}))}onBeforeUpdateDataValidationCriteria(t){return i.toDisposable(this._commandService.beforeCommandExecuted((e,a)=>{const o=e.params;if(e.id===r.UpdateSheetDataValidationSettingCommand.id){if(o.unitId!==this._workbook.getUnitId())return;if(t(o,a)===!1)throw new Error("Command is stopped by the hook onBeforeUpdateDataValidationCriteria")}}))}onBeforeUpdateDataValidationRange(t){return i.toDisposable(this._commandService.beforeCommandExecuted((e,a)=>{const o=e.params;if(e.id===r.UpdateSheetDataValidationRangeCommand.id){if(o.unitId!==this._workbook.getUnitId())return;if(t(o,a)===!1)throw new Error("Command is stopped by the hook onBeforeUpdateDataValidationRange")}}))}onBeforeUpdateDataValidationOptions(t){return i.toDisposable(this._commandService.beforeCommandExecuted((e,a)=>{const o=e.params;if(e.id===r.UpdateSheetDataValidationOptionsCommand.id){if(o.unitId!==this._workbook.getUnitId())return;if(t(o,a)===!1)throw new Error("Command is stopped by the hook onBeforeUpdateDataValidationOptions")}}))}onBeforeDeleteDataValidation(t){return i.toDisposable(this._commandService.beforeCommandExecuted((e,a)=>{const o=e.params;if(e.id===r.RemoveSheetDataValidationCommand.id){if(o.unitId!==this._workbook.getUnitId())return;if(t(o,a)===!1)throw new Error("Command is stopped by the hook onBeforeDeleteDataValidation")}}))}onBeforeDeleteAllDataValidation(t){return i.toDisposable(this._commandService.beforeCommandExecuted((e,a)=>{const o=e.params;if(e.id===r.RemoveSheetAllDataValidationCommand.id){if(o.unitId!==this._workbook.getUnitId())return;if(t(o,a)===!1)throw new Error("Command is stopped by the hook onBeforeDeleteAllDataValidation")}}))}}s.FWorkbook.extend(S);class V extends s.FWorksheet{getDataValidations(){return this._injector.get(m.DataValidationModel).getRules(this._workbook.getUnitId(),this._worksheet.getSheetId()).map(e=>new u(e))}getValidatorStatus(){return this._injector.get(r.SheetsDataValidationValidatorService).validatorWorksheet(this._workbook.getUnitId(),this._worksheet.getSheetId())}}s.FWorksheet.extend(V),n.FDataValidation=u,n.FDataValidationBuilder=l,Object.defineProperty(n,Symbol.toStringTag,{value:"Module"})});
|
|
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 I=(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)=>I(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}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){return 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}})?!1:(this.rule.operator=e[0],this.rule.formula1=e[1],this.rule.formula2=e[2],this.rule.type=t,!0)}setOptions(t){return 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}})?!1:(Object.assign(this.rule,t),!0)}setRanges(t){return 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())})?!1:(this.rule.ranges=t.map(e=>e.getRange()),!0)}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{async setDataValidation(t){if(!t)return this._commandService.executeCommand(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 await this._commandService.executeCommand(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"})});
|
|
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,
|
|
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={};/**
|
|
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 en=f,tn=Symbol.for("react.element"),nn=Symbol.for("react.fragment"),an=Object.prototype.hasOwnProperty,on=en.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,rn={key:!0,ref:!0,__self:!0,__source:!0};function yt(e,t,a){var n,i={},r=null,s=null;a!==void 0&&(r=""+a),t.key!==void 0&&(r=""+t.key),t.ref!==void 0&&(s=t.ref);for(n in t)an.call(t,n)&&!rn.hasOwnProperty(n)&&(i[n]=t[n]);if(e&&e.defaultProps)for(n in t=e.defaultProps,t)i[n]===void 0&&(i[n]=t[n]);return{$$typeof:tn,type:e,key:r,ref:s,props:i,_owner:on.current}}Ae.Fragment=nn,Ae.jsx=yt,Ae.jsxs=yt,Dt.exports=Ae;var h=Dt.exports,sn=Object.defineProperty,ln=Object.getOwnPropertyDescriptor,dn=(e,t,a,n)=>{for(var i=n>1?void 0:n?ln(t,a):t,r=e.length-1,s;r>=0;r--)(s=e[r])&&(i=(n?s(t,a,i):s(i))||i);return n&&i&&sn(t,a,i),i},Le=(e,t)=>(a,n)=>t(a,n,e);let Te=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 g;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((g=t==null?void 0:t.origin)!=null?g: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(O.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(O.Button,{type:"primary",onClick:()=>this._dialogService.close("reject-input-dialog")},this._localeService.t("dataValidation.alert.ok"))},onClose:()=>{this._dialogService.close("reject-input-dialog")}})}};Te=dn([Le(0,o.Inject(X.SheetInterceptorService)),Le(1,o.Inject(E.SheetDataValidationModel)),Le(2,o.Inject(Q.DataValidatorRegistryService)),Le(3,z.IDialogService),Le(4,o.Inject(o.LocaleService))],Te);const wt={dvDateDropdown:"univer-dv-date-dropdown",dvDateDropdownBtns:"univer-dv-date-dropdown-btns"},cn=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 un(e){var S;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(Te),m=n.getCell(i,r),c=E.getCellValueOrigin(n.getCellRaw(i,r)),C=cn(c),[v,g]=f.useState(C),V=v&&v.isValid()?v:o.dayjs(),_=o.useDependency(o.LocaleService),w=o.useDependency(E.SheetDataValidationModel),y=w.getRuleByLocation(s,d,i,r);if(!y)return null;const b=w.getValidator(y.type);if(!m||!b)return;const I=!!((S=y.bizInfo)!=null&&S.showTime),D=async()=>{var x,U,$;if(!V)return;const A=V.format(I?"YYYY-MM-DD HH:mm:ss":"YYYY-MM-DD 00:00:00"),W=(x=o.numfmt.parseDate(A))==null?void 0:x.v,F=l.getStyles().getStyleByCell(m),T=($=(U=F==null?void 0:F.n)==null?void 0:U.pattern)!=null?$:"",P=Jt.getPatternType(T);y.errorStyle!==o.DataValidationErrorStyle.STOP||await b.validator({value:W,unitId:s,subUnitId:d,row:i,column:r,worksheet:n,workbook:l,interceptValue:A.replace("Z","").replace("T"," "),t:o.CellValueType.NUMBER},y)?(a(),await u.executeCommand(N.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:W,t:2,p:null,f:null,si:null,s:{n:{pattern:I?P==="datetime"?T:"yyyy-MM-dd hh:mm:ss":P==="date"?T:"yyyy-MM-dd"}}}})):p.showReject(b.getRuleFinalError(y,{row:i,col:r,unitId:s,subUnitId:d}))};return h.jsxs("div",{className:wt.dvDateDropdown,children:[h.jsx(O.DatePanel,{defaultValue:V,pickerValue:V,showTime:I||void 0,onSelect:async R=>{g(R)},onPanelChange:R=>{g(R)},disabledDate:R=>!o.numfmt.parseDate(R.format("YYYY-MM-DD"))}),h.jsx("div",{className:wt.dvDateDropdownBtns,children:h.jsx(O.Button,{size:"small",type:"primary",onClick:D,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)},pn=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=pn(e,["icon","id","className","extend"]),d="univerjs-icon univerjs-icon-".concat(n," ").concat(i||"").trim(),l=f.useRef("_".concat(vn()));return Vt(a,"".concat(n),{defIds:a.defIds,idSuffix:l.current},se({ref:t,className:d},s),r)});function Vt(e,t,a,n,i){return f.createElement(e.tag,se(se({key:t},hn(e,a,i)),n),(mn(e,a).children||[]).map(function(r,s){return Vt(r,"".concat(t,"-").concat(e.tag,"-").concat(s),a,void 0,i)}))}function hn(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 mn(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 vn(){return Math.random().toString(36).substring(2,8)}ve.displayName="UniverIcon";var fn={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"}}]},Et=f.forwardRef(function(e,t){return f.createElement(ve,Object.assign({},e,{id:"check-mark-single",ref:t,icon:fn}))});Et.displayName="CheckMarkSingle";var gn={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"}}]},Mt=f.forwardRef(function(e,t){return f.createElement(ve,Object.assign({},e,{id:"data-validation-single",ref:t,icon:gn}))});Mt.displayName="DataValidationSingle";var Sn={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"}}]},tt=f.forwardRef(function(e,t){return f.createElement(ve,Object.assign({},e,{id:"delete-single",ref:t,icon:Sn}))});tt.displayName="DeleteSingle";var _n={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"}}]},Rt=f.forwardRef(function(e,t){return f.createElement(ve,Object.assign({},e,{id:"increase-single",ref:t,icon:_n}))});Rt.displayName="IncreaseSingle";var In={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M11.3536 6.14645C11.5488 6.34171 11.5488 6.65829 11.3536 6.85355L8.35355 9.85355C8.15829 10.0488 7.84171 10.0488 7.64645 9.85355L4.64645 6.85355C4.45118 6.65829 4.45118 6.34171 4.64645 6.14645C4.84171 5.95118 5.15829 5.95118 5.35355 6.14645L8 8.79289L10.6464 6.14645C10.8417 5.95118 11.1583 5.95118 11.3536 6.14645Z",fillRule:"evenodd",clipRule:"evenodd"}}]},bt=f.forwardRef(function(e,t){return f.createElement(ve,Object.assign({},e,{id:"more-down-single",ref:t,icon:In}))});bt.displayName="MoreDownSingle";var Cn={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"}}]},Ot=f.forwardRef(function(e,t){return f.createElement(ve,Object.assign({},e,{id:"more-up-single",ref:t,icon:Cn}))});Ot.displayName="MoreUpSingle";var Dn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"mask",attrs:{id:"mask0_622_8",style:{maskType:"alpha"},width:16,height:16,x:0,y:0,maskUnits:"userSpaceOnUse"},children:[{tag:"path",attrs:{fill:"#D9D9D9",d:"M0 0H16V16H0z"}}]},{tag:"g",attrs:{fill:"currentColor",mask:"url(#mask0_622_8)"},children:[{tag:"path",attrs:{d:"M6 5C6.55228 5 7 4.55228 7 4 7 3.44772 6.55228 3 6 3 5.44772 3 5 3.44772 5 4 5 4.55228 5.44772 5 6 5zM6 9C6.55228 9 7 8.55229 7 8 7 7.44772 6.55228 7 6 7 5.44772 7 5 7.44772 5 8 5 8.55229 5.44772 9 6 9zM7 12C7 12.5523 6.55228 13 6 13 5.44772 13 5 12.5523 5 12 5 11.4477 5.44772 11 6 11 6.55228 11 7 11.4477 7 12zM10 5C10.5523 5 11 4.55228 11 4 11 3.44772 10.5523 3 10 3 9.44771 3 9 3.44772 9 4 9 4.55228 9.44771 5 10 5zM11 8C11 8.55229 10.5523 9 10 9 9.44771 9 9 8.55229 9 8 9 7.44772 9.44771 7 10 7 10.5523 7 11 7.44772 11 8zM10 13C10.5523 13 11 12.5523 11 12 11 11.4477 10.5523 11 10 11 9.44771 11 9 11.4477 9 12 9 12.5523 9.44771 13 10 13z"}}]}]},Lt=f.forwardRef(function(e,t){return f.createElement(ve,Object.assign({},e,{id:"sequence-single",ref:t,icon:Dn}))});Lt.displayName="SequenceSingle";var yn=Object.defineProperty,wn=Object.getOwnPropertyDescriptor,Vn=(e,t,a,n)=>{for(var i=n>1?void 0:n?wn(t,a):t,r=e.length-1,s;r>=0;r--)(s=e[r])&&(i=(n?s(t,a,i):s(i))||i);return n&&i&&yn(t,a,i),i},Tt=(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===nt&&(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=Vn([Tt(0,o.IUniverInstanceService),Tt(1,z.ISidebarService)],ue);function En(){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 Pt="sheet.ui.dropdown";var Mn=Object.defineProperty,Rn=Object.getOwnPropertyDescriptor,bn=(e,t,a,n)=>{for(var i=n>1?void 0:n?Rn(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&&Mn(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:Pt,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=bn([Se(0,o.Inject(N.SheetCanvasPopManagerService)),Se(1,o.IUniverInstanceService),Se(2,o.Inject(Q.DataValidatorRegistryService)),Se(3,z.IZenZoneService),Se(4,B.IRenderManagerService),Se(5,o.Inject(E.SheetDataValidationModel)),Se(6,o.Inject(X.SheetsSelectionsService))],fe);const nt="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(Q.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({header:{title:n?"dataValidation.panel.addTitle":"dataValidation.panel.title"},children:{label:nt},width:312,onClose:()=>i.close()});return i.setCloseDisposable(c),!0}},at={id:"data-validation.operation.close-validation-panel",type:o.CommandType.OPERATION,handler(e){return e.get(ue).close(),!0}},jt={id:"data-validation.operation.toggle-validation-panel",type:o.CommandType.OPERATION,handler(e){const t=e.get(o.ICommandService),a=e.get(ue);return a.open(),a.isOpen?t.executeCommand(at.id):t.executeCommand(_e.id),!0}},Fe={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}},At={type:o.CommandType.OPERATION,id:"sheet.operation.hide-data-validation-dropdown",handler(e,t){return t?(e.get(fe).hideDropdown(),!0):!1}},Ie="#ECECEC",it="sheets-data-validation-ui.config",Ft={},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"},On=e=>{var I,D;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:C,col:v,unitId:g,subUnitId:V}=u,_=i.filter(S=>c?S.label.toLowerCase().includes(c):!0),w=(D=(I=m.getConfig(it))==null?void 0:I.showEditOnDropdown)!=null?D:!0,y=o.useDependency(N.SheetPermissionInterceptorBaseController),b=f.useMemo(()=>y.permissionCheckWithRanges({workbookTypes:[X.WorkbookEditablePermission],rangeTypes:[X.RangeProtectionPermissionEditPoint],worksheetTypes:[X.WorksheetEditPermission]},[{startColumn:v,startRow:C,endColumn:v,endRow:C}],g,V),[y,v,C,g,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(O.Scrollbar,{children:h.jsx("div",{className:me.dvListDropdownListContainer,children:_.map((S,R)=>{const A=t.indexOf(S.value)>-1,W=()=>{let T;A?T=new Set(t.filter(x=>x!==S.value)):T=new Set(n?[...t,S.value]:[S.value]);const P=[];i.forEach(x=>{T.has(x.value)&&P.push(x.value)}),a(P)},F=S.label.toLocaleLowerCase().indexOf(c);return h.jsxs("div",{className:me.dvListDropdownItemContainer,onClick:W,children:[h.jsx("div",{className:me.dvListDropdownItem,style:{background:S.color||Ie},children:c&&S.label.toLowerCase().includes(c)?h.jsxs(h.Fragment,{children:[h.jsx("span",{children:S.label.substring(0,F)}),h.jsx("span",{style:{fontWeight:"bold"},children:S.label.substring(F,F+c.length)}),h.jsx("span",{children:S.label.substring(F+c.length)})]}):S.label}),h.jsx("div",{className:me.dvListDropdownSelectedIcon,children:A?h.jsx(Et,{}):null})]},R)})})},l)}),w&&b?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 Ln(e){var U,$,q,Z;const{location:t,hideFn:a}=e,{worksheet:n,row:i,col:r,unitId:s,subUnitId:d}=t,l=o.useDependency(Q.DataValidationModel),[u,p]=f.useState(""),m=o.useDependency(o.ICommandService),c=o.useDependency(o.LocaleService),[C,v]=f.useState(""),g=o.useDependency(N.IEditorBridgeService),V=o.useDependency(o.IUniverInstanceService),_=f.useMemo(()=>l.ruleChange$.pipe(re.debounceTime(16)),[]),w=o.useDependency(E.SheetDataValidationModel);z.useObservable(_);const y=z.RectPopup.useContext(),b=(($=(U=y.current)==null?void 0:U.right)!=null?$:0)-((Z=(q=y.current)==null?void 0:q.left)!=null?Z:0);if(f.useEffect(()=>{const G=m.onCommandExecuted(J=>{var te,ae;if(J.id===Qt.RichTextEditingMutation.id){const ie=J.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()=>{G.dispose()}},[m,V]),!n)return null;const I=w.getRuleByLocation(s,d,i,r);if(!I)return null;const D=w.getValidator(I.type);if(!D)return null;const S=n.getCell(i,r),R=(I==null?void 0:I.renderMode)===o.DataValidationRenderMode.CUSTOM||(I==null?void 0:I.renderMode)===void 0;if(!S||!I||!D||D.id.indexOf(o.DataValidationType.LIST)!==0)return;const A=I.type===o.DataValidationType.LIST_MULTIPLE,W=D.getListWithColor(I,s,d),F=C||E.getDataValidationCellValue(n.getCellRaw(i,r)),T=E.deserializeListOptions(F),P=()=>{m.executeCommand(_e.id,{ruleId:I.uid}),a()},x=W.map(G=>({label:G.label,value:G.label,color:R||G.color?G.color:"transparent"}));return h.jsx(On,{style:{minWidth:b,maxWidth:Math.max(b,200)},title:A?c.t("dataValidation.listMultiple.dropdown"):c.t("dataValidation.list.dropdown"),value:T,multiple:A,onChange:async G=>{const J=E.serializeListOptions(G),te={unitId:s,subUnitId:d,range:{startColumn:r,endColumn:r,startRow:i,endRow:i},value:{v:J,p:null,f:null,si:null}};g.isVisible()&&g.changeVisible({visible:!1,keycode:z.KeyCode.ESC,eventType:B.DeviceInputEventType.Keyboard,unitId:s}),v(J),A||a(),g.isVisible().visible&&await m.executeCommand(N.SetCellEditVisibleOperation.id,{visible:!1,eventType:B.DeviceInputEventType.Keyboard,unitId:s,keycode:z.KeyCode.ESC}),m.executeCommand(X.SetRangeValuesCommand.id,te)},options:x,onEdit:P,filter:u,location:t})}const ot={dataValidationOptionsButton:"univer-data-validation-options-button",dataValidationOptionsButtonIcon:"univer-data-validation-options-button-icon"};function Tn(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:ot.dataValidationOptionsButton,onClick:()=>d(!s),children:[t.t("dataValidation.panel.options"),s?h.jsx(Ot,{className:ot.dataValidationOptionsButtonIcon}):h.jsx(bt,{className:ot.dataValidationOptionsButtonIcon})]}),s&&h.jsxs(h.Fragment,{children:[l?h.jsx(l,{value:n,onChange:i}):null,h.jsx(O.FormLayout,{label:t.t("dataValidation.panel.invalid"),children:h.jsxs(O.RadioGroup,{value:`${(u=n.errorStyle)!=null?u:o.DataValidationErrorStyle.WARNING}`,onChange:p=>i({...n,errorStyle:+p}),children:[h.jsx(O.Radio,{value:`${o.DataValidationErrorStyle.WARNING}`,children:t.t("dataValidation.panel.showWarning")}),h.jsx(O.Radio,{value:`${o.DataValidationErrorStyle.STOP}`,children:t.t("dataValidation.panel.rejectInput")})]})}),h.jsx(O.FormLayout,{label:t.t("dataValidation.panel.messageInfo"),children:h.jsx(O.Checkbox,{checked:n.showErrorMessage,onChange:()=>i({...n,showErrorMessage:!n.showErrorMessage}),children:t.t("dataValidation.panel.showInfo")})}),n.showErrorMessage?h.jsx(O.FormLayout,{children:h.jsx(O.Input,{value:n.error,onChange:p=>i({...n,error:p})})}):null]})]})}const ye={dataValidationDetail:"univer-data-validation-detail",dataValidationDetailFormItem:"univer-data-validation-detail-form-item",dataValidationDetailButtons:"univer-data-validation-detail-buttons",dataValidationDetailButton:"univer-data-validation-detail-button"},Pn=e=>o.debounce(async(t,a,n,i)=>{const r=await e.executeCommand(t,a,n);i==null||i(r)},1e3);function jn(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 An(){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(Q.DataValidatorRegistryService),u=o.useDependency(o.IUniverInstanceService),p=o.useDependency(z.ComponentManager),m=o.useDependency(o.ICommandService),c=o.useDependency(Q.DataValidationModel),C=o.useDependency(o.LocaleService),[v,g]=f.useState(s),V=l.getValidatorItem(v.type),[_,w]=f.useState(!1),y=l.getValidatorsByScope(Q.DataValidatorRegistryScope.SHEET),[b,I]=f.useState(()=>v.ranges.map(j=>({unitId:"",sheetId:"",range:j}))),D=f.useMemo(()=>Pn(m),[m]),[S,R]=f.useState(!1),A=f.useRef({}),[W,F]=f.useState(!1),T=o.useDependency(X.SheetsSelectionsService);if(f.useEffect(()=>()=>{const j=T.getCurrentLastSelection();j&&T.setSelections([j])},[T]),f.useEffect(()=>{m.onCommandExecuted(j=>{(j.id===o.UndoCommand.id||j.id===o.RedoCommand.id)&&setTimeout(()=>{const M=c.getRuleById(i,r,d);t(k=>k+1),M&&(g(M),I(M.ranges.map(k=>({unitId:"",sheetId:"",range:k}))))},20)})},[m,c,d,r,i]),!V)return null;const P=V.operators,x=V.operatorNames,U=v.operator?Q.TWO_FORMULA_OPERATOR_COUNT.includes(v.operator):!1,$=()=>{!v.ranges.length||S||(V.validatorFormula(v,i,r).success?a.setActiveRule(null):w(!0))},q=z.useEvent(j=>{const M=j.split(",").map(Qe.deserializeRangeWithSheet).map(K=>{const ge=K.sheetName;if(ge){const ai=jn(u,K.unitId,ge);return{...K,sheetId:ai}}return{...K,sheetId:""}});if(o.isUnitRangesEqual(M,b))return;I(M);const k=M.filter(K=>(!K.unitId||K.unitId===i)&&(!K.sheetId||K.sheetId===r)).map(K=>K.range);if(g({...v,ranges:k}),k.length===0)return;const H={unitId:i,subUnitId:r,ruleId:d,ranges:k};D(E.UpdateSheetDataValidationRangeCommand.id,H)}),Z=j=>{if(o.shallowEqual(j,Q.getRuleSetting(v)))return;g({...v,...j});const M={unitId:i,subUnitId:r,ruleId:d,setting:j};D(E.UpdateSheetDataValidationSettingCommand.id,M,void 0)},G=async()=>{await m.executeCommand(E.RemoveSheetDataValidationCommand.id,{ruleId:d,unitId:i,subUnitId:r}),a.setActiveRule(null)},J={type:v.type,operator:v.operator,formula1:v.formula1,formula2:v.formula2,allowBlank:v.allowBlank},te=j=>{const M=l.getValidatorItem(j);if(!M)return;const k=M.operators,H=c.getRuleById(i,r,d),K=j===(H==null?void 0:H.type)||j.includes("list")&&(H!=null&&H.type.includes("list"))?{...H,type:j}:{...v,type:j,operator:k[0],formula1:void 0,formula2:void 0};g(K),m.executeCommand(E.UpdateSheetDataValidationSettingCommand.id,{unitId:i,subUnitId:r,ruleId:v.uid,setting:Q.getRuleSetting(K)})},ae=p.get(V.formulaInput),ie=f.useMemo(()=>b.map(j=>Qe.serializeRange(j.range)).join(","),[]),le=Q.getRuleOptions(v),oe=j=>{o.shallowEqual(j,Q.getRuleOptions(v))||(g({...v,...j}),D(E.UpdateSheetDataValidationOptionsCommand.id,{unitId:i,subUnitId:r,ruleId:d,options:j}))};return z.useSidebarClick(j=>{var k;const M=(k=A.current)==null?void 0:k.handleOutClick;M&&M(j,()=>F(!1))}),h.jsxs("div",{className:ye.dataValidationDetail,children:[h.jsx(O.FormLayout,{label:C.t("dataValidation.panel.range"),error:!v.ranges.length||S?C.t("dataValidation.panel.rangeError"):"",children:h.jsx(et.RangeSelector,{unitId:i,subUnitId:r,initValue:ie,onChange:q,onFocus:()=>F(!0),isFocus:W,actions:A.current,onVerify:j=>R(!j)})}),h.jsx(O.FormLayout,{label:C.t("dataValidation.panel.type"),children:h.jsx(O.Select,{options:y==null?void 0:y.map(j=>({label:C.t(j.title),value:j.id})),value:v.type,onChange:te,className:ye.dataValidationDetailFormItem})}),P!=null&&P.length?h.jsx(O.FormLayout,{label:C.t("dataValidation.panel.operator"),children:h.jsx(O.Select,{options:P.map((j,M)=>({value:`${j}`,label:x[M]})),value:`${v.operator}`,onChange:j=>{Z({...J,operator:j})},className:ye.dataValidationDetailFormItem})}):null,ae?h.jsx(ae,{isTwoFormula:U,value:{formula1:v.formula1,formula2:v.formula2},onChange:j=>{Z({...J,...j})},showError:_,validResult:V.validatorFormula(v,i,r),unitId:i,subUnitId:r,ruleId:d},e+v.type):null,h.jsx(O.FormLayout,{children:h.jsx(O.Checkbox,{checked:(de=v.allowBlank)!=null?de:!0,onChange:()=>{var j;return Z({...J,allowBlank:!((j=v.allowBlank)==null||j)})},children:C.t("dataValidation.panel.allowBlank")})}),h.jsx(Tn,{value:le,onChange:oe,extraComponent:V.optionsInput}),h.jsxs("div",{className:ye.dataValidationDetailButtons,children:[h.jsx(O.Button,{className:ye.dataValidationDetailButton,onClick:G,children:C.t("dataValidation.panel.removeRule")}),h.jsx(O.Button,{className:ye.dataValidationDetailButton,type:"primary",onClick:$,children:C.t("dataValidation.panel.done")})]})]})}const xe={dataValidationItemContainer:"univer-data-validation-item-container",dataValidationItemTitle:"univer-data-validation-item-title",dataValidationItemContent:"univer-data-validation-item-content",dataValidationItemIcon:"univer-data-validation-item-icon"},Fn=e=>{const{rule:t,onClick:a,unitId:n,subUnitId:i,disable:r}=e,s=o.useDependency(Q.DataValidatorRegistryService),d=o.useDependency(o.ICommandService),l=o.useDependency(N.IMarkSelectionService),u=s.getValidatorItem(t.type),p=f.useRef(),[m,c]=f.useState(!1),C=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(g=>{g&&l.removeShape(g)}))},[l]),h.jsxs("div",{className:xe.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(g=>{g&&l.removeShape(g)}),p.current=void 0},children:[h.jsx("div",{className:xe.dataValidationItemTitle,children:u==null?void 0:u.generateRuleName(t)}),h.jsx("div",{className:xe.dataValidationItemContent,children:t.ranges.map(v=>Qe.serializeRange(v)).join(",")}),m?h.jsx("div",{className:xe.dataValidationItemIcon,onClick:C,children:h.jsx(tt,{})}):null]})},Ne={dataValidationList:"univer-data-validation-list",dataValidationListButtons:"univer-data-validation-list-buttons",dataValidationListButton:"univer-data-validation-list-button"};function xn(){const e=o.useDependency(o.IUniverInstanceService),t=z.useObservable(()=>e.getCurrentTypeOfUnit$(o.UniverInstanceType.UNIVER_SHEET),void 0,void 0,[]);return t?h.jsx(Nn,{workbook:t}):null}function Nn(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 w=t.ruleChange$.subscribe(y=>{y.unitId===m&&y.subUnitId===c&&l(t.getRules(m,c))});return()=>{w.unsubscribe()}},[m,c,t]);const C=async()=>{const w=E.createDefaultNewRule(i),y={unitId:m,subUnitId:c,rule:w};await n.executeCommand(E.AddSheetDataValidationCommand.id,y),r.setActiveRule({unitId:m,subUnitId:c,rule:w})},v=()=>{n.executeCommand(E.RemoveSheetAllDataValidationCommand.id,{unitId:m,subUnitId:c})},V=(w=>{const y=a.getCurrentUnitForType(o.UniverInstanceType.UNIVER_SHEET),b=y.getActiveSheet(),I=y.getUnitId(),D=b.getSheetId();return w.map(R=>X.checkRangesEditablePermission(i,I,D,R.ranges)?{...R}:{...R,disable:!0})})(d),_=V==null?void 0:V.some(w=>w.disable);return h.jsxs("div",{className:Ne.dataValidationList,children:[V==null?void 0:V.map(w=>{var y;return h.jsx(Fn,{unitId:m,subUnitId:c,onClick:()=>{w.disable||r.setActiveRule({unitId:m,subUnitId:c,rule:w})},rule:w,disable:(y=w.disable)!=null?y:!1},w.uid)}),h.jsxs("div",{className:Ne.dataValidationListButtons,children:[d.length&&!_?h.jsx(O.Button,{className:Ne.dataValidationListButton,onClick:v,children:s.t("dataValidation.panel.removeAll")}):null,h.jsx(O.Button,{className:Ne.dataValidationListButton,type:"primary",onClick:C,children:s.t("dataValidation.panel.add")})]})]})}const Un=()=>{const e=o.useDependency(ue),t=z.useObservable(e.activeRule$,e.activeRule);return t?h.jsx(An,{},t.rule.uid):h.jsx(xn,{})},Ue="data-validation.list.dropdown",rt="data-validation.date.dropdown",Be={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 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},we=(e,t)=>(a,n)=>t(a,n,e);const ke="SHEET_DATA_VALIDATION_ALERT";let Pe=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){if(!this._univerInstanceService.getCurrentUnitForType(o.UniverInstanceType.UNIVER_SHEET).getActiveSheet())return;const i=this._dataValidationModel.getRuleByLocation(e.location.unitId,e.location.subUnitId,e.location.row,e.location.col);if(!i)return;if(this._dataValidationModel.validator(i,e.location)===o.DataValidationStatus.INVALID){const s=this._cellAlertManagerService.currentAlert.get(ke),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)return;const l=this._dataValidationModel.getValidator(i.type);if(!l)return;this._cellAlertManagerService.showAlert({type:N.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:ke});return}}this._cellAlertManagerService.removeAlert(ke)}))}_initZenService(){this.disposeWithMe(this._zenZoneService.visible$.subscribe(e=>{e&&this._cellAlertManagerService.removeAlert(ke)}))}};Pe=Wn([we(0,o.Inject(N.HoverManagerService)),we(1,o.Inject(N.CellAlertManagerService)),we(2,o.IUniverInstanceService),we(3,o.Inject(o.LocaleService)),we(4,z.IZenZoneService),we(5,o.Inject(E.SheetDataValidationModel))],Pe);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},st=(e,t)=>(a,n)=>t(a,n,e);let Ve=class extends o.Disposable{constructor(e,t,a){super(),this._autoFillService=e,this._dataValidationModel=t,this._injector=a,this._initAutoFill()}_initAutoFill(){const e=()=>({redos:[],undos:[]}),t=(i,r)=>{const{source:s,target:d,unitId:l,subUnitId:u}=i,p=this._dataValidationModel.getRuleObjectMatrix(l,u).clone(),m=N.virtualizeDiscreteRanges([s,d]),[c,C]=m.ranges,{mapFunc:v}=m,g={row:c.startRow,col:c.startColumn},V=N.getAutoFillRepeatRange(c,C),_=new o.ObjectMatrix,w=new Set;V.forEach(S=>{const R=S.repeatStartCell,A=S.relativeRange,W={startRow:g.row,startColumn:g.col,endColumn:g.col,endRow:g.row},F={startRow:R.row,startColumn:R.col,endColumn:R.col,endRow:R.row};o.Range.foreach(A,(T,P)=>{const x=o.Rectangle.getPositionRange({startRow:T,startColumn:P,endColumn:P,endRow:T},W),{row:U,col:$}=v(x.startRow,x.startColumn),q=this._dataValidationModel.getRuleIdByLocation(l,u,U,$);if(q){const Z=o.Rectangle.getPositionRange({startRow:T,startColumn:P,endColumn:P,endRow:T},F),{row:G,col:J}=v(Z.startRow,Z.startColumn);_.setValue(G,J,q),w.add(q)}})});const y=Array.from(w).map(S=>({id:S,ranges:o.queryObjectMatrix(_,R=>R===S)}));p.addRangeRules(y);const b=p.diff(this._dataValidationModel.getRules(l,u)),{redoMutations:I,undoMutations:D}=E.getDataValidationDiffMutations(l,u,b,this._injector,"patched",r===N.APPLY_TYPE.ONLY_FORMAT);return{undos:D,redos:I}},a=[o.DataValidationType.CHECKBOX],n={id:E.DATA_VALIDATION_PLUGIN_NAME,onBeforeFillData:i=>{const{source:r,unitId:s,subUnitId:d}=i;for(const l of r.rows)for(const u of r.cols){const p=this._dataValidationModel.getRuleByLocation(s,d,l,u);if(p&&a.indexOf(p.type)>-1){this._autoFillService.setDisableApplyType(N.APPLY_TYPE.SERIES,!0);return}}},onFillData:(i,r,s)=>s===N.APPLY_TYPE.COPY||s===N.APPLY_TYPE.ONLY_FORMAT||s===N.APPLY_TYPE.SERIES?t(i,s):e(),onAfterFillData:()=>{}};this.disposeWithMe(this._autoFillService.addHook(n))}};Ve=Yn([st(0,N.IAutoFillService),st(1,o.Inject(E.SheetDataValidationModel)),st(2,o.Inject(o.Injector))],Ve);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},lt=(e,t)=>(a,n)=>t(a,n,e);let Ee=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=N.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=>N.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===N.COPY_TYPE.CUT)return this._copyInfo=null,{redos:[],undos:[]};if(!this._copyInfo||!this._copyInfo.matrix.getSizeOf()||!a.copyRange)return{redos:[],undos:[]};if([N.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_COL_WIDTH,N.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_VALUE,N.PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMAT,N.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}=N.virtualizeDiscreteRanges([a.copyRange,t]),m=N.getRepeatRange(l,u,!0),c=new Map;m.forEach(({startRange:V})=>{var _;(_=this._copyInfo)==null||_.matrix.forValue((w,y,b)=>{const I=o.Rectangle.getPositionRange({startRow:w,endRow:w,startColumn:y,endColumn:y},V),D=`${i}-${b}`,S=this._sheetDataValidationModel.getRuleById(n,i,b);!this._sheetDataValidationModel.getRuleById(a.unitId,a.subUnitId,D)&&S&&c.set(D,{...S,uid:D});const{row:R,col:A}=p(I.startRow,I.startColumn);d.add(D),s.setValue(R,A,D)})});const C=Array.from(d).map(V=>({id:V,ranges:o.queryObjectMatrix(s,_=>_===V)}));r.addRangeRules(C);const{redoMutations:v,undoMutations:g}=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:g}}else{const r=this._sheetDataValidationModel.getRuleObjectMatrix(n,i).clone(),s=new o.ObjectMatrix,d=new Set,{ranges:[l,u],mapFunc:p}=N.virtualizeDiscreteRanges([a.copyRange,t]);N.getRepeatRange(l,u,!0).forEach(({startRange:g})=>{var V;(V=this._copyInfo)==null||V.matrix.forValue((_,w,y)=>{const b=o.Rectangle.getPositionRange({startRow:_,endRow:_,startColumn:w,endColumn:w},g),{row:I,col:D}=p(b.startRow,b.startColumn);s.setValue(I,D,y),d.add(y)})});const c=Array.from(d).map(g=>({id:g,ranges:o.queryObjectMatrix(s,V=>V===g)}));r.addRangeRules(c);const{redoMutations:C,undoMutations:v}=E.getDataValidationDiffMutations(n,i,r.diff(this._sheetDataValidationModel.getRules(n,i)),this._injector,"patched",!1);return{redos:C,undos:v}}}};Ee=Kn([lt(0,N.ISheetClipboardService),lt(1,o.Inject(E.SheetDataValidationModel)),lt(2,o.Inject(o.Injector))],Ee);var Gn=Object.defineProperty,qn=Object.getOwnPropertyDescriptor,Zn=(e,t,a,n)=>{for(var i=n>1?void 0:n?qn(t,a):t,r=e.length-1,s;r>=0;r--)(s=e[r])&&(i=(n?s(t,a,i):s(i))||i);return n&&i&&Gn(t,a,i),i},dt=(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=Zn([dt(0,o.Inject(o.LocaleService)),dt(1,o.ICommandService),dt(2,o.Inject(N.SheetPermissionInterceptorBaseController))],Me);const xt="data-validation-single",Nt="sheet.menu.data-validation";function Jn(e){return{id:Nt,type:z.MenuItemType.SUBITEMS,icon:xt,tooltip:"dataValidation.title",hidden$:z.getMenuHiddenObservable(e,o.UniverInstanceType.UNIVER_SHEET),disabled$:N.getCurrentRangeDisable$(e,{workbookTypes:[X.WorkbookEditablePermission],worksheetTypes:[X.WorksheetSetCellStylePermission,X.WorksheetEditPermission],rangeTypes:[X.RangeProtectionPermissionEditPoint]})}}function Qn(e){return{id:_e.id,title:"dataValidation.panel.title",type:z.MenuItemType.BUTTON}}function ea(e){return{id:Be.id,title:"dataValidation.panel.add",type:z.MenuItemType.BUTTON}}const ta={[z.RibbonStartGroup.FORMULAS_INSERT]:{[Nt]:{order:9,menuItemFactory:Jn,[_e.id]:{order:0,menuItemFactory:Qn},[Be.id]:{order:1,menuItemFactory:ea}}}};var na=Object.defineProperty,aa=Object.getOwnPropertyDescriptor,Ut=(e,t,a,n)=>{for(var i=n>1?void 0:n?aa(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&&na(t,a,i),i},ee=(e,t)=>(a,n)=>t(a,n,e);const Bt={tr:{size:6,color:"#fe4b4b"}};let Re=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(ta)}_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,y,b,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),C=t.rawData;let v;const g={get value(){var D;return v!==void 0||(v=(D=E.getCellValueOrigin(C))!=null?D:null),v}},V={get value(){var D;return`${(D=g.value)!=null?D:""}`}};return a({...e,markers:{...e==null?void 0:e.markers,...m===o.DataValidationStatus.INVALID?Bt:null},customRender:[...(w=e==null?void 0:e.customRender)!=null?w:[],...c!=null&&c.canvasRender?[c.canvasRender]:[]],fontRenderExtension:{...e==null?void 0:e.fontRenderExtension,isSkip:((y=e==null?void 0:e.fontRenderExtension)==null?void 0:y.isSkip)||((b=c==null?void 0:c.skipDefaultFontRender)==null?void 0:b.call(c,p,g.value,t))},interceptorStyle:{...e==null?void 0:e.interceptorStyle,...c==null?void 0:c.getExtraStyle(p,V.value,{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 A,W,F,T,P,x;const D=(W=(A=this._renderManagerService.getRenderById(r))==null?void 0:A.with(N.SheetSkeletonManagerService).getWorksheetSkeleton(s))==null?void 0:W.skeleton;if(!D)return;const S=D.worksheet.getMergedCell(n,i),R={data:e,style:D.getsStyles().getStyleByCell(e),primaryWithCoord:D.getCellWithCoordByIndex((F=S==null?void 0:S.startRow)!=null?F:n,(T=S==null?void 0:S.startColumn)!=null?T:i),unitId:r,subUnitId:s,row:n,col:i,workbook:d,worksheet:l};return(x=(P=c==null?void 0:c.canvasRender)==null?void 0:P.calcCellAutoHeight)==null?void 0:x.call(P,R)},interceptorAutoWidth:()=>{var A,W,F,T,P,x;const D=(W=(A=this._renderManagerService.getRenderById(r))==null?void 0:A.with(N.SheetSkeletonManagerService).getWorksheetSkeleton(s))==null?void 0:W.skeleton;if(!D)return;const S=D.worksheet.getMergedCell(n,i),R={data:e,style:D.getsStyles().getStyleByCell(e),primaryWithCoord:D.getCellWithCoordByIndex((F=S==null?void 0:S.startRow)!=null?F:n,(T=S==null?void 0:S.startColumn)!=null?T:i),unitId:r,subUnitId:s,row:n,col:i,workbook:d,worksheet:l};return(x=(P=c==null?void 0:c.canvasRender)==null?void 0:P.calcCellAutoWidth)==null?void 0:x.call(P,R)},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(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)}})}};Re=Ut([ee(0,o.ICommandService),ee(1,z.IMenuManagerService),ee(2,B.IRenderManagerService),ee(3,o.IUniverInstanceService),ee(4,o.Inject(N.AutoHeightController)),ee(5,o.Inject(fe)),ee(6,o.Inject(E.SheetDataValidationModel)),ee(7,o.Inject(Q.DataValidatorRegistryService)),ee(8,o.Inject(X.SheetInterceptorService)),ee(9,o.Inject(E.DataValidationCacheService)),ee(10,o.Optional(N.IEditorBridgeService))],Re);let kt=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,y,b;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),C=l.getCellRaw(n,i),v=E.getCellValueOrigin(C),g=`${v!=null?v:""}`;return a({...e,markers:{...e==null?void 0:e.markers,...m===o.DataValidationStatus.INVALID?Bt: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)||((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,g,{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 R,A,W,F,T,P;const I=(A=(R=this._renderManagerService.getRenderById(r))==null?void 0:R.with(N.SheetSkeletonManagerService).getWorksheetSkeleton(s))==null?void 0:A.skeleton;if(!I)return;const D=I.worksheet.getMergedCell(n,i),S={data:e,style:I.getsStyles().getStyleByCell(e),primaryWithCoord:I.getCellWithCoordByIndex((W=D==null?void 0:D.startRow)!=null?W:n,(F=D==null?void 0:D.startColumn)!=null?F:i),unitId:r,subUnitId:s,row:n,col:i,workbook:d,worksheet:l};return(P=(T=c==null?void 0:c.canvasRender)==null?void 0:T.calcCellAutoHeight)==null?void 0:P.call(T,S)},coverable:((b=e==null?void 0:e.coverable)!=null?b:!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)}})}};kt=Ut([ee(0,o.ICommandService),ee(1,B.IRenderManagerService),ee(2,o.Inject(N.AutoHeightController)),ee(3,o.Inject(Q.DataValidatorRegistryService)),ee(4,o.Inject(X.SheetInterceptorService)),ee(5,o.Inject(E.SheetDataValidationModel)),ee(6,o.Inject(E.DataValidationCacheService))],kt);var ia=Object.defineProperty,oa=Object.getOwnPropertyDescriptor,ra=(e,t,a,n)=>{for(var i=n>1?void 0:n?oa(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&&ia(t,a,i),i},Wt=(e,t)=>(a,n)=>t(a,n,e);let We=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))}};We=ra([Wt(1,o.Inject(E.SheetDataValidationModel)),Wt(2,o.Inject(N.SheetSkeletonManagerService))],We);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"},sa=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(O.FormLayout,{error:d,children:h.jsx(O.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(O.FormLayout,{error:l,children:h.jsx(O.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(O.FormLayout,{error:d,children:h.jsx(O.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 la(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(O.FormLayout,{children:h.jsx(O.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(O.FormLayout,{label:r.t("dataValidation.checkbox.checked"),error:s,children:h.jsx(O.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(O.FormLayout,{label:r.t("dataValidation.checkbox.unchecked"),error:d,children:h.jsx(O.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 da(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 C=(v=l.current)==null?void 0:v.handleOutClick;C&&C(c,()=>p(!1))}),h.jsx(et.FormulaEditor,{initValue:(m=n==null?void 0:n.formula1)!=null?m:"",unitId:t,subUnitId:a,isFocus:u,onChange:c=>{const C=(c!=null?c:"").trim();C!==(n==null?void 0:n.formula1)&&(i==null||i({...n,formula1:C}))},errorText:d,onFocus:()=>p(!0),actions:l.current,isSupportAcrossSheet:!0})}function $t(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=$t(e[t]))&&(n&&(n+=" "),n+=a)}else for(a in e)e[a]&&(n&&(n+=" "),n+=a);return n}function ca(){for(var e,t,a=0,n="",i=arguments.length;a<i;a++)(e=arguments[a])&&(t=$t(e))&&(n&&(n+=" "),n+=t);return n}const ua=["#FFFFFF","#FEE7E7","#FEF0E6","#EFFBD0","#E4F4FE","#E8ECFD","#F1EAFA","#FDE8F3","#E5E5E5","#FDCECE","#FDC49B","#DEF6A2","#9FDAFF","#D0D9FB","#E3D5F6","#FBD0E8","#656565","#FE4B4B","#FF8C51","#8BBB11","#0B9EFB","#3A60F7","#9E6DE3","#F248A6"],pa=e=>{const{value:t,onChange:a,disabled:n}=e,[i,r]=f.useState(!1);return h.jsx(O.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:ua.map(s=>h.jsx("div",{onClick:()=>{a(s),r(!1)},className:ne.dataValidationFormulaColorItem,style:{background:s}},s))})})},Ht=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:ca(ne.dataValidationFormulaListItemDrag,"draggableHandle"),children:h.jsx(Lt,{})}),h.jsx(pa,{value:t.color,onChange:s=>{i(t.id,t.label,s)}}),h.jsx(O.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(tt,{onClick:()=>r(t.id)})})]})};function ha(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"),[C,v]=f.useState(m==="1"?l:"="),[g,V]=f.useState(m==="1"?l:"="),_=o.useDependency(o.LocaleService),w=o.useDependency(Q.DataValidatorRegistryService),y=o.useDependency(Q.DataValidationModel),b=o.useDependency(E.DataValidationFormulaController),[I,D]=f.useState(()=>u.split(",")),S=w.getValidatorItem(o.DataValidationType.LIST),[R,A]=f.useState([]),[W,F]=f.useState(""),T=s?r==null?void 0:r.formula1:"",P=f.useMemo(()=>y.ruleChange$.pipe(re.debounceTime(16)),[]),x=z.useObservable(P),U=z.useEvent(a);f.useEffect(()=>{(async()=>{await new Promise(H=>{setTimeout(()=>H(!0),100)});const M=y.getRuleById(n,i,d),k=M==null?void 0:M.formula1;if(o.isFormulaString(k)&&S&&M){const H=await S.getListAsync(M,n,i);A(H)}})()},[y,x,S,d,i,n]),f.useEffect(()=>{o.isFormulaString(l)&&l!==g&&(v(l),V(g))},[g,l]);const[$,q]=f.useState(()=>{const M=m!=="1"?E.deserializeListOptions(l):[],k=u.split(",");return M.map((H,K)=>({label:H,color:k[K]||Ie,isRef:!1,id:o.Tools.generateRandomId(4)}))}),Z=(M,k,H)=>{const K=$.find(ge=>ge.id===M);K&&(K.label=k,K.color=H,q([...$]))},G=M=>{const k=$.findIndex(H=>H.id===M);k!==-1&&($.splice(k,1),q([...$]))},J=u.split(","),te=f.useMemo(()=>R.map((M,k)=>({label:M,color:J[k]||Ie,id:`${k}`,isRef:!0})),[J,R]),ae=(M,k,H)=>{const K=[...I];K[+M]=H,D(K),U({formula1:l,formula2:K.join(",")})},ie=()=>{q([...$,{label:"",color:Ie,isRef:!1,id:o.Tools.generateRandomId(4)}])};f.useEffect(()=>{if(m==="1")return;const M=new Set,k=[];$.map(H=>({labelList:H.label.split(","),item:H})).forEach(({item:H,labelList:K})=>{K.forEach(ge=>{M.has(ge)||(M.add(ge),k.push({label:ge,color:H.color}))})}),U({formula1:E.serializeListOptions(k.map(H=>H.label)),formula2:k.map(H=>H.color===Ie?"":H.color).join(",")})},[$,U,m,g,I]);const le=f.useMemo(()=>async M=>{if(!o.isFormulaString(M)){U==null||U({formula1:"",formula2:u});return}b.getFormulaRefCheck(M)?(U==null||U({formula1:o.isFormulaString(M)?M:"",formula2:u}),F("")):(U==null||U({formula1:"",formula2:u}),v("="),F(_.t("dataValidation.validFail.formulaError")))},[u,U]),oe=f.useRef({}),[de,j]=f.useState(!1);return z.useSidebarClick(M=>{var H;const k=(H=oe.current)==null?void 0:H.handleOutClick;k&&k(M,()=>j(!1))}),h.jsxs(h.Fragment,{children:[h.jsx(O.FormLayout,{label:_.t("dataValidation.list.options"),children:h.jsxs(O.RadioGroup,{value:m,onChange:M=>{c(M),v(g),M==="1"&&U({formula1:g==="="?"":g,formula2:I.join(",")})},children:[h.jsx(O.Radio,{value:"0",children:_.t("dataValidation.list.customOptions")}),h.jsx(O.Radio,{value:"1",children:_.t("dataValidation.list.refOptions")})]})}),m==="1"?h.jsxs(h.Fragment,{children:[h.jsx(et.FormulaEditor,{initValue:C,unitId:n,subUnitId:i,isFocus:de,onChange:(M="")=>{const k=(M!=null?M:"").trim();V(k),le(k)},errorText:T||W||void 0,onFocus:()=>j(!0),actions:oe.current,isSupportAcrossSheet:!0}),h.jsx("div",{ref:p,style:{marginTop:"12px"},children:te.map(M=>h.jsx(Ht,{item:M,commonProps:{onItemChange:ae},style:{marginBottom:12}},M.id))})]}):h.jsx(O.FormLayout,{error:T,children:h.jsxs("div",{ref:p,style:{marginTop:"-12px"},children:[h.jsx(O.DraggableList,{list:$,onListChange:q,rowHeight:32,margin:[0,12],draggableHandle:".draggableHandle",itemRender:M=>h.jsx(Ht,{item:M,commonProps:{onItemChange:Z,onItemDelete:G}},M.id),idKey:"id"}),h.jsxs("a",{className:ne.dataValidationFormulaListAdd,onClick:ie,children:[h.jsx(Rt,{}),_.t("dataValidation.list.add")]})]})})]})}const Yt="data-validation.custom-formula-input",$e="data-validation.formula-input",ct="data-validation.list-formula-input",Xt="data-validation.checkbox-formula-input",ma=[[Yt,da],[$e,sa],[ct,ha],[Xt,la]],va="LIST_RENDER_MODE_OPTION_INPUT";function He(e){var i;const{value:t,onChange:a}=e,n=o.useDependency(o.LocaleService);return h.jsx(O.FormLayout,{label:n.t("dataValidation.renderMode.label"),children:h.jsxs(O.RadioGroup,{value:`${(i=t.renderMode)!=null?i:o.DataValidationRenderMode.CUSTOM}`,onChange:r=>a({...t,renderMode:+r}),children:[h.jsx(O.Radio,{value:`${o.DataValidationRenderMode.CUSTOM}`,children:n.t("dataValidation.renderMode.chip")}),h.jsx(O.Radio,{value:`${o.DataValidationRenderMode.ARROW}`,children:n.t("dataValidation.renderMode.arrow")}),h.jsx(O.Radio,{value:`${o.DataValidationRenderMode.TEXT}`,children:n.t("dataValidation.renderMode.text")})]})})}He.componentKey=va;const fa="DATE_SHOW_TIME_OPTION";function Ye(e){var i;const{value:t,onChange:a}=e,n=o.useDependency(o.LocaleService);return h.jsx(O.FormLayout,{children:h.jsx(O.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")})})}Ye.componentKey=fa;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},je=(e,t)=>(a,n)=>t(a,n,e);const Xe=6;let ut=class{constructor(e,t,a,n,i){this._commandService=e,this._formulaService=t,this._themeService=a,this._renderManagerService=n,this._dataValidationModel=i}_calc(e,t){var u,p,m;const{vt:a,ht:n}=t||{},i=e.endX-e.startX-Xe*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=Xe;break;case o.HorizontalAlign.RIGHT:d=Xe+(i-s);break;default:d=Xe+(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,C,v,g,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((v=(C=(c=r==null?void 0:r[1])==null?void 0:c.result)==null?void 0:C[0])==null?void 0:v[0]),l=E.isLegalFormulaResult(String(s))&&E.isLegalFormulaResult(String(d));return{formula1:o.isFormulaString(n)?E.getFormulaResult((_=(V=(g=r==null?void 0:r[0])==null?void 0:g.result)==null?void 0:V[0])==null?void 0:_[0]):n,formula2:o.isFormulaString(i)?d:i,isFormulaValid:l}}drawWith(e,t){var T,P,x,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 C=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:g}=v,V=this._calc(u,a),{a:_,d:w}=e.getTransform(),y=B.fixLineWidthByScale(V.left,_),b=B.fixLineWidthByScale(V.top,w),I=B.Transform.create().composeMatrix({left:y,top:b,scaleX:1,scaleY:1,angle:0,skewX:0,skewY:0,flipX:!1,flipY:!1}),D=u.endX-u.startX,S=u.endY-u.startY;e.save(),e.beginPath(),e.rect(u.startX,u.startY,D,S),e.clip();const R=I.getMatrix();e.transform(R[0],R[1],R[2],R[3],R[4],R[5]);const A=((P=a==null?void 0:a.fs)!=null?P:10)*1.6,W=String(p)===String(g),F=C.hyacinth500;B.Checkbox.drawWith(e,{checked:W,width:A,height:A,fill:(U=(x=a==null?void 0:a.cl)==null?void 0:x.rgb)!=null?U:F}),e.restore()}isHit(e,t){const a=t.primaryWithCoord.isMergedMainCell?t.primaryWithCoord.mergeInfo:t.primaryWithCoord,n=this._calc(a,t.style),i=n.top,r=n.top+n.height,s=n.left,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),C={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,C)}onPointerEnter(e,t){var a,n;(n=(a=this._renderManagerService.getCurrentTypeOfRenderer(o.UniverInstanceType.UNIVER_SHEET))==null?void 0:a.mainComponent)==null||n.setCursor(B.CURSOR_TYPE.POINTER)}onPointerLeave(e,t){var a,n;(n=(a=this._renderManagerService.getCurrentTypeOfRenderer(o.UniverInstanceType.UNIVER_SHEET))==null?void 0:a.mainComponent)==null||n.setCursor(B.CURSOR_TYPE.DEFAULT)}};ut=_a([je(0,o.ICommandService),je(1,o.Inject(E.DataValidationFormulaService)),je(2,o.Inject(o.ThemeService)),je(3,o.Inject(B.IRenderManagerService)),je(4,o.Inject(E.SheetDataValidationModel))],ut);var Ia=Object.defineProperty,Ca=Object.getOwnPropertyDescriptor,Da=(e,t,a,n)=>{for(var i=n>1?void 0:n?Ca(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&&Ia(t,a,i),i},ya=(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",ct);this.injector=e}};pe=Da([ya(0,o.Inject(o.Injector))],pe);class wa extends pe{constructor(){super(...arguments);L(this,"id",o.DataValidationType.CHECKBOX);L(this,"canvasRender",this.injector.createInstance(ut));L(this,"formulaInput",Xt)}}class Va extends pe{constructor(){super(...arguments);L(this,"id",o.DataValidationType.CUSTOM);L(this,"formulaInput",Yt)}}const Ea="data-validation.formula-input";class Ma extends pe{constructor(){super(...arguments);L(this,"id",o.DataValidationType.DATE);L(this,"formulaInput",Ea);L(this,"optionsInput",Ye.componentKey);L(this,"dropdown",rt)}}class Ra extends pe{constructor(){super(...arguments);L(this,"id",o.DataValidationType.DECIMAL);L(this,"formulaInput",$e)}}const zt=4,ba=0,pt=4,Kt=4,ht=6,ze=6,Ce=14;function Oa(e,t){const a=B.FontCache.getTextSize(e,t),n=a.width+zt*2,{ba:i,bd:r}=a,s=i+r;return{width:n,height:s+ba*2,ba:i}}function mt(e,t,a,n){const i=Ce+ht*2,r=a-i,s=n-ze*2,d=e.map(c=>({layout:Oa(c,t),text:c}));let l;const u=[];d.forEach(c=>{const{layout:C}=c,{width:v,height:g}=C;!l||l.width+v+pt>r?(l={width:v,height:g,items:[{...c,left:0}]},u.push(l)):(l.items.push({...c,left:l.width+pt}),l.width=l.width+v+pt)});let p=0,m=0;return u.forEach((c,C)=>{m=Math.max(m,c.width),C===u.length-1?p+=c.height:p+=c.height+Kt}),{lines:u,totalHeight:p,contentWidth:r,contentHeight:s,cellAutoHeight:p+ze*2,calcAutoWidth:m+i}}const La=8;class Ta 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:La,fill:r||Ie}),t.translateWithPrecision(zt,d.ba),t.font=n,t.fillStyle=s,t.fillText(l,0,0),t.restore()}}var Pa=Object.defineProperty,ja=Object.getOwnPropertyDescriptor,Aa=(e,t,a,n)=>{for(var i=n>1?void 0:n?ja(t,a):t,r=e.length-1,s;r>=0;r--)(s=e[r])&&(i=(n?s(t,a,i):s(i))||i);return n&&i&&Pa(t,a,i),i},vt=(e,t)=>(a,n)=>t(a,n,e);const Fa=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 ft=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-Ce+4;let s=4;switch(i){case o.VerticalAlign.MIDDLE:s=(n-Ce)/2+4;break;case o.VerticalAlign.BOTTOM:s=n-Ce+4;break}e.save(),e.translateWithPrecision(t.startX+r,t.startY+s),e.fillStyle="#565656",e.fill(Fa),e.restore()}drawWith(e,t,a,n){var Z,G;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:C=0,topOffset:v=0,downOffset:g=0}=m||{},V=this._ensureMap(u),_=this._generateKey(r,s),w=this._dataValidationModel.getRuleByLocation(t.unitId,t.subUnitId,r,s);if(!w)return;const y=this._dataValidationModel.getValidator(w.type);if(!y)return;const b={startX:p.startX+c,endX:p.endX-C,startY:p.startY+v,endY:p.endY-g},I=b.endX-b.startX,D=b.endY-b.startY,{cl:S}=d||{},R=(Z=typeof S=="object"?S==null?void 0:S.rgb:S)!=null?Z:"#000",A=B.getFontStyleString(d!=null?d:void 0),{vt:W,ht:F}=d||{},T=W!=null?W:o.VerticalAlign.MIDDLE,P=(G=E.getCellValueOrigin(l))!=null?G:"",x=y.parseCellValue(P),U=y.getListWithColorMap(w),$=mt(x,A,I,D);this._drawDownIcon(e,b,I,D,T),e.save(),e.translateWithPrecision(b.startX,b.startY),e.beginPath(),e.rect(0,0,I-Ce,D),e.clip(),e.translateWithPrecision(ht,ze);let q=0;switch(T){case o.VerticalAlign.MIDDLE:q=($.contentHeight-$.totalHeight)/2;break;case o.VerticalAlign.BOTTOM:q=$.contentHeight-$.totalHeight;break}e.translateWithPrecision(0,q),$.lines.forEach((J,te)=>{e.save();const{width:ae,height:ie,items:le}=J;let oe=0;switch(F){case o.HorizontalAlign.RIGHT:oe=$.contentWidth-ae;break;case o.HorizontalAlign.CENTER:oe=($.contentWidth-ae)/2;break}e.translate(oe,te*(ie+Kt)),le.forEach(de=>{e.save(),e.translateWithPrecision(de.left,0),Ta.drawWith(e,{...A,info:de,color:R,fill:U[de.text]}),e.restore()}),e.restore()}),e.restore(),V.set(_,{left:b.startX,top:b.startY,width:$.contentWidth+ht+Ce,height:$.contentHeight+ze*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},C=this._dataValidationModel.getRuleByLocation(e.unitId,e.subUnitId,i,r);if(!C)return;const v=this._dataValidationModel.getValidator(C.type);if(!v)return;const g=c.endX-c.startX,V=c.endY-c.startY,_=(I=E.getCellValueOrigin(n))!=null?I:"",w=v.parseCellValue(_),y=B.getFontStyleString(a!=null?a:void 0);return mt(w,y,g,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},C=this._dataValidationModel.getRuleByLocation(e.unitId,e.subUnitId,i,r);if(!C)return;const v=this._dataValidationModel.getValidator(C.type);if(!v)return;const g=c.endX-c.startX,V=c.endY-c.startY,_=(I=E.getCellValueOrigin(n))!=null?I:"",w=v.parseCellValue(_),y=B.getFontStyleString(a!=null?a:void 0);return mt(w,y,g,V).calcAutoWidth}isHit(e,t){const{primaryWithCoord:a}=t,n=a.isMergedMainCell?a.mergeInfo:a,{endX:i}=n,{x:r}=e;return r>=i-Ce&&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(Fe.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)}};ft=Aa([vt(0,o.ICommandService),vt(1,o.Inject(B.IRenderManagerService)),vt(2,o.Inject(E.SheetDataValidationModel))],ft);class xa extends pe{constructor(){super(...arguments);L(this,"id",o.DataValidationType.LIST_MULTIPLE);L(this,"canvasRender",this.injector.createInstance(ft));L(this,"dropdown",Ue)}}var Na=Object.defineProperty,Ua=Object.getOwnPropertyDescriptor,Ba=(e,t,a,n)=>{for(var i=n>1?void 0:n?Ua(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&&Na(t,a,i),i},Ke=(e,t)=>(a,n)=>t(a,n,e);const De=4,Ge=4,ce=14,he=6,be=4,gt=8,ka="#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 Wa(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 qt(e,t,a){const n=Wa(e,a),i=new o.DocumentDataModel(n),r=new B.DocumentViewModel(i);return{documentSkeleton:B.DocumentSkeleton.create(r,t),docModel:i,docViewModel:r}}function qe(e,t,a){const{documentSkeleton:n,docModel:i,docViewModel:r}=qt(e,t,a);return{documents:new B.Documents(`DOCUMENTS_${o.Tools.generateRandomId()}`,n,{pageMarginLeft:0,pageMarginTop:0}),documentSkeleton:n,docModel:i,docViewModel:r}}function Zt(e,t,a,n,i,r,s=!0){let d=0;const l=s?be: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(be,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 St=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-Ge)/2;break;case o.VerticalAlign.BOTTOM:p=n-l-i-be+(i/2-Ge/2);break;default:p=d+be+(i/2-Ge/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:C=0,rightOffset:v=0,topOffset:g=0,downOffset:V=0}=c||{};if(!p||!m||!m||m.id.indexOf(o.DataValidationType.LIST)!==0||!m.skipDefaultFontRender(p))return;const _={startX:u.startX+C,endX:u.endX-v,startY:u.startY+g,endY:u.endY-V},w=_.endX-_.startX,y=_.endY-_.startY,b=this._ensureMap(l),I=this._generateKey(i,r),D=m.getListWithColor(p),S=E.getCellValueOrigin(d),R=`${S!=null?S:""}`,A=D.find(x=>x.label===R);let{tb:W,vt:F,ht:T,pd:P}=s||{};if(W=W!=null?W:o.WrapStrategy.WRAP,F=F!=null?F:o.VerticalAlign.BOTTOM,T=T!=null?T:o.DEFAULT_STYLES.ht,P=P!=null?P:o.DEFAULT_STYLES.pd,p.renderMode===o.DataValidationRenderMode.ARROW){const{l:x=o.DEFAULT_STYLES.pd.l,t:U=o.DEFAULT_STYLES.pd.t,r:$=o.DEFAULT_STYLES.pd.r,b:q=o.DEFAULT_STYLES.pd.b}=P,Z=w-x-$-ce-4,{documentSkeleton:G,documents:J,docModel:te}=qe(R,this._localeService,s);W===o.WrapStrategy.WRAP&&te.updateDocumentDataPageSize(Math.max(Z,1)),G.calculate(),G.getActualSize();const ae=B.getDocsSkeletonPageSize(G),{height:ie,width:le}=ae,{paddingTop:oe,paddingLeft:de}=Zt(Z,y-U-q,le,ie,F,T,!0);this._drawDownIcon(e,_,w,y,ie,F,P),e.save(),e.translateWithPrecision(_.startX+x,_.startY+U),e.beginPath(),e.rect(0,0,w-x-$,y-U-q),e.clip(),e.translateWithPrecision(0,oe),e.save(),e.translateWithPrecision(De,0),e.beginPath(),e.rect(0,0,Z,ie),e.clip(),J.render(e),e.translateWithPrecision(de,0),e.restore(),e.restore(),b.set(I,{left:_.endX+x+a.rowHeaderWidth-ce,top:_.startY+U+a.columnHeaderHeight,width:ce,height:y-U-q})}else{e.save(),e.translateWithPrecision(_.startX,_.startY),e.beginPath(),e.rect(0,0,w,y),e.clip();const x=w-he*2-De-ce-4,{documentSkeleton:U,documents:$,docModel:q}=qe(R,this._localeService,s);W===o.WrapStrategy.WRAP&&q.updateDocumentDataPageSize(Math.max(x,1)),U.calculate();const Z=B.getDocsSkeletonPageSize(U),{height:G,width:J}=Z,{paddingTop:te,paddingLeft:ae}=Zt(x,y,J,G,F,T);e.translateWithPrecision(he,te);const ie=Math.max(w-he*2,1),le=G;B.Rect.drawWith(e,{width:ie,height:le,fill:(A==null?void 0:A.color)||Ie,radius:gt}),e.save(),e.translateWithPrecision(De,0),e.beginPath(),e.rect(0,0,x,G),e.clip(),e.translateWithPrecision(ae,0),$.render(e),e.restore(),e.translateWithPrecision(x+De+4,(G-Ge)/2),e.fillStyle=ka,e.fill(Gt),e.restore(),b.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 C={startX:s.startX+l,endX:s.endX-u,startY:s.startY+p,endY:s.endY-m},v=C.endX-C.startX,g=E.getCellValueOrigin(n),V=`${g!=null?g:""}`;let{tb:_,pd:w}=a||{};const{t:y=o.DEFAULT_STYLES.pd.t,b=o.DEFAULT_STYLES.pd.b}=w!=null?w:{};if(_=_!=null?_:o.WrapStrategy.WRAP,c.renderMode===o.DataValidationRenderMode.ARROW){const I=v-ce,{documentSkeleton:D,docModel:S}=qe(V,this._localeService,a);_===o.WrapStrategy.WRAP&&S.updateDocumentDataPageSize(Math.max(I,1)),D.calculate(),D.getActualSize();const R=B.getDocsSkeletonPageSize(D),{height:A}=R;return A+y+b+be*2}else{const I=v-he*2-De-ce,{documentSkeleton:D,docModel:S}=qt(V,this._localeService,a);_===o.WrapStrategy.WRAP&&S.updateDocumentDataPageSize(Math.max(I,1)),D.calculate();const R=B.getDocsSkeletonPageSize(D),{height:A}=R;return A+be*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 C={startX:s.startX+l,endX:s.endX-u,startY:s.startY+p,endY:s.endY-m},v=C.endX-C.startX,g=E.getCellValueOrigin(n),V=`${g!=null?g:""}`;let{tb:_,pd:w}=a||{};const{l:y=o.DEFAULT_STYLES.pd.l,r:b=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+b+y;break;case o.DataValidationRenderMode.CUSTOM:I=ce+he*2+De*2+b+y+gt/2+1;break;default:I=ce+he*2+De*2+b+y+gt/2+1}const D=v-I,{documentSkeleton:S,docModel:R}=qe(V,this._localeService,a);return _===o.WrapStrategy.WRAP&&R.updateDocumentDataPageSize(Math.max(D,1)),S.calculate(),S.getActualSize(),B.getDocsSkeletonPageSize(S).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:C}=e;return c>=u&&c<=u+p&&C>=l&&C<=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(Fe.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=Ba([Ke(0,o.Inject(o.LocaleService)),Ke(1,o.ICommandService),Ke(2,o.Inject(B.IRenderManagerService)),Ke(3,o.Inject(E.SheetDataValidationModel))],St);class $a extends pe{constructor(){super(...arguments);L(this,"id",o.DataValidationType.LIST);L(this,"canvasRender",this.injector.createInstance(St));L(this,"dropdown",Ue);L(this,"optionsInput",He.componentKey);L(this,"formulaInput",ct)}}class Ha extends pe{constructor(){super(...arguments);L(this,"id",o.DataValidationType.TEXT_LENGTH);L(this,"formulaInput",$e)}}class Ya extends pe{constructor(){super(...arguments);L(this,"id",o.DataValidationType.WHOLE);L(this,"formulaInput",$e)}}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},_t=(e,t)=>(a,n)=>t(a,n,e);let Oe=class extends o.RxDisposable{constructor(e,t,a){super(),this._injector=e,this._componentManger=t,this._dataValidatorRegistryService=a,this._initComponents(),this._registerValidatorViews()}_initComponents(){[[xt,Mt],[nt,Un],[Pt,En],[Ue,Ln],[rt,un],[He.componentKey,He],[Ye.componentKey,Ye],...ma].forEach(([e,t])=>{this.disposeWithMe(this._componentManger.register(e,t))})}_registerValidatorViews(){[Ra,Ya,Ha,Ma,wa,$a,xa,Va].forEach(e=>{const t=this._injector.createInstance(e),a=this._dataValidatorRegistryService.getValidatorItem(t.id);a&&(a.formulaInput=t.formulaInput,a.canvasRender=t.canvasRender,a.dropdown=t.dropdown,a.optionsInput=t.optionsInput)})}};Oe=Ka([_t(0,o.Inject(o.Injector)),_t(1,o.Inject(z.ComponentManager)),_t(2,o.Inject(Q.DataValidatorRegistryService))],Oe);var Ga=Object.defineProperty,qa=Object.getOwnPropertyDescriptor,Za=(e,t,a,n)=>{for(var i=n>1?void 0:n?qa(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},It=(e,t)=>(a,n)=>t(a,n,e);const Ja="SHEET_DATA_VALIDATION_UI_PLUGIN";Y.UniverSheetsDataValidationUIPlugin=(Ze=class extends o.Plugin{constructor(t=Ft,a,n,i){super(),this._config=t,this._injector=a,this._commandService=n,this._configService=i;const{menu:r,...s}=this._config;r&&this._configService.setConfig("menu",r,{merge:!0}),this._configService.setConfig(it,s)}onStarting(){[[ue],[fe],[Pe],[Ve],[Re],[Me],[Ee],[Te],[Oe]].forEach(t=>{this._injector.add(t)}),[Be,Fe,At,at,_e,jt].forEach(t=>{this._commandService.registerCommand(t)})}onReady(){this._injector.get(Ee),this._injector.get(Me),this._injector.get(Te),this._injector.get(Pe),this._injector.get(B.IRenderManagerService).registerRenderModule(o.UniverInstanceType.UNIVER_SHEET,[We])}onRendered(){this._injector.get(Oe),this._injector.get(Re)}onSteady(){this._injector.get(Ve)}},L(Ze,"pluginName",Ja),L(Ze,"type",o.UniverInstanceType.UNIVER_SHEET),Ze),Y.UniverSheetsDataValidationUIPlugin=Za([It(1,o.Inject(o.Injector)),It(2,o.ICommandService),It(3,o.IConfigService)],Y.UniverSheetsDataValidationUIPlugin);var Qa=Object.defineProperty,ei=Object.getOwnPropertyDescriptor,ti=(e,t,a,n)=>{for(var i=n>1?void 0:n?ei(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&&Qa(t,a,i),i},Ct=(e,t)=>(a,n)=>t(a,n,e);const ni="SHEET_DATA_VALIDATION_UI_PLUGIN";Y.UniverSheetsDataValidationMobileUIPlugin=(Je=class extends o.Plugin{constructor(t=Ft,a,n,i){super(),this._config=t,this._injector=a,this._commandService=n,this._configService=i;const{menu:r,...s}=this._config;r&&this._configService.setConfig("menu",r,{merge:!0}),this._configService.setConfig(it,s)}onStarting(){[[ue],[fe],[Pe],[Ve],[Re],[Me],[Ee],[Oe]].forEach(t=>{this._injector.add(t)}),[Be,Fe,At,at,_e,jt].forEach(t=>{this._commandService.registerCommand(t)})}onReady(){this._injector.get(Ee),this._injector.get(Me),this._injector.get(B.IRenderManagerService).registerRenderModule(o.UniverInstanceType.UNIVER_SHEET,[We])}onRendered(){this._injector.get(Oe),this._injector.get(Re)}onSteady(){this._injector.get(Ve)}},L(Je,"pluginName",ni),L(Je,"type",o.UniverInstanceType.UNIVER_SHEET),Je),Y.UniverSheetsDataValidationMobileUIPlugin=ti([Ct(1,o.Inject(o.Injector)),Ct(2,o.ICommandService),Ct(3,o.IConfigService)],Y.UniverSheetsDataValidationMobileUIPlugin),Y.DATE_DROPDOWN_KEY=rt,Y.LIST_DROPDOWN_KEY=Ue,Object.defineProperty(Y,Symbol.toStringTag,{value:"Module"})});
|
|
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(",").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"})});
|
|
23
23
|
|
|
24
24
|
|
|
25
25
|
// index
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
// @univerjs/sheets-data-validation-ui/locale/fr-FR
|
|
2
|
+
(function(e,t){typeof exports=="object"&&typeof module<"u"?module.exports=t():typeof define=="function"&&define.amd?define(t):(e=typeof globalThis<"u"?globalThis:e||self,e.UniverSheetsDataValidationUiFrFR=t())})(this,function(){"use strict";return{dataValidation:{title:"Validation des données",validFail:{value:"Veuillez entrer une valeur",common:"Veuillez entrer une valeur ou une formule",number:"Veuillez entrer un nombre ou une formule",formula:"Veuillez entrer une formule",integer:"Veuillez entrer un entier ou une formule",date:"Veuillez entrer une date ou une formule",list:"Veuillez entrer des options",listInvalid:"La source de la liste doit être une liste délimitée ou une référence à une seule ligne ou colonne",checkboxEqual:"Entrez des valeurs différentes pour les contenus des cellules cochées et décochées.",formulaError:"La plage de référence contient des données invisibles, veuillez réajuster la plage",listIntersects:"La plage sélectionnée ne peut pas croiser le champ des règles",primitive:"Les formules ne sont pas autorisées pour les valeurs personnalisées cochées et décochées."},panel:{title:"Gestion de la validation des données",addTitle:"Créer une nouvelle validation des données",removeAll:"Tout supprimer",add:"Ajouter une règle",range:"Plages",type:"Type",options:"Options avancées",operator:"Opérateur",removeRule:"Supprimer",done:"Terminé",formulaPlaceholder:"Veuillez entrer une valeur ou une formule",valuePlaceholder:"Veuillez entrer une valeur",formulaAnd:"et",invalid:"Invalide",showWarning:"Afficher un avertissement",rejectInput:"Rejeter l'entrée",messageInfo:"Message d'aide",showInfo:"Afficher le texte d'aide pour une cellule sélectionnée",rangeError:"Les plages ne sont pas légales",allowBlank:"Autoriser les valeurs vides"},operators:{between:"entre",greaterThan:"supérieur à",greaterThanOrEqual:"supérieur ou égal à",lessThan:"inférieur à",lessThanOrEqual:"inférieur ou égal à",equal:"égal à",notEqual:"différent de",notBetween:"pas entre"},ruleName:{between:"est entre {FORMULA1} et {FORMULA2}",greaterThan:"est supérieur à {FORMULA1}",greaterThanOrEqual:"est supérieur ou égal à {FORMULA1}",lessThan:"est inférieur à {FORMULA1}",lessThanOrEqual:"est inférieur ou égal à {FORMULA1}",equal:"est égal à {FORMULA1}",notEqual:"est différent de {FORMULA1}",notBetween:"n'est pas entre {FORMULA1} et {FORMULA2}"},errorMsg:{between:"La valeur doit être entre {FORMULA1} et {FORMULA2}",greaterThan:"La valeur doit être supérieure à {FORMULA1}",greaterThanOrEqual:"La valeur doit être supérieure ou égale à {FORMULA1}",lessThan:"La valeur doit être inférieure à {FORMULA1}",lessThanOrEqual:"La valeur doit être inférieure ou égale à {FORMULA1}",equal:"La valeur doit être égale à {FORMULA1}",notEqual:"La valeur doit être différente de {FORMULA1}",notBetween:"La valeur ne doit pas être entre {FORMULA1} et {FORMULA2}"},any:{title:"N'importe quelle valeur",error:"Le contenu de cette cellule viole la règle de validation"},date:{title:"Date",operators:{between:"entre",greaterThan:"après",greaterThanOrEqual:"le ou après",lessThan:"avant",lessThanOrEqual:"le ou avant",equal:"égal à",notEqual:"différent de",notBetween:"pas entre"},ruleName:{between:"est entre {FORMULA1} et {FORMULA2}",greaterThan:"est après {FORMULA1}",greaterThanOrEqual:"est le ou après {FORMULA1}",lessThan:"est avant {FORMULA1}",lessThanOrEqual:"est le ou avant {FORMULA1}",equal:"est {FORMULA1}",notEqual:"n'est pas {FORMULA1}",notBetween:"n'est pas entre {FORMULA1}"},errorMsg:{between:"La valeur doit être une date légale et entre {FORMULA1} et {FORMULA2}",greaterThan:"La valeur doit être une date légale et après {FORMULA1}",greaterThanOrEqual:"La valeur doit être une date légale et le ou après {FORMULA1}",lessThan:"La valeur doit être une date légale et avant {FORMULA1}",lessThanOrEqual:"La valeur doit être une date légale et le ou avant {FORMULA1}",equal:"La valeur doit être une date légale et {FORMULA1}",notEqual:"La valeur doit être une date légale et non {FORMULA1}",notBetween:"La valeur doit être une date légale et non entre {FORMULA1}"}},list:{title:"Liste déroulante",name:"La valeur contient une de la plage",error:"L'entrée doit être dans la plage spécifiée",emptyError:"Veuillez entrer une valeur",add:"Ajouter",dropdown:"Sélectionner",options:"Options",customOptions:"Personnalisé",refOptions:"D'une plage",formulaError:"La source de la liste doit être une liste délimitée de données, ou une référence à une seule ligne ou colonne.",edit:"Éditer"},listMultiple:{title:"Liste déroulante-Multiple",dropdown:"Sélection multiple"},textLength:{title:"Longueur du texte",errorMsg:{between:"La longueur du texte doit être entre {FORMULA1} et {FORMULA2}",greaterThan:"La longueur du texte doit être supérieure à {FORMULA1}",greaterThanOrEqual:"La longueur du texte doit être supérieure ou égale à {FORMULA1}",lessThan:"La longueur du texte doit être inférieure à {FORMULA1}",lessThanOrEqual:"La longueur du texte doit être inférieure ou égale à {FORMULA1}",equal:"La longueur du texte doit être {FORMULA1}",notEqual:"La longueur du texte doit être différente de {FORMULA1}",notBetween:"La longueur du texte ne doit pas être entre {FORMULA1} et {FORMULA2}"}},decimal:{title:"Nombre"},whole:{title:"Entier"},checkbox:{title:"Case à cocher",error:"Le contenu de cette cellule viole sa règle de validation",tips:"Utiliser des valeurs personnalisées dans les cellules",checked:"Valeur sélectionnée",unchecked:"Valeur non sélectionnée"},custom:{title:"Formule personnalisée",error:"Le contenu de cette cellule viole sa règle de validation",validFail:"Veuillez entrer une formule valide",ruleName:"La formule personnalisée est {FORMULA1}"},alert:{title:"Erreur",ok:"OK"},error:{title:"Invalide :"},renderMode:{arrow:"Flèche",chip:"Puce",text:"Texte brut",label:"Style d'affichage"},showTime:{label:"Afficher le sélecteur de temps"}}}});
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
// locale/fr-FR
|
|
6
|
+
(function(e,i){typeof exports=="object"&&typeof module<"u"?module.exports=i(require("@univerjs/core"),require("@univerjs/sheets-data-validation-ui/locale/fr-FR")):typeof define=="function"&&define.amd?define(["@univerjs/core","@univerjs/sheets-data-validation-ui/locale/fr-FR"],i):(e=typeof globalThis<"u"?globalThis:e||self,e.UniverPresetSheetsDataValidationFrFR=i(e.UniverCore,e.UniverSheetsDataValidationUiFrFR))})(this,function(e,i){"use strict";return e.Tools.deepMerge({},i)});
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@univerjs/preset-sheets-data-validation",
|
|
3
|
-
"version": "0.5.
|
|
3
|
+
"version": "0.5.1-nightly.202412271606",
|
|
4
4
|
"private": false,
|
|
5
5
|
"description": "",
|
|
6
6
|
"author": "DreamNum <developer@univer.ai>",
|
|
@@ -20,6 +20,9 @@
|
|
|
20
20
|
"keywords": [
|
|
21
21
|
"univer"
|
|
22
22
|
],
|
|
23
|
+
"sideEffects": [
|
|
24
|
+
"*.css"
|
|
25
|
+
],
|
|
23
26
|
"exports": {
|
|
24
27
|
".": {
|
|
25
28
|
"import": "./lib/es/index.js",
|
|
@@ -54,17 +57,17 @@
|
|
|
54
57
|
"rxjs": ">=7.0.0"
|
|
55
58
|
},
|
|
56
59
|
"dependencies": {
|
|
57
|
-
"@univerjs/data-validation": "0.5.
|
|
58
|
-
"@univerjs/sheets-data-validation": "0.5.
|
|
59
|
-
"@univerjs/sheets-data-validation-ui": "0.5.
|
|
60
|
+
"@univerjs/data-validation": "0.5.1-nightly.202412271606",
|
|
61
|
+
"@univerjs/sheets-data-validation": "0.5.1-nightly.202412271606",
|
|
62
|
+
"@univerjs/sheets-data-validation-ui": "0.5.1-nightly.202412271606"
|
|
60
63
|
},
|
|
61
64
|
"devDependencies": {
|
|
62
|
-
"@univerjs/core": "0.5.
|
|
63
|
-
"typescript": "^5.
|
|
64
|
-
"@univerjs-infra/shared": "0.5.
|
|
65
|
+
"@univerjs/core": "0.5.1-nightly.202412271606",
|
|
66
|
+
"typescript": "^5.7.2",
|
|
67
|
+
"@univerjs-infra/shared": "0.5.1-nightly.202412271606"
|
|
65
68
|
},
|
|
66
69
|
"scripts": {
|
|
67
|
-
"prebuild": "tsx prepare.ts",
|
|
70
|
+
"prebuild:preset": "tsx prepare.ts",
|
|
68
71
|
"build:preset": "tsx build.ts"
|
|
69
72
|
},
|
|
70
73
|
"module": "./lib/es/index.js"
|