@commercetools-uikit/filters 20.2.3 → 20.3.1

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.
@@ -83,9 +83,11 @@ var IconButton__default = /*#__PURE__*/_interopDefault(IconButton);
83
83
 
84
84
  var messages$1 = reactIntl.defineMessages({
85
85
  clearAllButtonLabel: {
86
- id: 'UIKit.ClearAllButton.clearAllButtonLabel',
87
- description: 'Label for the clear all button',
88
- defaultMessage: 'Clear all'
86
+ id: "UIKit.ClearAllButton.clearAllButtonLabel",
87
+ defaultMessage: [{
88
+ "type": 0,
89
+ "value": "Clear all"
90
+ }]
89
91
  }
90
92
  });
91
93
 
@@ -249,8 +251,8 @@ const TriggerButton = /*#__PURE__*/react$1.forwardRef(function TriggerButton(pro
249
251
  css: [triggerWrapper, isDisabled && disabled, process.env.NODE_ENV === "production" ? "" : ";label:TriggerButton;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyaWdnZXItYnV0dG9uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxSFMiLCJmaWxlIjoidHJpZ2dlci1idXR0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgdHlwZSBSZWFjdE5vZGUsXG4gIGZvcndhcmRSZWYsXG4gIHR5cGUgTGVnYWN5UmVmLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHR5cGUgS2V5Ym9hcmRFdmVudCxcbiAgdXNlQ2FsbGJhY2ssXG4gIHVzZVJlZixcbiAgdXNlU3RhdGUsXG59IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IENhcmV0RG93bkljb24sIENsb3NlQm9sZEljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgU2Vjb25kYXJ5SWNvbkJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9zZWNvbmRhcnktaWNvbi1idXR0b24nO1xuaW1wb3J0IHsgdHlwZSBUQXBwbGllZEZpbHRlclZhbHVlIH0gZnJvbSAnLi4vZmlsdGVyLW1lbnUnO1xuaW1wb3J0ICogYXMgc3R5bGVzIGZyb20gJy4vdHJpZ2dlci1idXR0b24uc3R5bGVzJztcbmltcG9ydCB7IEJhZGdlIH0gZnJvbSAnLi4vLi4vYmFkZ2UnO1xuaW1wb3J0IHsgQ2hpcCB9IGZyb20gJy4uL2NoaXAnO1xuXG5jb25zdCB1c2VTY3JvbGxPYnNlcnZlciA9ICh2YWx1ZXM6IFRBcHBsaWVkRmlsdGVyVmFsdWVbXSkgPT4ge1xuICBjb25zdCBbaXNPdmVyZmxvd2luZywgc2V0SXNPdmVyZmxvd2luZ10gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IFtvdmVyZmxvd0NvdW50LCBzZXRPdmVyZmxvd0NvdW50XSA9IHVzZVN0YXRlKDApO1xuICBjb25zdCBjb250YWluZXJSZWYgPSB1c2VSZWY8SFRNTFVMaXN0RWxlbWVudCB8IG51bGw+KG51bGwpO1xuXG4gIGNvbnN0IHNldENvbnRhaW5lclJlZiA9IHVzZUNhbGxiYWNrKFxuICAgIChub2RlOiBIVE1MVUxpc3RFbGVtZW50IHwgbnVsbCkgPT4ge1xuICAgICAgaWYgKG5vZGUpIHtcbiAgICAgICAgY29udGFpbmVyUmVmLmN1cnJlbnQgPSBub2RlO1xuXG4gICAgICAgIGNvbnN0IHsgY2xpZW50V2lkdGgsIHNjcm9sbFdpZHRoLCBjaGlsZHJlbiB9ID0gbm9kZTtcbiAgICAgICAgY29uc3QgaGFzT3ZlcmZsb3cgPSBzY3JvbGxXaWR0aCA+IGNsaWVudFdpZHRoO1xuXG4gICAgICAgIHNldElzT3ZlcmZsb3dpbmcoaGFzT3ZlcmZsb3cpO1xuXG4gICAgICAgIGxldCB2aXNpYmxlQ2hpcENvdW50ID0gMDtcblxuICAgICAgICBpZiAoaGFzT3ZlcmZsb3cpIHtcbiAgICAgICAgICBBcnJheS5mcm9tKGNoaWxkcmVuKS5mb3JFYWNoKChjaGlsZCkgPT4ge1xuICAgICAgICAgICAgY29uc3QgY2hpbGRSZWN0ID0gY2hpbGQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG4gICAgICAgICAgICBjb25zdCBjb250YWluZXJSZWN0ID0gbm9kZS5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKTtcbiAgICAgICAgICAgIGlmIChcbiAgICAgICAgICAgICAgLy8gaWYgdGhlIHJpZ2h0IGhhbmQgc2lkZSBvZiB0aGUgY2hpbGQgaXMgcGFzdCB0aGUgcmlnaHQgb2YgdGhlIGNvbnRhaW5lclxuICAgICAgICAgICAgICBjaGlsZFJlY3QucmlnaHQgPD0gY29udGFpbmVyUmVjdC5yaWdodCAmJlxuICAgICAgICAgICAgICAvLyBhbmQgaXQncyBub3QgdGhlIGJhZGdlXG4gICAgICAgICAgICAgICFBcnJheS5mcm9tKGNoaWxkLmNsYXNzTGlzdCkuaW5jbHVkZXMoXG4gICAgICAgICAgICAgICAgJ3VpLWtpdC1maWx0ZXItdHJpZ2dlci1iYWRnZS1jb250YWluZXInXG4gICAgICAgICAgICAgIClcbiAgICAgICAgICAgICkge1xuICAgICAgICAgICAgICArK3Zpc2libGVDaGlwQ291bnQ7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfSk7XG4gICAgICAgIH1cbiAgICAgICAgc2V0T3ZlcmZsb3dDb3VudCh2YWx1ZXMubGVuZ3RoIC0gdmlzaWJsZUNoaXBDb3VudCk7XG4gICAgICB9XG4gICAgfSxcbiAgICBbdmFsdWVzXVxuICApO1xuXG4gIHJldHVybiB7XG4gICAgaXNPdmVyZmxvd2luZyxcbiAgICBvdmVyZmxvd0NvdW50LFxuICAgIHNldENvbnRhaW5lclJlZixcbiAgfTtcbn07XG5cbmV4cG9ydCB0eXBlIFRGaWx0ZXJNZW51VHJpZ2dlckJ1dHRvblByb3BzID0ge1xuICAvKipcbiAgICogdW5pcXVlIGlkZW50aWZpZXIgZm9yIHRoZSBmaWx0ZXJcbiAgICovXG4gIGZpbHRlcktleTogc3RyaW5nO1xuICAvKipcbiAgICogZm9ybWF0dGVkIG1lc3NhZ2UgdG8gZGlzcGxheSB0aGUgZmlsdGVyJ3MgbmFtZVxuICAgKi9cbiAgbGFiZWw6IFJlYWN0Tm9kZTtcbiAgLyoqXG4gICAqIGZvcm1hdHRlZCBtZXNzYWdlIHRvIGRpc3BsYXkgdGhlIHNlbGVjdGVkIG9wZXJhdG9yIHZhbHVlXG4gICAqL1xuICBvcGVyYXRvckxhYmVsPzogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIHZhbHVlcyBhcHBsaWVkIHRvIHRoaXMgZmlsdGVyIGJ5IHRoZSB1c2VyXG4gICAqL1xuICBhcHBsaWVkRmlsdGVyVmFsdWVzOiBUQXBwbGllZEZpbHRlclZhbHVlW10gfCB1bmRlZmluZWQgfCBudWxsO1xuICAvKipcbiAgICogd2hldGhlciBvciBub3QgdGhlIGZpbHRlciBpcyBkaXNhYmxlZFxuICAgKi9cbiAgaXNEaXNhYmxlZD86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBpbmRpY2F0ZXMgd2hldGhlciBGaWx0ZXJNZW51IGNhbiBiZSByZW1vdmVkIGZyb20gdGhlIGZpbHRlcnNMaXN0XG4gICAqL1xuICBpc1BlcnNpc3RlbnQ/OiBib29sZWFuO1xuICAvKipcbiAgICogY29udHJvbHMgd2hldGhlciBgeGAgaW4gVHJpZ2dlciBCdXR0b24gaXMgZGlzcGxheWVkIC0gcmVxdWlyZWQgaWYgYGlzUGVyc2lzdGVudGAgaXMgYGZhbHNlYFxuICAgKi9cbiAgb25SZW1vdmVSZXF1ZXN0PzogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbn07XG5cbmNvbnN0IFRyaWdnZXJCdXR0b24gPSBmb3J3YXJkUmVmKGZ1bmN0aW9uIFRyaWdnZXJCdXR0b24oXG4gIHByb3BzOiBURmlsdGVyTWVudVRyaWdnZXJCdXR0b25Qcm9wcyxcbiAgcmVmOiBMZWdhY3lSZWY8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4pIHtcbiAgY29uc3Qge1xuICAgIGZpbHRlcktleSxcbiAgICBsYWJlbCxcbiAgICBvcGVyYXRvckxhYmVsLFxuICAgIGFwcGxpZWRGaWx0ZXJWYWx1ZXMsXG4gICAgaXNEaXNhYmxlZCxcbiAgICBpc1BlcnNpc3RlbnQsXG4gICAgb25SZW1vdmVSZXF1ZXN0LFxuICAgIC4uLnJlc3RcbiAgfSA9IHByb3BzO1xuICBjb25zdCB2YWx1ZXMgPSBhcHBsaWVkRmlsdGVyVmFsdWVzIHx8IFtdO1xuICBjb25zdCBmaWx0ZXJzQXBwbGllZDogYm9vbGVhbiA9IHZhbHVlcy5sZW5ndGggPiAwO1xuXG4gIGNvbnN0IHsgaXNPdmVyZmxvd2luZywgb3ZlcmZsb3dDb3VudCwgc2V0Q29udGFpbmVyUmVmIH0gPVxuICAgIHVzZVNjcm9sbE9ic2VydmVyKHZhbHVlcyk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNzcz17W3N0eWxlcy50cmlnZ2VyV3JhcHBlciwgaXNEaXNhYmxlZCAmJiBzdHlsZXMuZGlzYWJsZWRdfT5cbiAgICAgIDxsYWJlbFxuICAgICAgICBjc3M9e3N0eWxlcy5sYWJlbH1cbiAgICAgICAgaHRtbEZvcj17YCR7ZmlsdGVyS2V5fS1tZW51LXRyaWdnZXJgfVxuICAgICAgICBpZD17YCR7ZmlsdGVyS2V5fS1tZW51LWxhYmVsYH1cbiAgICAgID5cbiAgICAgICAge2xhYmVsfTpcbiAgICAgICAge29wZXJhdG9yTGFiZWwgJiYgKFxuICAgICAgICAgIDxzcGFuIGNzcz17c3R5bGVzLm9wZXJhdG9yQ29udGFpbmVyfT57b3BlcmF0b3JMYWJlbH08L3NwYW4+XG4gICAgICAgICl9XG4gICAgICA8L2xhYmVsPlxuICAgICAge2ZpbHRlcnNBcHBsaWVkICYmIChcbiAgICAgICAgPHVsXG4gICAgICAgICAgcmVmPXtzZXRDb250YWluZXJSZWZ9XG4gICAgICAgICAgY3NzPXtzdHlsZXMudmFsdWVzQ29udGFpbmVyfVxuICAgICAgICAgIGFyaWEtbGFiZWw9e2Ake2ZpbHRlcktleX0gc2VsZWN0ZWQgdmFsdWVzYH1cbiAgICAgICAgICBhcmlhLWxpdmU9XCJwb2xpdGVcIlxuICAgICAgICA+XG4gICAgICAgICAge3ZhbHVlcy5tYXAoKHZhbHVlKSA9PiAoXG4gICAgICAgICAgICA8Q2hpcFxuICAgICAgICAgICAgICBrZXk9e3ZhbHVlLnZhbHVlfVxuICAgICAgICAgICAgICBsYWJlbD17dmFsdWUubGFiZWx9XG4gICAgICAgICAgICAgIGlzRGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgICkpfVxuICAgICAgICAgIHtpc092ZXJmbG93aW5nICYmIG92ZXJmbG93Q291bnQgJiYgKFxuICAgICAgICAgICAgPGxpXG4gICAgICAgICAgICAgIGNsYXNzTmFtZT1cInVpLWtpdC1maWx0ZXItdHJpZ2dlci1iYWRnZS1jb250YWluZXJcIlxuICAgICAgICAgICAgICBjc3M9e3N0eWxlcy5iYWRnZUNvbnRhaW5lcn1cbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgPEJhZGdlXG4gICAgICAgICAgICAgICAgaWQ9XCJ1aS1raXQtZmlsdGVyLXRyaWdnZXItb3ZlcmZsb3ctY291bnQtYmFkZ2VcIlxuICAgICAgICAgICAgICAgIGxhYmVsPXtgKyR7b3ZlcmZsb3dDb3VudH1gfVxuICAgICAgICAgICAgICAgIGlzRGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8L2xpPlxuICAgICAgICAgICl9XG4gICAgICAgIDwvdWw+XG4gICAgICApfVxuICAgICAgeyFmaWx0ZXJzQXBwbGllZCAmJiAoXG4gICAgICAgIDxDYXJldERvd25JY29uXG4gICAgICAgICAgYXJpYS1sYWJlbD17YHRvZ2dsZSBmaWx0ZXIgbWVudSBpY29uYH1cbiAgICAgICAgICBzaXplPVwic21hbGxcIlxuICAgICAgICAgIGNvbG9yPVwibmV1dHJhbDYwXCJcbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgICA8YnV0dG9uXG4gICAgICAgIGNzcz17W3N0eWxlcy5tYWluQWN0aW9uQnV0dG9uXX1cbiAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgIGlkPXtgJHtmaWx0ZXJLZXl9LW1lbnUtdHJpZ2dlcmB9XG4gICAgICAgIGFyaWEtZGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgIGFyaWEtbGFiZWxsZWRieT17YCR7ZmlsdGVyS2V5fS1tZW51LWxhYmVsYH1cbiAgICAgICAgey4uLnJlc3R9XG4gICAgICAgIHsuLi4oaXNEaXNhYmxlZCAmJiB7XG4gICAgICAgICAgdGFiSW5kZXg6IC0xLFxuICAgICAgICAgIGRpc2FibGVkOiB0cnVlLFxuICAgICAgICAgIHJlYWRPbmx5OiB0cnVlLFxuICAgICAgICB9KX1cbiAgICAgIC8+XG4gICAgICB7ZmlsdGVyc0FwcGxpZWQgJiYgb25SZW1vdmVSZXF1ZXN0ICYmICFpc1BlcnNpc3RlbnQgJiYgKFxuICAgICAgICA8ZGl2IGNzcz17W3N0eWxlcy5yZW1vdmVCdXR0b25dfT5cbiAgICAgICAgICA8U2Vjb25kYXJ5SWNvbkJ1dHRvblxuICAgICAgICAgICAgaWNvbj17PENsb3NlQm9sZEljb24gLz59XG4gICAgICAgICAgICBzaXplPVwiMTBcIlxuICAgICAgICAgICAgbGFiZWw9e2ByZW1vdmUgJHtsYWJlbH0gZmlsdGVyYH1cbiAgICAgICAgICAgIGlzRGlzYWJsZWQ9e3Byb3BzLmlzRGlzYWJsZWR9XG4gICAgICAgICAgICBvbkNsaWNrPXsoZSkgPT4ge1xuICAgICAgICAgICAgICBlLnN0b3BQcm9wYWdhdGlvbigpO1xuICAgICAgICAgICAgICBvblJlbW92ZVJlcXVlc3QhKGUpO1xuICAgICAgICAgICAgfX1cbiAgICAgICAgICAvPlxuICAgICAgICA8L2Rpdj5cbiAgICAgICl9XG4gICAgPC9kaXY+XG4gICk7XG59KTtcblxuZXhwb3J0IGRlZmF1bHQgVHJpZ2dlckJ1dHRvbjtcbiJdfQ== */"],
250
252
  children: [jsxRuntime.jsxs("label", {
251
253
  css: label,
252
- htmlFor: `${filterKey}-menu-trigger`,
253
- id: `${filterKey}-menu-label`,
254
+ htmlFor: "".concat(filterKey, "-menu-trigger"),
255
+ id: "".concat(filterKey, "-menu-label"),
254
256
  children: [label$1, ":", operatorLabel && jsxRuntime.jsx("span", {
255
257
  css: operatorContainer,
256
258
  children: operatorLabel
@@ -258,7 +260,7 @@ const TriggerButton = /*#__PURE__*/react$1.forwardRef(function TriggerButton(pro
258
260
  }), filtersApplied && jsxRuntime.jsxs("ul", {
259
261
  ref: setContainerRef,
260
262
  css: valuesContainer,
261
- "aria-label": `${filterKey} selected values`,
263
+ "aria-label": "".concat(filterKey, " selected values"),
262
264
  "aria-live": "polite",
263
265
  children: [_mapInstanceProperty__default["default"](values).call(values, value => jsxRuntime.jsx(Chip, {
264
266
  label: value.label,
@@ -268,20 +270,20 @@ const TriggerButton = /*#__PURE__*/react$1.forwardRef(function TriggerButton(pro
268
270
  css: badgeContainer,
269
271
  children: jsxRuntime.jsx(Badge, {
270
272
  id: "ui-kit-filter-trigger-overflow-count-badge",
271
- label: `+${overflowCount}`,
273
+ label: "+".concat(overflowCount),
272
274
  isDisabled: isDisabled
273
275
  })
274
276
  })]
275
277
  }), !filtersApplied && jsxRuntime.jsx(icons.CaretDownIcon, {
276
- "aria-label": `toggle filter menu icon`,
278
+ "aria-label": "toggle filter menu icon",
277
279
  size: "small",
278
280
  color: "neutral60"
279
281
  }), jsxRuntime.jsx("button", _objectSpread(_objectSpread({
280
282
  css: [mainActionButton, process.env.NODE_ENV === "production" ? "" : ";label:TriggerButton;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyaWdnZXItYnV0dG9uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvS1EiLCJmaWxlIjoidHJpZ2dlci1idXR0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgdHlwZSBSZWFjdE5vZGUsXG4gIGZvcndhcmRSZWYsXG4gIHR5cGUgTGVnYWN5UmVmLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHR5cGUgS2V5Ym9hcmRFdmVudCxcbiAgdXNlQ2FsbGJhY2ssXG4gIHVzZVJlZixcbiAgdXNlU3RhdGUsXG59IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IENhcmV0RG93bkljb24sIENsb3NlQm9sZEljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgU2Vjb25kYXJ5SWNvbkJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9zZWNvbmRhcnktaWNvbi1idXR0b24nO1xuaW1wb3J0IHsgdHlwZSBUQXBwbGllZEZpbHRlclZhbHVlIH0gZnJvbSAnLi4vZmlsdGVyLW1lbnUnO1xuaW1wb3J0ICogYXMgc3R5bGVzIGZyb20gJy4vdHJpZ2dlci1idXR0b24uc3R5bGVzJztcbmltcG9ydCB7IEJhZGdlIH0gZnJvbSAnLi4vLi4vYmFkZ2UnO1xuaW1wb3J0IHsgQ2hpcCB9IGZyb20gJy4uL2NoaXAnO1xuXG5jb25zdCB1c2VTY3JvbGxPYnNlcnZlciA9ICh2YWx1ZXM6IFRBcHBsaWVkRmlsdGVyVmFsdWVbXSkgPT4ge1xuICBjb25zdCBbaXNPdmVyZmxvd2luZywgc2V0SXNPdmVyZmxvd2luZ10gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IFtvdmVyZmxvd0NvdW50LCBzZXRPdmVyZmxvd0NvdW50XSA9IHVzZVN0YXRlKDApO1xuICBjb25zdCBjb250YWluZXJSZWYgPSB1c2VSZWY8SFRNTFVMaXN0RWxlbWVudCB8IG51bGw+KG51bGwpO1xuXG4gIGNvbnN0IHNldENvbnRhaW5lclJlZiA9IHVzZUNhbGxiYWNrKFxuICAgIChub2RlOiBIVE1MVUxpc3RFbGVtZW50IHwgbnVsbCkgPT4ge1xuICAgICAgaWYgKG5vZGUpIHtcbiAgICAgICAgY29udGFpbmVyUmVmLmN1cnJlbnQgPSBub2RlO1xuXG4gICAgICAgIGNvbnN0IHsgY2xpZW50V2lkdGgsIHNjcm9sbFdpZHRoLCBjaGlsZHJlbiB9ID0gbm9kZTtcbiAgICAgICAgY29uc3QgaGFzT3ZlcmZsb3cgPSBzY3JvbGxXaWR0aCA+IGNsaWVudFdpZHRoO1xuXG4gICAgICAgIHNldElzT3ZlcmZsb3dpbmcoaGFzT3ZlcmZsb3cpO1xuXG4gICAgICAgIGxldCB2aXNpYmxlQ2hpcENvdW50ID0gMDtcblxuICAgICAgICBpZiAoaGFzT3ZlcmZsb3cpIHtcbiAgICAgICAgICBBcnJheS5mcm9tKGNoaWxkcmVuKS5mb3JFYWNoKChjaGlsZCkgPT4ge1xuICAgICAgICAgICAgY29uc3QgY2hpbGRSZWN0ID0gY2hpbGQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG4gICAgICAgICAgICBjb25zdCBjb250YWluZXJSZWN0ID0gbm9kZS5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKTtcbiAgICAgICAgICAgIGlmIChcbiAgICAgICAgICAgICAgLy8gaWYgdGhlIHJpZ2h0IGhhbmQgc2lkZSBvZiB0aGUgY2hpbGQgaXMgcGFzdCB0aGUgcmlnaHQgb2YgdGhlIGNvbnRhaW5lclxuICAgICAgICAgICAgICBjaGlsZFJlY3QucmlnaHQgPD0gY29udGFpbmVyUmVjdC5yaWdodCAmJlxuICAgICAgICAgICAgICAvLyBhbmQgaXQncyBub3QgdGhlIGJhZGdlXG4gICAgICAgICAgICAgICFBcnJheS5mcm9tKGNoaWxkLmNsYXNzTGlzdCkuaW5jbHVkZXMoXG4gICAgICAgICAgICAgICAgJ3VpLWtpdC1maWx0ZXItdHJpZ2dlci1iYWRnZS1jb250YWluZXInXG4gICAgICAgICAgICAgIClcbiAgICAgICAgICAgICkge1xuICAgICAgICAgICAgICArK3Zpc2libGVDaGlwQ291bnQ7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfSk7XG4gICAgICAgIH1cbiAgICAgICAgc2V0T3ZlcmZsb3dDb3VudCh2YWx1ZXMubGVuZ3RoIC0gdmlzaWJsZUNoaXBDb3VudCk7XG4gICAgICB9XG4gICAgfSxcbiAgICBbdmFsdWVzXVxuICApO1xuXG4gIHJldHVybiB7XG4gICAgaXNPdmVyZmxvd2luZyxcbiAgICBvdmVyZmxvd0NvdW50LFxuICAgIHNldENvbnRhaW5lclJlZixcbiAgfTtcbn07XG5cbmV4cG9ydCB0eXBlIFRGaWx0ZXJNZW51VHJpZ2dlckJ1dHRvblByb3BzID0ge1xuICAvKipcbiAgICogdW5pcXVlIGlkZW50aWZpZXIgZm9yIHRoZSBmaWx0ZXJcbiAgICovXG4gIGZpbHRlcktleTogc3RyaW5nO1xuICAvKipcbiAgICogZm9ybWF0dGVkIG1lc3NhZ2UgdG8gZGlzcGxheSB0aGUgZmlsdGVyJ3MgbmFtZVxuICAgKi9cbiAgbGFiZWw6IFJlYWN0Tm9kZTtcbiAgLyoqXG4gICAqIGZvcm1hdHRlZCBtZXNzYWdlIHRvIGRpc3BsYXkgdGhlIHNlbGVjdGVkIG9wZXJhdG9yIHZhbHVlXG4gICAqL1xuICBvcGVyYXRvckxhYmVsPzogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIHZhbHVlcyBhcHBsaWVkIHRvIHRoaXMgZmlsdGVyIGJ5IHRoZSB1c2VyXG4gICAqL1xuICBhcHBsaWVkRmlsdGVyVmFsdWVzOiBUQXBwbGllZEZpbHRlclZhbHVlW10gfCB1bmRlZmluZWQgfCBudWxsO1xuICAvKipcbiAgICogd2hldGhlciBvciBub3QgdGhlIGZpbHRlciBpcyBkaXNhYmxlZFxuICAgKi9cbiAgaXNEaXNhYmxlZD86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBpbmRpY2F0ZXMgd2hldGhlciBGaWx0ZXJNZW51IGNhbiBiZSByZW1vdmVkIGZyb20gdGhlIGZpbHRlcnNMaXN0XG4gICAqL1xuICBpc1BlcnNpc3RlbnQ/OiBib29sZWFuO1xuICAvKipcbiAgICogY29udHJvbHMgd2hldGhlciBgeGAgaW4gVHJpZ2dlciBCdXR0b24gaXMgZGlzcGxheWVkIC0gcmVxdWlyZWQgaWYgYGlzUGVyc2lzdGVudGAgaXMgYGZhbHNlYFxuICAgKi9cbiAgb25SZW1vdmVSZXF1ZXN0PzogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbn07XG5cbmNvbnN0IFRyaWdnZXJCdXR0b24gPSBmb3J3YXJkUmVmKGZ1bmN0aW9uIFRyaWdnZXJCdXR0b24oXG4gIHByb3BzOiBURmlsdGVyTWVudVRyaWdnZXJCdXR0b25Qcm9wcyxcbiAgcmVmOiBMZWdhY3lSZWY8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4pIHtcbiAgY29uc3Qge1xuICAgIGZpbHRlcktleSxcbiAgICBsYWJlbCxcbiAgICBvcGVyYXRvckxhYmVsLFxuICAgIGFwcGxpZWRGaWx0ZXJWYWx1ZXMsXG4gICAgaXNEaXNhYmxlZCxcbiAgICBpc1BlcnNpc3RlbnQsXG4gICAgb25SZW1vdmVSZXF1ZXN0LFxuICAgIC4uLnJlc3RcbiAgfSA9IHByb3BzO1xuICBjb25zdCB2YWx1ZXMgPSBhcHBsaWVkRmlsdGVyVmFsdWVzIHx8IFtdO1xuICBjb25zdCBmaWx0ZXJzQXBwbGllZDogYm9vbGVhbiA9IHZhbHVlcy5sZW5ndGggPiAwO1xuXG4gIGNvbnN0IHsgaXNPdmVyZmxvd2luZywgb3ZlcmZsb3dDb3VudCwgc2V0Q29udGFpbmVyUmVmIH0gPVxuICAgIHVzZVNjcm9sbE9ic2VydmVyKHZhbHVlcyk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNzcz17W3N0eWxlcy50cmlnZ2VyV3JhcHBlciwgaXNEaXNhYmxlZCAmJiBzdHlsZXMuZGlzYWJsZWRdfT5cbiAgICAgIDxsYWJlbFxuICAgICAgICBjc3M9e3N0eWxlcy5sYWJlbH1cbiAgICAgICAgaHRtbEZvcj17YCR7ZmlsdGVyS2V5fS1tZW51LXRyaWdnZXJgfVxuICAgICAgICBpZD17YCR7ZmlsdGVyS2V5fS1tZW51LWxhYmVsYH1cbiAgICAgID5cbiAgICAgICAge2xhYmVsfTpcbiAgICAgICAge29wZXJhdG9yTGFiZWwgJiYgKFxuICAgICAgICAgIDxzcGFuIGNzcz17c3R5bGVzLm9wZXJhdG9yQ29udGFpbmVyfT57b3BlcmF0b3JMYWJlbH08L3NwYW4+XG4gICAgICAgICl9XG4gICAgICA8L2xhYmVsPlxuICAgICAge2ZpbHRlcnNBcHBsaWVkICYmIChcbiAgICAgICAgPHVsXG4gICAgICAgICAgcmVmPXtzZXRDb250YWluZXJSZWZ9XG4gICAgICAgICAgY3NzPXtzdHlsZXMudmFsdWVzQ29udGFpbmVyfVxuICAgICAgICAgIGFyaWEtbGFiZWw9e2Ake2ZpbHRlcktleX0gc2VsZWN0ZWQgdmFsdWVzYH1cbiAgICAgICAgICBhcmlhLWxpdmU9XCJwb2xpdGVcIlxuICAgICAgICA+XG4gICAgICAgICAge3ZhbHVlcy5tYXAoKHZhbHVlKSA9PiAoXG4gICAgICAgICAgICA8Q2hpcFxuICAgICAgICAgICAgICBrZXk9e3ZhbHVlLnZhbHVlfVxuICAgICAgICAgICAgICBsYWJlbD17dmFsdWUubGFiZWx9XG4gICAgICAgICAgICAgIGlzRGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgICkpfVxuICAgICAgICAgIHtpc092ZXJmbG93aW5nICYmIG92ZXJmbG93Q291bnQgJiYgKFxuICAgICAgICAgICAgPGxpXG4gICAgICAgICAgICAgIGNsYXNzTmFtZT1cInVpLWtpdC1maWx0ZXItdHJpZ2dlci1iYWRnZS1jb250YWluZXJcIlxuICAgICAgICAgICAgICBjc3M9e3N0eWxlcy5iYWRnZUNvbnRhaW5lcn1cbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgPEJhZGdlXG4gICAgICAgICAgICAgICAgaWQ9XCJ1aS1raXQtZmlsdGVyLXRyaWdnZXItb3ZlcmZsb3ctY291bnQtYmFkZ2VcIlxuICAgICAgICAgICAgICAgIGxhYmVsPXtgKyR7b3ZlcmZsb3dDb3VudH1gfVxuICAgICAgICAgICAgICAgIGlzRGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8L2xpPlxuICAgICAgICAgICl9XG4gICAgICAgIDwvdWw+XG4gICAgICApfVxuICAgICAgeyFmaWx0ZXJzQXBwbGllZCAmJiAoXG4gICAgICAgIDxDYXJldERvd25JY29uXG4gICAgICAgICAgYXJpYS1sYWJlbD17YHRvZ2dsZSBmaWx0ZXIgbWVudSBpY29uYH1cbiAgICAgICAgICBzaXplPVwic21hbGxcIlxuICAgICAgICAgIGNvbG9yPVwibmV1dHJhbDYwXCJcbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgICA8YnV0dG9uXG4gICAgICAgIGNzcz17W3N0eWxlcy5tYWluQWN0aW9uQnV0dG9uXX1cbiAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgIGlkPXtgJHtmaWx0ZXJLZXl9LW1lbnUtdHJpZ2dlcmB9XG4gICAgICAgIGFyaWEtZGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgIGFyaWEtbGFiZWxsZWRieT17YCR7ZmlsdGVyS2V5fS1tZW51LWxhYmVsYH1cbiAgICAgICAgey4uLnJlc3R9XG4gICAgICAgIHsuLi4oaXNEaXNhYmxlZCAmJiB7XG4gICAgICAgICAgdGFiSW5kZXg6IC0xLFxuICAgICAgICAgIGRpc2FibGVkOiB0cnVlLFxuICAgICAgICAgIHJlYWRPbmx5OiB0cnVlLFxuICAgICAgICB9KX1cbiAgICAgIC8+XG4gICAgICB7ZmlsdGVyc0FwcGxpZWQgJiYgb25SZW1vdmVSZXF1ZXN0ICYmICFpc1BlcnNpc3RlbnQgJiYgKFxuICAgICAgICA8ZGl2IGNzcz17W3N0eWxlcy5yZW1vdmVCdXR0b25dfT5cbiAgICAgICAgICA8U2Vjb25kYXJ5SWNvbkJ1dHRvblxuICAgICAgICAgICAgaWNvbj17PENsb3NlQm9sZEljb24gLz59XG4gICAgICAgICAgICBzaXplPVwiMTBcIlxuICAgICAgICAgICAgbGFiZWw9e2ByZW1vdmUgJHtsYWJlbH0gZmlsdGVyYH1cbiAgICAgICAgICAgIGlzRGlzYWJsZWQ9e3Byb3BzLmlzRGlzYWJsZWR9XG4gICAgICAgICAgICBvbkNsaWNrPXsoZSkgPT4ge1xuICAgICAgICAgICAgICBlLnN0b3BQcm9wYWdhdGlvbigpO1xuICAgICAgICAgICAgICBvblJlbW92ZVJlcXVlc3QhKGUpO1xuICAgICAgICAgICAgfX1cbiAgICAgICAgICAvPlxuICAgICAgICA8L2Rpdj5cbiAgICAgICl9XG4gICAgPC9kaXY+XG4gICk7XG59KTtcblxuZXhwb3J0IGRlZmF1bHQgVHJpZ2dlckJ1dHRvbjtcbiJdfQ== */"],
281
283
  ref: ref,
282
- id: `${filterKey}-menu-trigger`,
284
+ id: "".concat(filterKey, "-menu-trigger"),
283
285
  "aria-disabled": isDisabled,
284
- "aria-labelledby": `${filterKey}-menu-label`
286
+ "aria-labelledby": "".concat(filterKey, "-menu-label")
285
287
  }, rest), isDisabled && {
286
288
  tabIndex: -1,
287
289
  disabled: true,
@@ -291,7 +293,7 @@ const TriggerButton = /*#__PURE__*/react$1.forwardRef(function TriggerButton(pro
291
293
  children: jsxRuntime.jsx(SecondaryIconButton__default["default"], {
292
294
  icon: jsxRuntime.jsx(icons.CloseBoldIcon, {}),
293
295
  size: "10",
294
- label: `remove ${label$1} filter`,
296
+ label: "remove ".concat(label$1, " filter"),
295
297
  isDisabled: props.isDisabled,
296
298
  onClick: e => {
297
299
  e.stopPropagation();
@@ -304,7 +306,7 @@ const TriggerButton = /*#__PURE__*/react$1.forwardRef(function TriggerButton(pro
304
306
  var TriggerButton$1 = TriggerButton;
305
307
 
306
308
  function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
307
- const FOCUSABLE_CSS_SELECTOR = `a[href], button:not([disabled]), input:not([disabled]), select:not([disabled]), textarea:not([disabled]), *[tabindex], *[contenteditable]`;
309
+ const FOCUSABLE_CSS_SELECTOR = "a[href], button:not([disabled]), input:not([disabled]), select:not([disabled]), textarea:not([disabled]), *[tabindex], *[contenteditable]";
308
310
 
309
311
  /**
310
312
  * Find the first focusable element in the given container,
@@ -341,7 +343,8 @@ function FilterMenu(props) {
341
343
  return jsxRuntime.jsxs(Popover__namespace.Root, {
342
344
  defaultOpen: props.isDisabled ? false : props.defaultOpen,
343
345
  onOpenChange: open => {
344
- if (!open && !props.appliedFilterValues?.length && !props.isPersistent && props.onRemoveRequest) {
346
+ var _props$appliedFilterV;
347
+ if (!open && !((_props$appliedFilterV = props.appliedFilterValues) !== null && _props$appliedFilterV !== void 0 && _props$appliedFilterV.length) && !props.isPersistent && props.onRemoveRequest) {
345
348
  props.onRemoveRequest();
346
349
  }
347
350
  },
@@ -381,19 +384,25 @@ function FilterMenu(props) {
381
384
 
382
385
  var messages = reactIntl.defineMessages({
383
386
  addFilterButtonLabel: {
384
- id: 'UIKit.AddFilterButton.addFilterButtonLabel',
385
- description: 'Label for the add filter button',
386
- defaultMessage: 'Add filter'
387
+ id: "UIKit.AddFilterButton.addFilterButtonLabel",
388
+ defaultMessage: [{
389
+ "type": 0,
390
+ "value": "Add filter"
391
+ }]
387
392
  },
388
393
  clearAllFiltersButtonLabel: {
389
- id: 'UIKit.ClearAllFiltersButton.clearAllFiltersButtonLabel',
390
- description: 'Label for the clear all filters button',
391
- defaultMessage: 'Clear all'
394
+ id: "UIKit.ClearAllFiltersButton.clearAllFiltersButtonLabel",
395
+ defaultMessage: [{
396
+ "type": 0,
397
+ "value": "Clear all"
398
+ }]
392
399
  },
393
400
  filtersButtonLabel: {
394
- id: 'UIKit.FiltersButton.filtersButtonLabel',
395
- description: 'Label for the filters button',
396
- defaultMessage: 'Filters'
401
+ id: "UIKit.FiltersButton.filtersButtonLabel",
402
+ defaultMessage: [{
403
+ "type": 0,
404
+ "value": "Filters"
405
+ }]
397
406
  }
398
407
  });
399
408
 
@@ -522,7 +531,7 @@ function Filters(_ref) {
522
531
  alignItems: "center",
523
532
  children: [jsxRuntime.jsx("div", {
524
533
  css: /*#__PURE__*/react.css({
525
- maxWidth: `${designSystem.designTokens.constraint16}`
534
+ maxWidth: "".concat(designSystem.designTokens.constraint16)
526
535
  }, process.env.NODE_ENV === "production" ? "" : ";label:Filters;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["filters.tsx"],"names":[],"mappings":"AA0Ta","file":"filters.tsx","sourcesContent":["import {\n  type KeyboardEvent,\n  type MouseEvent,\n  type ReactNode,\n  useEffect,\n  useRef,\n  useState,\n} from 'react';\nimport { css } from '@emotion/react';\nimport * as Popover from '@radix-ui/react-popover';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport {\n  CloseBoldIcon,\n  FilterIcon,\n  PlusBoldIcon,\n} from '@commercetools-uikit/icons';\nimport SelectInput, {\n  TOption,\n  TOptionObject,\n} from '@commercetools-uikit/select-input';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { useIntl } from 'react-intl';\nimport FilterMenu, {\n  menuBodyStyle,\n  menuStyles,\n  type TAppliedFilterValue,\n} from './filter-menu';\nimport messages from './messages';\nimport { Badge } from './badge';\n\ninterface TAddFilterSelectOption extends TOption {\n  isDisabled?: boolean;\n}\n\ninterface TAddFilterOptionGroup extends TOptionObject {\n  options: TAddFilterSelectOption[];\n  label: ReactNode;\n  key: string;\n}\n\nexport type TAppliedFilter = {\n  /**\n   * unique identifier for the filter\n   */\n  filterKey: string;\n  /**\n   * the values applied to this filter by the user\n   */\n  values: TAppliedFilterValue[];\n};\n\nexport type TFilterConfiguration = {\n  /**\n   * unique identifier for the filter\n   */\n  key: string;\n  /**\n   * formatted message to display the filter name\n   */\n  label: ReactNode;\n  /**\n   * formatted message to display the selected operator value\n   */\n  operatorLabel?: ReactNode;\n  /**\n   * configuration object for the filter menu.\n   */\n  filterMenuConfiguration: {\n    /**\n     * the input in which the user selects values for the filter\n     */\n    renderMenuBody: () => ReactNode;\n    /**\n     * the input in which the user can select which operator should be used for this filter\n     */\n    renderOperatorsInput?: () => ReactNode;\n    /**\n     * optional button that allows the user to apply selected filter values\n     */\n    renderApplyButton?: () => ReactNode;\n    /**\n     * controls whether `clear` button in Menu Body Footer is displayed\n     */\n    onClearRequest: (\n      event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => void;\n    /**\n     * controls whether `sort` button in Menu Body Header is displayed\n     */\n    onSortRequest?: (\n      event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => void;\n  };\n  /**\n   * optional key to group filters together.\n   */\n  groupKey?: string;\n  /**\n   * indicates whether filter menu can be removed from filters\n   */\n  isPersistent?: boolean;\n  /**\n   * indicates whether the filter is disabled\n   */\n  isDisabled?: boolean;\n  /**\n   * controls whether menu is wider than the default width. Set to true to allow the menu to be wider than the default width.\n   */\n  hasWideMenu?: boolean;\n};\n\nexport type TFilterGroupConfiguration = {\n  /**\n   * unique identifier for the filter group\n   */\n  key: string;\n  /**\n   * formatted message to display the filter group name\n   */\n  label: ReactNode;\n};\n\nexport type TFiltersProps = {\n  /**\n   * array of applied filters, each containing a unique key and an array of values.\n   */\n  appliedFilters: TAppliedFilter[];\n  /**\n   * configuration for the available filters.\n   *\n   */\n  filters: TFilterConfiguration[];\n  /**\n   * optional configuration for filter groups.\n   *\n   */\n  filterGroups?: TFilterGroupConfiguration[];\n\n  /**\n   * controls the `clear all` (added filters) button from the menu list, meant to clear the parent application's filter state\n   */\n  onClearAllRequest: (\n    event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * optional callback when the add filter button is clicked\n   */\n  onAddFilterRequest?: (\n    event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * function to render a search input, selectable from applicable UI Kit components.\n   */\n  renderSearchComponent: ReactNode;\n  /**\n   * controls whether the filters list is initially open\n   */\n  defaultOpen?: boolean;\n};\n\nconst horizontalDividerStyles = css`\n  color: ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral90};\n  width: 100%;\n  height: 1px;\n  border: 0;\n  margin-top: ${designTokens.spacing25};\n  margin-bottom: ${designTokens.spacing30};\n`;\n\nconst verticalDividerStyles = css`\n  width: 1px;\n  height: ${designTokens.spacing30};\n  background-color: ${designTokens.colorNeutral90};\n  margin: 0 ${designTokens.spacing20} 0 ${designTokens.spacing20};\n`;\n\nconst menuListStyles = css`\n  width: 100%;\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${designTokens.spacing20};\n`;\n\nfunction getFilterOptions(\n  filters: TFilterConfiguration[],\n  filterGroups?: TFilterGroupConfiguration[]\n): (TAddFilterSelectOption | TAddFilterOptionGroup)[] {\n  let filterOptions: (TAddFilterSelectOption | TAddFilterOptionGroup)[] = [];\n  // define option groups\n  if (filterGroups) {\n    filterOptions = filterGroups.map((filterGroup) => ({\n      label: filterGroup.label,\n      key: filterGroup.key,\n      options: [],\n    }));\n  }\n  return filters.reduce((filterOptions, filter) => {\n    const formattedOption = {\n      value: filter.key,\n      label: filter.label,\n      isDisabled: filter.isDisabled,\n    };\n    //if theres a groupkey, filterGroups, and the groupKey matches a filterGroup, add option to its group\n    if (filter.groupKey && filterGroups) {\n      const optionGroup = filterOptions.find(\n        (option) => 'key' in option && option.key === filter.groupKey\n      );\n      if (optionGroup && 'options' in optionGroup) {\n        optionGroup.options.push(formattedOption);\n        return filterOptions;\n      }\n    }\n    // otherwise add option directly\n    return [formattedOption, ...filterOptions];\n  }, filterOptions);\n}\n\nfunction Filters({\n  appliedFilters,\n  filters,\n  filterGroups,\n  onClearAllRequest,\n  onAddFilterRequest,\n  renderSearchComponent,\n  defaultOpen = false,\n}: TFiltersProps) {\n  const intl = useIntl();\n  const [showFilterControls, setShowFilterControls] = useState(defaultOpen);\n\n  const handleFiltersClick = () => {\n    setShowFilterControls((currState) => !currState);\n  };\n  /**\n   * persisted filters: always visible\n   * applied filters: filters for which values have been selected\n   * visible filters = persisted + applied\n   *\n   * visibleFiltersFromProps = filters visible based on props\n   * localVisibleFilters = filters actually visible in component currently\n   */\n  const persistedFilterKeys = filters\n    .filter(({ isPersistent }) => isPersistent)\n    .map((filter) => filter.key);\n\n  const persistedFiltersRef = useRef<string[]>(persistedFilterKeys);\n\n  const appliedFilterKeys = appliedFilters.map(({ filterKey }) => filterKey);\n\n  // applied filters must have corresponding filter in `props.filters`,\n  const visibleFiltersFromProps = filters\n    .filter(({ key, isPersistent }) => {\n      return Boolean(isPersistent) || appliedFilterKeys.includes(key);\n    })\n    // persistent filters should be first in filter list\n    .sort(({ isPersistent }) => (isPersistent ? -1 : 1));\n\n  // set initial state as visibleFiltersFromProps\n  const [localVisibleFilters, setLocalVisibleFilters] = useState<string[]>(\n    visibleFiltersFromProps.map(({ key }) => key)\n  );\n\n  // Update localVisibleFilters if appliedFilters or filters prop changes\n  useEffect(() => {\n    const allFilterKeys = filters.map((f) => f.key);\n    const persistedFilterKeys = filters\n      .filter((filter) => filter.isPersistent)\n      .map((filter) => filter.key);\n\n    const appliedFilterKeysWithValues = appliedFilters.map(\n      (af) => af.filterKey\n    );\n\n    // Calculate keys that *must* be visible based on props\n    const requiredVisibleKeys = new Set([\n      ...persistedFilterKeys,\n      ...appliedFilterKeysWithValues,\n    ]);\n\n    // Update state: keep existing keys, add required keys, remove keys no longer in props.filters\n    setLocalVisibleFilters((currentVisibleFilters) => {\n      const combinedKeys = new Set([\n        ...currentVisibleFilters,\n        ...requiredVisibleKeys,\n      ]);\n      // Ensure all keys in the final state actually exist in the filters prop\n      return Array.from(combinedKeys).filter((key) =>\n        allFilterKeys.includes(key)\n      );\n    });\n\n    // Update the ref for persisted keys (used elsewhere)\n    persistedFiltersRef.current = persistedFilterKeys;\n  }, [appliedFilters, filters]); // Keep dependencies correct\n\n  //update localVisibleFilters if persisted filter count changes\n  if (persistedFiltersRef.current.length !== persistedFilterKeys.length) {\n    setLocalVisibleFilters(visibleFiltersFromProps.map(({ key }) => key));\n    persistedFiltersRef.current = persistedFilterKeys;\n  }\n\n  const removeFilter = (filterKey: string) =>\n    setLocalVisibleFilters((currentVisibleFilters) =>\n      currentVisibleFilters.filter(\n        (visibleFilterKey) => visibleFilterKey !== filterKey\n      )\n    );\n\n  return (\n    <>\n      <Spacings.Inline scale=\"m\" alignItems=\"center\">\n        <div css={{ maxWidth: `${designTokens.constraint16}` }}>\n          {renderSearchComponent}\n        </div>\n        <Spacings.Inline scale=\"s\" alignItems=\"center\">\n          <FlatButton\n            label={intl.formatMessage(messages.filtersButtonLabel)}\n            icon={<FilterIcon />}\n            onClick={handleFiltersClick}\n          />\n          {appliedFilters.length > 0 && !showFilterControls && (\n            <Badge\n              id={'uikit-filters-selected-filter-count'}\n              label={`${appliedFilters.length}`}\n            />\n          )}\n        </Spacings.Inline>\n      </Spacings.Inline>\n      <hr css={horizontalDividerStyles} />\n      <CollapsibleMotion\n        isClosed={!showFilterControls}\n        onToggle={() => setShowFilterControls(!showFilterControls)}\n      >\n        {({ registerContentNode, containerStyles }) => (\n          <div style={containerStyles}>\n            <div\n              ref={registerContentNode}\n              css={menuListStyles}\n              aria-live=\"polite\"\n            >\n              {localVisibleFilters.map((activeFilter) => {\n                const activeFilterConfig = filters.find(\n                  (filter) => filter.key === activeFilter\n                )!;\n                return (\n                  <FilterMenu\n                    key={activeFilterConfig.key}\n                    filterKey={activeFilterConfig.key}\n                    label={activeFilterConfig.label}\n                    operatorLabel={activeFilterConfig.operatorLabel}\n                    isPersistent={activeFilterConfig.isPersistent}\n                    isDisabled={activeFilterConfig.isDisabled}\n                    hasWideMenu={activeFilterConfig.hasWideMenu}\n                    renderMenuBody={\n                      activeFilterConfig.filterMenuConfiguration.renderMenuBody\n                    }\n                    renderOperatorsInput={\n                      activeFilterConfig.filterMenuConfiguration\n                        .renderOperatorsInput\n                    }\n                    renderApplyButton={\n                      activeFilterConfig.filterMenuConfiguration\n                        .renderApplyButton\n                    }\n                    appliedFilterValues={\n                      appliedFilters.find(\n                        (appliedFilter) =>\n                          activeFilter === appliedFilter.filterKey\n                      )?.values\n                    }\n                    onClearRequest={\n                      activeFilterConfig.filterMenuConfiguration.onClearRequest\n                    }\n                    onRemoveRequest={(e) => {\n                      removeFilter(activeFilter);\n                      activeFilterConfig.filterMenuConfiguration.onClearRequest(\n                        e\n                      );\n                    }}\n                    onSortRequest={\n                      activeFilterConfig.filterMenuConfiguration.onSortRequest\n                    }\n                    defaultOpen={\n                      activeFilterConfig.isPersistent ||\n                      localVisibleFilters.length ===\n                        visibleFiltersFromProps.length\n                        ? false\n                        : true\n                    }\n                  />\n                );\n              })}\n              <Popover.Root>\n                <Popover.Trigger asChild>\n                  <FlatButton\n                    label={intl.formatMessage(messages.addFilterButtonLabel)}\n                    icon={<PlusBoldIcon />}\n                    onClick={(e) => {\n                      if (onAddFilterRequest) {\n                        onAddFilterRequest(e);\n                      }\n                      setShowFilterControls(true);\n                    }}\n                  />\n                </Popover.Trigger>\n                <Popover.Portal>\n                  <Popover.Content\n                    side=\"bottom\"\n                    align=\"start\"\n                    css={[\n                      () => menuStyles({ hasWideMenu: false }),\n                      menuBodyStyle,\n                    ]}\n                  >\n                    <SelectInput\n                      id=\"ui-kit-add-filters-select\"\n                      name=\"select filters\"\n                      aria-label=\"select filters\"\n                      appearance=\"filter\"\n                      options={\n                        getFilterOptions(filters, filterGroups) as TOption[]\n                      }\n                      onChange={(e) => {\n                        setLocalVisibleFilters(\n                          Array.prototype.concat(\n                            e.target.value ? e.target.value : []\n                          )\n                        );\n                      }}\n                      value={localVisibleFilters}\n                      isMulti={true}\n                      // @ts-ignore\n                      isOptionDisabled={(option: TAddFilterSelectOption) =>\n                        option.isDisabled\n                      }\n                    />\n                  </Popover.Content>\n                </Popover.Portal>\n              </Popover.Root>\n              {appliedFilters.length > 1 && (\n                <>\n                  <div css={verticalDividerStyles} />\n                  <FlatButton\n                    icon={<CloseBoldIcon />}\n                    label={intl.formatMessage(\n                      messages.clearAllFiltersButtonLabel\n                    )}\n                    onClick={(e) => {\n                      onClearAllRequest(e);\n                      setLocalVisibleFilters(persistedFilterKeys);\n                    }}\n                    tone=\"secondary\"\n                  />\n                </>\n              )}\n            </div>\n          </div>\n        )}\n      </CollapsibleMotion>\n    </>\n  );\n}\n\nFilters.displayName = 'Filters';\nexport default Filters;\n"]} */"),
527
536
  children: renderSearchComponent
528
537
  }), jsxRuntime.jsxs(Spacings__default["default"].Inline, {
@@ -534,7 +543,7 @@ function Filters(_ref) {
534
543
  onClick: handleFiltersClick
535
544
  }), appliedFilters.length > 0 && !showFilterControls && jsxRuntime.jsx(Badge, {
536
545
  id: 'uikit-filters-selected-filter-count',
537
- label: `${appliedFilters.length}`
546
+ label: "".concat(appliedFilters.length)
538
547
  })]
539
548
  })]
540
549
  }), jsxRuntime.jsx("hr", {
@@ -633,7 +642,7 @@ function Filters(_ref) {
633
642
  Filters.displayName = 'Filters';
634
643
 
635
644
  // NOTE: This string will be replaced on build time with the package version.
636
- var version = "20.2.3";
645
+ var version = "20.3.1";
637
646
 
638
647
  exports["default"] = Filters;
639
648
  exports.version = version;
@@ -83,9 +83,11 @@ var IconButton__default = /*#__PURE__*/_interopDefault(IconButton);
83
83
 
84
84
  var messages$1 = reactIntl.defineMessages({
85
85
  clearAllButtonLabel: {
86
- id: 'UIKit.ClearAllButton.clearAllButtonLabel',
87
- description: 'Label for the clear all button',
88
- defaultMessage: 'Clear all'
86
+ id: "UIKit.ClearAllButton.clearAllButtonLabel",
87
+ defaultMessage: [{
88
+ "type": 0,
89
+ "value": "Clear all"
90
+ }]
89
91
  }
90
92
  });
91
93
 
@@ -244,8 +246,8 @@ const TriggerButton = /*#__PURE__*/react$1.forwardRef(function TriggerButton(pro
244
246
  css: [triggerWrapper, isDisabled && disabled, "" , "" ],
245
247
  children: [jsxRuntime.jsxs("label", {
246
248
  css: label,
247
- htmlFor: `${filterKey}-menu-trigger`,
248
- id: `${filterKey}-menu-label`,
249
+ htmlFor: "".concat(filterKey, "-menu-trigger"),
250
+ id: "".concat(filterKey, "-menu-label"),
249
251
  children: [label$1, ":", operatorLabel && jsxRuntime.jsx("span", {
250
252
  css: operatorContainer,
251
253
  children: operatorLabel
@@ -253,7 +255,7 @@ const TriggerButton = /*#__PURE__*/react$1.forwardRef(function TriggerButton(pro
253
255
  }), filtersApplied && jsxRuntime.jsxs("ul", {
254
256
  ref: setContainerRef,
255
257
  css: valuesContainer,
256
- "aria-label": `${filterKey} selected values`,
258
+ "aria-label": "".concat(filterKey, " selected values"),
257
259
  "aria-live": "polite",
258
260
  children: [_mapInstanceProperty__default["default"](values).call(values, value => jsxRuntime.jsx(Chip, {
259
261
  label: value.label,
@@ -263,20 +265,20 @@ const TriggerButton = /*#__PURE__*/react$1.forwardRef(function TriggerButton(pro
263
265
  css: badgeContainer,
264
266
  children: jsxRuntime.jsx(Badge, {
265
267
  id: "ui-kit-filter-trigger-overflow-count-badge",
266
- label: `+${overflowCount}`,
268
+ label: "+".concat(overflowCount),
267
269
  isDisabled: isDisabled
268
270
  })
269
271
  })]
270
272
  }), !filtersApplied && jsxRuntime.jsx(icons.CaretDownIcon, {
271
- "aria-label": `toggle filter menu icon`,
273
+ "aria-label": "toggle filter menu icon",
272
274
  size: "small",
273
275
  color: "neutral60"
274
276
  }), jsxRuntime.jsx("button", _objectSpread(_objectSpread({
275
277
  css: [mainActionButton, "" , "" ],
276
278
  ref: ref,
277
- id: `${filterKey}-menu-trigger`,
279
+ id: "".concat(filterKey, "-menu-trigger"),
278
280
  "aria-disabled": isDisabled,
279
- "aria-labelledby": `${filterKey}-menu-label`
281
+ "aria-labelledby": "".concat(filterKey, "-menu-label")
280
282
  }, rest), isDisabled && {
281
283
  tabIndex: -1,
282
284
  disabled: true,
@@ -286,7 +288,7 @@ const TriggerButton = /*#__PURE__*/react$1.forwardRef(function TriggerButton(pro
286
288
  children: jsxRuntime.jsx(SecondaryIconButton__default["default"], {
287
289
  icon: jsxRuntime.jsx(icons.CloseBoldIcon, {}),
288
290
  size: "10",
289
- label: `remove ${label$1} filter`,
291
+ label: "remove ".concat(label$1, " filter"),
290
292
  isDisabled: props.isDisabled,
291
293
  onClick: e => {
292
294
  e.stopPropagation();
@@ -298,7 +300,7 @@ const TriggerButton = /*#__PURE__*/react$1.forwardRef(function TriggerButton(pro
298
300
  });
299
301
  var TriggerButton$1 = TriggerButton;
300
302
 
301
- const FOCUSABLE_CSS_SELECTOR = `a[href], button:not([disabled]), input:not([disabled]), select:not([disabled]), textarea:not([disabled]), *[tabindex], *[contenteditable]`;
303
+ const FOCUSABLE_CSS_SELECTOR = "a[href], button:not([disabled]), input:not([disabled]), select:not([disabled]), textarea:not([disabled]), *[tabindex], *[contenteditable]";
302
304
 
303
305
  /**
304
306
  * Find the first focusable element in the given container,
@@ -331,7 +333,8 @@ function FilterMenu(props) {
331
333
  return jsxRuntime.jsxs(Popover__namespace.Root, {
332
334
  defaultOpen: props.isDisabled ? false : props.defaultOpen,
333
335
  onOpenChange: open => {
334
- if (!open && !props.appliedFilterValues?.length && !props.isPersistent && props.onRemoveRequest) {
336
+ var _props$appliedFilterV;
337
+ if (!open && !((_props$appliedFilterV = props.appliedFilterValues) !== null && _props$appliedFilterV !== void 0 && _props$appliedFilterV.length) && !props.isPersistent && props.onRemoveRequest) {
335
338
  props.onRemoveRequest();
336
339
  }
337
340
  },
@@ -371,19 +374,25 @@ function FilterMenu(props) {
371
374
 
372
375
  var messages = reactIntl.defineMessages({
373
376
  addFilterButtonLabel: {
374
- id: 'UIKit.AddFilterButton.addFilterButtonLabel',
375
- description: 'Label for the add filter button',
376
- defaultMessage: 'Add filter'
377
+ id: "UIKit.AddFilterButton.addFilterButtonLabel",
378
+ defaultMessage: [{
379
+ "type": 0,
380
+ "value": "Add filter"
381
+ }]
377
382
  },
378
383
  clearAllFiltersButtonLabel: {
379
- id: 'UIKit.ClearAllFiltersButton.clearAllFiltersButtonLabel',
380
- description: 'Label for the clear all filters button',
381
- defaultMessage: 'Clear all'
384
+ id: "UIKit.ClearAllFiltersButton.clearAllFiltersButtonLabel",
385
+ defaultMessage: [{
386
+ "type": 0,
387
+ "value": "Clear all"
388
+ }]
382
389
  },
383
390
  filtersButtonLabel: {
384
- id: 'UIKit.FiltersButton.filtersButtonLabel',
385
- description: 'Label for the filters button',
386
- defaultMessage: 'Filters'
391
+ id: "UIKit.FiltersButton.filtersButtonLabel",
392
+ defaultMessage: [{
393
+ "type": 0,
394
+ "value": "Filters"
395
+ }]
387
396
  }
388
397
  });
389
398
 
@@ -512,7 +521,7 @@ function Filters(_ref) {
512
521
  alignItems: "center",
513
522
  children: [jsxRuntime.jsx("div", {
514
523
  css: /*#__PURE__*/react.css({
515
- maxWidth: `${designSystem.designTokens.constraint16}`
524
+ maxWidth: "".concat(designSystem.designTokens.constraint16)
516
525
  }, "" , "" ),
517
526
  children: renderSearchComponent
518
527
  }), jsxRuntime.jsxs(Spacings__default["default"].Inline, {
@@ -524,7 +533,7 @@ function Filters(_ref) {
524
533
  onClick: handleFiltersClick
525
534
  }), appliedFilters.length > 0 && !showFilterControls && jsxRuntime.jsx(Badge, {
526
535
  id: 'uikit-filters-selected-filter-count',
527
- label: `${appliedFilters.length}`
536
+ label: "".concat(appliedFilters.length)
528
537
  })]
529
538
  })]
530
539
  }), jsxRuntime.jsx("hr", {
@@ -623,7 +632,7 @@ function Filters(_ref) {
623
632
  Filters.displayName = 'Filters';
624
633
 
625
634
  // NOTE: This string will be replaced on build time with the package version.
626
- var version = "20.2.3";
635
+ var version = "20.3.1";
627
636
 
628
637
  exports["default"] = Filters;
629
638
  exports.version = version;
@@ -34,9 +34,11 @@ import IconButton from '@commercetools-uikit/icon-button';
34
34
 
35
35
  var messages$1 = defineMessages({
36
36
  clearAllButtonLabel: {
37
- id: 'UIKit.ClearAllButton.clearAllButtonLabel',
38
- description: 'Label for the clear all button',
39
- defaultMessage: 'Clear all'
37
+ id: "UIKit.ClearAllButton.clearAllButtonLabel",
38
+ defaultMessage: [{
39
+ "type": 0,
40
+ "value": "Clear all"
41
+ }]
40
42
  }
41
43
  });
42
44
 
@@ -200,8 +202,8 @@ const TriggerButton = /*#__PURE__*/forwardRef(function TriggerButton(props, ref)
200
202
  css: [triggerWrapper, isDisabled && disabled, process.env.NODE_ENV === "production" ? "" : ";label:TriggerButton;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyaWdnZXItYnV0dG9uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxSFMiLCJmaWxlIjoidHJpZ2dlci1idXR0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgdHlwZSBSZWFjdE5vZGUsXG4gIGZvcndhcmRSZWYsXG4gIHR5cGUgTGVnYWN5UmVmLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHR5cGUgS2V5Ym9hcmRFdmVudCxcbiAgdXNlQ2FsbGJhY2ssXG4gIHVzZVJlZixcbiAgdXNlU3RhdGUsXG59IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IENhcmV0RG93bkljb24sIENsb3NlQm9sZEljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgU2Vjb25kYXJ5SWNvbkJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9zZWNvbmRhcnktaWNvbi1idXR0b24nO1xuaW1wb3J0IHsgdHlwZSBUQXBwbGllZEZpbHRlclZhbHVlIH0gZnJvbSAnLi4vZmlsdGVyLW1lbnUnO1xuaW1wb3J0ICogYXMgc3R5bGVzIGZyb20gJy4vdHJpZ2dlci1idXR0b24uc3R5bGVzJztcbmltcG9ydCB7IEJhZGdlIH0gZnJvbSAnLi4vLi4vYmFkZ2UnO1xuaW1wb3J0IHsgQ2hpcCB9IGZyb20gJy4uL2NoaXAnO1xuXG5jb25zdCB1c2VTY3JvbGxPYnNlcnZlciA9ICh2YWx1ZXM6IFRBcHBsaWVkRmlsdGVyVmFsdWVbXSkgPT4ge1xuICBjb25zdCBbaXNPdmVyZmxvd2luZywgc2V0SXNPdmVyZmxvd2luZ10gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IFtvdmVyZmxvd0NvdW50LCBzZXRPdmVyZmxvd0NvdW50XSA9IHVzZVN0YXRlKDApO1xuICBjb25zdCBjb250YWluZXJSZWYgPSB1c2VSZWY8SFRNTFVMaXN0RWxlbWVudCB8IG51bGw+KG51bGwpO1xuXG4gIGNvbnN0IHNldENvbnRhaW5lclJlZiA9IHVzZUNhbGxiYWNrKFxuICAgIChub2RlOiBIVE1MVUxpc3RFbGVtZW50IHwgbnVsbCkgPT4ge1xuICAgICAgaWYgKG5vZGUpIHtcbiAgICAgICAgY29udGFpbmVyUmVmLmN1cnJlbnQgPSBub2RlO1xuXG4gICAgICAgIGNvbnN0IHsgY2xpZW50V2lkdGgsIHNjcm9sbFdpZHRoLCBjaGlsZHJlbiB9ID0gbm9kZTtcbiAgICAgICAgY29uc3QgaGFzT3ZlcmZsb3cgPSBzY3JvbGxXaWR0aCA+IGNsaWVudFdpZHRoO1xuXG4gICAgICAgIHNldElzT3ZlcmZsb3dpbmcoaGFzT3ZlcmZsb3cpO1xuXG4gICAgICAgIGxldCB2aXNpYmxlQ2hpcENvdW50ID0gMDtcblxuICAgICAgICBpZiAoaGFzT3ZlcmZsb3cpIHtcbiAgICAgICAgICBBcnJheS5mcm9tKGNoaWxkcmVuKS5mb3JFYWNoKChjaGlsZCkgPT4ge1xuICAgICAgICAgICAgY29uc3QgY2hpbGRSZWN0ID0gY2hpbGQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG4gICAgICAgICAgICBjb25zdCBjb250YWluZXJSZWN0ID0gbm9kZS5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKTtcbiAgICAgICAgICAgIGlmIChcbiAgICAgICAgICAgICAgLy8gaWYgdGhlIHJpZ2h0IGhhbmQgc2lkZSBvZiB0aGUgY2hpbGQgaXMgcGFzdCB0aGUgcmlnaHQgb2YgdGhlIGNvbnRhaW5lclxuICAgICAgICAgICAgICBjaGlsZFJlY3QucmlnaHQgPD0gY29udGFpbmVyUmVjdC5yaWdodCAmJlxuICAgICAgICAgICAgICAvLyBhbmQgaXQncyBub3QgdGhlIGJhZGdlXG4gICAgICAgICAgICAgICFBcnJheS5mcm9tKGNoaWxkLmNsYXNzTGlzdCkuaW5jbHVkZXMoXG4gICAgICAgICAgICAgICAgJ3VpLWtpdC1maWx0ZXItdHJpZ2dlci1iYWRnZS1jb250YWluZXInXG4gICAgICAgICAgICAgIClcbiAgICAgICAgICAgICkge1xuICAgICAgICAgICAgICArK3Zpc2libGVDaGlwQ291bnQ7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfSk7XG4gICAgICAgIH1cbiAgICAgICAgc2V0T3ZlcmZsb3dDb3VudCh2YWx1ZXMubGVuZ3RoIC0gdmlzaWJsZUNoaXBDb3VudCk7XG4gICAgICB9XG4gICAgfSxcbiAgICBbdmFsdWVzXVxuICApO1xuXG4gIHJldHVybiB7XG4gICAgaXNPdmVyZmxvd2luZyxcbiAgICBvdmVyZmxvd0NvdW50LFxuICAgIHNldENvbnRhaW5lclJlZixcbiAgfTtcbn07XG5cbmV4cG9ydCB0eXBlIFRGaWx0ZXJNZW51VHJpZ2dlckJ1dHRvblByb3BzID0ge1xuICAvKipcbiAgICogdW5pcXVlIGlkZW50aWZpZXIgZm9yIHRoZSBmaWx0ZXJcbiAgICovXG4gIGZpbHRlcktleTogc3RyaW5nO1xuICAvKipcbiAgICogZm9ybWF0dGVkIG1lc3NhZ2UgdG8gZGlzcGxheSB0aGUgZmlsdGVyJ3MgbmFtZVxuICAgKi9cbiAgbGFiZWw6IFJlYWN0Tm9kZTtcbiAgLyoqXG4gICAqIGZvcm1hdHRlZCBtZXNzYWdlIHRvIGRpc3BsYXkgdGhlIHNlbGVjdGVkIG9wZXJhdG9yIHZhbHVlXG4gICAqL1xuICBvcGVyYXRvckxhYmVsPzogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIHZhbHVlcyBhcHBsaWVkIHRvIHRoaXMgZmlsdGVyIGJ5IHRoZSB1c2VyXG4gICAqL1xuICBhcHBsaWVkRmlsdGVyVmFsdWVzOiBUQXBwbGllZEZpbHRlclZhbHVlW10gfCB1bmRlZmluZWQgfCBudWxsO1xuICAvKipcbiAgICogd2hldGhlciBvciBub3QgdGhlIGZpbHRlciBpcyBkaXNhYmxlZFxuICAgKi9cbiAgaXNEaXNhYmxlZD86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBpbmRpY2F0ZXMgd2hldGhlciBGaWx0ZXJNZW51IGNhbiBiZSByZW1vdmVkIGZyb20gdGhlIGZpbHRlcnNMaXN0XG4gICAqL1xuICBpc1BlcnNpc3RlbnQ/OiBib29sZWFuO1xuICAvKipcbiAgICogY29udHJvbHMgd2hldGhlciBgeGAgaW4gVHJpZ2dlciBCdXR0b24gaXMgZGlzcGxheWVkIC0gcmVxdWlyZWQgaWYgYGlzUGVyc2lzdGVudGAgaXMgYGZhbHNlYFxuICAgKi9cbiAgb25SZW1vdmVSZXF1ZXN0PzogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbn07XG5cbmNvbnN0IFRyaWdnZXJCdXR0b24gPSBmb3J3YXJkUmVmKGZ1bmN0aW9uIFRyaWdnZXJCdXR0b24oXG4gIHByb3BzOiBURmlsdGVyTWVudVRyaWdnZXJCdXR0b25Qcm9wcyxcbiAgcmVmOiBMZWdhY3lSZWY8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4pIHtcbiAgY29uc3Qge1xuICAgIGZpbHRlcktleSxcbiAgICBsYWJlbCxcbiAgICBvcGVyYXRvckxhYmVsLFxuICAgIGFwcGxpZWRGaWx0ZXJWYWx1ZXMsXG4gICAgaXNEaXNhYmxlZCxcbiAgICBpc1BlcnNpc3RlbnQsXG4gICAgb25SZW1vdmVSZXF1ZXN0LFxuICAgIC4uLnJlc3RcbiAgfSA9IHByb3BzO1xuICBjb25zdCB2YWx1ZXMgPSBhcHBsaWVkRmlsdGVyVmFsdWVzIHx8IFtdO1xuICBjb25zdCBmaWx0ZXJzQXBwbGllZDogYm9vbGVhbiA9IHZhbHVlcy5sZW5ndGggPiAwO1xuXG4gIGNvbnN0IHsgaXNPdmVyZmxvd2luZywgb3ZlcmZsb3dDb3VudCwgc2V0Q29udGFpbmVyUmVmIH0gPVxuICAgIHVzZVNjcm9sbE9ic2VydmVyKHZhbHVlcyk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNzcz17W3N0eWxlcy50cmlnZ2VyV3JhcHBlciwgaXNEaXNhYmxlZCAmJiBzdHlsZXMuZGlzYWJsZWRdfT5cbiAgICAgIDxsYWJlbFxuICAgICAgICBjc3M9e3N0eWxlcy5sYWJlbH1cbiAgICAgICAgaHRtbEZvcj17YCR7ZmlsdGVyS2V5fS1tZW51LXRyaWdnZXJgfVxuICAgICAgICBpZD17YCR7ZmlsdGVyS2V5fS1tZW51LWxhYmVsYH1cbiAgICAgID5cbiAgICAgICAge2xhYmVsfTpcbiAgICAgICAge29wZXJhdG9yTGFiZWwgJiYgKFxuICAgICAgICAgIDxzcGFuIGNzcz17c3R5bGVzLm9wZXJhdG9yQ29udGFpbmVyfT57b3BlcmF0b3JMYWJlbH08L3NwYW4+XG4gICAgICAgICl9XG4gICAgICA8L2xhYmVsPlxuICAgICAge2ZpbHRlcnNBcHBsaWVkICYmIChcbiAgICAgICAgPHVsXG4gICAgICAgICAgcmVmPXtzZXRDb250YWluZXJSZWZ9XG4gICAgICAgICAgY3NzPXtzdHlsZXMudmFsdWVzQ29udGFpbmVyfVxuICAgICAgICAgIGFyaWEtbGFiZWw9e2Ake2ZpbHRlcktleX0gc2VsZWN0ZWQgdmFsdWVzYH1cbiAgICAgICAgICBhcmlhLWxpdmU9XCJwb2xpdGVcIlxuICAgICAgICA+XG4gICAgICAgICAge3ZhbHVlcy5tYXAoKHZhbHVlKSA9PiAoXG4gICAgICAgICAgICA8Q2hpcFxuICAgICAgICAgICAgICBrZXk9e3ZhbHVlLnZhbHVlfVxuICAgICAgICAgICAgICBsYWJlbD17dmFsdWUubGFiZWx9XG4gICAgICAgICAgICAgIGlzRGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgICkpfVxuICAgICAgICAgIHtpc092ZXJmbG93aW5nICYmIG92ZXJmbG93Q291bnQgJiYgKFxuICAgICAgICAgICAgPGxpXG4gICAgICAgICAgICAgIGNsYXNzTmFtZT1cInVpLWtpdC1maWx0ZXItdHJpZ2dlci1iYWRnZS1jb250YWluZXJcIlxuICAgICAgICAgICAgICBjc3M9e3N0eWxlcy5iYWRnZUNvbnRhaW5lcn1cbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgPEJhZGdlXG4gICAgICAgICAgICAgICAgaWQ9XCJ1aS1raXQtZmlsdGVyLXRyaWdnZXItb3ZlcmZsb3ctY291bnQtYmFkZ2VcIlxuICAgICAgICAgICAgICAgIGxhYmVsPXtgKyR7b3ZlcmZsb3dDb3VudH1gfVxuICAgICAgICAgICAgICAgIGlzRGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8L2xpPlxuICAgICAgICAgICl9XG4gICAgICAgIDwvdWw+XG4gICAgICApfVxuICAgICAgeyFmaWx0ZXJzQXBwbGllZCAmJiAoXG4gICAgICAgIDxDYXJldERvd25JY29uXG4gICAgICAgICAgYXJpYS1sYWJlbD17YHRvZ2dsZSBmaWx0ZXIgbWVudSBpY29uYH1cbiAgICAgICAgICBzaXplPVwic21hbGxcIlxuICAgICAgICAgIGNvbG9yPVwibmV1dHJhbDYwXCJcbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgICA8YnV0dG9uXG4gICAgICAgIGNzcz17W3N0eWxlcy5tYWluQWN0aW9uQnV0dG9uXX1cbiAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgIGlkPXtgJHtmaWx0ZXJLZXl9LW1lbnUtdHJpZ2dlcmB9XG4gICAgICAgIGFyaWEtZGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgIGFyaWEtbGFiZWxsZWRieT17YCR7ZmlsdGVyS2V5fS1tZW51LWxhYmVsYH1cbiAgICAgICAgey4uLnJlc3R9XG4gICAgICAgIHsuLi4oaXNEaXNhYmxlZCAmJiB7XG4gICAgICAgICAgdGFiSW5kZXg6IC0xLFxuICAgICAgICAgIGRpc2FibGVkOiB0cnVlLFxuICAgICAgICAgIHJlYWRPbmx5OiB0cnVlLFxuICAgICAgICB9KX1cbiAgICAgIC8+XG4gICAgICB7ZmlsdGVyc0FwcGxpZWQgJiYgb25SZW1vdmVSZXF1ZXN0ICYmICFpc1BlcnNpc3RlbnQgJiYgKFxuICAgICAgICA8ZGl2IGNzcz17W3N0eWxlcy5yZW1vdmVCdXR0b25dfT5cbiAgICAgICAgICA8U2Vjb25kYXJ5SWNvbkJ1dHRvblxuICAgICAgICAgICAgaWNvbj17PENsb3NlQm9sZEljb24gLz59XG4gICAgICAgICAgICBzaXplPVwiMTBcIlxuICAgICAgICAgICAgbGFiZWw9e2ByZW1vdmUgJHtsYWJlbH0gZmlsdGVyYH1cbiAgICAgICAgICAgIGlzRGlzYWJsZWQ9e3Byb3BzLmlzRGlzYWJsZWR9XG4gICAgICAgICAgICBvbkNsaWNrPXsoZSkgPT4ge1xuICAgICAgICAgICAgICBlLnN0b3BQcm9wYWdhdGlvbigpO1xuICAgICAgICAgICAgICBvblJlbW92ZVJlcXVlc3QhKGUpO1xuICAgICAgICAgICAgfX1cbiAgICAgICAgICAvPlxuICAgICAgICA8L2Rpdj5cbiAgICAgICl9XG4gICAgPC9kaXY+XG4gICk7XG59KTtcblxuZXhwb3J0IGRlZmF1bHQgVHJpZ2dlckJ1dHRvbjtcbiJdfQ== */"],
201
203
  children: [jsxs("label", {
202
204
  css: label,
203
- htmlFor: `${filterKey}-menu-trigger`,
204
- id: `${filterKey}-menu-label`,
205
+ htmlFor: "".concat(filterKey, "-menu-trigger"),
206
+ id: "".concat(filterKey, "-menu-label"),
205
207
  children: [label$1, ":", operatorLabel && jsx("span", {
206
208
  css: operatorContainer,
207
209
  children: operatorLabel
@@ -209,7 +211,7 @@ const TriggerButton = /*#__PURE__*/forwardRef(function TriggerButton(props, ref)
209
211
  }), filtersApplied && jsxs("ul", {
210
212
  ref: setContainerRef,
211
213
  css: valuesContainer,
212
- "aria-label": `${filterKey} selected values`,
214
+ "aria-label": "".concat(filterKey, " selected values"),
213
215
  "aria-live": "polite",
214
216
  children: [_mapInstanceProperty(values).call(values, value => jsx(Chip, {
215
217
  label: value.label,
@@ -219,20 +221,20 @@ const TriggerButton = /*#__PURE__*/forwardRef(function TriggerButton(props, ref)
219
221
  css: badgeContainer,
220
222
  children: jsx(Badge, {
221
223
  id: "ui-kit-filter-trigger-overflow-count-badge",
222
- label: `+${overflowCount}`,
224
+ label: "+".concat(overflowCount),
223
225
  isDisabled: isDisabled
224
226
  })
225
227
  })]
226
228
  }), !filtersApplied && jsx(CaretDownIcon, {
227
- "aria-label": `toggle filter menu icon`,
229
+ "aria-label": "toggle filter menu icon",
228
230
  size: "small",
229
231
  color: "neutral60"
230
232
  }), jsx("button", _objectSpread(_objectSpread({
231
233
  css: [mainActionButton, process.env.NODE_ENV === "production" ? "" : ";label:TriggerButton;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyaWdnZXItYnV0dG9uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvS1EiLCJmaWxlIjoidHJpZ2dlci1idXR0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgdHlwZSBSZWFjdE5vZGUsXG4gIGZvcndhcmRSZWYsXG4gIHR5cGUgTGVnYWN5UmVmLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHR5cGUgS2V5Ym9hcmRFdmVudCxcbiAgdXNlQ2FsbGJhY2ssXG4gIHVzZVJlZixcbiAgdXNlU3RhdGUsXG59IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IENhcmV0RG93bkljb24sIENsb3NlQm9sZEljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgU2Vjb25kYXJ5SWNvbkJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9zZWNvbmRhcnktaWNvbi1idXR0b24nO1xuaW1wb3J0IHsgdHlwZSBUQXBwbGllZEZpbHRlclZhbHVlIH0gZnJvbSAnLi4vZmlsdGVyLW1lbnUnO1xuaW1wb3J0ICogYXMgc3R5bGVzIGZyb20gJy4vdHJpZ2dlci1idXR0b24uc3R5bGVzJztcbmltcG9ydCB7IEJhZGdlIH0gZnJvbSAnLi4vLi4vYmFkZ2UnO1xuaW1wb3J0IHsgQ2hpcCB9IGZyb20gJy4uL2NoaXAnO1xuXG5jb25zdCB1c2VTY3JvbGxPYnNlcnZlciA9ICh2YWx1ZXM6IFRBcHBsaWVkRmlsdGVyVmFsdWVbXSkgPT4ge1xuICBjb25zdCBbaXNPdmVyZmxvd2luZywgc2V0SXNPdmVyZmxvd2luZ10gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IFtvdmVyZmxvd0NvdW50LCBzZXRPdmVyZmxvd0NvdW50XSA9IHVzZVN0YXRlKDApO1xuICBjb25zdCBjb250YWluZXJSZWYgPSB1c2VSZWY8SFRNTFVMaXN0RWxlbWVudCB8IG51bGw+KG51bGwpO1xuXG4gIGNvbnN0IHNldENvbnRhaW5lclJlZiA9IHVzZUNhbGxiYWNrKFxuICAgIChub2RlOiBIVE1MVUxpc3RFbGVtZW50IHwgbnVsbCkgPT4ge1xuICAgICAgaWYgKG5vZGUpIHtcbiAgICAgICAgY29udGFpbmVyUmVmLmN1cnJlbnQgPSBub2RlO1xuXG4gICAgICAgIGNvbnN0IHsgY2xpZW50V2lkdGgsIHNjcm9sbFdpZHRoLCBjaGlsZHJlbiB9ID0gbm9kZTtcbiAgICAgICAgY29uc3QgaGFzT3ZlcmZsb3cgPSBzY3JvbGxXaWR0aCA+IGNsaWVudFdpZHRoO1xuXG4gICAgICAgIHNldElzT3ZlcmZsb3dpbmcoaGFzT3ZlcmZsb3cpO1xuXG4gICAgICAgIGxldCB2aXNpYmxlQ2hpcENvdW50ID0gMDtcblxuICAgICAgICBpZiAoaGFzT3ZlcmZsb3cpIHtcbiAgICAgICAgICBBcnJheS5mcm9tKGNoaWxkcmVuKS5mb3JFYWNoKChjaGlsZCkgPT4ge1xuICAgICAgICAgICAgY29uc3QgY2hpbGRSZWN0ID0gY2hpbGQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG4gICAgICAgICAgICBjb25zdCBjb250YWluZXJSZWN0ID0gbm9kZS5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKTtcbiAgICAgICAgICAgIGlmIChcbiAgICAgICAgICAgICAgLy8gaWYgdGhlIHJpZ2h0IGhhbmQgc2lkZSBvZiB0aGUgY2hpbGQgaXMgcGFzdCB0aGUgcmlnaHQgb2YgdGhlIGNvbnRhaW5lclxuICAgICAgICAgICAgICBjaGlsZFJlY3QucmlnaHQgPD0gY29udGFpbmVyUmVjdC5yaWdodCAmJlxuICAgICAgICAgICAgICAvLyBhbmQgaXQncyBub3QgdGhlIGJhZGdlXG4gICAgICAgICAgICAgICFBcnJheS5mcm9tKGNoaWxkLmNsYXNzTGlzdCkuaW5jbHVkZXMoXG4gICAgICAgICAgICAgICAgJ3VpLWtpdC1maWx0ZXItdHJpZ2dlci1iYWRnZS1jb250YWluZXInXG4gICAgICAgICAgICAgIClcbiAgICAgICAgICAgICkge1xuICAgICAgICAgICAgICArK3Zpc2libGVDaGlwQ291bnQ7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfSk7XG4gICAgICAgIH1cbiAgICAgICAgc2V0T3ZlcmZsb3dDb3VudCh2YWx1ZXMubGVuZ3RoIC0gdmlzaWJsZUNoaXBDb3VudCk7XG4gICAgICB9XG4gICAgfSxcbiAgICBbdmFsdWVzXVxuICApO1xuXG4gIHJldHVybiB7XG4gICAgaXNPdmVyZmxvd2luZyxcbiAgICBvdmVyZmxvd0NvdW50LFxuICAgIHNldENvbnRhaW5lclJlZixcbiAgfTtcbn07XG5cbmV4cG9ydCB0eXBlIFRGaWx0ZXJNZW51VHJpZ2dlckJ1dHRvblByb3BzID0ge1xuICAvKipcbiAgICogdW5pcXVlIGlkZW50aWZpZXIgZm9yIHRoZSBmaWx0ZXJcbiAgICovXG4gIGZpbHRlcktleTogc3RyaW5nO1xuICAvKipcbiAgICogZm9ybWF0dGVkIG1lc3NhZ2UgdG8gZGlzcGxheSB0aGUgZmlsdGVyJ3MgbmFtZVxuICAgKi9cbiAgbGFiZWw6IFJlYWN0Tm9kZTtcbiAgLyoqXG4gICAqIGZvcm1hdHRlZCBtZXNzYWdlIHRvIGRpc3BsYXkgdGhlIHNlbGVjdGVkIG9wZXJhdG9yIHZhbHVlXG4gICAqL1xuICBvcGVyYXRvckxhYmVsPzogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIHZhbHVlcyBhcHBsaWVkIHRvIHRoaXMgZmlsdGVyIGJ5IHRoZSB1c2VyXG4gICAqL1xuICBhcHBsaWVkRmlsdGVyVmFsdWVzOiBUQXBwbGllZEZpbHRlclZhbHVlW10gfCB1bmRlZmluZWQgfCBudWxsO1xuICAvKipcbiAgICogd2hldGhlciBvciBub3QgdGhlIGZpbHRlciBpcyBkaXNhYmxlZFxuICAgKi9cbiAgaXNEaXNhYmxlZD86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBpbmRpY2F0ZXMgd2hldGhlciBGaWx0ZXJNZW51IGNhbiBiZSByZW1vdmVkIGZyb20gdGhlIGZpbHRlcnNMaXN0XG4gICAqL1xuICBpc1BlcnNpc3RlbnQ/OiBib29sZWFuO1xuICAvKipcbiAgICogY29udHJvbHMgd2hldGhlciBgeGAgaW4gVHJpZ2dlciBCdXR0b24gaXMgZGlzcGxheWVkIC0gcmVxdWlyZWQgaWYgYGlzUGVyc2lzdGVudGAgaXMgYGZhbHNlYFxuICAgKi9cbiAgb25SZW1vdmVSZXF1ZXN0PzogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbn07XG5cbmNvbnN0IFRyaWdnZXJCdXR0b24gPSBmb3J3YXJkUmVmKGZ1bmN0aW9uIFRyaWdnZXJCdXR0b24oXG4gIHByb3BzOiBURmlsdGVyTWVudVRyaWdnZXJCdXR0b25Qcm9wcyxcbiAgcmVmOiBMZWdhY3lSZWY8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4pIHtcbiAgY29uc3Qge1xuICAgIGZpbHRlcktleSxcbiAgICBsYWJlbCxcbiAgICBvcGVyYXRvckxhYmVsLFxuICAgIGFwcGxpZWRGaWx0ZXJWYWx1ZXMsXG4gICAgaXNEaXNhYmxlZCxcbiAgICBpc1BlcnNpc3RlbnQsXG4gICAgb25SZW1vdmVSZXF1ZXN0LFxuICAgIC4uLnJlc3RcbiAgfSA9IHByb3BzO1xuICBjb25zdCB2YWx1ZXMgPSBhcHBsaWVkRmlsdGVyVmFsdWVzIHx8IFtdO1xuICBjb25zdCBmaWx0ZXJzQXBwbGllZDogYm9vbGVhbiA9IHZhbHVlcy5sZW5ndGggPiAwO1xuXG4gIGNvbnN0IHsgaXNPdmVyZmxvd2luZywgb3ZlcmZsb3dDb3VudCwgc2V0Q29udGFpbmVyUmVmIH0gPVxuICAgIHVzZVNjcm9sbE9ic2VydmVyKHZhbHVlcyk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNzcz17W3N0eWxlcy50cmlnZ2VyV3JhcHBlciwgaXNEaXNhYmxlZCAmJiBzdHlsZXMuZGlzYWJsZWRdfT5cbiAgICAgIDxsYWJlbFxuICAgICAgICBjc3M9e3N0eWxlcy5sYWJlbH1cbiAgICAgICAgaHRtbEZvcj17YCR7ZmlsdGVyS2V5fS1tZW51LXRyaWdnZXJgfVxuICAgICAgICBpZD17YCR7ZmlsdGVyS2V5fS1tZW51LWxhYmVsYH1cbiAgICAgID5cbiAgICAgICAge2xhYmVsfTpcbiAgICAgICAge29wZXJhdG9yTGFiZWwgJiYgKFxuICAgICAgICAgIDxzcGFuIGNzcz17c3R5bGVzLm9wZXJhdG9yQ29udGFpbmVyfT57b3BlcmF0b3JMYWJlbH08L3NwYW4+XG4gICAgICAgICl9XG4gICAgICA8L2xhYmVsPlxuICAgICAge2ZpbHRlcnNBcHBsaWVkICYmIChcbiAgICAgICAgPHVsXG4gICAgICAgICAgcmVmPXtzZXRDb250YWluZXJSZWZ9XG4gICAgICAgICAgY3NzPXtzdHlsZXMudmFsdWVzQ29udGFpbmVyfVxuICAgICAgICAgIGFyaWEtbGFiZWw9e2Ake2ZpbHRlcktleX0gc2VsZWN0ZWQgdmFsdWVzYH1cbiAgICAgICAgICBhcmlhLWxpdmU9XCJwb2xpdGVcIlxuICAgICAgICA+XG4gICAgICAgICAge3ZhbHVlcy5tYXAoKHZhbHVlKSA9PiAoXG4gICAgICAgICAgICA8Q2hpcFxuICAgICAgICAgICAgICBrZXk9e3ZhbHVlLnZhbHVlfVxuICAgICAgICAgICAgICBsYWJlbD17dmFsdWUubGFiZWx9XG4gICAgICAgICAgICAgIGlzRGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgICkpfVxuICAgICAgICAgIHtpc092ZXJmbG93aW5nICYmIG92ZXJmbG93Q291bnQgJiYgKFxuICAgICAgICAgICAgPGxpXG4gICAgICAgICAgICAgIGNsYXNzTmFtZT1cInVpLWtpdC1maWx0ZXItdHJpZ2dlci1iYWRnZS1jb250YWluZXJcIlxuICAgICAgICAgICAgICBjc3M9e3N0eWxlcy5iYWRnZUNvbnRhaW5lcn1cbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgPEJhZGdlXG4gICAgICAgICAgICAgICAgaWQ9XCJ1aS1raXQtZmlsdGVyLXRyaWdnZXItb3ZlcmZsb3ctY291bnQtYmFkZ2VcIlxuICAgICAgICAgICAgICAgIGxhYmVsPXtgKyR7b3ZlcmZsb3dDb3VudH1gfVxuICAgICAgICAgICAgICAgIGlzRGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8L2xpPlxuICAgICAgICAgICl9XG4gICAgICAgIDwvdWw+XG4gICAgICApfVxuICAgICAgeyFmaWx0ZXJzQXBwbGllZCAmJiAoXG4gICAgICAgIDxDYXJldERvd25JY29uXG4gICAgICAgICAgYXJpYS1sYWJlbD17YHRvZ2dsZSBmaWx0ZXIgbWVudSBpY29uYH1cbiAgICAgICAgICBzaXplPVwic21hbGxcIlxuICAgICAgICAgIGNvbG9yPVwibmV1dHJhbDYwXCJcbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgICA8YnV0dG9uXG4gICAgICAgIGNzcz17W3N0eWxlcy5tYWluQWN0aW9uQnV0dG9uXX1cbiAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgIGlkPXtgJHtmaWx0ZXJLZXl9LW1lbnUtdHJpZ2dlcmB9XG4gICAgICAgIGFyaWEtZGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgIGFyaWEtbGFiZWxsZWRieT17YCR7ZmlsdGVyS2V5fS1tZW51LWxhYmVsYH1cbiAgICAgICAgey4uLnJlc3R9XG4gICAgICAgIHsuLi4oaXNEaXNhYmxlZCAmJiB7XG4gICAgICAgICAgdGFiSW5kZXg6IC0xLFxuICAgICAgICAgIGRpc2FibGVkOiB0cnVlLFxuICAgICAgICAgIHJlYWRPbmx5OiB0cnVlLFxuICAgICAgICB9KX1cbiAgICAgIC8+XG4gICAgICB7ZmlsdGVyc0FwcGxpZWQgJiYgb25SZW1vdmVSZXF1ZXN0ICYmICFpc1BlcnNpc3RlbnQgJiYgKFxuICAgICAgICA8ZGl2IGNzcz17W3N0eWxlcy5yZW1vdmVCdXR0b25dfT5cbiAgICAgICAgICA8U2Vjb25kYXJ5SWNvbkJ1dHRvblxuICAgICAgICAgICAgaWNvbj17PENsb3NlQm9sZEljb24gLz59XG4gICAgICAgICAgICBzaXplPVwiMTBcIlxuICAgICAgICAgICAgbGFiZWw9e2ByZW1vdmUgJHtsYWJlbH0gZmlsdGVyYH1cbiAgICAgICAgICAgIGlzRGlzYWJsZWQ9e3Byb3BzLmlzRGlzYWJsZWR9XG4gICAgICAgICAgICBvbkNsaWNrPXsoZSkgPT4ge1xuICAgICAgICAgICAgICBlLnN0b3BQcm9wYWdhdGlvbigpO1xuICAgICAgICAgICAgICBvblJlbW92ZVJlcXVlc3QhKGUpO1xuICAgICAgICAgICAgfX1cbiAgICAgICAgICAvPlxuICAgICAgICA8L2Rpdj5cbiAgICAgICl9XG4gICAgPC9kaXY+XG4gICk7XG59KTtcblxuZXhwb3J0IGRlZmF1bHQgVHJpZ2dlckJ1dHRvbjtcbiJdfQ== */"],
232
234
  ref: ref,
233
- id: `${filterKey}-menu-trigger`,
235
+ id: "".concat(filterKey, "-menu-trigger"),
234
236
  "aria-disabled": isDisabled,
235
- "aria-labelledby": `${filterKey}-menu-label`
237
+ "aria-labelledby": "".concat(filterKey, "-menu-label")
236
238
  }, rest), isDisabled && {
237
239
  tabIndex: -1,
238
240
  disabled: true,
@@ -242,7 +244,7 @@ const TriggerButton = /*#__PURE__*/forwardRef(function TriggerButton(props, ref)
242
244
  children: jsx(SecondaryIconButton, {
243
245
  icon: jsx(CloseBoldIcon, {}),
244
246
  size: "10",
245
- label: `remove ${label$1} filter`,
247
+ label: "remove ".concat(label$1, " filter"),
246
248
  isDisabled: props.isDisabled,
247
249
  onClick: e => {
248
250
  e.stopPropagation();
@@ -255,7 +257,7 @@ const TriggerButton = /*#__PURE__*/forwardRef(function TriggerButton(props, ref)
255
257
  var TriggerButton$1 = TriggerButton;
256
258
 
257
259
  function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
258
- const FOCUSABLE_CSS_SELECTOR = `a[href], button:not([disabled]), input:not([disabled]), select:not([disabled]), textarea:not([disabled]), *[tabindex], *[contenteditable]`;
260
+ const FOCUSABLE_CSS_SELECTOR = "a[href], button:not([disabled]), input:not([disabled]), select:not([disabled]), textarea:not([disabled]), *[tabindex], *[contenteditable]";
259
261
 
260
262
  /**
261
263
  * Find the first focusable element in the given container,
@@ -292,7 +294,8 @@ function FilterMenu(props) {
292
294
  return jsxs(Popover.Root, {
293
295
  defaultOpen: props.isDisabled ? false : props.defaultOpen,
294
296
  onOpenChange: open => {
295
- if (!open && !props.appliedFilterValues?.length && !props.isPersistent && props.onRemoveRequest) {
297
+ var _props$appliedFilterV;
298
+ if (!open && !((_props$appliedFilterV = props.appliedFilterValues) !== null && _props$appliedFilterV !== void 0 && _props$appliedFilterV.length) && !props.isPersistent && props.onRemoveRequest) {
296
299
  props.onRemoveRequest();
297
300
  }
298
301
  },
@@ -332,19 +335,25 @@ function FilterMenu(props) {
332
335
 
333
336
  var messages = defineMessages({
334
337
  addFilterButtonLabel: {
335
- id: 'UIKit.AddFilterButton.addFilterButtonLabel',
336
- description: 'Label for the add filter button',
337
- defaultMessage: 'Add filter'
338
+ id: "UIKit.AddFilterButton.addFilterButtonLabel",
339
+ defaultMessage: [{
340
+ "type": 0,
341
+ "value": "Add filter"
342
+ }]
338
343
  },
339
344
  clearAllFiltersButtonLabel: {
340
- id: 'UIKit.ClearAllFiltersButton.clearAllFiltersButtonLabel',
341
- description: 'Label for the clear all filters button',
342
- defaultMessage: 'Clear all'
345
+ id: "UIKit.ClearAllFiltersButton.clearAllFiltersButtonLabel",
346
+ defaultMessage: [{
347
+ "type": 0,
348
+ "value": "Clear all"
349
+ }]
343
350
  },
344
351
  filtersButtonLabel: {
345
- id: 'UIKit.FiltersButton.filtersButtonLabel',
346
- description: 'Label for the filters button',
347
- defaultMessage: 'Filters'
352
+ id: "UIKit.FiltersButton.filtersButtonLabel",
353
+ defaultMessage: [{
354
+ "type": 0,
355
+ "value": "Filters"
356
+ }]
348
357
  }
349
358
  });
350
359
 
@@ -473,7 +482,7 @@ function Filters(_ref) {
473
482
  alignItems: "center",
474
483
  children: [jsx("div", {
475
484
  css: /*#__PURE__*/css({
476
- maxWidth: `${designTokens.constraint16}`
485
+ maxWidth: "".concat(designTokens.constraint16)
477
486
  }, process.env.NODE_ENV === "production" ? "" : ";label:Filters;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["filters.tsx"],"names":[],"mappings":"AA0Ta","file":"filters.tsx","sourcesContent":["import {\n  type KeyboardEvent,\n  type MouseEvent,\n  type ReactNode,\n  useEffect,\n  useRef,\n  useState,\n} from 'react';\nimport { css } from '@emotion/react';\nimport * as Popover from '@radix-ui/react-popover';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport {\n  CloseBoldIcon,\n  FilterIcon,\n  PlusBoldIcon,\n} from '@commercetools-uikit/icons';\nimport SelectInput, {\n  TOption,\n  TOptionObject,\n} from '@commercetools-uikit/select-input';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { useIntl } from 'react-intl';\nimport FilterMenu, {\n  menuBodyStyle,\n  menuStyles,\n  type TAppliedFilterValue,\n} from './filter-menu';\nimport messages from './messages';\nimport { Badge } from './badge';\n\ninterface TAddFilterSelectOption extends TOption {\n  isDisabled?: boolean;\n}\n\ninterface TAddFilterOptionGroup extends TOptionObject {\n  options: TAddFilterSelectOption[];\n  label: ReactNode;\n  key: string;\n}\n\nexport type TAppliedFilter = {\n  /**\n   * unique identifier for the filter\n   */\n  filterKey: string;\n  /**\n   * the values applied to this filter by the user\n   */\n  values: TAppliedFilterValue[];\n};\n\nexport type TFilterConfiguration = {\n  /**\n   * unique identifier for the filter\n   */\n  key: string;\n  /**\n   * formatted message to display the filter name\n   */\n  label: ReactNode;\n  /**\n   * formatted message to display the selected operator value\n   */\n  operatorLabel?: ReactNode;\n  /**\n   * configuration object for the filter menu.\n   */\n  filterMenuConfiguration: {\n    /**\n     * the input in which the user selects values for the filter\n     */\n    renderMenuBody: () => ReactNode;\n    /**\n     * the input in which the user can select which operator should be used for this filter\n     */\n    renderOperatorsInput?: () => ReactNode;\n    /**\n     * optional button that allows the user to apply selected filter values\n     */\n    renderApplyButton?: () => ReactNode;\n    /**\n     * controls whether `clear` button in Menu Body Footer is displayed\n     */\n    onClearRequest: (\n      event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => void;\n    /**\n     * controls whether `sort` button in Menu Body Header is displayed\n     */\n    onSortRequest?: (\n      event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => void;\n  };\n  /**\n   * optional key to group filters together.\n   */\n  groupKey?: string;\n  /**\n   * indicates whether filter menu can be removed from filters\n   */\n  isPersistent?: boolean;\n  /**\n   * indicates whether the filter is disabled\n   */\n  isDisabled?: boolean;\n  /**\n   * controls whether menu is wider than the default width. Set to true to allow the menu to be wider than the default width.\n   */\n  hasWideMenu?: boolean;\n};\n\nexport type TFilterGroupConfiguration = {\n  /**\n   * unique identifier for the filter group\n   */\n  key: string;\n  /**\n   * formatted message to display the filter group name\n   */\n  label: ReactNode;\n};\n\nexport type TFiltersProps = {\n  /**\n   * array of applied filters, each containing a unique key and an array of values.\n   */\n  appliedFilters: TAppliedFilter[];\n  /**\n   * configuration for the available filters.\n   *\n   */\n  filters: TFilterConfiguration[];\n  /**\n   * optional configuration for filter groups.\n   *\n   */\n  filterGroups?: TFilterGroupConfiguration[];\n\n  /**\n   * controls the `clear all` (added filters) button from the menu list, meant to clear the parent application's filter state\n   */\n  onClearAllRequest: (\n    event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * optional callback when the add filter button is clicked\n   */\n  onAddFilterRequest?: (\n    event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * function to render a search input, selectable from applicable UI Kit components.\n   */\n  renderSearchComponent: ReactNode;\n  /**\n   * controls whether the filters list is initially open\n   */\n  defaultOpen?: boolean;\n};\n\nconst horizontalDividerStyles = css`\n  color: ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral90};\n  width: 100%;\n  height: 1px;\n  border: 0;\n  margin-top: ${designTokens.spacing25};\n  margin-bottom: ${designTokens.spacing30};\n`;\n\nconst verticalDividerStyles = css`\n  width: 1px;\n  height: ${designTokens.spacing30};\n  background-color: ${designTokens.colorNeutral90};\n  margin: 0 ${designTokens.spacing20} 0 ${designTokens.spacing20};\n`;\n\nconst menuListStyles = css`\n  width: 100%;\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${designTokens.spacing20};\n`;\n\nfunction getFilterOptions(\n  filters: TFilterConfiguration[],\n  filterGroups?: TFilterGroupConfiguration[]\n): (TAddFilterSelectOption | TAddFilterOptionGroup)[] {\n  let filterOptions: (TAddFilterSelectOption | TAddFilterOptionGroup)[] = [];\n  // define option groups\n  if (filterGroups) {\n    filterOptions = filterGroups.map((filterGroup) => ({\n      label: filterGroup.label,\n      key: filterGroup.key,\n      options: [],\n    }));\n  }\n  return filters.reduce((filterOptions, filter) => {\n    const formattedOption = {\n      value: filter.key,\n      label: filter.label,\n      isDisabled: filter.isDisabled,\n    };\n    //if theres a groupkey, filterGroups, and the groupKey matches a filterGroup, add option to its group\n    if (filter.groupKey && filterGroups) {\n      const optionGroup = filterOptions.find(\n        (option) => 'key' in option && option.key === filter.groupKey\n      );\n      if (optionGroup && 'options' in optionGroup) {\n        optionGroup.options.push(formattedOption);\n        return filterOptions;\n      }\n    }\n    // otherwise add option directly\n    return [formattedOption, ...filterOptions];\n  }, filterOptions);\n}\n\nfunction Filters({\n  appliedFilters,\n  filters,\n  filterGroups,\n  onClearAllRequest,\n  onAddFilterRequest,\n  renderSearchComponent,\n  defaultOpen = false,\n}: TFiltersProps) {\n  const intl = useIntl();\n  const [showFilterControls, setShowFilterControls] = useState(defaultOpen);\n\n  const handleFiltersClick = () => {\n    setShowFilterControls((currState) => !currState);\n  };\n  /**\n   * persisted filters: always visible\n   * applied filters: filters for which values have been selected\n   * visible filters = persisted + applied\n   *\n   * visibleFiltersFromProps = filters visible based on props\n   * localVisibleFilters = filters actually visible in component currently\n   */\n  const persistedFilterKeys = filters\n    .filter(({ isPersistent }) => isPersistent)\n    .map((filter) => filter.key);\n\n  const persistedFiltersRef = useRef<string[]>(persistedFilterKeys);\n\n  const appliedFilterKeys = appliedFilters.map(({ filterKey }) => filterKey);\n\n  // applied filters must have corresponding filter in `props.filters`,\n  const visibleFiltersFromProps = filters\n    .filter(({ key, isPersistent }) => {\n      return Boolean(isPersistent) || appliedFilterKeys.includes(key);\n    })\n    // persistent filters should be first in filter list\n    .sort(({ isPersistent }) => (isPersistent ? -1 : 1));\n\n  // set initial state as visibleFiltersFromProps\n  const [localVisibleFilters, setLocalVisibleFilters] = useState<string[]>(\n    visibleFiltersFromProps.map(({ key }) => key)\n  );\n\n  // Update localVisibleFilters if appliedFilters or filters prop changes\n  useEffect(() => {\n    const allFilterKeys = filters.map((f) => f.key);\n    const persistedFilterKeys = filters\n      .filter((filter) => filter.isPersistent)\n      .map((filter) => filter.key);\n\n    const appliedFilterKeysWithValues = appliedFilters.map(\n      (af) => af.filterKey\n    );\n\n    // Calculate keys that *must* be visible based on props\n    const requiredVisibleKeys = new Set([\n      ...persistedFilterKeys,\n      ...appliedFilterKeysWithValues,\n    ]);\n\n    // Update state: keep existing keys, add required keys, remove keys no longer in props.filters\n    setLocalVisibleFilters((currentVisibleFilters) => {\n      const combinedKeys = new Set([\n        ...currentVisibleFilters,\n        ...requiredVisibleKeys,\n      ]);\n      // Ensure all keys in the final state actually exist in the filters prop\n      return Array.from(combinedKeys).filter((key) =>\n        allFilterKeys.includes(key)\n      );\n    });\n\n    // Update the ref for persisted keys (used elsewhere)\n    persistedFiltersRef.current = persistedFilterKeys;\n  }, [appliedFilters, filters]); // Keep dependencies correct\n\n  //update localVisibleFilters if persisted filter count changes\n  if (persistedFiltersRef.current.length !== persistedFilterKeys.length) {\n    setLocalVisibleFilters(visibleFiltersFromProps.map(({ key }) => key));\n    persistedFiltersRef.current = persistedFilterKeys;\n  }\n\n  const removeFilter = (filterKey: string) =>\n    setLocalVisibleFilters((currentVisibleFilters) =>\n      currentVisibleFilters.filter(\n        (visibleFilterKey) => visibleFilterKey !== filterKey\n      )\n    );\n\n  return (\n    <>\n      <Spacings.Inline scale=\"m\" alignItems=\"center\">\n        <div css={{ maxWidth: `${designTokens.constraint16}` }}>\n          {renderSearchComponent}\n        </div>\n        <Spacings.Inline scale=\"s\" alignItems=\"center\">\n          <FlatButton\n            label={intl.formatMessage(messages.filtersButtonLabel)}\n            icon={<FilterIcon />}\n            onClick={handleFiltersClick}\n          />\n          {appliedFilters.length > 0 && !showFilterControls && (\n            <Badge\n              id={'uikit-filters-selected-filter-count'}\n              label={`${appliedFilters.length}`}\n            />\n          )}\n        </Spacings.Inline>\n      </Spacings.Inline>\n      <hr css={horizontalDividerStyles} />\n      <CollapsibleMotion\n        isClosed={!showFilterControls}\n        onToggle={() => setShowFilterControls(!showFilterControls)}\n      >\n        {({ registerContentNode, containerStyles }) => (\n          <div style={containerStyles}>\n            <div\n              ref={registerContentNode}\n              css={menuListStyles}\n              aria-live=\"polite\"\n            >\n              {localVisibleFilters.map((activeFilter) => {\n                const activeFilterConfig = filters.find(\n                  (filter) => filter.key === activeFilter\n                )!;\n                return (\n                  <FilterMenu\n                    key={activeFilterConfig.key}\n                    filterKey={activeFilterConfig.key}\n                    label={activeFilterConfig.label}\n                    operatorLabel={activeFilterConfig.operatorLabel}\n                    isPersistent={activeFilterConfig.isPersistent}\n                    isDisabled={activeFilterConfig.isDisabled}\n                    hasWideMenu={activeFilterConfig.hasWideMenu}\n                    renderMenuBody={\n                      activeFilterConfig.filterMenuConfiguration.renderMenuBody\n                    }\n                    renderOperatorsInput={\n                      activeFilterConfig.filterMenuConfiguration\n                        .renderOperatorsInput\n                    }\n                    renderApplyButton={\n                      activeFilterConfig.filterMenuConfiguration\n                        .renderApplyButton\n                    }\n                    appliedFilterValues={\n                      appliedFilters.find(\n                        (appliedFilter) =>\n                          activeFilter === appliedFilter.filterKey\n                      )?.values\n                    }\n                    onClearRequest={\n                      activeFilterConfig.filterMenuConfiguration.onClearRequest\n                    }\n                    onRemoveRequest={(e) => {\n                      removeFilter(activeFilter);\n                      activeFilterConfig.filterMenuConfiguration.onClearRequest(\n                        e\n                      );\n                    }}\n                    onSortRequest={\n                      activeFilterConfig.filterMenuConfiguration.onSortRequest\n                    }\n                    defaultOpen={\n                      activeFilterConfig.isPersistent ||\n                      localVisibleFilters.length ===\n                        visibleFiltersFromProps.length\n                        ? false\n                        : true\n                    }\n                  />\n                );\n              })}\n              <Popover.Root>\n                <Popover.Trigger asChild>\n                  <FlatButton\n                    label={intl.formatMessage(messages.addFilterButtonLabel)}\n                    icon={<PlusBoldIcon />}\n                    onClick={(e) => {\n                      if (onAddFilterRequest) {\n                        onAddFilterRequest(e);\n                      }\n                      setShowFilterControls(true);\n                    }}\n                  />\n                </Popover.Trigger>\n                <Popover.Portal>\n                  <Popover.Content\n                    side=\"bottom\"\n                    align=\"start\"\n                    css={[\n                      () => menuStyles({ hasWideMenu: false }),\n                      menuBodyStyle,\n                    ]}\n                  >\n                    <SelectInput\n                      id=\"ui-kit-add-filters-select\"\n                      name=\"select filters\"\n                      aria-label=\"select filters\"\n                      appearance=\"filter\"\n                      options={\n                        getFilterOptions(filters, filterGroups) as TOption[]\n                      }\n                      onChange={(e) => {\n                        setLocalVisibleFilters(\n                          Array.prototype.concat(\n                            e.target.value ? e.target.value : []\n                          )\n                        );\n                      }}\n                      value={localVisibleFilters}\n                      isMulti={true}\n                      // @ts-ignore\n                      isOptionDisabled={(option: TAddFilterSelectOption) =>\n                        option.isDisabled\n                      }\n                    />\n                  </Popover.Content>\n                </Popover.Portal>\n              </Popover.Root>\n              {appliedFilters.length > 1 && (\n                <>\n                  <div css={verticalDividerStyles} />\n                  <FlatButton\n                    icon={<CloseBoldIcon />}\n                    label={intl.formatMessage(\n                      messages.clearAllFiltersButtonLabel\n                    )}\n                    onClick={(e) => {\n                      onClearAllRequest(e);\n                      setLocalVisibleFilters(persistedFilterKeys);\n                    }}\n                    tone=\"secondary\"\n                  />\n                </>\n              )}\n            </div>\n          </div>\n        )}\n      </CollapsibleMotion>\n    </>\n  );\n}\n\nFilters.displayName = 'Filters';\nexport default Filters;\n"]} */"),
478
487
  children: renderSearchComponent
479
488
  }), jsxs(Spacings.Inline, {
@@ -485,7 +494,7 @@ function Filters(_ref) {
485
494
  onClick: handleFiltersClick
486
495
  }), appliedFilters.length > 0 && !showFilterControls && jsx(Badge, {
487
496
  id: 'uikit-filters-selected-filter-count',
488
- label: `${appliedFilters.length}`
497
+ label: "".concat(appliedFilters.length)
489
498
  })]
490
499
  })]
491
500
  }), jsx("hr", {
@@ -584,6 +593,6 @@ function Filters(_ref) {
584
593
  Filters.displayName = 'Filters';
585
594
 
586
595
  // NOTE: This string will be replaced on build time with the package version.
587
- var version = "20.2.3";
596
+ var version = "20.3.1";
588
597
 
589
598
  export { Filters as default, version };
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@commercetools-uikit/filters",
3
3
  "description": "The `Filters` component displays filter controls.",
4
- "version": "20.2.3",
4
+ "version": "20.3.1",
5
5
  "bugs": "https://github.com/commercetools/ui-kit/issues",
6
6
  "repository": {
7
7
  "type": "git",
@@ -21,15 +21,15 @@
21
21
  "dependencies": {
22
22
  "@babel/runtime": "^7.20.13",
23
23
  "@babel/runtime-corejs3": "^7.20.13",
24
- "@commercetools-uikit/collapsible-motion": "20.2.3",
25
- "@commercetools-uikit/design-system": "20.2.3",
26
- "@commercetools-uikit/flat-button": "20.2.3",
27
- "@commercetools-uikit/icon-button": "20.2.3",
28
- "@commercetools-uikit/icons": "20.2.3",
29
- "@commercetools-uikit/secondary-icon-button": "20.2.3",
30
- "@commercetools-uikit/select-input": "20.2.3",
31
- "@commercetools-uikit/spacings": "20.2.3",
32
- "@commercetools-uikit/utils": "20.2.3",
24
+ "@commercetools-uikit/collapsible-motion": "20.3.1",
25
+ "@commercetools-uikit/design-system": "20.3.1",
26
+ "@commercetools-uikit/flat-button": "20.3.1",
27
+ "@commercetools-uikit/icon-button": "20.3.1",
28
+ "@commercetools-uikit/icons": "20.3.1",
29
+ "@commercetools-uikit/secondary-icon-button": "20.3.1",
30
+ "@commercetools-uikit/select-input": "20.3.1",
31
+ "@commercetools-uikit/spacings": "20.3.1",
32
+ "@commercetools-uikit/utils": "20.3.1",
33
33
  "@emotion/react": "^11.10.5",
34
34
  "@emotion/styled": "^11.10.5",
35
35
  "@radix-ui/react-popover": "^1.1.4",
@@ -40,8 +40,8 @@
40
40
  "@commercetools-uikit/radio-input": "workspace:^",
41
41
  "@commercetools-uikit/search-text-input": "workspace:^",
42
42
  "@commercetools-uikit/text-input": "workspace:^",
43
- "react": "19.1.0",
44
- "react-dom": "19.1.0"
43
+ "react": "19.2.0",
44
+ "react-dom": "19.2.0"
45
45
  },
46
46
  "peerDependencies": {
47
47
  "react": "19.x",