@box/metadata-filter 1.81.2 → 1.81.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (54) hide show
  1. package/dist/chunks/advanced-filter-select.js +60 -0
  2. package/dist/chunks/metadata-date-field.module.js +10 -12
  3. package/dist/chunks/metadata-filter.js +47 -0
  4. package/dist/chunks/metadata-float-field-advanced.js +79 -97
  5. package/dist/chunks/metadata-taxonomy-field-advanced.js +92 -0
  6. package/dist/chunks/types.js +6 -9
  7. package/dist/chunks/types2.js +4 -6
  8. package/dist/chunks/use-float-validation.js +21 -28
  9. package/dist/esm/index.js +11 -23
  10. package/dist/esm/lib/components/metadata-filter-fields/components/constants.js +2 -6
  11. package/dist/esm/lib/components/metadata-filter-fields/components/index.js +6 -13
  12. package/dist/esm/lib/components/metadata-filter-fields/components/metadata-date-field/constants.js +2 -4
  13. package/dist/esm/lib/components/metadata-filter-fields/components/metadata-date-field/date-conversion-utils.js +48 -68
  14. package/dist/esm/lib/components/metadata-filter-fields/components/metadata-date-field/metadata-date-field-advanced.js +166 -186
  15. package/dist/esm/lib/components/metadata-filter-fields/components/metadata-date-field/metadata-date-field-relative.js +237 -257
  16. package/dist/esm/lib/components/metadata-filter-fields/components/metadata-date-field/metadata-date-field.js +88 -128
  17. package/dist/esm/lib/components/metadata-filter-fields/components/metadata-date-field/use-date-internationalization.js +10 -12
  18. package/dist/esm/lib/components/metadata-filter-fields/components/metadata-date-field/use-date-validation.js +24 -36
  19. package/dist/esm/lib/components/metadata-filter-fields/components/metadata-date-field/use-integer-validation.js +14 -19
  20. package/dist/esm/lib/components/metadata-filter-fields/components/metadata-date-field/utils.js +8 -11
  21. package/dist/esm/lib/components/metadata-filter-fields/components/metadata-enum-field/metadata-enum-field.js +38 -57
  22. package/dist/esm/lib/components/metadata-filter-fields/components/metadata-float-field/handlers.js +12 -15
  23. package/dist/esm/lib/components/metadata-filter-fields/components/metadata-float-field/metadata-float-field-advanced.js +2 -17
  24. package/dist/esm/lib/components/metadata-filter-fields/components/metadata-float-field/metadata-float-field.js +67 -100
  25. package/dist/esm/lib/components/metadata-filter-fields/components/metadata-float-field/use-float-validation.js +2 -9
  26. package/dist/esm/lib/components/metadata-filter-fields/components/metadata-float-field/utils.js +44 -57
  27. package/dist/esm/lib/components/metadata-filter-fields/components/metadata-multi-select-field/metadata-multi-select-field-advanced.js +71 -91
  28. package/dist/esm/lib/components/metadata-filter-fields/components/metadata-multi-select-field/metadata-multi-select-field.js +35 -65
  29. package/dist/esm/lib/components/metadata-filter-fields/components/metadata-multi-select-field/utils.js +12 -20
  30. package/dist/esm/lib/components/metadata-filter-fields/components/metadata-string-field/metadata-string-field.js +63 -77
  31. package/dist/esm/lib/components/metadata-filter-fields/components/metadata-string-field/utils.js +7 -15
  32. package/dist/esm/lib/components/metadata-filter-fields/components/metadata-taxonomy-field/metadata-taxonomy-field-advanced.js +2 -113
  33. package/dist/esm/lib/components/metadata-filter-fields/components/metadata-taxonomy-field/metadata-taxonomy-field.js +45 -68
  34. package/dist/esm/lib/components/metadata-filter-fields/components/metadata-taxonomy-field/utils.js +8 -15
  35. package/dist/esm/lib/components/metadata-filter-fields/components/shared/advanced-filter-select.js +2 -11
  36. package/dist/esm/lib/components/metadata-filter-fields/components/shared/index.js +2 -4
  37. package/dist/esm/lib/components/metadata-filter-fields/field-processing-utils.js +26 -28
  38. package/dist/esm/lib/components/metadata-filter-fields/filter-field-types.js +26 -55
  39. package/dist/esm/lib/components/metadata-filter-fields/is-modified-utils.js +84 -94
  40. package/dist/esm/lib/components/metadata-filter-fields/metadata-filter-fields-accordion.js +60 -87
  41. package/dist/esm/lib/components/metadata-filter-fields/metadata-filter-fields.js +58 -84
  42. package/dist/esm/lib/components/metadata-template-selector/index.js +0 -1
  43. package/dist/esm/lib/components/metadata-template-selector/metadata-template-selector.js +32 -44
  44. package/dist/esm/lib/defaults.js +31 -40
  45. package/dist/esm/lib/mappers.js +17 -23
  46. package/dist/esm/lib/messages.js +218 -220
  47. package/dist/esm/lib/metadata-filter.js +3 -82
  48. package/dist/styles/advanced-filter-select.css +1 -0
  49. package/dist/styles/metadata-date-field.css +1 -1
  50. package/dist/styles/metadata-filter.css +1 -1
  51. package/dist/styles/metadata-float-field-advanced.css +1 -1
  52. package/package.json +7 -7
  53. package/dist/chunks/index.js +0 -82
  54. package/dist/styles/index.css +0 -1
