@ultraviolet/ui 1.67.3 → 1.68.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.
@@ -15,7 +15,7 @@ const DataList = /* @__PURE__ */ _styled__default.default("datalist", process.en
15
15
  theme
16
16
  }) => theme.typography.caption.lineHeight, ";&[data-double='true']{margin-top:", ({
17
17
  theme
18
- }) => theme.space["5"], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NsaWRlci9jb21wb25lbnRzL09wdGlvbnMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUl1QyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9TbGlkZXIvY29tcG9uZW50cy9PcHRpb25zLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uLy4uL1RleHQnXG5pbXBvcnQgeyBUSFVNQl9TSVpFIH0gZnJvbSAnLi4vY29uc3RhbnQnXG5cbmV4cG9ydCBjb25zdCBEYXRhTGlzdCA9IHN0eWxlZC5kYXRhbGlzdGBcbiAgd2lkdGg6IDEwMCU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgaGVpZ2h0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnR5cG9ncmFwaHkuY2FwdGlvbi5saW5lSGVpZ2h0fTtcblxuICAmW2RhdGEtZG91YmxlPSd0cnVlJ10ge1xuICAgIG1hcmdpbi10b3A6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzUnXX07XG4gIH1cbmBcblxuZXhwb3J0IGNvbnN0IE9wdGlvbiA9IHN0eWxlZCgnc3BhbicsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT4gIVsnbGVmdCcsICd3aWR0aCddLmluY2x1ZGVzKHByb3ApLFxufSk8eyBsZWZ0OiBudW1iZXI7IHdpZHRoOiBudW1iZXIgfT5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gIGxlZnQ6ICR7KHsgbGVmdCB9KSA9PiBsZWZ0fSU7XG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgdHJhbnNmb3JtOiB0cmFuc2xhdGVYKC01MCUpO1xuXG4gICZbZGF0YS1lbGVtZW50LWxlZnQ9J3RydWUnXSB7XG4gICAgdHJhbnNmb3JtOiBub25lO1xuICB9XG5cbiAgJltkYXRhLWVsZW1lbnQtcmlnaHQ9J3RydWUnXSB7XG4gICAgdHJhbnNmb3JtOiB0cmFuc2xhdGVYKC0xMDAlKTtcbiAgfVxuYFxuXG5leHBvcnQgdHlwZSBPcHRpb25zUHJvcHMgPSB7XG4gIHRpY2tzOiB7XG4gICAgdmFsdWU6IG51bWJlclxuICAgIGxhYmVsPzogc3RyaW5nIHwgdW5kZWZpbmVkXG4gIH1bXVxuICBtaW46IG51bWJlclxuICBtYXg6IG51bWJlclxuICBzbGlkZXJXaWR0aDogbnVtYmVyXG4gIHZhbHVlOiBudW1iZXIgfCBudW1iZXJbXVxuICBzdGVwOiBudW1iZXJcbn1cblxuZXhwb3J0IGNvbnN0IE9wdGlvbnMgPSAoe1xuICB0aWNrcyxcbiAgbWluLFxuICBtYXgsXG4gIHNsaWRlcldpZHRoLFxuICB2YWx1ZSxcbiAgc3RlcCxcbn06IE9wdGlvbnNQcm9wcykgPT4ge1xuICBjb25zdCBvcHRpb25XaWR0aCA9ICgoc2xpZGVyV2lkdGggLSBUSFVNQl9TSVpFIC8gMikgKiBzdGVwKSAvIChtYXggLSBtaW4pXG5cbiAgcmV0dXJuIChcbiAgICA8RGF0YUxpc3QgZGF0YS1kb3VibGU9e0FycmF5LmlzQXJyYXkodmFsdWUpfT5cbiAgICAgIHt0aWNrcy5tYXAoKGVsZW1lbnQsIGluZGV4LCB7IGxlbmd0aCB9KSA9PiB7XG4gICAgICAgIGNvbnN0IGxlZnQgPSAoKGluZGV4ICogc3RlcCAtIG1pbikgKiAxMDApIC8gKG1heCAtIG1pbilcblxuICAgICAgICBjb25zdCBmb3JtYXRlZEVsZW1lbnQgPSBlbGVtZW50LmxhYmVsID8/IFN0cmluZyhlbGVtZW50LnZhbHVlKVxuXG4gICAgICAgIGNvbnN0IGlzU2VsZWN0ZWQgPVxuICAgICAgICAgIHR5cGVvZiB2YWx1ZSA9PT0gJ251bWJlcidcbiAgICAgICAgICAgID8gZWxlbWVudC52YWx1ZSA9PT0gdmFsdWVcbiAgICAgICAgICAgIDogdmFsdWUuaW5jbHVkZXMoZWxlbWVudC52YWx1ZSlcblxuICAgICAgICByZXR1cm4gKFxuICAgICAgICAgIDxPcHRpb25cbiAgICAgICAgICAgIGtleT17ZWxlbWVudC52YWx1ZX1cbiAgICAgICAgICAgIGxlZnQ9e2xlZnR9XG4gICAgICAgICAgICB3aWR0aD17b3B0aW9uV2lkdGh9XG4gICAgICAgICAgICBkYXRhLXZhbHVlPXtlbGVtZW50LnZhbHVlfVxuICAgICAgICAgICAgZGF0YS1lbGVtZW50LWxlZnQ9e2luZGV4ID09PSAwfVxuICAgICAgICAgICAgZGF0YS1lbGVtZW50LXJpZ2h0PXtpbmRleCA9PT0gbGVuZ3RoIC0gMX1cbiAgICAgICAgICA+XG4gICAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgICBhcz1cInBcIlxuICAgICAgICAgICAgICB2YXJpYW50PXtpc1NlbGVjdGVkID8gJ2NhcHRpb25TdHJvbmcnIDogJ2NhcHRpb24nfVxuICAgICAgICAgICAgICBzZW50aW1lbnQ9e2lzU2VsZWN0ZWQgPyAncHJpbWFyeScgOiAnbmV1dHJhbCd9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtmb3JtYXRlZEVsZW1lbnR9XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgPC9PcHRpb24+XG4gICAgICAgIClcbiAgICAgIH0pfVxuICAgIDwvRGF0YUxpc3Q+XG4gIClcbn1cbiJdfQ== */"));
18
+ }) => theme.space["5"], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NsaWRlci9jb21wb25lbnRzL09wdGlvbnMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUl1QyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9TbGlkZXIvY29tcG9uZW50cy9PcHRpb25zLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uLy4uL1RleHQnXG5pbXBvcnQgeyBUSFVNQl9TSVpFIH0gZnJvbSAnLi4vY29uc3RhbnQnXG5cbmV4cG9ydCBjb25zdCBEYXRhTGlzdCA9IHN0eWxlZC5kYXRhbGlzdGBcbiAgd2lkdGg6IDEwMCU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgaGVpZ2h0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnR5cG9ncmFwaHkuY2FwdGlvbi5saW5lSGVpZ2h0fTtcblxuICAmW2RhdGEtZG91YmxlPSd0cnVlJ10ge1xuICAgIG1hcmdpbi10b3A6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzUnXX07XG4gIH1cbmBcblxuZXhwb3J0IGNvbnN0IE9wdGlvbiA9IHN0eWxlZCgnc3BhbicsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT4gIVsnbGVmdCcsICd3aWR0aCddLmluY2x1ZGVzKHByb3ApLFxufSk8eyBsZWZ0OiBudW1iZXI7IHdpZHRoOiBudW1iZXIgfT5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gIGxlZnQ6ICR7KHsgbGVmdCB9KSA9PiBsZWZ0fSU7XG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgdHJhbnNmb3JtOiB0cmFuc2xhdGVYKC01MCUpO1xuXG4gICZbZGF0YS1lbGVtZW50LWxlZnQ9J3RydWUnXSB7XG4gICAgdHJhbnNmb3JtOiBub25lO1xuICB9XG5cbiAgJltkYXRhLWVsZW1lbnQtcmlnaHQ9J3RydWUnXSB7XG4gICAgdHJhbnNmb3JtOiB0cmFuc2xhdGVYKC0xMDAlKTtcbiAgfVxuYFxuXG5leHBvcnQgdHlwZSBPcHRpb25zUHJvcHMgPSB7XG4gIHRpY2tzOiB7XG4gICAgdmFsdWU6IG51bWJlclxuICAgIGxhYmVsPzogc3RyaW5nIHwgdW5kZWZpbmVkXG4gIH1bXVxuICBtaW46IG51bWJlclxuICBtYXg6IG51bWJlclxuICBzbGlkZXJXaWR0aDogbnVtYmVyXG4gIHZhbHVlPzogbnVtYmVyIHwgbnVtYmVyW11cbiAgc3RlcDogbnVtYmVyXG59XG5cbmV4cG9ydCBjb25zdCBPcHRpb25zID0gKHtcbiAgdGlja3MsXG4gIG1pbixcbiAgbWF4LFxuICBzbGlkZXJXaWR0aCxcbiAgdmFsdWUsXG4gIHN0ZXAsXG59OiBPcHRpb25zUHJvcHMpID0+IHtcbiAgY29uc3Qgb3B0aW9uV2lkdGggPSAoKHNsaWRlcldpZHRoIC0gVEhVTUJfU0laRSAvIDIpICogc3RlcCkgLyAobWF4IC0gbWluKVxuXG4gIHJldHVybiAoXG4gICAgPERhdGFMaXN0IGRhdGEtZG91YmxlPXtBcnJheS5pc0FycmF5KHZhbHVlKX0+XG4gICAgICB7dGlja3MubWFwKChlbGVtZW50LCBpbmRleCwgeyBsZW5ndGggfSkgPT4ge1xuICAgICAgICBjb25zdCBsZWZ0ID0gKChpbmRleCAqIHN0ZXAgLSBtaW4pICogMTAwKSAvIChtYXggLSBtaW4pXG5cbiAgICAgICAgY29uc3QgZm9ybWF0ZWRFbGVtZW50ID0gZWxlbWVudC5sYWJlbCA/PyBTdHJpbmcoZWxlbWVudC52YWx1ZSlcblxuICAgICAgICBjb25zdCBnZXRJc1NlbGVjdGVkID0gKCkgPT4ge1xuICAgICAgICAgIGlmICghdmFsdWUpIHtcbiAgICAgICAgICAgIHJldHVybiBmYWxzZVxuICAgICAgICAgIH1cblxuICAgICAgICAgIHJldHVybiB0eXBlb2YgdmFsdWUgPT09ICdudW1iZXInXG4gICAgICAgICAgICA/IGVsZW1lbnQudmFsdWUgPT09IHZhbHVlXG4gICAgICAgICAgICA6IHZhbHVlLmluY2x1ZGVzKGVsZW1lbnQudmFsdWUpXG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCBpc1NlbGVjdGVkID0gZ2V0SXNTZWxlY3RlZCgpXG5cbiAgICAgICAgcmV0dXJuIChcbiAgICAgICAgICA8T3B0aW9uXG4gICAgICAgICAgICBrZXk9e2VsZW1lbnQudmFsdWV9XG4gICAgICAgICAgICBsZWZ0PXtsZWZ0fVxuICAgICAgICAgICAgd2lkdGg9e29wdGlvbldpZHRofVxuICAgICAgICAgICAgZGF0YS12YWx1ZT17ZWxlbWVudC52YWx1ZX1cbiAgICAgICAgICAgIGRhdGEtZWxlbWVudC1sZWZ0PXtpbmRleCA9PT0gMH1cbiAgICAgICAgICAgIGRhdGEtZWxlbWVudC1yaWdodD17aW5kZXggPT09IGxlbmd0aCAtIDF9XG4gICAgICAgICAgPlxuICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgYXM9XCJwXCJcbiAgICAgICAgICAgICAgdmFyaWFudD17aXNTZWxlY3RlZCA/ICdjYXB0aW9uU3Ryb25nJyA6ICdjYXB0aW9uJ31cbiAgICAgICAgICAgICAgc2VudGltZW50PXtpc1NlbGVjdGVkID8gJ3ByaW1hcnknIDogJ25ldXRyYWwnfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7Zm9ybWF0ZWRFbGVtZW50fVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgIDwvT3B0aW9uPlxuICAgICAgICApXG4gICAgICB9KX1cbiAgICA8L0RhdGFMaXN0PlxuICApXG59XG4iXX0= */"));
19
19
  const Option = /* @__PURE__ */ _styled__default.default("span", process.env.NODE_ENV === "production" ? {
20
20
  shouldForwardProp: (prop) => !["left", "width"].includes(prop),
21
21
  target: "e1dbiu720"
@@ -25,7 +25,7 @@ const Option = /* @__PURE__ */ _styled__default.default("span", process.env.NODE
25
25
  label: "Option"
26
26
  })("display:flex;white-space:nowrap;left:", ({
27
27
  left
28
- }) => left, "%;position:absolute;transform:translateX(-50%);&[data-element-left='true']{transform:none;}&[data-element-right='true']{transform:translateX(-100%);}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NsaWRlci9jb21wb25lbnRzL09wdGlvbnMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlCbUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvU2xpZGVyL2NvbXBvbmVudHMvT3B0aW9ucy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi8uLi9UZXh0J1xuaW1wb3J0IHsgVEhVTUJfU0laRSB9IGZyb20gJy4uL2NvbnN0YW50J1xuXG5leHBvcnQgY29uc3QgRGF0YUxpc3QgPSBzdHlsZWQuZGF0YWxpc3RgXG4gIHdpZHRoOiAxMDAlO1xuICBkaXNwbGF5OiBmbGV4O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGhlaWdodDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS50eXBvZ3JhcGh5LmNhcHRpb24ubGluZUhlaWdodH07XG5cbiAgJltkYXRhLWRvdWJsZT0ndHJ1ZSddIHtcbiAgICBtYXJnaW4tdG9wOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWyc1J119O1xuICB9XG5gXG5cbmV4cG9ydCBjb25zdCBPcHRpb24gPSBzdHlsZWQoJ3NwYW4nLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ2xlZnQnLCAnd2lkdGgnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgbGVmdDogbnVtYmVyOyB3aWR0aDogbnVtYmVyIH0+YFxuICBkaXNwbGF5OiBmbGV4O1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICBsZWZ0OiAkeyh7IGxlZnQgfSkgPT4gbGVmdH0lO1xuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIHRyYW5zZm9ybTogdHJhbnNsYXRlWCgtNTAlKTtcblxuICAmW2RhdGEtZWxlbWVudC1sZWZ0PSd0cnVlJ10ge1xuICAgIHRyYW5zZm9ybTogbm9uZTtcbiAgfVxuXG4gICZbZGF0YS1lbGVtZW50LXJpZ2h0PSd0cnVlJ10ge1xuICAgIHRyYW5zZm9ybTogdHJhbnNsYXRlWCgtMTAwJSk7XG4gIH1cbmBcblxuZXhwb3J0IHR5cGUgT3B0aW9uc1Byb3BzID0ge1xuICB0aWNrczoge1xuICAgIHZhbHVlOiBudW1iZXJcbiAgICBsYWJlbD86IHN0cmluZyB8IHVuZGVmaW5lZFxuICB9W11cbiAgbWluOiBudW1iZXJcbiAgbWF4OiBudW1iZXJcbiAgc2xpZGVyV2lkdGg6IG51bWJlclxuICB2YWx1ZTogbnVtYmVyIHwgbnVtYmVyW11cbiAgc3RlcDogbnVtYmVyXG59XG5cbmV4cG9ydCBjb25zdCBPcHRpb25zID0gKHtcbiAgdGlja3MsXG4gIG1pbixcbiAgbWF4LFxuICBzbGlkZXJXaWR0aCxcbiAgdmFsdWUsXG4gIHN0ZXAsXG59OiBPcHRpb25zUHJvcHMpID0+IHtcbiAgY29uc3Qgb3B0aW9uV2lkdGggPSAoKHNsaWRlcldpZHRoIC0gVEhVTUJfU0laRSAvIDIpICogc3RlcCkgLyAobWF4IC0gbWluKVxuXG4gIHJldHVybiAoXG4gICAgPERhdGFMaXN0IGRhdGEtZG91YmxlPXtBcnJheS5pc0FycmF5KHZhbHVlKX0+XG4gICAgICB7dGlja3MubWFwKChlbGVtZW50LCBpbmRleCwgeyBsZW5ndGggfSkgPT4ge1xuICAgICAgICBjb25zdCBsZWZ0ID0gKChpbmRleCAqIHN0ZXAgLSBtaW4pICogMTAwKSAvIChtYXggLSBtaW4pXG5cbiAgICAgICAgY29uc3QgZm9ybWF0ZWRFbGVtZW50ID0gZWxlbWVudC5sYWJlbCA/PyBTdHJpbmcoZWxlbWVudC52YWx1ZSlcblxuICAgICAgICBjb25zdCBpc1NlbGVjdGVkID1cbiAgICAgICAgICB0eXBlb2YgdmFsdWUgPT09ICdudW1iZXInXG4gICAgICAgICAgICA/IGVsZW1lbnQudmFsdWUgPT09IHZhbHVlXG4gICAgICAgICAgICA6IHZhbHVlLmluY2x1ZGVzKGVsZW1lbnQudmFsdWUpXG5cbiAgICAgICAgcmV0dXJuIChcbiAgICAgICAgICA8T3B0aW9uXG4gICAgICAgICAgICBrZXk9e2VsZW1lbnQudmFsdWV9XG4gICAgICAgICAgICBsZWZ0PXtsZWZ0fVxuICAgICAgICAgICAgd2lkdGg9e29wdGlvbldpZHRofVxuICAgICAgICAgICAgZGF0YS12YWx1ZT17ZWxlbWVudC52YWx1ZX1cbiAgICAgICAgICAgIGRhdGEtZWxlbWVudC1sZWZ0PXtpbmRleCA9PT0gMH1cbiAgICAgICAgICAgIGRhdGEtZWxlbWVudC1yaWdodD17aW5kZXggPT09IGxlbmd0aCAtIDF9XG4gICAgICAgICAgPlxuICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgYXM9XCJwXCJcbiAgICAgICAgICAgICAgdmFyaWFudD17aXNTZWxlY3RlZCA/ICdjYXB0aW9uU3Ryb25nJyA6ICdjYXB0aW9uJ31cbiAgICAgICAgICAgICAgc2VudGltZW50PXtpc1NlbGVjdGVkID8gJ3ByaW1hcnknIDogJ25ldXRyYWwnfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7Zm9ybWF0ZWRFbGVtZW50fVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgIDwvT3B0aW9uPlxuICAgICAgICApXG4gICAgICB9KX1cbiAgICA8L0RhdGFMaXN0PlxuICApXG59XG4iXX0= */"));
28
+ }) => left, "%;position:absolute;transform:translateX(-50%);&[data-element-left='true']{transform:none;}&[data-element-right='true']{transform:translateX(-100%);}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NsaWRlci9jb21wb25lbnRzL09wdGlvbnMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlCbUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvU2xpZGVyL2NvbXBvbmVudHMvT3B0aW9ucy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi8uLi9UZXh0J1xuaW1wb3J0IHsgVEhVTUJfU0laRSB9IGZyb20gJy4uL2NvbnN0YW50J1xuXG5leHBvcnQgY29uc3QgRGF0YUxpc3QgPSBzdHlsZWQuZGF0YWxpc3RgXG4gIHdpZHRoOiAxMDAlO1xuICBkaXNwbGF5OiBmbGV4O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGhlaWdodDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS50eXBvZ3JhcGh5LmNhcHRpb24ubGluZUhlaWdodH07XG5cbiAgJltkYXRhLWRvdWJsZT0ndHJ1ZSddIHtcbiAgICBtYXJnaW4tdG9wOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWyc1J119O1xuICB9XG5gXG5cbmV4cG9ydCBjb25zdCBPcHRpb24gPSBzdHlsZWQoJ3NwYW4nLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ2xlZnQnLCAnd2lkdGgnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgbGVmdDogbnVtYmVyOyB3aWR0aDogbnVtYmVyIH0+YFxuICBkaXNwbGF5OiBmbGV4O1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICBsZWZ0OiAkeyh7IGxlZnQgfSkgPT4gbGVmdH0lO1xuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIHRyYW5zZm9ybTogdHJhbnNsYXRlWCgtNTAlKTtcblxuICAmW2RhdGEtZWxlbWVudC1sZWZ0PSd0cnVlJ10ge1xuICAgIHRyYW5zZm9ybTogbm9uZTtcbiAgfVxuXG4gICZbZGF0YS1lbGVtZW50LXJpZ2h0PSd0cnVlJ10ge1xuICAgIHRyYW5zZm9ybTogdHJhbnNsYXRlWCgtMTAwJSk7XG4gIH1cbmBcblxuZXhwb3J0IHR5cGUgT3B0aW9uc1Byb3BzID0ge1xuICB0aWNrczoge1xuICAgIHZhbHVlOiBudW1iZXJcbiAgICBsYWJlbD86IHN0cmluZyB8IHVuZGVmaW5lZFxuICB9W11cbiAgbWluOiBudW1iZXJcbiAgbWF4OiBudW1iZXJcbiAgc2xpZGVyV2lkdGg6IG51bWJlclxuICB2YWx1ZT86IG51bWJlciB8IG51bWJlcltdXG4gIHN0ZXA6IG51bWJlclxufVxuXG5leHBvcnQgY29uc3QgT3B0aW9ucyA9ICh7XG4gIHRpY2tzLFxuICBtaW4sXG4gIG1heCxcbiAgc2xpZGVyV2lkdGgsXG4gIHZhbHVlLFxuICBzdGVwLFxufTogT3B0aW9uc1Byb3BzKSA9PiB7XG4gIGNvbnN0IG9wdGlvbldpZHRoID0gKChzbGlkZXJXaWR0aCAtIFRIVU1CX1NJWkUgLyAyKSAqIHN0ZXApIC8gKG1heCAtIG1pbilcblxuICByZXR1cm4gKFxuICAgIDxEYXRhTGlzdCBkYXRhLWRvdWJsZT17QXJyYXkuaXNBcnJheSh2YWx1ZSl9PlxuICAgICAge3RpY2tzLm1hcCgoZWxlbWVudCwgaW5kZXgsIHsgbGVuZ3RoIH0pID0+IHtcbiAgICAgICAgY29uc3QgbGVmdCA9ICgoaW5kZXggKiBzdGVwIC0gbWluKSAqIDEwMCkgLyAobWF4IC0gbWluKVxuXG4gICAgICAgIGNvbnN0IGZvcm1hdGVkRWxlbWVudCA9IGVsZW1lbnQubGFiZWwgPz8gU3RyaW5nKGVsZW1lbnQudmFsdWUpXG5cbiAgICAgICAgY29uc3QgZ2V0SXNTZWxlY3RlZCA9ICgpID0+IHtcbiAgICAgICAgICBpZiAoIXZhbHVlKSB7XG4gICAgICAgICAgICByZXR1cm4gZmFsc2VcbiAgICAgICAgICB9XG5cbiAgICAgICAgICByZXR1cm4gdHlwZW9mIHZhbHVlID09PSAnbnVtYmVyJ1xuICAgICAgICAgICAgPyBlbGVtZW50LnZhbHVlID09PSB2YWx1ZVxuICAgICAgICAgICAgOiB2YWx1ZS5pbmNsdWRlcyhlbGVtZW50LnZhbHVlKVxuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgaXNTZWxlY3RlZCA9IGdldElzU2VsZWN0ZWQoKVxuXG4gICAgICAgIHJldHVybiAoXG4gICAgICAgICAgPE9wdGlvblxuICAgICAgICAgICAga2V5PXtlbGVtZW50LnZhbHVlfVxuICAgICAgICAgICAgbGVmdD17bGVmdH1cbiAgICAgICAgICAgIHdpZHRoPXtvcHRpb25XaWR0aH1cbiAgICAgICAgICAgIGRhdGEtdmFsdWU9e2VsZW1lbnQudmFsdWV9XG4gICAgICAgICAgICBkYXRhLWVsZW1lbnQtbGVmdD17aW5kZXggPT09IDB9XG4gICAgICAgICAgICBkYXRhLWVsZW1lbnQtcmlnaHQ9e2luZGV4ID09PSBsZW5ndGggLSAxfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgIGFzPVwicFwiXG4gICAgICAgICAgICAgIHZhcmlhbnQ9e2lzU2VsZWN0ZWQgPyAnY2FwdGlvblN0cm9uZycgOiAnY2FwdGlvbid9XG4gICAgICAgICAgICAgIHNlbnRpbWVudD17aXNTZWxlY3RlZCA/ICdwcmltYXJ5JyA6ICduZXV0cmFsJ31cbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAge2Zvcm1hdGVkRWxlbWVudH1cbiAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICA8L09wdGlvbj5cbiAgICAgICAgKVxuICAgICAgfSl9XG4gICAgPC9EYXRhTGlzdD5cbiAgKVxufVxuIl19 */"));
29
29
  const Options = ({
30
30
  ticks,
31
31
  min,
@@ -40,7 +40,13 @@ const Options = ({
40
40
  }) => {
41
41
  const left = (index$1 * step - min) * 100 / (max - min);
42
42
  const formatedElement = element.label ?? String(element.value);
43
- const isSelected = typeof value === "number" ? element.value === value : value.includes(element.value);
43
+ const getIsSelected = () => {
44
+ if (!value) {
45
+ return false;
46
+ }
47
+ return typeof value === "number" ? element.value === value : value.includes(element.value);
48
+ };
49
+ const isSelected = getIsSelected();
44
50
  return /* @__PURE__ */ jsxRuntime.jsx(Option, { left, width: optionWidth, "data-value": element.value, "data-element-left": index$1 === 0, "data-element-right": index$1 === length - 1, children: /* @__PURE__ */ jsxRuntime.jsx(index.Text, { as: "p", variant: isSelected ? "captionStrong" : "caption", sentiment: isSelected ? "primary" : "neutral", children: formatedElement }) }, element.value);
45
51
  }) });
