@ultraviolet/ui 2.0.0-beta.13 → 2.0.0-beta.15

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 (65) hide show
  1. package/dist/components/Card/index.cjs +4 -5
  2. package/dist/components/Card/index.d.ts +0 -4
  3. package/dist/components/Card/index.js +4 -5
  4. package/dist/components/Checkbox/index.cjs +35 -53
  5. package/dist/components/Checkbox/index.d.ts +0 -8
  6. package/dist/components/Checkbox/index.js +27 -45
  7. package/dist/components/CopyButton/index.cjs +1 -2
  8. package/dist/components/CopyButton/index.d.ts +1 -5
  9. package/dist/components/CopyButton/index.js +1 -2
  10. package/dist/components/LineChart/CustomLegend.cjs +9 -9
  11. package/dist/components/LineChart/CustomLegend.js +9 -9
  12. package/dist/components/Link/index.cjs +14 -30
  13. package/dist/components/Link/index.d.ts +2 -11
  14. package/dist/components/Link/index.js +14 -30
  15. package/dist/components/List/Cell.cjs +2 -15
  16. package/dist/components/List/Cell.d.ts +0 -6
  17. package/dist/components/List/Cell.js +2 -15
  18. package/dist/components/List/Row.cjs +7 -7
  19. package/dist/components/List/Row.js +7 -7
  20. package/dist/components/List/index.d.ts +0 -1
  21. package/dist/components/Menu/MenuContent.cjs +8 -12
  22. package/dist/components/Menu/MenuContent.d.ts +0 -3
  23. package/dist/components/Menu/MenuContent.js +8 -12
  24. package/dist/components/Menu/constants.cjs +0 -1
  25. package/dist/components/Menu/constants.js +0 -1
  26. package/dist/components/Menu/index.d.ts +0 -2
  27. package/dist/components/Menu/types.d.ts +0 -9
  28. package/dist/components/Modal/ModalContent.cjs +2 -8
  29. package/dist/components/Modal/ModalContent.d.ts +1 -2
  30. package/dist/components/Modal/ModalContent.js +2 -8
  31. package/dist/components/Modal/components/Dialog.cjs +6 -8
  32. package/dist/components/Modal/components/Dialog.d.ts +1 -1
  33. package/dist/components/Modal/components/Dialog.js +6 -8
  34. package/dist/components/Modal/components/Disclosure.cjs +0 -3
  35. package/dist/components/Modal/components/Disclosure.js +0 -3
  36. package/dist/components/Modal/index.cjs +2 -7
  37. package/dist/components/Modal/index.d.ts +1 -18
  38. package/dist/components/Modal/index.js +2 -7
  39. package/dist/components/Modal/types.d.ts +0 -15
  40. package/dist/components/RadioGroup/index.cjs +2 -3
  41. package/dist/components/RadioGroup/index.d.ts +2 -7
  42. package/dist/components/RadioGroup/index.js +2 -3
  43. package/dist/components/SelectInput/SelectInputProvider.cjs +8 -8
  44. package/dist/components/SelectInput/SelectInputProvider.d.ts +2 -1
  45. package/dist/components/SelectInput/SelectInputProvider.js +8 -8
  46. package/dist/components/SelectInput/index.cjs +5 -4
  47. package/dist/components/SelectInput/index.d.ts +6 -1
  48. package/dist/components/SelectInput/index.js +5 -4
  49. package/dist/components/Separator/index.cjs +8 -9
  50. package/dist/components/Separator/index.d.ts +1 -5
  51. package/dist/components/Separator/index.js +8 -9
  52. package/dist/components/Skeleton/Slider.cjs +3 -3
  53. package/dist/components/Skeleton/Slider.js +3 -3
  54. package/dist/components/SwitchButton/Option.cjs +25 -4
  55. package/dist/components/SwitchButton/Option.d.ts +4 -2
  56. package/dist/components/SwitchButton/Option.js +25 -4
  57. package/dist/components/SwitchButton/index.cjs +1 -1
  58. package/dist/components/SwitchButton/index.d.ts +3 -1
  59. package/dist/components/SwitchButton/index.js +1 -1
  60. package/dist/components/Table/HeaderCell.cjs +4 -4
  61. package/dist/components/Table/HeaderCell.js +4 -4
  62. package/dist/components/Text/index.cjs +2 -4
  63. package/dist/components/Text/index.d.ts +2 -6
  64. package/dist/components/Text/index.js +2 -4
  65. package/package.json +3 -3
