@uniformdev/design-system 19.121.0 → 19.121.1-alpha.3

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/dist/esm/index.js CHANGED
@@ -1255,7 +1255,7 @@ function IconsProvider({ children }) {
1255
1255
  const [isLoading, setIsLoading] = useState2(true);
1256
1256
  const [iconsMap, setIconsMap] = useState2({});
1257
1257
  const initializeIconsMap = async () => {
1258
- const { importedIcons } = await import("./importedIcons-GRLD5JXK.js");
1258
+ const { importedIcons } = await import("./importedIcons-XEGXOSVC.js");
1259
1259
  setIconsMap({ ...importedIcons, ...customIcons });
1260
1260
  setIsLoading(false);
1261
1261
  };
@@ -2557,7 +2557,7 @@ import { css as css15 } from "@emotion/react";
2557
2557
  var PageHeaderSectionContainer = css15`
2558
2558
  display: flex;
2559
2559
  justify-content: space-between;
2560
- margin-bottom: var(--spacing-lg);
2560
+ margin-bottom: var(--spacing-sm);
2561
2561
  flex-direction: column;
2562
2562
  gap: var(--spacing-sm);
2563
2563
 
@@ -13845,7 +13845,8 @@ function InputComboBox(props) {
13845
13845
  background: "var(--gray-100)",
13846
13846
  "&:hover": {
13847
13847
  borderColor: "var(--gray-300)"
13848
- }
13848
+ },
13849
+ ...state.isFocused ? { borderColor: "var(--gray-300)" } : {}
13849
13850
  },
13850
13851
  ...(_b = (_a2 = props.styles) == null ? void 0 : _a2.control) == null ? void 0 : _b.call(_a2, base, state)
13851
13852
  };
@@ -17561,6 +17562,16 @@ var toggleInput2 = css79`
17561
17562
  color: var(--white);
17562
17563
  }
17563
17564
 
17565
+ &:indeterminate,
17566
+ &:indeterminate:hover,
17567
+ &:indeterminate:focus {
17568
+ background: var(--accent-dark-active)
17569
+ url('')
17570
+ no-repeat center center;
17571
+ border-color: var(--accent-dark-active);
17572
+ color: var(--white);
17573
+ }
17574
+
17564
17575
  &:hover {
17565
17576
  border-color: var(--accent-dark-hover);
17566
17577
  }
@@ -20272,6 +20283,60 @@ var TEXTBOX_OPERATORS = [
20272
20283
  editorType: "empty"
20273
20284
  }
20274
20285
  ];