46
52
  };
@@ -17,7 +17,7 @@ export type OptionsProps = {
17
17
  min: number;
18
18
  max: number;
19
19
  sliderWidth: number;
20
- value: number | number[];
20
+ value?: number | number[];
21
21
  step: number;
22
22
  };
23
23
  export declare const Options: ({ ticks, min, max, sliderWidth, value, step, }: OptionsProps) => import("@emotion/react/jsx-runtime").JSX.Element;
@@ -11,7 +11,7 @@ const DataList = /* @__PURE__ */ _styled("datalist", process.env.NODE_ENV === "p
11
11
  theme
12
12
  }) => theme.typography.caption.lineHeight, ";&[data-double='true']{margin-top:", ({
13
13
  theme
14
- }) => theme.space["5"], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NsaWRlci9jb21wb25lbnRzL09wdGlvbnMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUl1QyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9TbGlkZXIvY29tcG9uZW50cy9PcHRpb25zLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uLy4uL1RleHQnXG5pbXBvcnQgeyBUSFVNQl9TSVpFIH0gZnJvbSAnLi4vY29uc3RhbnQnXG5cbmV4cG9ydCBjb25zdCBEYXRhTGlzdCA9IHN0eWxlZC5kYXRhbGlzdGBcbiAgd2lkdGg6IDEwMCU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgaGVpZ2h0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnR5cG9ncmFwaHkuY2FwdGlvbi5saW5lSGVpZ2h0fTtcblxuICAmW2RhdGEtZG91YmxlPSd0cnVlJ10ge1xuICAgIG1hcmdpbi10b3A6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzUnXX07XG4gIH1cbmBcblxuZXhwb3J0IGNvbnN0IE9wdGlvbiA9IHN0eWxlZCgnc3BhbicsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT4gIVsnbGVmdCcsICd3aWR0aCddLmluY2x1ZGVzKHByb3ApLFxufSk8eyBsZWZ0OiBudW1iZXI7IHdpZHRoOiBudW1iZXIgfT5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gIGxlZnQ6ICR7KHsgbGVmdCB9KSA9PiBsZWZ0fSU7XG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgdHJhbnNmb3JtOiB0cmFuc2xhdGVYKC01MCUpO1xuXG4gICZbZGF0YS1lbGVtZW50LWxlZnQ9J3RydWUnXSB7XG4gICAgdHJhbnNmb3JtOiBub25lO1xuICB9XG5cbiAgJltkYXRhLWVsZW1lbnQtcmlnaHQ9J3RydWUnXSB7XG4gICAgdHJhbnNmb3JtOiB0cmFuc2xhdGVYKC0xMDAlKTtcbiAgfVxuYFxuXG5leHBvcnQgdHlwZSBPcHRpb25zUHJvcHMgPSB7XG4gIHRpY2tzOiB7XG4gICAgdmFsdWU6IG51bWJlclxuICAgIGxhYmVsPzogc3RyaW5nIHwgdW5kZWZpbmVkXG4gIH1bXVxuICBtaW46IG51bWJlclxuICBtYXg6IG51bWJlclxuICBzbGlkZXJXaWR0aDogbnVtYmVyXG4gIHZhbHVlOiBudW1iZXIgfCBudW1iZXJbXVxuICBzdGVwOiBudW1iZXJcbn1cblxuZXhwb3J0IGNvbnN0IE9wdGlvbnMgPSAoe1xuICB0aWNrcyxcbiAgbWluLFxuICBtYXgsXG4gIHNsaWRlcldpZHRoLFxuICB2YWx1ZSxcbiAgc3RlcCxcbn06IE9wdGlvbnNQcm9wcykgPT4ge1xuICBjb25zdCBvcHRpb25XaWR0aCA9ICgoc2xpZGVyV2lkdGggLSBUSFVNQl9TSVpFIC8gMikgKiBzdGVwKSAvIChtYXggLSBtaW4pXG5cbiAgcmV0dXJuIChcbiAgICA8RGF0YUxpc3QgZGF0YS1kb3VibGU9e0FycmF5LmlzQXJyYXkodmFsdWUpfT5cbiAgICAgIHt0aWNrcy5tYXAoKGVsZW1lbnQsIGluZGV4LCB7IGxlbmd0aCB9KSA9PiB7XG4gICAgICAgIGNvbnN0IGxlZnQgPSAoKGluZGV4ICogc3RlcCAtIG1pbikgKiAxMDApIC8gKG1heCAtIG1pbilcblxuICAgICAgICBjb25zdCBmb3JtYXRlZEVsZW1lbnQgPSBlbGVtZW50LmxhYmVsID8/IFN0cmluZyhlbGVtZW50LnZhbHVlKVxuXG4gICAgICAgIGNvbnN0IGlzU2VsZWN0ZWQgPVxuICAgICAgICAgIHR5cGVvZiB2YWx1ZSA9PT0gJ251bWJlcidcbiAgICAgICAgICAgID8gZWxlbWVudC52YWx1ZSA9PT0gdmFsdWVcbiAgICAgICAgICAgIDogdmFsdWUuaW5jbHVkZXMoZWxlbWVudC52YWx1ZSlcblxuICAgICAgICByZXR1cm4gKFxuICAgICAgICAgIDxPcHRpb25cbiAgICAgICAgICAgIGtleT17ZWxlbWVudC52YWx1ZX1cbiAgICAgICAgICAgIGxlZnQ9e2xlZnR9XG4gICAgICAgICAgICB3aWR0aD17b3B0aW9uV2lkdGh9XG4gICAgICAgICAgICBkYXRhLXZhbHVlPXtlbGVtZW50LnZhbHVlfVxuICAgICAgICAgICAgZGF0YS1lbGVtZW50LWxlZnQ9e2luZGV4ID09PSAwfVxuICAgICAgICAgICAgZGF0YS1lbGVtZW50LXJpZ2h0PXtpbmRleCA9PT0gbGVuZ3RoIC0gMX1cbiAgICAgICAgICA+XG4gICAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgICBhcz1cInBcIlxuICAgICAgICAgICAgICB2YXJpYW50PXtpc1NlbGVjdGVkID8gJ2NhcHRpb25TdHJvbmcnIDogJ2NhcHRpb24nfVxuICAgICAgICAgICAgICBzZW50aW1lbnQ9e2lzU2VsZWN0ZWQgPyAncHJpbWFyeScgOiAnbmV1dHJhbCd9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtmb3JtYXRlZEVsZW1lbnR9XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgPC9PcHRpb24+XG4gICAgICAgIClcbiAgICAgIH0pfVxuICAgIDwvRGF0YUxpc3Q+XG4gIClcbn1cbiJdfQ== */"));
14
+ }) => theme.space["5"], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NsaWRlci9jb21wb25lbnRzL09wdGlvbnMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUl1QyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9TbGlkZXIvY29tcG9uZW50cy9PcHRpb25zLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uLy4uL1RleHQnXG5pbXBvcnQgeyBUSFVNQl9TSVpFIH0gZnJvbSAnLi4vY29uc3RhbnQnXG5cbmV4cG9ydCBjb25zdCBEYXRhTGlzdCA9IHN0eWxlZC5kYXRhbGlzdGBcbiAgd2lkdGg6IDEwMCU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgaGVpZ2h0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnR5cG9ncmFwaHkuY2FwdGlvbi5saW5lSGVpZ2h0fTtcblxuICAmW2RhdGEtZG91YmxlPSd0cnVlJ10ge1xuICAgIG1hcmdpbi10b3A6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzUnXX07XG4gIH1cbmBcblxuZXhwb3J0IGNvbnN0IE9wdGlvbiA9IHN0eWxlZCgnc3BhbicsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT4gIVsnbGVmdCcsICd3aWR0aCddLmluY2x1ZGVzKHByb3ApLFxufSk8eyBsZWZ0OiBudW1iZXI7IHdpZHRoOiBudW1iZXIgfT5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gIGxlZnQ6ICR7KHsgbGVmdCB9KSA9PiBsZWZ0fSU7XG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgdHJhbnNmb3JtOiB0cmFuc2xhdGVYKC01MCUpO1xuXG4gICZbZGF0YS1lbGVtZW50LWxlZnQ9J3RydWUnXSB7XG4gICAgdHJhbnNmb3JtOiBub25lO1xuICB9XG5cbiAgJltkYXRhLWVsZW1lbnQtcmlnaHQ9J3RydWUnXSB7XG4gICAgdHJhbnNmb3JtOiB0cmFuc2xhdGVYKC0xMDAlKTtcbiAgfVxuYFxuXG5leHBvcnQgdHlwZSBPcHRpb25zUHJvcHMgPSB7XG4gIHRpY2tzOiB7XG4gICAgdmFsdWU6IG51bWJlclxuICAgIGxhYmVsPzogc3RyaW5nIHwgdW5kZWZpbmVkXG4gIH1bXVxuICBtaW46IG51bWJlclxuICBtYXg6IG51bWJlclxuICBzbGlkZXJXaWR0aDogbnVtYmVyXG4gIHZhbHVlPzogbnVtYmVyIHwgbnVtYmVyW11cbiAgc3RlcDogbnVtYmVyXG59XG5cbmV4cG9ydCBjb25zdCBPcHRpb25zID0gKHtcbiAgdGlja3MsXG4gIG1pbixcbiAgbWF4LFxuICBzbGlkZXJXaWR0aCxcbiAgdmFsdWUsXG4gIHN0ZXAsXG59OiBPcHRpb25zUHJvcHMpID0+IHtcbiAgY29uc3Qgb3B0aW9uV2lkdGggPSAoKHNsaWRlcldpZHRoIC0gVEhVTUJfU0laRSAvIDIpICogc3RlcCkgLyAobWF4IC0gbWluKVxuXG4gIHJldHVybiAoXG4gICAgPERhdGFMaXN0IGRhdGEtZG91YmxlPXtBcnJheS5pc0FycmF5KHZhbHVlKX0+XG4gICAgICB7dGlja3MubWFwKChlbGVtZW50LCBpbmRleCwgeyBsZW5ndGggfSkgPT4ge1xuICAgICAgICBjb25zdCBsZWZ0ID0gKChpbmRleCAqIHN0ZXAgLSBtaW4pICogMTAwKSAvIChtYXggLSBtaW4pXG5cbiAgICAgICAgY29uc3QgZm9ybWF0ZWRFbGVtZW50ID0gZWxlbWVudC5sYWJlbCA/PyBTdHJpbmcoZWxlbWVudC52YWx1ZSlcblxuICAgICAgICBjb25zdCBnZXRJc1NlbGVjdGVkID0gKCkgPT4ge1xuICAgICAgICAgIGlmICghdmFsdWUpIHtcbiAgICAgICAgICAgIHJldHVybiBmYWxzZVxuICAgICAgICAgIH1cblxuICAgICAgICAgIHJldHVybiB0eXBlb2YgdmFsdWUgPT09ICdudW1iZXInXG4gICAgICAgICAgICA/IGVsZW1lbnQudmFsdWUgPT09IHZhbHVlXG4gICAgICAgICAgICA6IHZhbHVlLmluY2x1ZGVzKGVsZW1lbnQudmFsdWUpXG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCBpc1NlbGVjdGVkID0gZ2V0SXNTZWxlY3RlZCgpXG5cbiAgICAgICAgcmV0dXJuIChcbiAgICAgICAgICA8T3B0aW9uXG4gICAgICAgICAgICBrZXk9e2VsZW1lbnQudmFsdWV9XG4gICAgICAgICAgICBsZWZ0PXtsZWZ0fVxuICAgICAgICAgICAgd2lkdGg9e29wdGlvbldpZHRofVxuICAgICAgICAgICAgZGF0YS12YWx1ZT17ZWxlbWVudC52YWx1ZX1cbiAgICAgICAgICAgIGRhdGEtZWxlbWVudC1sZWZ0PXtpbmRleCA9PT0gMH1cbiAgICAgICAgICAgIGRhdGEtZWxlbWVudC1yaWdodD17aW5kZXggPT09IGxlbmd0aCAtIDF9XG4gICAgICAgICAgPlxuICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgYXM9XCJwXCJcbiAgICAgICAgICAgICAgdmFyaWFudD17aXNTZWxlY3RlZCA/ICdjYXB0aW9uU3Ryb25nJyA6ICdjYXB0aW9uJ31cbiAgICAgICAgICAgICAgc2VudGltZW50PXtpc1NlbGVjdGVkID8gJ3ByaW1hcnknIDogJ25ldXRyYWwnfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7Zm9ybWF0ZWRFbGVtZW50fVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgIDwvT3B0aW9uPlxuICAgICAgICApXG4gICAgICB9KX1cbiAgICA8L0RhdGFMaXN0PlxuICApXG59XG4iXX0= */"));
15
15
  const Option = /* @__PURE__ */ _styled("span", process.env.NODE_ENV === "production" ? {
16
16
  shouldForwardProp: (prop) => !["left", "width"].includes(prop),
17
17
  target: "e1dbiu720"
@@ -21,7 +21,7 @@ const Option = /* @__PURE__ */ _styled("span", process.env.NODE_ENV === "product
21
21
  label: "Option"
22
22
  })("display:flex;white-space:nowrap;left:", ({
23
23
  left
24
- }) => left, "%;position:absolute;transform:translateX(-50%);&[data-element-left='true']{transform:none;}&[data-element-right='true']{transform:translateX(-100%);}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NsaWRlci9jb21wb25lbnRzL09wdGlvbnMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlCbUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvU2xpZGVyL2NvbXBvbmVudHMvT3B0aW9ucy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi8uLi9UZXh0J1xuaW1wb3J0IHsgVEhVTUJfU0laRSB9IGZyb20gJy4uL2NvbnN0YW50J1xuXG5leHBvcnQgY29uc3QgRGF0YUxpc3QgPSBzdHlsZWQuZGF0YWxpc3RgXG4gIHdpZHRoOiAxMDAlO1xuICBkaXNwbGF5OiBmbGV4O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGhlaWdodDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS50eXBvZ3JhcGh5LmNhcHRpb24ubGluZUhlaWdodH07XG5cbiAgJltkYXRhLWRvdWJsZT0ndHJ1ZSddIHtcbiAgICBtYXJnaW4tdG9wOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWyc1J119O1xuICB9XG5gXG5cbmV4cG9ydCBjb25zdCBPcHRpb24gPSBzdHlsZWQoJ3NwYW4nLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ2xlZnQnLCAnd2lkdGgnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgbGVmdDogbnVtYmVyOyB3aWR0aDogbnVtYmVyIH0+YFxuICBkaXNwbGF5OiBmbGV4O1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICBsZWZ0OiAkeyh7IGxlZnQgfSkgPT4gbGVmdH0lO1xuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIHRyYW5zZm9ybTogdHJhbnNsYXRlWCgtNTAlKTtcblxuICAmW2RhdGEtZWxlbWVudC1sZWZ0PSd0cnVlJ10ge1xuICAgIHRyYW5zZm9ybTogbm9uZTtcbiAgfVxuXG4gICZbZGF0YS1lbGVtZW50LXJpZ2h0PSd0cnVlJ10ge1xuICAgIHRyYW5zZm9ybTogdHJhbnNsYXRlWCgtMTAwJSk7XG4gIH1cbmBcblxuZXhwb3J0IHR5cGUgT3B0aW9uc1Byb3BzID0ge1xuICB0aWNrczoge1xuICAgIHZhbHVlOiBudW1iZXJcbiAgICBsYWJlbD86IHN0cmluZyB8IHVuZGVmaW5lZFxuICB9W11cbiAgbWluOiBudW1iZXJcbiAgbWF4OiBudW1iZXJcbiAgc2xpZGVyV2lkdGg6IG51bWJlclxuICB2YWx1ZTogbnVtYmVyIHwgbnVtYmVyW11cbiAgc3RlcDogbnVtYmVyXG59XG5cbmV4cG9ydCBjb25zdCBPcHRpb25zID0gKHtcbiAgdGlja3MsXG4gIG1pbixcbiAgbWF4LFxuICBzbGlkZXJXaWR0aCxcbiAgdmFsdWUsXG4gIHN0ZXAsXG59OiBPcHRpb25zUHJvcHMpID0+IHtcbiAgY29uc3Qgb3B0aW9uV2lkdGggPSAoKHNsaWRlcldpZHRoIC0gVEhVTUJfU0laRSAvIDIpICogc3RlcCkgLyAobWF4IC0gbWluKVxuXG4gIHJldHVybiAoXG4gICAgPERhdGFMaXN0IGRhdGEtZG91YmxlPXtBcnJheS5pc0FycmF5KHZhbHVlKX0+XG4gICAgICB7dGlja3MubWFwKChlbGVtZW50LCBpbmRleCwgeyBsZW5ndGggfSkgPT4ge1xuICAgICAgICBjb25zdCBsZWZ0ID0gKChpbmRleCAqIHN0ZXAgLSBtaW4pICogMTAwKSAvIChtYXggLSBtaW4pXG5cbiAgICAgICAgY29uc3QgZm9ybWF0ZWRFbGVtZW50ID0gZWxlbWVudC5sYWJlbCA/PyBTdHJpbmcoZWxlbWVudC52YWx1ZSlcblxuICAgICAgICBjb25zdCBpc1NlbGVjdGVkID1cbiAgICAgICAgICB0eXBlb2YgdmFsdWUgPT09ICdudW1iZXInXG4gICAgICAgICAgICA/IGVsZW1lbnQudmFsdWUgPT09IHZhbHVlXG4gICAgICAgICAgICA6IHZhbHVlLmluY2x1ZGVzKGVsZW1lbnQudmFsdWUpXG5cbiAgICAgICAgcmV0dXJuIChcbiAgICAgICAgICA8T3B0aW9uXG4gICAgICAgICAgICBrZXk9e2VsZW1lbnQudmFsdWV9XG4gICAgICAgICAgICBsZWZ0PXtsZWZ0fVxuICAgICAgICAgICAgd2lkdGg9e29wdGlvbldpZHRofVxuICAgICAgICAgICAgZGF0YS12YWx1ZT17ZWxlbWVudC52YWx1ZX1cbiAgICAgICAgICAgIGRhdGEtZWxlbWVudC1sZWZ0PXtpbmRleCA9PT0gMH1cbiAgICAgICAgICAgIGRhdGEtZWxlbWVudC1yaWdodD17aW5kZXggPT09IGxlbmd0aCAtIDF9XG4gICAgICAgICAgPlxuICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgYXM9XCJwXCJcbiAgICAgICAgICAgICAgdmFyaWFudD17aXNTZWxlY3RlZCA/ICdjYXB0aW9uU3Ryb25nJyA6ICdjYXB0aW9uJ31cbiAgICAgICAgICAgICAgc2VudGltZW50PXtpc1NlbGVjdGVkID8gJ3ByaW1hcnknIDogJ25ldXRyYWwnfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7Zm9ybWF0ZWRFbGVtZW50fVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgIDwvT3B0aW9uPlxuICAgICAgICApXG4gICAgICB9KX1cbiAgICA8L0RhdGFMaXN0PlxuICApXG59XG4iXX0= */"));
24
+ }) => left, "%;position:absolute;transform:translateX(-50%);&[data-element-left='true']{transform:none;}&[data-element-right='true']{transform:translateX(-100%);}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1NsaWRlci9jb21wb25lbnRzL09wdGlvbnMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlCbUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvU2xpZGVyL2NvbXBvbmVudHMvT3B0aW9ucy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi8uLi9UZXh0J1xuaW1wb3J0IHsgVEhVTUJfU0laRSB9IGZyb20gJy4uL2NvbnN0YW50J1xuXG5leHBvcnQgY29uc3QgRGF0YUxpc3QgPSBzdHlsZWQuZGF0YWxpc3RgXG4gIHdpZHRoOiAxMDAlO1xuICBkaXNwbGF5OiBmbGV4O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGhlaWdodDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS50eXBvZ3JhcGh5LmNhcHRpb24ubGluZUhlaWdodH07XG5cbiAgJltkYXRhLWRvdWJsZT0ndHJ1ZSddIHtcbiAgICBtYXJnaW4tdG9wOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWyc1J119O1xuICB9XG5gXG5cbmV4cG9ydCBjb25zdCBPcHRpb24gPSBzdHlsZWQoJ3NwYW4nLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ2xlZnQnLCAnd2lkdGgnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgbGVmdDogbnVtYmVyOyB3aWR0aDogbnVtYmVyIH0+YFxuICBkaXNwbGF5OiBmbGV4O1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICBsZWZ0OiAkeyh7IGxlZnQgfSkgPT4gbGVmdH0lO1xuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIHRyYW5zZm9ybTogdHJhbnNsYXRlWCgtNTAlKTtcblxuICAmW2RhdGEtZWxlbWVudC1sZWZ0PSd0cnVlJ10ge1xuICAgIHRyYW5zZm9ybTogbm9uZTtcbiAgfVxuXG4gICZbZGF0YS1lbGVtZW50LXJpZ2h0PSd0cnVlJ10ge1xuICAgIHRyYW5zZm9ybTogdHJhbnNsYXRlWCgtMTAwJSk7XG4gIH1cbmBcblxuZXhwb3J0IHR5cGUgT3B0aW9uc1Byb3BzID0ge1xuICB0aWNrczoge1xuICAgIHZhbHVlOiBudW1iZXJcbiAgICBsYWJlbD86IHN0cmluZyB8IHVuZGVmaW5lZFxuICB9W11cbiAgbWluOiBudW1iZXJcbiAgbWF4OiBudW1iZXJcbiAgc2xpZGVyV2lkdGg6IG51bWJlclxuICB2YWx1ZT86IG51bWJlciB8IG51bWJlcltdXG4gIHN0ZXA6IG51bWJlclxufVxuXG5leHBvcnQgY29uc3QgT3B0aW9ucyA9ICh7XG4gIHRpY2tzLFxuICBtaW4sXG4gIG1heCxcbiAgc2xpZGVyV2lkdGgsXG4gIHZhbHVlLFxuICBzdGVwLFxufTogT3B0aW9uc1Byb3BzKSA9PiB7XG4gIGNvbnN0IG9wdGlvbldpZHRoID0gKChzbGlkZXJXaWR0aCAtIFRIVU1CX1NJWkUgLyAyKSAqIHN0ZXApIC8gKG1heCAtIG1pbilcblxuICByZXR1cm4gKFxuICAgIDxEYXRhTGlzdCBkYXRhLWRvdWJsZT17QXJyYXkuaXNBcnJheSh2YWx1ZSl9PlxuICAgICAge3RpY2tzLm1hcCgoZWxlbWVudCwgaW5kZXgsIHsgbGVuZ3RoIH0pID0+IHtcbiAgICAgICAgY29uc3QgbGVmdCA9ICgoaW5kZXggKiBzdGVwIC0gbWluKSAqIDEwMCkgLyAobWF4IC0gbWluKVxuXG4gICAgICAgIGNvbnN0IGZvcm1hdGVkRWxlbWVudCA9IGVsZW1lbnQubGFiZWwgPz8gU3RyaW5nKGVsZW1lbnQudmFsdWUpXG5cbiAgICAgICAgY29uc3QgZ2V0SXNTZWxlY3RlZCA9ICgpID0+IHtcbiAgICAgICAgICBpZiAoIXZhbHVlKSB7XG4gICAgICAgICAgICByZXR1cm4gZmFsc2VcbiAgICAgICAgICB9XG5cbiAgICAgICAgICByZXR1cm4gdHlwZW9mIHZhbHVlID09PSAnbnVtYmVyJ1xuICAgICAgICAgICAgPyBlbGVtZW50LnZhbHVlID09PSB2YWx1ZVxuICAgICAgICAgICAgOiB2YWx1ZS5pbmNsdWRlcyhlbGVtZW50LnZhbHVlKVxuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgaXNTZWxlY3RlZCA9IGdldElzU2VsZWN0ZWQoKVxuXG4gICAgICAgIHJldHVybiAoXG4gICAgICAgICAgPE9wdGlvblxuICAgICAgICAgICAga2V5PXtlbGVtZW50LnZhbHVlfVxuICAgICAgICAgICAgbGVmdD17bGVmdH1cbiAgICAgICAgICAgIHdpZHRoPXtvcHRpb25XaWR0aH1cbiAgICAgICAgICAgIGRhdGEtdmFsdWU9e2VsZW1lbnQudmFsdWV9XG4gICAgICAgICAgICBkYXRhLWVsZW1lbnQtbGVmdD17aW5kZXggPT09IDB9XG4gICAgICAgICAgICBkYXRhLWVsZW1lbnQtcmlnaHQ9e2luZGV4ID09PSBsZW5ndGggLSAxfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgIGFzPVwicFwiXG4gICAgICAgICAgICAgIHZhcmlhbnQ9e2lzU2VsZWN0ZWQgPyAnY2FwdGlvblN0cm9uZycgOiAnY2FwdGlvbid9XG4gICAgICAgICAgICAgIHNlbnRpbWVudD17aXNTZWxlY3RlZCA/ICdwcmltYXJ5JyA6ICduZXV0cmFsJ31cbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAge2Zvcm1hdGVkRWxlbWVudH1cbiAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICA8L09wdGlvbj5cbiAgICAgICAgKVxuICAgICAgfSl9XG4gICAgPC9EYXRhTGlzdD5cbiAgKVxufVxuIl19 */"));
25
25
  const Options = ({
26
26
  ticks,
27
27
  min,
@@ -36,7 +36,13 @@ const Options = ({
36
36
  }) => {
37
37
  const left = (index * step - min) * 100 / (max - min);
38
38
  const formatedElement = element.label ?? String(element.value);
39
- const isSelected = typeof value === "number" ? element.value === value : value.includes(element.value);
39
+ const getIsSelected = () => {
40
+ if (!value) {
41
+ return false;
42
+ }
43
+ return typeof value === "number" ? element.value === value : value.includes(element.value);
44
+ };
45
+ const isSelected = getIsSelected();
40
46
  return /* @__PURE__ */ jsx(Option, { left, width: optionWidth, "data-value": element.value, "data-element-left": index === 0, "data-element-right": index === length - 1, children: /* @__PURE__ */ jsx(Text, { as: "p", variant: isSelected ? "captionStrong" : "caption", sentiment: isSelected ? "primary" : "neutral", children: formatedElement }) }, element.value);
41
47
  }) });
