@ultraviolet/ui 1.71.0 → 1.72.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (58) hide show
  1. package/dist/components/Checkbox/index.cjs +12 -12
  2. package/dist/components/Checkbox/index.js +12 -12
  3. package/dist/components/CheckboxGroup/index.cjs +7 -7
  4. package/dist/components/CheckboxGroup/index.js +7 -7
  5. package/dist/components/DateInput/index.cjs +5 -5
  6. package/dist/components/DateInput/index.js +5 -5
  7. package/dist/components/List/HeaderCell.cjs +15 -31
  8. package/dist/components/List/HeaderCell.js +14 -30
  9. package/dist/components/NumberInputV2/index.cjs +23 -15
  10. package/dist/components/NumberInputV2/index.js +23 -15
  11. package/dist/components/Radio/index.cjs +13 -9
  12. package/dist/components/Radio/index.js +13 -9
  13. package/dist/components/RadioGroup/index.cjs +6 -6
  14. package/dist/components/RadioGroup/index.js +6 -6
  15. package/dist/components/SelectInputV2/SelectBar.cjs +11 -11
  16. package/dist/components/SelectInputV2/SelectBar.js +11 -11
  17. package/dist/components/SelectInputV2/index.cjs +5 -5
  18. package/dist/components/SelectInputV2/index.js +5 -5
  19. package/dist/components/SelectableCardGroup/index.cjs +6 -6
  20. package/dist/components/SelectableCardGroup/index.js +6 -6
  21. package/dist/components/Slider/components/Label.cjs +3 -3
  22. package/dist/components/Slider/components/Label.js +3 -3
  23. package/dist/components/Slider/index.cjs +2 -2
  24. package/dist/components/Slider/index.js +2 -2
  25. package/dist/components/Table/Cell.cjs +14 -4
  26. package/dist/components/Table/Cell.d.ts +5 -1
  27. package/dist/components/Table/Cell.js +14 -4
  28. package/dist/components/Table/HeaderCell.cjs +25 -23
  29. package/dist/components/Table/HeaderCell.d.ts +4 -3
  30. package/dist/components/Table/HeaderCell.js +22 -20
  31. package/dist/components/Table/HeaderRow.cjs +5 -3
  32. package/dist/components/Table/HeaderRow.js +5 -3
  33. package/dist/components/Table/Row.cjs +52 -16
  34. package/dist/components/Table/Row.d.ts +3 -1
  35. package/dist/components/Table/Row.js +53 -17
  36. package/dist/components/Table/TableContext.cjs +38 -3
  37. package/dist/components/Table/TableContext.d.ts +8 -1
  38. package/dist/components/Table/TableContext.js +38 -3
  39. package/dist/components/Table/constants.cjs +12 -0
  40. package/dist/components/Table/constants.d.ts +7 -0
  41. package/dist/components/Table/constants.js +12 -0
  42. package/dist/components/Table/index.cjs +33 -22
  43. package/dist/components/Table/index.d.ts +19 -2
  44. package/dist/components/Table/index.js +33 -22
  45. package/dist/components/TagInput/index.cjs +9 -9
  46. package/dist/components/TagInput/index.js +9 -9
  47. package/dist/components/TextArea/index.cjs +14 -11
  48. package/dist/components/TextArea/index.d.ts +8 -2
  49. package/dist/components/TextArea/index.js +14 -11
  50. package/dist/components/TextInputV2/index.cjs +11 -11
  51. package/dist/components/TextInputV2/index.js +11 -11
  52. package/dist/components/Toggle/index.cjs +7 -7
  53. package/dist/components/Toggle/index.js +7 -7
  54. package/dist/components/ToggleGroup/index.cjs +6 -6
  55. package/dist/components/ToggleGroup/index.js +6 -6
  56. package/dist/components/UnitInput/index.cjs +10 -10
  57. package/dist/components/UnitInput/index.js +10 -10
  58. package/package.json +4 -4
@@ -1,6 +1,6 @@
1
1
  import { jsx, jsxs } from "@emotion/react/jsx-runtime";
2
2
  import _styled from "@emotion/styled/base";
3
- import { Icon } from "@ultraviolet/icons/legacy";
3
+ import { AsteriskIcon } from "@ultraviolet/icons";
4
4
  import { createContext, useMemo, useContext } from "react";
5
5
  import { Radio } from "../Radio/index.js";
6
6
  import { Stack } from "../Stack/index.js";
@@ -46,10 +46,10 @@ const FieldSet = /* @__PURE__ */ _styled("fieldset", process.env.NODE_ENV === "p
46
46
  } : {
47
47
  name: "7o2an9",
48
48
  styles: "border:none;padding:0;margin:0",
49
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1JhZGlvR3JvdXAvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThFZ0MiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvUmFkaW9Hcm91cC9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IEljb24gfSBmcm9tICdAdWx0cmF2aW9sZXQvaWNvbnMvbGVnYWN5J1xuaW1wb3J0IHtcbiAgdHlwZSBDb21wb25lbnRQcm9wcyxcbiAgdHlwZSBJbnB1dEhUTUxBdHRyaWJ1dGVzLFxuICB0eXBlIFJlYWN0Tm9kZSxcbiAgY3JlYXRlQ29udGV4dCxcbiAgdXNlQ29udGV4dCxcbiAgdXNlTWVtbyxcbn0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBSYWRpbyB9IGZyb20gJy4uL1JhZGlvJ1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tICcuLi9TdGFjaydcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuXG50eXBlIFJhZGlvR3JvdXBDb250ZXh0VHlwZSA9IHtcbiAgZ3JvdXBOYW1lOiBzdHJpbmdcbiAgZ3JvdXBWYWx1ZTogc3RyaW5nIHwgbnVtYmVyXG59ICYgUmVxdWlyZWQ8UGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAnb25DaGFuZ2UnPj4gJlxuICBQaWNrPElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4sICdyZXF1aXJlZCc+XG5cbmNvbnN0IFJhZGlvR3JvdXBDb250ZXh0ID0gY3JlYXRlQ29udGV4dDxSYWRpb0dyb3VwQ29udGV4dFR5cGUgfCB1bmRlZmluZWQ+KFxuICB1bmRlZmluZWQsXG4pXG5cbnR5cGUgUmFkaW9Hcm91cFJhZGlvUHJvcHMgPSBPbWl0PFxuICBDb21wb25lbnRQcm9wczx0eXBlb2YgUmFkaW8+LFxuICAnb25DaGFuZ2UnIHwgJ2NoZWNrZWQnIHwgJ3JlcXVpcmVkJ1xuPiAmIHtcbiAgLyoqXG4gICAqIEBkZXByZWNhdGVkIHlvdSBkb24ndCBuZWVkIHRvIHVzZSBgbmFtZWAgYW55bW9yZSwgdGhlIG5hbWUgd2lsbCBiZSBwYXNzZWQgZnJvbSB0aGUgcGFyZW50IGBSYWRpb0dyb3VwYC5cbiAgICovXG4gIG5hbWU/OiBzdHJpbmdcbn1cblxuY29uc3QgUmFkaW9Hcm91cFJhZGlvID0gKHtcbiAgb25Gb2N1cyxcbiAgb25CbHVyLFxuICBkaXNhYmxlZCxcbiAgZXJyb3IsXG4gIG5hbWUsXG4gIHZhbHVlLFxuICBsYWJlbCxcbiAgaGVscGVyLFxuICBjbGFzc05hbWUsXG4gIGF1dG9Gb2N1cyxcbiAgb25LZXlEb3duLFxuICB0b29sdGlwLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxufTogUmFkaW9Hcm91cFJhZGlvUHJvcHMpID0+IHtcbiAgY29uc3QgY29udGV4dCA9IHVzZUNvbnRleHQoUmFkaW9Hcm91cENvbnRleHQpXG5cbiAgaWYgKCFjb250ZXh0KSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdSYWRpb0dyb3VwLlJhZGlvIGNhbiBvbmx5IGJlIHVzZWQgaW5zaWRlIGEgUmFkaW9Hcm91cCcpXG4gIH1cblxuICBjb25zdCB7IGdyb3VwTmFtZSwgb25DaGFuZ2UsIGdyb3VwVmFsdWUgfSA9IGNvbnRleHRcblxuICByZXR1cm4gKFxuICAgIDxSYWRpb1xuICAgICAgb25DaGFuZ2U9e29uQ2hhbmdlfVxuICAgICAgY2hlY2tlZD17Z3JvdXBWYWx1ZSA9PT0gdmFsdWV9XG4gICAgICBvbkZvY3VzPXtvbkZvY3VzfVxuICAgICAgb25CbHVyPXtvbkJsdXJ9XG4gICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICBlcnJvcj17ZXJyb3J9XG4gICAgICBuYW1lPXtncm91cE5hbWUgPz8gbmFtZX1cbiAgICAgIHZhbHVlPXt2YWx1ZX1cbiAgICAgIGxhYmVsPXtsYWJlbH1cbiAgICAgIGhlbHBlcj17aGVscGVyfVxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBhdXRvRm9jdXM9e2F1dG9Gb2N1c31cbiAgICAgIG9uS2V5RG93bj17b25LZXlEb3dufVxuICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICB0b29sdGlwPXt0b29sdGlwfVxuICAgIC8+XG4gIClcbn1cblxuY29uc3QgRmllbGRTZXQgPSBzdHlsZWQuZmllbGRzZXRgXG4gIGJvcmRlcjogbm9uZTtcbiAgcGFkZGluZzogMDtcbiAgbWFyZ2luOiAwO1xuYFxuXG5jb25zdCBTdHlsZWRSZXF1aXJlZEljb24gPSBzdHlsZWQoSWNvbilgXG4gIHZlcnRpY2FsLWFsaWduOiBzdXBlcjtcbmBcblxudHlwZSBSYWRpb0dyb3VwUHJvcHMgPSB7XG4gIGxlZ2VuZDogc3RyaW5nXG4gIHZhbHVlOiBzdHJpbmcgfCBudW1iZXJcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGhlbHBlcj86IFJlYWN0Tm9kZVxuICBlcnJvcj86IFJlYWN0Tm9kZVxuICBkaXJlY3Rpb24/OiAncm93JyB8ICdjb2x1bW4nXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbn0gJiBSZXF1aXJlZDxQaWNrPElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4sICdvbkNoYW5nZScgfCAnbmFtZSc+PiAmXG4gIFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ3JlcXVpcmVkJz5cblxuLyoqXG4gKiBSYWRpb0dyb3VwIGlzIGEgY29tcG9uZW50IHRoYXQgYWxsb3dzIHVzZXJzIHRvIHNlbGVjdCBvbmUgb3B0aW9uIGZyb20gYSBsaXN0IG9mIG9wdGlvbnMgdXNpbmcgcmFkaW8uXG4gKi9cbmV4cG9ydCBjb25zdCBSYWRpb0dyb3VwID0gKHtcbiAgbGVnZW5kLFxuICB2YWx1ZSxcbiAgY2xhc3NOYW1lLFxuICBoZWxwZXIsXG4gIGVycm9yLFxuICBkaXJlY3Rpb24gPSAnY29sdW1uJyxcbiAgY2hpbGRyZW4sXG4gIG9uQ2hhbmdlLFxuICBuYW1lLFxuICByZXF1aXJlZCA9IGZhbHNlLFxufTogUmFkaW9Hcm91cFByb3BzKSA9PiB7XG4gIGNvbnN0IGNvbnRleHRWYWx1ZSA9IHVzZU1lbW8oXG4gICAgKCkgPT4gKHtcbiAgICAgIGdyb3VwTmFtZTogbmFtZSxcbiAgICAgIGdyb3VwVmFsdWU6IHZhbHVlLFxuICAgICAgb25DaGFuZ2UsXG4gICAgICByZXF1aXJlZCxcbiAgICB9KSxcbiAgICBbbmFtZSwgdmFsdWUsIG9uQ2hhbmdlLCByZXF1aXJlZF0sXG4gIClcblxuICByZXR1cm4gKFxuICAgIDxSYWRpb0dyb3VwQ29udGV4dC5Qcm92aWRlciB2YWx1ZT17Y29udGV4dFZhbHVlfT5cbiAgICAgIDxTdGFjayBnYXA9ezF9PlxuICAgICAgICA8RmllbGRTZXQgY2xhc3NOYW1lPXtjbGFzc05hbWV9PlxuICAgICAgICAgIDxTdGFjayBnYXA9ezEuNX0+XG4gICAgICAgICAgICA8VGV4dCBhcz1cImxlZ2VuZFwiIHZhcmlhbnQ9XCJib2R5U3Ryb25nXCI+XG4gICAgICAgICAgICAgIHtsZWdlbmR9Jm5ic3A7XG4gICAgICAgICAgICAgIHtyZXF1aXJlZCA/IChcbiAgICAgICAgICAgICAgICA8U3R5bGVkUmVxdWlyZWRJY29uIG5hbWU9XCJhc3Rlcmlza1wiIGNvbG9yPVwiZGFuZ2VyXCIgc2l6ZT17OH0gLz5cbiAgICAgICAgICAgICAgKSA6IG51bGx9XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICA8U3RhY2tcbiAgICAgICAgICAgICAgZ2FwPXtkaXJlY3Rpb24gPT09ICdjb2x1bW4nID8gMSA6IDJ9XG4gICAgICAgICAgICAgIGRpcmVjdGlvbj17ZGlyZWN0aW9ufVxuICAgICAgICAgICAgICBhbGlnbkl0ZW1zPVwic3RhcnRcIlxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgICAgICA8L1N0YWNrPlxuICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgIDwvRmllbGRTZXQ+XG4gICAgICAgIHtoZWxwZXIgPyAoXG4gICAgICAgICAgPFRleHRcbiAgICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgICB2YXJpYW50PVwiY2FwdGlvblwiXG4gICAgICAgICAgICBwcm9taW5lbmNlPVwid2Vha1wiXG4gICAgICAgICAgICBzZW50aW1lbnQ9XCJuZXV0cmFsXCJcbiAgICAgICAgICA+XG4gICAgICAgICAgICB7aGVscGVyfVxuICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICAgIHtlcnJvciA/IChcbiAgICAgICAgICA8VGV4dCBhcz1cInNwYW5cIiB2YXJpYW50PVwiY2FwdGlvblwiIHNlbnRpbWVudD1cImRhbmdlclwiPlxuICAgICAgICAgICAge2Vycm9yfVxuICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICA8L1N0YWNrPlxuICAgIDwvUmFkaW9Hcm91cENvbnRleHQuUHJvdmlkZXI+XG4gIClcbn1cblxuUmFkaW9Hcm91cC5SYWRpbyA9IFJhZGlvR3JvdXBSYWRpb1xuIl19 */",
49
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1JhZGlvR3JvdXAvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThFZ0MiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvUmFkaW9Hcm91cC9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IEFzdGVyaXNrSWNvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC9pY29ucydcbmltcG9ydCB7XG4gIHR5cGUgQ29tcG9uZW50UHJvcHMsXG4gIHR5cGUgSW5wdXRIVE1MQXR0cmlidXRlcyxcbiAgdHlwZSBSZWFjdE5vZGUsXG4gIGNyZWF0ZUNvbnRleHQsXG4gIHVzZUNvbnRleHQsXG4gIHVzZU1lbW8sXG59IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgUmFkaW8gfSBmcm9tICcuLi9SYWRpbydcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcblxudHlwZSBSYWRpb0dyb3VwQ29udGV4dFR5cGUgPSB7XG4gIGdyb3VwTmFtZTogc3RyaW5nXG4gIGdyb3VwVmFsdWU6IHN0cmluZyB8IG51bWJlclxufSAmIFJlcXVpcmVkPFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ29uQ2hhbmdlJz4+ICZcbiAgUGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAncmVxdWlyZWQnPlxuXG5jb25zdCBSYWRpb0dyb3VwQ29udGV4dCA9IGNyZWF0ZUNvbnRleHQ8UmFkaW9Hcm91cENvbnRleHRUeXBlIHwgdW5kZWZpbmVkPihcbiAgdW5kZWZpbmVkLFxuKVxuXG50eXBlIFJhZGlvR3JvdXBSYWRpb1Byb3BzID0gT21pdDxcbiAgQ29tcG9uZW50UHJvcHM8dHlwZW9mIFJhZGlvPixcbiAgJ29uQ2hhbmdlJyB8ICdjaGVja2VkJyB8ICdyZXF1aXJlZCdcbj4gJiB7XG4gIC8qKlxuICAgKiBAZGVwcmVjYXRlZCB5b3UgZG9uJ3QgbmVlZCB0byB1c2UgYG5hbWVgIGFueW1vcmUsIHRoZSBuYW1lIHdpbGwgYmUgcGFzc2VkIGZyb20gdGhlIHBhcmVudCBgUmFkaW9Hcm91cGAuXG4gICAqL1xuICBuYW1lPzogc3RyaW5nXG59XG5cbmNvbnN0IFJhZGlvR3JvdXBSYWRpbyA9ICh7XG4gIG9uRm9jdXMsXG4gIG9uQmx1cixcbiAgZGlzYWJsZWQsXG4gIGVycm9yLFxuICBuYW1lLFxuICB2YWx1ZSxcbiAgbGFiZWwsXG4gIGhlbHBlcixcbiAgY2xhc3NOYW1lLFxuICBhdXRvRm9jdXMsXG4gIG9uS2V5RG93bixcbiAgdG9vbHRpcCxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbn06IFJhZGlvR3JvdXBSYWRpb1Byb3BzKSA9PiB7XG4gIGNvbnN0IGNvbnRleHQgPSB1c2VDb250ZXh0KFJhZGlvR3JvdXBDb250ZXh0KVxuXG4gIGlmICghY29udGV4dCkge1xuICAgIHRocm93IG5ldyBFcnJvcignUmFkaW9Hcm91cC5SYWRpbyBjYW4gb25seSBiZSB1c2VkIGluc2lkZSBhIFJhZGlvR3JvdXAnKVxuICB9XG5cbiAgY29uc3QgeyBncm91cE5hbWUsIG9uQ2hhbmdlLCBncm91cFZhbHVlIH0gPSBjb250ZXh0XG5cbiAgcmV0dXJuIChcbiAgICA8UmFkaW9cbiAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAgIGNoZWNrZWQ9e2dyb3VwVmFsdWUgPT09IHZhbHVlfVxuICAgICAgb25Gb2N1cz17b25Gb2N1c31cbiAgICAgIG9uQmx1cj17b25CbHVyfVxuICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgZXJyb3I9e2Vycm9yfVxuICAgICAgbmFtZT17Z3JvdXBOYW1lID8/IG5hbWV9XG4gICAgICB2YWx1ZT17dmFsdWV9XG4gICAgICBsYWJlbD17bGFiZWx9XG4gICAgICBoZWxwZXI9e2hlbHBlcn1cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgYXV0b0ZvY3VzPXthdXRvRm9jdXN9XG4gICAgICBvbktleURvd249e29uS2V5RG93bn1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgdG9vbHRpcD17dG9vbHRpcH1cbiAgICAvPlxuICApXG59XG5cbmNvbnN0IEZpZWxkU2V0ID0gc3R5bGVkLmZpZWxkc2V0YFxuICBib3JkZXI6IG5vbmU7XG4gIHBhZGRpbmc6IDA7XG4gIG1hcmdpbjogMDtcbmBcblxuY29uc3QgU3R5bGVkUmVxdWlyZWRJY29uID0gc3R5bGVkKEFzdGVyaXNrSWNvbilgXG4gIHZlcnRpY2FsLWFsaWduOiBzdXBlcjtcbmBcblxudHlwZSBSYWRpb0dyb3VwUHJvcHMgPSB7XG4gIGxlZ2VuZDogc3RyaW5nXG4gIHZhbHVlOiBzdHJpbmcgfCBudW1iZXJcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGhlbHBlcj86IFJlYWN0Tm9kZVxuICBlcnJvcj86IFJlYWN0Tm9kZVxuICBkaXJlY3Rpb24/OiAncm93JyB8ICdjb2x1bW4nXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbn0gJiBSZXF1aXJlZDxQaWNrPElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4sICdvbkNoYW5nZScgfCAnbmFtZSc+PiAmXG4gIFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ3JlcXVpcmVkJz5cblxuLyoqXG4gKiBSYWRpb0dyb3VwIGlzIGEgY29tcG9uZW50IHRoYXQgYWxsb3dzIHVzZXJzIHRvIHNlbGVjdCBvbmUgb3B0aW9uIGZyb20gYSBsaXN0IG9mIG9wdGlvbnMgdXNpbmcgcmFkaW8uXG4gKi9cbmV4cG9ydCBjb25zdCBSYWRpb0dyb3VwID0gKHtcbiAgbGVnZW5kLFxuICB2YWx1ZSxcbiAgY2xhc3NOYW1lLFxuICBoZWxwZXIsXG4gIGVycm9yLFxuICBkaXJlY3Rpb24gPSAnY29sdW1uJyxcbiAgY2hpbGRyZW4sXG4gIG9uQ2hhbmdlLFxuICBuYW1lLFxuICByZXF1aXJlZCA9IGZhbHNlLFxufTogUmFkaW9Hcm91cFByb3BzKSA9PiB7XG4gIGNvbnN0IGNvbnRleHRWYWx1ZSA9IHVzZU1lbW8oXG4gICAgKCkgPT4gKHtcbiAgICAgIGdyb3VwTmFtZTogbmFtZSxcbiAgICAgIGdyb3VwVmFsdWU6IHZhbHVlLFxuICAgICAgb25DaGFuZ2UsXG4gICAgICByZXF1aXJlZCxcbiAgICB9KSxcbiAgICBbbmFtZSwgdmFsdWUsIG9uQ2hhbmdlLCByZXF1aXJlZF0sXG4gIClcblxuICByZXR1cm4gKFxuICAgIDxSYWRpb0dyb3VwQ29udGV4dC5Qcm92aWRlciB2YWx1ZT17Y29udGV4dFZhbHVlfT5cbiAgICAgIDxTdGFjayBnYXA9ezF9PlxuICAgICAgICA8RmllbGRTZXQgY2xhc3NOYW1lPXtjbGFzc05hbWV9PlxuICAgICAgICAgIDxTdGFjayBnYXA9ezEuNX0+XG4gICAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgICBhcz1cImxlZ2VuZFwiXG4gICAgICAgICAgICAgIHZhcmlhbnQ9XCJib2R5U3Ryb25nXCJcbiAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgIHByb21pbmVuY2U9XCJzdHJvbmdcIlxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7bGVnZW5kfSZuYnNwO1xuICAgICAgICAgICAgICB7cmVxdWlyZWQgPyAoXG4gICAgICAgICAgICAgICAgPFN0eWxlZFJlcXVpcmVkSWNvbiBzZW50aW1lbnQ9XCJkYW5nZXJcIiBzaXplPXs4fSAvPlxuICAgICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICAgIDxTdGFja1xuICAgICAgICAgICAgICBnYXA9e2RpcmVjdGlvbiA9PT0gJ2NvbHVtbicgPyAxIDogMn1cbiAgICAgICAgICAgICAgZGlyZWN0aW9uPXtkaXJlY3Rpb259XG4gICAgICAgICAgICAgIGFsaWduSXRlbXM9XCJzdGFydFwiXG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgPC9GaWVsZFNldD5cbiAgICAgICAge2hlbHBlciA/IChcbiAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgYXM9XCJzcGFuXCJcbiAgICAgICAgICAgIHZhcmlhbnQ9XCJjYXB0aW9uXCJcbiAgICAgICAgICAgIHByb21pbmVuY2U9XCJ3ZWFrXCJcbiAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtoZWxwZXJ9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICApIDogbnVsbH1cbiAgICAgICAge2Vycm9yID8gKFxuICAgICAgICAgIDxUZXh0IGFzPVwic3BhblwiIHZhcmlhbnQ9XCJjYXB0aW9uXCIgc2VudGltZW50PVwiZGFuZ2VyXCI+XG4gICAgICAgICAgICB7ZXJyb3J9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvU3RhY2s+XG4gICAgPC9SYWRpb0dyb3VwQ29udGV4dC5Qcm92aWRlcj5cbiAgKVxufVxuXG5SYWRpb0dyb3VwLlJhZGlvID0gUmFkaW9Hcm91cFJhZGlvXG4iXX0= */",
50
50
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
51
51
  });
