@ultraviolet/ui 2.0.0-beta.11 → 2.0.0-beta.12
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.
- package/dist/components/List/HeaderCell.cjs +3 -3
- package/dist/components/List/HeaderCell.js +4 -4
- package/dist/components/Table/HeaderCell.cjs +4 -4
- package/dist/components/Table/HeaderCell.js +5 -5
- package/dist/components/UnitInput/index.cjs +5 -5
- package/dist/components/UnitInput/index.js +5 -5
- package/package.json +3 -3
|
@@ -17,7 +17,7 @@ const StyledSortIcon = /* @__PURE__ */ _styled__default.default(Icon.SouthShortI
|
|
|
17
17
|
label: "StyledSortIcon"
|
|
18
18
|
})("transform:", ({
|
|
19
19
|
order
|
|
20
|
-
}) => order === "ascending" ? "rotate(-180deg)" : "none", ";transition:transform 0.2s ease-in-out;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
20
|
+
}) => order === "ascending" ? "rotate(-180deg)" : "none", ";transition:transform 0.2s ease-in-out;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0xpc3QvSGVhZGVyQ2VsbC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBY3lDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0xpc3QvSGVhZGVyQ2VsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQge1xuICBJbmZvcm1hdGlvbk91dGxpbmVJY29uLFxuICBTb3J0SWNvbiBhcyBTb3J0SWNvblVWLFxuICBTb3V0aFNob3J0SWNvbixcbn0gZnJvbSAnQHVsdHJhdmlvbGV0L2ljb25zJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vU3RhY2snXG5pbXBvcnQgeyBUb29sdGlwIH0gZnJvbSAnLi4vVG9vbHRpcCdcblxuY29uc3QgU3R5bGVkU29ydEljb24gPSBzdHlsZWQoU291dGhTaG9ydEljb24sIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT4gIVsnb3JkZXInXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgb3JkZXI6ICdhc2NlbmRpbmcnIHwgJ2Rlc2NlbmRpbmcnIH0+YFxuICB0cmFuc2Zvcm06ICR7KHsgb3JkZXIgfSkgPT5cbiAgICBvcmRlciA9PT0gJ2FzY2VuZGluZycgPyAncm90YXRlKC0xODBkZWcpJyA6ICdub25lJ307XG4gIHRyYW5zaXRpb246IHRyYW5zZm9ybSAwLjJzIGVhc2UtaW4tb3V0O1xuYFxuXG5jb25zdCBTb3J0SWNvbiA9ICh7IG9yZGVyIH06IHsgb3JkZXI/OiAnYXNjZW5kaW5nJyB8ICdkZXNjZW5kaW5nJyB9KSA9PlxuICBvcmRlciA/IChcbiAgICA8U3R5bGVkU29ydEljb24gb3JkZXI9e29yZGVyfSBzZW50aW1lbnQ9XCJwcmltYXJ5XCIgLz5cbiAgKSA6IChcbiAgICA8U29ydEljb25VViBzZW50aW1lbnQ9XCJuZXV0cmFsXCIgLz5cbiAgKVxuXG5jb25zdCBTdHlsZWRIZWFkZXJDZWxsID0gc3R5bGVkKCd0aCcsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT4gIVsnd2lkdGgnLCAnbWluV2lkdGgnLCAnbWF4V2lkdGgnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgd2lkdGg/OiBzdHJpbmc7IG1pbldpZHRoPzogc3RyaW5nOyBtYXhXaWR0aD86IHN0cmluZyB9PmBcbiAgZGlzcGxheTogdGFibGUtY2VsbDtcbiAgdGV4dC1hbGlnbjogbGVmdDtcbiAgdmVydGljYWwtYWxpZ246IG1pZGRsZTtcbiAgZm9udC1zaXplOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnR5cG9ncmFwaHkuYm9keVNtYWxsLmZvbnRTaXplfTtcbiAgZm9udC13ZWlnaHQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUudHlwb2dyYXBoeS5ib2R5U21hbGwud2VpZ2h0fTtcbiAgZm9udC1mYW1pbHk6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUudHlwb2dyYXBoeS5ib2R5U21hbGwuZm9udEZhbWlseX07XG4gIGNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHR9O1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG4gIHBhZGRpbmc6IDAgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcblxuICAmW3JvbGUqPSdidXR0b24nXSB7XG4gICAgY3Vyc29yOiBwb2ludGVyO1xuICAgIHVzZXItc2VsZWN0OiBub25lO1xuICB9XG5cbiAgJlthcmlhLXNvcnRdIHtcbiAgICBjb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMucHJpbWFyeS50ZXh0fTtcbiAgfVxuXG4gIHdpZHRoOiAkeyh7IHdpZHRoIH0pID0+IHdpZHRofTtcbiAgbWluLXdpZHRoOiAkeyh7IG1pbldpZHRoIH0pID0+IG1pbldpZHRofTtcbiAgbWF4LXdpZHRoOiAkeyh7IG1heFdpZHRoIH0pID0+IG1heFdpZHRofTtcbmBcblxudHlwZSBIZWFkZXJDZWxsUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGlzT3JkZXJlZD86IGJvb2xlYW5cbiAgb3JkZXJEaXJlY3Rpb24/OiAnYXNjJyB8ICdkZXNjJyB8ICdub25lJ1xuICBvbk9yZGVyPzogKG5ld09yZGVyOiAnYXNjJyB8ICdkZXNjJykgPT4gdm9pZFxuICBpbmZvPzogc3RyaW5nXG4gIHdpZHRoPzogc3RyaW5nXG4gIG1pbldpdGg/OiBzdHJpbmdcbiAgbWF4V2lkdGg/OiBzdHJpbmdcbn1cblxuZXhwb3J0IGNvbnN0IEhlYWRlckNlbGwgPSAoe1xuICBjaGlsZHJlbixcbiAgaXNPcmRlcmVkLFxuICBvcmRlckRpcmVjdGlvbixcbiAgb25PcmRlcixcbiAgY2xhc3NOYW1lLFxuICBpbmZvLFxuICB3aWR0aCxcbiAgbWluV2l0aCxcbiAgbWF4V2lkdGgsXG59OiBIZWFkZXJDZWxsUHJvcHMpID0+IHtcbiAgbGV0IG9yZGVyOiB1bmRlZmluZWQgfCAnYXNjZW5kaW5nJyB8ICdkZXNjZW5kaW5nJ1xuICBpZiAoaXNPcmRlcmVkICYmIG9yZGVyRGlyZWN0aW9uID09PSAnYXNjJykge1xuICAgIG9yZGVyID0gJ2FzY2VuZGluZydcbiAgfSBlbHNlIGlmIChpc09yZGVyZWQgJiYgb3JkZXJEaXJlY3Rpb24gPT09ICdkZXNjJykge1xuICAgIG9yZGVyID0gJ2Rlc2NlbmRpbmcnXG4gIH1cblxuICBjb25zdCBoYW5kbGVPcmRlciA9IG9uT3JkZXJcbiAgICA/ICgpID0+IG9uT3JkZXIob3JkZXIgPT09ICdhc2NlbmRpbmcnID8gJ2Rlc2MnIDogJ2FzYycpXG4gICAgOiB1bmRlZmluZWRcblxuICByZXR1cm4gKFxuICAgIDxTdHlsZWRIZWFkZXJDZWxsXG4gICAgICBhcmlhLXNvcnQ9e29yZGVyfVxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBvbkNsaWNrPXtoYW5kbGVPcmRlcn1cbiAgICAgIG9uS2V5RG93bj17XG4gICAgICAgIGhhbmRsZU9yZGVyXG4gICAgICAgICAgPyBldmVudCA9PiB7XG4gICAgICAgICAgICAgIGlmIChldmVudC5rZXkgPT09ICcgJyB8fCBldmVudC5rZXkgPT09ICdFbnRlcicpIHtcbiAgICAgICAgICAgICAgICBoYW5kbGVPcmRlcigpXG4gICAgICAgICAgICAgICAgaWYgKGV2ZW50LmtleSA9PT0gJyAnKSB7XG4gICAgICAgICAgICAgICAgICAvLyBAbm90ZTogaXQgYXZvaWQgc2Nyb2xsIHdoZW4gcHJlc3NpbmcgU3BhY2VcbiAgICAgICAgICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KClcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICA6IHVuZGVmaW5lZFxuICAgICAgfVxuICAgICAgcm9sZT17b25PcmRlciA/ICdidXR0b24gY29sdW1uaGVhZGVyJyA6IHVuZGVmaW5lZH1cbiAgICAgIHRhYkluZGV4PXtoYW5kbGVPcmRlciA/IDAgOiAtMX1cbiAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICAgIG1heFdpZHRoPXttYXhXaWR0aH1cbiAgICAgIG1pbldpZHRoPXttaW5XaXRofVxuICAgID5cbiAgICAgIDxTdGFjayBkaXJlY3Rpb249XCJyb3dcIiBnYXA9ezF9IGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgICB7aW5mbyA/IChcbiAgICAgICAgICA8VG9vbHRpcCB0ZXh0PXtpbmZvfT5cbiAgICAgICAgICAgIDxJbmZvcm1hdGlvbk91dGxpbmVJY29uXG4gICAgICAgICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgICAgICAgIHByb21pbmVuY2U9XCJ3ZWFrXCJcbiAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvVG9vbHRpcD5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICAgIHtvcmRlckRpcmVjdGlvbiAhPT0gdW5kZWZpbmVkICYmIGlzT3JkZXJlZCAhPT0gdW5kZWZpbmVkID8gKFxuICAgICAgICAgIDxTb3J0SWNvbiBvcmRlcj17b3JkZXJ9IC8+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgPC9TdGFjaz5cbiAgICA8L1N0eWxlZEhlYWRlckNlbGw+XG4gIClcbn1cbiJdfQ== */"));
|
|
21
21
|
const SortIcon = ({
|
|
22
22
|
order
|
|
23
23
|
}) => order ? /* @__PURE__ */ jsxRuntime.jsx(StyledSortIcon, { order, sentiment: "primary" }) : /* @__PURE__ */ jsxRuntime.jsx(Icon.SortIcon, { sentiment: "neutral" });
|
|
@@ -48,7 +48,7 @@ const StyledHeaderCell = /* @__PURE__ */ _styled__default.default("th", process.
|
|
|
48
48
|
minWidth
|
|
49
49
|
}) => minWidth, ";max-width:", ({
|
|
50
50
|
maxWidth
|
|
51
|
-
}) => maxWidth, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
51
|
+
}) => maxWidth, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0xpc3QvSGVhZGVyQ2VsbC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkI0RCIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9MaXN0L0hlYWRlckNlbGwudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHtcbiAgSW5mb3JtYXRpb25PdXRsaW5lSWNvbixcbiAgU29ydEljb24gYXMgU29ydEljb25VVixcbiAgU291dGhTaG9ydEljb24sXG59IGZyb20gJ0B1bHRyYXZpb2xldC9pY29ucydcbmltcG9ydCB0eXBlIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBTdGFjayB9IGZyb20gJy4uL1N0YWNrJ1xuaW1wb3J0IHsgVG9vbHRpcCB9IGZyb20gJy4uL1Rvb2x0aXAnXG5cbmNvbnN0IFN0eWxlZFNvcnRJY29uID0gc3R5bGVkKFNvdXRoU2hvcnRJY29uLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ29yZGVyJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IG9yZGVyOiAnYXNjZW5kaW5nJyB8ICdkZXNjZW5kaW5nJyB9PmBcbiAgdHJhbnNmb3JtOiAkeyh7IG9yZGVyIH0pID0+XG4gICAgb3JkZXIgPT09ICdhc2NlbmRpbmcnID8gJ3JvdGF0ZSgtMTgwZGVnKScgOiAnbm9uZSd9O1xuICB0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gMC4ycyBlYXNlLWluLW91dDtcbmBcblxuY29uc3QgU29ydEljb24gPSAoeyBvcmRlciB9OiB7IG9yZGVyPzogJ2FzY2VuZGluZycgfCAnZGVzY2VuZGluZycgfSkgPT5cbiAgb3JkZXIgPyAoXG4gICAgPFN0eWxlZFNvcnRJY29uIG9yZGVyPXtvcmRlcn0gc2VudGltZW50PVwicHJpbWFyeVwiIC8+XG4gICkgOiAoXG4gICAgPFNvcnRJY29uVVYgc2VudGltZW50PVwibmV1dHJhbFwiIC8+XG4gIClcblxuY29uc3QgU3R5bGVkSGVhZGVyQ2VsbCA9IHN0eWxlZCgndGgnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3dpZHRoJywgJ21pbldpZHRoJywgJ21heFdpZHRoJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IHdpZHRoPzogc3RyaW5nOyBtaW5XaWR0aD86IHN0cmluZzsgbWF4V2lkdGg/OiBzdHJpbmcgfT5gXG4gIGRpc3BsYXk6IHRhYmxlLWNlbGw7XG4gIHRleHQtYWxpZ246IGxlZnQ7XG4gIHZlcnRpY2FsLWFsaWduOiBtaWRkbGU7XG4gIGZvbnQtc2l6ZTogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS50eXBvZ3JhcGh5LmJvZHlTbWFsbC5mb250U2l6ZX07XG4gIGZvbnQtd2VpZ2h0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnR5cG9ncmFwaHkuYm9keVNtYWxsLndlaWdodH07XG4gIGZvbnQtZmFtaWx5OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnR5cG9ncmFwaHkuYm9keVNtYWxsLmZvbnRGYW1pbHl9O1xuICBjb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC50ZXh0fTtcbiAgZ2FwOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuICBwYWRkaW5nOiAwICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzInXX07XG5cbiAgJltyb2xlKj0nYnV0dG9uJ10ge1xuICAgIGN1cnNvcjogcG9pbnRlcjtcbiAgICB1c2VyLXNlbGVjdDogbm9uZTtcbiAgfVxuXG4gICZbYXJpYS1zb3J0XSB7XG4gICAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnkudGV4dH07XG4gIH1cblxuICB3aWR0aDogJHsoeyB3aWR0aCB9KSA9PiB3aWR0aH07XG4gIG1pbi13aWR0aDogJHsoeyBtaW5XaWR0aCB9KSA9PiBtaW5XaWR0aH07XG4gIG1heC13aWR0aDogJHsoeyBtYXhXaWR0aCB9KSA9PiBtYXhXaWR0aH07XG5gXG5cbnR5cGUgSGVhZGVyQ2VsbFByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBpc09yZGVyZWQ/OiBib29sZWFuXG4gIG9yZGVyRGlyZWN0aW9uPzogJ2FzYycgfCAnZGVzYycgfCAnbm9uZSdcbiAgb25PcmRlcj86IChuZXdPcmRlcjogJ2FzYycgfCAnZGVzYycpID0+IHZvaWRcbiAgaW5mbz86IHN0cmluZ1xuICB3aWR0aD86IHN0cmluZ1xuICBtaW5XaXRoPzogc3RyaW5nXG4gIG1heFdpZHRoPzogc3RyaW5nXG59XG5cbmV4cG9ydCBjb25zdCBIZWFkZXJDZWxsID0gKHtcbiAgY2hpbGRyZW4sXG4gIGlzT3JkZXJlZCxcbiAgb3JkZXJEaXJlY3Rpb24sXG4gIG9uT3JkZXIsXG4gIGNsYXNzTmFtZSxcbiAgaW5mbyxcbiAgd2lkdGgsXG4gIG1pbldpdGgsXG4gIG1heFdpZHRoLFxufTogSGVhZGVyQ2VsbFByb3BzKSA9PiB7XG4gIGxldCBvcmRlcjogdW5kZWZpbmVkIHwgJ2FzY2VuZGluZycgfCAnZGVzY2VuZGluZydcbiAgaWYgKGlzT3JkZXJlZCAmJiBvcmRlckRpcmVjdGlvbiA9PT0gJ2FzYycpIHtcbiAgICBvcmRlciA9ICdhc2NlbmRpbmcnXG4gIH0gZWxzZSBpZiAoaXNPcmRlcmVkICYmIG9yZGVyRGlyZWN0aW9uID09PSAnZGVzYycpIHtcbiAgICBvcmRlciA9ICdkZXNjZW5kaW5nJ1xuICB9XG5cbiAgY29uc3QgaGFuZGxlT3JkZXIgPSBvbk9yZGVyXG4gICAgPyAoKSA9PiBvbk9yZGVyKG9yZGVyID09PSAnYXNjZW5kaW5nJyA/ICdkZXNjJyA6ICdhc2MnKVxuICAgIDogdW5kZWZpbmVkXG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkSGVhZGVyQ2VsbFxuICAgICAgYXJpYS1zb3J0PXtvcmRlcn1cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgb25DbGljaz17aGFuZGxlT3JkZXJ9XG4gICAgICBvbktleURvd249e1xuICAgICAgICBoYW5kbGVPcmRlclxuICAgICAgICAgID8gZXZlbnQgPT4ge1xuICAgICAgICAgICAgICBpZiAoZXZlbnQua2V5ID09PSAnICcgfHwgZXZlbnQua2V5ID09PSAnRW50ZXInKSB7XG4gICAgICAgICAgICAgICAgaGFuZGxlT3JkZXIoKVxuICAgICAgICAgICAgICAgIGlmIChldmVudC5rZXkgPT09ICcgJykge1xuICAgICAgICAgICAgICAgICAgLy8gQG5vdGU6IGl0IGF2b2lkIHNjcm9sbCB3aGVuIHByZXNzaW5nIFNwYWNlXG4gICAgICAgICAgICAgICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgICAgOiB1bmRlZmluZWRcbiAgICAgIH1cbiAgICAgIHJvbGU9e29uT3JkZXIgPyAnYnV0dG9uIGNvbHVtbmhlYWRlcicgOiB1bmRlZmluZWR9XG4gICAgICB0YWJJbmRleD17aGFuZGxlT3JkZXIgPyAwIDogLTF9XG4gICAgICB3aWR0aD17d2lkdGh9XG4gICAgICBtYXhXaWR0aD17bWF4V2lkdGh9XG4gICAgICBtaW5XaWR0aD17bWluV2l0aH1cbiAgICA+XG4gICAgICA8U3RhY2sgZGlyZWN0aW9uPVwicm93XCIgZ2FwPXsxfSBhbGlnbkl0ZW1zPVwiY2VudGVyXCI+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAge2luZm8gPyAoXG4gICAgICAgICAgPFRvb2x0aXAgdGV4dD17aW5mb30+XG4gICAgICAgICAgICA8SW5mb3JtYXRpb25PdXRsaW5lSWNvblxuICAgICAgICAgICAgICBzaXplPVwic21hbGxcIlxuICAgICAgICAgICAgICBwcm9taW5lbmNlPVwid2Vha1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L1Rvb2x0aXA+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgICB7b3JkZXJEaXJlY3Rpb24gIT09IHVuZGVmaW5lZCAmJiBpc09yZGVyZWQgIT09IHVuZGVmaW5lZCA/IChcbiAgICAgICAgICA8U29ydEljb24gb3JkZXI9e29yZGVyfSAvPlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvU3RhY2s+XG4gICAgPC9TdHlsZWRIZWFkZXJDZWxsPlxuICApXG59XG4iXX0= */"));
|
|
52
52
|
const HeaderCell = ({
|
|
53
53
|
children,
|
|
54
54
|
isOrdered,
|
|
@@ -76,7 +76,7 @@ const HeaderCell = ({
|
|
|
76
76
|
}
|
|
77
77
|
} : void 0, role: onOrder ? "button columnheader" : void 0, tabIndex: handleOrder ? 0 : -1, width, maxWidth, minWidth: minWith, children: /* @__PURE__ */ jsxRuntime.jsxs(index.Stack, { direction: "row", gap: 1, alignItems: "center", children: [
|
|
78
78
|
children,
|
|
79
|
-
info ? /* @__PURE__ */ jsxRuntime.jsx(index$1.Tooltip, { text: info, children: /* @__PURE__ */ jsxRuntime.jsx(Icon.
|
|
79
|
+
info ? /* @__PURE__ */ jsxRuntime.jsx(index$1.Tooltip, { text: info, children: /* @__PURE__ */ jsxRuntime.jsx(Icon.InformationOutlineIcon, { size: "small", prominence: "weak", sentiment: "neutral" }) }) : null,
|
|
80
80
|
orderDirection !== void 0 && isOrdered !== void 0 ? /* @__PURE__ */ jsxRuntime.jsx(SortIcon, { order }) : null
|
|
81
81
|
] }) });
|
|
82
82
|
};
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
"use client";
|
|
2
2
|
import { jsx, jsxs } from "@emotion/react/jsx-runtime";
|
|
3
3
|
import _styled from "@emotion/styled/base";
|
|
4
|
-
import {
|
|
4
|
+
import { InformationOutlineIcon, SortIcon as SortIcon$1, SouthShortIcon } from "@ultraviolet/icons";
|
|
5
5
|
import { Stack } from "../Stack/index.js";
|
|
6
6
|
import { Tooltip } from "../Tooltip/index.js";
|
|
7
7
|
const StyledSortIcon = /* @__PURE__ */ _styled(SouthShortIcon, process.env.NODE_ENV === "production" ? {
|
|
@@ -13,7 +13,7 @@ const StyledSortIcon = /* @__PURE__ */ _styled(SouthShortIcon, process.env.NODE_
|
|
|
13
13
|
label: "StyledSortIcon"
|
|
14
14
|
})("transform:", ({
|
|
15
15
|
order
|
|
16
|
-
}) => order === "ascending" ? "rotate(-180deg)" : "none", ";transition:transform 0.2s ease-in-out;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
16
|
+
}) => order === "ascending" ? "rotate(-180deg)" : "none", ";transition:transform 0.2s ease-in-out;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0xpc3QvSGVhZGVyQ2VsbC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBY3lDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0xpc3QvSGVhZGVyQ2VsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQge1xuICBJbmZvcm1hdGlvbk91dGxpbmVJY29uLFxuICBTb3J0SWNvbiBhcyBTb3J0SWNvblVWLFxuICBTb3V0aFNob3J0SWNvbixcbn0gZnJvbSAnQHVsdHJhdmlvbGV0L2ljb25zJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vU3RhY2snXG5pbXBvcnQgeyBUb29sdGlwIH0gZnJvbSAnLi4vVG9vbHRpcCdcblxuY29uc3QgU3R5bGVkU29ydEljb24gPSBzdHlsZWQoU291dGhTaG9ydEljb24sIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT4gIVsnb3JkZXInXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgb3JkZXI6ICdhc2NlbmRpbmcnIHwgJ2Rlc2NlbmRpbmcnIH0+YFxuICB0cmFuc2Zvcm06ICR7KHsgb3JkZXIgfSkgPT5cbiAgICBvcmRlciA9PT0gJ2FzY2VuZGluZycgPyAncm90YXRlKC0xODBkZWcpJyA6ICdub25lJ307XG4gIHRyYW5zaXRpb246IHRyYW5zZm9ybSAwLjJzIGVhc2UtaW4tb3V0O1xuYFxuXG5jb25zdCBTb3J0SWNvbiA9ICh7IG9yZGVyIH06IHsgb3JkZXI/OiAnYXNjZW5kaW5nJyB8ICdkZXNjZW5kaW5nJyB9KSA9PlxuICBvcmRlciA/IChcbiAgICA8U3R5bGVkU29ydEljb24gb3JkZXI9e29yZGVyfSBzZW50aW1lbnQ9XCJwcmltYXJ5XCIgLz5cbiAgKSA6IChcbiAgICA8U29ydEljb25VViBzZW50aW1lbnQ9XCJuZXV0cmFsXCIgLz5cbiAgKVxuXG5jb25zdCBTdHlsZWRIZWFkZXJDZWxsID0gc3R5bGVkKCd0aCcsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT4gIVsnd2lkdGgnLCAnbWluV2lkdGgnLCAnbWF4V2lkdGgnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgd2lkdGg/OiBzdHJpbmc7IG1pbldpZHRoPzogc3RyaW5nOyBtYXhXaWR0aD86IHN0cmluZyB9PmBcbiAgZGlzcGxheTogdGFibGUtY2VsbDtcbiAgdGV4dC1hbGlnbjogbGVmdDtcbiAgdmVydGljYWwtYWxpZ246IG1pZGRsZTtcbiAgZm9udC1zaXplOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnR5cG9ncmFwaHkuYm9keVNtYWxsLmZvbnRTaXplfTtcbiAgZm9udC13ZWlnaHQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUudHlwb2dyYXBoeS5ib2R5U21hbGwud2VpZ2h0fTtcbiAgZm9udC1mYW1pbHk6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUudHlwb2dyYXBoeS5ib2R5U21hbGwuZm9udEZhbWlseX07XG4gIGNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHR9O1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG4gIHBhZGRpbmc6IDAgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcblxuICAmW3JvbGUqPSdidXR0b24nXSB7XG4gICAgY3Vyc29yOiBwb2ludGVyO1xuICAgIHVzZXItc2VsZWN0OiBub25lO1xuICB9XG5cbiAgJlthcmlhLXNvcnRdIHtcbiAgICBjb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMucHJpbWFyeS50ZXh0fTtcbiAgfVxuXG4gIHdpZHRoOiAkeyh7IHdpZHRoIH0pID0+IHdpZHRofTtcbiAgbWluLXdpZHRoOiAkeyh7IG1pbldpZHRoIH0pID0+IG1pbldpZHRofTtcbiAgbWF4LXdpZHRoOiAkeyh7IG1heFdpZHRoIH0pID0+IG1heFdpZHRofTtcbmBcblxudHlwZSBIZWFkZXJDZWxsUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGlzT3JkZXJlZD86IGJvb2xlYW5cbiAgb3JkZXJEaXJlY3Rpb24/OiAnYXNjJyB8ICdkZXNjJyB8ICdub25lJ1xuICBvbk9yZGVyPzogKG5ld09yZGVyOiAnYXNjJyB8ICdkZXNjJykgPT4gdm9pZFxuICBpbmZvPzogc3RyaW5nXG4gIHdpZHRoPzogc3RyaW5nXG4gIG1pbldpdGg/OiBzdHJpbmdcbiAgbWF4V2lkdGg/OiBzdHJpbmdcbn1cblxuZXhwb3J0IGNvbnN0IEhlYWRlckNlbGwgPSAoe1xuICBjaGlsZHJlbixcbiAgaXNPcmRlcmVkLFxuICBvcmRlckRpcmVjdGlvbixcbiAgb25PcmRlcixcbiAgY2xhc3NOYW1lLFxuICBpbmZvLFxuICB3aWR0aCxcbiAgbWluV2l0aCxcbiAgbWF4V2lkdGgsXG59OiBIZWFkZXJDZWxsUHJvcHMpID0+IHtcbiAgbGV0IG9yZGVyOiB1bmRlZmluZWQgfCAnYXNjZW5kaW5nJyB8ICdkZXNjZW5kaW5nJ1xuICBpZiAoaXNPcmRlcmVkICYmIG9yZGVyRGlyZWN0aW9uID09PSAnYXNjJykge1xuICAgIG9yZGVyID0gJ2FzY2VuZGluZydcbiAgfSBlbHNlIGlmIChpc09yZGVyZWQgJiYgb3JkZXJEaXJlY3Rpb24gPT09ICdkZXNjJykge1xuICAgIG9yZGVyID0gJ2Rlc2NlbmRpbmcnXG4gIH1cblxuICBjb25zdCBoYW5kbGVPcmRlciA9IG9uT3JkZXJcbiAgICA/ICgpID0+IG9uT3JkZXIob3JkZXIgPT09ICdhc2NlbmRpbmcnID8gJ2Rlc2MnIDogJ2FzYycpXG4gICAgOiB1bmRlZmluZWRcblxuICByZXR1cm4gKFxuICAgIDxTdHlsZWRIZWFkZXJDZWxsXG4gICAgICBhcmlhLXNvcnQ9e29yZGVyfVxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBvbkNsaWNrPXtoYW5kbGVPcmRlcn1cbiAgICAgIG9uS2V5RG93bj17XG4gICAgICAgIGhhbmRsZU9yZGVyXG4gICAgICAgICAgPyBldmVudCA9PiB7XG4gICAgICAgICAgICAgIGlmIChldmVudC5rZXkgPT09ICcgJyB8fCBldmVudC5rZXkgPT09ICdFbnRlcicpIHtcbiAgICAgICAgICAgICAgICBoYW5kbGVPcmRlcigpXG4gICAgICAgICAgICAgICAgaWYgKGV2ZW50LmtleSA9PT0gJyAnKSB7XG4gICAgICAgICAgICAgICAgICAvLyBAbm90ZTogaXQgYXZvaWQgc2Nyb2xsIHdoZW4gcHJlc3NpbmcgU3BhY2VcbiAgICAgICAgICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KClcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICA6IHVuZGVmaW5lZFxuICAgICAgfVxuICAgICAgcm9sZT17b25PcmRlciA/ICdidXR0b24gY29sdW1uaGVhZGVyJyA6IHVuZGVmaW5lZH1cbiAgICAgIHRhYkluZGV4PXtoYW5kbGVPcmRlciA/IDAgOiAtMX1cbiAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICAgIG1heFdpZHRoPXttYXhXaWR0aH1cbiAgICAgIG1pbldpZHRoPXttaW5XaXRofVxuICAgID5cbiAgICAgIDxTdGFjayBkaXJlY3Rpb249XCJyb3dcIiBnYXA9ezF9IGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgICB7aW5mbyA/IChcbiAgICAgICAgICA8VG9vbHRpcCB0ZXh0PXtpbmZvfT5cbiAgICAgICAgICAgIDxJbmZvcm1hdGlvbk91dGxpbmVJY29uXG4gICAgICAgICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgICAgICAgIHByb21pbmVuY2U9XCJ3ZWFrXCJcbiAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvVG9vbHRpcD5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICAgIHtvcmRlckRpcmVjdGlvbiAhPT0gdW5kZWZpbmVkICYmIGlzT3JkZXJlZCAhPT0gdW5kZWZpbmVkID8gKFxuICAgICAgICAgIDxTb3J0SWNvbiBvcmRlcj17b3JkZXJ9IC8+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgPC9TdGFjaz5cbiAgICA8L1N0eWxlZEhlYWRlckNlbGw+XG4gIClcbn1cbiJdfQ== */"));
|
|
17
17
|
const SortIcon = ({
|
|
18
18
|
order
|
|
19
19
|
}) => order ? /* @__PURE__ */ jsx(StyledSortIcon, { order, sentiment: "primary" }) : /* @__PURE__ */ jsx(SortIcon$1, { sentiment: "neutral" });
|
|
@@ -44,7 +44,7 @@ const StyledHeaderCell = /* @__PURE__ */ _styled("th", process.env.NODE_ENV ===
|
|
|
44
44
|
minWidth
|
|
45
45
|
}) => minWidth, ";max-width:", ({
|
|
46
46
|
maxWidth
|
|
47
|
-
}) => maxWidth, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
47
|
+
}) => maxWidth, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0xpc3QvSGVhZGVyQ2VsbC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkI0RCIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9MaXN0L0hlYWRlckNlbGwudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHtcbiAgSW5mb3JtYXRpb25PdXRsaW5lSWNvbixcbiAgU29ydEljb24gYXMgU29ydEljb25VVixcbiAgU291dGhTaG9ydEljb24sXG59IGZyb20gJ0B1bHRyYXZpb2xldC9pY29ucydcbmltcG9ydCB0eXBlIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBTdGFjayB9IGZyb20gJy4uL1N0YWNrJ1xuaW1wb3J0IHsgVG9vbHRpcCB9IGZyb20gJy4uL1Rvb2x0aXAnXG5cbmNvbnN0IFN0eWxlZFNvcnRJY29uID0gc3R5bGVkKFNvdXRoU2hvcnRJY29uLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ29yZGVyJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IG9yZGVyOiAnYXNjZW5kaW5nJyB8ICdkZXNjZW5kaW5nJyB9PmBcbiAgdHJhbnNmb3JtOiAkeyh7IG9yZGVyIH0pID0+XG4gICAgb3JkZXIgPT09ICdhc2NlbmRpbmcnID8gJ3JvdGF0ZSgtMTgwZGVnKScgOiAnbm9uZSd9O1xuICB0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gMC4ycyBlYXNlLWluLW91dDtcbmBcblxuY29uc3QgU29ydEljb24gPSAoeyBvcmRlciB9OiB7IG9yZGVyPzogJ2FzY2VuZGluZycgfCAnZGVzY2VuZGluZycgfSkgPT5cbiAgb3JkZXIgPyAoXG4gICAgPFN0eWxlZFNvcnRJY29uIG9yZGVyPXtvcmRlcn0gc2VudGltZW50PVwicHJpbWFyeVwiIC8+XG4gICkgOiAoXG4gICAgPFNvcnRJY29uVVYgc2VudGltZW50PVwibmV1dHJhbFwiIC8+XG4gIClcblxuY29uc3QgU3R5bGVkSGVhZGVyQ2VsbCA9IHN0eWxlZCgndGgnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3dpZHRoJywgJ21pbldpZHRoJywgJ21heFdpZHRoJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IHdpZHRoPzogc3RyaW5nOyBtaW5XaWR0aD86IHN0cmluZzsgbWF4V2lkdGg/OiBzdHJpbmcgfT5gXG4gIGRpc3BsYXk6IHRhYmxlLWNlbGw7XG4gIHRleHQtYWxpZ246IGxlZnQ7XG4gIHZlcnRpY2FsLWFsaWduOiBtaWRkbGU7XG4gIGZvbnQtc2l6ZTogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS50eXBvZ3JhcGh5LmJvZHlTbWFsbC5mb250U2l6ZX07XG4gIGZvbnQtd2VpZ2h0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnR5cG9ncmFwaHkuYm9keVNtYWxsLndlaWdodH07XG4gIGZvbnQtZmFtaWx5OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnR5cG9ncmFwaHkuYm9keVNtYWxsLmZvbnRGYW1pbHl9O1xuICBjb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC50ZXh0fTtcbiAgZ2FwOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuICBwYWRkaW5nOiAwICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzInXX07XG5cbiAgJltyb2xlKj0nYnV0dG9uJ10ge1xuICAgIGN1cnNvcjogcG9pbnRlcjtcbiAgICB1c2VyLXNlbGVjdDogbm9uZTtcbiAgfVxuXG4gICZbYXJpYS1zb3J0XSB7XG4gICAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnkudGV4dH07XG4gIH1cblxuICB3aWR0aDogJHsoeyB3aWR0aCB9KSA9PiB3aWR0aH07XG4gIG1pbi13aWR0aDogJHsoeyBtaW5XaWR0aCB9KSA9PiBtaW5XaWR0aH07XG4gIG1heC13aWR0aDogJHsoeyBtYXhXaWR0aCB9KSA9PiBtYXhXaWR0aH07XG5gXG5cbnR5cGUgSGVhZGVyQ2VsbFByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBpc09yZGVyZWQ/OiBib29sZWFuXG4gIG9yZGVyRGlyZWN0aW9uPzogJ2FzYycgfCAnZGVzYycgfCAnbm9uZSdcbiAgb25PcmRlcj86IChuZXdPcmRlcjogJ2FzYycgfCAnZGVzYycpID0+IHZvaWRcbiAgaW5mbz86IHN0cmluZ1xuICB3aWR0aD86IHN0cmluZ1xuICBtaW5XaXRoPzogc3RyaW5nXG4gIG1heFdpZHRoPzogc3RyaW5nXG59XG5cbmV4cG9ydCBjb25zdCBIZWFkZXJDZWxsID0gKHtcbiAgY2hpbGRyZW4sXG4gIGlzT3JkZXJlZCxcbiAgb3JkZXJEaXJlY3Rpb24sXG4gIG9uT3JkZXIsXG4gIGNsYXNzTmFtZSxcbiAgaW5mbyxcbiAgd2lkdGgsXG4gIG1pbldpdGgsXG4gIG1heFdpZHRoLFxufTogSGVhZGVyQ2VsbFByb3BzKSA9PiB7XG4gIGxldCBvcmRlcjogdW5kZWZpbmVkIHwgJ2FzY2VuZGluZycgfCAnZGVzY2VuZGluZydcbiAgaWYgKGlzT3JkZXJlZCAmJiBvcmRlckRpcmVjdGlvbiA9PT0gJ2FzYycpIHtcbiAgICBvcmRlciA9ICdhc2NlbmRpbmcnXG4gIH0gZWxzZSBpZiAoaXNPcmRlcmVkICYmIG9yZGVyRGlyZWN0aW9uID09PSAnZGVzYycpIHtcbiAgICBvcmRlciA9ICdkZXNjZW5kaW5nJ1xuICB9XG5cbiAgY29uc3QgaGFuZGxlT3JkZXIgPSBvbk9yZGVyXG4gICAgPyAoKSA9PiBvbk9yZGVyKG9yZGVyID09PSAnYXNjZW5kaW5nJyA/ICdkZXNjJyA6ICdhc2MnKVxuICAgIDogdW5kZWZpbmVkXG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkSGVhZGVyQ2VsbFxuICAgICAgYXJpYS1zb3J0PXtvcmRlcn1cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgb25DbGljaz17aGFuZGxlT3JkZXJ9XG4gICAgICBvbktleURvd249e1xuICAgICAgICBoYW5kbGVPcmRlclxuICAgICAgICAgID8gZXZlbnQgPT4ge1xuICAgICAgICAgICAgICBpZiAoZXZlbnQua2V5ID09PSAnICcgfHwgZXZlbnQua2V5ID09PSAnRW50ZXInKSB7XG4gICAgICAgICAgICAgICAgaGFuZGxlT3JkZXIoKVxuICAgICAgICAgICAgICAgIGlmIChldmVudC5rZXkgPT09ICcgJykge1xuICAgICAgICAgICAgICAgICAgLy8gQG5vdGU6IGl0IGF2b2lkIHNjcm9sbCB3aGVuIHByZXNzaW5nIFNwYWNlXG4gICAgICAgICAgICAgICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgICAgOiB1bmRlZmluZWRcbiAgICAgIH1cbiAgICAgIHJvbGU9e29uT3JkZXIgPyAnYnV0dG9uIGNvbHVtbmhlYWRlcicgOiB1bmRlZmluZWR9XG4gICAgICB0YWJJbmRleD17aGFuZGxlT3JkZXIgPyAwIDogLTF9XG4gICAgICB3aWR0aD17d2lkdGh9XG4gICAgICBtYXhXaWR0aD17bWF4V2lkdGh9XG4gICAgICBtaW5XaWR0aD17bWluV2l0aH1cbiAgICA+XG4gICAgICA8U3RhY2sgZGlyZWN0aW9uPVwicm93XCIgZ2FwPXsxfSBhbGlnbkl0ZW1zPVwiY2VudGVyXCI+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAge2luZm8gPyAoXG4gICAgICAgICAgPFRvb2x0aXAgdGV4dD17aW5mb30+XG4gICAgICAgICAgICA8SW5mb3JtYXRpb25PdXRsaW5lSWNvblxuICAgICAgICAgICAgICBzaXplPVwic21hbGxcIlxuICAgICAgICAgICAgICBwcm9taW5lbmNlPVwid2Vha1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L1Rvb2x0aXA+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgICB7b3JkZXJEaXJlY3Rpb24gIT09IHVuZGVmaW5lZCAmJiBpc09yZGVyZWQgIT09IHVuZGVmaW5lZCA/IChcbiAgICAgICAgICA8U29ydEljb24gb3JkZXI9e29yZGVyfSAvPlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvU3RhY2s+XG4gICAgPC9TdHlsZWRIZWFkZXJDZWxsPlxuICApXG59XG4iXX0= */"));
|
|
48
48
|
const HeaderCell = ({
|
|
49
49
|
children,
|
|
50
50
|
isOrdered,
|
|
@@ -72,7 +72,7 @@ const HeaderCell = ({
|
|
|
72
72
|
}
|
|
73
73
|
} : void 0, role: onOrder ? "button columnheader" : void 0, tabIndex: handleOrder ? 0 : -1, width, maxWidth, minWidth: minWith, children: /* @__PURE__ */ jsxs(Stack, { direction: "row", gap: 1, alignItems: "center", children: [
|
|
74
74
|
children,
|
|
75
|
-
info ? /* @__PURE__ */ jsx(Tooltip, { text: info, children: /* @__PURE__ */ jsx(
|
|
75
|
+
info ? /* @__PURE__ */ jsx(Tooltip, { text: info, children: /* @__PURE__ */ jsx(InformationOutlineIcon, { size: "small", prominence: "weak", sentiment: "neutral" }) }) : null,
|
|
76
76
|
orderDirection !== void 0 && isOrdered !== void 0 ? /* @__PURE__ */ jsx(SortIcon, { order }) : null
|
|
77
77
|
] }) });
|
|
78
78
|
};
|
|
@@ -17,7 +17,7 @@ const StyledSortIcon = /* @__PURE__ */ _styled__default.default(Icon.SouthShortI
|
|
|
17
17
|
label: "StyledSortIcon"
|
|
18
18
|
})("transform:", ({
|
|
19
19
|
order
|
|
20
|
-
}) => order === "ascending" ? "rotate(-180deg)" : "none", ";transition:transform 0.2s;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
20
|
+
}) => order === "ascending" ? "rotate(-180deg)" : "none", ";transition:transform 0.2s;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYmxlL0hlYWRlckNlbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWN5QyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9UYWJsZS9IZWFkZXJDZWxsLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7XG4gIEluZm9ybWF0aW9uT3V0bGluZUljb24sXG4gIFNvcnRJY29uIGFzIFNvcnRJY29uVVYsXG4gIFNvdXRoU2hvcnRJY29uLFxufSBmcm9tICdAdWx0cmF2aW9sZXQvaWNvbnMnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL1RleHQnXG5pbXBvcnQgeyBUb29sdGlwIH0gZnJvbSAnLi4vVG9vbHRpcCdcblxuY29uc3QgU3R5bGVkU29ydEljb24gPSBzdHlsZWQoU291dGhTaG9ydEljb24sIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT4gIVsnb3JkZXInXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgb3JkZXI6ICdhc2NlbmRpbmcnIHwgJ2Rlc2NlbmRpbmcnIH0+YFxuICAgIHRyYW5zZm9ybTogJHsoeyBvcmRlciB9KSA9PlxuICAgICAgb3JkZXIgPT09ICdhc2NlbmRpbmcnID8gJ3JvdGF0ZSgtMTgwZGVnKScgOiAnbm9uZSd9O1xuICAgIHRyYW5zaXRpb246IHRyYW5zZm9ybSAwLjJzO1xuYFxuXG5jb25zdCBTb3J0SWNvbiA9ICh7IG9yZGVyIH06IHsgb3JkZXI/OiAnYXNjZW5kaW5nJyB8ICdkZXNjZW5kaW5nJyB9KSA9PlxuICBvcmRlciA/IChcbiAgICA8U3R5bGVkU29ydEljb24gb3JkZXI9e29yZGVyfSBzZW50aW1lbnQ9XCJwcmltYXJ5XCIgLz5cbiAgKSA6IChcbiAgICA8U29ydEljb25VViBzZW50aW1lbnQ9XCJuZXV0cmFsXCIgLz5cbiAgKVxuXG50eXBlIFN0eWxlZEhlYWRlckNlbGxQcm9wcyA9IFBpY2s8XG4gIEhlYWRlckNlbGxQcm9wcyxcbiAgJ3dpZHRoJyB8ICdtYXhXaWR0aCcgfCAnbWluV2lkdGgnXG4+ICYge1xuICBhbGlnbj86ICdsZWZ0JyB8ICdjZW50ZXInIHwgJ3JpZ2h0J1xufVxuXG5jb25zdCBTdHlsZWRIZWFkZXJDZWxsID0gc3R5bGVkKCd0aCcsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT5cbiAgICAhWydhbGlnbicsICd3aWR0aCcsICdtYXhXaWR0aCcsICdtaW5XaWR0aCddLmluY2x1ZGVzKHByb3ApLFxufSk8U3R5bGVkSGVhZGVyQ2VsbFByb3BzPmBcbiR7KHsgd2lkdGgsIG1heFdpZHRoLCBtaW5XaWR0aCB9KSA9PiBgXG4gICAgJHt3aWR0aCA/IGB3aWR0aDogJHt3aWR0aH07YCA6ICcnfVxuICAgICR7bWF4V2lkdGggPyBgbWF4LXdpZHRoOiAke21heFdpZHRofTtgIDogJyd9XG4gICAgJHttaW5XaWR0aCA/IGBtaW4td2lkdGg6ICR7bWluV2lkdGh9O2AgOiAnJ31cbiAgYH1cbiAgZGlzcGxheTogdGFibGUtY2VsbDtcbiAgdmVydGljYWwtYWxpZ246IG1pZGRsZTtcbiAgdGV4dC1hbGlnbjogJHsoeyBhbGlnbiB9KSA9PiBhbGlnbn07XG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG5cbiAgJltyb2xlKj0nYnV0dG9uJ10ge1xuICAgIGN1cnNvcjogcG9pbnRlcjtcbiAgICB1c2VyLXNlbGVjdDogbm9uZTtcbiAgfVxuXG4gICY6Zmlyc3Qtb2YtdHlwZSB7XG4gICAgcGFkZGluZy1sZWZ0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycyJ119O1xuICB9XG5gXG5cbmNvbnN0IFN0eWxlZFRleHQgPSBzdHlsZWQoVGV4dClgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiByb3c7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGdhcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfTtcbmBcblxudHlwZSBIZWFkZXJDZWxsUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGlzT3JkZXJlZD86IGJvb2xlYW5cbiAgb3JkZXJEaXJlY3Rpb24/OiAnYXNjJyB8ICdkZXNjJyB8ICdub25lJ1xuICBvbk9yZGVyPzogKG5ld09yZGVyOiAnYXNjJyB8ICdkZXNjJykgPT4gdm9pZFxuICBpbmZvPzogc3RyaW5nXG4gIGFsaWduPzogJ2xlZnQnIHwgJ2NlbnRlcicgfCAncmlnaHQnXG4gIHdpZHRoPzogc3RyaW5nXG4gIG1heFdpZHRoPzogc3RyaW5nXG4gIG1pbldpZHRoPzogc3RyaW5nXG59XG5cbmV4cG9ydCBjb25zdCBIZWFkZXJDZWxsID0gKHtcbiAgY2hpbGRyZW4sXG4gIGNsYXNzTmFtZSxcbiAgaXNPcmRlcmVkLFxuICBvbk9yZGVyLFxuICBvcmRlckRpcmVjdGlvbixcbiAgaW5mbyxcbiAgYWxpZ24sXG4gIHdpZHRoLFxuICBtYXhXaWR0aCxcbiAgbWluV2lkdGgsXG59OiBIZWFkZXJDZWxsUHJvcHMpID0+IHtcbiAgbGV0IG9yZGVyOiB1bmRlZmluZWQgfCAnYXNjZW5kaW5nJyB8ICdkZXNjZW5kaW5nJ1xuICBpZiAoaXNPcmRlcmVkICYmIG9yZGVyRGlyZWN0aW9uID09PSAnYXNjJykge1xuICAgIG9yZGVyID0gJ2FzY2VuZGluZydcbiAgfSBlbHNlIGlmIChpc09yZGVyZWQgJiYgb3JkZXJEaXJlY3Rpb24gPT09ICdkZXNjJykge1xuICAgIG9yZGVyID0gJ2Rlc2NlbmRpbmcnXG4gIH1cblxuICBjb25zdCBoYW5kbGVPcmRlciA9IG9uT3JkZXJcbiAgICA/ICgpID0+IG9uT3JkZXIob3JkZXIgPT09ICdhc2NlbmRpbmcnID8gJ2Rlc2MnIDogJ2FzYycpXG4gICAgOiB1bmRlZmluZWRcblxuICByZXR1cm4gKFxuICAgIDxTdHlsZWRIZWFkZXJDZWxsXG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIG9uQ2xpY2s9e2hhbmRsZU9yZGVyfVxuICAgICAgb25LZXlEb3duPXtcbiAgICAgICAgaGFuZGxlT3JkZXJcbiAgICAgICAgICA/IGV2ZW50ID0+IHtcbiAgICAgICAgICAgICAgaWYgKGV2ZW50LmtleSA9PT0gJyAnIHx8IGV2ZW50LmtleSA9PT0gJ0VudGVyJykge1xuICAgICAgICAgICAgICAgIGhhbmRsZU9yZGVyKClcbiAgICAgICAgICAgICAgICBpZiAoZXZlbnQua2V5ID09PSAnICcpIHtcbiAgICAgICAgICAgICAgICAgIC8vIEBub3RlOiBpdCBhdm9pZCBzY3JvbGwgd2hlbiBwcmVzc2luZyBTcGFjZVxuICAgICAgICAgICAgICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKVxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgIDogdW5kZWZpbmVkXG4gICAgICB9XG4gICAgICByb2xlPXtvbk9yZGVyID8gJ2J1dHRvbiBjb2x1bW5oZWFkZXInIDogdW5kZWZpbmVkfVxuICAgICAgdGFiSW5kZXg9e2hhbmRsZU9yZGVyID8gMCA6IC0xfVxuICAgICAgYXJpYS1zb3J0PXtvcmRlcn1cbiAgICAgIGFsaWduPXthbGlnbn1cbiAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICAgIG1heFdpZHRoPXttYXhXaWR0aH1cbiAgICAgIG1pbldpZHRoPXttaW5XaWR0aH1cbiAgICA+XG4gICAgICA8U3R5bGVkVGV4dFxuICAgICAgICBhcz1cImRpdlwiXG4gICAgICAgIHZhcmlhbnQ9XCJib2R5U21hbGxcIlxuICAgICAgICBjb2xvcj17b3JkZXIgIT09IHVuZGVmaW5lZCA/ICdwcmltYXJ5JyA6ICduZXV0cmFsJ31cbiAgICAgID5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgICB7aW5mbyA/IChcbiAgICAgICAgICA8VG9vbHRpcCB0ZXh0PXtpbmZvfT5cbiAgICAgICAgICAgIDxJbmZvcm1hdGlvbk91dGxpbmVJY29uXG4gICAgICAgICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgICAgICAgIHByb21pbmVuY2U9XCJ3ZWFrXCJcbiAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvVG9vbHRpcD5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICAgIHtvcmRlckRpcmVjdGlvbiAhPT0gdW5kZWZpbmVkICYmIGlzT3JkZXJlZCAhPT0gdW5kZWZpbmVkID8gKFxuICAgICAgICAgIDxTb3J0SWNvbiBhcmlhLWRpc2FibGVkPXshb25PcmRlcn0gb3JkZXI9e29yZGVyfSAvPlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvU3R5bGVkVGV4dD5cbiAgICA8L1N0eWxlZEhlYWRlckNlbGw+XG4gIClcbn1cbiJdfQ== */"));
|
|
21
21
|
const SortIcon = ({
|
|
22
22
|
order
|
|
23
23
|
}) => order ? /* @__PURE__ */ jsxRuntime.jsx(StyledSortIcon, { order, sentiment: "primary" }) : /* @__PURE__ */ jsxRuntime.jsx(Icon.SortIcon, { sentiment: "neutral" });
|
|
@@ -42,7 +42,7 @@ const StyledHeaderCell = /* @__PURE__ */ _styled__default.default("th", process.
|
|
|
42
42
|
theme
|
|
43
43
|
}) => theme.space["1"], ";&[role*='button']{cursor:pointer;user-select:none;}&:first-of-type{padding-left:", ({
|
|
44
44
|
theme
|
|
45
|
-
}) => theme.space["2"], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
45
|
+
}) => theme.space["2"], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYmxlL0hlYWRlckNlbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFDeUIiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvVGFibGUvSGVhZGVyQ2VsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQge1xuICBJbmZvcm1hdGlvbk91dGxpbmVJY29uLFxuICBTb3J0SWNvbiBhcyBTb3J0SWNvblVWLFxuICBTb3V0aFNob3J0SWNvbixcbn0gZnJvbSAnQHVsdHJhdmlvbGV0L2ljb25zJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuaW1wb3J0IHsgVG9vbHRpcCB9IGZyb20gJy4uL1Rvb2x0aXAnXG5cbmNvbnN0IFN0eWxlZFNvcnRJY29uID0gc3R5bGVkKFNvdXRoU2hvcnRJY29uLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ29yZGVyJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IG9yZGVyOiAnYXNjZW5kaW5nJyB8ICdkZXNjZW5kaW5nJyB9PmBcbiAgICB0cmFuc2Zvcm06ICR7KHsgb3JkZXIgfSkgPT5cbiAgICAgIG9yZGVyID09PSAnYXNjZW5kaW5nJyA/ICdyb3RhdGUoLTE4MGRlZyknIDogJ25vbmUnfTtcbiAgICB0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gMC4ycztcbmBcblxuY29uc3QgU29ydEljb24gPSAoeyBvcmRlciB9OiB7IG9yZGVyPzogJ2FzY2VuZGluZycgfCAnZGVzY2VuZGluZycgfSkgPT5cbiAgb3JkZXIgPyAoXG4gICAgPFN0eWxlZFNvcnRJY29uIG9yZGVyPXtvcmRlcn0gc2VudGltZW50PVwicHJpbWFyeVwiIC8+XG4gICkgOiAoXG4gICAgPFNvcnRJY29uVVYgc2VudGltZW50PVwibmV1dHJhbFwiIC8+XG4gIClcblxudHlwZSBTdHlsZWRIZWFkZXJDZWxsUHJvcHMgPSBQaWNrPFxuICBIZWFkZXJDZWxsUHJvcHMsXG4gICd3aWR0aCcgfCAnbWF4V2lkdGgnIHwgJ21pbldpZHRoJ1xuPiAmIHtcbiAgYWxpZ24/OiAnbGVmdCcgfCAnY2VudGVyJyB8ICdyaWdodCdcbn1cblxuY29uc3QgU3R5bGVkSGVhZGVyQ2VsbCA9IHN0eWxlZCgndGgnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+XG4gICAgIVsnYWxpZ24nLCAnd2lkdGgnLCAnbWF4V2lkdGgnLCAnbWluV2lkdGgnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPFN0eWxlZEhlYWRlckNlbGxQcm9wcz5gXG4keyh7IHdpZHRoLCBtYXhXaWR0aCwgbWluV2lkdGggfSkgPT4gYFxuICAgICR7d2lkdGggPyBgd2lkdGg6ICR7d2lkdGh9O2AgOiAnJ31cbiAgICAke21heFdpZHRoID8gYG1heC13aWR0aDogJHttYXhXaWR0aH07YCA6ICcnfVxuICAgICR7bWluV2lkdGggPyBgbWluLXdpZHRoOiAke21pbldpZHRofTtgIDogJyd9XG4gIGB9XG4gIGRpc3BsYXk6IHRhYmxlLWNlbGw7XG4gIHZlcnRpY2FsLWFsaWduOiBtaWRkbGU7XG4gIHRleHQtYWxpZ246ICR7KHsgYWxpZ24gfSkgPT4gYWxpZ259O1xuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuXG4gICZbcm9sZSo9J2J1dHRvbiddIHtcbiAgICBjdXJzb3I6IHBvaW50ZXI7XG4gICAgdXNlci1zZWxlY3Q6IG5vbmU7XG4gIH1cblxuICAmOmZpcnN0LW9mLXR5cGUge1xuICAgIHBhZGRpbmctbGVmdDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbiAgfVxuYFxuXG5jb25zdCBTdHlsZWRUZXh0ID0gc3R5bGVkKFRleHQpYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogcm93O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG5gXG5cbnR5cGUgSGVhZGVyQ2VsbFByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBpc09yZGVyZWQ/OiBib29sZWFuXG4gIG9yZGVyRGlyZWN0aW9uPzogJ2FzYycgfCAnZGVzYycgfCAnbm9uZSdcbiAgb25PcmRlcj86IChuZXdPcmRlcjogJ2FzYycgfCAnZGVzYycpID0+IHZvaWRcbiAgaW5mbz86IHN0cmluZ1xuICBhbGlnbj86ICdsZWZ0JyB8ICdjZW50ZXInIHwgJ3JpZ2h0J1xuICB3aWR0aD86IHN0cmluZ1xuICBtYXhXaWR0aD86IHN0cmluZ1xuICBtaW5XaWR0aD86IHN0cmluZ1xufVxuXG5leHBvcnQgY29uc3QgSGVhZGVyQ2VsbCA9ICh7XG4gIGNoaWxkcmVuLFxuICBjbGFzc05hbWUsXG4gIGlzT3JkZXJlZCxcbiAgb25PcmRlcixcbiAgb3JkZXJEaXJlY3Rpb24sXG4gIGluZm8sXG4gIGFsaWduLFxuICB3aWR0aCxcbiAgbWF4V2lkdGgsXG4gIG1pbldpZHRoLFxufTogSGVhZGVyQ2VsbFByb3BzKSA9PiB7XG4gIGxldCBvcmRlcjogdW5kZWZpbmVkIHwgJ2FzY2VuZGluZycgfCAnZGVzY2VuZGluZydcbiAgaWYgKGlzT3JkZXJlZCAmJiBvcmRlckRpcmVjdGlvbiA9PT0gJ2FzYycpIHtcbiAgICBvcmRlciA9ICdhc2NlbmRpbmcnXG4gIH0gZWxzZSBpZiAoaXNPcmRlcmVkICYmIG9yZGVyRGlyZWN0aW9uID09PSAnZGVzYycpIHtcbiAgICBvcmRlciA9ICdkZXNjZW5kaW5nJ1xuICB9XG5cbiAgY29uc3QgaGFuZGxlT3JkZXIgPSBvbk9yZGVyXG4gICAgPyAoKSA9PiBvbk9yZGVyKG9yZGVyID09PSAnYXNjZW5kaW5nJyA/ICdkZXNjJyA6ICdhc2MnKVxuICAgIDogdW5kZWZpbmVkXG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkSGVhZGVyQ2VsbFxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBvbkNsaWNrPXtoYW5kbGVPcmRlcn1cbiAgICAgIG9uS2V5RG93bj17XG4gICAgICAgIGhhbmRsZU9yZGVyXG4gICAgICAgICAgPyBldmVudCA9PiB7XG4gICAgICAgICAgICAgIGlmIChldmVudC5rZXkgPT09ICcgJyB8fCBldmVudC5rZXkgPT09ICdFbnRlcicpIHtcbiAgICAgICAgICAgICAgICBoYW5kbGVPcmRlcigpXG4gICAgICAgICAgICAgICAgaWYgKGV2ZW50LmtleSA9PT0gJyAnKSB7XG4gICAgICAgICAgICAgICAgICAvLyBAbm90ZTogaXQgYXZvaWQgc2Nyb2xsIHdoZW4gcHJlc3NpbmcgU3BhY2VcbiAgICAgICAgICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KClcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICA6IHVuZGVmaW5lZFxuICAgICAgfVxuICAgICAgcm9sZT17b25PcmRlciA/ICdidXR0b24gY29sdW1uaGVhZGVyJyA6IHVuZGVmaW5lZH1cbiAgICAgIHRhYkluZGV4PXtoYW5kbGVPcmRlciA/IDAgOiAtMX1cbiAgICAgIGFyaWEtc29ydD17b3JkZXJ9XG4gICAgICBhbGlnbj17YWxpZ259XG4gICAgICB3aWR0aD17d2lkdGh9XG4gICAgICBtYXhXaWR0aD17bWF4V2lkdGh9XG4gICAgICBtaW5XaWR0aD17bWluV2lkdGh9XG4gICAgPlxuICAgICAgPFN0eWxlZFRleHRcbiAgICAgICAgYXM9XCJkaXZcIlxuICAgICAgICB2YXJpYW50PVwiYm9keVNtYWxsXCJcbiAgICAgICAgY29sb3I9e29yZGVyICE9PSB1bmRlZmluZWQgPyAncHJpbWFyeScgOiAnbmV1dHJhbCd9XG4gICAgICA+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAge2luZm8gPyAoXG4gICAgICAgICAgPFRvb2x0aXAgdGV4dD17aW5mb30+XG4gICAgICAgICAgICA8SW5mb3JtYXRpb25PdXRsaW5lSWNvblxuICAgICAgICAgICAgICBzaXplPVwic21hbGxcIlxuICAgICAgICAgICAgICBwcm9taW5lbmNlPVwid2Vha1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L1Rvb2x0aXA+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgICB7b3JkZXJEaXJlY3Rpb24gIT09IHVuZGVmaW5lZCAmJiBpc09yZGVyZWQgIT09IHVuZGVmaW5lZCA/IChcbiAgICAgICAgICA8U29ydEljb24gYXJpYS1kaXNhYmxlZD17IW9uT3JkZXJ9IG9yZGVyPXtvcmRlcn0gLz5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICA8L1N0eWxlZFRleHQ+XG4gICAgPC9TdHlsZWRIZWFkZXJDZWxsPlxuICApXG59XG4iXX0= */"));
|
|
46
46
|
const StyledText = /* @__PURE__ */ _styled__default.default(index$1.Text, process.env.NODE_ENV === "production" ? {
|
|
47
47
|
target: "ev6jkq80"
|
|
48
48
|
} : {
|
|
@@ -50,7 +50,7 @@ const StyledText = /* @__PURE__ */ _styled__default.default(index$1.Text, proces
|
|
|
50
50
|
label: "StyledText"
|
|
51
51
|
})("display:flex;flex-direction:row;align-items:center;gap:", ({
|
|
52
52
|
theme
|
|
53
|
-
}) => theme.space["1"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
53
|
+
}) => theme.space["1"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYmxlL0hlYWRlckNlbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBEK0IiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvVGFibGUvSGVhZGVyQ2VsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQge1xuICBJbmZvcm1hdGlvbk91dGxpbmVJY29uLFxuICBTb3J0SWNvbiBhcyBTb3J0SWNvblVWLFxuICBTb3V0aFNob3J0SWNvbixcbn0gZnJvbSAnQHVsdHJhdmlvbGV0L2ljb25zJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuaW1wb3J0IHsgVG9vbHRpcCB9IGZyb20gJy4uL1Rvb2x0aXAnXG5cbmNvbnN0IFN0eWxlZFNvcnRJY29uID0gc3R5bGVkKFNvdXRoU2hvcnRJY29uLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ29yZGVyJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IG9yZGVyOiAnYXNjZW5kaW5nJyB8ICdkZXNjZW5kaW5nJyB9PmBcbiAgICB0cmFuc2Zvcm06ICR7KHsgb3JkZXIgfSkgPT5cbiAgICAgIG9yZGVyID09PSAnYXNjZW5kaW5nJyA/ICdyb3RhdGUoLTE4MGRlZyknIDogJ25vbmUnfTtcbiAgICB0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gMC4ycztcbmBcblxuY29uc3QgU29ydEljb24gPSAoeyBvcmRlciB9OiB7IG9yZGVyPzogJ2FzY2VuZGluZycgfCAnZGVzY2VuZGluZycgfSkgPT5cbiAgb3JkZXIgPyAoXG4gICAgPFN0eWxlZFNvcnRJY29uIG9yZGVyPXtvcmRlcn0gc2VudGltZW50PVwicHJpbWFyeVwiIC8+XG4gICkgOiAoXG4gICAgPFNvcnRJY29uVVYgc2VudGltZW50PVwibmV1dHJhbFwiIC8+XG4gIClcblxudHlwZSBTdHlsZWRIZWFkZXJDZWxsUHJvcHMgPSBQaWNrPFxuICBIZWFkZXJDZWxsUHJvcHMsXG4gICd3aWR0aCcgfCAnbWF4V2lkdGgnIHwgJ21pbldpZHRoJ1xuPiAmIHtcbiAgYWxpZ24/OiAnbGVmdCcgfCAnY2VudGVyJyB8ICdyaWdodCdcbn1cblxuY29uc3QgU3R5bGVkSGVhZGVyQ2VsbCA9IHN0eWxlZCgndGgnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+XG4gICAgIVsnYWxpZ24nLCAnd2lkdGgnLCAnbWF4V2lkdGgnLCAnbWluV2lkdGgnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPFN0eWxlZEhlYWRlckNlbGxQcm9wcz5gXG4keyh7IHdpZHRoLCBtYXhXaWR0aCwgbWluV2lkdGggfSkgPT4gYFxuICAgICR7d2lkdGggPyBgd2lkdGg6ICR7d2lkdGh9O2AgOiAnJ31cbiAgICAke21heFdpZHRoID8gYG1heC13aWR0aDogJHttYXhXaWR0aH07YCA6ICcnfVxuICAgICR7bWluV2lkdGggPyBgbWluLXdpZHRoOiAke21pbldpZHRofTtgIDogJyd9XG4gIGB9XG4gIGRpc3BsYXk6IHRhYmxlLWNlbGw7XG4gIHZlcnRpY2FsLWFsaWduOiBtaWRkbGU7XG4gIHRleHQtYWxpZ246ICR7KHsgYWxpZ24gfSkgPT4gYWxpZ259O1xuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuXG4gICZbcm9sZSo9J2J1dHRvbiddIHtcbiAgICBjdXJzb3I6IHBvaW50ZXI7XG4gICAgdXNlci1zZWxlY3Q6IG5vbmU7XG4gIH1cblxuICAmOmZpcnN0LW9mLXR5cGUge1xuICAgIHBhZGRpbmctbGVmdDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbiAgfVxuYFxuXG5jb25zdCBTdHlsZWRUZXh0ID0gc3R5bGVkKFRleHQpYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogcm93O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG5gXG5cbnR5cGUgSGVhZGVyQ2VsbFByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBpc09yZGVyZWQ/OiBib29sZWFuXG4gIG9yZGVyRGlyZWN0aW9uPzogJ2FzYycgfCAnZGVzYycgfCAnbm9uZSdcbiAgb25PcmRlcj86IChuZXdPcmRlcjogJ2FzYycgfCAnZGVzYycpID0+IHZvaWRcbiAgaW5mbz86IHN0cmluZ1xuICBhbGlnbj86ICdsZWZ0JyB8ICdjZW50ZXInIHwgJ3JpZ2h0J1xuICB3aWR0aD86IHN0cmluZ1xuICBtYXhXaWR0aD86IHN0cmluZ1xuICBtaW5XaWR0aD86IHN0cmluZ1xufVxuXG5leHBvcnQgY29uc3QgSGVhZGVyQ2VsbCA9ICh7XG4gIGNoaWxkcmVuLFxuICBjbGFzc05hbWUsXG4gIGlzT3JkZXJlZCxcbiAgb25PcmRlcixcbiAgb3JkZXJEaXJlY3Rpb24sXG4gIGluZm8sXG4gIGFsaWduLFxuICB3aWR0aCxcbiAgbWF4V2lkdGgsXG4gIG1pbldpZHRoLFxufTogSGVhZGVyQ2VsbFByb3BzKSA9PiB7XG4gIGxldCBvcmRlcjogdW5kZWZpbmVkIHwgJ2FzY2VuZGluZycgfCAnZGVzY2VuZGluZydcbiAgaWYgKGlzT3JkZXJlZCAmJiBvcmRlckRpcmVjdGlvbiA9PT0gJ2FzYycpIHtcbiAgICBvcmRlciA9ICdhc2NlbmRpbmcnXG4gIH0gZWxzZSBpZiAoaXNPcmRlcmVkICYmIG9yZGVyRGlyZWN0aW9uID09PSAnZGVzYycpIHtcbiAgICBvcmRlciA9ICdkZXNjZW5kaW5nJ1xuICB9XG5cbiAgY29uc3QgaGFuZGxlT3JkZXIgPSBvbk9yZGVyXG4gICAgPyAoKSA9PiBvbk9yZGVyKG9yZGVyID09PSAnYXNjZW5kaW5nJyA/ICdkZXNjJyA6ICdhc2MnKVxuICAgIDogdW5kZWZpbmVkXG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkSGVhZGVyQ2VsbFxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBvbkNsaWNrPXtoYW5kbGVPcmRlcn1cbiAgICAgIG9uS2V5RG93bj17XG4gICAgICAgIGhhbmRsZU9yZGVyXG4gICAgICAgICAgPyBldmVudCA9PiB7XG4gICAgICAgICAgICAgIGlmIChldmVudC5rZXkgPT09ICcgJyB8fCBldmVudC5rZXkgPT09ICdFbnRlcicpIHtcbiAgICAgICAgICAgICAgICBoYW5kbGVPcmRlcigpXG4gICAgICAgICAgICAgICAgaWYgKGV2ZW50LmtleSA9PT0gJyAnKSB7XG4gICAgICAgICAgICAgICAgICAvLyBAbm90ZTogaXQgYXZvaWQgc2Nyb2xsIHdoZW4gcHJlc3NpbmcgU3BhY2VcbiAgICAgICAgICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KClcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICA6IHVuZGVmaW5lZFxuICAgICAgfVxuICAgICAgcm9sZT17b25PcmRlciA/ICdidXR0b24gY29sdW1uaGVhZGVyJyA6IHVuZGVmaW5lZH1cbiAgICAgIHRhYkluZGV4PXtoYW5kbGVPcmRlciA/IDAgOiAtMX1cbiAgICAgIGFyaWEtc29ydD17b3JkZXJ9XG4gICAgICBhbGlnbj17YWxpZ259XG4gICAgICB3aWR0aD17d2lkdGh9XG4gICAgICBtYXhXaWR0aD17bWF4V2lkdGh9XG4gICAgICBtaW5XaWR0aD17bWluV2lkdGh9XG4gICAgPlxuICAgICAgPFN0eWxlZFRleHRcbiAgICAgICAgYXM9XCJkaXZcIlxuICAgICAgICB2YXJpYW50PVwiYm9keVNtYWxsXCJcbiAgICAgICAgY29sb3I9e29yZGVyICE9PSB1bmRlZmluZWQgPyAncHJpbWFyeScgOiAnbmV1dHJhbCd9XG4gICAgICA+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAge2luZm8gPyAoXG4gICAgICAgICAgPFRvb2x0aXAgdGV4dD17aW5mb30+XG4gICAgICAgICAgICA8SW5mb3JtYXRpb25PdXRsaW5lSWNvblxuICAgICAgICAgICAgICBzaXplPVwic21hbGxcIlxuICAgICAgICAgICAgICBwcm9taW5lbmNlPVwid2Vha1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L1Rvb2x0aXA+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgICB7b3JkZXJEaXJlY3Rpb24gIT09IHVuZGVmaW5lZCAmJiBpc09yZGVyZWQgIT09IHVuZGVmaW5lZCA/IChcbiAgICAgICAgICA8U29ydEljb24gYXJpYS1kaXNhYmxlZD17IW9uT3JkZXJ9IG9yZGVyPXtvcmRlcn0gLz5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICA8L1N0eWxlZFRleHQ+XG4gICAgPC9TdHlsZWRIZWFkZXJDZWxsPlxuICApXG59XG4iXX0= */"));
|
|
54
54
|
const HeaderCell = ({
|
|
55
55
|
children,
|
|
56
56
|
className,
|
|
@@ -79,7 +79,7 @@ const HeaderCell = ({
|
|
|
79
79
|
}
|
|
80
80
|
} : void 0, role: onOrder ? "button columnheader" : void 0, tabIndex: handleOrder ? 0 : -1, "aria-sort": order, align, width, maxWidth, minWidth, children: /* @__PURE__ */ jsxRuntime.jsxs(StyledText, { as: "div", variant: "bodySmall", color: order !== void 0 ? "primary" : "neutral", children: [
|
|
81
81
|
children,
|
|
82
|
-
info ? /* @__PURE__ */ jsxRuntime.jsx(index.Tooltip, { text: info, children: /* @__PURE__ */ jsxRuntime.jsx(Icon.
|
|
82
|
+
info ? /* @__PURE__ */ jsxRuntime.jsx(index.Tooltip, { text: info, children: /* @__PURE__ */ jsxRuntime.jsx(Icon.InformationOutlineIcon, { size: "small", prominence: "weak", sentiment: "neutral" }) }) : null,
|
|
83
83
|
orderDirection !== void 0 && isOrdered !== void 0 ? /* @__PURE__ */ jsxRuntime.jsx(SortIcon, { "aria-disabled": !onOrder, order }) : null
|
|
84
84
|
] }) });
|
|
85
85
|
};
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
"use client";
|
|
2
2
|
import { jsx, jsxs } from "@emotion/react/jsx-runtime";
|
|
3
3
|
import _styled from "@emotion/styled/base";
|
|
4
|
-
import {
|
|
4
|
+
import { InformationOutlineIcon, SortIcon as SortIcon$1, SouthShortIcon } from "@ultraviolet/icons";
|
|
5
5
|
import { Text } from "../Text/index.js";
|
|
6
6
|
import { Tooltip } from "../Tooltip/index.js";
|
|
7
7
|
const StyledSortIcon = /* @__PURE__ */ _styled(SouthShortIcon, process.env.NODE_ENV === "production" ? {
|
|
@@ -13,7 +13,7 @@ const StyledSortIcon = /* @__PURE__ */ _styled(SouthShortIcon, process.env.NODE_
|
|
|
13
13
|
label: "StyledSortIcon"
|
|
14
14
|
})("transform:", ({
|
|
15
15
|
order
|
|
16
|
-
}) => order === "ascending" ? "rotate(-180deg)" : "none", ";transition:transform 0.2s;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
16
|
+
}) => order === "ascending" ? "rotate(-180deg)" : "none", ";transition:transform 0.2s;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYmxlL0hlYWRlckNlbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWN5QyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9UYWJsZS9IZWFkZXJDZWxsLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7XG4gIEluZm9ybWF0aW9uT3V0bGluZUljb24sXG4gIFNvcnRJY29uIGFzIFNvcnRJY29uVVYsXG4gIFNvdXRoU2hvcnRJY29uLFxufSBmcm9tICdAdWx0cmF2aW9sZXQvaWNvbnMnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL1RleHQnXG5pbXBvcnQgeyBUb29sdGlwIH0gZnJvbSAnLi4vVG9vbHRpcCdcblxuY29uc3QgU3R5bGVkU29ydEljb24gPSBzdHlsZWQoU291dGhTaG9ydEljb24sIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT4gIVsnb3JkZXInXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgb3JkZXI6ICdhc2NlbmRpbmcnIHwgJ2Rlc2NlbmRpbmcnIH0+YFxuICAgIHRyYW5zZm9ybTogJHsoeyBvcmRlciB9KSA9PlxuICAgICAgb3JkZXIgPT09ICdhc2NlbmRpbmcnID8gJ3JvdGF0ZSgtMTgwZGVnKScgOiAnbm9uZSd9O1xuICAgIHRyYW5zaXRpb246IHRyYW5zZm9ybSAwLjJzO1xuYFxuXG5jb25zdCBTb3J0SWNvbiA9ICh7IG9yZGVyIH06IHsgb3JkZXI/OiAnYXNjZW5kaW5nJyB8ICdkZXNjZW5kaW5nJyB9KSA9PlxuICBvcmRlciA/IChcbiAgICA8U3R5bGVkU29ydEljb24gb3JkZXI9e29yZGVyfSBzZW50aW1lbnQ9XCJwcmltYXJ5XCIgLz5cbiAgKSA6IChcbiAgICA8U29ydEljb25VViBzZW50aW1lbnQ9XCJuZXV0cmFsXCIgLz5cbiAgKVxuXG50eXBlIFN0eWxlZEhlYWRlckNlbGxQcm9wcyA9IFBpY2s8XG4gIEhlYWRlckNlbGxQcm9wcyxcbiAgJ3dpZHRoJyB8ICdtYXhXaWR0aCcgfCAnbWluV2lkdGgnXG4+ICYge1xuICBhbGlnbj86ICdsZWZ0JyB8ICdjZW50ZXInIHwgJ3JpZ2h0J1xufVxuXG5jb25zdCBTdHlsZWRIZWFkZXJDZWxsID0gc3R5bGVkKCd0aCcsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT5cbiAgICAhWydhbGlnbicsICd3aWR0aCcsICdtYXhXaWR0aCcsICdtaW5XaWR0aCddLmluY2x1ZGVzKHByb3ApLFxufSk8U3R5bGVkSGVhZGVyQ2VsbFByb3BzPmBcbiR7KHsgd2lkdGgsIG1heFdpZHRoLCBtaW5XaWR0aCB9KSA9PiBgXG4gICAgJHt3aWR0aCA/IGB3aWR0aDogJHt3aWR0aH07YCA6ICcnfVxuICAgICR7bWF4V2lkdGggPyBgbWF4LXdpZHRoOiAke21heFdpZHRofTtgIDogJyd9XG4gICAgJHttaW5XaWR0aCA/IGBtaW4td2lkdGg6ICR7bWluV2lkdGh9O2AgOiAnJ31cbiAgYH1cbiAgZGlzcGxheTogdGFibGUtY2VsbDtcbiAgdmVydGljYWwtYWxpZ246IG1pZGRsZTtcbiAgdGV4dC1hbGlnbjogJHsoeyBhbGlnbiB9KSA9PiBhbGlnbn07XG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG5cbiAgJltyb2xlKj0nYnV0dG9uJ10ge1xuICAgIGN1cnNvcjogcG9pbnRlcjtcbiAgICB1c2VyLXNlbGVjdDogbm9uZTtcbiAgfVxuXG4gICY6Zmlyc3Qtb2YtdHlwZSB7XG4gICAgcGFkZGluZy1sZWZ0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycyJ119O1xuICB9XG5gXG5cbmNvbnN0IFN0eWxlZFRleHQgPSBzdHlsZWQoVGV4dClgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiByb3c7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGdhcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfTtcbmBcblxudHlwZSBIZWFkZXJDZWxsUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGlzT3JkZXJlZD86IGJvb2xlYW5cbiAgb3JkZXJEaXJlY3Rpb24/OiAnYXNjJyB8ICdkZXNjJyB8ICdub25lJ1xuICBvbk9yZGVyPzogKG5ld09yZGVyOiAnYXNjJyB8ICdkZXNjJykgPT4gdm9pZFxuICBpbmZvPzogc3RyaW5nXG4gIGFsaWduPzogJ2xlZnQnIHwgJ2NlbnRlcicgfCAncmlnaHQnXG4gIHdpZHRoPzogc3RyaW5nXG4gIG1heFdpZHRoPzogc3RyaW5nXG4gIG1pbldpZHRoPzogc3RyaW5nXG59XG5cbmV4cG9ydCBjb25zdCBIZWFkZXJDZWxsID0gKHtcbiAgY2hpbGRyZW4sXG4gIGNsYXNzTmFtZSxcbiAgaXNPcmRlcmVkLFxuICBvbk9yZGVyLFxuICBvcmRlckRpcmVjdGlvbixcbiAgaW5mbyxcbiAgYWxpZ24sXG4gIHdpZHRoLFxuICBtYXhXaWR0aCxcbiAgbWluV2lkdGgsXG59OiBIZWFkZXJDZWxsUHJvcHMpID0+IHtcbiAgbGV0IG9yZGVyOiB1bmRlZmluZWQgfCAnYXNjZW5kaW5nJyB8ICdkZXNjZW5kaW5nJ1xuICBpZiAoaXNPcmRlcmVkICYmIG9yZGVyRGlyZWN0aW9uID09PSAnYXNjJykge1xuICAgIG9yZGVyID0gJ2FzY2VuZGluZydcbiAgfSBlbHNlIGlmIChpc09yZGVyZWQgJiYgb3JkZXJEaXJlY3Rpb24gPT09ICdkZXNjJykge1xuICAgIG9yZGVyID0gJ2Rlc2NlbmRpbmcnXG4gIH1cblxuICBjb25zdCBoYW5kbGVPcmRlciA9IG9uT3JkZXJcbiAgICA/ICgpID0+IG9uT3JkZXIob3JkZXIgPT09ICdhc2NlbmRpbmcnID8gJ2Rlc2MnIDogJ2FzYycpXG4gICAgOiB1bmRlZmluZWRcblxuICByZXR1cm4gKFxuICAgIDxTdHlsZWRIZWFkZXJDZWxsXG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIG9uQ2xpY2s9e2hhbmRsZU9yZGVyfVxuICAgICAgb25LZXlEb3duPXtcbiAgICAgICAgaGFuZGxlT3JkZXJcbiAgICAgICAgICA/IGV2ZW50ID0+IHtcbiAgICAgICAgICAgICAgaWYgKGV2ZW50LmtleSA9PT0gJyAnIHx8IGV2ZW50LmtleSA9PT0gJ0VudGVyJykge1xuICAgICAgICAgICAgICAgIGhhbmRsZU9yZGVyKClcbiAgICAgICAgICAgICAgICBpZiAoZXZlbnQua2V5ID09PSAnICcpIHtcbiAgICAgICAgICAgICAgICAgIC8vIEBub3RlOiBpdCBhdm9pZCBzY3JvbGwgd2hlbiBwcmVzc2luZyBTcGFjZVxuICAgICAgICAgICAgICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKVxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgIDogdW5kZWZpbmVkXG4gICAgICB9XG4gICAgICByb2xlPXtvbk9yZGVyID8gJ2J1dHRvbiBjb2x1bW5oZWFkZXInIDogdW5kZWZpbmVkfVxuICAgICAgdGFiSW5kZXg9e2hhbmRsZU9yZGVyID8gMCA6IC0xfVxuICAgICAgYXJpYS1zb3J0PXtvcmRlcn1cbiAgICAgIGFsaWduPXthbGlnbn1cbiAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICAgIG1heFdpZHRoPXttYXhXaWR0aH1cbiAgICAgIG1pbldpZHRoPXttaW5XaWR0aH1cbiAgICA+XG4gICAgICA8U3R5bGVkVGV4dFxuICAgICAgICBhcz1cImRpdlwiXG4gICAgICAgIHZhcmlhbnQ9XCJib2R5U21hbGxcIlxuICAgICAgICBjb2xvcj17b3JkZXIgIT09IHVuZGVmaW5lZCA/ICdwcmltYXJ5JyA6ICduZXV0cmFsJ31cbiAgICAgID5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgICB7aW5mbyA/IChcbiAgICAgICAgICA8VG9vbHRpcCB0ZXh0PXtpbmZvfT5cbiAgICAgICAgICAgIDxJbmZvcm1hdGlvbk91dGxpbmVJY29uXG4gICAgICAgICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgICAgICAgIHByb21pbmVuY2U9XCJ3ZWFrXCJcbiAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvVG9vbHRpcD5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICAgIHtvcmRlckRpcmVjdGlvbiAhPT0gdW5kZWZpbmVkICYmIGlzT3JkZXJlZCAhPT0gdW5kZWZpbmVkID8gKFxuICAgICAgICAgIDxTb3J0SWNvbiBhcmlhLWRpc2FibGVkPXshb25PcmRlcn0gb3JkZXI9e29yZGVyfSAvPlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvU3R5bGVkVGV4dD5cbiAgICA8L1N0eWxlZEhlYWRlckNlbGw+XG4gIClcbn1cbiJdfQ== */"));
|
|
17
17
|
const SortIcon = ({
|
|
18
18
|
order
|
|
19
19
|
}) => order ? /* @__PURE__ */ jsx(StyledSortIcon, { order, sentiment: "primary" }) : /* @__PURE__ */ jsx(SortIcon$1, { sentiment: "neutral" });
|
|
@@ -38,7 +38,7 @@ const StyledHeaderCell = /* @__PURE__ */ _styled("th", process.env.NODE_ENV ===
|
|
|
38
38
|
theme
|
|
39
39
|
}) => theme.space["1"], ";&[role*='button']{cursor:pointer;user-select:none;}&:first-of-type{padding-left:", ({
|
|
40
40
|
theme
|
|
41
|
-
}) => theme.space["2"], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
41
|
+
}) => theme.space["2"], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYmxlL0hlYWRlckNlbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFDeUIiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvVGFibGUvSGVhZGVyQ2VsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQge1xuICBJbmZvcm1hdGlvbk91dGxpbmVJY29uLFxuICBTb3J0SWNvbiBhcyBTb3J0SWNvblVWLFxuICBTb3V0aFNob3J0SWNvbixcbn0gZnJvbSAnQHVsdHJhdmlvbGV0L2ljb25zJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuaW1wb3J0IHsgVG9vbHRpcCB9IGZyb20gJy4uL1Rvb2x0aXAnXG5cbmNvbnN0IFN0eWxlZFNvcnRJY29uID0gc3R5bGVkKFNvdXRoU2hvcnRJY29uLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ29yZGVyJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IG9yZGVyOiAnYXNjZW5kaW5nJyB8ICdkZXNjZW5kaW5nJyB9PmBcbiAgICB0cmFuc2Zvcm06ICR7KHsgb3JkZXIgfSkgPT5cbiAgICAgIG9yZGVyID09PSAnYXNjZW5kaW5nJyA/ICdyb3RhdGUoLTE4MGRlZyknIDogJ25vbmUnfTtcbiAgICB0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gMC4ycztcbmBcblxuY29uc3QgU29ydEljb24gPSAoeyBvcmRlciB9OiB7IG9yZGVyPzogJ2FzY2VuZGluZycgfCAnZGVzY2VuZGluZycgfSkgPT5cbiAgb3JkZXIgPyAoXG4gICAgPFN0eWxlZFNvcnRJY29uIG9yZGVyPXtvcmRlcn0gc2VudGltZW50PVwicHJpbWFyeVwiIC8+XG4gICkgOiAoXG4gICAgPFNvcnRJY29uVVYgc2VudGltZW50PVwibmV1dHJhbFwiIC8+XG4gIClcblxudHlwZSBTdHlsZWRIZWFkZXJDZWxsUHJvcHMgPSBQaWNrPFxuICBIZWFkZXJDZWxsUHJvcHMsXG4gICd3aWR0aCcgfCAnbWF4V2lkdGgnIHwgJ21pbldpZHRoJ1xuPiAmIHtcbiAgYWxpZ24/OiAnbGVmdCcgfCAnY2VudGVyJyB8ICdyaWdodCdcbn1cblxuY29uc3QgU3R5bGVkSGVhZGVyQ2VsbCA9IHN0eWxlZCgndGgnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+XG4gICAgIVsnYWxpZ24nLCAnd2lkdGgnLCAnbWF4V2lkdGgnLCAnbWluV2lkdGgnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPFN0eWxlZEhlYWRlckNlbGxQcm9wcz5gXG4keyh7IHdpZHRoLCBtYXhXaWR0aCwgbWluV2lkdGggfSkgPT4gYFxuICAgICR7d2lkdGggPyBgd2lkdGg6ICR7d2lkdGh9O2AgOiAnJ31cbiAgICAke21heFdpZHRoID8gYG1heC13aWR0aDogJHttYXhXaWR0aH07YCA6ICcnfVxuICAgICR7bWluV2lkdGggPyBgbWluLXdpZHRoOiAke21pbldpZHRofTtgIDogJyd9XG4gIGB9XG4gIGRpc3BsYXk6IHRhYmxlLWNlbGw7XG4gIHZlcnRpY2FsLWFsaWduOiBtaWRkbGU7XG4gIHRleHQtYWxpZ246ICR7KHsgYWxpZ24gfSkgPT4gYWxpZ259O1xuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuXG4gICZbcm9sZSo9J2J1dHRvbiddIHtcbiAgICBjdXJzb3I6IHBvaW50ZXI7XG4gICAgdXNlci1zZWxlY3Q6IG5vbmU7XG4gIH1cblxuICAmOmZpcnN0LW9mLXR5cGUge1xuICAgIHBhZGRpbmctbGVmdDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbiAgfVxuYFxuXG5jb25zdCBTdHlsZWRUZXh0ID0gc3R5bGVkKFRleHQpYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogcm93O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG5gXG5cbnR5cGUgSGVhZGVyQ2VsbFByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBpc09yZGVyZWQ/OiBib29sZWFuXG4gIG9yZGVyRGlyZWN0aW9uPzogJ2FzYycgfCAnZGVzYycgfCAnbm9uZSdcbiAgb25PcmRlcj86IChuZXdPcmRlcjogJ2FzYycgfCAnZGVzYycpID0+IHZvaWRcbiAgaW5mbz86IHN0cmluZ1xuICBhbGlnbj86ICdsZWZ0JyB8ICdjZW50ZXInIHwgJ3JpZ2h0J1xuICB3aWR0aD86IHN0cmluZ1xuICBtYXhXaWR0aD86IHN0cmluZ1xuICBtaW5XaWR0aD86IHN0cmluZ1xufVxuXG5leHBvcnQgY29uc3QgSGVhZGVyQ2VsbCA9ICh7XG4gIGNoaWxkcmVuLFxuICBjbGFzc05hbWUsXG4gIGlzT3JkZXJlZCxcbiAgb25PcmRlcixcbiAgb3JkZXJEaXJlY3Rpb24sXG4gIGluZm8sXG4gIGFsaWduLFxuICB3aWR0aCxcbiAgbWF4V2lkdGgsXG4gIG1pbldpZHRoLFxufTogSGVhZGVyQ2VsbFByb3BzKSA9PiB7XG4gIGxldCBvcmRlcjogdW5kZWZpbmVkIHwgJ2FzY2VuZGluZycgfCAnZGVzY2VuZGluZydcbiAgaWYgKGlzT3JkZXJlZCAmJiBvcmRlckRpcmVjdGlvbiA9PT0gJ2FzYycpIHtcbiAgICBvcmRlciA9ICdhc2NlbmRpbmcnXG4gIH0gZWxzZSBpZiAoaXNPcmRlcmVkICYmIG9yZGVyRGlyZWN0aW9uID09PSAnZGVzYycpIHtcbiAgICBvcmRlciA9ICdkZXNjZW5kaW5nJ1xuICB9XG5cbiAgY29uc3QgaGFuZGxlT3JkZXIgPSBvbk9yZGVyXG4gICAgPyAoKSA9PiBvbk9yZGVyKG9yZGVyID09PSAnYXNjZW5kaW5nJyA/ICdkZXNjJyA6ICdhc2MnKVxuICAgIDogdW5kZWZpbmVkXG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkSGVhZGVyQ2VsbFxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBvbkNsaWNrPXtoYW5kbGVPcmRlcn1cbiAgICAgIG9uS2V5RG93bj17XG4gICAgICAgIGhhbmRsZU9yZGVyXG4gICAgICAgICAgPyBldmVudCA9PiB7XG4gICAgICAgICAgICAgIGlmIChldmVudC5rZXkgPT09ICcgJyB8fCBldmVudC5rZXkgPT09ICdFbnRlcicpIHtcbiAgICAgICAgICAgICAgICBoYW5kbGVPcmRlcigpXG4gICAgICAgICAgICAgICAgaWYgKGV2ZW50LmtleSA9PT0gJyAnKSB7XG4gICAgICAgICAgICAgICAgICAvLyBAbm90ZTogaXQgYXZvaWQgc2Nyb2xsIHdoZW4gcHJlc3NpbmcgU3BhY2VcbiAgICAgICAgICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KClcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICA6IHVuZGVmaW5lZFxuICAgICAgfVxuICAgICAgcm9sZT17b25PcmRlciA/ICdidXR0b24gY29sdW1uaGVhZGVyJyA6IHVuZGVmaW5lZH1cbiAgICAgIHRhYkluZGV4PXtoYW5kbGVPcmRlciA/IDAgOiAtMX1cbiAgICAgIGFyaWEtc29ydD17b3JkZXJ9XG4gICAgICBhbGlnbj17YWxpZ259XG4gICAgICB3aWR0aD17d2lkdGh9XG4gICAgICBtYXhXaWR0aD17bWF4V2lkdGh9XG4gICAgICBtaW5XaWR0aD17bWluV2lkdGh9XG4gICAgPlxuICAgICAgPFN0eWxlZFRleHRcbiAgICAgICAgYXM9XCJkaXZcIlxuICAgICAgICB2YXJpYW50PVwiYm9keVNtYWxsXCJcbiAgICAgICAgY29sb3I9e29yZGVyICE9PSB1bmRlZmluZWQgPyAncHJpbWFyeScgOiAnbmV1dHJhbCd9XG4gICAgICA+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAge2luZm8gPyAoXG4gICAgICAgICAgPFRvb2x0aXAgdGV4dD17aW5mb30+XG4gICAgICAgICAgICA8SW5mb3JtYXRpb25PdXRsaW5lSWNvblxuICAgICAgICAgICAgICBzaXplPVwic21hbGxcIlxuICAgICAgICAgICAgICBwcm9taW5lbmNlPVwid2Vha1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L1Rvb2x0aXA+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgICB7b3JkZXJEaXJlY3Rpb24gIT09IHVuZGVmaW5lZCAmJiBpc09yZGVyZWQgIT09IHVuZGVmaW5lZCA/IChcbiAgICAgICAgICA8U29ydEljb24gYXJpYS1kaXNhYmxlZD17IW9uT3JkZXJ9IG9yZGVyPXtvcmRlcn0gLz5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICA8L1N0eWxlZFRleHQ+XG4gICAgPC9TdHlsZWRIZWFkZXJDZWxsPlxuICApXG59XG4iXX0= */"));
|
|
42
42
|
const StyledText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
|
|
43
43
|
target: "ev6jkq80"
|
|
44
44
|
} : {
|
|
@@ -46,7 +46,7 @@ const StyledText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "produ
|
|
|
46
46
|
label: "StyledText"
|
|
47
47
|
})("display:flex;flex-direction:row;align-items:center;gap:", ({
|
|
48
48
|
theme
|
|
49
|
-
}) => theme.space["1"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
49
|
+
}) => theme.space["1"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYmxlL0hlYWRlckNlbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBEK0IiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvVGFibGUvSGVhZGVyQ2VsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQge1xuICBJbmZvcm1hdGlvbk91dGxpbmVJY29uLFxuICBTb3J0SWNvbiBhcyBTb3J0SWNvblVWLFxuICBTb3V0aFNob3J0SWNvbixcbn0gZnJvbSAnQHVsdHJhdmlvbGV0L2ljb25zJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuaW1wb3J0IHsgVG9vbHRpcCB9IGZyb20gJy4uL1Rvb2x0aXAnXG5cbmNvbnN0IFN0eWxlZFNvcnRJY29uID0gc3R5bGVkKFNvdXRoU2hvcnRJY29uLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ29yZGVyJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IG9yZGVyOiAnYXNjZW5kaW5nJyB8ICdkZXNjZW5kaW5nJyB9PmBcbiAgICB0cmFuc2Zvcm06ICR7KHsgb3JkZXIgfSkgPT5cbiAgICAgIG9yZGVyID09PSAnYXNjZW5kaW5nJyA/ICdyb3RhdGUoLTE4MGRlZyknIDogJ25vbmUnfTtcbiAgICB0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gMC4ycztcbmBcblxuY29uc3QgU29ydEljb24gPSAoeyBvcmRlciB9OiB7IG9yZGVyPzogJ2FzY2VuZGluZycgfCAnZGVzY2VuZGluZycgfSkgPT5cbiAgb3JkZXIgPyAoXG4gICAgPFN0eWxlZFNvcnRJY29uIG9yZGVyPXtvcmRlcn0gc2VudGltZW50PVwicHJpbWFyeVwiIC8+XG4gICkgOiAoXG4gICAgPFNvcnRJY29uVVYgc2VudGltZW50PVwibmV1dHJhbFwiIC8+XG4gIClcblxudHlwZSBTdHlsZWRIZWFkZXJDZWxsUHJvcHMgPSBQaWNrPFxuICBIZWFkZXJDZWxsUHJvcHMsXG4gICd3aWR0aCcgfCAnbWF4V2lkdGgnIHwgJ21pbldpZHRoJ1xuPiAmIHtcbiAgYWxpZ24/OiAnbGVmdCcgfCAnY2VudGVyJyB8ICdyaWdodCdcbn1cblxuY29uc3QgU3R5bGVkSGVhZGVyQ2VsbCA9IHN0eWxlZCgndGgnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+XG4gICAgIVsnYWxpZ24nLCAnd2lkdGgnLCAnbWF4V2lkdGgnLCAnbWluV2lkdGgnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPFN0eWxlZEhlYWRlckNlbGxQcm9wcz5gXG4keyh7IHdpZHRoLCBtYXhXaWR0aCwgbWluV2lkdGggfSkgPT4gYFxuICAgICR7d2lkdGggPyBgd2lkdGg6ICR7d2lkdGh9O2AgOiAnJ31cbiAgICAke21heFdpZHRoID8gYG1heC13aWR0aDogJHttYXhXaWR0aH07YCA6ICcnfVxuICAgICR7bWluV2lkdGggPyBgbWluLXdpZHRoOiAke21pbldpZHRofTtgIDogJyd9XG4gIGB9XG4gIGRpc3BsYXk6IHRhYmxlLWNlbGw7XG4gIHZlcnRpY2FsLWFsaWduOiBtaWRkbGU7XG4gIHRleHQtYWxpZ246ICR7KHsgYWxpZ24gfSkgPT4gYWxpZ259O1xuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuXG4gICZbcm9sZSo9J2J1dHRvbiddIHtcbiAgICBjdXJzb3I6IHBvaW50ZXI7XG4gICAgdXNlci1zZWxlY3Q6IG5vbmU7XG4gIH1cblxuICAmOmZpcnN0LW9mLXR5cGUge1xuICAgIHBhZGRpbmctbGVmdDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbiAgfVxuYFxuXG5jb25zdCBTdHlsZWRUZXh0ID0gc3R5bGVkKFRleHQpYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogcm93O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG5gXG5cbnR5cGUgSGVhZGVyQ2VsbFByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBpc09yZGVyZWQ/OiBib29sZWFuXG4gIG9yZGVyRGlyZWN0aW9uPzogJ2FzYycgfCAnZGVzYycgfCAnbm9uZSdcbiAgb25PcmRlcj86IChuZXdPcmRlcjogJ2FzYycgfCAnZGVzYycpID0+IHZvaWRcbiAgaW5mbz86IHN0cmluZ1xuICBhbGlnbj86ICdsZWZ0JyB8ICdjZW50ZXInIHwgJ3JpZ2h0J1xuICB3aWR0aD86IHN0cmluZ1xuICBtYXhXaWR0aD86IHN0cmluZ1xuICBtaW5XaWR0aD86IHN0cmluZ1xufVxuXG5leHBvcnQgY29uc3QgSGVhZGVyQ2VsbCA9ICh7XG4gIGNoaWxkcmVuLFxuICBjbGFzc05hbWUsXG4gIGlzT3JkZXJlZCxcbiAgb25PcmRlcixcbiAgb3JkZXJEaXJlY3Rpb24sXG4gIGluZm8sXG4gIGFsaWduLFxuICB3aWR0aCxcbiAgbWF4V2lkdGgsXG4gIG1pbldpZHRoLFxufTogSGVhZGVyQ2VsbFByb3BzKSA9PiB7XG4gIGxldCBvcmRlcjogdW5kZWZpbmVkIHwgJ2FzY2VuZGluZycgfCAnZGVzY2VuZGluZydcbiAgaWYgKGlzT3JkZXJlZCAmJiBvcmRlckRpcmVjdGlvbiA9PT0gJ2FzYycpIHtcbiAgICBvcmRlciA9ICdhc2NlbmRpbmcnXG4gIH0gZWxzZSBpZiAoaXNPcmRlcmVkICYmIG9yZGVyRGlyZWN0aW9uID09PSAnZGVzYycpIHtcbiAgICBvcmRlciA9ICdkZXNjZW5kaW5nJ1xuICB9XG5cbiAgY29uc3QgaGFuZGxlT3JkZXIgPSBvbk9yZGVyXG4gICAgPyAoKSA9PiBvbk9yZGVyKG9yZGVyID09PSAnYXNjZW5kaW5nJyA/ICdkZXNjJyA6ICdhc2MnKVxuICAgIDogdW5kZWZpbmVkXG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkSGVhZGVyQ2VsbFxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBvbkNsaWNrPXtoYW5kbGVPcmRlcn1cbiAgICAgIG9uS2V5RG93bj17XG4gICAgICAgIGhhbmRsZU9yZGVyXG4gICAgICAgICAgPyBldmVudCA9PiB7XG4gICAgICAgICAgICAgIGlmIChldmVudC5rZXkgPT09ICcgJyB8fCBldmVudC5rZXkgPT09ICdFbnRlcicpIHtcbiAgICAgICAgICAgICAgICBoYW5kbGVPcmRlcigpXG4gICAgICAgICAgICAgICAgaWYgKGV2ZW50LmtleSA9PT0gJyAnKSB7XG4gICAgICAgICAgICAgICAgICAvLyBAbm90ZTogaXQgYXZvaWQgc2Nyb2xsIHdoZW4gcHJlc3NpbmcgU3BhY2VcbiAgICAgICAgICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KClcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICA6IHVuZGVmaW5lZFxuICAgICAgfVxuICAgICAgcm9sZT17b25PcmRlciA/ICdidXR0b24gY29sdW1uaGVhZGVyJyA6IHVuZGVmaW5lZH1cbiAgICAgIHRhYkluZGV4PXtoYW5kbGVPcmRlciA/IDAgOiAtMX1cbiAgICAgIGFyaWEtc29ydD17b3JkZXJ9XG4gICAgICBhbGlnbj17YWxpZ259XG4gICAgICB3aWR0aD17d2lkdGh9XG4gICAgICBtYXhXaWR0aD17bWF4V2lkdGh9XG4gICAgICBtaW5XaWR0aD17bWluV2lkdGh9XG4gICAgPlxuICAgICAgPFN0eWxlZFRleHRcbiAgICAgICAgYXM9XCJkaXZcIlxuICAgICAgICB2YXJpYW50PVwiYm9keVNtYWxsXCJcbiAgICAgICAgY29sb3I9e29yZGVyICE9PSB1bmRlZmluZWQgPyAncHJpbWFyeScgOiAnbmV1dHJhbCd9XG4gICAgICA+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAge2luZm8gPyAoXG4gICAgICAgICAgPFRvb2x0aXAgdGV4dD17aW5mb30+XG4gICAgICAgICAgICA8SW5mb3JtYXRpb25PdXRsaW5lSWNvblxuICAgICAgICAgICAgICBzaXplPVwic21hbGxcIlxuICAgICAgICAgICAgICBwcm9taW5lbmNlPVwid2Vha1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L1Rvb2x0aXA+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgICB7b3JkZXJEaXJlY3Rpb24gIT09IHVuZGVmaW5lZCAmJiBpc09yZGVyZWQgIT09IHVuZGVmaW5lZCA/IChcbiAgICAgICAgICA8U29ydEljb24gYXJpYS1kaXNhYmxlZD17IW9uT3JkZXJ9IG9yZGVyPXtvcmRlcn0gLz5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICA8L1N0eWxlZFRleHQ+XG4gICAgPC9TdHlsZWRIZWFkZXJDZWxsPlxuICApXG59XG4iXX0= */"));
|
|
50
50
|
const HeaderCell = ({
|
|
51
51
|
children,
|
|
52
52
|
className,
|
|
@@ -75,7 +75,7 @@ const HeaderCell = ({
|
|
|
75
75
|
}
|
|
76
76
|
} : void 0, role: onOrder ? "button columnheader" : void 0, tabIndex: handleOrder ? 0 : -1, "aria-sort": order, align, width, maxWidth, minWidth, children: /* @__PURE__ */ jsxs(StyledText, { as: "div", variant: "bodySmall", color: order !== void 0 ? "primary" : "neutral", children: [
|
|
77
77
|
children,
|
|
78
|
-
info ? /* @__PURE__ */ jsx(Tooltip, { text: info, children: /* @__PURE__ */ jsx(
|
|
78
|
+
info ? /* @__PURE__ */ jsx(Tooltip, { text: info, children: /* @__PURE__ */ jsx(InformationOutlineIcon, { size: "small", prominence: "weak", sentiment: "neutral" }) }) : null,
|
|
79
79
|
orderDirection !== void 0 && isOrdered !== void 0 ? /* @__PURE__ */ jsx(SortIcon, { "aria-disabled": !onOrder, order }) : null
|
|
80
80
|
] }) });
|
|
81
81
|
};
|
|
@@ -26,7 +26,7 @@ const StyledNumberInputWrapper = /* @__PURE__ */ _styled__default.default("div",
|
|
|
26
26
|
theme
|
|
27
27
|
}) => theme.space["2"], ";border-right:1px solid ", ({
|
|
28
28
|
theme
|
|
29
|
-
}) => theme.colors.neutral.border, ";width:100%;height:100%;" + (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/UnitInput/index.tsx"],"names":[],"mappings":"AAkB2C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/UnitInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { AlertCircleIcon, CheckCircleIcon } from '@ultraviolet/icons'\nimport type { ComponentProps, InputHTMLAttributes, ReactNode } from 'react'\nimport { useEffect, useId, useMemo, useState } from 'react'\nimport { Label } from '../Label'\nimport { SelectInput } from '../SelectInput'\nimport type { OptionType } from '../SelectInput/types'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst INPUT_SIZE_HEIGHT = {\n  small: '400', // sizing theme tokens key\n  medium: '500',\n  large: '600',\n} as const\n\nconst StyledNumberInputWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex-direction: row;\n  padding-right: ${({ theme }) => theme.space['2']};\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  width: 100%;\n  height: 100%;\n`\n\nconst StyledInput = styled.input`\n  flex: 1;\n  border: none;\n  outline: none;\n  height: 100%;\n  width: 100%;\n  padding-left: ${({ theme }) => theme.space['2']};\n  background: transparent;\n  color: ${({ theme }) => theme.colors.neutral.text};\n  &[data-size=\"small\"] {\n    padding-left: ${({ theme }) => theme.space['1']};\n  }\n\n  &[data-size=\"large\"] {\n    font-size: ${({ theme }) => theme.typography.body.fontSize};\n  }\n\n  &::placeholder {\n    color: ${({ theme }) => theme.colors.neutral.textWeak};\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n`\n\nconst UnitInputWrapper = styled(Stack)<{\n  'data-size': 'small' | 'medium' | 'large'\n  'data-success': boolean\n  'data-error': boolean\n  'data-disabled': boolean\n  'data-readonly': boolean\n}>`\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus,\n  :not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):active {\n    box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus-within  {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n    }\n\n  &:not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):not([data-readonly='true']):hover,\n  :not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):focus {\n    text-decoration: none;\n    border-color: ${({ theme }) => theme.colors.primary.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-readonly='true']:active {\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  &[data-size='small'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.small]};\n  }\n  &[data-size='medium'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.medium]};\n  }\n  &[data-size='large'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.large]};\n  }\n\n  &[data-success='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n  &[data-success='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n\n  &[data-error='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-error='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n`\n\nconst CustomSelectInput = styled(SelectInput)<{\n  width?: number | string\n  maxWidth?: number | string\n  'data-disabled': boolean\n}>`\n  #unit {\n    border: none;\n    background: transparent;\n  }\n\n  ${({ width }) =>\n    width && `width: ${typeof width === 'string' ? width : `${width}px`};`}\n  ${({ maxWidth }) =>\n    maxWidth &&\n    `max-width: ${typeof maxWidth === 'string' ? maxWidth : `${maxWidth}px`};`}\n\n  #unit:focus,\n  #unit:active {\n    box-shadow: none;\n  }\n`\ntype UnitInputValue = { inputValue: number; unit: string }\n\ntype UnitInputProps = {\n  className?: string\n  max?: number\n  min?: number\n  value?: UnitInputValue['inputValue']\n  unitValue?: UnitInputValue['unit']\n  onChange?: (value: UnitInputValue['inputValue']) => void\n  onChangeUnitValue?: (values: string) => void\n  options: OptionType[]\n  selectInputWidth?: number | string\n  size?: 'small' | 'medium' | 'large'\n  'data-testid'?: string\n  helper?: string\n  unitError?: string\n  width?: ComponentProps<typeof Stack>['width']\n  placeholderUnit?: string\n  error?: boolean | string\n  success?: boolean | string\n  label?: string\n  labelInformation?: ReactNode\n  step?: number | string\n  dropdownAlign?: ComponentProps<typeof SelectInput>['dropdownAlign']\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'id'\n  | 'placeholder'\n  | 'disabled'\n  | 'readOnly'\n  | 'required'\n  | 'autoFocus'\n  | 'onKeyDown'\n>\n\nexport const UnitInput = ({\n  id,\n  name = '',\n  max = Number.MAX_SAFE_INTEGER,\n  min = 0,\n  autoFocus = false,\n  size = 'large',\n  placeholder = '0',\n  placeholderUnit = 'Select item',\n  onChange,\n  onChangeUnitValue,\n  value,\n  unitValue,\n  selectInputWidth = '12.6rem',\n  disabled = false,\n  options,\n  className,\n  label,\n  step = 1,\n  error,\n  required,\n  helper,\n  unitError,\n  success,\n  'data-testid': dataTestId,\n  width,\n  labelInformation,\n  readOnly,\n  onFocus,\n  onBlur,\n  onKeyDown,\n  dropdownAlign,\n}: UnitInputProps) => {\n  const [val, setVal] = useState(value)\n  const localId = useId()\n  const sentiment = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    if (value !== undefined) {\n      setVal(value)\n    }\n  }, [value])\n\n  return (\n    <Stack gap={0.5}>\n      {label || labelInformation ? (\n        <Label\n          labelDescription={labelInformation}\n          required={required}\n          size={size}\n          htmlFor={id ?? localId}\n        >\n          {label}\n        </Label>\n      ) : null}\n      <UnitInputWrapper\n        direction=\"row\"\n        data-testid={dataTestId}\n        data-size={size}\n        width={width}\n        data-success={!!success}\n        data-error={!!error}\n        data-disabled={!!disabled}\n        data-readonly={!!readOnly}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n      >\n        <StyledNumberInputWrapper id=\"input-field\">\n          <StyledInput\n            type=\"number\"\n            aria-invalid={!!error}\n            autoFocus={autoFocus}\n            disabled={disabled}\n            name={`${name}-value`}\n            width={width}\n            id={id ? `${id}-value` : undefined}\n            value={val}\n            onChange={event => {\n              const numericValue = Number.parseInt(event.target.value, 10)\n              if (numericValue > max) {\n                setVal(max)\n                onChange?.(max)\n              } else if (numericValue < min) {\n                setVal(min)\n                onChange?.(min)\n              } else {\n                setVal(numericValue)\n                onChange?.(numericValue)\n              }\n            }}\n            placeholder={placeholder}\n            max={max}\n            readOnly={readOnly}\n            min={min}\n            step={step}\n            data-success={success}\n            data-error={error}\n            data-testid=\"unit-input\"\n            required={required}\n            className={className}\n            data-size={size}\n          />\n          {error ? <AlertCircleIcon sentiment=\"danger\" /> : null}\n          {success && !error ? <CheckCircleIcon sentiment=\"success\" /> : null}\n        </StyledNumberInputWrapper>\n        <CustomSelectInput\n          data-disabled={disabled}\n          id=\"unit\"\n          name={`${name}-unit`}\n          onChange={(newValue: string) => {\n            onChangeUnitValue?.(newValue)\n          }}\n          error={unitError}\n          value={unitValue}\n          options={options}\n          width={selectInputWidth}\n          searchable={false}\n          clearable={false}\n          placeholder={placeholderUnit}\n          disabled={disabled}\n          size={size}\n          multiselect={false}\n          readOnly={readOnly}\n          dropdownAlign={dropdownAlign}\n        />\n      </UnitInputWrapper>\n      {error || typeof success === 'string' || typeof helper === 'string' ? (\n        <Text\n          as=\"p\"\n          variant=\"caption\"\n          sentiment={sentiment}\n          disabled={disabled}\n          prominence={sentiment === 'neutral' ? 'weak' : 'default'}\n        >\n          {error || success || helper}\n        </Text>\n      ) : null}\n      {!error && !success && typeof helper !== 'string' && helper\n        ? helper\n        : null}\n    </Stack>\n  )\n}\n"]} */"));
|
|
29
|
+
}) => theme.colors.neutral.border, ";width:100%;height:100%;" + (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/UnitInput/index.tsx"],"names":[],"mappings":"AAkB2C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/UnitInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { AlertCircleIcon, CheckCircleIcon } from '@ultraviolet/icons'\nimport type { ComponentProps, InputHTMLAttributes, ReactNode } from 'react'\nimport { useEffect, useId, useMemo, useState } from 'react'\nimport { Label } from '../Label'\nimport { SelectInput } from '../SelectInput'\nimport type { OptionType } from '../SelectInput/types'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst INPUT_SIZE_HEIGHT = {\n  small: '400', // sizing theme tokens key\n  medium: '500',\n  large: '600',\n} as const\n\nconst StyledNumberInputWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex-direction: row;\n  padding-right: ${({ theme }) => theme.space['2']};\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  width: 100%;\n  height: 100%;\n`\n\nconst StyledInput = styled.input`\n  flex: 1;\n  border: none;\n  outline: none;\n  height: 100%;\n  width: 100%;\n  padding-left: ${({ theme }) => theme.space['2']};\n  background: transparent;\n  color: ${({ theme }) => theme.colors.neutral.text};\n  &[data-size=\"small\"] {\n    padding-left: ${({ theme }) => theme.space['1']};\n  }\n\n  &[data-size=\"large\"] {\n    font-size: ${({ theme }) => theme.typography.body.fontSize};\n  }\n\n  &::placeholder {\n    color: ${({ theme }) => theme.colors.neutral.textWeak};\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n`\n\nconst UnitInputWrapper = styled(Stack)<{\n  'data-size': 'small' | 'medium' | 'large'\n  'data-success': boolean\n  'data-error': boolean\n  'data-disabled': boolean\n  'data-readonly': boolean\n}>`\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus,\n  :not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):active {\n    box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus-within  {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n    }\n\n  &:not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):not([data-readonly='true']):hover,\n  :not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):focus {\n    text-decoration: none;\n    border-color: ${({ theme }) => theme.colors.primary.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-readonly='true']:active {\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  &[data-size='small'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.small]};\n  }\n  &[data-size='medium'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.medium]};\n  }\n  &[data-size='large'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.large]};\n  }\n\n  &[data-success='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n  &[data-success='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n\n  &[data-error='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-error='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n`\n\nconst CustomSelectInput = styled(SelectInput)<{\n  width?: number | string\n  maxWidth?: number | string\n  'data-disabled': boolean\n}>`\n  #unit {\n    border: none;\n    background: transparent;\n  }\n\n  ${({ width }) =>\n    width && `width: ${typeof width === 'string' ? width : `${width}px`};`}\n  ${({ maxWidth }) =>\n    maxWidth &&\n    `max-width: ${typeof maxWidth === 'string' ? maxWidth : `${maxWidth}px`};`}\n\n  #unit:focus,\n  #unit:active {\n    box-shadow: none;\n  }\n`\ntype UnitInputValue = { inputValue: number; unit: string }\n\ntype UnitInputProps = {\n  className?: string\n  max?: number\n  min?: number\n  value?: UnitInputValue['inputValue']\n  unitValue?: UnitInputValue['unit']\n  onChange?: (value: UnitInputValue['inputValue']) => void\n  onChangeUnitValue?: (values: string) => void\n  options: OptionType[]\n  selectInputWidth?: number | string\n  size?: 'small' | 'medium' | 'large'\n  'data-testid'?: string\n  helper?: string\n  unitError?: string\n  width?: ComponentProps<typeof Stack>['width']\n  placeholderUnit?: string\n  error?: boolean | string\n  success?: boolean | string\n  label?: string\n  labelInformation?: ReactNode\n  step?: number | string\n  dropdownAlign?: ComponentProps<typeof SelectInput>['dropdownAlign']\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'id'\n  | 'placeholder'\n  | 'disabled'\n  | 'readOnly'\n  | 'required'\n  | 'autoFocus'\n  | 'onKeyDown'\n>\n\nexport const UnitInput = ({\n  id,\n  name = '',\n  max = Number.MAX_SAFE_INTEGER,\n  min = 0,\n  autoFocus = false,\n  size = 'large',\n  placeholder = '0',\n  placeholderUnit = 'Select item',\n  onChange,\n  onChangeUnitValue,\n  value,\n  unitValue,\n  selectInputWidth = '12.6rem',\n  disabled = false,\n  options,\n  className,\n  label,\n  step = 1,\n  error,\n  required,\n  helper,\n  unitError,\n  success,\n  'data-testid': dataTestId,\n  width,\n  labelInformation,\n  readOnly,\n  onFocus,\n  onBlur,\n  onKeyDown,\n  dropdownAlign,\n}: UnitInputProps) => {\n  const [val, setVal] = useState(value)\n  const localId = useId()\n  const sentiment = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    if (value !== undefined) {\n      setVal(value)\n    }\n  }, [value])\n\n  return (\n    <Stack gap={0.5}>\n      {label || labelInformation ? (\n        <Label\n          labelDescription={labelInformation}\n          required={required}\n          size={size}\n          htmlFor={id ?? localId}\n        >\n          {label}\n        </Label>\n      ) : null}\n      <UnitInputWrapper\n        direction=\"row\"\n        data-testid={dataTestId}\n        data-size={size}\n        width={width}\n        data-success={!!success}\n        data-error={!!error}\n        data-disabled={!!disabled}\n        data-readonly={!!readOnly}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n      >\n        <StyledNumberInputWrapper id=\"input-field\">\n          <StyledInput\n            type=\"number\"\n            aria-invalid={!!error}\n            autoFocus={autoFocus}\n            disabled={disabled}\n            name={`${name}-value`}\n            width={width}\n            id={id ?? localId}\n            value={val}\n            onChange={event => {\n              const numericValue = Number.parseInt(event.target.value, 10)\n              if (numericValue > max) {\n                setVal(max)\n                onChange?.(max)\n              } else if (numericValue < min) {\n                setVal(min)\n                onChange?.(min)\n              } else {\n                setVal(numericValue)\n                onChange?.(numericValue)\n              }\n            }}\n            placeholder={placeholder}\n            max={max}\n            readOnly={readOnly}\n            min={min}\n            step={step}\n            data-success={success}\n            data-error={error}\n            data-testid=\"unit-input\"\n            required={required}\n            className={className}\n            data-size={size}\n          />\n          {error ? <AlertCircleIcon sentiment=\"danger\" /> : null}\n          {success && !error ? <CheckCircleIcon sentiment=\"success\" /> : null}\n        </StyledNumberInputWrapper>\n        <CustomSelectInput\n          data-disabled={disabled}\n          id=\"unit\"\n          name={`${name}-unit`}\n          onChange={(newValue: string) => {\n            onChangeUnitValue?.(newValue)\n          }}\n          error={unitError}\n          value={unitValue}\n          options={options}\n          width={selectInputWidth}\n          searchable={false}\n          clearable={false}\n          placeholder={placeholderUnit}\n          disabled={disabled}\n          size={size}\n          multiselect={false}\n          readOnly={readOnly}\n          dropdownAlign={dropdownAlign}\n        />\n      </UnitInputWrapper>\n      {error || typeof success === 'string' || typeof helper === 'string' ? (\n        <Text\n          as=\"p\"\n          variant=\"caption\"\n          sentiment={sentiment}\n          disabled={disabled}\n          prominence={sentiment === 'neutral' ? 'weak' : 'default'}\n        >\n          {error || success || helper}\n        </Text>\n      ) : null}\n      {!error && !success && typeof helper !== 'string' && helper\n        ? helper\n        : null}\n    </Stack>\n  )\n}\n"]} */"));
|
|
30
30
|
const StyledInput = /* @__PURE__ */ _styled__default.default("input", process.env.NODE_ENV === "production" ? {
|
|
31
31
|
target: "ex81jph2"
|
|
32
32
|
} : {
|
|
@@ -44,7 +44,7 @@ const StyledInput = /* @__PURE__ */ _styled__default.default("input", process.en
|
|
|
44
44
|
theme
|
|
45
45
|
}) => theme.colors.neutral.textWeak, ";}&:disabled{cursor:not-allowed;&::placeholder{color:", ({
|
|
46
46
|
theme
|
|
47
|
-
}) => theme.colors.neutral.textWeakDisabled, ";}}" + (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/UnitInput/index.tsx"],"names":[],"mappings":"AA4BgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/UnitInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { AlertCircleIcon, CheckCircleIcon } from '@ultraviolet/icons'\nimport type { ComponentProps, InputHTMLAttributes, ReactNode } from 'react'\nimport { useEffect, useId, useMemo, useState } from 'react'\nimport { Label } from '../Label'\nimport { SelectInput } from '../SelectInput'\nimport type { OptionType } from '../SelectInput/types'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst INPUT_SIZE_HEIGHT = {\n  small: '400', // sizing theme tokens key\n  medium: '500',\n  large: '600',\n} as const\n\nconst StyledNumberInputWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex-direction: row;\n  padding-right: ${({ theme }) => theme.space['2']};\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  width: 100%;\n  height: 100%;\n`\n\nconst StyledInput = styled.input`\n  flex: 1;\n  border: none;\n  outline: none;\n  height: 100%;\n  width: 100%;\n  padding-left: ${({ theme }) => theme.space['2']};\n  background: transparent;\n  color: ${({ theme }) => theme.colors.neutral.text};\n  &[data-size=\"small\"] {\n    padding-left: ${({ theme }) => theme.space['1']};\n  }\n\n  &[data-size=\"large\"] {\n    font-size: ${({ theme }) => theme.typography.body.fontSize};\n  }\n\n  &::placeholder {\n    color: ${({ theme }) => theme.colors.neutral.textWeak};\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n`\n\nconst UnitInputWrapper = styled(Stack)<{\n  'data-size': 'small' | 'medium' | 'large'\n  'data-success': boolean\n  'data-error': boolean\n  'data-disabled': boolean\n  'data-readonly': boolean\n}>`\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus,\n  :not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):active {\n    box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus-within  {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n    }\n\n  &:not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):not([data-readonly='true']):hover,\n  :not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):focus {\n    text-decoration: none;\n    border-color: ${({ theme }) => theme.colors.primary.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-readonly='true']:active {\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  &[data-size='small'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.small]};\n  }\n  &[data-size='medium'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.medium]};\n  }\n  &[data-size='large'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.large]};\n  }\n\n  &[data-success='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n  &[data-success='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n\n  &[data-error='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-error='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n`\n\nconst CustomSelectInput = styled(SelectInput)<{\n  width?: number | string\n  maxWidth?: number | string\n  'data-disabled': boolean\n}>`\n  #unit {\n    border: none;\n    background: transparent;\n  }\n\n  ${({ width }) =>\n    width && `width: ${typeof width === 'string' ? width : `${width}px`};`}\n  ${({ maxWidth }) =>\n    maxWidth &&\n    `max-width: ${typeof maxWidth === 'string' ? maxWidth : `${maxWidth}px`};`}\n\n  #unit:focus,\n  #unit:active {\n    box-shadow: none;\n  }\n`\ntype UnitInputValue = { inputValue: number; unit: string }\n\ntype UnitInputProps = {\n  className?: string\n  max?: number\n  min?: number\n  value?: UnitInputValue['inputValue']\n  unitValue?: UnitInputValue['unit']\n  onChange?: (value: UnitInputValue['inputValue']) => void\n  onChangeUnitValue?: (values: string) => void\n  options: OptionType[]\n  selectInputWidth?: number | string\n  size?: 'small' | 'medium' | 'large'\n  'data-testid'?: string\n  helper?: string\n  unitError?: string\n  width?: ComponentProps<typeof Stack>['width']\n  placeholderUnit?: string\n  error?: boolean | string\n  success?: boolean | string\n  label?: string\n  labelInformation?: ReactNode\n  step?: number | string\n  dropdownAlign?: ComponentProps<typeof SelectInput>['dropdownAlign']\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'id'\n  | 'placeholder'\n  | 'disabled'\n  | 'readOnly'\n  | 'required'\n  | 'autoFocus'\n  | 'onKeyDown'\n>\n\nexport const UnitInput = ({\n  id,\n  name = '',\n  max = Number.MAX_SAFE_INTEGER,\n  min = 0,\n  autoFocus = false,\n  size = 'large',\n  placeholder = '0',\n  placeholderUnit = 'Select item',\n  onChange,\n  onChangeUnitValue,\n  value,\n  unitValue,\n  selectInputWidth = '12.6rem',\n  disabled = false,\n  options,\n  className,\n  label,\n  step = 1,\n  error,\n  required,\n  helper,\n  unitError,\n  success,\n  'data-testid': dataTestId,\n  width,\n  labelInformation,\n  readOnly,\n  onFocus,\n  onBlur,\n  onKeyDown,\n  dropdownAlign,\n}: UnitInputProps) => {\n  const [val, setVal] = useState(value)\n  const localId = useId()\n  const sentiment = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    if (value !== undefined) {\n      setVal(value)\n    }\n  }, [value])\n\n  return (\n    <Stack gap={0.5}>\n      {label || labelInformation ? (\n        <Label\n          labelDescription={labelInformation}\n          required={required}\n          size={size}\n          htmlFor={id ?? localId}\n        >\n          {label}\n        </Label>\n      ) : null}\n      <UnitInputWrapper\n        direction=\"row\"\n        data-testid={dataTestId}\n        data-size={size}\n        width={width}\n        data-success={!!success}\n        data-error={!!error}\n        data-disabled={!!disabled}\n        data-readonly={!!readOnly}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n      >\n        <StyledNumberInputWrapper id=\"input-field\">\n          <StyledInput\n            type=\"number\"\n            aria-invalid={!!error}\n            autoFocus={autoFocus}\n            disabled={disabled}\n            name={`${name}-value`}\n            width={width}\n            id={id ? `${id}-value` : undefined}\n            value={val}\n            onChange={event => {\n              const numericValue = Number.parseInt(event.target.value, 10)\n              if (numericValue > max) {\n                setVal(max)\n                onChange?.(max)\n              } else if (numericValue < min) {\n                setVal(min)\n                onChange?.(min)\n              } else {\n                setVal(numericValue)\n                onChange?.(numericValue)\n              }\n            }}\n            placeholder={placeholder}\n            max={max}\n            readOnly={readOnly}\n            min={min}\n            step={step}\n            data-success={success}\n            data-error={error}\n            data-testid=\"unit-input\"\n            required={required}\n            className={className}\n            data-size={size}\n          />\n          {error ? <AlertCircleIcon sentiment=\"danger\" /> : null}\n          {success && !error ? <CheckCircleIcon sentiment=\"success\" /> : null}\n        </StyledNumberInputWrapper>\n        <CustomSelectInput\n          data-disabled={disabled}\n          id=\"unit\"\n          name={`${name}-unit`}\n          onChange={(newValue: string) => {\n            onChangeUnitValue?.(newValue)\n          }}\n          error={unitError}\n          value={unitValue}\n          options={options}\n          width={selectInputWidth}\n          searchable={false}\n          clearable={false}\n          placeholder={placeholderUnit}\n          disabled={disabled}\n          size={size}\n          multiselect={false}\n          readOnly={readOnly}\n          dropdownAlign={dropdownAlign}\n        />\n      </UnitInputWrapper>\n      {error || typeof success === 'string' || typeof helper === 'string' ? (\n        <Text\n          as=\"p\"\n          variant=\"caption\"\n          sentiment={sentiment}\n          disabled={disabled}\n          prominence={sentiment === 'neutral' ? 'weak' : 'default'}\n        >\n          {error || success || helper}\n        </Text>\n      ) : null}\n      {!error && !success && typeof helper !== 'string' && helper\n        ? helper\n        : null}\n    </Stack>\n  )\n}\n"]} */"));
|
|
47
|
+
}) => theme.colors.neutral.textWeakDisabled, ";}}" + (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/UnitInput/index.tsx"],"names":[],"mappings":"AA4BgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/UnitInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { AlertCircleIcon, CheckCircleIcon } from '@ultraviolet/icons'\nimport type { ComponentProps, InputHTMLAttributes, ReactNode } from 'react'\nimport { useEffect, useId, useMemo, useState } from 'react'\nimport { Label } from '../Label'\nimport { SelectInput } from '../SelectInput'\nimport type { OptionType } from '../SelectInput/types'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst INPUT_SIZE_HEIGHT = {\n  small: '400', // sizing theme tokens key\n  medium: '500',\n  large: '600',\n} as const\n\nconst StyledNumberInputWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex-direction: row;\n  padding-right: ${({ theme }) => theme.space['2']};\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  width: 100%;\n  height: 100%;\n`\n\nconst StyledInput = styled.input`\n  flex: 1;\n  border: none;\n  outline: none;\n  height: 100%;\n  width: 100%;\n  padding-left: ${({ theme }) => theme.space['2']};\n  background: transparent;\n  color: ${({ theme }) => theme.colors.neutral.text};\n  &[data-size=\"small\"] {\n    padding-left: ${({ theme }) => theme.space['1']};\n  }\n\n  &[data-size=\"large\"] {\n    font-size: ${({ theme }) => theme.typography.body.fontSize};\n  }\n\n  &::placeholder {\n    color: ${({ theme }) => theme.colors.neutral.textWeak};\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n`\n\nconst UnitInputWrapper = styled(Stack)<{\n  'data-size': 'small' | 'medium' | 'large'\n  'data-success': boolean\n  'data-error': boolean\n  'data-disabled': boolean\n  'data-readonly': boolean\n}>`\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus,\n  :not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):active {\n    box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus-within  {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n    }\n\n  &:not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):not([data-readonly='true']):hover,\n  :not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):focus {\n    text-decoration: none;\n    border-color: ${({ theme }) => theme.colors.primary.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-readonly='true']:active {\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  &[data-size='small'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.small]};\n  }\n  &[data-size='medium'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.medium]};\n  }\n  &[data-size='large'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.large]};\n  }\n\n  &[data-success='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n  &[data-success='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n\n  &[data-error='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-error='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n`\n\nconst CustomSelectInput = styled(SelectInput)<{\n  width?: number | string\n  maxWidth?: number | string\n  'data-disabled': boolean\n}>`\n  #unit {\n    border: none;\n    background: transparent;\n  }\n\n  ${({ width }) =>\n    width && `width: ${typeof width === 'string' ? width : `${width}px`};`}\n  ${({ maxWidth }) =>\n    maxWidth &&\n    `max-width: ${typeof maxWidth === 'string' ? maxWidth : `${maxWidth}px`};`}\n\n  #unit:focus,\n  #unit:active {\n    box-shadow: none;\n  }\n`\ntype UnitInputValue = { inputValue: number; unit: string }\n\ntype UnitInputProps = {\n  className?: string\n  max?: number\n  min?: number\n  value?: UnitInputValue['inputValue']\n  unitValue?: UnitInputValue['unit']\n  onChange?: (value: UnitInputValue['inputValue']) => void\n  onChangeUnitValue?: (values: string) => void\n  options: OptionType[]\n  selectInputWidth?: number | string\n  size?: 'small' | 'medium' | 'large'\n  'data-testid'?: string\n  helper?: string\n  unitError?: string\n  width?: ComponentProps<typeof Stack>['width']\n  placeholderUnit?: string\n  error?: boolean | string\n  success?: boolean | string\n  label?: string\n  labelInformation?: ReactNode\n  step?: number | string\n  dropdownAlign?: ComponentProps<typeof SelectInput>['dropdownAlign']\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'id'\n  | 'placeholder'\n  | 'disabled'\n  | 'readOnly'\n  | 'required'\n  | 'autoFocus'\n  | 'onKeyDown'\n>\n\nexport const UnitInput = ({\n  id,\n  name = '',\n  max = Number.MAX_SAFE_INTEGER,\n  min = 0,\n  autoFocus = false,\n  size = 'large',\n  placeholder = '0',\n  placeholderUnit = 'Select item',\n  onChange,\n  onChangeUnitValue,\n  value,\n  unitValue,\n  selectInputWidth = '12.6rem',\n  disabled = false,\n  options,\n  className,\n  label,\n  step = 1,\n  error,\n  required,\n  helper,\n  unitError,\n  success,\n  'data-testid': dataTestId,\n  width,\n  labelInformation,\n  readOnly,\n  onFocus,\n  onBlur,\n  onKeyDown,\n  dropdownAlign,\n}: UnitInputProps) => {\n  const [val, setVal] = useState(value)\n  const localId = useId()\n  const sentiment = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    if (value !== undefined) {\n      setVal(value)\n    }\n  }, [value])\n\n  return (\n    <Stack gap={0.5}>\n      {label || labelInformation ? (\n        <Label\n          labelDescription={labelInformation}\n          required={required}\n          size={size}\n          htmlFor={id ?? localId}\n        >\n          {label}\n        </Label>\n      ) : null}\n      <UnitInputWrapper\n        direction=\"row\"\n        data-testid={dataTestId}\n        data-size={size}\n        width={width}\n        data-success={!!success}\n        data-error={!!error}\n        data-disabled={!!disabled}\n        data-readonly={!!readOnly}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n      >\n        <StyledNumberInputWrapper id=\"input-field\">\n          <StyledInput\n            type=\"number\"\n            aria-invalid={!!error}\n            autoFocus={autoFocus}\n            disabled={disabled}\n            name={`${name}-value`}\n            width={width}\n            id={id ?? localId}\n            value={val}\n            onChange={event => {\n              const numericValue = Number.parseInt(event.target.value, 10)\n              if (numericValue > max) {\n                setVal(max)\n                onChange?.(max)\n              } else if (numericValue < min) {\n                setVal(min)\n                onChange?.(min)\n              } else {\n                setVal(numericValue)\n                onChange?.(numericValue)\n              }\n            }}\n            placeholder={placeholder}\n            max={max}\n            readOnly={readOnly}\n            min={min}\n            step={step}\n            data-success={success}\n            data-error={error}\n            data-testid=\"unit-input\"\n            required={required}\n            className={className}\n            data-size={size}\n          />\n          {error ? <AlertCircleIcon sentiment=\"danger\" /> : null}\n          {success && !error ? <CheckCircleIcon sentiment=\"success\" /> : null}\n        </StyledNumberInputWrapper>\n        <CustomSelectInput\n          data-disabled={disabled}\n          id=\"unit\"\n          name={`${name}-unit`}\n          onChange={(newValue: string) => {\n            onChangeUnitValue?.(newValue)\n          }}\n          error={unitError}\n          value={unitValue}\n          options={options}\n          width={selectInputWidth}\n          searchable={false}\n          clearable={false}\n          placeholder={placeholderUnit}\n          disabled={disabled}\n          size={size}\n          multiselect={false}\n          readOnly={readOnly}\n          dropdownAlign={dropdownAlign}\n        />\n      </UnitInputWrapper>\n      {error || typeof success === 'string' || typeof helper === 'string' ? (\n        <Text\n          as=\"p\"\n          variant=\"caption\"\n          sentiment={sentiment}\n          disabled={disabled}\n          prominence={sentiment === 'neutral' ? 'weak' : 'default'}\n        >\n          {error || success || helper}\n        </Text>\n      ) : null}\n      {!error && !success && typeof helper !== 'string' && helper\n        ? helper\n        : null}\n    </Stack>\n  )\n}\n"]} */"));
|
|
48
48
|
const UnitInputWrapper = /* @__PURE__ */ _styled__default.default(index.Stack, process.env.NODE_ENV === "production" ? {
|
|
49
49
|
target: "ex81jph1"
|
|
50
50
|
} : {
|
|
@@ -110,7 +110,7 @@ const UnitInputWrapper = /* @__PURE__ */ _styled__default.default(index.Stack, p
|
|
|
110
110
|
theme
|
|
111
111
|
}) => theme.colors.neutral.borderDisabled, ";cursor:not-allowed;&>", StyledNumberInputWrapper, "{border-right-color:", ({
|
|
112
112
|
theme
|
|
113
|
-
}) => theme.colors.neutral.borderDisabled, ";}}" + (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/UnitInput/index.tsx"],"names":[],"mappings":"AAgEE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/UnitInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { AlertCircleIcon, CheckCircleIcon } from '@ultraviolet/icons'\nimport type { ComponentProps, InputHTMLAttributes, ReactNode } from 'react'\nimport { useEffect, useId, useMemo, useState } from 'react'\nimport { Label } from '../Label'\nimport { SelectInput } from '../SelectInput'\nimport type { OptionType } from '../SelectInput/types'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst INPUT_SIZE_HEIGHT = {\n  small: '400', // sizing theme tokens key\n  medium: '500',\n  large: '600',\n} as const\n\nconst StyledNumberInputWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex-direction: row;\n  padding-right: ${({ theme }) => theme.space['2']};\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  width: 100%;\n  height: 100%;\n`\n\nconst StyledInput = styled.input`\n  flex: 1;\n  border: none;\n  outline: none;\n  height: 100%;\n  width: 100%;\n  padding-left: ${({ theme }) => theme.space['2']};\n  background: transparent;\n  color: ${({ theme }) => theme.colors.neutral.text};\n  &[data-size=\"small\"] {\n    padding-left: ${({ theme }) => theme.space['1']};\n  }\n\n  &[data-size=\"large\"] {\n    font-size: ${({ theme }) => theme.typography.body.fontSize};\n  }\n\n  &::placeholder {\n    color: ${({ theme }) => theme.colors.neutral.textWeak};\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n`\n\nconst UnitInputWrapper = styled(Stack)<{\n  'data-size': 'small' | 'medium' | 'large'\n  'data-success': boolean\n  'data-error': boolean\n  'data-disabled': boolean\n  'data-readonly': boolean\n}>`\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus,\n  :not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):active {\n    box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus-within  {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n    }\n\n  &:not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):not([data-readonly='true']):hover,\n  :not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):focus {\n    text-decoration: none;\n    border-color: ${({ theme }) => theme.colors.primary.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-readonly='true']:active {\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  &[data-size='small'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.small]};\n  }\n  &[data-size='medium'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.medium]};\n  }\n  &[data-size='large'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.large]};\n  }\n\n  &[data-success='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n  &[data-success='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n\n  &[data-error='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-error='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n`\n\nconst CustomSelectInput = styled(SelectInput)<{\n  width?: number | string\n  maxWidth?: number | string\n  'data-disabled': boolean\n}>`\n  #unit {\n    border: none;\n    background: transparent;\n  }\n\n  ${({ width }) =>\n    width && `width: ${typeof width === 'string' ? width : `${width}px`};`}\n  ${({ maxWidth }) =>\n    maxWidth &&\n    `max-width: ${typeof maxWidth === 'string' ? maxWidth : `${maxWidth}px`};`}\n\n  #unit:focus,\n  #unit:active {\n    box-shadow: none;\n  }\n`\ntype UnitInputValue = { inputValue: number; unit: string }\n\ntype UnitInputProps = {\n  className?: string\n  max?: number\n  min?: number\n  value?: UnitInputValue['inputValue']\n  unitValue?: UnitInputValue['unit']\n  onChange?: (value: UnitInputValue['inputValue']) => void\n  onChangeUnitValue?: (values: string) => void\n  options: OptionType[]\n  selectInputWidth?: number | string\n  size?: 'small' | 'medium' | 'large'\n  'data-testid'?: string\n  helper?: string\n  unitError?: string\n  width?: ComponentProps<typeof Stack>['width']\n  placeholderUnit?: string\n  error?: boolean | string\n  success?: boolean | string\n  label?: string\n  labelInformation?: ReactNode\n  step?: number | string\n  dropdownAlign?: ComponentProps<typeof SelectInput>['dropdownAlign']\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'id'\n  | 'placeholder'\n  | 'disabled'\n  | 'readOnly'\n  | 'required'\n  | 'autoFocus'\n  | 'onKeyDown'\n>\n\nexport const UnitInput = ({\n  id,\n  name = '',\n  max = Number.MAX_SAFE_INTEGER,\n  min = 0,\n  autoFocus = false,\n  size = 'large',\n  placeholder = '0',\n  placeholderUnit = 'Select item',\n  onChange,\n  onChangeUnitValue,\n  value,\n  unitValue,\n  selectInputWidth = '12.6rem',\n  disabled = false,\n  options,\n  className,\n  label,\n  step = 1,\n  error,\n  required,\n  helper,\n  unitError,\n  success,\n  'data-testid': dataTestId,\n  width,\n  labelInformation,\n  readOnly,\n  onFocus,\n  onBlur,\n  onKeyDown,\n  dropdownAlign,\n}: UnitInputProps) => {\n  const [val, setVal] = useState(value)\n  const localId = useId()\n  const sentiment = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    if (value !== undefined) {\n      setVal(value)\n    }\n  }, [value])\n\n  return (\n    <Stack gap={0.5}>\n      {label || labelInformation ? (\n        <Label\n          labelDescription={labelInformation}\n          required={required}\n          size={size}\n          htmlFor={id ?? localId}\n        >\n          {label}\n        </Label>\n      ) : null}\n      <UnitInputWrapper\n        direction=\"row\"\n        data-testid={dataTestId}\n        data-size={size}\n        width={width}\n        data-success={!!success}\n        data-error={!!error}\n        data-disabled={!!disabled}\n        data-readonly={!!readOnly}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n      >\n        <StyledNumberInputWrapper id=\"input-field\">\n          <StyledInput\n            type=\"number\"\n            aria-invalid={!!error}\n            autoFocus={autoFocus}\n            disabled={disabled}\n            name={`${name}-value`}\n            width={width}\n            id={id ? `${id}-value` : undefined}\n            value={val}\n            onChange={event => {\n              const numericValue = Number.parseInt(event.target.value, 10)\n              if (numericValue > max) {\n                setVal(max)\n                onChange?.(max)\n              } else if (numericValue < min) {\n                setVal(min)\n                onChange?.(min)\n              } else {\n                setVal(numericValue)\n                onChange?.(numericValue)\n              }\n            }}\n            placeholder={placeholder}\n            max={max}\n            readOnly={readOnly}\n            min={min}\n            step={step}\n            data-success={success}\n            data-error={error}\n            data-testid=\"unit-input\"\n            required={required}\n            className={className}\n            data-size={size}\n          />\n          {error ? <AlertCircleIcon sentiment=\"danger\" /> : null}\n          {success && !error ? <CheckCircleIcon sentiment=\"success\" /> : null}\n        </StyledNumberInputWrapper>\n        <CustomSelectInput\n          data-disabled={disabled}\n          id=\"unit\"\n          name={`${name}-unit`}\n          onChange={(newValue: string) => {\n            onChangeUnitValue?.(newValue)\n          }}\n          error={unitError}\n          value={unitValue}\n          options={options}\n          width={selectInputWidth}\n          searchable={false}\n          clearable={false}\n          placeholder={placeholderUnit}\n          disabled={disabled}\n          size={size}\n          multiselect={false}\n          readOnly={readOnly}\n          dropdownAlign={dropdownAlign}\n        />\n      </UnitInputWrapper>\n      {error || typeof success === 'string' || typeof helper === 'string' ? (\n        <Text\n          as=\"p\"\n          variant=\"caption\"\n          sentiment={sentiment}\n          disabled={disabled}\n          prominence={sentiment === 'neutral' ? 'weak' : 'default'}\n        >\n          {error || success || helper}\n        </Text>\n      ) : null}\n      {!error && !success && typeof helper !== 'string' && helper\n        ? helper\n        : null}\n    </Stack>\n  )\n}\n"]} */"));
|
|
113
|
+
}) => theme.colors.neutral.borderDisabled, ";}}" + (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/UnitInput/index.tsx"],"names":[],"mappings":"AAgEE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/UnitInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { AlertCircleIcon, CheckCircleIcon } from '@ultraviolet/icons'\nimport type { ComponentProps, InputHTMLAttributes, ReactNode } from 'react'\nimport { useEffect, useId, useMemo, useState } from 'react'\nimport { Label } from '../Label'\nimport { SelectInput } from '../SelectInput'\nimport type { OptionType } from '../SelectInput/types'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst INPUT_SIZE_HEIGHT = {\n  small: '400', // sizing theme tokens key\n  medium: '500',\n  large: '600',\n} as const\n\nconst StyledNumberInputWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex-direction: row;\n  padding-right: ${({ theme }) => theme.space['2']};\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  width: 100%;\n  height: 100%;\n`\n\nconst StyledInput = styled.input`\n  flex: 1;\n  border: none;\n  outline: none;\n  height: 100%;\n  width: 100%;\n  padding-left: ${({ theme }) => theme.space['2']};\n  background: transparent;\n  color: ${({ theme }) => theme.colors.neutral.text};\n  &[data-size=\"small\"] {\n    padding-left: ${({ theme }) => theme.space['1']};\n  }\n\n  &[data-size=\"large\"] {\n    font-size: ${({ theme }) => theme.typography.body.fontSize};\n  }\n\n  &::placeholder {\n    color: ${({ theme }) => theme.colors.neutral.textWeak};\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n`\n\nconst UnitInputWrapper = styled(Stack)<{\n  'data-size': 'small' | 'medium' | 'large'\n  'data-success': boolean\n  'data-error': boolean\n  'data-disabled': boolean\n  'data-readonly': boolean\n}>`\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus,\n  :not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):active {\n    box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus-within  {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n    }\n\n  &:not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):not([data-readonly='true']):hover,\n  :not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):focus {\n    text-decoration: none;\n    border-color: ${({ theme }) => theme.colors.primary.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-readonly='true']:active {\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  &[data-size='small'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.small]};\n  }\n  &[data-size='medium'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.medium]};\n  }\n  &[data-size='large'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.large]};\n  }\n\n  &[data-success='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n  &[data-success='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n\n  &[data-error='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-error='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n`\n\nconst CustomSelectInput = styled(SelectInput)<{\n  width?: number | string\n  maxWidth?: number | string\n  'data-disabled': boolean\n}>`\n  #unit {\n    border: none;\n    background: transparent;\n  }\n\n  ${({ width }) =>\n    width && `width: ${typeof width === 'string' ? width : `${width}px`};`}\n  ${({ maxWidth }) =>\n    maxWidth &&\n    `max-width: ${typeof maxWidth === 'string' ? maxWidth : `${maxWidth}px`};`}\n\n  #unit:focus,\n  #unit:active {\n    box-shadow: none;\n  }\n`\ntype UnitInputValue = { inputValue: number; unit: string }\n\ntype UnitInputProps = {\n  className?: string\n  max?: number\n  min?: number\n  value?: UnitInputValue['inputValue']\n  unitValue?: UnitInputValue['unit']\n  onChange?: (value: UnitInputValue['inputValue']) => void\n  onChangeUnitValue?: (values: string) => void\n  options: OptionType[]\n  selectInputWidth?: number | string\n  size?: 'small' | 'medium' | 'large'\n  'data-testid'?: string\n  helper?: string\n  unitError?: string\n  width?: ComponentProps<typeof Stack>['width']\n  placeholderUnit?: string\n  error?: boolean | string\n  success?: boolean | string\n  label?: string\n  labelInformation?: ReactNode\n  step?: number | string\n  dropdownAlign?: ComponentProps<typeof SelectInput>['dropdownAlign']\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'id'\n  | 'placeholder'\n  | 'disabled'\n  | 'readOnly'\n  | 'required'\n  | 'autoFocus'\n  | 'onKeyDown'\n>\n\nexport const UnitInput = ({\n  id,\n  name = '',\n  max = Number.MAX_SAFE_INTEGER,\n  min = 0,\n  autoFocus = false,\n  size = 'large',\n  placeholder = '0',\n  placeholderUnit = 'Select item',\n  onChange,\n  onChangeUnitValue,\n  value,\n  unitValue,\n  selectInputWidth = '12.6rem',\n  disabled = false,\n  options,\n  className,\n  label,\n  step = 1,\n  error,\n  required,\n  helper,\n  unitError,\n  success,\n  'data-testid': dataTestId,\n  width,\n  labelInformation,\n  readOnly,\n  onFocus,\n  onBlur,\n  onKeyDown,\n  dropdownAlign,\n}: UnitInputProps) => {\n  const [val, setVal] = useState(value)\n  const localId = useId()\n  const sentiment = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    if (value !== undefined) {\n      setVal(value)\n    }\n  }, [value])\n\n  return (\n    <Stack gap={0.5}>\n      {label || labelInformation ? (\n        <Label\n          labelDescription={labelInformation}\n          required={required}\n          size={size}\n          htmlFor={id ?? localId}\n        >\n          {label}\n        </Label>\n      ) : null}\n      <UnitInputWrapper\n        direction=\"row\"\n        data-testid={dataTestId}\n        data-size={size}\n        width={width}\n        data-success={!!success}\n        data-error={!!error}\n        data-disabled={!!disabled}\n        data-readonly={!!readOnly}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n      >\n        <StyledNumberInputWrapper id=\"input-field\">\n          <StyledInput\n            type=\"number\"\n            aria-invalid={!!error}\n            autoFocus={autoFocus}\n            disabled={disabled}\n            name={`${name}-value`}\n            width={width}\n            id={id ?? localId}\n            value={val}\n            onChange={event => {\n              const numericValue = Number.parseInt(event.target.value, 10)\n              if (numericValue > max) {\n                setVal(max)\n                onChange?.(max)\n              } else if (numericValue < min) {\n                setVal(min)\n                onChange?.(min)\n              } else {\n                setVal(numericValue)\n                onChange?.(numericValue)\n              }\n            }}\n            placeholder={placeholder}\n            max={max}\n            readOnly={readOnly}\n            min={min}\n            step={step}\n            data-success={success}\n            data-error={error}\n            data-testid=\"unit-input\"\n            required={required}\n            className={className}\n            data-size={size}\n          />\n          {error ? <AlertCircleIcon sentiment=\"danger\" /> : null}\n          {success && !error ? <CheckCircleIcon sentiment=\"success\" /> : null}\n        </StyledNumberInputWrapper>\n        <CustomSelectInput\n          data-disabled={disabled}\n          id=\"unit\"\n          name={`${name}-unit`}\n          onChange={(newValue: string) => {\n            onChangeUnitValue?.(newValue)\n          }}\n          error={unitError}\n          value={unitValue}\n          options={options}\n          width={selectInputWidth}\n          searchable={false}\n          clearable={false}\n          placeholder={placeholderUnit}\n          disabled={disabled}\n          size={size}\n          multiselect={false}\n          readOnly={readOnly}\n          dropdownAlign={dropdownAlign}\n        />\n      </UnitInputWrapper>\n      {error || typeof success === 'string' || typeof helper === 'string' ? (\n        <Text\n          as=\"p\"\n          variant=\"caption\"\n          sentiment={sentiment}\n          disabled={disabled}\n          prominence={sentiment === 'neutral' ? 'weak' : 'default'}\n        >\n          {error || success || helper}\n        </Text>\n      ) : null}\n      {!error && !success && typeof helper !== 'string' && helper\n        ? helper\n        : null}\n    </Stack>\n  )\n}\n"]} */"));
|
|
114
114
|
const CustomSelectInput = /* @__PURE__ */ _styled__default.default(index$3.SelectInput, process.env.NODE_ENV === "production" ? {
|
|
115
115
|
target: "ex81jph0"
|
|
116
116
|
} : {
|
|
@@ -120,7 +120,7 @@ const CustomSelectInput = /* @__PURE__ */ _styled__default.default(index$3.Selec
|
|
|
120
120
|
width
|
|
121
121
|
}) => width && `width: ${typeof width === "string" ? width : `${width}px`};`, " ", ({
|
|
122
122
|
maxWidth
|
|
123
|
-
}) => maxWidth && `max-width: ${typeof maxWidth === "string" ? maxWidth : `${maxWidth}px`};`, " #unit:focus,#unit:active{box-shadow:none;}" + (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/UnitInput/index.tsx"],"names":[],"mappings":"AAkLE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/UnitInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { AlertCircleIcon, CheckCircleIcon } from '@ultraviolet/icons'\nimport type { ComponentProps, InputHTMLAttributes, ReactNode } from 'react'\nimport { useEffect, useId, useMemo, useState } from 'react'\nimport { Label } from '../Label'\nimport { SelectInput } from '../SelectInput'\nimport type { OptionType } from '../SelectInput/types'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst INPUT_SIZE_HEIGHT = {\n  small: '400', // sizing theme tokens key\n  medium: '500',\n  large: '600',\n} as const\n\nconst StyledNumberInputWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex-direction: row;\n  padding-right: ${({ theme }) => theme.space['2']};\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  width: 100%;\n  height: 100%;\n`\n\nconst StyledInput = styled.input`\n  flex: 1;\n  border: none;\n  outline: none;\n  height: 100%;\n  width: 100%;\n  padding-left: ${({ theme }) => theme.space['2']};\n  background: transparent;\n  color: ${({ theme }) => theme.colors.neutral.text};\n  &[data-size=\"small\"] {\n    padding-left: ${({ theme }) => theme.space['1']};\n  }\n\n  &[data-size=\"large\"] {\n    font-size: ${({ theme }) => theme.typography.body.fontSize};\n  }\n\n  &::placeholder {\n    color: ${({ theme }) => theme.colors.neutral.textWeak};\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n`\n\nconst UnitInputWrapper = styled(Stack)<{\n  'data-size': 'small' | 'medium' | 'large'\n  'data-success': boolean\n  'data-error': boolean\n  'data-disabled': boolean\n  'data-readonly': boolean\n}>`\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus,\n  :not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):active {\n    box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus-within  {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n    }\n\n  &:not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):not([data-readonly='true']):hover,\n  :not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):focus {\n    text-decoration: none;\n    border-color: ${({ theme }) => theme.colors.primary.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-readonly='true']:active {\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  &[data-size='small'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.small]};\n  }\n  &[data-size='medium'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.medium]};\n  }\n  &[data-size='large'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.large]};\n  }\n\n  &[data-success='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n  &[data-success='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n\n  &[data-error='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-error='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n`\n\nconst CustomSelectInput = styled(SelectInput)<{\n  width?: number | string\n  maxWidth?: number | string\n  'data-disabled': boolean\n}>`\n  #unit {\n    border: none;\n    background: transparent;\n  }\n\n  ${({ width }) =>\n    width && `width: ${typeof width === 'string' ? width : `${width}px`};`}\n  ${({ maxWidth }) =>\n    maxWidth &&\n    `max-width: ${typeof maxWidth === 'string' ? maxWidth : `${maxWidth}px`};`}\n\n  #unit:focus,\n  #unit:active {\n    box-shadow: none;\n  }\n`\ntype UnitInputValue = { inputValue: number; unit: string }\n\ntype UnitInputProps = {\n  className?: string\n  max?: number\n  min?: number\n  value?: UnitInputValue['inputValue']\n  unitValue?: UnitInputValue['unit']\n  onChange?: (value: UnitInputValue['inputValue']) => void\n  onChangeUnitValue?: (values: string) => void\n  options: OptionType[]\n  selectInputWidth?: number | string\n  size?: 'small' | 'medium' | 'large'\n  'data-testid'?: string\n  helper?: string\n  unitError?: string\n  width?: ComponentProps<typeof Stack>['width']\n  placeholderUnit?: string\n  error?: boolean | string\n  success?: boolean | string\n  label?: string\n  labelInformation?: ReactNode\n  step?: number | string\n  dropdownAlign?: ComponentProps<typeof SelectInput>['dropdownAlign']\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'id'\n  | 'placeholder'\n  | 'disabled'\n  | 'readOnly'\n  | 'required'\n  | 'autoFocus'\n  | 'onKeyDown'\n>\n\nexport const UnitInput = ({\n  id,\n  name = '',\n  max = Number.MAX_SAFE_INTEGER,\n  min = 0,\n  autoFocus = false,\n  size = 'large',\n  placeholder = '0',\n  placeholderUnit = 'Select item',\n  onChange,\n  onChangeUnitValue,\n  value,\n  unitValue,\n  selectInputWidth = '12.6rem',\n  disabled = false,\n  options,\n  className,\n  label,\n  step = 1,\n  error,\n  required,\n  helper,\n  unitError,\n  success,\n  'data-testid': dataTestId,\n  width,\n  labelInformation,\n  readOnly,\n  onFocus,\n  onBlur,\n  onKeyDown,\n  dropdownAlign,\n}: UnitInputProps) => {\n  const [val, setVal] = useState(value)\n  const localId = useId()\n  const sentiment = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    if (value !== undefined) {\n      setVal(value)\n    }\n  }, [value])\n\n  return (\n    <Stack gap={0.5}>\n      {label || labelInformation ? (\n        <Label\n          labelDescription={labelInformation}\n          required={required}\n          size={size}\n          htmlFor={id ?? localId}\n        >\n          {label}\n        </Label>\n      ) : null}\n      <UnitInputWrapper\n        direction=\"row\"\n        data-testid={dataTestId}\n        data-size={size}\n        width={width}\n        data-success={!!success}\n        data-error={!!error}\n        data-disabled={!!disabled}\n        data-readonly={!!readOnly}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n      >\n        <StyledNumberInputWrapper id=\"input-field\">\n          <StyledInput\n            type=\"number\"\n            aria-invalid={!!error}\n            autoFocus={autoFocus}\n            disabled={disabled}\n            name={`${name}-value`}\n            width={width}\n            id={id ? `${id}-value` : undefined}\n            value={val}\n            onChange={event => {\n              const numericValue = Number.parseInt(event.target.value, 10)\n              if (numericValue > max) {\n                setVal(max)\n                onChange?.(max)\n              } else if (numericValue < min) {\n                setVal(min)\n                onChange?.(min)\n              } else {\n                setVal(numericValue)\n                onChange?.(numericValue)\n              }\n            }}\n            placeholder={placeholder}\n            max={max}\n            readOnly={readOnly}\n            min={min}\n            step={step}\n            data-success={success}\n            data-error={error}\n            data-testid=\"unit-input\"\n            required={required}\n            className={className}\n            data-size={size}\n          />\n          {error ? <AlertCircleIcon sentiment=\"danger\" /> : null}\n          {success && !error ? <CheckCircleIcon sentiment=\"success\" /> : null}\n        </StyledNumberInputWrapper>\n        <CustomSelectInput\n          data-disabled={disabled}\n          id=\"unit\"\n          name={`${name}-unit`}\n          onChange={(newValue: string) => {\n            onChangeUnitValue?.(newValue)\n          }}\n          error={unitError}\n          value={unitValue}\n          options={options}\n          width={selectInputWidth}\n          searchable={false}\n          clearable={false}\n          placeholder={placeholderUnit}\n          disabled={disabled}\n          size={size}\n          multiselect={false}\n          readOnly={readOnly}\n          dropdownAlign={dropdownAlign}\n        />\n      </UnitInputWrapper>\n      {error || typeof success === 'string' || typeof helper === 'string' ? (\n        <Text\n          as=\"p\"\n          variant=\"caption\"\n          sentiment={sentiment}\n          disabled={disabled}\n          prominence={sentiment === 'neutral' ? 'weak' : 'default'}\n        >\n          {error || success || helper}\n        </Text>\n      ) : null}\n      {!error && !success && typeof helper !== 'string' && helper\n        ? helper\n        : null}\n    </Stack>\n  )\n}\n"]} */"));
|
|
123
|
+
}) => maxWidth && `max-width: ${typeof maxWidth === "string" ? maxWidth : `${maxWidth}px`};`, " #unit:focus,#unit:active{box-shadow:none;}" + (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/UnitInput/index.tsx"],"names":[],"mappings":"AAkLE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/UnitInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { AlertCircleIcon, CheckCircleIcon } from '@ultraviolet/icons'\nimport type { ComponentProps, InputHTMLAttributes, ReactNode } from 'react'\nimport { useEffect, useId, useMemo, useState } from 'react'\nimport { Label } from '../Label'\nimport { SelectInput } from '../SelectInput'\nimport type { OptionType } from '../SelectInput/types'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst INPUT_SIZE_HEIGHT = {\n  small: '400', // sizing theme tokens key\n  medium: '500',\n  large: '600',\n} as const\n\nconst StyledNumberInputWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex-direction: row;\n  padding-right: ${({ theme }) => theme.space['2']};\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  width: 100%;\n  height: 100%;\n`\n\nconst StyledInput = styled.input`\n  flex: 1;\n  border: none;\n  outline: none;\n  height: 100%;\n  width: 100%;\n  padding-left: ${({ theme }) => theme.space['2']};\n  background: transparent;\n  color: ${({ theme }) => theme.colors.neutral.text};\n  &[data-size=\"small\"] {\n    padding-left: ${({ theme }) => theme.space['1']};\n  }\n\n  &[data-size=\"large\"] {\n    font-size: ${({ theme }) => theme.typography.body.fontSize};\n  }\n\n  &::placeholder {\n    color: ${({ theme }) => theme.colors.neutral.textWeak};\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n`\n\nconst UnitInputWrapper = styled(Stack)<{\n  'data-size': 'small' | 'medium' | 'large'\n  'data-success': boolean\n  'data-error': boolean\n  'data-disabled': boolean\n  'data-readonly': boolean\n}>`\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus,\n  :not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):active {\n    box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus-within  {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n    }\n\n  &:not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):not([data-readonly='true']):hover,\n  :not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):focus {\n    text-decoration: none;\n    border-color: ${({ theme }) => theme.colors.primary.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-readonly='true']:active {\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  &[data-size='small'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.small]};\n  }\n  &[data-size='medium'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.medium]};\n  }\n  &[data-size='large'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.large]};\n  }\n\n  &[data-success='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n  &[data-success='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n\n  &[data-error='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-error='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n`\n\nconst CustomSelectInput = styled(SelectInput)<{\n  width?: number | string\n  maxWidth?: number | string\n  'data-disabled': boolean\n}>`\n  #unit {\n    border: none;\n    background: transparent;\n  }\n\n  ${({ width }) =>\n    width && `width: ${typeof width === 'string' ? width : `${width}px`};`}\n  ${({ maxWidth }) =>\n    maxWidth &&\n    `max-width: ${typeof maxWidth === 'string' ? maxWidth : `${maxWidth}px`};`}\n\n  #unit:focus,\n  #unit:active {\n    box-shadow: none;\n  }\n`\ntype UnitInputValue = { inputValue: number; unit: string }\n\ntype UnitInputProps = {\n  className?: string\n  max?: number\n  min?: number\n  value?: UnitInputValue['inputValue']\n  unitValue?: UnitInputValue['unit']\n  onChange?: (value: UnitInputValue['inputValue']) => void\n  onChangeUnitValue?: (values: string) => void\n  options: OptionType[]\n  selectInputWidth?: number | string\n  size?: 'small' | 'medium' | 'large'\n  'data-testid'?: string\n  helper?: string\n  unitError?: string\n  width?: ComponentProps<typeof Stack>['width']\n  placeholderUnit?: string\n  error?: boolean | string\n  success?: boolean | string\n  label?: string\n  labelInformation?: ReactNode\n  step?: number | string\n  dropdownAlign?: ComponentProps<typeof SelectInput>['dropdownAlign']\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'id'\n  | 'placeholder'\n  | 'disabled'\n  | 'readOnly'\n  | 'required'\n  | 'autoFocus'\n  | 'onKeyDown'\n>\n\nexport const UnitInput = ({\n  id,\n  name = '',\n  max = Number.MAX_SAFE_INTEGER,\n  min = 0,\n  autoFocus = false,\n  size = 'large',\n  placeholder = '0',\n  placeholderUnit = 'Select item',\n  onChange,\n  onChangeUnitValue,\n  value,\n  unitValue,\n  selectInputWidth = '12.6rem',\n  disabled = false,\n  options,\n  className,\n  label,\n  step = 1,\n  error,\n  required,\n  helper,\n  unitError,\n  success,\n  'data-testid': dataTestId,\n  width,\n  labelInformation,\n  readOnly,\n  onFocus,\n  onBlur,\n  onKeyDown,\n  dropdownAlign,\n}: UnitInputProps) => {\n  const [val, setVal] = useState(value)\n  const localId = useId()\n  const sentiment = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    if (value !== undefined) {\n      setVal(value)\n    }\n  }, [value])\n\n  return (\n    <Stack gap={0.5}>\n      {label || labelInformation ? (\n        <Label\n          labelDescription={labelInformation}\n          required={required}\n          size={size}\n          htmlFor={id ?? localId}\n        >\n          {label}\n        </Label>\n      ) : null}\n      <UnitInputWrapper\n        direction=\"row\"\n        data-testid={dataTestId}\n        data-size={size}\n        width={width}\n        data-success={!!success}\n        data-error={!!error}\n        data-disabled={!!disabled}\n        data-readonly={!!readOnly}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n      >\n        <StyledNumberInputWrapper id=\"input-field\">\n          <StyledInput\n            type=\"number\"\n            aria-invalid={!!error}\n            autoFocus={autoFocus}\n            disabled={disabled}\n            name={`${name}-value`}\n            width={width}\n            id={id ?? localId}\n            value={val}\n            onChange={event => {\n              const numericValue = Number.parseInt(event.target.value, 10)\n              if (numericValue > max) {\n                setVal(max)\n                onChange?.(max)\n              } else if (numericValue < min) {\n                setVal(min)\n                onChange?.(min)\n              } else {\n                setVal(numericValue)\n                onChange?.(numericValue)\n              }\n            }}\n            placeholder={placeholder}\n            max={max}\n            readOnly={readOnly}\n            min={min}\n            step={step}\n            data-success={success}\n            data-error={error}\n            data-testid=\"unit-input\"\n            required={required}\n            className={className}\n            data-size={size}\n          />\n          {error ? <AlertCircleIcon sentiment=\"danger\" /> : null}\n          {success && !error ? <CheckCircleIcon sentiment=\"success\" /> : null}\n        </StyledNumberInputWrapper>\n        <CustomSelectInput\n          data-disabled={disabled}\n          id=\"unit\"\n          name={`${name}-unit`}\n          onChange={(newValue: string) => {\n            onChangeUnitValue?.(newValue)\n          }}\n          error={unitError}\n          value={unitValue}\n          options={options}\n          width={selectInputWidth}\n          searchable={false}\n          clearable={false}\n          placeholder={placeholderUnit}\n          disabled={disabled}\n          size={size}\n          multiselect={false}\n          readOnly={readOnly}\n          dropdownAlign={dropdownAlign}\n        />\n      </UnitInputWrapper>\n      {error || typeof success === 'string' || typeof helper === 'string' ? (\n        <Text\n          as=\"p\"\n          variant=\"caption\"\n          sentiment={sentiment}\n          disabled={disabled}\n          prominence={sentiment === 'neutral' ? 'weak' : 'default'}\n        >\n          {error || success || helper}\n        </Text>\n      ) : null}\n      {!error && !success && typeof helper !== 'string' && helper\n        ? helper\n        : null}\n    </Stack>\n  )\n}\n"]} */"));
|
|
124
124
|
const UnitInput = ({
|
|
125
125
|
id,
|
|
126
126
|
name = "",
|
|
@@ -174,7 +174,7 @@ const UnitInput = ({
|
|
|
174
174
|
label || labelInformation ? /* @__PURE__ */ jsxRuntime.jsx(index$1.Label, { labelDescription: labelInformation, required, size, htmlFor: id ?? localId, children: label }) : null,
|
|
175
175
|
/* @__PURE__ */ jsxRuntime.jsxs(UnitInputWrapper, { direction: "row", "data-testid": dataTestId, "data-size": size, width, "data-success": !!success, "data-error": !!error, "data-disabled": !!disabled, "data-readonly": !!readOnly, onFocus, onBlur, onKeyDown, children: [
|
|
176
176
|
/* @__PURE__ */ jsxRuntime.jsxs(StyledNumberInputWrapper, { id: "input-field", children: [
|
|
177
|
-
/* @__PURE__ */ jsxRuntime.jsx(StyledInput, { type: "number", "aria-invalid": !!error, autoFocus, disabled, name: `${name}-value`, width, id: id
|
|
177
|
+
/* @__PURE__ */ jsxRuntime.jsx(StyledInput, { type: "number", "aria-invalid": !!error, autoFocus, disabled, name: `${name}-value`, width, id: id ?? localId, value: val, onChange: (event) => {
|
|
178
178
|
const numericValue = Number.parseInt(event.target.value, 10);
|
|
179
179
|
if (numericValue > max) {
|
|
180
180
|
setVal(max);
|
|
@@ -22,7 +22,7 @@ const StyledNumberInputWrapper = /* @__PURE__ */ _styled("div", process.env.NODE
|
|
|
22
22
|
theme
|
|
23
23
|
}) => theme.space["2"], ";border-right:1px solid ", ({
|
|
24
24
|
theme
|
|
25
|
-
}) => theme.colors.neutral.border, ";width:100%;height:100%;" + (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/UnitInput/index.tsx"],"names":[],"mappings":"AAkB2C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/UnitInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { AlertCircleIcon, CheckCircleIcon } from '@ultraviolet/icons'\nimport type { ComponentProps, InputHTMLAttributes, ReactNode } from 'react'\nimport { useEffect, useId, useMemo, useState } from 'react'\nimport { Label } from '../Label'\nimport { SelectInput } from '../SelectInput'\nimport type { OptionType } from '../SelectInput/types'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst INPUT_SIZE_HEIGHT = {\n  small: '400', // sizing theme tokens key\n  medium: '500',\n  large: '600',\n} as const\n\nconst StyledNumberInputWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex-direction: row;\n  padding-right: ${({ theme }) => theme.space['2']};\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  width: 100%;\n  height: 100%;\n`\n\nconst StyledInput = styled.input`\n  flex: 1;\n  border: none;\n  outline: none;\n  height: 100%;\n  width: 100%;\n  padding-left: ${({ theme }) => theme.space['2']};\n  background: transparent;\n  color: ${({ theme }) => theme.colors.neutral.text};\n  &[data-size=\"small\"] {\n    padding-left: ${({ theme }) => theme.space['1']};\n  }\n\n  &[data-size=\"large\"] {\n    font-size: ${({ theme }) => theme.typography.body.fontSize};\n  }\n\n  &::placeholder {\n    color: ${({ theme }) => theme.colors.neutral.textWeak};\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n`\n\nconst UnitInputWrapper = styled(Stack)<{\n  'data-size': 'small' | 'medium' | 'large'\n  'data-success': boolean\n  'data-error': boolean\n  'data-disabled': boolean\n  'data-readonly': boolean\n}>`\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus,\n  :not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):active {\n    box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus-within  {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n    }\n\n  &:not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):not([data-readonly='true']):hover,\n  :not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):focus {\n    text-decoration: none;\n    border-color: ${({ theme }) => theme.colors.primary.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-readonly='true']:active {\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  &[data-size='small'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.small]};\n  }\n  &[data-size='medium'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.medium]};\n  }\n  &[data-size='large'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.large]};\n  }\n\n  &[data-success='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n  &[data-success='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n\n  &[data-error='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-error='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n`\n\nconst CustomSelectInput = styled(SelectInput)<{\n  width?: number | string\n  maxWidth?: number | string\n  'data-disabled': boolean\n}>`\n  #unit {\n    border: none;\n    background: transparent;\n  }\n\n  ${({ width }) =>\n    width && `width: ${typeof width === 'string' ? width : `${width}px`};`}\n  ${({ maxWidth }) =>\n    maxWidth &&\n    `max-width: ${typeof maxWidth === 'string' ? maxWidth : `${maxWidth}px`};`}\n\n  #unit:focus,\n  #unit:active {\n    box-shadow: none;\n  }\n`\ntype UnitInputValue = { inputValue: number; unit: string }\n\ntype UnitInputProps = {\n  className?: string\n  max?: number\n  min?: number\n  value?: UnitInputValue['inputValue']\n  unitValue?: UnitInputValue['unit']\n  onChange?: (value: UnitInputValue['inputValue']) => void\n  onChangeUnitValue?: (values: string) => void\n  options: OptionType[]\n  selectInputWidth?: number | string\n  size?: 'small' | 'medium' | 'large'\n  'data-testid'?: string\n  helper?: string\n  unitError?: string\n  width?: ComponentProps<typeof Stack>['width']\n  placeholderUnit?: string\n  error?: boolean | string\n  success?: boolean | string\n  label?: string\n  labelInformation?: ReactNode\n  step?: number | string\n  dropdownAlign?: ComponentProps<typeof SelectInput>['dropdownAlign']\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'id'\n  | 'placeholder'\n  | 'disabled'\n  | 'readOnly'\n  | 'required'\n  | 'autoFocus'\n  | 'onKeyDown'\n>\n\nexport const UnitInput = ({\n  id,\n  name = '',\n  max = Number.MAX_SAFE_INTEGER,\n  min = 0,\n  autoFocus = false,\n  size = 'large',\n  placeholder = '0',\n  placeholderUnit = 'Select item',\n  onChange,\n  onChangeUnitValue,\n  value,\n  unitValue,\n  selectInputWidth = '12.6rem',\n  disabled = false,\n  options,\n  className,\n  label,\n  step = 1,\n  error,\n  required,\n  helper,\n  unitError,\n  success,\n  'data-testid': dataTestId,\n  width,\n  labelInformation,\n  readOnly,\n  onFocus,\n  onBlur,\n  onKeyDown,\n  dropdownAlign,\n}: UnitInputProps) => {\n  const [val, setVal] = useState(value)\n  const localId = useId()\n  const sentiment = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    if (value !== undefined) {\n      setVal(value)\n    }\n  }, [value])\n\n  return (\n    <Stack gap={0.5}>\n      {label || labelInformation ? (\n        <Label\n          labelDescription={labelInformation}\n          required={required}\n          size={size}\n          htmlFor={id ?? localId}\n        >\n          {label}\n        </Label>\n      ) : null}\n      <UnitInputWrapper\n        direction=\"row\"\n        data-testid={dataTestId}\n        data-size={size}\n        width={width}\n        data-success={!!success}\n        data-error={!!error}\n        data-disabled={!!disabled}\n        data-readonly={!!readOnly}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n      >\n        <StyledNumberInputWrapper id=\"input-field\">\n          <StyledInput\n            type=\"number\"\n            aria-invalid={!!error}\n            autoFocus={autoFocus}\n            disabled={disabled}\n            name={`${name}-value`}\n            width={width}\n            id={id ? `${id}-value` : undefined}\n            value={val}\n            onChange={event => {\n              const numericValue = Number.parseInt(event.target.value, 10)\n              if (numericValue > max) {\n                setVal(max)\n                onChange?.(max)\n              } else if (numericValue < min) {\n                setVal(min)\n                onChange?.(min)\n              } else {\n                setVal(numericValue)\n                onChange?.(numericValue)\n              }\n            }}\n            placeholder={placeholder}\n            max={max}\n            readOnly={readOnly}\n            min={min}\n            step={step}\n            data-success={success}\n            data-error={error}\n            data-testid=\"unit-input\"\n            required={required}\n            className={className}\n            data-size={size}\n          />\n          {error ? <AlertCircleIcon sentiment=\"danger\" /> : null}\n          {success && !error ? <CheckCircleIcon sentiment=\"success\" /> : null}\n        </StyledNumberInputWrapper>\n        <CustomSelectInput\n          data-disabled={disabled}\n          id=\"unit\"\n          name={`${name}-unit`}\n          onChange={(newValue: string) => {\n            onChangeUnitValue?.(newValue)\n          }}\n          error={unitError}\n          value={unitValue}\n          options={options}\n          width={selectInputWidth}\n          searchable={false}\n          clearable={false}\n          placeholder={placeholderUnit}\n          disabled={disabled}\n          size={size}\n          multiselect={false}\n          readOnly={readOnly}\n          dropdownAlign={dropdownAlign}\n        />\n      </UnitInputWrapper>\n      {error || typeof success === 'string' || typeof helper === 'string' ? (\n        <Text\n          as=\"p\"\n          variant=\"caption\"\n          sentiment={sentiment}\n          disabled={disabled}\n          prominence={sentiment === 'neutral' ? 'weak' : 'default'}\n        >\n          {error || success || helper}\n        </Text>\n      ) : null}\n      {!error && !success && typeof helper !== 'string' && helper\n        ? helper\n        : null}\n    </Stack>\n  )\n}\n"]} */"));
|
|
25
|
+
}) => theme.colors.neutral.border, ";width:100%;height:100%;" + (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/UnitInput/index.tsx"],"names":[],"mappings":"AAkB2C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/UnitInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { AlertCircleIcon, CheckCircleIcon } from '@ultraviolet/icons'\nimport type { ComponentProps, InputHTMLAttributes, ReactNode } from 'react'\nimport { useEffect, useId, useMemo, useState } from 'react'\nimport { Label } from '../Label'\nimport { SelectInput } from '../SelectInput'\nimport type { OptionType } from '../SelectInput/types'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst INPUT_SIZE_HEIGHT = {\n  small: '400', // sizing theme tokens key\n  medium: '500',\n  large: '600',\n} as const\n\nconst StyledNumberInputWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex-direction: row;\n  padding-right: ${({ theme }) => theme.space['2']};\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  width: 100%;\n  height: 100%;\n`\n\nconst StyledInput = styled.input`\n  flex: 1;\n  border: none;\n  outline: none;\n  height: 100%;\n  width: 100%;\n  padding-left: ${({ theme }) => theme.space['2']};\n  background: transparent;\n  color: ${({ theme }) => theme.colors.neutral.text};\n  &[data-size=\"small\"] {\n    padding-left: ${({ theme }) => theme.space['1']};\n  }\n\n  &[data-size=\"large\"] {\n    font-size: ${({ theme }) => theme.typography.body.fontSize};\n  }\n\n  &::placeholder {\n    color: ${({ theme }) => theme.colors.neutral.textWeak};\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n`\n\nconst UnitInputWrapper = styled(Stack)<{\n  'data-size': 'small' | 'medium' | 'large'\n  'data-success': boolean\n  'data-error': boolean\n  'data-disabled': boolean\n  'data-readonly': boolean\n}>`\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus,\n  :not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):active {\n    box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus-within  {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n    }\n\n  &:not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):not([data-readonly='true']):hover,\n  :not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):focus {\n    text-decoration: none;\n    border-color: ${({ theme }) => theme.colors.primary.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-readonly='true']:active {\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  &[data-size='small'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.small]};\n  }\n  &[data-size='medium'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.medium]};\n  }\n  &[data-size='large'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.large]};\n  }\n\n  &[data-success='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n  &[data-success='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n\n  &[data-error='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-error='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n`\n\nconst CustomSelectInput = styled(SelectInput)<{\n  width?: number | string\n  maxWidth?: number | string\n  'data-disabled': boolean\n}>`\n  #unit {\n    border: none;\n    background: transparent;\n  }\n\n  ${({ width }) =>\n    width && `width: ${typeof width === 'string' ? width : `${width}px`};`}\n  ${({ maxWidth }) =>\n    maxWidth &&\n    `max-width: ${typeof maxWidth === 'string' ? maxWidth : `${maxWidth}px`};`}\n\n  #unit:focus,\n  #unit:active {\n    box-shadow: none;\n  }\n`\ntype UnitInputValue = { inputValue: number; unit: string }\n\ntype UnitInputProps = {\n  className?: string\n  max?: number\n  min?: number\n  value?: UnitInputValue['inputValue']\n  unitValue?: UnitInputValue['unit']\n  onChange?: (value: UnitInputValue['inputValue']) => void\n  onChangeUnitValue?: (values: string) => void\n  options: OptionType[]\n  selectInputWidth?: number | string\n  size?: 'small' | 'medium' | 'large'\n  'data-testid'?: string\n  helper?: string\n  unitError?: string\n  width?: ComponentProps<typeof Stack>['width']\n  placeholderUnit?: string\n  error?: boolean | string\n  success?: boolean | string\n  label?: string\n  labelInformation?: ReactNode\n  step?: number | string\n  dropdownAlign?: ComponentProps<typeof SelectInput>['dropdownAlign']\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'id'\n  | 'placeholder'\n  | 'disabled'\n  | 'readOnly'\n  | 'required'\n  | 'autoFocus'\n  | 'onKeyDown'\n>\n\nexport const UnitInput = ({\n  id,\n  name = '',\n  max = Number.MAX_SAFE_INTEGER,\n  min = 0,\n  autoFocus = false,\n  size = 'large',\n  placeholder = '0',\n  placeholderUnit = 'Select item',\n  onChange,\n  onChangeUnitValue,\n  value,\n  unitValue,\n  selectInputWidth = '12.6rem',\n  disabled = false,\n  options,\n  className,\n  label,\n  step = 1,\n  error,\n  required,\n  helper,\n  unitError,\n  success,\n  'data-testid': dataTestId,\n  width,\n  labelInformation,\n  readOnly,\n  onFocus,\n  onBlur,\n  onKeyDown,\n  dropdownAlign,\n}: UnitInputProps) => {\n  const [val, setVal] = useState(value)\n  const localId = useId()\n  const sentiment = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    if (value !== undefined) {\n      setVal(value)\n    }\n  }, [value])\n\n  return (\n    <Stack gap={0.5}>\n      {label || labelInformation ? (\n        <Label\n          labelDescription={labelInformation}\n          required={required}\n          size={size}\n          htmlFor={id ?? localId}\n        >\n          {label}\n        </Label>\n      ) : null}\n      <UnitInputWrapper\n        direction=\"row\"\n        data-testid={dataTestId}\n        data-size={size}\n        width={width}\n        data-success={!!success}\n        data-error={!!error}\n        data-disabled={!!disabled}\n        data-readonly={!!readOnly}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n      >\n        <StyledNumberInputWrapper id=\"input-field\">\n          <StyledInput\n            type=\"number\"\n            aria-invalid={!!error}\n            autoFocus={autoFocus}\n            disabled={disabled}\n            name={`${name}-value`}\n            width={width}\n            id={id ?? localId}\n            value={val}\n            onChange={event => {\n              const numericValue = Number.parseInt(event.target.value, 10)\n              if (numericValue > max) {\n                setVal(max)\n                onChange?.(max)\n              } else if (numericValue < min) {\n                setVal(min)\n                onChange?.(min)\n              } else {\n                setVal(numericValue)\n                onChange?.(numericValue)\n              }\n            }}\n            placeholder={placeholder}\n            max={max}\n            readOnly={readOnly}\n            min={min}\n            step={step}\n            data-success={success}\n            data-error={error}\n            data-testid=\"unit-input\"\n            required={required}\n            className={className}\n            data-size={size}\n          />\n          {error ? <AlertCircleIcon sentiment=\"danger\" /> : null}\n          {success && !error ? <CheckCircleIcon sentiment=\"success\" /> : null}\n        </StyledNumberInputWrapper>\n        <CustomSelectInput\n          data-disabled={disabled}\n          id=\"unit\"\n          name={`${name}-unit`}\n          onChange={(newValue: string) => {\n            onChangeUnitValue?.(newValue)\n          }}\n          error={unitError}\n          value={unitValue}\n          options={options}\n          width={selectInputWidth}\n          searchable={false}\n          clearable={false}\n          placeholder={placeholderUnit}\n          disabled={disabled}\n          size={size}\n          multiselect={false}\n          readOnly={readOnly}\n          dropdownAlign={dropdownAlign}\n        />\n      </UnitInputWrapper>\n      {error || typeof success === 'string' || typeof helper === 'string' ? (\n        <Text\n          as=\"p\"\n          variant=\"caption\"\n          sentiment={sentiment}\n          disabled={disabled}\n          prominence={sentiment === 'neutral' ? 'weak' : 'default'}\n        >\n          {error || success || helper}\n        </Text>\n      ) : null}\n      {!error && !success && typeof helper !== 'string' && helper\n        ? helper\n        : null}\n    </Stack>\n  )\n}\n"]} */"));
|
|
26
26
|
const StyledInput = /* @__PURE__ */ _styled("input", process.env.NODE_ENV === "production" ? {
|
|
27
27
|
target: "ex81jph2"
|
|
28
28
|
} : {
|
|
@@ -40,7 +40,7 @@ const StyledInput = /* @__PURE__ */ _styled("input", process.env.NODE_ENV === "p
|
|
|
40
40
|
theme
|
|
41
41
|
}) => theme.colors.neutral.textWeak, ";}&:disabled{cursor:not-allowed;&::placeholder{color:", ({
|
|
42
42
|
theme
|
|
43
|
-
}) => theme.colors.neutral.textWeakDisabled, ";}}" + (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/UnitInput/index.tsx"],"names":[],"mappings":"AA4BgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/UnitInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { AlertCircleIcon, CheckCircleIcon } from '@ultraviolet/icons'\nimport type { ComponentProps, InputHTMLAttributes, ReactNode } from 'react'\nimport { useEffect, useId, useMemo, useState } from 'react'\nimport { Label } from '../Label'\nimport { SelectInput } from '../SelectInput'\nimport type { OptionType } from '../SelectInput/types'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst INPUT_SIZE_HEIGHT = {\n  small: '400', // sizing theme tokens key\n  medium: '500',\n  large: '600',\n} as const\n\nconst StyledNumberInputWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex-direction: row;\n  padding-right: ${({ theme }) => theme.space['2']};\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  width: 100%;\n  height: 100%;\n`\n\nconst StyledInput = styled.input`\n  flex: 1;\n  border: none;\n  outline: none;\n  height: 100%;\n  width: 100%;\n  padding-left: ${({ theme }) => theme.space['2']};\n  background: transparent;\n  color: ${({ theme }) => theme.colors.neutral.text};\n  &[data-size=\"small\"] {\n    padding-left: ${({ theme }) => theme.space['1']};\n  }\n\n  &[data-size=\"large\"] {\n    font-size: ${({ theme }) => theme.typography.body.fontSize};\n  }\n\n  &::placeholder {\n    color: ${({ theme }) => theme.colors.neutral.textWeak};\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n`\n\nconst UnitInputWrapper = styled(Stack)<{\n  'data-size': 'small' | 'medium' | 'large'\n  'data-success': boolean\n  'data-error': boolean\n  'data-disabled': boolean\n  'data-readonly': boolean\n}>`\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus,\n  :not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):active {\n    box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus-within  {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n    }\n\n  &:not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):not([data-readonly='true']):hover,\n  :not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):focus {\n    text-decoration: none;\n    border-color: ${({ theme }) => theme.colors.primary.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-readonly='true']:active {\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  &[data-size='small'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.small]};\n  }\n  &[data-size='medium'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.medium]};\n  }\n  &[data-size='large'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.large]};\n  }\n\n  &[data-success='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n  &[data-success='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n\n  &[data-error='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-error='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n`\n\nconst CustomSelectInput = styled(SelectInput)<{\n  width?: number | string\n  maxWidth?: number | string\n  'data-disabled': boolean\n}>`\n  #unit {\n    border: none;\n    background: transparent;\n  }\n\n  ${({ width }) =>\n    width && `width: ${typeof width === 'string' ? width : `${width}px`};`}\n  ${({ maxWidth }) =>\n    maxWidth &&\n    `max-width: ${typeof maxWidth === 'string' ? maxWidth : `${maxWidth}px`};`}\n\n  #unit:focus,\n  #unit:active {\n    box-shadow: none;\n  }\n`\ntype UnitInputValue = { inputValue: number; unit: string }\n\ntype UnitInputProps = {\n  className?: string\n  max?: number\n  min?: number\n  value?: UnitInputValue['inputValue']\n  unitValue?: UnitInputValue['unit']\n  onChange?: (value: UnitInputValue['inputValue']) => void\n  onChangeUnitValue?: (values: string) => void\n  options: OptionType[]\n  selectInputWidth?: number | string\n  size?: 'small' | 'medium' | 'large'\n  'data-testid'?: string\n  helper?: string\n  unitError?: string\n  width?: ComponentProps<typeof Stack>['width']\n  placeholderUnit?: string\n  error?: boolean | string\n  success?: boolean | string\n  label?: string\n  labelInformation?: ReactNode\n  step?: number | string\n  dropdownAlign?: ComponentProps<typeof SelectInput>['dropdownAlign']\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'id'\n  | 'placeholder'\n  | 'disabled'\n  | 'readOnly'\n  | 'required'\n  | 'autoFocus'\n  | 'onKeyDown'\n>\n\nexport const UnitInput = ({\n  id,\n  name = '',\n  max = Number.MAX_SAFE_INTEGER,\n  min = 0,\n  autoFocus = false,\n  size = 'large',\n  placeholder = '0',\n  placeholderUnit = 'Select item',\n  onChange,\n  onChangeUnitValue,\n  value,\n  unitValue,\n  selectInputWidth = '12.6rem',\n  disabled = false,\n  options,\n  className,\n  label,\n  step = 1,\n  error,\n  required,\n  helper,\n  unitError,\n  success,\n  'data-testid': dataTestId,\n  width,\n  labelInformation,\n  readOnly,\n  onFocus,\n  onBlur,\n  onKeyDown,\n  dropdownAlign,\n}: UnitInputProps) => {\n  const [val, setVal] = useState(value)\n  const localId = useId()\n  const sentiment = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    if (value !== undefined) {\n      setVal(value)\n    }\n  }, [value])\n\n  return (\n    <Stack gap={0.5}>\n      {label || labelInformation ? (\n        <Label\n          labelDescription={labelInformation}\n          required={required}\n          size={size}\n          htmlFor={id ?? localId}\n        >\n          {label}\n        </Label>\n      ) : null}\n      <UnitInputWrapper\n        direction=\"row\"\n        data-testid={dataTestId}\n        data-size={size}\n        width={width}\n        data-success={!!success}\n        data-error={!!error}\n        data-disabled={!!disabled}\n        data-readonly={!!readOnly}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n      >\n        <StyledNumberInputWrapper id=\"input-field\">\n          <StyledInput\n            type=\"number\"\n            aria-invalid={!!error}\n            autoFocus={autoFocus}\n            disabled={disabled}\n            name={`${name}-value`}\n            width={width}\n            id={id ? `${id}-value` : undefined}\n            value={val}\n            onChange={event => {\n              const numericValue = Number.parseInt(event.target.value, 10)\n              if (numericValue > max) {\n                setVal(max)\n                onChange?.(max)\n              } else if (numericValue < min) {\n                setVal(min)\n                onChange?.(min)\n              } else {\n                setVal(numericValue)\n                onChange?.(numericValue)\n              }\n            }}\n            placeholder={placeholder}\n            max={max}\n            readOnly={readOnly}\n            min={min}\n            step={step}\n            data-success={success}\n            data-error={error}\n            data-testid=\"unit-input\"\n            required={required}\n            className={className}\n            data-size={size}\n          />\n          {error ? <AlertCircleIcon sentiment=\"danger\" /> : null}\n          {success && !error ? <CheckCircleIcon sentiment=\"success\" /> : null}\n        </StyledNumberInputWrapper>\n        <CustomSelectInput\n          data-disabled={disabled}\n          id=\"unit\"\n          name={`${name}-unit`}\n          onChange={(newValue: string) => {\n            onChangeUnitValue?.(newValue)\n          }}\n          error={unitError}\n          value={unitValue}\n          options={options}\n          width={selectInputWidth}\n          searchable={false}\n          clearable={false}\n          placeholder={placeholderUnit}\n          disabled={disabled}\n          size={size}\n          multiselect={false}\n          readOnly={readOnly}\n          dropdownAlign={dropdownAlign}\n        />\n      </UnitInputWrapper>\n      {error || typeof success === 'string' || typeof helper === 'string' ? (\n        <Text\n          as=\"p\"\n          variant=\"caption\"\n          sentiment={sentiment}\n          disabled={disabled}\n          prominence={sentiment === 'neutral' ? 'weak' : 'default'}\n        >\n          {error || success || helper}\n        </Text>\n      ) : null}\n      {!error && !success && typeof helper !== 'string' && helper\n        ? helper\n        : null}\n    </Stack>\n  )\n}\n"]} */"));
|
|
43
|
+
}) => theme.colors.neutral.textWeakDisabled, ";}}" + (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/UnitInput/index.tsx"],"names":[],"mappings":"AA4BgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/UnitInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { AlertCircleIcon, CheckCircleIcon } from '@ultraviolet/icons'\nimport type { ComponentProps, InputHTMLAttributes, ReactNode } from 'react'\nimport { useEffect, useId, useMemo, useState } from 'react'\nimport { Label } from '../Label'\nimport { SelectInput } from '../SelectInput'\nimport type { OptionType } from '../SelectInput/types'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst INPUT_SIZE_HEIGHT = {\n  small: '400', // sizing theme tokens key\n  medium: '500',\n  large: '600',\n} as const\n\nconst StyledNumberInputWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex-direction: row;\n  padding-right: ${({ theme }) => theme.space['2']};\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  width: 100%;\n  height: 100%;\n`\n\nconst StyledInput = styled.input`\n  flex: 1;\n  border: none;\n  outline: none;\n  height: 100%;\n  width: 100%;\n  padding-left: ${({ theme }) => theme.space['2']};\n  background: transparent;\n  color: ${({ theme }) => theme.colors.neutral.text};\n  &[data-size=\"small\"] {\n    padding-left: ${({ theme }) => theme.space['1']};\n  }\n\n  &[data-size=\"large\"] {\n    font-size: ${({ theme }) => theme.typography.body.fontSize};\n  }\n\n  &::placeholder {\n    color: ${({ theme }) => theme.colors.neutral.textWeak};\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n`\n\nconst UnitInputWrapper = styled(Stack)<{\n  'data-size': 'small' | 'medium' | 'large'\n  'data-success': boolean\n  'data-error': boolean\n  'data-disabled': boolean\n  'data-readonly': boolean\n}>`\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus,\n  :not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):active {\n    box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus-within  {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n    }\n\n  &:not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):not([data-readonly='true']):hover,\n  :not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):focus {\n    text-decoration: none;\n    border-color: ${({ theme }) => theme.colors.primary.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-readonly='true']:active {\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  &[data-size='small'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.small]};\n  }\n  &[data-size='medium'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.medium]};\n  }\n  &[data-size='large'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.large]};\n  }\n\n  &[data-success='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n  &[data-success='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n\n  &[data-error='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-error='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n`\n\nconst CustomSelectInput = styled(SelectInput)<{\n  width?: number | string\n  maxWidth?: number | string\n  'data-disabled': boolean\n}>`\n  #unit {\n    border: none;\n    background: transparent;\n  }\n\n  ${({ width }) =>\n    width && `width: ${typeof width === 'string' ? width : `${width}px`};`}\n  ${({ maxWidth }) =>\n    maxWidth &&\n    `max-width: ${typeof maxWidth === 'string' ? maxWidth : `${maxWidth}px`};`}\n\n  #unit:focus,\n  #unit:active {\n    box-shadow: none;\n  }\n`\ntype UnitInputValue = { inputValue: number; unit: string }\n\ntype UnitInputProps = {\n  className?: string\n  max?: number\n  min?: number\n  value?: UnitInputValue['inputValue']\n  unitValue?: UnitInputValue['unit']\n  onChange?: (value: UnitInputValue['inputValue']) => void\n  onChangeUnitValue?: (values: string) => void\n  options: OptionType[]\n  selectInputWidth?: number | string\n  size?: 'small' | 'medium' | 'large'\n  'data-testid'?: string\n  helper?: string\n  unitError?: string\n  width?: ComponentProps<typeof Stack>['width']\n  placeholderUnit?: string\n  error?: boolean | string\n  success?: boolean | string\n  label?: string\n  labelInformation?: ReactNode\n  step?: number | string\n  dropdownAlign?: ComponentProps<typeof SelectInput>['dropdownAlign']\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'id'\n  | 'placeholder'\n  | 'disabled'\n  | 'readOnly'\n  | 'required'\n  | 'autoFocus'\n  | 'onKeyDown'\n>\n\nexport const UnitInput = ({\n  id,\n  name = '',\n  max = Number.MAX_SAFE_INTEGER,\n  min = 0,\n  autoFocus = false,\n  size = 'large',\n  placeholder = '0',\n  placeholderUnit = 'Select item',\n  onChange,\n  onChangeUnitValue,\n  value,\n  unitValue,\n  selectInputWidth = '12.6rem',\n  disabled = false,\n  options,\n  className,\n  label,\n  step = 1,\n  error,\n  required,\n  helper,\n  unitError,\n  success,\n  'data-testid': dataTestId,\n  width,\n  labelInformation,\n  readOnly,\n  onFocus,\n  onBlur,\n  onKeyDown,\n  dropdownAlign,\n}: UnitInputProps) => {\n  const [val, setVal] = useState(value)\n  const localId = useId()\n  const sentiment = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    if (value !== undefined) {\n      setVal(value)\n    }\n  }, [value])\n\n  return (\n    <Stack gap={0.5}>\n      {label || labelInformation ? (\n        <Label\n          labelDescription={labelInformation}\n          required={required}\n          size={size}\n          htmlFor={id ?? localId}\n        >\n          {label}\n        </Label>\n      ) : null}\n      <UnitInputWrapper\n        direction=\"row\"\n        data-testid={dataTestId}\n        data-size={size}\n        width={width}\n        data-success={!!success}\n        data-error={!!error}\n        data-disabled={!!disabled}\n        data-readonly={!!readOnly}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n      >\n        <StyledNumberInputWrapper id=\"input-field\">\n          <StyledInput\n            type=\"number\"\n            aria-invalid={!!error}\n            autoFocus={autoFocus}\n            disabled={disabled}\n            name={`${name}-value`}\n            width={width}\n            id={id ?? localId}\n            value={val}\n            onChange={event => {\n              const numericValue = Number.parseInt(event.target.value, 10)\n              if (numericValue > max) {\n                setVal(max)\n                onChange?.(max)\n              } else if (numericValue < min) {\n                setVal(min)\n                onChange?.(min)\n              } else {\n                setVal(numericValue)\n                onChange?.(numericValue)\n              }\n            }}\n            placeholder={placeholder}\n            max={max}\n            readOnly={readOnly}\n            min={min}\n            step={step}\n            data-success={success}\n            data-error={error}\n            data-testid=\"unit-input\"\n            required={required}\n            className={className}\n            data-size={size}\n          />\n          {error ? <AlertCircleIcon sentiment=\"danger\" /> : null}\n          {success && !error ? <CheckCircleIcon sentiment=\"success\" /> : null}\n        </StyledNumberInputWrapper>\n        <CustomSelectInput\n          data-disabled={disabled}\n          id=\"unit\"\n          name={`${name}-unit`}\n          onChange={(newValue: string) => {\n            onChangeUnitValue?.(newValue)\n          }}\n          error={unitError}\n          value={unitValue}\n          options={options}\n          width={selectInputWidth}\n          searchable={false}\n          clearable={false}\n          placeholder={placeholderUnit}\n          disabled={disabled}\n          size={size}\n          multiselect={false}\n          readOnly={readOnly}\n          dropdownAlign={dropdownAlign}\n        />\n      </UnitInputWrapper>\n      {error || typeof success === 'string' || typeof helper === 'string' ? (\n        <Text\n          as=\"p\"\n          variant=\"caption\"\n          sentiment={sentiment}\n          disabled={disabled}\n          prominence={sentiment === 'neutral' ? 'weak' : 'default'}\n        >\n          {error || success || helper}\n        </Text>\n      ) : null}\n      {!error && !success && typeof helper !== 'string' && helper\n        ? helper\n        : null}\n    </Stack>\n  )\n}\n"]} */"));
|
|
44
44
|
const UnitInputWrapper = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
|
|
45
45
|
target: "ex81jph1"
|
|
46
46
|
} : {
|
|
@@ -106,7 +106,7 @@ const UnitInputWrapper = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV ===
|
|
|
106
106
|
theme
|
|
107
107
|
}) => theme.colors.neutral.borderDisabled, ";cursor:not-allowed;&>", StyledNumberInputWrapper, "{border-right-color:", ({
|
|
108
108
|
theme
|
|
109
|
-
}) => theme.colors.neutral.borderDisabled, ";}}" + (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/UnitInput/index.tsx"],"names":[],"mappings":"AAgEE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/UnitInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { AlertCircleIcon, CheckCircleIcon } from '@ultraviolet/icons'\nimport type { ComponentProps, InputHTMLAttributes, ReactNode } from 'react'\nimport { useEffect, useId, useMemo, useState } from 'react'\nimport { Label } from '../Label'\nimport { SelectInput } from '../SelectInput'\nimport type { OptionType } from '../SelectInput/types'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst INPUT_SIZE_HEIGHT = {\n  small: '400', // sizing theme tokens key\n  medium: '500',\n  large: '600',\n} as const\n\nconst StyledNumberInputWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex-direction: row;\n  padding-right: ${({ theme }) => theme.space['2']};\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  width: 100%;\n  height: 100%;\n`\n\nconst StyledInput = styled.input`\n  flex: 1;\n  border: none;\n  outline: none;\n  height: 100%;\n  width: 100%;\n  padding-left: ${({ theme }) => theme.space['2']};\n  background: transparent;\n  color: ${({ theme }) => theme.colors.neutral.text};\n  &[data-size=\"small\"] {\n    padding-left: ${({ theme }) => theme.space['1']};\n  }\n\n  &[data-size=\"large\"] {\n    font-size: ${({ theme }) => theme.typography.body.fontSize};\n  }\n\n  &::placeholder {\n    color: ${({ theme }) => theme.colors.neutral.textWeak};\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n`\n\nconst UnitInputWrapper = styled(Stack)<{\n  'data-size': 'small' | 'medium' | 'large'\n  'data-success': boolean\n  'data-error': boolean\n  'data-disabled': boolean\n  'data-readonly': boolean\n}>`\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus,\n  :not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):active {\n    box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus-within  {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n    }\n\n  &:not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):not([data-readonly='true']):hover,\n  :not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):focus {\n    text-decoration: none;\n    border-color: ${({ theme }) => theme.colors.primary.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-readonly='true']:active {\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  &[data-size='small'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.small]};\n  }\n  &[data-size='medium'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.medium]};\n  }\n  &[data-size='large'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.large]};\n  }\n\n  &[data-success='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n  &[data-success='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n\n  &[data-error='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-error='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n`\n\nconst CustomSelectInput = styled(SelectInput)<{\n  width?: number | string\n  maxWidth?: number | string\n  'data-disabled': boolean\n}>`\n  #unit {\n    border: none;\n    background: transparent;\n  }\n\n  ${({ width }) =>\n    width && `width: ${typeof width === 'string' ? width : `${width}px`};`}\n  ${({ maxWidth }) =>\n    maxWidth &&\n    `max-width: ${typeof maxWidth === 'string' ? maxWidth : `${maxWidth}px`};`}\n\n  #unit:focus,\n  #unit:active {\n    box-shadow: none;\n  }\n`\ntype UnitInputValue = { inputValue: number; unit: string }\n\ntype UnitInputProps = {\n  className?: string\n  max?: number\n  min?: number\n  value?: UnitInputValue['inputValue']\n  unitValue?: UnitInputValue['unit']\n  onChange?: (value: UnitInputValue['inputValue']) => void\n  onChangeUnitValue?: (values: string) => void\n  options: OptionType[]\n  selectInputWidth?: number | string\n  size?: 'small' | 'medium' | 'large'\n  'data-testid'?: string\n  helper?: string\n  unitError?: string\n  width?: ComponentProps<typeof Stack>['width']\n  placeholderUnit?: string\n  error?: boolean | string\n  success?: boolean | string\n  label?: string\n  labelInformation?: ReactNode\n  step?: number | string\n  dropdownAlign?: ComponentProps<typeof SelectInput>['dropdownAlign']\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'id'\n  | 'placeholder'\n  | 'disabled'\n  | 'readOnly'\n  | 'required'\n  | 'autoFocus'\n  | 'onKeyDown'\n>\n\nexport const UnitInput = ({\n  id,\n  name = '',\n  max = Number.MAX_SAFE_INTEGER,\n  min = 0,\n  autoFocus = false,\n  size = 'large',\n  placeholder = '0',\n  placeholderUnit = 'Select item',\n  onChange,\n  onChangeUnitValue,\n  value,\n  unitValue,\n  selectInputWidth = '12.6rem',\n  disabled = false,\n  options,\n  className,\n  label,\n  step = 1,\n  error,\n  required,\n  helper,\n  unitError,\n  success,\n  'data-testid': dataTestId,\n  width,\n  labelInformation,\n  readOnly,\n  onFocus,\n  onBlur,\n  onKeyDown,\n  dropdownAlign,\n}: UnitInputProps) => {\n  const [val, setVal] = useState(value)\n  const localId = useId()\n  const sentiment = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    if (value !== undefined) {\n      setVal(value)\n    }\n  }, [value])\n\n  return (\n    <Stack gap={0.5}>\n      {label || labelInformation ? (\n        <Label\n          labelDescription={labelInformation}\n          required={required}\n          size={size}\n          htmlFor={id ?? localId}\n        >\n          {label}\n        </Label>\n      ) : null}\n      <UnitInputWrapper\n        direction=\"row\"\n        data-testid={dataTestId}\n        data-size={size}\n        width={width}\n        data-success={!!success}\n        data-error={!!error}\n        data-disabled={!!disabled}\n        data-readonly={!!readOnly}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n      >\n        <StyledNumberInputWrapper id=\"input-field\">\n          <StyledInput\n            type=\"number\"\n            aria-invalid={!!error}\n            autoFocus={autoFocus}\n            disabled={disabled}\n            name={`${name}-value`}\n            width={width}\n            id={id ? `${id}-value` : undefined}\n            value={val}\n            onChange={event => {\n              const numericValue = Number.parseInt(event.target.value, 10)\n              if (numericValue > max) {\n                setVal(max)\n                onChange?.(max)\n              } else if (numericValue < min) {\n                setVal(min)\n                onChange?.(min)\n              } else {\n                setVal(numericValue)\n                onChange?.(numericValue)\n              }\n            }}\n            placeholder={placeholder}\n            max={max}\n            readOnly={readOnly}\n            min={min}\n            step={step}\n            data-success={success}\n            data-error={error}\n            data-testid=\"unit-input\"\n            required={required}\n            className={className}\n            data-size={size}\n          />\n          {error ? <AlertCircleIcon sentiment=\"danger\" /> : null}\n          {success && !error ? <CheckCircleIcon sentiment=\"success\" /> : null}\n        </StyledNumberInputWrapper>\n        <CustomSelectInput\n          data-disabled={disabled}\n          id=\"unit\"\n          name={`${name}-unit`}\n          onChange={(newValue: string) => {\n            onChangeUnitValue?.(newValue)\n          }}\n          error={unitError}\n          value={unitValue}\n          options={options}\n          width={selectInputWidth}\n          searchable={false}\n          clearable={false}\n          placeholder={placeholderUnit}\n          disabled={disabled}\n          size={size}\n          multiselect={false}\n          readOnly={readOnly}\n          dropdownAlign={dropdownAlign}\n        />\n      </UnitInputWrapper>\n      {error || typeof success === 'string' || typeof helper === 'string' ? (\n        <Text\n          as=\"p\"\n          variant=\"caption\"\n          sentiment={sentiment}\n          disabled={disabled}\n          prominence={sentiment === 'neutral' ? 'weak' : 'default'}\n        >\n          {error || success || helper}\n        </Text>\n      ) : null}\n      {!error && !success && typeof helper !== 'string' && helper\n        ? helper\n        : null}\n    </Stack>\n  )\n}\n"]} */"));
|
|
109
|
+
}) => theme.colors.neutral.borderDisabled, ";}}" + (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/UnitInput/index.tsx"],"names":[],"mappings":"AAgEE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/UnitInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { AlertCircleIcon, CheckCircleIcon } from '@ultraviolet/icons'\nimport type { ComponentProps, InputHTMLAttributes, ReactNode } from 'react'\nimport { useEffect, useId, useMemo, useState } from 'react'\nimport { Label } from '../Label'\nimport { SelectInput } from '../SelectInput'\nimport type { OptionType } from '../SelectInput/types'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst INPUT_SIZE_HEIGHT = {\n  small: '400', // sizing theme tokens key\n  medium: '500',\n  large: '600',\n} as const\n\nconst StyledNumberInputWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex-direction: row;\n  padding-right: ${({ theme }) => theme.space['2']};\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  width: 100%;\n  height: 100%;\n`\n\nconst StyledInput = styled.input`\n  flex: 1;\n  border: none;\n  outline: none;\n  height: 100%;\n  width: 100%;\n  padding-left: ${({ theme }) => theme.space['2']};\n  background: transparent;\n  color: ${({ theme }) => theme.colors.neutral.text};\n  &[data-size=\"small\"] {\n    padding-left: ${({ theme }) => theme.space['1']};\n  }\n\n  &[data-size=\"large\"] {\n    font-size: ${({ theme }) => theme.typography.body.fontSize};\n  }\n\n  &::placeholder {\n    color: ${({ theme }) => theme.colors.neutral.textWeak};\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n`\n\nconst UnitInputWrapper = styled(Stack)<{\n  'data-size': 'small' | 'medium' | 'large'\n  'data-success': boolean\n  'data-error': boolean\n  'data-disabled': boolean\n  'data-readonly': boolean\n}>`\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus,\n  :not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):active {\n    box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus-within  {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n    }\n\n  &:not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):not([data-readonly='true']):hover,\n  :not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):focus {\n    text-decoration: none;\n    border-color: ${({ theme }) => theme.colors.primary.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-readonly='true']:active {\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  &[data-size='small'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.small]};\n  }\n  &[data-size='medium'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.medium]};\n  }\n  &[data-size='large'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.large]};\n  }\n\n  &[data-success='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n  &[data-success='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n\n  &[data-error='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-error='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n`\n\nconst CustomSelectInput = styled(SelectInput)<{\n  width?: number | string\n  maxWidth?: number | string\n  'data-disabled': boolean\n}>`\n  #unit {\n    border: none;\n    background: transparent;\n  }\n\n  ${({ width }) =>\n    width && `width: ${typeof width === 'string' ? width : `${width}px`};`}\n  ${({ maxWidth }) =>\n    maxWidth &&\n    `max-width: ${typeof maxWidth === 'string' ? maxWidth : `${maxWidth}px`};`}\n\n  #unit:focus,\n  #unit:active {\n    box-shadow: none;\n  }\n`\ntype UnitInputValue = { inputValue: number; unit: string }\n\ntype UnitInputProps = {\n  className?: string\n  max?: number\n  min?: number\n  value?: UnitInputValue['inputValue']\n  unitValue?: UnitInputValue['unit']\n  onChange?: (value: UnitInputValue['inputValue']) => void\n  onChangeUnitValue?: (values: string) => void\n  options: OptionType[]\n  selectInputWidth?: number | string\n  size?: 'small' | 'medium' | 'large'\n  'data-testid'?: string\n  helper?: string\n  unitError?: string\n  width?: ComponentProps<typeof Stack>['width']\n  placeholderUnit?: string\n  error?: boolean | string\n  success?: boolean | string\n  label?: string\n  labelInformation?: ReactNode\n  step?: number | string\n  dropdownAlign?: ComponentProps<typeof SelectInput>['dropdownAlign']\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'id'\n  | 'placeholder'\n  | 'disabled'\n  | 'readOnly'\n  | 'required'\n  | 'autoFocus'\n  | 'onKeyDown'\n>\n\nexport const UnitInput = ({\n  id,\n  name = '',\n  max = Number.MAX_SAFE_INTEGER,\n  min = 0,\n  autoFocus = false,\n  size = 'large',\n  placeholder = '0',\n  placeholderUnit = 'Select item',\n  onChange,\n  onChangeUnitValue,\n  value,\n  unitValue,\n  selectInputWidth = '12.6rem',\n  disabled = false,\n  options,\n  className,\n  label,\n  step = 1,\n  error,\n  required,\n  helper,\n  unitError,\n  success,\n  'data-testid': dataTestId,\n  width,\n  labelInformation,\n  readOnly,\n  onFocus,\n  onBlur,\n  onKeyDown,\n  dropdownAlign,\n}: UnitInputProps) => {\n  const [val, setVal] = useState(value)\n  const localId = useId()\n  const sentiment = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    if (value !== undefined) {\n      setVal(value)\n    }\n  }, [value])\n\n  return (\n    <Stack gap={0.5}>\n      {label || labelInformation ? (\n        <Label\n          labelDescription={labelInformation}\n          required={required}\n          size={size}\n          htmlFor={id ?? localId}\n        >\n          {label}\n        </Label>\n      ) : null}\n      <UnitInputWrapper\n        direction=\"row\"\n        data-testid={dataTestId}\n        data-size={size}\n        width={width}\n        data-success={!!success}\n        data-error={!!error}\n        data-disabled={!!disabled}\n        data-readonly={!!readOnly}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n      >\n        <StyledNumberInputWrapper id=\"input-field\">\n          <StyledInput\n            type=\"number\"\n            aria-invalid={!!error}\n            autoFocus={autoFocus}\n            disabled={disabled}\n            name={`${name}-value`}\n            width={width}\n            id={id ?? localId}\n            value={val}\n            onChange={event => {\n              const numericValue = Number.parseInt(event.target.value, 10)\n              if (numericValue > max) {\n                setVal(max)\n                onChange?.(max)\n              } else if (numericValue < min) {\n                setVal(min)\n                onChange?.(min)\n              } else {\n                setVal(numericValue)\n                onChange?.(numericValue)\n              }\n            }}\n            placeholder={placeholder}\n            max={max}\n            readOnly={readOnly}\n            min={min}\n            step={step}\n            data-success={success}\n            data-error={error}\n            data-testid=\"unit-input\"\n            required={required}\n            className={className}\n            data-size={size}\n          />\n          {error ? <AlertCircleIcon sentiment=\"danger\" /> : null}\n          {success && !error ? <CheckCircleIcon sentiment=\"success\" /> : null}\n        </StyledNumberInputWrapper>\n        <CustomSelectInput\n          data-disabled={disabled}\n          id=\"unit\"\n          name={`${name}-unit`}\n          onChange={(newValue: string) => {\n            onChangeUnitValue?.(newValue)\n          }}\n          error={unitError}\n          value={unitValue}\n          options={options}\n          width={selectInputWidth}\n          searchable={false}\n          clearable={false}\n          placeholder={placeholderUnit}\n          disabled={disabled}\n          size={size}\n          multiselect={false}\n          readOnly={readOnly}\n          dropdownAlign={dropdownAlign}\n        />\n      </UnitInputWrapper>\n      {error || typeof success === 'string' || typeof helper === 'string' ? (\n        <Text\n          as=\"p\"\n          variant=\"caption\"\n          sentiment={sentiment}\n          disabled={disabled}\n          prominence={sentiment === 'neutral' ? 'weak' : 'default'}\n        >\n          {error || success || helper}\n        </Text>\n      ) : null}\n      {!error && !success && typeof helper !== 'string' && helper\n        ? helper\n        : null}\n    </Stack>\n  )\n}\n"]} */"));
|
|
110
110
|
const CustomSelectInput = /* @__PURE__ */ _styled(SelectInput, process.env.NODE_ENV === "production" ? {
|
|
111
111
|
target: "ex81jph0"
|
|
112
112
|
} : {
|
|
@@ -116,7 +116,7 @@ const CustomSelectInput = /* @__PURE__ */ _styled(SelectInput, process.env.NODE_
|
|
|
116
116
|
width
|
|
117
117
|
}) => width && `width: ${typeof width === "string" ? width : `${width}px`};`, " ", ({
|
|
118
118
|
maxWidth
|
|
119
|
-
}) => maxWidth && `max-width: ${typeof maxWidth === "string" ? maxWidth : `${maxWidth}px`};`, " #unit:focus,#unit:active{box-shadow:none;}" + (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/UnitInput/index.tsx"],"names":[],"mappings":"AAkLE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/UnitInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { AlertCircleIcon, CheckCircleIcon } from '@ultraviolet/icons'\nimport type { ComponentProps, InputHTMLAttributes, ReactNode } from 'react'\nimport { useEffect, useId, useMemo, useState } from 'react'\nimport { Label } from '../Label'\nimport { SelectInput } from '../SelectInput'\nimport type { OptionType } from '../SelectInput/types'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst INPUT_SIZE_HEIGHT = {\n  small: '400', // sizing theme tokens key\n  medium: '500',\n  large: '600',\n} as const\n\nconst StyledNumberInputWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex-direction: row;\n  padding-right: ${({ theme }) => theme.space['2']};\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  width: 100%;\n  height: 100%;\n`\n\nconst StyledInput = styled.input`\n  flex: 1;\n  border: none;\n  outline: none;\n  height: 100%;\n  width: 100%;\n  padding-left: ${({ theme }) => theme.space['2']};\n  background: transparent;\n  color: ${({ theme }) => theme.colors.neutral.text};\n  &[data-size=\"small\"] {\n    padding-left: ${({ theme }) => theme.space['1']};\n  }\n\n  &[data-size=\"large\"] {\n    font-size: ${({ theme }) => theme.typography.body.fontSize};\n  }\n\n  &::placeholder {\n    color: ${({ theme }) => theme.colors.neutral.textWeak};\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n`\n\nconst UnitInputWrapper = styled(Stack)<{\n  'data-size': 'small' | 'medium' | 'large'\n  'data-success': boolean\n  'data-error': boolean\n  'data-disabled': boolean\n  'data-readonly': boolean\n}>`\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus,\n  :not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):active {\n    box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus-within  {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n    }\n\n  &:not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):not([data-readonly='true']):hover,\n  :not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):focus {\n    text-decoration: none;\n    border-color: ${({ theme }) => theme.colors.primary.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-readonly='true']:active {\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  &[data-size='small'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.small]};\n  }\n  &[data-size='medium'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.medium]};\n  }\n  &[data-size='large'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.large]};\n  }\n\n  &[data-success='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n  &[data-success='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n\n  &[data-error='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-error='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n`\n\nconst CustomSelectInput = styled(SelectInput)<{\n  width?: number | string\n  maxWidth?: number | string\n  'data-disabled': boolean\n}>`\n  #unit {\n    border: none;\n    background: transparent;\n  }\n\n  ${({ width }) =>\n    width && `width: ${typeof width === 'string' ? width : `${width}px`};`}\n  ${({ maxWidth }) =>\n    maxWidth &&\n    `max-width: ${typeof maxWidth === 'string' ? maxWidth : `${maxWidth}px`};`}\n\n  #unit:focus,\n  #unit:active {\n    box-shadow: none;\n  }\n`\ntype UnitInputValue = { inputValue: number; unit: string }\n\ntype UnitInputProps = {\n  className?: string\n  max?: number\n  min?: number\n  value?: UnitInputValue['inputValue']\n  unitValue?: UnitInputValue['unit']\n  onChange?: (value: UnitInputValue['inputValue']) => void\n  onChangeUnitValue?: (values: string) => void\n  options: OptionType[]\n  selectInputWidth?: number | string\n  size?: 'small' | 'medium' | 'large'\n  'data-testid'?: string\n  helper?: string\n  unitError?: string\n  width?: ComponentProps<typeof Stack>['width']\n  placeholderUnit?: string\n  error?: boolean | string\n  success?: boolean | string\n  label?: string\n  labelInformation?: ReactNode\n  step?: number | string\n  dropdownAlign?: ComponentProps<typeof SelectInput>['dropdownAlign']\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'id'\n  | 'placeholder'\n  | 'disabled'\n  | 'readOnly'\n  | 'required'\n  | 'autoFocus'\n  | 'onKeyDown'\n>\n\nexport const UnitInput = ({\n  id,\n  name = '',\n  max = Number.MAX_SAFE_INTEGER,\n  min = 0,\n  autoFocus = false,\n  size = 'large',\n  placeholder = '0',\n  placeholderUnit = 'Select item',\n  onChange,\n  onChangeUnitValue,\n  value,\n  unitValue,\n  selectInputWidth = '12.6rem',\n  disabled = false,\n  options,\n  className,\n  label,\n  step = 1,\n  error,\n  required,\n  helper,\n  unitError,\n  success,\n  'data-testid': dataTestId,\n  width,\n  labelInformation,\n  readOnly,\n  onFocus,\n  onBlur,\n  onKeyDown,\n  dropdownAlign,\n}: UnitInputProps) => {\n  const [val, setVal] = useState(value)\n  const localId = useId()\n  const sentiment = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    if (value !== undefined) {\n      setVal(value)\n    }\n  }, [value])\n\n  return (\n    <Stack gap={0.5}>\n      {label || labelInformation ? (\n        <Label\n          labelDescription={labelInformation}\n          required={required}\n          size={size}\n          htmlFor={id ?? localId}\n        >\n          {label}\n        </Label>\n      ) : null}\n      <UnitInputWrapper\n        direction=\"row\"\n        data-testid={dataTestId}\n        data-size={size}\n        width={width}\n        data-success={!!success}\n        data-error={!!error}\n        data-disabled={!!disabled}\n        data-readonly={!!readOnly}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n      >\n        <StyledNumberInputWrapper id=\"input-field\">\n          <StyledInput\n            type=\"number\"\n            aria-invalid={!!error}\n            autoFocus={autoFocus}\n            disabled={disabled}\n            name={`${name}-value`}\n            width={width}\n            id={id ? `${id}-value` : undefined}\n            value={val}\n            onChange={event => {\n              const numericValue = Number.parseInt(event.target.value, 10)\n              if (numericValue > max) {\n                setVal(max)\n                onChange?.(max)\n              } else if (numericValue < min) {\n                setVal(min)\n                onChange?.(min)\n              } else {\n                setVal(numericValue)\n                onChange?.(numericValue)\n              }\n            }}\n            placeholder={placeholder}\n            max={max}\n            readOnly={readOnly}\n            min={min}\n            step={step}\n            data-success={success}\n            data-error={error}\n            data-testid=\"unit-input\"\n            required={required}\n            className={className}\n            data-size={size}\n          />\n          {error ? <AlertCircleIcon sentiment=\"danger\" /> : null}\n          {success && !error ? <CheckCircleIcon sentiment=\"success\" /> : null}\n        </StyledNumberInputWrapper>\n        <CustomSelectInput\n          data-disabled={disabled}\n          id=\"unit\"\n          name={`${name}-unit`}\n          onChange={(newValue: string) => {\n            onChangeUnitValue?.(newValue)\n          }}\n          error={unitError}\n          value={unitValue}\n          options={options}\n          width={selectInputWidth}\n          searchable={false}\n          clearable={false}\n          placeholder={placeholderUnit}\n          disabled={disabled}\n          size={size}\n          multiselect={false}\n          readOnly={readOnly}\n          dropdownAlign={dropdownAlign}\n        />\n      </UnitInputWrapper>\n      {error || typeof success === 'string' || typeof helper === 'string' ? (\n        <Text\n          as=\"p\"\n          variant=\"caption\"\n          sentiment={sentiment}\n          disabled={disabled}\n          prominence={sentiment === 'neutral' ? 'weak' : 'default'}\n        >\n          {error || success || helper}\n        </Text>\n      ) : null}\n      {!error && !success && typeof helper !== 'string' && helper\n        ? helper\n        : null}\n    </Stack>\n  )\n}\n"]} */"));
|
|
119
|
+
}) => maxWidth && `max-width: ${typeof maxWidth === "string" ? maxWidth : `${maxWidth}px`};`, " #unit:focus,#unit:active{box-shadow:none;}" + (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/UnitInput/index.tsx"],"names":[],"mappings":"AAkLE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/UnitInput/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { AlertCircleIcon, CheckCircleIcon } from '@ultraviolet/icons'\nimport type { ComponentProps, InputHTMLAttributes, ReactNode } from 'react'\nimport { useEffect, useId, useMemo, useState } from 'react'\nimport { Label } from '../Label'\nimport { SelectInput } from '../SelectInput'\nimport type { OptionType } from '../SelectInput/types'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst INPUT_SIZE_HEIGHT = {\n  small: '400', // sizing theme tokens key\n  medium: '500',\n  large: '600',\n} as const\n\nconst StyledNumberInputWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex-direction: row;\n  padding-right: ${({ theme }) => theme.space['2']};\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  width: 100%;\n  height: 100%;\n`\n\nconst StyledInput = styled.input`\n  flex: 1;\n  border: none;\n  outline: none;\n  height: 100%;\n  width: 100%;\n  padding-left: ${({ theme }) => theme.space['2']};\n  background: transparent;\n  color: ${({ theme }) => theme.colors.neutral.text};\n  &[data-size=\"small\"] {\n    padding-left: ${({ theme }) => theme.space['1']};\n  }\n\n  &[data-size=\"large\"] {\n    font-size: ${({ theme }) => theme.typography.body.fontSize};\n  }\n\n  &::placeholder {\n    color: ${({ theme }) => theme.colors.neutral.textWeak};\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n`\n\nconst UnitInputWrapper = styled(Stack)<{\n  'data-size': 'small' | 'medium' | 'large'\n  'data-success': boolean\n  'data-error': boolean\n  'data-disabled': boolean\n  'data-readonly': boolean\n}>`\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus,\n  :not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):active {\n    box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    border-color: ${({ theme }) => theme.colors.primary.borderHover};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &:not([data-disabled='true']):not([data-readonly='true']):not(\n      [data-success='true']\n    ):not([data-error='true']):focus-within  {\n      border-color: ${({ theme }) => theme.colors.primary.borderHover};\n      & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n    }\n\n  &:not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):not([data-readonly='true']):hover,\n  :not([data-disabled='true']):not([data-error='true']):not(\n      [data-success='true']\n    ):focus {\n    text-decoration: none;\n    border-color: ${({ theme }) => theme.colors.primary.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n    cursor: default;\n  }\n\n  &[data-readonly='true']:active {\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  &[data-size='small'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.small]};\n  }\n  &[data-size='medium'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.medium]};\n  }\n  &[data-size='large'] {\n    height: ${({ theme }) => theme.sizing[INPUT_SIZE_HEIGHT.large]};\n  }\n\n  &[data-success='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n  &[data-success='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.success.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusSuccess};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.success.border};\n    }\n  }\n\n  &[data-error='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-error='true']:active {\n    border: 1px solid ${({ theme }) => theme.colors.danger.border};\n    box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n    & > ${StyledNumberInputWrapper}:hover {\n      border-right-color: ${({ theme }) => theme.colors.danger.border};\n    }\n  }\n\n  &[data-disabled='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    cursor: not-allowed;\n\n    & > ${StyledNumberInputWrapper} {\n      border-right-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n`\n\nconst CustomSelectInput = styled(SelectInput)<{\n  width?: number | string\n  maxWidth?: number | string\n  'data-disabled': boolean\n}>`\n  #unit {\n    border: none;\n    background: transparent;\n  }\n\n  ${({ width }) =>\n    width && `width: ${typeof width === 'string' ? width : `${width}px`};`}\n  ${({ maxWidth }) =>\n    maxWidth &&\n    `max-width: ${typeof maxWidth === 'string' ? maxWidth : `${maxWidth}px`};`}\n\n  #unit:focus,\n  #unit:active {\n    box-shadow: none;\n  }\n`\ntype UnitInputValue = { inputValue: number; unit: string }\n\ntype UnitInputProps = {\n  className?: string\n  max?: number\n  min?: number\n  value?: UnitInputValue['inputValue']\n  unitValue?: UnitInputValue['unit']\n  onChange?: (value: UnitInputValue['inputValue']) => void\n  onChangeUnitValue?: (values: string) => void\n  options: OptionType[]\n  selectInputWidth?: number | string\n  size?: 'small' | 'medium' | 'large'\n  'data-testid'?: string\n  helper?: string\n  unitError?: string\n  width?: ComponentProps<typeof Stack>['width']\n  placeholderUnit?: string\n  error?: boolean | string\n  success?: boolean | string\n  label?: string\n  labelInformation?: ReactNode\n  step?: number | string\n  dropdownAlign?: ComponentProps<typeof SelectInput>['dropdownAlign']\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'id'\n  | 'placeholder'\n  | 'disabled'\n  | 'readOnly'\n  | 'required'\n  | 'autoFocus'\n  | 'onKeyDown'\n>\n\nexport const UnitInput = ({\n  id,\n  name = '',\n  max = Number.MAX_SAFE_INTEGER,\n  min = 0,\n  autoFocus = false,\n  size = 'large',\n  placeholder = '0',\n  placeholderUnit = 'Select item',\n  onChange,\n  onChangeUnitValue,\n  value,\n  unitValue,\n  selectInputWidth = '12.6rem',\n  disabled = false,\n  options,\n  className,\n  label,\n  step = 1,\n  error,\n  required,\n  helper,\n  unitError,\n  success,\n  'data-testid': dataTestId,\n  width,\n  labelInformation,\n  readOnly,\n  onFocus,\n  onBlur,\n  onKeyDown,\n  dropdownAlign,\n}: UnitInputProps) => {\n  const [val, setVal] = useState(value)\n  const localId = useId()\n  const sentiment = useMemo(() => {\n    if (error) {\n      return 'danger'\n    }\n    if (success) {\n      return 'success'\n    }\n\n    return 'neutral'\n  }, [error, success])\n\n  useEffect(() => {\n    if (value !== undefined) {\n      setVal(value)\n    }\n  }, [value])\n\n  return (\n    <Stack gap={0.5}>\n      {label || labelInformation ? (\n        <Label\n          labelDescription={labelInformation}\n          required={required}\n          size={size}\n          htmlFor={id ?? localId}\n        >\n          {label}\n        </Label>\n      ) : null}\n      <UnitInputWrapper\n        direction=\"row\"\n        data-testid={dataTestId}\n        data-size={size}\n        width={width}\n        data-success={!!success}\n        data-error={!!error}\n        data-disabled={!!disabled}\n        data-readonly={!!readOnly}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n      >\n        <StyledNumberInputWrapper id=\"input-field\">\n          <StyledInput\n            type=\"number\"\n            aria-invalid={!!error}\n            autoFocus={autoFocus}\n            disabled={disabled}\n            name={`${name}-value`}\n            width={width}\n            id={id ?? localId}\n            value={val}\n            onChange={event => {\n              const numericValue = Number.parseInt(event.target.value, 10)\n              if (numericValue > max) {\n                setVal(max)\n                onChange?.(max)\n              } else if (numericValue < min) {\n                setVal(min)\n                onChange?.(min)\n              } else {\n                setVal(numericValue)\n                onChange?.(numericValue)\n              }\n            }}\n            placeholder={placeholder}\n            max={max}\n            readOnly={readOnly}\n            min={min}\n            step={step}\n            data-success={success}\n            data-error={error}\n            data-testid=\"unit-input\"\n            required={required}\n            className={className}\n            data-size={size}\n          />\n          {error ? <AlertCircleIcon sentiment=\"danger\" /> : null}\n          {success && !error ? <CheckCircleIcon sentiment=\"success\" /> : null}\n        </StyledNumberInputWrapper>\n        <CustomSelectInput\n          data-disabled={disabled}\n          id=\"unit\"\n          name={`${name}-unit`}\n          onChange={(newValue: string) => {\n            onChangeUnitValue?.(newValue)\n          }}\n          error={unitError}\n          value={unitValue}\n          options={options}\n          width={selectInputWidth}\n          searchable={false}\n          clearable={false}\n          placeholder={placeholderUnit}\n          disabled={disabled}\n          size={size}\n          multiselect={false}\n          readOnly={readOnly}\n          dropdownAlign={dropdownAlign}\n        />\n      </UnitInputWrapper>\n      {error || typeof success === 'string' || typeof helper === 'string' ? (\n        <Text\n          as=\"p\"\n          variant=\"caption\"\n          sentiment={sentiment}\n          disabled={disabled}\n          prominence={sentiment === 'neutral' ? 'weak' : 'default'}\n        >\n          {error || success || helper}\n        </Text>\n      ) : null}\n      {!error && !success && typeof helper !== 'string' && helper\n        ? helper\n        : null}\n    </Stack>\n  )\n}\n"]} */"));
|
|
120
120
|
const UnitInput = ({
|
|
121
121
|
id,
|
|
122
122
|
name = "",
|
|
@@ -170,7 +170,7 @@ const UnitInput = ({
|
|
|
170
170
|
label || labelInformation ? /* @__PURE__ */ jsx(Label, { labelDescription: labelInformation, required, size, htmlFor: id ?? localId, children: label }) : null,
|
|
171
171
|
/* @__PURE__ */ jsxs(UnitInputWrapper, { direction: "row", "data-testid": dataTestId, "data-size": size, width, "data-success": !!success, "data-error": !!error, "data-disabled": !!disabled, "data-readonly": !!readOnly, onFocus, onBlur, onKeyDown, children: [
|
|
172
172
|
/* @__PURE__ */ jsxs(StyledNumberInputWrapper, { id: "input-field", children: [
|
|
173
|
-
/* @__PURE__ */ jsx(StyledInput, { type: "number", "aria-invalid": !!error, autoFocus, disabled, name: `${name}-value`, width, id: id
|
|
173
|
+
/* @__PURE__ */ jsx(StyledInput, { type: "number", "aria-invalid": !!error, autoFocus, disabled, name: `${name}-value`, width, id: id ?? localId, value: val, onChange: (event) => {
|
|
174
174
|
const numericValue = Number.parseInt(event.target.value, 10);
|
|
175
175
|
if (numericValue > max) {
|
|
176
176
|
setVal(max);
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ultraviolet/ui",
|
|
3
|
-
"version": "2.0.0-beta.
|
|
3
|
+
"version": "2.0.0-beta.12",
|
|
4
4
|
"description": "Ultraviolet UI",
|
|
5
5
|
"homepage": "https://github.com/scaleway/ultraviolet#readme",
|
|
6
6
|
"repository": {
|
|
@@ -83,8 +83,8 @@
|
|
|
83
83
|
"next": "15.3.4",
|
|
84
84
|
"react-toastify": "11.0.5",
|
|
85
85
|
"react-use-clipboard": "1.0.9",
|
|
86
|
-
"@ultraviolet/
|
|
87
|
-
"@ultraviolet/
|
|
86
|
+
"@ultraviolet/icons": "4.0.0-beta.6",
|
|
87
|
+
"@ultraviolet/themes": "2.0.0-beta.2"
|
|
88
88
|
},
|
|
89
89
|
"scripts": {
|
|
90
90
|
"type:generate": "tsc --declaration -p tsconfig.build.json",
|