20286
+ var USER_OPERATORS = [
20287
+ {
20288
+ label: "is...",
20289
+ value: "eq",
20290
+ editorType: "text"
20291
+ },
20292
+ {
20293
+ label: "contains...",
20294
+ value: "match",
20295
+ editorType: "text"
20296
+ },
20297
+ {
20298
+ label: "is not...",
20299
+ value: "neq",
20300
+ editorType: "text"
20301
+ }
20302
+ ];
20303
+ var SYSTEM_DATE_OPERATORS = [
20304
+ {
20305
+ label: "is...",
20306
+ value: "eq",
20307
+ editorType: "date"
20308
+ },
20309
+ {
20310
+ label: "is between...",
20311
+ value: "between",
20312
+ editorType: "dateRange"
20313
+ },
20314
+ {
20315
+ label: "is before...",
20316
+ value: "lt",
20317
+ editorType: "date"
20318
+ },
20319
+ {
20320
+ label: "is after...",
20321
+ value: "gt",
20322
+ editorType: "date"
20323
+ },
20324
+ {
20325
+ label: "is on or before...",
20326
+ value: "lte",
20327
+ editorType: "date"
20328
+ },
20329
+ {
20330
+ label: "is on or after...",
20331
+ value: "gte",
20332
+ editorType: "date"
20333
+ },
20334
+ {
20335
+ label: "is not...",
20336
+ value: "neq",
20337
+ editorType: "date"
20338
+ }
20339
+ ];
20275
20340
  var RICHTEXT_OPERATORS = [
20276
20341
  {
20277
20342
  label: "is empty...",
@@ -20413,6 +20478,12 @@ var FilterButton = css92`
20413
20478
  opacity: var(--opacity-50);
20414
20479
  }
20415
20480
  `;
20481
+ var FilterButtonText = css92`
20482
+ overflow: hidden;
20483
+ text-overflow: ellipsis;
20484
+ white-space: nowrap;
20485
+ max-width: 14ch;
20486
+ `;
20416
20487
  var FilterButtonSelected = css92`
20417
20488
  background: var(--gray-100);
20418
20489
  border-color: var(--gray-300);
@@ -20449,7 +20520,6 @@ var AddConditionalBtn = css92`
20449
20520
  gap: var(--spacing-sm);
20450
20521
  transition: color var(--duration-fast) var(--timing-ease-out);
20451
20522
  padding: 0;
20452
- font-size: var(--fs-sm);
20453
20523
 
20454
20524
  &:hover,
20455
20525
  &:focus {
@@ -20504,7 +20574,7 @@ var SearchAndFilterOptionsContainer = css92`
20504
20574
  padding: var(--spacing-md) var(--spacing-md) var(--spacing-base);
20505
20575
  will-change: height;
20506
20576
  position: relative;
20507
- z-index: 2;
20577
+ z-index: 1;
20508
20578
  `;
20509
20579
  var SearchAndFilterOptionsInnerContainer = css92`
20510
20580
  display: flex;
@@ -20514,6 +20584,11 @@ var SearchAndFilterOptionsInnerContainer = css92`
20514
20584
  var SearchAndFilterButtonGroup = css92`
20515
20585
  margin-top: var(--spacing-base);
20516
20586
  `;
20587
+ var SortFilterInputRow = css92`
20588
+ align-items: center;
20589
+ display: flex;
20590
+ gap: var(--spacing-sm);
20591
+ `;
20517
20592
 
20518
20593
  // src/components/SearchAndFilter/FilterButton.tsx
20519
20594
  import { jsx as jsx117, jsxs as jsxs79 } from "@emotion/react/jsx-runtime";
@@ -20537,7 +20612,7 @@ var FilterButton2 = ({
20537
20612
  "data-testid": "filters-button",
20538
20613
  children: [
20539
20614
  /* @__PURE__ */ jsx117(Icon, { icon, iconColor: "currentColor", size: "1rem" }),
20540
- text,
20615
+ /* @__PURE__ */ jsx117("span", { css: FilterButtonText, children: text }),
20541
20616
  filterCount ? /* @__PURE__ */ jsx117(Counter, { count: filterCount, bgColor: "var(--white)" }) : null
20542
20617
  ]
20543
20618
  }
@@ -20546,7 +20621,7 @@ var FilterButton2 = ({
20546
20621
 
20547
20622
  // src/components/SearchAndFilter/FilterControls.tsx
20548
20623
  import { useEffect as useEffect18, useState as useState17 } from "react";
20549
- import { useDebounce as useDebounce2 } from "react-use";
20624
+ import { useDebounce as useDebounce2, useEffectOnce } from "react-use";
20550
20625
 
20551
20626
  // src/components/SearchAndFilter/hooks/useSearchAndFilter.tsx
20552
20627
  import {
@@ -20682,10 +20757,22 @@ var useSearchAndFilter = () => {
20682
20757
  import { Fragment as Fragment19, jsx as jsx119, jsxs as jsxs80 } from "@emotion/react/jsx-runtime";
20683
20758
  var FilterControls = ({
20684
20759
  children,
20760
+ defaultSortByValue,
20685
20761
  hideSearchInput
20686
20762
  }) => {
20687
- const { setFilterVisibility, filterVisibility, setSearchTerm, validFilterQuery, searchTerm, sortByValue } = useSearchAndFilter();
20763
+ var _a, _b, _c;
20764
+ const {
20765
+ setFilterVisibility,
20766
+ filterVisibility,
20767
+ setSearchTerm,
20768
+ validFilterQuery,
20769
+ searchTerm,
20770
+ sortByValue,
20771
+ filterOptions
20772
+ } = useSearchAndFilter();
20773
+ const [initialSortValue, setInitialSortValue] = useState17(sortByValue);
20688
20774
  const [localeSearchTerm, setLocaleSearchTerm] = useState17("");
20775
+ const [userHasChangedSortByValue, setUserHasChangedSortByValue] = useState17(false);
20689
20776
  useDebounce2(
20690
20777
  () => {
20691
20778
  setSearchTerm(localeSearchTerm);
@@ -20699,14 +20786,25 @@ var FilterControls = ({
20699
20786
  }
20700
20787
  }, [searchTerm]);
20701
20788
  const handleFilterToggle = (mode) => {
20702
- if (filterVisibility && ["sort", "filters"].includes(filterVisibility)) {
20789
+ if (filterVisibility === "filters" && mode === "filters" || filterVisibility === "sort" && mode === "sort") {
20703
20790
  return setFilterVisibility(void 0);
20704
20791
  }
20705
20792
  return setFilterVisibility(mode);
20706
20793
  };
20707
- const sortByValues = sortByValue ? sortByValue == null ? void 0 : sortByValue.split("_") : "Sort";
20708
- const sortByValueLabel = Array.isArray(sortByValues) ? sortByValue == null ? void 0 : sortByValue.split("_")[0] : "Sort";
20709
- const sortByIcon = Array.isArray(sortByValues) ? sortByValues[1] === "ASC" ? "arrow-up" : "arrow-down" : "sort-az";
20794
+ const sortValue = (sortByValue != null ? sortByValue : defaultSortByValue).split("_");
20795
+ const sortDirection = sortValue == null ? void 0 : sortValue.pop();
20796
+ const sortField = sortValue == null ? void 0 : sortValue.join("_");
20797
+ const sortOn = sortField.startsWith("fields.") ? "contentTypeFields" : "metadata";
20798
+ const sortByValueLabel = (_c = (_b = (_a = filterOptions == null ? void 0 : filterOptions.find((op) => op.value === sortOn)) == null ? void 0 : _a.options) == null ? void 0 : _b.find((f) => f.value === sortField)) == null ? void 0 : _c.label;
20799
+ const sortByIcon = userHasChangedSortByValue ? sortDirection === "ASC" ? "arrow-up" : "arrow-down" : "sort-az";
20800
+ useEffectOnce(() => {
20801
+ setInitialSortValue(sortByValue);
20802
+ });
20803
+ useEffect18(() => {
20804
+ if (initialSortValue !== sortByValue) {
20805
+ setUserHasChangedSortByValue(true);
20806
+ }
20807
+ }, [initialSortValue, sortByValue]);
20710
20808
  return /* @__PURE__ */ jsxs80(Fragment19, { children: [
20711
20809
  /* @__PURE__ */ jsx119(
20712
20810
  FilterButton2,
@@ -20725,7 +20823,7 @@ var FilterControls = ({
20725
20823
  "aria-controls": "search-and-filter-sortBy",
20726
20824
  "aria-label": "sort by options",
20727
20825
  "aria-haspopup": "true",
20728
- text: sortByValueLabel,
20826
+ text: !userHasChangedSortByValue ? "Sort" : sortByValueLabel,
20729
20827
  icon: sortByIcon,
20730
20828
  "aria-expanded": filterVisibility === "sort",
20731
20829
  hasSelectedValue: sortByValue !== "",
@@ -20867,7 +20965,7 @@ var StatusBullet = ({
20867
20965
  };
20868
20966
 
20869
20967
  // src/components/SearchAndFilter/FilterEditor.tsx
20870
- import { jsx as jsx121, jsxs as jsxs81 } from "@emotion/react/jsx-runtime";
20968
+ import { Fragment as Fragment20, jsx as jsx121, jsxs as jsxs81 } from "@emotion/react/jsx-runtime";
20871
20969
  var readOnlyAttributes = {
20872
20970
  isSearchable: false,
20873
20971
  menuIsOpen: false,
@@ -20878,10 +20976,11 @@ var FilterMultiChoiceEditor = ({
20878
20976
  options,
20879
20977
  isDisabled,
20880
20978
  readOnly,
20979
+ valueTestId,
20881
20980
  ...props
20882
20981
  }) => {
20883
20982
  const readOnlyProps = readOnly ? readOnlyAttributes : {};
20884
- return /* @__PURE__ */ jsx121(
20983
+ return /* @__PURE__ */ jsx121("div", { "data-testid": valueTestId, children: /* @__PURE__ */ jsx121(
20885
20984
  InputComboBox,
20886
20985
  {
20887
20986
  ...props,
@@ -20896,19 +20995,28 @@ var FilterMultiChoiceEditor = ({
20896
20995
  },
20897
20996
  value,
20898
20997
  "aria-readonly": readOnly,
20998
+ styles: {
20999
+ menu(base) {
21000
+ return {
21001
+ ...base,
21002
+ minWidth: "max-content"
21003
+ };
21004
+ }
21005
+ },
20899
21006
  ...readOnlyProps
20900
21007
  }
20901
- );
21008
+ ) });
20902
21009
  };
20903
21010
  var FilterSingleChoiceEditor = ({
20904
21011
  options,
20905
21012
  value,
20906
21013
  isDisabled,
20907
21014
  readOnly,
20908
- onChange
21015
+ onChange,
21016
+ valueTestId
20909
21017
  }) => {
20910
21018
  const readOnlyProps = readOnly ? readOnlyAttributes : {};
20911
- return /* @__PURE__ */ jsx121(
21019
+ return /* @__PURE__ */ jsx121("div", { "data-testid": valueTestId, children: /* @__PURE__ */ jsx121(
20912
21020
  InputComboBox,
20913
21021
  {
20914
21022
  placeholder: "Type to search...",
@@ -20921,9 +21029,17 @@ var FilterSingleChoiceEditor = ({
20921
21029
  isDisabled,
20922
21030
  value,
20923
21031
  "aria-readonly": readOnly,
21032
+ styles: {
21033
+ menu(base) {
21034
+ return {
21035
+ ...base,
21036
+ minWidth: "max-content"
21037
+ };
21038
+ }
21039
+ },
20924
21040
  ...readOnlyProps
20925
21041
  }
20926
- );
21042
+ ) });
20927
21043
  };
20928
21044
  var CustomOptions = ({ label, value }) => {
20929
21045
  return /* @__PURE__ */ jsx121(StatusBullet, { status: label, message: value });
@@ -20933,10 +21049,11 @@ var StatusMultiEditor = ({
20933
21049
  value,
20934
21050
  isDisabled,
20935
21051
  readOnly,
20936
- onChange
21052
+ onChange,
21053
+ valueTestId
20937
21054
  }) => {
20938
21055
  const readOnlyProps = readOnly ? readOnlyAttributes : {};
20939
- return /* @__PURE__ */ jsx121(
21056
+ return /* @__PURE__ */ jsx121("div", { "data-testid": valueTestId, children: /* @__PURE__ */ jsx121(
20940
21057
  InputComboBox,
20941
21058
  {
20942
21059
  options,
@@ -20948,19 +21065,28 @@ var StatusMultiEditor = ({
20948
21065
  formatOptionLabel: CustomOptions,
20949
21066
  value,
20950
21067
  isDisabled,
21068
+ styles: {
21069
+ menu(base) {
21070
+ return {
21071
+ ...base,
21072
+ minWidth: "max-content"
21073
+ };
21074
+ }
21075
+ },
20951
21076
  ...readOnlyProps
20952
21077
  }
20953
- );
21078
+ ) });
20954
21079
  };
20955
21080
  var StatusSingleEditor = ({
20956
21081
  options,
20957
21082
  value,
20958
21083
  isDisabled,
20959
21084
  readOnly,
20960
- onChange
21085
+ onChange,
21086
+ valueTestId
20961
21087
  }) => {
20962
21088
  const readOnlyProps = readOnly ? readOnlyAttributes : {};
20963
- return /* @__PURE__ */ jsx121(
21089
+ return /* @__PURE__ */ jsx121("div", { "data-testid": valueTestId, children: /* @__PURE__ */ jsx121(
20964
21090
  InputComboBox,
20965
21091
  {
20966
21092
  options,
@@ -20971,11 +21097,19 @@ var StatusSingleEditor = ({
20971
21097
  formatOptionLabel: CustomOptions,
20972
21098
  value,
20973
21099
  isDisabled,
21100
+ styles: {
21101
+ menu(base) {
21102
+ return {
21103
+ ...base,
21104
+ minWidth: "max-content"
21105
+ };
21106
+ }
21107
+ },
20974
21108
  ...readOnlyProps
20975
21109
  }
20976
- );
21110
+ ) });
20977
21111
  };
20978
- var TextEditor = ({ onChange, ariaLabel, value, readOnly }) => {
21112
+ var TextEditor = ({ onChange, ariaLabel, value, readOnly, valueTestId }) => {
20979
21113
  useDebounce3(() => onChange, 500, [value]);
20980
21114
  return /* @__PURE__ */ jsx121(
20981
21115
  Input,
@@ -20985,11 +21119,19 @@ var TextEditor = ({ onChange, ariaLabel, value, readOnly }) => {
20985
21119
  onChange: (e) => onChange(e.currentTarget.value),
20986
21120
  placeholder: "Enter phrase to search\u2026",
20987
21121
  value,
20988
- readOnly
21122
+ readOnly,
21123
+ "data-testid": valueTestId
20989
21124
  }
20990
21125
  );
20991
21126
  };
20992
- var NumberRangeEditor = ({ onChange, disabled: disabled2, ariaLabel, value, readOnly }) => {
21127
+ var NumberRangeEditor = ({
21128
+ onChange,
21129
+ disabled: disabled2,
21130
+ ariaLabel,
21131
+ value,
21132
+ readOnly,
21133
+ valueTestId
21134
+ }) => {
20993
21135
  const [minValue, setMinValue] = useState18("");
20994
21136
  const [maxValue, setMaxValue] = useState18("");
20995
21137
  const [error, setError] = useState18("");
@@ -21012,41 +21154,50 @@ var NumberRangeEditor = ({ onChange, disabled: disabled2, ariaLabel, value, read
21012
21154
  setError("");
21013
21155
  onChange([minValue, maxValue]);
21014
21156
  }, [maxValue, minValue, setError]);
21015
- return /* @__PURE__ */ jsxs81("div", { css: twoColumnGrid, children: [
21016
- /* @__PURE__ */ jsx121(
21017
- Input,
21018
- {
21019
- label: `${ariaLabel}-min`,
21020
- type: "number",
21021
- showLabel: false,
21022
- min: 0,
21023
- placeholder: "Low",
21024
- onChange: (e) => setMinValue(e.currentTarget.value),
21025
- "aria-invalid": !error ? false : true,
21026
- disabled: disabled2,
21027
- value: value ? value[0] : "",
21028
- readOnly
21029
- }
21030
- ),
21031
- /* @__PURE__ */ jsx121(
21032
- Input,
21033
- {
21034
- type: "number",
21035
- label: `${ariaLabel}-max`,
21036
- showLabel: false,
21037
- min: 0,
21038
- placeholder: "High",
21039
- onChange: (e) => setMaxValue(e.currentTarget.value),
21040
- "aria-invalid": !error ? false : true,
21041
- disabled: disabled2,
21042
- value: value ? value[1] : "",
21043
- readOnly
21044
- }
21045
- ),
21157
+ return /* @__PURE__ */ jsxs81(Fragment20, { children: [
21158
+ /* @__PURE__ */ jsxs81("div", { css: twoColumnGrid, "data-testid": valueTestId, children: [
21159
+ /* @__PURE__ */ jsx121(
21160
+ Input,
21161
+ {
21162
+ label: `${ariaLabel}-min`,
21163
+ type: "number",
21164
+ showLabel: false,
21165
+ min: 0,
21166
+ placeholder: "Low",
21167
+ onChange: (e) => setMinValue(e.currentTarget.value),
21168
+ "aria-invalid": !error ? false : true,
21169
+ disabled: disabled2,
21170
+ value: value ? value[0] : "",
21171
+ readOnly
21172
+ }
21173
+ ),
21174
+ /* @__PURE__ */ jsx121(
21175
+ Input,
21176
+ {
21177
+ type: "number",
21178
+ label: `${ariaLabel}-max`,
21179
+ showLabel: false,
21180
+ min: 0,
21181
+ placeholder: "High",
21182
+ onChange: (e) => setMaxValue(e.currentTarget.value),
21183
+ "aria-invalid": !error ? false : true,
21184
+ disabled: disabled2,
21185
+ value: value ? value[1] : "",
21186
+ readOnly
21187
+ }
21188
+ )
21189
+ ] }),
21046
21190
  /* @__PURE__ */ jsx121(ErrorContainer, { errorMessage: error })
21047
21191
  ] });
21048
21192
  };
21049
- var NumberEditor = ({ ariaLabel, onChange, disabled: disabled2, value, readOnly }) => {
21193
+ var NumberEditor = ({
21194
+ ariaLabel,
21195
+ onChange,
21196
+ disabled: disabled2,
21197
+ value,
21198
+ readOnly,
21199
+ valueTestId
21200
+ }) => {
21050
21201
  return /* @__PURE__ */ jsx121(
21051
21202
  Input,
21052
21203
  {
@@ -21057,11 +21208,19 @@ var NumberEditor = ({ ariaLabel, onChange, disabled: disabled2, value, readOnly
21057
21208
  onChange: (e) => onChange(e.currentTarget.value),
21058
21209
  disabled: disabled2,
21059
21210
  value,
21060
- readOnly
21211
+ readOnly,
21212
+ "data-testid": valueTestId
21061
21213
  }
21062
21214
  );
21063
21215
  };
21064
- var DateEditor = ({ onChange, ariaLabel, disabled: disabled2, value, readOnly }) => {
21216
+ var DateEditor = ({
21217
+ onChange,
21218
+ ariaLabel,
21219
+ disabled: disabled2,
21220
+ value,
21221
+ readOnly,
21222
+ valueTestId
21223
+ }) => {
21065
21224
  return /* @__PURE__ */ jsx121(
21066
21225
  Input,
21067
21226
  {
@@ -21071,11 +21230,19 @@ var DateEditor = ({ onChange, ariaLabel, disabled: disabled2, value, readOnly })
21071
21230
  onChange: (e) => onChange(e.currentTarget.value),
21072
21231
  disabled: disabled2,
21073
21232
  value,
21074
- readOnly
21233
+ readOnly,
21234
+ "data-testid": valueTestId
21075
21235
  }
21076
21236
  );
21077
21237
  };
21078
- var DateRangeEditor = ({ ariaLabel, onChange, disabled: disabled2, value, readOnly }) => {
21238
+ var DateRangeEditor = ({
21239
+ ariaLabel,
21240
+ onChange,
21241
+ disabled: disabled2,
21242
+ value,
21243
+ readOnly,
21244
+ valueTestId
21245
+ }) => {
21079
21246
  const [minDateValue, setMinDateValue] = useState18(value ? value[0] : "");
21080
21247
  const [maxDateValue, setMaxDateValue] = useState18(value ? value[1] : "");
21081
21248
  const [error, setError] = useState18("");
@@ -21110,33 +21277,35 @@ var DateRangeEditor = ({ ariaLabel, onChange, disabled: disabled2, value, readOn
21110
21277
  setError("");
21111
21278
  onChange([minDateValue, maxDateValue]);
21112
21279
  }, [minDateValue, maxDateValue, setError]);
21113
- return /* @__PURE__ */ jsxs81("div", { css: twoColumnGrid, children: [
21114
- /* @__PURE__ */ jsx121(
21115
- Input,
21116
- {
21117
- label: `${ariaLabel}-min-date`,
21118
- type: "date",
21119
- showLabel: false,
21120
- value: minDateValue,
21121
- onChange: (e) => setMinDateValue(e.currentTarget.value),
21122
- "aria-invalid": !error ? false : true,
21123
- disabled: disabled2,
21124
- readOnly
21125
- }
21126
- ),
21127
- /* @__PURE__ */ jsx121(
21128
- Input,
21129
- {
21130
- label: `${ariaLabel}-max-date`,
21131
- type: "date",
21132
- showLabel: false,
21133
- value: maxDateValue,
21134
- onChange: (e) => setMaxDateValue(e.currentTarget.value),
21135
- "aria-invalid": !error ? false : true,
21136
- disabled: disabled2,
21137
- readOnly
21138
- }
21139
- ),
21280
+ return /* @__PURE__ */ jsxs81(Fragment20, { children: [
21281
+ /* @__PURE__ */ jsxs81("div", { css: twoColumnGrid, "data-testid": valueTestId, children: [
21282
+ /* @__PURE__ */ jsx121(
21283
+ Input,
21284
+ {
21285
+ label: `${ariaLabel}-min-date`,
21286
+ type: "date",
21287
+ showLabel: false,
21288
+ value: minDateValue,
21289
+ onChange: (e) => setMinDateValue(e.currentTarget.value),
21290
+ "aria-invalid": !error ? false : true,
21291
+ disabled: disabled2,
21292
+ readOnly
21293
+ }
21294
+ ),
21295
+ /* @__PURE__ */ jsx121(
21296
+ Input,
21297
+ {
21298
+ label: `${ariaLabel}-max-date`,
21299
+ type: "date",
21300
+ showLabel: false,
21301
+ value: maxDateValue,
21302
+ onChange: (e) => setMaxDateValue(e.currentTarget.value),
21303
+ "aria-invalid": !error ? false : true,
21304
+ disabled: disabled2,
21305
+ readOnly
21306
+ }
21307
+ )
21308
+ ] }),
21140
21309
  /* @__PURE__ */ jsx121(ErrorContainer, { errorMessage: error })
21141
21310
  ] });
21142
21311
  };
@@ -21201,7 +21370,7 @@ var SearchAndFilterOptionsContainer2 = ({
21201
21370
  ) : null
21202
21371
  ] });
21203
21372
  };
21204
- var FilterMenu = ({ id, filterTitle = "Show records", menuControls, children }) => {
21373
+ var FilterMenu = ({ id, filterTitle = "Show results", menuControls, children }) => {
21205
21374
  const { filterVisibility, setFilterVisibility } = useSearchAndFilter();
21206
21375
  const innerMenuRef = React24.useRef(null);
21207
21376
  useEffect20(() => {
@@ -21227,7 +21396,7 @@ var FilterMenu = ({ id, filterTitle = "Show records", menuControls, children })
21227
21396
  };
21228
21397
 
21229
21398
  // src/components/SearchAndFilter/FilterItem.tsx
21230
- import { Fragment as Fragment20, jsx as jsx123, jsxs as jsxs83 } from "@emotion/react/jsx-runtime";
21399
+ import { Fragment as Fragment21, jsx as jsx123, jsxs as jsxs83 } from "@emotion/react/jsx-runtime";
21231
21400
  var FilterItem = ({
21232
21401
  index,
21233
21402
  paramOptions,
@@ -21275,8 +21444,8 @@ var FilterItem = ({
21275
21444
  menuIsOpen: false,
21276
21445
  isClearable: false
21277
21446
  } : {};
21278
- return /* @__PURE__ */ jsxs83("div", { css: ConditionalFilterRow, children: [
21279
- /* @__PURE__ */ jsx123("span", { children: index === 0 ? "where" : "and" }),
21447
+ return /* @__PURE__ */ jsxs83("div", { css: ConditionalFilterRow, "data-testid": "filter-item", children: [
21448
+ /* @__PURE__ */ jsx123("span", { children: index === 0 ? "Where" : "and" }),
21280
21449
  /* @__PURE__ */ jsxs83("div", { css: ConditionalInputRow, children: [
21281
21450
  /* @__PURE__ */ jsx123(
21282
21451
  InputComboBox,
@@ -21287,8 +21456,21 @@ var FilterItem = ({
21287
21456
  var _a2;
21288
21457
  onParamChange((_a2 = e == null ? void 0 : e.value) != null ? _a2 : "");
21289
21458
  },
21459
+ isOptionDisabled: (option) => {
21460
+ var _a2;
21461
+ return (_a2 = option == null ? void 0 : option.disabled) != null ? _a2 : false;
21462
+ },
21463
+ styles: {
21464
+ menu(base) {
21465
+ return {
21466
+ ...base,
21467
+ minWidth: "max-content"
21468
+ };
21469
+ }
21470
+ },
21290
21471
  value: selectedFieldValue,
21291
- ...readOnlyProps
21472
+ ...readOnlyProps,
21473
+ id: "filter-field"
21292
21474
  }
21293
21475
  ),
21294
21476
  /* @__PURE__ */ jsx123(
@@ -21302,7 +21484,16 @@ var FilterItem = ({
21302
21484
  },
21303
21485
  isDisabled: !filters[index].field,
21304
21486
  value: selectedOperatorValue,
21305
- ...readOnlyProps
21487
+ styles: {
21488
+ menu(base) {
21489
+ return {
21490
+ ...base,
21491
+ minWidth: "max-content"
21492
+ };
21493
+ }
21494
+ },
21495
+ ...readOnlyProps,
21496
+ id: "filter-operator"
21306
21497
  }
21307
21498
  ),
21308
21499
  /* @__PURE__ */ jsx123(
@@ -21314,16 +21505,18 @@ var FilterItem = ({
21314
21505
  onChange: (e) => onValueChange(e != null ? e : ""),
21315
21506
  readOnly,
21316
21507
  isDisabled: !filters[index].operator,
21317
- value: selectedMetaValue
21508
+ value: selectedMetaValue,
21509
+ valueTestId: "filter-value"
21318
21510
  }
21319
21511
  ),
21320
- /* @__PURE__ */ jsx123(
21512
+ readOnly ? null : /* @__PURE__ */ jsx123(
21321
21513
  "button",
21322
21514
  {
21323
21515
  type: "button",
21324
21516
  onClick: () => handleDeleteFilter(index),
21325
21517
  "aria-label": "delete filter",
21326
21518
  css: IconBtn,
21519
+ "data-testid": "delete-filter",
21327
21520
  children: /* @__PURE__ */ jsx123(Icon, { icon: "trash", iconColor: "red", size: "1rem" })
21328
21521
  }
21329
21522
  )
@@ -21336,6 +21529,7 @@ var FilterItems = ({
21336
21529
  }) => {
21337
21530
  const { filterOptions, filters, setFilters, handleAddFilter, handleResetFilters, setFilterVisibility } = useSearchAndFilter();
21338
21531
  const handleUpdateFilter = (index, prop, value) => {
21532
+ var _a, _b, _c, _d, _e;
21339
21533
  const next = [...filters];
21340
21534
  next[index] = { ...next[index], [prop]: value };
21341
21535
  if (prop === "operator") {
@@ -21348,7 +21542,11 @@ var FilterItems = ({
21348
21542
  }
21349
21543
  }
21350
21544
  if (prop === "field") {
21351
- next[index].operator = "";
21545
+ const firstOperatorInAvailableOperators = (_e = (_d = (_c = (_b = (_a = filterOptions.find((fo) => {
21546
+ var _a2;
21547
+ return (_a2 = fo.options) == null ? void 0 : _a2.find((op) => op.value === value);
21548
+ })) == null ? void 0 : _a.options) == null ? void 0 : _b.find((op) => op.value === next[index].field)) == null ? void 0 : _c.operatorOptions) == null ? void 0 : _d[0].value) != null ? _e : "eq";
21549
+ next[index].operator = firstOperatorInAvailableOperators;
21352
21550
  next[index].value = "";
21353
21551
  }
21354
21552
  setFilters(next);
@@ -21357,11 +21555,20 @@ var FilterItems = ({
21357
21555
  FilterMenu,
21358
21556
  {
21359
21557
  id: "search-and-filter-options",
21360
- menuControls: /* @__PURE__ */ jsxs83(Fragment20, { children: [
21361
- /* @__PURE__ */ jsxs83("button", { type: "button", css: AddConditionalBtn, onClick: handleAddFilter, children: [
21362
- /* @__PURE__ */ jsx123(Icon, { icon: "math-plus", iconColor: "currentColor", size: "1rem" }),
21363
- addButtonText
21364
- ] }),
21558
+ menuControls: /* @__PURE__ */ jsxs83(Fragment21, { children: [
21559
+ /* @__PURE__ */ jsxs83(
21560
+ "button",
21561
+ {
21562
+ type: "button",
21563
+ css: AddConditionalBtn,
21564
+ onClick: handleAddFilter,
21565
+ "data-testid": "add-filter",
21566
+ children: [
21567
+ /* @__PURE__ */ jsx123(Icon, { icon: "math-plus", iconColor: "currentColor", size: "1rem" }),
21568
+ addButtonText
21569
+ ]
21570
+ }
21571
+ ),
21365
21572
  (filters == null ? void 0 : filters.length) ? /* @__PURE__ */ jsx123(
21366
21573
  "button",
21367
21574
  {
@@ -21371,6 +21578,7 @@ var FilterItems = ({
21371
21578
  handleResetFilters();
21372
21579
  setFilterVisibility(void 0);
21373
21580
  },
21581
+ "data-testid": "reset-filters",
21374
21582
  children: resetButtonText
21375
21583
  }
21376
21584
  ) : null
@@ -21617,7 +21825,7 @@ var SortItems = () => {
21617
21825
  var _a2;
21618
21826
  return (_a2 = item.options) == null ? void 0 : _a2.find((option) => option.value === sortField);
21619
21827
  })) == null ? void 0 : _a.options) == null ? void 0 : _b.find((nestedOption) => nestedOption.value === sortField);
21620
- return /* @__PURE__ */ jsx125(FilterMenu, { id: "search-and-filter-options", filterTitle: "Sort by", children: /* @__PURE__ */ jsx125("div", { css: ConditionalFilterRow, children: /* @__PURE__ */ jsxs85("div", { css: ConditionalInputRow, children: [
21828
+ return /* @__PURE__ */ jsx125(FilterMenu, { id: "search-and-filter-options", filterTitle: "Sort by", children: /* @__PURE__ */ jsxs85("div", { css: SortFilterInputRow, children: [
21621
21829
  /* @__PURE__ */ jsx125(
21622
21830
  InputComboBox,
21623
21831
  {
@@ -21626,6 +21834,14 @@ var SortItems = () => {
21626
21834
  const fieldName = e == null ? void 0 : e.value;
21627
21835
  setSortBy(`${fieldName}_${sortDirection}`);
21628
21836
  },
21837
+ styles: {
21838
+ menu(base) {
21839
+ return {
21840
+ ...base,
21841
+ minWidth: "max-content"
21842
+ };
21843
+ }
21844
+ },
21629
21845
  value: currentSelectedOption
21630
21846
  }
21631
21847
  ),
@@ -21642,7 +21858,7 @@ var SortItems = () => {
21642
21858
  value: sortDirection
21643
21859
  }
21644
21860
  )
21645
- ] }) }) });
21861
+ ] }) });
21646
21862
  };
21647
21863
 
21648
21864
  // src/components/SearchAndFilter/FilterModeView.tsx
@@ -21657,7 +21873,7 @@ var FilterModeView = () => {
21657
21873
  };
21658
21874
 
21659
21875
  // src/components/SearchAndFilter/SearchAndFilterResultContainer.tsx
21660
- import { Fragment as Fragment21, jsx as jsx127, jsxs as jsxs86 } from "@emotion/react/jsx-runtime";
21876
+ import { Fragment as Fragment22, jsx as jsx127, jsxs as jsxs86 } from "@emotion/react/jsx-runtime";
21661
21877
  var SearchAndFilterResultContainer = ({
21662
21878
  buttonText,
21663
21879
  clearButtonLabel = "clear",
@@ -21691,7 +21907,7 @@ var SearchAndFilterResultContainer = ({
21691
21907
  if (totalResults && totalResults > 0) {
21692
21908
  return null;
21693
21909
  }
21694
- return /* @__PURE__ */ jsxs86(Fragment21, { children: [
21910
+ return /* @__PURE__ */ jsxs86(Fragment22, { children: [
21695
21911
  /* @__PURE__ */ jsxs86(HorizontalRhythm, { children: [
21696
21912
  /* @__PURE__ */ jsxs86("span", { children: [
21697
21913
  totalResults,
@@ -21744,7 +21960,7 @@ var SearchAndFilter = ({
21744
21960
  css: SearchAndFilterControlsWrapper(
21745
21961
  viewSwitchControls ? "auto auto 1fr 0.5fr" : "auto auto 1fr"
21746
21962
  ),
21747
- children: !filterControls ? /* @__PURE__ */ jsx128(FilterControls, { hideSearchInput: !onSearchChange }) : filterControls
21963
+ children: !filterControls ? /* @__PURE__ */ jsx128(FilterControls, { hideSearchInput: !onSearchChange, defaultSortByValue }) : filterControls
21748
21964
  }
21749
21965
  ),
21750
21966
  viewSwitchControls
@@ -21924,14 +22140,14 @@ var SwitchText = css97`
21924
22140
  `;
21925
22141
 
21926
22142
  // src/components/Switch/Switch.tsx
21927
- import { Fragment as Fragment22, jsx as jsx131, jsxs as jsxs88 } from "@emotion/react/jsx-runtime";
22143
+ import { Fragment as Fragment23, jsx as jsx131, jsxs as jsxs88 } from "@emotion/react/jsx-runtime";
21928
22144
  var Switch = React26.forwardRef(
21929
22145
  ({ label, infoText, toggleText, children, ...inputProps }, ref) => {
21930
22146
  let additionalText = infoText;
21931
22147
  if (infoText && toggleText) {
21932
22148
  additionalText = inputProps.checked ? toggleText : infoText;
21933
22149
  }
21934
- return /* @__PURE__ */ jsxs88(Fragment22, { children: [
22150
+ return /* @__PURE__ */ jsxs88(Fragment23, { children: [
21935
22151
  /* @__PURE__ */ jsxs88("label", { css: [SwitchInputContainer, inputProps.disabled ? SwitchInputDisabled : void 0], children: [
21936
22152
  /* @__PURE__ */ jsx131("input", { type: "checkbox", css: SwitchInput, ...inputProps, ref }),
21937
22153
  /* @__PURE__ */ jsx131("span", { css: SwitchInputLabel, children: label })
@@ -22469,6 +22685,7 @@ export {
22469
22685
  RICHTEXT_OPERATORS,
22470
22686
  ResolveIcon,
22471
22687
  RichTextToolbarIcon,
22688
+ SYSTEM_DATE_OPERATORS,
22472
22689
  SYSTEM_FIELD_OPERATORS,
22473
22690
  ScrollableList,
22474
22691
  ScrollableListInputItem,
@@ -22509,6 +22726,7 @@ export {
22509
22726
  ToastContainer,
22510
22727
  Tooltip,
22511
22728
  TwoColumnLayout,
22729
+ USER_OPERATORS,
22512
22730
  UniformBadge,
22513
22731
  UniformLogo,
22514
22732
  UniformLogoLarge,