52
- const StyledRequiredIcon = /* @__PURE__ */ _styled(Icon, process.env.NODE_ENV === "production" ? {
52
+ const StyledRequiredIcon = /* @__PURE__ */ _styled(AsteriskIcon, process.env.NODE_ENV === "production" ? {
53
53
  target: "e15shfap0"
54
54
  } : {
55
55
  target: "e15shfap0",
@@ -60,7 +60,7 @@ const StyledRequiredIcon = /* @__PURE__ */ _styled(Icon, process.env.NODE_ENV ==
60
60
  } : {
61
61
  name: "1nglpc5",
62
62
  styles: "vertical-align:super",
63
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1JhZGlvR3JvdXAvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9GdUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvUmFkaW9Hcm91cC9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IEljb24gfSBmcm9tICdAdWx0cmF2aW9sZXQvaWNvbnMvbGVnYWN5J1xuaW1wb3J0IHtcbiAgdHlwZSBDb21wb25lbnRQcm9wcyxcbiAgdHlwZSBJbnB1dEhUTUxBdHRyaWJ1dGVzLFxuICB0eXBlIFJlYWN0Tm9kZSxcbiAgY3JlYXRlQ29udGV4dCxcbiAgdXNlQ29udGV4dCxcbiAgdXNlTWVtbyxcbn0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBSYWRpbyB9IGZyb20gJy4uL1JhZGlvJ1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tICcuLi9TdGFjaydcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuXG50eXBlIFJhZGlvR3JvdXBDb250ZXh0VHlwZSA9IHtcbiAgZ3JvdXBOYW1lOiBzdHJpbmdcbiAgZ3JvdXBWYWx1ZTogc3RyaW5nIHwgbnVtYmVyXG59ICYgUmVxdWlyZWQ8UGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAnb25DaGFuZ2UnPj4gJlxuICBQaWNrPElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4sICdyZXF1aXJlZCc+XG5cbmNvbnN0IFJhZGlvR3JvdXBDb250ZXh0ID0gY3JlYXRlQ29udGV4dDxSYWRpb0dyb3VwQ29udGV4dFR5cGUgfCB1bmRlZmluZWQ+KFxuICB1bmRlZmluZWQsXG4pXG5cbnR5cGUgUmFkaW9Hcm91cFJhZGlvUHJvcHMgPSBPbWl0PFxuICBDb21wb25lbnRQcm9wczx0eXBlb2YgUmFkaW8+LFxuICAnb25DaGFuZ2UnIHwgJ2NoZWNrZWQnIHwgJ3JlcXVpcmVkJ1xuPiAmIHtcbiAgLyoqXG4gICAqIEBkZXByZWNhdGVkIHlvdSBkb24ndCBuZWVkIHRvIHVzZSBgbmFtZWAgYW55bW9yZSwgdGhlIG5hbWUgd2lsbCBiZSBwYXNzZWQgZnJvbSB0aGUgcGFyZW50IGBSYWRpb0dyb3VwYC5cbiAgICovXG4gIG5hbWU/OiBzdHJpbmdcbn1cblxuY29uc3QgUmFkaW9Hcm91cFJhZGlvID0gKHtcbiAgb25Gb2N1cyxcbiAgb25CbHVyLFxuICBkaXNhYmxlZCxcbiAgZXJyb3IsXG4gIG5hbWUsXG4gIHZhbHVlLFxuICBsYWJlbCxcbiAgaGVscGVyLFxuICBjbGFzc05hbWUsXG4gIGF1dG9Gb2N1cyxcbiAgb25LZXlEb3duLFxuICB0b29sdGlwLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxufTogUmFkaW9Hcm91cFJhZGlvUHJvcHMpID0+IHtcbiAgY29uc3QgY29udGV4dCA9IHVzZUNvbnRleHQoUmFkaW9Hcm91cENvbnRleHQpXG5cbiAgaWYgKCFjb250ZXh0KSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdSYWRpb0dyb3VwLlJhZGlvIGNhbiBvbmx5IGJlIHVzZWQgaW5zaWRlIGEgUmFkaW9Hcm91cCcpXG4gIH1cblxuICBjb25zdCB7IGdyb3VwTmFtZSwgb25DaGFuZ2UsIGdyb3VwVmFsdWUgfSA9IGNvbnRleHRcblxuICByZXR1cm4gKFxuICAgIDxSYWRpb1xuICAgICAgb25DaGFuZ2U9e29uQ2hhbmdlfVxuICAgICAgY2hlY2tlZD17Z3JvdXBWYWx1ZSA9PT0gdmFsdWV9XG4gICAgICBvbkZvY3VzPXtvbkZvY3VzfVxuICAgICAgb25CbHVyPXtvbkJsdXJ9XG4gICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICBlcnJvcj17ZXJyb3J9XG4gICAgICBuYW1lPXtncm91cE5hbWUgPz8gbmFtZX1cbiAgICAgIHZhbHVlPXt2YWx1ZX1cbiAgICAgIGxhYmVsPXtsYWJlbH1cbiAgICAgIGhlbHBlcj17aGVscGVyfVxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBhdXRvRm9jdXM9e2F1dG9Gb2N1c31cbiAgICAgIG9uS2V5RG93bj17b25LZXlEb3dufVxuICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICB0b29sdGlwPXt0b29sdGlwfVxuICAgIC8+XG4gIClcbn1cblxuY29uc3QgRmllbGRTZXQgPSBzdHlsZWQuZmllbGRzZXRgXG4gIGJvcmRlcjogbm9uZTtcbiAgcGFkZGluZzogMDtcbiAgbWFyZ2luOiAwO1xuYFxuXG5jb25zdCBTdHlsZWRSZXF1aXJlZEljb24gPSBzdHlsZWQoSWNvbilgXG4gIHZlcnRpY2FsLWFsaWduOiBzdXBlcjtcbmBcblxudHlwZSBSYWRpb0dyb3VwUHJvcHMgPSB7XG4gIGxlZ2VuZDogc3RyaW5nXG4gIHZhbHVlOiBzdHJpbmcgfCBudW1iZXJcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGhlbHBlcj86IFJlYWN0Tm9kZVxuICBlcnJvcj86IFJlYWN0Tm9kZVxuICBkaXJlY3Rpb24/OiAncm93JyB8ICdjb2x1bW4nXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbn0gJiBSZXF1aXJlZDxQaWNrPElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4sICdvbkNoYW5nZScgfCAnbmFtZSc+PiAmXG4gIFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ3JlcXVpcmVkJz5cblxuLyoqXG4gKiBSYWRpb0dyb3VwIGlzIGEgY29tcG9uZW50IHRoYXQgYWxsb3dzIHVzZXJzIHRvIHNlbGVjdCBvbmUgb3B0aW9uIGZyb20gYSBsaXN0IG9mIG9wdGlvbnMgdXNpbmcgcmFkaW8uXG4gKi9cbmV4cG9ydCBjb25zdCBSYWRpb0dyb3VwID0gKHtcbiAgbGVnZW5kLFxuICB2YWx1ZSxcbiAgY2xhc3NOYW1lLFxuICBoZWxwZXIsXG4gIGVycm9yLFxuICBkaXJlY3Rpb24gPSAnY29sdW1uJyxcbiAgY2hpbGRyZW4sXG4gIG9uQ2hhbmdlLFxuICBuYW1lLFxuICByZXF1aXJlZCA9IGZhbHNlLFxufTogUmFkaW9Hcm91cFByb3BzKSA9PiB7XG4gIGNvbnN0IGNvbnRleHRWYWx1ZSA9IHVzZU1lbW8oXG4gICAgKCkgPT4gKHtcbiAgICAgIGdyb3VwTmFtZTogbmFtZSxcbiAgICAgIGdyb3VwVmFsdWU6IHZhbHVlLFxuICAgICAgb25DaGFuZ2UsXG4gICAgICByZXF1aXJlZCxcbiAgICB9KSxcbiAgICBbbmFtZSwgdmFsdWUsIG9uQ2hhbmdlLCByZXF1aXJlZF0sXG4gIClcblxuICByZXR1cm4gKFxuICAgIDxSYWRpb0dyb3VwQ29udGV4dC5Qcm92aWRlciB2YWx1ZT17Y29udGV4dFZhbHVlfT5cbiAgICAgIDxTdGFjayBnYXA9ezF9PlxuICAgICAgICA8RmllbGRTZXQgY2xhc3NOYW1lPXtjbGFzc05hbWV9PlxuICAgICAgICAgIDxTdGFjayBnYXA9ezEuNX0+XG4gICAgICAgICAgICA8VGV4dCBhcz1cImxlZ2VuZFwiIHZhcmlhbnQ9XCJib2R5U3Ryb25nXCI+XG4gICAgICAgICAgICAgIHtsZWdlbmR9Jm5ic3A7XG4gICAgICAgICAgICAgIHtyZXF1aXJlZCA/IChcbiAgICAgICAgICAgICAgICA8U3R5bGVkUmVxdWlyZWRJY29uIG5hbWU9XCJhc3Rlcmlza1wiIGNvbG9yPVwiZGFuZ2VyXCIgc2l6ZT17OH0gLz5cbiAgICAgICAgICAgICAgKSA6IG51bGx9XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICA8U3RhY2tcbiAgICAgICAgICAgICAgZ2FwPXtkaXJlY3Rpb24gPT09ICdjb2x1bW4nID8gMSA6IDJ9XG4gICAgICAgICAgICAgIGRpcmVjdGlvbj17ZGlyZWN0aW9ufVxuICAgICAgICAgICAgICBhbGlnbkl0ZW1zPVwic3RhcnRcIlxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgICAgICA8L1N0YWNrPlxuICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgIDwvRmllbGRTZXQ+XG4gICAgICAgIHtoZWxwZXIgPyAoXG4gICAgICAgICAgPFRleHRcbiAgICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgICB2YXJpYW50PVwiY2FwdGlvblwiXG4gICAgICAgICAgICBwcm9taW5lbmNlPVwid2Vha1wiXG4gICAgICAgICAgICBzZW50aW1lbnQ9XCJuZXV0cmFsXCJcbiAgICAgICAgICA+XG4gICAgICAgICAgICB7aGVscGVyfVxuICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICAgIHtlcnJvciA/IChcbiAgICAgICAgICA8VGV4dCBhcz1cInNwYW5cIiB2YXJpYW50PVwiY2FwdGlvblwiIHNlbnRpbWVudD1cImRhbmdlclwiPlxuICAgICAgICAgICAge2Vycm9yfVxuICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICA8L1N0YWNrPlxuICAgIDwvUmFkaW9Hcm91cENvbnRleHQuUHJvdmlkZXI+XG4gIClcbn1cblxuUmFkaW9Hcm91cC5SYWRpbyA9IFJhZGlvR3JvdXBSYWRpb1xuIl19 */",
63
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1JhZGlvR3JvdXAvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9GK0MiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvUmFkaW9Hcm91cC9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IEFzdGVyaXNrSWNvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC9pY29ucydcbmltcG9ydCB7XG4gIHR5cGUgQ29tcG9uZW50UHJvcHMsXG4gIHR5cGUgSW5wdXRIVE1MQXR0cmlidXRlcyxcbiAgdHlwZSBSZWFjdE5vZGUsXG4gIGNyZWF0ZUNvbnRleHQsXG4gIHVzZUNvbnRleHQsXG4gIHVzZU1lbW8sXG59IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgUmFkaW8gfSBmcm9tICcuLi9SYWRpbydcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcblxudHlwZSBSYWRpb0dyb3VwQ29udGV4dFR5cGUgPSB7XG4gIGdyb3VwTmFtZTogc3RyaW5nXG4gIGdyb3VwVmFsdWU6IHN0cmluZyB8IG51bWJlclxufSAmIFJlcXVpcmVkPFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ29uQ2hhbmdlJz4+ICZcbiAgUGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAncmVxdWlyZWQnPlxuXG5jb25zdCBSYWRpb0dyb3VwQ29udGV4dCA9IGNyZWF0ZUNvbnRleHQ8UmFkaW9Hcm91cENvbnRleHRUeXBlIHwgdW5kZWZpbmVkPihcbiAgdW5kZWZpbmVkLFxuKVxuXG50eXBlIFJhZGlvR3JvdXBSYWRpb1Byb3BzID0gT21pdDxcbiAgQ29tcG9uZW50UHJvcHM8dHlwZW9mIFJhZGlvPixcbiAgJ29uQ2hhbmdlJyB8ICdjaGVja2VkJyB8ICdyZXF1aXJlZCdcbj4gJiB7XG4gIC8qKlxuICAgKiBAZGVwcmVjYXRlZCB5b3UgZG9uJ3QgbmVlZCB0byB1c2UgYG5hbWVgIGFueW1vcmUsIHRoZSBuYW1lIHdpbGwgYmUgcGFzc2VkIGZyb20gdGhlIHBhcmVudCBgUmFkaW9Hcm91cGAuXG4gICAqL1xuICBuYW1lPzogc3RyaW5nXG59XG5cbmNvbnN0IFJhZGlvR3JvdXBSYWRpbyA9ICh7XG4gIG9uRm9jdXMsXG4gIG9uQmx1cixcbiAgZGlzYWJsZWQsXG4gIGVycm9yLFxuICBuYW1lLFxuICB2YWx1ZSxcbiAgbGFiZWwsXG4gIGhlbHBlcixcbiAgY2xhc3NOYW1lLFxuICBhdXRvRm9jdXMsXG4gIG9uS2V5RG93bixcbiAgdG9vbHRpcCxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbn06IFJhZGlvR3JvdXBSYWRpb1Byb3BzKSA9PiB7XG4gIGNvbnN0IGNvbnRleHQgPSB1c2VDb250ZXh0KFJhZGlvR3JvdXBDb250ZXh0KVxuXG4gIGlmICghY29udGV4dCkge1xuICAgIHRocm93IG5ldyBFcnJvcignUmFkaW9Hcm91cC5SYWRpbyBjYW4gb25seSBiZSB1c2VkIGluc2lkZSBhIFJhZGlvR3JvdXAnKVxuICB9XG5cbiAgY29uc3QgeyBncm91cE5hbWUsIG9uQ2hhbmdlLCBncm91cFZhbHVlIH0gPSBjb250ZXh0XG5cbiAgcmV0dXJuIChcbiAgICA8UmFkaW9cbiAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAgIGNoZWNrZWQ9e2dyb3VwVmFsdWUgPT09IHZhbHVlfVxuICAgICAgb25Gb2N1cz17b25Gb2N1c31cbiAgICAgIG9uQmx1cj17b25CbHVyfVxuICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgZXJyb3I9e2Vycm9yfVxuICAgICAgbmFtZT17Z3JvdXBOYW1lID8/IG5hbWV9XG4gICAgICB2YWx1ZT17dmFsdWV9XG4gICAgICBsYWJlbD17bGFiZWx9XG4gICAgICBoZWxwZXI9e2hlbHBlcn1cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgYXV0b0ZvY3VzPXthdXRvRm9jdXN9XG4gICAgICBvbktleURvd249e29uS2V5RG93bn1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgdG9vbHRpcD17dG9vbHRpcH1cbiAgICAvPlxuICApXG59XG5cbmNvbnN0IEZpZWxkU2V0ID0gc3R5bGVkLmZpZWxkc2V0YFxuICBib3JkZXI6IG5vbmU7XG4gIHBhZGRpbmc6IDA7XG4gIG1hcmdpbjogMDtcbmBcblxuY29uc3QgU3R5bGVkUmVxdWlyZWRJY29uID0gc3R5bGVkKEFzdGVyaXNrSWNvbilgXG4gIHZlcnRpY2FsLWFsaWduOiBzdXBlcjtcbmBcblxudHlwZSBSYWRpb0dyb3VwUHJvcHMgPSB7XG4gIGxlZ2VuZDogc3RyaW5nXG4gIHZhbHVlOiBzdHJpbmcgfCBudW1iZXJcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGhlbHBlcj86IFJlYWN0Tm9kZVxuICBlcnJvcj86IFJlYWN0Tm9kZVxuICBkaXJlY3Rpb24/OiAncm93JyB8ICdjb2x1bW4nXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbn0gJiBSZXF1aXJlZDxQaWNrPElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4sICdvbkNoYW5nZScgfCAnbmFtZSc+PiAmXG4gIFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ3JlcXVpcmVkJz5cblxuLyoqXG4gKiBSYWRpb0dyb3VwIGlzIGEgY29tcG9uZW50IHRoYXQgYWxsb3dzIHVzZXJzIHRvIHNlbGVjdCBvbmUgb3B0aW9uIGZyb20gYSBsaXN0IG9mIG9wdGlvbnMgdXNpbmcgcmFkaW8uXG4gKi9cbmV4cG9ydCBjb25zdCBSYWRpb0dyb3VwID0gKHtcbiAgbGVnZW5kLFxuICB2YWx1ZSxcbiAgY2xhc3NOYW1lLFxuICBoZWxwZXIsXG4gIGVycm9yLFxuICBkaXJlY3Rpb24gPSAnY29sdW1uJyxcbiAgY2hpbGRyZW4sXG4gIG9uQ2hhbmdlLFxuICBuYW1lLFxuICByZXF1aXJlZCA9IGZhbHNlLFxufTogUmFkaW9Hcm91cFByb3BzKSA9PiB7XG4gIGNvbnN0IGNvbnRleHRWYWx1ZSA9IHVzZU1lbW8oXG4gICAgKCkgPT4gKHtcbiAgICAgIGdyb3VwTmFtZTogbmFtZSxcbiAgICAgIGdyb3VwVmFsdWU6IHZhbHVlLFxuICAgICAgb25DaGFuZ2UsXG4gICAgICByZXF1aXJlZCxcbiAgICB9KSxcbiAgICBbbmFtZSwgdmFsdWUsIG9uQ2hhbmdlLCByZXF1aXJlZF0sXG4gIClcblxuICByZXR1cm4gKFxuICAgIDxSYWRpb0dyb3VwQ29udGV4dC5Qcm92aWRlciB2YWx1ZT17Y29udGV4dFZhbHVlfT5cbiAgICAgIDxTdGFjayBnYXA9ezF9PlxuICAgICAgICA8RmllbGRTZXQgY2xhc3NOYW1lPXtjbGFzc05hbWV9PlxuICAgICAgICAgIDxTdGFjayBnYXA9ezEuNX0+XG4gICAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgICBhcz1cImxlZ2VuZFwiXG4gICAgICAgICAgICAgIHZhcmlhbnQ9XCJib2R5U3Ryb25nXCJcbiAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgIHByb21pbmVuY2U9XCJzdHJvbmdcIlxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7bGVnZW5kfSZuYnNwO1xuICAgICAgICAgICAgICB7cmVxdWlyZWQgPyAoXG4gICAgICAgICAgICAgICAgPFN0eWxlZFJlcXVpcmVkSWNvbiBzZW50aW1lbnQ9XCJkYW5nZXJcIiBzaXplPXs4fSAvPlxuICAgICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICAgIDxTdGFja1xuICAgICAgICAgICAgICBnYXA9e2RpcmVjdGlvbiA9PT0gJ2NvbHVtbicgPyAxIDogMn1cbiAgICAgICAgICAgICAgZGlyZWN0aW9uPXtkaXJlY3Rpb259XG4gICAgICAgICAgICAgIGFsaWduSXRlbXM9XCJzdGFydFwiXG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgPC9GaWVsZFNldD5cbiAgICAgICAge2hlbHBlciA/IChcbiAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgYXM9XCJzcGFuXCJcbiAgICAgICAgICAgIHZhcmlhbnQ9XCJjYXB0aW9uXCJcbiAgICAgICAgICAgIHByb21pbmVuY2U9XCJ3ZWFrXCJcbiAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtoZWxwZXJ9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICApIDogbnVsbH1cbiAgICAgICAge2Vycm9yID8gKFxuICAgICAgICAgIDxUZXh0IGFzPVwic3BhblwiIHZhcmlhbnQ9XCJjYXB0aW9uXCIgc2VudGltZW50PVwiZGFuZ2VyXCI+XG4gICAgICAgICAgICB7ZXJyb3J9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvU3RhY2s+XG4gICAgPC9SYWRpb0dyb3VwQ29udGV4dC5Qcm92aWRlcj5cbiAgKVxufVxuXG5SYWRpb0dyb3VwLlJhZGlvID0gUmFkaW9Hcm91cFJhZGlvXG4iXX0= */",
64
64
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
65
65
  });
66
66
  const RadioGroup = ({
@@ -83,10 +83,10 @@ const RadioGroup = ({
83
83
  }), [name, value, onChange, required]);
84
84
  return /* @__PURE__ */ jsx(RadioGroupContext.Provider, { value: contextValue, children: /* @__PURE__ */ jsxs(Stack, { gap: 1, children: [
85
85
  /* @__PURE__ */ jsx(FieldSet, { className, children: /* @__PURE__ */ jsxs(Stack, { gap: 1.5, children: [
86
- /* @__PURE__ */ jsxs(Text, { as: "legend", variant: "bodyStrong", children: [
86
+ /* @__PURE__ */ jsxs(Text, { as: "legend", variant: "bodyStrong", sentiment: "neutral", prominence: "strong", children: [
87
87
  legend,
88
88
  " ",
89
- required ? /* @__PURE__ */ jsx(StyledRequiredIcon, { name: "asterisk", color: "danger", size: 8 }) : null
89
+ required ? /* @__PURE__ */ jsx(StyledRequiredIcon, { sentiment: "danger", size: 8 }) : null
90
90
  ] }),
91
91
  /* @__PURE__ */ jsx(Stack, { gap: direction === "column" ? 1 : 2, direction, alignItems: "start", children })
92
92
  ] }) }),
@@ -2,7 +2,7 @@
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const jsxRuntime = require("@emotion/react/jsx-runtime");
4
4
  const _styled = require("@emotion/styled/base");
5
- const legacy = require("@ultraviolet/icons/legacy");
5
+ const icons = require("@ultraviolet/icons");
6
6
  const React = require("react");
7
7
  const index$4 = require("../Button/index.cjs");
8
8
  const index = require("../Stack/index.cjs");
@@ -24,7 +24,7 @@ const StateStack = /* @__PURE__ */ _styled__default.default(index.Stack, process
24
24
  label: "StateStack"
25
25
  })("padding-right:", ({
26
26
  theme
27
- }) => theme.space["2"], ";display:flex;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInputV2/SelectBar.tsx"],"names":[],"mappings":"AAwCgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInputV2/SelectBar.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons/legacy'\nimport type { RefObject } from 'react'\nimport { useEffect, useMemo, useRef, useState } from 'react'\nimport { Button } from '../Button'\nimport { Stack } from '../Stack'\nimport { Tag } from '../Tag'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\nimport { useSelectInput } from './SelectInputProvider'\nimport { findOptionInOptions } from './findOptionInOptions'\nimport type { DataType, OptionType } from './types'\nimport { INPUT_SIZE_HEIGHT, SIZES_TAG } from './types'\n\ntype SelectBarProps = {\n  size: 'small' | 'medium' | 'large'\n  clearable: boolean\n  disabled: boolean\n  readOnly: boolean\n  placeholder: string\n  success?: string\n  error?: string\n  autoFocus?: boolean\n  innerRef: RefObject<HTMLDivElement>\n  id?: string\n  'data-testid': string\n  label?: string\n  tooltip?: string\n}\n\ntype DisplayValuesProps = {\n  refTag: RefObject<HTMLDivElement>\n  nonOverflowedValues: OptionType[]\n  disabled: boolean\n  readOnly: boolean\n  overflowed: boolean\n  overflowAmount: number\n  size: 'small' | 'medium' | 'large'\n}\n\nconst StateStack = styled(Stack)`\n  padding-right: ${({ theme }) => theme.space['2']};\n  display: flex;\n`\nconst Placeholder = styled(Text)`\nuser-select: none;\n`\n\nconst StyledInputWrapper = styled(Stack)<{\n  'data-readonly': boolean\n  'data-disabled': boolean\n  'data-size': 'small' | 'medium' | 'large'\n  'data-state': 'neutral' | 'success' | 'danger'\n  'data-dropdownvisible': boolean\n  'aria-label'?: string\n}>`\n  display: flex;\n  padding: ${({ theme }) => theme.space[1]};\n  padding-right: 0;\n  padding-left: ${({ theme }) => theme.space[2]};\n  cursor: pointer;\n  box-shadow: none;\n  background: ${({ theme }) => theme.colors.neutral.background};\n  border-radius: ${({ theme }) => theme.radii.default};\n  width: 100%;\n  overflow: hidden;\n\n  &[data-size='small'] {\n    height: ${INPUT_SIZE_HEIGHT.small}px;\n    padding-left: ${({ theme }) => theme.space[1]};\n  }\n  &[data-size='medium'] {\n    height: ${INPUT_SIZE_HEIGHT.medium}px;\n  }\n  &[data-size='large'] {\n    height: ${INPUT_SIZE_HEIGHT.large}px;\n  }\n  &[data-state='neutral'] {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n    &:not([data-disabled='true']):hover,\n    :not([data-disabled='true']):focus {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      outline: none;\n    }\n\n    &[data-dropdownvisible='true'] {\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n  }\n  }\n\n  &[data-state='success'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.success.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n    }\n  \n    &[data-dropdownvisible='true'] {\n      border-color: ${({ theme }) => theme.colors.success.borderHover};\n    }\n  }\n\n  &[data-state='danger'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.danger.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n  \n    &[data-dropdownvisible='true'] {\n      border-color: ${({ theme }) => theme.colors.danger.borderHover};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly]):hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n  }\n`\nconst CustomTag = styled(Tag)`\n  height: fit-content;\n  width: fit-content;\n`\nconst SelectedValues = styled(Text)`\ntext-overflow: ellipsis;\noverflow: hidden; \n`\n\nconst isValidSelectedValue = (selectedValue: string, options: DataType) =>\n  !Array.isArray(options)\n    ? Object.keys(options).some(group =>\n        options[group].some(\n          option => option.value === selectedValue && !option.disabled,\n        ),\n      )\n    : options.some(option => option.value === selectedValue && !option.disabled)\n\nconst DisplayValues = ({\n  refTag,\n  nonOverflowedValues,\n  disabled,\n  readOnly,\n  overflowed,\n  overflowAmount,\n  size,\n}: DisplayValuesProps) => {\n  const { multiselect, selectedData, setSelectedData, options, onChange } =\n    useSelectInput()\n\n  return multiselect ? (\n    <Stack\n      direction=\"row\"\n      gap=\"1\"\n      wrap=\"nowrap\"\n      ref={refTag}\n      alignItems=\"center\"\n    >\n      {nonOverflowedValues.map(option => (\n        <CustomTag\n          data-testid=\"selected-options-tags\"\n          key={option?.value}\n          sentiment=\"neutral\"\n          disabled={disabled}\n          onClose={\n            !readOnly\n              ? event => {\n                  event.stopPropagation()\n                  setSelectedData({\n                    type: 'selectOption',\n                    clickedOption: option,\n                  })\n                  const newSelectedValues = selectedData.selectedValues?.filter(\n                    val => val !== option.value,\n                  )\n                  onChange?.(newSelectedValues)\n                }\n              : undefined\n          }\n        >\n          {option?.label}\n        </CustomTag>\n      ))}\n      {overflowed ? (\n        <Tag\n          sentiment=\"neutral\"\n          disabled={disabled}\n          key=\"+\"\n          data-testid=\"plus-tag\"\n          aria-label=\"Plus tag\"\n        >\n          <Icon name=\"plus\" />\n          {overflowAmount}\n        </Tag>\n      ) : null}\n    </Stack>\n  ) : (\n    <SelectedValues as=\"div\" variant={size === 'large' ? 'body' : 'bodySmall'}>\n      {selectedData.selectedValues[0]\n        ? findOptionInOptions(options, selectedData.selectedValues[0])?.label\n        : null}\n    </SelectedValues>\n  )\n}\n\nexport const SelectBar = ({\n  size,\n  clearable,\n  disabled,\n  readOnly,\n  placeholder,\n  success,\n  error,\n  autoFocus,\n  tooltip,\n  innerRef,\n  id,\n  'data-testid': dataTestId,\n  label,\n}: SelectBarProps) => {\n  const {\n    isDropdownVisible,\n    onChange,\n    setIsDropdownVisible,\n    options,\n    selectedData,\n    setSelectedData,\n    multiselect,\n  } = useSelectInput()\n  const openable = !(readOnly || disabled)\n  const refTag = useRef<HTMLDivElement>(null)\n  const width = innerRef.current?.offsetWidth\n  const [overflowed, setOverflowed] = useState(false)\n  const [overflowAmount, setOverflowAmount] = useState(0)\n  const [nonOverflowedValues, setNonOverFlowedValues] = useState<OptionType[]>(\n    () => {\n      if (selectedData.selectedValues[0]) {\n        const firstSelectOption = findOptionInOptions(\n          options,\n          selectedData.selectedValues[0],\n        )\n\n        return firstSelectOption ? [firstSelectOption] : []\n      }\n\n      return []\n    },\n  )\n\n  const state = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    // When too many items are selected, too avoid overflow, compute the number of tags to display and add a + tag\n    let tagsWidth = 0\n    let computedOverflowAmount = 0\n    let computedNonOverflowedValues: OptionType[] = []\n    const newSelectedValues = selectedData.selectedValues.filter(\n      selectedValue => isValidSelectedValue(selectedValue, options),\n    )\n    for (const selectedValue of newSelectedValues) {\n      const selectedOption = findOptionInOptions(options, selectedValue)\n      if (\n        selectedOption?.label &&\n        width &&\n        isValidSelectedValue(selectedValue, options)\n      ) {\n        const lengthValue = selectedOption.value.length // Find a better way to find the number of displayed characters?\n        const totalTagWidth =\n          SIZES_TAG.tagWidth + SIZES_TAG.letterWidth * lengthValue\n        if (totalTagWidth + tagsWidth > width - 100) {\n          computedOverflowAmount += 1\n          setOverflowAmount(computedOverflowAmount)\n        } else {\n          computedNonOverflowedValues = [\n            ...computedNonOverflowedValues,\n            selectedOption,\n          ]\n          setNonOverFlowedValues(computedNonOverflowedValues)\n          tagsWidth += totalTagWidth\n        }\n      }\n    }\n    if (computedOverflowAmount === 0) {\n      setOverflowed(false)\n    } else {\n      setOverflowed(true)\n    }\n    setOverflowAmount(computedOverflowAmount)\n  }, [options, selectedData.selectedValues, width])\n\n  useEffect(() => {\n    setSelectedData({ type: 'update' })\n  }, [setSelectedData, options])\n\n  return (\n    <Tooltip text={tooltip}>\n      <StyledInputWrapper\n        role=\"combobox\"\n        id={id}\n        data-disabled={disabled}\n        data-readonly={readOnly}\n        data-size={size}\n        data-dropdownvisible={isDropdownVisible}\n        data-state={state}\n        direction=\"row\"\n        wrap=\"nowrap\"\n        gap=\"1\"\n        justifyContent=\"space-between\"\n        alignItems=\"center\"\n        onClick={\n          openable ? () => setIsDropdownVisible(!isDropdownVisible) : undefined\n        }\n        data-testid={dataTestId}\n        autoFocus={autoFocus}\n        onKeyDown={event => {\n          if (event.key === 'ArrowDown') {\n            if (!isDropdownVisible) {\n              setIsDropdownVisible(true)\n            } else {\n              document.getElementById(`option-0`)?.focus()\n            }\n          }\n\n          return ['Enter', ' '].includes(event.key) && openable\n            ? setIsDropdownVisible(!isDropdownVisible)\n            : null\n        }}\n        ref={innerRef}\n        aria-haspopup=\"listbox\"\n        aria-expanded={isDropdownVisible}\n        tabIndex={0}\n        aria-label={label}\n      >\n        {selectedData.selectedValues.length > 0 ? (\n          <DisplayValues\n            refTag={refTag}\n            nonOverflowedValues={nonOverflowedValues}\n            disabled={disabled}\n            readOnly={readOnly}\n            overflowed={overflowed}\n            overflowAmount={overflowAmount}\n            size={size}\n          />\n        ) : (\n          <Placeholder\n            as=\"p\"\n            variant={size === 'large' ? 'body' : 'bodySmall'}\n            sentiment=\"neutral\"\n            disabled={disabled}\n            prominence=\"weak\"\n          >\n            {placeholder}\n          </Placeholder>\n        )}\n        <StateStack direction=\"row\" gap={1} alignItems=\"center\">\n          {error ? <Icon name=\"alert\" sentiment=\"danger\" /> : null}\n          {success && !error ? (\n            <Icon name=\"checkbox-circle-outline\" sentiment=\"success\" />\n          ) : null}\n          {clearable && selectedData.selectedValues.length > 0 ? (\n            <Button\n              aria-label=\"clear value\"\n              disabled={disabled || !selectedData.selectedValues[0] || readOnly}\n              variant=\"ghost\"\n              size=\"small\"\n              icon=\"close\"\n              onClick={event => {\n                event.stopPropagation()\n                setSelectedData({ type: 'clearAll' })\n                if (multiselect) {\n                  onChange?.([])\n                } else {\n                  onChange?.('')\n                }\n              }}\n              sentiment=\"neutral\"\n              data-testid=\"clear-all\"\n            />\n          ) : null}\n          <Icon\n            aria-label=\"show dropdown\"\n            size=\"small\"\n            name=\"arrow-down\"\n            sentiment=\"neutral\"\n            disabled={disabled || readOnly}\n          />\n        </StateStack>\n      </StyledInputWrapper>\n    </Tooltip>\n  )\n}\n"]} */"));
27
+ }) => theme.space["2"], ";display:flex;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInputV2/SelectBar.tsx"],"names":[],"mappings":"AA6CgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInputV2/SelectBar.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport {\n  AlertCircleIcon,\n  ArrowDownIcon,\n  CheckCircleIcon,\n  PlusIcon,\n} from '@ultraviolet/icons'\nimport type { RefObject } from 'react'\nimport { useEffect, useMemo, useRef, useState } from 'react'\nimport { Button } from '../Button'\nimport { Stack } from '../Stack'\nimport { Tag } from '../Tag'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\nimport { useSelectInput } from './SelectInputProvider'\nimport { findOptionInOptions } from './findOptionInOptions'\nimport type { DataType, OptionType } from './types'\nimport { INPUT_SIZE_HEIGHT, SIZES_TAG } from './types'\n\ntype SelectBarProps = {\n  size: 'small' | 'medium' | 'large'\n  clearable: boolean\n  disabled: boolean\n  readOnly: boolean\n  placeholder: string\n  success?: string\n  error?: string\n  autoFocus?: boolean\n  innerRef: RefObject<HTMLDivElement>\n  id?: string\n  'data-testid': string\n  label?: string\n  tooltip?: string\n}\n\ntype DisplayValuesProps = {\n  refTag: RefObject<HTMLDivElement>\n  nonOverflowedValues: OptionType[]\n  disabled: boolean\n  readOnly: boolean\n  overflowed: boolean\n  overflowAmount: number\n  size: 'small' | 'medium' | 'large'\n}\n\nconst StateStack = styled(Stack)`\n  padding-right: ${({ theme }) => theme.space['2']};\n  display: flex;\n`\nconst Placeholder = styled(Text)`\nuser-select: none;\n`\n\nconst StyledInputWrapper = styled(Stack)<{\n  'data-readonly': boolean\n  'data-disabled': boolean\n  'data-size': 'small' | 'medium' | 'large'\n  'data-state': 'neutral' | 'success' | 'danger'\n  'data-dropdownvisible': boolean\n  'aria-label'?: string\n}>`\n  display: flex;\n  padding: ${({ theme }) => theme.space[1]};\n  padding-right: 0;\n  padding-left: ${({ theme }) => theme.space[2]};\n  cursor: pointer;\n  box-shadow: none;\n  background: ${({ theme }) => theme.colors.neutral.background};\n  border-radius: ${({ theme }) => theme.radii.default};\n  width: 100%;\n  overflow: hidden;\n\n  &[data-size='small'] {\n    height: ${INPUT_SIZE_HEIGHT.small}px;\n    padding-left: ${({ theme }) => theme.space[1]};\n  }\n  &[data-size='medium'] {\n    height: ${INPUT_SIZE_HEIGHT.medium}px;\n  }\n  &[data-size='large'] {\n    height: ${INPUT_SIZE_HEIGHT.large}px;\n  }\n  &[data-state='neutral'] {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n    &:not([data-disabled='true']):hover,\n    :not([data-disabled='true']):focus {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      outline: none;\n    }\n\n    &[data-dropdownvisible='true'] {\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n  }\n  }\n\n  &[data-state='success'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.success.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n    }\n  \n    &[data-dropdownvisible='true'] {\n      border-color: ${({ theme }) => theme.colors.success.borderHover};\n    }\n  }\n\n  &[data-state='danger'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.danger.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n  \n    &[data-dropdownvisible='true'] {\n      border-color: ${({ theme }) => theme.colors.danger.borderHover};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly]):hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n  }\n`\nconst CustomTag = styled(Tag)`\n  height: fit-content;\n  width: fit-content;\n`\nconst SelectedValues = styled(Text)`\ntext-overflow: ellipsis;\noverflow: hidden; \n`\n\nconst isValidSelectedValue = (selectedValue: string, options: DataType) =>\n  !Array.isArray(options)\n    ? Object.keys(options).some(group =>\n        options[group].some(\n          option => option.value === selectedValue && !option.disabled,\n        ),\n      )\n    : options.some(option => option.value === selectedValue && !option.disabled)\n\nconst DisplayValues = ({\n  refTag,\n  nonOverflowedValues,\n  disabled,\n  readOnly,\n  overflowed,\n  overflowAmount,\n  size,\n}: DisplayValuesProps) => {\n  const { multiselect, selectedData, setSelectedData, options, onChange } =\n    useSelectInput()\n\n  return multiselect ? (\n    <Stack\n      direction=\"row\"\n      gap=\"1\"\n      wrap=\"nowrap\"\n      ref={refTag}\n      alignItems=\"center\"\n    >\n      {nonOverflowedValues.map(option => (\n        <CustomTag\n          data-testid=\"selected-options-tags\"\n          key={option?.value}\n          sentiment=\"neutral\"\n          disabled={disabled}\n          onClose={\n            !readOnly\n              ? event => {\n                  event.stopPropagation()\n                  setSelectedData({\n                    type: 'selectOption',\n                    clickedOption: option,\n                  })\n                  const newSelectedValues = selectedData.selectedValues?.filter(\n                    val => val !== option.value,\n                  )\n                  onChange?.(newSelectedValues)\n                }\n              : undefined\n          }\n        >\n          {option?.label}\n        </CustomTag>\n      ))}\n      {overflowed ? (\n        <Tag\n          sentiment=\"neutral\"\n          disabled={disabled}\n          key=\"+\"\n          data-testid=\"plus-tag\"\n          aria-label=\"Plus tag\"\n        >\n          <PlusIcon />\n          {overflowAmount}\n        </Tag>\n      ) : null}\n    </Stack>\n  ) : (\n    <SelectedValues\n      as=\"div\"\n      variant={size === 'large' ? 'body' : 'bodySmall'}\n      disabled={disabled}\n      prominence=\"default\"\n      sentiment=\"neutral\"\n    >\n      {selectedData.selectedValues[0]\n        ? findOptionInOptions(options, selectedData.selectedValues[0])?.label\n        : null}\n    </SelectedValues>\n  )\n}\n\nexport const SelectBar = ({\n  size,\n  clearable,\n  disabled,\n  readOnly,\n  placeholder,\n  success,\n  error,\n  autoFocus,\n  tooltip,\n  innerRef,\n  id,\n  'data-testid': dataTestId,\n  label,\n}: SelectBarProps) => {\n  const {\n    isDropdownVisible,\n    onChange,\n    setIsDropdownVisible,\n    options,\n    selectedData,\n    setSelectedData,\n    multiselect,\n  } = useSelectInput()\n  const openable = !(readOnly || disabled)\n  const refTag = useRef<HTMLDivElement>(null)\n  const width = innerRef.current?.offsetWidth\n  const [overflowed, setOverflowed] = useState(false)\n  const [overflowAmount, setOverflowAmount] = useState(0)\n  const [nonOverflowedValues, setNonOverFlowedValues] = useState<OptionType[]>(\n    () => {\n      if (selectedData.selectedValues[0]) {\n        const firstSelectOption = findOptionInOptions(\n          options,\n          selectedData.selectedValues[0],\n        )\n\n        return firstSelectOption ? [firstSelectOption] : []\n      }\n\n      return []\n    },\n  )\n\n  const state = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    // When too many items are selected, too avoid overflow, compute the number of tags to display and add a + tag\n    let tagsWidth = 0\n    let computedOverflowAmount = 0\n    let computedNonOverflowedValues: OptionType[] = []\n    const newSelectedValues = selectedData.selectedValues.filter(\n      selectedValue => isValidSelectedValue(selectedValue, options),\n    )\n    for (const selectedValue of newSelectedValues) {\n      const selectedOption = findOptionInOptions(options, selectedValue)\n      if (\n        selectedOption?.label &&\n        width &&\n        isValidSelectedValue(selectedValue, options)\n      ) {\n        const lengthValue = selectedOption.value.length // Find a better way to find the number of displayed characters?\n        const totalTagWidth =\n          SIZES_TAG.tagWidth + SIZES_TAG.letterWidth * lengthValue\n        if (totalTagWidth + tagsWidth > width - 100) {\n          computedOverflowAmount += 1\n          setOverflowAmount(computedOverflowAmount)\n        } else {\n          computedNonOverflowedValues = [\n            ...computedNonOverflowedValues,\n            selectedOption,\n          ]\n          setNonOverFlowedValues(computedNonOverflowedValues)\n          tagsWidth += totalTagWidth\n        }\n      }\n    }\n    if (computedOverflowAmount === 0) {\n      setOverflowed(false)\n    } else {\n      setOverflowed(true)\n    }\n    setOverflowAmount(computedOverflowAmount)\n  }, [options, selectedData.selectedValues, width])\n\n  useEffect(() => {\n    setSelectedData({ type: 'update' })\n  }, [setSelectedData, options])\n\n  return (\n    <Tooltip text={tooltip}>\n      <StyledInputWrapper\n        role=\"combobox\"\n        id={id}\n        data-disabled={disabled}\n        data-readonly={readOnly}\n        data-size={size}\n        data-dropdownvisible={isDropdownVisible}\n        data-state={state}\n        direction=\"row\"\n        wrap=\"nowrap\"\n        gap=\"1\"\n        justifyContent=\"space-between\"\n        alignItems=\"center\"\n        onClick={\n          openable ? () => setIsDropdownVisible(!isDropdownVisible) : undefined\n        }\n        data-testid={dataTestId}\n        autoFocus={autoFocus}\n        onKeyDown={event => {\n          if (event.key === 'ArrowDown') {\n            if (!isDropdownVisible) {\n              setIsDropdownVisible(true)\n            } else {\n              document.getElementById(`option-0`)?.focus()\n            }\n          }\n\n          return ['Enter', ' '].includes(event.key) && openable\n            ? setIsDropdownVisible(!isDropdownVisible)\n            : null\n        }}\n        ref={innerRef}\n        aria-haspopup=\"listbox\"\n        aria-expanded={isDropdownVisible}\n        tabIndex={0}\n        aria-label={label}\n      >\n        {selectedData.selectedValues.length > 0 ? (\n          <DisplayValues\n            refTag={refTag}\n            nonOverflowedValues={nonOverflowedValues}\n            disabled={disabled}\n            readOnly={readOnly}\n            overflowed={overflowed}\n            overflowAmount={overflowAmount}\n            size={size}\n          />\n        ) : (\n          <Placeholder\n            as=\"p\"\n            variant={size === 'large' ? 'body' : 'bodySmall'}\n            sentiment=\"neutral\"\n            disabled={disabled}\n            prominence=\"weak\"\n          >\n            {placeholder}\n          </Placeholder>\n        )}\n        <StateStack direction=\"row\" gap={1} alignItems=\"center\">\n          {error ? <AlertCircleIcon sentiment=\"danger\" /> : null}\n          {success && !error ? <CheckCircleIcon sentiment=\"success\" /> : null}\n          {clearable && selectedData.selectedValues.length > 0 ? (\n            <Button\n              aria-label=\"clear value\"\n              disabled={disabled || !selectedData.selectedValues[0] || readOnly}\n              variant=\"ghost\"\n              size=\"small\"\n              icon=\"close\"\n              onClick={event => {\n                event.stopPropagation()\n                setSelectedData({ type: 'clearAll' })\n                if (multiselect) {\n                  onChange?.([])\n                } else {\n                  onChange?.('')\n                }\n              }}\n              sentiment=\"neutral\"\n              data-testid=\"clear-all\"\n            />\n          ) : null}\n          <ArrowDownIcon\n            aria-label=\"show dropdown\"\n            size=\"small\"\n            sentiment=\"neutral\"\n            disabled={disabled || readOnly}\n          />\n        </StateStack>\n      </StyledInputWrapper>\n    </Tooltip>\n  )\n}\n"]} */"));
28
28
  const Placeholder = /* @__PURE__ */ _styled__default.default(index$1.Text, process.env.NODE_ENV === "production" ? {
29
29
  target: "ejy0aca3"
30
30
  } : {
@@ -36,7 +36,7 @@ const Placeholder = /* @__PURE__ */ _styled__default.default(index$1.Text, proce
36
36
  } : {
37
37
  name: "oldbq4",
38
38
  styles: "user-select:none",
39
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInputV2/SelectBar.tsx"],"names":[],"mappings":"AA4CgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInputV2/SelectBar.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons/legacy'\nimport type { RefObject } from 'react'\nimport { useEffect, useMemo, useRef, useState } from 'react'\nimport { Button } from '../Button'\nimport { Stack } from '../Stack'\nimport { Tag } from '../Tag'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\nimport { useSelectInput } from './SelectInputProvider'\nimport { findOptionInOptions } from './findOptionInOptions'\nimport type { DataType, OptionType } from './types'\nimport { INPUT_SIZE_HEIGHT, SIZES_TAG } from './types'\n\ntype SelectBarProps = {\n  size: 'small' | 'medium' | 'large'\n  clearable: boolean\n  disabled: boolean\n  readOnly: boolean\n  placeholder: string\n  success?: string\n  error?: string\n  autoFocus?: boolean\n  innerRef: RefObject<HTMLDivElement>\n  id?: string\n  'data-testid': string\n  label?: string\n  tooltip?: string\n}\n\ntype DisplayValuesProps = {\n  refTag: RefObject<HTMLDivElement>\n  nonOverflowedValues: OptionType[]\n  disabled: boolean\n  readOnly: boolean\n  overflowed: boolean\n  overflowAmount: number\n  size: 'small' | 'medium' | 'large'\n}\n\nconst StateStack = styled(Stack)`\n  padding-right: ${({ theme }) => theme.space['2']};\n  display: flex;\n`\nconst Placeholder = styled(Text)`\nuser-select: none;\n`\n\nconst StyledInputWrapper = styled(Stack)<{\n  'data-readonly': boolean\n  'data-disabled': boolean\n  'data-size': 'small' | 'medium' | 'large'\n  'data-state': 'neutral' | 'success' | 'danger'\n  'data-dropdownvisible': boolean\n  'aria-label'?: string\n}>`\n  display: flex;\n  padding: ${({ theme }) => theme.space[1]};\n  padding-right: 0;\n  padding-left: ${({ theme }) => theme.space[2]};\n  cursor: pointer;\n  box-shadow: none;\n  background: ${({ theme }) => theme.colors.neutral.background};\n  border-radius: ${({ theme }) => theme.radii.default};\n  width: 100%;\n  overflow: hidden;\n\n  &[data-size='small'] {\n    height: ${INPUT_SIZE_HEIGHT.small}px;\n    padding-left: ${({ theme }) => theme.space[1]};\n  }\n  &[data-size='medium'] {\n    height: ${INPUT_SIZE_HEIGHT.medium}px;\n  }\n  &[data-size='large'] {\n    height: ${INPUT_SIZE_HEIGHT.large}px;\n  }\n  &[data-state='neutral'] {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n    &:not([data-disabled='true']):hover,\n    :not([data-disabled='true']):focus {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      outline: none;\n    }\n\n    &[data-dropdownvisible='true'] {\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n  }\n  }\n\n  &[data-state='success'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.success.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n    }\n  \n    &[data-dropdownvisible='true'] {\n      border-color: ${({ theme }) => theme.colors.success.borderHover};\n    }\n  }\n\n  &[data-state='danger'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.danger.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n  \n    &[data-dropdownvisible='true'] {\n      border-color: ${({ theme }) => theme.colors.danger.borderHover};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly]):hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n  }\n`\nconst CustomTag = styled(Tag)`\n  height: fit-content;\n  width: fit-content;\n`\nconst SelectedValues = styled(Text)`\ntext-overflow: ellipsis;\noverflow: hidden; \n`\n\nconst isValidSelectedValue = (selectedValue: string, options: DataType) =>\n  !Array.isArray(options)\n    ? Object.keys(options).some(group =>\n        options[group].some(\n          option => option.value === selectedValue && !option.disabled,\n        ),\n      )\n    : options.some(option => option.value === selectedValue && !option.disabled)\n\nconst DisplayValues = ({\n  refTag,\n  nonOverflowedValues,\n  disabled,\n  readOnly,\n  overflowed,\n  overflowAmount,\n  size,\n}: DisplayValuesProps) => {\n  const { multiselect, selectedData, setSelectedData, options, onChange } =\n    useSelectInput()\n\n  return multiselect ? (\n    <Stack\n      direction=\"row\"\n      gap=\"1\"\n      wrap=\"nowrap\"\n      ref={refTag}\n      alignItems=\"center\"\n    >\n      {nonOverflowedValues.map(option => (\n        <CustomTag\n          data-testid=\"selected-options-tags\"\n          key={option?.value}\n          sentiment=\"neutral\"\n          disabled={disabled}\n          onClose={\n            !readOnly\n              ? event => {\n                  event.stopPropagation()\n                  setSelectedData({\n                    type: 'selectOption',\n                    clickedOption: option,\n                  })\n                  const newSelectedValues = selectedData.selectedValues?.filter(\n                    val => val !== option.value,\n                  )\n                  onChange?.(newSelectedValues)\n                }\n              : undefined\n          }\n        >\n          {option?.label}\n        </CustomTag>\n      ))}\n      {overflowed ? (\n        <Tag\n          sentiment=\"neutral\"\n          disabled={disabled}\n          key=\"+\"\n          data-testid=\"plus-tag\"\n          aria-label=\"Plus tag\"\n        >\n          <Icon name=\"plus\" />\n          {overflowAmount}\n        </Tag>\n      ) : null}\n    </Stack>\n  ) : (\n    <SelectedValues as=\"div\" variant={size === 'large' ? 'body' : 'bodySmall'}>\n      {selectedData.selectedValues[0]\n        ? findOptionInOptions(options, selectedData.selectedValues[0])?.label\n        : null}\n    </SelectedValues>\n  )\n}\n\nexport const SelectBar = ({\n  size,\n  clearable,\n  disabled,\n  readOnly,\n  placeholder,\n  success,\n  error,\n  autoFocus,\n  tooltip,\n  innerRef,\n  id,\n  'data-testid': dataTestId,\n  label,\n}: SelectBarProps) => {\n  const {\n    isDropdownVisible,\n    onChange,\n    setIsDropdownVisible,\n    options,\n    selectedData,\n    setSelectedData,\n    multiselect,\n  } = useSelectInput()\n  const openable = !(readOnly || disabled)\n  const refTag = useRef<HTMLDivElement>(null)\n  const width = innerRef.current?.offsetWidth\n  const [overflowed, setOverflowed] = useState(false)\n  const [overflowAmount, setOverflowAmount] = useState(0)\n  const [nonOverflowedValues, setNonOverFlowedValues] = useState<OptionType[]>(\n    () => {\n      if (selectedData.selectedValues[0]) {\n        const firstSelectOption = findOptionInOptions(\n          options,\n          selectedData.selectedValues[0],\n        )\n\n        return firstSelectOption ? [firstSelectOption] : []\n      }\n\n      return []\n    },\n  )\n\n  const state = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    // When too many items are selected, too avoid overflow, compute the number of tags to display and add a + tag\n    let tagsWidth = 0\n    let computedOverflowAmount = 0\n    let computedNonOverflowedValues: OptionType[] = []\n    const newSelectedValues = selectedData.selectedValues.filter(\n      selectedValue => isValidSelectedValue(selectedValue, options),\n    )\n    for (const selectedValue of newSelectedValues) {\n      const selectedOption = findOptionInOptions(options, selectedValue)\n      if (\n        selectedOption?.label &&\n        width &&\n        isValidSelectedValue(selectedValue, options)\n      ) {\n        const lengthValue = selectedOption.value.length // Find a better way to find the number of displayed characters?\n        const totalTagWidth =\n          SIZES_TAG.tagWidth + SIZES_TAG.letterWidth * lengthValue\n        if (totalTagWidth + tagsWidth > width - 100) {\n          computedOverflowAmount += 1\n          setOverflowAmount(computedOverflowAmount)\n        } else {\n          computedNonOverflowedValues = [\n            ...computedNonOverflowedValues,\n            selectedOption,\n          ]\n          setNonOverFlowedValues(computedNonOverflowedValues)\n          tagsWidth += totalTagWidth\n        }\n      }\n    }\n    if (computedOverflowAmount === 0) {\n      setOverflowed(false)\n    } else {\n      setOverflowed(true)\n    }\n    setOverflowAmount(computedOverflowAmount)\n  }, [options, selectedData.selectedValues, width])\n\n  useEffect(() => {\n    setSelectedData({ type: 'update' })\n  }, [setSelectedData, options])\n\n  return (\n    <Tooltip text={tooltip}>\n      <StyledInputWrapper\n        role=\"combobox\"\n        id={id}\n        data-disabled={disabled}\n        data-readonly={readOnly}\n        data-size={size}\n        data-dropdownvisible={isDropdownVisible}\n        data-state={state}\n        direction=\"row\"\n        wrap=\"nowrap\"\n        gap=\"1\"\n        justifyContent=\"space-between\"\n        alignItems=\"center\"\n        onClick={\n          openable ? () => setIsDropdownVisible(!isDropdownVisible) : undefined\n        }\n        data-testid={dataTestId}\n        autoFocus={autoFocus}\n        onKeyDown={event => {\n          if (event.key === 'ArrowDown') {\n            if (!isDropdownVisible) {\n              setIsDropdownVisible(true)\n            } else {\n              document.getElementById(`option-0`)?.focus()\n            }\n          }\n\n          return ['Enter', ' '].includes(event.key) && openable\n            ? setIsDropdownVisible(!isDropdownVisible)\n            : null\n        }}\n        ref={innerRef}\n        aria-haspopup=\"listbox\"\n        aria-expanded={isDropdownVisible}\n        tabIndex={0}\n        aria-label={label}\n      >\n        {selectedData.selectedValues.length > 0 ? (\n          <DisplayValues\n            refTag={refTag}\n            nonOverflowedValues={nonOverflowedValues}\n            disabled={disabled}\n            readOnly={readOnly}\n            overflowed={overflowed}\n            overflowAmount={overflowAmount}\n            size={size}\n          />\n        ) : (\n          <Placeholder\n            as=\"p\"\n            variant={size === 'large' ? 'body' : 'bodySmall'}\n            sentiment=\"neutral\"\n            disabled={disabled}\n            prominence=\"weak\"\n          >\n            {placeholder}\n          </Placeholder>\n        )}\n        <StateStack direction=\"row\" gap={1} alignItems=\"center\">\n          {error ? <Icon name=\"alert\" sentiment=\"danger\" /> : null}\n          {success && !error ? (\n            <Icon name=\"checkbox-circle-outline\" sentiment=\"success\" />\n          ) : null}\n          {clearable && selectedData.selectedValues.length > 0 ? (\n            <Button\n              aria-label=\"clear value\"\n              disabled={disabled || !selectedData.selectedValues[0] || readOnly}\n              variant=\"ghost\"\n              size=\"small\"\n              icon=\"close\"\n              onClick={event => {\n                event.stopPropagation()\n                setSelectedData({ type: 'clearAll' })\n                if (multiselect) {\n                  onChange?.([])\n                } else {\n                  onChange?.('')\n                }\n              }}\n              sentiment=\"neutral\"\n              data-testid=\"clear-all\"\n            />\n          ) : null}\n          <Icon\n            aria-label=\"show dropdown\"\n            size=\"small\"\n            name=\"arrow-down\"\n            sentiment=\"neutral\"\n            disabled={disabled || readOnly}\n          />\n        </StateStack>\n      </StyledInputWrapper>\n    </Tooltip>\n  )\n}\n"]} */",
39
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInputV2/SelectBar.tsx"],"names":[],"mappings":"AAiDgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInputV2/SelectBar.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport {\n  AlertCircleIcon,\n  ArrowDownIcon,\n  CheckCircleIcon,\n  PlusIcon,\n} from '@ultraviolet/icons'\nimport type { RefObject } from 'react'\nimport { useEffect, useMemo, useRef, useState } from 'react'\nimport { Button } from '../Button'\nimport { Stack } from '../Stack'\nimport { Tag } from '../Tag'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\nimport { useSelectInput } from './SelectInputProvider'\nimport { findOptionInOptions } from './findOptionInOptions'\nimport type { DataType, OptionType } from './types'\nimport { INPUT_SIZE_HEIGHT, SIZES_TAG } from './types'\n\ntype SelectBarProps = {\n  size: 'small' | 'medium' | 'large'\n  clearable: boolean\n  disabled: boolean\n  readOnly: boolean\n  placeholder: string\n  success?: string\n  error?: string\n  autoFocus?: boolean\n  innerRef: RefObject<HTMLDivElement>\n  id?: string\n  'data-testid': string\n  label?: string\n  tooltip?: string\n}\n\ntype DisplayValuesProps = {\n  refTag: RefObject<HTMLDivElement>\n  nonOverflowedValues: OptionType[]\n  disabled: boolean\n  readOnly: boolean\n  overflowed: boolean\n  overflowAmount: number\n  size: 'small' | 'medium' | 'large'\n}\n\nconst StateStack = styled(Stack)`\n  padding-right: ${({ theme }) => theme.space['2']};\n  display: flex;\n`\nconst Placeholder = styled(Text)`\nuser-select: none;\n`\n\nconst StyledInputWrapper = styled(Stack)<{\n  'data-readonly': boolean\n  'data-disabled': boolean\n  'data-size': 'small' | 'medium' | 'large'\n  'data-state': 'neutral' | 'success' | 'danger'\n  'data-dropdownvisible': boolean\n  'aria-label'?: string\n}>`\n  display: flex;\n  padding: ${({ theme }) => theme.space[1]};\n  padding-right: 0;\n  padding-left: ${({ theme }) => theme.space[2]};\n  cursor: pointer;\n  box-shadow: none;\n  background: ${({ theme }) => theme.colors.neutral.background};\n  border-radius: ${({ theme }) => theme.radii.default};\n  width: 100%;\n  overflow: hidden;\n\n  &[data-size='small'] {\n    height: ${INPUT_SIZE_HEIGHT.small}px;\n    padding-left: ${({ theme }) => theme.space[1]};\n  }\n  &[data-size='medium'] {\n    height: ${INPUT_SIZE_HEIGHT.medium}px;\n  }\n  &[data-size='large'] {\n    height: ${INPUT_SIZE_HEIGHT.large}px;\n  }\n  &[data-state='neutral'] {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n    &:not([data-disabled='true']):hover,\n    :not([data-disabled='true']):focus {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      outline: none;\n    }\n\n    &[data-dropdownvisible='true'] {\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n  }\n  }\n\n  &[data-state='success'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.success.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n    }\n  \n    &[data-dropdownvisible='true'] {\n      border-color: ${({ theme }) => theme.colors.success.borderHover};\n    }\n  }\n\n  &[data-state='danger'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.danger.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n  \n    &[data-dropdownvisible='true'] {\n      border-color: ${({ theme }) => theme.colors.danger.borderHover};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly]):hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n  }\n`\nconst CustomTag = styled(Tag)`\n  height: fit-content;\n  width: fit-content;\n`\nconst SelectedValues = styled(Text)`\ntext-overflow: ellipsis;\noverflow: hidden; \n`\n\nconst isValidSelectedValue = (selectedValue: string, options: DataType) =>\n  !Array.isArray(options)\n    ? Object.keys(options).some(group =>\n        options[group].some(\n          option => option.value === selectedValue && !option.disabled,\n        ),\n      )\n    : options.some(option => option.value === selectedValue && !option.disabled)\n\nconst DisplayValues = ({\n  refTag,\n  nonOverflowedValues,\n  disabled,\n  readOnly,\n  overflowed,\n  overflowAmount,\n  size,\n}: DisplayValuesProps) => {\n  const { multiselect, selectedData, setSelectedData, options, onChange } =\n    useSelectInput()\n\n  return multiselect ? (\n    <Stack\n      direction=\"row\"\n      gap=\"1\"\n      wrap=\"nowrap\"\n      ref={refTag}\n      alignItems=\"center\"\n    >\n      {nonOverflowedValues.map(option => (\n        <CustomTag\n          data-testid=\"selected-options-tags\"\n          key={option?.value}\n          sentiment=\"neutral\"\n          disabled={disabled}\n          onClose={\n            !readOnly\n              ? event => {\n                  event.stopPropagation()\n                  setSelectedData({\n                    type: 'selectOption',\n                    clickedOption: option,\n                  })\n                  const newSelectedValues = selectedData.selectedValues?.filter(\n                    val => val !== option.value,\n                  )\n                  onChange?.(newSelectedValues)\n                }\n              : undefined\n          }\n        >\n          {option?.label}\n        </CustomTag>\n      ))}\n      {overflowed ? (\n        <Tag\n          sentiment=\"neutral\"\n          disabled={disabled}\n          key=\"+\"\n          data-testid=\"plus-tag\"\n          aria-label=\"Plus tag\"\n        >\n          <PlusIcon />\n          {overflowAmount}\n        </Tag>\n      ) : null}\n    </Stack>\n  ) : (\n    <SelectedValues\n      as=\"div\"\n      variant={size === 'large' ? 'body' : 'bodySmall'}\n      disabled={disabled}\n      prominence=\"default\"\n      sentiment=\"neutral\"\n    >\n      {selectedData.selectedValues[0]\n        ? findOptionInOptions(options, selectedData.selectedValues[0])?.label\n        : null}\n    </SelectedValues>\n  )\n}\n\nexport const SelectBar = ({\n  size,\n  clearable,\n  disabled,\n  readOnly,\n  placeholder,\n  success,\n  error,\n  autoFocus,\n  tooltip,\n  innerRef,\n  id,\n  'data-testid': dataTestId,\n  label,\n}: SelectBarProps) => {\n  const {\n    isDropdownVisible,\n    onChange,\n    setIsDropdownVisible,\n    options,\n    selectedData,\n    setSelectedData,\n    multiselect,\n  } = useSelectInput()\n  const openable = !(readOnly || disabled)\n  const refTag = useRef<HTMLDivElement>(null)\n  const width = innerRef.current?.offsetWidth\n  const [overflowed, setOverflowed] = useState(false)\n  const [overflowAmount, setOverflowAmount] = useState(0)\n  const [nonOverflowedValues, setNonOverFlowedValues] = useState<OptionType[]>(\n    () => {\n      if (selectedData.selectedValues[0]) {\n        const firstSelectOption = findOptionInOptions(\n          options,\n          selectedData.selectedValues[0],\n        )\n\n        return firstSelectOption ? [firstSelectOption] : []\n      }\n\n      return []\n    },\n  )\n\n  const state = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    // When too many items are selected, too avoid overflow, compute the number of tags to display and add a + tag\n    let tagsWidth = 0\n    let computedOverflowAmount = 0\n    let computedNonOverflowedValues: OptionType[] = []\n    const newSelectedValues = selectedData.selectedValues.filter(\n      selectedValue => isValidSelectedValue(selectedValue, options),\n    )\n    for (const selectedValue of newSelectedValues) {\n      const selectedOption = findOptionInOptions(options, selectedValue)\n      if (\n        selectedOption?.label &&\n        width &&\n        isValidSelectedValue(selectedValue, options)\n      ) {\n        const lengthValue = selectedOption.value.length // Find a better way to find the number of displayed characters?\n        const totalTagWidth =\n          SIZES_TAG.tagWidth + SIZES_TAG.letterWidth * lengthValue\n        if (totalTagWidth + tagsWidth > width - 100) {\n          computedOverflowAmount += 1\n          setOverflowAmount(computedOverflowAmount)\n        } else {\n          computedNonOverflowedValues = [\n            ...computedNonOverflowedValues,\n            selectedOption,\n          ]\n          setNonOverFlowedValues(computedNonOverflowedValues)\n          tagsWidth += totalTagWidth\n        }\n      }\n    }\n    if (computedOverflowAmount === 0) {\n      setOverflowed(false)\n    } else {\n      setOverflowed(true)\n    }\n    setOverflowAmount(computedOverflowAmount)\n  }, [options, selectedData.selectedValues, width])\n\n  useEffect(() => {\n    setSelectedData({ type: 'update' })\n  }, [setSelectedData, options])\n\n  return (\n    <Tooltip text={tooltip}>\n      <StyledInputWrapper\n        role=\"combobox\"\n        id={id}\n        data-disabled={disabled}\n        data-readonly={readOnly}\n        data-size={size}\n        data-dropdownvisible={isDropdownVisible}\n        data-state={state}\n        direction=\"row\"\n        wrap=\"nowrap\"\n        gap=\"1\"\n        justifyContent=\"space-between\"\n        alignItems=\"center\"\n        onClick={\n          openable ? () => setIsDropdownVisible(!isDropdownVisible) : undefined\n        }\n        data-testid={dataTestId}\n        autoFocus={autoFocus}\n        onKeyDown={event => {\n          if (event.key === 'ArrowDown') {\n            if (!isDropdownVisible) {\n              setIsDropdownVisible(true)\n            } else {\n              document.getElementById(`option-0`)?.focus()\n            }\n          }\n\n          return ['Enter', ' '].includes(event.key) && openable\n            ? setIsDropdownVisible(!isDropdownVisible)\n            : null\n        }}\n        ref={innerRef}\n        aria-haspopup=\"listbox\"\n        aria-expanded={isDropdownVisible}\n        tabIndex={0}\n        aria-label={label}\n      >\n        {selectedData.selectedValues.length > 0 ? (\n          <DisplayValues\n            refTag={refTag}\n            nonOverflowedValues={nonOverflowedValues}\n            disabled={disabled}\n            readOnly={readOnly}\n            overflowed={overflowed}\n            overflowAmount={overflowAmount}\n            size={size}\n          />\n        ) : (\n          <Placeholder\n            as=\"p\"\n            variant={size === 'large' ? 'body' : 'bodySmall'}\n            sentiment=\"neutral\"\n            disabled={disabled}\n            prominence=\"weak\"\n          >\n            {placeholder}\n          </Placeholder>\n        )}\n        <StateStack direction=\"row\" gap={1} alignItems=\"center\">\n          {error ? <AlertCircleIcon sentiment=\"danger\" /> : null}\n          {success && !error ? <CheckCircleIcon sentiment=\"success\" /> : null}\n          {clearable && selectedData.selectedValues.length > 0 ? (\n            <Button\n              aria-label=\"clear value\"\n              disabled={disabled || !selectedData.selectedValues[0] || readOnly}\n              variant=\"ghost\"\n              size=\"small\"\n              icon=\"close\"\n              onClick={event => {\n                event.stopPropagation()\n                setSelectedData({ type: 'clearAll' })\n                if (multiselect) {\n                  onChange?.([])\n                } else {\n                  onChange?.('')\n                }\n              }}\n              sentiment=\"neutral\"\n              data-testid=\"clear-all\"\n            />\n          ) : null}\n          <ArrowDownIcon\n            aria-label=\"show dropdown\"\n            size=\"small\"\n            sentiment=\"neutral\"\n            disabled={disabled || readOnly}\n          />\n        </StateStack>\n      </StyledInputWrapper>\n    </Tooltip>\n  )\n}\n"]} */",
40
40
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
41
41
  });
42
42
  const StyledInputWrapper = /* @__PURE__ */ _styled__default.default(index.Stack, process.env.NODE_ENV === "production" ? {
@@ -90,7 +90,7 @@ const StyledInputWrapper = /* @__PURE__ */ _styled__default.default(index.Stack,
90
90
  theme
91
91
  }) => theme.colors.neutral.backgroundDisabled, ";border-color:", ({
92
92
  theme
93
- }) => theme.colors.neutral.borderDisabled, ";cursor:not-allowed;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInputV2/SelectBar.tsx"],"names":[],"mappings":"AAuDE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInputV2/SelectBar.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons/legacy'\nimport type { RefObject } from 'react'\nimport { useEffect, useMemo, useRef, useState } from 'react'\nimport { Button } from '../Button'\nimport { Stack } from '../Stack'\nimport { Tag } from '../Tag'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\nimport { useSelectInput } from './SelectInputProvider'\nimport { findOptionInOptions } from './findOptionInOptions'\nimport type { DataType, OptionType } from './types'\nimport { INPUT_SIZE_HEIGHT, SIZES_TAG } from './types'\n\ntype SelectBarProps = {\n  size: 'small' | 'medium' | 'large'\n  clearable: boolean\n  disabled: boolean\n  readOnly: boolean\n  placeholder: string\n  success?: string\n  error?: string\n  autoFocus?: boolean\n  innerRef: RefObject<HTMLDivElement>\n  id?: string\n  'data-testid': string\n  label?: string\n  tooltip?: string\n}\n\ntype DisplayValuesProps = {\n  refTag: RefObject<HTMLDivElement>\n  nonOverflowedValues: OptionType[]\n  disabled: boolean\n  readOnly: boolean\n  overflowed: boolean\n  overflowAmount: number\n  size: 'small' | 'medium' | 'large'\n}\n\nconst StateStack = styled(Stack)`\n  padding-right: ${({ theme }) => theme.space['2']};\n  display: flex;\n`\nconst Placeholder = styled(Text)`\nuser-select: none;\n`\n\nconst StyledInputWrapper = styled(Stack)<{\n  'data-readonly': boolean\n  'data-disabled': boolean\n  'data-size': 'small' | 'medium' | 'large'\n  'data-state': 'neutral' | 'success' | 'danger'\n  'data-dropdownvisible': boolean\n  'aria-label'?: string\n}>`\n  display: flex;\n  padding: ${({ theme }) => theme.space[1]};\n  padding-right: 0;\n  padding-left: ${({ theme }) => theme.space[2]};\n  cursor: pointer;\n  box-shadow: none;\n  background: ${({ theme }) => theme.colors.neutral.background};\n  border-radius: ${({ theme }) => theme.radii.default};\n  width: 100%;\n  overflow: hidden;\n\n  &[data-size='small'] {\n    height: ${INPUT_SIZE_HEIGHT.small}px;\n    padding-left: ${({ theme }) => theme.space[1]};\n  }\n  &[data-size='medium'] {\n    height: ${INPUT_SIZE_HEIGHT.medium}px;\n  }\n  &[data-size='large'] {\n    height: ${INPUT_SIZE_HEIGHT.large}px;\n  }\n  &[data-state='neutral'] {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n    &:not([data-disabled='true']):hover,\n    :not([data-disabled='true']):focus {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      outline: none;\n    }\n\n    &[data-dropdownvisible='true'] {\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n  }\n  }\n\n  &[data-state='success'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.success.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n    }\n  \n    &[data-dropdownvisible='true'] {\n      border-color: ${({ theme }) => theme.colors.success.borderHover};\n    }\n  }\n\n  &[data-state='danger'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.danger.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n  \n    &[data-dropdownvisible='true'] {\n      border-color: ${({ theme }) => theme.colors.danger.borderHover};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly]):hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n  }\n`\nconst CustomTag = styled(Tag)`\n  height: fit-content;\n  width: fit-content;\n`\nconst SelectedValues = styled(Text)`\ntext-overflow: ellipsis;\noverflow: hidden; \n`\n\nconst isValidSelectedValue = (selectedValue: string, options: DataType) =>\n  !Array.isArray(options)\n    ? Object.keys(options).some(group =>\n        options[group].some(\n          option => option.value === selectedValue && !option.disabled,\n        ),\n      )\n    : options.some(option => option.value === selectedValue && !option.disabled)\n\nconst DisplayValues = ({\n  refTag,\n  nonOverflowedValues,\n  disabled,\n  readOnly,\n  overflowed,\n  overflowAmount,\n  size,\n}: DisplayValuesProps) => {\n  const { multiselect, selectedData, setSelectedData, options, onChange } =\n    useSelectInput()\n\n  return multiselect ? (\n    <Stack\n      direction=\"row\"\n      gap=\"1\"\n      wrap=\"nowrap\"\n      ref={refTag}\n      alignItems=\"center\"\n    >\n      {nonOverflowedValues.map(option => (\n        <CustomTag\n          data-testid=\"selected-options-tags\"\n          key={option?.value}\n          sentiment=\"neutral\"\n          disabled={disabled}\n          onClose={\n            !readOnly\n              ? event => {\n                  event.stopPropagation()\n                  setSelectedData({\n                    type: 'selectOption',\n                    clickedOption: option,\n                  })\n                  const newSelectedValues = selectedData.selectedValues?.filter(\n                    val => val !== option.value,\n                  )\n                  onChange?.(newSelectedValues)\n                }\n              : undefined\n          }\n        >\n          {option?.label}\n        </CustomTag>\n      ))}\n      {overflowed ? (\n        <Tag\n          sentiment=\"neutral\"\n          disabled={disabled}\n          key=\"+\"\n          data-testid=\"plus-tag\"\n          aria-label=\"Plus tag\"\n        >\n          <Icon name=\"plus\" />\n          {overflowAmount}\n        </Tag>\n      ) : null}\n    </Stack>\n  ) : (\n    <SelectedValues as=\"div\" variant={size === 'large' ? 'body' : 'bodySmall'}>\n      {selectedData.selectedValues[0]\n        ? findOptionInOptions(options, selectedData.selectedValues[0])?.label\n        : null}\n    </SelectedValues>\n  )\n}\n\nexport const SelectBar = ({\n  size,\n  clearable,\n  disabled,\n  readOnly,\n  placeholder,\n  success,\n  error,\n  autoFocus,\n  tooltip,\n  innerRef,\n  id,\n  'data-testid': dataTestId,\n  label,\n}: SelectBarProps) => {\n  const {\n    isDropdownVisible,\n    onChange,\n    setIsDropdownVisible,\n    options,\n    selectedData,\n    setSelectedData,\n    multiselect,\n  } = useSelectInput()\n  const openable = !(readOnly || disabled)\n  const refTag = useRef<HTMLDivElement>(null)\n  const width = innerRef.current?.offsetWidth\n  const [overflowed, setOverflowed] = useState(false)\n  const [overflowAmount, setOverflowAmount] = useState(0)\n  const [nonOverflowedValues, setNonOverFlowedValues] = useState<OptionType[]>(\n    () => {\n      if (selectedData.selectedValues[0]) {\n        const firstSelectOption = findOptionInOptions(\n          options,\n          selectedData.selectedValues[0],\n        )\n\n        return firstSelectOption ? [firstSelectOption] : []\n      }\n\n      return []\n    },\n  )\n\n  const state = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    // When too many items are selected, too avoid overflow, compute the number of tags to display and add a + tag\n    let tagsWidth = 0\n    let computedOverflowAmount = 0\n    let computedNonOverflowedValues: OptionType[] = []\n    const newSelectedValues = selectedData.selectedValues.filter(\n      selectedValue => isValidSelectedValue(selectedValue, options),\n    )\n    for (const selectedValue of newSelectedValues) {\n      const selectedOption = findOptionInOptions(options, selectedValue)\n      if (\n        selectedOption?.label &&\n        width &&\n        isValidSelectedValue(selectedValue, options)\n      ) {\n        const lengthValue = selectedOption.value.length // Find a better way to find the number of displayed characters?\n        const totalTagWidth =\n          SIZES_TAG.tagWidth + SIZES_TAG.letterWidth * lengthValue\n        if (totalTagWidth + tagsWidth > width - 100) {\n          computedOverflowAmount += 1\n          setOverflowAmount(computedOverflowAmount)\n        } else {\n          computedNonOverflowedValues = [\n            ...computedNonOverflowedValues,\n            selectedOption,\n          ]\n          setNonOverFlowedValues(computedNonOverflowedValues)\n          tagsWidth += totalTagWidth\n        }\n      }\n    }\n    if (computedOverflowAmount === 0) {\n      setOverflowed(false)\n    } else {\n      setOverflowed(true)\n    }\n    setOverflowAmount(computedOverflowAmount)\n  }, [options, selectedData.selectedValues, width])\n\n  useEffect(() => {\n    setSelectedData({ type: 'update' })\n  }, [setSelectedData, options])\n\n  return (\n    <Tooltip text={tooltip}>\n      <StyledInputWrapper\n        role=\"combobox\"\n        id={id}\n        data-disabled={disabled}\n        data-readonly={readOnly}\n        data-size={size}\n        data-dropdownvisible={isDropdownVisible}\n        data-state={state}\n        direction=\"row\"\n        wrap=\"nowrap\"\n        gap=\"1\"\n        justifyContent=\"space-between\"\n        alignItems=\"center\"\n        onClick={\n          openable ? () => setIsDropdownVisible(!isDropdownVisible) : undefined\n        }\n        data-testid={dataTestId}\n        autoFocus={autoFocus}\n        onKeyDown={event => {\n          if (event.key === 'ArrowDown') {\n            if (!isDropdownVisible) {\n              setIsDropdownVisible(true)\n            } else {\n              document.getElementById(`option-0`)?.focus()\n            }\n          }\n\n          return ['Enter', ' '].includes(event.key) && openable\n            ? setIsDropdownVisible(!isDropdownVisible)\n            : null\n        }}\n        ref={innerRef}\n        aria-haspopup=\"listbox\"\n        aria-expanded={isDropdownVisible}\n        tabIndex={0}\n        aria-label={label}\n      >\n        {selectedData.selectedValues.length > 0 ? (\n          <DisplayValues\n            refTag={refTag}\n            nonOverflowedValues={nonOverflowedValues}\n            disabled={disabled}\n            readOnly={readOnly}\n            overflowed={overflowed}\n            overflowAmount={overflowAmount}\n            size={size}\n          />\n        ) : (\n          <Placeholder\n            as=\"p\"\n            variant={size === 'large' ? 'body' : 'bodySmall'}\n            sentiment=\"neutral\"\n            disabled={disabled}\n            prominence=\"weak\"\n          >\n            {placeholder}\n          </Placeholder>\n        )}\n        <StateStack direction=\"row\" gap={1} alignItems=\"center\">\n          {error ? <Icon name=\"alert\" sentiment=\"danger\" /> : null}\n          {success && !error ? (\n            <Icon name=\"checkbox-circle-outline\" sentiment=\"success\" />\n          ) : null}\n          {clearable && selectedData.selectedValues.length > 0 ? (\n            <Button\n              aria-label=\"clear value\"\n              disabled={disabled || !selectedData.selectedValues[0] || readOnly}\n              variant=\"ghost\"\n              size=\"small\"\n              icon=\"close\"\n              onClick={event => {\n                event.stopPropagation()\n                setSelectedData({ type: 'clearAll' })\n                if (multiselect) {\n                  onChange?.([])\n                } else {\n                  onChange?.('')\n                }\n              }}\n              sentiment=\"neutral\"\n              data-testid=\"clear-all\"\n            />\n          ) : null}\n          <Icon\n            aria-label=\"show dropdown\"\n            size=\"small\"\n            name=\"arrow-down\"\n            sentiment=\"neutral\"\n            disabled={disabled || readOnly}\n          />\n        </StateStack>\n      </StyledInputWrapper>\n    </Tooltip>\n  )\n}\n"]} */"));
93
+ }) => theme.colors.neutral.borderDisabled, ";cursor:not-allowed;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInputV2/SelectBar.tsx"],"names":[],"mappings":"AA4DE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInputV2/SelectBar.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport {\n  AlertCircleIcon,\n  ArrowDownIcon,\n  CheckCircleIcon,\n  PlusIcon,\n} from '@ultraviolet/icons'\nimport type { RefObject } from 'react'\nimport { useEffect, useMemo, useRef, useState } from 'react'\nimport { Button } from '../Button'\nimport { Stack } from '../Stack'\nimport { Tag } from '../Tag'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\nimport { useSelectInput } from './SelectInputProvider'\nimport { findOptionInOptions } from './findOptionInOptions'\nimport type { DataType, OptionType } from './types'\nimport { INPUT_SIZE_HEIGHT, SIZES_TAG } from './types'\n\ntype SelectBarProps = {\n  size: 'small' | 'medium' | 'large'\n  clearable: boolean\n  disabled: boolean\n  readOnly: boolean\n  placeholder: string\n  success?: string\n  error?: string\n  autoFocus?: boolean\n  innerRef: RefObject<HTMLDivElement>\n  id?: string\n  'data-testid': string\n  label?: string\n  tooltip?: string\n}\n\ntype DisplayValuesProps = {\n  refTag: RefObject<HTMLDivElement>\n  nonOverflowedValues: OptionType[]\n  disabled: boolean\n  readOnly: boolean\n  overflowed: boolean\n  overflowAmount: number\n  size: 'small' | 'medium' | 'large'\n}\n\nconst StateStack = styled(Stack)`\n  padding-right: ${({ theme }) => theme.space['2']};\n  display: flex;\n`\nconst Placeholder = styled(Text)`\nuser-select: none;\n`\n\nconst StyledInputWrapper = styled(Stack)<{\n  'data-readonly': boolean\n  'data-disabled': boolean\n  'data-size': 'small' | 'medium' | 'large'\n  'data-state': 'neutral' | 'success' | 'danger'\n  'data-dropdownvisible': boolean\n  'aria-label'?: string\n}>`\n  display: flex;\n  padding: ${({ theme }) => theme.space[1]};\n  padding-right: 0;\n  padding-left: ${({ theme }) => theme.space[2]};\n  cursor: pointer;\n  box-shadow: none;\n  background: ${({ theme }) => theme.colors.neutral.background};\n  border-radius: ${({ theme }) => theme.radii.default};\n  width: 100%;\n  overflow: hidden;\n\n  &[data-size='small'] {\n    height: ${INPUT_SIZE_HEIGHT.small}px;\n    padding-left: ${({ theme }) => theme.space[1]};\n  }\n  &[data-size='medium'] {\n    height: ${INPUT_SIZE_HEIGHT.medium}px;\n  }\n  &[data-size='large'] {\n    height: ${INPUT_SIZE_HEIGHT.large}px;\n  }\n  &[data-state='neutral'] {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n    &:not([data-disabled='true']):hover,\n    :not([data-disabled='true']):focus {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      outline: none;\n    }\n\n    &[data-dropdownvisible='true'] {\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n  }\n  }\n\n  &[data-state='success'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.success.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n    }\n  \n    &[data-dropdownvisible='true'] {\n      border-color: ${({ theme }) => theme.colors.success.borderHover};\n    }\n  }\n\n  &[data-state='danger'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.danger.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n  \n    &[data-dropdownvisible='true'] {\n      border-color: ${({ theme }) => theme.colors.danger.borderHover};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly]):hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n  }\n`\nconst CustomTag = styled(Tag)`\n  height: fit-content;\n  width: fit-content;\n`\nconst SelectedValues = styled(Text)`\ntext-overflow: ellipsis;\noverflow: hidden; \n`\n\nconst isValidSelectedValue = (selectedValue: string, options: DataType) =>\n  !Array.isArray(options)\n    ? Object.keys(options).some(group =>\n        options[group].some(\n          option => option.value === selectedValue && !option.disabled,\n        ),\n      )\n    : options.some(option => option.value === selectedValue && !option.disabled)\n\nconst DisplayValues = ({\n  refTag,\n  nonOverflowedValues,\n  disabled,\n  readOnly,\n  overflowed,\n  overflowAmount,\n  size,\n}: DisplayValuesProps) => {\n  const { multiselect, selectedData, setSelectedData, options, onChange } =\n    useSelectInput()\n\n  return multiselect ? (\n    <Stack\n      direction=\"row\"\n      gap=\"1\"\n      wrap=\"nowrap\"\n      ref={refTag}\n      alignItems=\"center\"\n    >\n      {nonOverflowedValues.map(option => (\n        <CustomTag\n          data-testid=\"selected-options-tags\"\n          key={option?.value}\n          sentiment=\"neutral\"\n          disabled={disabled}\n          onClose={\n            !readOnly\n              ? event => {\n                  event.stopPropagation()\n                  setSelectedData({\n                    type: 'selectOption',\n                    clickedOption: option,\n                  })\n                  const newSelectedValues = selectedData.selectedValues?.filter(\n                    val => val !== option.value,\n                  )\n                  onChange?.(newSelectedValues)\n                }\n              : undefined\n          }\n        >\n          {option?.label}\n        </CustomTag>\n      ))}\n      {overflowed ? (\n        <Tag\n          sentiment=\"neutral\"\n          disabled={disabled}\n          key=\"+\"\n          data-testid=\"plus-tag\"\n          aria-label=\"Plus tag\"\n        >\n          <PlusIcon />\n          {overflowAmount}\n        </Tag>\n      ) : null}\n    </Stack>\n  ) : (\n    <SelectedValues\n      as=\"div\"\n      variant={size === 'large' ? 'body' : 'bodySmall'}\n      disabled={disabled}\n      prominence=\"default\"\n      sentiment=\"neutral\"\n    >\n      {selectedData.selectedValues[0]\n        ? findOptionInOptions(options, selectedData.selectedValues[0])?.label\n        : null}\n    </SelectedValues>\n  )\n}\n\nexport const SelectBar = ({\n  size,\n  clearable,\n  disabled,\n  readOnly,\n  placeholder,\n  success,\n  error,\n  autoFocus,\n  tooltip,\n  innerRef,\n  id,\n  'data-testid': dataTestId,\n  label,\n}: SelectBarProps) => {\n  const {\n    isDropdownVisible,\n    onChange,\n    setIsDropdownVisible,\n    options,\n    selectedData,\n    setSelectedData,\n    multiselect,\n  } = useSelectInput()\n  const openable = !(readOnly || disabled)\n  const refTag = useRef<HTMLDivElement>(null)\n  const width = innerRef.current?.offsetWidth\n  const [overflowed, setOverflowed] = useState(false)\n  const [overflowAmount, setOverflowAmount] = useState(0)\n  const [nonOverflowedValues, setNonOverFlowedValues] = useState<OptionType[]>(\n    () => {\n      if (selectedData.selectedValues[0]) {\n        const firstSelectOption = findOptionInOptions(\n          options,\n          selectedData.selectedValues[0],\n        )\n\n        return firstSelectOption ? [firstSelectOption] : []\n      }\n\n      return []\n    },\n  )\n\n  const state = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    // When too many items are selected, too avoid overflow, compute the number of tags to display and add a + tag\n    let tagsWidth = 0\n    let computedOverflowAmount = 0\n    let computedNonOverflowedValues: OptionType[] = []\n    const newSelectedValues = selectedData.selectedValues.filter(\n      selectedValue => isValidSelectedValue(selectedValue, options),\n    )\n    for (const selectedValue of newSelectedValues) {\n      const selectedOption = findOptionInOptions(options, selectedValue)\n      if (\n        selectedOption?.label &&\n        width &&\n        isValidSelectedValue(selectedValue, options)\n      ) {\n        const lengthValue = selectedOption.value.length // Find a better way to find the number of displayed characters?\n        const totalTagWidth =\n          SIZES_TAG.tagWidth + SIZES_TAG.letterWidth * lengthValue\n        if (totalTagWidth + tagsWidth > width - 100) {\n          computedOverflowAmount += 1\n          setOverflowAmount(computedOverflowAmount)\n        } else {\n          computedNonOverflowedValues = [\n            ...computedNonOverflowedValues,\n            selectedOption,\n          ]\n          setNonOverFlowedValues(computedNonOverflowedValues)\n          tagsWidth += totalTagWidth\n        }\n      }\n    }\n    if (computedOverflowAmount === 0) {\n      setOverflowed(false)\n    } else {\n      setOverflowed(true)\n    }\n    setOverflowAmount(computedOverflowAmount)\n  }, [options, selectedData.selectedValues, width])\n\n  useEffect(() => {\n    setSelectedData({ type: 'update' })\n  }, [setSelectedData, options])\n\n  return (\n    <Tooltip text={tooltip}>\n      <StyledInputWrapper\n        role=\"combobox\"\n        id={id}\n        data-disabled={disabled}\n        data-readonly={readOnly}\n        data-size={size}\n        data-dropdownvisible={isDropdownVisible}\n        data-state={state}\n        direction=\"row\"\n        wrap=\"nowrap\"\n        gap=\"1\"\n        justifyContent=\"space-between\"\n        alignItems=\"center\"\n        onClick={\n          openable ? () => setIsDropdownVisible(!isDropdownVisible) : undefined\n        }\n        data-testid={dataTestId}\n        autoFocus={autoFocus}\n        onKeyDown={event => {\n          if (event.key === 'ArrowDown') {\n            if (!isDropdownVisible) {\n              setIsDropdownVisible(true)\n            } else {\n              document.getElementById(`option-0`)?.focus()\n            }\n          }\n\n          return ['Enter', ' '].includes(event.key) && openable\n            ? setIsDropdownVisible(!isDropdownVisible)\n            : null\n        }}\n        ref={innerRef}\n        aria-haspopup=\"listbox\"\n        aria-expanded={isDropdownVisible}\n        tabIndex={0}\n        aria-label={label}\n      >\n        {selectedData.selectedValues.length > 0 ? (\n          <DisplayValues\n            refTag={refTag}\n            nonOverflowedValues={nonOverflowedValues}\n            disabled={disabled}\n            readOnly={readOnly}\n            overflowed={overflowed}\n            overflowAmount={overflowAmount}\n            size={size}\n          />\n        ) : (\n          <Placeholder\n            as=\"p\"\n            variant={size === 'large' ? 'body' : 'bodySmall'}\n            sentiment=\"neutral\"\n            disabled={disabled}\n            prominence=\"weak\"\n          >\n            {placeholder}\n          </Placeholder>\n        )}\n        <StateStack direction=\"row\" gap={1} alignItems=\"center\">\n          {error ? <AlertCircleIcon sentiment=\"danger\" /> : null}\n          {success && !error ? <CheckCircleIcon sentiment=\"success\" /> : null}\n          {clearable && selectedData.selectedValues.length > 0 ? (\n            <Button\n              aria-label=\"clear value\"\n              disabled={disabled || !selectedData.selectedValues[0] || readOnly}\n              variant=\"ghost\"\n              size=\"small\"\n              icon=\"close\"\n              onClick={event => {\n                event.stopPropagation()\n                setSelectedData({ type: 'clearAll' })\n                if (multiselect) {\n                  onChange?.([])\n                } else {\n                  onChange?.('')\n                }\n              }}\n              sentiment=\"neutral\"\n              data-testid=\"clear-all\"\n            />\n          ) : null}\n          <ArrowDownIcon\n            aria-label=\"show dropdown\"\n            size=\"small\"\n            sentiment=\"neutral\"\n            disabled={disabled || readOnly}\n          />\n        </StateStack>\n      </StyledInputWrapper>\n    </Tooltip>\n  )\n}\n"]} */"));
94
94
  const CustomTag = /* @__PURE__ */ _styled__default.default(index$2.Tag, process.env.NODE_ENV === "production" ? {
95
95
  target: "ejy0aca1"
96
96
  } : {
@@ -102,7 +102,7 @@ const CustomTag = /* @__PURE__ */ _styled__default.default(index$2.Tag, process.
102
102
  } : {
103
103
  name: "1snt5jp",
104
104
  styles: "height:fit-content;width:fit-content",
105
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInputV2/SelectBar.tsx"],"names":[],"mappings":"AAwI6B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInputV2/SelectBar.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons/legacy'\nimport type { RefObject } from 'react'\nimport { useEffect, useMemo, useRef, useState } from 'react'\nimport { Button } from '../Button'\nimport { Stack } from '../Stack'\nimport { Tag } from '../Tag'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\nimport { useSelectInput } from './SelectInputProvider'\nimport { findOptionInOptions } from './findOptionInOptions'\nimport type { DataType, OptionType } from './types'\nimport { INPUT_SIZE_HEIGHT, SIZES_TAG } from './types'\n\ntype SelectBarProps = {\n  size: 'small' | 'medium' | 'large'\n  clearable: boolean\n  disabled: boolean\n  readOnly: boolean\n  placeholder: string\n  success?: string\n  error?: string\n  autoFocus?: boolean\n  innerRef: RefObject<HTMLDivElement>\n  id?: string\n  'data-testid': string\n  label?: string\n  tooltip?: string\n}\n\ntype DisplayValuesProps = {\n  refTag: RefObject<HTMLDivElement>\n  nonOverflowedValues: OptionType[]\n  disabled: boolean\n  readOnly: boolean\n  overflowed: boolean\n  overflowAmount: number\n  size: 'small' | 'medium' | 'large'\n}\n\nconst StateStack = styled(Stack)`\n  padding-right: ${({ theme }) => theme.space['2']};\n  display: flex;\n`\nconst Placeholder = styled(Text)`\nuser-select: none;\n`\n\nconst StyledInputWrapper = styled(Stack)<{\n  'data-readonly': boolean\n  'data-disabled': boolean\n  'data-size': 'small' | 'medium' | 'large'\n  'data-state': 'neutral' | 'success' | 'danger'\n  'data-dropdownvisible': boolean\n  'aria-label'?: string\n}>`\n  display: flex;\n  padding: ${({ theme }) => theme.space[1]};\n  padding-right: 0;\n  padding-left: ${({ theme }) => theme.space[2]};\n  cursor: pointer;\n  box-shadow: none;\n  background: ${({ theme }) => theme.colors.neutral.background};\n  border-radius: ${({ theme }) => theme.radii.default};\n  width: 100%;\n  overflow: hidden;\n\n  &[data-size='small'] {\n    height: ${INPUT_SIZE_HEIGHT.small}px;\n    padding-left: ${({ theme }) => theme.space[1]};\n  }\n  &[data-size='medium'] {\n    height: ${INPUT_SIZE_HEIGHT.medium}px;\n  }\n  &[data-size='large'] {\n    height: ${INPUT_SIZE_HEIGHT.large}px;\n  }\n  &[data-state='neutral'] {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n    &:not([data-disabled='true']):hover,\n    :not([data-disabled='true']):focus {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      outline: none;\n    }\n\n    &[data-dropdownvisible='true'] {\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n  }\n  }\n\n  &[data-state='success'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.success.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n    }\n  \n    &[data-dropdownvisible='true'] {\n      border-color: ${({ theme }) => theme.colors.success.borderHover};\n    }\n  }\n\n  &[data-state='danger'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.danger.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n  \n    &[data-dropdownvisible='true'] {\n      border-color: ${({ theme }) => theme.colors.danger.borderHover};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly]):hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n  }\n`\nconst CustomTag = styled(Tag)`\n  height: fit-content;\n  width: fit-content;\n`\nconst SelectedValues = styled(Text)`\ntext-overflow: ellipsis;\noverflow: hidden; \n`\n\nconst isValidSelectedValue = (selectedValue: string, options: DataType) =>\n  !Array.isArray(options)\n    ? Object.keys(options).some(group =>\n        options[group].some(\n          option => option.value === selectedValue && !option.disabled,\n        ),\n      )\n    : options.some(option => option.value === selectedValue && !option.disabled)\n\nconst DisplayValues = ({\n  refTag,\n  nonOverflowedValues,\n  disabled,\n  readOnly,\n  overflowed,\n  overflowAmount,\n  size,\n}: DisplayValuesProps) => {\n  const { multiselect, selectedData, setSelectedData, options, onChange } =\n    useSelectInput()\n\n  return multiselect ? (\n    <Stack\n      direction=\"row\"\n      gap=\"1\"\n      wrap=\"nowrap\"\n      ref={refTag}\n      alignItems=\"center\"\n    >\n      {nonOverflowedValues.map(option => (\n        <CustomTag\n          data-testid=\"selected-options-tags\"\n          key={option?.value}\n          sentiment=\"neutral\"\n          disabled={disabled}\n          onClose={\n            !readOnly\n              ? event => {\n                  event.stopPropagation()\n                  setSelectedData({\n                    type: 'selectOption',\n                    clickedOption: option,\n                  })\n                  const newSelectedValues = selectedData.selectedValues?.filter(\n                    val => val !== option.value,\n                  )\n                  onChange?.(newSelectedValues)\n                }\n              : undefined\n          }\n        >\n          {option?.label}\n        </CustomTag>\n      ))}\n      {overflowed ? (\n        <Tag\n          sentiment=\"neutral\"\n          disabled={disabled}\n          key=\"+\"\n          data-testid=\"plus-tag\"\n          aria-label=\"Plus tag\"\n        >\n          <Icon name=\"plus\" />\n          {overflowAmount}\n        </Tag>\n      ) : null}\n    </Stack>\n  ) : (\n    <SelectedValues as=\"div\" variant={size === 'large' ? 'body' : 'bodySmall'}>\n      {selectedData.selectedValues[0]\n        ? findOptionInOptions(options, selectedData.selectedValues[0])?.label\n        : null}\n    </SelectedValues>\n  )\n}\n\nexport const SelectBar = ({\n  size,\n  clearable,\n  disabled,\n  readOnly,\n  placeholder,\n  success,\n  error,\n  autoFocus,\n  tooltip,\n  innerRef,\n  id,\n  'data-testid': dataTestId,\n  label,\n}: SelectBarProps) => {\n  const {\n    isDropdownVisible,\n    onChange,\n    setIsDropdownVisible,\n    options,\n    selectedData,\n    setSelectedData,\n    multiselect,\n  } = useSelectInput()\n  const openable = !(readOnly || disabled)\n  const refTag = useRef<HTMLDivElement>(null)\n  const width = innerRef.current?.offsetWidth\n  const [overflowed, setOverflowed] = useState(false)\n  const [overflowAmount, setOverflowAmount] = useState(0)\n  const [nonOverflowedValues, setNonOverFlowedValues] = useState<OptionType[]>(\n    () => {\n      if (selectedData.selectedValues[0]) {\n        const firstSelectOption = findOptionInOptions(\n          options,\n          selectedData.selectedValues[0],\n        )\n\n        return firstSelectOption ? [firstSelectOption] : []\n      }\n\n      return []\n    },\n  )\n\n  const state = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    // When too many items are selected, too avoid overflow, compute the number of tags to display and add a + tag\n    let tagsWidth = 0\n    let computedOverflowAmount = 0\n    let computedNonOverflowedValues: OptionType[] = []\n    const newSelectedValues = selectedData.selectedValues.filter(\n      selectedValue => isValidSelectedValue(selectedValue, options),\n    )\n    for (const selectedValue of newSelectedValues) {\n      const selectedOption = findOptionInOptions(options, selectedValue)\n      if (\n        selectedOption?.label &&\n        width &&\n        isValidSelectedValue(selectedValue, options)\n      ) {\n        const lengthValue = selectedOption.value.length // Find a better way to find the number of displayed characters?\n        const totalTagWidth =\n          SIZES_TAG.tagWidth + SIZES_TAG.letterWidth * lengthValue\n        if (totalTagWidth + tagsWidth > width - 100) {\n          computedOverflowAmount += 1\n          setOverflowAmount(computedOverflowAmount)\n        } else {\n          computedNonOverflowedValues = [\n            ...computedNonOverflowedValues,\n            selectedOption,\n          ]\n          setNonOverFlowedValues(computedNonOverflowedValues)\n          tagsWidth += totalTagWidth\n        }\n      }\n    }\n    if (computedOverflowAmount === 0) {\n      setOverflowed(false)\n    } else {\n      setOverflowed(true)\n    }\n    setOverflowAmount(computedOverflowAmount)\n  }, [options, selectedData.selectedValues, width])\n\n  useEffect(() => {\n    setSelectedData({ type: 'update' })\n  }, [setSelectedData, options])\n\n  return (\n    <Tooltip text={tooltip}>\n      <StyledInputWrapper\n        role=\"combobox\"\n        id={id}\n        data-disabled={disabled}\n        data-readonly={readOnly}\n        data-size={size}\n        data-dropdownvisible={isDropdownVisible}\n        data-state={state}\n        direction=\"row\"\n        wrap=\"nowrap\"\n        gap=\"1\"\n        justifyContent=\"space-between\"\n        alignItems=\"center\"\n        onClick={\n          openable ? () => setIsDropdownVisible(!isDropdownVisible) : undefined\n        }\n        data-testid={dataTestId}\n        autoFocus={autoFocus}\n        onKeyDown={event => {\n          if (event.key === 'ArrowDown') {\n            if (!isDropdownVisible) {\n              setIsDropdownVisible(true)\n            } else {\n              document.getElementById(`option-0`)?.focus()\n            }\n          }\n\n          return ['Enter', ' '].includes(event.key) && openable\n            ? setIsDropdownVisible(!isDropdownVisible)\n            : null\n        }}\n        ref={innerRef}\n        aria-haspopup=\"listbox\"\n        aria-expanded={isDropdownVisible}\n        tabIndex={0}\n        aria-label={label}\n      >\n        {selectedData.selectedValues.length > 0 ? (\n          <DisplayValues\n            refTag={refTag}\n            nonOverflowedValues={nonOverflowedValues}\n            disabled={disabled}\n            readOnly={readOnly}\n            overflowed={overflowed}\n            overflowAmount={overflowAmount}\n            size={size}\n          />\n        ) : (\n          <Placeholder\n            as=\"p\"\n            variant={size === 'large' ? 'body' : 'bodySmall'}\n            sentiment=\"neutral\"\n            disabled={disabled}\n            prominence=\"weak\"\n          >\n            {placeholder}\n          </Placeholder>\n        )}\n        <StateStack direction=\"row\" gap={1} alignItems=\"center\">\n          {error ? <Icon name=\"alert\" sentiment=\"danger\" /> : null}\n          {success && !error ? (\n            <Icon name=\"checkbox-circle-outline\" sentiment=\"success\" />\n          ) : null}\n          {clearable && selectedData.selectedValues.length > 0 ? (\n            <Button\n              aria-label=\"clear value\"\n              disabled={disabled || !selectedData.selectedValues[0] || readOnly}\n              variant=\"ghost\"\n              size=\"small\"\n              icon=\"close\"\n              onClick={event => {\n                event.stopPropagation()\n                setSelectedData({ type: 'clearAll' })\n                if (multiselect) {\n                  onChange?.([])\n                } else {\n                  onChange?.('')\n                }\n              }}\n              sentiment=\"neutral\"\n              data-testid=\"clear-all\"\n            />\n          ) : null}\n          <Icon\n            aria-label=\"show dropdown\"\n            size=\"small\"\n            name=\"arrow-down\"\n            sentiment=\"neutral\"\n            disabled={disabled || readOnly}\n          />\n        </StateStack>\n      </StyledInputWrapper>\n    </Tooltip>\n  )\n}\n"]} */",
105
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInputV2/SelectBar.tsx"],"names":[],"mappings":"AA6I6B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInputV2/SelectBar.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport {\n  AlertCircleIcon,\n  ArrowDownIcon,\n  CheckCircleIcon,\n  PlusIcon,\n} from '@ultraviolet/icons'\nimport type { RefObject } from 'react'\nimport { useEffect, useMemo, useRef, useState } from 'react'\nimport { Button } from '../Button'\nimport { Stack } from '../Stack'\nimport { Tag } from '../Tag'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\nimport { useSelectInput } from './SelectInputProvider'\nimport { findOptionInOptions } from './findOptionInOptions'\nimport type { DataType, OptionType } from './types'\nimport { INPUT_SIZE_HEIGHT, SIZES_TAG } from './types'\n\ntype SelectBarProps = {\n  size: 'small' | 'medium' | 'large'\n  clearable: boolean\n  disabled: boolean\n  readOnly: boolean\n  placeholder: string\n  success?: string\n  error?: string\n  autoFocus?: boolean\n  innerRef: RefObject<HTMLDivElement>\n  id?: string\n  'data-testid': string\n  label?: string\n  tooltip?: string\n}\n\ntype DisplayValuesProps = {\n  refTag: RefObject<HTMLDivElement>\n  nonOverflowedValues: OptionType[]\n  disabled: boolean\n  readOnly: boolean\n  overflowed: boolean\n  overflowAmount: number\n  size: 'small' | 'medium' | 'large'\n}\n\nconst StateStack = styled(Stack)`\n  padding-right: ${({ theme }) => theme.space['2']};\n  display: flex;\n`\nconst Placeholder = styled(Text)`\nuser-select: none;\n`\n\nconst StyledInputWrapper = styled(Stack)<{\n  'data-readonly': boolean\n  'data-disabled': boolean\n  'data-size': 'small' | 'medium' | 'large'\n  'data-state': 'neutral' | 'success' | 'danger'\n  'data-dropdownvisible': boolean\n  'aria-label'?: string\n}>`\n  display: flex;\n  padding: ${({ theme }) => theme.space[1]};\n  padding-right: 0;\n  padding-left: ${({ theme }) => theme.space[2]};\n  cursor: pointer;\n  box-shadow: none;\n  background: ${({ theme }) => theme.colors.neutral.background};\n  border-radius: ${({ theme }) => theme.radii.default};\n  width: 100%;\n  overflow: hidden;\n\n  &[data-size='small'] {\n    height: ${INPUT_SIZE_HEIGHT.small}px;\n    padding-left: ${({ theme }) => theme.space[1]};\n  }\n  &[data-size='medium'] {\n    height: ${INPUT_SIZE_HEIGHT.medium}px;\n  }\n  &[data-size='large'] {\n    height: ${INPUT_SIZE_HEIGHT.large}px;\n  }\n  &[data-state='neutral'] {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n    &:not([data-disabled='true']):hover,\n    :not([data-disabled='true']):focus {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      outline: none;\n    }\n\n    &[data-dropdownvisible='true'] {\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n  }\n  }\n\n  &[data-state='success'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.success.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n    }\n  \n    &[data-dropdownvisible='true'] {\n      border-color: ${({ theme }) => theme.colors.success.borderHover};\n    }\n  }\n\n  &[data-state='danger'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.danger.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n  \n    &[data-dropdownvisible='true'] {\n      border-color: ${({ theme }) => theme.colors.danger.borderHover};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly]):hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n  }\n`\nconst CustomTag = styled(Tag)`\n  height: fit-content;\n  width: fit-content;\n`\nconst SelectedValues = styled(Text)`\ntext-overflow: ellipsis;\noverflow: hidden; \n`\n\nconst isValidSelectedValue = (selectedValue: string, options: DataType) =>\n  !Array.isArray(options)\n    ? Object.keys(options).some(group =>\n        options[group].some(\n          option => option.value === selectedValue && !option.disabled,\n        ),\n      )\n    : options.some(option => option.value === selectedValue && !option.disabled)\n\nconst DisplayValues = ({\n  refTag,\n  nonOverflowedValues,\n  disabled,\n  readOnly,\n  overflowed,\n  overflowAmount,\n  size,\n}: DisplayValuesProps) => {\n  const { multiselect, selectedData, setSelectedData, options, onChange } =\n    useSelectInput()\n\n  return multiselect ? (\n    <Stack\n      direction=\"row\"\n      gap=\"1\"\n      wrap=\"nowrap\"\n      ref={refTag}\n      alignItems=\"center\"\n    >\n      {nonOverflowedValues.map(option => (\n        <CustomTag\n          data-testid=\"selected-options-tags\"\n          key={option?.value}\n          sentiment=\"neutral\"\n          disabled={disabled}\n          onClose={\n            !readOnly\n              ? event => {\n                  event.stopPropagation()\n                  setSelectedData({\n                    type: 'selectOption',\n                    clickedOption: option,\n                  })\n                  const newSelectedValues = selectedData.selectedValues?.filter(\n                    val => val !== option.value,\n                  )\n                  onChange?.(newSelectedValues)\n                }\n              : undefined\n          }\n        >\n          {option?.label}\n        </CustomTag>\n      ))}\n      {overflowed ? (\n        <Tag\n          sentiment=\"neutral\"\n          disabled={disabled}\n          key=\"+\"\n          data-testid=\"plus-tag\"\n          aria-label=\"Plus tag\"\n        >\n          <PlusIcon />\n          {overflowAmount}\n        </Tag>\n      ) : null}\n    </Stack>\n  ) : (\n    <SelectedValues\n      as=\"div\"\n      variant={size === 'large' ? 'body' : 'bodySmall'}\n      disabled={disabled}\n      prominence=\"default\"\n      sentiment=\"neutral\"\n    >\n      {selectedData.selectedValues[0]\n        ? findOptionInOptions(options, selectedData.selectedValues[0])?.label\n        : null}\n    </SelectedValues>\n  )\n}\n\nexport const SelectBar = ({\n  size,\n  clearable,\n  disabled,\n  readOnly,\n  placeholder,\n  success,\n  error,\n  autoFocus,\n  tooltip,\n  innerRef,\n  id,\n  'data-testid': dataTestId,\n  label,\n}: SelectBarProps) => {\n  const {\n    isDropdownVisible,\n    onChange,\n    setIsDropdownVisible,\n    options,\n    selectedData,\n    setSelectedData,\n    multiselect,\n  } = useSelectInput()\n  const openable = !(readOnly || disabled)\n  const refTag = useRef<HTMLDivElement>(null)\n  const width = innerRef.current?.offsetWidth\n  const [overflowed, setOverflowed] = useState(false)\n  const [overflowAmount, setOverflowAmount] = useState(0)\n  const [nonOverflowedValues, setNonOverFlowedValues] = useState<OptionType[]>(\n    () => {\n      if (selectedData.selectedValues[0]) {\n        const firstSelectOption = findOptionInOptions(\n          options,\n          selectedData.selectedValues[0],\n        )\n\n        return firstSelectOption ? [firstSelectOption] : []\n      }\n\n      return []\n    },\n  )\n\n  const state = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    // When too many items are selected, too avoid overflow, compute the number of tags to display and add a + tag\n    let tagsWidth = 0\n    let computedOverflowAmount = 0\n    let computedNonOverflowedValues: OptionType[] = []\n    const newSelectedValues = selectedData.selectedValues.filter(\n      selectedValue => isValidSelectedValue(selectedValue, options),\n    )\n    for (const selectedValue of newSelectedValues) {\n      const selectedOption = findOptionInOptions(options, selectedValue)\n      if (\n        selectedOption?.label &&\n        width &&\n        isValidSelectedValue(selectedValue, options)\n      ) {\n        const lengthValue = selectedOption.value.length // Find a better way to find the number of displayed characters?\n        const totalTagWidth =\n          SIZES_TAG.tagWidth + SIZES_TAG.letterWidth * lengthValue\n        if (totalTagWidth + tagsWidth > width - 100) {\n          computedOverflowAmount += 1\n          setOverflowAmount(computedOverflowAmount)\n        } else {\n          computedNonOverflowedValues = [\n            ...computedNonOverflowedValues,\n            selectedOption,\n          ]\n          setNonOverFlowedValues(computedNonOverflowedValues)\n          tagsWidth += totalTagWidth\n        }\n      }\n    }\n    if (computedOverflowAmount === 0) {\n      setOverflowed(false)\n    } else {\n      setOverflowed(true)\n    }\n    setOverflowAmount(computedOverflowAmount)\n  }, [options, selectedData.selectedValues, width])\n\n  useEffect(() => {\n    setSelectedData({ type: 'update' })\n  }, [setSelectedData, options])\n\n  return (\n    <Tooltip text={tooltip}>\n      <StyledInputWrapper\n        role=\"combobox\"\n        id={id}\n        data-disabled={disabled}\n        data-readonly={readOnly}\n        data-size={size}\n        data-dropdownvisible={isDropdownVisible}\n        data-state={state}\n        direction=\"row\"\n        wrap=\"nowrap\"\n        gap=\"1\"\n        justifyContent=\"space-between\"\n        alignItems=\"center\"\n        onClick={\n          openable ? () => setIsDropdownVisible(!isDropdownVisible) : undefined\n        }\n        data-testid={dataTestId}\n        autoFocus={autoFocus}\n        onKeyDown={event => {\n          if (event.key === 'ArrowDown') {\n            if (!isDropdownVisible) {\n              setIsDropdownVisible(true)\n            } else {\n              document.getElementById(`option-0`)?.focus()\n            }\n          }\n\n          return ['Enter', ' '].includes(event.key) && openable\n            ? setIsDropdownVisible(!isDropdownVisible)\n            : null\n        }}\n        ref={innerRef}\n        aria-haspopup=\"listbox\"\n        aria-expanded={isDropdownVisible}\n        tabIndex={0}\n        aria-label={label}\n      >\n        {selectedData.selectedValues.length > 0 ? (\n          <DisplayValues\n            refTag={refTag}\n            nonOverflowedValues={nonOverflowedValues}\n            disabled={disabled}\n            readOnly={readOnly}\n            overflowed={overflowed}\n            overflowAmount={overflowAmount}\n            size={size}\n          />\n        ) : (\n          <Placeholder\n            as=\"p\"\n            variant={size === 'large' ? 'body' : 'bodySmall'}\n            sentiment=\"neutral\"\n            disabled={disabled}\n            prominence=\"weak\"\n          >\n            {placeholder}\n          </Placeholder>\n        )}\n        <StateStack direction=\"row\" gap={1} alignItems=\"center\">\n          {error ? <AlertCircleIcon sentiment=\"danger\" /> : null}\n          {success && !error ? <CheckCircleIcon sentiment=\"success\" /> : null}\n          {clearable && selectedData.selectedValues.length > 0 ? (\n            <Button\n              aria-label=\"clear value\"\n              disabled={disabled || !selectedData.selectedValues[0] || readOnly}\n              variant=\"ghost\"\n              size=\"small\"\n              icon=\"close\"\n              onClick={event => {\n                event.stopPropagation()\n                setSelectedData({ type: 'clearAll' })\n                if (multiselect) {\n                  onChange?.([])\n                } else {\n                  onChange?.('')\n                }\n              }}\n              sentiment=\"neutral\"\n              data-testid=\"clear-all\"\n            />\n          ) : null}\n          <ArrowDownIcon\n            aria-label=\"show dropdown\"\n            size=\"small\"\n            sentiment=\"neutral\"\n            disabled={disabled || readOnly}\n          />\n        </StateStack>\n      </StyledInputWrapper>\n    </Tooltip>\n  )\n}\n"]} */",
106
106
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
107
107
  });
108
108
  const SelectedValues = /* @__PURE__ */ _styled__default.default(index$1.Text, process.env.NODE_ENV === "production" ? {
@@ -116,7 +116,7 @@ const SelectedValues = /* @__PURE__ */ _styled__default.default(index$1.Text, pr
116
116
  } : {
117
117
  name: "fzu03x",
118
118
  styles: "text-overflow:ellipsis;overflow:hidden",
119
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInputV2/SelectBar.tsx"],"names":[],"mappings":"AA4ImC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInputV2/SelectBar.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons/legacy'\nimport type { RefObject } from 'react'\nimport { useEffect, useMemo, useRef, useState } from 'react'\nimport { Button } from '../Button'\nimport { Stack } from '../Stack'\nimport { Tag } from '../Tag'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\nimport { useSelectInput } from './SelectInputProvider'\nimport { findOptionInOptions } from './findOptionInOptions'\nimport type { DataType, OptionType } from './types'\nimport { INPUT_SIZE_HEIGHT, SIZES_TAG } from './types'\n\ntype SelectBarProps = {\n  size: 'small' | 'medium' | 'large'\n  clearable: boolean\n  disabled: boolean\n  readOnly: boolean\n  placeholder: string\n  success?: string\n  error?: string\n  autoFocus?: boolean\n  innerRef: RefObject<HTMLDivElement>\n  id?: string\n  'data-testid': string\n  label?: string\n  tooltip?: string\n}\n\ntype DisplayValuesProps = {\n  refTag: RefObject<HTMLDivElement>\n  nonOverflowedValues: OptionType[]\n  disabled: boolean\n  readOnly: boolean\n  overflowed: boolean\n  overflowAmount: number\n  size: 'small' | 'medium' | 'large'\n}\n\nconst StateStack = styled(Stack)`\n  padding-right: ${({ theme }) => theme.space['2']};\n  display: flex;\n`\nconst Placeholder = styled(Text)`\nuser-select: none;\n`\n\nconst StyledInputWrapper = styled(Stack)<{\n  'data-readonly': boolean\n  'data-disabled': boolean\n  'data-size': 'small' | 'medium' | 'large'\n  'data-state': 'neutral' | 'success' | 'danger'\n  'data-dropdownvisible': boolean\n  'aria-label'?: string\n}>`\n  display: flex;\n  padding: ${({ theme }) => theme.space[1]};\n  padding-right: 0;\n  padding-left: ${({ theme }) => theme.space[2]};\n  cursor: pointer;\n  box-shadow: none;\n  background: ${({ theme }) => theme.colors.neutral.background};\n  border-radius: ${({ theme }) => theme.radii.default};\n  width: 100%;\n  overflow: hidden;\n\n  &[data-size='small'] {\n    height: ${INPUT_SIZE_HEIGHT.small}px;\n    padding-left: ${({ theme }) => theme.space[1]};\n  }\n  &[data-size='medium'] {\n    height: ${INPUT_SIZE_HEIGHT.medium}px;\n  }\n  &[data-size='large'] {\n    height: ${INPUT_SIZE_HEIGHT.large}px;\n  }\n  &[data-state='neutral'] {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n    &:not([data-disabled='true']):hover,\n    :not([data-disabled='true']):focus {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      outline: none;\n    }\n\n    &[data-dropdownvisible='true'] {\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n  }\n  }\n\n  &[data-state='success'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.success.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n    }\n  \n    &[data-dropdownvisible='true'] {\n      border-color: ${({ theme }) => theme.colors.success.borderHover};\n    }\n  }\n\n  &[data-state='danger'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.danger.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n  \n    &[data-dropdownvisible='true'] {\n      border-color: ${({ theme }) => theme.colors.danger.borderHover};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly]):hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n  }\n`\nconst CustomTag = styled(Tag)`\n  height: fit-content;\n  width: fit-content;\n`\nconst SelectedValues = styled(Text)`\ntext-overflow: ellipsis;\noverflow: hidden; \n`\n\nconst isValidSelectedValue = (selectedValue: string, options: DataType) =>\n  !Array.isArray(options)\n    ? Object.keys(options).some(group =>\n        options[group].some(\n          option => option.value === selectedValue && !option.disabled,\n        ),\n      )\n    : options.some(option => option.value === selectedValue && !option.disabled)\n\nconst DisplayValues = ({\n  refTag,\n  nonOverflowedValues,\n  disabled,\n  readOnly,\n  overflowed,\n  overflowAmount,\n  size,\n}: DisplayValuesProps) => {\n  const { multiselect, selectedData, setSelectedData, options, onChange } =\n    useSelectInput()\n\n  return multiselect ? (\n    <Stack\n      direction=\"row\"\n      gap=\"1\"\n      wrap=\"nowrap\"\n      ref={refTag}\n      alignItems=\"center\"\n    >\n      {nonOverflowedValues.map(option => (\n        <CustomTag\n          data-testid=\"selected-options-tags\"\n          key={option?.value}\n          sentiment=\"neutral\"\n          disabled={disabled}\n          onClose={\n            !readOnly\n              ? event => {\n                  event.stopPropagation()\n                  setSelectedData({\n                    type: 'selectOption',\n                    clickedOption: option,\n                  })\n                  const newSelectedValues = selectedData.selectedValues?.filter(\n                    val => val !== option.value,\n                  )\n                  onChange?.(newSelectedValues)\n                }\n              : undefined\n          }\n        >\n          {option?.label}\n        </CustomTag>\n      ))}\n      {overflowed ? (\n        <Tag\n          sentiment=\"neutral\"\n          disabled={disabled}\n          key=\"+\"\n          data-testid=\"plus-tag\"\n          aria-label=\"Plus tag\"\n        >\n          <Icon name=\"plus\" />\n          {overflowAmount}\n        </Tag>\n      ) : null}\n    </Stack>\n  ) : (\n    <SelectedValues as=\"div\" variant={size === 'large' ? 'body' : 'bodySmall'}>\n      {selectedData.selectedValues[0]\n        ? findOptionInOptions(options, selectedData.selectedValues[0])?.label\n        : null}\n    </SelectedValues>\n  )\n}\n\nexport const SelectBar = ({\n  size,\n  clearable,\n  disabled,\n  readOnly,\n  placeholder,\n  success,\n  error,\n  autoFocus,\n  tooltip,\n  innerRef,\n  id,\n  'data-testid': dataTestId,\n  label,\n}: SelectBarProps) => {\n  const {\n    isDropdownVisible,\n    onChange,\n    setIsDropdownVisible,\n    options,\n    selectedData,\n    setSelectedData,\n    multiselect,\n  } = useSelectInput()\n  const openable = !(readOnly || disabled)\n  const refTag = useRef<HTMLDivElement>(null)\n  const width = innerRef.current?.offsetWidth\n  const [overflowed, setOverflowed] = useState(false)\n  const [overflowAmount, setOverflowAmount] = useState(0)\n  const [nonOverflowedValues, setNonOverFlowedValues] = useState<OptionType[]>(\n    () => {\n      if (selectedData.selectedValues[0]) {\n        const firstSelectOption = findOptionInOptions(\n          options,\n          selectedData.selectedValues[0],\n        )\n\n        return firstSelectOption ? [firstSelectOption] : []\n      }\n\n      return []\n    },\n  )\n\n  const state = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    // When too many items are selected, too avoid overflow, compute the number of tags to display and add a + tag\n    let tagsWidth = 0\n    let computedOverflowAmount = 0\n    let computedNonOverflowedValues: OptionType[] = []\n    const newSelectedValues = selectedData.selectedValues.filter(\n      selectedValue => isValidSelectedValue(selectedValue, options),\n    )\n    for (const selectedValue of newSelectedValues) {\n      const selectedOption = findOptionInOptions(options, selectedValue)\n      if (\n        selectedOption?.label &&\n        width &&\n        isValidSelectedValue(selectedValue, options)\n      ) {\n        const lengthValue = selectedOption.value.length // Find a better way to find the number of displayed characters?\n        const totalTagWidth =\n          SIZES_TAG.tagWidth + SIZES_TAG.letterWidth * lengthValue\n        if (totalTagWidth + tagsWidth > width - 100) {\n          computedOverflowAmount += 1\n          setOverflowAmount(computedOverflowAmount)\n        } else {\n          computedNonOverflowedValues = [\n            ...computedNonOverflowedValues,\n            selectedOption,\n          ]\n          setNonOverFlowedValues(computedNonOverflowedValues)\n          tagsWidth += totalTagWidth\n        }\n      }\n    }\n    if (computedOverflowAmount === 0) {\n      setOverflowed(false)\n    } else {\n      setOverflowed(true)\n    }\n    setOverflowAmount(computedOverflowAmount)\n  }, [options, selectedData.selectedValues, width])\n\n  useEffect(() => {\n    setSelectedData({ type: 'update' })\n  }, [setSelectedData, options])\n\n  return (\n    <Tooltip text={tooltip}>\n      <StyledInputWrapper\n        role=\"combobox\"\n        id={id}\n        data-disabled={disabled}\n        data-readonly={readOnly}\n        data-size={size}\n        data-dropdownvisible={isDropdownVisible}\n        data-state={state}\n        direction=\"row\"\n        wrap=\"nowrap\"\n        gap=\"1\"\n        justifyContent=\"space-between\"\n        alignItems=\"center\"\n        onClick={\n          openable ? () => setIsDropdownVisible(!isDropdownVisible) : undefined\n        }\n        data-testid={dataTestId}\n        autoFocus={autoFocus}\n        onKeyDown={event => {\n          if (event.key === 'ArrowDown') {\n            if (!isDropdownVisible) {\n              setIsDropdownVisible(true)\n            } else {\n              document.getElementById(`option-0`)?.focus()\n            }\n          }\n\n          return ['Enter', ' '].includes(event.key) && openable\n            ? setIsDropdownVisible(!isDropdownVisible)\n            : null\n        }}\n        ref={innerRef}\n        aria-haspopup=\"listbox\"\n        aria-expanded={isDropdownVisible}\n        tabIndex={0}\n        aria-label={label}\n      >\n        {selectedData.selectedValues.length > 0 ? (\n          <DisplayValues\n            refTag={refTag}\n            nonOverflowedValues={nonOverflowedValues}\n            disabled={disabled}\n            readOnly={readOnly}\n            overflowed={overflowed}\n            overflowAmount={overflowAmount}\n            size={size}\n          />\n        ) : (\n          <Placeholder\n            as=\"p\"\n            variant={size === 'large' ? 'body' : 'bodySmall'}\n            sentiment=\"neutral\"\n            disabled={disabled}\n            prominence=\"weak\"\n          >\n            {placeholder}\n          </Placeholder>\n        )}\n        <StateStack direction=\"row\" gap={1} alignItems=\"center\">\n          {error ? <Icon name=\"alert\" sentiment=\"danger\" /> : null}\n          {success && !error ? (\n            <Icon name=\"checkbox-circle-outline\" sentiment=\"success\" />\n          ) : null}\n          {clearable && selectedData.selectedValues.length > 0 ? (\n            <Button\n              aria-label=\"clear value\"\n              disabled={disabled || !selectedData.selectedValues[0] || readOnly}\n              variant=\"ghost\"\n              size=\"small\"\n              icon=\"close\"\n              onClick={event => {\n                event.stopPropagation()\n                setSelectedData({ type: 'clearAll' })\n                if (multiselect) {\n                  onChange?.([])\n                } else {\n                  onChange?.('')\n                }\n              }}\n              sentiment=\"neutral\"\n              data-testid=\"clear-all\"\n            />\n          ) : null}\n          <Icon\n            aria-label=\"show dropdown\"\n            size=\"small\"\n            name=\"arrow-down\"\n            sentiment=\"neutral\"\n            disabled={disabled || readOnly}\n          />\n        </StateStack>\n      </StyledInputWrapper>\n    </Tooltip>\n  )\n}\n"]} */",
119
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInputV2/SelectBar.tsx"],"names":[],"mappings":"AAiJmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInputV2/SelectBar.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport {\n  AlertCircleIcon,\n  ArrowDownIcon,\n  CheckCircleIcon,\n  PlusIcon,\n} from '@ultraviolet/icons'\nimport type { RefObject } from 'react'\nimport { useEffect, useMemo, useRef, useState } from 'react'\nimport { Button } from '../Button'\nimport { Stack } from '../Stack'\nimport { Tag } from '../Tag'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\nimport { useSelectInput } from './SelectInputProvider'\nimport { findOptionInOptions } from './findOptionInOptions'\nimport type { DataType, OptionType } from './types'\nimport { INPUT_SIZE_HEIGHT, SIZES_TAG } from './types'\n\ntype SelectBarProps = {\n  size: 'small' | 'medium' | 'large'\n  clearable: boolean\n  disabled: boolean\n  readOnly: boolean\n  placeholder: string\n  success?: string\n  error?: string\n  autoFocus?: boolean\n  innerRef: RefObject<HTMLDivElement>\n  id?: string\n  'data-testid': string\n  label?: string\n  tooltip?: string\n}\n\ntype DisplayValuesProps = {\n  refTag: RefObject<HTMLDivElement>\n  nonOverflowedValues: OptionType[]\n  disabled: boolean\n  readOnly: boolean\n  overflowed: boolean\n  overflowAmount: number\n  size: 'small' | 'medium' | 'large'\n}\n\nconst StateStack = styled(Stack)`\n  padding-right: ${({ theme }) => theme.space['2']};\n  display: flex;\n`\nconst Placeholder = styled(Text)`\nuser-select: none;\n`\n\nconst StyledInputWrapper = styled(Stack)<{\n  'data-readonly': boolean\n  'data-disabled': boolean\n  'data-size': 'small' | 'medium' | 'large'\n  'data-state': 'neutral' | 'success' | 'danger'\n  'data-dropdownvisible': boolean\n  'aria-label'?: string\n}>`\n  display: flex;\n  padding: ${({ theme }) => theme.space[1]};\n  padding-right: 0;\n  padding-left: ${({ theme }) => theme.space[2]};\n  cursor: pointer;\n  box-shadow: none;\n  background: ${({ theme }) => theme.colors.neutral.background};\n  border-radius: ${({ theme }) => theme.radii.default};\n  width: 100%;\n  overflow: hidden;\n\n  &[data-size='small'] {\n    height: ${INPUT_SIZE_HEIGHT.small}px;\n    padding-left: ${({ theme }) => theme.space[1]};\n  }\n  &[data-size='medium'] {\n    height: ${INPUT_SIZE_HEIGHT.medium}px;\n  }\n  &[data-size='large'] {\n    height: ${INPUT_SIZE_HEIGHT.large}px;\n  }\n  &[data-state='neutral'] {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n    &:not([data-disabled='true']):hover,\n    :not([data-disabled='true']):focus {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      outline: none;\n    }\n\n    &[data-dropdownvisible='true'] {\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n  }\n  }\n\n  &[data-state='success'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.success.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n    }\n  \n    &[data-dropdownvisible='true'] {\n      border-color: ${({ theme }) => theme.colors.success.borderHover};\n    }\n  }\n\n  &[data-state='danger'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    &:not([data-disabled=\"true\"]):not([data-readonly=\"true\"]):active {\n      border-color: ${({ theme }) => theme.colors.danger.borderHover};\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n  \n    &[data-dropdownvisible='true'] {\n      border-color: ${({ theme }) => theme.colors.danger.borderHover};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly]):hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n  }\n`\nconst CustomTag = styled(Tag)`\n  height: fit-content;\n  width: fit-content;\n`\nconst SelectedValues = styled(Text)`\ntext-overflow: ellipsis;\noverflow: hidden; \n`\n\nconst isValidSelectedValue = (selectedValue: string, options: DataType) =>\n  !Array.isArray(options)\n    ? Object.keys(options).some(group =>\n        options[group].some(\n          option => option.value === selectedValue && !option.disabled,\n        ),\n      )\n    : options.some(option => option.value === selectedValue && !option.disabled)\n\nconst DisplayValues = ({\n  refTag,\n  nonOverflowedValues,\n  disabled,\n  readOnly,\n  overflowed,\n  overflowAmount,\n  size,\n}: DisplayValuesProps) => {\n  const { multiselect, selectedData, setSelectedData, options, onChange } =\n    useSelectInput()\n\n  return multiselect ? (\n    <Stack\n      direction=\"row\"\n      gap=\"1\"\n      wrap=\"nowrap\"\n      ref={refTag}\n      alignItems=\"center\"\n    >\n      {nonOverflowedValues.map(option => (\n        <CustomTag\n          data-testid=\"selected-options-tags\"\n          key={option?.value}\n          sentiment=\"neutral\"\n          disabled={disabled}\n          onClose={\n            !readOnly\n              ? event => {\n                  event.stopPropagation()\n                  setSelectedData({\n                    type: 'selectOption',\n                    clickedOption: option,\n                  })\n                  const newSelectedValues = selectedData.selectedValues?.filter(\n                    val => val !== option.value,\n                  )\n                  onChange?.(newSelectedValues)\n                }\n              : undefined\n          }\n        >\n          {option?.label}\n        </CustomTag>\n      ))}\n      {overflowed ? (\n        <Tag\n          sentiment=\"neutral\"\n          disabled={disabled}\n          key=\"+\"\n          data-testid=\"plus-tag\"\n          aria-label=\"Plus tag\"\n        >\n          <PlusIcon />\n          {overflowAmount}\n        </Tag>\n      ) : null}\n    </Stack>\n  ) : (\n    <SelectedValues\n      as=\"div\"\n      variant={size === 'large' ? 'body' : 'bodySmall'}\n      disabled={disabled}\n      prominence=\"default\"\n      sentiment=\"neutral\"\n    >\n      {selectedData.selectedValues[0]\n        ? findOptionInOptions(options, selectedData.selectedValues[0])?.label\n        : null}\n    </SelectedValues>\n  )\n}\n\nexport const SelectBar = ({\n  size,\n  clearable,\n  disabled,\n  readOnly,\n  placeholder,\n  success,\n  error,\n  autoFocus,\n  tooltip,\n  innerRef,\n  id,\n  'data-testid': dataTestId,\n  label,\n}: SelectBarProps) => {\n  const {\n    isDropdownVisible,\n    onChange,\n    setIsDropdownVisible,\n    options,\n    selectedData,\n    setSelectedData,\n    multiselect,\n  } = useSelectInput()\n  const openable = !(readOnly || disabled)\n  const refTag = useRef<HTMLDivElement>(null)\n  const width = innerRef.current?.offsetWidth\n  const [overflowed, setOverflowed] = useState(false)\n  const [overflowAmount, setOverflowAmount] = useState(0)\n  const [nonOverflowedValues, setNonOverFlowedValues] = useState<OptionType[]>(\n    () => {\n      if (selectedData.selectedValues[0]) {\n        const firstSelectOption = findOptionInOptions(\n          options,\n          selectedData.selectedValues[0],\n        )\n\n        return firstSelectOption ? [firstSelectOption] : []\n      }\n\n      return []\n    },\n  )\n\n  const state = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    // When too many items are selected, too avoid overflow, compute the number of tags to display and add a + tag\n    let tagsWidth = 0\n    let computedOverflowAmount = 0\n    let computedNonOverflowedValues: OptionType[] = []\n    const newSelectedValues = selectedData.selectedValues.filter(\n      selectedValue => isValidSelectedValue(selectedValue, options),\n    )\n    for (const selectedValue of newSelectedValues) {\n      const selectedOption = findOptionInOptions(options, selectedValue)\n      if (\n        selectedOption?.label &&\n        width &&\n        isValidSelectedValue(selectedValue, options)\n      ) {\n        const lengthValue = selectedOption.value.length // Find a better way to find the number of displayed characters?\n        const totalTagWidth =\n          SIZES_TAG.tagWidth + SIZES_TAG.letterWidth * lengthValue\n        if (totalTagWidth + tagsWidth > width - 100) {\n          computedOverflowAmount += 1\n          setOverflowAmount(computedOverflowAmount)\n        } else {\n          computedNonOverflowedValues = [\n            ...computedNonOverflowedValues,\n            selectedOption,\n          ]\n          setNonOverFlowedValues(computedNonOverflowedValues)\n          tagsWidth += totalTagWidth\n        }\n      }\n    }\n    if (computedOverflowAmount === 0) {\n      setOverflowed(false)\n    } else {\n      setOverflowed(true)\n    }\n    setOverflowAmount(computedOverflowAmount)\n  }, [options, selectedData.selectedValues, width])\n\n  useEffect(() => {\n    setSelectedData({ type: 'update' })\n  }, [setSelectedData, options])\n\n  return (\n    <Tooltip text={tooltip}>\n      <StyledInputWrapper\n        role=\"combobox\"\n        id={id}\n        data-disabled={disabled}\n        data-readonly={readOnly}\n        data-size={size}\n        data-dropdownvisible={isDropdownVisible}\n        data-state={state}\n        direction=\"row\"\n        wrap=\"nowrap\"\n        gap=\"1\"\n        justifyContent=\"space-between\"\n        alignItems=\"center\"\n        onClick={\n          openable ? () => setIsDropdownVisible(!isDropdownVisible) : undefined\n        }\n        data-testid={dataTestId}\n        autoFocus={autoFocus}\n        onKeyDown={event => {\n          if (event.key === 'ArrowDown') {\n            if (!isDropdownVisible) {\n              setIsDropdownVisible(true)\n            } else {\n              document.getElementById(`option-0`)?.focus()\n            }\n          }\n\n          return ['Enter', ' '].includes(event.key) && openable\n            ? setIsDropdownVisible(!isDropdownVisible)\n            : null\n        }}\n        ref={innerRef}\n        aria-haspopup=\"listbox\"\n        aria-expanded={isDropdownVisible}\n        tabIndex={0}\n        aria-label={label}\n      >\n        {selectedData.selectedValues.length > 0 ? (\n          <DisplayValues\n            refTag={refTag}\n            nonOverflowedValues={nonOverflowedValues}\n            disabled={disabled}\n            readOnly={readOnly}\n            overflowed={overflowed}\n            overflowAmount={overflowAmount}\n            size={size}\n          />\n        ) : (\n          <Placeholder\n            as=\"p\"\n            variant={size === 'large' ? 'body' : 'bodySmall'}\n            sentiment=\"neutral\"\n            disabled={disabled}\n            prominence=\"weak\"\n          >\n            {placeholder}\n          </Placeholder>\n        )}\n        <StateStack direction=\"row\" gap={1} alignItems=\"center\">\n          {error ? <AlertCircleIcon sentiment=\"danger\" /> : null}\n          {success && !error ? <CheckCircleIcon sentiment=\"success\" /> : null}\n          {clearable && selectedData.selectedValues.length > 0 ? (\n            <Button\n              aria-label=\"clear value\"\n              disabled={disabled || !selectedData.selectedValues[0] || readOnly}\n              variant=\"ghost\"\n              size=\"small\"\n              icon=\"close\"\n              onClick={event => {\n                event.stopPropagation()\n                setSelectedData({ type: 'clearAll' })\n                if (multiselect) {\n                  onChange?.([])\n                } else {\n                  onChange?.('')\n                }\n              }}\n              sentiment=\"neutral\"\n              data-testid=\"clear-all\"\n            />\n          ) : null}\n          <ArrowDownIcon\n            aria-label=\"show dropdown\"\n            size=\"small\"\n            sentiment=\"neutral\"\n            disabled={disabled || readOnly}\n          />\n        </StateStack>\n      </StyledInputWrapper>\n    </Tooltip>\n  )\n}\n"]} */",
120
120
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
121
121
  });
122
122
  const isValidSelectedValue = (selectedValue, options) => !Array.isArray(options) ? Object.keys(options).some((group) => options[group].some((option) => option.value === selectedValue && !option.disabled)) : options.some((option) => option.value === selectedValue && !option.disabled);
@@ -147,10 +147,10 @@ const DisplayValues = ({
147
147
  onChange?.(newSelectedValues);
148
148
  } : void 0, children: option?.label }, option?.value)),
