@ultraviolet/ui 1.93.0 → 1.94.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -12,6 +12,18 @@ const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
12
12
  const PROMINENCES = {
13
13
  strong: "strong"
14
14
  };
15
+ const SIZES = {
16
+ xxsmall: "200",
17
+ xsmall: "250",
18
+ small: "300",
19
+ medium: "400"
20
+ };
21
+ const TEXT_VARIANT = {
22
+ xxsmall: "captionSmallStrong",
23
+ xsmall: "caption",
24
+ small: "bodySmall",
25
+ medium: "body"
26
+ };
15
27
  const sentimentStyles = ({
16
28
  theme,
17
29
  prominence
@@ -45,25 +57,25 @@ const StyledContainer = /* @__PURE__ */ _styled__default.default("div", process.
45
57
  } : {
46
58
  target: "e11loam60",
47
59
  label: "StyledContainer"
48
- })("display:inline-flex;border-radius:", ({
60
+ })("display:flex;border-radius:", ({
49
61
  theme
50
62
  }) => theme.radii.circle, ";justify-content:center;align-items:center;width:", ({
51
63
  size,
52
64
  theme
53
- }) => size === "medium" ? theme.sizing["400"] : theme.sizing["300"], ";height:", ({
65
+ }) => theme.sizing[SIZES[size]], ";height:", ({
54
66
  size,
55
67
  theme
56
- }) => size === "medium" ? theme.sizing["400"] : theme.sizing["300"], ";font-size:", ({
68
+ }) => theme.sizing[SIZES[size]], ";font-size:", ({
57
69
  size,
58
70
  theme
59
- }) => size === "medium" ? theme.typography.body.fontSize : theme.typography.bodySmall.fontSize, ";", ({
71
+ }) => theme.typography[TEXT_VARIANT[size]].fontSize, ";", ({
60
72
  theme,
61
73
  prominence,
62
74
  sentiment
63
75
  }) => sentimentStyles({
64
76
  theme,
65
77
  prominence
66
- })[sentiment], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0J1bGxldC9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEUwRCIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9CdWxsZXQvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCB0eXBlIHsgVGhlbWUgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCdcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC9pY29ucy9sZWdhY3knXG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFNFTlRJTUVOVFMsIFNFTlRJTUVOVFNfV0lUSE9VVF9ORVVUUkFMIH0gZnJvbSAnLi4vLi4vdGhlbWUnXG5pbXBvcnQgY2FwaXRhbGl6ZSBmcm9tICcuLi8uLi91dGlscy9jYXBpdGFsaXplJ1xuaW1wb3J0IHsgVG9vbHRpcCB9IGZyb20gJy4uL1Rvb2x0aXAnXG5cbmV4cG9ydCBjb25zdCBQUk9NSU5FTkNFUyA9IHtcbiAgZGVmYXVsdDogJ2RlZmF1bHQnLFxuICBzdHJvbmc6ICdzdHJvbmcnLFxufVxuXG50eXBlIFByb21pbmVuY2VUeXBlID0ga2V5b2YgdHlwZW9mIFBST01JTkVOQ0VTXG5jb25zdCBCVUxMRVRfU0VOVElNRU5UUyA9IFsuLi5TRU5USU1FTlRTLCAnZGlzYWJsZWQnXVxuXG50eXBlIEJ1bGxldFNlbnRpbWVudCA9ICh0eXBlb2YgQlVMTEVUX1NFTlRJTUVOVFMpW251bWJlcl1cblxudHlwZSBCdWxsZXRTaXplID0gJ21lZGl1bScgfCAnc21hbGwnXG5cbmNvbnN0IHNlbnRpbWVudFN0eWxlcyA9ICh7XG4gIHRoZW1lLFxuICBwcm9taW5lbmNlLFxufToge1xuICB0aGVtZTogVGhlbWVcbiAgcHJvbWluZW5jZTogUHJvbWluZW5jZVR5cGVcbn0pID0+IHtcbiAgY29uc3QgZGVmaW5lZFByb21pbmVuY2UgPVxuICAgIHByb21pbmVuY2UgPT09IFBST01JTkVOQ0VTLnN0cm9uZyA/IGNhcGl0YWxpemUoUFJPTUlORU5DRVMuc3Ryb25nKSA6ICcnXG5cbiAgY29uc3QgdGV4dCA9IGB0ZXh0JHtkZWZpbmVkUHJvbWluZW5jZX1gXG4gIGNvbnN0IGJhY2tncm91bmQgPSBgYmFja2dyb3VuZCR7ZGVmaW5lZFByb21pbmVuY2V9YFxuXG4gIHJldHVybiB7XG4gICAgLi4uU0VOVElNRU5UU19XSVRIT1VUX05FVVRSQUwucmVkdWNlKFxuICAgICAgKHJlZHVjZXIsIHNlbnRpbWVudCkgPT4gKHtcbiAgICAgICAgLi4ucmVkdWNlcixcbiAgICAgICAgW3NlbnRpbWVudF06IGBcbiAgICAgIGNvbG9yOiAke1xuICAgICAgICB0aGVtZS5jb2xvcnNbc2VudGltZW50XVt0ZXh0IGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMucHJpbWFyeV1cbiAgICAgIH07XG4gICAgICBiYWNrZ3JvdW5kOiAke1xuICAgICAgICB0aGVtZS5jb2xvcnNbc2VudGltZW50XVtiYWNrZ3JvdW5kIGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMucHJpbWFyeV1cbiAgICAgIH07XG4gICAgICBib3JkZXI6IDFweCBzb2xpZCAke1xuICAgICAgICB0aGVtZS5jb2xvcnNbc2VudGltZW50XVtiYWNrZ3JvdW5kIGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMucHJpbWFyeV1cbiAgICAgIH07XG4gICAgYCxcbiAgICAgIH0pLFxuICAgICAge30sXG4gICAgKSxcbiAgICBuZXV0cmFsOiBgXG4gICAgICBjb2xvcjogJHtcbiAgICAgICAgcHJvbWluZW5jZSA9PT0gUFJPTUlORU5DRVMuc3Ryb25nXG4gICAgICAgICAgPyB0aGVtZS5jb2xvcnMubmV1dHJhbFt0ZXh0IGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMubmV1dHJhbF1cbiAgICAgICAgICA6IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHRcbiAgICAgIH07XG4gICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5uZXV0cmFsLmJhY2tncm91bmR9O1xuICAgICAgYm9yZGVyOiAxcHggc29saWQgJHt0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJ9O1xuICAgIGAsXG4gICAgZGlzYWJsZWQ6IGBcbiAgICAgIGNvbG9yOiAke3RoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHRXZWFrfTtcbiAgICAgIGJhY2tncm91bmQ6ICR7dGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZFN0cm9uZ307XG4gICAgICBib3JkZXI6IG5vbmU7XG4gICAgYCxcbiAgfVxufVxuXG50eXBlIFN0eWxlZENvbnRhaW5lclR5cGUgPSB7XG4gIHNlbnRpbWVudDogQnVsbGV0U2VudGltZW50XG4gIHNpemU6IEJ1bGxldFNpemVcbiAgcHJvbWluZW5jZTogUHJvbWluZW5jZVR5cGVcbn1cblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkKCdkaXYnKTxTdHlsZWRDb250YWluZXJUeXBlPmBcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGJvcmRlci1yYWRpdXM6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuY2lyY2xlfTtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHdpZHRoOiAkeyh7IHNpemUsIHRoZW1lIH0pID0+IChzaXplID09PSAnbWVkaXVtJyA/IHRoZW1lLnNpemluZ1snNDAwJ10gOiB0aGVtZS5zaXppbmdbJzMwMCddKX07XG4gIGhlaWdodDogJHsoeyBzaXplLCB0aGVtZSB9KSA9PiAoc2l6ZSA9PT0gJ21lZGl1bScgPyB0aGVtZS5zaXppbmdbJzQwMCddIDogdGhlbWUuc2l6aW5nWyczMDAnXSl9O1xuICBmb250LXNpemU6ICR7KHsgc2l6ZSwgdGhlbWUgfSkgPT4gKHNpemUgPT09ICdtZWRpdW0nID8gdGhlbWUudHlwb2dyYXBoeS5ib2R5LmZvbnRTaXplIDogdGhlbWUudHlwb2dyYXBoeS5ib2R5U21hbGwuZm9udFNpemUpfTtcbiAgJHsoeyB0aGVtZSwgcHJvbWluZW5jZSwgc2VudGltZW50IH0pID0+XG4gICAgKHNlbnRpbWVudFN0eWxlcyh7IHRoZW1lLCBwcm9taW5lbmNlIH0pIGFzIFJlY29yZDxCdWxsZXRTZW50aW1lbnQsIHN0cmluZz4pW1xuICAgICAgc2VudGltZW50XG4gICAgXX07XG5gXG5cbnR5cGUgQnVsbGV0UHJvcHMgPSB7XG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBzaXplPzogQnVsbGV0U2l6ZVxuICB0b29sdGlwPzogc3RyaW5nXG4gIHRvb2x0aXBCYXNlSWQ/OiBzdHJpbmdcbiAgc2VudGltZW50PzogQnVsbGV0U2VudGltZW50XG4gICdkYXRhLXRlc3RpZCc/OiBzdHJpbmdcbiAgcHJvbWluZW5jZT86IFByb21pbmVuY2VUeXBlXG4gIGNoaWxkcmVuPzogUmVhY3ROb2RlXG4gIC8qKlxuICAgKiBAZGVwcmVjYXRlZCBBZGQgdGhlIGljb24gZGlyZWN0bHkgaW50byB0aGUgY2hpbGRyZW5cbiAgICovXG4gIGljb24/OiBDb21wb25lbnRQcm9wczx0eXBlb2YgSWNvbj5bJ25hbWUnXVxuICAvKipcbiAgICogQGRlcHJlY2F0ZWQgQWRkIHRoZSBpY29uIGRpcmVjdGx5IGludG8gdGhlIGNoaWxkcmVuXG4gICAqL1xuICBpY29uVmFyaWFudD86IENvbXBvbmVudFByb3BzPHR5cGVvZiBJY29uPlsndmFyaWFudCddXG4gIC8qKlxuICAgKiBAZGVwcmVjYXRlZCBBZGQgdGhlIHRleHQgZGlyZWN0bHkgaW50byB0aGUgY2hpbGRyZW5cbiAgICovXG4gIHRleHQ/OiBzdHJpbmdcbn1cblxuLyoqXG4gKiBCdWxsZXQgY29tcG9uZW50IGlzIHVzZWQgdG8gZGlzcGxheSBhIHNtYWxsIGljb24gb3IgdGV4dCB3aXRoIGEgY29sb3JlZCBiYWNrZ3JvdW5kIGluIGEgY2lyY2xlLlxuICovXG5leHBvcnQgY29uc3QgQnVsbGV0ID0gKHtcbiAgY2xhc3NOYW1lLFxuICBzZW50aW1lbnQgPSAnbmV1dHJhbCcsXG4gIHNpemUgPSAnbWVkaXVtJyxcbiAgaWNvbixcbiAgaWNvblZhcmlhbnQsXG4gIHRleHQsXG4gIHRvb2x0aXAsXG4gIHRvb2x0aXBCYXNlSWQsXG4gICdkYXRhLXRlc3RpZCc6IGRhdGFUZXN0SWQsXG4gIHByb21pbmVuY2UgPSAnZGVmYXVsdCcsXG4gIGNoaWxkcmVuLFxufTogQnVsbGV0UHJvcHMpID0+IChcbiAgPFRvb2x0aXAgaWQ9e3Rvb2x0aXBCYXNlSWR9IHRleHQ9e3Rvb2x0aXB9PlxuICAgIDxTdHlsZWRDb250YWluZXJcbiAgICAgIHNlbnRpbWVudD17c2VudGltZW50fVxuICAgICAgc2l6ZT17c2l6ZX1cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICBwcm9taW5lbmNlPXtwcm9taW5lbmNlfVxuICAgID5cbiAgICAgIHtpY29uID8gPEljb24gbmFtZT17aWNvbn0gc2l6ZT1cInNtYWxsXCIgdmFyaWFudD17aWNvblZhcmlhbnR9IC8+IDogdGV4dH1cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgPC9Ub29sdGlwPlxuKVxuIl19 */"));
78
+ })[sentiment], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0J1bGxldC9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUYwRCIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9CdWxsZXQvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCB0eXBlIHsgVGhlbWUgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCdcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC9pY29ucy9sZWdhY3knXG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFNFTlRJTUVOVFMsIFNFTlRJTUVOVFNfV0lUSE9VVF9ORVVUUkFMIH0gZnJvbSAnLi4vLi4vdGhlbWUnXG5pbXBvcnQgY2FwaXRhbGl6ZSBmcm9tICcuLi8uLi91dGlscy9jYXBpdGFsaXplJ1xuaW1wb3J0IHsgVG9vbHRpcCB9IGZyb20gJy4uL1Rvb2x0aXAnXG5cbmV4cG9ydCBjb25zdCBQUk9NSU5FTkNFUyA9IHtcbiAgZGVmYXVsdDogJ2RlZmF1bHQnLFxuICBzdHJvbmc6ICdzdHJvbmcnLFxufVxuXG50eXBlIFByb21pbmVuY2VUeXBlID0ga2V5b2YgdHlwZW9mIFBST01JTkVOQ0VTXG5jb25zdCBCVUxMRVRfU0VOVElNRU5UUyA9IFsuLi5TRU5USU1FTlRTLCAnZGlzYWJsZWQnXVxuXG50eXBlIEJ1bGxldFNlbnRpbWVudCA9ICh0eXBlb2YgQlVMTEVUX1NFTlRJTUVOVFMpW251bWJlcl1cblxuLy8gVmFsdWVzIGFyZSB0aGVuIHVzZWQgYXMgdGhlbWUuc2l6aW5nW1hdXG5jb25zdCBTSVpFUyA9IHtcbiAgeHhzbWFsbDogJzIwMCcsXG4gIHhzbWFsbDogJzI1MCcsXG4gIHNtYWxsOiAnMzAwJyxcbiAgbWVkaXVtOiAnNDAwJyxcbn0gYXMgY29uc3RcblxuY29uc3QgVEVYVF9WQVJJQU5UID0ge1xuICB4eHNtYWxsOiAnY2FwdGlvblNtYWxsU3Ryb25nJyxcbiAgeHNtYWxsOiAnY2FwdGlvbicsXG4gIHNtYWxsOiAnYm9keVNtYWxsJyxcbiAgbWVkaXVtOiAnYm9keScsXG59IGFzIGNvbnN0XG5cbmNvbnN0IHNlbnRpbWVudFN0eWxlcyA9ICh7XG4gIHRoZW1lLFxuICBwcm9taW5lbmNlLFxufToge1xuICB0aGVtZTogVGhlbWVcbiAgcHJvbWluZW5jZTogUHJvbWluZW5jZVR5cGVcbn0pID0+IHtcbiAgY29uc3QgZGVmaW5lZFByb21pbmVuY2UgPVxuICAgIHByb21pbmVuY2UgPT09IFBST01JTkVOQ0VTLnN0cm9uZyA/IGNhcGl0YWxpemUoUFJPTUlORU5DRVMuc3Ryb25nKSA6ICcnXG5cbiAgY29uc3QgdGV4dCA9IGB0ZXh0JHtkZWZpbmVkUHJvbWluZW5jZX1gXG4gIGNvbnN0IGJhY2tncm91bmQgPSBgYmFja2dyb3VuZCR7ZGVmaW5lZFByb21pbmVuY2V9YFxuXG4gIHJldHVybiB7XG4gICAgLi4uU0VOVElNRU5UU19XSVRIT1VUX05FVVRSQUwucmVkdWNlKFxuICAgICAgKHJlZHVjZXIsIHNlbnRpbWVudCkgPT4gKHtcbiAgICAgICAgLi4ucmVkdWNlcixcbiAgICAgICAgW3NlbnRpbWVudF06IGBcbiAgICAgIGNvbG9yOiAke1xuICAgICAgICB0aGVtZS5jb2xvcnNbc2VudGltZW50XVt0ZXh0IGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMucHJpbWFyeV1cbiAgICAgIH07XG4gICAgICBiYWNrZ3JvdW5kOiAke1xuICAgICAgICB0aGVtZS5jb2xvcnNbc2VudGltZW50XVtiYWNrZ3JvdW5kIGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMucHJpbWFyeV1cbiAgICAgIH07XG4gICAgICBib3JkZXI6IDFweCBzb2xpZCAke1xuICAgICAgICB0aGVtZS5jb2xvcnNbc2VudGltZW50XVtiYWNrZ3JvdW5kIGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMucHJpbWFyeV1cbiAgICAgIH07XG4gICAgYCxcbiAgICAgIH0pLFxuICAgICAge30sXG4gICAgKSxcbiAgICBuZXV0cmFsOiBgXG4gICAgICBjb2xvcjogJHtcbiAgICAgICAgcHJvbWluZW5jZSA9PT0gUFJPTUlORU5DRVMuc3Ryb25nXG4gICAgICAgICAgPyB0aGVtZS5jb2xvcnMubmV1dHJhbFt0ZXh0IGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMubmV1dHJhbF1cbiAgICAgICAgICA6IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHRcbiAgICAgIH07XG4gICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5uZXV0cmFsLmJhY2tncm91bmR9O1xuICAgICAgYm9yZGVyOiAxcHggc29saWQgJHt0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJ9O1xuICAgIGAsXG4gICAgZGlzYWJsZWQ6IGBcbiAgICAgIGNvbG9yOiAke3RoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHRXZWFrfTtcbiAgICAgIGJhY2tncm91bmQ6ICR7dGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZFN0cm9uZ307XG4gICAgICBib3JkZXI6IG5vbmU7XG4gICAgYCxcbiAgfVxufVxuXG50eXBlIFN0eWxlZENvbnRhaW5lclR5cGUgPSB7XG4gIHNlbnRpbWVudDogQnVsbGV0U2VudGltZW50XG4gIHNpemU6IGtleW9mIHR5cGVvZiBTSVpFU1xuICBwcm9taW5lbmNlOiBQcm9taW5lbmNlVHlwZVxufVxuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQoJ2RpdicpPFN0eWxlZENvbnRhaW5lclR5cGU+YFxuICBkaXNwbGF5OiBmbGV4O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmNpcmNsZX07XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICB3aWR0aDogJHsoeyBzaXplLCB0aGVtZSB9KSA9PiB0aGVtZS5zaXppbmdbU0laRVNbc2l6ZV1dfTtcbiAgaGVpZ2h0OiAkeyh7IHNpemUsIHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1tTSVpFU1tzaXplXV19O1xuICBmb250LXNpemU6ICR7KHsgc2l6ZSwgdGhlbWUgfSkgPT4gdGhlbWUudHlwb2dyYXBoeVtURVhUX1ZBUklBTlRbc2l6ZV1dLmZvbnRTaXplfTtcbiAgJHsoeyB0aGVtZSwgcHJvbWluZW5jZSwgc2VudGltZW50IH0pID0+XG4gICAgKHNlbnRpbWVudFN0eWxlcyh7IHRoZW1lLCBwcm9taW5lbmNlIH0pIGFzIFJlY29yZDxCdWxsZXRTZW50aW1lbnQsIHN0cmluZz4pW1xuICAgICAgc2VudGltZW50XG4gICAgXX07XG5gXG5cbnR5cGUgQnVsbGV0UHJvcHMgPSB7XG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBzaXplPzoga2V5b2YgdHlwZW9mIFNJWkVTXG4gIHRvb2x0aXA/OiBzdHJpbmdcbiAgdG9vbHRpcEJhc2VJZD86IHN0cmluZ1xuICBzZW50aW1lbnQ/OiBCdWxsZXRTZW50aW1lbnRcbiAgJ2RhdGEtdGVzdGlkJz86IHN0cmluZ1xuICBwcm9taW5lbmNlPzogUHJvbWluZW5jZVR5cGVcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGVcbiAgLyoqXG4gICAqIEBkZXByZWNhdGVkIEFkZCB0aGUgaWNvbiBkaXJlY3RseSBpbnRvIHRoZSBjaGlsZHJlblxuICAgKi9cbiAgaWNvbj86IENvbXBvbmVudFByb3BzPHR5cGVvZiBJY29uPlsnbmFtZSddXG4gIC8qKlxuICAgKiBAZGVwcmVjYXRlZCBBZGQgdGhlIGljb24gZGlyZWN0bHkgaW50byB0aGUgY2hpbGRyZW5cbiAgICovXG4gIGljb25WYXJpYW50PzogQ29tcG9uZW50UHJvcHM8dHlwZW9mIEljb24+Wyd2YXJpYW50J11cbiAgLyoqXG4gICAqIEBkZXByZWNhdGVkIEFkZCB0aGUgdGV4dCBkaXJlY3RseSBpbnRvIHRoZSBjaGlsZHJlblxuICAgKi9cbiAgdGV4dD86IHN0cmluZ1xufVxuXG4vKipcbiAqIEJ1bGxldCBjb21wb25lbnQgaXMgdXNlZCB0byBkaXNwbGF5IGEgc21hbGwgaWNvbiBvciB0ZXh0IHdpdGggYSBjb2xvcmVkIGJhY2tncm91bmQgaW4gYSBjaXJjbGUuXG4gKi9cbmV4cG9ydCBjb25zdCBCdWxsZXQgPSAoe1xuICBjbGFzc05hbWUsXG4gIHNlbnRpbWVudCA9ICduZXV0cmFsJyxcbiAgc2l6ZSA9ICdtZWRpdW0nLFxuICBpY29uLFxuICBpY29uVmFyaWFudCxcbiAgdGV4dCxcbiAgdG9vbHRpcCxcbiAgdG9vbHRpcEJhc2VJZCxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbiAgcHJvbWluZW5jZSA9ICdkZWZhdWx0JyxcbiAgY2hpbGRyZW4sXG59OiBCdWxsZXRQcm9wcykgPT4gKFxuICA8VG9vbHRpcCBpZD17dG9vbHRpcEJhc2VJZH0gdGV4dD17dG9vbHRpcH0+XG4gICAgPFN0eWxlZENvbnRhaW5lclxuICAgICAgc2VudGltZW50PXtzZW50aW1lbnR9XG4gICAgICBzaXplPXtzaXplfVxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAgIHByb21pbmVuY2U9e3Byb21pbmVuY2V9XG4gICAgPlxuICAgICAge2ljb24gPyA8SWNvbiBuYW1lPXtpY29ufSBzaXplPVwic21hbGxcIiB2YXJpYW50PXtpY29uVmFyaWFudH0gLz4gOiB0ZXh0fVxuICAgICAge2NoaWxkcmVufVxuICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICA8L1Rvb2x0aXA+XG4pXG4iXX0= */"));
67
79
  const Bullet = ({
68
80
  className,
69
81
  sentiment = "neutral",
@@ -7,10 +7,15 @@ export declare const PROMINENCES: {
7
7
  type ProminenceType = keyof typeof PROMINENCES;
8
8
  declare const BULLET_SENTIMENTS: string[];
9
9
  type BulletSentiment = (typeof BULLET_SENTIMENTS)[number];
10
- type BulletSize = 'medium' | 'small';
10
+ declare const SIZES: {
11
+ readonly xxsmall: "200";
12
+ readonly xsmall: "250";
13
+ readonly small: "300";
14
+ readonly medium: "400";
15
+ };
11
16
  type BulletProps = {
12
17
  className?: string;
13
- size?: BulletSize;
18
+ size?: keyof typeof SIZES;
14
19
  tooltip?: string;
15
20
  tooltipBaseId?: string;
16
21
  sentiment?: BulletSentiment;
@@ -8,6 +8,18 @@ import { Tooltip } from "../Tooltip/index.js";
8
8
  const PROMINENCES = {
9
9
  strong: "strong"
10
10
  };
11
+ const SIZES = {
12
+ xxsmall: "200",
13
+ xsmall: "250",
14
+ small: "300",
15
+ medium: "400"
16
+ };
17
+ const TEXT_VARIANT = {
18
+ xxsmall: "captionSmallStrong",
19
+ xsmall: "caption",
20
+ small: "bodySmall",
21
+ medium: "body"
22
+ };
11
23
  const sentimentStyles = ({
12
24
  theme,
13
25
  prominence
@@ -41,25 +53,25 @@ const StyledContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV ===
41
53
  } : {
42
54
  target: "e11loam60",
43
55
  label: "StyledContainer"
44
- })("display:inline-flex;border-radius:", ({
56
+ })("display:flex;border-radius:", ({
45
57
  theme
46
58
  }) => theme.radii.circle, ";justify-content:center;align-items:center;width:", ({
47
59
  size,
48
60
  theme
49
- }) => size === "medium" ? theme.sizing["400"] : theme.sizing["300"], ";height:", ({
61
+ }) => theme.sizing[SIZES[size]], ";height:", ({
50
62
  size,
51
63
  theme
52
- }) => size === "medium" ? theme.sizing["400"] : theme.sizing["300"], ";font-size:", ({
64
+ }) => theme.sizing[SIZES[size]], ";font-size:", ({
53
65
  size,
54
66
  theme
55
- }) => size === "medium" ? theme.typography.body.fontSize : theme.typography.bodySmall.fontSize, ";", ({
67
+ }) => theme.typography[TEXT_VARIANT[size]].fontSize, ";", ({
56
68
  theme,
57
69
  prominence,
58
70
  sentiment
59
71
  }) => sentimentStyles({
60
72
  theme,
61
73
  prominence
62
- })[sentiment], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0J1bGxldC9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEUwRCIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9CdWxsZXQvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCB0eXBlIHsgVGhlbWUgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCdcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC9pY29ucy9sZWdhY3knXG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFNFTlRJTUVOVFMsIFNFTlRJTUVOVFNfV0lUSE9VVF9ORVVUUkFMIH0gZnJvbSAnLi4vLi4vdGhlbWUnXG5pbXBvcnQgY2FwaXRhbGl6ZSBmcm9tICcuLi8uLi91dGlscy9jYXBpdGFsaXplJ1xuaW1wb3J0IHsgVG9vbHRpcCB9IGZyb20gJy4uL1Rvb2x0aXAnXG5cbmV4cG9ydCBjb25zdCBQUk9NSU5FTkNFUyA9IHtcbiAgZGVmYXVsdDogJ2RlZmF1bHQnLFxuICBzdHJvbmc6ICdzdHJvbmcnLFxufVxuXG50eXBlIFByb21pbmVuY2VUeXBlID0ga2V5b2YgdHlwZW9mIFBST01JTkVOQ0VTXG5jb25zdCBCVUxMRVRfU0VOVElNRU5UUyA9IFsuLi5TRU5USU1FTlRTLCAnZGlzYWJsZWQnXVxuXG50eXBlIEJ1bGxldFNlbnRpbWVudCA9ICh0eXBlb2YgQlVMTEVUX1NFTlRJTUVOVFMpW251bWJlcl1cblxudHlwZSBCdWxsZXRTaXplID0gJ21lZGl1bScgfCAnc21hbGwnXG5cbmNvbnN0IHNlbnRpbWVudFN0eWxlcyA9ICh7XG4gIHRoZW1lLFxuICBwcm9taW5lbmNlLFxufToge1xuICB0aGVtZTogVGhlbWVcbiAgcHJvbWluZW5jZTogUHJvbWluZW5jZVR5cGVcbn0pID0+IHtcbiAgY29uc3QgZGVmaW5lZFByb21pbmVuY2UgPVxuICAgIHByb21pbmVuY2UgPT09IFBST01JTkVOQ0VTLnN0cm9uZyA/IGNhcGl0YWxpemUoUFJPTUlORU5DRVMuc3Ryb25nKSA6ICcnXG5cbiAgY29uc3QgdGV4dCA9IGB0ZXh0JHtkZWZpbmVkUHJvbWluZW5jZX1gXG4gIGNvbnN0IGJhY2tncm91bmQgPSBgYmFja2dyb3VuZCR7ZGVmaW5lZFByb21pbmVuY2V9YFxuXG4gIHJldHVybiB7XG4gICAgLi4uU0VOVElNRU5UU19XSVRIT1VUX05FVVRSQUwucmVkdWNlKFxuICAgICAgKHJlZHVjZXIsIHNlbnRpbWVudCkgPT4gKHtcbiAgICAgICAgLi4ucmVkdWNlcixcbiAgICAgICAgW3NlbnRpbWVudF06IGBcbiAgICAgIGNvbG9yOiAke1xuICAgICAgICB0aGVtZS5jb2xvcnNbc2VudGltZW50XVt0ZXh0IGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMucHJpbWFyeV1cbiAgICAgIH07XG4gICAgICBiYWNrZ3JvdW5kOiAke1xuICAgICAgICB0aGVtZS5jb2xvcnNbc2VudGltZW50XVtiYWNrZ3JvdW5kIGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMucHJpbWFyeV1cbiAgICAgIH07XG4gICAgICBib3JkZXI6IDFweCBzb2xpZCAke1xuICAgICAgICB0aGVtZS5jb2xvcnNbc2VudGltZW50XVtiYWNrZ3JvdW5kIGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMucHJpbWFyeV1cbiAgICAgIH07XG4gICAgYCxcbiAgICAgIH0pLFxuICAgICAge30sXG4gICAgKSxcbiAgICBuZXV0cmFsOiBgXG4gICAgICBjb2xvcjogJHtcbiAgICAgICAgcHJvbWluZW5jZSA9PT0gUFJPTUlORU5DRVMuc3Ryb25nXG4gICAgICAgICAgPyB0aGVtZS5jb2xvcnMubmV1dHJhbFt0ZXh0IGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMubmV1dHJhbF1cbiAgICAgICAgICA6IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHRcbiAgICAgIH07XG4gICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5uZXV0cmFsLmJhY2tncm91bmR9O1xuICAgICAgYm9yZGVyOiAxcHggc29saWQgJHt0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJ9O1xuICAgIGAsXG4gICAgZGlzYWJsZWQ6IGBcbiAgICAgIGNvbG9yOiAke3RoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHRXZWFrfTtcbiAgICAgIGJhY2tncm91bmQ6ICR7dGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZFN0cm9uZ307XG4gICAgICBib3JkZXI6IG5vbmU7XG4gICAgYCxcbiAgfVxufVxuXG50eXBlIFN0eWxlZENvbnRhaW5lclR5cGUgPSB7XG4gIHNlbnRpbWVudDogQnVsbGV0U2VudGltZW50XG4gIHNpemU6IEJ1bGxldFNpemVcbiAgcHJvbWluZW5jZTogUHJvbWluZW5jZVR5cGVcbn1cblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkKCdkaXYnKTxTdHlsZWRDb250YWluZXJUeXBlPmBcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGJvcmRlci1yYWRpdXM6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuY2lyY2xlfTtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHdpZHRoOiAkeyh7IHNpemUsIHRoZW1lIH0pID0+IChzaXplID09PSAnbWVkaXVtJyA/IHRoZW1lLnNpemluZ1snNDAwJ10gOiB0aGVtZS5zaXppbmdbJzMwMCddKX07XG4gIGhlaWdodDogJHsoeyBzaXplLCB0aGVtZSB9KSA9PiAoc2l6ZSA9PT0gJ21lZGl1bScgPyB0aGVtZS5zaXppbmdbJzQwMCddIDogdGhlbWUuc2l6aW5nWyczMDAnXSl9O1xuICBmb250LXNpemU6ICR7KHsgc2l6ZSwgdGhlbWUgfSkgPT4gKHNpemUgPT09ICdtZWRpdW0nID8gdGhlbWUudHlwb2dyYXBoeS5ib2R5LmZvbnRTaXplIDogdGhlbWUudHlwb2dyYXBoeS5ib2R5U21hbGwuZm9udFNpemUpfTtcbiAgJHsoeyB0aGVtZSwgcHJvbWluZW5jZSwgc2VudGltZW50IH0pID0+XG4gICAgKHNlbnRpbWVudFN0eWxlcyh7IHRoZW1lLCBwcm9taW5lbmNlIH0pIGFzIFJlY29yZDxCdWxsZXRTZW50aW1lbnQsIHN0cmluZz4pW1xuICAgICAgc2VudGltZW50XG4gICAgXX07XG5gXG5cbnR5cGUgQnVsbGV0UHJvcHMgPSB7XG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBzaXplPzogQnVsbGV0U2l6ZVxuICB0b29sdGlwPzogc3RyaW5nXG4gIHRvb2x0aXBCYXNlSWQ/OiBzdHJpbmdcbiAgc2VudGltZW50PzogQnVsbGV0U2VudGltZW50XG4gICdkYXRhLXRlc3RpZCc/OiBzdHJpbmdcbiAgcHJvbWluZW5jZT86IFByb21pbmVuY2VUeXBlXG4gIGNoaWxkcmVuPzogUmVhY3ROb2RlXG4gIC8qKlxuICAgKiBAZGVwcmVjYXRlZCBBZGQgdGhlIGljb24gZGlyZWN0bHkgaW50byB0aGUgY2hpbGRyZW5cbiAgICovXG4gIGljb24/OiBDb21wb25lbnRQcm9wczx0eXBlb2YgSWNvbj5bJ25hbWUnXVxuICAvKipcbiAgICogQGRlcHJlY2F0ZWQgQWRkIHRoZSBpY29uIGRpcmVjdGx5IGludG8gdGhlIGNoaWxkcmVuXG4gICAqL1xuICBpY29uVmFyaWFudD86IENvbXBvbmVudFByb3BzPHR5cGVvZiBJY29uPlsndmFyaWFudCddXG4gIC8qKlxuICAgKiBAZGVwcmVjYXRlZCBBZGQgdGhlIHRleHQgZGlyZWN0bHkgaW50byB0aGUgY2hpbGRyZW5cbiAgICovXG4gIHRleHQ/OiBzdHJpbmdcbn1cblxuLyoqXG4gKiBCdWxsZXQgY29tcG9uZW50IGlzIHVzZWQgdG8gZGlzcGxheSBhIHNtYWxsIGljb24gb3IgdGV4dCB3aXRoIGEgY29sb3JlZCBiYWNrZ3JvdW5kIGluIGEgY2lyY2xlLlxuICovXG5leHBvcnQgY29uc3QgQnVsbGV0ID0gKHtcbiAgY2xhc3NOYW1lLFxuICBzZW50aW1lbnQgPSAnbmV1dHJhbCcsXG4gIHNpemUgPSAnbWVkaXVtJyxcbiAgaWNvbixcbiAgaWNvblZhcmlhbnQsXG4gIHRleHQsXG4gIHRvb2x0aXAsXG4gIHRvb2x0aXBCYXNlSWQsXG4gICdkYXRhLXRlc3RpZCc6IGRhdGFUZXN0SWQsXG4gIHByb21pbmVuY2UgPSAnZGVmYXVsdCcsXG4gIGNoaWxkcmVuLFxufTogQnVsbGV0UHJvcHMpID0+IChcbiAgPFRvb2x0aXAgaWQ9e3Rvb2x0aXBCYXNlSWR9IHRleHQ9e3Rvb2x0aXB9PlxuICAgIDxTdHlsZWRDb250YWluZXJcbiAgICAgIHNlbnRpbWVudD17c2VudGltZW50fVxuICAgICAgc2l6ZT17c2l6ZX1cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICBwcm9taW5lbmNlPXtwcm9taW5lbmNlfVxuICAgID5cbiAgICAgIHtpY29uID8gPEljb24gbmFtZT17aWNvbn0gc2l6ZT1cInNtYWxsXCIgdmFyaWFudD17aWNvblZhcmlhbnR9IC8+IDogdGV4dH1cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgPC9Ub29sdGlwPlxuKVxuIl19 */"));
74
+ })[sentiment], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0J1bGxldC9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUYwRCIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9CdWxsZXQvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCB0eXBlIHsgVGhlbWUgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCdcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC9pY29ucy9sZWdhY3knXG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFNFTlRJTUVOVFMsIFNFTlRJTUVOVFNfV0lUSE9VVF9ORVVUUkFMIH0gZnJvbSAnLi4vLi4vdGhlbWUnXG5pbXBvcnQgY2FwaXRhbGl6ZSBmcm9tICcuLi8uLi91dGlscy9jYXBpdGFsaXplJ1xuaW1wb3J0IHsgVG9vbHRpcCB9IGZyb20gJy4uL1Rvb2x0aXAnXG5cbmV4cG9ydCBjb25zdCBQUk9NSU5FTkNFUyA9IHtcbiAgZGVmYXVsdDogJ2RlZmF1bHQnLFxuICBzdHJvbmc6ICdzdHJvbmcnLFxufVxuXG50eXBlIFByb21pbmVuY2VUeXBlID0ga2V5b2YgdHlwZW9mIFBST01JTkVOQ0VTXG5jb25zdCBCVUxMRVRfU0VOVElNRU5UUyA9IFsuLi5TRU5USU1FTlRTLCAnZGlzYWJsZWQnXVxuXG50eXBlIEJ1bGxldFNlbnRpbWVudCA9ICh0eXBlb2YgQlVMTEVUX1NFTlRJTUVOVFMpW251bWJlcl1cblxuLy8gVmFsdWVzIGFyZSB0aGVuIHVzZWQgYXMgdGhlbWUuc2l6aW5nW1hdXG5jb25zdCBTSVpFUyA9IHtcbiAgeHhzbWFsbDogJzIwMCcsXG4gIHhzbWFsbDogJzI1MCcsXG4gIHNtYWxsOiAnMzAwJyxcbiAgbWVkaXVtOiAnNDAwJyxcbn0gYXMgY29uc3RcblxuY29uc3QgVEVYVF9WQVJJQU5UID0ge1xuICB4eHNtYWxsOiAnY2FwdGlvblNtYWxsU3Ryb25nJyxcbiAgeHNtYWxsOiAnY2FwdGlvbicsXG4gIHNtYWxsOiAnYm9keVNtYWxsJyxcbiAgbWVkaXVtOiAnYm9keScsXG59IGFzIGNvbnN0XG5cbmNvbnN0IHNlbnRpbWVudFN0eWxlcyA9ICh7XG4gIHRoZW1lLFxuICBwcm9taW5lbmNlLFxufToge1xuICB0aGVtZTogVGhlbWVcbiAgcHJvbWluZW5jZTogUHJvbWluZW5jZVR5cGVcbn0pID0+IHtcbiAgY29uc3QgZGVmaW5lZFByb21pbmVuY2UgPVxuICAgIHByb21pbmVuY2UgPT09IFBST01JTkVOQ0VTLnN0cm9uZyA/IGNhcGl0YWxpemUoUFJPTUlORU5DRVMuc3Ryb25nKSA6ICcnXG5cbiAgY29uc3QgdGV4dCA9IGB0ZXh0JHtkZWZpbmVkUHJvbWluZW5jZX1gXG4gIGNvbnN0IGJhY2tncm91bmQgPSBgYmFja2dyb3VuZCR7ZGVmaW5lZFByb21pbmVuY2V9YFxuXG4gIHJldHVybiB7XG4gICAgLi4uU0VOVElNRU5UU19XSVRIT1VUX05FVVRSQUwucmVkdWNlKFxuICAgICAgKHJlZHVjZXIsIHNlbnRpbWVudCkgPT4gKHtcbiAgICAgICAgLi4ucmVkdWNlcixcbiAgICAgICAgW3NlbnRpbWVudF06IGBcbiAgICAgIGNvbG9yOiAke1xuICAgICAgICB0aGVtZS5jb2xvcnNbc2VudGltZW50XVt0ZXh0IGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMucHJpbWFyeV1cbiAgICAgIH07XG4gICAgICBiYWNrZ3JvdW5kOiAke1xuICAgICAgICB0aGVtZS5jb2xvcnNbc2VudGltZW50XVtiYWNrZ3JvdW5kIGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMucHJpbWFyeV1cbiAgICAgIH07XG4gICAgICBib3JkZXI6IDFweCBzb2xpZCAke1xuICAgICAgICB0aGVtZS5jb2xvcnNbc2VudGltZW50XVtiYWNrZ3JvdW5kIGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMucHJpbWFyeV1cbiAgICAgIH07XG4gICAgYCxcbiAgICAgIH0pLFxuICAgICAge30sXG4gICAgKSxcbiAgICBuZXV0cmFsOiBgXG4gICAgICBjb2xvcjogJHtcbiAgICAgICAgcHJvbWluZW5jZSA9PT0gUFJPTUlORU5DRVMuc3Ryb25nXG4gICAgICAgICAgPyB0aGVtZS5jb2xvcnMubmV1dHJhbFt0ZXh0IGFzIGtleW9mIHR5cGVvZiB0aGVtZS5jb2xvcnMubmV1dHJhbF1cbiAgICAgICAgICA6IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHRcbiAgICAgIH07XG4gICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5uZXV0cmFsLmJhY2tncm91bmR9O1xuICAgICAgYm9yZGVyOiAxcHggc29saWQgJHt0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJ9O1xuICAgIGAsXG4gICAgZGlzYWJsZWQ6IGBcbiAgICAgIGNvbG9yOiAke3RoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHRXZWFrfTtcbiAgICAgIGJhY2tncm91bmQ6ICR7dGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZFN0cm9uZ307XG4gICAgICBib3JkZXI6IG5vbmU7XG4gICAgYCxcbiAgfVxufVxuXG50eXBlIFN0eWxlZENvbnRhaW5lclR5cGUgPSB7XG4gIHNlbnRpbWVudDogQnVsbGV0U2VudGltZW50XG4gIHNpemU6IGtleW9mIHR5cGVvZiBTSVpFU1xuICBwcm9taW5lbmNlOiBQcm9taW5lbmNlVHlwZVxufVxuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQoJ2RpdicpPFN0eWxlZENvbnRhaW5lclR5cGU+YFxuICBkaXNwbGF5OiBmbGV4O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmNpcmNsZX07XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICB3aWR0aDogJHsoeyBzaXplLCB0aGVtZSB9KSA9PiB0aGVtZS5zaXppbmdbU0laRVNbc2l6ZV1dfTtcbiAgaGVpZ2h0OiAkeyh7IHNpemUsIHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1tTSVpFU1tzaXplXV19O1xuICBmb250LXNpemU6ICR7KHsgc2l6ZSwgdGhlbWUgfSkgPT4gdGhlbWUudHlwb2dyYXBoeVtURVhUX1ZBUklBTlRbc2l6ZV1dLmZvbnRTaXplfTtcbiAgJHsoeyB0aGVtZSwgcHJvbWluZW5jZSwgc2VudGltZW50IH0pID0+XG4gICAgKHNlbnRpbWVudFN0eWxlcyh7IHRoZW1lLCBwcm9taW5lbmNlIH0pIGFzIFJlY29yZDxCdWxsZXRTZW50aW1lbnQsIHN0cmluZz4pW1xuICAgICAgc2VudGltZW50XG4gICAgXX07XG5gXG5cbnR5cGUgQnVsbGV0UHJvcHMgPSB7XG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBzaXplPzoga2V5b2YgdHlwZW9mIFNJWkVTXG4gIHRvb2x0aXA/OiBzdHJpbmdcbiAgdG9vbHRpcEJhc2VJZD86IHN0cmluZ1xuICBzZW50aW1lbnQ/OiBCdWxsZXRTZW50aW1lbnRcbiAgJ2RhdGEtdGVzdGlkJz86IHN0cmluZ1xuICBwcm9taW5lbmNlPzogUHJvbWluZW5jZVR5cGVcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGVcbiAgLyoqXG4gICAqIEBkZXByZWNhdGVkIEFkZCB0aGUgaWNvbiBkaXJlY3RseSBpbnRvIHRoZSBjaGlsZHJlblxuICAgKi9cbiAgaWNvbj86IENvbXBvbmVudFByb3BzPHR5cGVvZiBJY29uPlsnbmFtZSddXG4gIC8qKlxuICAgKiBAZGVwcmVjYXRlZCBBZGQgdGhlIGljb24gZGlyZWN0bHkgaW50byB0aGUgY2hpbGRyZW5cbiAgICovXG4gIGljb25WYXJpYW50PzogQ29tcG9uZW50UHJvcHM8dHlwZW9mIEljb24+Wyd2YXJpYW50J11cbiAgLyoqXG4gICAqIEBkZXByZWNhdGVkIEFkZCB0aGUgdGV4dCBkaXJlY3RseSBpbnRvIHRoZSBjaGlsZHJlblxuICAgKi9cbiAgdGV4dD86IHN0cmluZ1xufVxuXG4vKipcbiAqIEJ1bGxldCBjb21wb25lbnQgaXMgdXNlZCB0byBkaXNwbGF5IGEgc21hbGwgaWNvbiBvciB0ZXh0IHdpdGggYSBjb2xvcmVkIGJhY2tncm91bmQgaW4gYSBjaXJjbGUuXG4gKi9cbmV4cG9ydCBjb25zdCBCdWxsZXQgPSAoe1xuICBjbGFzc05hbWUsXG4gIHNlbnRpbWVudCA9ICduZXV0cmFsJyxcbiAgc2l6ZSA9ICdtZWRpdW0nLFxuICBpY29uLFxuICBpY29uVmFyaWFudCxcbiAgdGV4dCxcbiAgdG9vbHRpcCxcbiAgdG9vbHRpcEJhc2VJZCxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbiAgcHJvbWluZW5jZSA9ICdkZWZhdWx0JyxcbiAgY2hpbGRyZW4sXG59OiBCdWxsZXRQcm9wcykgPT4gKFxuICA8VG9vbHRpcCBpZD17dG9vbHRpcEJhc2VJZH0gdGV4dD17dG9vbHRpcH0+XG4gICAgPFN0eWxlZENvbnRhaW5lclxuICAgICAgc2VudGltZW50PXtzZW50aW1lbnR9XG4gICAgICBzaXplPXtzaXplfVxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAgIHByb21pbmVuY2U9e3Byb21pbmVuY2V9XG4gICAgPlxuICAgICAge2ljb24gPyA8SWNvbiBuYW1lPXtpY29ufSBzaXplPVwic21hbGxcIiB2YXJpYW50PXtpY29uVmFyaWFudH0gLz4gOiB0ZXh0fVxuICAgICAge2NoaWxkcmVufVxuICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICA8L1Rvb2x0aXA+XG4pXG4iXX0= */"));
63
75
  const Bullet = ({
64
76
  className,
65
77
  sentiment = "neutral",
@@ -29,7 +29,7 @@ const Container = /* @__PURE__ */ _styled__default.default("div", process.env.NO
29
29
  styles: "width:100%"
30
30
  } : {
31
31
  name: "1d3w5wq",
32
- styles: "width:100%/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx"],"names":[],"mappings":"AAiB4B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { CalendarRangeIcon } from '@ultraviolet/icons'\nimport type { Locale } from 'date-fns'\nimport type { ChangeEvent, FocusEvent } from 'react'\nimport { useEffect, useMemo, useRef, useState } from 'react'\nimport { Card } from '../Card'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { TextInputV2 } from '../TextInputV2'\nimport { type ContextProps, DateInputContext } from './Context'\nimport { CalendarContent } from './components/CalendarContent'\nimport { CalendarPopup } from './components/Popup'\nimport { formatValue, styleCalendarContainer } from './helpers'\nimport { getDays, getLocalizedMonths, getMonths } from './helpersLocale'\n\nconst Container = styled.div`\nwidth: 100%;`\n\nconst StyledCard = styled(Card)`\n  ${({ theme }) => styleCalendarContainer(theme)}\n  width: 16.5rem;\n\n  &[data-disabled=\"true\"] {\n      cursor: not-allowed;\n    }\n`\n\ntype DateInputProps<IsRange extends undefined | boolean = false> = {\n  autoFocus?: boolean\n  locale?: string | Locale\n  disabled?: boolean\n  maxDate?: Date | null\n  minDate?: Date | null\n  name?: string\n  onBlur?: (event: FocusEvent<HTMLInputElement>) => void\n  onFocus?: (event: FocusEvent<HTMLInputElement>) => void\n  error?: string\n  required?: boolean\n  format?: (value?: Date) => string | undefined\n  /**\n   * Label of the field\n   */\n  label?: string\n  value?: Date | null\n  className?: string\n  'data-testid'?: string\n  excludeDates?: Date[]\n  id?: string\n  labelDescription?: string\n  success?: string | boolean\n  helper?: string\n  size?: 'small' | 'medium' | 'large'\n  readOnly?: boolean\n  tooltip?: string\n  showMonthYearPicker?: boolean\n  placeholder?: string\n  startDate?: Date | null\n  endDate?: Date | null\n  /**\n   * Display the component as an input + a calendar popup (\"text\") or only as a calendar (\"calendar\")\n   */\n  input?: 'calendar' | 'text'\n  selectsRange?: IsRange\n  onChange?: IsRange extends true\n    ? (\n        date: Date[] | [Date | null, Date | null],\n        event?: React.SyntheticEvent,\n      ) => void\n    : (date: Date | null, event?: React.SyntheticEvent) => void\n}\n\n/**\n * DateInput can be used to select a specific date\n */\nexport const DateInput = <IsRange extends undefined | boolean>({\n  autoFocus = false,\n  disabled = false,\n  error,\n  format,\n  label,\n  labelDescription,\n  locale = 'en-US',\n  maxDate,\n  minDate,\n  startDate,\n  endDate,\n  name,\n  onBlur,\n  onChange,\n  placeholder,\n  onFocus,\n  required = false,\n  excludeDates,\n  value,\n  className,\n  id,\n  success,\n  helper,\n  size = 'large',\n  readOnly = false,\n  tooltip,\n  selectsRange = false,\n  showMonthYearPicker = false,\n  input = 'text',\n  'data-testid': dataTestId,\n}: DateInputProps<IsRange>) => {\n  const defaultMonthToShow = useMemo(() => {\n    if (value) return new Date(value).getMonth() + 1\n    if (startDate && selectsRange) return startDate.getMonth() + 1\n    if (endDate && selectsRange) return endDate.getMonth() + 1\n\n    return new Date().getMonth() + 1\n  }, [endDate, selectsRange, startDate, value])\n\n  const defaultYearToShow = useMemo(() => {\n    if (value) return new Date(value).getFullYear()\n    if (startDate && selectsRange) return startDate.getFullYear()\n    if (endDate && selectsRange) return endDate.getFullYear()\n\n    return new Date().getFullYear()\n  }, [endDate, selectsRange, startDate, value])\n\n  const [computedValue, setValue] = useState(\n    value && !selectsRange ? new Date(value) : null,\n  )\n  const [computedRange, setRange] = useState({\n    start: startDate ?? null,\n    end: endDate ?? null,\n  })\n  const [isPopupVisible, setVisible] = useState(false)\n  const [monthToShow, setMonthToShow] = useState(defaultMonthToShow)\n  const [yearToShow, setYearToShow] = useState(defaultYearToShow)\n  const [inputValue, setInputValue] = useState(\n    formatValue(\n      computedValue,\n      computedRange,\n      showMonthYearPicker,\n      selectsRange,\n      format,\n    ),\n  )\n  const [hoveredDate, setHoveredDate] = useState<Date | null>(null)\n  const refInput = useRef<HTMLInputElement>(null)\n  const MONTHS = getMonths(locale)\n  const DAYS = getDays(locale)\n  const MONTHS_ARR = getLocalizedMonths(locale)\n\n  const valueContext = useMemo(\n    () =>\n      ({\n        showMonthYearPicker,\n        disabled,\n        readOnly,\n        value: computedValue,\n        range: computedRange,\n        setRange,\n        setValue,\n        monthToShow,\n        yearToShow,\n        setMonthToShow,\n        setYearToShow,\n        excludeDates,\n        maxDate,\n        minDate,\n        MONTHS,\n        MONTHS_ARR,\n        DAYS,\n        onChange,\n        selectsRange,\n        format,\n        setInputValue,\n        setVisible,\n        hoveredDate,\n        setHoveredDate,\n      }) as ContextProps,\n    [\n      showMonthYearPicker,\n      disabled,\n      readOnly,\n      selectsRange,\n      computedValue,\n      computedRange,\n      monthToShow,\n      yearToShow,\n      excludeDates,\n      maxDate,\n      minDate,\n      MONTHS,\n      MONTHS_ARR,\n      DAYS,\n      onChange,\n      format,\n      setInputValue,\n      setVisible,\n      hoveredDate,\n      setHoveredDate,\n    ],\n  )\n\n  useEffect(() => {\n    if (value && !selectsRange) {\n      setValue(new Date(value))\n      setInputValue(\n        formatValue(\n          new Date(value),\n          null,\n          showMonthYearPicker,\n          selectsRange,\n          format,\n        ),\n      )\n    }\n    if (selectsRange) {\n      setRange({\n        start: startDate ?? computedRange.start,\n        end: endDate ?? computedRange.end,\n      })\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [endDate, startDate, value])\n\n  const manageOnChange = (event: ChangeEvent<HTMLInputElement>) => {\n    const newValue = event.currentTarget.value\n\n    if (selectsRange) {\n      const [startDateInput, endDateInput] = newValue.split(' - ').map(val => {\n        if (showMonthYearPicker) {\n          // Force YYYY/MM (since MM/YYYY not recognised as a date in typescript)\n          const res = val.split(/\\D+/).map(aa => Number.parseInt(aa, 10))\n\n          return new Date(Math.max(...res), Math.min(...res) - 1)\n        }\n\n        return new Date(val)\n      })\n\n      const computedNewRange: [Date | null, Date | null] = [\n        startDateInput instanceof Date &&\n        !Number.isNaN(startDateInput.getTime())\n          ? startDateInput\n          : null,\n        endDateInput instanceof Date && !Number.isNaN(endDateInput.getTime())\n          ? endDateInput\n          : null,\n      ]\n\n      setRange({ start: computedNewRange[0], end: computedNewRange[1] })\n      setInputValue(newValue)\n\n      if (computedNewRange[0]) {\n        setMonthToShow(computedNewRange[0].getMonth() + 1)\n        setYearToShow(computedNewRange[0].getFullYear())\n      }\n      // TypeScript fails to automatically get the correct type of onChange here\n      ;(\n        onChange as (\n          date: Date[] | [Date | null, Date | null],\n          event: React.SyntheticEvent | undefined,\n        ) => void\n      )?.(computedNewRange, event)\n    } else {\n      const computedDate = new Date(newValue)\n      setInputValue(newValue)\n\n      if (Date.parse(newValue)) {\n        setValue(computedDate)\n        setMonthToShow(computedDate.getMonth() + 1)\n        setYearToShow(computedDate.getFullYear())\n\n        // TypeScript fails to automatically get the correct type of onChange here\n        ;(\n          onChange as (date: Date | null, event?: React.SyntheticEvent) => void\n        )?.(computedDate, event)\n      }\n    }\n  }\n\n  return (\n    <DateInputContext.Provider value={valueContext}>\n      <Container\n        id={id}\n        className={className}\n        data-testid={dataTestId}\n        onBlur={onBlur}\n        onFocus={onFocus}\n        onClick={() => {\n          if (!isPopupVisible) setVisible(true)\n        }}\n      >\n        {input === 'text' ? (\n          <CalendarPopup\n            visible={isPopupVisible}\n            setVisible={setVisible}\n            refInput={refInput}\n            content={<CalendarContent />}\n          >\n            <TextInputV2\n              label={label}\n              placeholder={placeholder}\n              value={inputValue}\n              required={required}\n              error={error}\n              success={success}\n              readOnly={readOnly}\n              disabled={disabled}\n              size={size}\n              autoFocus={autoFocus}\n              helper={helper}\n              labelDescription={labelDescription}\n              name={name}\n              suffix={\n                <CalendarRangeIcon\n                  size=\"medium\"\n                  sentiment=\"neutral\"\n                  disabled={disabled}\n                />\n              }\n              ref={refInput}\n              tooltip={tooltip}\n              autoComplete=\"false\"\n              onChange={manageOnChange}\n            />\n          </CalendarPopup>\n        ) : (\n          <Stack gap={0.5}>\n            {labelDescription ? (\n              <Stack direction=\"row\" gap=\"1\">\n                <Text\n                  as=\"label\"\n                  variant=\"bodyStrong\"\n                  prominence=\"strong\"\n                  sentiment=\"neutral\"\n                >\n                  {label}\n                </Text>\n                {labelDescription}\n              </Stack>\n            ) : (\n              <Text\n                as=\"label\"\n                variant=\"bodyStrong\"\n                prominence=\"strong\"\n                sentiment=\"neutral\"\n              >\n                {label}\n              </Text>\n            )}\n\n            <StyledCard disabled={disabled}>\n              <CalendarContent />\n            </StyledCard>\n          </Stack>\n        )}\n      </Container>\n    </DateInputContext.Provider>\n  )\n}\n"]} */",
32
+ styles: "width:100%/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx"],"names":[],"mappings":"AAiB4B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { CalendarRangeIcon } from '@ultraviolet/icons'\nimport type { Locale } from 'date-fns'\nimport type { ChangeEvent, FocusEvent } from 'react'\nimport { useEffect, useMemo, useRef, useState } from 'react'\nimport { Card } from '../Card'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { TextInputV2 } from '../TextInputV2'\nimport { type ContextProps, DateInputContext } from './Context'\nimport { CalendarContent } from './components/CalendarContent'\nimport { CalendarPopup } from './components/Popup'\nimport { formatValue, styleCalendarContainer } from './helpers'\nimport { getDays, getLocalizedMonths, getMonths } from './helpersLocale'\n\nconst Container = styled.div`\nwidth: 100%;`\n\nconst StyledCard = styled(Card)`\n  ${({ theme }) => styleCalendarContainer(theme)}\n  width: 16.5rem;\n\n  &[data-disabled=\"true\"] {\n      cursor: not-allowed;\n    }\n`\n\ntype DateInputProps<IsRange extends undefined | boolean = false> = {\n  autoFocus?: boolean\n  locale?: string | Locale\n  disabled?: boolean\n  maxDate?: Date | null\n  minDate?: Date | null\n  name?: string\n  onBlur?: (event: FocusEvent<HTMLInputElement>) => void\n  onFocus?: (event: FocusEvent<HTMLInputElement>) => void\n  error?: string\n  required?: boolean\n  format?: (value?: Date) => string | undefined\n  /**\n   * Label of the field\n   */\n  label?: string\n  value?: Date | null\n  className?: string\n  'data-testid'?: string\n  excludeDates?: Date[]\n  id?: string\n  labelDescription?: string\n  success?: string | boolean\n  helper?: string\n  size?: 'small' | 'medium' | 'large'\n  readOnly?: boolean\n  tooltip?: string\n  clearable?: boolean\n  showMonthYearPicker?: boolean\n  placeholder?: string\n  startDate?: Date | null\n  endDate?: Date | null\n  /**\n   * Display the component as an input + a calendar popup (\"text\") or only as a calendar (\"calendar\")\n   */\n  input?: 'calendar' | 'text'\n  selectsRange?: IsRange\n  onChange?: IsRange extends true\n    ? (\n        date: Date[] | [Date | null, Date | null],\n        event?: React.SyntheticEvent,\n      ) => void\n    : (date: Date | null, event?: React.SyntheticEvent) => void\n}\n\n/**\n * DateInput can be used to select a specific date\n */\nexport const DateInput = <IsRange extends undefined | boolean>({\n  autoFocus = false,\n  disabled = false,\n  error,\n  format,\n  label,\n  labelDescription,\n  locale = 'en-US',\n  maxDate,\n  minDate,\n  startDate,\n  endDate,\n  name,\n  onBlur,\n  onChange,\n  placeholder,\n  onFocus,\n  required = false,\n  excludeDates,\n  value,\n  className,\n  id,\n  success,\n  helper,\n  size = 'large',\n  readOnly = false,\n  tooltip,\n  clearable,\n  selectsRange = false,\n  showMonthYearPicker = false,\n  input = 'text',\n  'data-testid': dataTestId,\n}: DateInputProps<IsRange>) => {\n  const defaultMonthToShow = useMemo(() => {\n    if (value) return new Date(value).getMonth() + 1\n    if (startDate && selectsRange) return startDate.getMonth() + 1\n    if (endDate && selectsRange) return endDate.getMonth() + 1\n\n    return new Date().getMonth() + 1\n  }, [endDate, selectsRange, startDate, value])\n\n  const defaultYearToShow = useMemo(() => {\n    if (value) return new Date(value).getFullYear()\n    if (startDate && selectsRange) return startDate.getFullYear()\n    if (endDate && selectsRange) return endDate.getFullYear()\n\n    return new Date().getFullYear()\n  }, [endDate, selectsRange, startDate, value])\n\n  const [computedValue, setValue] = useState(\n    value && !selectsRange ? new Date(value) : null,\n  )\n  const [computedRange, setRange] = useState({\n    start: startDate ?? null,\n    end: endDate ?? null,\n  })\n  const [isPopupVisible, setVisible] = useState(false)\n  const [monthToShow, setMonthToShow] = useState(defaultMonthToShow)\n  const [yearToShow, setYearToShow] = useState(defaultYearToShow)\n  const [inputValue, setInputValue] = useState(\n    formatValue(\n      computedValue,\n      computedRange,\n      showMonthYearPicker,\n      selectsRange,\n      format,\n    ),\n  )\n  const [hoveredDate, setHoveredDate] = useState<Date | null>(null)\n  const refInput = useRef<HTMLInputElement>(null)\n  const MONTHS = getMonths(locale)\n  const DAYS = getDays(locale)\n  const MONTHS_ARR = getLocalizedMonths(locale)\n\n  const valueContext = useMemo(\n    () =>\n      ({\n        showMonthYearPicker,\n        disabled,\n        readOnly,\n        value: computedValue,\n        range: computedRange,\n        setRange,\n        setValue,\n        monthToShow,\n        yearToShow,\n        setMonthToShow,\n        setYearToShow,\n        excludeDates,\n        maxDate,\n        minDate,\n        MONTHS,\n        MONTHS_ARR,\n        DAYS,\n        onChange,\n        selectsRange,\n        format,\n        setInputValue,\n        setVisible,\n        hoveredDate,\n        setHoveredDate,\n      }) as ContextProps,\n    [\n      showMonthYearPicker,\n      disabled,\n      readOnly,\n      selectsRange,\n      computedValue,\n      computedRange,\n      monthToShow,\n      yearToShow,\n      excludeDates,\n      maxDate,\n      minDate,\n      MONTHS,\n      MONTHS_ARR,\n      DAYS,\n      onChange,\n      format,\n      setInputValue,\n      setVisible,\n      hoveredDate,\n      setHoveredDate,\n    ],\n  )\n\n  useEffect(() => {\n    if (value && !selectsRange) {\n      setValue(new Date(value))\n      setInputValue(\n        formatValue(\n          new Date(value),\n          null,\n          showMonthYearPicker,\n          selectsRange,\n          format,\n        ),\n      )\n    }\n    if (selectsRange) {\n      setRange({\n        start: startDate ?? computedRange.start,\n        end: endDate ?? computedRange.end,\n      })\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [endDate, startDate, value])\n\n  const manageOnChange = (event: ChangeEvent<HTMLInputElement>) => {\n    const newValue = event.currentTarget.value\n\n    if (selectsRange) {\n      const [startDateInput, endDateInput] = newValue.split(' - ').map(val => {\n        if (showMonthYearPicker) {\n          // Force YYYY/MM (since MM/YYYY not recognised as a date in typescript)\n          const res = val.split(/\\D+/).map(aa => Number.parseInt(aa, 10))\n\n          return new Date(Math.max(...res), Math.min(...res) - 1)\n        }\n\n        return new Date(val)\n      })\n\n      const computedNewRange: [Date | null, Date | null] = [\n        startDateInput instanceof Date &&\n        !Number.isNaN(startDateInput.getTime())\n          ? startDateInput\n          : null,\n        endDateInput instanceof Date && !Number.isNaN(endDateInput.getTime())\n          ? endDateInput\n          : null,\n      ]\n\n      setRange({ start: computedNewRange[0], end: computedNewRange[1] })\n      setInputValue(newValue)\n\n      if (computedNewRange[0]) {\n        setMonthToShow(computedNewRange[0].getMonth() + 1)\n        setYearToShow(computedNewRange[0].getFullYear())\n      }\n      // TypeScript fails to automatically get the correct type of onChange here\n      ;(\n        onChange as (\n          date: Date[] | [Date | null, Date | null],\n          event: React.SyntheticEvent | undefined,\n        ) => void\n      )?.(computedNewRange, event)\n    } else {\n      const computedDate = Date.parse(newValue) ? new Date(newValue) : null\n      setInputValue(newValue)\n      setValue(computedDate)\n\n      if (computedDate) {\n        setMonthToShow(computedDate.getMonth() + 1)\n        setYearToShow(computedDate.getFullYear())\n      }\n      // TypeScript fails to automatically get the correct type of onChange here\n      ;(\n        onChange as (date: Date | null, event?: React.SyntheticEvent) => void\n      )?.(computedDate, event)\n    }\n  }\n\n  return (\n    <DateInputContext.Provider value={valueContext}>\n      <Container\n        id={id}\n        className={className}\n        data-testid={dataTestId}\n        onBlur={onBlur}\n        onFocus={onFocus}\n        onClick={() => {\n          if (!isPopupVisible) setVisible(true)\n        }}\n      >\n        {input === 'text' ? (\n          <CalendarPopup\n            visible={isPopupVisible}\n            setVisible={setVisible}\n            refInput={refInput}\n            content={<CalendarContent />}\n          >\n            <TextInputV2\n              label={label}\n              placeholder={placeholder}\n              value={inputValue}\n              required={required}\n              error={error}\n              success={success}\n              readOnly={readOnly}\n              disabled={disabled}\n              size={size}\n              autoFocus={autoFocus}\n              helper={helper}\n              labelDescription={labelDescription}\n              name={name}\n              suffix={\n                <CalendarRangeIcon\n                  size=\"medium\"\n                  sentiment=\"neutral\"\n                  disabled={disabled}\n                />\n              }\n              ref={refInput}\n              tooltip={tooltip}\n              autoComplete=\"false\"\n              onChange={manageOnChange}\n              clearable={clearable}\n            />\n          </CalendarPopup>\n        ) : (\n          <Stack gap={0.5}>\n            {labelDescription ? (\n              <Stack direction=\"row\" gap=\"1\">\n                <Text\n                  as=\"label\"\n                  variant=\"bodyStrong\"\n                  prominence=\"strong\"\n                  sentiment=\"neutral\"\n                >\n                  {label}\n                </Text>\n                {labelDescription}\n              </Stack>\n            ) : (\n              <Text\n                as=\"label\"\n                variant=\"bodyStrong\"\n                prominence=\"strong\"\n                sentiment=\"neutral\"\n              >\n                {label}\n              </Text>\n            )}\n\n            <StyledCard disabled={disabled}>\n              <CalendarContent />\n            </StyledCard>\n          </Stack>\n        )}\n      </Container>\n    </DateInputContext.Provider>\n  )\n}\n"]} */",
33
33
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
34
34
  });
