@univerjs/sheets-conditional-formatting 0.2.2 → 0.2.4-alpha.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +11 -4
- package/lib/cjs/index.js +1 -1
- package/lib/es/index.js +87 -85
- package/lib/types/commands/mutations/add-conditional-rule.mutation.d.ts +1 -2
- package/lib/types/commands/mutations/delete-conditional-rule.mutation.d.ts +1 -2
- package/lib/types/commands/mutations/set-conditional-rule.mutation.d.ts +1 -2
- package/lib/types/models/conditional-formatting-rule-model.d.ts +1 -1
- package/lib/types/plugin.d.ts +1 -2
- package/lib/types/services/__test__/test.util.d.ts +7 -8
- package/lib/types/services/calculate-unit/type.d.ts +1 -2
- package/lib/types/services/conditional-formatting-formula.service.d.ts +2 -2
- package/lib/types/services/conditional-formatting.service.d.ts +1 -2
- package/lib/umd/index.js +1 -1
- package/package.json +13 -15
package/lib/es/index.js
CHANGED
|
@@ -1,17 +1,16 @@
|
|
|
1
1
|
var CA = Object.defineProperty;
|
|
2
2
|
var YA = (f, v, e) => v in f ? CA(f, v, { enumerable: !0, configurable: !0, writable: !0, value: e }) : f[v] = e;
|
|
3
3
|
var D = (f, v, e) => YA(f, typeof v != "symbol" ? v + "" : v, e);
|
|
4
|
-
import { Tools as _, ObjectMatrix as Y, Range as W, CommandType as vA, ICommandService as PA, Disposable as WA, toDisposable as OA, RefAlias as
|
|
5
|
-
import { Inject as J, Injector as XA } from "@wendellhu/redi";
|
|
4
|
+
import { Tools as _, ObjectMatrix as Y, Range as W, Inject as J, Injector as NA, CommandType as vA, ICommandService as PA, Disposable as WA, toDisposable as OA, RefAlias as hA, CellValueType as c, BooleanNumber as EA, ColorKit as JA, Rectangle as R, createInterceptorKey as jA, OnLifecycle as UA, LifecycleStages as RA, IUniverInstanceService as MA, IResourceManagerService as VA, afterInitApply as bA, InterceptorManager as FA, UniverInstanceType as XA, Plugin as IA } from "@univerjs/core";
|
|
6
5
|
import { SheetInterceptorService as zA, RemoveSheetCommand as qA, ReorderRangeMutation as KA, MoveRangeMutation as yA, MoveColsMutation as xA, MoveRowsMutation as GA, InsertRowMutation as _A, RemoveRowMutation as $A, RemoveColMutation as Av, InsertColMutation as vv, SetRangeValuesMutation as ev } from "@univerjs/sheets";
|
|
7
6
|
import { Subject as LA } from "rxjs";
|
|
8
|
-
import { bufferTime as Zv, filter as
|
|
7
|
+
import { bufferTime as Zv, filter as aA, map as fv } from "rxjs/operators";
|
|
9
8
|
import { IActiveDirtyManagerService as nv, SetFormulaCalculationResultMutation as mv, SetOtherFormulaMutation as Tv, RemoveOtherFormulaMutation as Sv, BooleanValue as uA, LexerTreeBuilder as lv, sequenceNodeType as Nv, deserializeRangeWithSheet as Xv, serializeRange as Lv, generateStringWithSequence as tv, ERROR_TYPE_SET as DA } from "@univerjs/engine-formula";
|
|
10
9
|
import E from "dayjs";
|
|
11
|
-
import { isObject as kv, SpreadsheetExtensionRegistry as
|
|
10
|
+
import { isObject as kv, SpreadsheetExtensionRegistry as iA, SheetExtension as sA, FIX_ONE_PIXEL_BLUR_OFFSET as wv } from "@univerjs/engine-render";
|
|
12
11
|
const oA = "SHEET_CONDITIONAL_FORMATTING_PLUGIN";
|
|
13
|
-
var o = /* @__PURE__ */ ((f) => (f.beginsWith = "beginsWith", f.endsWith = "endsWith", f.containsText = "containsText", f.notContainsText = "notContainsText", f.equal = "equal", f.notEqual = "notEqual", f.containsBlanks = "containsBlanks", f.notContainsBlanks = "notContainsBlanks", f.containsErrors = "containsErrors", f.notContainsErrors = "notContainsErrors", f))(o || {}), g = /* @__PURE__ */ ((f) => (f.today = "today", f.yesterday = "yesterday", f.tomorrow = "tomorrow", f.last7Days = "last7Days", f.thisMonth = "thisMonth", f.lastMonth = "lastMonth", f.nextMonth = "nextMonth", f.thisWeek = "thisWeek", f.lastWeek = "lastWeek", f.nextWeek = "nextWeek", f))(g || {}), H = /* @__PURE__ */ ((f) => (f.greaterThan = "greaterThan", f.greaterThanOrEqual = "greaterThanOrEqual", f.lessThan = "lessThan", f.lessThanOrEqual = "lessThanOrEqual", f.notBetween = "notBetween", f.between = "between", f.equal = "equal", f.notEqual = "notEqual", f))(H || {}),
|
|
14
|
-
const
|
|
12
|
+
var o = /* @__PURE__ */ ((f) => (f.beginsWith = "beginsWith", f.endsWith = "endsWith", f.containsText = "containsText", f.notContainsText = "notContainsText", f.equal = "equal", f.notEqual = "notEqual", f.containsBlanks = "containsBlanks", f.notContainsBlanks = "notContainsBlanks", f.containsErrors = "containsErrors", f.notContainsErrors = "notContainsErrors", f))(o || {}), g = /* @__PURE__ */ ((f) => (f.today = "today", f.yesterday = "yesterday", f.tomorrow = "tomorrow", f.last7Days = "last7Days", f.thisMonth = "thisMonth", f.lastMonth = "lastMonth", f.nextMonth = "nextMonth", f.thisWeek = "thisWeek", f.lastWeek = "lastWeek", f.nextWeek = "nextWeek", f))(g || {}), H = /* @__PURE__ */ ((f) => (f.greaterThan = "greaterThan", f.greaterThanOrEqual = "greaterThanOrEqual", f.lessThan = "lessThan", f.lessThanOrEqual = "lessThanOrEqual", f.notBetween = "notBetween", f.between = "between", f.equal = "equal", f.notEqual = "notEqual", f))(H || {}), j = /* @__PURE__ */ ((f) => (f.highlightCell = "highlightCell", f.dataBar = "dataBar", f.colorScale = "colorScale", f.iconSet = "iconSet", f))(j || {}), i = /* @__PURE__ */ ((f) => (f.uniqueValues = "uniqueValues", f.duplicateValues = "duplicateValues", f.rank = "rank", f.text = "text", f.timePeriod = "timePeriod", f.number = "number", f.average = "average", f.formula = "formula", f))(i || {}), z = /* @__PURE__ */ ((f) => (f.num = "num", f.min = "min", f.max = "max", f.percent = "percent", f.percentile = "percentile", f.formula = "formula", f))(z || {});
|
|
13
|
+
const De = "#fff", re = "#000000", He = () => ({
|
|
15
14
|
cfId: void 0,
|
|
16
15
|
ranges: [],
|
|
17
16
|
stopIfTrue: !1,
|
|
@@ -21,7 +20,7 @@ const re = "#fff", He = "#000000", Qe = () => ({
|
|
|
21
20
|
operator: "containsText"
|
|
22
21
|
/* containsText */
|
|
23
22
|
}
|
|
24
|
-
}),
|
|
23
|
+
}), Qe = (f, v) => {
|
|
25
24
|
switch (f) {
|
|
26
25
|
case "text": {
|
|
27
26
|
if ([
|
|
@@ -44,7 +43,7 @@ const re = "#fff", He = "#000000", Qe = () => ({
|
|
|
44
43
|
].includes(v) ? [10, 100] : 10;
|
|
45
44
|
}
|
|
46
45
|
return "";
|
|
47
|
-
},
|
|
46
|
+
}, We = (f, v) => {
|
|
48
47
|
switch (f) {
|
|
49
48
|
case "formula":
|
|
50
49
|
return "=";
|
|
@@ -133,7 +132,7 @@ const re = "#fff", He = "#000000", Qe = () => ({
|
|
|
133
132
|
return [v, { ...f, type: "self" }];
|
|
134
133
|
}
|
|
135
134
|
return null;
|
|
136
|
-
},
|
|
135
|
+
}, Ee = (f, v) => f.id === v.id && f.type === v.type;
|
|
137
136
|
class eA {
|
|
138
137
|
constructor() {
|
|
139
138
|
// Map<unitID ,<sheetId ,ObjectMatrix>>
|
|
@@ -321,9 +320,9 @@ let O = class {
|
|
|
321
320
|
};
|
|
322
321
|
O = rv([
|
|
323
322
|
rA(0, J(eA)),
|
|
324
|
-
rA(1, J(
|
|
323
|
+
rA(1, J(NA))
|
|
325
324
|
], O);
|
|
326
|
-
const
|
|
325
|
+
const Je = (f, v) => ({ id: dA.id, params: { unitId: v.unitId, subUnitId: v.subUnitId, cfId: v.rule.cfId } }), gA = {
|
|
327
326
|
type: vA.MUTATION,
|
|
328
327
|
id: "sheet.mutation.add-conditional-rule",
|
|
329
328
|
handler(f, v) {
|
|
@@ -413,6 +412,9 @@ let M = class extends WA {
|
|
|
413
412
|
this._cache.clear(), this._formulaMap.clear();
|
|
414
413
|
}));
|
|
415
414
|
}
|
|
415
|
+
dispose() {
|
|
416
|
+
this._formulaChange$.complete();
|
|
417
|
+
}
|
|
416
418
|
_initCache() {
|
|
417
419
|
const v = this._injector.get(G);
|
|
418
420
|
this.disposeWithMe(v.ruleComputeStatus$.subscribe((e) => {
|
|
@@ -464,7 +466,7 @@ let M = class extends WA {
|
|
|
464
466
|
};
|
|
465
467
|
}
|
|
466
468
|
}
|
|
467
|
-
), this.formulaChange$.pipe(Zv(16),
|
|
469
|
+
), this.formulaChange$.pipe(Zv(16), aA((v) => !!v.length), fv((v) => v.reduce((e, A) => {
|
|
468
470
|
const { unitId: Z, subUnitId: n, formulaId: m, formulaText: T } = A;
|
|
469
471
|
return e[Z] || (e[Z] = {}), e[Z][n] || (e[Z][n] = {}), e[Z][n][m] = { f: T }, e;
|
|
470
472
|
}, {}))).subscribe((v) => {
|
|
@@ -484,7 +486,7 @@ let M = class extends WA {
|
|
|
484
486
|
let A = this._formulaMap.get(v);
|
|
485
487
|
A || (A = /* @__PURE__ */ new Map(), this._formulaMap.set(v, A));
|
|
486
488
|
let Z = A.get(e);
|
|
487
|
-
return Z || (Z = new
|
|
489
|
+
return Z || (Z = new hA([], ["formulaId", "formulaText"]), A.set(e, Z)), Z;
|
|
488
490
|
}
|
|
489
491
|
_ensureCacheMap(v, e) {
|
|
490
492
|
let A = this._cache.get(v);
|
|
@@ -555,7 +557,7 @@ let M = class extends WA {
|
|
|
555
557
|
};
|
|
556
558
|
M = Ev([
|
|
557
559
|
$(0, J(PA)),
|
|
558
|
-
$(1, J(
|
|
560
|
+
$(1, J(NA)),
|
|
559
561
|
$(2, J(nv)),
|
|
560
562
|
$(3, J(eA)),
|
|
561
563
|
$(4, J(O))
|
|
@@ -572,7 +574,7 @@ const C = (f) => [void 0, null].includes(f), U = (f) => {
|
|
|
572
574
|
const v = f.v, e = (Z = (A = f.p) == null ? void 0 : A.body) == null ? void 0 : Z.dataStream.replace(/\r\n$/, "");
|
|
573
575
|
return C(v) ? C(e) ? null : e : v;
|
|
574
576
|
}, wA = 86400;
|
|
575
|
-
function
|
|
577
|
+
function av(f, v = !0) {
|
|
576
578
|
if (v && f >= 0) {
|
|
577
579
|
if (f === 0)
|
|
578
580
|
return [1900, 1, 0];
|
|
@@ -591,12 +593,12 @@ function iv(f, v = !0) {
|
|
|
591
593
|
const T = n + 2 - 12 * e;
|
|
592
594
|
return [100 * (A - 49) + Z + e | 0, T | 0, m | 0];
|
|
593
595
|
}
|
|
594
|
-
const
|
|
596
|
+
const iv = (f) => {
|
|
595
597
|
let v = f | 0;
|
|
596
598
|
const e = wA * (f - v);
|
|
597
599
|
let A = Math.floor(e);
|
|
598
600
|
e - A > 0.9999 && (A += 1, A === wA && (A = 0, v += 1));
|
|
599
|
-
const Z = A < 0 ? wA + A : A, [n, m, T] =
|
|
601
|
+
const Z = A < 0 ? wA + A : A, [n, m, T] = av(f, !0), l = Math.floor(Z / 60 / 60) % 60, S = Math.floor(Z / 60) % 60, N = Math.floor(Z) % 60, X = /* @__PURE__ */ new Date(0);
|
|
600
602
|
return X.setUTCFullYear(n, m - 1, T), X.setUTCHours(l, S, N), X.getTime();
|
|
601
603
|
}, SA = (f, v, e) => {
|
|
602
604
|
switch (f.type) {
|
|
@@ -648,7 +650,7 @@ const av = (f) => {
|
|
|
648
650
|
};
|
|
649
651
|
}
|
|
650
652
|
}
|
|
651
|
-
},
|
|
653
|
+
}, ie = (f, v, e, A) => {
|
|
652
654
|
const { accessor: Z } = A, n = Z.get(eA), m = new Y();
|
|
653
655
|
return e.ranges.forEach((T) => {
|
|
654
656
|
W.foreach(T, (l, S) => {
|
|
@@ -735,7 +737,7 @@ const av = (f) => {
|
|
|
735
737
|
}).filter((A) => !!A), K = {};
|
|
736
738
|
Object.freeze(K);
|
|
737
739
|
const gv = {
|
|
738
|
-
type:
|
|
740
|
+
type: j.dataBar,
|
|
739
741
|
handle: async (f, v) => {
|
|
740
742
|
const e = f.rule, A = v.accessor.get(M), { worksheet: Z } = v, n = new Y(), m = tA(f.ranges, Z.getMaxRows() - 1, Z.getMaxColumns() - 1);
|
|
741
743
|
m.forEach((t) => {
|
|
@@ -804,11 +806,11 @@ const gv = {
|
|
|
804
806
|
return T;
|
|
805
807
|
}
|
|
806
808
|
}, cv = {
|
|
807
|
-
type:
|
|
809
|
+
type: j.highlightCell,
|
|
808
810
|
handle: async (f, v) => {
|
|
809
811
|
const e = f.rule, { worksheet: A } = v, Z = tA(f.ranges, A.getMaxRows() - 1, A.getMaxColumns() - 1), m = (() => {
|
|
810
812
|
switch (e.subType) {
|
|
811
|
-
case
|
|
813
|
+
case i.average: {
|
|
812
814
|
let S = 0, N = 0;
|
|
813
815
|
return Z.forEach((X) => {
|
|
814
816
|
W.foreach(X, (k, w) => {
|
|
@@ -817,8 +819,8 @@ const gv = {
|
|
|
817
819
|
});
|
|
818
820
|
}), { average: S / N };
|
|
819
821
|
}
|
|
820
|
-
case
|
|
821
|
-
case
|
|
822
|
+
case i.uniqueValues:
|
|
823
|
+
case i.duplicateValues: {
|
|
822
824
|
const S = /* @__PURE__ */ new Map();
|
|
823
825
|
return Z.forEach((N) => {
|
|
824
826
|
W.foreach(N, (X, k) => {
|
|
@@ -830,7 +832,7 @@ const gv = {
|
|
|
830
832
|
});
|
|
831
833
|
}), { count: S };
|
|
832
834
|
}
|
|
833
|
-
case
|
|
835
|
+
case i.rank: {
|
|
834
836
|
const S = [];
|
|
835
837
|
Z.forEach((k) => {
|
|
836
838
|
W.foreach(k, (w, L) => {
|
|
@@ -841,7 +843,7 @@ const gv = {
|
|
|
841
843
|
const N = f.rule, X = N.isPercent ? Math.round(Math.max(Math.min(N.value, 100), 0) / 100 * S.length) : Math.round(Math.max(Math.min(N.value, S.length), 0));
|
|
842
844
|
return N.isBottom ? { rank: S[S.length - X] } : { rank: S[Math.max(X - 1, 0)] };
|
|
843
845
|
}
|
|
844
|
-
case
|
|
846
|
+
case i.formula: {
|
|
845
847
|
const S = e, N = v.accessor.get(lv), X = S.value, k = N.sequenceNodesBuilder(X);
|
|
846
848
|
return k ? { sequenceNodes: k } : {
|
|
847
849
|
sequenceNodes: null
|
|
@@ -851,14 +853,14 @@ const gv = {
|
|
|
851
853
|
})(), T = (S, N) => {
|
|
852
854
|
const X = A == null ? void 0 : A.getCellRaw(S, N);
|
|
853
855
|
switch (e.subType) {
|
|
854
|
-
case
|
|
856
|
+
case i.number: {
|
|
855
857
|
const k = X && Number(X.v);
|
|
856
858
|
if (C(k) || Number.isNaN(k) || (X == null ? void 0 : X.t) !== c.NUMBER)
|
|
857
859
|
return !1;
|
|
858
860
|
const w = e;
|
|
859
861
|
return AA({ operator: w.operator, value: w.value || 0 }, k || 0);
|
|
860
862
|
}
|
|
861
|
-
case
|
|
863
|
+
case i.text: {
|
|
862
864
|
const k = e, w = U(X), L = w === null ? "" : String(w), t = k.value || "";
|
|
863
865
|
switch (k.operator) {
|
|
864
866
|
case o.beginsWith:
|
|
@@ -885,11 +887,11 @@ const gv = {
|
|
|
885
887
|
return !1;
|
|
886
888
|
}
|
|
887
889
|
}
|
|
888
|
-
case
|
|
890
|
+
case i.timePeriod: {
|
|
889
891
|
const k = U(X);
|
|
890
892
|
if (C(k) || Number.isNaN(Number(k)) || (X == null ? void 0 : X.t) !== c.NUMBER)
|
|
891
893
|
return !1;
|
|
892
|
-
const w = e, L =
|
|
894
|
+
const w = e, L = iv(Number(k));
|
|
893
895
|
switch (w.operator) {
|
|
894
896
|
case g.last7Days: {
|
|
895
897
|
const t = E().subtract(7, "day").valueOf(), B = E().valueOf();
|
|
@@ -935,7 +937,7 @@ const gv = {
|
|
|
935
937
|
return !1;
|
|
936
938
|
}
|
|
937
939
|
}
|
|
938
|
-
case
|
|
940
|
+
case i.average: {
|
|
939
941
|
const k = X && X.v, w = Number(k);
|
|
940
942
|
if (C(k) || Number.isNaN(w) || (X == null ? void 0 : X.t) !== c.NUMBER)
|
|
941
943
|
return !1;
|
|
@@ -957,27 +959,27 @@ const gv = {
|
|
|
957
959
|
return !1;
|
|
958
960
|
}
|
|
959
961
|
}
|
|
960
|
-
case
|
|
962
|
+
case i.rank: {
|
|
961
963
|
const k = U(X), w = Number(k);
|
|
962
964
|
if (C(k) || Number.isNaN(w) || (X == null ? void 0 : X.t) !== c.NUMBER)
|
|
963
965
|
return !1;
|
|
964
966
|
const L = m.rank;
|
|
965
967
|
return e.isBottom ? w <= L : w >= L;
|
|
966
968
|
}
|
|
967
|
-
case
|
|
969
|
+
case i.uniqueValues: {
|
|
968
970
|
const k = U(X);
|
|
969
971
|
return C(k) ? !1 : m.count.get(k) === 1;
|
|
970
972
|
}
|
|
971
|
-
case
|
|
973
|
+
case i.duplicateValues: {
|
|
972
974
|
const k = U(X);
|
|
973
975
|
return C(k) ? !1 : m.count.get(k) !== 1;
|
|
974
976
|
}
|
|
975
|
-
case
|
|
977
|
+
case i.formula: {
|
|
976
978
|
if (!(m != null && m.sequenceNodes))
|
|
977
979
|
return !1;
|
|
978
980
|
const { unitId: k, subUnitId: w } = v, L = v.accessor.get(M), t = (p, Q) => ({ startRow: p, endRow: p, startColumn: Q, endColumn: Q }), B = t(f.ranges[0].startRow, f.ranges[0].startColumn), d = _.deepClone(m.sequenceNodes), r = Array.isArray(d) ? d.map((p) => {
|
|
979
981
|
if (typeof p == "object" && p.nodeType === Nv.REFERENCE) {
|
|
980
|
-
const Q = Xv(p.token),
|
|
982
|
+
const Q = Xv(p.token), a = R.getRelativeRange(Q.range, B), h = R.getPositionRange(a, t(S, N), Q.range), y = Lv(h);
|
|
981
983
|
return {
|
|
982
984
|
...p,
|
|
983
985
|
token: y
|
|
@@ -992,8 +994,8 @@ const gv = {
|
|
|
992
994
|
if (p && p.status === s.SUCCESS)
|
|
993
995
|
return p.result === !0;
|
|
994
996
|
{
|
|
995
|
-
const Q = L.getCache(k, w, f.cfId),
|
|
996
|
-
return
|
|
997
|
+
const Q = L.getCache(k, w, f.cfId), a = Q == null ? void 0 : Q.getValue(S, N);
|
|
998
|
+
return a && a !== K;
|
|
997
999
|
}
|
|
998
1000
|
}
|
|
999
1001
|
return !1;
|
|
@@ -1007,7 +1009,7 @@ const gv = {
|
|
|
1007
1009
|
}), l;
|
|
1008
1010
|
}
|
|
1009
1011
|
}, Cv = "", Yv = {
|
|
1010
|
-
type:
|
|
1012
|
+
type: j.colorScale,
|
|
1011
1013
|
handle: async (f, v) => {
|
|
1012
1014
|
var X;
|
|
1013
1015
|
const e = f.rule, A = v.accessor.get(M), { worksheet: Z } = v, n = new Y(), m = tA(f.ranges, Z.getMaxRows() - 1, Z.getMaxColumns() - 1);
|
|
@@ -1042,7 +1044,7 @@ const gv = {
|
|
|
1042
1044
|
}), T;
|
|
1043
1045
|
}
|
|
1044
1046
|
}, Ov = {
|
|
1045
|
-
type:
|
|
1047
|
+
type: j.iconSet,
|
|
1046
1048
|
handle: async (f, v) => {
|
|
1047
1049
|
var k;
|
|
1048
1050
|
const e = f.rule, A = v.accessor.get(M), { worksheet: Z } = v, n = new Y(), m = tA(f.ranges, Z.getMaxRows() - 1, Z.getMaxColumns() - 1);
|
|
@@ -1089,8 +1091,8 @@ const gv = {
|
|
|
1089
1091
|
T.setValue(w, L, { iconId: p, iconType: Q, isShowValue: X });
|
|
1090
1092
|
return;
|
|
1091
1093
|
} else {
|
|
1092
|
-
const
|
|
1093
|
-
if (u.operator = sv(
|
|
1094
|
+
const a = N[B - 1];
|
|
1095
|
+
if (u.operator = sv(a.operator), u.value = a.value, AA(r, t) && AA(u, t)) {
|
|
1094
1096
|
T.setValue(w, L, { iconId: p, iconType: Q, isShowValue: X });
|
|
1095
1097
|
return;
|
|
1096
1098
|
}
|
|
@@ -1099,12 +1101,12 @@ const gv = {
|
|
|
1099
1101
|
}), T;
|
|
1100
1102
|
}
|
|
1101
1103
|
};
|
|
1102
|
-
var
|
|
1103
|
-
for (var Z = A > 1 ? void 0 : A ?
|
|
1104
|
+
var hv = Object.defineProperty, jv = Object.getOwnPropertyDescriptor, Uv = (f, v, e, A) => {
|
|
1105
|
+
for (var Z = A > 1 ? void 0 : A ? jv(v, e) : v, n = f.length - 1, m; n >= 0; n--)
|
|
1104
1106
|
(m = f[n]) && (Z = (A ? m(v, e, Z) : m(Z)) || Z);
|
|
1105
|
-
return A && Z &&
|
|
1107
|
+
return A && Z && hv(v, e, Z), Z;
|
|
1106
1108
|
}, I = (f, v) => (e, A) => v(e, A, f);
|
|
1107
|
-
const Rv =
|
|
1109
|
+
const Rv = jA("conditional-formatting-before-update-rule-result");
|
|
1108
1110
|
let G = class extends WA {
|
|
1109
1111
|
constructor(v, e, A, Z, n, m, T) {
|
|
1110
1112
|
super();
|
|
@@ -1124,15 +1126,15 @@ let G = class extends WA {
|
|
|
1124
1126
|
return T > -1 && m.splice(T + 1), m.reduce((S, N) => {
|
|
1125
1127
|
var w;
|
|
1126
1128
|
const X = N.rule.type, k = n.cfList.find((L) => L.cfId === N.cfId);
|
|
1127
|
-
if (k != null && k.isDirty && this._handleCalculateUnit(v, e, N), X ===
|
|
1129
|
+
if (k != null && k.isDirty && this._handleCalculateUnit(v, e, N), X === j.highlightCell)
|
|
1128
1130
|
k.ruleCache && _.deepMerge(S, { style: k.ruleCache });
|
|
1129
|
-
else if (X ===
|
|
1131
|
+
else if (X === j.colorScale) {
|
|
1130
1132
|
const L = k == null ? void 0 : k.ruleCache;
|
|
1131
1133
|
L && (S.style = { ...(w = S.style) != null ? w : {}, bg: { rgb: L } });
|
|
1132
|
-
} else if (X ===
|
|
1134
|
+
} else if (X === j.dataBar) {
|
|
1133
1135
|
const L = k == null ? void 0 : k.ruleCache;
|
|
1134
1136
|
L && L !== K && (S.dataBar = L, S.isShowValue = L.isShowValue);
|
|
1135
|
-
} else if (X ===
|
|
1137
|
+
} else if (X === j.iconSet) {
|
|
1136
1138
|
const L = k == null ? void 0 : k.ruleCache;
|
|
1137
1139
|
L && L !== K && (S.iconSet = L, S.isShowValue = L.isShowValue);
|
|
1138
1140
|
}
|
|
@@ -1159,7 +1161,7 @@ let G = class extends WA {
|
|
|
1159
1161
|
this.disposeWithMe(
|
|
1160
1162
|
this._resourceManagerService.registerPluginResource({
|
|
1161
1163
|
pluginName: oA,
|
|
1162
|
-
businesses: [
|
|
1164
|
+
businesses: [XA.UNIVER_SHEET],
|
|
1163
1165
|
toJson: (A) => v(A),
|
|
1164
1166
|
parseJson: (A) => e(A),
|
|
1165
1167
|
onUnLoad: (A) => {
|
|
@@ -1227,7 +1229,7 @@ let G = class extends WA {
|
|
|
1227
1229
|
_initCacheManager() {
|
|
1228
1230
|
this.disposeWithMe(this._conditionalFormattingViewModel.markDirty$.subscribe((v) => {
|
|
1229
1231
|
this._deleteComputeCache(v.unitId, v.subUnitId, v.rule.cfId);
|
|
1230
|
-
})), this.disposeWithMe(this._conditionalFormattingRuleModel.$ruleChange.pipe(
|
|
1232
|
+
})), this.disposeWithMe(this._conditionalFormattingRuleModel.$ruleChange.pipe(aA((v) => v.type !== "sort")).subscribe((v) => {
|
|
1231
1233
|
this._deleteComputeCache(v.unitId, v.subUnitId, v.rule.cfId);
|
|
1232
1234
|
}));
|
|
1233
1235
|
}
|
|
@@ -1344,16 +1346,16 @@ let G = class extends WA {
|
|
|
1344
1346
|
G = Uv([
|
|
1345
1347
|
UA(RA.Starting, G),
|
|
1346
1348
|
I(0, J(O)),
|
|
1347
|
-
I(1, J(
|
|
1349
|
+
I(1, J(NA)),
|
|
1348
1350
|
I(2, J(eA)),
|
|
1349
1351
|
I(3, J(MA)),
|
|
1350
1352
|
I(4, J(VA)),
|
|
1351
1353
|
I(5, J(zA)),
|
|
1352
1354
|
I(6, J(PA))
|
|
1353
1355
|
], G);
|
|
1354
|
-
const Mv = (f) => f.getCurrentUnitForType(
|
|
1356
|
+
const Mv = (f) => f.getCurrentUnitForType(XA.UNIVER_SHEET).getUnitId(), Vv = (f) => {
|
|
1355
1357
|
var v;
|
|
1356
|
-
return (v = f.getCurrentUnitForType(
|
|
1358
|
+
return (v = f.getCurrentUnitForType(XA.UNIVER_SHEET).getActiveSheet()) == null ? void 0 : v.getSheetId();
|
|
1357
1359
|
}, cA = {
|
|
1358
1360
|
type: vA.MUTATION,
|
|
1359
1361
|
id: "sheet.mutation.set-conditional-rule",
|
|
@@ -1363,7 +1365,7 @@ const Mv = (f) => f.getCurrentUnitForType(NA.UNIVER_SHEET).getUnitId(), Vv = (f)
|
|
|
1363
1365
|
const { unitId: e, subUnitId: A, rule: Z } = v, n = v.cfId || v.rule.cfId;
|
|
1364
1366
|
return f.get(O).setRule(e, A, Z, n), !0;
|
|
1365
1367
|
}
|
|
1366
|
-
},
|
|
1368
|
+
}, se = (f, v) => {
|
|
1367
1369
|
const e = f.get(O), { unitId: A, subUnitId: Z } = v, n = v.cfId || v.rule.cfId, m = e.getRule(A, Z, n);
|
|
1368
1370
|
return m ? [
|
|
1369
1371
|
{
|
|
@@ -1404,15 +1406,15 @@ let QA = (nA = class extends IA {
|
|
|
1404
1406
|
this._commandService.registerCommand(f);
|
|
1405
1407
|
});
|
|
1406
1408
|
}
|
|
1407
|
-
}, D(nA, "pluginName", oA), D(nA, "type",
|
|
1409
|
+
}, D(nA, "pluginName", oA), D(nA, "type", XA.UNIVER_SHEET), nA);
|
|
1408
1410
|
QA = Iv([
|
|
1409
|
-
HA(1, J(
|
|
1411
|
+
HA(1, J(NA)),
|
|
1410
1412
|
HA(2, J(PA))
|
|
1411
1413
|
], QA);
|
|
1412
|
-
const
|
|
1414
|
+
const oe = (f) => {
|
|
1413
1415
|
var e;
|
|
1414
1416
|
return ((e = f.body) == null ? void 0 : e.dataStream.replace(/\r\n$/, "")) || "";
|
|
1415
|
-
},
|
|
1417
|
+
}, ge = (f, v) => v.length === f.length && !f.some((e) => v.some((A) => !R.equals(A, e)));
|
|
1416
1418
|
function zv(f) {
|
|
1417
1419
|
if (typeof f != "object" || f === null)
|
|
1418
1420
|
return f;
|
|
@@ -1444,12 +1446,12 @@ class yv extends sA {
|
|
|
1444
1446
|
if (!l.getColVisible(X) || !l.getRowRawVisible(N))
|
|
1445
1447
|
return;
|
|
1446
1448
|
const { color: w, value: L, startPoint: t, isGradient: B } = k.dataBar, d = this.getCellIndex(N, X, m, T, S);
|
|
1447
|
-
let { isMerged: r, isMergedMainCell: u, mergeInfo: p, startY: Q, endY:
|
|
1448
|
-
if (r || (u && (Q = p.startY,
|
|
1449
|
+
let { isMerged: r, isMergedMainCell: u, mergeInfo: p, startY: Q, endY: a, startX: h, endX: y } = d;
|
|
1450
|
+
if (r || (u && (Q = p.startY, a = p.endY, h = p.startX, y = p.endX), !this.isRenderDiffRangesByCell(p, n)))
|
|
1449
1451
|
return;
|
|
1450
|
-
const ZA = y -
|
|
1452
|
+
const ZA = y - h, kA = a + wv - Q, fA = ZA - this._paddingRightAndLeft * 2, pA = kA - this._paddingTopAndBottom * 2;
|
|
1451
1453
|
if (L > 0) {
|
|
1452
|
-
const x = Math.max(fA * (1 - t / 100) * L / 100, 1), V =
|
|
1454
|
+
const x = Math.max(fA * (1 - t / 100) * L / 100, 1), V = h + this._paddingRightAndLeft + t / 100 * fA, b = Q + this._paddingTopAndBottom;
|
|
1453
1455
|
if (B) {
|
|
1454
1456
|
const F = e.createLinearGradient(V, b, V + x, b);
|
|
1455
1457
|
F.addColorStop(0, w), F.addColorStop(1, "rgb(255 255 255)"), e.fillStyle = F, e.strokeStyle = w, e.lineWidth = 1;
|
|
@@ -1457,7 +1459,7 @@ class yv extends sA {
|
|
|
1457
1459
|
e.fillStyle = w;
|
|
1458
1460
|
this._drawRectWithRoundedCorner(e, V, b, x, pA, !1, !0, !0, !1), B && e.stroke();
|
|
1459
1461
|
} else {
|
|
1460
|
-
const x = Math.max(fA * t / 100 * Math.abs(L) / 100, 1), V =
|
|
1462
|
+
const x = Math.max(fA * t / 100 * Math.abs(L) / 100, 1), V = h + this._paddingRightAndLeft + t / 100 * fA - x, b = Q + this._paddingTopAndBottom;
|
|
1461
1463
|
if (B) {
|
|
1462
1464
|
const F = e.createLinearGradient(V, b, V + x, b);
|
|
1463
1465
|
F.addColorStop(0, "rgb(255 255 255)"), F.addColorStop(1, w), e.fillStyle = F, e.strokeStyle = w, e.lineWidth = 1;
|
|
@@ -1473,7 +1475,7 @@ class yv extends sA {
|
|
|
1473
1475
|
!m || !n || (e.beginPath(), e.moveTo(A + X, Z), e.lineTo(A + n - X, Z), l ? e.arcTo(A + n, Z, A + n, Z + X, X) : e.lineTo(A + n, Z), e.lineTo(A + n, Z + m - X), S ? e.arcTo(A + n, Z + m, A + n - X, Z + m, X) : e.lineTo(A + n, Z + m), e.lineTo(A + X, Z + m), N ? e.arcTo(A, Z + m, A, Z + m - X, X) : e.lineTo(A, Z + m), e.lineTo(A, Z + X), T ? e.arcTo(A, Z, A + X, Z, X) : e.lineTo(A, Z), e.closePath(), e.fill());
|
|
1474
1476
|
}
|
|
1475
1477
|
}
|
|
1476
|
-
|
|
1478
|
+
iA.add(yv);
|
|
1477
1479
|
const xv = {
|
|
1478
1480
|
mistake: "",
|
|
1479
1481
|
warn: "",
|
|
@@ -1671,14 +1673,14 @@ class Le extends sA {
|
|
|
1671
1673
|
if (!t)
|
|
1672
1674
|
return;
|
|
1673
1675
|
const B = this.getCellIndex(N, X, m, T, S);
|
|
1674
|
-
let { isMerged: d, isMergedMainCell: r, mergeInfo: u, startY: p, endY: Q, startX:
|
|
1675
|
-
if (d || (r && (p = u.startY, Q = u.endY,
|
|
1676
|
+
let { isMerged: d, isMergedMainCell: r, mergeInfo: u, startY: p, endY: Q, startX: a, endX: h } = B;
|
|
1677
|
+
if (d || (r && (p = u.startY, Q = u.endY, a = u.startX, h = u.endX), !this.isRenderDiffRangesByCell(u, n)))
|
|
1676
1678
|
return;
|
|
1677
|
-
const y =
|
|
1679
|
+
const y = h - a, ZA = Q - p;
|
|
1678
1680
|
if (this._width > ZA || this._width > y + this._paddingRightAndLeft * 2)
|
|
1679
1681
|
return;
|
|
1680
1682
|
const kA = (ZA - this._width) / 2 + p;
|
|
1681
|
-
e.drawImage(t,
|
|
1683
|
+
e.drawImage(t, a + this._paddingRightAndLeft, kA, this._width, this._width);
|
|
1682
1684
|
}
|
|
1683
1685
|
}), e.restore();
|
|
1684
1686
|
}
|
|
@@ -1695,13 +1697,13 @@ class Le extends sA {
|
|
|
1695
1697
|
return `${e}_${A}`;
|
|
1696
1698
|
}
|
|
1697
1699
|
}
|
|
1698
|
-
|
|
1700
|
+
iA.add(Le);
|
|
1699
1701
|
export {
|
|
1700
1702
|
gA as AddConditionalRuleMutation,
|
|
1701
|
-
|
|
1703
|
+
Je as AddConditionalRuleMutationUndoFactory,
|
|
1702
1704
|
H as CFNumberOperator,
|
|
1703
|
-
|
|
1704
|
-
|
|
1705
|
+
j as CFRuleType,
|
|
1706
|
+
i as CFSubRuleType,
|
|
1705
1707
|
o as CFTextOperator,
|
|
1706
1708
|
g as CFTimePeriodOperator,
|
|
1707
1709
|
z as CFValueType,
|
|
@@ -1711,8 +1713,8 @@ export {
|
|
|
1711
1713
|
O as ConditionalFormattingRuleModel,
|
|
1712
1714
|
G as ConditionalFormattingService,
|
|
1713
1715
|
eA as ConditionalFormattingViewModel,
|
|
1714
|
-
|
|
1715
|
-
|
|
1716
|
+
De as DEFAULT_BG_COLOR,
|
|
1717
|
+
re as DEFAULT_FONT_COLOR,
|
|
1716
1718
|
Xe as DEFAULT_PADDING,
|
|
1717
1719
|
Ne as DEFAULT_WIDTH,
|
|
1718
1720
|
yv as DataBar,
|
|
@@ -1730,28 +1732,28 @@ export {
|
|
|
1730
1732
|
pv as anchorUndoFactory,
|
|
1731
1733
|
AA as compareWithNumber,
|
|
1732
1734
|
Pv as createCfId,
|
|
1733
|
-
|
|
1734
|
-
|
|
1735
|
-
|
|
1735
|
+
He as createDefaultRule,
|
|
1736
|
+
Qe as createDefaultValue,
|
|
1737
|
+
We as createDefaultValueByValueType,
|
|
1736
1738
|
qv as dataBarUKey,
|
|
1737
1739
|
tA as filterRange,
|
|
1738
1740
|
q as findIndexByAnchor,
|
|
1739
|
-
|
|
1741
|
+
ie as getCacheStyleMatrix,
|
|
1740
1742
|
U as getCellValue,
|
|
1741
1743
|
ov as getColorScaleFromValue,
|
|
1742
1744
|
sv as getOppositeOperator,
|
|
1743
|
-
|
|
1745
|
+
oe as getStringFromDataStream,
|
|
1744
1746
|
SA as getValueByType,
|
|
1745
1747
|
me as iconGroup,
|
|
1746
1748
|
lA as iconMap,
|
|
1747
|
-
|
|
1749
|
+
Ee as isAnchorEqual,
|
|
1748
1750
|
TA as isFloatsEqual,
|
|
1749
1751
|
C as isNullable,
|
|
1750
|
-
|
|
1752
|
+
ge as isRangesEqual,
|
|
1751
1753
|
Bv as moveByAnchor,
|
|
1752
1754
|
zv as removeUndefinedAttr,
|
|
1753
|
-
|
|
1754
|
-
|
|
1755
|
-
|
|
1755
|
+
iv as serialTimeToTimestamp,
|
|
1756
|
+
se as setConditionalRuleMutationUndoFactory,
|
|
1757
|
+
av as toYMD_1900,
|
|
1756
1758
|
dv as transformSupportSymmetryAnchor
|
|
1757
1759
|
};
|