149
149
  overflowed ? /* @__PURE__ */ jsxRuntime.jsxs(index$2.Tag, { sentiment: "neutral", disabled, "data-testid": "plus-tag", "aria-label": "Plus tag", children: [
150
- /* @__PURE__ */ jsxRuntime.jsx(legacy.Icon, { name: "plus" }),
150
+ /* @__PURE__ */ jsxRuntime.jsx(icons.PlusIcon, {}),
151
151
  overflowAmount
152
152
  ] }, "+") : null
153
- ] }) : /* @__PURE__ */ jsxRuntime.jsx(SelectedValues, { as: "div", variant: size === "large" ? "body" : "bodySmall", children: selectedData.selectedValues[0] ? findOptionInOptions.findOptionInOptions(options, selectedData.selectedValues[0])?.label : null });
153
+ ] }) : /* @__PURE__ */ jsxRuntime.jsx(SelectedValues, { as: "div", variant: size === "large" ? "body" : "bodySmall", disabled, prominence: "default", sentiment: "neutral", children: selectedData.selectedValues[0] ? findOptionInOptions.findOptionInOptions(options, selectedData.selectedValues[0])?.label : null });
154
154
  };
155
155
  const SelectBar = ({
156
156
  size,
@@ -241,8 +241,8 @@ const SelectBar = ({
241
241
  }, ref: innerRef, "aria-haspopup": "listbox", "aria-expanded": isDropdownVisible, tabIndex: 0, "aria-label": label, children: [
242
242
  selectedData.selectedValues.length > 0 ? /* @__PURE__ */ jsxRuntime.jsx(DisplayValues, { refTag, nonOverflowedValues, disabled, readOnly, overflowed, overflowAmount, size }) : /* @__PURE__ */ jsxRuntime.jsx(Placeholder, { as: "p", variant: size === "large" ? "body" : "bodySmall", sentiment: "neutral", disabled, prominence: "weak", children: placeholder }),
243
243
  /* @__PURE__ */ jsxRuntime.jsxs(StateStack, { direction: "row", gap: 1, alignItems: "center", children: [
244
- error ? /* @__PURE__ */ jsxRuntime.jsx(legacy.Icon, { name: "alert", sentiment: "danger" }) : null,
245
- success && !error ? /* @__PURE__ */ jsxRuntime.jsx(legacy.Icon, { name: "checkbox-circle-outline", sentiment: "success" }) : null,
244
+ error ? /* @__PURE__ */ jsxRuntime.jsx(icons.AlertCircleIcon, { sentiment: "danger" }) : null,
245
+ success && !error ? /* @__PURE__ */ jsxRuntime.jsx(icons.CheckCircleIcon, { sentiment: "success" }) : null,
246
246
  clearable && selectedData.selectedValues.length > 0 ? /* @__PURE__ */ jsxRuntime.jsx(index$4.Button, { "aria-label": "clear value", disabled: disabled || !selectedData.selectedValues[0] || readOnly, variant: "ghost", size: "small", icon: "close", onClick: (event) => {
247
247
  event.stopPropagation();
248
248
  setSelectedData({
@@ -254,7 +254,7 @@ const SelectBar = ({
254
254
  onChange?.("");
255
255
  }
256
256
  }, sentiment: "neutral", "data-testid": "clear-all" }) : null,
257
- /* @__PURE__ */ jsxRuntime.jsx(legacy.Icon, { "aria-label": "show dropdown", size: "small", name: "arrow-down", sentiment: "neutral", disabled: disabled || readOnly })
257
+ /* @__PURE__ */ jsxRuntime.jsx(icons.ArrowDownIcon, { "aria-label": "show dropdown", size: "small", sentiment: "neutral", disabled: disabled || readOnly })
258
258
  ] })
259
259
  ] }) });
260
260
  };