@@ -15,7 +15,6 @@ const RadioGroupRadio = ({
15
15
  onBlur,
16
16
  disabled,
17
17
  error,
18
- name,
19
18
  value,
20
19
  label,
21
20
  helper,
@@ -35,7 +34,7 @@ const RadioGroupRadio = ({
35
34
  groupValue,
36
35
  error: errorContext
37
36
  } = context;
38
- return /* @__PURE__ */ jsx(Radio, { onChange, checked: groupValue === value, onFocus, onBlur, disabled, error: error || errorContext, name: groupName ?? name, value, label, helper, className, autoFocus, onKeyDown, "data-testid": dataTestId, tooltip });
37
+ return /* @__PURE__ */ jsx(Radio, { onChange, checked: groupValue === value, onFocus, onBlur, disabled, error: error || errorContext, name: groupName, value, label, helper, className, autoFocus, onKeyDown, "data-testid": dataTestId, tooltip });
39
38
  };
40
39
  const FieldSet = /* @__PURE__ */ _styled("fieldset", process.env.NODE_ENV === "production" ? {
41
40
  target: "e15shfap0"
@@ -47,7 +46,7 @@ const FieldSet = /* @__PURE__ */ _styled("fieldset", process.env.NODE_ENV === "p
47
46
  styles: "border:none;padding:0;margin:0"
48
47
  } : {
49
48
  name: "7o2an9",
50
- styles: "border:none;padding:0;margin:0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1JhZGlvR3JvdXAvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlGZ0MiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvUmFkaW9Hcm91cC9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQge1xuICB0eXBlIENvbXBvbmVudFByb3BzLFxuICB0eXBlIElucHV0SFRNTEF0dHJpYnV0ZXMsXG4gIHR5cGUgUmVhY3ROb2RlLFxuICBjcmVhdGVDb250ZXh0LFxuICB1c2VDb250ZXh0LFxuICB1c2VNZW1vLFxufSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IExhYmVsIH0gZnJvbSAnLi4vTGFiZWwnXG5pbXBvcnQgeyBSYWRpbyB9IGZyb20gJy4uL1JhZGlvJ1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tICcuLi9TdGFjaydcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuXG50eXBlIFJhZGlvR3JvdXBDb250ZXh0VHlwZSA9IHtcbiAgZ3JvdXBOYW1lPzogc3RyaW5nXG4gIGdyb3VwVmFsdWU6IHN0cmluZyB8IG51bWJlclxuICBlcnJvcjogYm9vbGVhblxufSAmIFJlcXVpcmVkPFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ29uQ2hhbmdlJz4+ICZcbiAgUGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAncmVxdWlyZWQnPlxuXG5jb25zdCBSYWRpb0dyb3VwQ29udGV4dCA9IGNyZWF0ZUNvbnRleHQ8UmFkaW9Hcm91cENvbnRleHRUeXBlIHwgdW5kZWZpbmVkPihcbiAgdW5kZWZpbmVkLFxuKVxuXG50eXBlIFJhZGlvR3JvdXBSYWRpb1Byb3BzID0gT21pdDxcbiAgQ29tcG9uZW50UHJvcHM8dHlwZW9mIFJhZGlvPixcbiAgJ29uQ2hhbmdlJyB8ICdjaGVja2VkJyB8ICdyZXF1aXJlZCdcbj4gJiB7XG4gIC8qKlxuICAgKiBAZGVwcmVjYXRlZCB5b3UgZG9uJ3QgbmVlZCB0byB1c2UgYG5hbWVgIGFueW1vcmUsIHRoZSBuYW1lIHdpbGwgYmUgcGFzc2VkIGZyb20gdGhlIHBhcmVudCBgUmFkaW9Hcm91cGAuXG4gICAqL1xuICBuYW1lPzogc3RyaW5nXG59XG5cbmNvbnN0IFJhZGlvR3JvdXBSYWRpbyA9ICh7XG4gIG9uRm9jdXMsXG4gIG9uQmx1cixcbiAgZGlzYWJsZWQsXG4gIGVycm9yLFxuICBuYW1lLFxuICB2YWx1ZSxcbiAgbGFiZWwsXG4gIGhlbHBlcixcbiAgY2xhc3NOYW1lLFxuICBhdXRvRm9jdXMsXG4gIG9uS2V5RG93bixcbiAgdG9vbHRpcCxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbn06IFJhZGlvR3JvdXBSYWRpb1Byb3BzKSA9PiB7XG4gIGNvbnN0IGNvbnRleHQgPSB1c2VDb250ZXh0KFJhZGlvR3JvdXBDb250ZXh0KVxuXG4gIGlmICghY29udGV4dCkge1xuICAgIHRocm93IG5ldyBFcnJvcignUmFkaW9Hcm91cC5SYWRpbyBjYW4gb25seSBiZSB1c2VkIGluc2lkZSBhIFJhZGlvR3JvdXAnKVxuICB9XG5cbiAgY29uc3QgeyBncm91cE5hbWUsIG9uQ2hhbmdlLCBncm91cFZhbHVlLCBlcnJvcjogZXJyb3JDb250ZXh0IH0gPSBjb250ZXh0XG5cbiAgcmV0dXJuIChcbiAgICA8UmFkaW9cbiAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAgIGNoZWNrZWQ9e2dyb3VwVmFsdWUgPT09IHZhbHVlfVxuICAgICAgb25Gb2N1cz17b25Gb2N1c31cbiAgICAgIG9uQmx1cj17b25CbHVyfVxuICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgZXJyb3I9e2Vycm9yIHx8IGVycm9yQ29udGV4dH1cbiAgICAgIG5hbWU9e2dyb3VwTmFtZSA/PyBuYW1lfVxuICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgbGFiZWw9e2xhYmVsfVxuICAgICAgaGVscGVyPXtoZWxwZXJ9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGF1dG9Gb2N1cz17YXV0b0ZvY3VzfVxuICAgICAgb25LZXlEb3duPXtvbktleURvd259XG4gICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAgIHRvb2x0aXA9e3Rvb2x0aXB9XG4gICAgLz5cbiAgKVxufVxuXG5jb25zdCBGaWVsZFNldCA9IHN0eWxlZC5maWVsZHNldGBcbiAgYm9yZGVyOiBub25lO1xuICBwYWRkaW5nOiAwO1xuICBtYXJnaW46IDA7XG5gXG5cbnR5cGUgUmFkaW9Hcm91cFByb3BzID0ge1xuICBsZWdlbmQ/OiBzdHJpbmdcbiAgbGVnZW5kRGVzY3JpcHRpb24/OiBSZWFjdE5vZGVcbiAgdmFsdWU6IHN0cmluZyB8IG51bWJlclxuICBjbGFzc05hbWU/OiBzdHJpbmdcbiAgaGVscGVyPzogUmVhY3ROb2RlXG4gIGVycm9yPzogUmVhY3ROb2RlXG4gIGRpcmVjdGlvbj86ICdyb3cnIHwgJ2NvbHVtbidcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZVxuICBkZXNjcmlwdGlvbj86IFJlYWN0Tm9kZVxufSAmIFJlcXVpcmVkPFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ29uQ2hhbmdlJz4+ICZcbiAgUGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAncmVxdWlyZWQnIHwgJ25hbWUnPlxuXG4vKipcbiAqIFJhZGlvR3JvdXAgaXMgYSBjb21wb25lbnQgdGhhdCBhbGxvd3MgdXNlcnMgdG8gc2VsZWN0IG9uZSBvcHRpb24gZnJvbSBhIGxpc3Qgb2Ygb3B0aW9ucyB1c2luZyByYWRpby5cbiAqL1xuZXhwb3J0IGNvbnN0IFJhZGlvR3JvdXAgPSAoe1xuICBsZWdlbmQsXG4gIGxlZ2VuZERlc2NyaXB0aW9uLFxuICB2YWx1ZSxcbiAgY2xhc3NOYW1lLFxuICBoZWxwZXIsXG4gIGVycm9yLFxuICBkaXJlY3Rpb24gPSAnY29sdW1uJyxcbiAgY2hpbGRyZW4sXG4gIG9uQ2hhbmdlLFxuICBuYW1lLFxuICBkZXNjcmlwdGlvbixcbiAgcmVxdWlyZWQgPSBmYWxzZSxcbn06IFJhZGlvR3JvdXBQcm9wcykgPT4ge1xuICBjb25zdCBjb250ZXh0VmFsdWUgPSB1c2VNZW1vKFxuICAgICgpID0+ICh7XG4gICAgICBncm91cE5hbWU6IG5hbWUsXG4gICAgICBncm91cFZhbHVlOiB2YWx1ZSxcbiAgICAgIG9uQ2hhbmdlLFxuICAgICAgcmVxdWlyZWQsXG4gICAgICBlcnJvcjogISFlcnJvcixcbiAgICB9KSxcbiAgICBbbmFtZSwgdmFsdWUsIG9uQ2hhbmdlLCByZXF1aXJlZCwgZXJyb3JdLFxuICApXG5cbiAgcmV0dXJuIChcbiAgICA8UmFkaW9Hcm91cENvbnRleHQuUHJvdmlkZXIgdmFsdWU9e2NvbnRleHRWYWx1ZX0+XG4gICAgICA8U3RhY2sgZ2FwPXsxfT5cbiAgICAgICAgPEZpZWxkU2V0IGNsYXNzTmFtZT17Y2xhc3NOYW1lfT5cbiAgICAgICAgICA8U3RhY2sgZ2FwPXsxLjV9PlxuICAgICAgICAgICAge2xlZ2VuZCB8fCBkZXNjcmlwdGlvbiA/IChcbiAgICAgICAgICAgICAgPFN0YWNrIGdhcD17MC41fT5cbiAgICAgICAgICAgICAgICB7bGVnZW5kID8gKFxuICAgICAgICAgICAgICAgICAgPExhYmVsXG4gICAgICAgICAgICAgICAgICAgIGFzPVwibGVnZW5kXCJcbiAgICAgICAgICAgICAgICAgICAgcmVxdWlyZWQ9e3JlcXVpcmVkfVxuICAgICAgICAgICAgICAgICAgICBsYWJlbERlc2NyaXB0aW9uPXtsZWdlbmREZXNjcmlwdGlvbn1cbiAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAge2xlZ2VuZH1cbiAgICAgICAgICAgICAgICAgIDwvTGFiZWw+XG4gICAgICAgICAgICAgICAgKSA6IG51bGx9XG4gICAgICAgICAgICAgICAge2Rlc2NyaXB0aW9uID8gKFxuICAgICAgICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgICAgICAgdmFyaWFudD1cImJvZHlTbWFsbFwiXG4gICAgICAgICAgICAgICAgICAgIGFzPXt0eXBlb2YgZGVzY3JpcHRpb24gPT09ICdzdHJpbmcnID8gJ3AnIDogJ2Rpdid9XG4gICAgICAgICAgICAgICAgICAgIHByb21pbmVuY2U9XCJ3ZWFrXCJcbiAgICAgICAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICAgIHtkZXNjcmlwdGlvbn1cbiAgICAgICAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgICAgPFN0YWNrXG4gICAgICAgICAgICAgIGdhcD17ZGlyZWN0aW9uID09PSAnY29sdW1uJyA/IDEgOiAyfVxuICAgICAgICAgICAgICBkaXJlY3Rpb249e2RpcmVjdGlvbn1cbiAgICAgICAgICAgICAgYWxpZ25JdGVtcz1cInN0YXJ0XCJcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgICA8L1N0YWNrPlxuICAgICAgICA8L0ZpZWxkU2V0PlxuICAgICAgICB7aGVscGVyID8gKFxuICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICBhcz1cInNwYW5cIlxuICAgICAgICAgICAgdmFyaWFudD1cImNhcHRpb25cIlxuICAgICAgICAgICAgcHJvbWluZW5jZT1cIndlYWtcIlxuICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgPlxuICAgICAgICAgICAge2hlbHBlcn1cbiAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgICB7ZXJyb3IgPyAoXG4gICAgICAgICAgPFRleHQgYXM9XCJzcGFuXCIgdmFyaWFudD1cImNhcHRpb25cIiBzZW50aW1lbnQ9XCJkYW5nZXJcIj5cbiAgICAgICAgICAgIHtlcnJvcn1cbiAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgPC9TdGFjaz5cbiAgICA8L1JhZGlvR3JvdXBDb250ZXh0LlByb3ZpZGVyPlxuICApXG59XG5cblJhZGlvR3JvdXAuUmFkaW8gPSBSYWRpb0dyb3VwUmFkaW9cbiJdfQ== */",
49
+ styles: "border:none;padding:0;margin:0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1JhZGlvR3JvdXAvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBFZ0MiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvUmFkaW9Hcm91cC9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQge1xuICB0eXBlIENvbXBvbmVudFByb3BzLFxuICB0eXBlIElucHV0SFRNTEF0dHJpYnV0ZXMsXG4gIHR5cGUgUmVhY3ROb2RlLFxuICBjcmVhdGVDb250ZXh0LFxuICB1c2VDb250ZXh0LFxuICB1c2VNZW1vLFxufSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IExhYmVsIH0gZnJvbSAnLi4vTGFiZWwnXG5pbXBvcnQgeyBSYWRpbyB9IGZyb20gJy4uL1JhZGlvJ1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tICcuLi9TdGFjaydcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuXG50eXBlIFJhZGlvR3JvdXBDb250ZXh0VHlwZSA9IHtcbiAgZ3JvdXBOYW1lPzogc3RyaW5nXG4gIGdyb3VwVmFsdWU6IHN0cmluZyB8IG51bWJlclxuICBlcnJvcjogYm9vbGVhblxufSAmIFJlcXVpcmVkPFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ29uQ2hhbmdlJz4+ICZcbiAgUGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAncmVxdWlyZWQnPlxuXG5jb25zdCBSYWRpb0dyb3VwQ29udGV4dCA9IGNyZWF0ZUNvbnRleHQ8UmFkaW9Hcm91cENvbnRleHRUeXBlIHwgdW5kZWZpbmVkPihcbiAgdW5kZWZpbmVkLFxuKVxuXG50eXBlIFJhZGlvR3JvdXBSYWRpb1Byb3BzID0gT21pdDxcbiAgQ29tcG9uZW50UHJvcHM8dHlwZW9mIFJhZGlvPixcbiAgJ29uQ2hhbmdlJyB8ICdjaGVja2VkJyB8ICdyZXF1aXJlZCcgfCAnbmFtZSdcbj5cbmNvbnN0IFJhZGlvR3JvdXBSYWRpbyA9ICh7XG4gIG9uRm9jdXMsXG4gIG9uQmx1cixcbiAgZGlzYWJsZWQsXG4gIGVycm9yLFxuICB2YWx1ZSxcbiAgbGFiZWwsXG4gIGhlbHBlcixcbiAgY2xhc3NOYW1lLFxuICBhdXRvRm9jdXMsXG4gIG9uS2V5RG93bixcbiAgdG9vbHRpcCxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbn06IFJhZGlvR3JvdXBSYWRpb1Byb3BzKSA9PiB7XG4gIGNvbnN0IGNvbnRleHQgPSB1c2VDb250ZXh0KFJhZGlvR3JvdXBDb250ZXh0KVxuXG4gIGlmICghY29udGV4dCkge1xuICAgIHRocm93IG5ldyBFcnJvcignUmFkaW9Hcm91cC5SYWRpbyBjYW4gb25seSBiZSB1c2VkIGluc2lkZSBhIFJhZGlvR3JvdXAnKVxuICB9XG5cbiAgY29uc3QgeyBncm91cE5hbWUsIG9uQ2hhbmdlLCBncm91cFZhbHVlLCBlcnJvcjogZXJyb3JDb250ZXh0IH0gPSBjb250ZXh0XG5cbiAgcmV0dXJuIChcbiAgICA8UmFkaW9cbiAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAgIGNoZWNrZWQ9e2dyb3VwVmFsdWUgPT09IHZhbHVlfVxuICAgICAgb25Gb2N1cz17b25Gb2N1c31cbiAgICAgIG9uQmx1cj17b25CbHVyfVxuICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgZXJyb3I9e2Vycm9yIHx8IGVycm9yQ29udGV4dH1cbiAgICAgIG5hbWU9e2dyb3VwTmFtZX1cbiAgICAgIHZhbHVlPXt2YWx1ZX1cbiAgICAgIGxhYmVsPXtsYWJlbH1cbiAgICAgIGhlbHBlcj17aGVscGVyfVxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBhdXRvRm9jdXM9e2F1dG9Gb2N1c31cbiAgICAgIG9uS2V5RG93bj17b25LZXlEb3dufVxuICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICB0b29sdGlwPXt0b29sdGlwfVxuICAgIC8+XG4gIClcbn1cblxuY29uc3QgRmllbGRTZXQgPSBzdHlsZWQuZmllbGRzZXRgXG4gIGJvcmRlcjogbm9uZTtcbiAgcGFkZGluZzogMDtcbiAgbWFyZ2luOiAwO1xuYFxuXG50eXBlIFJhZGlvR3JvdXBQcm9wcyA9IHtcbiAgbGVnZW5kPzogc3RyaW5nXG4gIGxlZ2VuZERlc2NyaXB0aW9uPzogUmVhY3ROb2RlXG4gIHZhbHVlOiBzdHJpbmcgfCBudW1iZXJcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGhlbHBlcj86IFJlYWN0Tm9kZVxuICBlcnJvcj86IFJlYWN0Tm9kZVxuICBkaXJlY3Rpb24/OiAncm93JyB8ICdjb2x1bW4nXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgZGVzY3JpcHRpb24/OiBSZWFjdE5vZGVcbn0gJiBSZXF1aXJlZDxQaWNrPElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4sICdvbkNoYW5nZSc+PiAmXG4gIFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ3JlcXVpcmVkJyB8ICduYW1lJz5cblxuLyoqXG4gKiBSYWRpb0dyb3VwIGlzIGEgY29tcG9uZW50IHRoYXQgYWxsb3dzIHVzZXJzIHRvIHNlbGVjdCBvbmUgb3B0aW9uIGZyb20gYSBsaXN0IG9mIG9wdGlvbnMgdXNpbmcgcmFkaW8uXG4gKi9cbmV4cG9ydCBjb25zdCBSYWRpb0dyb3VwID0gKHtcbiAgbGVnZW5kLFxuICBsZWdlbmREZXNjcmlwdGlvbixcbiAgdmFsdWUsXG4gIGNsYXNzTmFtZSxcbiAgaGVscGVyLFxuICBlcnJvcixcbiAgZGlyZWN0aW9uID0gJ2NvbHVtbicsXG4gIGNoaWxkcmVuLFxuICBvbkNoYW5nZSxcbiAgbmFtZSxcbiAgZGVzY3JpcHRpb24sXG4gIHJlcXVpcmVkID0gZmFsc2UsXG59OiBSYWRpb0dyb3VwUHJvcHMpID0+IHtcbiAgY29uc3QgY29udGV4dFZhbHVlID0gdXNlTWVtbyhcbiAgICAoKSA9PiAoe1xuICAgICAgZ3JvdXBOYW1lOiBuYW1lLFxuICAgICAgZ3JvdXBWYWx1ZTogdmFsdWUsXG4gICAgICBvbkNoYW5nZSxcbiAgICAgIHJlcXVpcmVkLFxuICAgICAgZXJyb3I6ICEhZXJyb3IsXG4gICAgfSksXG4gICAgW25hbWUsIHZhbHVlLCBvbkNoYW5nZSwgcmVxdWlyZWQsIGVycm9yXSxcbiAgKVxuXG4gIHJldHVybiAoXG4gICAgPFJhZGlvR3JvdXBDb250ZXh0LlByb3ZpZGVyIHZhbHVlPXtjb250ZXh0VmFsdWV9PlxuICAgICAgPFN0YWNrIGdhcD17MX0+XG4gICAgICAgIDxGaWVsZFNldCBjbGFzc05hbWU9e2NsYXNzTmFtZX0+XG4gICAgICAgICAgPFN0YWNrIGdhcD17MS41fT5cbiAgICAgICAgICAgIHtsZWdlbmQgfHwgZGVzY3JpcHRpb24gPyAoXG4gICAgICAgICAgICAgIDxTdGFjayBnYXA9ezAuNX0+XG4gICAgICAgICAgICAgICAge2xlZ2VuZCA/IChcbiAgICAgICAgICAgICAgICAgIDxMYWJlbFxuICAgICAgICAgICAgICAgICAgICBhcz1cImxlZ2VuZFwiXG4gICAgICAgICAgICAgICAgICAgIHJlcXVpcmVkPXtyZXF1aXJlZH1cbiAgICAgICAgICAgICAgICAgICAgbGFiZWxEZXNjcmlwdGlvbj17bGVnZW5kRGVzY3JpcHRpb259XG4gICAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICAgIHtsZWdlbmR9XG4gICAgICAgICAgICAgICAgICA8L0xhYmVsPlxuICAgICAgICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgICAgICAgIHtkZXNjcmlwdGlvbiA/IChcbiAgICAgICAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgICAgICAgIHZhcmlhbnQ9XCJib2R5U21hbGxcIlxuICAgICAgICAgICAgICAgICAgICBhcz17dHlwZW9mIGRlc2NyaXB0aW9uID09PSAnc3RyaW5nJyA/ICdwJyA6ICdkaXYnfVxuICAgICAgICAgICAgICAgICAgICBwcm9taW5lbmNlPVwid2Vha1wiXG4gICAgICAgICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICB7ZGVzY3JpcHRpb259XG4gICAgICAgICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICAgICAgKSA6IG51bGx9XG4gICAgICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICAgIDxTdGFja1xuICAgICAgICAgICAgICBnYXA9e2RpcmVjdGlvbiA9PT0gJ2NvbHVtbicgPyAxIDogMn1cbiAgICAgICAgICAgICAgZGlyZWN0aW9uPXtkaXJlY3Rpb259XG4gICAgICAgICAgICAgIGFsaWduSXRlbXM9XCJzdGFydFwiXG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgPC9GaWVsZFNldD5cbiAgICAgICAge2hlbHBlciA/IChcbiAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgYXM9XCJzcGFuXCJcbiAgICAgICAgICAgIHZhcmlhbnQ9XCJjYXB0aW9uXCJcbiAgICAgICAgICAgIHByb21pbmVuY2U9XCJ3ZWFrXCJcbiAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtoZWxwZXJ9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICApIDogbnVsbH1cbiAgICAgICAge2Vycm9yID8gKFxuICAgICAgICAgIDxUZXh0IGFzPVwic3BhblwiIHZhcmlhbnQ9XCJjYXB0aW9uXCIgc2VudGltZW50PVwiZGFuZ2VyXCI+XG4gICAgICAgICAgICB7ZXJyb3J9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvU3RhY2s+XG4gICAgPC9SYWRpb0dyb3VwQ29udGV4dC5Qcm92aWRlcj5cbiAgKVxufVxuXG5SYWRpb0dyb3VwLlJhZGlvID0gUmFkaW9Hcm91cFJhZGlvXG4iXX0= */",
51
50
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
52
51
  });
53
52
  const RadioGroup = ({
@@ -40,7 +40,8 @@ const SelectInputProvider = ({
40
40
  numberOfOptions,
41
41
  children,
42
42
  onChange,
43
- refSelect
43
+ refSelect,
44
+ onOpen
44
45
  }) => {
45
46
  const currentValue = react.useMemo(() => {
46
47
  if (value) {
@@ -61,15 +62,14 @@ const SelectInputProvider = ({
61
62
  const [isDropdownVisible, setIsDropdownVisible] = react.useState(false);
62
63
  const [searchInput, setSearchInput] = react.useState("");
63
64
  const handleDropDownVisible = react.useCallback((newValue) => {
65
+ setIsDropdownVisible(newValue);
64
66
  if (newValue) {
65
- setIsDropdownVisible(newValue);
66
- } else {
67
- setIsDropdownVisible(newValue);
68
- if (refSelect) {
69
- refSelect.current?.focus();
70
- }
67
+ onOpen?.();
68
+ }
69
+ if (!newValue && refSelect) {
70
+ refSelect.current?.focus();
71
71
  }
72
- }, [refSelect]);
72
+ }, [refSelect, onOpen]);
73
73
  const allValues = react.useMemo(() => {
74
74
  if (!Array.isArray(options)) {
75
75
  return Object.keys(options).flatMap((group) => options[group].filter((option) => !option.disabled));
@@ -37,6 +37,7 @@ type SelectInputProviderProps<IsMulti extends boolean> = {
37
37
  multiselect: IsMulti;
38
38
  refSelect?: RefObject<HTMLDivElement | null>;
39
39
  onChange?: IsMulti extends true ? (value: string[]) => void : (value: string) => void;
40
+ onOpen?: () => void;
40
41
  };
41
- export declare const SelectInputProvider: <T extends boolean>({ options, multiselect, selectAll, value, selectAllGroup, numberOfOptions, children, onChange, refSelect, }: SelectInputProviderProps<T>) => import("@emotion/react/jsx-runtime").JSX.Element;
42
+ export declare const SelectInputProvider: <T extends boolean>({ options, multiselect, selectAll, value, selectAllGroup, numberOfOptions, children, onChange, refSelect, onOpen, }: SelectInputProviderProps<T>) => import("@emotion/react/jsx-runtime").JSX.Element;
42
43
  export {};
@@ -38,7 +38,8 @@ const SelectInputProvider = ({
38
38
  numberOfOptions,
39
39
  children,
40
40
  onChange,
41
- refSelect
41
+ refSelect,
42
+ onOpen
42
43
  }) => {
43
44
  const currentValue = useMemo(() => {
44
45
  if (value) {
@@ -59,15 +60,14 @@ const SelectInputProvider = ({
59
60
  const [isDropdownVisible, setIsDropdownVisible] = useState(false);
60
61
  const [searchInput, setSearchInput] = useState("");
61
62
  const handleDropDownVisible = useCallback((newValue) => {
63
+ setIsDropdownVisible(newValue);
62
64
  if (newValue) {
63
- setIsDropdownVisible(newValue);
64
- } else {
65
- setIsDropdownVisible(newValue);
66
- if (refSelect) {
67
- refSelect.current?.focus();
68
- }
65
+ onOpen?.();
66
+ }
67
+ if (!newValue && refSelect) {
68
+ refSelect.current?.focus();
69
69
  }
70
- }, [refSelect]);
70
+ }, [refSelect, onOpen]);
71
71
  const allValues = useMemo(() => {
72
72
  if (!Array.isArray(options)) {
73
73
  return Object.keys(options).flatMap((group) => options[group].filter((option) => !option.disabled));
@@ -25,7 +25,7 @@ const SelectInputContainer = /* @__PURE__ */ _styled__default.default("div", pro
25
25
  styles: "width:100%"
26
26
  } : {
27
27
  name: "1d3w5wq",
28
- styles: "width:100%/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInput/index.tsx"],"names":[],"mappings":"AAuIuC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { useId, useRef } from 'react'\nimport type { ComponentProps, HTMLAttributes, ReactNode } from 'react'\nimport { Label } from '../Label'\nimport type { Popup } from '../Popup'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Dropdown } from './Dropdown'\nimport { SelectBar } from './SelectBar'\nimport { SelectInputProvider } from './SelectInputProvider'\nimport type { DataType } from './types'\n\ntype SelectInputProps<IsMulti extends undefined | boolean = false> = {\n  /**\n   * Input name\n   */\n  name?: string\n  /**\n   * Place holder when no value defined\n   */\n  placeholder?: string\n  /**\n   * When searchable, placeholder when no value is searched\n   */\n  placeholderSearch?: string\n  /**\n   * Label of the component\n   */\n  label?: string\n  /**\n   * Helper text to give more information to the user\n   */\n  helper?: string\n  /**\n   * Selectable options\n   */\n  options: DataType\n  /**\n   * Message to show when no option available\n   */\n  emptyState?: ReactNode\n  /**\n   * Whether it is possible to search through the input\n   */\n  searchable?: boolean\n  /**\n   * Whether the component in disabled\n   */\n  disabled?: boolean\n  /**\n   * Whether the component in readOnly\n   */\n  readOnly?: boolean\n  /**\n   * Whether it is possible to clear the search input\n   */\n  clearable?: boolean\n  /**\n   * Size of the input\n   */\n  size?: 'small' | 'medium' | 'large'\n  /**\n   * Whether field is required\n   */\n  required?: boolean\n  /**\n   * More information regarding/description ofs the selectInput\n   */\n  labelDescription?: ReactNode\n  /**\n   * Whether option description is on the right of the option or under it\n   */\n  descriptionDirection?: 'row' | 'column'\n  /**\n   * Where to place the additional info prop\n   */\n  optionalInfoPlacement?: 'left' | 'right'\n  /**\n   * To add custom fixed elements at the bottom of the dropdown\n   */\n  footer?: ((closeDropdown: () => void) => ReactNode) | ReactNode\n  /**\n   * Display an error message under the select bar\n   */\n  error?: string | boolean\n  /**\n   * Display a success message under the select bar\n   */\n  success?: string\n  /**\n   * Load more button to implement lazy loading\n   */\n  loadMore?: ReactNode\n  /**\n   * When the options are loading, display a skeleton\n   */\n  isLoading?: boolean\n  /**\n   * Add a tooltip around the select bar\n   */\n  tooltip?: string\n  /**\n   * Adds an option to select every selectable options\n   */\n  selectAll?: { label: ReactNode; description?: string }\n  /**\n   * When options are group, define a option to select every selectable options of a group\n   */\n  selectAllGroup?: boolean\n  dropdownAlign?: ComponentProps<typeof Popup>['align']\n  autofocus?: boolean\n  /**\n   * Whether it is possible to select multiple options\n   */\n  multiselect?: IsMulti\n  /**\n   * Default value, must be one of the options\n   */\n  value?: IsMulti extends true ? string[] : string\n  onChange?: IsMulti extends true\n    ? (value: string[]) => void\n    : (value: string) => void\n  'data-testid'?: string\n  /**\n   * In some cases, when the space is limited, you will need to change the `portalTarget` of the dropdown for a higher parent element.\n   * If you don't know which element to target, you can use `document.body`.\n   */\n  portalTarget?: ComponentProps<typeof Popup>['portalTarget']\n} & Pick<\n  HTMLAttributes<HTMLDivElement>,\n  'id' | 'onBlur' | 'onFocus' | 'aria-label' | 'className'\n>\n\nconst SelectInputContainer = styled.div`\n  width: 100%;\n`\nconst HelperText = styled(Text)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\n`\n\n/**\n * SelectInput component is used to select one or many elements from a selection.\n */\nexport const SelectInput = <IsMulti extends undefined | boolean>({\n  name,\n  id,\n  onBlur,\n  onFocus,\n  onChange,\n  'aria-label': ariaLabel,\n  value,\n  label,\n  helper,\n  options,\n  size = 'large',\n  emptyState,\n  descriptionDirection = 'column',\n  success,\n  error,\n  'data-testid': dataTestId,\n  className,\n  tooltip,\n  footer,\n  placeholderSearch = 'Search in list',\n  placeholder = 'Select item',\n  searchable = true,\n  disabled = false,\n  readOnly = false,\n  clearable = false,\n  multiselect = false,\n  required = false,\n  labelDescription,\n  autofocus,\n  loadMore,\n  optionalInfoPlacement = 'right',\n  isLoading,\n  selectAll,\n  selectAllGroup = false,\n  dropdownAlign,\n  portalTarget,\n}: SelectInputProps<IsMulti>) => {\n  const localId = useId()\n  const finalId = id ?? localId\n  const ref = useRef<HTMLDivElement | null>(null)\n  const numberOfOptions = Array.isArray(options)\n    ? options.length\n    : Object.values(options).reduce(\n        (acc, current) =>\n          acc + current.filter(option => !option.disabled).length,\n        0,\n      )\n  const finalDataTestId = dataTestId ?? `select-input-${name ?? 'name'}`\n\n  return (\n    <SelectInputProvider\n      options={options}\n      multiselect={multiselect}\n      selectAll={selectAll}\n      value={value}\n      selectAllGroup={selectAllGroup}\n      numberOfOptions={numberOfOptions}\n      onChange={onChange}\n      refSelect={ref}\n    >\n      <SelectInputContainer\n        onBlur={onBlur}\n        onFocus={onFocus}\n        className={className}\n        aria-label={name}\n      >\n        <Dropdown\n          emptyState={emptyState}\n          descriptionDirection={descriptionDirection}\n          searchable={searchable}\n          placeholder={placeholderSearch}\n          footer={footer}\n          refSelect={ref}\n          loadMore={loadMore}\n          optionalInfoPlacement={optionalInfoPlacement}\n          isLoading={isLoading}\n          size={size}\n          dropdownAlign={dropdownAlign}\n          portalTarget={portalTarget}\n        >\n          <Stack gap={0.5} aria-label={ariaLabel}>\n            {label || labelDescription ? (\n              <Label\n                htmlFor={finalId}\n                labelDescription={labelDescription}\n                required={required}\n                size={size}\n              >\n                {label}\n              </Label>\n            ) : null}\n            <SelectBar\n              size={size}\n              data-testid={finalDataTestId}\n              clearable={clearable}\n              readOnly={readOnly}\n              disabled={disabled}\n              placeholder={placeholder}\n              success={success}\n              error={error}\n              autoFocus={autofocus}\n              innerRef={ref}\n              id={finalId}\n              label={label}\n              tooltip={tooltip}\n            />\n          </Stack>\n        </Dropdown>\n        {!error && !success && helper ? (\n          <HelperText\n            variant=\"caption\"\n            as=\"p\"\n            sentiment=\"neutral\"\n            prominence=\"weak\"\n          >\n            {helper}\n          </HelperText>\n        ) : null}\n        {(error && typeof error === 'string') || success ? (\n          <HelperText\n            variant=\"caption\"\n            as=\"p\"\n            sentiment={error ? 'danger' : 'success'}\n            prominence=\"default\"\n          >\n            {error || success}\n          </HelperText>\n        ) : null}\n      </SelectInputContainer>\n    </SelectInputProvider>\n  )\n}\n"]} */",
28
+ styles: "width:100%/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInput/index.tsx"],"names":[],"mappings":"AA4IuC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { useId, useRef } from 'react'\nimport type { ComponentProps, HTMLAttributes, ReactNode } from 'react'\nimport { Label } from '../Label'\nimport type { Popup } from '../Popup'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Dropdown } from './Dropdown'\nimport { SelectBar } from './SelectBar'\nimport { SelectInputProvider } from './SelectInputProvider'\nimport type { DataType } from './types'\n\ntype SelectInputProps<IsMulti extends undefined | boolean = false> = {\n  /**\n   * Input name\n   */\n  name?: string\n  /**\n   * Place holder when no value defined\n   */\n  placeholder?: string\n  /**\n   * When searchable, placeholder when no value is searched\n   */\n  placeholderSearch?: string\n  /**\n   * Label of the component\n   */\n  label?: string\n  /**\n   * Helper text to give more information to the user\n   */\n  helper?: string\n  /**\n   * Selectable options\n   */\n  options: DataType\n  /**\n   * Message to show when no option available\n   */\n  emptyState?: ReactNode\n  /**\n   * Whether it is possible to search through the input\n   */\n  searchable?: boolean\n  /**\n   * Whether the component in disabled\n   */\n  disabled?: boolean\n  /**\n   * Whether the component in readOnly\n   */\n  readOnly?: boolean\n  /**\n   * Whether it is possible to clear the search input\n   */\n  clearable?: boolean\n  /**\n   * Size of the input\n   */\n  size?: 'small' | 'medium' | 'large'\n  /**\n   * Whether field is required\n   */\n  required?: boolean\n  /**\n   * More information regarding/description ofs the selectInput\n   */\n  labelDescription?: ReactNode\n  /**\n   * Whether option description is on the right of the option or under it\n   */\n  descriptionDirection?: 'row' | 'column'\n  /**\n   * Where to place the additional info prop\n   */\n  optionalInfoPlacement?: 'left' | 'right'\n  /**\n   * To add custom fixed elements at the bottom of the dropdown\n   */\n  footer?: ((closeDropdown: () => void) => ReactNode) | ReactNode\n  /**\n   * Display an error message under the select bar\n   */\n  error?: string | boolean\n  /**\n   * Display a success message under the select bar\n   */\n  success?: string\n  /**\n   * Load more button to implement lazy loading\n   */\n  loadMore?: ReactNode\n  /**\n   * When the options are loading, display a skeleton\n   */\n  isLoading?: boolean\n  /**\n   * Add a tooltip around the select bar\n   */\n  tooltip?: string\n  /**\n   * Adds an option to select every selectable options\n   */\n  selectAll?: { label: ReactNode; description?: string }\n  /**\n   * When options are group, define a option to select every selectable options of a group\n   */\n  selectAllGroup?: boolean\n  dropdownAlign?: ComponentProps<typeof Popup>['align']\n  autofocus?: boolean\n  /**\n   * Whether it is possible to select multiple options\n   */\n  multiselect?: IsMulti\n  /**\n   * Default value, must be one of the options\n   */\n  value?: IsMulti extends true ? string[] : string\n  onChange?: IsMulti extends true\n    ? (value: string[]) => void\n    : (value: string) => void\n  'data-testid'?: string\n  /**\n   * In some cases, when the space is limited, you will need to change the `portalTarget` of the dropdown for a higher parent element.\n   * If you don't know which element to target, you can use `document.body`.\n   */\n  portalTarget?: ComponentProps<typeof Popup>['portalTarget']\n  /**\n   * Allow to specify a callback called when option dropdown is open\n   * Please wrap that definition in useCallback\n   */\n  onOpen?: () => void\n} & Pick<\n  HTMLAttributes<HTMLDivElement>,\n  'id' | 'onBlur' | 'onFocus' | 'aria-label' | 'className'\n>\n\nconst SelectInputContainer = styled.div`\n  width: 100%;\n`\nconst HelperText = styled(Text)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\n`\n\n/**\n * SelectInput component is used to select one or many elements from a selection.\n */\nexport const SelectInput = <IsMulti extends undefined | boolean>({\n  name,\n  id,\n  onBlur,\n  onFocus,\n  onChange,\n  'aria-label': ariaLabel,\n  value,\n  label,\n  helper,\n  options,\n  size = 'large',\n  emptyState,\n  descriptionDirection = 'column',\n  success,\n  error,\n  'data-testid': dataTestId,\n  className,\n  tooltip,\n  footer,\n  placeholderSearch = 'Search in list',\n  placeholder = 'Select item',\n  searchable = true,\n  disabled = false,\n  readOnly = false,\n  clearable = false,\n  multiselect = false,\n  required = false,\n  labelDescription,\n  autofocus,\n  loadMore,\n  optionalInfoPlacement = 'right',\n  isLoading,\n  selectAll,\n  selectAllGroup = false,\n  dropdownAlign,\n  portalTarget,\n  onOpen,\n}: SelectInputProps<IsMulti>) => {\n  const localId = useId()\n  const finalId = id ?? localId\n  const ref = useRef<HTMLDivElement | null>(null)\n  const numberOfOptions = Array.isArray(options)\n    ? options.length\n    : Object.values(options).reduce(\n        (acc, current) =>\n          acc + current.filter(option => !option.disabled).length,\n        0,\n      )\n  const finalDataTestId = dataTestId ?? `select-input-${name ?? 'name'}`\n\n  return (\n    <SelectInputProvider\n      options={options}\n      multiselect={multiselect}\n      selectAll={selectAll}\n      value={value}\n      selectAllGroup={selectAllGroup}\n      numberOfOptions={numberOfOptions}\n      onChange={onChange}\n      refSelect={ref}\n      onOpen={onOpen}\n    >\n      <SelectInputContainer\n        onBlur={onBlur}\n        onFocus={onFocus}\n        className={className}\n        aria-label={name}\n      >\n        <Dropdown\n          emptyState={emptyState}\n          descriptionDirection={descriptionDirection}\n          searchable={searchable}\n          placeholder={placeholderSearch}\n          footer={footer}\n          refSelect={ref}\n          loadMore={loadMore}\n          optionalInfoPlacement={optionalInfoPlacement}\n          isLoading={isLoading}\n          size={size}\n          dropdownAlign={dropdownAlign}\n          portalTarget={portalTarget}\n        >\n          <Stack gap={0.5} aria-label={ariaLabel}>\n            {label || labelDescription ? (\n              <Label\n                htmlFor={finalId}\n                labelDescription={labelDescription}\n                required={required}\n                size={size}\n              >\n                {label}\n              </Label>\n            ) : null}\n            <SelectBar\n              size={size}\n              data-testid={finalDataTestId}\n              clearable={clearable}\n              readOnly={readOnly}\n              disabled={disabled}\n              placeholder={placeholder}\n              success={success}\n              error={error}\n              autoFocus={autofocus}\n              innerRef={ref}\n              id={finalId}\n              label={label}\n              tooltip={tooltip}\n            />\n          </Stack>\n        </Dropdown>\n        {!error && !success && helper ? (\n          <HelperText\n            variant=\"caption\"\n            as=\"p\"\n            sentiment=\"neutral\"\n            prominence=\"weak\"\n          >\n            {helper}\n          </HelperText>\n        ) : null}\n        {(error && typeof error === 'string') || success ? (\n          <HelperText\n            variant=\"caption\"\n            as=\"p\"\n            sentiment={error ? 'danger' : 'success'}\n            prominence=\"default\"\n          >\n            {error || success}\n          </HelperText>\n        ) : null}\n      </SelectInputContainer>\n    </SelectInputProvider>\n  )\n}\n"]} */",
29
29
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
30
30
  });
31
31
  const HelperText = /* @__PURE__ */ _styled__default.default(index$2.Text, process.env.NODE_ENV === "production" ? {
@@ -35,7 +35,7 @@ const HelperText = /* @__PURE__ */ _styled__default.default(index$2.Text, proces
35
35
  label: "HelperText"
36
36
  })("padding-top:", ({
37
37
  theme
38
- }) => theme.space["0.5"], ";" + (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/SelectInput/index.tsx"],"names":[],"mappings":"AA0I+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { useId, useRef } from 'react'\nimport type { ComponentProps, HTMLAttributes, ReactNode } from 'react'\nimport { Label } from '../Label'\nimport type { Popup } from '../Popup'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Dropdown } from './Dropdown'\nimport { SelectBar } from './SelectBar'\nimport { SelectInputProvider } from './SelectInputProvider'\nimport type { DataType } from './types'\n\ntype SelectInputProps<IsMulti extends undefined | boolean = false> = {\n  /**\n   * Input name\n   */\n  name?: string\n  /**\n   * Place holder when no value defined\n   */\n  placeholder?: string\n  /**\n   * When searchable, placeholder when no value is searched\n   */\n  placeholderSearch?: string\n  /**\n   * Label of the component\n   */\n  label?: string\n  /**\n   * Helper text to give more information to the user\n   */\n  helper?: string\n  /**\n   * Selectable options\n   */\n  options: DataType\n  /**\n   * Message to show when no option available\n   */\n  emptyState?: ReactNode\n  /**\n   * Whether it is possible to search through the input\n   */\n  searchable?: boolean\n  /**\n   * Whether the component in disabled\n   */\n  disabled?: boolean\n  /**\n   * Whether the component in readOnly\n   */\n  readOnly?: boolean\n  /**\n   * Whether it is possible to clear the search input\n   */\n  clearable?: boolean\n  /**\n   * Size of the input\n   */\n  size?: 'small' | 'medium' | 'large'\n  /**\n   * Whether field is required\n   */\n  required?: boolean\n  /**\n   * More information regarding/description ofs the selectInput\n   */\n  labelDescription?: ReactNode\n  /**\n   * Whether option description is on the right of the option or under it\n   */\n  descriptionDirection?: 'row' | 'column'\n  /**\n   * Where to place the additional info prop\n   */\n  optionalInfoPlacement?: 'left' | 'right'\n  /**\n   * To add custom fixed elements at the bottom of the dropdown\n   */\n  footer?: ((closeDropdown: () => void) => ReactNode) | ReactNode\n  /**\n   * Display an error message under the select bar\n   */\n  error?: string | boolean\n  /**\n   * Display a success message under the select bar\n   */\n  success?: string\n  /**\n   * Load more button to implement lazy loading\n   */\n  loadMore?: ReactNode\n  /**\n   * When the options are loading, display a skeleton\n   */\n  isLoading?: boolean\n  /**\n   * Add a tooltip around the select bar\n   */\n  tooltip?: string\n  /**\n   * Adds an option to select every selectable options\n   */\n  selectAll?: { label: ReactNode; description?: string }\n  /**\n   * When options are group, define a option to select every selectable options of a group\n   */\n  selectAllGroup?: boolean\n  dropdownAlign?: ComponentProps<typeof Popup>['align']\n  autofocus?: boolean\n  /**\n   * Whether it is possible to select multiple options\n   */\n  multiselect?: IsMulti\n  /**\n   * Default value, must be one of the options\n   */\n  value?: IsMulti extends true ? string[] : string\n  onChange?: IsMulti extends true\n    ? (value: string[]) => void\n    : (value: string) => void\n  'data-testid'?: string\n  /**\n   * In some cases, when the space is limited, you will need to change the `portalTarget` of the dropdown for a higher parent element.\n   * If you don't know which element to target, you can use `document.body`.\n   */\n  portalTarget?: ComponentProps<typeof Popup>['portalTarget']\n} & Pick<\n  HTMLAttributes<HTMLDivElement>,\n  'id' | 'onBlur' | 'onFocus' | 'aria-label' | 'className'\n>\n\nconst SelectInputContainer = styled.div`\n  width: 100%;\n`\nconst HelperText = styled(Text)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\n`\n\n/**\n * SelectInput component is used to select one or many elements from a selection.\n */\nexport const SelectInput = <IsMulti extends undefined | boolean>({\n  name,\n  id,\n  onBlur,\n  onFocus,\n  onChange,\n  'aria-label': ariaLabel,\n  value,\n  label,\n  helper,\n  options,\n  size = 'large',\n  emptyState,\n  descriptionDirection = 'column',\n  success,\n  error,\n  'data-testid': dataTestId,\n  className,\n  tooltip,\n  footer,\n  placeholderSearch = 'Search in list',\n  placeholder = 'Select item',\n  searchable = true,\n  disabled = false,\n  readOnly = false,\n  clearable = false,\n  multiselect = false,\n  required = false,\n  labelDescription,\n  autofocus,\n  loadMore,\n  optionalInfoPlacement = 'right',\n  isLoading,\n  selectAll,\n  selectAllGroup = false,\n  dropdownAlign,\n  portalTarget,\n}: SelectInputProps<IsMulti>) => {\n  const localId = useId()\n  const finalId = id ?? localId\n  const ref = useRef<HTMLDivElement | null>(null)\n  const numberOfOptions = Array.isArray(options)\n    ? options.length\n    : Object.values(options).reduce(\n        (acc, current) =>\n          acc + current.filter(option => !option.disabled).length,\n        0,\n      )\n  const finalDataTestId = dataTestId ?? `select-input-${name ?? 'name'}`\n\n  return (\n    <SelectInputProvider\n      options={options}\n      multiselect={multiselect}\n      selectAll={selectAll}\n      value={value}\n      selectAllGroup={selectAllGroup}\n      numberOfOptions={numberOfOptions}\n      onChange={onChange}\n      refSelect={ref}\n    >\n      <SelectInputContainer\n        onBlur={onBlur}\n        onFocus={onFocus}\n        className={className}\n        aria-label={name}\n      >\n        <Dropdown\n          emptyState={emptyState}\n          descriptionDirection={descriptionDirection}\n          searchable={searchable}\n          placeholder={placeholderSearch}\n          footer={footer}\n          refSelect={ref}\n          loadMore={loadMore}\n          optionalInfoPlacement={optionalInfoPlacement}\n          isLoading={isLoading}\n          size={size}\n          dropdownAlign={dropdownAlign}\n          portalTarget={portalTarget}\n        >\n          <Stack gap={0.5} aria-label={ariaLabel}>\n            {label || labelDescription ? (\n              <Label\n                htmlFor={finalId}\n                labelDescription={labelDescription}\n                required={required}\n                size={size}\n              >\n                {label}\n              </Label>\n            ) : null}\n            <SelectBar\n              size={size}\n              data-testid={finalDataTestId}\n              clearable={clearable}\n              readOnly={readOnly}\n              disabled={disabled}\n              placeholder={placeholder}\n              success={success}\n              error={error}\n              autoFocus={autofocus}\n              innerRef={ref}\n              id={finalId}\n              label={label}\n              tooltip={tooltip}\n            />\n          </Stack>\n        </Dropdown>\n        {!error && !success && helper ? (\n          <HelperText\n            variant=\"caption\"\n            as=\"p\"\n            sentiment=\"neutral\"\n            prominence=\"weak\"\n          >\n            {helper}\n          </HelperText>\n        ) : null}\n        {(error && typeof error === 'string') || success ? (\n          <HelperText\n            variant=\"caption\"\n            as=\"p\"\n            sentiment={error ? 'danger' : 'success'}\n            prominence=\"default\"\n          >\n            {error || success}\n          </HelperText>\n        ) : null}\n      </SelectInputContainer>\n    </SelectInputProvider>\n  )\n}\n"]} */"));
38
+ }) => theme.space["0.5"], ";" + (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/SelectInput/index.tsx"],"names":[],"mappings":"AA+I+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { useId, useRef } from 'react'\nimport type { ComponentProps, HTMLAttributes, ReactNode } from 'react'\nimport { Label } from '../Label'\nimport type { Popup } from '../Popup'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Dropdown } from './Dropdown'\nimport { SelectBar } from './SelectBar'\nimport { SelectInputProvider } from './SelectInputProvider'\nimport type { DataType } from './types'\n\ntype SelectInputProps<IsMulti extends undefined | boolean = false> = {\n  /**\n   * Input name\n   */\n  name?: string\n  /**\n   * Place holder when no value defined\n   */\n  placeholder?: string\n  /**\n   * When searchable, placeholder when no value is searched\n   */\n  placeholderSearch?: string\n  /**\n   * Label of the component\n   */\n  label?: string\n  /**\n   * Helper text to give more information to the user\n   */\n  helper?: string\n  /**\n   * Selectable options\n   */\n  options: DataType\n  /**\n   * Message to show when no option available\n   */\n  emptyState?: ReactNode\n  /**\n   * Whether it is possible to search through the input\n   */\n  searchable?: boolean\n  /**\n   * Whether the component in disabled\n   */\n  disabled?: boolean\n  /**\n   * Whether the component in readOnly\n   */\n  readOnly?: boolean\n  /**\n   * Whether it is possible to clear the search input\n   */\n  clearable?: boolean\n  /**\n   * Size of the input\n   */\n  size?: 'small' | 'medium' | 'large'\n  /**\n   * Whether field is required\n   */\n  required?: boolean\n  /**\n   * More information regarding/description ofs the selectInput\n   */\n  labelDescription?: ReactNode\n  /**\n   * Whether option description is on the right of the option or under it\n   */\n  descriptionDirection?: 'row' | 'column'\n  /**\n   * Where to place the additional info prop\n   */\n  optionalInfoPlacement?: 'left' | 'right'\n  /**\n   * To add custom fixed elements at the bottom of the dropdown\n   */\n  footer?: ((closeDropdown: () => void) => ReactNode) | ReactNode\n  /**\n   * Display an error message under the select bar\n   */\n  error?: string | boolean\n  /**\n   * Display a success message under the select bar\n   */\n  success?: string\n  /**\n   * Load more button to implement lazy loading\n   */\n  loadMore?: ReactNode\n  /**\n   * When the options are loading, display a skeleton\n   */\n  isLoading?: boolean\n  /**\n   * Add a tooltip around the select bar\n   */\n  tooltip?: string\n  /**\n   * Adds an option to select every selectable options\n   */\n  selectAll?: { label: ReactNode; description?: string }\n  /**\n   * When options are group, define a option to select every selectable options of a group\n   */\n  selectAllGroup?: boolean\n  dropdownAlign?: ComponentProps<typeof Popup>['align']\n  autofocus?: boolean\n  /**\n   * Whether it is possible to select multiple options\n   */\n  multiselect?: IsMulti\n  /**\n   * Default value, must be one of the options\n   */\n  value?: IsMulti extends true ? string[] : string\n  onChange?: IsMulti extends true\n    ? (value: string[]) => void\n    : (value: string) => void\n  'data-testid'?: string\n  /**\n   * In some cases, when the space is limited, you will need to change the `portalTarget` of the dropdown for a higher parent element.\n   * If you don't know which element to target, you can use `document.body`.\n   */\n  portalTarget?: ComponentProps<typeof Popup>['portalTarget']\n  /**\n   * Allow to specify a callback called when option dropdown is open\n   * Please wrap that definition in useCallback\n   */\n  onOpen?: () => void\n} & Pick<\n  HTMLAttributes<HTMLDivElement>,\n  'id' | 'onBlur' | 'onFocus' | 'aria-label' | 'className'\n>\n\nconst SelectInputContainer = styled.div`\n  width: 100%;\n`\nconst HelperText = styled(Text)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\n`\n\n/**\n * SelectInput component is used to select one or many elements from a selection.\n */\nexport const SelectInput = <IsMulti extends undefined | boolean>({\n  name,\n  id,\n  onBlur,\n  onFocus,\n  onChange,\n  'aria-label': ariaLabel,\n  value,\n  label,\n  helper,\n  options,\n  size = 'large',\n  emptyState,\n  descriptionDirection = 'column',\n  success,\n  error,\n  'data-testid': dataTestId,\n  className,\n  tooltip,\n  footer,\n  placeholderSearch = 'Search in list',\n  placeholder = 'Select item',\n  searchable = true,\n  disabled = false,\n  readOnly = false,\n  clearable = false,\n  multiselect = false,\n  required = false,\n  labelDescription,\n  autofocus,\n  loadMore,\n  optionalInfoPlacement = 'right',\n  isLoading,\n  selectAll,\n  selectAllGroup = false,\n  dropdownAlign,\n  portalTarget,\n  onOpen,\n}: SelectInputProps<IsMulti>) => {\n  const localId = useId()\n  const finalId = id ?? localId\n  const ref = useRef<HTMLDivElement | null>(null)\n  const numberOfOptions = Array.isArray(options)\n    ? options.length\n    : Object.values(options).reduce(\n        (acc, current) =>\n          acc + current.filter(option => !option.disabled).length,\n        0,\n      )\n  const finalDataTestId = dataTestId ?? `select-input-${name ?? 'name'}`\n\n  return (\n    <SelectInputProvider\n      options={options}\n      multiselect={multiselect}\n      selectAll={selectAll}\n      value={value}\n      selectAllGroup={selectAllGroup}\n      numberOfOptions={numberOfOptions}\n      onChange={onChange}\n      refSelect={ref}\n      onOpen={onOpen}\n    >\n      <SelectInputContainer\n        onBlur={onBlur}\n        onFocus={onFocus}\n        className={className}\n        aria-label={name}\n      >\n        <Dropdown\n          emptyState={emptyState}\n          descriptionDirection={descriptionDirection}\n          searchable={searchable}\n          placeholder={placeholderSearch}\n          footer={footer}\n          refSelect={ref}\n          loadMore={loadMore}\n          optionalInfoPlacement={optionalInfoPlacement}\n          isLoading={isLoading}\n          size={size}\n          dropdownAlign={dropdownAlign}\n          portalTarget={portalTarget}\n        >\n          <Stack gap={0.5} aria-label={ariaLabel}>\n            {label || labelDescription ? (\n              <Label\n                htmlFor={finalId}\n                labelDescription={labelDescription}\n                required={required}\n                size={size}\n              >\n                {label}\n              </Label>\n            ) : null}\n            <SelectBar\n              size={size}\n              data-testid={finalDataTestId}\n              clearable={clearable}\n              readOnly={readOnly}\n              disabled={disabled}\n              placeholder={placeholder}\n              success={success}\n              error={error}\n              autoFocus={autofocus}\n              innerRef={ref}\n              id={finalId}\n              label={label}\n              tooltip={tooltip}\n            />\n          </Stack>\n        </Dropdown>\n        {!error && !success && helper ? (\n          <HelperText\n            variant=\"caption\"\n            as=\"p\"\n            sentiment=\"neutral\"\n            prominence=\"weak\"\n          >\n            {helper}\n          </HelperText>\n        ) : null}\n        {(error && typeof error === 'string') || success ? (\n          <HelperText\n            variant=\"caption\"\n            as=\"p\"\n            sentiment={error ? 'danger' : 'success'}\n            prominence=\"default\"\n          >\n            {error || success}\n          </HelperText>\n        ) : null}\n      </SelectInputContainer>\n    </SelectInputProvider>\n  )\n}\n"]} */"));
39
39
  const SelectInput = ({
40
40
  name,
41
41
  id,
@@ -72,14 +72,15 @@ const SelectInput = ({
72
72
  selectAll,
73
73
  selectAllGroup = false,
74
74
  dropdownAlign,
75
- portalTarget
75
+ portalTarget,
76
+ onOpen
76
77
  }) => {
77
78
  const localId = react.useId();
78
79
  const finalId = id ?? localId;
79
80
  const ref = react.useRef(null);
80
81
  const numberOfOptions = Array.isArray(options) ? options.length : Object.values(options).reduce((acc, current) => acc + current.filter((option) => !option.disabled).length, 0);
81
82
  const finalDataTestId = dataTestId ?? `select-input-${name ?? "name"}`;
82
- return /* @__PURE__ */ jsxRuntime.jsx(SelectInputProvider.SelectInputProvider, { options, multiselect, selectAll, value, selectAllGroup, numberOfOptions, onChange, refSelect: ref, children: /* @__PURE__ */ jsxRuntime.jsxs(SelectInputContainer, { onBlur, onFocus, className, "aria-label": name, children: [
83
+ return /* @__PURE__ */ jsxRuntime.jsx(SelectInputProvider.SelectInputProvider, { options, multiselect, selectAll, value, selectAllGroup, numberOfOptions, onChange, refSelect: ref, onOpen, children: /* @__PURE__ */ jsxRuntime.jsxs(SelectInputContainer, { onBlur, onFocus, className, "aria-label": name, children: [
83
84
  /* @__PURE__ */ jsxRuntime.jsx(Dropdown.Dropdown, { emptyState, descriptionDirection, searchable, placeholder: placeholderSearch, footer, refSelect: ref, loadMore, optionalInfoPlacement, isLoading, size, dropdownAlign, portalTarget, children: /* @__PURE__ */ jsxRuntime.jsxs(index.Stack, { gap: 0.5, "aria-label": ariaLabel, children: [
84
85
  label || labelDescription ? /* @__PURE__ */ jsxRuntime.jsx(index$1.Label, { htmlFor: finalId, labelDescription, required, size, children: label }) : null,
85
86
  /* @__PURE__ */ jsxRuntime.jsx(SelectBar.SelectBar, { size, "data-testid": finalDataTestId, clearable, readOnly, disabled, placeholder, success, error, autoFocus: autofocus, innerRef: ref, id: finalId, label, tooltip })
@@ -118,9 +118,14 @@ type SelectInputProps<IsMulti extends undefined | boolean = false> = {
118
118
  * If you don't know which element to target, you can use `document.body`.
119
119
  */
120
120
  portalTarget?: ComponentProps<typeof Popup>['portalTarget'];
121
+ /**
122
+ * Allow to specify a callback called when option dropdown is open
123
+ * Please wrap that definition in useCallback
124
+ */
125
+ onOpen?: () => void;
121
126
  } & Pick<HTMLAttributes<HTMLDivElement>, 'id' | 'onBlur' | 'onFocus' | 'aria-label' | 'className'>;
122
127
  /**
123
128
  * SelectInput component is used to select one or many elements from a selection.
124
129
  */
125
- export declare const SelectInput: <IsMulti extends undefined | boolean>({ name, id, onBlur, onFocus, onChange, "aria-label": ariaLabel, value, label, helper, options, size, emptyState, descriptionDirection, success, error, "data-testid": dataTestId, className, tooltip, footer, placeholderSearch, placeholder, searchable, disabled, readOnly, clearable, multiselect, required, labelDescription, autofocus, loadMore, optionalInfoPlacement, isLoading, selectAll, selectAllGroup, dropdownAlign, portalTarget, }: SelectInputProps<IsMulti>) => import("@emotion/react/jsx-runtime").JSX.Element;
130
+ export declare const SelectInput: <IsMulti extends undefined | boolean>({ name, id, onBlur, onFocus, onChange, "aria-label": ariaLabel, value, label, helper, options, size, emptyState, descriptionDirection, success, error, "data-testid": dataTestId, className, tooltip, footer, placeholderSearch, placeholder, searchable, disabled, readOnly, clearable, multiselect, required, labelDescription, autofocus, loadMore, optionalInfoPlacement, isLoading, selectAll, selectAllGroup, dropdownAlign, portalTarget, onOpen, }: SelectInputProps<IsMulti>) => import("@emotion/react/jsx-runtime").JSX.Element;
126
131
  export {};
@@ -21,7 +21,7 @@ const SelectInputContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV
21
21
  styles: "width:100%"
22
22
  } : {
23
23
  name: "1d3w5wq",
24
- styles: "width:100%/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInput/index.tsx"],"names":[],"mappings":"AAuIuC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { useId, useRef } from 'react'\nimport type { ComponentProps, HTMLAttributes, ReactNode } from 'react'\nimport { Label } from '../Label'\nimport type { Popup } from '../Popup'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Dropdown } from './Dropdown'\nimport { SelectBar } from './SelectBar'\nimport { SelectInputProvider } from './SelectInputProvider'\nimport type { DataType } from './types'\n\ntype SelectInputProps<IsMulti extends undefined | boolean = false> = {\n  /**\n   * Input name\n   */\n  name?: string\n  /**\n   * Place holder when no value defined\n   */\n  placeholder?: string\n  /**\n   * When searchable, placeholder when no value is searched\n   */\n  placeholderSearch?: string\n  /**\n   * Label of the component\n   */\n  label?: string\n  /**\n   * Helper text to give more information to the user\n   */\n  helper?: string\n  /**\n   * Selectable options\n   */\n  options: DataType\n  /**\n   * Message to show when no option available\n   */\n  emptyState?: ReactNode\n  /**\n   * Whether it is possible to search through the input\n   */\n  searchable?: boolean\n  /**\n   * Whether the component in disabled\n   */\n  disabled?: boolean\n  /**\n   * Whether the component in readOnly\n   */\n  readOnly?: boolean\n  /**\n   * Whether it is possible to clear the search input\n   */\n  clearable?: boolean\n  /**\n   * Size of the input\n   */\n  size?: 'small' | 'medium' | 'large'\n  /**\n   * Whether field is required\n   */\n  required?: boolean\n  /**\n   * More information regarding/description ofs the selectInput\n   */\n  labelDescription?: ReactNode\n  /**\n   * Whether option description is on the right of the option or under it\n   */\n  descriptionDirection?: 'row' | 'column'\n  /**\n   * Where to place the additional info prop\n   */\n  optionalInfoPlacement?: 'left' | 'right'\n  /**\n   * To add custom fixed elements at the bottom of the dropdown\n   */\n  footer?: ((closeDropdown: () => void) => ReactNode) | ReactNode\n  /**\n   * Display an error message under the select bar\n   */\n  error?: string | boolean\n  /**\n   * Display a success message under the select bar\n   */\n  success?: string\n  /**\n   * Load more button to implement lazy loading\n   */\n  loadMore?: ReactNode\n  /**\n   * When the options are loading, display a skeleton\n   */\n  isLoading?: boolean\n  /**\n   * Add a tooltip around the select bar\n   */\n  tooltip?: string\n  /**\n   * Adds an option to select every selectable options\n   */\n  selectAll?: { label: ReactNode; description?: string }\n  /**\n   * When options are group, define a option to select every selectable options of a group\n   */\n  selectAllGroup?: boolean\n  dropdownAlign?: ComponentProps<typeof Popup>['align']\n  autofocus?: boolean\n  /**\n   * Whether it is possible to select multiple options\n   */\n  multiselect?: IsMulti\n  /**\n   * Default value, must be one of the options\n   */\n  value?: IsMulti extends true ? string[] : string\n  onChange?: IsMulti extends true\n    ? (value: string[]) => void\n    : (value: string) => void\n  'data-testid'?: string\n  /**\n   * In some cases, when the space is limited, you will need to change the `portalTarget` of the dropdown for a higher parent element.\n   * If you don't know which element to target, you can use `document.body`.\n   */\n  portalTarget?: ComponentProps<typeof Popup>['portalTarget']\n} & Pick<\n  HTMLAttributes<HTMLDivElement>,\n  'id' | 'onBlur' | 'onFocus' | 'aria-label' | 'className'\n>\n\nconst SelectInputContainer = styled.div`\n  width: 100%;\n`\nconst HelperText = styled(Text)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\n`\n\n/**\n * SelectInput component is used to select one or many elements from a selection.\n */\nexport const SelectInput = <IsMulti extends undefined | boolean>({\n  name,\n  id,\n  onBlur,\n  onFocus,\n  onChange,\n  'aria-label': ariaLabel,\n  value,\n  label,\n  helper,\n  options,\n  size = 'large',\n  emptyState,\n  descriptionDirection = 'column',\n  success,\n  error,\n  'data-testid': dataTestId,\n  className,\n  tooltip,\n  footer,\n  placeholderSearch = 'Search in list',\n  placeholder = 'Select item',\n  searchable = true,\n  disabled = false,\n  readOnly = false,\n  clearable = false,\n  multiselect = false,\n  required = false,\n  labelDescription,\n  autofocus,\n  loadMore,\n  optionalInfoPlacement = 'right',\n  isLoading,\n  selectAll,\n  selectAllGroup = false,\n  dropdownAlign,\n  portalTarget,\n}: SelectInputProps<IsMulti>) => {\n  const localId = useId()\n  const finalId = id ?? localId\n  const ref = useRef<HTMLDivElement | null>(null)\n  const numberOfOptions = Array.isArray(options)\n    ? options.length\n    : Object.values(options).reduce(\n        (acc, current) =>\n          acc + current.filter(option => !option.disabled).length,\n        0,\n      )\n  const finalDataTestId = dataTestId ?? `select-input-${name ?? 'name'}`\n\n  return (\n    <SelectInputProvider\n      options={options}\n      multiselect={multiselect}\n      selectAll={selectAll}\n      value={value}\n      selectAllGroup={selectAllGroup}\n      numberOfOptions={numberOfOptions}\n      onChange={onChange}\n      refSelect={ref}\n    >\n      <SelectInputContainer\n        onBlur={onBlur}\n        onFocus={onFocus}\n        className={className}\n        aria-label={name}\n      >\n        <Dropdown\n          emptyState={emptyState}\n          descriptionDirection={descriptionDirection}\n          searchable={searchable}\n          placeholder={placeholderSearch}\n          footer={footer}\n          refSelect={ref}\n          loadMore={loadMore}\n          optionalInfoPlacement={optionalInfoPlacement}\n          isLoading={isLoading}\n          size={size}\n          dropdownAlign={dropdownAlign}\n          portalTarget={portalTarget}\n        >\n          <Stack gap={0.5} aria-label={ariaLabel}>\n            {label || labelDescription ? (\n              <Label\n                htmlFor={finalId}\n                labelDescription={labelDescription}\n                required={required}\n                size={size}\n              >\n                {label}\n              </Label>\n            ) : null}\n            <SelectBar\n              size={size}\n              data-testid={finalDataTestId}\n              clearable={clearable}\n              readOnly={readOnly}\n              disabled={disabled}\n              placeholder={placeholder}\n              success={success}\n              error={error}\n              autoFocus={autofocus}\n              innerRef={ref}\n              id={finalId}\n              label={label}\n              tooltip={tooltip}\n            />\n          </Stack>\n        </Dropdown>\n        {!error && !success && helper ? (\n          <HelperText\n            variant=\"caption\"\n            as=\"p\"\n            sentiment=\"neutral\"\n            prominence=\"weak\"\n          >\n            {helper}\n          </HelperText>\n        ) : null}\n        {(error && typeof error === 'string') || success ? (\n          <HelperText\n            variant=\"caption\"\n            as=\"p\"\n            sentiment={error ? 'danger' : 'success'}\n            prominence=\"default\"\n          >\n            {error || success}\n          </HelperText>\n        ) : null}\n      </SelectInputContainer>\n    </SelectInputProvider>\n  )\n}\n"]} */",
24
+ styles: "width:100%/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInput/index.tsx"],"names":[],"mappings":"AA4IuC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { useId, useRef } from 'react'\nimport type { ComponentProps, HTMLAttributes, ReactNode } from 'react'\nimport { Label } from '../Label'\nimport type { Popup } from '../Popup'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Dropdown } from './Dropdown'\nimport { SelectBar } from './SelectBar'\nimport { SelectInputProvider } from './SelectInputProvider'\nimport type { DataType } from './types'\n\ntype SelectInputProps<IsMulti extends undefined | boolean = false> = {\n  /**\n   * Input name\n   */\n  name?: string\n  /**\n   * Place holder when no value defined\n   */\n  placeholder?: string\n  /**\n   * When searchable, placeholder when no value is searched\n   */\n  placeholderSearch?: string\n  /**\n   * Label of the component\n   */\n  label?: string\n  /**\n   * Helper text to give more information to the user\n   */\n  helper?: string\n  /**\n   * Selectable options\n   */\n  options: DataType\n  /**\n   * Message to show when no option available\n   */\n  emptyState?: ReactNode\n  /**\n   * Whether it is possible to search through the input\n   */\n  searchable?: boolean\n  /**\n   * Whether the component in disabled\n   */\n  disabled?: boolean\n  /**\n   * Whether the component in readOnly\n   */\n  readOnly?: boolean\n  /**\n   * Whether it is possible to clear the search input\n   */\n  clearable?: boolean\n  /**\n   * Size of the input\n   */\n  size?: 'small' | 'medium' | 'large'\n  /**\n   * Whether field is required\n   */\n  required?: boolean\n  /**\n   * More information regarding/description ofs the selectInput\n   */\n  labelDescription?: ReactNode\n  /**\n   * Whether option description is on the right of the option or under it\n   */\n  descriptionDirection?: 'row' | 'column'\n  /**\n   * Where to place the additional info prop\n   */\n  optionalInfoPlacement?: 'left' | 'right'\n  /**\n   * To add custom fixed elements at the bottom of the dropdown\n   */\n  footer?: ((closeDropdown: () => void) => ReactNode) | ReactNode\n  /**\n   * Display an error message under the select bar\n   */\n  error?: string | boolean\n  /**\n   * Display a success message under the select bar\n   */\n  success?: string\n  /**\n   * Load more button to implement lazy loading\n   */\n  loadMore?: ReactNode\n  /**\n   * When the options are loading, display a skeleton\n   */\n  isLoading?: boolean\n  /**\n   * Add a tooltip around the select bar\n   */\n  tooltip?: string\n  /**\n   * Adds an option to select every selectable options\n   */\n  selectAll?: { label: ReactNode; description?: string }\n  /**\n   * When options are group, define a option to select every selectable options of a group\n   */\n  selectAllGroup?: boolean\n  dropdownAlign?: ComponentProps<typeof Popup>['align']\n  autofocus?: boolean\n  /**\n   * Whether it is possible to select multiple options\n   */\n  multiselect?: IsMulti\n  /**\n   * Default value, must be one of the options\n   */\n  value?: IsMulti extends true ? string[] : string\n  onChange?: IsMulti extends true\n    ? (value: string[]) => void\n    : (value: string) => void\n  'data-testid'?: string\n  /**\n   * In some cases, when the space is limited, you will need to change the `portalTarget` of the dropdown for a higher parent element.\n   * If you don't know which element to target, you can use `document.body`.\n   */\n  portalTarget?: ComponentProps<typeof Popup>['portalTarget']\n  /**\n   * Allow to specify a callback called when option dropdown is open\n   * Please wrap that definition in useCallback\n   */\n  onOpen?: () => void\n} & Pick<\n  HTMLAttributes<HTMLDivElement>,\n  'id' | 'onBlur' | 'onFocus' | 'aria-label' | 'className'\n>\n\nconst SelectInputContainer = styled.div`\n  width: 100%;\n`\nconst HelperText = styled(Text)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\n`\n\n/**\n * SelectInput component is used to select one or many elements from a selection.\n */\nexport const SelectInput = <IsMulti extends undefined | boolean>({\n  name,\n  id,\n  onBlur,\n  onFocus,\n  onChange,\n  'aria-label': ariaLabel,\n  value,\n  label,\n  helper,\n  options,\n  size = 'large',\n  emptyState,\n  descriptionDirection = 'column',\n  success,\n  error,\n  'data-testid': dataTestId,\n  className,\n  tooltip,\n  footer,\n  placeholderSearch = 'Search in list',\n  placeholder = 'Select item',\n  searchable = true,\n  disabled = false,\n  readOnly = false,\n  clearable = false,\n  multiselect = false,\n  required = false,\n  labelDescription,\n  autofocus,\n  loadMore,\n  optionalInfoPlacement = 'right',\n  isLoading,\n  selectAll,\n  selectAllGroup = false,\n  dropdownAlign,\n  portalTarget,\n  onOpen,\n}: SelectInputProps<IsMulti>) => {\n  const localId = useId()\n  const finalId = id ?? localId\n  const ref = useRef<HTMLDivElement | null>(null)\n  const numberOfOptions = Array.isArray(options)\n    ? options.length\n    : Object.values(options).reduce(\n        (acc, current) =>\n          acc + current.filter(option => !option.disabled).length,\n        0,\n      )\n  const finalDataTestId = dataTestId ?? `select-input-${name ?? 'name'}`\n\n  return (\n    <SelectInputProvider\n      options={options}\n      multiselect={multiselect}\n      selectAll={selectAll}\n      value={value}\n      selectAllGroup={selectAllGroup}\n      numberOfOptions={numberOfOptions}\n      onChange={onChange}\n      refSelect={ref}\n      onOpen={onOpen}\n    >\n      <SelectInputContainer\n        onBlur={onBlur}\n        onFocus={onFocus}\n        className={className}\n        aria-label={name}\n      >\n        <Dropdown\n          emptyState={emptyState}\n          descriptionDirection={descriptionDirection}\n          searchable={searchable}\n          placeholder={placeholderSearch}\n          footer={footer}\n          refSelect={ref}\n          loadMore={loadMore}\n          optionalInfoPlacement={optionalInfoPlacement}\n          isLoading={isLoading}\n          size={size}\n          dropdownAlign={dropdownAlign}\n          portalTarget={portalTarget}\n        >\n          <Stack gap={0.5} aria-label={ariaLabel}>\n            {label || labelDescription ? (\n              <Label\n                htmlFor={finalId}\n                labelDescription={labelDescription}\n                required={required}\n                size={size}\n              >\n                {label}\n              </Label>\n            ) : null}\n            <SelectBar\n              size={size}\n              data-testid={finalDataTestId}\n              clearable={clearable}\n              readOnly={readOnly}\n              disabled={disabled}\n              placeholder={placeholder}\n              success={success}\n              error={error}\n              autoFocus={autofocus}\n              innerRef={ref}\n              id={finalId}\n              label={label}\n              tooltip={tooltip}\n            />\n          </Stack>\n        </Dropdown>\n        {!error && !success && helper ? (\n          <HelperText\n            variant=\"caption\"\n            as=\"p\"\n            sentiment=\"neutral\"\n            prominence=\"weak\"\n          >\n            {helper}\n          </HelperText>\n        ) : null}\n        {(error && typeof error === 'string') || success ? (\n          <HelperText\n            variant=\"caption\"\n            as=\"p\"\n            sentiment={error ? 'danger' : 'success'}\n            prominence=\"default\"\n          >\n            {error || success}\n          </HelperText>\n        ) : null}\n      </SelectInputContainer>\n    </SelectInputProvider>\n  )\n}\n"]} */",
25
25
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
26
26
  });
27
27
  const HelperText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
@@ -31,7 +31,7 @@ const HelperText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "produ
31
31
  label: "HelperText"
32
32
  })("padding-top:", ({
33
33
  theme
34
- }) => theme.space["0.5"], ";" + (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/SelectInput/index.tsx"],"names":[],"mappings":"AA0I+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { useId, useRef } from 'react'\nimport type { ComponentProps, HTMLAttributes, ReactNode } from 'react'\nimport { Label } from '../Label'\nimport type { Popup } from '../Popup'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Dropdown } from './Dropdown'\nimport { SelectBar } from './SelectBar'\nimport { SelectInputProvider } from './SelectInputProvider'\nimport type { DataType } from './types'\n\ntype SelectInputProps<IsMulti extends undefined | boolean = false> = {\n  /**\n   * Input name\n   */\n  name?: string\n  /**\n   * Place holder when no value defined\n   */\n  placeholder?: string\n  /**\n   * When searchable, placeholder when no value is searched\n   */\n  placeholderSearch?: string\n  /**\n   * Label of the component\n   */\n  label?: string\n  /**\n   * Helper text to give more information to the user\n   */\n  helper?: string\n  /**\n   * Selectable options\n   */\n  options: DataType\n  /**\n   * Message to show when no option available\n   */\n  emptyState?: ReactNode\n  /**\n   * Whether it is possible to search through the input\n   */\n  searchable?: boolean\n  /**\n   * Whether the component in disabled\n   */\n  disabled?: boolean\n  /**\n   * Whether the component in readOnly\n   */\n  readOnly?: boolean\n  /**\n   * Whether it is possible to clear the search input\n   */\n  clearable?: boolean\n  /**\n   * Size of the input\n   */\n  size?: 'small' | 'medium' | 'large'\n  /**\n   * Whether field is required\n   */\n  required?: boolean\n  /**\n   * More information regarding/description ofs the selectInput\n   */\n  labelDescription?: ReactNode\n  /**\n   * Whether option description is on the right of the option or under it\n   */\n  descriptionDirection?: 'row' | 'column'\n  /**\n   * Where to place the additional info prop\n   */\n  optionalInfoPlacement?: 'left' | 'right'\n  /**\n   * To add custom fixed elements at the bottom of the dropdown\n   */\n  footer?: ((closeDropdown: () => void) => ReactNode) | ReactNode\n  /**\n   * Display an error message under the select bar\n   */\n  error?: string | boolean\n  /**\n   * Display a success message under the select bar\n   */\n  success?: string\n  /**\n   * Load more button to implement lazy loading\n   */\n  loadMore?: ReactNode\n  /**\n   * When the options are loading, display a skeleton\n   */\n  isLoading?: boolean\n  /**\n   * Add a tooltip around the select bar\n   */\n  tooltip?: string\n  /**\n   * Adds an option to select every selectable options\n   */\n  selectAll?: { label: ReactNode; description?: string }\n  /**\n   * When options are group, define a option to select every selectable options of a group\n   */\n  selectAllGroup?: boolean\n  dropdownAlign?: ComponentProps<typeof Popup>['align']\n  autofocus?: boolean\n  /**\n   * Whether it is possible to select multiple options\n   */\n  multiselect?: IsMulti\n  /**\n   * Default value, must be one of the options\n   */\n  value?: IsMulti extends true ? string[] : string\n  onChange?: IsMulti extends true\n    ? (value: string[]) => void\n    : (value: string) => void\n  'data-testid'?: string\n  /**\n   * In some cases, when the space is limited, you will need to change the `portalTarget` of the dropdown for a higher parent element.\n   * If you don't know which element to target, you can use `document.body`.\n   */\n  portalTarget?: ComponentProps<typeof Popup>['portalTarget']\n} & Pick<\n  HTMLAttributes<HTMLDivElement>,\n  'id' | 'onBlur' | 'onFocus' | 'aria-label' | 'className'\n>\n\nconst SelectInputContainer = styled.div`\n  width: 100%;\n`\nconst HelperText = styled(Text)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\n`\n\n/**\n * SelectInput component is used to select one or many elements from a selection.\n */\nexport const SelectInput = <IsMulti extends undefined | boolean>({\n  name,\n  id,\n  onBlur,\n  onFocus,\n  onChange,\n  'aria-label': ariaLabel,\n  value,\n  label,\n  helper,\n  options,\n  size = 'large',\n  emptyState,\n  descriptionDirection = 'column',\n  success,\n  error,\n  'data-testid': dataTestId,\n  className,\n  tooltip,\n  footer,\n  placeholderSearch = 'Search in list',\n  placeholder = 'Select item',\n  searchable = true,\n  disabled = false,\n  readOnly = false,\n  clearable = false,\n  multiselect = false,\n  required = false,\n  labelDescription,\n  autofocus,\n  loadMore,\n  optionalInfoPlacement = 'right',\n  isLoading,\n  selectAll,\n  selectAllGroup = false,\n  dropdownAlign,\n  portalTarget,\n}: SelectInputProps<IsMulti>) => {\n  const localId = useId()\n  const finalId = id ?? localId\n  const ref = useRef<HTMLDivElement | null>(null)\n  const numberOfOptions = Array.isArray(options)\n    ? options.length\n    : Object.values(options).reduce(\n        (acc, current) =>\n          acc + current.filter(option => !option.disabled).length,\n        0,\n      )\n  const finalDataTestId = dataTestId ?? `select-input-${name ?? 'name'}`\n\n  return (\n    <SelectInputProvider\n      options={options}\n      multiselect={multiselect}\n      selectAll={selectAll}\n      value={value}\n      selectAllGroup={selectAllGroup}\n      numberOfOptions={numberOfOptions}\n      onChange={onChange}\n      refSelect={ref}\n    >\n      <SelectInputContainer\n        onBlur={onBlur}\n        onFocus={onFocus}\n        className={className}\n        aria-label={name}\n      >\n        <Dropdown\n          emptyState={emptyState}\n          descriptionDirection={descriptionDirection}\n          searchable={searchable}\n          placeholder={placeholderSearch}\n          footer={footer}\n          refSelect={ref}\n          loadMore={loadMore}\n          optionalInfoPlacement={optionalInfoPlacement}\n          isLoading={isLoading}\n          size={size}\n          dropdownAlign={dropdownAlign}\n          portalTarget={portalTarget}\n        >\n          <Stack gap={0.5} aria-label={ariaLabel}>\n            {label || labelDescription ? (\n              <Label\n                htmlFor={finalId}\n                labelDescription={labelDescription}\n                required={required}\n                size={size}\n              >\n                {label}\n              </Label>\n            ) : null}\n            <SelectBar\n              size={size}\n              data-testid={finalDataTestId}\n              clearable={clearable}\n              readOnly={readOnly}\n              disabled={disabled}\n              placeholder={placeholder}\n              success={success}\n              error={error}\n              autoFocus={autofocus}\n              innerRef={ref}\n              id={finalId}\n              label={label}\n              tooltip={tooltip}\n            />\n          </Stack>\n        </Dropdown>\n        {!error && !success && helper ? (\n          <HelperText\n            variant=\"caption\"\n            as=\"p\"\n            sentiment=\"neutral\"\n            prominence=\"weak\"\n          >\n            {helper}\n          </HelperText>\n        ) : null}\n        {(error && typeof error === 'string') || success ? (\n          <HelperText\n            variant=\"caption\"\n            as=\"p\"\n            sentiment={error ? 'danger' : 'success'}\n            prominence=\"default\"\n          >\n            {error || success}\n          </HelperText>\n        ) : null}\n      </SelectInputContainer>\n    </SelectInputProvider>\n  )\n}\n"]} */"));
34
+ }) => theme.space["0.5"], ";" + (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/SelectInput/index.tsx"],"names":[],"mappings":"AA+I+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/SelectInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { useId, useRef } from 'react'\nimport type { ComponentProps, HTMLAttributes, ReactNode } from 'react'\nimport { Label } from '../Label'\nimport type { Popup } from '../Popup'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Dropdown } from './Dropdown'\nimport { SelectBar } from './SelectBar'\nimport { SelectInputProvider } from './SelectInputProvider'\nimport type { DataType } from './types'\n\ntype SelectInputProps<IsMulti extends undefined | boolean = false> = {\n  /**\n   * Input name\n   */\n  name?: string\n  /**\n   * Place holder when no value defined\n   */\n  placeholder?: string\n  /**\n   * When searchable, placeholder when no value is searched\n   */\n  placeholderSearch?: string\n  /**\n   * Label of the component\n   */\n  label?: string\n  /**\n   * Helper text to give more information to the user\n   */\n  helper?: string\n  /**\n   * Selectable options\n   */\n  options: DataType\n  /**\n   * Message to show when no option available\n   */\n  emptyState?: ReactNode\n  /**\n   * Whether it is possible to search through the input\n   */\n  searchable?: boolean\n  /**\n   * Whether the component in disabled\n   */\n  disabled?: boolean\n  /**\n   * Whether the component in readOnly\n   */\n  readOnly?: boolean\n  /**\n   * Whether it is possible to clear the search input\n   */\n  clearable?: boolean\n  /**\n   * Size of the input\n   */\n  size?: 'small' | 'medium' | 'large'\n  /**\n   * Whether field is required\n   */\n  required?: boolean\n  /**\n   * More information regarding/description ofs the selectInput\n   */\n  labelDescription?: ReactNode\n  /**\n   * Whether option description is on the right of the option or under it\n   */\n  descriptionDirection?: 'row' | 'column'\n  /**\n   * Where to place the additional info prop\n   */\n  optionalInfoPlacement?: 'left' | 'right'\n  /**\n   * To add custom fixed elements at the bottom of the dropdown\n   */\n  footer?: ((closeDropdown: () => void) => ReactNode) | ReactNode\n  /**\n   * Display an error message under the select bar\n   */\n  error?: string | boolean\n  /**\n   * Display a success message under the select bar\n   */\n  success?: string\n  /**\n   * Load more button to implement lazy loading\n   */\n  loadMore?: ReactNode\n  /**\n   * When the options are loading, display a skeleton\n   */\n  isLoading?: boolean\n  /**\n   * Add a tooltip around the select bar\n   */\n  tooltip?: string\n  /**\n   * Adds an option to select every selectable options\n   */\n  selectAll?: { label: ReactNode; description?: string }\n  /**\n   * When options are group, define a option to select every selectable options of a group\n   */\n  selectAllGroup?: boolean\n  dropdownAlign?: ComponentProps<typeof Popup>['align']\n  autofocus?: boolean\n  /**\n   * Whether it is possible to select multiple options\n   */\n  multiselect?: IsMulti\n  /**\n   * Default value, must be one of the options\n   */\n  value?: IsMulti extends true ? string[] : string\n  onChange?: IsMulti extends true\n    ? (value: string[]) => void\n    : (value: string) => void\n  'data-testid'?: string\n  /**\n   * In some cases, when the space is limited, you will need to change the `portalTarget` of the dropdown for a higher parent element.\n   * If you don't know which element to target, you can use `document.body`.\n   */\n  portalTarget?: ComponentProps<typeof Popup>['portalTarget']\n  /**\n   * Allow to specify a callback called when option dropdown is open\n   * Please wrap that definition in useCallback\n   */\n  onOpen?: () => void\n} & Pick<\n  HTMLAttributes<HTMLDivElement>,\n  'id' | 'onBlur' | 'onFocus' | 'aria-label' | 'className'\n>\n\nconst SelectInputContainer = styled.div`\n  width: 100%;\n`\nconst HelperText = styled(Text)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\n`\n\n/**\n * SelectInput component is used to select one or many elements from a selection.\n */\nexport const SelectInput = <IsMulti extends undefined | boolean>({\n  name,\n  id,\n  onBlur,\n  onFocus,\n  onChange,\n  'aria-label': ariaLabel,\n  value,\n  label,\n  helper,\n  options,\n  size = 'large',\n  emptyState,\n  descriptionDirection = 'column',\n  success,\n  error,\n  'data-testid': dataTestId,\n  className,\n  tooltip,\n  footer,\n  placeholderSearch = 'Search in list',\n  placeholder = 'Select item',\n  searchable = true,\n  disabled = false,\n  readOnly = false,\n  clearable = false,\n  multiselect = false,\n  required = false,\n  labelDescription,\n  autofocus,\n  loadMore,\n  optionalInfoPlacement = 'right',\n  isLoading,\n  selectAll,\n  selectAllGroup = false,\n  dropdownAlign,\n  portalTarget,\n  onOpen,\n}: SelectInputProps<IsMulti>) => {\n  const localId = useId()\n  const finalId = id ?? localId\n  const ref = useRef<HTMLDivElement | null>(null)\n  const numberOfOptions = Array.isArray(options)\n    ? options.length\n    : Object.values(options).reduce(\n        (acc, current) =>\n          acc + current.filter(option => !option.disabled).length,\n        0,\n      )\n  const finalDataTestId = dataTestId ?? `select-input-${name ?? 'name'}`\n\n  return (\n    <SelectInputProvider\n      options={options}\n      multiselect={multiselect}\n      selectAll={selectAll}\n      value={value}\n      selectAllGroup={selectAllGroup}\n      numberOfOptions={numberOfOptions}\n      onChange={onChange}\n      refSelect={ref}\n      onOpen={onOpen}\n    >\n      <SelectInputContainer\n        onBlur={onBlur}\n        onFocus={onFocus}\n        className={className}\n        aria-label={name}\n      >\n        <Dropdown\n          emptyState={emptyState}\n          descriptionDirection={descriptionDirection}\n          searchable={searchable}\n          placeholder={placeholderSearch}\n          footer={footer}\n          refSelect={ref}\n          loadMore={loadMore}\n          optionalInfoPlacement={optionalInfoPlacement}\n          isLoading={isLoading}\n          size={size}\n          dropdownAlign={dropdownAlign}\n          portalTarget={portalTarget}\n        >\n          <Stack gap={0.5} aria-label={ariaLabel}>\n            {label || labelDescription ? (\n              <Label\n                htmlFor={finalId}\n                labelDescription={labelDescription}\n                required={required}\n                size={size}\n              >\n                {label}\n              </Label>\n            ) : null}\n            <SelectBar\n              size={size}\n              data-testid={finalDataTestId}\n              clearable={clearable}\n              readOnly={readOnly}\n              disabled={disabled}\n              placeholder={placeholder}\n              success={success}\n              error={error}\n              autoFocus={autofocus}\n              innerRef={ref}\n              id={finalId}\n              label={label}\n              tooltip={tooltip}\n            />\n          </Stack>\n        </Dropdown>\n        {!error && !success && helper ? (\n          <HelperText\n            variant=\"caption\"\n            as=\"p\"\n            sentiment=\"neutral\"\n            prominence=\"weak\"\n          >\n            {helper}\n          </HelperText>\n        ) : null}\n        {(error && typeof error === 'string') || success ? (\n          <HelperText\n            variant=\"caption\"\n            as=\"p\"\n            sentiment={error ? 'danger' : 'success'}\n            prominence=\"default\"\n          >\n            {error || success}\n          </HelperText>\n        ) : null}\n      </SelectInputContainer>\n    </SelectInputProvider>\n  )\n}\n"]} */"));
35
35
  const SelectInput = ({
36
36
  name,
37
37
  id,
@@ -68,14 +68,15 @@ const SelectInput = ({
68
68
  selectAll,
69
69
  selectAllGroup = false,
70
70
  dropdownAlign,
71
- portalTarget
71
+ portalTarget,
72
+ onOpen
72
73
  }) => {
73
74
  const localId = useId();
74
75
  const finalId = id ?? localId;
75
76
  const ref = useRef(null);
76
77
  const numberOfOptions = Array.isArray(options) ? options.length : Object.values(options).reduce((acc, current) => acc + current.filter((option) => !option.disabled).length, 0);
77
78
  const finalDataTestId = dataTestId ?? `select-input-${name ?? "name"}`;
78
- return /* @__PURE__ */ jsx(SelectInputProvider, { options, multiselect, selectAll, value, selectAllGroup, numberOfOptions, onChange, refSelect: ref, children: /* @__PURE__ */ jsxs(SelectInputContainer, { onBlur, onFocus, className, "aria-label": name, children: [
79
+ return /* @__PURE__ */ jsx(SelectInputProvider, { options, multiselect, selectAll, value, selectAllGroup, numberOfOptions, onChange, refSelect: ref, onOpen, children: /* @__PURE__ */ jsxs(SelectInputContainer, { onBlur, onFocus, className, "aria-label": name, children: [
79
80
  /* @__PURE__ */ jsx(Dropdown, { emptyState, descriptionDirection, searchable, placeholder: placeholderSearch, footer, refSelect: ref, loadMore, optionalInfoPlacement, isLoading, size, dropdownAlign, portalTarget, children: /* @__PURE__ */ jsxs(Stack, { gap: 0.5, "aria-label": ariaLabel, children: [
80
81
  label || labelDescription ? /* @__PURE__ */ jsx(Label, { htmlFor: finalId, labelDescription, required, size, children: label }) : null,
81
82
  /* @__PURE__ */ jsx(SelectBar, { size, "data-testid": finalDataTestId, clearable, readOnly, disabled, placeholder, success, error, autoFocus: autofocus, innerRef: ref, id: finalId, label, tooltip })
@@ -6,10 +6,10 @@ const _styled = require("@emotion/styled/base");
6
6
  const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
7
7
  const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
8
8
  const StyledIconWrapper = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
9
- shouldForwardProp: (prop) => !["direction", "color", "sentiment"].includes(prop),
9
+ shouldForwardProp: (prop) => !["direction", "sentiment"].includes(prop),
10
10
  target: "e1d1zom91"
11
11
  } : {
12
- shouldForwardProp: (prop) => !["direction", "color", "sentiment"].includes(prop),
12
+ shouldForwardProp: (prop) => !["direction", "sentiment"].includes(prop),
13
13
  target: "e1d1zom91",
14
14
  label: "StyledIconWrapper"
15
15
  })("display:flex;flex-direction:", ({
@@ -17,7 +17,7 @@ const StyledIconWrapper = /* @__PURE__ */ _styled__default.default("div", proces
17
17
  }) => direction === "vertical" ? "column" : "row", ";align-items:center;svg{fill:", ({
18
18
  sentiment,
19
19
  theme
20
- }) => sentiment === "neutral" ? theme.colors.neutral.borderWeak : theme.colors[sentiment].border, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NlcGFyYXRvci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0JtQiIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9TZXBhcmF0b3IvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB0eXBlIHsgQ29sb3IgfSBmcm9tICcuLi8uLi90aGVtZSdcblxudHlwZSBEaXJlY3Rpb24gPSAnaG9yaXpvbnRhbCcgfCAndmVydGljYWwnXG5cbnR5cGUgU3R5bGVkSWNvblByb3BzID0ge1xuICBkaXJlY3Rpb246IERpcmVjdGlvblxuICBzZW50aW1lbnQ6IENvbG9yXG59XG5cbmNvbnN0IFN0eWxlZEljb25XcmFwcGVyID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+XG4gICAgIVsnZGlyZWN0aW9uJywgJ2NvbG9yJywgJ3NlbnRpbWVudCddLmluY2x1ZGVzKHByb3ApLFxufSk8U3R5bGVkSWNvblByb3BzPmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246ICR7KHsgZGlyZWN0aW9uIH0pID0+XG4gICAgZGlyZWN0aW9uID09PSAndmVydGljYWwnID8gJ2NvbHVtbicgOiAncm93J307XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cbiAgc3ZnIHtcbiAgICBmaWxsOiAkeyh7IHNlbnRpbWVudCwgdGhlbWUgfSkgPT4gKHNlbnRpbWVudCA9PT0gJ25ldXRyYWwnID8gdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyV2VhayA6IHRoZW1lLmNvbG9yc1tzZW50aW1lbnRdLmJvcmRlcil9O1xuICB9XG5gXG5cbnR5cGUgSG9yaXpvbnRhbFNlcGFyYXRvclByb3BzID0gT21pdDxTZXBhcmF0b3JQcm9wcywgJ2NvbG9yJyB8ICdzZW50aW1lbnQnPiAmIHtcbiAgaGFzSWNvbj86IGJvb2xlYW5cbiAgc2VudGltZW50OiBDb2xvclxufVxuXG5jb25zdCBTdHlsZWRIciA9IHN0eWxlZCgnaHInLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+XG4gICAgIVsnZGlyZWN0aW9uJywgJ3RoaWNrbmVzcycsICdoYXNJY29uJywgJ3NlbnRpbWVudCddLmluY2x1ZGVzKHByb3ApLFxufSk8SG9yaXpvbnRhbFNlcGFyYXRvclByb3BzPmBcbiAgbWFyZ2luOiAwO1xuICBib3JkZXI6IDA7XG4gIHdpZHRoOiAkeyh7IGRpcmVjdGlvbiwgdGhpY2tuZXNzID0gMSB9KSA9PlxuICAgIGRpcmVjdGlvbiA9PT0gJ3ZlcnRpY2FsJyA/IGAke3RoaWNrbmVzc31weGAgOiAnYXV0byd9O1xuICBoZWlnaHQ6ICR7KHsgZGlyZWN0aW9uLCB0aGlja25lc3MgPSAxIH0pID0+XG4gICAgZGlyZWN0aW9uID09PSAnaG9yaXpvbnRhbCcgPyBgJHt0aGlja25lc3N9cHhgIDogJ2F1dG8nfTtcbiAgZmxleC1zaHJpbms6IDA7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUsIHNlbnRpbWVudCB9KSA9PlxuICAgIHNlbnRpbWVudCA9PT0gJ25ldXRyYWwnXG4gICAgICA/IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJvcmRlcldlYWtcbiAgICAgIDogdGhlbWUuY29sb3JzW3NlbnRpbWVudF0uYm9yZGVyfTtcbiAgJHsoeyBoYXNJY29uIH0pID0+IGhhc0ljb24gJiYgYGZsZXg6IDE7YH1cbmBcblxudHlwZSBTZXBhcmF0b3JQcm9wcyA9IHtcbiAgZGlyZWN0aW9uPzogRGlyZWN0aW9uXG4gIHRoaWNrbmVzcz86IG51bWJlclxuICAvKipcbiAgICogQGRlcHJlY2F0ZWQgVXNlIGBzZW50aW1lbnRgIGluc3RlYWRcbiAgICovXG4gIGNvbG9yPzogQ29sb3JcbiAgc2VudGltZW50PzogQ29sb3JcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gICdkYXRhLXRlc3RpZCc/OiBzdHJpbmdcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGVcbn1cblxuLyoqXG4gKiBTZXBhcmF0b3IgY29tcG9uZW50IHVzZWQgdG8gc2VwYXJhdGUgY29udGVudCB3aXRoIGEgaG9yaXpvbnRhbCBvciB2ZXJ0aWNhbCBsaW5lLlxuICovXG5leHBvcnQgY29uc3QgU2VwYXJhdG9yID0gKHtcbiAgZGlyZWN0aW9uID0gJ2hvcml6b250YWwnLFxuICB0aGlja25lc3MgPSAxLFxuICBjb2xvciA9ICduZXV0cmFsJyxcbiAgc2VudGltZW50ID0gJ25ldXRyYWwnLFxuICBjbGFzc05hbWUsXG4gICdkYXRhLXRlc3RpZCc6IGRhdGFUZXN0SWQsXG4gIGNoaWxkcmVuLFxufTogU2VwYXJhdG9yUHJvcHMpID0+XG4gIGNoaWxkcmVuID8gKFxuICAgIDxTdHlsZWRJY29uV3JhcHBlclxuICAgICAgcm9sZT1cInNlcGFyYXRvclwiXG4gICAgICBhcmlhLW9yaWVudGF0aW9uPXtkaXJlY3Rpb259XG4gICAgICBkaXJlY3Rpb249e2RpcmVjdGlvbn1cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICBzZW50aW1lbnQ9e3NlbnRpbWVudH1cbiAgICAgIGNvbG9yPXtjb2xvcn1cbiAgICA+XG4gICAgICA8U3R5bGVkSHJcbiAgICAgICAgZGlyZWN0aW9uPXtkaXJlY3Rpb259XG4gICAgICAgIHRoaWNrbmVzcz17dGhpY2tuZXNzfVxuICAgICAgICBjb2xvcj17Y29sb3J9XG4gICAgICAgIHNlbnRpbWVudD17c2VudGltZW50fVxuICAgICAgICBoYXNJY29uXG4gICAgICAvPlxuICAgICAge2NoaWxkcmVufVxuICAgICAgPFN0eWxlZEhyXG4gICAgICAgIGRpcmVjdGlvbj17ZGlyZWN0aW9ufVxuICAgICAgICB0aGlja25lc3M9e3RoaWNrbmVzc31cbiAgICAgICAgY29sb3I9e2NvbG9yfVxuICAgICAgICBzZW50aW1lbnQ9e3NlbnRpbWVudH1cbiAgICAgICAgaGFzSWNvblxuICAgICAgLz5cbiAgICA8L1N0eWxlZEljb25XcmFwcGVyPlxuICApIDogKFxuICAgIDxTdHlsZWRIclxuICAgICAgcm9sZT1cInNlcGFyYXRvclwiXG4gICAgICBhcmlhLW9yaWVudGF0aW9uPXtkaXJlY3Rpb259XG4gICAgICBkaXJlY3Rpb249e2RpcmVjdGlvbn1cbiAgICAgIHRoaWNrbmVzcz17dGhpY2tuZXNzfVxuICAgICAgY29sb3I9e2NvbG9yfVxuICAgICAgc2VudGltZW50PXtzZW50aW1lbnR9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgIC8+XG4gIClcbiJdfQ== */"));
20
+ }) => sentiment === "neutral" ? theme.colors.neutral.borderWeak : theme.colors[sentiment].border, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NlcGFyYXRvci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZW1CIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NlcGFyYXRvci9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHR5cGUgeyBDb2xvciB9IGZyb20gJy4uLy4uL3RoZW1lJ1xuXG50eXBlIERpcmVjdGlvbiA9ICdob3Jpem9udGFsJyB8ICd2ZXJ0aWNhbCdcblxudHlwZSBTdHlsZWRJY29uUHJvcHMgPSB7XG4gIGRpcmVjdGlvbjogRGlyZWN0aW9uXG4gIHNlbnRpbWVudDogQ29sb3Jcbn1cblxuY29uc3QgU3R5bGVkSWNvbldyYXBwZXIgPSBzdHlsZWQoJ2RpdicsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT4gIVsnZGlyZWN0aW9uJywgJ3NlbnRpbWVudCddLmluY2x1ZGVzKHByb3ApLFxufSk8U3R5bGVkSWNvblByb3BzPmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246ICR7KHsgZGlyZWN0aW9uIH0pID0+XG4gICAgZGlyZWN0aW9uID09PSAndmVydGljYWwnID8gJ2NvbHVtbicgOiAncm93J307XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cbiAgc3ZnIHtcbiAgICBmaWxsOiAkeyh7IHNlbnRpbWVudCwgdGhlbWUgfSkgPT4gKHNlbnRpbWVudCA9PT0gJ25ldXRyYWwnID8gdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyV2VhayA6IHRoZW1lLmNvbG9yc1tzZW50aW1lbnRdLmJvcmRlcil9O1xuICB9XG5gXG5cbnR5cGUgSG9yaXpvbnRhbFNlcGFyYXRvclByb3BzID0gT21pdDxTZXBhcmF0b3JQcm9wcywgJ2NvbG9yJyB8ICdzZW50aW1lbnQnPiAmIHtcbiAgaGFzSWNvbj86IGJvb2xlYW5cbiAgc2VudGltZW50OiBDb2xvclxufVxuXG5jb25zdCBTdHlsZWRIciA9IHN0eWxlZCgnaHInLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+XG4gICAgIVsnZGlyZWN0aW9uJywgJ3RoaWNrbmVzcycsICdoYXNJY29uJywgJ3NlbnRpbWVudCddLmluY2x1ZGVzKHByb3ApLFxufSk8SG9yaXpvbnRhbFNlcGFyYXRvclByb3BzPmBcbiAgbWFyZ2luOiAwO1xuICBib3JkZXI6IDA7XG4gIHdpZHRoOiAkeyh7IGRpcmVjdGlvbiwgdGhpY2tuZXNzID0gMSB9KSA9PlxuICAgIGRpcmVjdGlvbiA9PT0gJ3ZlcnRpY2FsJyA/IGAke3RoaWNrbmVzc31weGAgOiAnYXV0byd9O1xuICBoZWlnaHQ6ICR7KHsgZGlyZWN0aW9uLCB0aGlja25lc3MgPSAxIH0pID0+XG4gICAgZGlyZWN0aW9uID09PSAnaG9yaXpvbnRhbCcgPyBgJHt0aGlja25lc3N9cHhgIDogJ2F1dG8nfTtcbiAgZmxleC1zaHJpbms6IDA7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUsIHNlbnRpbWVudCB9KSA9PlxuICAgIHNlbnRpbWVudCA9PT0gJ25ldXRyYWwnXG4gICAgICA/IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJvcmRlcldlYWtcbiAgICAgIDogdGhlbWUuY29sb3JzW3NlbnRpbWVudF0uYm9yZGVyfTtcbiAgJHsoeyBoYXNJY29uIH0pID0+IGhhc0ljb24gJiYgYGZsZXg6IDE7YH1cbmBcblxudHlwZSBTZXBhcmF0b3JQcm9wcyA9IHtcbiAgZGlyZWN0aW9uPzogRGlyZWN0aW9uXG4gIHRoaWNrbmVzcz86IG51bWJlclxuICBzZW50aW1lbnQ/OiBDb2xvclxuICBjbGFzc05hbWU/OiBzdHJpbmdcbiAgJ2RhdGEtdGVzdGlkJz86IHN0cmluZ1xuICBjaGlsZHJlbj86IFJlYWN0Tm9kZVxufVxuXG4vKipcbiAqIFNlcGFyYXRvciBjb21wb25lbnQgdXNlZCB0byBzZXBhcmF0ZSBjb250ZW50IHdpdGggYSBob3Jpem9udGFsIG9yIHZlcnRpY2FsIGxpbmUuXG4gKi9cbmV4cG9ydCBjb25zdCBTZXBhcmF0b3IgPSAoe1xuICBkaXJlY3Rpb24gPSAnaG9yaXpvbnRhbCcsXG4gIHRoaWNrbmVzcyA9IDEsXG4gIHNlbnRpbWVudCA9ICduZXV0cmFsJyxcbiAgY2xhc3NOYW1lLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxuICBjaGlsZHJlbixcbn06IFNlcGFyYXRvclByb3BzKSA9PlxuICBjaGlsZHJlbiA/IChcbiAgICA8U3R5bGVkSWNvbldyYXBwZXJcbiAgICAgIHJvbGU9XCJzZXBhcmF0b3JcIlxuICAgICAgYXJpYS1vcmllbnRhdGlvbj17ZGlyZWN0aW9ufVxuICAgICAgZGlyZWN0aW9uPXtkaXJlY3Rpb259XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgc2VudGltZW50PXtzZW50aW1lbnR9XG4gICAgPlxuICAgICAgPFN0eWxlZEhyXG4gICAgICAgIGRpcmVjdGlvbj17ZGlyZWN0aW9ufVxuICAgICAgICB0aGlja25lc3M9e3RoaWNrbmVzc31cbiAgICAgICAgc2VudGltZW50PXtzZW50aW1lbnR9XG4gICAgICAgIGhhc0ljb25cbiAgICAgIC8+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgICA8U3R5bGVkSHJcbiAgICAgICAgZGlyZWN0aW9uPXtkaXJlY3Rpb259XG4gICAgICAgIHRoaWNrbmVzcz17dGhpY2tuZXNzfVxuICAgICAgICBzZW50aW1lbnQ9e3NlbnRpbWVudH1cbiAgICAgICAgaGFzSWNvblxuICAgICAgLz5cbiAgICA8L1N0eWxlZEljb25XcmFwcGVyPlxuICApIDogKFxuICAgIDxTdHlsZWRIclxuICAgICAgcm9sZT1cInNlcGFyYXRvclwiXG4gICAgICBhcmlhLW9yaWVudGF0aW9uPXtkaXJlY3Rpb259XG4gICAgICBkaXJlY3Rpb249e2RpcmVjdGlvbn1cbiAgICAgIHRoaWNrbmVzcz17dGhpY2tuZXNzfVxuICAgICAgc2VudGltZW50PXtzZW50aW1lbnR9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgIC8+XG4gIClcbiJdfQ== */"));
21
21
  const StyledHr = /* @__PURE__ */ _styled__default.default("hr", process.env.NODE_ENV === "production" ? {
22
22
  shouldForwardProp: (prop) => !["direction", "thickness", "hasIcon", "sentiment"].includes(prop),
23
23
  target: "e1d1zom90"
@@ -36,18 +36,17 @@ const StyledHr = /* @__PURE__ */ _styled__default.default("hr", process.env.NODE
36
36
  sentiment
37
37
  }) => sentiment === "neutral" ? theme.colors.neutral.borderWeak : theme.colors[sentiment].border, ";", ({
38
38
  hasIcon
39
- }) => hasIcon && `flex: 1;`, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NlcGFyYXRvci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUM0QiIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9TZXBhcmF0b3IvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB0eXBlIHsgQ29sb3IgfSBmcm9tICcuLi8uLi90aGVtZSdcblxudHlwZSBEaXJlY3Rpb24gPSAnaG9yaXpvbnRhbCcgfCAndmVydGljYWwnXG5cbnR5cGUgU3R5bGVkSWNvblByb3BzID0ge1xuICBkaXJlY3Rpb246IERpcmVjdGlvblxuICBzZW50aW1lbnQ6IENvbG9yXG59XG5cbmNvbnN0IFN0eWxlZEljb25XcmFwcGVyID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+XG4gICAgIVsnZGlyZWN0aW9uJywgJ2NvbG9yJywgJ3NlbnRpbWVudCddLmluY2x1ZGVzKHByb3ApLFxufSk8U3R5bGVkSWNvblByb3BzPmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246ICR7KHsgZGlyZWN0aW9uIH0pID0+XG4gICAgZGlyZWN0aW9uID09PSAndmVydGljYWwnID8gJ2NvbHVtbicgOiAncm93J307XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cbiAgc3ZnIHtcbiAgICBmaWxsOiAkeyh7IHNlbnRpbWVudCwgdGhlbWUgfSkgPT4gKHNlbnRpbWVudCA9PT0gJ25ldXRyYWwnID8gdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyV2VhayA6IHRoZW1lLmNvbG9yc1tzZW50aW1lbnRdLmJvcmRlcil9O1xuICB9XG5gXG5cbnR5cGUgSG9yaXpvbnRhbFNlcGFyYXRvclByb3BzID0gT21pdDxTZXBhcmF0b3JQcm9wcywgJ2NvbG9yJyB8ICdzZW50aW1lbnQnPiAmIHtcbiAgaGFzSWNvbj86IGJvb2xlYW5cbiAgc2VudGltZW50OiBDb2xvclxufVxuXG5jb25zdCBTdHlsZWRIciA9IHN0eWxlZCgnaHInLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+XG4gICAgIVsnZGlyZWN0aW9uJywgJ3RoaWNrbmVzcycsICdoYXNJY29uJywgJ3NlbnRpbWVudCddLmluY2x1ZGVzKHByb3ApLFxufSk8SG9yaXpvbnRhbFNlcGFyYXRvclByb3BzPmBcbiAgbWFyZ2luOiAwO1xuICBib3JkZXI6IDA7XG4gIHdpZHRoOiAkeyh7IGRpcmVjdGlvbiwgdGhpY2tuZXNzID0gMSB9KSA9PlxuICAgIGRpcmVjdGlvbiA9PT0gJ3ZlcnRpY2FsJyA/IGAke3RoaWNrbmVzc31weGAgOiAnYXV0byd9O1xuICBoZWlnaHQ6ICR7KHsgZGlyZWN0aW9uLCB0aGlja25lc3MgPSAxIH0pID0+XG4gICAgZGlyZWN0aW9uID09PSAnaG9yaXpvbnRhbCcgPyBgJHt0aGlja25lc3N9cHhgIDogJ2F1dG8nfTtcbiAgZmxleC1zaHJpbms6IDA7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUsIHNlbnRpbWVudCB9KSA9PlxuICAgIHNlbnRpbWVudCA9PT0gJ25ldXRyYWwnXG4gICAgICA/IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJvcmRlcldlYWtcbiAgICAgIDogdGhlbWUuY29sb3JzW3NlbnRpbWVudF0uYm9yZGVyfTtcbiAgJHsoeyBoYXNJY29uIH0pID0+IGhhc0ljb24gJiYgYGZsZXg6IDE7YH1cbmBcblxudHlwZSBTZXBhcmF0b3JQcm9wcyA9IHtcbiAgZGlyZWN0aW9uPzogRGlyZWN0aW9uXG4gIHRoaWNrbmVzcz86IG51bWJlclxuICAvKipcbiAgICogQGRlcHJlY2F0ZWQgVXNlIGBzZW50aW1lbnRgIGluc3RlYWRcbiAgICovXG4gIGNvbG9yPzogQ29sb3JcbiAgc2VudGltZW50PzogQ29sb3JcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gICdkYXRhLXRlc3RpZCc/OiBzdHJpbmdcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGVcbn1cblxuLyoqXG4gKiBTZXBhcmF0b3IgY29tcG9uZW50IHVzZWQgdG8gc2VwYXJhdGUgY29udGVudCB3aXRoIGEgaG9yaXpvbnRhbCBvciB2ZXJ0aWNhbCBsaW5lLlxuICovXG5leHBvcnQgY29uc3QgU2VwYXJhdG9yID0gKHtcbiAgZGlyZWN0aW9uID0gJ2hvcml6b250YWwnLFxuICB0aGlja25lc3MgPSAxLFxuICBjb2xvciA9ICduZXV0cmFsJyxcbiAgc2VudGltZW50ID0gJ25ldXRyYWwnLFxuICBjbGFzc05hbWUsXG4gICdkYXRhLXRlc3RpZCc6IGRhdGFUZXN0SWQsXG4gIGNoaWxkcmVuLFxufTogU2VwYXJhdG9yUHJvcHMpID0+XG4gIGNoaWxkcmVuID8gKFxuICAgIDxTdHlsZWRJY29uV3JhcHBlclxuICAgICAgcm9sZT1cInNlcGFyYXRvclwiXG4gICAgICBhcmlhLW9yaWVudGF0aW9uPXtkaXJlY3Rpb259XG4gICAgICBkaXJlY3Rpb249e2RpcmVjdGlvbn1cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICBzZW50aW1lbnQ9e3NlbnRpbWVudH1cbiAgICAgIGNvbG9yPXtjb2xvcn1cbiAgICA+XG4gICAgICA8U3R5bGVkSHJcbiAgICAgICAgZGlyZWN0aW9uPXtkaXJlY3Rpb259XG4gICAgICAgIHRoaWNrbmVzcz17dGhpY2tuZXNzfVxuICAgICAgICBjb2xvcj17Y29sb3J9XG4gICAgICAgIHNlbnRpbWVudD17c2VudGltZW50fVxuICAgICAgICBoYXNJY29uXG4gICAgICAvPlxuICAgICAge2NoaWxkcmVufVxuICAgICAgPFN0eWxlZEhyXG4gICAgICAgIGRpcmVjdGlvbj17ZGlyZWN0aW9ufVxuICAgICAgICB0aGlja25lc3M9e3RoaWNrbmVzc31cbiAgICAgICAgY29sb3I9e2NvbG9yfVxuICAgICAgICBzZW50aW1lbnQ9e3NlbnRpbWVudH1cbiAgICAgICAgaGFzSWNvblxuICAgICAgLz5cbiAgICA8L1N0eWxlZEljb25XcmFwcGVyPlxuICApIDogKFxuICAgIDxTdHlsZWRIclxuICAgICAgcm9sZT1cInNlcGFyYXRvclwiXG4gICAgICBhcmlhLW9yaWVudGF0aW9uPXtkaXJlY3Rpb259XG4gICAgICBkaXJlY3Rpb249e2RpcmVjdGlvbn1cbiAgICAgIHRoaWNrbmVzcz17dGhpY2tuZXNzfVxuICAgICAgY29sb3I9e2NvbG9yfVxuICAgICAgc2VudGltZW50PXtzZW50aW1lbnR9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgIC8+XG4gIClcbiJdfQ== */"));
39
+ }) => hasIcon && `flex: 1;`, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NlcGFyYXRvci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0M0QiIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9TZXBhcmF0b3IvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB0eXBlIHsgQ29sb3IgfSBmcm9tICcuLi8uLi90aGVtZSdcblxudHlwZSBEaXJlY3Rpb24gPSAnaG9yaXpvbnRhbCcgfCAndmVydGljYWwnXG5cbnR5cGUgU3R5bGVkSWNvblByb3BzID0ge1xuICBkaXJlY3Rpb246IERpcmVjdGlvblxuICBzZW50aW1lbnQ6IENvbG9yXG59XG5cbmNvbnN0IFN0eWxlZEljb25XcmFwcGVyID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ2RpcmVjdGlvbicsICdzZW50aW1lbnQnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPFN0eWxlZEljb25Qcm9wcz5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiAkeyh7IGRpcmVjdGlvbiB9KSA9PlxuICAgIGRpcmVjdGlvbiA9PT0gJ3ZlcnRpY2FsJyA/ICdjb2x1bW4nIDogJ3Jvdyd9O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuXG4gIHN2ZyB7XG4gICAgZmlsbDogJHsoeyBzZW50aW1lbnQsIHRoZW1lIH0pID0+IChzZW50aW1lbnQgPT09ICduZXV0cmFsJyA/IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJvcmRlcldlYWsgOiB0aGVtZS5jb2xvcnNbc2VudGltZW50XS5ib3JkZXIpfTtcbiAgfVxuYFxuXG50eXBlIEhvcml6b250YWxTZXBhcmF0b3JQcm9wcyA9IE9taXQ8U2VwYXJhdG9yUHJvcHMsICdjb2xvcicgfCAnc2VudGltZW50Jz4gJiB7XG4gIGhhc0ljb24/OiBib29sZWFuXG4gIHNlbnRpbWVudDogQ29sb3Jcbn1cblxuY29uc3QgU3R5bGVkSHIgPSBzdHlsZWQoJ2hyJywge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PlxuICAgICFbJ2RpcmVjdGlvbicsICd0aGlja25lc3MnLCAnaGFzSWNvbicsICdzZW50aW1lbnQnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPEhvcml6b250YWxTZXBhcmF0b3JQcm9wcz5gXG4gIG1hcmdpbjogMDtcbiAgYm9yZGVyOiAwO1xuICB3aWR0aDogJHsoeyBkaXJlY3Rpb24sIHRoaWNrbmVzcyA9IDEgfSkgPT5cbiAgICBkaXJlY3Rpb24gPT09ICd2ZXJ0aWNhbCcgPyBgJHt0aGlja25lc3N9cHhgIDogJ2F1dG8nfTtcbiAgaGVpZ2h0OiAkeyh7IGRpcmVjdGlvbiwgdGhpY2tuZXNzID0gMSB9KSA9PlxuICAgIGRpcmVjdGlvbiA9PT0gJ2hvcml6b250YWwnID8gYCR7dGhpY2tuZXNzfXB4YCA6ICdhdXRvJ307XG4gIGZsZXgtc2hyaW5rOiAwO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IHRoZW1lLCBzZW50aW1lbnQgfSkgPT5cbiAgICBzZW50aW1lbnQgPT09ICduZXV0cmFsJ1xuICAgICAgPyB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJXZWFrXG4gICAgICA6IHRoZW1lLmNvbG9yc1tzZW50aW1lbnRdLmJvcmRlcn07XG4gICR7KHsgaGFzSWNvbiB9KSA9PiBoYXNJY29uICYmIGBmbGV4OiAxO2B9XG5gXG5cbnR5cGUgU2VwYXJhdG9yUHJvcHMgPSB7XG4gIGRpcmVjdGlvbj86IERpcmVjdGlvblxuICB0aGlja25lc3M/OiBudW1iZXJcbiAgc2VudGltZW50PzogQ29sb3JcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gICdkYXRhLXRlc3RpZCc/OiBzdHJpbmdcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGVcbn1cblxuLyoqXG4gKiBTZXBhcmF0b3IgY29tcG9uZW50IHVzZWQgdG8gc2VwYXJhdGUgY29udGVudCB3aXRoIGEgaG9yaXpvbnRhbCBvciB2ZXJ0aWNhbCBsaW5lLlxuICovXG5leHBvcnQgY29uc3QgU2VwYXJhdG9yID0gKHtcbiAgZGlyZWN0aW9uID0gJ2hvcml6b250YWwnLFxuICB0aGlja25lc3MgPSAxLFxuICBzZW50aW1lbnQgPSAnbmV1dHJhbCcsXG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbiAgY2hpbGRyZW4sXG59OiBTZXBhcmF0b3JQcm9wcykgPT5cbiAgY2hpbGRyZW4gPyAoXG4gICAgPFN0eWxlZEljb25XcmFwcGVyXG4gICAgICByb2xlPVwic2VwYXJhdG9yXCJcbiAgICAgIGFyaWEtb3JpZW50YXRpb249e2RpcmVjdGlvbn1cbiAgICAgIGRpcmVjdGlvbj17ZGlyZWN0aW9ufVxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAgIHNlbnRpbWVudD17c2VudGltZW50fVxuICAgID5cbiAgICAgIDxTdHlsZWRIclxuICAgICAgICBkaXJlY3Rpb249e2RpcmVjdGlvbn1cbiAgICAgICAgdGhpY2tuZXNzPXt0aGlja25lc3N9XG4gICAgICAgIHNlbnRpbWVudD17c2VudGltZW50fVxuICAgICAgICBoYXNJY29uXG4gICAgICAvPlxuICAgICAge2NoaWxkcmVufVxuICAgICAgPFN0eWxlZEhyXG4gICAgICAgIGRpcmVjdGlvbj17ZGlyZWN0aW9ufVxuICAgICAgICB0aGlja25lc3M9e3RoaWNrbmVzc31cbiAgICAgICAgc2VudGltZW50PXtzZW50aW1lbnR9XG4gICAgICAgIGhhc0ljb25cbiAgICAgIC8+XG4gICAgPC9TdHlsZWRJY29uV3JhcHBlcj5cbiAgKSA6IChcbiAgICA8U3R5bGVkSHJcbiAgICAgIHJvbGU9XCJzZXBhcmF0b3JcIlxuICAgICAgYXJpYS1vcmllbnRhdGlvbj17ZGlyZWN0aW9ufVxuICAgICAgZGlyZWN0aW9uPXtkaXJlY3Rpb259XG4gICAgICB0aGlja25lc3M9e3RoaWNrbmVzc31cbiAgICAgIHNlbnRpbWVudD17c2VudGltZW50fVxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAvPlxuICApXG4iXX0= */"));
40
40
  const Separator = ({
41
41
  direction = "horizontal",
42
42
  thickness = 1,
43
- color = "neutral",
44
43
  sentiment = "neutral",
45
44
  className,
46
45
  "data-testid": dataTestId,
47
46
  children
48
- }) => children ? /* @__PURE__ */ jsxRuntime.jsxs(StyledIconWrapper, { role: "separator", "aria-orientation": direction, direction, className, "data-testid": dataTestId, sentiment, color, children: [
49
- /* @__PURE__ */ jsxRuntime.jsx(StyledHr, { direction, thickness, color, sentiment, hasIcon: true }),
47
+ }) => children ? /* @__PURE__ */ jsxRuntime.jsxs(StyledIconWrapper, { role: "separator", "aria-orientation": direction, direction, className, "data-testid": dataTestId, sentiment, children: [
48
+ /* @__PURE__ */ jsxRuntime.jsx(StyledHr, { direction, thickness, sentiment, hasIcon: true }),
50
49
  children,
51
- /* @__PURE__ */ jsxRuntime.jsx(StyledHr, { direction, thickness, color, sentiment, hasIcon: true })
52
- ] }) : /* @__PURE__ */ jsxRuntime.jsx(StyledHr, { role: "separator", "aria-orientation": direction, direction, thickness, color, sentiment, className, "data-testid": dataTestId });
50
+ /* @__PURE__ */ jsxRuntime.jsx(StyledHr, { direction, thickness, sentiment, hasIcon: true })
51
+ ] }) : /* @__PURE__ */ jsxRuntime.jsx(StyledHr, { role: "separator", "aria-orientation": direction, direction, thickness, sentiment, className, "data-testid": dataTestId });
53
52
  exports.Separator = Separator;
@@ -4,10 +4,6 @@ type Direction = 'horizontal' | 'vertical';
4
4
  type SeparatorProps = {
5
5
  direction?: Direction;
6
6
  thickness?: number;
7
- /**
8
- * @deprecated Use `sentiment` instead
9
- */
10
- color?: Color;
11
7
  sentiment?: Color;
12
8
  className?: string;
13
9
  'data-testid'?: string;
@@ -16,5 +12,5 @@ type SeparatorProps = {
16
12
  /**
17
13
  * Separator component used to separate content with a horizontal or vertical line.
18
14
  */
19
- export declare const Separator: ({ direction, thickness, color, sentiment, className, "data-testid": dataTestId, children, }: SeparatorProps) => import("@emotion/react/jsx-runtime").JSX.Element;
15
+ export declare const Separator: ({ direction, thickness, sentiment, className, "data-testid": dataTestId, children, }: SeparatorProps) => import("@emotion/react/jsx-runtime").JSX.Element;
20
16
  export {};
@@ -2,10 +2,10 @@
2
2
  import { jsxs, jsx } from "@emotion/react/jsx-runtime";
3
3
  import _styled from "@emotion/styled/base";
4
4
  const StyledIconWrapper = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
5
- shouldForwardProp: (prop) => !["direction", "color", "sentiment"].includes(prop),
5
+ shouldForwardProp: (prop) => !["direction", "sentiment"].includes(prop),
6
6
  target: "e1d1zom91"
7
7
  } : {
8
- shouldForwardProp: (prop) => !["direction", "color", "sentiment"].includes(prop),
8
+ shouldForwardProp: (prop) => !["direction", "sentiment"].includes(prop),
9
9
  target: "e1d1zom91",
10
10
  label: "StyledIconWrapper"
11
11
  })("display:flex;flex-direction:", ({
@@ -13,7 +13,7 @@ const StyledIconWrapper = /* @__PURE__ */ _styled("div", process.env.NODE_ENV ==
13
13
  }) => direction === "vertical" ? "column" : "row", ";align-items:center;svg{fill:", ({
14
14
  sentiment,
15
15
  theme
16
- }) => sentiment === "neutral" ? theme.colors.neutral.borderWeak : theme.colors[sentiment].border, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NlcGFyYXRvci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0JtQiIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9TZXBhcmF0b3IvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB0eXBlIHsgQ29sb3IgfSBmcm9tICcuLi8uLi90aGVtZSdcblxudHlwZSBEaXJlY3Rpb24gPSAnaG9yaXpvbnRhbCcgfCAndmVydGljYWwnXG5cbnR5cGUgU3R5bGVkSWNvblByb3BzID0ge1xuICBkaXJlY3Rpb246IERpcmVjdGlvblxuICBzZW50aW1lbnQ6IENvbG9yXG59XG5cbmNvbnN0IFN0eWxlZEljb25XcmFwcGVyID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+XG4gICAgIVsnZGlyZWN0aW9uJywgJ2NvbG9yJywgJ3NlbnRpbWVudCddLmluY2x1ZGVzKHByb3ApLFxufSk8U3R5bGVkSWNvblByb3BzPmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246ICR7KHsgZGlyZWN0aW9uIH0pID0+XG4gICAgZGlyZWN0aW9uID09PSAndmVydGljYWwnID8gJ2NvbHVtbicgOiAncm93J307XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cbiAgc3ZnIHtcbiAgICBmaWxsOiAkeyh7IHNlbnRpbWVudCwgdGhlbWUgfSkgPT4gKHNlbnRpbWVudCA9PT0gJ25ldXRyYWwnID8gdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyV2VhayA6IHRoZW1lLmNvbG9yc1tzZW50aW1lbnRdLmJvcmRlcil9O1xuICB9XG5gXG5cbnR5cGUgSG9yaXpvbnRhbFNlcGFyYXRvclByb3BzID0gT21pdDxTZXBhcmF0b3JQcm9wcywgJ2NvbG9yJyB8ICdzZW50aW1lbnQnPiAmIHtcbiAgaGFzSWNvbj86IGJvb2xlYW5cbiAgc2VudGltZW50OiBDb2xvclxufVxuXG5jb25zdCBTdHlsZWRIciA9IHN0eWxlZCgnaHInLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+XG4gICAgIVsnZGlyZWN0aW9uJywgJ3RoaWNrbmVzcycsICdoYXNJY29uJywgJ3NlbnRpbWVudCddLmluY2x1ZGVzKHByb3ApLFxufSk8SG9yaXpvbnRhbFNlcGFyYXRvclByb3BzPmBcbiAgbWFyZ2luOiAwO1xuICBib3JkZXI6IDA7XG4gIHdpZHRoOiAkeyh7IGRpcmVjdGlvbiwgdGhpY2tuZXNzID0gMSB9KSA9PlxuICAgIGRpcmVjdGlvbiA9PT0gJ3ZlcnRpY2FsJyA/IGAke3RoaWNrbmVzc31weGAgOiAnYXV0byd9O1xuICBoZWlnaHQ6ICR7KHsgZGlyZWN0aW9uLCB0aGlja25lc3MgPSAxIH0pID0+XG4gICAgZGlyZWN0aW9uID09PSAnaG9yaXpvbnRhbCcgPyBgJHt0aGlja25lc3N9cHhgIDogJ2F1dG8nfTtcbiAgZmxleC1zaHJpbms6IDA7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUsIHNlbnRpbWVudCB9KSA9PlxuICAgIHNlbnRpbWVudCA9PT0gJ25ldXRyYWwnXG4gICAgICA/IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJvcmRlcldlYWtcbiAgICAgIDogdGhlbWUuY29sb3JzW3NlbnRpbWVudF0uYm9yZGVyfTtcbiAgJHsoeyBoYXNJY29uIH0pID0+IGhhc0ljb24gJiYgYGZsZXg6IDE7YH1cbmBcblxudHlwZSBTZXBhcmF0b3JQcm9wcyA9IHtcbiAgZGlyZWN0aW9uPzogRGlyZWN0aW9uXG4gIHRoaWNrbmVzcz86IG51bWJlclxuICAvKipcbiAgICogQGRlcHJlY2F0ZWQgVXNlIGBzZW50aW1lbnRgIGluc3RlYWRcbiAgICovXG4gIGNvbG9yPzogQ29sb3JcbiAgc2VudGltZW50PzogQ29sb3JcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gICdkYXRhLXRlc3RpZCc/OiBzdHJpbmdcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGVcbn1cblxuLyoqXG4gKiBTZXBhcmF0b3IgY29tcG9uZW50IHVzZWQgdG8gc2VwYXJhdGUgY29udGVudCB3aXRoIGEgaG9yaXpvbnRhbCBvciB2ZXJ0aWNhbCBsaW5lLlxuICovXG5leHBvcnQgY29uc3QgU2VwYXJhdG9yID0gKHtcbiAgZGlyZWN0aW9uID0gJ2hvcml6b250YWwnLFxuICB0aGlja25lc3MgPSAxLFxuICBjb2xvciA9ICduZXV0cmFsJyxcbiAgc2VudGltZW50ID0gJ25ldXRyYWwnLFxuICBjbGFzc05hbWUsXG4gICdkYXRhLXRlc3RpZCc6IGRhdGFUZXN0SWQsXG4gIGNoaWxkcmVuLFxufTogU2VwYXJhdG9yUHJvcHMpID0+XG4gIGNoaWxkcmVuID8gKFxuICAgIDxTdHlsZWRJY29uV3JhcHBlclxuICAgICAgcm9sZT1cInNlcGFyYXRvclwiXG4gICAgICBhcmlhLW9yaWVudGF0aW9uPXtkaXJlY3Rpb259XG4gICAgICBkaXJlY3Rpb249e2RpcmVjdGlvbn1cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICBzZW50aW1lbnQ9e3NlbnRpbWVudH1cbiAgICAgIGNvbG9yPXtjb2xvcn1cbiAgICA+XG4gICAgICA8U3R5bGVkSHJcbiAgICAgICAgZGlyZWN0aW9uPXtkaXJlY3Rpb259XG4gICAgICAgIHRoaWNrbmVzcz17dGhpY2tuZXNzfVxuICAgICAgICBjb2xvcj17Y29sb3J9XG4gICAgICAgIHNlbnRpbWVudD17c2VudGltZW50fVxuICAgICAgICBoYXNJY29uXG4gICAgICAvPlxuICAgICAge2NoaWxkcmVufVxuICAgICAgPFN0eWxlZEhyXG4gICAgICAgIGRpcmVjdGlvbj17ZGlyZWN0aW9ufVxuICAgICAgICB0aGlja25lc3M9e3RoaWNrbmVzc31cbiAgICAgICAgY29sb3I9e2NvbG9yfVxuICAgICAgICBzZW50aW1lbnQ9e3NlbnRpbWVudH1cbiAgICAgICAgaGFzSWNvblxuICAgICAgLz5cbiAgICA8L1N0eWxlZEljb25XcmFwcGVyPlxuICApIDogKFxuICAgIDxTdHlsZWRIclxuICAgICAgcm9sZT1cInNlcGFyYXRvclwiXG4gICAgICBhcmlhLW9yaWVudGF0aW9uPXtkaXJlY3Rpb259XG4gICAgICBkaXJlY3Rpb249e2RpcmVjdGlvbn1cbiAgICAgIHRoaWNrbmVzcz17dGhpY2tuZXNzfVxuICAgICAgY29sb3I9e2NvbG9yfVxuICAgICAgc2VudGltZW50PXtzZW50aW1lbnR9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgIC8+XG4gIClcbiJdfQ== */"));
16
+ }) => sentiment === "neutral" ? theme.colors.neutral.borderWeak : theme.colors[sentiment].border, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NlcGFyYXRvci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZW1CIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NlcGFyYXRvci9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHR5cGUgeyBDb2xvciB9IGZyb20gJy4uLy4uL3RoZW1lJ1xuXG50eXBlIERpcmVjdGlvbiA9ICdob3Jpem9udGFsJyB8ICd2ZXJ0aWNhbCdcblxudHlwZSBTdHlsZWRJY29uUHJvcHMgPSB7XG4gIGRpcmVjdGlvbjogRGlyZWN0aW9uXG4gIHNlbnRpbWVudDogQ29sb3Jcbn1cblxuY29uc3QgU3R5bGVkSWNvbldyYXBwZXIgPSBzdHlsZWQoJ2RpdicsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT4gIVsnZGlyZWN0aW9uJywgJ3NlbnRpbWVudCddLmluY2x1ZGVzKHByb3ApLFxufSk8U3R5bGVkSWNvblByb3BzPmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246ICR7KHsgZGlyZWN0aW9uIH0pID0+XG4gICAgZGlyZWN0aW9uID09PSAndmVydGljYWwnID8gJ2NvbHVtbicgOiAncm93J307XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cbiAgc3ZnIHtcbiAgICBmaWxsOiAkeyh7IHNlbnRpbWVudCwgdGhlbWUgfSkgPT4gKHNlbnRpbWVudCA9PT0gJ25ldXRyYWwnID8gdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyV2VhayA6IHRoZW1lLmNvbG9yc1tzZW50aW1lbnRdLmJvcmRlcil9O1xuICB9XG5gXG5cbnR5cGUgSG9yaXpvbnRhbFNlcGFyYXRvclByb3BzID0gT21pdDxTZXBhcmF0b3JQcm9wcywgJ2NvbG9yJyB8ICdzZW50aW1lbnQnPiAmIHtcbiAgaGFzSWNvbj86IGJvb2xlYW5cbiAgc2VudGltZW50OiBDb2xvclxufVxuXG5jb25zdCBTdHlsZWRIciA9IHN0eWxlZCgnaHInLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+XG4gICAgIVsnZGlyZWN0aW9uJywgJ3RoaWNrbmVzcycsICdoYXNJY29uJywgJ3NlbnRpbWVudCddLmluY2x1ZGVzKHByb3ApLFxufSk8SG9yaXpvbnRhbFNlcGFyYXRvclByb3BzPmBcbiAgbWFyZ2luOiAwO1xuICBib3JkZXI6IDA7XG4gIHdpZHRoOiAkeyh7IGRpcmVjdGlvbiwgdGhpY2tuZXNzID0gMSB9KSA9PlxuICAgIGRpcmVjdGlvbiA9PT0gJ3ZlcnRpY2FsJyA/IGAke3RoaWNrbmVzc31weGAgOiAnYXV0byd9O1xuICBoZWlnaHQ6ICR7KHsgZGlyZWN0aW9uLCB0aGlja25lc3MgPSAxIH0pID0+XG4gICAgZGlyZWN0aW9uID09PSAnaG9yaXpvbnRhbCcgPyBgJHt0aGlja25lc3N9cHhgIDogJ2F1dG8nfTtcbiAgZmxleC1zaHJpbms6IDA7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUsIHNlbnRpbWVudCB9KSA9PlxuICAgIHNlbnRpbWVudCA9PT0gJ25ldXRyYWwnXG4gICAgICA/IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJvcmRlcldlYWtcbiAgICAgIDogdGhlbWUuY29sb3JzW3NlbnRpbWVudF0uYm9yZGVyfTtcbiAgJHsoeyBoYXNJY29uIH0pID0+IGhhc0ljb24gJiYgYGZsZXg6IDE7YH1cbmBcblxudHlwZSBTZXBhcmF0b3JQcm9wcyA9IHtcbiAgZGlyZWN0aW9uPzogRGlyZWN0aW9uXG4gIHRoaWNrbmVzcz86IG51bWJlclxuICBzZW50aW1lbnQ/OiBDb2xvclxuICBjbGFzc05hbWU/OiBzdHJpbmdcbiAgJ2RhdGEtdGVzdGlkJz86IHN0cmluZ1xuICBjaGlsZHJlbj86IFJlYWN0Tm9kZVxufVxuXG4vKipcbiAqIFNlcGFyYXRvciBjb21wb25lbnQgdXNlZCB0byBzZXBhcmF0ZSBjb250ZW50IHdpdGggYSBob3Jpem9udGFsIG9yIHZlcnRpY2FsIGxpbmUuXG4gKi9cbmV4cG9ydCBjb25zdCBTZXBhcmF0b3IgPSAoe1xuICBkaXJlY3Rpb24gPSAnaG9yaXpvbnRhbCcsXG4gIHRoaWNrbmVzcyA9IDEsXG4gIHNlbnRpbWVudCA9ICduZXV0cmFsJyxcbiAgY2xhc3NOYW1lLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxuICBjaGlsZHJlbixcbn06IFNlcGFyYXRvclByb3BzKSA9PlxuICBjaGlsZHJlbiA/IChcbiAgICA8U3R5bGVkSWNvbldyYXBwZXJcbiAgICAgIHJvbGU9XCJzZXBhcmF0b3JcIlxuICAgICAgYXJpYS1vcmllbnRhdGlvbj17ZGlyZWN0aW9ufVxuICAgICAgZGlyZWN0aW9uPXtkaXJlY3Rpb259XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgc2VudGltZW50PXtzZW50aW1lbnR9XG4gICAgPlxuICAgICAgPFN0eWxlZEhyXG4gICAgICAgIGRpcmVjdGlvbj17ZGlyZWN0aW9ufVxuICAgICAgICB0aGlja25lc3M9e3RoaWNrbmVzc31cbiAgICAgICAgc2VudGltZW50PXtzZW50aW1lbnR9XG4gICAgICAgIGhhc0ljb25cbiAgICAgIC8+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgICA8U3R5bGVkSHJcbiAgICAgICAgZGlyZWN0aW9uPXtkaXJlY3Rpb259XG4gICAgICAgIHRoaWNrbmVzcz17dGhpY2tuZXNzfVxuICAgICAgICBzZW50aW1lbnQ9e3NlbnRpbWVudH1cbiAgICAgICAgaGFzSWNvblxuICAgICAgLz5cbiAgICA8L1N0eWxlZEljb25XcmFwcGVyPlxuICApIDogKFxuICAgIDxTdHlsZWRIclxuICAgICAgcm9sZT1cInNlcGFyYXRvclwiXG4gICAgICBhcmlhLW9yaWVudGF0aW9uPXtkaXJlY3Rpb259XG4gICAgICBkaXJlY3Rpb249e2RpcmVjdGlvbn1cbiAgICAgIHRoaWNrbmVzcz17dGhpY2tuZXNzfVxuICAgICAgc2VudGltZW50PXtzZW50aW1lbnR9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgIC8+XG4gIClcbiJdfQ== */"));
17
17
  const StyledHr = /* @__PURE__ */ _styled("hr", process.env.NODE_ENV === "production" ? {
18
18
  shouldForwardProp: (prop) => !["direction", "thickness", "hasIcon", "sentiment"].includes(prop),
19
19
  target: "e1d1zom90"
@@ -32,20 +32,19 @@ const StyledHr = /* @__PURE__ */ _styled("hr", process.env.NODE_ENV === "product
32
32
  sentiment
33
33
  }) => sentiment === "neutral" ? theme.colors.neutral.borderWeak : theme.colors[sentiment].border, ";", ({
34
34
  hasIcon
35
- }) => hasIcon && `flex: 1;`, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NlcGFyYXRvci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUM0QiIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9TZXBhcmF0b3IvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB0eXBlIHsgQ29sb3IgfSBmcm9tICcuLi8uLi90aGVtZSdcblxudHlwZSBEaXJlY3Rpb24gPSAnaG9yaXpvbnRhbCcgfCAndmVydGljYWwnXG5cbnR5cGUgU3R5bGVkSWNvblByb3BzID0ge1xuICBkaXJlY3Rpb246IERpcmVjdGlvblxuICBzZW50aW1lbnQ6IENvbG9yXG59XG5cbmNvbnN0IFN0eWxlZEljb25XcmFwcGVyID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+XG4gICAgIVsnZGlyZWN0aW9uJywgJ2NvbG9yJywgJ3NlbnRpbWVudCddLmluY2x1ZGVzKHByb3ApLFxufSk8U3R5bGVkSWNvblByb3BzPmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246ICR7KHsgZGlyZWN0aW9uIH0pID0+XG4gICAgZGlyZWN0aW9uID09PSAndmVydGljYWwnID8gJ2NvbHVtbicgOiAncm93J307XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cbiAgc3ZnIHtcbiAgICBmaWxsOiAkeyh7IHNlbnRpbWVudCwgdGhlbWUgfSkgPT4gKHNlbnRpbWVudCA9PT0gJ25ldXRyYWwnID8gdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyV2VhayA6IHRoZW1lLmNvbG9yc1tzZW50aW1lbnRdLmJvcmRlcil9O1xuICB9XG5gXG5cbnR5cGUgSG9yaXpvbnRhbFNlcGFyYXRvclByb3BzID0gT21pdDxTZXBhcmF0b3JQcm9wcywgJ2NvbG9yJyB8ICdzZW50aW1lbnQnPiAmIHtcbiAgaGFzSWNvbj86IGJvb2xlYW5cbiAgc2VudGltZW50OiBDb2xvclxufVxuXG5jb25zdCBTdHlsZWRIciA9IHN0eWxlZCgnaHInLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+XG4gICAgIVsnZGlyZWN0aW9uJywgJ3RoaWNrbmVzcycsICdoYXNJY29uJywgJ3NlbnRpbWVudCddLmluY2x1ZGVzKHByb3ApLFxufSk8SG9yaXpvbnRhbFNlcGFyYXRvclByb3BzPmBcbiAgbWFyZ2luOiAwO1xuICBib3JkZXI6IDA7XG4gIHdpZHRoOiAkeyh7IGRpcmVjdGlvbiwgdGhpY2tuZXNzID0gMSB9KSA9PlxuICAgIGRpcmVjdGlvbiA9PT0gJ3ZlcnRpY2FsJyA/IGAke3RoaWNrbmVzc31weGAgOiAnYXV0byd9O1xuICBoZWlnaHQ6ICR7KHsgZGlyZWN0aW9uLCB0aGlja25lc3MgPSAxIH0pID0+XG4gICAgZGlyZWN0aW9uID09PSAnaG9yaXpvbnRhbCcgPyBgJHt0aGlja25lc3N9cHhgIDogJ2F1dG8nfTtcbiAgZmxleC1zaHJpbms6IDA7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUsIHNlbnRpbWVudCB9KSA9PlxuICAgIHNlbnRpbWVudCA9PT0gJ25ldXRyYWwnXG4gICAgICA/IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJvcmRlcldlYWtcbiAgICAgIDogdGhlbWUuY29sb3JzW3NlbnRpbWVudF0uYm9yZGVyfTtcbiAgJHsoeyBoYXNJY29uIH0pID0+IGhhc0ljb24gJiYgYGZsZXg6IDE7YH1cbmBcblxudHlwZSBTZXBhcmF0b3JQcm9wcyA9IHtcbiAgZGlyZWN0aW9uPzogRGlyZWN0aW9uXG4gIHRoaWNrbmVzcz86IG51bWJlclxuICAvKipcbiAgICogQGRlcHJlY2F0ZWQgVXNlIGBzZW50aW1lbnRgIGluc3RlYWRcbiAgICovXG4gIGNvbG9yPzogQ29sb3JcbiAgc2VudGltZW50PzogQ29sb3JcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gICdkYXRhLXRlc3RpZCc/OiBzdHJpbmdcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGVcbn1cblxuLyoqXG4gKiBTZXBhcmF0b3IgY29tcG9uZW50IHVzZWQgdG8gc2VwYXJhdGUgY29udGVudCB3aXRoIGEgaG9yaXpvbnRhbCBvciB2ZXJ0aWNhbCBsaW5lLlxuICovXG5leHBvcnQgY29uc3QgU2VwYXJhdG9yID0gKHtcbiAgZGlyZWN0aW9uID0gJ2hvcml6b250YWwnLFxuICB0aGlja25lc3MgPSAxLFxuICBjb2xvciA9ICduZXV0cmFsJyxcbiAgc2VudGltZW50ID0gJ25ldXRyYWwnLFxuICBjbGFzc05hbWUsXG4gICdkYXRhLXRlc3RpZCc6IGRhdGFUZXN0SWQsXG4gIGNoaWxkcmVuLFxufTogU2VwYXJhdG9yUHJvcHMpID0+XG4gIGNoaWxkcmVuID8gKFxuICAgIDxTdHlsZWRJY29uV3JhcHBlclxuICAgICAgcm9sZT1cInNlcGFyYXRvclwiXG4gICAgICBhcmlhLW9yaWVudGF0aW9uPXtkaXJlY3Rpb259XG4gICAgICBkaXJlY3Rpb249e2RpcmVjdGlvbn1cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICBzZW50aW1lbnQ9e3NlbnRpbWVudH1cbiAgICAgIGNvbG9yPXtjb2xvcn1cbiAgICA+XG4gICAgICA8U3R5bGVkSHJcbiAgICAgICAgZGlyZWN0aW9uPXtkaXJlY3Rpb259XG4gICAgICAgIHRoaWNrbmVzcz17dGhpY2tuZXNzfVxuICAgICAgICBjb2xvcj17Y29sb3J9XG4gICAgICAgIHNlbnRpbWVudD17c2VudGltZW50fVxuICAgICAgICBoYXNJY29uXG4gICAgICAvPlxuICAgICAge2NoaWxkcmVufVxuICAgICAgPFN0eWxlZEhyXG4gICAgICAgIGRpcmVjdGlvbj17ZGlyZWN0aW9ufVxuICAgICAgICB0aGlja25lc3M9e3RoaWNrbmVzc31cbiAgICAgICAgY29sb3I9e2NvbG9yfVxuICAgICAgICBzZW50aW1lbnQ9e3NlbnRpbWVudH1cbiAgICAgICAgaGFzSWNvblxuICAgICAgLz5cbiAgICA8L1N0eWxlZEljb25XcmFwcGVyPlxuICApIDogKFxuICAgIDxTdHlsZWRIclxuICAgICAgcm9sZT1cInNlcGFyYXRvclwiXG4gICAgICBhcmlhLW9yaWVudGF0aW9uPXtkaXJlY3Rpb259XG4gICAgICBkaXJlY3Rpb249e2RpcmVjdGlvbn1cbiAgICAgIHRoaWNrbmVzcz17dGhpY2tuZXNzfVxuICAgICAgY29sb3I9e2NvbG9yfVxuICAgICAgc2VudGltZW50PXtzZW50aW1lbnR9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgIC8+XG4gIClcbiJdfQ== */"));
35
+ }) => hasIcon && `flex: 1;`, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NlcGFyYXRvci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0M0QiIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9TZXBhcmF0b3IvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB0eXBlIHsgQ29sb3IgfSBmcm9tICcuLi8uLi90aGVtZSdcblxudHlwZSBEaXJlY3Rpb24gPSAnaG9yaXpvbnRhbCcgfCAndmVydGljYWwnXG5cbnR5cGUgU3R5bGVkSWNvblByb3BzID0ge1xuICBkaXJlY3Rpb246IERpcmVjdGlvblxuICBzZW50aW1lbnQ6IENvbG9yXG59XG5cbmNvbnN0IFN0eWxlZEljb25XcmFwcGVyID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ2RpcmVjdGlvbicsICdzZW50aW1lbnQnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPFN0eWxlZEljb25Qcm9wcz5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiAkeyh7IGRpcmVjdGlvbiB9KSA9PlxuICAgIGRpcmVjdGlvbiA9PT0gJ3ZlcnRpY2FsJyA/ICdjb2x1bW4nIDogJ3Jvdyd9O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuXG4gIHN2ZyB7XG4gICAgZmlsbDogJHsoeyBzZW50aW1lbnQsIHRoZW1lIH0pID0+IChzZW50aW1lbnQgPT09ICduZXV0cmFsJyA/IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJvcmRlcldlYWsgOiB0aGVtZS5jb2xvcnNbc2VudGltZW50XS5ib3JkZXIpfTtcbiAgfVxuYFxuXG50eXBlIEhvcml6b250YWxTZXBhcmF0b3JQcm9wcyA9IE9taXQ8U2VwYXJhdG9yUHJvcHMsICdjb2xvcicgfCAnc2VudGltZW50Jz4gJiB7XG4gIGhhc0ljb24/OiBib29sZWFuXG4gIHNlbnRpbWVudDogQ29sb3Jcbn1cblxuY29uc3QgU3R5bGVkSHIgPSBzdHlsZWQoJ2hyJywge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PlxuICAgICFbJ2RpcmVjdGlvbicsICd0aGlja25lc3MnLCAnaGFzSWNvbicsICdzZW50aW1lbnQnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPEhvcml6b250YWxTZXBhcmF0b3JQcm9wcz5gXG4gIG1hcmdpbjogMDtcbiAgYm9yZGVyOiAwO1xuICB3aWR0aDogJHsoeyBkaXJlY3Rpb24sIHRoaWNrbmVzcyA9IDEgfSkgPT5cbiAgICBkaXJlY3Rpb24gPT09ICd2ZXJ0aWNhbCcgPyBgJHt0aGlja25lc3N9cHhgIDogJ2F1dG8nfTtcbiAgaGVpZ2h0OiAkeyh7IGRpcmVjdGlvbiwgdGhpY2tuZXNzID0gMSB9KSA9PlxuICAgIGRpcmVjdGlvbiA9PT0gJ2hvcml6b250YWwnID8gYCR7dGhpY2tuZXNzfXB4YCA6ICdhdXRvJ307XG4gIGZsZXgtc2hyaW5rOiAwO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IHRoZW1lLCBzZW50aW1lbnQgfSkgPT5cbiAgICBzZW50aW1lbnQgPT09ICduZXV0cmFsJ1xuICAgICAgPyB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJXZWFrXG4gICAgICA6IHRoZW1lLmNvbG9yc1tzZW50aW1lbnRdLmJvcmRlcn07XG4gICR7KHsgaGFzSWNvbiB9KSA9PiBoYXNJY29uICYmIGBmbGV4OiAxO2B9XG5gXG5cbnR5cGUgU2VwYXJhdG9yUHJvcHMgPSB7XG4gIGRpcmVjdGlvbj86IERpcmVjdGlvblxuICB0aGlja25lc3M/OiBudW1iZXJcbiAgc2VudGltZW50PzogQ29sb3JcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gICdkYXRhLXRlc3RpZCc/OiBzdHJpbmdcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGVcbn1cblxuLyoqXG4gKiBTZXBhcmF0b3IgY29tcG9uZW50IHVzZWQgdG8gc2VwYXJhdGUgY29udGVudCB3aXRoIGEgaG9yaXpvbnRhbCBvciB2ZXJ0aWNhbCBsaW5lLlxuICovXG5leHBvcnQgY29uc3QgU2VwYXJhdG9yID0gKHtcbiAgZGlyZWN0aW9uID0gJ2hvcml6b250YWwnLFxuICB0aGlja25lc3MgPSAxLFxuICBzZW50aW1lbnQgPSAnbmV1dHJhbCcsXG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbiAgY2hpbGRyZW4sXG59OiBTZXBhcmF0b3JQcm9wcykgPT5cbiAgY2hpbGRyZW4gPyAoXG4gICAgPFN0eWxlZEljb25XcmFwcGVyXG4gICAgICByb2xlPVwic2VwYXJhdG9yXCJcbiAgICAgIGFyaWEtb3JpZW50YXRpb249e2RpcmVjdGlvbn1cbiAgICAgIGRpcmVjdGlvbj17ZGlyZWN0aW9ufVxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAgIHNlbnRpbWVudD17c2VudGltZW50fVxuICAgID5cbiAgICAgIDxTdHlsZWRIclxuICAgICAgICBkaXJlY3Rpb249e2RpcmVjdGlvbn1cbiAgICAgICAgdGhpY2tuZXNzPXt0aGlja25lc3N9XG4gICAgICAgIHNlbnRpbWVudD17c2VudGltZW50fVxuICAgICAgICBoYXNJY29uXG4gICAgICAvPlxuICAgICAge2NoaWxkcmVufVxuICAgICAgPFN0eWxlZEhyXG4gICAgICAgIGRpcmVjdGlvbj17ZGlyZWN0aW9ufVxuICAgICAgICB0aGlja25lc3M9e3RoaWNrbmVzc31cbiAgICAgICAgc2VudGltZW50PXtzZW50aW1lbnR9XG4gICAgICAgIGhhc0ljb25cbiAgICAgIC8+XG4gICAgPC9TdHlsZWRJY29uV3JhcHBlcj5cbiAgKSA6IChcbiAgICA8U3R5bGVkSHJcbiAgICAgIHJvbGU9XCJzZXBhcmF0b3JcIlxuICAgICAgYXJpYS1vcmllbnRhdGlvbj17ZGlyZWN0aW9ufVxuICAgICAgZGlyZWN0aW9uPXtkaXJlY3Rpb259XG4gICAgICB0aGlja25lc3M9e3RoaWNrbmVzc31cbiAgICAgIHNlbnRpbWVudD17c2VudGltZW50fVxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAvPlxuICApXG4iXX0= */"));
36
36
  const Separator = ({
37
37
  direction = "horizontal",
38
38
  thickness = 1,
39
- color = "neutral",
40
39
  sentiment = "neutral",
41
40
  className,
42
41
  "data-testid": dataTestId,
43
42
  children
44
- }) => children ? /* @__PURE__ */ jsxs(StyledIconWrapper, { role: "separator", "aria-orientation": direction, direction, className, "data-testid": dataTestId, sentiment, color, children: [
45
- /* @__PURE__ */ jsx(StyledHr, { direction, thickness, color, sentiment, hasIcon: true }),
43
+ }) => children ? /* @__PURE__ */ jsxs(StyledIconWrapper, { role: "separator", "aria-orientation": direction, direction, className, "data-testid": dataTestId, sentiment, children: [
44
+ /* @__PURE__ */ jsx(StyledHr, { direction, thickness, sentiment, hasIcon: true }),
46
45
  children,
47
- /* @__PURE__ */ jsx(StyledHr, { direction, thickness, color, sentiment, hasIcon: true })
48
- ] }) : /* @__PURE__ */ jsx(StyledHr, { role: "separator", "aria-orientation": direction, direction, thickness, color, sentiment, className, "data-testid": dataTestId });
46
+ /* @__PURE__ */ jsx(StyledHr, { direction, thickness, sentiment, hasIcon: true })
47
+ ] }) : /* @__PURE__ */ jsx(StyledHr, { role: "separator", "aria-orientation": direction, direction, thickness, sentiment, className, "data-testid": dataTestId });
49
48
  export {
50
49
  Separator
51
50
  };