42
48
  };
@@ -27,7 +27,7 @@ const StyledTextValue = /* @__PURE__ */ _styled__default.default(index.Text, pro
27
27
  }) => double && isColumn ? null : theme.space["5"], ";align-self:", ({
28
28
  double,
29
29
  isColumn
30
- }) => double || !isColumn ? "center" : "end", ";" + (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/Slider/components/SingleSlider.tsx"],"names":[],"mappings":"AAc0C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Slider/components/SingleSlider.tsx","sourcesContent":["import { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { useCallback, useEffect, useId, useMemo, useRef, useState } from 'react'\nimport { NumberInputV2 } from '../../NumberInputV2'\nimport { Stack } from '../../Stack'\nimport { Text } from '../../Text'\nimport { SLIDER_WIDTH, THUMB_SIZE } from '../constant'\nimport { StyledTooltip, thumbStyle, trackStyle } from '../styles'\nimport type { SingleSliderProps } from '../types'\nimport { Label } from './Label'\nimport { Options } from './Options'\n\nconst StyledTextValue = styled(Text, {\n  shouldForwardProp: prop => !['double', 'isColumn'].includes(prop),\n})<{ double: boolean; isColumn: boolean }>`\n  min-width: ${({ theme, double, isColumn }) => (double && isColumn ? null : theme.space['5'])};\n  align-self: ${({ double, isColumn }) => (double || !isColumn ? 'center' : 'end')};\n`\n\nconst SliderElement = styled('input', {\n  shouldForwardProp: prop => !['themeSlider', 'left'].includes(prop),\n})<{ themeSlider: string; disabled: boolean; left: number }>`\n    appearance: none;\n    height: ${({ theme }) => theme.space['1']};\n    width: 100%;\n    position: relative;\n    min-width: ${SLIDER_WIDTH.min}px;\n    background-color: ${({ theme }) => theme.colors.neutral.borderWeak};\n\n    border-radius: ${({ theme }) => theme.radii.default};\n    background-image:linear-gradient(${({ theme }) => theme.colors.primary.border}, ${({ theme }) => theme.colors.primary.border});\n    background-repeat: no-repeat;\n    align-self: center;\n    outline: none;\n\n    &:focus {\n        &::-moz-range-thumb {\n          border: ${({ theme, disabled }) => (disabled ? null : `1.5px solid ${theme.colors.primary.border}`)};\n          box-shadow: ${({ theme, disabled }) => (disabled ? null : theme.shadows.focusPrimary)};\n        }\n\n        &::-webkit-slider-thumb {\n          border: ${({ theme, disabled }) => (disabled ? null : `1.5px solid ${theme.colors.primary.border}`)};\n          box-shadow: ${({ theme, disabled }) => (disabled ? null : theme.shadows.focusPrimary)};\n        }\n  }\n    &[data-error='true']{\n        background-image:linear-gradient(${({ theme }) => theme.colors.danger.backgroundStrong}, ${({ theme }) => theme.colors.danger.backgroundStrong});\n    }\n\n    &[data-direction='column'] {\n      align-self: baseline;\n    }\n\n    &[aria-disabled='true']{\n      background-image:linear-gradient(${({ theme }) => theme.colors.primary.borderDisabled}, ${({ theme }) => theme.colors.primary.borderDisabled});\n    }\n\n    /* Mozilla */\n    ::-moz-range-track {\n        ${trackStyle}\n    }\n    ::-moz-range-thumb {\n        ${({ theme, themeSlider, disabled, left }) => thumbStyle(theme, themeSlider, disabled, left, false)}\n    }\n\n    /* Other browsers */\n    ::-webkit-slider-runnable-track {\n        ${trackStyle}\n    }\n    ::-webkit-slider-thumb {\n        ${({ theme, themeSlider, disabled, left }) => thumbStyle(theme, themeSlider, disabled, left, false)}\n    }\n`\n\nexport const SingleSlider = ({\n  name,\n  tooltip,\n  direction,\n  disabled,\n  error,\n  'data-testid': dataTestId,\n  value,\n  onChange,\n  min = 0,\n  max = 100,\n  step = 1,\n  id,\n  onBlur,\n  unit,\n  options,\n  onFocus,\n  className,\n  label,\n  input,\n  prefix,\n  suffix,\n  required,\n  'aria-label': ariaLabel,\n  tooltipPosition,\n}: SingleSliderProps) => {\n  const localId = useId()\n  const { theme } = useTheme()\n  const finalId = id ?? localId\n  const safeValue = value ?? min\n  const [computedValue, setComputedValue] = useState(safeValue)\n  const [valueToShow, setValueToShow] = useState<number | null>(\n    options ? options[safeValue].value : safeValue, // if option exists we get the index of the current value in the options array and get the value of it\n  )\n  const refSlider = useRef<HTMLInputElement>(null)\n  const [sliderWidth, setWidth] = useState(\n    refSlider.current?.offsetWidth ?? SLIDER_WIDTH.max,\n  )\n  const [customValue, setCustomValue] = useState<undefined | number>(undefined)\n\n  const ticks = useMemo(() => {\n    if (options) {\n      return options.map((element, index) => ({\n        value: index,\n        label: element.label,\n      }))\n    }\n\n    return []\n  }, [options])\n\n  const onChangeCallback = useCallback(\n    (newValue: number) => {\n      setValueToShow(options ? options[newValue].value : newValue)\n      setComputedValue(newValue ?? min)\n      onChange?.(newValue ?? min)\n    },\n    [min, onChange, options],\n  )\n\n  // Make sure that min <= value <= max\n  useEffect(() => {\n    if (value < min) {\n      onChangeCallback(min)\n    }\n    if (value > max) {\n      onChangeCallback(max)\n    }\n  }, [value, max, min, onChange, step, onChangeCallback])\n\n  // Get slider size\n  useEffect(() => {\n    const setWidthResize = () => {\n      setWidth(refSlider.current?.offsetWidth ?? SLIDER_WIDTH.max)\n    }\n    window.addEventListener('resize', setWidthResize)\n\n    return () => {\n      window.removeEventListener('resize', setWidthResize)\n    }\n  }, [])\n\n  const handleChange = useCallback(\n    (newValue: number) => {\n      if (options) {\n        // Custom scale\n        const optionLabel = options[newValue].value // we use the index of the option to get the value\n        setCustomValue(optionLabel)\n      }\n      onChangeCallback(newValue)\n    },\n    [onChangeCallback, options],\n  )\n\n  const leftPosition = useMemo(\n    () => ((computedValue - min) * 100) / (max - min),\n    [computedValue, max, min],\n  )\n\n  const getBackgroundSize = useMemo(\n    () => ({\n      backgroundSize: `${leftPosition}% 100%`,\n    }),\n    [leftPosition],\n  )\n\n  const styledValue = (valueNumber: string | number | null) =>\n    input && !options ? (\n      <NumberInputV2\n        value={\n          typeof valueNumber === 'string'\n            ? parseFloat(valueNumber)\n            : valueNumber\n        }\n        size=\"small\"\n        min={min}\n        aria-label=\"input\"\n        max={max}\n        step={step}\n        controls={false}\n        data-testid={dataTestId ? `${dataTestId}-input` : 'slider-input'}\n        unit={typeof suffix === 'string' ? suffix : unit}\n        onChange={newVal => {\n          if (newVal) {\n            onChangeCallback(newVal)\n          } else onChangeCallback(0)\n        }}\n        onBlur={event => {\n          if (!event.target.value) onChangeCallback(min)\n        }}\n      />\n    ) : (\n      <StyledTextValue\n        as=\"span\"\n        variant=\"bodySmall\"\n        sentiment=\"neutral\"\n        placement={direction === 'column' ? 'right' : 'center'}\n        double={false}\n        isColumn={direction === 'column'}\n        data-testid={dataTestId ? `${dataTestId}-value` : 'slider-value'}\n      >\n        {prefix}\n        {valueNumber}\n        {suffix ?? unit}\n      </StyledTextValue>\n    )\n\n  const tooltipText = useMemo(() => {\n    if (tooltip === true) {\n      return computedValue\n    }\n    if (tooltip) {\n      return tooltip\n    }\n\n    return undefined\n  }, [tooltip, computedValue])\n\n  const placementTooltip =\n    ((computedValue - min) / (max - min)) * (sliderWidth - THUMB_SIZE) +\n    THUMB_SIZE / 2 -\n    sliderWidth / 2\n\n  return (\n    <Stack gap={1} direction={direction} justifyContent=\"left\">\n      {label ? (\n        <Stack justifyContent=\"space-between\" direction=\"row\">\n          <Label\n            direction={direction}\n            input={input}\n            finalId={finalId}\n            label={label}\n            required={required}\n          />\n          {direction === 'column'\n            ? styledValue(customValue ?? valueToShow)\n            : null}\n        </Stack>\n      ) : null}\n\n      {direction === 'column' && !label\n        ? styledValue(customValue ?? valueToShow)\n        : null}\n      <Stack direction=\"column\" width=\"100%\" gap={1} justifyContent=\"center\">\n        <StyledTooltip\n          text={tooltipText}\n          placement={tooltipPosition}\n          left={placementTooltip}\n        >\n          <SliderElement\n            type=\"range\"\n            value={computedValue}\n            onChange={event => {\n              handleChange(parseFloat(event.target.value))\n            }}\n            min={min}\n            max={max}\n            tabIndex={0}\n            step={step}\n            name={name}\n            disabled={!!disabled}\n            aria-disabled={disabled}\n            data-testid={dataTestId}\n            id={finalId}\n            onBlur={onBlur}\n            onFocus={onFocus}\n            aria-label={ariaLabel ?? name}\n            className={className}\n            style={getBackgroundSize}\n            data-error={!!error}\n            data-direction={direction}\n            themeSlider={theme}\n            ref={refSlider}\n            left={leftPosition}\n          />\n        </StyledTooltip>\n        {options ? (\n          <Options\n            ticks={ticks}\n            min={min}\n            max={max}\n            sliderWidth={sliderWidth}\n            value={computedValue}\n            step={step}\n          />\n        ) : null}\n      </Stack>\n      {direction === 'row' ? styledValue(customValue ?? valueToShow) : null}\n    </Stack>\n  )\n}\n"]} */"));
30
+ }) => double || !isColumn ? "center" : "end", ";" + (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/Slider/components/SingleSlider.tsx"],"names":[],"mappings":"AAc0C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Slider/components/SingleSlider.tsx","sourcesContent":["import { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { useEffect, useId, useMemo, useRef, useState } from 'react'\nimport { NumberInputV2 } from '../../NumberInputV2'\nimport { Stack } from '../../Stack'\nimport { Text } from '../../Text'\nimport { SLIDER_WIDTH, THUMB_SIZE } from '../constant'\nimport { StyledTooltip, thumbStyle, trackStyle } from '../styles'\nimport type { SingleSliderProps } from '../types'\nimport { Label } from './Label'\nimport { Options } from './Options'\n\nconst StyledTextValue = styled(Text, {\n  shouldForwardProp: prop => !['double', 'isColumn'].includes(prop),\n})<{ double: boolean; isColumn: boolean }>`\n  min-width: ${({ theme, double, isColumn }) => (double && isColumn ? null : theme.space['5'])};\n  align-self: ${({ double, isColumn }) => (double || !isColumn ? 'center' : 'end')};\n`\n\nconst SliderElement = styled('input', {\n  shouldForwardProp: prop => !['themeSlider', 'left'].includes(prop),\n})<{ themeSlider: string; disabled: boolean; left: number }>`\n    appearance: none;\n    height: ${({ theme }) => theme.space['1']};\n    width: 100%;\n    position: relative;\n    min-width: ${SLIDER_WIDTH.min}px;\n    background-color: ${({ theme }) => theme.colors.neutral.borderWeak};\n\n    border-radius: ${({ theme }) => theme.radii.default};\n    background-image:linear-gradient(${({ theme }) => theme.colors.primary.border}, ${({ theme }) => theme.colors.primary.border});\n    background-repeat: no-repeat;\n    align-self: center;\n    outline: none;\n\n    &:focus {\n        &::-moz-range-thumb {\n          border: ${({ theme, disabled }) => (disabled ? null : `1.5px solid ${theme.colors.primary.border}`)};\n          box-shadow: ${({ theme, disabled }) => (disabled ? null : theme.shadows.focusPrimary)};\n        }\n\n        &::-webkit-slider-thumb {\n          border: ${({ theme, disabled }) => (disabled ? null : `1.5px solid ${theme.colors.primary.border}`)};\n          box-shadow: ${({ theme, disabled }) => (disabled ? null : theme.shadows.focusPrimary)};\n        }\n  }\n    &[data-error='true']{\n        background-image:linear-gradient(${({ theme }) => theme.colors.danger.backgroundStrong}, ${({ theme }) => theme.colors.danger.backgroundStrong});\n    }\n\n    &[data-direction='column'] {\n      align-self: baseline;\n    }\n\n    &[aria-disabled='true']{\n      background-image:linear-gradient(${({ theme }) => theme.colors.primary.borderDisabled}, ${({ theme }) => theme.colors.primary.borderDisabled});\n    }\n\n    /* Mozilla */\n    ::-moz-range-track {\n        ${trackStyle}\n    }\n    ::-moz-range-thumb {\n        ${({ theme, themeSlider, disabled, left }) => thumbStyle(theme, themeSlider, disabled, left, false)}\n    }\n\n    /* Other browsers */\n    ::-webkit-slider-runnable-track {\n        ${trackStyle}\n    }\n    ::-webkit-slider-thumb {\n        ${({ theme, themeSlider, disabled, left }) => thumbStyle(theme, themeSlider, disabled, left, false)}\n    }\n`\n\nexport const SingleSlider = ({\n  name,\n  tooltip,\n  direction,\n  disabled,\n  error,\n  'data-testid': dataTestId,\n  value,\n  onChange,\n  min = 0,\n  max = 100,\n  step = 1,\n  id,\n  onBlur,\n  unit,\n  options,\n  onFocus,\n  className,\n  label,\n  input,\n  prefix,\n  suffix,\n  required,\n  'aria-label': ariaLabel,\n  tooltipPosition,\n}: SingleSliderProps) => {\n  const localId = useId()\n  const { theme } = useTheme()\n  const finalId = id ?? localId\n  const safeValue = value ?? min\n  const [selectedIndex, setSelectedIndex] = useState(safeValue)\n  const refSlider = useRef<HTMLInputElement>(null)\n  const [sliderWidth, setWidth] = useState(\n    refSlider.current?.offsetWidth ?? SLIDER_WIDTH.max,\n  )\n\n  const ticks = useMemo(() => {\n    if (options) {\n      return options.map((element, index) => ({\n        value: index,\n        label: element.label,\n      }))\n    }\n\n    return []\n  }, [options])\n\n  const internalOnChangeRef = useRef((newValue: number) => {\n    setSelectedIndex(newValue ?? min)\n    onChange?.(newValue ?? min)\n  })\n\n  // Make sure that min <= value <= max\n  useEffect(() => {\n    if (value < min) {\n      internalOnChangeRef.current(min)\n    } else if (value > max) {\n      internalOnChangeRef.current(max)\n    } else {\n      setSelectedIndex(() => value ?? min)\n    }\n  }, [value, max, min])\n\n  // Get slider size\n  useEffect(() => {\n    const setWidthResize = () => {\n      setWidth(refSlider.current?.offsetWidth ?? SLIDER_WIDTH.max)\n    }\n    window.addEventListener('resize', setWidthResize)\n\n    return () => {\n      window.removeEventListener('resize', setWidthResize)\n    }\n  }, [])\n\n  const leftPosition = useMemo(\n    () => ((selectedIndex - min) * 100) / (max - min),\n    [selectedIndex, max, min],\n  )\n\n  const getBackgroundSize = useMemo(\n    () => ({\n      backgroundSize: `${leftPosition}% 100%`,\n    }),\n    [leftPosition],\n  )\n\n  const styledValue = (valueNumber: string | number | null) =>\n    input && !options ? (\n      <NumberInputV2\n        value={\n          typeof valueNumber === 'string'\n            ? parseFloat(valueNumber)\n            : valueNumber\n        }\n        size=\"small\"\n        min={min}\n        aria-label=\"input\"\n        max={max}\n        step={step}\n        controls={false}\n        data-testid={dataTestId ? `${dataTestId}-input` : 'slider-input'}\n        unit={typeof suffix === 'string' ? suffix : unit}\n        onChange={newVal => {\n          if (newVal) {\n            internalOnChangeRef.current(newVal)\n          } else internalOnChangeRef.current(0)\n        }}\n        onBlur={event => {\n          if (!event.target.value) internalOnChangeRef.current(min)\n        }}\n      />\n    ) : (\n      <StyledTextValue\n        as=\"span\"\n        variant=\"bodySmall\"\n        sentiment=\"neutral\"\n        placement={direction === 'column' ? 'right' : 'center'}\n        double={false}\n        isColumn={direction === 'column'}\n        data-testid={dataTestId ? `${dataTestId}-value` : 'slider-value'}\n      >\n        {prefix}\n        {valueNumber}\n        {suffix ?? unit}\n      </StyledTextValue>\n    )\n\n  const tooltipText = useMemo(() => {\n    if (tooltip === true) {\n      return selectedIndex\n    }\n    if (tooltip) {\n      return tooltip\n    }\n\n    return undefined\n  }, [tooltip, selectedIndex])\n\n  const placementTooltip =\n    ((selectedIndex - min) / (max - min)) * (sliderWidth - THUMB_SIZE) +\n    THUMB_SIZE / 2 -\n    sliderWidth / 2\n\n  const valueToShow = options ? options[selectedIndex]?.value : selectedIndex\n\n  return (\n    <Stack gap={1} direction={direction} justifyContent=\"left\">\n      {label ? (\n        <Stack justifyContent=\"space-between\" direction=\"row\">\n          <Label\n            direction={direction}\n            input={input}\n            finalId={finalId}\n            label={label}\n            required={required}\n          />\n          {direction === 'column' ? styledValue(valueToShow) : null}\n        </Stack>\n      ) : null}\n\n      {direction === 'column' && !label ? styledValue(valueToShow) : null}\n      <Stack direction=\"column\" width=\"100%\" gap={1} justifyContent=\"center\">\n        <StyledTooltip\n          text={tooltipText}\n          placement={tooltipPosition}\n          left={placementTooltip}\n        >\n          <SliderElement\n            type=\"range\"\n            value={selectedIndex}\n            onChange={event => {\n              internalOnChangeRef.current(parseFloat(event.target.value))\n            }}\n            min={min}\n            max={max}\n            tabIndex={0}\n            step={step}\n            name={name}\n            disabled={!!disabled}\n            aria-disabled={disabled}\n            data-testid={dataTestId}\n            id={finalId}\n            onBlur={onBlur}\n            onFocus={onFocus}\n            aria-label={ariaLabel ?? name}\n            className={className}\n            style={getBackgroundSize}\n            data-error={!!error}\n            data-direction={direction}\n            themeSlider={theme}\n            ref={refSlider}\n            left={leftPosition}\n          />\n        </StyledTooltip>\n        {options ? (\n          <Options\n            ticks={ticks}\n            min={min}\n            max={max}\n            sliderWidth={sliderWidth}\n            value={selectedIndex}\n            step={step}\n          />\n        ) : null}\n      </Stack>\n      {direction === 'row' ? styledValue(valueToShow) : null}\n    </Stack>\n  )\n}\n"]} */"));
31
31
  const SliderElement = /* @__PURE__ */ _styled__default.default("input", process.env.NODE_ENV === "production" ? {
32
32
  shouldForwardProp: (prop) => !["themeSlider", "left"].includes(prop),
33
33
  target: "elmzsg30"
@@ -75,7 +75,7 @@ const SliderElement = /* @__PURE__ */ _styled__default.default("input", process.
75
75
  themeSlider,
76
76
  disabled,
77
77
  left
78
- }) => styles.thumbStyle(theme, themeSlider, disabled, left, false), ";}" + (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/Slider/components/SingleSlider.tsx"],"names":[],"mappings":"AAqB4D","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Slider/components/SingleSlider.tsx","sourcesContent":["import { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { useCallback, useEffect, useId, useMemo, useRef, useState } from 'react'\nimport { NumberInputV2 } from '../../NumberInputV2'\nimport { Stack } from '../../Stack'\nimport { Text } from '../../Text'\nimport { SLIDER_WIDTH, THUMB_SIZE } from '../constant'\nimport { StyledTooltip, thumbStyle, trackStyle } from '../styles'\nimport type { SingleSliderProps } from '../types'\nimport { Label } from './Label'\nimport { Options } from './Options'\n\nconst StyledTextValue = styled(Text, {\n  shouldForwardProp: prop => !['double', 'isColumn'].includes(prop),\n})<{ double: boolean; isColumn: boolean }>`\n  min-width: ${({ theme, double, isColumn }) => (double && isColumn ? null : theme.space['5'])};\n  align-self: ${({ double, isColumn }) => (double || !isColumn ? 'center' : 'end')};\n`\n\nconst SliderElement = styled('input', {\n  shouldForwardProp: prop => !['themeSlider', 'left'].includes(prop),\n})<{ themeSlider: string; disabled: boolean; left: number }>`\n    appearance: none;\n    height: ${({ theme }) => theme.space['1']};\n    width: 100%;\n    position: relative;\n    min-width: ${SLIDER_WIDTH.min}px;\n    background-color: ${({ theme }) => theme.colors.neutral.borderWeak};\n\n    border-radius: ${({ theme }) => theme.radii.default};\n    background-image:linear-gradient(${({ theme }) => theme.colors.primary.border}, ${({ theme }) => theme.colors.primary.border});\n    background-repeat: no-repeat;\n    align-self: center;\n    outline: none;\n\n    &:focus {\n        &::-moz-range-thumb {\n          border: ${({ theme, disabled }) => (disabled ? null : `1.5px solid ${theme.colors.primary.border}`)};\n          box-shadow: ${({ theme, disabled }) => (disabled ? null : theme.shadows.focusPrimary)};\n        }\n\n        &::-webkit-slider-thumb {\n          border: ${({ theme, disabled }) => (disabled ? null : `1.5px solid ${theme.colors.primary.border}`)};\n          box-shadow: ${({ theme, disabled }) => (disabled ? null : theme.shadows.focusPrimary)};\n        }\n  }\n    &[data-error='true']{\n        background-image:linear-gradient(${({ theme }) => theme.colors.danger.backgroundStrong}, ${({ theme }) => theme.colors.danger.backgroundStrong});\n    }\n\n    &[data-direction='column'] {\n      align-self: baseline;\n    }\n\n    &[aria-disabled='true']{\n      background-image:linear-gradient(${({ theme }) => theme.colors.primary.borderDisabled}, ${({ theme }) => theme.colors.primary.borderDisabled});\n    }\n\n    /* Mozilla */\n    ::-moz-range-track {\n        ${trackStyle}\n    }\n    ::-moz-range-thumb {\n        ${({ theme, themeSlider, disabled, left }) => thumbStyle(theme, themeSlider, disabled, left, false)}\n    }\n\n    /* Other browsers */\n    ::-webkit-slider-runnable-track {\n        ${trackStyle}\n    }\n    ::-webkit-slider-thumb {\n        ${({ theme, themeSlider, disabled, left }) => thumbStyle(theme, themeSlider, disabled, left, false)}\n    }\n`\n\nexport const SingleSlider = ({\n  name,\n  tooltip,\n  direction,\n  disabled,\n  error,\n  'data-testid': dataTestId,\n  value,\n  onChange,\n  min = 0,\n  max = 100,\n  step = 1,\n  id,\n  onBlur,\n  unit,\n  options,\n  onFocus,\n  className,\n  label,\n  input,\n  prefix,\n  suffix,\n  required,\n  'aria-label': ariaLabel,\n  tooltipPosition,\n}: SingleSliderProps) => {\n  const localId = useId()\n  const { theme } = useTheme()\n  const finalId = id ?? localId\n  const safeValue = value ?? min\n  const [computedValue, setComputedValue] = useState(safeValue)\n  const [valueToShow, setValueToShow] = useState<number | null>(\n    options ? options[safeValue].value : safeValue, // if option exists we get the index of the current value in the options array and get the value of it\n  )\n  const refSlider = useRef<HTMLInputElement>(null)\n  const [sliderWidth, setWidth] = useState(\n    refSlider.current?.offsetWidth ?? SLIDER_WIDTH.max,\n  )\n  const [customValue, setCustomValue] = useState<undefined | number>(undefined)\n\n  const ticks = useMemo(() => {\n    if (options) {\n      return options.map((element, index) => ({\n        value: index,\n        label: element.label,\n      }))\n    }\n\n    return []\n  }, [options])\n\n  const onChangeCallback = useCallback(\n    (newValue: number) => {\n      setValueToShow(options ? options[newValue].value : newValue)\n      setComputedValue(newValue ?? min)\n      onChange?.(newValue ?? min)\n    },\n    [min, onChange, options],\n  )\n\n  // Make sure that min <= value <= max\n  useEffect(() => {\n    if (value < min) {\n      onChangeCallback(min)\n    }\n    if (value > max) {\n      onChangeCallback(max)\n    }\n  }, [value, max, min, onChange, step, onChangeCallback])\n\n  // Get slider size\n  useEffect(() => {\n    const setWidthResize = () => {\n      setWidth(refSlider.current?.offsetWidth ?? SLIDER_WIDTH.max)\n    }\n    window.addEventListener('resize', setWidthResize)\n\n    return () => {\n      window.removeEventListener('resize', setWidthResize)\n    }\n  }, [])\n\n  const handleChange = useCallback(\n    (newValue: number) => {\n      if (options) {\n        // Custom scale\n        const optionLabel = options[newValue].value // we use the index of the option to get the value\n        setCustomValue(optionLabel)\n      }\n      onChangeCallback(newValue)\n    },\n    [onChangeCallback, options],\n  )\n\n  const leftPosition = useMemo(\n    () => ((computedValue - min) * 100) / (max - min),\n    [computedValue, max, min],\n  )\n\n  const getBackgroundSize = useMemo(\n    () => ({\n      backgroundSize: `${leftPosition}% 100%`,\n    }),\n    [leftPosition],\n  )\n\n  const styledValue = (valueNumber: string | number | null) =>\n    input && !options ? (\n      <NumberInputV2\n        value={\n          typeof valueNumber === 'string'\n            ? parseFloat(valueNumber)\n            : valueNumber\n        }\n        size=\"small\"\n        min={min}\n        aria-label=\"input\"\n        max={max}\n        step={step}\n        controls={false}\n        data-testid={dataTestId ? `${dataTestId}-input` : 'slider-input'}\n        unit={typeof suffix === 'string' ? suffix : unit}\n        onChange={newVal => {\n          if (newVal) {\n            onChangeCallback(newVal)\n          } else onChangeCallback(0)\n        }}\n        onBlur={event => {\n          if (!event.target.value) onChangeCallback(min)\n        }}\n      />\n    ) : (\n      <StyledTextValue\n        as=\"span\"\n        variant=\"bodySmall\"\n        sentiment=\"neutral\"\n        placement={direction === 'column' ? 'right' : 'center'}\n        double={false}\n        isColumn={direction === 'column'}\n        data-testid={dataTestId ? `${dataTestId}-value` : 'slider-value'}\n      >\n        {prefix}\n        {valueNumber}\n        {suffix ?? unit}\n      </StyledTextValue>\n    )\n\n  const tooltipText = useMemo(() => {\n    if (tooltip === true) {\n      return computedValue\n    }\n    if (tooltip) {\n      return tooltip\n    }\n\n    return undefined\n  }, [tooltip, computedValue])\n\n  const placementTooltip =\n    ((computedValue - min) / (max - min)) * (sliderWidth - THUMB_SIZE) +\n    THUMB_SIZE / 2 -\n    sliderWidth / 2\n\n  return (\n    <Stack gap={1} direction={direction} justifyContent=\"left\">\n      {label ? (\n        <Stack justifyContent=\"space-between\" direction=\"row\">\n          <Label\n            direction={direction}\n            input={input}\n            finalId={finalId}\n            label={label}\n            required={required}\n          />\n          {direction === 'column'\n            ? styledValue(customValue ?? valueToShow)\n            : null}\n        </Stack>\n      ) : null}\n\n      {direction === 'column' && !label\n        ? styledValue(customValue ?? valueToShow)\n        : null}\n      <Stack direction=\"column\" width=\"100%\" gap={1} justifyContent=\"center\">\n        <StyledTooltip\n          text={tooltipText}\n          placement={tooltipPosition}\n          left={placementTooltip}\n        >\n          <SliderElement\n            type=\"range\"\n            value={computedValue}\n            onChange={event => {\n              handleChange(parseFloat(event.target.value))\n            }}\n            min={min}\n            max={max}\n            tabIndex={0}\n            step={step}\n            name={name}\n            disabled={!!disabled}\n            aria-disabled={disabled}\n            data-testid={dataTestId}\n            id={finalId}\n            onBlur={onBlur}\n            onFocus={onFocus}\n            aria-label={ariaLabel ?? name}\n            className={className}\n            style={getBackgroundSize}\n            data-error={!!error}\n            data-direction={direction}\n            themeSlider={theme}\n            ref={refSlider}\n            left={leftPosition}\n          />\n        </StyledTooltip>\n        {options ? (\n          <Options\n            ticks={ticks}\n            min={min}\n            max={max}\n            sliderWidth={sliderWidth}\n            value={computedValue}\n            step={step}\n          />\n        ) : null}\n      </Stack>\n      {direction === 'row' ? styledValue(customValue ?? valueToShow) : null}\n    </Stack>\n  )\n}\n"]} */"));
78
+ }) => styles.thumbStyle(theme, themeSlider, disabled, left, false), ";}" + (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/Slider/components/SingleSlider.tsx"],"names":[],"mappings":"AAqB4D","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Slider/components/SingleSlider.tsx","sourcesContent":["import { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { useEffect, useId, useMemo, useRef, useState } from 'react'\nimport { NumberInputV2 } from '../../NumberInputV2'\nimport { Stack } from '../../Stack'\nimport { Text } from '../../Text'\nimport { SLIDER_WIDTH, THUMB_SIZE } from '../constant'\nimport { StyledTooltip, thumbStyle, trackStyle } from '../styles'\nimport type { SingleSliderProps } from '../types'\nimport { Label } from './Label'\nimport { Options } from './Options'\n\nconst StyledTextValue = styled(Text, {\n  shouldForwardProp: prop => !['double', 'isColumn'].includes(prop),\n})<{ double: boolean; isColumn: boolean }>`\n  min-width: ${({ theme, double, isColumn }) => (double && isColumn ? null : theme.space['5'])};\n  align-self: ${({ double, isColumn }) => (double || !isColumn ? 'center' : 'end')};\n`\n\nconst SliderElement = styled('input', {\n  shouldForwardProp: prop => !['themeSlider', 'left'].includes(prop),\n})<{ themeSlider: string; disabled: boolean; left: number }>`\n    appearance: none;\n    height: ${({ theme }) => theme.space['1']};\n    width: 100%;\n    position: relative;\n    min-width: ${SLIDER_WIDTH.min}px;\n    background-color: ${({ theme }) => theme.colors.neutral.borderWeak};\n\n    border-radius: ${({ theme }) => theme.radii.default};\n    background-image:linear-gradient(${({ theme }) => theme.colors.primary.border}, ${({ theme }) => theme.colors.primary.border});\n    background-repeat: no-repeat;\n    align-self: center;\n    outline: none;\n\n    &:focus {\n        &::-moz-range-thumb {\n          border: ${({ theme, disabled }) => (disabled ? null : `1.5px solid ${theme.colors.primary.border}`)};\n          box-shadow: ${({ theme, disabled }) => (disabled ? null : theme.shadows.focusPrimary)};\n        }\n\n        &::-webkit-slider-thumb {\n          border: ${({ theme, disabled }) => (disabled ? null : `1.5px solid ${theme.colors.primary.border}`)};\n          box-shadow: ${({ theme, disabled }) => (disabled ? null : theme.shadows.focusPrimary)};\n        }\n  }\n    &[data-error='true']{\n        background-image:linear-gradient(${({ theme }) => theme.colors.danger.backgroundStrong}, ${({ theme }) => theme.colors.danger.backgroundStrong});\n    }\n\n    &[data-direction='column'] {\n      align-self: baseline;\n    }\n\n    &[aria-disabled='true']{\n      background-image:linear-gradient(${({ theme }) => theme.colors.primary.borderDisabled}, ${({ theme }) => theme.colors.primary.borderDisabled});\n    }\n\n    /* Mozilla */\n    ::-moz-range-track {\n        ${trackStyle}\n    }\n    ::-moz-range-thumb {\n        ${({ theme, themeSlider, disabled, left }) => thumbStyle(theme, themeSlider, disabled, left, false)}\n    }\n\n    /* Other browsers */\n    ::-webkit-slider-runnable-track {\n        ${trackStyle}\n    }\n    ::-webkit-slider-thumb {\n        ${({ theme, themeSlider, disabled, left }) => thumbStyle(theme, themeSlider, disabled, left, false)}\n    }\n`\n\nexport const SingleSlider = ({\n  name,\n  tooltip,\n  direction,\n  disabled,\n  error,\n  'data-testid': dataTestId,\n  value,\n  onChange,\n  min = 0,\n  max = 100,\n  step = 1,\n  id,\n  onBlur,\n  unit,\n  options,\n  onFocus,\n  className,\n  label,\n  input,\n  prefix,\n  suffix,\n  required,\n  'aria-label': ariaLabel,\n  tooltipPosition,\n}: SingleSliderProps) => {\n  const localId = useId()\n  const { theme } = useTheme()\n  const finalId = id ?? localId\n  const safeValue = value ?? min\n  const [selectedIndex, setSelectedIndex] = useState(safeValue)\n  const refSlider = useRef<HTMLInputElement>(null)\n  const [sliderWidth, setWidth] = useState(\n    refSlider.current?.offsetWidth ?? SLIDER_WIDTH.max,\n  )\n\n  const ticks = useMemo(() => {\n    if (options) {\n      return options.map((element, index) => ({\n        value: index,\n        label: element.label,\n      }))\n    }\n\n    return []\n  }, [options])\n\n  const internalOnChangeRef = useRef((newValue: number) => {\n    setSelectedIndex(newValue ?? min)\n    onChange?.(newValue ?? min)\n  })\n\n  // Make sure that min <= value <= max\n  useEffect(() => {\n    if (value < min) {\n      internalOnChangeRef.current(min)\n    } else if (value > max) {\n      internalOnChangeRef.current(max)\n    } else {\n      setSelectedIndex(() => value ?? min)\n    }\n  }, [value, max, min])\n\n  // Get slider size\n  useEffect(() => {\n    const setWidthResize = () => {\n      setWidth(refSlider.current?.offsetWidth ?? SLIDER_WIDTH.max)\n    }\n    window.addEventListener('resize', setWidthResize)\n\n    return () => {\n      window.removeEventListener('resize', setWidthResize)\n    }\n  }, [])\n\n  const leftPosition = useMemo(\n    () => ((selectedIndex - min) * 100) / (max - min),\n    [selectedIndex, max, min],\n  )\n\n  const getBackgroundSize = useMemo(\n    () => ({\n      backgroundSize: `${leftPosition}% 100%`,\n    }),\n    [leftPosition],\n  )\n\n  const styledValue = (valueNumber: string | number | null) =>\n    input && !options ? (\n      <NumberInputV2\n        value={\n          typeof valueNumber === 'string'\n            ? parseFloat(valueNumber)\n            : valueNumber\n        }\n        size=\"small\"\n        min={min}\n        aria-label=\"input\"\n        max={max}\n        step={step}\n        controls={false}\n        data-testid={dataTestId ? `${dataTestId}-input` : 'slider-input'}\n        unit={typeof suffix === 'string' ? suffix : unit}\n        onChange={newVal => {\n          if (newVal) {\n            internalOnChangeRef.current(newVal)\n          } else internalOnChangeRef.current(0)\n        }}\n        onBlur={event => {\n          if (!event.target.value) internalOnChangeRef.current(min)\n        }}\n      />\n    ) : (\n      <StyledTextValue\n        as=\"span\"\n        variant=\"bodySmall\"\n        sentiment=\"neutral\"\n        placement={direction === 'column' ? 'right' : 'center'}\n        double={false}\n        isColumn={direction === 'column'}\n        data-testid={dataTestId ? `${dataTestId}-value` : 'slider-value'}\n      >\n        {prefix}\n        {valueNumber}\n        {suffix ?? unit}\n      </StyledTextValue>\n    )\n\n  const tooltipText = useMemo(() => {\n    if (tooltip === true) {\n      return selectedIndex\n    }\n    if (tooltip) {\n      return tooltip\n    }\n\n    return undefined\n  }, [tooltip, selectedIndex])\n\n  const placementTooltip =\n    ((selectedIndex - min) / (max - min)) * (sliderWidth - THUMB_SIZE) +\n    THUMB_SIZE / 2 -\n    sliderWidth / 2\n\n  const valueToShow = options ? options[selectedIndex]?.value : selectedIndex\n\n  return (\n    <Stack gap={1} direction={direction} justifyContent=\"left\">\n      {label ? (\n        <Stack justifyContent=\"space-between\" direction=\"row\">\n          <Label\n            direction={direction}\n            input={input}\n            finalId={finalId}\n            label={label}\n            required={required}\n          />\n          {direction === 'column' ? styledValue(valueToShow) : null}\n        </Stack>\n      ) : null}\n\n      {direction === 'column' && !label ? styledValue(valueToShow) : null}\n      <Stack direction=\"column\" width=\"100%\" gap={1} justifyContent=\"center\">\n        <StyledTooltip\n          text={tooltipText}\n          placement={tooltipPosition}\n          left={placementTooltip}\n        >\n          <SliderElement\n            type=\"range\"\n            value={selectedIndex}\n            onChange={event => {\n              internalOnChangeRef.current(parseFloat(event.target.value))\n            }}\n            min={min}\n            max={max}\n            tabIndex={0}\n            step={step}\n            name={name}\n            disabled={!!disabled}\n            aria-disabled={disabled}\n            data-testid={dataTestId}\n            id={finalId}\n            onBlur={onBlur}\n            onFocus={onFocus}\n            aria-label={ariaLabel ?? name}\n            className={className}\n            style={getBackgroundSize}\n            data-error={!!error}\n            data-direction={direction}\n            themeSlider={theme}\n            ref={refSlider}\n            left={leftPosition}\n          />\n        </StyledTooltip>\n        {options ? (\n          <Options\n            ticks={ticks}\n            min={min}\n            max={max}\n            sliderWidth={sliderWidth}\n            value={selectedIndex}\n            step={step}\n          />\n        ) : null}\n      </Stack>\n      {direction === 'row' ? styledValue(valueToShow) : null}\n    </Stack>\n  )\n}\n"]} */"));
79
79
  const SingleSlider = ({
80
80
  name,
81
81
  tooltip,
@@ -108,14 +108,9 @@ const SingleSlider = ({
108
108
  } = react.useTheme();
109
109
  const finalId = id ?? localId;
110
110
  const safeValue = value ?? min;
111
- const [computedValue, setComputedValue] = React.useState(safeValue);
112
- const [valueToShow, setValueToShow] = React.useState(
113
- options ? options[safeValue].value : safeValue
114
- // if option exists we get the index of the current value in the options array and get the value of it
115
- );
111
+ const [selectedIndex, setSelectedIndex] = React.useState(safeValue);
116
112
  const refSlider = React.useRef(null);
117
113
  const [sliderWidth, setWidth] = React.useState(refSlider.current?.offsetWidth ?? constant.SLIDER_WIDTH.max);
118
- const [customValue, setCustomValue] = React.useState(void 0);
119
114
  const ticks = React.useMemo(() => {
120
115
  if (options) {
121
116
  return options.map((element, index2) => ({
@@ -125,19 +120,19 @@ const SingleSlider = ({
125
120
  }
126
121
  return [];
127
122
  }, [options]);
128
- const onChangeCallback = React.useCallback((newValue) => {
129
- setValueToShow(options ? options[newValue].value : newValue);
130
- setComputedValue(newValue ?? min);
123
+ const internalOnChangeRef = React.useRef((newValue) => {
124
+ setSelectedIndex(newValue ?? min);
131
125
  onChange?.(newValue ?? min);
132
- }, [min, onChange, options]);
126
+ });
133
127
  React.useEffect(() => {
134
128
  if (value < min) {
135
- onChangeCallback(min);
129
+ internalOnChangeRef.current(min);
130
+ } else if (value > max) {
131
+ internalOnChangeRef.current(max);
132
+ } else {
133
+ setSelectedIndex(() => value ?? min);
136
134
  }
137
- if (value > max) {
138
- onChangeCallback(max);
139
- }
140
- }, [value, max, min, onChange, step, onChangeCallback]);
135
+ }, [value, max, min]);
141
136
  React.useEffect(() => {
142
137
  const setWidthResize = () => {
143
138
  setWidth(refSlider.current?.offsetWidth ?? constant.SLIDER_WIDTH.max);
@@ -147,23 +142,16 @@ const SingleSlider = ({
147
142
  window.removeEventListener("resize", setWidthResize);
148
143
  };
149
144
  }, []);
150
- const handleChange = React.useCallback((newValue) => {
151
- if (options) {
152
- const optionLabel = options[newValue].value;
153
- setCustomValue(optionLabel);
154
- }
155
- onChangeCallback(newValue);
156
- }, [onChangeCallback, options]);
157
- const leftPosition = React.useMemo(() => (computedValue - min) * 100 / (max - min), [computedValue, max, min]);
145
+ const leftPosition = React.useMemo(() => (selectedIndex - min) * 100 / (max - min), [selectedIndex, max, min]);
158
146
  const getBackgroundSize = React.useMemo(() => ({
159
147
  backgroundSize: `${leftPosition}% 100%`
160
148
  }), [leftPosition]);
161
149
  const styledValue = (valueNumber) => input && !options ? /* @__PURE__ */ jsxRuntime.jsx(index$2.NumberInputV2, { value: typeof valueNumber === "string" ? parseFloat(valueNumber) : valueNumber, size: "small", min, "aria-label": "input", max, step, controls: false, "data-testid": dataTestId ? `${dataTestId}-input` : "slider-input", unit: typeof suffix === "string" ? suffix : unit, onChange: (newVal) => {
162
150
  if (newVal) {
163
- onChangeCallback(newVal);
164
- } else onChangeCallback(0);
151
+ internalOnChangeRef.current(newVal);
152
+ } else internalOnChangeRef.current(0);
165
153
  }, onBlur: (event) => {
166
- if (!event.target.value) onChangeCallback(min);
154
+ if (!event.target.value) internalOnChangeRef.current(min);
167
155
  } }) : /* @__PURE__ */ jsxRuntime.jsxs(StyledTextValue, { as: "span", variant: "bodySmall", sentiment: "neutral", placement: direction === "column" ? "right" : "center", double: false, isColumn: direction === "column", "data-testid": dataTestId ? `${dataTestId}-value` : "slider-value", children: [
168
156
  prefix,
169
157
  valueNumber,
@@ -171,27 +159,28 @@ const SingleSlider = ({
171
159
  ] });
172
160
  const tooltipText = React.useMemo(() => {
173
161
  if (tooltip === true) {
174
- return computedValue;
162
+ return selectedIndex;
175
163
  }
176
164
  if (tooltip) {
177
165
  return tooltip;
178
166
  }
179
167
  return void 0;
180
- }, [tooltip, computedValue]);
181
- const placementTooltip = (computedValue - min) / (max - min) * (sliderWidth - constant.THUMB_SIZE) + constant.THUMB_SIZE / 2 - sliderWidth / 2;
168
+ }, [tooltip, selectedIndex]);
169
+ const placementTooltip = (selectedIndex - min) / (max - min) * (sliderWidth - constant.THUMB_SIZE) + constant.THUMB_SIZE / 2 - sliderWidth / 2;
170
+ const valueToShow = options ? options[selectedIndex]?.value : selectedIndex;
182
171
  return /* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { gap: 1, direction, justifyContent: "left", children: [
183
172
  label ? /* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { justifyContent: "space-between", direction: "row", children: [
184
173
  /* @__PURE__ */ jsxRuntime.jsx(Label.Label, { direction, input, finalId, label, required }),
185
- direction === "column" ? styledValue(customValue ?? valueToShow) : null
174
+ direction === "column" ? styledValue(valueToShow) : null
186
175
  ] }) : null,
187
- direction === "column" && !label ? styledValue(customValue ?? valueToShow) : null,
176
+ direction === "column" && !label ? styledValue(valueToShow) : null,
188
177
  /* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { direction: "column", width: "100%", gap: 1, justifyContent: "center", children: [
189
- /* @__PURE__ */ jsxRuntime.jsx(styles.StyledTooltip, { text: tooltipText, placement: tooltipPosition, left: placementTooltip, children: /* @__PURE__ */ jsxRuntime.jsx(SliderElement, { type: "range", value: computedValue, onChange: (event) => {
190
- handleChange(parseFloat(event.target.value));
178
+ /* @__PURE__ */ jsxRuntime.jsx(styles.StyledTooltip, { text: tooltipText, placement: tooltipPosition, left: placementTooltip, children: /* @__PURE__ */ jsxRuntime.jsx(SliderElement, { type: "range", value: selectedIndex, onChange: (event) => {
179
+ internalOnChangeRef.current(parseFloat(event.target.value));
191
180
  }, min, max, tabIndex: 0, step, name, disabled: !!disabled, "aria-disabled": disabled, "data-testid": dataTestId, id: finalId, onBlur, onFocus, "aria-label": ariaLabel ?? name, className, style: getBackgroundSize, "data-error": !!error, "data-direction": direction, themeSlider: theme, ref: refSlider, left: leftPosition }) }),
192
- options ? /* @__PURE__ */ jsxRuntime.jsx(Options.Options, { ticks, min, max, sliderWidth, value: computedValue, step }) : null
181
+ options ? /* @__PURE__ */ jsxRuntime.jsx(Options.Options, { ticks, min, max, sliderWidth, value: selectedIndex, step }) : null
193
182
  ] }),
194
- direction === "row" ? styledValue(customValue ?? valueToShow) : null
183
+ direction === "row" ? styledValue(valueToShow) : null
195
184
  ] });
196
185
  };
197
186
  exports.SingleSlider = SingleSlider;