@@ -1,95 +1,85 @@
1
- import { getIn as g } from "formik";
2
- const f = (t) => typeof t == "object" && t !== null && "range" in t, O = (t) => typeof t == "object" && t !== null && "value" in t && typeof t.value == "string", p = ["string", "enum", "multiSelect", "float", "date", "taxonomy"], A = {
3
- string: "matchExactly",
4
- float: "equals",
5
- enum: "matchAny",
6
- multiSelect: "matchAny",
7
- date: "selectFilterType",
8
- taxonomy: "matchAny"
9
- }, l = (t) => typeof t == "string" && t.trim() !== "", x = (t, r, e) => t !== void 0 ? t !== e : r === void 0 ? !1 : e !== r, u = (t) => {
10
- if (!t || typeof t != "object")
11
- return !1;
12
- const r = t;
13
- return l(r.gt) || l(r.lt);
14
- }, m = (t) => Array.isArray(t) ? t.filter((r) => typeof r == "string" && r !== "").length > 0 : !1, o = (t) => {
15
- if (!(!t || t === ""))
16
- return t;
17
- }, a = (t) => {
18
- if (t && typeof t == "object")
19
- return o(t.advancedFilterOption);
20
- }, h = (t) => {
21
- const r = t.enum?.[0];
22
- return a(r);
23
- }, y = (t) => {
24
- const r = t.enum;
25
- if (r && typeof r == "object" && !Array.isArray(r))
26
- return a(r);
27
- const e = Array.isArray(r) ? r[0] : void 0;
28
- return a(e);
29
- }, V = (t) => {
30
- const r = t.enum?.[0];
31
- return a(r);
32
- }, j = (t) => o(t.advancedFilterOption), S = (t) => o(t.advancedFilterOption), b = {
33
- string: h,
34
- enum: y,
35
- multiSelect: y,
36
- float: V,
37
- date: j,
38
- taxonomy: S
39
- }, E = (t, r, e) => {
40
- if (!e || !p.includes(t))
41
- return;
42
- const n = b[t];
43
- return n ? n(r) : void 0;
44
- }, M = (t, r) => {
45
- if (!r)
46
- return !1;
47
- const e = t.enum?.[0];
48
- return e && typeof e == "object" && O(e) ? l(e.value) : typeof e == "string" && e !== "";
49
- }, F = (t, r) => {
50
- if (!r)
51
- return !1;
52
- const e = t.enum;
53
- return Array.isArray(e) ? m(e) : e && typeof e == "object" ? m(e.value) : !1;
54
- }, C = (t, r) => {
55
- if (r) {
56
- const e = t.enum?.[0];
57
- if (e && typeof e == "object") {
58
- if ("value" in e && f(e.value))
59
- return u(e.value.range);
60
- if (f(e))
61
- return u(e.range);
62
- }
63
- }
64
- return u(t.range);
65
- }, D = () => !1, I = (t, r) => {
66
- if (Array.isArray(t))
67
- return t.length > 0;
68
- if (r) {
69
- const e = t.value;
70
- return Array.isArray(e) && e.length > 0;
71
- }
72
- return !1;
73
- }, k = {
74
- string: M,
75
- enum: F,
76
- multiSelect: F,
77
- float: C,
78
- date: D,
79
- taxonomy: I
80
- }, L = (t, r) => g(t, `metadata.fields[${r}].value`), N = (t) => t.advancedFilterOptionToExecute || A[t.type], R = (t, r, e, n) => {
81
- const i = r || {}, s = E(t, i, e), c = o(n), v = o(A[t]);
82
- if ((e || t === "date") && x(s, c, v))
83
- return !0;
84
- if (!p.includes(t))
85
- return !1;
86
- const d = k[t];
87
- return d ? d(i, e) : !1;
88
- }, _ = (t, r, e) => !t || !Array.isArray(t) ? !1 : t.some((n, i) => {
89
- const s = L(r, i), c = N(n);
90
- return R(n.type, s, e, c);
1
+ import { getIn as e } from "formik";
2
+ var t = (e) => typeof e == "object" && !!e && "range" in e, n = (e) => typeof e == "object" && !!e && "value" in e && typeof e.value == "string", r = [
3
+ "string",
4
+ "enum",
5
+ "multiSelect",
6
+ "float",
7
+ "date",
8
+ "taxonomy"
9
+ ], i = {
10
+ string: "matchExactly",
11
+ float: "equals",
12
+ enum: "matchAny",
13
+ multiSelect: "matchAny",
14
+ date: "selectFilterType",
15
+ taxonomy: "matchAny"
16
+ }, a = (e) => typeof e == "string" && e.trim() !== "", o = (e, t, n) => e === void 0 ? t === void 0 ? !1 : n !== t : e !== n, s = (e) => {
17
+ if (!e || typeof e != "object") return !1;
18
+ let t = e;
19
+ return a(t.gt) || a(t.lt);
20
+ }, c = (e) => Array.isArray(e) ? e.filter((e) => typeof e == "string" && e !== "").length > 0 : !1, l = (e) => {
21
+ if (!(!e || e === "")) return e;
22
+ }, u = (e) => {
23
+ if (e && typeof e == "object") return l(e.advancedFilterOption);
24
+ }, d = (e) => {
25
+ let t = e.enum?.[0];
26
+ return u(t);
27
+ }, f = (e) => {
28
+ let t = e.enum;
29
+ return u(t && typeof t == "object" && !Array.isArray(t) ? t : Array.isArray(t) ? t[0] : void 0);
30
+ }, p = {
31
+ string: d,
32
+ enum: f,
33
+ multiSelect: f,
34
+ float: (e) => {
35
+ let t = e.enum?.[0];
36
+ return u(t);
37
+ },
38
+ date: (e) => l(e.advancedFilterOption),
39
+ taxonomy: (e) => l(e.advancedFilterOption)
40
+ }, m = (e, t, n) => {
41
+ if (!n || !r.includes(e)) return;
42
+ let i = p[e];
43
+ return i ? i(t) : void 0;
44
+ }, h = (e, t) => {
45
+ if (!t) return !1;
46
+ let r = e.enum?.[0];
47
+ return r && typeof r == "object" && n(r) ? a(r.value) : typeof r == "string" && r !== "";
48
+ }, g = (e, t) => {
49
+ if (!t) return !1;
50
+ let n = e.enum;
51
+ return Array.isArray(n) ? c(n) : n && typeof n == "object" ? c(n.value) : !1;
52
+ }, _ = {
53
+ string: h,
54
+ enum: g,
55
+ multiSelect: g,
56
+ float: (e, n) => {
57
+ if (n) {
58
+ let n = e.enum?.[0];
59
+ if (n && typeof n == "object") {
60
+ if ("value" in n && t(n.value)) return s(n.value.range);
61
+ if (t(n)) return s(n.range);
62
+ }
63
+ }
64
+ return s(e.range);
65
+ },
66
+ date: () => !1,
67
+ taxonomy: (e, t) => {
68
+ if (Array.isArray(e)) return e.length > 0;
69
+ if (t) {
70
+ let t = e.value;
71
+ return Array.isArray(t) && t.length > 0;
72
+ }
73
+ return !1;
74
+ }
75
+ }, v = (t, n) => e(t, `metadata.fields[${n}].value`), y = (e) => e.advancedFilterOptionToExecute || i[e.type], b = (e, t, n, a) => {
76
+ let s = t || {}, c = m(e, s, n), u = l(a), d = l(i[e]);
77
+ if ((n || e === "date") && o(c, u, d)) return !0;
78
+ if (!r.includes(e)) return !1;
79
+ let f = _[e];
80
+ return f ? f(s, n) : !1;
81
+ }, x = (e, t, n) => !e || !Array.isArray(e) ? !1 : e.some((e, r) => {
82
+ let i = v(t, r), a = y(e);
83
+ return b(e.type, i, n, a);
91
84
  });
92
- export {
93
- _ as isAnyFieldModified,
94
- R as isFieldModifiedFromValue
95
- };
85
+ export { x as isAnyFieldModified, b as isFieldModifiedFromValue };
@@ -1,88 +1,61 @@
1
- import { Accordion as c, Text as p } from "@box/blueprint-web";
2
- import { useFormikContext as T, getIn as f, FieldArray as b } from "formik";
3
- import { useMemo as j } from "react";
4
- import { useIntl as S, FormattedMessage as w } from "react-intl";
5
- import u from "../../messages.js";
6
- import { processMetadataField as P } from "./field-processing-utils.js";
7
- import { isFieldModifiedFromValue as q } from "./is-modified-utils.js";
8
- import { s as z } from "../../../../chunks/index.js";
9
- import { jsx as t, jsxs as B } from "react/jsx-runtime";
10
- const X = ({
11
- disableForm: y,
12
- locale: F,
13
- portalElement: h,
14
- taxonomyOptionsFetcher: g,
15
- canUseRelativeDates: M,
16
- isAdvancedFilterEnabled: i,
17
- isModifiedMarkerEnabled: r,
18
- onAdvancedFilterOptionChange: v,
19
- fieldAdvancedFilterOptions: s,
20
- isMultilevelTaxonomyFieldEnabled: x,
21
- filterOptionsMap: A,
22
- hasAccordion: O,
23
- isAdvancedTaxonomy: $
24
- }) => {
25
- const {
26
- values: n
27
- } = T(), l = S(), m = "metadata.fields", o = f(n, m), k = j(() => o.map((e, a) => `field-${e.key}-${a}`), [o]);
28
- return o.length ? /* @__PURE__ */ t(b, {
29
- name: m,
30
- validateOnChange: !1,
31
- children: () => /* @__PURE__ */ t(c, {
32
- defaultValue: k,
33
- type: "multiple",
34
- children: o.map((e, a) => {
35
- const {
36
- MetadataFilterField: N,
37
- showField: V,
38
- getFilterOptionsForField: L
39
- } = P({
40
- field: e,
41
- isAdvancedFilterEnabled: i,
42
- isAdvancedTaxonomy: $,
43
- intl: l,
44
- filterOptionsMap: A
45
- }), C = f(n, `metadata.fields[${a}].value`), I = s?.[e.key], d = q(e.type, C, i, I);
46
- return V && /* @__PURE__ */ t(c.Item, {
47
- iconAriaLabel: d && r ? l.formatMessage(u.filterModifiedAriaLabel) : void 0,
48
- iconVariant: d && r ? "status-modified" : void 0,
49
- title: e.displayName,
50
- value: `field-${e.key}-${a}`,
51
- children: /* @__PURE__ */ B("div", {
52
- children: [/* @__PURE__ */ t(N, {
53
- canUseRelativeDates: M,
54
- disableForm: y,
55
- fieldAdvancedFilterOptions: s?.[e.key],
56
- fieldNamePrefix: `metadata.fields[${a}]`,
57
- filterOptionsMap: L(),
58
- hasAccordion: O,
59
- isAdvancedFilterEnabled: i,
60
- isMultilevelTaxonomyFieldEnabled: x,
61
- label: e.displayName,
62
- locale: F,
63
- onAdvancedFilterOptionChange: v,
64
- portalElement: h,
65
- taxonomyOptionsFetcher: g
66
- }), !!e.description && /* @__PURE__ */ t(p, {
67
- as: "span",
68
- color: "textOnLightSecondary",
69
- variant: "caption",
70
- children: e.description
71
- })]
72
- })
73
- }, e.key);
74
- })
75
- })
76
- }) : /* @__PURE__ */ t(p, {
77
- as: "span",
78
- className: z.noAttributesText,
79
- color: "textOnLightSecondary",
80
- children: /* @__PURE__ */ t(w, {
81
- ...u.noTemplateAtributesError
82
- })
83
- });
84
- };
85
- export {
86
- X as MetadataFilterFieldsAccordion,
87
- X as default
1
+ import e from "../../messages.js";
2
+ import { n as t } from "../../../../chunks/advanced-filter-select.js";
3
+ import { processMetadataField as n } from "./field-processing-utils.js";
4
+ import { isFieldModifiedFromValue as r } from "./is-modified-utils.js";
5
+ import { Accordion as i, Text as a } from "@box/blueprint-web";
6
+ import { FieldArray as o, getIn as s, useFormikContext as c } from "formik";
7
+ import { useMemo as l } from "react";
8
+ import { FormattedMessage as u, useIntl as d } from "react-intl";
9
+ import { jsx as f, jsxs as p } from "react/jsx-runtime";
10
+ var m = ({ disableForm: m, locale: h, portalElement: g, taxonomyOptionsFetcher: _, canUseRelativeDates: v, isAdvancedFilterEnabled: y, isModifiedMarkerEnabled: b, onAdvancedFilterOptionChange: x, fieldAdvancedFilterOptions: S, isMultilevelTaxonomyFieldEnabled: C, filterOptionsMap: w, hasAccordion: T, isAdvancedTaxonomy: E }) => {
11
+ let { values: D } = c(), O = d(), k = "metadata.fields", A = s(D, k), j = l(() => A.map((e, t) => `field-${e.key}-${t}`), [A]);
12
+ return A.length ? /* @__PURE__ */ f(o, {
13
+ name: k,
14
+ validateOnChange: !1,
15
+ children: () => /* @__PURE__ */ f(i, {
16
+ defaultValue: j,
17
+ type: "multiple",
18
+ children: A.map((t, o) => {
19
+ let { MetadataFilterField: c, showField: l, getFilterOptionsForField: u } = n({
20
+ field: t,
21
+ isAdvancedFilterEnabled: y,
22
+ isAdvancedTaxonomy: E,
23
+ intl: O,
24
+ filterOptionsMap: w
25
+ }), d = s(D, `metadata.fields[${o}].value`), k = S?.[t.key], A = r(t.type, d, y, k);
26
+ return l && /* @__PURE__ */ f(i.Item, {
27
+ iconAriaLabel: A && b ? O.formatMessage(e.filterModifiedAriaLabel) : void 0,
28
+ iconVariant: A && b ? "status-modified" : void 0,
29
+ title: t.displayName,
30
+ value: `field-${t.key}-${o}`,
31
+ children: /* @__PURE__ */ p("div", { children: [/* @__PURE__ */ f(c, {
32
+ canUseRelativeDates: v,
33
+ disableForm: m,
34
+ fieldAdvancedFilterOptions: S?.[t.key],
35
+ fieldNamePrefix: `metadata.fields[${o}]`,
36
+ filterOptionsMap: u(),
37
+ hasAccordion: T,
38
+ isAdvancedFilterEnabled: y,
39
+ isMultilevelTaxonomyFieldEnabled: C,
40
+ label: t.displayName,
41
+ locale: h,
42
+ onAdvancedFilterOptionChange: x,
43
+ portalElement: g,
44
+ taxonomyOptionsFetcher: _
45
+ }), !!t.description && /* @__PURE__ */ f(a, {
46
+ as: "span",
47
+ color: "textOnLightSecondary",
48
+ variant: "caption",
49
+ children: t.description
50
+ })] })
51
+ }, t.key);
52
+ })
53
+ })
54
+ }) : /* @__PURE__ */ f(a, {
55
+ as: "span",
56
+ className: t.noAttributesText,
57
+ color: "textOnLightSecondary",
58
+ children: /* @__PURE__ */ f(u, { ...e.noTemplateAtributesError })
59
+ });
88
60
  };
61
+ export { m as MetadataFilterFieldsAccordion, m as default };
@@ -1,85 +1,59 @@
1
- import { Text as m } from "@box/blueprint-web";
2
- import { useFormikContext as L, getIn as l, FieldArray as S } from "formik";
3
- import { useEffect as V } from "react";
4
- import { useIntl as $, FormattedMessage as w } from "react-intl";
5
- import C from "../../messages.js";
6
- import { processMetadataField as P } from "./field-processing-utils.js";
7
- import { isAnyFieldModified as q, isFieldModifiedFromValue as z } from "./is-modified-utils.js";
8
- import { s as B } from "../../../../chunks/index.js";
9
- import { jsx as i, jsxs as G } from "react/jsx-runtime";
10
- const Z = ({
11
- disableForm: d,
12
- locale: p,
13
- portalElement: c,
14
- taxonomyOptionsFetcher: f,
15
- canUseRelativeDates: u,
16
- isAdvancedFilterEnabled: e,
17
- isModifiedMarkerEnabled: F,
18
- onAdvancedFilterOptionChange: x,
19
- fieldAdvancedFilterOptions: M,
20
- isMultilevelTaxonomyFieldEnabled: y,
21
- filterOptionsMap: O,
22
- onDirtyChange: a,
23
- isAdvancedTaxonomy: h,
24
- hasExperimentalVirtualization: g
25
- }) => {
26
- const {
27
- values: o
28
- } = L(), v = $(), r = "metadata.fields", s = l(o, r);
29
- return V(() => {
30
- if (a) {
31
- const t = q(s, o, e);
32
- a(t);
33
- }
34
- }, [o, e, a, s]), s.length ? /* @__PURE__ */ i(S, {
35
- name: r,
36
- validateOnChange: !1,
37
- children: () => s.map((t, n) => {
38
- const {
39
- MetadataFilterField: N,
40
- showField: T,
41
- getFilterOptionsForField: k
42
- } = P({
43
- field: t,
44
- isAdvancedFilterEnabled: e,
45
- isAdvancedTaxonomy: h,
46
- intl: v,
47
- filterOptionsMap: O
48
- }), j = l(o, `metadata.fields[${n}].value`), A = t.advancedFilterOptionToExecute, I = z(t.type, j, e, A);
49
- return T && /* @__PURE__ */ G("div", {
50
- children: [/* @__PURE__ */ i(N, {
51
- canUseRelativeDates: u,
52
- disableForm: d,
53
- fieldAdvancedFilterOptions: M?.[t.key],
54
- fieldNamePrefix: `metadata.fields[${n}]`,
55
- filterOptionsMap: k(),
56
- isAdvancedFilterEnabled: e,
57
- isModified: I && F,
58
- isMultilevelTaxonomyFieldEnabled: y,
59
- label: t.displayName,
60
- locale: p,
61
- onAdvancedFilterOptionChange: x,
62
- portalElement: c,
63
- taxonomyOptionsFetcher: f,
64
- hasExperimentalVirtualization: g
65
- }), !!t.description && /* @__PURE__ */ i(m, {
66
- as: "span",
67
- color: "textOnLightSecondary",
68
- variant: "caption",
69
- children: t.description
70
- })]
71
- }, t.key);
72
- })
73
- }) : /* @__PURE__ */ i(m, {
74
- as: "span",
75
- className: B.noAttributesText,
76
- color: "textOnLightSecondary",
77
- children: /* @__PURE__ */ i(w, {
78
- ...C.noTemplateAtributesError
79
- })
80
- });
81
- };
82
- export {
83
- Z as MetadataFilterFields,
84
- Z as default
1
+ import e from "../../messages.js";
2
+ import { n as t } from "../../../../chunks/advanced-filter-select.js";
3
+ import { processMetadataField as n } from "./field-processing-utils.js";
4
+ import { isAnyFieldModified as r, isFieldModifiedFromValue as i } from "./is-modified-utils.js";
5
+ import { Text as a } from "@box/blueprint-web";
6
+ import { FieldArray as o, getIn as s, useFormikContext as c } from "formik";
7
+ import { useEffect as l } from "react";
8
+ import { FormattedMessage as u, useIntl as d } from "react-intl";
9
+ import { jsx as f, jsxs as p } from "react/jsx-runtime";
10
+ var m = ({ disableForm: m, locale: h, portalElement: g, taxonomyOptionsFetcher: _, canUseRelativeDates: v, isAdvancedFilterEnabled: y, isModifiedMarkerEnabled: b, onAdvancedFilterOptionChange: x, fieldAdvancedFilterOptions: S, isMultilevelTaxonomyFieldEnabled: C, filterOptionsMap: w, onDirtyChange: T, isAdvancedTaxonomy: E, hasExperimentalVirtualization: D }) => {
11
+ let { values: O } = c(), k = d(), A = "metadata.fields", j = s(O, A);
12
+ return l(() => {
13
+ T && T(r(j, O, y));
14
+ }, [
15
+ O,
16
+ y,
17
+ T,
18
+ j
19
+ ]), j.length ? /* @__PURE__ */ f(o, {
20
+ name: A,
21
+ validateOnChange: !1,
22
+ children: () => j.map((e, t) => {
23
+ let { MetadataFilterField: r, showField: o, getFilterOptionsForField: c } = n({
24
+ field: e,
25
+ isAdvancedFilterEnabled: y,
26
+ isAdvancedTaxonomy: E,
27
+ intl: k,
28
+ filterOptionsMap: w
29
+ }), l = s(O, `metadata.fields[${t}].value`), u = e.advancedFilterOptionToExecute, d = i(e.type, l, y, u);
30
+ return o && /* @__PURE__ */ p("div", { children: [/* @__PURE__ */ f(r, {
31
+ canUseRelativeDates: v,
32
+ disableForm: m,
33
+ fieldAdvancedFilterOptions: S?.[e.key],
34
+ fieldNamePrefix: `metadata.fields[${t}]`,
35
+ filterOptionsMap: c(),
36
+ isAdvancedFilterEnabled: y,
37
+ isModified: d && b,
38
+ isMultilevelTaxonomyFieldEnabled: C,
39
+ label: e.displayName,
40
+ locale: h,
41
+ onAdvancedFilterOptionChange: x,
42
+ portalElement: g,
43
+ taxonomyOptionsFetcher: _,
44
+ hasExperimentalVirtualization: D
45
+ }), !!e.description && /* @__PURE__ */ f(a, {
46
+ as: "span",
47
+ color: "textOnLightSecondary",
48
+ variant: "caption",
49
+ children: e.description
50
+ })] }, e.key);
51
+ })
52
+ }) : /* @__PURE__ */ f(a, {
53
+ as: "span",
54
+ className: t.noAttributesText,
55
+ color: "textOnLightSecondary",
56
+ children: /* @__PURE__ */ f(u, { ...e.noTemplateAtributesError })
57
+ });
85
58
  };
59
+ export { m as MetadataFilterFields, m as default };
@@ -1,45 +1,33 @@
1
- import { Select as r, SELECT_EMPTY_VALUE as f } from "@box/blueprint-web";
2
- import { useFormikContext as u, Field as h } from "formik";
3
- import { useMemo as x } from "react";
4
- import { useIntl as E } from "react-intl";
5
- import m from "../../messages.js";
6
- import { jsx as o, jsxs as M } from "react/jsx-runtime";
7
- const T = ({
8
- hasError: a,
9
- metadataTemplateOptions: l,
10
- portalElement: c
11
- }) => {
12
- const n = "metadata.id", {
13
- setFieldValue: d
14
- } = u(), s = E(), t = s.formatMessage(m.selectTemplate), p = x(() => l.filter((i) => !i.hidden), [l]);
15
- return /* @__PURE__ */ o(h, {
16
- name: n,
17
- children: ({
18
- field: i,
19
- meta: g
20
- }) => /* @__PURE__ */ o(r, {
21
- error: a ? s.formatMessage(m.selectTemplateError) : void 0,
22
- hideLabel: !0,
23
- label: t,
24
- onValueChange: (e) => d(n, e),
25
- placeholder: t,
26
- ...i,
27
- children: /* @__PURE__ */ M(r.Content, {
28
- container: c,
29
- children: [/* @__PURE__ */ o(r.Option, {
30
- text: t,
31
- value: f,
32
- children: t
33
- }, t), p.map((e) => /* @__PURE__ */ o(r.Option, {
34
- text: e.displayName,
35
- value: e.id,
36
- children: e.displayName
37
- }, e.id))]
38
- })
39
- })
40
- });
41
- };
42
- export {
43
- T as MetadataTemplateSelector,
44
- T as default
1
+ import e from "../../messages.js";
2
+ import { SELECT_EMPTY_VALUE as t, Select as n } from "@box/blueprint-web";
3
+ import { Field as r, useFormikContext as i } from "formik";
4
+ import { useMemo as a } from "react";
5
+ import { useIntl as o } from "react-intl";
6
+ import { jsx as s, jsxs as c } from "react/jsx-runtime";
7
+ var l = ({ hasError: l, metadataTemplateOptions: u, portalElement: d }) => {
8
+ let f = "metadata.id", { setFieldValue: p } = i(), m = o(), h = m.formatMessage(e.selectTemplate), g = a(() => u.filter((e) => !e.hidden), [u]);
9
+ return /* @__PURE__ */ s(r, {
10
+ name: f,
11
+ children: ({ field: r, meta: i }) => /* @__PURE__ */ s(n, {
12
+ error: l ? m.formatMessage(e.selectTemplateError) : void 0,
13
+ hideLabel: !0,
14
+ label: h,
15
+ onValueChange: (e) => p(f, e),
16
+ placeholder: h,
17
+ ...r,
18
+ children: /* @__PURE__ */ c(n.Content, {
19
+ container: d,
20
+ children: [/* @__PURE__ */ s(n.Option, {
21
+ text: h,
22
+ value: t,
23
+ children: h
24
+ }, h), g.map((e) => /* @__PURE__ */ s(n.Option, {
25
+ text: e.displayName,
26
+ value: e.id,
27
+ children: e.displayName
28
+ }, e.id))]
29
+ })
30
+ })
31
+ });
45
32
  };
33
+ export { l as MetadataTemplateSelector, l as default };
@@ -1,41 +1,32 @@
1
- import { SELECT_EMPTY_VALUE as e } from "@box/blueprint-web";
2
- import { F as t } from "../../chunks/types.js";
3
- const l = {
4
- scope: "",
5
- templateKey: "",
6
- type: "",
7
- id: e,
8
- hidden: !1,
9
- fields: []
10
- }, o = {
11
- string: {
12
- enum: [""]
13
- },
14
- enum: {
15
- enum: [""]
16
- },
17
- multiSelect: {
18
- enum: []
19
- },
20
- float: {
21
- range: {
22
- gt: "",
23
- lt: ""
24
- },
25
- advancedFilterOption: t.EQUALS
26
- },
27
- date: {
28
- range: {
29
- gt: "",
30
- lt: ""
31
- },
32
- relativeDays: void 0,
33
- relativeType: void 0,
34
- customType: "anyTime",
35
- customDays: void 0
36
- }
37
- };
38
- export {
39
- l as defaultInitialValues,
40
- o as defaultMetadataValueMap
1
+ import { t as e } from "../../chunks/types.js";
2
+ import { SELECT_EMPTY_VALUE as t } from "@box/blueprint-web";
3
+ var n = {
4
+ scope: "",
5
+ templateKey: "",
6
+ type: "",
7
+ id: t,
8
+ hidden: !1,
9
+ fields: []
10
+ }, r = {
11
+ string: { enum: [""] },
12
+ enum: { enum: [""] },
13
+ multiSelect: { enum: [] },
14
+ float: {
15
+ range: {
16
+ gt: "",
17
+ lt: ""
18
+ },
19
+ advancedFilterOption: e.EQUALS
20
+ },
21
+ date: {
22
+ range: {
23
+ gt: "",
24
+ lt: ""
25
+ },
26
+ relativeDays: void 0,
27
+ relativeType: void 0,
28
+ customType: "anyTime",
29
+ customDays: void 0
30
+ }
41
31
  };
32
+ export { n as defaultInitialValues, r as defaultMetadataValueMap };