35
35
  const StyledCard = /* @__PURE__ */ _styled__default.default(index$3.Card, process.env.NODE_ENV === "production" ? {
@@ -39,7 +39,7 @@ const StyledCard = /* @__PURE__ */ _styled__default.default(index$3.Card, proces
39
39
  label: "StyledCard"
40
40
  })(({
41
41
  theme
42
- }) => helpers.styleCalendarContainer(theme), ' width:16.5rem;&[data-disabled="true"]{cursor:not-allowed;}' + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx"],"names":[],"mappings":"AAoB+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { CalendarRangeIcon } from '@ultraviolet/icons'\nimport type { Locale } from 'date-fns'\nimport type { ChangeEvent, FocusEvent } from 'react'\nimport { useEffect, useMemo, useRef, useState } from 'react'\nimport { Card } from '../Card'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { TextInputV2 } from '../TextInputV2'\nimport { type ContextProps, DateInputContext } from './Context'\nimport { CalendarContent } from './components/CalendarContent'\nimport { CalendarPopup } from './components/Popup'\nimport { formatValue, styleCalendarContainer } from './helpers'\nimport { getDays, getLocalizedMonths, getMonths } from './helpersLocale'\n\nconst Container = styled.div`\nwidth: 100%;`\n\nconst StyledCard = styled(Card)`\n  ${({ theme }) => styleCalendarContainer(theme)}\n  width: 16.5rem;\n\n  &[data-disabled=\"true\"] {\n      cursor: not-allowed;\n    }\n`\n\ntype DateInputProps<IsRange extends undefined | boolean = false> = {\n  autoFocus?: boolean\n  locale?: string | Locale\n  disabled?: boolean\n  maxDate?: Date | null\n  minDate?: Date | null\n  name?: string\n  onBlur?: (event: FocusEvent<HTMLInputElement>) => void\n  onFocus?: (event: FocusEvent<HTMLInputElement>) => void\n  error?: string\n  required?: boolean\n  format?: (value?: Date) => string | undefined\n  /**\n   * Label of the field\n   */\n  label?: string\n  value?: Date | null\n  className?: string\n  'data-testid'?: string\n  excludeDates?: Date[]\n  id?: string\n  labelDescription?: string\n  success?: string | boolean\n  helper?: string\n  size?: 'small' | 'medium' | 'large'\n  readOnly?: boolean\n  tooltip?: string\n  showMonthYearPicker?: boolean\n  placeholder?: string\n  startDate?: Date | null\n  endDate?: Date | null\n  /**\n   * Display the component as an input + a calendar popup (\"text\") or only as a calendar (\"calendar\")\n   */\n  input?: 'calendar' | 'text'\n  selectsRange?: IsRange\n  onChange?: IsRange extends true\n    ? (\n        date: Date[] | [Date | null, Date | null],\n        event?: React.SyntheticEvent,\n      ) => void\n    : (date: Date | null, event?: React.SyntheticEvent) => void\n}\n\n/**\n * DateInput can be used to select a specific date\n */\nexport const DateInput = <IsRange extends undefined | boolean>({\n  autoFocus = false,\n  disabled = false,\n  error,\n  format,\n  label,\n  labelDescription,\n  locale = 'en-US',\n  maxDate,\n  minDate,\n  startDate,\n  endDate,\n  name,\n  onBlur,\n  onChange,\n  placeholder,\n  onFocus,\n  required = false,\n  excludeDates,\n  value,\n  className,\n  id,\n  success,\n  helper,\n  size = 'large',\n  readOnly = false,\n  tooltip,\n  selectsRange = false,\n  showMonthYearPicker = false,\n  input = 'text',\n  'data-testid': dataTestId,\n}: DateInputProps<IsRange>) => {\n  const defaultMonthToShow = useMemo(() => {\n    if (value) return new Date(value).getMonth() + 1\n    if (startDate && selectsRange) return startDate.getMonth() + 1\n    if (endDate && selectsRange) return endDate.getMonth() + 1\n\n    return new Date().getMonth() + 1\n  }, [endDate, selectsRange, startDate, value])\n\n  const defaultYearToShow = useMemo(() => {\n    if (value) return new Date(value).getFullYear()\n    if (startDate && selectsRange) return startDate.getFullYear()\n    if (endDate && selectsRange) return endDate.getFullYear()\n\n    return new Date().getFullYear()\n  }, [endDate, selectsRange, startDate, value])\n\n  const [computedValue, setValue] = useState(\n    value && !selectsRange ? new Date(value) : null,\n  )\n  const [computedRange, setRange] = useState({\n    start: startDate ?? null,\n    end: endDate ?? null,\n  })\n  const [isPopupVisible, setVisible] = useState(false)\n  const [monthToShow, setMonthToShow] = useState(defaultMonthToShow)\n  const [yearToShow, setYearToShow] = useState(defaultYearToShow)\n  const [inputValue, setInputValue] = useState(\n    formatValue(\n      computedValue,\n      computedRange,\n      showMonthYearPicker,\n      selectsRange,\n      format,\n    ),\n  )\n  const [hoveredDate, setHoveredDate] = useState<Date | null>(null)\n  const refInput = useRef<HTMLInputElement>(null)\n  const MONTHS = getMonths(locale)\n  const DAYS = getDays(locale)\n  const MONTHS_ARR = getLocalizedMonths(locale)\n\n  const valueContext = useMemo(\n    () =>\n      ({\n        showMonthYearPicker,\n        disabled,\n        readOnly,\n        value: computedValue,\n        range: computedRange,\n        setRange,\n        setValue,\n        monthToShow,\n        yearToShow,\n        setMonthToShow,\n        setYearToShow,\n        excludeDates,\n        maxDate,\n        minDate,\n        MONTHS,\n        MONTHS_ARR,\n        DAYS,\n        onChange,\n        selectsRange,\n        format,\n        setInputValue,\n        setVisible,\n        hoveredDate,\n        setHoveredDate,\n      }) as ContextProps,\n    [\n      showMonthYearPicker,\n      disabled,\n      readOnly,\n      selectsRange,\n      computedValue,\n      computedRange,\n      monthToShow,\n      yearToShow,\n      excludeDates,\n      maxDate,\n      minDate,\n      MONTHS,\n      MONTHS_ARR,\n      DAYS,\n      onChange,\n      format,\n      setInputValue,\n      setVisible,\n      hoveredDate,\n      setHoveredDate,\n    ],\n  )\n\n  useEffect(() => {\n    if (value && !selectsRange) {\n      setValue(new Date(value))\n      setInputValue(\n        formatValue(\n          new Date(value),\n          null,\n          showMonthYearPicker,\n          selectsRange,\n          format,\n        ),\n      )\n    }\n    if (selectsRange) {\n      setRange({\n        start: startDate ?? computedRange.start,\n        end: endDate ?? computedRange.end,\n      })\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [endDate, startDate, value])\n\n  const manageOnChange = (event: ChangeEvent<HTMLInputElement>) => {\n    const newValue = event.currentTarget.value\n\n    if (selectsRange) {\n      const [startDateInput, endDateInput] = newValue.split(' - ').map(val => {\n        if (showMonthYearPicker) {\n          // Force YYYY/MM (since MM/YYYY not recognised as a date in typescript)\n          const res = val.split(/\\D+/).map(aa => Number.parseInt(aa, 10))\n\n          return new Date(Math.max(...res), Math.min(...res) - 1)\n        }\n\n        return new Date(val)\n      })\n\n      const computedNewRange: [Date | null, Date | null] = [\n        startDateInput instanceof Date &&\n        !Number.isNaN(startDateInput.getTime())\n          ? startDateInput\n          : null,\n        endDateInput instanceof Date && !Number.isNaN(endDateInput.getTime())\n          ? endDateInput\n          : null,\n      ]\n\n      setRange({ start: computedNewRange[0], end: computedNewRange[1] })\n      setInputValue(newValue)\n\n      if (computedNewRange[0]) {\n        setMonthToShow(computedNewRange[0].getMonth() + 1)\n        setYearToShow(computedNewRange[0].getFullYear())\n      }\n      // TypeScript fails to automatically get the correct type of onChange here\n      ;(\n        onChange as (\n          date: Date[] | [Date | null, Date | null],\n          event: React.SyntheticEvent | undefined,\n        ) => void\n      )?.(computedNewRange, event)\n    } else {\n      const computedDate = new Date(newValue)\n      setInputValue(newValue)\n\n      if (Date.parse(newValue)) {\n        setValue(computedDate)\n        setMonthToShow(computedDate.getMonth() + 1)\n        setYearToShow(computedDate.getFullYear())\n\n        // TypeScript fails to automatically get the correct type of onChange here\n        ;(\n          onChange as (date: Date | null, event?: React.SyntheticEvent) => void\n        )?.(computedDate, event)\n      }\n    }\n  }\n\n  return (\n    <DateInputContext.Provider value={valueContext}>\n      <Container\n        id={id}\n        className={className}\n        data-testid={dataTestId}\n        onBlur={onBlur}\n        onFocus={onFocus}\n        onClick={() => {\n          if (!isPopupVisible) setVisible(true)\n        }}\n      >\n        {input === 'text' ? (\n          <CalendarPopup\n            visible={isPopupVisible}\n            setVisible={setVisible}\n            refInput={refInput}\n            content={<CalendarContent />}\n          >\n            <TextInputV2\n              label={label}\n              placeholder={placeholder}\n              value={inputValue}\n              required={required}\n              error={error}\n              success={success}\n              readOnly={readOnly}\n              disabled={disabled}\n              size={size}\n              autoFocus={autoFocus}\n              helper={helper}\n              labelDescription={labelDescription}\n              name={name}\n              suffix={\n                <CalendarRangeIcon\n                  size=\"medium\"\n                  sentiment=\"neutral\"\n                  disabled={disabled}\n                />\n              }\n              ref={refInput}\n              tooltip={tooltip}\n              autoComplete=\"false\"\n              onChange={manageOnChange}\n            />\n          </CalendarPopup>\n        ) : (\n          <Stack gap={0.5}>\n            {labelDescription ? (\n              <Stack direction=\"row\" gap=\"1\">\n                <Text\n                  as=\"label\"\n                  variant=\"bodyStrong\"\n                  prominence=\"strong\"\n                  sentiment=\"neutral\"\n                >\n                  {label}\n                </Text>\n                {labelDescription}\n              </Stack>\n            ) : (\n              <Text\n                as=\"label\"\n                variant=\"bodyStrong\"\n                prominence=\"strong\"\n                sentiment=\"neutral\"\n              >\n                {label}\n              </Text>\n            )}\n\n            <StyledCard disabled={disabled}>\n              <CalendarContent />\n            </StyledCard>\n          </Stack>\n        )}\n      </Container>\n    </DateInputContext.Provider>\n  )\n}\n"]} */"));
42
+ }) => helpers.styleCalendarContainer(theme), ' width:16.5rem;&[data-disabled="true"]{cursor:not-allowed;}' + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx"],"names":[],"mappings":"AAoB+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { CalendarRangeIcon } from '@ultraviolet/icons'\nimport type { Locale } from 'date-fns'\nimport type { ChangeEvent, FocusEvent } from 'react'\nimport { useEffect, useMemo, useRef, useState } from 'react'\nimport { Card } from '../Card'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { TextInputV2 } from '../TextInputV2'\nimport { type ContextProps, DateInputContext } from './Context'\nimport { CalendarContent } from './components/CalendarContent'\nimport { CalendarPopup } from './components/Popup'\nimport { formatValue, styleCalendarContainer } from './helpers'\nimport { getDays, getLocalizedMonths, getMonths } from './helpersLocale'\n\nconst Container = styled.div`\nwidth: 100%;`\n\nconst StyledCard = styled(Card)`\n  ${({ theme }) => styleCalendarContainer(theme)}\n  width: 16.5rem;\n\n  &[data-disabled=\"true\"] {\n      cursor: not-allowed;\n    }\n`\n\ntype DateInputProps<IsRange extends undefined | boolean = false> = {\n  autoFocus?: boolean\n  locale?: string | Locale\n  disabled?: boolean\n  maxDate?: Date | null\n  minDate?: Date | null\n  name?: string\n  onBlur?: (event: FocusEvent<HTMLInputElement>) => void\n  onFocus?: (event: FocusEvent<HTMLInputElement>) => void\n  error?: string\n  required?: boolean\n  format?: (value?: Date) => string | undefined\n  /**\n   * Label of the field\n   */\n  label?: string\n  value?: Date | null\n  className?: string\n  'data-testid'?: string\n  excludeDates?: Date[]\n  id?: string\n  labelDescription?: string\n  success?: string | boolean\n  helper?: string\n  size?: 'small' | 'medium' | 'large'\n  readOnly?: boolean\n  tooltip?: string\n  clearable?: boolean\n  showMonthYearPicker?: boolean\n  placeholder?: string\n  startDate?: Date | null\n  endDate?: Date | null\n  /**\n   * Display the component as an input + a calendar popup (\"text\") or only as a calendar (\"calendar\")\n   */\n  input?: 'calendar' | 'text'\n  selectsRange?: IsRange\n  onChange?: IsRange extends true\n    ? (\n        date: Date[] | [Date | null, Date | null],\n        event?: React.SyntheticEvent,\n      ) => void\n    : (date: Date | null, event?: React.SyntheticEvent) => void\n}\n\n/**\n * DateInput can be used to select a specific date\n */\nexport const DateInput = <IsRange extends undefined | boolean>({\n  autoFocus = false,\n  disabled = false,\n  error,\n  format,\n  label,\n  labelDescription,\n  locale = 'en-US',\n  maxDate,\n  minDate,\n  startDate,\n  endDate,\n  name,\n  onBlur,\n  onChange,\n  placeholder,\n  onFocus,\n  required = false,\n  excludeDates,\n  value,\n  className,\n  id,\n  success,\n  helper,\n  size = 'large',\n  readOnly = false,\n  tooltip,\n  clearable,\n  selectsRange = false,\n  showMonthYearPicker = false,\n  input = 'text',\n  'data-testid': dataTestId,\n}: DateInputProps<IsRange>) => {\n  const defaultMonthToShow = useMemo(() => {\n    if (value) return new Date(value).getMonth() + 1\n    if (startDate && selectsRange) return startDate.getMonth() + 1\n    if (endDate && selectsRange) return endDate.getMonth() + 1\n\n    return new Date().getMonth() + 1\n  }, [endDate, selectsRange, startDate, value])\n\n  const defaultYearToShow = useMemo(() => {\n    if (value) return new Date(value).getFullYear()\n    if (startDate && selectsRange) return startDate.getFullYear()\n    if (endDate && selectsRange) return endDate.getFullYear()\n\n    return new Date().getFullYear()\n  }, [endDate, selectsRange, startDate, value])\n\n  const [computedValue, setValue] = useState(\n    value && !selectsRange ? new Date(value) : null,\n  )\n  const [computedRange, setRange] = useState({\n    start: startDate ?? null,\n    end: endDate ?? null,\n  })\n  const [isPopupVisible, setVisible] = useState(false)\n  const [monthToShow, setMonthToShow] = useState(defaultMonthToShow)\n  const [yearToShow, setYearToShow] = useState(defaultYearToShow)\n  const [inputValue, setInputValue] = useState(\n    formatValue(\n      computedValue,\n      computedRange,\n      showMonthYearPicker,\n      selectsRange,\n      format,\n    ),\n  )\n  const [hoveredDate, setHoveredDate] = useState<Date | null>(null)\n  const refInput = useRef<HTMLInputElement>(null)\n  const MONTHS = getMonths(locale)\n  const DAYS = getDays(locale)\n  const MONTHS_ARR = getLocalizedMonths(locale)\n\n  const valueContext = useMemo(\n    () =>\n      ({\n        showMonthYearPicker,\n        disabled,\n        readOnly,\n        value: computedValue,\n        range: computedRange,\n        setRange,\n        setValue,\n        monthToShow,\n        yearToShow,\n        setMonthToShow,\n        setYearToShow,\n        excludeDates,\n        maxDate,\n        minDate,\n        MONTHS,\n        MONTHS_ARR,\n        DAYS,\n        onChange,\n        selectsRange,\n        format,\n        setInputValue,\n        setVisible,\n        hoveredDate,\n        setHoveredDate,\n      }) as ContextProps,\n    [\n      showMonthYearPicker,\n      disabled,\n      readOnly,\n      selectsRange,\n      computedValue,\n      computedRange,\n      monthToShow,\n      yearToShow,\n      excludeDates,\n      maxDate,\n      minDate,\n      MONTHS,\n      MONTHS_ARR,\n      DAYS,\n      onChange,\n      format,\n      setInputValue,\n      setVisible,\n      hoveredDate,\n      setHoveredDate,\n    ],\n  )\n\n  useEffect(() => {\n    if (value && !selectsRange) {\n      setValue(new Date(value))\n      setInputValue(\n        formatValue(\n          new Date(value),\n          null,\n          showMonthYearPicker,\n          selectsRange,\n          format,\n        ),\n      )\n    }\n    if (selectsRange) {\n      setRange({\n        start: startDate ?? computedRange.start,\n        end: endDate ?? computedRange.end,\n      })\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [endDate, startDate, value])\n\n  const manageOnChange = (event: ChangeEvent<HTMLInputElement>) => {\n    const newValue = event.currentTarget.value\n\n    if (selectsRange) {\n      const [startDateInput, endDateInput] = newValue.split(' - ').map(val => {\n        if (showMonthYearPicker) {\n          // Force YYYY/MM (since MM/YYYY not recognised as a date in typescript)\n          const res = val.split(/\\D+/).map(aa => Number.parseInt(aa, 10))\n\n          return new Date(Math.max(...res), Math.min(...res) - 1)\n        }\n\n        return new Date(val)\n      })\n\n      const computedNewRange: [Date | null, Date | null] = [\n        startDateInput instanceof Date &&\n        !Number.isNaN(startDateInput.getTime())\n          ? startDateInput\n          : null,\n        endDateInput instanceof Date && !Number.isNaN(endDateInput.getTime())\n          ? endDateInput\n          : null,\n      ]\n\n      setRange({ start: computedNewRange[0], end: computedNewRange[1] })\n      setInputValue(newValue)\n\n      if (computedNewRange[0]) {\n        setMonthToShow(computedNewRange[0].getMonth() + 1)\n        setYearToShow(computedNewRange[0].getFullYear())\n      }\n      // TypeScript fails to automatically get the correct type of onChange here\n      ;(\n        onChange as (\n          date: Date[] | [Date | null, Date | null],\n          event: React.SyntheticEvent | undefined,\n        ) => void\n      )?.(computedNewRange, event)\n    } else {\n      const computedDate = Date.parse(newValue) ? new Date(newValue) : null\n      setInputValue(newValue)\n      setValue(computedDate)\n\n      if (computedDate) {\n        setMonthToShow(computedDate.getMonth() + 1)\n        setYearToShow(computedDate.getFullYear())\n      }\n      // TypeScript fails to automatically get the correct type of onChange here\n      ;(\n        onChange as (date: Date | null, event?: React.SyntheticEvent) => void\n      )?.(computedDate, event)\n    }\n  }\n\n  return (\n    <DateInputContext.Provider value={valueContext}>\n      <Container\n        id={id}\n        className={className}\n        data-testid={dataTestId}\n        onBlur={onBlur}\n        onFocus={onFocus}\n        onClick={() => {\n          if (!isPopupVisible) setVisible(true)\n        }}\n      >\n        {input === 'text' ? (\n          <CalendarPopup\n            visible={isPopupVisible}\n            setVisible={setVisible}\n            refInput={refInput}\n            content={<CalendarContent />}\n          >\n            <TextInputV2\n              label={label}\n              placeholder={placeholder}\n              value={inputValue}\n              required={required}\n              error={error}\n              success={success}\n              readOnly={readOnly}\n              disabled={disabled}\n              size={size}\n              autoFocus={autoFocus}\n              helper={helper}\n              labelDescription={labelDescription}\n              name={name}\n              suffix={\n                <CalendarRangeIcon\n                  size=\"medium\"\n                  sentiment=\"neutral\"\n                  disabled={disabled}\n                />\n              }\n              ref={refInput}\n              tooltip={tooltip}\n              autoComplete=\"false\"\n              onChange={manageOnChange}\n              clearable={clearable}\n            />\n          </CalendarPopup>\n        ) : (\n          <Stack gap={0.5}>\n            {labelDescription ? (\n              <Stack direction=\"row\" gap=\"1\">\n                <Text\n                  as=\"label\"\n                  variant=\"bodyStrong\"\n                  prominence=\"strong\"\n                  sentiment=\"neutral\"\n                >\n                  {label}\n                </Text>\n                {labelDescription}\n              </Stack>\n            ) : (\n              <Text\n                as=\"label\"\n                variant=\"bodyStrong\"\n                prominence=\"strong\"\n                sentiment=\"neutral\"\n              >\n                {label}\n              </Text>\n            )}\n\n            <StyledCard disabled={disabled}>\n              <CalendarContent />\n            </StyledCard>\n          </Stack>\n        )}\n      </Container>\n    </DateInputContext.Provider>\n  )\n}\n"]} */"));
43
43
  const DateInput = ({
44
44
  autoFocus = false,
45
45
  disabled = false,
@@ -67,6 +67,7 @@ const DateInput = ({
67
67
  size = "large",
68
68
  readOnly = false,
69
69
  tooltip,
70
+ clearable,
70
71
  selectsRange = false,
71
72
  showMonthYearPicker = false,
72
73
  input = "text",
@@ -158,19 +159,19 @@ const DateInput = ({
158
159
  }
159
160
  onChange?.(computedNewRange, event);
160
161
  } else {
161
- const computedDate = new Date(newValue);
162
+ const computedDate = Date.parse(newValue) ? new Date(newValue) : null;
162
163
  setInputValue(newValue);
163
- if (Date.parse(newValue)) {
164
- setValue(computedDate);
164
+ setValue(computedDate);
165
+ if (computedDate) {
165
166
  setMonthToShow(computedDate.getMonth() + 1);
166
167
  setYearToShow(computedDate.getFullYear());
167
- onChange?.(computedDate, event);
168
168
  }
169
+ onChange?.(computedDate, event);
169
170
  }
170
171
  };
171
172
  return /* @__PURE__ */ jsxRuntime.jsx(Context.DateInputContext.Provider, { value: valueContext, children: /* @__PURE__ */ jsxRuntime.jsx(Container, { id, className, "data-testid": dataTestId, onBlur, onFocus, onClick: () => {
172
173
  if (!isPopupVisible) setVisible(true);
173
- }, children: input === "text" ? /* @__PURE__ */ jsxRuntime.jsx(Popup.CalendarPopup, { visible: isPopupVisible, setVisible, refInput, content: /* @__PURE__ */ jsxRuntime.jsx(CalendarContent.CalendarContent, {}), children: /* @__PURE__ */ jsxRuntime.jsx(index.TextInputV2, { label, placeholder, value: inputValue, required, error, success, readOnly, disabled, size, autoFocus, helper, labelDescription, name, suffix: /* @__PURE__ */ jsxRuntime.jsx(Icon.CalendarRangeIcon, { size: "medium", sentiment: "neutral", disabled }), ref: refInput, tooltip, autoComplete: "false", onChange: manageOnChange }) }) : /* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { gap: 0.5, children: [
174
+ }, children: input === "text" ? /* @__PURE__ */ jsxRuntime.jsx(Popup.CalendarPopup, { visible: isPopupVisible, setVisible, refInput, content: /* @__PURE__ */ jsxRuntime.jsx(CalendarContent.CalendarContent, {}), children: /* @__PURE__ */ jsxRuntime.jsx(index.TextInputV2, { label, placeholder, value: inputValue, required, error, success, readOnly, disabled, size, autoFocus, helper, labelDescription, name, suffix: /* @__PURE__ */ jsxRuntime.jsx(Icon.CalendarRangeIcon, { size: "medium", sentiment: "neutral", disabled }), ref: refInput, tooltip, autoComplete: "false", onChange: manageOnChange, clearable }) }) : /* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { gap: 0.5, children: [
174
175
  labelDescription ? /* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { direction: "row", gap: "1", children: [
175
176
  /* @__PURE__ */ jsxRuntime.jsx(index$2.Text, { as: "label", variant: "bodyStrong", prominence: "strong", sentiment: "neutral", children: label }),
176
177
  labelDescription
@@ -27,6 +27,7 @@ type DateInputProps<IsRange extends undefined | boolean = false> = {
27
27
  size?: 'small' | 'medium' | 'large';
28
28
  readOnly?: boolean;
29
29
  tooltip?: string;
30
+ clearable?: boolean;
30
31
  showMonthYearPicker?: boolean;
31
32
  placeholder?: string;
32
33
  startDate?: Date | null;
@@ -41,5 +42,5 @@ type DateInputProps<IsRange extends undefined | boolean = false> = {
41
42
  /**
42
43
  * DateInput can be used to select a specific date
43
44
  */
44
- export declare const DateInput: <IsRange extends undefined | boolean>({ autoFocus, disabled, error, format, label, labelDescription, locale, maxDate, minDate, startDate, endDate, name, onBlur, onChange, placeholder, onFocus, required, excludeDates, value, className, id, success, helper, size, readOnly, tooltip, selectsRange, showMonthYearPicker, input, "data-testid": dataTestId, }: DateInputProps<IsRange>) => import("@emotion/react/jsx-runtime").JSX.Element;
45
+ export declare const DateInput: <IsRange extends undefined | boolean>({ autoFocus, disabled, error, format, label, labelDescription, locale, maxDate, minDate, startDate, endDate, name, onBlur, onChange, placeholder, onFocus, required, excludeDates, value, className, id, success, helper, size, readOnly, tooltip, clearable, selectsRange, showMonthYearPicker, input, "data-testid": dataTestId, }: DateInputProps<IsRange>) => import("@emotion/react/jsx-runtime").JSX.Element;
45
46
  export {};
@@ -25,7 +25,7 @@ const Container = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "produ
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/DateInput/index.tsx"],"names":[],"mappings":"AAiB4B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { CalendarRangeIcon } from '@ultraviolet/icons'\nimport type { Locale } from 'date-fns'\nimport type { ChangeEvent, FocusEvent } from 'react'\nimport { useEffect, useMemo, useRef, useState } from 'react'\nimport { Card } from '../Card'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { TextInputV2 } from '../TextInputV2'\nimport { type ContextProps, DateInputContext } from './Context'\nimport { CalendarContent } from './components/CalendarContent'\nimport { CalendarPopup } from './components/Popup'\nimport { formatValue, styleCalendarContainer } from './helpers'\nimport { getDays, getLocalizedMonths, getMonths } from './helpersLocale'\n\nconst Container = styled.div`\nwidth: 100%;`\n\nconst StyledCard = styled(Card)`\n  ${({ theme }) => styleCalendarContainer(theme)}\n  width: 16.5rem;\n\n  &[data-disabled=\"true\"] {\n      cursor: not-allowed;\n    }\n`\n\ntype DateInputProps<IsRange extends undefined | boolean = false> = {\n  autoFocus?: boolean\n  locale?: string | Locale\n  disabled?: boolean\n  maxDate?: Date | null\n  minDate?: Date | null\n  name?: string\n  onBlur?: (event: FocusEvent<HTMLInputElement>) => void\n  onFocus?: (event: FocusEvent<HTMLInputElement>) => void\n  error?: string\n  required?: boolean\n  format?: (value?: Date) => string | undefined\n  /**\n   * Label of the field\n   */\n  label?: string\n  value?: Date | null\n  className?: string\n  'data-testid'?: string\n  excludeDates?: Date[]\n  id?: string\n  labelDescription?: string\n  success?: string | boolean\n  helper?: string\n  size?: 'small' | 'medium' | 'large'\n  readOnly?: boolean\n  tooltip?: string\n  showMonthYearPicker?: boolean\n  placeholder?: string\n  startDate?: Date | null\n  endDate?: Date | null\n  /**\n   * Display the component as an input + a calendar popup (\"text\") or only as a calendar (\"calendar\")\n   */\n  input?: 'calendar' | 'text'\n  selectsRange?: IsRange\n  onChange?: IsRange extends true\n    ? (\n        date: Date[] | [Date | null, Date | null],\n        event?: React.SyntheticEvent,\n      ) => void\n    : (date: Date | null, event?: React.SyntheticEvent) => void\n}\n\n/**\n * DateInput can be used to select a specific date\n */\nexport const DateInput = <IsRange extends undefined | boolean>({\n  autoFocus = false,\n  disabled = false,\n  error,\n  format,\n  label,\n  labelDescription,\n  locale = 'en-US',\n  maxDate,\n  minDate,\n  startDate,\n  endDate,\n  name,\n  onBlur,\n  onChange,\n  placeholder,\n  onFocus,\n  required = false,\n  excludeDates,\n  value,\n  className,\n  id,\n  success,\n  helper,\n  size = 'large',\n  readOnly = false,\n  tooltip,\n  selectsRange = false,\n  showMonthYearPicker = false,\n  input = 'text',\n  'data-testid': dataTestId,\n}: DateInputProps<IsRange>) => {\n  const defaultMonthToShow = useMemo(() => {\n    if (value) return new Date(value).getMonth() + 1\n    if (startDate && selectsRange) return startDate.getMonth() + 1\n    if (endDate && selectsRange) return endDate.getMonth() + 1\n\n    return new Date().getMonth() + 1\n  }, [endDate, selectsRange, startDate, value])\n\n  const defaultYearToShow = useMemo(() => {\n    if (value) return new Date(value).getFullYear()\n    if (startDate && selectsRange) return startDate.getFullYear()\n    if (endDate && selectsRange) return endDate.getFullYear()\n\n    return new Date().getFullYear()\n  }, [endDate, selectsRange, startDate, value])\n\n  const [computedValue, setValue] = useState(\n    value && !selectsRange ? new Date(value) : null,\n  )\n  const [computedRange, setRange] = useState({\n    start: startDate ?? null,\n    end: endDate ?? null,\n  })\n  const [isPopupVisible, setVisible] = useState(false)\n  const [monthToShow, setMonthToShow] = useState(defaultMonthToShow)\n  const [yearToShow, setYearToShow] = useState(defaultYearToShow)\n  const [inputValue, setInputValue] = useState(\n    formatValue(\n      computedValue,\n      computedRange,\n      showMonthYearPicker,\n      selectsRange,\n      format,\n    ),\n  )\n  const [hoveredDate, setHoveredDate] = useState<Date | null>(null)\n  const refInput = useRef<HTMLInputElement>(null)\n  const MONTHS = getMonths(locale)\n  const DAYS = getDays(locale)\n  const MONTHS_ARR = getLocalizedMonths(locale)\n\n  const valueContext = useMemo(\n    () =>\n      ({\n        showMonthYearPicker,\n        disabled,\n        readOnly,\n        value: computedValue,\n        range: computedRange,\n        setRange,\n        setValue,\n        monthToShow,\n        yearToShow,\n        setMonthToShow,\n        setYearToShow,\n        excludeDates,\n        maxDate,\n        minDate,\n        MONTHS,\n        MONTHS_ARR,\n        DAYS,\n        onChange,\n        selectsRange,\n        format,\n        setInputValue,\n        setVisible,\n        hoveredDate,\n        setHoveredDate,\n      }) as ContextProps,\n    [\n      showMonthYearPicker,\n      disabled,\n      readOnly,\n      selectsRange,\n      computedValue,\n      computedRange,\n      monthToShow,\n      yearToShow,\n      excludeDates,\n      maxDate,\n      minDate,\n      MONTHS,\n      MONTHS_ARR,\n      DAYS,\n      onChange,\n      format,\n      setInputValue,\n      setVisible,\n      hoveredDate,\n      setHoveredDate,\n    ],\n  )\n\n  useEffect(() => {\n    if (value && !selectsRange) {\n      setValue(new Date(value))\n      setInputValue(\n        formatValue(\n          new Date(value),\n          null,\n          showMonthYearPicker,\n          selectsRange,\n          format,\n        ),\n      )\n    }\n    if (selectsRange) {\n      setRange({\n        start: startDate ?? computedRange.start,\n        end: endDate ?? computedRange.end,\n      })\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [endDate, startDate, value])\n\n  const manageOnChange = (event: ChangeEvent<HTMLInputElement>) => {\n    const newValue = event.currentTarget.value\n\n    if (selectsRange) {\n      const [startDateInput, endDateInput] = newValue.split(' - ').map(val => {\n        if (showMonthYearPicker) {\n          // Force YYYY/MM (since MM/YYYY not recognised as a date in typescript)\n          const res = val.split(/\\D+/).map(aa => Number.parseInt(aa, 10))\n\n          return new Date(Math.max(...res), Math.min(...res) - 1)\n        }\n\n        return new Date(val)\n      })\n\n      const computedNewRange: [Date | null, Date | null] = [\n        startDateInput instanceof Date &&\n        !Number.isNaN(startDateInput.getTime())\n          ? startDateInput\n          : null,\n        endDateInput instanceof Date && !Number.isNaN(endDateInput.getTime())\n          ? endDateInput\n          : null,\n      ]\n\n      setRange({ start: computedNewRange[0], end: computedNewRange[1] })\n      setInputValue(newValue)\n\n      if (computedNewRange[0]) {\n        setMonthToShow(computedNewRange[0].getMonth() + 1)\n        setYearToShow(computedNewRange[0].getFullYear())\n      }\n      // TypeScript fails to automatically get the correct type of onChange here\n      ;(\n        onChange as (\n          date: Date[] | [Date | null, Date | null],\n          event: React.SyntheticEvent | undefined,\n        ) => void\n      )?.(computedNewRange, event)\n    } else {\n      const computedDate = new Date(newValue)\n      setInputValue(newValue)\n\n      if (Date.parse(newValue)) {\n        setValue(computedDate)\n        setMonthToShow(computedDate.getMonth() + 1)\n        setYearToShow(computedDate.getFullYear())\n\n        // TypeScript fails to automatically get the correct type of onChange here\n        ;(\n          onChange as (date: Date | null, event?: React.SyntheticEvent) => void\n        )?.(computedDate, event)\n      }\n    }\n  }\n\n  return (\n    <DateInputContext.Provider value={valueContext}>\n      <Container\n        id={id}\n        className={className}\n        data-testid={dataTestId}\n        onBlur={onBlur}\n        onFocus={onFocus}\n        onClick={() => {\n          if (!isPopupVisible) setVisible(true)\n        }}\n      >\n        {input === 'text' ? (\n          <CalendarPopup\n            visible={isPopupVisible}\n            setVisible={setVisible}\n            refInput={refInput}\n            content={<CalendarContent />}\n          >\n            <TextInputV2\n              label={label}\n              placeholder={placeholder}\n              value={inputValue}\n              required={required}\n              error={error}\n              success={success}\n              readOnly={readOnly}\n              disabled={disabled}\n              size={size}\n              autoFocus={autoFocus}\n              helper={helper}\n              labelDescription={labelDescription}\n              name={name}\n              suffix={\n                <CalendarRangeIcon\n                  size=\"medium\"\n                  sentiment=\"neutral\"\n                  disabled={disabled}\n                />\n              }\n              ref={refInput}\n              tooltip={tooltip}\n              autoComplete=\"false\"\n              onChange={manageOnChange}\n            />\n          </CalendarPopup>\n        ) : (\n          <Stack gap={0.5}>\n            {labelDescription ? (\n              <Stack direction=\"row\" gap=\"1\">\n                <Text\n                  as=\"label\"\n                  variant=\"bodyStrong\"\n                  prominence=\"strong\"\n                  sentiment=\"neutral\"\n                >\n                  {label}\n                </Text>\n                {labelDescription}\n              </Stack>\n            ) : (\n              <Text\n                as=\"label\"\n                variant=\"bodyStrong\"\n                prominence=\"strong\"\n                sentiment=\"neutral\"\n              >\n                {label}\n              </Text>\n            )}\n\n            <StyledCard disabled={disabled}>\n              <CalendarContent />\n            </StyledCard>\n          </Stack>\n        )}\n      </Container>\n    </DateInputContext.Provider>\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/DateInput/index.tsx"],"names":[],"mappings":"AAiB4B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { CalendarRangeIcon } from '@ultraviolet/icons'\nimport type { Locale } from 'date-fns'\nimport type { ChangeEvent, FocusEvent } from 'react'\nimport { useEffect, useMemo, useRef, useState } from 'react'\nimport { Card } from '../Card'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { TextInputV2 } from '../TextInputV2'\nimport { type ContextProps, DateInputContext } from './Context'\nimport { CalendarContent } from './components/CalendarContent'\nimport { CalendarPopup } from './components/Popup'\nimport { formatValue, styleCalendarContainer } from './helpers'\nimport { getDays, getLocalizedMonths, getMonths } from './helpersLocale'\n\nconst Container = styled.div`\nwidth: 100%;`\n\nconst StyledCard = styled(Card)`\n  ${({ theme }) => styleCalendarContainer(theme)}\n  width: 16.5rem;\n\n  &[data-disabled=\"true\"] {\n      cursor: not-allowed;\n    }\n`\n\ntype DateInputProps<IsRange extends undefined | boolean = false> = {\n  autoFocus?: boolean\n  locale?: string | Locale\n  disabled?: boolean\n  maxDate?: Date | null\n  minDate?: Date | null\n  name?: string\n  onBlur?: (event: FocusEvent<HTMLInputElement>) => void\n  onFocus?: (event: FocusEvent<HTMLInputElement>) => void\n  error?: string\n  required?: boolean\n  format?: (value?: Date) => string | undefined\n  /**\n   * Label of the field\n   */\n  label?: string\n  value?: Date | null\n  className?: string\n  'data-testid'?: string\n  excludeDates?: Date[]\n  id?: string\n  labelDescription?: string\n  success?: string | boolean\n  helper?: string\n  size?: 'small' | 'medium' | 'large'\n  readOnly?: boolean\n  tooltip?: string\n  clearable?: boolean\n  showMonthYearPicker?: boolean\n  placeholder?: string\n  startDate?: Date | null\n  endDate?: Date | null\n  /**\n   * Display the component as an input + a calendar popup (\"text\") or only as a calendar (\"calendar\")\n   */\n  input?: 'calendar' | 'text'\n  selectsRange?: IsRange\n  onChange?: IsRange extends true\n    ? (\n        date: Date[] | [Date | null, Date | null],\n        event?: React.SyntheticEvent,\n      ) => void\n    : (date: Date | null, event?: React.SyntheticEvent) => void\n}\n\n/**\n * DateInput can be used to select a specific date\n */\nexport const DateInput = <IsRange extends undefined | boolean>({\n  autoFocus = false,\n  disabled = false,\n  error,\n  format,\n  label,\n  labelDescription,\n  locale = 'en-US',\n  maxDate,\n  minDate,\n  startDate,\n  endDate,\n  name,\n  onBlur,\n  onChange,\n  placeholder,\n  onFocus,\n  required = false,\n  excludeDates,\n  value,\n  className,\n  id,\n  success,\n  helper,\n  size = 'large',\n  readOnly = false,\n  tooltip,\n  clearable,\n  selectsRange = false,\n  showMonthYearPicker = false,\n  input = 'text',\n  'data-testid': dataTestId,\n}: DateInputProps<IsRange>) => {\n  const defaultMonthToShow = useMemo(() => {\n    if (value) return new Date(value).getMonth() + 1\n    if (startDate && selectsRange) return startDate.getMonth() + 1\n    if (endDate && selectsRange) return endDate.getMonth() + 1\n\n    return new Date().getMonth() + 1\n  }, [endDate, selectsRange, startDate, value])\n\n  const defaultYearToShow = useMemo(() => {\n    if (value) return new Date(value).getFullYear()\n    if (startDate && selectsRange) return startDate.getFullYear()\n    if (endDate && selectsRange) return endDate.getFullYear()\n\n    return new Date().getFullYear()\n  }, [endDate, selectsRange, startDate, value])\n\n  const [computedValue, setValue] = useState(\n    value && !selectsRange ? new Date(value) : null,\n  )\n  const [computedRange, setRange] = useState({\n    start: startDate ?? null,\n    end: endDate ?? null,\n  })\n  const [isPopupVisible, setVisible] = useState(false)\n  const [monthToShow, setMonthToShow] = useState(defaultMonthToShow)\n  const [yearToShow, setYearToShow] = useState(defaultYearToShow)\n  const [inputValue, setInputValue] = useState(\n    formatValue(\n      computedValue,\n      computedRange,\n      showMonthYearPicker,\n      selectsRange,\n      format,\n    ),\n  )\n  const [hoveredDate, setHoveredDate] = useState<Date | null>(null)\n  const refInput = useRef<HTMLInputElement>(null)\n  const MONTHS = getMonths(locale)\n  const DAYS = getDays(locale)\n  const MONTHS_ARR = getLocalizedMonths(locale)\n\n  const valueContext = useMemo(\n    () =>\n      ({\n        showMonthYearPicker,\n        disabled,\n        readOnly,\n        value: computedValue,\n        range: computedRange,\n        setRange,\n        setValue,\n        monthToShow,\n        yearToShow,\n        setMonthToShow,\n        setYearToShow,\n        excludeDates,\n        maxDate,\n        minDate,\n        MONTHS,\n        MONTHS_ARR,\n        DAYS,\n        onChange,\n        selectsRange,\n        format,\n        setInputValue,\n        setVisible,\n        hoveredDate,\n        setHoveredDate,\n      }) as ContextProps,\n    [\n      showMonthYearPicker,\n      disabled,\n      readOnly,\n      selectsRange,\n      computedValue,\n      computedRange,\n      monthToShow,\n      yearToShow,\n      excludeDates,\n      maxDate,\n      minDate,\n      MONTHS,\n      MONTHS_ARR,\n      DAYS,\n      onChange,\n      format,\n      setInputValue,\n      setVisible,\n      hoveredDate,\n      setHoveredDate,\n    ],\n  )\n\n  useEffect(() => {\n    if (value && !selectsRange) {\n      setValue(new Date(value))\n      setInputValue(\n        formatValue(\n          new Date(value),\n          null,\n          showMonthYearPicker,\n          selectsRange,\n          format,\n        ),\n      )\n    }\n    if (selectsRange) {\n      setRange({\n        start: startDate ?? computedRange.start,\n        end: endDate ?? computedRange.end,\n      })\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [endDate, startDate, value])\n\n  const manageOnChange = (event: ChangeEvent<HTMLInputElement>) => {\n    const newValue = event.currentTarget.value\n\n    if (selectsRange) {\n      const [startDateInput, endDateInput] = newValue.split(' - ').map(val => {\n        if (showMonthYearPicker) {\n          // Force YYYY/MM (since MM/YYYY not recognised as a date in typescript)\n          const res = val.split(/\\D+/).map(aa => Number.parseInt(aa, 10))\n\n          return new Date(Math.max(...res), Math.min(...res) - 1)\n        }\n\n        return new Date(val)\n      })\n\n      const computedNewRange: [Date | null, Date | null] = [\n        startDateInput instanceof Date &&\n        !Number.isNaN(startDateInput.getTime())\n          ? startDateInput\n          : null,\n        endDateInput instanceof Date && !Number.isNaN(endDateInput.getTime())\n          ? endDateInput\n          : null,\n      ]\n\n      setRange({ start: computedNewRange[0], end: computedNewRange[1] })\n      setInputValue(newValue)\n\n      if (computedNewRange[0]) {\n        setMonthToShow(computedNewRange[0].getMonth() + 1)\n        setYearToShow(computedNewRange[0].getFullYear())\n      }\n      // TypeScript fails to automatically get the correct type of onChange here\n      ;(\n        onChange as (\n          date: Date[] | [Date | null, Date | null],\n          event: React.SyntheticEvent | undefined,\n        ) => void\n      )?.(computedNewRange, event)\n    } else {\n      const computedDate = Date.parse(newValue) ? new Date(newValue) : null\n      setInputValue(newValue)\n      setValue(computedDate)\n\n      if (computedDate) {\n        setMonthToShow(computedDate.getMonth() + 1)\n        setYearToShow(computedDate.getFullYear())\n      }\n      // TypeScript fails to automatically get the correct type of onChange here\n      ;(\n        onChange as (date: Date | null, event?: React.SyntheticEvent) => void\n      )?.(computedDate, event)\n    }\n  }\n\n  return (\n    <DateInputContext.Provider value={valueContext}>\n      <Container\n        id={id}\n        className={className}\n        data-testid={dataTestId}\n        onBlur={onBlur}\n        onFocus={onFocus}\n        onClick={() => {\n          if (!isPopupVisible) setVisible(true)\n        }}\n      >\n        {input === 'text' ? (\n          <CalendarPopup\n            visible={isPopupVisible}\n            setVisible={setVisible}\n            refInput={refInput}\n            content={<CalendarContent />}\n          >\n            <TextInputV2\n              label={label}\n              placeholder={placeholder}\n              value={inputValue}\n              required={required}\n              error={error}\n              success={success}\n              readOnly={readOnly}\n              disabled={disabled}\n              size={size}\n              autoFocus={autoFocus}\n              helper={helper}\n              labelDescription={labelDescription}\n              name={name}\n              suffix={\n                <CalendarRangeIcon\n                  size=\"medium\"\n                  sentiment=\"neutral\"\n                  disabled={disabled}\n                />\n              }\n              ref={refInput}\n              tooltip={tooltip}\n              autoComplete=\"false\"\n              onChange={manageOnChange}\n              clearable={clearable}\n            />\n          </CalendarPopup>\n        ) : (\n          <Stack gap={0.5}>\n            {labelDescription ? (\n              <Stack direction=\"row\" gap=\"1\">\n                <Text\n                  as=\"label\"\n                  variant=\"bodyStrong\"\n                  prominence=\"strong\"\n                  sentiment=\"neutral\"\n                >\n                  {label}\n                </Text>\n                {labelDescription}\n              </Stack>\n            ) : (\n              <Text\n                as=\"label\"\n                variant=\"bodyStrong\"\n                prominence=\"strong\"\n                sentiment=\"neutral\"\n              >\n                {label}\n              </Text>\n            )}\n\n            <StyledCard disabled={disabled}>\n              <CalendarContent />\n            </StyledCard>\n          </Stack>\n        )}\n      </Container>\n    </DateInputContext.Provider>\n  )\n}\n"]} */",
29
29
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
30
30
  });
31
31
  const StyledCard = /* @__PURE__ */ _styled(Card, process.env.NODE_ENV === "production" ? {
@@ -35,7 +35,7 @@ const StyledCard = /* @__PURE__ */ _styled(Card, process.env.NODE_ENV === "produ
35
35
  label: "StyledCard"
36
36
  })(({
37
37
  theme
38
- }) => styleCalendarContainer(theme), ' width:16.5rem;&[data-disabled="true"]{cursor:not-allowed;}' + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx"],"names":[],"mappings":"AAoB+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { CalendarRangeIcon } from '@ultraviolet/icons'\nimport type { Locale } from 'date-fns'\nimport type { ChangeEvent, FocusEvent } from 'react'\nimport { useEffect, useMemo, useRef, useState } from 'react'\nimport { Card } from '../Card'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { TextInputV2 } from '../TextInputV2'\nimport { type ContextProps, DateInputContext } from './Context'\nimport { CalendarContent } from './components/CalendarContent'\nimport { CalendarPopup } from './components/Popup'\nimport { formatValue, styleCalendarContainer } from './helpers'\nimport { getDays, getLocalizedMonths, getMonths } from './helpersLocale'\n\nconst Container = styled.div`\nwidth: 100%;`\n\nconst StyledCard = styled(Card)`\n  ${({ theme }) => styleCalendarContainer(theme)}\n  width: 16.5rem;\n\n  &[data-disabled=\"true\"] {\n      cursor: not-allowed;\n    }\n`\n\ntype DateInputProps<IsRange extends undefined | boolean = false> = {\n  autoFocus?: boolean\n  locale?: string | Locale\n  disabled?: boolean\n  maxDate?: Date | null\n  minDate?: Date | null\n  name?: string\n  onBlur?: (event: FocusEvent<HTMLInputElement>) => void\n  onFocus?: (event: FocusEvent<HTMLInputElement>) => void\n  error?: string\n  required?: boolean\n  format?: (value?: Date) => string | undefined\n  /**\n   * Label of the field\n   */\n  label?: string\n  value?: Date | null\n  className?: string\n  'data-testid'?: string\n  excludeDates?: Date[]\n  id?: string\n  labelDescription?: string\n  success?: string | boolean\n  helper?: string\n  size?: 'small' | 'medium' | 'large'\n  readOnly?: boolean\n  tooltip?: string\n  showMonthYearPicker?: boolean\n  placeholder?: string\n  startDate?: Date | null\n  endDate?: Date | null\n  /**\n   * Display the component as an input + a calendar popup (\"text\") or only as a calendar (\"calendar\")\n   */\n  input?: 'calendar' | 'text'\n  selectsRange?: IsRange\n  onChange?: IsRange extends true\n    ? (\n        date: Date[] | [Date | null, Date | null],\n        event?: React.SyntheticEvent,\n      ) => void\n    : (date: Date | null, event?: React.SyntheticEvent) => void\n}\n\n/**\n * DateInput can be used to select a specific date\n */\nexport const DateInput = <IsRange extends undefined | boolean>({\n  autoFocus = false,\n  disabled = false,\n  error,\n  format,\n  label,\n  labelDescription,\n  locale = 'en-US',\n  maxDate,\n  minDate,\n  startDate,\n  endDate,\n  name,\n  onBlur,\n  onChange,\n  placeholder,\n  onFocus,\n  required = false,\n  excludeDates,\n  value,\n  className,\n  id,\n  success,\n  helper,\n  size = 'large',\n  readOnly = false,\n  tooltip,\n  selectsRange = false,\n  showMonthYearPicker = false,\n  input = 'text',\n  'data-testid': dataTestId,\n}: DateInputProps<IsRange>) => {\n  const defaultMonthToShow = useMemo(() => {\n    if (value) return new Date(value).getMonth() + 1\n    if (startDate && selectsRange) return startDate.getMonth() + 1\n    if (endDate && selectsRange) return endDate.getMonth() + 1\n\n    return new Date().getMonth() + 1\n  }, [endDate, selectsRange, startDate, value])\n\n  const defaultYearToShow = useMemo(() => {\n    if (value) return new Date(value).getFullYear()\n    if (startDate && selectsRange) return startDate.getFullYear()\n    if (endDate && selectsRange) return endDate.getFullYear()\n\n    return new Date().getFullYear()\n  }, [endDate, selectsRange, startDate, value])\n\n  const [computedValue, setValue] = useState(\n    value && !selectsRange ? new Date(value) : null,\n  )\n  const [computedRange, setRange] = useState({\n    start: startDate ?? null,\n    end: endDate ?? null,\n  })\n  const [isPopupVisible, setVisible] = useState(false)\n  const [monthToShow, setMonthToShow] = useState(defaultMonthToShow)\n  const [yearToShow, setYearToShow] = useState(defaultYearToShow)\n  const [inputValue, setInputValue] = useState(\n    formatValue(\n      computedValue,\n      computedRange,\n      showMonthYearPicker,\n      selectsRange,\n      format,\n    ),\n  )\n  const [hoveredDate, setHoveredDate] = useState<Date | null>(null)\n  const refInput = useRef<HTMLInputElement>(null)\n  const MONTHS = getMonths(locale)\n  const DAYS = getDays(locale)\n  const MONTHS_ARR = getLocalizedMonths(locale)\n\n  const valueContext = useMemo(\n    () =>\n      ({\n        showMonthYearPicker,\n        disabled,\n        readOnly,\n        value: computedValue,\n        range: computedRange,\n        setRange,\n        setValue,\n        monthToShow,\n        yearToShow,\n        setMonthToShow,\n        setYearToShow,\n        excludeDates,\n        maxDate,\n        minDate,\n        MONTHS,\n        MONTHS_ARR,\n        DAYS,\n        onChange,\n        selectsRange,\n        format,\n        setInputValue,\n        setVisible,\n        hoveredDate,\n        setHoveredDate,\n      }) as ContextProps,\n    [\n      showMonthYearPicker,\n      disabled,\n      readOnly,\n      selectsRange,\n      computedValue,\n      computedRange,\n      monthToShow,\n      yearToShow,\n      excludeDates,\n      maxDate,\n      minDate,\n      MONTHS,\n      MONTHS_ARR,\n      DAYS,\n      onChange,\n      format,\n      setInputValue,\n      setVisible,\n      hoveredDate,\n      setHoveredDate,\n    ],\n  )\n\n  useEffect(() => {\n    if (value && !selectsRange) {\n      setValue(new Date(value))\n      setInputValue(\n        formatValue(\n          new Date(value),\n          null,\n          showMonthYearPicker,\n          selectsRange,\n          format,\n        ),\n      )\n    }\n    if (selectsRange) {\n      setRange({\n        start: startDate ?? computedRange.start,\n        end: endDate ?? computedRange.end,\n      })\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [endDate, startDate, value])\n\n  const manageOnChange = (event: ChangeEvent<HTMLInputElement>) => {\n    const newValue = event.currentTarget.value\n\n    if (selectsRange) {\n      const [startDateInput, endDateInput] = newValue.split(' - ').map(val => {\n        if (showMonthYearPicker) {\n          // Force YYYY/MM (since MM/YYYY not recognised as a date in typescript)\n          const res = val.split(/\\D+/).map(aa => Number.parseInt(aa, 10))\n\n          return new Date(Math.max(...res), Math.min(...res) - 1)\n        }\n\n        return new Date(val)\n      })\n\n      const computedNewRange: [Date | null, Date | null] = [\n        startDateInput instanceof Date &&\n        !Number.isNaN(startDateInput.getTime())\n          ? startDateInput\n          : null,\n        endDateInput instanceof Date && !Number.isNaN(endDateInput.getTime())\n          ? endDateInput\n          : null,\n      ]\n\n      setRange({ start: computedNewRange[0], end: computedNewRange[1] })\n      setInputValue(newValue)\n\n      if (computedNewRange[0]) {\n        setMonthToShow(computedNewRange[0].getMonth() + 1)\n        setYearToShow(computedNewRange[0].getFullYear())\n      }\n      // TypeScript fails to automatically get the correct type of onChange here\n      ;(\n        onChange as (\n          date: Date[] | [Date | null, Date | null],\n          event: React.SyntheticEvent | undefined,\n        ) => void\n      )?.(computedNewRange, event)\n    } else {\n      const computedDate = new Date(newValue)\n      setInputValue(newValue)\n\n      if (Date.parse(newValue)) {\n        setValue(computedDate)\n        setMonthToShow(computedDate.getMonth() + 1)\n        setYearToShow(computedDate.getFullYear())\n\n        // TypeScript fails to automatically get the correct type of onChange here\n        ;(\n          onChange as (date: Date | null, event?: React.SyntheticEvent) => void\n        )?.(computedDate, event)\n      }\n    }\n  }\n\n  return (\n    <DateInputContext.Provider value={valueContext}>\n      <Container\n        id={id}\n        className={className}\n        data-testid={dataTestId}\n        onBlur={onBlur}\n        onFocus={onFocus}\n        onClick={() => {\n          if (!isPopupVisible) setVisible(true)\n        }}\n      >\n        {input === 'text' ? (\n          <CalendarPopup\n            visible={isPopupVisible}\n            setVisible={setVisible}\n            refInput={refInput}\n            content={<CalendarContent />}\n          >\n            <TextInputV2\n              label={label}\n              placeholder={placeholder}\n              value={inputValue}\n              required={required}\n              error={error}\n              success={success}\n              readOnly={readOnly}\n              disabled={disabled}\n              size={size}\n              autoFocus={autoFocus}\n              helper={helper}\n              labelDescription={labelDescription}\n              name={name}\n              suffix={\n                <CalendarRangeIcon\n                  size=\"medium\"\n                  sentiment=\"neutral\"\n                  disabled={disabled}\n                />\n              }\n              ref={refInput}\n              tooltip={tooltip}\n              autoComplete=\"false\"\n              onChange={manageOnChange}\n            />\n          </CalendarPopup>\n        ) : (\n          <Stack gap={0.5}>\n            {labelDescription ? (\n              <Stack direction=\"row\" gap=\"1\">\n                <Text\n                  as=\"label\"\n                  variant=\"bodyStrong\"\n                  prominence=\"strong\"\n                  sentiment=\"neutral\"\n                >\n                  {label}\n                </Text>\n                {labelDescription}\n              </Stack>\n            ) : (\n              <Text\n                as=\"label\"\n                variant=\"bodyStrong\"\n                prominence=\"strong\"\n                sentiment=\"neutral\"\n              >\n                {label}\n              </Text>\n            )}\n\n            <StyledCard disabled={disabled}>\n              <CalendarContent />\n            </StyledCard>\n          </Stack>\n        )}\n      </Container>\n    </DateInputContext.Provider>\n  )\n}\n"]} */"));
38
+ }) => styleCalendarContainer(theme), ' width:16.5rem;&[data-disabled="true"]{cursor:not-allowed;}' + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx"],"names":[],"mappings":"AAoB+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { CalendarRangeIcon } from '@ultraviolet/icons'\nimport type { Locale } from 'date-fns'\nimport type { ChangeEvent, FocusEvent } from 'react'\nimport { useEffect, useMemo, useRef, useState } from 'react'\nimport { Card } from '../Card'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { TextInputV2 } from '../TextInputV2'\nimport { type ContextProps, DateInputContext } from './Context'\nimport { CalendarContent } from './components/CalendarContent'\nimport { CalendarPopup } from './components/Popup'\nimport { formatValue, styleCalendarContainer } from './helpers'\nimport { getDays, getLocalizedMonths, getMonths } from './helpersLocale'\n\nconst Container = styled.div`\nwidth: 100%;`\n\nconst StyledCard = styled(Card)`\n  ${({ theme }) => styleCalendarContainer(theme)}\n  width: 16.5rem;\n\n  &[data-disabled=\"true\"] {\n      cursor: not-allowed;\n    }\n`\n\ntype DateInputProps<IsRange extends undefined | boolean = false> = {\n  autoFocus?: boolean\n  locale?: string | Locale\n  disabled?: boolean\n  maxDate?: Date | null\n  minDate?: Date | null\n  name?: string\n  onBlur?: (event: FocusEvent<HTMLInputElement>) => void\n  onFocus?: (event: FocusEvent<HTMLInputElement>) => void\n  error?: string\n  required?: boolean\n  format?: (value?: Date) => string | undefined\n  /**\n   * Label of the field\n   */\n  label?: string\n  value?: Date | null\n  className?: string\n  'data-testid'?: string\n  excludeDates?: Date[]\n  id?: string\n  labelDescription?: string\n  success?: string | boolean\n  helper?: string\n  size?: 'small' | 'medium' | 'large'\n  readOnly?: boolean\n  tooltip?: string\n  clearable?: boolean\n  showMonthYearPicker?: boolean\n  placeholder?: string\n  startDate?: Date | null\n  endDate?: Date | null\n  /**\n   * Display the component as an input + a calendar popup (\"text\") or only as a calendar (\"calendar\")\n   */\n  input?: 'calendar' | 'text'\n  selectsRange?: IsRange\n  onChange?: IsRange extends true\n    ? (\n        date: Date[] | [Date | null, Date | null],\n        event?: React.SyntheticEvent,\n      ) => void\n    : (date: Date | null, event?: React.SyntheticEvent) => void\n}\n\n/**\n * DateInput can be used to select a specific date\n */\nexport const DateInput = <IsRange extends undefined | boolean>({\n  autoFocus = false,\n  disabled = false,\n  error,\n  format,\n  label,\n  labelDescription,\n  locale = 'en-US',\n  maxDate,\n  minDate,\n  startDate,\n  endDate,\n  name,\n  onBlur,\n  onChange,\n  placeholder,\n  onFocus,\n  required = false,\n  excludeDates,\n  value,\n  className,\n  id,\n  success,\n  helper,\n  size = 'large',\n  readOnly = false,\n  tooltip,\n  clearable,\n  selectsRange = false,\n  showMonthYearPicker = false,\n  input = 'text',\n  'data-testid': dataTestId,\n}: DateInputProps<IsRange>) => {\n  const defaultMonthToShow = useMemo(() => {\n    if (value) return new Date(value).getMonth() + 1\n    if (startDate && selectsRange) return startDate.getMonth() + 1\n    if (endDate && selectsRange) return endDate.getMonth() + 1\n\n    return new Date().getMonth() + 1\n  }, [endDate, selectsRange, startDate, value])\n\n  const defaultYearToShow = useMemo(() => {\n    if (value) return new Date(value).getFullYear()\n    if (startDate && selectsRange) return startDate.getFullYear()\n    if (endDate && selectsRange) return endDate.getFullYear()\n\n    return new Date().getFullYear()\n  }, [endDate, selectsRange, startDate, value])\n\n  const [computedValue, setValue] = useState(\n    value && !selectsRange ? new Date(value) : null,\n  )\n  const [computedRange, setRange] = useState({\n    start: startDate ?? null,\n    end: endDate ?? null,\n  })\n  const [isPopupVisible, setVisible] = useState(false)\n  const [monthToShow, setMonthToShow] = useState(defaultMonthToShow)\n  const [yearToShow, setYearToShow] = useState(defaultYearToShow)\n  const [inputValue, setInputValue] = useState(\n    formatValue(\n      computedValue,\n      computedRange,\n      showMonthYearPicker,\n      selectsRange,\n      format,\n    ),\n  )\n  const [hoveredDate, setHoveredDate] = useState<Date | null>(null)\n  const refInput = useRef<HTMLInputElement>(null)\n  const MONTHS = getMonths(locale)\n  const DAYS = getDays(locale)\n  const MONTHS_ARR = getLocalizedMonths(locale)\n\n  const valueContext = useMemo(\n    () =>\n      ({\n        showMonthYearPicker,\n        disabled,\n        readOnly,\n        value: computedValue,\n        range: computedRange,\n        setRange,\n        setValue,\n        monthToShow,\n        yearToShow,\n        setMonthToShow,\n        setYearToShow,\n        excludeDates,\n        maxDate,\n        minDate,\n        MONTHS,\n        MONTHS_ARR,\n        DAYS,\n        onChange,\n        selectsRange,\n        format,\n        setInputValue,\n        setVisible,\n        hoveredDate,\n        setHoveredDate,\n      }) as ContextProps,\n    [\n      showMonthYearPicker,\n      disabled,\n      readOnly,\n      selectsRange,\n      computedValue,\n      computedRange,\n      monthToShow,\n      yearToShow,\n      excludeDates,\n      maxDate,\n      minDate,\n      MONTHS,\n      MONTHS_ARR,\n      DAYS,\n      onChange,\n      format,\n      setInputValue,\n      setVisible,\n      hoveredDate,\n      setHoveredDate,\n    ],\n  )\n\n  useEffect(() => {\n    if (value && !selectsRange) {\n      setValue(new Date(value))\n      setInputValue(\n        formatValue(\n          new Date(value),\n          null,\n          showMonthYearPicker,\n          selectsRange,\n          format,\n        ),\n      )\n    }\n    if (selectsRange) {\n      setRange({\n        start: startDate ?? computedRange.start,\n        end: endDate ?? computedRange.end,\n      })\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [endDate, startDate, value])\n\n  const manageOnChange = (event: ChangeEvent<HTMLInputElement>) => {\n    const newValue = event.currentTarget.value\n\n    if (selectsRange) {\n      const [startDateInput, endDateInput] = newValue.split(' - ').map(val => {\n        if (showMonthYearPicker) {\n          // Force YYYY/MM (since MM/YYYY not recognised as a date in typescript)\n          const res = val.split(/\\D+/).map(aa => Number.parseInt(aa, 10))\n\n          return new Date(Math.max(...res), Math.min(...res) - 1)\n        }\n\n        return new Date(val)\n      })\n\n      const computedNewRange: [Date | null, Date | null] = [\n        startDateInput instanceof Date &&\n        !Number.isNaN(startDateInput.getTime())\n          ? startDateInput\n          : null,\n        endDateInput instanceof Date && !Number.isNaN(endDateInput.getTime())\n          ? endDateInput\n          : null,\n      ]\n\n      setRange({ start: computedNewRange[0], end: computedNewRange[1] })\n      setInputValue(newValue)\n\n      if (computedNewRange[0]) {\n        setMonthToShow(computedNewRange[0].getMonth() + 1)\n        setYearToShow(computedNewRange[0].getFullYear())\n      }\n      // TypeScript fails to automatically get the correct type of onChange here\n      ;(\n        onChange as (\n          date: Date[] | [Date | null, Date | null],\n          event: React.SyntheticEvent | undefined,\n        ) => void\n      )?.(computedNewRange, event)\n    } else {\n      const computedDate = Date.parse(newValue) ? new Date(newValue) : null\n      setInputValue(newValue)\n      setValue(computedDate)\n\n      if (computedDate) {\n        setMonthToShow(computedDate.getMonth() + 1)\n        setYearToShow(computedDate.getFullYear())\n      }\n      // TypeScript fails to automatically get the correct type of onChange here\n      ;(\n        onChange as (date: Date | null, event?: React.SyntheticEvent) => void\n      )?.(computedDate, event)\n    }\n  }\n\n  return (\n    <DateInputContext.Provider value={valueContext}>\n      <Container\n        id={id}\n        className={className}\n        data-testid={dataTestId}\n        onBlur={onBlur}\n        onFocus={onFocus}\n        onClick={() => {\n          if (!isPopupVisible) setVisible(true)\n        }}\n      >\n        {input === 'text' ? (\n          <CalendarPopup\n            visible={isPopupVisible}\n            setVisible={setVisible}\n            refInput={refInput}\n            content={<CalendarContent />}\n          >\n            <TextInputV2\n              label={label}\n              placeholder={placeholder}\n              value={inputValue}\n              required={required}\n              error={error}\n              success={success}\n              readOnly={readOnly}\n              disabled={disabled}\n              size={size}\n              autoFocus={autoFocus}\n              helper={helper}\n              labelDescription={labelDescription}\n              name={name}\n              suffix={\n                <CalendarRangeIcon\n                  size=\"medium\"\n                  sentiment=\"neutral\"\n                  disabled={disabled}\n                />\n              }\n              ref={refInput}\n              tooltip={tooltip}\n              autoComplete=\"false\"\n              onChange={manageOnChange}\n              clearable={clearable}\n            />\n          </CalendarPopup>\n        ) : (\n          <Stack gap={0.5}>\n            {labelDescription ? (\n              <Stack direction=\"row\" gap=\"1\">\n                <Text\n                  as=\"label\"\n                  variant=\"bodyStrong\"\n                  prominence=\"strong\"\n                  sentiment=\"neutral\"\n                >\n                  {label}\n                </Text>\n                {labelDescription}\n              </Stack>\n            ) : (\n              <Text\n                as=\"label\"\n                variant=\"bodyStrong\"\n                prominence=\"strong\"\n                sentiment=\"neutral\"\n              >\n                {label}\n              </Text>\n            )}\n\n            <StyledCard disabled={disabled}>\n              <CalendarContent />\n            </StyledCard>\n          </Stack>\n        )}\n      </Container>\n    </DateInputContext.Provider>\n  )\n}\n"]} */"));
39
39
  const DateInput = ({
40
40
  autoFocus = false,
41
41
  disabled = false,
@@ -63,6 +63,7 @@ const DateInput = ({
63
63
  size = "large",
64
64
  readOnly = false,
65
65
  tooltip,
66
+ clearable,
66
67
  selectsRange = false,
67
68
  showMonthYearPicker = false,
68
69
  input = "text",
@@ -154,19 +155,19 @@ const DateInput = ({
154
155
  }
155
156
  onChange?.(computedNewRange, event);
156
157
  } else {
157
- const computedDate = new Date(newValue);
158
+ const computedDate = Date.parse(newValue) ? new Date(newValue) : null;
158
159
  setInputValue(newValue);
159
- if (Date.parse(newValue)) {
160
- setValue(computedDate);
160
+ setValue(computedDate);
161
+ if (computedDate) {
161
162
  setMonthToShow(computedDate.getMonth() + 1);
162
163
  setYearToShow(computedDate.getFullYear());
163
- onChange?.(computedDate, event);
164
164
  }
165
+ onChange?.(computedDate, event);
165
166
  }
166
167
  };
167
168
  return /* @__PURE__ */ jsx(DateInputContext.Provider, { value: valueContext, children: /* @__PURE__ */ jsx(Container, { id, className, "data-testid": dataTestId, onBlur, onFocus, onClick: () => {
168
169
  if (!isPopupVisible) setVisible(true);
169
- }, children: input === "text" ? /* @__PURE__ */ jsx(CalendarPopup, { visible: isPopupVisible, setVisible, refInput, content: /* @__PURE__ */ jsx(CalendarContent, {}), children: /* @__PURE__ */ jsx(TextInputV2, { label, placeholder, value: inputValue, required, error, success, readOnly, disabled, size, autoFocus, helper, labelDescription, name, suffix: /* @__PURE__ */ jsx(CalendarRangeIcon, { size: "medium", sentiment: "neutral", disabled }), ref: refInput, tooltip, autoComplete: "false", onChange: manageOnChange }) }) : /* @__PURE__ */ jsxs(Stack, { gap: 0.5, children: [
170
+ }, children: input === "text" ? /* @__PURE__ */ jsx(CalendarPopup, { visible: isPopupVisible, setVisible, refInput, content: /* @__PURE__ */ jsx(CalendarContent, {}), children: /* @__PURE__ */ jsx(TextInputV2, { label, placeholder, value: inputValue, required, error, success, readOnly, disabled, size, autoFocus, helper, labelDescription, name, suffix: /* @__PURE__ */ jsx(CalendarRangeIcon, { size: "medium", sentiment: "neutral", disabled }), ref: refInput, tooltip, autoComplete: "false", onChange: manageOnChange, clearable }) }) : /* @__PURE__ */ jsxs(Stack, { gap: 0.5, children: [
170
171
  labelDescription ? /* @__PURE__ */ jsxs(Stack, { direction: "row", gap: "1", children: [
171
172
  /* @__PURE__ */ jsx(Text, { as: "label", variant: "bodyStrong", prominence: "strong", sentiment: "neutral", children: label }),
172
173
  labelDescription
@@ -18,8 +18,18 @@ const StyledExpandable = /* @__PURE__ */ _styled__default.default("div", process
18
18
  animationDuration
19
19
  }) => animationDuration, "ms ease-out,opacity ", ({
20
20
  animationDuration
21
- }) => animationDuration, "ms ease-out;}height:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0V4cGFuZGFibGUvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQStCaUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvRXhwYW5kYWJsZS9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VSZWYsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5cbmNvbnN0IEFOSU1BVElPTl9EVVJBVElPTiA9IDMwMCAvLyBpbiBtc1xuXG50eXBlIEV4cGFuZGFibGVQcm9wcyA9IHtcbiAgLyoqXG4gICAqIFRoZSBjb250ZW50IHRvIGRpc3BsYXlcbiAgICovXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgLyoqXG4gICAqIFRvIGRpc3BsYXkgb3Igbm90IHRoZSBjb250ZW50XG4gICAqL1xuICBvcGVuZWQ/OiBib29sZWFuXG4gIC8qKlxuICAgKiBUaGUgbWluaW11bSBoZWlnaHQgb2YgdGhlIGNvbnRlbnRcbiAgICovXG4gIG1pbkhlaWdodD86IG51bWJlclxuICBjbGFzc05hbWU/OiBzdHJpbmdcbiAgJ2RhdGEtdGVzdGlkJz86IHN0cmluZ1xuICAvKipcbiAgICogVGhlIGR1cmF0aW9uIG9mIHRoZSBhbmltYXRpb24gaW4gbXMuIElmIHNldCB0byAwLCB0aGUgYW5pbWF0aW9uIHdpbGwgYmUgZGlzYWJsZWQuXG4gICAqL1xuICBhbmltYXRpb25EdXJhdGlvbj86IG51bWJlclxufVxuXG5leHBvcnQgY29uc3QgU3R5bGVkRXhwYW5kYWJsZSA9IHN0eWxlZCgnZGl2Jywge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PiAhWydhbmltYXRpb25EdXJhdGlvbiddLmluY2x1ZGVzKHByb3ApLFxufSk8eyBhbmltYXRpb25EdXJhdGlvbjogbnVtYmVyIH0+YFxuICAmW2RhdGEtaXMtYW5pbWF0ZWQ9XCJ0cnVlXCJdIHtcbiAgICB0cmFuc2l0aW9uOlxuICAgICAgbWF4LWhlaWdodCAkeyh7IGFuaW1hdGlvbkR1cmF0aW9uIH0pID0+IGFuaW1hdGlvbkR1cmF0aW9ufW1zIGVhc2Utb3V0LFxuICAgICAgb3BhY2l0eSAkeyh7IGFuaW1hdGlvbkR1cmF0aW9uIH0pID0+IGFuaW1hdGlvbkR1cmF0aW9ufW1zIGVhc2Utb3V0O1xuICAgIH1cbiAgaGVpZ2h0OiBhdXRvO1xuYFxuXG4vKipcbiAqIFRoZSBFeHBhbmRhYmxlIGNvbXBvbmVudCBpcyBhIGR5bmFtaWMgUmVhY3QgY29tcG9uZW50IHRoYXQgYWxsb3dzIGZvciB0aGUgZXhwYW5zaW9uIG9mIGl0cyBjaGlsZHJlbiBjb250ZW50XG4gKiBiYXNlZCBvbiBpdHMgaGVpZ2h0LiBUaGUgY29tcG9uZW50IGNvbWVzIHdpdGggYSBzbGVlayBhbmQgc21vb3RoIGFuaW1hdGlvbiwgcHJvdmlkaW5nIGEgdmlzdWFsbHkgcGxlYXNpbmdcbiAqIHVzZXIgZXhwZXJpZW5jZS5cbiAqL1xuZXhwb3J0IGNvbnN0IEV4cGFuZGFibGUgPSAoe1xuICBjaGlsZHJlbixcbiAgb3BlbmVkLFxuICBtaW5IZWlnaHQgPSAwLFxuICBjbGFzc05hbWUsXG4gICdkYXRhLXRlc3RpZCc6IGRhdGFUZXN0SWQsXG4gIGFuaW1hdGlvbkR1cmF0aW9uID0gQU5JTUFUSU9OX0RVUkFUSU9OLFxufTogRXhwYW5kYWJsZVByb3BzKSA9PiB7XG4gIGNvbnN0IFtoZWlnaHQsIHNldEhlaWdodF0gPSB1c2VTdGF0ZTxudW1iZXIgfCBudWxsPihudWxsKVxuICBjb25zdCB0cmFuc2l0aW9uVGltZXIgPSB1c2VSZWY8UmV0dXJuVHlwZTx0eXBlb2Ygc2V0VGltZW91dD4gfCB1bmRlZmluZWQ+KFxuICAgIG51bGwsXG4gIClcbiAgY29uc3QgcmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKVxuICBjb25zdCBzaG91bGRCZUFuaW1hdGVkID0gYW5pbWF0aW9uRHVyYXRpb24gPiAwXG5cbiAgLyoqXG4gICAqIEF0IG1vdW50LCB3ZSBzZXQgdGhlIGhlaWdodCB2YXJpYWJsZSB0byB0aGUgaGVpZ2h0IG9mIHRoZSBjb250ZW50IG9ubHkgaWYgdGhlIGNvbXBvbmVudCBpcyBjbG9zZWQuXG4gICAqIFRoaXMgaXMgdG8gZW5zdXJlIHdlIGRvbid0IGhhdmUgYW5pbWF0aW9uIHdoZW4gdGhlIGNvbXBvbmVudCBpcyBvcGVuZWQgYXQgbW91bnQuXG4gICAqL1xuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChyZWYuY3VycmVudCkge1xuICAgICAgc2V0SGVpZ2h0KHJlZi5jdXJyZW50LnNjcm9sbEhlaWdodCA/PyAwKVxuICAgIH1cbiAgfSwgW3JlZi5jdXJyZW50Py5zY3JvbGxIZWlnaHRdKVxuXG4gIC8qKlxuICAgKiBIZXJlIHdlIHNldCBtYXhIZWlnaHQgdG8gdGhlIGhlaWdodCBvZiB0aGUgY29udGVudCB3aGVuIHRoZSBjb21wb25lbnQgaXMgb3BlbmVkXG4gICAqIGFuZCBhZnRlciAzMDBtcyB3ZSBzZXQgbWF4SGVpZ2h0IHRvIGluaXRpYWwgdG8gbGV0IHRoZSBjb250ZW50IGdyb3cgd2l0aCBhbmltYXRpb24uXG4gICAqIFNldHRpbmcgaXQgdG8gaW5pdGlhbCBpcyByZXF1aXJlZCB0byBiZSBhYmxlIHRvIGhhdmUgbmVzdGVkIGV4cGFuZGFibGUgb3IgdGhlIGhlaWdodCB3b24ndCBmb2xsb3cuXG4gICAqL1xuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChvcGVuZWQgJiYgcmVmLmN1cnJlbnQgJiYgaGVpZ2h0KSB7XG4gICAgICByZWYuY3VycmVudC5zdHlsZS5tYXhIZWlnaHQgPSBgJHtoZWlnaHR9cHhgXG4gICAgICByZWYuY3VycmVudC5zdHlsZS52aXNpYmlsaXR5ID0gJydcbiAgICAgIGlmIChzaG91bGRCZUFuaW1hdGVkKSB7XG4gICAgICAgIHRyYW5zaXRpb25UaW1lci5jdXJyZW50ID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgICAgaWYgKHJlZi5jdXJyZW50KSB7XG4gICAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS5tYXhIZWlnaHQgPSAnaW5pdGlhbCdcbiAgICAgICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLm92ZXJmbG93ID0gJ3Zpc2libGUnXG4gICAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS52aXNpYmlsaXR5ID0gJydcbiAgICAgICAgICB9XG4gICAgICAgIH0sIEFOSU1BVElPTl9EVVJBVElPTilcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLm1heEhlaWdodCA9ICdpbml0aWFsJ1xuICAgICAgICByZWYuY3VycmVudC5zdHlsZS5vdmVyZmxvdyA9ICd2aXNpYmxlJ1xuICAgICAgICByZWYuY3VycmVudC5zdHlsZS52aXNpYmlsaXR5ID0gJydcbiAgICAgIH1cbiAgICB9IGVsc2Uge1xuICAgICAgaWYgKHRyYW5zaXRpb25UaW1lcj8uY3VycmVudCkge1xuICAgICAgICBjbGVhclRpbWVvdXQodHJhbnNpdGlvblRpbWVyLmN1cnJlbnQpXG4gICAgICB9XG5cbiAgICAgIGlmIChyZWYuY3VycmVudCAmJiBoZWlnaHQpIHtcbiAgICAgICAgcmVmLmN1cnJlbnQuc3R5bGUubWF4SGVpZ2h0ID0gYCR7aGVpZ2h0fXB4YFxuICAgICAgICBpZiAoc2hvdWxkQmVBbmltYXRlZCkge1xuICAgICAgICAgIHRyYW5zaXRpb25UaW1lci5jdXJyZW50ID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgICAgICBpZiAocmVmLmN1cnJlbnQpIHtcbiAgICAgICAgICAgICAgcmVmLmN1cnJlbnQuc3R5bGUubWF4SGVpZ2h0ID0gYCR7bWluSGVpZ2h0fXB4YFxuICAgICAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS5vdmVyZmxvdyA9ICdoaWRkZW4nXG4gICAgICAgICAgICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgICAgICAgICAgIGlmIChyZWYuY3VycmVudCAmJiAhbWluSGVpZ2h0KSB7XG4gICAgICAgICAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS52aXNpYmlsaXR5ID0gJ2hpZGRlbidcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgIH0sIEFOSU1BVElPTl9EVVJBVElPTilcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9LCAwKVxuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLm1heEhlaWdodCA9IGAke21pbkhlaWdodH1weGBcbiAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS5vdmVyZmxvdyA9ICdoaWRkZW4nXG4gICAgICAgICAgaWYgKCFtaW5IZWlnaHQpIHtcbiAgICAgICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLnZpc2liaWxpdHkgPSAnaGlkZGVuJ1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiAoKSA9PiB7XG4gICAgICBpZiAodHJhbnNpdGlvblRpbWVyPy5jdXJyZW50KSB7XG4gICAgICAgIGNsZWFyVGltZW91dCh0cmFuc2l0aW9uVGltZXIuY3VycmVudClcbiAgICAgIH1cbiAgICB9XG4gIH0sIFthbmltYXRpb25EdXJhdGlvbiwgaGVpZ2h0LCBtaW5IZWlnaHQsIG9wZW5lZCwgc2hvdWxkQmVBbmltYXRlZF0pXG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkRXhwYW5kYWJsZVxuICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICByZWY9e3JlZn1cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgYW5pbWF0aW9uRHVyYXRpb249e2FuaW1hdGlvbkR1cmF0aW9ufVxuICAgICAgZGF0YS1pcy1hbmltYXRlZD17c2hvdWxkQmVBbmltYXRlZH1cbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9TdHlsZWRFeHBhbmRhYmxlPlxuICApXG59XG4iXX0= */"));
22
- const Expandable = ({
21
+ }) => animationDuration, "ms ease-out;}height:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0V4cGFuZGFibGUvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQStCaUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvRXhwYW5kYWJsZS9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VSZWYsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5cbmNvbnN0IEFOSU1BVElPTl9EVVJBVElPTiA9IDMwMCAvLyBpbiBtc1xuXG50eXBlIEV4cGFuZGFibGVQcm9wcyA9IHtcbiAgLyoqXG4gICAqIFRoZSBjb250ZW50IHRvIGRpc3BsYXlcbiAgICovXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgLyoqXG4gICAqIFRvIGRpc3BsYXkgb3Igbm90IHRoZSBjb250ZW50XG4gICAqL1xuICBvcGVuZWQ/OiBib29sZWFuXG4gIC8qKlxuICAgKiBUaGUgbWluaW11bSBoZWlnaHQgb2YgdGhlIGNvbnRlbnRcbiAgICovXG4gIG1pbkhlaWdodD86IG51bWJlclxuICBjbGFzc05hbWU/OiBzdHJpbmdcbiAgJ2RhdGEtdGVzdGlkJz86IHN0cmluZ1xuICAvKipcbiAgICogVGhlIGR1cmF0aW9uIG9mIHRoZSBhbmltYXRpb24gaW4gbXMuIElmIHNldCB0byAwLCB0aGUgYW5pbWF0aW9uIHdpbGwgYmUgZGlzYWJsZWQuXG4gICAqL1xuICBhbmltYXRpb25EdXJhdGlvbj86IG51bWJlclxufVxuXG5leHBvcnQgY29uc3QgU3R5bGVkRXhwYW5kYWJsZSA9IHN0eWxlZCgnZGl2Jywge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PiAhWydhbmltYXRpb25EdXJhdGlvbiddLmluY2x1ZGVzKHByb3ApLFxufSk8eyBhbmltYXRpb25EdXJhdGlvbjogbnVtYmVyIH0+YFxuICAmW2RhdGEtaXMtYW5pbWF0ZWQ9XCJ0cnVlXCJdIHtcbiAgICB0cmFuc2l0aW9uOlxuICAgICAgbWF4LWhlaWdodCAkeyh7IGFuaW1hdGlvbkR1cmF0aW9uIH0pID0+IGFuaW1hdGlvbkR1cmF0aW9ufW1zIGVhc2Utb3V0LFxuICAgICAgb3BhY2l0eSAkeyh7IGFuaW1hdGlvbkR1cmF0aW9uIH0pID0+IGFuaW1hdGlvbkR1cmF0aW9ufW1zIGVhc2Utb3V0O1xuICAgIH1cbiAgaGVpZ2h0OiBhdXRvO1xuYFxuXG5jb25zdCBOb0FuaW1hdGlvbkV4cGFuZGFibGUgPSAoe1xuICBjaGlsZHJlbixcbiAgb3BlbmVkLFxuICBtaW5IZWlnaHQsXG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbn06IEV4cGFuZGFibGVQcm9wcykgPT4gKFxuICA8ZGl2XG4gICAgc3R5bGU9e3sgbWluSGVpZ2h0LCBkaXNwbGF5OiAhb3BlbmVkID8gJ25vbmUnIDogdW5kZWZpbmVkIH19XG4gICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gID5cbiAgICB7Y2hpbGRyZW59XG4gIDwvZGl2PlxuKVxuXG5leHBvcnQgY29uc3QgQW5pbWF0ZWRFeHBhbmRhYmxlID0gKHtcbiAgY2hpbGRyZW4sXG4gIG9wZW5lZCxcbiAgbWluSGVpZ2h0ID0gMCxcbiAgY2xhc3NOYW1lLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxuICBhbmltYXRpb25EdXJhdGlvbiA9IEFOSU1BVElPTl9EVVJBVElPTixcbn06IEV4cGFuZGFibGVQcm9wcykgPT4ge1xuICBjb25zdCBbaGVpZ2h0LCBzZXRIZWlnaHRdID0gdXNlU3RhdGU8bnVtYmVyIHwgbnVsbD4obnVsbClcbiAgY29uc3QgdHJhbnNpdGlvblRpbWVyID0gdXNlUmVmPFJldHVyblR5cGU8dHlwZW9mIHNldFRpbWVvdXQ+IHwgdW5kZWZpbmVkPihcbiAgICBudWxsLFxuICApXG4gIGNvbnN0IHJlZiA9IHVzZVJlZjxIVE1MRGl2RWxlbWVudD4obnVsbClcbiAgY29uc3Qgc2hvdWxkQmVBbmltYXRlZCA9IGFuaW1hdGlvbkR1cmF0aW9uID4gMFxuXG4gIC8qKlxuICAgKiBBdCBtb3VudCwgd2Ugc2V0IHRoZSBoZWlnaHQgdmFyaWFibGUgdG8gdGhlIGhlaWdodCBvZiB0aGUgY29udGVudCBvbmx5IGlmIHRoZSBjb21wb25lbnQgaXMgY2xvc2VkLlxuICAgKiBUaGlzIGlzIHRvIGVuc3VyZSB3ZSBkb24ndCBoYXZlIGFuaW1hdGlvbiB3aGVuIHRoZSBjb21wb25lbnQgaXMgb3BlbmVkIGF0IG1vdW50LlxuICAgKi9cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAocmVmLmN1cnJlbnQpIHtcbiAgICAgIHNldEhlaWdodChyZWYuY3VycmVudC5zY3JvbGxIZWlnaHQgPz8gMClcbiAgICB9XG4gIH0sIFtyZWYuY3VycmVudD8uc2Nyb2xsSGVpZ2h0XSlcblxuICAvKipcbiAgICogSGVyZSB3ZSBzZXQgbWF4SGVpZ2h0IHRvIHRoZSBoZWlnaHQgb2YgdGhlIGNvbnRlbnQgd2hlbiB0aGUgY29tcG9uZW50IGlzIG9wZW5lZFxuICAgKiBhbmQgYWZ0ZXIgMzAwbXMgd2Ugc2V0IG1heEhlaWdodCB0byBpbml0aWFsIHRvIGxldCB0aGUgY29udGVudCBncm93IHdpdGggYW5pbWF0aW9uLlxuICAgKiBTZXR0aW5nIGl0IHRvIGluaXRpYWwgaXMgcmVxdWlyZWQgdG8gYmUgYWJsZSB0byBoYXZlIG5lc3RlZCBleHBhbmRhYmxlIG9yIHRoZSBoZWlnaHQgd29uJ3QgZm9sbG93LlxuICAgKi9cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAob3BlbmVkICYmIHJlZi5jdXJyZW50ICYmIGhlaWdodCkge1xuICAgICAgcmVmLmN1cnJlbnQuc3R5bGUubWF4SGVpZ2h0ID0gYCR7aGVpZ2h0fXB4YFxuICAgICAgcmVmLmN1cnJlbnQuc3R5bGUudmlzaWJpbGl0eSA9ICcnXG4gICAgICB0cmFuc2l0aW9uVGltZXIuY3VycmVudCA9IHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgICBpZiAocmVmLmN1cnJlbnQpIHtcbiAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS5tYXhIZWlnaHQgPSAnaW5pdGlhbCdcbiAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS5vdmVyZmxvdyA9ICd2aXNpYmxlJ1xuICAgICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLnZpc2liaWxpdHkgPSAnJ1xuICAgICAgICB9XG4gICAgICB9LCBBTklNQVRJT05fRFVSQVRJT04pXG4gICAgfSBlbHNlIHtcbiAgICAgIGlmICh0cmFuc2l0aW9uVGltZXI/LmN1cnJlbnQpIHtcbiAgICAgICAgY2xlYXJUaW1lb3V0KHRyYW5zaXRpb25UaW1lci5jdXJyZW50KVxuICAgICAgfVxuXG4gICAgICBpZiAocmVmLmN1cnJlbnQgJiYgaGVpZ2h0KSB7XG4gICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLm1heEhlaWdodCA9IGAke2hlaWdodH1weGBcbiAgICAgICAgdHJhbnNpdGlvblRpbWVyLmN1cnJlbnQgPSBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgICBpZiAocmVmLmN1cnJlbnQpIHtcbiAgICAgICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLm1heEhlaWdodCA9IGAke21pbkhlaWdodH1weGBcbiAgICAgICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLm92ZXJmbG93ID0gJ2hpZGRlbidcbiAgICAgICAgICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgICAgICAgICBpZiAocmVmLmN1cnJlbnQgJiYgIW1pbkhlaWdodCkge1xuICAgICAgICAgICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLnZpc2liaWxpdHkgPSAnaGlkZGVuJ1xuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9LCBBTklNQVRJT05fRFVSQVRJT04pXG4gICAgICAgICAgfVxuICAgICAgICB9LCAwKVxuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiAoKSA9PiB7XG4gICAgICBpZiAodHJhbnNpdGlvblRpbWVyPy5jdXJyZW50KSB7XG4gICAgICAgIGNsZWFyVGltZW91dCh0cmFuc2l0aW9uVGltZXIuY3VycmVudClcbiAgICAgIH1cbiAgICB9XG4gIH0sIFthbmltYXRpb25EdXJhdGlvbiwgaGVpZ2h0LCBtaW5IZWlnaHQsIG9wZW5lZCwgc2hvdWxkQmVBbmltYXRlZF0pXG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkRXhwYW5kYWJsZVxuICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICByZWY9e3JlZn1cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgYW5pbWF0aW9uRHVyYXRpb249e2FuaW1hdGlvbkR1cmF0aW9ufVxuICAgICAgZGF0YS1pcy1hbmltYXRlZD17c2hvdWxkQmVBbmltYXRlZH1cbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9TdHlsZWRFeHBhbmRhYmxlPlxuICApXG59XG5cbi8qKlxuICogVGhlIEV4cGFuZGFibGUgY29tcG9uZW50IGlzIGEgZHluYW1pYyBSZWFjdCBjb21wb25lbnQgdGhhdCBhbGxvd3MgZm9yIHRoZSBleHBhbnNpb24gb2YgaXRzIGNoaWxkcmVuIGNvbnRlbnRcbiAqIGJhc2VkIG9uIGl0cyBoZWlnaHQuIFRoZSBjb21wb25lbnQgY29tZXMgd2l0aCBhIHNsZWVrIGFuZCBzbW9vdGggYW5pbWF0aW9uLCBwcm92aWRpbmcgYSB2aXN1YWxseSBwbGVhc2luZ1xuICogdXNlciBleHBlcmllbmNlLlxuICovXG5leHBvcnQgY29uc3QgRXhwYW5kYWJsZSA9ICh7XG4gIGNoaWxkcmVuLFxuICBvcGVuZWQsXG4gIG1pbkhlaWdodCxcbiAgY2xhc3NOYW1lLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxuICBhbmltYXRpb25EdXJhdGlvbiA9IEFOSU1BVElPTl9EVVJBVElPTixcbn06IEV4cGFuZGFibGVQcm9wcykgPT4ge1xuICBpZiAoYW5pbWF0aW9uRHVyYXRpb24gPiAwKSB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxBbmltYXRlZEV4cGFuZGFibGVcbiAgICAgICAgb3BlbmVkPXtvcGVuZWR9XG4gICAgICAgIG1pbkhlaWdodD17bWluSGVpZ2h0fVxuICAgICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICAgIGFuaW1hdGlvbkR1cmF0aW9uPXthbmltYXRpb25EdXJhdGlvbn1cbiAgICAgID5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgPC9BbmltYXRlZEV4cGFuZGFibGU+XG4gICAgKVxuICB9XG5cbiAgcmV0dXJuIChcbiAgICA8Tm9BbmltYXRpb25FeHBhbmRhYmxlXG4gICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgbWluSGVpZ2h0PXttaW5IZWlnaHR9XG4gICAgICBvcGVuZWQ9e29wZW5lZH1cbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9Ob0FuaW1hdGlvbkV4cGFuZGFibGU+XG4gIClcbn1cbiJdfQ== */"));
22
+ const NoAnimationExpandable = ({
23
+ children,
24
+ opened,
25
+ minHeight,
26
+ className,
27
+ "data-testid": dataTestId
28
+ }) => /* @__PURE__ */ jsxRuntime.jsx("div", { style: {
29
+ minHeight,
30
+ display: !opened ? "none" : void 0
31
+ }, "data-testid": dataTestId, className, children });
32
+ const AnimatedExpandable = ({
23
33
  children,
24
34
  opened,
25
35
  minHeight = 0,
@@ -40,44 +50,30 @@ const Expandable = ({
40
50
  if (opened && ref.current && height) {
41
51
  ref.current.style.maxHeight = `${height}px`;
42
52
  ref.current.style.visibility = "";
43
- if (shouldBeAnimated) {
44
- transitionTimer.current = setTimeout(() => {
45
- if (ref.current) {
46
- ref.current.style.maxHeight = "initial";
47
- ref.current.style.overflow = "visible";
48
- ref.current.style.visibility = "";
49
- }
50
- }, ANIMATION_DURATION);
51
- } else {
52
- ref.current.style.maxHeight = "initial";
53
- ref.current.style.overflow = "visible";
54
- ref.current.style.visibility = "";
55
- }
53
+ transitionTimer.current = setTimeout(() => {
54
+ if (ref.current) {
55
+ ref.current.style.maxHeight = "initial";
56
+ ref.current.style.overflow = "visible";
57
+ ref.current.style.visibility = "";
58
+ }
59
+ }, ANIMATION_DURATION);
56
60
  } else {
57
61
  if (transitionTimer?.current) {
58
62
  clearTimeout(transitionTimer.current);
59
63
  }
60
64
  if (ref.current && height) {
61
65
  ref.current.style.maxHeight = `${height}px`;
62
- if (shouldBeAnimated) {
63
- transitionTimer.current = setTimeout(() => {
64
- if (ref.current) {
65
- ref.current.style.maxHeight = `${minHeight}px`;
66
- ref.current.style.overflow = "hidden";
67
- setTimeout(() => {
68
- if (ref.current && !minHeight) {
69
- ref.current.style.visibility = "hidden";
70
- }
71
- }, ANIMATION_DURATION);
72
- }
73
- }, 0);
74
- } else {
75
- ref.current.style.maxHeight = `${minHeight}px`;
76
- ref.current.style.overflow = "hidden";
77
- if (!minHeight) {
78
- ref.current.style.visibility = "hidden";
66
+ transitionTimer.current = setTimeout(() => {
67
+ if (ref.current) {
68
+ ref.current.style.maxHeight = `${minHeight}px`;
69
+ ref.current.style.overflow = "hidden";
70
+ setTimeout(() => {
71
+ if (ref.current && !minHeight) {
72
+ ref.current.style.visibility = "hidden";
73
+ }
74
+ }, ANIMATION_DURATION);
79
75
  }
80
- }
76
+ }, 0);
81
77
  }
82
78
  }
83
79
  return () => {
@@ -88,5 +84,19 @@ const Expandable = ({
88
84
  }, [animationDuration, height, minHeight, opened, shouldBeAnimated]);
89
85
  return /* @__PURE__ */ jsxRuntime.jsx(StyledExpandable, { "data-testid": dataTestId, ref, className, animationDuration, "data-is-animated": shouldBeAnimated, children });
90
86
  };
87
+ const Expandable = ({
88
+ children,
89
+ opened,
90
+ minHeight,
91
+ className,
92
+ "data-testid": dataTestId,
93
+ animationDuration = ANIMATION_DURATION
94
+ }) => {
95
+ if (animationDuration > 0) {
96
+ return /* @__PURE__ */ jsxRuntime.jsx(AnimatedExpandable, { opened, minHeight, className, "data-testid": dataTestId, animationDuration, children });
97
+ }
98
+ return /* @__PURE__ */ jsxRuntime.jsx(NoAnimationExpandable, { "data-testid": dataTestId, className, minHeight, opened, children });
99
+ };
100
+ exports.AnimatedExpandable = AnimatedExpandable;
91
101
  exports.Expandable = Expandable;
92
102
  exports.StyledExpandable = StyledExpandable;
@@ -25,6 +25,7 @@ export declare const StyledExpandable: import("@emotion/styled").StyledComponent
25
25
  } & {
26
26
  animationDuration: number;
27
27
  }, import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, {}>;
28
+ export declare const AnimatedExpandable: ({ children, opened, minHeight, className, "data-testid": dataTestId, animationDuration, }: ExpandableProps) => import("@emotion/react/jsx-runtime").JSX.Element;
28
29
  /**
29
30
  * The Expandable component is a dynamic React component that allows for the expansion of its children content
30
31
  * based on its height. The component comes with a sleek and smooth animation, providing a visually pleasing
@@ -14,8 +14,18 @@ const StyledExpandable = /* @__PURE__ */ _styled("div", process.env.NODE_ENV ===
14
14
  animationDuration
15
15
  }) => animationDuration, "ms ease-out,opacity ", ({
16
16
  animationDuration
17
- }) => animationDuration, "ms ease-out;}height:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0V4cGFuZGFibGUvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQStCaUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvRXhwYW5kYWJsZS9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VSZWYsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5cbmNvbnN0IEFOSU1BVElPTl9EVVJBVElPTiA9IDMwMCAvLyBpbiBtc1xuXG50eXBlIEV4cGFuZGFibGVQcm9wcyA9IHtcbiAgLyoqXG4gICAqIFRoZSBjb250ZW50IHRvIGRpc3BsYXlcbiAgICovXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgLyoqXG4gICAqIFRvIGRpc3BsYXkgb3Igbm90IHRoZSBjb250ZW50XG4gICAqL1xuICBvcGVuZWQ/OiBib29sZWFuXG4gIC8qKlxuICAgKiBUaGUgbWluaW11bSBoZWlnaHQgb2YgdGhlIGNvbnRlbnRcbiAgICovXG4gIG1pbkhlaWdodD86IG51bWJlclxuICBjbGFzc05hbWU/OiBzdHJpbmdcbiAgJ2RhdGEtdGVzdGlkJz86IHN0cmluZ1xuICAvKipcbiAgICogVGhlIGR1cmF0aW9uIG9mIHRoZSBhbmltYXRpb24gaW4gbXMuIElmIHNldCB0byAwLCB0aGUgYW5pbWF0aW9uIHdpbGwgYmUgZGlzYWJsZWQuXG4gICAqL1xuICBhbmltYXRpb25EdXJhdGlvbj86IG51bWJlclxufVxuXG5leHBvcnQgY29uc3QgU3R5bGVkRXhwYW5kYWJsZSA9IHN0eWxlZCgnZGl2Jywge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PiAhWydhbmltYXRpb25EdXJhdGlvbiddLmluY2x1ZGVzKHByb3ApLFxufSk8eyBhbmltYXRpb25EdXJhdGlvbjogbnVtYmVyIH0+YFxuICAmW2RhdGEtaXMtYW5pbWF0ZWQ9XCJ0cnVlXCJdIHtcbiAgICB0cmFuc2l0aW9uOlxuICAgICAgbWF4LWhlaWdodCAkeyh7IGFuaW1hdGlvbkR1cmF0aW9uIH0pID0+IGFuaW1hdGlvbkR1cmF0aW9ufW1zIGVhc2Utb3V0LFxuICAgICAgb3BhY2l0eSAkeyh7IGFuaW1hdGlvbkR1cmF0aW9uIH0pID0+IGFuaW1hdGlvbkR1cmF0aW9ufW1zIGVhc2Utb3V0O1xuICAgIH1cbiAgaGVpZ2h0OiBhdXRvO1xuYFxuXG4vKipcbiAqIFRoZSBFeHBhbmRhYmxlIGNvbXBvbmVudCBpcyBhIGR5bmFtaWMgUmVhY3QgY29tcG9uZW50IHRoYXQgYWxsb3dzIGZvciB0aGUgZXhwYW5zaW9uIG9mIGl0cyBjaGlsZHJlbiBjb250ZW50XG4gKiBiYXNlZCBvbiBpdHMgaGVpZ2h0LiBUaGUgY29tcG9uZW50IGNvbWVzIHdpdGggYSBzbGVlayBhbmQgc21vb3RoIGFuaW1hdGlvbiwgcHJvdmlkaW5nIGEgdmlzdWFsbHkgcGxlYXNpbmdcbiAqIHVzZXIgZXhwZXJpZW5jZS5cbiAqL1xuZXhwb3J0IGNvbnN0IEV4cGFuZGFibGUgPSAoe1xuICBjaGlsZHJlbixcbiAgb3BlbmVkLFxuICBtaW5IZWlnaHQgPSAwLFxuICBjbGFzc05hbWUsXG4gICdkYXRhLXRlc3RpZCc6IGRhdGFUZXN0SWQsXG4gIGFuaW1hdGlvbkR1cmF0aW9uID0gQU5JTUFUSU9OX0RVUkFUSU9OLFxufTogRXhwYW5kYWJsZVByb3BzKSA9PiB7XG4gIGNvbnN0IFtoZWlnaHQsIHNldEhlaWdodF0gPSB1c2VTdGF0ZTxudW1iZXIgfCBudWxsPihudWxsKVxuICBjb25zdCB0cmFuc2l0aW9uVGltZXIgPSB1c2VSZWY8UmV0dXJuVHlwZTx0eXBlb2Ygc2V0VGltZW91dD4gfCB1bmRlZmluZWQ+KFxuICAgIG51bGwsXG4gIClcbiAgY29uc3QgcmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKVxuICBjb25zdCBzaG91bGRCZUFuaW1hdGVkID0gYW5pbWF0aW9uRHVyYXRpb24gPiAwXG5cbiAgLyoqXG4gICAqIEF0IG1vdW50LCB3ZSBzZXQgdGhlIGhlaWdodCB2YXJpYWJsZSB0byB0aGUgaGVpZ2h0IG9mIHRoZSBjb250ZW50IG9ubHkgaWYgdGhlIGNvbXBvbmVudCBpcyBjbG9zZWQuXG4gICAqIFRoaXMgaXMgdG8gZW5zdXJlIHdlIGRvbid0IGhhdmUgYW5pbWF0aW9uIHdoZW4gdGhlIGNvbXBvbmVudCBpcyBvcGVuZWQgYXQgbW91bnQuXG4gICAqL1xuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChyZWYuY3VycmVudCkge1xuICAgICAgc2V0SGVpZ2h0KHJlZi5jdXJyZW50LnNjcm9sbEhlaWdodCA/PyAwKVxuICAgIH1cbiAgfSwgW3JlZi5jdXJyZW50Py5zY3JvbGxIZWlnaHRdKVxuXG4gIC8qKlxuICAgKiBIZXJlIHdlIHNldCBtYXhIZWlnaHQgdG8gdGhlIGhlaWdodCBvZiB0aGUgY29udGVudCB3aGVuIHRoZSBjb21wb25lbnQgaXMgb3BlbmVkXG4gICAqIGFuZCBhZnRlciAzMDBtcyB3ZSBzZXQgbWF4SGVpZ2h0IHRvIGluaXRpYWwgdG8gbGV0IHRoZSBjb250ZW50IGdyb3cgd2l0aCBhbmltYXRpb24uXG4gICAqIFNldHRpbmcgaXQgdG8gaW5pdGlhbCBpcyByZXF1aXJlZCB0byBiZSBhYmxlIHRvIGhhdmUgbmVzdGVkIGV4cGFuZGFibGUgb3IgdGhlIGhlaWdodCB3b24ndCBmb2xsb3cuXG4gICAqL1xuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChvcGVuZWQgJiYgcmVmLmN1cnJlbnQgJiYgaGVpZ2h0KSB7XG4gICAgICByZWYuY3VycmVudC5zdHlsZS5tYXhIZWlnaHQgPSBgJHtoZWlnaHR9cHhgXG4gICAgICByZWYuY3VycmVudC5zdHlsZS52aXNpYmlsaXR5ID0gJydcbiAgICAgIGlmIChzaG91bGRCZUFuaW1hdGVkKSB7XG4gICAgICAgIHRyYW5zaXRpb25UaW1lci5jdXJyZW50ID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgICAgaWYgKHJlZi5jdXJyZW50KSB7XG4gICAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS5tYXhIZWlnaHQgPSAnaW5pdGlhbCdcbiAgICAgICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLm92ZXJmbG93ID0gJ3Zpc2libGUnXG4gICAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS52aXNpYmlsaXR5ID0gJydcbiAgICAgICAgICB9XG4gICAgICAgIH0sIEFOSU1BVElPTl9EVVJBVElPTilcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLm1heEhlaWdodCA9ICdpbml0aWFsJ1xuICAgICAgICByZWYuY3VycmVudC5zdHlsZS5vdmVyZmxvdyA9ICd2aXNpYmxlJ1xuICAgICAgICByZWYuY3VycmVudC5zdHlsZS52aXNpYmlsaXR5ID0gJydcbiAgICAgIH1cbiAgICB9IGVsc2Uge1xuICAgICAgaWYgKHRyYW5zaXRpb25UaW1lcj8uY3VycmVudCkge1xuICAgICAgICBjbGVhclRpbWVvdXQodHJhbnNpdGlvblRpbWVyLmN1cnJlbnQpXG4gICAgICB9XG5cbiAgICAgIGlmIChyZWYuY3VycmVudCAmJiBoZWlnaHQpIHtcbiAgICAgICAgcmVmLmN1cnJlbnQuc3R5bGUubWF4SGVpZ2h0ID0gYCR7aGVpZ2h0fXB4YFxuICAgICAgICBpZiAoc2hvdWxkQmVBbmltYXRlZCkge1xuICAgICAgICAgIHRyYW5zaXRpb25UaW1lci5jdXJyZW50ID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgICAgICBpZiAocmVmLmN1cnJlbnQpIHtcbiAgICAgICAgICAgICAgcmVmLmN1cnJlbnQuc3R5bGUubWF4SGVpZ2h0ID0gYCR7bWluSGVpZ2h0fXB4YFxuICAgICAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS5vdmVyZmxvdyA9ICdoaWRkZW4nXG4gICAgICAgICAgICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgICAgICAgICAgIGlmIChyZWYuY3VycmVudCAmJiAhbWluSGVpZ2h0KSB7XG4gICAgICAgICAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS52aXNpYmlsaXR5ID0gJ2hpZGRlbidcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgIH0sIEFOSU1BVElPTl9EVVJBVElPTilcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9LCAwKVxuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLm1heEhlaWdodCA9IGAke21pbkhlaWdodH1weGBcbiAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS5vdmVyZmxvdyA9ICdoaWRkZW4nXG4gICAgICAgICAgaWYgKCFtaW5IZWlnaHQpIHtcbiAgICAgICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLnZpc2liaWxpdHkgPSAnaGlkZGVuJ1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiAoKSA9PiB7XG4gICAgICBpZiAodHJhbnNpdGlvblRpbWVyPy5jdXJyZW50KSB7XG4gICAgICAgIGNsZWFyVGltZW91dCh0cmFuc2l0aW9uVGltZXIuY3VycmVudClcbiAgICAgIH1cbiAgICB9XG4gIH0sIFthbmltYXRpb25EdXJhdGlvbiwgaGVpZ2h0LCBtaW5IZWlnaHQsIG9wZW5lZCwgc2hvdWxkQmVBbmltYXRlZF0pXG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkRXhwYW5kYWJsZVxuICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICByZWY9e3JlZn1cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgYW5pbWF0aW9uRHVyYXRpb249e2FuaW1hdGlvbkR1cmF0aW9ufVxuICAgICAgZGF0YS1pcy1hbmltYXRlZD17c2hvdWxkQmVBbmltYXRlZH1cbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9TdHlsZWRFeHBhbmRhYmxlPlxuICApXG59XG4iXX0= */"));
18
- const Expandable = ({
17
+ }) => animationDuration, "ms ease-out;}height:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0V4cGFuZGFibGUvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQStCaUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvRXhwYW5kYWJsZS9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VSZWYsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5cbmNvbnN0IEFOSU1BVElPTl9EVVJBVElPTiA9IDMwMCAvLyBpbiBtc1xuXG50eXBlIEV4cGFuZGFibGVQcm9wcyA9IHtcbiAgLyoqXG4gICAqIFRoZSBjb250ZW50IHRvIGRpc3BsYXlcbiAgICovXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgLyoqXG4gICAqIFRvIGRpc3BsYXkgb3Igbm90IHRoZSBjb250ZW50XG4gICAqL1xuICBvcGVuZWQ/OiBib29sZWFuXG4gIC8qKlxuICAgKiBUaGUgbWluaW11bSBoZWlnaHQgb2YgdGhlIGNvbnRlbnRcbiAgICovXG4gIG1pbkhlaWdodD86IG51bWJlclxuICBjbGFzc05hbWU/OiBzdHJpbmdcbiAgJ2RhdGEtdGVzdGlkJz86IHN0cmluZ1xuICAvKipcbiAgICogVGhlIGR1cmF0aW9uIG9mIHRoZSBhbmltYXRpb24gaW4gbXMuIElmIHNldCB0byAwLCB0aGUgYW5pbWF0aW9uIHdpbGwgYmUgZGlzYWJsZWQuXG4gICAqL1xuICBhbmltYXRpb25EdXJhdGlvbj86IG51bWJlclxufVxuXG5leHBvcnQgY29uc3QgU3R5bGVkRXhwYW5kYWJsZSA9IHN0eWxlZCgnZGl2Jywge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PiAhWydhbmltYXRpb25EdXJhdGlvbiddLmluY2x1ZGVzKHByb3ApLFxufSk8eyBhbmltYXRpb25EdXJhdGlvbjogbnVtYmVyIH0+YFxuICAmW2RhdGEtaXMtYW5pbWF0ZWQ9XCJ0cnVlXCJdIHtcbiAgICB0cmFuc2l0aW9uOlxuICAgICAgbWF4LWhlaWdodCAkeyh7IGFuaW1hdGlvbkR1cmF0aW9uIH0pID0+IGFuaW1hdGlvbkR1cmF0aW9ufW1zIGVhc2Utb3V0LFxuICAgICAgb3BhY2l0eSAkeyh7IGFuaW1hdGlvbkR1cmF0aW9uIH0pID0+IGFuaW1hdGlvbkR1cmF0aW9ufW1zIGVhc2Utb3V0O1xuICAgIH1cbiAgaGVpZ2h0OiBhdXRvO1xuYFxuXG5jb25zdCBOb0FuaW1hdGlvbkV4cGFuZGFibGUgPSAoe1xuICBjaGlsZHJlbixcbiAgb3BlbmVkLFxuICBtaW5IZWlnaHQsXG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbn06IEV4cGFuZGFibGVQcm9wcykgPT4gKFxuICA8ZGl2XG4gICAgc3R5bGU9e3sgbWluSGVpZ2h0LCBkaXNwbGF5OiAhb3BlbmVkID8gJ25vbmUnIDogdW5kZWZpbmVkIH19XG4gICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gID5cbiAgICB7Y2hpbGRyZW59XG4gIDwvZGl2PlxuKVxuXG5leHBvcnQgY29uc3QgQW5pbWF0ZWRFeHBhbmRhYmxlID0gKHtcbiAgY2hpbGRyZW4sXG4gIG9wZW5lZCxcbiAgbWluSGVpZ2h0ID0gMCxcbiAgY2xhc3NOYW1lLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxuICBhbmltYXRpb25EdXJhdGlvbiA9IEFOSU1BVElPTl9EVVJBVElPTixcbn06IEV4cGFuZGFibGVQcm9wcykgPT4ge1xuICBjb25zdCBbaGVpZ2h0LCBzZXRIZWlnaHRdID0gdXNlU3RhdGU8bnVtYmVyIHwgbnVsbD4obnVsbClcbiAgY29uc3QgdHJhbnNpdGlvblRpbWVyID0gdXNlUmVmPFJldHVyblR5cGU8dHlwZW9mIHNldFRpbWVvdXQ+IHwgdW5kZWZpbmVkPihcbiAgICBudWxsLFxuICApXG4gIGNvbnN0IHJlZiA9IHVzZVJlZjxIVE1MRGl2RWxlbWVudD4obnVsbClcbiAgY29uc3Qgc2hvdWxkQmVBbmltYXRlZCA9IGFuaW1hdGlvbkR1cmF0aW9uID4gMFxuXG4gIC8qKlxuICAgKiBBdCBtb3VudCwgd2Ugc2V0IHRoZSBoZWlnaHQgdmFyaWFibGUgdG8gdGhlIGhlaWdodCBvZiB0aGUgY29udGVudCBvbmx5IGlmIHRoZSBjb21wb25lbnQgaXMgY2xvc2VkLlxuICAgKiBUaGlzIGlzIHRvIGVuc3VyZSB3ZSBkb24ndCBoYXZlIGFuaW1hdGlvbiB3aGVuIHRoZSBjb21wb25lbnQgaXMgb3BlbmVkIGF0IG1vdW50LlxuICAgKi9cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAocmVmLmN1cnJlbnQpIHtcbiAgICAgIHNldEhlaWdodChyZWYuY3VycmVudC5zY3JvbGxIZWlnaHQgPz8gMClcbiAgICB9XG4gIH0sIFtyZWYuY3VycmVudD8uc2Nyb2xsSGVpZ2h0XSlcblxuICAvKipcbiAgICogSGVyZSB3ZSBzZXQgbWF4SGVpZ2h0IHRvIHRoZSBoZWlnaHQgb2YgdGhlIGNvbnRlbnQgd2hlbiB0aGUgY29tcG9uZW50IGlzIG9wZW5lZFxuICAgKiBhbmQgYWZ0ZXIgMzAwbXMgd2Ugc2V0IG1heEhlaWdodCB0byBpbml0aWFsIHRvIGxldCB0aGUgY29udGVudCBncm93IHdpdGggYW5pbWF0aW9uLlxuICAgKiBTZXR0aW5nIGl0IHRvIGluaXRpYWwgaXMgcmVxdWlyZWQgdG8gYmUgYWJsZSB0byBoYXZlIG5lc3RlZCBleHBhbmRhYmxlIG9yIHRoZSBoZWlnaHQgd29uJ3QgZm9sbG93LlxuICAgKi9cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAob3BlbmVkICYmIHJlZi5jdXJyZW50ICYmIGhlaWdodCkge1xuICAgICAgcmVmLmN1cnJlbnQuc3R5bGUubWF4SGVpZ2h0ID0gYCR7aGVpZ2h0fXB4YFxuICAgICAgcmVmLmN1cnJlbnQuc3R5bGUudmlzaWJpbGl0eSA9ICcnXG4gICAgICB0cmFuc2l0aW9uVGltZXIuY3VycmVudCA9IHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgICBpZiAocmVmLmN1cnJlbnQpIHtcbiAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS5tYXhIZWlnaHQgPSAnaW5pdGlhbCdcbiAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS5vdmVyZmxvdyA9ICd2aXNpYmxlJ1xuICAgICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLnZpc2liaWxpdHkgPSAnJ1xuICAgICAgICB9XG4gICAgICB9LCBBTklNQVRJT05fRFVSQVRJT04pXG4gICAgfSBlbHNlIHtcbiAgICAgIGlmICh0cmFuc2l0aW9uVGltZXI/LmN1cnJlbnQpIHtcbiAgICAgICAgY2xlYXJUaW1lb3V0KHRyYW5zaXRpb25UaW1lci5jdXJyZW50KVxuICAgICAgfVxuXG4gICAgICBpZiAocmVmLmN1cnJlbnQgJiYgaGVpZ2h0KSB7XG4gICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLm1heEhlaWdodCA9IGAke2hlaWdodH1weGBcbiAgICAgICAgdHJhbnNpdGlvblRpbWVyLmN1cnJlbnQgPSBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgICBpZiAocmVmLmN1cnJlbnQpIHtcbiAgICAgICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLm1heEhlaWdodCA9IGAke21pbkhlaWdodH1weGBcbiAgICAgICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLm92ZXJmbG93ID0gJ2hpZGRlbidcbiAgICAgICAgICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgICAgICAgICBpZiAocmVmLmN1cnJlbnQgJiYgIW1pbkhlaWdodCkge1xuICAgICAgICAgICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLnZpc2liaWxpdHkgPSAnaGlkZGVuJ1xuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9LCBBTklNQVRJT05fRFVSQVRJT04pXG4gICAgICAgICAgfVxuICAgICAgICB9LCAwKVxuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiAoKSA9PiB7XG4gICAgICBpZiAodHJhbnNpdGlvblRpbWVyPy5jdXJyZW50KSB7XG4gICAgICAgIGNsZWFyVGltZW91dCh0cmFuc2l0aW9uVGltZXIuY3VycmVudClcbiAgICAgIH1cbiAgICB9XG4gIH0sIFthbmltYXRpb25EdXJhdGlvbiwgaGVpZ2h0LCBtaW5IZWlnaHQsIG9wZW5lZCwgc2hvdWxkQmVBbmltYXRlZF0pXG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkRXhwYW5kYWJsZVxuICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICByZWY9e3JlZn1cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgYW5pbWF0aW9uRHVyYXRpb249e2FuaW1hdGlvbkR1cmF0aW9ufVxuICAgICAgZGF0YS1pcy1hbmltYXRlZD17c2hvdWxkQmVBbmltYXRlZH1cbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9TdHlsZWRFeHBhbmRhYmxlPlxuICApXG59XG5cbi8qKlxuICogVGhlIEV4cGFuZGFibGUgY29tcG9uZW50IGlzIGEgZHluYW1pYyBSZWFjdCBjb21wb25lbnQgdGhhdCBhbGxvd3MgZm9yIHRoZSBleHBhbnNpb24gb2YgaXRzIGNoaWxkcmVuIGNvbnRlbnRcbiAqIGJhc2VkIG9uIGl0cyBoZWlnaHQuIFRoZSBjb21wb25lbnQgY29tZXMgd2l0aCBhIHNsZWVrIGFuZCBzbW9vdGggYW5pbWF0aW9uLCBwcm92aWRpbmcgYSB2aXN1YWxseSBwbGVhc2luZ1xuICogdXNlciBleHBlcmllbmNlLlxuICovXG5leHBvcnQgY29uc3QgRXhwYW5kYWJsZSA9ICh7XG4gIGNoaWxkcmVuLFxuICBvcGVuZWQsXG4gIG1pbkhlaWdodCxcbiAgY2xhc3NOYW1lLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxuICBhbmltYXRpb25EdXJhdGlvbiA9IEFOSU1BVElPTl9EVVJBVElPTixcbn06IEV4cGFuZGFibGVQcm9wcykgPT4ge1xuICBpZiAoYW5pbWF0aW9uRHVyYXRpb24gPiAwKSB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxBbmltYXRlZEV4cGFuZGFibGVcbiAgICAgICAgb3BlbmVkPXtvcGVuZWR9XG4gICAgICAgIG1pbkhlaWdodD17bWluSGVpZ2h0fVxuICAgICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICAgIGFuaW1hdGlvbkR1cmF0aW9uPXthbmltYXRpb25EdXJhdGlvbn1cbiAgICAgID5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgPC9BbmltYXRlZEV4cGFuZGFibGU+XG4gICAgKVxuICB9XG5cbiAgcmV0dXJuIChcbiAgICA8Tm9BbmltYXRpb25FeHBhbmRhYmxlXG4gICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgbWluSGVpZ2h0PXttaW5IZWlnaHR9XG4gICAgICBvcGVuZWQ9e29wZW5lZH1cbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9Ob0FuaW1hdGlvbkV4cGFuZGFibGU+XG4gIClcbn1cbiJdfQ== */"));
18
+ const NoAnimationExpandable = ({
19
+ children,
20
+ opened,
21
+ minHeight,
22
+ className,
23
+ "data-testid": dataTestId
24
+ }) => /* @__PURE__ */ jsx("div", { style: {
25
+ minHeight,
26
+ display: !opened ? "none" : void 0
27
+ }, "data-testid": dataTestId, className, children });
28
+ const AnimatedExpandable = ({
19
29
  children,
20
30
  opened,
21
31
  minHeight = 0,
@@ -36,44 +46,30 @@ const Expandable = ({
36
46
  if (opened && ref.current && height) {
37
47
  ref.current.style.maxHeight = `${height}px`;
38
48
  ref.current.style.visibility = "";
39
- if (shouldBeAnimated) {
40
- transitionTimer.current = setTimeout(() => {
41
- if (ref.current) {
42
- ref.current.style.maxHeight = "initial";
43
- ref.current.style.overflow = "visible";
44
- ref.current.style.visibility = "";
45
- }
46
- }, ANIMATION_DURATION);
47
- } else {
48
- ref.current.style.maxHeight = "initial";
49
- ref.current.style.overflow = "visible";
50
- ref.current.style.visibility = "";
51
- }
49
+ transitionTimer.current = setTimeout(() => {
50
+ if (ref.current) {
51
+ ref.current.style.maxHeight = "initial";
52
+ ref.current.style.overflow = "visible";
53
+ ref.current.style.visibility = "";
54
+ }
55
+ }, ANIMATION_DURATION);
52
56
  } else {
53
57
  if (transitionTimer?.current) {
54
58
  clearTimeout(transitionTimer.current);
55
59
  }
56
60
  if (ref.current && height) {
57
61
  ref.current.style.maxHeight = `${height}px`;
58
- if (shouldBeAnimated) {
59
- transitionTimer.current = setTimeout(() => {
60
- if (ref.current) {
61
- ref.current.style.maxHeight = `${minHeight}px`;
62
- ref.current.style.overflow = "hidden";
63
- setTimeout(() => {
64
- if (ref.current && !minHeight) {
65
- ref.current.style.visibility = "hidden";
66
- }
67
- }, ANIMATION_DURATION);
68
- }
69
- }, 0);
70
- } else {
71
- ref.current.style.maxHeight = `${minHeight}px`;
72
- ref.current.style.overflow = "hidden";
73
- if (!minHeight) {
74
- ref.current.style.visibility = "hidden";
62
+ transitionTimer.current = setTimeout(() => {
63
+ if (ref.current) {
64
+ ref.current.style.maxHeight = `${minHeight}px`;
65
+ ref.current.style.overflow = "hidden";
66
+ setTimeout(() => {
67
+ if (ref.current && !minHeight) {
68
+ ref.current.style.visibility = "hidden";
69
+ }
70
+ }, ANIMATION_DURATION);
75
71
  }
76
- }
72
+ }, 0);
77
73
  }
78
74
  }
79
75
  return () => {
@@ -84,7 +80,21 @@ const Expandable = ({
84
80
  }, [animationDuration, height, minHeight, opened, shouldBeAnimated]);
85
81
  return /* @__PURE__ */ jsx(StyledExpandable, { "data-testid": dataTestId, ref, className, animationDuration, "data-is-animated": shouldBeAnimated, children });
86
82
  };
83
+ const Expandable = ({
84
+ children,
85
+ opened,
86
+ minHeight,
87
+ className,
88
+ "data-testid": dataTestId,
89
+ animationDuration = ANIMATION_DURATION
90
+ }) => {
91
+ if (animationDuration > 0) {
92
+ return /* @__PURE__ */ jsx(AnimatedExpandable, { opened, minHeight, className, "data-testid": dataTestId, animationDuration, children });
93
+ }
94
+ return /* @__PURE__ */ jsx(NoAnimationExpandable, { "data-testid": dataTestId, className, minHeight, opened, children });
95
+ };
87
96
  export {
97
+ AnimatedExpandable,
88
98
  Expandable,
89
99
  StyledExpandable
90
100
  };
@@ -14,6 +14,8 @@ export declare const RadioStack: import("@emotion/styled").StyledComponent<{
14
14
  justifyContent?: import("react").CSSProperties["justifyContent"];
15
15
  wrap?: boolean | import("react").CSSProperties["flexWrap"];
16
16
  width?: import("react").CSSProperties["width"];
17
+ maxWidth?: import("react").CSSProperties["maxWidth"];
18
+ minWidth?: import("react").CSSProperties["minWidth"];
17
19
  flex?: import("react").CSSProperties["flex"];
18
20
  className?: string;
19
21
  children: ReactNode;
@@ -22,7 +22,7 @@ const StyledInput = /* @__PURE__ */ _styled__default.default(index.TextInputV2,
22
22
  theme
23
23
  }) => theme.space[2], ";padding-right:", ({
24
24
  theme
25
- }) => theme.space[2], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NlbGVjdElucHV0VjIvU2VhcmNoQmFyRHJvcGRvd24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdCdUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvU2VsZWN0SW5wdXRWMi9TZWFyY2hCYXJEcm9wZG93bi50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBTZWFyY2hJY29uIH0gZnJvbSAnQHVsdHJhdmlvbGV0L2ljb25zJ1xuaW1wb3J0IHR5cGUgeyBEaXNwYXRjaCwgU2V0U3RhdGVBY3Rpb24gfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZUVmZmVjdCwgdXNlUmVmIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBUZXh0SW5wdXRWMiB9IGZyb20gJy4uL1RleHRJbnB1dFYyJ1xuaW1wb3J0IHsgdXNlU2VsZWN0SW5wdXQgfSBmcm9tICcuL1NlbGVjdElucHV0UHJvdmlkZXInXG5pbXBvcnQgdHlwZSB7IERhdGFUeXBlLCBPcHRpb25UeXBlIH0gZnJvbSAnLi90eXBlcydcblxudHlwZSBTZWFyY2hCYXJQcm9wcyA9IHtcbiAgcGxhY2Vob2xkZXI6IHN0cmluZ1xuICBkaXNwbGF5ZWRPcHRpb25zOiBEYXRhVHlwZVxuICBzZXRTZWFyY2hCYXJBY3RpdmU6IERpc3BhdGNoPFNldFN0YXRlQWN0aW9uPGJvb2xlYW4+PlxufVxuXG5jb25zdCBTdHlsZWRJbnB1dCA9IHN0eWxlZChUZXh0SW5wdXRWMilgXG4gIHBhZGRpbmctdG9wOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWzEuNV19O1xuICBwYWRkaW5nLWJvdHRvbTogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsxLjVdfTtcbiAgcGFkZGluZy1sZWZ0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWzJdfTtcbiAgcGFkZGluZy1yaWdodDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsyXX07XG5gXG5jb25zdCBtYXRjaFJlZ2V4ID0gKGRhdGE6IE9wdGlvblR5cGVbXSwgcmVnZXg6IFJlZ0V4cCkgPT5cbiAgZGF0YS5maWx0ZXIoXG4gICAgb3B0aW9uID0+XG4gICAgICAvLyBveGxpbnQtZGlzYWJsZS1uZXh0LWxpbmUgZXNsaW50LXBsdWdpbi11bmljb3JuKHByZWZlci1yZWdleHAtdGVzdClcbiAgICAgIChvcHRpb24uc2VhcmNoVGV4dCAmJiAhIW9wdGlvbi5zZWFyY2hUZXh0Lm1hdGNoKHJlZ2V4KSkgfHxcbiAgICAgICh0eXBlb2Ygb3B0aW9uLmxhYmVsID09PSAnc3RyaW5nJyAmJiBvcHRpb24ubGFiZWwubWF0Y2gocmVnZXgpKSB8fFxuICAgICAgKHR5cGVvZiBvcHRpb24uZGVzY3JpcHRpb24gPT09ICdzdHJpbmcnICYmXG4gICAgICAgIG9wdGlvbi5kZXNjcmlwdGlvbi5tYXRjaChyZWdleCkpIHx8XG4gICAgICBvcHRpb24udmFsdWUubWF0Y2gocmVnZXgpLFxuICApXG5jb25zdCBmaW5kQ2xvc2VzdE9wdGlvbiA9IChcbiAgb3B0aW9uczogRGF0YVR5cGUsXG4gIHNlYXJjaElucHV0OiBzdHJpbmcgfCB1bmRlZmluZWQsXG4pID0+IHtcbiAgaWYgKHNlYXJjaElucHV0KSB7XG4gICAgaWYgKCFBcnJheS5pc0FycmF5KG9wdGlvbnMpKSB7XG4gICAgICBjb25zdCBwb3NzaWJsZU9wdGlvbnMgPSB7IC4uLm9wdGlvbnMgfVxuICAgICAgT2JqZWN0LmtleXMocG9zc2libGVPcHRpb25zKS5tYXAoKGdyb3VwOiBzdHJpbmcpID0+IHtcbiAgICAgICAgcG9zc2libGVPcHRpb25zW2dyb3VwXSA9IHBvc3NpYmxlT3B0aW9uc1tncm91cF0uZmlsdGVyKFxuICAgICAgICAgIG9wdGlvbiA9PiAhb3B0aW9uLmRpc2FibGVkLFxuICAgICAgICApXG5cbiAgICAgICAgcmV0dXJuIG51bGxcbiAgICAgIH0pXG4gICAgICBpZiAoXG4gICAgICAgIE9iamVjdC5rZXlzKHBvc3NpYmxlT3B0aW9ucykuc29tZShcbiAgICAgICAgICBncm91cCA9PiBwb3NzaWJsZU9wdGlvbnNbZ3JvdXBdLmxlbmd0aCA+IDAsXG4gICAgICAgIClcbiAgICAgICkge1xuICAgICAgICBjb25zdCBmaXJzdEZpdCA9IE9iamVjdC5rZXlzKHBvc3NpYmxlT3B0aW9ucylcbiAgICAgICAgICAubWFwKGdyb3VwID0+IHBvc3NpYmxlT3B0aW9uc1tncm91cF1bMF0pXG4gICAgICAgICAgLmZpbHRlcih2YWx1ZSA9PiAhIXZhbHVlKVswXVxuXG4gICAgICAgIHJldHVybiBmaXJzdEZpdFxuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICBjb25zdCBwb3NzaWJsZU9wdGlvbnMgPSBbLi4ub3B0aW9uc10uZmlsdGVyKG9wdGlvbiA9PiAhb3B0aW9uLmRpc2FibGVkKVxuXG4gICAgICBpZiAocG9zc2libGVPcHRpb25zLmxlbmd0aCA+IDApIHtcbiAgICAgICAgcmV0dXJuIHBvc3NpYmxlT3B0aW9uc1swXVxuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIHJldHVybiBudWxsXG59XG5leHBvcnQgY29uc3QgU2VhcmNoQmFyRHJvcGRvd24gPSAoe1xuICBwbGFjZWhvbGRlcixcbiAgZGlzcGxheWVkT3B0aW9ucyxcbiAgc2V0U2VhcmNoQmFyQWN0aXZlLFxufTogU2VhcmNoQmFyUHJvcHMpID0+IHtcbiAgY29uc3Qgc2VhcmNoSW5wdXRSZWYgPSB1c2VSZWY8SFRNTElucHV0RWxlbWVudD4obnVsbClcbiAgY29uc3Qge1xuICAgIG9uQ2hhbmdlLFxuICAgIG9uU2VhcmNoLFxuICAgIHNldFNlYXJjaElucHV0LFxuICAgIHNlYXJjaElucHV0LFxuICAgIG9wdGlvbnMsXG4gICAgbXVsdGlzZWxlY3QsXG4gICAgc2V0U2VsZWN0ZWREYXRhLFxuICAgIHNlbGVjdGVkRGF0YSxcbiAgfSA9IHVzZVNlbGVjdElucHV0KClcbiAgY29uc3QgaGFuZGxlQ2hhbmdlID0gKHNlYXJjaDogc3RyaW5nKSA9PiB7XG4gICAgaWYgKHNlYXJjaC5sZW5ndGggPiAwKSB7XG4gICAgICAvLyBjYXNlIGluc2Vuc2l0aXZlIHNlYXJjaFxuICAgICAgY29uc3QgcmVnZXggPSBuZXcgUmVnRXhwKHNlYXJjaC50b1N0cmluZygpLCAnaScpXG4gICAgICBpZiAoIUFycmF5LmlzQXJyYXkob3B0aW9ucykpIHtcbiAgICAgICAgY29uc3QgZmlsdGVyZWRPcHRpb25zID0geyAuLi5vcHRpb25zIH1cbiAgICAgICAgT2JqZWN0LmtleXMoZmlsdGVyZWRPcHRpb25zKS5tYXAoKGdyb3VwOiBzdHJpbmcpID0+IHtcbiAgICAgICAgICBmaWx0ZXJlZE9wdGlvbnNbZ3JvdXBdID0gbWF0Y2hSZWdleChmaWx0ZXJlZE9wdGlvbnNbZ3JvdXBdLCByZWdleClcblxuICAgICAgICAgIHJldHVybiBudWxsXG4gICAgICAgIH0pXG4gICAgICAgIG9uU2VhcmNoKGZpbHRlcmVkT3B0aW9ucylcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGNvbnN0IGZpbHRlcmVkT3B0aW9ucyA9IG1hdGNoUmVnZXgoWy4uLm9wdGlvbnNdLCByZWdleClcbiAgICAgICAgb25TZWFyY2goZmlsdGVyZWRPcHRpb25zKVxuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICBvblNlYXJjaChvcHRpb25zKVxuICAgIH1cbiAgICBzZXRTZWFyY2hJbnB1dChzZWFyY2gpXG4gIH1cblxuICBjb25zdCBoYW5kbGVLZXlEb3duID0gKGtleTogc3RyaW5nLCBzZWFyY2g/OiBzdHJpbmcpID0+IHtcbiAgICBpZiAoa2V5ID09PSAnRW50ZXInKSB7XG4gICAgICBjb25zdCBjbG9zZXN0T3B0aW9uID0gZmluZENsb3Nlc3RPcHRpb24oZGlzcGxheWVkT3B0aW9ucywgc2VhcmNoKVxuICAgICAgaWYgKGNsb3Nlc3RPcHRpb24pIHtcbiAgICAgICAgaWYgKG11bHRpc2VsZWN0KSB7XG4gICAgICAgICAgc2V0U2VsZWN0ZWREYXRhKHtcbiAgICAgICAgICAgIHR5cGU6ICdzZWxlY3RPcHRpb24nLFxuICAgICAgICAgICAgY2xpY2tlZE9wdGlvbjogY2xvc2VzdE9wdGlvbixcbiAgICAgICAgICAgIGdyb3VwOiAhQXJyYXkuaXNBcnJheShvcHRpb25zKVxuICAgICAgICAgICAgICA/IE9iamVjdC5rZXlzKG9wdGlvbnMpLmZpbHRlcihncm91cCA9PlxuICAgICAgICAgICAgICAgICAgb3B0aW9uc1tncm91cF0uaW5jbHVkZXMoY2xvc2VzdE9wdGlvbiksXG4gICAgICAgICAgICAgICAgKVswXVxuICAgICAgICAgICAgICA6IHVuZGVmaW5lZCxcbiAgICAgICAgICB9KVxuICAgICAgICAgIG9uQ2hhbmdlPy4oXG4gICAgICAgICAgICBzZWxlY3RlZERhdGEuc2VsZWN0ZWRWYWx1ZXMuaW5jbHVkZXMoY2xvc2VzdE9wdGlvbi52YWx1ZSlcbiAgICAgICAgICAgICAgPyBzZWxlY3RlZERhdGEuc2VsZWN0ZWRWYWx1ZXNcbiAgICAgICAgICAgICAgOiBbLi4uc2VsZWN0ZWREYXRhLnNlbGVjdGVkVmFsdWVzLCBjbG9zZXN0T3B0aW9uLnZhbHVlXSxcbiAgICAgICAgICApXG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgc2V0U2VsZWN0ZWREYXRhKHtcbiAgICAgICAgICAgIHR5cGU6ICdzZWxlY3RPcHRpb24nLFxuICAgICAgICAgICAgY2xpY2tlZE9wdGlvbjogY2xvc2VzdE9wdGlvbixcbiAgICAgICAgICB9KVxuICAgICAgICAgIG9uQ2hhbmdlPy4oc2VsZWN0ZWREYXRhLnNlbGVjdGVkVmFsdWVzWzBdID8/ICcnKVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfSBlbHNlIGlmIChrZXkgPT09ICdUYWInKSB7XG4gICAgICBzZWFyY2hJbnB1dFJlZi5jdXJyZW50Py5ibHVyKClcbiAgICB9XG4gIH1cblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIC8vIFRPRE86IFJlbW92ZSBtZSBhbmQgdXNlIGF1dG9Gb2N1cyB3aGVuIHBvcHVwIGlzIGZpeGVkXG4gICAgLy8gQXV0b2ZvY3VzIG9uIHRoZSBzZWFyY2ggYmFyIGNyZWF0ZSBzb21lIHNjcm9sbCBpc3N1ZXNcbiAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgIHNlYXJjaElucHV0UmVmLmN1cnJlbnQ/LmZvY3VzKClcbiAgICB9LCA1MClcbiAgfSwgW10pXG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkSW5wdXRcbiAgICAgIHZhbHVlPXtzZWFyY2hJbnB1dH1cbiAgICAgIG9uQ2hhbmdlPXtldmVudCA9PiBoYW5kbGVDaGFuZ2UoZXZlbnQudGFyZ2V0LnZhbHVlKX1cbiAgICAgIHBsYWNlaG9sZGVyPXtwbGFjZWhvbGRlcn1cbiAgICAgIG9uRm9jdXM9eygpID0+IHNldFNlYXJjaEJhckFjdGl2ZSh0cnVlKX1cbiAgICAgIG9uQmx1cj17KCkgPT4gc2V0U2VhcmNoQmFyQWN0aXZlKGZhbHNlKX1cbiAgICAgIGRhdGEtdGVzdGlkPVwic2VhcmNoLWJhclwiXG4gICAgICBwcmVmaXg9ezxTZWFyY2hJY29uIHNpemU9XCJzbWFsbFwiIHNlbnRpbWVudD1cIm5ldXRyYWxcIiAvPn1cbiAgICAgIG9uS2V5RG93bj17ZXZlbnQgPT4gaGFuZGxlS2V5RG93bihldmVudC5rZXksIHNlYXJjaElucHV0KX1cbiAgICAgIHNpemU9XCJtZWRpdW1cIlxuICAgICAgYXJpYS1sYWJlbD1cInNlYXJjaC1iYXJcIlxuICAgICAgcmVmPXtzZWFyY2hJbnB1dFJlZn1cbiAgICAvPlxuICApXG59XG4iXX0= */"));
25
+ }) => theme.space[2], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NlbGVjdElucHV0VjIvU2VhcmNoQmFyRHJvcGRvd24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdCdUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvU2VsZWN0SW5wdXRWMi9TZWFyY2hCYXJEcm9wZG93bi50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBTZWFyY2hJY29uIH0gZnJvbSAnQHVsdHJhdmlvbGV0L2ljb25zJ1xuaW1wb3J0IHR5cGUgeyBEaXNwYXRjaCwgU2V0U3RhdGVBY3Rpb24gfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZUVmZmVjdCwgdXNlUmVmIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBUZXh0SW5wdXRWMiB9IGZyb20gJy4uL1RleHRJbnB1dFYyJ1xuaW1wb3J0IHsgdXNlU2VsZWN0SW5wdXQgfSBmcm9tICcuL1NlbGVjdElucHV0UHJvdmlkZXInXG5pbXBvcnQgdHlwZSB7IERhdGFUeXBlLCBPcHRpb25UeXBlIH0gZnJvbSAnLi90eXBlcydcblxudHlwZSBTZWFyY2hCYXJQcm9wcyA9IHtcbiAgcGxhY2Vob2xkZXI6IHN0cmluZ1xuICBkaXNwbGF5ZWRPcHRpb25zOiBEYXRhVHlwZVxuICBzZXRTZWFyY2hCYXJBY3RpdmU6IERpc3BhdGNoPFNldFN0YXRlQWN0aW9uPGJvb2xlYW4+PlxufVxuXG5jb25zdCBTdHlsZWRJbnB1dCA9IHN0eWxlZChUZXh0SW5wdXRWMilgXG4gIHBhZGRpbmctdG9wOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWzEuNV19O1xuICBwYWRkaW5nLWJvdHRvbTogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsxLjVdfTtcbiAgcGFkZGluZy1sZWZ0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWzJdfTtcbiAgcGFkZGluZy1yaWdodDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsyXX07XG5gXG5jb25zdCBtYXRjaFJlZ2V4ID0gKGRhdGE6IE9wdGlvblR5cGVbXSwgcmVnZXg6IFJlZ0V4cCkgPT5cbiAgZGF0YS5maWx0ZXIoXG4gICAgb3B0aW9uID0+XG4gICAgICAvLyBveGxpbnQtZGlzYWJsZS1uZXh0LWxpbmUgZXNsaW50LXBsdWdpbi11bmljb3JuKHByZWZlci1yZWdleHAtdGVzdClcbiAgICAgIChvcHRpb24uc2VhcmNoVGV4dCAmJiAhIW9wdGlvbi5zZWFyY2hUZXh0Lm1hdGNoKHJlZ2V4KSkgfHxcbiAgICAgICh0eXBlb2Ygb3B0aW9uLmxhYmVsID09PSAnc3RyaW5nJyAmJiBvcHRpb24ubGFiZWwubWF0Y2gocmVnZXgpKSB8fFxuICAgICAgKHR5cGVvZiBvcHRpb24uZGVzY3JpcHRpb24gPT09ICdzdHJpbmcnICYmXG4gICAgICAgIG9wdGlvbi5kZXNjcmlwdGlvbi5tYXRjaChyZWdleCkpIHx8XG4gICAgICBvcHRpb24udmFsdWUubWF0Y2gocmVnZXgpLFxuICApXG5jb25zdCBmaW5kQ2xvc2VzdE9wdGlvbiA9IChcbiAgb3B0aW9uczogRGF0YVR5cGUsXG4gIHNlYXJjaElucHV0OiBzdHJpbmcgfCB1bmRlZmluZWQsXG4pID0+IHtcbiAgaWYgKHNlYXJjaElucHV0KSB7XG4gICAgaWYgKCFBcnJheS5pc0FycmF5KG9wdGlvbnMpKSB7XG4gICAgICBjb25zdCBwb3NzaWJsZU9wdGlvbnMgPSB7IC4uLm9wdGlvbnMgfVxuICAgICAgT2JqZWN0LmtleXMocG9zc2libGVPcHRpb25zKS5tYXAoKGdyb3VwOiBzdHJpbmcpID0+IHtcbiAgICAgICAgcG9zc2libGVPcHRpb25zW2dyb3VwXSA9IHBvc3NpYmxlT3B0aW9uc1tncm91cF0uZmlsdGVyKFxuICAgICAgICAgIG9wdGlvbiA9PiAhb3B0aW9uLmRpc2FibGVkLFxuICAgICAgICApXG5cbiAgICAgICAgcmV0dXJuIG51bGxcbiAgICAgIH0pXG4gICAgICBpZiAoXG4gICAgICAgIE9iamVjdC5rZXlzKHBvc3NpYmxlT3B0aW9ucykuc29tZShcbiAgICAgICAgICBncm91cCA9PiBwb3NzaWJsZU9wdGlvbnNbZ3JvdXBdLmxlbmd0aCA+IDAsXG4gICAgICAgIClcbiAgICAgICkge1xuICAgICAgICBjb25zdCBmaXJzdEZpdCA9IE9iamVjdC5rZXlzKHBvc3NpYmxlT3B0aW9ucylcbiAgICAgICAgICAubWFwKGdyb3VwID0+IHBvc3NpYmxlT3B0aW9uc1tncm91cF1bMF0pXG4gICAgICAgICAgLmZpbHRlcih2YWx1ZSA9PiAhIXZhbHVlKVswXVxuXG4gICAgICAgIHJldHVybiBmaXJzdEZpdFxuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICBjb25zdCBwb3NzaWJsZU9wdGlvbnMgPSBbLi4ub3B0aW9uc10uZmlsdGVyKG9wdGlvbiA9PiAhb3B0aW9uLmRpc2FibGVkKVxuXG4gICAgICBpZiAocG9zc2libGVPcHRpb25zLmxlbmd0aCA+IDApIHtcbiAgICAgICAgcmV0dXJuIHBvc3NpYmxlT3B0aW9uc1swXVxuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIHJldHVybiBudWxsXG59XG5leHBvcnQgY29uc3QgU2VhcmNoQmFyRHJvcGRvd24gPSAoe1xuICBwbGFjZWhvbGRlcixcbiAgZGlzcGxheWVkT3B0aW9ucyxcbiAgc2V0U2VhcmNoQmFyQWN0aXZlLFxufTogU2VhcmNoQmFyUHJvcHMpID0+IHtcbiAgY29uc3Qgc2VhcmNoSW5wdXRSZWYgPSB1c2VSZWY8SFRNTElucHV0RWxlbWVudD4obnVsbClcbiAgY29uc3Qge1xuICAgIG9uQ2hhbmdlLFxuICAgIG9uU2VhcmNoLFxuICAgIHNldFNlYXJjaElucHV0LFxuICAgIHNlYXJjaElucHV0LFxuICAgIG9wdGlvbnMsXG4gICAgbXVsdGlzZWxlY3QsXG4gICAgc2V0U2VsZWN0ZWREYXRhLFxuICAgIHNlbGVjdGVkRGF0YSxcbiAgfSA9IHVzZVNlbGVjdElucHV0KClcbiAgY29uc3QgZXNjYXBlUmVnRXhwID0gKHN0cmluZzogc3RyaW5nKSA9PlxuICAgIHN0cmluZy5yZXBsYWNlKC9bLiorP157fSgpfFtcXF1cXFxcXS9nLCBTdHJpbmcucmF3YFxcJCZgKVxuXG4gIGNvbnN0IGhhbmRsZUNoYW5nZSA9IChzZWFyY2g6IHN0cmluZykgPT4ge1xuICAgIGlmIChzZWFyY2gubGVuZ3RoID4gMCkge1xuICAgICAgLy8gY2FzZSBpbnNlbnNpdGl2ZSBzZWFyY2hcbiAgICAgIGNvbnN0IHJlZ2V4ID0gbmV3IFJlZ0V4cChlc2NhcGVSZWdFeHAoc2VhcmNoLnRvU3RyaW5nKCkpLCAnaScpXG4gICAgICBpZiAoIUFycmF5LmlzQXJyYXkob3B0aW9ucykpIHtcbiAgICAgICAgY29uc3QgZmlsdGVyZWRPcHRpb25zID0geyAuLi5vcHRpb25zIH1cbiAgICAgICAgT2JqZWN0LmtleXMoZmlsdGVyZWRPcHRpb25zKS5tYXAoKGdyb3VwOiBzdHJpbmcpID0+IHtcbiAgICAgICAgICBmaWx0ZXJlZE9wdGlvbnNbZ3JvdXBdID0gbWF0Y2hSZWdleChmaWx0ZXJlZE9wdGlvbnNbZ3JvdXBdLCByZWdleClcblxuICAgICAgICAgIHJldHVybiBudWxsXG4gICAgICAgIH0pXG4gICAgICAgIG9uU2VhcmNoKGZpbHRlcmVkT3B0aW9ucylcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGNvbnN0IGZpbHRlcmVkT3B0aW9ucyA9IG1hdGNoUmVnZXgoWy4uLm9wdGlvbnNdLCByZWdleClcbiAgICAgICAgb25TZWFyY2goZmlsdGVyZWRPcHRpb25zKVxuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICBvblNlYXJjaChvcHRpb25zKVxuICAgIH1cbiAgICBzZXRTZWFyY2hJbnB1dChzZWFyY2gpXG4gIH1cblxuICBjb25zdCBoYW5kbGVLZXlEb3duID0gKGtleTogc3RyaW5nLCBzZWFyY2g/OiBzdHJpbmcpID0+IHtcbiAgICBpZiAoa2V5ID09PSAnRW50ZXInKSB7XG4gICAgICBjb25zdCBjbG9zZXN0T3B0aW9uID0gZmluZENsb3Nlc3RPcHRpb24oZGlzcGxheWVkT3B0aW9ucywgc2VhcmNoKVxuICAgICAgaWYgKGNsb3Nlc3RPcHRpb24pIHtcbiAgICAgICAgaWYgKG11bHRpc2VsZWN0KSB7XG4gICAgICAgICAgc2V0U2VsZWN0ZWREYXRhKHtcbiAgICAgICAgICAgIHR5cGU6ICdzZWxlY3RPcHRpb24nLFxuICAgICAgICAgICAgY2xpY2tlZE9wdGlvbjogY2xvc2VzdE9wdGlvbixcbiAgICAgICAgICAgIGdyb3VwOiAhQXJyYXkuaXNBcnJheShvcHRpb25zKVxuICAgICAgICAgICAgICA/IE9iamVjdC5rZXlzKG9wdGlvbnMpLmZpbHRlcihncm91cCA9PlxuICAgICAgICAgICAgICAgICAgb3B0aW9uc1tncm91cF0uaW5jbHVkZXMoY2xvc2VzdE9wdGlvbiksXG4gICAgICAgICAgICAgICAgKVswXVxuICAgICAgICAgICAgICA6IHVuZGVmaW5lZCxcbiAgICAgICAgICB9KVxuICAgICAgICAgIG9uQ2hhbmdlPy4oXG4gICAgICAgICAgICBzZWxlY3RlZERhdGEuc2VsZWN0ZWRWYWx1ZXMuaW5jbHVkZXMoY2xvc2VzdE9wdGlvbi52YWx1ZSlcbiAgICAgICAgICAgICAgPyBzZWxlY3RlZERhdGEuc2VsZWN0ZWRWYWx1ZXNcbiAgICAgICAgICAgICAgOiBbLi4uc2VsZWN0ZWREYXRhLnNlbGVjdGVkVmFsdWVzLCBjbG9zZXN0T3B0aW9uLnZhbHVlXSxcbiAgICAgICAgICApXG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgc2V0U2VsZWN0ZWREYXRhKHtcbiAgICAgICAgICAgIHR5cGU6ICdzZWxlY3RPcHRpb24nLFxuICAgICAgICAgICAgY2xpY2tlZE9wdGlvbjogY2xvc2VzdE9wdGlvbixcbiAgICAgICAgICB9KVxuICAgICAgICAgIG9uQ2hhbmdlPy4oc2VsZWN0ZWREYXRhLnNlbGVjdGVkVmFsdWVzWzBdID8/ICcnKVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfSBlbHNlIGlmIChrZXkgPT09ICdUYWInKSB7XG4gICAgICBzZWFyY2hJbnB1dFJlZi5jdXJyZW50Py5ibHVyKClcbiAgICB9XG4gIH1cblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIC8vIFRPRE86IFJlbW92ZSBtZSBhbmQgdXNlIGF1dG9Gb2N1cyB3aGVuIHBvcHVwIGlzIGZpeGVkXG4gICAgLy8gQXV0b2ZvY3VzIG9uIHRoZSBzZWFyY2ggYmFyIGNyZWF0ZSBzb21lIHNjcm9sbCBpc3N1ZXNcbiAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgIHNlYXJjaElucHV0UmVmLmN1cnJlbnQ/LmZvY3VzKClcbiAgICB9LCA1MClcbiAgfSwgW10pXG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkSW5wdXRcbiAgICAgIHZhbHVlPXtzZWFyY2hJbnB1dH1cbiAgICAgIG9uQ2hhbmdlPXtldmVudCA9PiBoYW5kbGVDaGFuZ2UoZXZlbnQudGFyZ2V0LnZhbHVlKX1cbiAgICAgIHBsYWNlaG9sZGVyPXtwbGFjZWhvbGRlcn1cbiAgICAgIG9uRm9jdXM9eygpID0+IHNldFNlYXJjaEJhckFjdGl2ZSh0cnVlKX1cbiAgICAgIG9uQmx1cj17KCkgPT4gc2V0U2VhcmNoQmFyQWN0aXZlKGZhbHNlKX1cbiAgICAgIGRhdGEtdGVzdGlkPVwic2VhcmNoLWJhclwiXG4gICAgICBwcmVmaXg9ezxTZWFyY2hJY29uIHNpemU9XCJzbWFsbFwiIHNlbnRpbWVudD1cIm5ldXRyYWxcIiAvPn1cbiAgICAgIG9uS2V5RG93bj17ZXZlbnQgPT4gaGFuZGxlS2V5RG93bihldmVudC5rZXksIHNlYXJjaElucHV0KX1cbiAgICAgIHNpemU9XCJtZWRpdW1cIlxuICAgICAgYXJpYS1sYWJlbD1cInNlYXJjaC1iYXJcIlxuICAgICAgcmVmPXtzZWFyY2hJbnB1dFJlZn1cbiAgICAvPlxuICApXG59XG4iXX0= */"));
26
26
  const matchRegex = (data, regex) => data.filter((option) => (
27
27
  // oxlint-disable-next-line eslint-plugin-unicorn(prefer-regexp-test)
28
28
  option.searchText && !!option.searchText.match(regex) || typeof option.label === "string" && option.label.match(regex) || typeof option.description === "string" && option.description.match(regex) || option.value.match(regex)
@@ -66,9 +66,10 @@ const SearchBarDropdown = ({
66
66
  setSelectedData,
67
67
  selectedData
68
68
  } = SelectInputProvider.useSelectInput();
69
+ const escapeRegExp = (string) => string.replace(/[.*+?^{}()|[\]\\]/g, String.raw`\$&`);
69
70
  const handleChange = (search) => {
70
71
  if (search.length > 0) {
71
- const regex = new RegExp(search.toString(), "i");
72
+ const regex = new RegExp(escapeRegExp(search.toString()), "i");
72
73
  if (!Array.isArray(options)) {
73
74
  const filteredOptions = {
74
75
  ...options
@@ -18,7 +18,7 @@ const StyledInput = /* @__PURE__ */ _styled(TextInputV2, process.env.NODE_ENV ==
18
18
  theme
19
19
  }) => theme.space[2], ";padding-right:", ({
20
20
  theme
21
- }) => theme.space[2], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NlbGVjdElucHV0VjIvU2VhcmNoQmFyRHJvcGRvd24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdCdUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvU2VsZWN0SW5wdXRWMi9TZWFyY2hCYXJEcm9wZG93bi50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBTZWFyY2hJY29uIH0gZnJvbSAnQHVsdHJhdmlvbGV0L2ljb25zJ1xuaW1wb3J0IHR5cGUgeyBEaXNwYXRjaCwgU2V0U3RhdGVBY3Rpb24gfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZUVmZmVjdCwgdXNlUmVmIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBUZXh0SW5wdXRWMiB9IGZyb20gJy4uL1RleHRJbnB1dFYyJ1xuaW1wb3J0IHsgdXNlU2VsZWN0SW5wdXQgfSBmcm9tICcuL1NlbGVjdElucHV0UHJvdmlkZXInXG5pbXBvcnQgdHlwZSB7IERhdGFUeXBlLCBPcHRpb25UeXBlIH0gZnJvbSAnLi90eXBlcydcblxudHlwZSBTZWFyY2hCYXJQcm9wcyA9IHtcbiAgcGxhY2Vob2xkZXI6IHN0cmluZ1xuICBkaXNwbGF5ZWRPcHRpb25zOiBEYXRhVHlwZVxuICBzZXRTZWFyY2hCYXJBY3RpdmU6IERpc3BhdGNoPFNldFN0YXRlQWN0aW9uPGJvb2xlYW4+PlxufVxuXG5jb25zdCBTdHlsZWRJbnB1dCA9IHN0eWxlZChUZXh0SW5wdXRWMilgXG4gIHBhZGRpbmctdG9wOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWzEuNV19O1xuICBwYWRkaW5nLWJvdHRvbTogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsxLjVdfTtcbiAgcGFkZGluZy1sZWZ0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWzJdfTtcbiAgcGFkZGluZy1yaWdodDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsyXX07XG5gXG5jb25zdCBtYXRjaFJlZ2V4ID0gKGRhdGE6IE9wdGlvblR5cGVbXSwgcmVnZXg6IFJlZ0V4cCkgPT5cbiAgZGF0YS5maWx0ZXIoXG4gICAgb3B0aW9uID0+XG4gICAgICAvLyBveGxpbnQtZGlzYWJsZS1uZXh0LWxpbmUgZXNsaW50LXBsdWdpbi11bmljb3JuKHByZWZlci1yZWdleHAtdGVzdClcbiAgICAgIChvcHRpb24uc2VhcmNoVGV4dCAmJiAhIW9wdGlvbi5zZWFyY2hUZXh0Lm1hdGNoKHJlZ2V4KSkgfHxcbiAgICAgICh0eXBlb2Ygb3B0aW9uLmxhYmVsID09PSAnc3RyaW5nJyAmJiBvcHRpb24ubGFiZWwubWF0Y2gocmVnZXgpKSB8fFxuICAgICAgKHR5cGVvZiBvcHRpb24uZGVzY3JpcHRpb24gPT09ICdzdHJpbmcnICYmXG4gICAgICAgIG9wdGlvbi5kZXNjcmlwdGlvbi5tYXRjaChyZWdleCkpIHx8XG4gICAgICBvcHRpb24udmFsdWUubWF0Y2gocmVnZXgpLFxuICApXG5jb25zdCBmaW5kQ2xvc2VzdE9wdGlvbiA9IChcbiAgb3B0aW9uczogRGF0YVR5cGUsXG4gIHNlYXJjaElucHV0OiBzdHJpbmcgfCB1bmRlZmluZWQsXG4pID0+IHtcbiAgaWYgKHNlYXJjaElucHV0KSB7XG4gICAgaWYgKCFBcnJheS5pc0FycmF5KG9wdGlvbnMpKSB7XG4gICAgICBjb25zdCBwb3NzaWJsZU9wdGlvbnMgPSB7IC4uLm9wdGlvbnMgfVxuICAgICAgT2JqZWN0LmtleXMocG9zc2libGVPcHRpb25zKS5tYXAoKGdyb3VwOiBzdHJpbmcpID0+IHtcbiAgICAgICAgcG9zc2libGVPcHRpb25zW2dyb3VwXSA9IHBvc3NpYmxlT3B0aW9uc1tncm91cF0uZmlsdGVyKFxuICAgICAgICAgIG9wdGlvbiA9PiAhb3B0aW9uLmRpc2FibGVkLFxuICAgICAgICApXG5cbiAgICAgICAgcmV0dXJuIG51bGxcbiAgICAgIH0pXG4gICAgICBpZiAoXG4gICAgICAgIE9iamVjdC5rZXlzKHBvc3NpYmxlT3B0aW9ucykuc29tZShcbiAgICAgICAgICBncm91cCA9PiBwb3NzaWJsZU9wdGlvbnNbZ3JvdXBdLmxlbmd0aCA+IDAsXG4gICAgICAgIClcbiAgICAgICkge1xuICAgICAgICBjb25zdCBmaXJzdEZpdCA9IE9iamVjdC5rZXlzKHBvc3NpYmxlT3B0aW9ucylcbiAgICAgICAgICAubWFwKGdyb3VwID0+IHBvc3NpYmxlT3B0aW9uc1tncm91cF1bMF0pXG4gICAgICAgICAgLmZpbHRlcih2YWx1ZSA9PiAhIXZhbHVlKVswXVxuXG4gICAgICAgIHJldHVybiBmaXJzdEZpdFxuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICBjb25zdCBwb3NzaWJsZU9wdGlvbnMgPSBbLi4ub3B0aW9uc10uZmlsdGVyKG9wdGlvbiA9PiAhb3B0aW9uLmRpc2FibGVkKVxuXG4gICAgICBpZiAocG9zc2libGVPcHRpb25zLmxlbmd0aCA+IDApIHtcbiAgICAgICAgcmV0dXJuIHBvc3NpYmxlT3B0aW9uc1swXVxuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIHJldHVybiBudWxsXG59XG5leHBvcnQgY29uc3QgU2VhcmNoQmFyRHJvcGRvd24gPSAoe1xuICBwbGFjZWhvbGRlcixcbiAgZGlzcGxheWVkT3B0aW9ucyxcbiAgc2V0U2VhcmNoQmFyQWN0aXZlLFxufTogU2VhcmNoQmFyUHJvcHMpID0+IHtcbiAgY29uc3Qgc2VhcmNoSW5wdXRSZWYgPSB1c2VSZWY8SFRNTElucHV0RWxlbWVudD4obnVsbClcbiAgY29uc3Qge1xuICAgIG9uQ2hhbmdlLFxuICAgIG9uU2VhcmNoLFxuICAgIHNldFNlYXJjaElucHV0LFxuICAgIHNlYXJjaElucHV0LFxuICAgIG9wdGlvbnMsXG4gICAgbXVsdGlzZWxlY3QsXG4gICAgc2V0U2VsZWN0ZWREYXRhLFxuICAgIHNlbGVjdGVkRGF0YSxcbiAgfSA9IHVzZVNlbGVjdElucHV0KClcbiAgY29uc3QgaGFuZGxlQ2hhbmdlID0gKHNlYXJjaDogc3RyaW5nKSA9PiB7XG4gICAgaWYgKHNlYXJjaC5sZW5ndGggPiAwKSB7XG4gICAgICAvLyBjYXNlIGluc2Vuc2l0aXZlIHNlYXJjaFxuICAgICAgY29uc3QgcmVnZXggPSBuZXcgUmVnRXhwKHNlYXJjaC50b1N0cmluZygpLCAnaScpXG4gICAgICBpZiAoIUFycmF5LmlzQXJyYXkob3B0aW9ucykpIHtcbiAgICAgICAgY29uc3QgZmlsdGVyZWRPcHRpb25zID0geyAuLi5vcHRpb25zIH1cbiAgICAgICAgT2JqZWN0LmtleXMoZmlsdGVyZWRPcHRpb25zKS5tYXAoKGdyb3VwOiBzdHJpbmcpID0+IHtcbiAgICAgICAgICBmaWx0ZXJlZE9wdGlvbnNbZ3JvdXBdID0gbWF0Y2hSZWdleChmaWx0ZXJlZE9wdGlvbnNbZ3JvdXBdLCByZWdleClcblxuICAgICAgICAgIHJldHVybiBudWxsXG4gICAgICAgIH0pXG4gICAgICAgIG9uU2VhcmNoKGZpbHRlcmVkT3B0aW9ucylcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGNvbnN0IGZpbHRlcmVkT3B0aW9ucyA9IG1hdGNoUmVnZXgoWy4uLm9wdGlvbnNdLCByZWdleClcbiAgICAgICAgb25TZWFyY2goZmlsdGVyZWRPcHRpb25zKVxuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICBvblNlYXJjaChvcHRpb25zKVxuICAgIH1cbiAgICBzZXRTZWFyY2hJbnB1dChzZWFyY2gpXG4gIH1cblxuICBjb25zdCBoYW5kbGVLZXlEb3duID0gKGtleTogc3RyaW5nLCBzZWFyY2g/OiBzdHJpbmcpID0+IHtcbiAgICBpZiAoa2V5ID09PSAnRW50ZXInKSB7XG4gICAgICBjb25zdCBjbG9zZXN0T3B0aW9uID0gZmluZENsb3Nlc3RPcHRpb24oZGlzcGxheWVkT3B0aW9ucywgc2VhcmNoKVxuICAgICAgaWYgKGNsb3Nlc3RPcHRpb24pIHtcbiAgICAgICAgaWYgKG11bHRpc2VsZWN0KSB7XG4gICAgICAgICAgc2V0U2VsZWN0ZWREYXRhKHtcbiAgICAgICAgICAgIHR5cGU6ICdzZWxlY3RPcHRpb24nLFxuICAgICAgICAgICAgY2xpY2tlZE9wdGlvbjogY2xvc2VzdE9wdGlvbixcbiAgICAgICAgICAgIGdyb3VwOiAhQXJyYXkuaXNBcnJheShvcHRpb25zKVxuICAgICAgICAgICAgICA/IE9iamVjdC5rZXlzKG9wdGlvbnMpLmZpbHRlcihncm91cCA9PlxuICAgICAgICAgICAgICAgICAgb3B0aW9uc1tncm91cF0uaW5jbHVkZXMoY2xvc2VzdE9wdGlvbiksXG4gICAgICAgICAgICAgICAgKVswXVxuICAgICAgICAgICAgICA6IHVuZGVmaW5lZCxcbiAgICAgICAgICB9KVxuICAgICAgICAgIG9uQ2hhbmdlPy4oXG4gICAgICAgICAgICBzZWxlY3RlZERhdGEuc2VsZWN0ZWRWYWx1ZXMuaW5jbHVkZXMoY2xvc2VzdE9wdGlvbi52YWx1ZSlcbiAgICAgICAgICAgICAgPyBzZWxlY3RlZERhdGEuc2VsZWN0ZWRWYWx1ZXNcbiAgICAgICAgICAgICAgOiBbLi4uc2VsZWN0ZWREYXRhLnNlbGVjdGVkVmFsdWVzLCBjbG9zZXN0T3B0aW9uLnZhbHVlXSxcbiAgICAgICAgICApXG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgc2V0U2VsZWN0ZWREYXRhKHtcbiAgICAgICAgICAgIHR5cGU6ICdzZWxlY3RPcHRpb24nLFxuICAgICAgICAgICAgY2xpY2tlZE9wdGlvbjogY2xvc2VzdE9wdGlvbixcbiAgICAgICAgICB9KVxuICAgICAgICAgIG9uQ2hhbmdlPy4oc2VsZWN0ZWREYXRhLnNlbGVjdGVkVmFsdWVzWzBdID8/ICcnKVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfSBlbHNlIGlmIChrZXkgPT09ICdUYWInKSB7XG4gICAgICBzZWFyY2hJbnB1dFJlZi5jdXJyZW50Py5ibHVyKClcbiAgICB9XG4gIH1cblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIC8vIFRPRE86IFJlbW92ZSBtZSBhbmQgdXNlIGF1dG9Gb2N1cyB3aGVuIHBvcHVwIGlzIGZpeGVkXG4gICAgLy8gQXV0b2ZvY3VzIG9uIHRoZSBzZWFyY2ggYmFyIGNyZWF0ZSBzb21lIHNjcm9sbCBpc3N1ZXNcbiAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgIHNlYXJjaElucHV0UmVmLmN1cnJlbnQ/LmZvY3VzKClcbiAgICB9LCA1MClcbiAgfSwgW10pXG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkSW5wdXRcbiAgICAgIHZhbHVlPXtzZWFyY2hJbnB1dH1cbiAgICAgIG9uQ2hhbmdlPXtldmVudCA9PiBoYW5kbGVDaGFuZ2UoZXZlbnQudGFyZ2V0LnZhbHVlKX1cbiAgICAgIHBsYWNlaG9sZGVyPXtwbGFjZWhvbGRlcn1cbiAgICAgIG9uRm9jdXM9eygpID0+IHNldFNlYXJjaEJhckFjdGl2ZSh0cnVlKX1cbiAgICAgIG9uQmx1cj17KCkgPT4gc2V0U2VhcmNoQmFyQWN0aXZlKGZhbHNlKX1cbiAgICAgIGRhdGEtdGVzdGlkPVwic2VhcmNoLWJhclwiXG4gICAgICBwcmVmaXg9ezxTZWFyY2hJY29uIHNpemU9XCJzbWFsbFwiIHNlbnRpbWVudD1cIm5ldXRyYWxcIiAvPn1cbiAgICAgIG9uS2V5RG93bj17ZXZlbnQgPT4gaGFuZGxlS2V5RG93bihldmVudC5rZXksIHNlYXJjaElucHV0KX1cbiAgICAgIHNpemU9XCJtZWRpdW1cIlxuICAgICAgYXJpYS1sYWJlbD1cInNlYXJjaC1iYXJcIlxuICAgICAgcmVmPXtzZWFyY2hJbnB1dFJlZn1cbiAgICAvPlxuICApXG59XG4iXX0= */"));
21
+ }) => theme.space[2], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NlbGVjdElucHV0VjIvU2VhcmNoQmFyRHJvcGRvd24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdCdUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvU2VsZWN0SW5wdXRWMi9TZWFyY2hCYXJEcm9wZG93bi50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBTZWFyY2hJY29uIH0gZnJvbSAnQHVsdHJhdmlvbGV0L2ljb25zJ1xuaW1wb3J0IHR5cGUgeyBEaXNwYXRjaCwgU2V0U3RhdGVBY3Rpb24gfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZUVmZmVjdCwgdXNlUmVmIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBUZXh0SW5wdXRWMiB9IGZyb20gJy4uL1RleHRJbnB1dFYyJ1xuaW1wb3J0IHsgdXNlU2VsZWN0SW5wdXQgfSBmcm9tICcuL1NlbGVjdElucHV0UHJvdmlkZXInXG5pbXBvcnQgdHlwZSB7IERhdGFUeXBlLCBPcHRpb25UeXBlIH0gZnJvbSAnLi90eXBlcydcblxudHlwZSBTZWFyY2hCYXJQcm9wcyA9IHtcbiAgcGxhY2Vob2xkZXI6IHN0cmluZ1xuICBkaXNwbGF5ZWRPcHRpb25zOiBEYXRhVHlwZVxuICBzZXRTZWFyY2hCYXJBY3RpdmU6IERpc3BhdGNoPFNldFN0YXRlQWN0aW9uPGJvb2xlYW4+PlxufVxuXG5jb25zdCBTdHlsZWRJbnB1dCA9IHN0eWxlZChUZXh0SW5wdXRWMilgXG4gIHBhZGRpbmctdG9wOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWzEuNV19O1xuICBwYWRkaW5nLWJvdHRvbTogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsxLjVdfTtcbiAgcGFkZGluZy1sZWZ0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWzJdfTtcbiAgcGFkZGluZy1yaWdodDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsyXX07XG5gXG5jb25zdCBtYXRjaFJlZ2V4ID0gKGRhdGE6IE9wdGlvblR5cGVbXSwgcmVnZXg6IFJlZ0V4cCkgPT5cbiAgZGF0YS5maWx0ZXIoXG4gICAgb3B0aW9uID0+XG4gICAgICAvLyBveGxpbnQtZGlzYWJsZS1uZXh0LWxpbmUgZXNsaW50LXBsdWdpbi11bmljb3JuKHByZWZlci1yZWdleHAtdGVzdClcbiAgICAgIChvcHRpb24uc2VhcmNoVGV4dCAmJiAhIW9wdGlvbi5zZWFyY2hUZXh0Lm1hdGNoKHJlZ2V4KSkgfHxcbiAgICAgICh0eXBlb2Ygb3B0aW9uLmxhYmVsID09PSAnc3RyaW5nJyAmJiBvcHRpb24ubGFiZWwubWF0Y2gocmVnZXgpKSB8fFxuICAgICAgKHR5cGVvZiBvcHRpb24uZGVzY3JpcHRpb24gPT09ICdzdHJpbmcnICYmXG4gICAgICAgIG9wdGlvbi5kZXNjcmlwdGlvbi5tYXRjaChyZWdleCkpIHx8XG4gICAgICBvcHRpb24udmFsdWUubWF0Y2gocmVnZXgpLFxuICApXG5jb25zdCBmaW5kQ2xvc2VzdE9wdGlvbiA9IChcbiAgb3B0aW9uczogRGF0YVR5cGUsXG4gIHNlYXJjaElucHV0OiBzdHJpbmcgfCB1bmRlZmluZWQsXG4pID0+IHtcbiAgaWYgKHNlYXJjaElucHV0KSB7XG4gICAgaWYgKCFBcnJheS5pc0FycmF5KG9wdGlvbnMpKSB7XG4gICAgICBjb25zdCBwb3NzaWJsZU9wdGlvbnMgPSB7IC4uLm9wdGlvbnMgfVxuICAgICAgT2JqZWN0LmtleXMocG9zc2libGVPcHRpb25zKS5tYXAoKGdyb3VwOiBzdHJpbmcpID0+IHtcbiAgICAgICAgcG9zc2libGVPcHRpb25zW2dyb3VwXSA9IHBvc3NpYmxlT3B0aW9uc1tncm91cF0uZmlsdGVyKFxuICAgICAgICAgIG9wdGlvbiA9PiAhb3B0aW9uLmRpc2FibGVkLFxuICAgICAgICApXG5cbiAgICAgICAgcmV0dXJuIG51bGxcbiAgICAgIH0pXG4gICAgICBpZiAoXG4gICAgICAgIE9iamVjdC5rZXlzKHBvc3NpYmxlT3B0aW9ucykuc29tZShcbiAgICAgICAgICBncm91cCA9PiBwb3NzaWJsZU9wdGlvbnNbZ3JvdXBdLmxlbmd0aCA+IDAsXG4gICAgICAgIClcbiAgICAgICkge1xuICAgICAgICBjb25zdCBmaXJzdEZpdCA9IE9iamVjdC5rZXlzKHBvc3NpYmxlT3B0aW9ucylcbiAgICAgICAgICAubWFwKGdyb3VwID0+IHBvc3NpYmxlT3B0aW9uc1tncm91cF1bMF0pXG4gICAgICAgICAgLmZpbHRlcih2YWx1ZSA9PiAhIXZhbHVlKVswXVxuXG4gICAgICAgIHJldHVybiBmaXJzdEZpdFxuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICBjb25zdCBwb3NzaWJsZU9wdGlvbnMgPSBbLi4ub3B0aW9uc10uZmlsdGVyKG9wdGlvbiA9PiAhb3B0aW9uLmRpc2FibGVkKVxuXG4gICAgICBpZiAocG9zc2libGVPcHRpb25zLmxlbmd0aCA+IDApIHtcbiAgICAgICAgcmV0dXJuIHBvc3NpYmxlT3B0aW9uc1swXVxuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIHJldHVybiBudWxsXG59XG5leHBvcnQgY29uc3QgU2VhcmNoQmFyRHJvcGRvd24gPSAoe1xuICBwbGFjZWhvbGRlcixcbiAgZGlzcGxheWVkT3B0aW9ucyxcbiAgc2V0U2VhcmNoQmFyQWN0aXZlLFxufTogU2VhcmNoQmFyUHJvcHMpID0+IHtcbiAgY29uc3Qgc2VhcmNoSW5wdXRSZWYgPSB1c2VSZWY8SFRNTElucHV0RWxlbWVudD4obnVsbClcbiAgY29uc3Qge1xuICAgIG9uQ2hhbmdlLFxuICAgIG9uU2VhcmNoLFxuICAgIHNldFNlYXJjaElucHV0LFxuICAgIHNlYXJjaElucHV0LFxuICAgIG9wdGlvbnMsXG4gICAgbXVsdGlzZWxlY3QsXG4gICAgc2V0U2VsZWN0ZWREYXRhLFxuICAgIHNlbGVjdGVkRGF0YSxcbiAgfSA9IHVzZVNlbGVjdElucHV0KClcbiAgY29uc3QgZXNjYXBlUmVnRXhwID0gKHN0cmluZzogc3RyaW5nKSA9PlxuICAgIHN0cmluZy5yZXBsYWNlKC9bLiorP157fSgpfFtcXF1cXFxcXS9nLCBTdHJpbmcucmF3YFxcJCZgKVxuXG4gIGNvbnN0IGhhbmRsZUNoYW5nZSA9IChzZWFyY2g6IHN0cmluZykgPT4ge1xuICAgIGlmIChzZWFyY2gubGVuZ3RoID4gMCkge1xuICAgICAgLy8gY2FzZSBpbnNlbnNpdGl2ZSBzZWFyY2hcbiAgICAgIGNvbnN0IHJlZ2V4ID0gbmV3IFJlZ0V4cChlc2NhcGVSZWdFeHAoc2VhcmNoLnRvU3RyaW5nKCkpLCAnaScpXG4gICAgICBpZiAoIUFycmF5LmlzQXJyYXkob3B0aW9ucykpIHtcbiAgICAgICAgY29uc3QgZmlsdGVyZWRPcHRpb25zID0geyAuLi5vcHRpb25zIH1cbiAgICAgICAgT2JqZWN0LmtleXMoZmlsdGVyZWRPcHRpb25zKS5tYXAoKGdyb3VwOiBzdHJpbmcpID0+IHtcbiAgICAgICAgICBmaWx0ZXJlZE9wdGlvbnNbZ3JvdXBdID0gbWF0Y2hSZWdleChmaWx0ZXJlZE9wdGlvbnNbZ3JvdXBdLCByZWdleClcblxuICAgICAgICAgIHJldHVybiBudWxsXG4gICAgICAgIH0pXG4gICAgICAgIG9uU2VhcmNoKGZpbHRlcmVkT3B0aW9ucylcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGNvbnN0IGZpbHRlcmVkT3B0aW9ucyA9IG1hdGNoUmVnZXgoWy4uLm9wdGlvbnNdLCByZWdleClcbiAgICAgICAgb25TZWFyY2goZmlsdGVyZWRPcHRpb25zKVxuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICBvblNlYXJjaChvcHRpb25zKVxuICAgIH1cbiAgICBzZXRTZWFyY2hJbnB1dChzZWFyY2gpXG4gIH1cblxuICBjb25zdCBoYW5kbGVLZXlEb3duID0gKGtleTogc3RyaW5nLCBzZWFyY2g/OiBzdHJpbmcpID0+IHtcbiAgICBpZiAoa2V5ID09PSAnRW50ZXInKSB7XG4gICAgICBjb25zdCBjbG9zZXN0T3B0aW9uID0gZmluZENsb3Nlc3RPcHRpb24oZGlzcGxheWVkT3B0aW9ucywgc2VhcmNoKVxuICAgICAgaWYgKGNsb3Nlc3RPcHRpb24pIHtcbiAgICAgICAgaWYgKG11bHRpc2VsZWN0KSB7XG4gICAgICAgICAgc2V0U2VsZWN0ZWREYXRhKHtcbiAgICAgICAgICAgIHR5cGU6ICdzZWxlY3RPcHRpb24nLFxuICAgICAgICAgICAgY2xpY2tlZE9wdGlvbjogY2xvc2VzdE9wdGlvbixcbiAgICAgICAgICAgIGdyb3VwOiAhQXJyYXkuaXNBcnJheShvcHRpb25zKVxuICAgICAgICAgICAgICA/IE9iamVjdC5rZXlzKG9wdGlvbnMpLmZpbHRlcihncm91cCA9PlxuICAgICAgICAgICAgICAgICAgb3B0aW9uc1tncm91cF0uaW5jbHVkZXMoY2xvc2VzdE9wdGlvbiksXG4gICAgICAgICAgICAgICAgKVswXVxuICAgICAgICAgICAgICA6IHVuZGVmaW5lZCxcbiAgICAgICAgICB9KVxuICAgICAgICAgIG9uQ2hhbmdlPy4oXG4gICAgICAgICAgICBzZWxlY3RlZERhdGEuc2VsZWN0ZWRWYWx1ZXMuaW5jbHVkZXMoY2xvc2VzdE9wdGlvbi52YWx1ZSlcbiAgICAgICAgICAgICAgPyBzZWxlY3RlZERhdGEuc2VsZWN0ZWRWYWx1ZXNcbiAgICAgICAgICAgICAgOiBbLi4uc2VsZWN0ZWREYXRhLnNlbGVjdGVkVmFsdWVzLCBjbG9zZXN0T3B0aW9uLnZhbHVlXSxcbiAgICAgICAgICApXG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgc2V0U2VsZWN0ZWREYXRhKHtcbiAgICAgICAgICAgIHR5cGU6ICdzZWxlY3RPcHRpb24nLFxuICAgICAgICAgICAgY2xpY2tlZE9wdGlvbjogY2xvc2VzdE9wdGlvbixcbiAgICAgICAgICB9KVxuICAgICAgICAgIG9uQ2hhbmdlPy4oc2VsZWN0ZWREYXRhLnNlbGVjdGVkVmFsdWVzWzBdID8/ICcnKVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfSBlbHNlIGlmIChrZXkgPT09ICdUYWInKSB7XG4gICAgICBzZWFyY2hJbnB1dFJlZi5jdXJyZW50Py5ibHVyKClcbiAgICB9XG4gIH1cblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIC8vIFRPRE86IFJlbW92ZSBtZSBhbmQgdXNlIGF1dG9Gb2N1cyB3aGVuIHBvcHVwIGlzIGZpeGVkXG4gICAgLy8gQXV0b2ZvY3VzIG9uIHRoZSBzZWFyY2ggYmFyIGNyZWF0ZSBzb21lIHNjcm9sbCBpc3N1ZXNcbiAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgIHNlYXJjaElucHV0UmVmLmN1cnJlbnQ/LmZvY3VzKClcbiAgICB9LCA1MClcbiAgfSwgW10pXG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkSW5wdXRcbiAgICAgIHZhbHVlPXtzZWFyY2hJbnB1dH1cbiAgICAgIG9uQ2hhbmdlPXtldmVudCA9PiBoYW5kbGVDaGFuZ2UoZXZlbnQudGFyZ2V0LnZhbHVlKX1cbiAgICAgIHBsYWNlaG9sZGVyPXtwbGFjZWhvbGRlcn1cbiAgICAgIG9uRm9jdXM9eygpID0+IHNldFNlYXJjaEJhckFjdGl2ZSh0cnVlKX1cbiAgICAgIG9uQmx1cj17KCkgPT4gc2V0U2VhcmNoQmFyQWN0aXZlKGZhbHNlKX1cbiAgICAgIGRhdGEtdGVzdGlkPVwic2VhcmNoLWJhclwiXG4gICAgICBwcmVmaXg9ezxTZWFyY2hJY29uIHNpemU9XCJzbWFsbFwiIHNlbnRpbWVudD1cIm5ldXRyYWxcIiAvPn1cbiAgICAgIG9uS2V5RG93bj17ZXZlbnQgPT4gaGFuZGxlS2V5RG93bihldmVudC5rZXksIHNlYXJjaElucHV0KX1cbiAgICAgIHNpemU9XCJtZWRpdW1cIlxuICAgICAgYXJpYS1sYWJlbD1cInNlYXJjaC1iYXJcIlxuICAgICAgcmVmPXtzZWFyY2hJbnB1dFJlZn1cbiAgICAvPlxuICApXG59XG4iXX0= */"));
22
22
  const matchRegex = (data, regex) => data.filter((option) => (
23
23
  // oxlint-disable-next-line eslint-plugin-unicorn(prefer-regexp-test)
24
24
  option.searchText && !!option.searchText.match(regex) || typeof option.label === "string" && option.label.match(regex) || typeof option.description === "string" && option.description.match(regex) || option.value.match(regex)
@@ -62,9 +62,10 @@ const SearchBarDropdown = ({
62
62
  setSelectedData,
63
63
  selectedData
64
64
  } = useSelectInput();
65
+ const escapeRegExp = (string) => string.replace(/[.*+?^{}()|[\]\\]/g, String.raw`\$&`);
65
66
  const handleChange = (search) => {
66
67
  if (search.length > 0) {
67
- const regex = new RegExp(search.toString(), "i");
68
+ const regex = new RegExp(escapeRegExp(search.toString()), "i");
68
69
  if (!Array.isArray(options)) {
69
70
  const filteredOptions = {
70
71
  ...options
@@ -24,6 +24,8 @@ export declare const StyledInputWrapper: import("@emotion/styled").StyledCompone
24
24
  justifyContent?: import("react").CSSProperties["justifyContent"];
25
25
  wrap?: boolean | import("react").CSSProperties["flexWrap"];
26
26
  width?: import("react").CSSProperties["width"];
27
+ maxWidth?: import("react").CSSProperties["maxWidth"];
28
+ minWidth?: import("react").CSSProperties["minWidth"];
27
29
  flex?: import("react").CSSProperties["flex"];
28
30
  className?: string;
29
31
  children: import("react").ReactNode;
@@ -9,6 +9,8 @@ export declare const SliderContainer: import("@emotion/styled").StyledComponent<
9
9
  justifyContent?: import("react").CSSProperties["justifyContent"];
10
10
  wrap?: boolean | import("react").CSSProperties["flexWrap"];
11
11
  width?: import("react").CSSProperties["width"];
12
+ maxWidth?: import("react").CSSProperties["maxWidth"];
13
+ minWidth?: import("react").CSSProperties["minWidth"];
12
14
  flex?: import("react").CSSProperties["flex"];
13
15
  className?: string;
14
16
  children: import("react").ReactNode;
@@ -5,10 +5,10 @@ const _styled = require("@emotion/styled/base");
5
5
  const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
6
6
  const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
7
7
  const Stack = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
8
- shouldForwardProp: (prop) => !["gap", "direction", "alignItems", "justifyContent", "wrap", "width", "flex"].includes(prop),
8
+ shouldForwardProp: (prop) => !["gap", "direction", "alignItems", "justifyContent", "wrap", "width", "maxWidth", "minWidth", "flex"].includes(prop),
9
9
  target: "ehpbis70"
10
10
  } : {
11
- shouldForwardProp: (prop) => !["gap", "direction", "alignItems", "justifyContent", "wrap", "width", "flex"].includes(prop),
11
+ shouldForwardProp: (prop) => !["gap", "direction", "alignItems", "justifyContent", "wrap", "width", "maxWidth", "minWidth", "flex"].includes(prop),
12
12
  target: "ehpbis70",
13
13
  label: "Stack"
14
14
  })("display:flex;", ({
@@ -19,6 +19,8 @@ const Stack = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_E
19
19
  justifyContent = "normal",
20
20
  wrap = "nowrap",
21
21
  width,
22
+ maxWidth,
23
+ minWidth,
22
24
  flex
23
25
  }) => `
24
26
  gap: ${theme.space[gap]};
@@ -28,5 +30,7 @@ const Stack = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_E
28
30
  flex-wrap: ${typeof wrap === "boolean" ? "wrap" : wrap};
29
31
  ${flex ? `flex: ${flex};` : ""}
30
32
  ${width ? `width: ${width};` : ""}
31
- `, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1N0YWNrL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtQ2MiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvU3RhY2svaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBDU1NQcm9wZXJ0aWVzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB0eXBlIHsgVWx0cmF2aW9sZXRVSVRoZW1lIH0gZnJvbSAnLi4vLi4vdGhlbWUnXG5cbnR5cGUgU3RhY2tQcm9wcyA9IHtcbiAgZ2FwPzoga2V5b2YgVWx0cmF2aW9sZXRVSVRoZW1lWydzcGFjZSddIHwgbnVtYmVyXG4gIGRpcmVjdGlvbj86ICdyb3cnIHwgJ2NvbHVtbidcbiAgYWxpZ25JdGVtcz86IENTU1Byb3BlcnRpZXNbJ2FsaWduSXRlbXMnXVxuICBqdXN0aWZ5Q29udGVudD86IENTU1Byb3BlcnRpZXNbJ2p1c3RpZnlDb250ZW50J11cbiAgd3JhcD86IGJvb2xlYW4gfCBDU1NQcm9wZXJ0aWVzWydmbGV4V3JhcCddXG4gIHdpZHRoPzogQ1NTUHJvcGVydGllc1snd2lkdGgnXVxuICBmbGV4PzogQ1NTUHJvcGVydGllc1snZmxleCddXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gICdkYXRhLXRlc3RpZCc/OiBzdHJpbmdcbiAgaWQ/OiBzdHJpbmdcbn1cblxuLyoqXG4gKiBBIFN0YWNrIGlzIGEgd2lkZ2V0IHRoYXQgb3JnYW5pemUgY2hpbGRyZW4gaW4gYSB2ZXJ0aWNhbCBvciBob3Jpem9udGFsIGxheW91dCBiYXNlZCBvbiBjc3MgRmxleCxcbiAqIGl0IGFjY2VwdHMgZmV3IHByb3BzIHRvIGRlYWwgd2l0aCBzcGFjaW5nIGFuZCBhbGlnbi5cbiAqL1xuZXhwb3J0IGNvbnN0IFN0YWNrID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+XG4gICAgIVtcbiAgICAgICdnYXAnLFxuICAgICAgJ2RpcmVjdGlvbicsXG4gICAgICAnYWxpZ25JdGVtcycsXG4gICAgICAnanVzdGlmeUNvbnRlbnQnLFxuICAgICAgJ3dyYXAnLFxuICAgICAgJ3dpZHRoJyxcbiAgICAgICdmbGV4JyxcbiAgICBdLmluY2x1ZGVzKHByb3ApLFxufSk8U3RhY2tQcm9wcz5gXG4gIGRpc3BsYXk6IGZsZXg7XG5cbiAgJHsoe1xuICAgIHRoZW1lLFxuICAgIGdhcCA9IDAsXG4gICAgZGlyZWN0aW9uID0gJ2NvbHVtbicsXG4gICAgYWxpZ25JdGVtcyA9ICdub3JtYWwnLFxuICAgIGp1c3RpZnlDb250ZW50ID0gJ25vcm1hbCcsXG4gICAgd3JhcCA9ICdub3dyYXAnLFxuICAgIHdpZHRoLFxuICAgIGZsZXgsXG4gIH0pID0+IGBcbiAgICBnYXA6ICR7dGhlbWUuc3BhY2VbZ2FwIGFzIGtleW9mIFVsdHJhdmlvbGV0VUlUaGVtZVsnc3BhY2UnXV19O1xuICAgIGZsZXgtZGlyZWN0aW9uOiAke2RpcmVjdGlvbn07XG4gICAgYWxpZ24taXRlbXM6ICR7YWxpZ25JdGVtc307XG4gICAganVzdGlmeS1jb250ZW50OiAke2p1c3RpZnlDb250ZW50fTtcbiAgICBmbGV4LXdyYXA6ICR7dHlwZW9mIHdyYXAgPT09ICdib29sZWFuJyA/ICd3cmFwJyA6IHdyYXB9O1xuICAgICR7ZmxleCA/IGBmbGV4OiAke2ZsZXh9O2AgOiAnJ31cbiAgICAke3dpZHRoID8gYHdpZHRoOiAke3dpZHRofTtgIDogJyd9XG4gIGB9XG5gXG4iXX0= */"));
33
+ ${maxWidth ? `max-width: ${maxWidth};` : ""}
34
+ ${minWidth ? `min-width: ${minWidth};` : ""}
35
+ `, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1N0YWNrL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1Q2MiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvU3RhY2svaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBDU1NQcm9wZXJ0aWVzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB0eXBlIHsgVWx0cmF2aW9sZXRVSVRoZW1lIH0gZnJvbSAnLi4vLi4vdGhlbWUnXG5cbnR5cGUgU3RhY2tQcm9wcyA9IHtcbiAgZ2FwPzoga2V5b2YgVWx0cmF2aW9sZXRVSVRoZW1lWydzcGFjZSddIHwgbnVtYmVyXG4gIGRpcmVjdGlvbj86ICdyb3cnIHwgJ2NvbHVtbidcbiAgYWxpZ25JdGVtcz86IENTU1Byb3BlcnRpZXNbJ2FsaWduSXRlbXMnXVxuICBqdXN0aWZ5Q29udGVudD86IENTU1Byb3BlcnRpZXNbJ2p1c3RpZnlDb250ZW50J11cbiAgd3JhcD86IGJvb2xlYW4gfCBDU1NQcm9wZXJ0aWVzWydmbGV4V3JhcCddXG4gIHdpZHRoPzogQ1NTUHJvcGVydGllc1snd2lkdGgnXVxuICBtYXhXaWR0aD86IENTU1Byb3BlcnRpZXNbJ21heFdpZHRoJ11cbiAgbWluV2lkdGg/OiBDU1NQcm9wZXJ0aWVzWydtaW5XaWR0aCddXG4gIGZsZXg/OiBDU1NQcm9wZXJ0aWVzWydmbGV4J11cbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgJ2RhdGEtdGVzdGlkJz86IHN0cmluZ1xuICBpZD86IHN0cmluZ1xufVxuXG4vKipcbiAqIEEgU3RhY2sgaXMgYSB3aWRnZXQgdGhhdCBvcmdhbml6ZSBjaGlsZHJlbiBpbiBhIHZlcnRpY2FsIG9yIGhvcml6b250YWwgbGF5b3V0IGJhc2VkIG9uIGNzcyBGbGV4LFxuICogaXQgYWNjZXB0cyBmZXcgcHJvcHMgdG8gZGVhbCB3aXRoIHNwYWNpbmcgYW5kIGFsaWduLlxuICovXG5leHBvcnQgY29uc3QgU3RhY2sgPSBzdHlsZWQoJ2RpdicsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT5cbiAgICAhW1xuICAgICAgJ2dhcCcsXG4gICAgICAnZGlyZWN0aW9uJyxcbiAgICAgICdhbGlnbkl0ZW1zJyxcbiAgICAgICdqdXN0aWZ5Q29udGVudCcsXG4gICAgICAnd3JhcCcsXG4gICAgICAnd2lkdGgnLFxuICAgICAgJ21heFdpZHRoJyxcbiAgICAgICdtaW5XaWR0aCcsXG4gICAgICAnZmxleCcsXG4gICAgXS5pbmNsdWRlcyhwcm9wKSxcbn0pPFN0YWNrUHJvcHM+YFxuICBkaXNwbGF5OiBmbGV4O1xuXG4gICR7KHtcbiAgICB0aGVtZSxcbiAgICBnYXAgPSAwLFxuICAgIGRpcmVjdGlvbiA9ICdjb2x1bW4nLFxuICAgIGFsaWduSXRlbXMgPSAnbm9ybWFsJyxcbiAgICBqdXN0aWZ5Q29udGVudCA9ICdub3JtYWwnLFxuICAgIHdyYXAgPSAnbm93cmFwJyxcbiAgICB3aWR0aCxcbiAgICBtYXhXaWR0aCxcbiAgICBtaW5XaWR0aCxcbiAgICBmbGV4LFxuICB9KSA9PiBgXG4gICAgZ2FwOiAke3RoZW1lLnNwYWNlW2dhcCBhcyBrZXlvZiBVbHRyYXZpb2xldFVJVGhlbWVbJ3NwYWNlJ11dfTtcbiAgICBmbGV4LWRpcmVjdGlvbjogJHtkaXJlY3Rpb259O1xuICAgIGFsaWduLWl0ZW1zOiAke2FsaWduSXRlbXN9O1xuICAgIGp1c3RpZnktY29udGVudDogJHtqdXN0aWZ5Q29udGVudH07XG4gICAgZmxleC13cmFwOiAke3R5cGVvZiB3cmFwID09PSAnYm9vbGVhbicgPyAnd3JhcCcgOiB3cmFwfTtcbiAgICAke2ZsZXggPyBgZmxleDogJHtmbGV4fTtgIDogJyd9XG4gICAgJHt3aWR0aCA/IGB3aWR0aDogJHt3aWR0aH07YCA6ICcnfVxuICAgICR7bWF4V2lkdGggPyBgbWF4LXdpZHRoOiAke21heFdpZHRofTtgIDogJyd9XG4gICAgJHttaW5XaWR0aCA/IGBtaW4td2lkdGg6ICR7bWluV2lkdGh9O2AgOiAnJ31cbiAgYH1cbmBcbiJdfQ== */"));
32
36
  exports.Stack = Stack;
@@ -7,6 +7,8 @@ type StackProps = {
7
7
  justifyContent?: CSSProperties['justifyContent'];
8
8
  wrap?: boolean | CSSProperties['flexWrap'];
9
9
  width?: CSSProperties['width'];
10
+ maxWidth?: CSSProperties['maxWidth'];
11
+ minWidth?: CSSProperties['minWidth'];
10
12
  flex?: CSSProperties['flex'];
11
13
  className?: string;
12
14
  children: ReactNode;
@@ -1,10 +1,10 @@
1
1
  "use client";
2
2
  import _styled from "@emotion/styled/base";
3
3
  const Stack = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
4
- shouldForwardProp: (prop) => !["gap", "direction", "alignItems", "justifyContent", "wrap", "width", "flex"].includes(prop),
4
+ shouldForwardProp: (prop) => !["gap", "direction", "alignItems", "justifyContent", "wrap", "width", "maxWidth", "minWidth", "flex"].includes(prop),
5
5
  target: "ehpbis70"
6
6
  } : {
7
- shouldForwardProp: (prop) => !["gap", "direction", "alignItems", "justifyContent", "wrap", "width", "flex"].includes(prop),
7
+ shouldForwardProp: (prop) => !["gap", "direction", "alignItems", "justifyContent", "wrap", "width", "maxWidth", "minWidth", "flex"].includes(prop),
8
8
  target: "ehpbis70",
9
9
  label: "Stack"
10
10
  })("display:flex;", ({
@@ -15,6 +15,8 @@ const Stack = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "productio
15
15
  justifyContent = "normal",
16
16
  wrap = "nowrap",
17
17
  width,
18
+ maxWidth,
19
+ minWidth,
18
20
  flex
19
21
  }) => `
20
22
  gap: ${theme.space[gap]};
@@ -24,7 +26,9 @@ const Stack = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "productio
24
26
  flex-wrap: ${typeof wrap === "boolean" ? "wrap" : wrap};
25
27
  ${flex ? `flex: ${flex};` : ""}
26
28
  ${width ? `width: ${width};` : ""}
27
- `, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1N0YWNrL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtQ2MiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvU3RhY2svaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBDU1NQcm9wZXJ0aWVzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB0eXBlIHsgVWx0cmF2aW9sZXRVSVRoZW1lIH0gZnJvbSAnLi4vLi4vdGhlbWUnXG5cbnR5cGUgU3RhY2tQcm9wcyA9IHtcbiAgZ2FwPzoga2V5b2YgVWx0cmF2aW9sZXRVSVRoZW1lWydzcGFjZSddIHwgbnVtYmVyXG4gIGRpcmVjdGlvbj86ICdyb3cnIHwgJ2NvbHVtbidcbiAgYWxpZ25JdGVtcz86IENTU1Byb3BlcnRpZXNbJ2FsaWduSXRlbXMnXVxuICBqdXN0aWZ5Q29udGVudD86IENTU1Byb3BlcnRpZXNbJ2p1c3RpZnlDb250ZW50J11cbiAgd3JhcD86IGJvb2xlYW4gfCBDU1NQcm9wZXJ0aWVzWydmbGV4V3JhcCddXG4gIHdpZHRoPzogQ1NTUHJvcGVydGllc1snd2lkdGgnXVxuICBmbGV4PzogQ1NTUHJvcGVydGllc1snZmxleCddXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gICdkYXRhLXRlc3RpZCc/OiBzdHJpbmdcbiAgaWQ/OiBzdHJpbmdcbn1cblxuLyoqXG4gKiBBIFN0YWNrIGlzIGEgd2lkZ2V0IHRoYXQgb3JnYW5pemUgY2hpbGRyZW4gaW4gYSB2ZXJ0aWNhbCBvciBob3Jpem9udGFsIGxheW91dCBiYXNlZCBvbiBjc3MgRmxleCxcbiAqIGl0IGFjY2VwdHMgZmV3IHByb3BzIHRvIGRlYWwgd2l0aCBzcGFjaW5nIGFuZCBhbGlnbi5cbiAqL1xuZXhwb3J0IGNvbnN0IFN0YWNrID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+XG4gICAgIVtcbiAgICAgICdnYXAnLFxuICAgICAgJ2RpcmVjdGlvbicsXG4gICAgICAnYWxpZ25JdGVtcycsXG4gICAgICAnanVzdGlmeUNvbnRlbnQnLFxuICAgICAgJ3dyYXAnLFxuICAgICAgJ3dpZHRoJyxcbiAgICAgICdmbGV4JyxcbiAgICBdLmluY2x1ZGVzKHByb3ApLFxufSk8U3RhY2tQcm9wcz5gXG4gIGRpc3BsYXk6IGZsZXg7XG5cbiAgJHsoe1xuICAgIHRoZW1lLFxuICAgIGdhcCA9IDAsXG4gICAgZGlyZWN0aW9uID0gJ2NvbHVtbicsXG4gICAgYWxpZ25JdGVtcyA9ICdub3JtYWwnLFxuICAgIGp1c3RpZnlDb250ZW50ID0gJ25vcm1hbCcsXG4gICAgd3JhcCA9ICdub3dyYXAnLFxuICAgIHdpZHRoLFxuICAgIGZsZXgsXG4gIH0pID0+IGBcbiAgICBnYXA6ICR7dGhlbWUuc3BhY2VbZ2FwIGFzIGtleW9mIFVsdHJhdmlvbGV0VUlUaGVtZVsnc3BhY2UnXV19O1xuICAgIGZsZXgtZGlyZWN0aW9uOiAke2RpcmVjdGlvbn07XG4gICAgYWxpZ24taXRlbXM6ICR7YWxpZ25JdGVtc307XG4gICAganVzdGlmeS1jb250ZW50OiAke2p1c3RpZnlDb250ZW50fTtcbiAgICBmbGV4LXdyYXA6ICR7dHlwZW9mIHdyYXAgPT09ICdib29sZWFuJyA/ICd3cmFwJyA6IHdyYXB9O1xuICAgICR7ZmxleCA/IGBmbGV4OiAke2ZsZXh9O2AgOiAnJ31cbiAgICAke3dpZHRoID8gYHdpZHRoOiAke3dpZHRofTtgIDogJyd9XG4gIGB9XG5gXG4iXX0= */"));
29
+ ${maxWidth ? `max-width: ${maxWidth};` : ""}
30
+ ${minWidth ? `min-width: ${minWidth};` : ""}
31
+ `, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1N0YWNrL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1Q2MiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvU3RhY2svaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBDU1NQcm9wZXJ0aWVzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB0eXBlIHsgVWx0cmF2aW9sZXRVSVRoZW1lIH0gZnJvbSAnLi4vLi4vdGhlbWUnXG5cbnR5cGUgU3RhY2tQcm9wcyA9IHtcbiAgZ2FwPzoga2V5b2YgVWx0cmF2aW9sZXRVSVRoZW1lWydzcGFjZSddIHwgbnVtYmVyXG4gIGRpcmVjdGlvbj86ICdyb3cnIHwgJ2NvbHVtbidcbiAgYWxpZ25JdGVtcz86IENTU1Byb3BlcnRpZXNbJ2FsaWduSXRlbXMnXVxuICBqdXN0aWZ5Q29udGVudD86IENTU1Byb3BlcnRpZXNbJ2p1c3RpZnlDb250ZW50J11cbiAgd3JhcD86IGJvb2xlYW4gfCBDU1NQcm9wZXJ0aWVzWydmbGV4V3JhcCddXG4gIHdpZHRoPzogQ1NTUHJvcGVydGllc1snd2lkdGgnXVxuICBtYXhXaWR0aD86IENTU1Byb3BlcnRpZXNbJ21heFdpZHRoJ11cbiAgbWluV2lkdGg/OiBDU1NQcm9wZXJ0aWVzWydtaW5XaWR0aCddXG4gIGZsZXg/OiBDU1NQcm9wZXJ0aWVzWydmbGV4J11cbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgJ2RhdGEtdGVzdGlkJz86IHN0cmluZ1xuICBpZD86IHN0cmluZ1xufVxuXG4vKipcbiAqIEEgU3RhY2sgaXMgYSB3aWRnZXQgdGhhdCBvcmdhbml6ZSBjaGlsZHJlbiBpbiBhIHZlcnRpY2FsIG9yIGhvcml6b250YWwgbGF5b3V0IGJhc2VkIG9uIGNzcyBGbGV4LFxuICogaXQgYWNjZXB0cyBmZXcgcHJvcHMgdG8gZGVhbCB3aXRoIHNwYWNpbmcgYW5kIGFsaWduLlxuICovXG5leHBvcnQgY29uc3QgU3RhY2sgPSBzdHlsZWQoJ2RpdicsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT5cbiAgICAhW1xuICAgICAgJ2dhcCcsXG4gICAgICAnZGlyZWN0aW9uJyxcbiAgICAgICdhbGlnbkl0ZW1zJyxcbiAgICAgICdqdXN0aWZ5Q29udGVudCcsXG4gICAgICAnd3JhcCcsXG4gICAgICAnd2lkdGgnLFxuICAgICAgJ21heFdpZHRoJyxcbiAgICAgICdtaW5XaWR0aCcsXG4gICAgICAnZmxleCcsXG4gICAgXS5pbmNsdWRlcyhwcm9wKSxcbn0pPFN0YWNrUHJvcHM+YFxuICBkaXNwbGF5OiBmbGV4O1xuXG4gICR7KHtcbiAgICB0aGVtZSxcbiAgICBnYXAgPSAwLFxuICAgIGRpcmVjdGlvbiA9ICdjb2x1bW4nLFxuICAgIGFsaWduSXRlbXMgPSAnbm9ybWFsJyxcbiAgICBqdXN0aWZ5Q29udGVudCA9ICdub3JtYWwnLFxuICAgIHdyYXAgPSAnbm93cmFwJyxcbiAgICB3aWR0aCxcbiAgICBtYXhXaWR0aCxcbiAgICBtaW5XaWR0aCxcbiAgICBmbGV4LFxuICB9KSA9PiBgXG4gICAgZ2FwOiAke3RoZW1lLnNwYWNlW2dhcCBhcyBrZXlvZiBVbHRyYXZpb2xldFVJVGhlbWVbJ3NwYWNlJ11dfTtcbiAgICBmbGV4LWRpcmVjdGlvbjogJHtkaXJlY3Rpb259O1xuICAgIGFsaWduLWl0ZW1zOiAke2FsaWduSXRlbXN9O1xuICAgIGp1c3RpZnktY29udGVudDogJHtqdXN0aWZ5Q29udGVudH07XG4gICAgZmxleC13cmFwOiAke3R5cGVvZiB3cmFwID09PSAnYm9vbGVhbicgPyAnd3JhcCcgOiB3cmFwfTtcbiAgICAke2ZsZXggPyBgZmxleDogJHtmbGV4fTtgIDogJyd9XG4gICAgJHt3aWR0aCA/IGB3aWR0aDogJHt3aWR0aH07YCA6ICcnfVxuICAgICR7bWF4V2lkdGggPyBgbWF4LXdpZHRoOiAke21heFdpZHRofTtgIDogJyd9XG4gICAgJHttaW5XaWR0aCA/IGBtaW4td2lkdGg6ICR7bWluV2lkdGh9O2AgOiAnJ31cbiAgYH1cbmBcbiJdfQ== */"));
28
32
  export {
29
33
  Stack
30
34
  };
@@ -15,6 +15,8 @@ export declare const BasicPrefixStack: import("@emotion/styled").StyledComponent
15
15
  justifyContent?: import("react").CSSProperties["justifyContent"];
16
16
  wrap?: boolean | import("react").CSSProperties["flexWrap"];
17
17
  width?: import("react").CSSProperties["width"];
18
+ maxWidth?: import("react").CSSProperties["maxWidth"];
19
+ minWidth?: import("react").CSSProperties["minWidth"];
18
20
  flex?: import("react").CSSProperties["flex"];
19
21
  className?: string;
20
22
  children: ReactNode;
@@ -33,6 +35,8 @@ export declare const BasicSuffixStack: import("@emotion/styled").StyledComponent
33
35
  justifyContent?: import("react").CSSProperties["justifyContent"];
34
36
  wrap?: boolean | import("react").CSSProperties["flexWrap"];
35
37
  width?: import("react").CSSProperties["width"];
38
+ maxWidth?: import("react").CSSProperties["maxWidth"];
39
+ minWidth?: import("react").CSSProperties["minWidth"];
36
40
  flex?: import("react").CSSProperties["flex"];
37
41
  className?: string;
38
42
  children: ReactNode;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ultraviolet/ui",
3
- "version": "1.93.0",
3
+ "version": "1.94.0",
4
4
  "description": "Ultraviolet UI",
5
5
  "homepage": "https://github.com/scaleway/ultraviolet#readme",
6
6
  "repository": {
@@ -80,13 +80,13 @@
80
80
  "@scaleway/random-name": "5.1.1",
81
81
  "@scaleway/use-media": "3.0.3",
82
82
  "deepmerge": "4.3.1",
83
- "next": "15.3.0",
83
+ "next": "15.3.1",
84
84
  "react-select": "5.10.0",
85
85
  "react-toastify": "11.0.5",
86
86
  "react-use-clipboard": "1.0.9",
87
87
  "reakit": "1.3.11",
88
- "@ultraviolet/icons": "3.13.0",
89
- "@ultraviolet/themes": "1.17.0"
88
+ "@ultraviolet/themes": "1.17.0",
89
+ "@ultraviolet/icons": "3.14.0"
90
90
  },
91
91
  "scripts": {
92
92
  "type:generate": "tsc --declaration -p tsconfig.build.json",