@ultraviolet/plus 3.0.0-beta.1 → 3.0.0-beta.2

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.
@@ -20,11 +20,13 @@ const StyledDl = /* @__PURE__ */ _styled__default.default("dl", process.env.NODE
20
20
  theme
21
21
  }) => theme.typography.body.lineHeight, ";flex-direction:column;align-items:start;margin:0;width:100%;", Row.StyledRow, "{width:", ({
22
22
  width
23
- }) => width ?? "100%", ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvSW5mb1RhYmxlL0luZm9UYWJsZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBU3NCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvSW5mb1RhYmxlL0luZm9UYWJsZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgSW5mb1RhYmxlQ2VsbCB9IGZyb20gJy4vY29tcG9uZW50cy9DZWxsJ1xuaW1wb3J0IHsgSW5mb1RhYmxlUm93LCBTdHlsZWRSb3cgfSBmcm9tICcuL2NvbXBvbmVudHMvUm93J1xuXG5jb25zdCBTdHlsZWREbCA9IHN0eWxlZCgnZGwnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3dpZHRoJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IHdpZHRoPzogc3RyaW5nIH0+YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmb250LXNpemU6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUudHlwb2dyYXBoeS5ib2R5LmZvbnRTaXplfTtcbiAgbGluZS1oZWlnaHQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUudHlwb2dyYXBoeS5ib2R5LmxpbmVIZWlnaHR9O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogc3RhcnQ7XG4gIG1hcmdpbjogMDtcbiAgd2lkdGg6IDEwMCU7XG5cbiAgJHtTdHlsZWRSb3d9IHtcbiAgICB3aWR0aDogJHsoeyB3aWR0aCB9KSA9PiB3aWR0aCA/PyAnMTAwJSd9O1xuICB9XG5gXG5cbnR5cGUgSW5mb1RhYmxlUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgd2lkdGg/OiBzdHJpbmdcbn1cblxuLyoqXG4gKiBVc2UgdGhpcyBjb21wb25lbnQgdG8gZGlzcGxheSBvZmZlcnMuXG4gKiBDcmVhdGUgcm93cyB3aXRoIGBJbmZvVGFibGUuUm93YCBhbmQgcGxhY2UgY2VsbHMgd2l0aGluIGVhY2ggcm93IHVzaW5nIGBJbmZvVGFibGUuQ2VsbGAuXG4gKi9cbmV4cG9ydCBjb25zdCBJbmZvVGFibGUgPSAoeyBjaGlsZHJlbiwgd2lkdGggfTogSW5mb1RhYmxlUHJvcHMpID0+IChcbiAgPFN0eWxlZERsIHdpZHRoPXt3aWR0aH0+e2NoaWxkcmVufTwvU3R5bGVkRGw+XG4pXG5cbkluZm9UYWJsZS5Sb3cgPSBJbmZvVGFibGVSb3dcbkluZm9UYWJsZS5DZWxsID0gSW5mb1RhYmxlQ2VsbFxuIl19 */"));
23
+ }) => width ?? "100%", ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvSW5mb1RhYmxlL0luZm9UYWJsZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBU3NCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvSW5mb1RhYmxlL0luZm9UYWJsZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgSW5mb1RhYmxlQ2VsbCB9IGZyb20gJy4vY29tcG9uZW50cy9DZWxsJ1xuaW1wb3J0IHsgSW5mb1RhYmxlUm93LCBTdHlsZWRSb3cgfSBmcm9tICcuL2NvbXBvbmVudHMvUm93J1xuXG5jb25zdCBTdHlsZWREbCA9IHN0eWxlZCgnZGwnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3dpZHRoJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IHdpZHRoPzogc3RyaW5nIH0+YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmb250LXNpemU6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUudHlwb2dyYXBoeS5ib2R5LmZvbnRTaXplfTtcbiAgbGluZS1oZWlnaHQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUudHlwb2dyYXBoeS5ib2R5LmxpbmVIZWlnaHR9O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogc3RhcnQ7XG4gIG1hcmdpbjogMDtcbiAgd2lkdGg6IDEwMCU7XG5cbiAgJHtTdHlsZWRSb3d9IHtcbiAgICB3aWR0aDogJHsoeyB3aWR0aCB9KSA9PiB3aWR0aCA/PyAnMTAwJSd9O1xuICB9XG5gXG5cbnR5cGUgSW5mb1RhYmxlUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgd2lkdGg/OiBzdHJpbmdcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gICdkYXRhLXRlc3RpZCc/OiBzdHJpbmdcbn1cblxuLyoqXG4gKiBVc2UgdGhpcyBjb21wb25lbnQgdG8gZGlzcGxheSBvZmZlcnMuXG4gKiBDcmVhdGUgcm93cyB3aXRoIGBJbmZvVGFibGUuUm93YCBhbmQgcGxhY2UgY2VsbHMgd2l0aGluIGVhY2ggcm93IHVzaW5nIGBJbmZvVGFibGUuQ2VsbGAuXG4gKi9cbmV4cG9ydCBjb25zdCBJbmZvVGFibGUgPSAoe1xuICBjaGlsZHJlbixcbiAgd2lkdGgsXG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbn06IEluZm9UYWJsZVByb3BzKSA9PiAoXG4gIDxTdHlsZWREbCBjbGFzc05hbWU9e2NsYXNzTmFtZX0gZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9IHdpZHRoPXt3aWR0aH0+XG4gICAge2NoaWxkcmVufVxuICA8L1N0eWxlZERsPlxuKVxuXG5JbmZvVGFibGUuUm93ID0gSW5mb1RhYmxlUm93XG5JbmZvVGFibGUuQ2VsbCA9IEluZm9UYWJsZUNlbGxcbiJdfQ== */"));
24
24
  const InfoTable = ({
25
25
  children,
26
- width
27
- }) => /* @__PURE__ */ jsxRuntime.jsx(StyledDl, { width, children });
26
+ width,
27
+ className,
28
+ "data-testid": dataTestId
29
+ }) => /* @__PURE__ */ jsxRuntime.jsx(StyledDl, { className, "data-testid": dataTestId, width, children });
28
30
  InfoTable.Row = Row.InfoTableRow;
29
31
  InfoTable.Cell = Cell.InfoTableCell;
30
32
  exports.InfoTable = InfoTable;
@@ -2,13 +2,15 @@ import type { ReactNode } from 'react';
2
2
  type InfoTableProps = {
3
3
  children: ReactNode;
4
4
  width?: string;
5
+ className?: string;
6
+ 'data-testid'?: string;
5
7
  };
6
8
  /**
7
9
  * Use this component to display offers.
8
10
  * Create rows with `InfoTable.Row` and place cells within each row using `InfoTable.Cell`.
9
11
  */
10
12
  export declare const InfoTable: {
11
- ({ children, width }: InfoTableProps): import("@emotion/react/jsx-runtime").JSX.Element;
13
+ ({ children, width, className, "data-testid": dataTestId, }: InfoTableProps): import("@emotion/react/jsx-runtime").JSX.Element;
12
14
  Row: ({ children, templateColumns }: {
13
15
  children: ReactNode;
14
16
  templateColumns: string;
@@ -16,11 +16,13 @@ const StyledDl = /* @__PURE__ */ _styled("dl", process.env.NODE_ENV === "product
16
16
  theme
17
17
  }) => theme.typography.body.lineHeight, ";flex-direction:column;align-items:start;margin:0;width:100%;", StyledRow, "{width:", ({
18
18
  width
19
- }) => width ?? "100%", ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvSW5mb1RhYmxlL0luZm9UYWJsZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBU3NCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvSW5mb1RhYmxlL0luZm9UYWJsZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgSW5mb1RhYmxlQ2VsbCB9IGZyb20gJy4vY29tcG9uZW50cy9DZWxsJ1xuaW1wb3J0IHsgSW5mb1RhYmxlUm93LCBTdHlsZWRSb3cgfSBmcm9tICcuL2NvbXBvbmVudHMvUm93J1xuXG5jb25zdCBTdHlsZWREbCA9IHN0eWxlZCgnZGwnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3dpZHRoJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IHdpZHRoPzogc3RyaW5nIH0+YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmb250LXNpemU6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUudHlwb2dyYXBoeS5ib2R5LmZvbnRTaXplfTtcbiAgbGluZS1oZWlnaHQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUudHlwb2dyYXBoeS5ib2R5LmxpbmVIZWlnaHR9O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogc3RhcnQ7XG4gIG1hcmdpbjogMDtcbiAgd2lkdGg6IDEwMCU7XG5cbiAgJHtTdHlsZWRSb3d9IHtcbiAgICB3aWR0aDogJHsoeyB3aWR0aCB9KSA9PiB3aWR0aCA/PyAnMTAwJSd9O1xuICB9XG5gXG5cbnR5cGUgSW5mb1RhYmxlUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgd2lkdGg/OiBzdHJpbmdcbn1cblxuLyoqXG4gKiBVc2UgdGhpcyBjb21wb25lbnQgdG8gZGlzcGxheSBvZmZlcnMuXG4gKiBDcmVhdGUgcm93cyB3aXRoIGBJbmZvVGFibGUuUm93YCBhbmQgcGxhY2UgY2VsbHMgd2l0aGluIGVhY2ggcm93IHVzaW5nIGBJbmZvVGFibGUuQ2VsbGAuXG4gKi9cbmV4cG9ydCBjb25zdCBJbmZvVGFibGUgPSAoeyBjaGlsZHJlbiwgd2lkdGggfTogSW5mb1RhYmxlUHJvcHMpID0+IChcbiAgPFN0eWxlZERsIHdpZHRoPXt3aWR0aH0+e2NoaWxkcmVufTwvU3R5bGVkRGw+XG4pXG5cbkluZm9UYWJsZS5Sb3cgPSBJbmZvVGFibGVSb3dcbkluZm9UYWJsZS5DZWxsID0gSW5mb1RhYmxlQ2VsbFxuIl19 */"));
19
+ }) => width ?? "100%", ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvSW5mb1RhYmxlL0luZm9UYWJsZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBU3NCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvSW5mb1RhYmxlL0luZm9UYWJsZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgSW5mb1RhYmxlQ2VsbCB9IGZyb20gJy4vY29tcG9uZW50cy9DZWxsJ1xuaW1wb3J0IHsgSW5mb1RhYmxlUm93LCBTdHlsZWRSb3cgfSBmcm9tICcuL2NvbXBvbmVudHMvUm93J1xuXG5jb25zdCBTdHlsZWREbCA9IHN0eWxlZCgnZGwnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3dpZHRoJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IHdpZHRoPzogc3RyaW5nIH0+YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmb250LXNpemU6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUudHlwb2dyYXBoeS5ib2R5LmZvbnRTaXplfTtcbiAgbGluZS1oZWlnaHQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUudHlwb2dyYXBoeS5ib2R5LmxpbmVIZWlnaHR9O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogc3RhcnQ7XG4gIG1hcmdpbjogMDtcbiAgd2lkdGg6IDEwMCU7XG5cbiAgJHtTdHlsZWRSb3d9IHtcbiAgICB3aWR0aDogJHsoeyB3aWR0aCB9KSA9PiB3aWR0aCA/PyAnMTAwJSd9O1xuICB9XG5gXG5cbnR5cGUgSW5mb1RhYmxlUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgd2lkdGg/OiBzdHJpbmdcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gICdkYXRhLXRlc3RpZCc/OiBzdHJpbmdcbn1cblxuLyoqXG4gKiBVc2UgdGhpcyBjb21wb25lbnQgdG8gZGlzcGxheSBvZmZlcnMuXG4gKiBDcmVhdGUgcm93cyB3aXRoIGBJbmZvVGFibGUuUm93YCBhbmQgcGxhY2UgY2VsbHMgd2l0aGluIGVhY2ggcm93IHVzaW5nIGBJbmZvVGFibGUuQ2VsbGAuXG4gKi9cbmV4cG9ydCBjb25zdCBJbmZvVGFibGUgPSAoe1xuICBjaGlsZHJlbixcbiAgd2lkdGgsXG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbn06IEluZm9UYWJsZVByb3BzKSA9PiAoXG4gIDxTdHlsZWREbCBjbGFzc05hbWU9e2NsYXNzTmFtZX0gZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9IHdpZHRoPXt3aWR0aH0+XG4gICAge2NoaWxkcmVufVxuICA8L1N0eWxlZERsPlxuKVxuXG5JbmZvVGFibGUuUm93ID0gSW5mb1RhYmxlUm93XG5JbmZvVGFibGUuQ2VsbCA9IEluZm9UYWJsZUNlbGxcbiJdfQ== */"));
20
20
  const InfoTable = ({
21
21
  children,
22
- width
23
- }) => /* @__PURE__ */ jsx(StyledDl, { width, children });
22
+ width,
23
+ className,
24
+ "data-testid": dataTestId
25
+ }) => /* @__PURE__ */ jsx(StyledDl, { className, "data-testid": dataTestId, width, children });
24
26
  InfoTable.Row = InfoTableRow;
25
27
  InfoTable.Cell = InfoTableCell;
26
28
  export {
@@ -21,7 +21,7 @@ const StyledNav = /* @__PURE__ */ _styled__default.default("nav", process.env.NO
21
21
  label: "StyledNav"
22
22
  })("display:flex;flex-direction:row;position:relative;border-right:1px solid ", ({
23
23
  theme
24
- }) => theme.colors.neutral.borderWeak, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx"],"names":[],"mappings":"AAgB4B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { Stack } from '@ultraviolet/ui'\nimport { useEffect, useRef } from 'react'\nimport {\n  ANIMATION_DURATION,\n  NAVIGATION_COLLASPED_WIDTH,\n  NAVIGATION_MAX_WIDTH,\n  NAVIGATION_MIN_WIDTH,\n} from './constants'\nimport { Footer } from './Footer'\nimport { Header } from './Header'\nimport { useNavigation } from './NavigationProvider'\nimport type { NavigationProps } from './types'\n\nconst StyledNav = styled.nav`\n  display: flex;\n  flex-direction: row;\n  position: relative;\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.borderWeak};\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['width'].includes(prop),\n})<{\n  width: number\n}>`\n  background: ${({ theme }) => theme.colors.neutral.background};\n  display: flex;\n  flex-direction: column;\n\n  width: ${({ width }) => width}px;\n\n  &[data-expanded=\"true\"][data-animation=\"false\"] {\n    max-width: ${NAVIGATION_MAX_WIDTH}px;\n    min-width: ${NAVIGATION_MIN_WIDTH}px;\n  }\n\n  &[data-expanded=\"false\"] {\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n\n  &[data-animation=\"expand\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${({ width }) => width}px;\n  }\n\n  &[data-animation=\"collapse\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n`\n\nconst ContentContainer = styled.div`\n  overflow: hidden;\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n`\n\nconst Content = styled(Stack)`\n  overflow-y: auto;\n  overflow-x: hidden;\n  flex-grow: 1;\n\n  &[data-is-expanded=\"false\"] {\n    align-items: center;\n    padding: ${({ theme }) => theme.space['2']};\n  }\n\n  &[data-is-expanded=\"true\"],\n  &[data-animation=\"expand\"] {\n    padding: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst Slider = styled.div`\n  background: transparent;\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  right: 0;\n  width: 6px;\n  cursor: col-resize;\n  border-right: 2px solid transparent;\n  display: flex;\n\n  &:hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nexport const NavigationContent = ({\n  children,\n  logo,\n  onWidthResize,\n  className,\n  id,\n  onToggleExpand,\n}: NavigationProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation should be inside NavigationProvider to use it properly.',\n    )\n  }\n\n  const {\n    setWidth,\n    width,\n    expanded,\n    toggleExpand,\n    animation,\n    navigationRef,\n    allowNavigationResize,\n    shouldAnimate,\n  } = context\n\n  const sliderRef = useRef<HTMLDivElement | null>(null)\n  const contentRef = useRef<HTMLDivElement | null>(null)\n\n  // It will handle the resize of the navigation when the user drag the vertical bar\n  useEffect(() => {\n    let prevX: number | undefined\n    let navRect: DOMRect | undefined\n    let shouldCollapseOnMouseUp = false\n    let shouldExpandOnMouseUp = false\n\n    const mouseMove = (event: MouseEvent) => {\n      if (prevX !== undefined) {\n        const navWidth = navRect?.width ?? 0\n        const newWidth = navWidth + (event.clientX - prevX)\n\n        if (navigationRef.current && expanded) {\n          navigationRef.current.style.width = `${newWidth}px`\n        }\n\n        if (newWidth <= NAVIGATION_MIN_WIDTH) {\n          shouldCollapseOnMouseUp = true\n        } else {\n          shouldCollapseOnMouseUp = false\n        }\n\n        if (newWidth >= NAVIGATION_COLLASPED_WIDTH && !expanded) {\n          shouldExpandOnMouseUp = true\n        } else {\n          shouldExpandOnMouseUp = false\n        }\n      }\n    }\n\n    const mousedown = (event: MouseEvent) => {\n      document.body.style.pointerEvents = 'none'\n      document.body.style.userSelect = 'none'\n\n      prevX = event.clientX\n      navRect = navigationRef.current?.getBoundingClientRect()\n\n      const mouseup = () => {\n        if (shouldCollapseOnMouseUp || shouldExpandOnMouseUp) {\n          toggleExpand()\n          onToggleExpand?.(!expanded)\n        }\n\n        if (navigationRef.current) {\n          if (!shouldCollapseOnMouseUp && !shouldExpandOnMouseUp) {\n            onWidthResize?.(navigationRef.current.offsetWidth)\n            setWidth?.(navigationRef.current.offsetWidth)\n          }\n\n          if (!expanded) {\n            navigationRef.current.style.width = ''\n          }\n        }\n\n        document.removeEventListener('mousemove', mouseMove)\n        window.removeEventListener('mouseup', mouseup)\n\n        document.body.style.pointerEvents = ''\n        document.body.style.userSelect = ''\n      }\n\n      document.addEventListener('mousemove', mouseMove)\n      window.addEventListener('mouseup', mouseup)\n    }\n    const sliderRefCurrent = sliderRef.current\n\n    sliderRefCurrent?.addEventListener('mousedown', mousedown)\n\n    return () => {\n      sliderRefCurrent?.removeEventListener('mousedown', mousedown)\n    }\n  }, [\n    expanded,\n    navigationRef,\n    onToggleExpand,\n    onWidthResize,\n    setWidth,\n    toggleExpand,\n  ])\n\n  return (\n    <StyledNav className={className} id={id}>\n      <Container\n        data-animation={shouldAnimate ? animation : undefined}\n        data-expanded={expanded}\n        ref={navigationRef}\n        width={width}\n      >\n        {logo ? <Header logo={logo} /> : null}\n        <ContentContainer>\n          <Content\n            data-animation={shouldAnimate ? animation : undefined}\n            data-is-expanded={expanded}\n            gap={0.25}\n            ref={contentRef}\n          >\n            {children}\n          </Content>\n          {allowNavigationResize ? (\n            <Footer contentRef={contentRef} onToggleExpand={onToggleExpand} />\n          ) : null}\n        </ContentContainer>\n      </Container>\n      {allowNavigationResize ? (\n        <Slider data-testid=\"slider\" ref={sliderRef} />\n      ) : null}\n    </StyledNav>\n  )\n}\n"]} */"));
24
+ }) => theme.colors.neutral.borderWeak, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx"],"names":[],"mappings":"AAgB4B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { Stack } from '@ultraviolet/ui'\nimport { useEffect, useRef } from 'react'\nimport {\n  ANIMATION_DURATION,\n  NAVIGATION_COLLASPED_WIDTH,\n  NAVIGATION_MAX_WIDTH,\n  NAVIGATION_MIN_WIDTH,\n} from './constants'\nimport { Footer } from './Footer'\nimport { Header } from './Header'\nimport { useNavigation } from './NavigationProvider'\nimport type { NavigationProps } from './types'\n\nconst StyledNav = styled.nav`\n  display: flex;\n  flex-direction: row;\n  position: relative;\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.borderWeak};\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['width'].includes(prop),\n})<{\n  width: number\n}>`\n  background: ${({ theme }) => theme.colors.neutral.background};\n  display: flex;\n  flex-direction: column;\n\n  width: ${({ width }) => width}px;\n\n  &[data-expanded=\"true\"][data-animation=\"false\"] {\n    max-width: ${NAVIGATION_MAX_WIDTH}px;\n    min-width: ${NAVIGATION_MIN_WIDTH}px;\n  }\n\n  &[data-expanded=\"false\"] {\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n\n  &[data-animation=\"expand\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${({ width }) => width}px;\n  }\n\n  &[data-animation=\"collapse\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n`\n\nconst ContentContainer = styled.div`\n  overflow: hidden;\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n`\n\nconst Content = styled(Stack)`\n  overflow-y: auto;\n  overflow-x: hidden;\n  flex-grow: 1;\n\n  &[data-is-expanded=\"false\"] {\n    align-items: center;\n    padding: ${({ theme }) => theme.space['2']};\n  }\n\n  &[data-is-expanded=\"true\"],\n  &[data-animation=\"expand\"] {\n    padding: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst Slider = styled.div`\n  background: transparent;\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  right: 0;\n  width: 6px;\n  cursor: col-resize;\n  border-right: 2px solid transparent;\n  display: flex;\n\n  &:hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nexport const NavigationContent = ({\n  children,\n  logo,\n  onWidthResize,\n  className,\n  'data-testid': dataTestId,\n  id,\n  onToggleExpand,\n}: NavigationProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation should be inside NavigationProvider to use it properly.',\n    )\n  }\n\n  const {\n    setWidth,\n    width,\n    expanded,\n    toggleExpand,\n    animation,\n    navigationRef,\n    allowNavigationResize,\n    shouldAnimate,\n  } = context\n\n  const sliderRef = useRef<HTMLDivElement | null>(null)\n  const contentRef = useRef<HTMLDivElement | null>(null)\n\n  // It will handle the resize of the navigation when the user drag the vertical bar\n  useEffect(() => {\n    let prevX: number | undefined\n    let navRect: DOMRect | undefined\n    let shouldCollapseOnMouseUp = false\n    let shouldExpandOnMouseUp = false\n\n    const mouseMove = (event: MouseEvent) => {\n      if (prevX !== undefined) {\n        const navWidth = navRect?.width ?? 0\n        const newWidth = navWidth + (event.clientX - prevX)\n\n        if (navigationRef.current && expanded) {\n          navigationRef.current.style.width = `${newWidth}px`\n        }\n\n        if (newWidth <= NAVIGATION_MIN_WIDTH) {\n          shouldCollapseOnMouseUp = true\n        } else {\n          shouldCollapseOnMouseUp = false\n        }\n\n        if (newWidth >= NAVIGATION_COLLASPED_WIDTH && !expanded) {\n          shouldExpandOnMouseUp = true\n        } else {\n          shouldExpandOnMouseUp = false\n        }\n      }\n    }\n\n    const mousedown = (event: MouseEvent) => {\n      document.body.style.pointerEvents = 'none'\n      document.body.style.userSelect = 'none'\n\n      prevX = event.clientX\n      navRect = navigationRef.current?.getBoundingClientRect()\n\n      const mouseup = () => {\n        if (shouldCollapseOnMouseUp || shouldExpandOnMouseUp) {\n          toggleExpand()\n          onToggleExpand?.(!expanded)\n        }\n\n        if (navigationRef.current) {\n          if (!shouldCollapseOnMouseUp && !shouldExpandOnMouseUp) {\n            onWidthResize?.(navigationRef.current.offsetWidth)\n            setWidth?.(navigationRef.current.offsetWidth)\n          }\n\n          if (!expanded) {\n            navigationRef.current.style.width = ''\n          }\n        }\n\n        document.removeEventListener('mousemove', mouseMove)\n        window.removeEventListener('mouseup', mouseup)\n\n        document.body.style.pointerEvents = ''\n        document.body.style.userSelect = ''\n      }\n\n      document.addEventListener('mousemove', mouseMove)\n      window.addEventListener('mouseup', mouseup)\n    }\n    const sliderRefCurrent = sliderRef.current\n\n    sliderRefCurrent?.addEventListener('mousedown', mousedown)\n\n    return () => {\n      sliderRefCurrent?.removeEventListener('mousedown', mousedown)\n    }\n  }, [\n    expanded,\n    navigationRef,\n    onToggleExpand,\n    onWidthResize,\n    setWidth,\n    toggleExpand,\n  ])\n\n  return (\n    <StyledNav className={className} data-testid={dataTestId} id={id}>\n      <Container\n        data-animation={shouldAnimate ? animation : undefined}\n        data-expanded={expanded}\n        ref={navigationRef}\n        width={width}\n      >\n        {logo ? <Header logo={logo} /> : null}\n        <ContentContainer>\n          <Content\n            data-animation={shouldAnimate ? animation : undefined}\n            data-is-expanded={expanded}\n            gap={0.25}\n            ref={contentRef}\n          >\n            {children}\n          </Content>\n          {allowNavigationResize ? (\n            <Footer contentRef={contentRef} onToggleExpand={onToggleExpand} />\n          ) : null}\n        </ContentContainer>\n      </Container>\n      {allowNavigationResize ? (\n        <Slider data-testid=\"slider\" ref={sliderRef} />\n      ) : null}\n    </StyledNav>\n  )\n}\n"]} */"));
25
25
  const Container = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
26
26
  shouldForwardProp: (prop) => !["width"].includes(prop),
27
27
  target: "esezfu53"
@@ -35,7 +35,7 @@ const Container = /* @__PURE__ */ _styled__default.default("div", process.env.NO
35
35
  width
36
36
  }) => width, 'px;&[data-expanded="true"][data-animation="false"]{max-width:', constants.NAVIGATION_MAX_WIDTH, "px;min-width:", constants.NAVIGATION_MIN_WIDTH, 'px;}&[data-expanded="false"]{width:', constants.NAVIGATION_COLLASPED_WIDTH, 'px;}&[data-animation="expand"]{transition:width ', constants.ANIMATION_DURATION, "ms ease-in-out;width:", ({
37
37
  width
38
- }) => width, 'px;}&[data-animation="collapse"]{transition:width ', constants.ANIMATION_DURATION, "ms ease-in-out;width:", constants.NAVIGATION_COLLASPED_WIDTH, "px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx"],"names":[],"mappings":"AA2BE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { Stack } from '@ultraviolet/ui'\nimport { useEffect, useRef } from 'react'\nimport {\n  ANIMATION_DURATION,\n  NAVIGATION_COLLASPED_WIDTH,\n  NAVIGATION_MAX_WIDTH,\n  NAVIGATION_MIN_WIDTH,\n} from './constants'\nimport { Footer } from './Footer'\nimport { Header } from './Header'\nimport { useNavigation } from './NavigationProvider'\nimport type { NavigationProps } from './types'\n\nconst StyledNav = styled.nav`\n  display: flex;\n  flex-direction: row;\n  position: relative;\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.borderWeak};\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['width'].includes(prop),\n})<{\n  width: number\n}>`\n  background: ${({ theme }) => theme.colors.neutral.background};\n  display: flex;\n  flex-direction: column;\n\n  width: ${({ width }) => width}px;\n\n  &[data-expanded=\"true\"][data-animation=\"false\"] {\n    max-width: ${NAVIGATION_MAX_WIDTH}px;\n    min-width: ${NAVIGATION_MIN_WIDTH}px;\n  }\n\n  &[data-expanded=\"false\"] {\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n\n  &[data-animation=\"expand\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${({ width }) => width}px;\n  }\n\n  &[data-animation=\"collapse\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n`\n\nconst ContentContainer = styled.div`\n  overflow: hidden;\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n`\n\nconst Content = styled(Stack)`\n  overflow-y: auto;\n  overflow-x: hidden;\n  flex-grow: 1;\n\n  &[data-is-expanded=\"false\"] {\n    align-items: center;\n    padding: ${({ theme }) => theme.space['2']};\n  }\n\n  &[data-is-expanded=\"true\"],\n  &[data-animation=\"expand\"] {\n    padding: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst Slider = styled.div`\n  background: transparent;\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  right: 0;\n  width: 6px;\n  cursor: col-resize;\n  border-right: 2px solid transparent;\n  display: flex;\n\n  &:hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nexport const NavigationContent = ({\n  children,\n  logo,\n  onWidthResize,\n  className,\n  id,\n  onToggleExpand,\n}: NavigationProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation should be inside NavigationProvider to use it properly.',\n    )\n  }\n\n  const {\n    setWidth,\n    width,\n    expanded,\n    toggleExpand,\n    animation,\n    navigationRef,\n    allowNavigationResize,\n    shouldAnimate,\n  } = context\n\n  const sliderRef = useRef<HTMLDivElement | null>(null)\n  const contentRef = useRef<HTMLDivElement | null>(null)\n\n  // It will handle the resize of the navigation when the user drag the vertical bar\n  useEffect(() => {\n    let prevX: number | undefined\n    let navRect: DOMRect | undefined\n    let shouldCollapseOnMouseUp = false\n    let shouldExpandOnMouseUp = false\n\n    const mouseMove = (event: MouseEvent) => {\n      if (prevX !== undefined) {\n        const navWidth = navRect?.width ?? 0\n        const newWidth = navWidth + (event.clientX - prevX)\n\n        if (navigationRef.current && expanded) {\n          navigationRef.current.style.width = `${newWidth}px`\n        }\n\n        if (newWidth <= NAVIGATION_MIN_WIDTH) {\n          shouldCollapseOnMouseUp = true\n        } else {\n          shouldCollapseOnMouseUp = false\n        }\n\n        if (newWidth >= NAVIGATION_COLLASPED_WIDTH && !expanded) {\n          shouldExpandOnMouseUp = true\n        } else {\n          shouldExpandOnMouseUp = false\n        }\n      }\n    }\n\n    const mousedown = (event: MouseEvent) => {\n      document.body.style.pointerEvents = 'none'\n      document.body.style.userSelect = 'none'\n\n      prevX = event.clientX\n      navRect = navigationRef.current?.getBoundingClientRect()\n\n      const mouseup = () => {\n        if (shouldCollapseOnMouseUp || shouldExpandOnMouseUp) {\n          toggleExpand()\n          onToggleExpand?.(!expanded)\n        }\n\n        if (navigationRef.current) {\n          if (!shouldCollapseOnMouseUp && !shouldExpandOnMouseUp) {\n            onWidthResize?.(navigationRef.current.offsetWidth)\n            setWidth?.(navigationRef.current.offsetWidth)\n          }\n\n          if (!expanded) {\n            navigationRef.current.style.width = ''\n          }\n        }\n\n        document.removeEventListener('mousemove', mouseMove)\n        window.removeEventListener('mouseup', mouseup)\n\n        document.body.style.pointerEvents = ''\n        document.body.style.userSelect = ''\n      }\n\n      document.addEventListener('mousemove', mouseMove)\n      window.addEventListener('mouseup', mouseup)\n    }\n    const sliderRefCurrent = sliderRef.current\n\n    sliderRefCurrent?.addEventListener('mousedown', mousedown)\n\n    return () => {\n      sliderRefCurrent?.removeEventListener('mousedown', mousedown)\n    }\n  }, [\n    expanded,\n    navigationRef,\n    onToggleExpand,\n    onWidthResize,\n    setWidth,\n    toggleExpand,\n  ])\n\n  return (\n    <StyledNav className={className} id={id}>\n      <Container\n        data-animation={shouldAnimate ? animation : undefined}\n        data-expanded={expanded}\n        ref={navigationRef}\n        width={width}\n      >\n        {logo ? <Header logo={logo} /> : null}\n        <ContentContainer>\n          <Content\n            data-animation={shouldAnimate ? animation : undefined}\n            data-is-expanded={expanded}\n            gap={0.25}\n            ref={contentRef}\n          >\n            {children}\n          </Content>\n          {allowNavigationResize ? (\n            <Footer contentRef={contentRef} onToggleExpand={onToggleExpand} />\n          ) : null}\n        </ContentContainer>\n      </Container>\n      {allowNavigationResize ? (\n        <Slider data-testid=\"slider\" ref={sliderRef} />\n      ) : null}\n    </StyledNav>\n  )\n}\n"]} */"));
38
+ }) => width, 'px;}&[data-animation="collapse"]{transition:width ', constants.ANIMATION_DURATION, "ms ease-in-out;width:", constants.NAVIGATION_COLLASPED_WIDTH, "px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx"],"names":[],"mappings":"AA2BE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { Stack } from '@ultraviolet/ui'\nimport { useEffect, useRef } from 'react'\nimport {\n  ANIMATION_DURATION,\n  NAVIGATION_COLLASPED_WIDTH,\n  NAVIGATION_MAX_WIDTH,\n  NAVIGATION_MIN_WIDTH,\n} from './constants'\nimport { Footer } from './Footer'\nimport { Header } from './Header'\nimport { useNavigation } from './NavigationProvider'\nimport type { NavigationProps } from './types'\n\nconst StyledNav = styled.nav`\n  display: flex;\n  flex-direction: row;\n  position: relative;\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.borderWeak};\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['width'].includes(prop),\n})<{\n  width: number\n}>`\n  background: ${({ theme }) => theme.colors.neutral.background};\n  display: flex;\n  flex-direction: column;\n\n  width: ${({ width }) => width}px;\n\n  &[data-expanded=\"true\"][data-animation=\"false\"] {\n    max-width: ${NAVIGATION_MAX_WIDTH}px;\n    min-width: ${NAVIGATION_MIN_WIDTH}px;\n  }\n\n  &[data-expanded=\"false\"] {\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n\n  &[data-animation=\"expand\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${({ width }) => width}px;\n  }\n\n  &[data-animation=\"collapse\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n`\n\nconst ContentContainer = styled.div`\n  overflow: hidden;\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n`\n\nconst Content = styled(Stack)`\n  overflow-y: auto;\n  overflow-x: hidden;\n  flex-grow: 1;\n\n  &[data-is-expanded=\"false\"] {\n    align-items: center;\n    padding: ${({ theme }) => theme.space['2']};\n  }\n\n  &[data-is-expanded=\"true\"],\n  &[data-animation=\"expand\"] {\n    padding: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst Slider = styled.div`\n  background: transparent;\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  right: 0;\n  width: 6px;\n  cursor: col-resize;\n  border-right: 2px solid transparent;\n  display: flex;\n\n  &:hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nexport const NavigationContent = ({\n  children,\n  logo,\n  onWidthResize,\n  className,\n  'data-testid': dataTestId,\n  id,\n  onToggleExpand,\n}: NavigationProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation should be inside NavigationProvider to use it properly.',\n    )\n  }\n\n  const {\n    setWidth,\n    width,\n    expanded,\n    toggleExpand,\n    animation,\n    navigationRef,\n    allowNavigationResize,\n    shouldAnimate,\n  } = context\n\n  const sliderRef = useRef<HTMLDivElement | null>(null)\n  const contentRef = useRef<HTMLDivElement | null>(null)\n\n  // It will handle the resize of the navigation when the user drag the vertical bar\n  useEffect(() => {\n    let prevX: number | undefined\n    let navRect: DOMRect | undefined\n    let shouldCollapseOnMouseUp = false\n    let shouldExpandOnMouseUp = false\n\n    const mouseMove = (event: MouseEvent) => {\n      if (prevX !== undefined) {\n        const navWidth = navRect?.width ?? 0\n        const newWidth = navWidth + (event.clientX - prevX)\n\n        if (navigationRef.current && expanded) {\n          navigationRef.current.style.width = `${newWidth}px`\n        }\n\n        if (newWidth <= NAVIGATION_MIN_WIDTH) {\n          shouldCollapseOnMouseUp = true\n        } else {\n          shouldCollapseOnMouseUp = false\n        }\n\n        if (newWidth >= NAVIGATION_COLLASPED_WIDTH && !expanded) {\n          shouldExpandOnMouseUp = true\n        } else {\n          shouldExpandOnMouseUp = false\n        }\n      }\n    }\n\n    const mousedown = (event: MouseEvent) => {\n      document.body.style.pointerEvents = 'none'\n      document.body.style.userSelect = 'none'\n\n      prevX = event.clientX\n      navRect = navigationRef.current?.getBoundingClientRect()\n\n      const mouseup = () => {\n        if (shouldCollapseOnMouseUp || shouldExpandOnMouseUp) {\n          toggleExpand()\n          onToggleExpand?.(!expanded)\n        }\n\n        if (navigationRef.current) {\n          if (!shouldCollapseOnMouseUp && !shouldExpandOnMouseUp) {\n            onWidthResize?.(navigationRef.current.offsetWidth)\n            setWidth?.(navigationRef.current.offsetWidth)\n          }\n\n          if (!expanded) {\n            navigationRef.current.style.width = ''\n          }\n        }\n\n        document.removeEventListener('mousemove', mouseMove)\n        window.removeEventListener('mouseup', mouseup)\n\n        document.body.style.pointerEvents = ''\n        document.body.style.userSelect = ''\n      }\n\n      document.addEventListener('mousemove', mouseMove)\n      window.addEventListener('mouseup', mouseup)\n    }\n    const sliderRefCurrent = sliderRef.current\n\n    sliderRefCurrent?.addEventListener('mousedown', mousedown)\n\n    return () => {\n      sliderRefCurrent?.removeEventListener('mousedown', mousedown)\n    }\n  }, [\n    expanded,\n    navigationRef,\n    onToggleExpand,\n    onWidthResize,\n    setWidth,\n    toggleExpand,\n  ])\n\n  return (\n    <StyledNav className={className} data-testid={dataTestId} id={id}>\n      <Container\n        data-animation={shouldAnimate ? animation : undefined}\n        data-expanded={expanded}\n        ref={navigationRef}\n        width={width}\n      >\n        {logo ? <Header logo={logo} /> : null}\n        <ContentContainer>\n          <Content\n            data-animation={shouldAnimate ? animation : undefined}\n            data-is-expanded={expanded}\n            gap={0.25}\n            ref={contentRef}\n          >\n            {children}\n          </Content>\n          {allowNavigationResize ? (\n            <Footer contentRef={contentRef} onToggleExpand={onToggleExpand} />\n          ) : null}\n        </ContentContainer>\n      </Container>\n      {allowNavigationResize ? (\n        <Slider data-testid=\"slider\" ref={sliderRef} />\n      ) : null}\n    </StyledNav>\n  )\n}\n"]} */"));
39
39
  const ContentContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
40
40
  target: "esezfu52"
41
41
  } : {
@@ -46,7 +46,7 @@ const ContentContainer = /* @__PURE__ */ _styled__default.default("div", process
46
46
  styles: "overflow:hidden;display:flex;flex-direction:column;flex-grow:1"
47
47
  } : {
48
48
  name: "12is9id",
49
- styles: "overflow:hidden;display:flex;flex-direction:column;flex-grow:1/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx"],"names":[],"mappings":"AAsDmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { Stack } from '@ultraviolet/ui'\nimport { useEffect, useRef } from 'react'\nimport {\n  ANIMATION_DURATION,\n  NAVIGATION_COLLASPED_WIDTH,\n  NAVIGATION_MAX_WIDTH,\n  NAVIGATION_MIN_WIDTH,\n} from './constants'\nimport { Footer } from './Footer'\nimport { Header } from './Header'\nimport { useNavigation } from './NavigationProvider'\nimport type { NavigationProps } from './types'\n\nconst StyledNav = styled.nav`\n  display: flex;\n  flex-direction: row;\n  position: relative;\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.borderWeak};\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['width'].includes(prop),\n})<{\n  width: number\n}>`\n  background: ${({ theme }) => theme.colors.neutral.background};\n  display: flex;\n  flex-direction: column;\n\n  width: ${({ width }) => width}px;\n\n  &[data-expanded=\"true\"][data-animation=\"false\"] {\n    max-width: ${NAVIGATION_MAX_WIDTH}px;\n    min-width: ${NAVIGATION_MIN_WIDTH}px;\n  }\n\n  &[data-expanded=\"false\"] {\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n\n  &[data-animation=\"expand\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${({ width }) => width}px;\n  }\n\n  &[data-animation=\"collapse\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n`\n\nconst ContentContainer = styled.div`\n  overflow: hidden;\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n`\n\nconst Content = styled(Stack)`\n  overflow-y: auto;\n  overflow-x: hidden;\n  flex-grow: 1;\n\n  &[data-is-expanded=\"false\"] {\n    align-items: center;\n    padding: ${({ theme }) => theme.space['2']};\n  }\n\n  &[data-is-expanded=\"true\"],\n  &[data-animation=\"expand\"] {\n    padding: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst Slider = styled.div`\n  background: transparent;\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  right: 0;\n  width: 6px;\n  cursor: col-resize;\n  border-right: 2px solid transparent;\n  display: flex;\n\n  &:hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nexport const NavigationContent = ({\n  children,\n  logo,\n  onWidthResize,\n  className,\n  id,\n  onToggleExpand,\n}: NavigationProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation should be inside NavigationProvider to use it properly.',\n    )\n  }\n\n  const {\n    setWidth,\n    width,\n    expanded,\n    toggleExpand,\n    animation,\n    navigationRef,\n    allowNavigationResize,\n    shouldAnimate,\n  } = context\n\n  const sliderRef = useRef<HTMLDivElement | null>(null)\n  const contentRef = useRef<HTMLDivElement | null>(null)\n\n  // It will handle the resize of the navigation when the user drag the vertical bar\n  useEffect(() => {\n    let prevX: number | undefined\n    let navRect: DOMRect | undefined\n    let shouldCollapseOnMouseUp = false\n    let shouldExpandOnMouseUp = false\n\n    const mouseMove = (event: MouseEvent) => {\n      if (prevX !== undefined) {\n        const navWidth = navRect?.width ?? 0\n        const newWidth = navWidth + (event.clientX - prevX)\n\n        if (navigationRef.current && expanded) {\n          navigationRef.current.style.width = `${newWidth}px`\n        }\n\n        if (newWidth <= NAVIGATION_MIN_WIDTH) {\n          shouldCollapseOnMouseUp = true\n        } else {\n          shouldCollapseOnMouseUp = false\n        }\n\n        if (newWidth >= NAVIGATION_COLLASPED_WIDTH && !expanded) {\n          shouldExpandOnMouseUp = true\n        } else {\n          shouldExpandOnMouseUp = false\n        }\n      }\n    }\n\n    const mousedown = (event: MouseEvent) => {\n      document.body.style.pointerEvents = 'none'\n      document.body.style.userSelect = 'none'\n\n      prevX = event.clientX\n      navRect = navigationRef.current?.getBoundingClientRect()\n\n      const mouseup = () => {\n        if (shouldCollapseOnMouseUp || shouldExpandOnMouseUp) {\n          toggleExpand()\n          onToggleExpand?.(!expanded)\n        }\n\n        if (navigationRef.current) {\n          if (!shouldCollapseOnMouseUp && !shouldExpandOnMouseUp) {\n            onWidthResize?.(navigationRef.current.offsetWidth)\n            setWidth?.(navigationRef.current.offsetWidth)\n          }\n\n          if (!expanded) {\n            navigationRef.current.style.width = ''\n          }\n        }\n\n        document.removeEventListener('mousemove', mouseMove)\n        window.removeEventListener('mouseup', mouseup)\n\n        document.body.style.pointerEvents = ''\n        document.body.style.userSelect = ''\n      }\n\n      document.addEventListener('mousemove', mouseMove)\n      window.addEventListener('mouseup', mouseup)\n    }\n    const sliderRefCurrent = sliderRef.current\n\n    sliderRefCurrent?.addEventListener('mousedown', mousedown)\n\n    return () => {\n      sliderRefCurrent?.removeEventListener('mousedown', mousedown)\n    }\n  }, [\n    expanded,\n    navigationRef,\n    onToggleExpand,\n    onWidthResize,\n    setWidth,\n    toggleExpand,\n  ])\n\n  return (\n    <StyledNav className={className} id={id}>\n      <Container\n        data-animation={shouldAnimate ? animation : undefined}\n        data-expanded={expanded}\n        ref={navigationRef}\n        width={width}\n      >\n        {logo ? <Header logo={logo} /> : null}\n        <ContentContainer>\n          <Content\n            data-animation={shouldAnimate ? animation : undefined}\n            data-is-expanded={expanded}\n            gap={0.25}\n            ref={contentRef}\n          >\n            {children}\n          </Content>\n          {allowNavigationResize ? (\n            <Footer contentRef={contentRef} onToggleExpand={onToggleExpand} />\n          ) : null}\n        </ContentContainer>\n      </Container>\n      {allowNavigationResize ? (\n        <Slider data-testid=\"slider\" ref={sliderRef} />\n      ) : null}\n    </StyledNav>\n  )\n}\n"]} */",
49
+ styles: "overflow:hidden;display:flex;flex-direction:column;flex-grow:1/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx"],"names":[],"mappings":"AAsDmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { Stack } from '@ultraviolet/ui'\nimport { useEffect, useRef } from 'react'\nimport {\n  ANIMATION_DURATION,\n  NAVIGATION_COLLASPED_WIDTH,\n  NAVIGATION_MAX_WIDTH,\n  NAVIGATION_MIN_WIDTH,\n} from './constants'\nimport { Footer } from './Footer'\nimport { Header } from './Header'\nimport { useNavigation } from './NavigationProvider'\nimport type { NavigationProps } from './types'\n\nconst StyledNav = styled.nav`\n  display: flex;\n  flex-direction: row;\n  position: relative;\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.borderWeak};\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['width'].includes(prop),\n})<{\n  width: number\n}>`\n  background: ${({ theme }) => theme.colors.neutral.background};\n  display: flex;\n  flex-direction: column;\n\n  width: ${({ width }) => width}px;\n\n  &[data-expanded=\"true\"][data-animation=\"false\"] {\n    max-width: ${NAVIGATION_MAX_WIDTH}px;\n    min-width: ${NAVIGATION_MIN_WIDTH}px;\n  }\n\n  &[data-expanded=\"false\"] {\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n\n  &[data-animation=\"expand\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${({ width }) => width}px;\n  }\n\n  &[data-animation=\"collapse\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n`\n\nconst ContentContainer = styled.div`\n  overflow: hidden;\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n`\n\nconst Content = styled(Stack)`\n  overflow-y: auto;\n  overflow-x: hidden;\n  flex-grow: 1;\n\n  &[data-is-expanded=\"false\"] {\n    align-items: center;\n    padding: ${({ theme }) => theme.space['2']};\n  }\n\n  &[data-is-expanded=\"true\"],\n  &[data-animation=\"expand\"] {\n    padding: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst Slider = styled.div`\n  background: transparent;\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  right: 0;\n  width: 6px;\n  cursor: col-resize;\n  border-right: 2px solid transparent;\n  display: flex;\n\n  &:hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nexport const NavigationContent = ({\n  children,\n  logo,\n  onWidthResize,\n  className,\n  'data-testid': dataTestId,\n  id,\n  onToggleExpand,\n}: NavigationProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation should be inside NavigationProvider to use it properly.',\n    )\n  }\n\n  const {\n    setWidth,\n    width,\n    expanded,\n    toggleExpand,\n    animation,\n    navigationRef,\n    allowNavigationResize,\n    shouldAnimate,\n  } = context\n\n  const sliderRef = useRef<HTMLDivElement | null>(null)\n  const contentRef = useRef<HTMLDivElement | null>(null)\n\n  // It will handle the resize of the navigation when the user drag the vertical bar\n  useEffect(() => {\n    let prevX: number | undefined\n    let navRect: DOMRect | undefined\n    let shouldCollapseOnMouseUp = false\n    let shouldExpandOnMouseUp = false\n\n    const mouseMove = (event: MouseEvent) => {\n      if (prevX !== undefined) {\n        const navWidth = navRect?.width ?? 0\n        const newWidth = navWidth + (event.clientX - prevX)\n\n        if (navigationRef.current && expanded) {\n          navigationRef.current.style.width = `${newWidth}px`\n        }\n\n        if (newWidth <= NAVIGATION_MIN_WIDTH) {\n          shouldCollapseOnMouseUp = true\n        } else {\n          shouldCollapseOnMouseUp = false\n        }\n\n        if (newWidth >= NAVIGATION_COLLASPED_WIDTH && !expanded) {\n          shouldExpandOnMouseUp = true\n        } else {\n          shouldExpandOnMouseUp = false\n        }\n      }\n    }\n\n    const mousedown = (event: MouseEvent) => {\n      document.body.style.pointerEvents = 'none'\n      document.body.style.userSelect = 'none'\n\n      prevX = event.clientX\n      navRect = navigationRef.current?.getBoundingClientRect()\n\n      const mouseup = () => {\n        if (shouldCollapseOnMouseUp || shouldExpandOnMouseUp) {\n          toggleExpand()\n          onToggleExpand?.(!expanded)\n        }\n\n        if (navigationRef.current) {\n          if (!shouldCollapseOnMouseUp && !shouldExpandOnMouseUp) {\n            onWidthResize?.(navigationRef.current.offsetWidth)\n            setWidth?.(navigationRef.current.offsetWidth)\n          }\n\n          if (!expanded) {\n            navigationRef.current.style.width = ''\n          }\n        }\n\n        document.removeEventListener('mousemove', mouseMove)\n        window.removeEventListener('mouseup', mouseup)\n\n        document.body.style.pointerEvents = ''\n        document.body.style.userSelect = ''\n      }\n\n      document.addEventListener('mousemove', mouseMove)\n      window.addEventListener('mouseup', mouseup)\n    }\n    const sliderRefCurrent = sliderRef.current\n\n    sliderRefCurrent?.addEventListener('mousedown', mousedown)\n\n    return () => {\n      sliderRefCurrent?.removeEventListener('mousedown', mousedown)\n    }\n  }, [\n    expanded,\n    navigationRef,\n    onToggleExpand,\n    onWidthResize,\n    setWidth,\n    toggleExpand,\n  ])\n\n  return (\n    <StyledNav className={className} data-testid={dataTestId} id={id}>\n      <Container\n        data-animation={shouldAnimate ? animation : undefined}\n        data-expanded={expanded}\n        ref={navigationRef}\n        width={width}\n      >\n        {logo ? <Header logo={logo} /> : null}\n        <ContentContainer>\n          <Content\n            data-animation={shouldAnimate ? animation : undefined}\n            data-is-expanded={expanded}\n            gap={0.25}\n            ref={contentRef}\n          >\n            {children}\n          </Content>\n          {allowNavigationResize ? (\n            <Footer contentRef={contentRef} onToggleExpand={onToggleExpand} />\n          ) : null}\n        </ContentContainer>\n      </Container>\n      {allowNavigationResize ? (\n        <Slider data-testid=\"slider\" ref={sliderRef} />\n      ) : null}\n    </StyledNav>\n  )\n}\n"]} */",
50
50
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
51
51
  });
52
52
  const Content = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
@@ -58,7 +58,7 @@ const Content = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.N
58
58
  theme
59
59
  }) => theme.space["2"], ';}&[data-is-expanded="true"],&[data-animation="expand"]{padding:', ({
60
60
  theme
61
- }) => theme.space["2"], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx"],"names":[],"mappings":"AA6D6B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { Stack } from '@ultraviolet/ui'\nimport { useEffect, useRef } from 'react'\nimport {\n  ANIMATION_DURATION,\n  NAVIGATION_COLLASPED_WIDTH,\n  NAVIGATION_MAX_WIDTH,\n  NAVIGATION_MIN_WIDTH,\n} from './constants'\nimport { Footer } from './Footer'\nimport { Header } from './Header'\nimport { useNavigation } from './NavigationProvider'\nimport type { NavigationProps } from './types'\n\nconst StyledNav = styled.nav`\n  display: flex;\n  flex-direction: row;\n  position: relative;\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.borderWeak};\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['width'].includes(prop),\n})<{\n  width: number\n}>`\n  background: ${({ theme }) => theme.colors.neutral.background};\n  display: flex;\n  flex-direction: column;\n\n  width: ${({ width }) => width}px;\n\n  &[data-expanded=\"true\"][data-animation=\"false\"] {\n    max-width: ${NAVIGATION_MAX_WIDTH}px;\n    min-width: ${NAVIGATION_MIN_WIDTH}px;\n  }\n\n  &[data-expanded=\"false\"] {\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n\n  &[data-animation=\"expand\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${({ width }) => width}px;\n  }\n\n  &[data-animation=\"collapse\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n`\n\nconst ContentContainer = styled.div`\n  overflow: hidden;\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n`\n\nconst Content = styled(Stack)`\n  overflow-y: auto;\n  overflow-x: hidden;\n  flex-grow: 1;\n\n  &[data-is-expanded=\"false\"] {\n    align-items: center;\n    padding: ${({ theme }) => theme.space['2']};\n  }\n\n  &[data-is-expanded=\"true\"],\n  &[data-animation=\"expand\"] {\n    padding: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst Slider = styled.div`\n  background: transparent;\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  right: 0;\n  width: 6px;\n  cursor: col-resize;\n  border-right: 2px solid transparent;\n  display: flex;\n\n  &:hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nexport const NavigationContent = ({\n  children,\n  logo,\n  onWidthResize,\n  className,\n  id,\n  onToggleExpand,\n}: NavigationProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation should be inside NavigationProvider to use it properly.',\n    )\n  }\n\n  const {\n    setWidth,\n    width,\n    expanded,\n    toggleExpand,\n    animation,\n    navigationRef,\n    allowNavigationResize,\n    shouldAnimate,\n  } = context\n\n  const sliderRef = useRef<HTMLDivElement | null>(null)\n  const contentRef = useRef<HTMLDivElement | null>(null)\n\n  // It will handle the resize of the navigation when the user drag the vertical bar\n  useEffect(() => {\n    let prevX: number | undefined\n    let navRect: DOMRect | undefined\n    let shouldCollapseOnMouseUp = false\n    let shouldExpandOnMouseUp = false\n\n    const mouseMove = (event: MouseEvent) => {\n      if (prevX !== undefined) {\n        const navWidth = navRect?.width ?? 0\n        const newWidth = navWidth + (event.clientX - prevX)\n\n        if (navigationRef.current && expanded) {\n          navigationRef.current.style.width = `${newWidth}px`\n        }\n\n        if (newWidth <= NAVIGATION_MIN_WIDTH) {\n          shouldCollapseOnMouseUp = true\n        } else {\n          shouldCollapseOnMouseUp = false\n        }\n\n        if (newWidth >= NAVIGATION_COLLASPED_WIDTH && !expanded) {\n          shouldExpandOnMouseUp = true\n        } else {\n          shouldExpandOnMouseUp = false\n        }\n      }\n    }\n\n    const mousedown = (event: MouseEvent) => {\n      document.body.style.pointerEvents = 'none'\n      document.body.style.userSelect = 'none'\n\n      prevX = event.clientX\n      navRect = navigationRef.current?.getBoundingClientRect()\n\n      const mouseup = () => {\n        if (shouldCollapseOnMouseUp || shouldExpandOnMouseUp) {\n          toggleExpand()\n          onToggleExpand?.(!expanded)\n        }\n\n        if (navigationRef.current) {\n          if (!shouldCollapseOnMouseUp && !shouldExpandOnMouseUp) {\n            onWidthResize?.(navigationRef.current.offsetWidth)\n            setWidth?.(navigationRef.current.offsetWidth)\n          }\n\n          if (!expanded) {\n            navigationRef.current.style.width = ''\n          }\n        }\n\n        document.removeEventListener('mousemove', mouseMove)\n        window.removeEventListener('mouseup', mouseup)\n\n        document.body.style.pointerEvents = ''\n        document.body.style.userSelect = ''\n      }\n\n      document.addEventListener('mousemove', mouseMove)\n      window.addEventListener('mouseup', mouseup)\n    }\n    const sliderRefCurrent = sliderRef.current\n\n    sliderRefCurrent?.addEventListener('mousedown', mousedown)\n\n    return () => {\n      sliderRefCurrent?.removeEventListener('mousedown', mousedown)\n    }\n  }, [\n    expanded,\n    navigationRef,\n    onToggleExpand,\n    onWidthResize,\n    setWidth,\n    toggleExpand,\n  ])\n\n  return (\n    <StyledNav className={className} id={id}>\n      <Container\n        data-animation={shouldAnimate ? animation : undefined}\n        data-expanded={expanded}\n        ref={navigationRef}\n        width={width}\n      >\n        {logo ? <Header logo={logo} /> : null}\n        <ContentContainer>\n          <Content\n            data-animation={shouldAnimate ? animation : undefined}\n            data-is-expanded={expanded}\n            gap={0.25}\n            ref={contentRef}\n          >\n            {children}\n          </Content>\n          {allowNavigationResize ? (\n            <Footer contentRef={contentRef} onToggleExpand={onToggleExpand} />\n          ) : null}\n        </ContentContainer>\n      </Container>\n      {allowNavigationResize ? (\n        <Slider data-testid=\"slider\" ref={sliderRef} />\n      ) : null}\n    </StyledNav>\n  )\n}\n"]} */"));
61
+ }) => theme.space["2"], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx"],"names":[],"mappings":"AA6D6B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { Stack } from '@ultraviolet/ui'\nimport { useEffect, useRef } from 'react'\nimport {\n  ANIMATION_DURATION,\n  NAVIGATION_COLLASPED_WIDTH,\n  NAVIGATION_MAX_WIDTH,\n  NAVIGATION_MIN_WIDTH,\n} from './constants'\nimport { Footer } from './Footer'\nimport { Header } from './Header'\nimport { useNavigation } from './NavigationProvider'\nimport type { NavigationProps } from './types'\n\nconst StyledNav = styled.nav`\n  display: flex;\n  flex-direction: row;\n  position: relative;\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.borderWeak};\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['width'].includes(prop),\n})<{\n  width: number\n}>`\n  background: ${({ theme }) => theme.colors.neutral.background};\n  display: flex;\n  flex-direction: column;\n\n  width: ${({ width }) => width}px;\n\n  &[data-expanded=\"true\"][data-animation=\"false\"] {\n    max-width: ${NAVIGATION_MAX_WIDTH}px;\n    min-width: ${NAVIGATION_MIN_WIDTH}px;\n  }\n\n  &[data-expanded=\"false\"] {\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n\n  &[data-animation=\"expand\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${({ width }) => width}px;\n  }\n\n  &[data-animation=\"collapse\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n`\n\nconst ContentContainer = styled.div`\n  overflow: hidden;\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n`\n\nconst Content = styled(Stack)`\n  overflow-y: auto;\n  overflow-x: hidden;\n  flex-grow: 1;\n\n  &[data-is-expanded=\"false\"] {\n    align-items: center;\n    padding: ${({ theme }) => theme.space['2']};\n  }\n\n  &[data-is-expanded=\"true\"],\n  &[data-animation=\"expand\"] {\n    padding: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst Slider = styled.div`\n  background: transparent;\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  right: 0;\n  width: 6px;\n  cursor: col-resize;\n  border-right: 2px solid transparent;\n  display: flex;\n\n  &:hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nexport const NavigationContent = ({\n  children,\n  logo,\n  onWidthResize,\n  className,\n  'data-testid': dataTestId,\n  id,\n  onToggleExpand,\n}: NavigationProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation should be inside NavigationProvider to use it properly.',\n    )\n  }\n\n  const {\n    setWidth,\n    width,\n    expanded,\n    toggleExpand,\n    animation,\n    navigationRef,\n    allowNavigationResize,\n    shouldAnimate,\n  } = context\n\n  const sliderRef = useRef<HTMLDivElement | null>(null)\n  const contentRef = useRef<HTMLDivElement | null>(null)\n\n  // It will handle the resize of the navigation when the user drag the vertical bar\n  useEffect(() => {\n    let prevX: number | undefined\n    let navRect: DOMRect | undefined\n    let shouldCollapseOnMouseUp = false\n    let shouldExpandOnMouseUp = false\n\n    const mouseMove = (event: MouseEvent) => {\n      if (prevX !== undefined) {\n        const navWidth = navRect?.width ?? 0\n        const newWidth = navWidth + (event.clientX - prevX)\n\n        if (navigationRef.current && expanded) {\n          navigationRef.current.style.width = `${newWidth}px`\n        }\n\n        if (newWidth <= NAVIGATION_MIN_WIDTH) {\n          shouldCollapseOnMouseUp = true\n        } else {\n          shouldCollapseOnMouseUp = false\n        }\n\n        if (newWidth >= NAVIGATION_COLLASPED_WIDTH && !expanded) {\n          shouldExpandOnMouseUp = true\n        } else {\n          shouldExpandOnMouseUp = false\n        }\n      }\n    }\n\n    const mousedown = (event: MouseEvent) => {\n      document.body.style.pointerEvents = 'none'\n      document.body.style.userSelect = 'none'\n\n      prevX = event.clientX\n      navRect = navigationRef.current?.getBoundingClientRect()\n\n      const mouseup = () => {\n        if (shouldCollapseOnMouseUp || shouldExpandOnMouseUp) {\n          toggleExpand()\n          onToggleExpand?.(!expanded)\n        }\n\n        if (navigationRef.current) {\n          if (!shouldCollapseOnMouseUp && !shouldExpandOnMouseUp) {\n            onWidthResize?.(navigationRef.current.offsetWidth)\n            setWidth?.(navigationRef.current.offsetWidth)\n          }\n\n          if (!expanded) {\n            navigationRef.current.style.width = ''\n          }\n        }\n\n        document.removeEventListener('mousemove', mouseMove)\n        window.removeEventListener('mouseup', mouseup)\n\n        document.body.style.pointerEvents = ''\n        document.body.style.userSelect = ''\n      }\n\n      document.addEventListener('mousemove', mouseMove)\n      window.addEventListener('mouseup', mouseup)\n    }\n    const sliderRefCurrent = sliderRef.current\n\n    sliderRefCurrent?.addEventListener('mousedown', mousedown)\n\n    return () => {\n      sliderRefCurrent?.removeEventListener('mousedown', mousedown)\n    }\n  }, [\n    expanded,\n    navigationRef,\n    onToggleExpand,\n    onWidthResize,\n    setWidth,\n    toggleExpand,\n  ])\n\n  return (\n    <StyledNav className={className} data-testid={dataTestId} id={id}>\n      <Container\n        data-animation={shouldAnimate ? animation : undefined}\n        data-expanded={expanded}\n        ref={navigationRef}\n        width={width}\n      >\n        {logo ? <Header logo={logo} /> : null}\n        <ContentContainer>\n          <Content\n            data-animation={shouldAnimate ? animation : undefined}\n            data-is-expanded={expanded}\n            gap={0.25}\n            ref={contentRef}\n          >\n            {children}\n          </Content>\n          {allowNavigationResize ? (\n            <Footer contentRef={contentRef} onToggleExpand={onToggleExpand} />\n          ) : null}\n        </ContentContainer>\n      </Container>\n      {allowNavigationResize ? (\n        <Slider data-testid=\"slider\" ref={sliderRef} />\n      ) : null}\n    </StyledNav>\n  )\n}\n"]} */"));
62
62
  const Slider = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
63
63
  target: "esezfu50"
64
64
  } : {
@@ -66,12 +66,13 @@ const Slider = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_
66
66
  label: "Slider"
67
67
  })("background:transparent;position:absolute;top:0;bottom:0;right:0;width:6px;cursor:col-resize;border-right:2px solid transparent;display:flex;&:hover{border-color:", ({
68
68
  theme
69
- }) => theme.colors.primary.border, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx"],"names":[],"mappings":"AA6EyB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { Stack } from '@ultraviolet/ui'\nimport { useEffect, useRef } from 'react'\nimport {\n  ANIMATION_DURATION,\n  NAVIGATION_COLLASPED_WIDTH,\n  NAVIGATION_MAX_WIDTH,\n  NAVIGATION_MIN_WIDTH,\n} from './constants'\nimport { Footer } from './Footer'\nimport { Header } from './Header'\nimport { useNavigation } from './NavigationProvider'\nimport type { NavigationProps } from './types'\n\nconst StyledNav = styled.nav`\n  display: flex;\n  flex-direction: row;\n  position: relative;\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.borderWeak};\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['width'].includes(prop),\n})<{\n  width: number\n}>`\n  background: ${({ theme }) => theme.colors.neutral.background};\n  display: flex;\n  flex-direction: column;\n\n  width: ${({ width }) => width}px;\n\n  &[data-expanded=\"true\"][data-animation=\"false\"] {\n    max-width: ${NAVIGATION_MAX_WIDTH}px;\n    min-width: ${NAVIGATION_MIN_WIDTH}px;\n  }\n\n  &[data-expanded=\"false\"] {\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n\n  &[data-animation=\"expand\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${({ width }) => width}px;\n  }\n\n  &[data-animation=\"collapse\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n`\n\nconst ContentContainer = styled.div`\n  overflow: hidden;\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n`\n\nconst Content = styled(Stack)`\n  overflow-y: auto;\n  overflow-x: hidden;\n  flex-grow: 1;\n\n  &[data-is-expanded=\"false\"] {\n    align-items: center;\n    padding: ${({ theme }) => theme.space['2']};\n  }\n\n  &[data-is-expanded=\"true\"],\n  &[data-animation=\"expand\"] {\n    padding: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst Slider = styled.div`\n  background: transparent;\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  right: 0;\n  width: 6px;\n  cursor: col-resize;\n  border-right: 2px solid transparent;\n  display: flex;\n\n  &:hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nexport const NavigationContent = ({\n  children,\n  logo,\n  onWidthResize,\n  className,\n  id,\n  onToggleExpand,\n}: NavigationProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation should be inside NavigationProvider to use it properly.',\n    )\n  }\n\n  const {\n    setWidth,\n    width,\n    expanded,\n    toggleExpand,\n    animation,\n    navigationRef,\n    allowNavigationResize,\n    shouldAnimate,\n  } = context\n\n  const sliderRef = useRef<HTMLDivElement | null>(null)\n  const contentRef = useRef<HTMLDivElement | null>(null)\n\n  // It will handle the resize of the navigation when the user drag the vertical bar\n  useEffect(() => {\n    let prevX: number | undefined\n    let navRect: DOMRect | undefined\n    let shouldCollapseOnMouseUp = false\n    let shouldExpandOnMouseUp = false\n\n    const mouseMove = (event: MouseEvent) => {\n      if (prevX !== undefined) {\n        const navWidth = navRect?.width ?? 0\n        const newWidth = navWidth + (event.clientX - prevX)\n\n        if (navigationRef.current && expanded) {\n          navigationRef.current.style.width = `${newWidth}px`\n        }\n\n        if (newWidth <= NAVIGATION_MIN_WIDTH) {\n          shouldCollapseOnMouseUp = true\n        } else {\n          shouldCollapseOnMouseUp = false\n        }\n\n        if (newWidth >= NAVIGATION_COLLASPED_WIDTH && !expanded) {\n          shouldExpandOnMouseUp = true\n        } else {\n          shouldExpandOnMouseUp = false\n        }\n      }\n    }\n\n    const mousedown = (event: MouseEvent) => {\n      document.body.style.pointerEvents = 'none'\n      document.body.style.userSelect = 'none'\n\n      prevX = event.clientX\n      navRect = navigationRef.current?.getBoundingClientRect()\n\n      const mouseup = () => {\n        if (shouldCollapseOnMouseUp || shouldExpandOnMouseUp) {\n          toggleExpand()\n          onToggleExpand?.(!expanded)\n        }\n\n        if (navigationRef.current) {\n          if (!shouldCollapseOnMouseUp && !shouldExpandOnMouseUp) {\n            onWidthResize?.(navigationRef.current.offsetWidth)\n            setWidth?.(navigationRef.current.offsetWidth)\n          }\n\n          if (!expanded) {\n            navigationRef.current.style.width = ''\n          }\n        }\n\n        document.removeEventListener('mousemove', mouseMove)\n        window.removeEventListener('mouseup', mouseup)\n\n        document.body.style.pointerEvents = ''\n        document.body.style.userSelect = ''\n      }\n\n      document.addEventListener('mousemove', mouseMove)\n      window.addEventListener('mouseup', mouseup)\n    }\n    const sliderRefCurrent = sliderRef.current\n\n    sliderRefCurrent?.addEventListener('mousedown', mousedown)\n\n    return () => {\n      sliderRefCurrent?.removeEventListener('mousedown', mousedown)\n    }\n  }, [\n    expanded,\n    navigationRef,\n    onToggleExpand,\n    onWidthResize,\n    setWidth,\n    toggleExpand,\n  ])\n\n  return (\n    <StyledNav className={className} id={id}>\n      <Container\n        data-animation={shouldAnimate ? animation : undefined}\n        data-expanded={expanded}\n        ref={navigationRef}\n        width={width}\n      >\n        {logo ? <Header logo={logo} /> : null}\n        <ContentContainer>\n          <Content\n            data-animation={shouldAnimate ? animation : undefined}\n            data-is-expanded={expanded}\n            gap={0.25}\n            ref={contentRef}\n          >\n            {children}\n          </Content>\n          {allowNavigationResize ? (\n            <Footer contentRef={contentRef} onToggleExpand={onToggleExpand} />\n          ) : null}\n        </ContentContainer>\n      </Container>\n      {allowNavigationResize ? (\n        <Slider data-testid=\"slider\" ref={sliderRef} />\n      ) : null}\n    </StyledNav>\n  )\n}\n"]} */"));
69
+ }) => theme.colors.primary.border, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx"],"names":[],"mappings":"AA6EyB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { Stack } from '@ultraviolet/ui'\nimport { useEffect, useRef } from 'react'\nimport {\n  ANIMATION_DURATION,\n  NAVIGATION_COLLASPED_WIDTH,\n  NAVIGATION_MAX_WIDTH,\n  NAVIGATION_MIN_WIDTH,\n} from './constants'\nimport { Footer } from './Footer'\nimport { Header } from './Header'\nimport { useNavigation } from './NavigationProvider'\nimport type { NavigationProps } from './types'\n\nconst StyledNav = styled.nav`\n  display: flex;\n  flex-direction: row;\n  position: relative;\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.borderWeak};\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['width'].includes(prop),\n})<{\n  width: number\n}>`\n  background: ${({ theme }) => theme.colors.neutral.background};\n  display: flex;\n  flex-direction: column;\n\n  width: ${({ width }) => width}px;\n\n  &[data-expanded=\"true\"][data-animation=\"false\"] {\n    max-width: ${NAVIGATION_MAX_WIDTH}px;\n    min-width: ${NAVIGATION_MIN_WIDTH}px;\n  }\n\n  &[data-expanded=\"false\"] {\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n\n  &[data-animation=\"expand\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${({ width }) => width}px;\n  }\n\n  &[data-animation=\"collapse\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n`\n\nconst ContentContainer = styled.div`\n  overflow: hidden;\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n`\n\nconst Content = styled(Stack)`\n  overflow-y: auto;\n  overflow-x: hidden;\n  flex-grow: 1;\n\n  &[data-is-expanded=\"false\"] {\n    align-items: center;\n    padding: ${({ theme }) => theme.space['2']};\n  }\n\n  &[data-is-expanded=\"true\"],\n  &[data-animation=\"expand\"] {\n    padding: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst Slider = styled.div`\n  background: transparent;\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  right: 0;\n  width: 6px;\n  cursor: col-resize;\n  border-right: 2px solid transparent;\n  display: flex;\n\n  &:hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nexport const NavigationContent = ({\n  children,\n  logo,\n  onWidthResize,\n  className,\n  'data-testid': dataTestId,\n  id,\n  onToggleExpand,\n}: NavigationProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation should be inside NavigationProvider to use it properly.',\n    )\n  }\n\n  const {\n    setWidth,\n    width,\n    expanded,\n    toggleExpand,\n    animation,\n    navigationRef,\n    allowNavigationResize,\n    shouldAnimate,\n  } = context\n\n  const sliderRef = useRef<HTMLDivElement | null>(null)\n  const contentRef = useRef<HTMLDivElement | null>(null)\n\n  // It will handle the resize of the navigation when the user drag the vertical bar\n  useEffect(() => {\n    let prevX: number | undefined\n    let navRect: DOMRect | undefined\n    let shouldCollapseOnMouseUp = false\n    let shouldExpandOnMouseUp = false\n\n    const mouseMove = (event: MouseEvent) => {\n      if (prevX !== undefined) {\n        const navWidth = navRect?.width ?? 0\n        const newWidth = navWidth + (event.clientX - prevX)\n\n        if (navigationRef.current && expanded) {\n          navigationRef.current.style.width = `${newWidth}px`\n        }\n\n        if (newWidth <= NAVIGATION_MIN_WIDTH) {\n          shouldCollapseOnMouseUp = true\n        } else {\n          shouldCollapseOnMouseUp = false\n        }\n\n        if (newWidth >= NAVIGATION_COLLASPED_WIDTH && !expanded) {\n          shouldExpandOnMouseUp = true\n        } else {\n          shouldExpandOnMouseUp = false\n        }\n      }\n    }\n\n    const mousedown = (event: MouseEvent) => {\n      document.body.style.pointerEvents = 'none'\n      document.body.style.userSelect = 'none'\n\n      prevX = event.clientX\n      navRect = navigationRef.current?.getBoundingClientRect()\n\n      const mouseup = () => {\n        if (shouldCollapseOnMouseUp || shouldExpandOnMouseUp) {\n          toggleExpand()\n          onToggleExpand?.(!expanded)\n        }\n\n        if (navigationRef.current) {\n          if (!shouldCollapseOnMouseUp && !shouldExpandOnMouseUp) {\n            onWidthResize?.(navigationRef.current.offsetWidth)\n            setWidth?.(navigationRef.current.offsetWidth)\n          }\n\n          if (!expanded) {\n            navigationRef.current.style.width = ''\n          }\n        }\n\n        document.removeEventListener('mousemove', mouseMove)\n        window.removeEventListener('mouseup', mouseup)\n\n        document.body.style.pointerEvents = ''\n        document.body.style.userSelect = ''\n      }\n\n      document.addEventListener('mousemove', mouseMove)\n      window.addEventListener('mouseup', mouseup)\n    }\n    const sliderRefCurrent = sliderRef.current\n\n    sliderRefCurrent?.addEventListener('mousedown', mousedown)\n\n    return () => {\n      sliderRefCurrent?.removeEventListener('mousedown', mousedown)\n    }\n  }, [\n    expanded,\n    navigationRef,\n    onToggleExpand,\n    onWidthResize,\n    setWidth,\n    toggleExpand,\n  ])\n\n  return (\n    <StyledNav className={className} data-testid={dataTestId} id={id}>\n      <Container\n        data-animation={shouldAnimate ? animation : undefined}\n        data-expanded={expanded}\n        ref={navigationRef}\n        width={width}\n      >\n        {logo ? <Header logo={logo} /> : null}\n        <ContentContainer>\n          <Content\n            data-animation={shouldAnimate ? animation : undefined}\n            data-is-expanded={expanded}\n            gap={0.25}\n            ref={contentRef}\n          >\n            {children}\n          </Content>\n          {allowNavigationResize ? (\n            <Footer contentRef={contentRef} onToggleExpand={onToggleExpand} />\n          ) : null}\n        </ContentContainer>\n      </Container>\n      {allowNavigationResize ? (\n        <Slider data-testid=\"slider\" ref={sliderRef} />\n      ) : null}\n    </StyledNav>\n  )\n}\n"]} */"));
70
70
  const NavigationContent = ({
71
71
  children,
72
72
  logo,
73
73
  onWidthResize,
74
74
  className,
75
+ "data-testid": dataTestId,
75
76
  id,
76
77
  onToggleExpand
77
78
  }) => {
@@ -148,7 +149,7 @@ const NavigationContent = ({
148
149
  sliderRefCurrent?.removeEventListener("mousedown", mousedown);
149
150
  };
150
151
  }, [expanded, navigationRef, onToggleExpand, onWidthResize, setWidth, toggleExpand]);
151
- return /* @__PURE__ */ jsxRuntime.jsxs(StyledNav, { className, id, children: [
152
+ return /* @__PURE__ */ jsxRuntime.jsxs(StyledNav, { className, "data-testid": dataTestId, id, children: [
152
153
  /* @__PURE__ */ jsxRuntime.jsxs(Container, { "data-animation": shouldAnimate ? animation : void 0, "data-expanded": expanded, ref: navigationRef, width, children: [
153
154
  logo ? /* @__PURE__ */ jsxRuntime.jsx(Header.Header, { logo }) : null,
154
155
  /* @__PURE__ */ jsxRuntime.jsxs(ContentContainer, { children: [
@@ -1,2 +1,2 @@
1
1
  import type { NavigationProps } from './types';
2
- export declare const NavigationContent: ({ children, logo, onWidthResize, className, id, onToggleExpand, }: NavigationProps) => import("@emotion/react/jsx-runtime").JSX.Element;
2
+ export declare const NavigationContent: ({ children, logo, onWidthResize, className, "data-testid": dataTestId, id, onToggleExpand, }: NavigationProps) => import("@emotion/react/jsx-runtime").JSX.Element;
@@ -17,7 +17,7 @@ const StyledNav = /* @__PURE__ */ _styled("nav", process.env.NODE_ENV === "produ
17
17
  label: "StyledNav"
18
18
  })("display:flex;flex-direction:row;position:relative;border-right:1px solid ", ({
19
19
  theme
20
- }) => theme.colors.neutral.borderWeak, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx"],"names":[],"mappings":"AAgB4B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { Stack } from '@ultraviolet/ui'\nimport { useEffect, useRef } from 'react'\nimport {\n  ANIMATION_DURATION,\n  NAVIGATION_COLLASPED_WIDTH,\n  NAVIGATION_MAX_WIDTH,\n  NAVIGATION_MIN_WIDTH,\n} from './constants'\nimport { Footer } from './Footer'\nimport { Header } from './Header'\nimport { useNavigation } from './NavigationProvider'\nimport type { NavigationProps } from './types'\n\nconst StyledNav = styled.nav`\n  display: flex;\n  flex-direction: row;\n  position: relative;\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.borderWeak};\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['width'].includes(prop),\n})<{\n  width: number\n}>`\n  background: ${({ theme }) => theme.colors.neutral.background};\n  display: flex;\n  flex-direction: column;\n\n  width: ${({ width }) => width}px;\n\n  &[data-expanded=\"true\"][data-animation=\"false\"] {\n    max-width: ${NAVIGATION_MAX_WIDTH}px;\n    min-width: ${NAVIGATION_MIN_WIDTH}px;\n  }\n\n  &[data-expanded=\"false\"] {\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n\n  &[data-animation=\"expand\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${({ width }) => width}px;\n  }\n\n  &[data-animation=\"collapse\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n`\n\nconst ContentContainer = styled.div`\n  overflow: hidden;\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n`\n\nconst Content = styled(Stack)`\n  overflow-y: auto;\n  overflow-x: hidden;\n  flex-grow: 1;\n\n  &[data-is-expanded=\"false\"] {\n    align-items: center;\n    padding: ${({ theme }) => theme.space['2']};\n  }\n\n  &[data-is-expanded=\"true\"],\n  &[data-animation=\"expand\"] {\n    padding: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst Slider = styled.div`\n  background: transparent;\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  right: 0;\n  width: 6px;\n  cursor: col-resize;\n  border-right: 2px solid transparent;\n  display: flex;\n\n  &:hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nexport const NavigationContent = ({\n  children,\n  logo,\n  onWidthResize,\n  className,\n  id,\n  onToggleExpand,\n}: NavigationProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation should be inside NavigationProvider to use it properly.',\n    )\n  }\n\n  const {\n    setWidth,\n    width,\n    expanded,\n    toggleExpand,\n    animation,\n    navigationRef,\n    allowNavigationResize,\n    shouldAnimate,\n  } = context\n\n  const sliderRef = useRef<HTMLDivElement | null>(null)\n  const contentRef = useRef<HTMLDivElement | null>(null)\n\n  // It will handle the resize of the navigation when the user drag the vertical bar\n  useEffect(() => {\n    let prevX: number | undefined\n    let navRect: DOMRect | undefined\n    let shouldCollapseOnMouseUp = false\n    let shouldExpandOnMouseUp = false\n\n    const mouseMove = (event: MouseEvent) => {\n      if (prevX !== undefined) {\n        const navWidth = navRect?.width ?? 0\n        const newWidth = navWidth + (event.clientX - prevX)\n\n        if (navigationRef.current && expanded) {\n          navigationRef.current.style.width = `${newWidth}px`\n        }\n\n        if (newWidth <= NAVIGATION_MIN_WIDTH) {\n          shouldCollapseOnMouseUp = true\n        } else {\n          shouldCollapseOnMouseUp = false\n        }\n\n        if (newWidth >= NAVIGATION_COLLASPED_WIDTH && !expanded) {\n          shouldExpandOnMouseUp = true\n        } else {\n          shouldExpandOnMouseUp = false\n        }\n      }\n    }\n\n    const mousedown = (event: MouseEvent) => {\n      document.body.style.pointerEvents = 'none'\n      document.body.style.userSelect = 'none'\n\n      prevX = event.clientX\n      navRect = navigationRef.current?.getBoundingClientRect()\n\n      const mouseup = () => {\n        if (shouldCollapseOnMouseUp || shouldExpandOnMouseUp) {\n          toggleExpand()\n          onToggleExpand?.(!expanded)\n        }\n\n        if (navigationRef.current) {\n          if (!shouldCollapseOnMouseUp && !shouldExpandOnMouseUp) {\n            onWidthResize?.(navigationRef.current.offsetWidth)\n            setWidth?.(navigationRef.current.offsetWidth)\n          }\n\n          if (!expanded) {\n            navigationRef.current.style.width = ''\n          }\n        }\n\n        document.removeEventListener('mousemove', mouseMove)\n        window.removeEventListener('mouseup', mouseup)\n\n        document.body.style.pointerEvents = ''\n        document.body.style.userSelect = ''\n      }\n\n      document.addEventListener('mousemove', mouseMove)\n      window.addEventListener('mouseup', mouseup)\n    }\n    const sliderRefCurrent = sliderRef.current\n\n    sliderRefCurrent?.addEventListener('mousedown', mousedown)\n\n    return () => {\n      sliderRefCurrent?.removeEventListener('mousedown', mousedown)\n    }\n  }, [\n    expanded,\n    navigationRef,\n    onToggleExpand,\n    onWidthResize,\n    setWidth,\n    toggleExpand,\n  ])\n\n  return (\n    <StyledNav className={className} id={id}>\n      <Container\n        data-animation={shouldAnimate ? animation : undefined}\n        data-expanded={expanded}\n        ref={navigationRef}\n        width={width}\n      >\n        {logo ? <Header logo={logo} /> : null}\n        <ContentContainer>\n          <Content\n            data-animation={shouldAnimate ? animation : undefined}\n            data-is-expanded={expanded}\n            gap={0.25}\n            ref={contentRef}\n          >\n            {children}\n          </Content>\n          {allowNavigationResize ? (\n            <Footer contentRef={contentRef} onToggleExpand={onToggleExpand} />\n          ) : null}\n        </ContentContainer>\n      </Container>\n      {allowNavigationResize ? (\n        <Slider data-testid=\"slider\" ref={sliderRef} />\n      ) : null}\n    </StyledNav>\n  )\n}\n"]} */"));
20
+ }) => theme.colors.neutral.borderWeak, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx"],"names":[],"mappings":"AAgB4B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { Stack } from '@ultraviolet/ui'\nimport { useEffect, useRef } from 'react'\nimport {\n  ANIMATION_DURATION,\n  NAVIGATION_COLLASPED_WIDTH,\n  NAVIGATION_MAX_WIDTH,\n  NAVIGATION_MIN_WIDTH,\n} from './constants'\nimport { Footer } from './Footer'\nimport { Header } from './Header'\nimport { useNavigation } from './NavigationProvider'\nimport type { NavigationProps } from './types'\n\nconst StyledNav = styled.nav`\n  display: flex;\n  flex-direction: row;\n  position: relative;\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.borderWeak};\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['width'].includes(prop),\n})<{\n  width: number\n}>`\n  background: ${({ theme }) => theme.colors.neutral.background};\n  display: flex;\n  flex-direction: column;\n\n  width: ${({ width }) => width}px;\n\n  &[data-expanded=\"true\"][data-animation=\"false\"] {\n    max-width: ${NAVIGATION_MAX_WIDTH}px;\n    min-width: ${NAVIGATION_MIN_WIDTH}px;\n  }\n\n  &[data-expanded=\"false\"] {\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n\n  &[data-animation=\"expand\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${({ width }) => width}px;\n  }\n\n  &[data-animation=\"collapse\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n`\n\nconst ContentContainer = styled.div`\n  overflow: hidden;\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n`\n\nconst Content = styled(Stack)`\n  overflow-y: auto;\n  overflow-x: hidden;\n  flex-grow: 1;\n\n  &[data-is-expanded=\"false\"] {\n    align-items: center;\n    padding: ${({ theme }) => theme.space['2']};\n  }\n\n  &[data-is-expanded=\"true\"],\n  &[data-animation=\"expand\"] {\n    padding: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst Slider = styled.div`\n  background: transparent;\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  right: 0;\n  width: 6px;\n  cursor: col-resize;\n  border-right: 2px solid transparent;\n  display: flex;\n\n  &:hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nexport const NavigationContent = ({\n  children,\n  logo,\n  onWidthResize,\n  className,\n  'data-testid': dataTestId,\n  id,\n  onToggleExpand,\n}: NavigationProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation should be inside NavigationProvider to use it properly.',\n    )\n  }\n\n  const {\n    setWidth,\n    width,\n    expanded,\n    toggleExpand,\n    animation,\n    navigationRef,\n    allowNavigationResize,\n    shouldAnimate,\n  } = context\n\n  const sliderRef = useRef<HTMLDivElement | null>(null)\n  const contentRef = useRef<HTMLDivElement | null>(null)\n\n  // It will handle the resize of the navigation when the user drag the vertical bar\n  useEffect(() => {\n    let prevX: number | undefined\n    let navRect: DOMRect | undefined\n    let shouldCollapseOnMouseUp = false\n    let shouldExpandOnMouseUp = false\n\n    const mouseMove = (event: MouseEvent) => {\n      if (prevX !== undefined) {\n        const navWidth = navRect?.width ?? 0\n        const newWidth = navWidth + (event.clientX - prevX)\n\n        if (navigationRef.current && expanded) {\n          navigationRef.current.style.width = `${newWidth}px`\n        }\n\n        if (newWidth <= NAVIGATION_MIN_WIDTH) {\n          shouldCollapseOnMouseUp = true\n        } else {\n          shouldCollapseOnMouseUp = false\n        }\n\n        if (newWidth >= NAVIGATION_COLLASPED_WIDTH && !expanded) {\n          shouldExpandOnMouseUp = true\n        } else {\n          shouldExpandOnMouseUp = false\n        }\n      }\n    }\n\n    const mousedown = (event: MouseEvent) => {\n      document.body.style.pointerEvents = 'none'\n      document.body.style.userSelect = 'none'\n\n      prevX = event.clientX\n      navRect = navigationRef.current?.getBoundingClientRect()\n\n      const mouseup = () => {\n        if (shouldCollapseOnMouseUp || shouldExpandOnMouseUp) {\n          toggleExpand()\n          onToggleExpand?.(!expanded)\n        }\n\n        if (navigationRef.current) {\n          if (!shouldCollapseOnMouseUp && !shouldExpandOnMouseUp) {\n            onWidthResize?.(navigationRef.current.offsetWidth)\n            setWidth?.(navigationRef.current.offsetWidth)\n          }\n\n          if (!expanded) {\n            navigationRef.current.style.width = ''\n          }\n        }\n\n        document.removeEventListener('mousemove', mouseMove)\n        window.removeEventListener('mouseup', mouseup)\n\n        document.body.style.pointerEvents = ''\n        document.body.style.userSelect = ''\n      }\n\n      document.addEventListener('mousemove', mouseMove)\n      window.addEventListener('mouseup', mouseup)\n    }\n    const sliderRefCurrent = sliderRef.current\n\n    sliderRefCurrent?.addEventListener('mousedown', mousedown)\n\n    return () => {\n      sliderRefCurrent?.removeEventListener('mousedown', mousedown)\n    }\n  }, [\n    expanded,\n    navigationRef,\n    onToggleExpand,\n    onWidthResize,\n    setWidth,\n    toggleExpand,\n  ])\n\n  return (\n    <StyledNav className={className} data-testid={dataTestId} id={id}>\n      <Container\n        data-animation={shouldAnimate ? animation : undefined}\n        data-expanded={expanded}\n        ref={navigationRef}\n        width={width}\n      >\n        {logo ? <Header logo={logo} /> : null}\n        <ContentContainer>\n          <Content\n            data-animation={shouldAnimate ? animation : undefined}\n            data-is-expanded={expanded}\n            gap={0.25}\n            ref={contentRef}\n          >\n            {children}\n          </Content>\n          {allowNavigationResize ? (\n            <Footer contentRef={contentRef} onToggleExpand={onToggleExpand} />\n          ) : null}\n        </ContentContainer>\n      </Container>\n      {allowNavigationResize ? (\n        <Slider data-testid=\"slider\" ref={sliderRef} />\n      ) : null}\n    </StyledNav>\n  )\n}\n"]} */"));
21
21
  const Container = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
22
22
  shouldForwardProp: (prop) => !["width"].includes(prop),
23
23
  target: "esezfu53"
@@ -31,7 +31,7 @@ const Container = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "produ
31
31
  width
32
32
  }) => width, 'px;&[data-expanded="true"][data-animation="false"]{max-width:', NAVIGATION_MAX_WIDTH, "px;min-width:", NAVIGATION_MIN_WIDTH, 'px;}&[data-expanded="false"]{width:', NAVIGATION_COLLASPED_WIDTH, 'px;}&[data-animation="expand"]{transition:width ', ANIMATION_DURATION, "ms ease-in-out;width:", ({
33
33
  width
34
- }) => width, 'px;}&[data-animation="collapse"]{transition:width ', ANIMATION_DURATION, "ms ease-in-out;width:", NAVIGATION_COLLASPED_WIDTH, "px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx"],"names":[],"mappings":"AA2BE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { Stack } from '@ultraviolet/ui'\nimport { useEffect, useRef } from 'react'\nimport {\n  ANIMATION_DURATION,\n  NAVIGATION_COLLASPED_WIDTH,\n  NAVIGATION_MAX_WIDTH,\n  NAVIGATION_MIN_WIDTH,\n} from './constants'\nimport { Footer } from './Footer'\nimport { Header } from './Header'\nimport { useNavigation } from './NavigationProvider'\nimport type { NavigationProps } from './types'\n\nconst StyledNav = styled.nav`\n  display: flex;\n  flex-direction: row;\n  position: relative;\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.borderWeak};\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['width'].includes(prop),\n})<{\n  width: number\n}>`\n  background: ${({ theme }) => theme.colors.neutral.background};\n  display: flex;\n  flex-direction: column;\n\n  width: ${({ width }) => width}px;\n\n  &[data-expanded=\"true\"][data-animation=\"false\"] {\n    max-width: ${NAVIGATION_MAX_WIDTH}px;\n    min-width: ${NAVIGATION_MIN_WIDTH}px;\n  }\n\n  &[data-expanded=\"false\"] {\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n\n  &[data-animation=\"expand\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${({ width }) => width}px;\n  }\n\n  &[data-animation=\"collapse\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n`\n\nconst ContentContainer = styled.div`\n  overflow: hidden;\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n`\n\nconst Content = styled(Stack)`\n  overflow-y: auto;\n  overflow-x: hidden;\n  flex-grow: 1;\n\n  &[data-is-expanded=\"false\"] {\n    align-items: center;\n    padding: ${({ theme }) => theme.space['2']};\n  }\n\n  &[data-is-expanded=\"true\"],\n  &[data-animation=\"expand\"] {\n    padding: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst Slider = styled.div`\n  background: transparent;\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  right: 0;\n  width: 6px;\n  cursor: col-resize;\n  border-right: 2px solid transparent;\n  display: flex;\n\n  &:hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nexport const NavigationContent = ({\n  children,\n  logo,\n  onWidthResize,\n  className,\n  id,\n  onToggleExpand,\n}: NavigationProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation should be inside NavigationProvider to use it properly.',\n    )\n  }\n\n  const {\n    setWidth,\n    width,\n    expanded,\n    toggleExpand,\n    animation,\n    navigationRef,\n    allowNavigationResize,\n    shouldAnimate,\n  } = context\n\n  const sliderRef = useRef<HTMLDivElement | null>(null)\n  const contentRef = useRef<HTMLDivElement | null>(null)\n\n  // It will handle the resize of the navigation when the user drag the vertical bar\n  useEffect(() => {\n    let prevX: number | undefined\n    let navRect: DOMRect | undefined\n    let shouldCollapseOnMouseUp = false\n    let shouldExpandOnMouseUp = false\n\n    const mouseMove = (event: MouseEvent) => {\n      if (prevX !== undefined) {\n        const navWidth = navRect?.width ?? 0\n        const newWidth = navWidth + (event.clientX - prevX)\n\n        if (navigationRef.current && expanded) {\n          navigationRef.current.style.width = `${newWidth}px`\n        }\n\n        if (newWidth <= NAVIGATION_MIN_WIDTH) {\n          shouldCollapseOnMouseUp = true\n        } else {\n          shouldCollapseOnMouseUp = false\n        }\n\n        if (newWidth >= NAVIGATION_COLLASPED_WIDTH && !expanded) {\n          shouldExpandOnMouseUp = true\n        } else {\n          shouldExpandOnMouseUp = false\n        }\n      }\n    }\n\n    const mousedown = (event: MouseEvent) => {\n      document.body.style.pointerEvents = 'none'\n      document.body.style.userSelect = 'none'\n\n      prevX = event.clientX\n      navRect = navigationRef.current?.getBoundingClientRect()\n\n      const mouseup = () => {\n        if (shouldCollapseOnMouseUp || shouldExpandOnMouseUp) {\n          toggleExpand()\n          onToggleExpand?.(!expanded)\n        }\n\n        if (navigationRef.current) {\n          if (!shouldCollapseOnMouseUp && !shouldExpandOnMouseUp) {\n            onWidthResize?.(navigationRef.current.offsetWidth)\n            setWidth?.(navigationRef.current.offsetWidth)\n          }\n\n          if (!expanded) {\n            navigationRef.current.style.width = ''\n          }\n        }\n\n        document.removeEventListener('mousemove', mouseMove)\n        window.removeEventListener('mouseup', mouseup)\n\n        document.body.style.pointerEvents = ''\n        document.body.style.userSelect = ''\n      }\n\n      document.addEventListener('mousemove', mouseMove)\n      window.addEventListener('mouseup', mouseup)\n    }\n    const sliderRefCurrent = sliderRef.current\n\n    sliderRefCurrent?.addEventListener('mousedown', mousedown)\n\n    return () => {\n      sliderRefCurrent?.removeEventListener('mousedown', mousedown)\n    }\n  }, [\n    expanded,\n    navigationRef,\n    onToggleExpand,\n    onWidthResize,\n    setWidth,\n    toggleExpand,\n  ])\n\n  return (\n    <StyledNav className={className} id={id}>\n      <Container\n        data-animation={shouldAnimate ? animation : undefined}\n        data-expanded={expanded}\n        ref={navigationRef}\n        width={width}\n      >\n        {logo ? <Header logo={logo} /> : null}\n        <ContentContainer>\n          <Content\n            data-animation={shouldAnimate ? animation : undefined}\n            data-is-expanded={expanded}\n            gap={0.25}\n            ref={contentRef}\n          >\n            {children}\n          </Content>\n          {allowNavigationResize ? (\n            <Footer contentRef={contentRef} onToggleExpand={onToggleExpand} />\n          ) : null}\n        </ContentContainer>\n      </Container>\n      {allowNavigationResize ? (\n        <Slider data-testid=\"slider\" ref={sliderRef} />\n      ) : null}\n    </StyledNav>\n  )\n}\n"]} */"));
34
+ }) => width, 'px;}&[data-animation="collapse"]{transition:width ', ANIMATION_DURATION, "ms ease-in-out;width:", NAVIGATION_COLLASPED_WIDTH, "px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx"],"names":[],"mappings":"AA2BE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { Stack } from '@ultraviolet/ui'\nimport { useEffect, useRef } from 'react'\nimport {\n  ANIMATION_DURATION,\n  NAVIGATION_COLLASPED_WIDTH,\n  NAVIGATION_MAX_WIDTH,\n  NAVIGATION_MIN_WIDTH,\n} from './constants'\nimport { Footer } from './Footer'\nimport { Header } from './Header'\nimport { useNavigation } from './NavigationProvider'\nimport type { NavigationProps } from './types'\n\nconst StyledNav = styled.nav`\n  display: flex;\n  flex-direction: row;\n  position: relative;\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.borderWeak};\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['width'].includes(prop),\n})<{\n  width: number\n}>`\n  background: ${({ theme }) => theme.colors.neutral.background};\n  display: flex;\n  flex-direction: column;\n\n  width: ${({ width }) => width}px;\n\n  &[data-expanded=\"true\"][data-animation=\"false\"] {\n    max-width: ${NAVIGATION_MAX_WIDTH}px;\n    min-width: ${NAVIGATION_MIN_WIDTH}px;\n  }\n\n  &[data-expanded=\"false\"] {\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n\n  &[data-animation=\"expand\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${({ width }) => width}px;\n  }\n\n  &[data-animation=\"collapse\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n`\n\nconst ContentContainer = styled.div`\n  overflow: hidden;\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n`\n\nconst Content = styled(Stack)`\n  overflow-y: auto;\n  overflow-x: hidden;\n  flex-grow: 1;\n\n  &[data-is-expanded=\"false\"] {\n    align-items: center;\n    padding: ${({ theme }) => theme.space['2']};\n  }\n\n  &[data-is-expanded=\"true\"],\n  &[data-animation=\"expand\"] {\n    padding: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst Slider = styled.div`\n  background: transparent;\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  right: 0;\n  width: 6px;\n  cursor: col-resize;\n  border-right: 2px solid transparent;\n  display: flex;\n\n  &:hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nexport const NavigationContent = ({\n  children,\n  logo,\n  onWidthResize,\n  className,\n  'data-testid': dataTestId,\n  id,\n  onToggleExpand,\n}: NavigationProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation should be inside NavigationProvider to use it properly.',\n    )\n  }\n\n  const {\n    setWidth,\n    width,\n    expanded,\n    toggleExpand,\n    animation,\n    navigationRef,\n    allowNavigationResize,\n    shouldAnimate,\n  } = context\n\n  const sliderRef = useRef<HTMLDivElement | null>(null)\n  const contentRef = useRef<HTMLDivElement | null>(null)\n\n  // It will handle the resize of the navigation when the user drag the vertical bar\n  useEffect(() => {\n    let prevX: number | undefined\n    let navRect: DOMRect | undefined\n    let shouldCollapseOnMouseUp = false\n    let shouldExpandOnMouseUp = false\n\n    const mouseMove = (event: MouseEvent) => {\n      if (prevX !== undefined) {\n        const navWidth = navRect?.width ?? 0\n        const newWidth = navWidth + (event.clientX - prevX)\n\n        if (navigationRef.current && expanded) {\n          navigationRef.current.style.width = `${newWidth}px`\n        }\n\n        if (newWidth <= NAVIGATION_MIN_WIDTH) {\n          shouldCollapseOnMouseUp = true\n        } else {\n          shouldCollapseOnMouseUp = false\n        }\n\n        if (newWidth >= NAVIGATION_COLLASPED_WIDTH && !expanded) {\n          shouldExpandOnMouseUp = true\n        } else {\n          shouldExpandOnMouseUp = false\n        }\n      }\n    }\n\n    const mousedown = (event: MouseEvent) => {\n      document.body.style.pointerEvents = 'none'\n      document.body.style.userSelect = 'none'\n\n      prevX = event.clientX\n      navRect = navigationRef.current?.getBoundingClientRect()\n\n      const mouseup = () => {\n        if (shouldCollapseOnMouseUp || shouldExpandOnMouseUp) {\n          toggleExpand()\n          onToggleExpand?.(!expanded)\n        }\n\n        if (navigationRef.current) {\n          if (!shouldCollapseOnMouseUp && !shouldExpandOnMouseUp) {\n            onWidthResize?.(navigationRef.current.offsetWidth)\n            setWidth?.(navigationRef.current.offsetWidth)\n          }\n\n          if (!expanded) {\n            navigationRef.current.style.width = ''\n          }\n        }\n\n        document.removeEventListener('mousemove', mouseMove)\n        window.removeEventListener('mouseup', mouseup)\n\n        document.body.style.pointerEvents = ''\n        document.body.style.userSelect = ''\n      }\n\n      document.addEventListener('mousemove', mouseMove)\n      window.addEventListener('mouseup', mouseup)\n    }\n    const sliderRefCurrent = sliderRef.current\n\n    sliderRefCurrent?.addEventListener('mousedown', mousedown)\n\n    return () => {\n      sliderRefCurrent?.removeEventListener('mousedown', mousedown)\n    }\n  }, [\n    expanded,\n    navigationRef,\n    onToggleExpand,\n    onWidthResize,\n    setWidth,\n    toggleExpand,\n  ])\n\n  return (\n    <StyledNav className={className} data-testid={dataTestId} id={id}>\n      <Container\n        data-animation={shouldAnimate ? animation : undefined}\n        data-expanded={expanded}\n        ref={navigationRef}\n        width={width}\n      >\n        {logo ? <Header logo={logo} /> : null}\n        <ContentContainer>\n          <Content\n            data-animation={shouldAnimate ? animation : undefined}\n            data-is-expanded={expanded}\n            gap={0.25}\n            ref={contentRef}\n          >\n            {children}\n          </Content>\n          {allowNavigationResize ? (\n            <Footer contentRef={contentRef} onToggleExpand={onToggleExpand} />\n          ) : null}\n        </ContentContainer>\n      </Container>\n      {allowNavigationResize ? (\n        <Slider data-testid=\"slider\" ref={sliderRef} />\n      ) : null}\n    </StyledNav>\n  )\n}\n"]} */"));
35
35
  const ContentContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
36
36
  target: "esezfu52"
37
37
  } : {
@@ -42,7 +42,7 @@ const ContentContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV ===
42
42
  styles: "overflow:hidden;display:flex;flex-direction:column;flex-grow:1"
43
43
  } : {
44
44
  name: "12is9id",
45
- styles: "overflow:hidden;display:flex;flex-direction:column;flex-grow:1/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx"],"names":[],"mappings":"AAsDmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { Stack } from '@ultraviolet/ui'\nimport { useEffect, useRef } from 'react'\nimport {\n  ANIMATION_DURATION,\n  NAVIGATION_COLLASPED_WIDTH,\n  NAVIGATION_MAX_WIDTH,\n  NAVIGATION_MIN_WIDTH,\n} from './constants'\nimport { Footer } from './Footer'\nimport { Header } from './Header'\nimport { useNavigation } from './NavigationProvider'\nimport type { NavigationProps } from './types'\n\nconst StyledNav = styled.nav`\n  display: flex;\n  flex-direction: row;\n  position: relative;\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.borderWeak};\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['width'].includes(prop),\n})<{\n  width: number\n}>`\n  background: ${({ theme }) => theme.colors.neutral.background};\n  display: flex;\n  flex-direction: column;\n\n  width: ${({ width }) => width}px;\n\n  &[data-expanded=\"true\"][data-animation=\"false\"] {\n    max-width: ${NAVIGATION_MAX_WIDTH}px;\n    min-width: ${NAVIGATION_MIN_WIDTH}px;\n  }\n\n  &[data-expanded=\"false\"] {\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n\n  &[data-animation=\"expand\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${({ width }) => width}px;\n  }\n\n  &[data-animation=\"collapse\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n`\n\nconst ContentContainer = styled.div`\n  overflow: hidden;\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n`\n\nconst Content = styled(Stack)`\n  overflow-y: auto;\n  overflow-x: hidden;\n  flex-grow: 1;\n\n  &[data-is-expanded=\"false\"] {\n    align-items: center;\n    padding: ${({ theme }) => theme.space['2']};\n  }\n\n  &[data-is-expanded=\"true\"],\n  &[data-animation=\"expand\"] {\n    padding: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst Slider = styled.div`\n  background: transparent;\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  right: 0;\n  width: 6px;\n  cursor: col-resize;\n  border-right: 2px solid transparent;\n  display: flex;\n\n  &:hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nexport const NavigationContent = ({\n  children,\n  logo,\n  onWidthResize,\n  className,\n  id,\n  onToggleExpand,\n}: NavigationProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation should be inside NavigationProvider to use it properly.',\n    )\n  }\n\n  const {\n    setWidth,\n    width,\n    expanded,\n    toggleExpand,\n    animation,\n    navigationRef,\n    allowNavigationResize,\n    shouldAnimate,\n  } = context\n\n  const sliderRef = useRef<HTMLDivElement | null>(null)\n  const contentRef = useRef<HTMLDivElement | null>(null)\n\n  // It will handle the resize of the navigation when the user drag the vertical bar\n  useEffect(() => {\n    let prevX: number | undefined\n    let navRect: DOMRect | undefined\n    let shouldCollapseOnMouseUp = false\n    let shouldExpandOnMouseUp = false\n\n    const mouseMove = (event: MouseEvent) => {\n      if (prevX !== undefined) {\n        const navWidth = navRect?.width ?? 0\n        const newWidth = navWidth + (event.clientX - prevX)\n\n        if (navigationRef.current && expanded) {\n          navigationRef.current.style.width = `${newWidth}px`\n        }\n\n        if (newWidth <= NAVIGATION_MIN_WIDTH) {\n          shouldCollapseOnMouseUp = true\n        } else {\n          shouldCollapseOnMouseUp = false\n        }\n\n        if (newWidth >= NAVIGATION_COLLASPED_WIDTH && !expanded) {\n          shouldExpandOnMouseUp = true\n        } else {\n          shouldExpandOnMouseUp = false\n        }\n      }\n    }\n\n    const mousedown = (event: MouseEvent) => {\n      document.body.style.pointerEvents = 'none'\n      document.body.style.userSelect = 'none'\n\n      prevX = event.clientX\n      navRect = navigationRef.current?.getBoundingClientRect()\n\n      const mouseup = () => {\n        if (shouldCollapseOnMouseUp || shouldExpandOnMouseUp) {\n          toggleExpand()\n          onToggleExpand?.(!expanded)\n        }\n\n        if (navigationRef.current) {\n          if (!shouldCollapseOnMouseUp && !shouldExpandOnMouseUp) {\n            onWidthResize?.(navigationRef.current.offsetWidth)\n            setWidth?.(navigationRef.current.offsetWidth)\n          }\n\n          if (!expanded) {\n            navigationRef.current.style.width = ''\n          }\n        }\n\n        document.removeEventListener('mousemove', mouseMove)\n        window.removeEventListener('mouseup', mouseup)\n\n        document.body.style.pointerEvents = ''\n        document.body.style.userSelect = ''\n      }\n\n      document.addEventListener('mousemove', mouseMove)\n      window.addEventListener('mouseup', mouseup)\n    }\n    const sliderRefCurrent = sliderRef.current\n\n    sliderRefCurrent?.addEventListener('mousedown', mousedown)\n\n    return () => {\n      sliderRefCurrent?.removeEventListener('mousedown', mousedown)\n    }\n  }, [\n    expanded,\n    navigationRef,\n    onToggleExpand,\n    onWidthResize,\n    setWidth,\n    toggleExpand,\n  ])\n\n  return (\n    <StyledNav className={className} id={id}>\n      <Container\n        data-animation={shouldAnimate ? animation : undefined}\n        data-expanded={expanded}\n        ref={navigationRef}\n        width={width}\n      >\n        {logo ? <Header logo={logo} /> : null}\n        <ContentContainer>\n          <Content\n            data-animation={shouldAnimate ? animation : undefined}\n            data-is-expanded={expanded}\n            gap={0.25}\n            ref={contentRef}\n          >\n            {children}\n          </Content>\n          {allowNavigationResize ? (\n            <Footer contentRef={contentRef} onToggleExpand={onToggleExpand} />\n          ) : null}\n        </ContentContainer>\n      </Container>\n      {allowNavigationResize ? (\n        <Slider data-testid=\"slider\" ref={sliderRef} />\n      ) : null}\n    </StyledNav>\n  )\n}\n"]} */",
45
+ styles: "overflow:hidden;display:flex;flex-direction:column;flex-grow:1/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx"],"names":[],"mappings":"AAsDmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { Stack } from '@ultraviolet/ui'\nimport { useEffect, useRef } from 'react'\nimport {\n  ANIMATION_DURATION,\n  NAVIGATION_COLLASPED_WIDTH,\n  NAVIGATION_MAX_WIDTH,\n  NAVIGATION_MIN_WIDTH,\n} from './constants'\nimport { Footer } from './Footer'\nimport { Header } from './Header'\nimport { useNavigation } from './NavigationProvider'\nimport type { NavigationProps } from './types'\n\nconst StyledNav = styled.nav`\n  display: flex;\n  flex-direction: row;\n  position: relative;\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.borderWeak};\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['width'].includes(prop),\n})<{\n  width: number\n}>`\n  background: ${({ theme }) => theme.colors.neutral.background};\n  display: flex;\n  flex-direction: column;\n\n  width: ${({ width }) => width}px;\n\n  &[data-expanded=\"true\"][data-animation=\"false\"] {\n    max-width: ${NAVIGATION_MAX_WIDTH}px;\n    min-width: ${NAVIGATION_MIN_WIDTH}px;\n  }\n\n  &[data-expanded=\"false\"] {\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n\n  &[data-animation=\"expand\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${({ width }) => width}px;\n  }\n\n  &[data-animation=\"collapse\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n`\n\nconst ContentContainer = styled.div`\n  overflow: hidden;\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n`\n\nconst Content = styled(Stack)`\n  overflow-y: auto;\n  overflow-x: hidden;\n  flex-grow: 1;\n\n  &[data-is-expanded=\"false\"] {\n    align-items: center;\n    padding: ${({ theme }) => theme.space['2']};\n  }\n\n  &[data-is-expanded=\"true\"],\n  &[data-animation=\"expand\"] {\n    padding: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst Slider = styled.div`\n  background: transparent;\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  right: 0;\n  width: 6px;\n  cursor: col-resize;\n  border-right: 2px solid transparent;\n  display: flex;\n\n  &:hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nexport const NavigationContent = ({\n  children,\n  logo,\n  onWidthResize,\n  className,\n  'data-testid': dataTestId,\n  id,\n  onToggleExpand,\n}: NavigationProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation should be inside NavigationProvider to use it properly.',\n    )\n  }\n\n  const {\n    setWidth,\n    width,\n    expanded,\n    toggleExpand,\n    animation,\n    navigationRef,\n    allowNavigationResize,\n    shouldAnimate,\n  } = context\n\n  const sliderRef = useRef<HTMLDivElement | null>(null)\n  const contentRef = useRef<HTMLDivElement | null>(null)\n\n  // It will handle the resize of the navigation when the user drag the vertical bar\n  useEffect(() => {\n    let prevX: number | undefined\n    let navRect: DOMRect | undefined\n    let shouldCollapseOnMouseUp = false\n    let shouldExpandOnMouseUp = false\n\n    const mouseMove = (event: MouseEvent) => {\n      if (prevX !== undefined) {\n        const navWidth = navRect?.width ?? 0\n        const newWidth = navWidth + (event.clientX - prevX)\n\n        if (navigationRef.current && expanded) {\n          navigationRef.current.style.width = `${newWidth}px`\n        }\n\n        if (newWidth <= NAVIGATION_MIN_WIDTH) {\n          shouldCollapseOnMouseUp = true\n        } else {\n          shouldCollapseOnMouseUp = false\n        }\n\n        if (newWidth >= NAVIGATION_COLLASPED_WIDTH && !expanded) {\n          shouldExpandOnMouseUp = true\n        } else {\n          shouldExpandOnMouseUp = false\n        }\n      }\n    }\n\n    const mousedown = (event: MouseEvent) => {\n      document.body.style.pointerEvents = 'none'\n      document.body.style.userSelect = 'none'\n\n      prevX = event.clientX\n      navRect = navigationRef.current?.getBoundingClientRect()\n\n      const mouseup = () => {\n        if (shouldCollapseOnMouseUp || shouldExpandOnMouseUp) {\n          toggleExpand()\n          onToggleExpand?.(!expanded)\n        }\n\n        if (navigationRef.current) {\n          if (!shouldCollapseOnMouseUp && !shouldExpandOnMouseUp) {\n            onWidthResize?.(navigationRef.current.offsetWidth)\n            setWidth?.(navigationRef.current.offsetWidth)\n          }\n\n          if (!expanded) {\n            navigationRef.current.style.width = ''\n          }\n        }\n\n        document.removeEventListener('mousemove', mouseMove)\n        window.removeEventListener('mouseup', mouseup)\n\n        document.body.style.pointerEvents = ''\n        document.body.style.userSelect = ''\n      }\n\n      document.addEventListener('mousemove', mouseMove)\n      window.addEventListener('mouseup', mouseup)\n    }\n    const sliderRefCurrent = sliderRef.current\n\n    sliderRefCurrent?.addEventListener('mousedown', mousedown)\n\n    return () => {\n      sliderRefCurrent?.removeEventListener('mousedown', mousedown)\n    }\n  }, [\n    expanded,\n    navigationRef,\n    onToggleExpand,\n    onWidthResize,\n    setWidth,\n    toggleExpand,\n  ])\n\n  return (\n    <StyledNav className={className} data-testid={dataTestId} id={id}>\n      <Container\n        data-animation={shouldAnimate ? animation : undefined}\n        data-expanded={expanded}\n        ref={navigationRef}\n        width={width}\n      >\n        {logo ? <Header logo={logo} /> : null}\n        <ContentContainer>\n          <Content\n            data-animation={shouldAnimate ? animation : undefined}\n            data-is-expanded={expanded}\n            gap={0.25}\n            ref={contentRef}\n          >\n            {children}\n          </Content>\n          {allowNavigationResize ? (\n            <Footer contentRef={contentRef} onToggleExpand={onToggleExpand} />\n          ) : null}\n        </ContentContainer>\n      </Container>\n      {allowNavigationResize ? (\n        <Slider data-testid=\"slider\" ref={sliderRef} />\n      ) : null}\n    </StyledNav>\n  )\n}\n"]} */",
46
46
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
47
47
  });
48
48
  const Content = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
@@ -54,7 +54,7 @@ const Content = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "product
54
54
  theme
55
55
  }) => theme.space["2"], ';}&[data-is-expanded="true"],&[data-animation="expand"]{padding:', ({
56
56
  theme
57
- }) => theme.space["2"], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx"],"names":[],"mappings":"AA6D6B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { Stack } from '@ultraviolet/ui'\nimport { useEffect, useRef } from 'react'\nimport {\n  ANIMATION_DURATION,\n  NAVIGATION_COLLASPED_WIDTH,\n  NAVIGATION_MAX_WIDTH,\n  NAVIGATION_MIN_WIDTH,\n} from './constants'\nimport { Footer } from './Footer'\nimport { Header } from './Header'\nimport { useNavigation } from './NavigationProvider'\nimport type { NavigationProps } from './types'\n\nconst StyledNav = styled.nav`\n  display: flex;\n  flex-direction: row;\n  position: relative;\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.borderWeak};\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['width'].includes(prop),\n})<{\n  width: number\n}>`\n  background: ${({ theme }) => theme.colors.neutral.background};\n  display: flex;\n  flex-direction: column;\n\n  width: ${({ width }) => width}px;\n\n  &[data-expanded=\"true\"][data-animation=\"false\"] {\n    max-width: ${NAVIGATION_MAX_WIDTH}px;\n    min-width: ${NAVIGATION_MIN_WIDTH}px;\n  }\n\n  &[data-expanded=\"false\"] {\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n\n  &[data-animation=\"expand\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${({ width }) => width}px;\n  }\n\n  &[data-animation=\"collapse\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n`\n\nconst ContentContainer = styled.div`\n  overflow: hidden;\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n`\n\nconst Content = styled(Stack)`\n  overflow-y: auto;\n  overflow-x: hidden;\n  flex-grow: 1;\n\n  &[data-is-expanded=\"false\"] {\n    align-items: center;\n    padding: ${({ theme }) => theme.space['2']};\n  }\n\n  &[data-is-expanded=\"true\"],\n  &[data-animation=\"expand\"] {\n    padding: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst Slider = styled.div`\n  background: transparent;\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  right: 0;\n  width: 6px;\n  cursor: col-resize;\n  border-right: 2px solid transparent;\n  display: flex;\n\n  &:hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nexport const NavigationContent = ({\n  children,\n  logo,\n  onWidthResize,\n  className,\n  id,\n  onToggleExpand,\n}: NavigationProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation should be inside NavigationProvider to use it properly.',\n    )\n  }\n\n  const {\n    setWidth,\n    width,\n    expanded,\n    toggleExpand,\n    animation,\n    navigationRef,\n    allowNavigationResize,\n    shouldAnimate,\n  } = context\n\n  const sliderRef = useRef<HTMLDivElement | null>(null)\n  const contentRef = useRef<HTMLDivElement | null>(null)\n\n  // It will handle the resize of the navigation when the user drag the vertical bar\n  useEffect(() => {\n    let prevX: number | undefined\n    let navRect: DOMRect | undefined\n    let shouldCollapseOnMouseUp = false\n    let shouldExpandOnMouseUp = false\n\n    const mouseMove = (event: MouseEvent) => {\n      if (prevX !== undefined) {\n        const navWidth = navRect?.width ?? 0\n        const newWidth = navWidth + (event.clientX - prevX)\n\n        if (navigationRef.current && expanded) {\n          navigationRef.current.style.width = `${newWidth}px`\n        }\n\n        if (newWidth <= NAVIGATION_MIN_WIDTH) {\n          shouldCollapseOnMouseUp = true\n        } else {\n          shouldCollapseOnMouseUp = false\n        }\n\n        if (newWidth >= NAVIGATION_COLLASPED_WIDTH && !expanded) {\n          shouldExpandOnMouseUp = true\n        } else {\n          shouldExpandOnMouseUp = false\n        }\n      }\n    }\n\n    const mousedown = (event: MouseEvent) => {\n      document.body.style.pointerEvents = 'none'\n      document.body.style.userSelect = 'none'\n\n      prevX = event.clientX\n      navRect = navigationRef.current?.getBoundingClientRect()\n\n      const mouseup = () => {\n        if (shouldCollapseOnMouseUp || shouldExpandOnMouseUp) {\n          toggleExpand()\n          onToggleExpand?.(!expanded)\n        }\n\n        if (navigationRef.current) {\n          if (!shouldCollapseOnMouseUp && !shouldExpandOnMouseUp) {\n            onWidthResize?.(navigationRef.current.offsetWidth)\n            setWidth?.(navigationRef.current.offsetWidth)\n          }\n\n          if (!expanded) {\n            navigationRef.current.style.width = ''\n          }\n        }\n\n        document.removeEventListener('mousemove', mouseMove)\n        window.removeEventListener('mouseup', mouseup)\n\n        document.body.style.pointerEvents = ''\n        document.body.style.userSelect = ''\n      }\n\n      document.addEventListener('mousemove', mouseMove)\n      window.addEventListener('mouseup', mouseup)\n    }\n    const sliderRefCurrent = sliderRef.current\n\n    sliderRefCurrent?.addEventListener('mousedown', mousedown)\n\n    return () => {\n      sliderRefCurrent?.removeEventListener('mousedown', mousedown)\n    }\n  }, [\n    expanded,\n    navigationRef,\n    onToggleExpand,\n    onWidthResize,\n    setWidth,\n    toggleExpand,\n  ])\n\n  return (\n    <StyledNav className={className} id={id}>\n      <Container\n        data-animation={shouldAnimate ? animation : undefined}\n        data-expanded={expanded}\n        ref={navigationRef}\n        width={width}\n      >\n        {logo ? <Header logo={logo} /> : null}\n        <ContentContainer>\n          <Content\n            data-animation={shouldAnimate ? animation : undefined}\n            data-is-expanded={expanded}\n            gap={0.25}\n            ref={contentRef}\n          >\n            {children}\n          </Content>\n          {allowNavigationResize ? (\n            <Footer contentRef={contentRef} onToggleExpand={onToggleExpand} />\n          ) : null}\n        </ContentContainer>\n      </Container>\n      {allowNavigationResize ? (\n        <Slider data-testid=\"slider\" ref={sliderRef} />\n      ) : null}\n    </StyledNav>\n  )\n}\n"]} */"));
57
+ }) => theme.space["2"], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx"],"names":[],"mappings":"AA6D6B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { Stack } from '@ultraviolet/ui'\nimport { useEffect, useRef } from 'react'\nimport {\n  ANIMATION_DURATION,\n  NAVIGATION_COLLASPED_WIDTH,\n  NAVIGATION_MAX_WIDTH,\n  NAVIGATION_MIN_WIDTH,\n} from './constants'\nimport { Footer } from './Footer'\nimport { Header } from './Header'\nimport { useNavigation } from './NavigationProvider'\nimport type { NavigationProps } from './types'\n\nconst StyledNav = styled.nav`\n  display: flex;\n  flex-direction: row;\n  position: relative;\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.borderWeak};\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['width'].includes(prop),\n})<{\n  width: number\n}>`\n  background: ${({ theme }) => theme.colors.neutral.background};\n  display: flex;\n  flex-direction: column;\n\n  width: ${({ width }) => width}px;\n\n  &[data-expanded=\"true\"][data-animation=\"false\"] {\n    max-width: ${NAVIGATION_MAX_WIDTH}px;\n    min-width: ${NAVIGATION_MIN_WIDTH}px;\n  }\n\n  &[data-expanded=\"false\"] {\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n\n  &[data-animation=\"expand\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${({ width }) => width}px;\n  }\n\n  &[data-animation=\"collapse\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n`\n\nconst ContentContainer = styled.div`\n  overflow: hidden;\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n`\n\nconst Content = styled(Stack)`\n  overflow-y: auto;\n  overflow-x: hidden;\n  flex-grow: 1;\n\n  &[data-is-expanded=\"false\"] {\n    align-items: center;\n    padding: ${({ theme }) => theme.space['2']};\n  }\n\n  &[data-is-expanded=\"true\"],\n  &[data-animation=\"expand\"] {\n    padding: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst Slider = styled.div`\n  background: transparent;\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  right: 0;\n  width: 6px;\n  cursor: col-resize;\n  border-right: 2px solid transparent;\n  display: flex;\n\n  &:hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nexport const NavigationContent = ({\n  children,\n  logo,\n  onWidthResize,\n  className,\n  'data-testid': dataTestId,\n  id,\n  onToggleExpand,\n}: NavigationProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation should be inside NavigationProvider to use it properly.',\n    )\n  }\n\n  const {\n    setWidth,\n    width,\n    expanded,\n    toggleExpand,\n    animation,\n    navigationRef,\n    allowNavigationResize,\n    shouldAnimate,\n  } = context\n\n  const sliderRef = useRef<HTMLDivElement | null>(null)\n  const contentRef = useRef<HTMLDivElement | null>(null)\n\n  // It will handle the resize of the navigation when the user drag the vertical bar\n  useEffect(() => {\n    let prevX: number | undefined\n    let navRect: DOMRect | undefined\n    let shouldCollapseOnMouseUp = false\n    let shouldExpandOnMouseUp = false\n\n    const mouseMove = (event: MouseEvent) => {\n      if (prevX !== undefined) {\n        const navWidth = navRect?.width ?? 0\n        const newWidth = navWidth + (event.clientX - prevX)\n\n        if (navigationRef.current && expanded) {\n          navigationRef.current.style.width = `${newWidth}px`\n        }\n\n        if (newWidth <= NAVIGATION_MIN_WIDTH) {\n          shouldCollapseOnMouseUp = true\n        } else {\n          shouldCollapseOnMouseUp = false\n        }\n\n        if (newWidth >= NAVIGATION_COLLASPED_WIDTH && !expanded) {\n          shouldExpandOnMouseUp = true\n        } else {\n          shouldExpandOnMouseUp = false\n        }\n      }\n    }\n\n    const mousedown = (event: MouseEvent) => {\n      document.body.style.pointerEvents = 'none'\n      document.body.style.userSelect = 'none'\n\n      prevX = event.clientX\n      navRect = navigationRef.current?.getBoundingClientRect()\n\n      const mouseup = () => {\n        if (shouldCollapseOnMouseUp || shouldExpandOnMouseUp) {\n          toggleExpand()\n          onToggleExpand?.(!expanded)\n        }\n\n        if (navigationRef.current) {\n          if (!shouldCollapseOnMouseUp && !shouldExpandOnMouseUp) {\n            onWidthResize?.(navigationRef.current.offsetWidth)\n            setWidth?.(navigationRef.current.offsetWidth)\n          }\n\n          if (!expanded) {\n            navigationRef.current.style.width = ''\n          }\n        }\n\n        document.removeEventListener('mousemove', mouseMove)\n        window.removeEventListener('mouseup', mouseup)\n\n        document.body.style.pointerEvents = ''\n        document.body.style.userSelect = ''\n      }\n\n      document.addEventListener('mousemove', mouseMove)\n      window.addEventListener('mouseup', mouseup)\n    }\n    const sliderRefCurrent = sliderRef.current\n\n    sliderRefCurrent?.addEventListener('mousedown', mousedown)\n\n    return () => {\n      sliderRefCurrent?.removeEventListener('mousedown', mousedown)\n    }\n  }, [\n    expanded,\n    navigationRef,\n    onToggleExpand,\n    onWidthResize,\n    setWidth,\n    toggleExpand,\n  ])\n\n  return (\n    <StyledNav className={className} data-testid={dataTestId} id={id}>\n      <Container\n        data-animation={shouldAnimate ? animation : undefined}\n        data-expanded={expanded}\n        ref={navigationRef}\n        width={width}\n      >\n        {logo ? <Header logo={logo} /> : null}\n        <ContentContainer>\n          <Content\n            data-animation={shouldAnimate ? animation : undefined}\n            data-is-expanded={expanded}\n            gap={0.25}\n            ref={contentRef}\n          >\n            {children}\n          </Content>\n          {allowNavigationResize ? (\n            <Footer contentRef={contentRef} onToggleExpand={onToggleExpand} />\n          ) : null}\n        </ContentContainer>\n      </Container>\n      {allowNavigationResize ? (\n        <Slider data-testid=\"slider\" ref={sliderRef} />\n      ) : null}\n    </StyledNav>\n  )\n}\n"]} */"));
58
58
  const Slider = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
59
59
  target: "esezfu50"
60
60
  } : {
@@ -62,12 +62,13 @@ const Slider = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "producti
62
62
  label: "Slider"
63
63
  })("background:transparent;position:absolute;top:0;bottom:0;right:0;width:6px;cursor:col-resize;border-right:2px solid transparent;display:flex;&:hover{border-color:", ({
64
64
  theme
65
- }) => theme.colors.primary.border, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx"],"names":[],"mappings":"AA6EyB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { Stack } from '@ultraviolet/ui'\nimport { useEffect, useRef } from 'react'\nimport {\n  ANIMATION_DURATION,\n  NAVIGATION_COLLASPED_WIDTH,\n  NAVIGATION_MAX_WIDTH,\n  NAVIGATION_MIN_WIDTH,\n} from './constants'\nimport { Footer } from './Footer'\nimport { Header } from './Header'\nimport { useNavigation } from './NavigationProvider'\nimport type { NavigationProps } from './types'\n\nconst StyledNav = styled.nav`\n  display: flex;\n  flex-direction: row;\n  position: relative;\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.borderWeak};\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['width'].includes(prop),\n})<{\n  width: number\n}>`\n  background: ${({ theme }) => theme.colors.neutral.background};\n  display: flex;\n  flex-direction: column;\n\n  width: ${({ width }) => width}px;\n\n  &[data-expanded=\"true\"][data-animation=\"false\"] {\n    max-width: ${NAVIGATION_MAX_WIDTH}px;\n    min-width: ${NAVIGATION_MIN_WIDTH}px;\n  }\n\n  &[data-expanded=\"false\"] {\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n\n  &[data-animation=\"expand\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${({ width }) => width}px;\n  }\n\n  &[data-animation=\"collapse\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n`\n\nconst ContentContainer = styled.div`\n  overflow: hidden;\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n`\n\nconst Content = styled(Stack)`\n  overflow-y: auto;\n  overflow-x: hidden;\n  flex-grow: 1;\n\n  &[data-is-expanded=\"false\"] {\n    align-items: center;\n    padding: ${({ theme }) => theme.space['2']};\n  }\n\n  &[data-is-expanded=\"true\"],\n  &[data-animation=\"expand\"] {\n    padding: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst Slider = styled.div`\n  background: transparent;\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  right: 0;\n  width: 6px;\n  cursor: col-resize;\n  border-right: 2px solid transparent;\n  display: flex;\n\n  &:hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nexport const NavigationContent = ({\n  children,\n  logo,\n  onWidthResize,\n  className,\n  id,\n  onToggleExpand,\n}: NavigationProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation should be inside NavigationProvider to use it properly.',\n    )\n  }\n\n  const {\n    setWidth,\n    width,\n    expanded,\n    toggleExpand,\n    animation,\n    navigationRef,\n    allowNavigationResize,\n    shouldAnimate,\n  } = context\n\n  const sliderRef = useRef<HTMLDivElement | null>(null)\n  const contentRef = useRef<HTMLDivElement | null>(null)\n\n  // It will handle the resize of the navigation when the user drag the vertical bar\n  useEffect(() => {\n    let prevX: number | undefined\n    let navRect: DOMRect | undefined\n    let shouldCollapseOnMouseUp = false\n    let shouldExpandOnMouseUp = false\n\n    const mouseMove = (event: MouseEvent) => {\n      if (prevX !== undefined) {\n        const navWidth = navRect?.width ?? 0\n        const newWidth = navWidth + (event.clientX - prevX)\n\n        if (navigationRef.current && expanded) {\n          navigationRef.current.style.width = `${newWidth}px`\n        }\n\n        if (newWidth <= NAVIGATION_MIN_WIDTH) {\n          shouldCollapseOnMouseUp = true\n        } else {\n          shouldCollapseOnMouseUp = false\n        }\n\n        if (newWidth >= NAVIGATION_COLLASPED_WIDTH && !expanded) {\n          shouldExpandOnMouseUp = true\n        } else {\n          shouldExpandOnMouseUp = false\n        }\n      }\n    }\n\n    const mousedown = (event: MouseEvent) => {\n      document.body.style.pointerEvents = 'none'\n      document.body.style.userSelect = 'none'\n\n      prevX = event.clientX\n      navRect = navigationRef.current?.getBoundingClientRect()\n\n      const mouseup = () => {\n        if (shouldCollapseOnMouseUp || shouldExpandOnMouseUp) {\n          toggleExpand()\n          onToggleExpand?.(!expanded)\n        }\n\n        if (navigationRef.current) {\n          if (!shouldCollapseOnMouseUp && !shouldExpandOnMouseUp) {\n            onWidthResize?.(navigationRef.current.offsetWidth)\n            setWidth?.(navigationRef.current.offsetWidth)\n          }\n\n          if (!expanded) {\n            navigationRef.current.style.width = ''\n          }\n        }\n\n        document.removeEventListener('mousemove', mouseMove)\n        window.removeEventListener('mouseup', mouseup)\n\n        document.body.style.pointerEvents = ''\n        document.body.style.userSelect = ''\n      }\n\n      document.addEventListener('mousemove', mouseMove)\n      window.addEventListener('mouseup', mouseup)\n    }\n    const sliderRefCurrent = sliderRef.current\n\n    sliderRefCurrent?.addEventListener('mousedown', mousedown)\n\n    return () => {\n      sliderRefCurrent?.removeEventListener('mousedown', mousedown)\n    }\n  }, [\n    expanded,\n    navigationRef,\n    onToggleExpand,\n    onWidthResize,\n    setWidth,\n    toggleExpand,\n  ])\n\n  return (\n    <StyledNav className={className} id={id}>\n      <Container\n        data-animation={shouldAnimate ? animation : undefined}\n        data-expanded={expanded}\n        ref={navigationRef}\n        width={width}\n      >\n        {logo ? <Header logo={logo} /> : null}\n        <ContentContainer>\n          <Content\n            data-animation={shouldAnimate ? animation : undefined}\n            data-is-expanded={expanded}\n            gap={0.25}\n            ref={contentRef}\n          >\n            {children}\n          </Content>\n          {allowNavigationResize ? (\n            <Footer contentRef={contentRef} onToggleExpand={onToggleExpand} />\n          ) : null}\n        </ContentContainer>\n      </Container>\n      {allowNavigationResize ? (\n        <Slider data-testid=\"slider\" ref={sliderRef} />\n      ) : null}\n    </StyledNav>\n  )\n}\n"]} */"));
65
+ }) => theme.colors.primary.border, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx"],"names":[],"mappings":"AA6EyB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/NavigationContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { Stack } from '@ultraviolet/ui'\nimport { useEffect, useRef } from 'react'\nimport {\n  ANIMATION_DURATION,\n  NAVIGATION_COLLASPED_WIDTH,\n  NAVIGATION_MAX_WIDTH,\n  NAVIGATION_MIN_WIDTH,\n} from './constants'\nimport { Footer } from './Footer'\nimport { Header } from './Header'\nimport { useNavigation } from './NavigationProvider'\nimport type { NavigationProps } from './types'\n\nconst StyledNav = styled.nav`\n  display: flex;\n  flex-direction: row;\n  position: relative;\n  border-right: 1px solid ${({ theme }) => theme.colors.neutral.borderWeak};\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['width'].includes(prop),\n})<{\n  width: number\n}>`\n  background: ${({ theme }) => theme.colors.neutral.background};\n  display: flex;\n  flex-direction: column;\n\n  width: ${({ width }) => width}px;\n\n  &[data-expanded=\"true\"][data-animation=\"false\"] {\n    max-width: ${NAVIGATION_MAX_WIDTH}px;\n    min-width: ${NAVIGATION_MIN_WIDTH}px;\n  }\n\n  &[data-expanded=\"false\"] {\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n\n  &[data-animation=\"expand\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${({ width }) => width}px;\n  }\n\n  &[data-animation=\"collapse\"] {\n    transition: width ${ANIMATION_DURATION}ms ease-in-out;\n    width: ${NAVIGATION_COLLASPED_WIDTH}px;\n  }\n`\n\nconst ContentContainer = styled.div`\n  overflow: hidden;\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n`\n\nconst Content = styled(Stack)`\n  overflow-y: auto;\n  overflow-x: hidden;\n  flex-grow: 1;\n\n  &[data-is-expanded=\"false\"] {\n    align-items: center;\n    padding: ${({ theme }) => theme.space['2']};\n  }\n\n  &[data-is-expanded=\"true\"],\n  &[data-animation=\"expand\"] {\n    padding: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst Slider = styled.div`\n  background: transparent;\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  right: 0;\n  width: 6px;\n  cursor: col-resize;\n  border-right: 2px solid transparent;\n  display: flex;\n\n  &:hover {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nexport const NavigationContent = ({\n  children,\n  logo,\n  onWidthResize,\n  className,\n  'data-testid': dataTestId,\n  id,\n  onToggleExpand,\n}: NavigationProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation should be inside NavigationProvider to use it properly.',\n    )\n  }\n\n  const {\n    setWidth,\n    width,\n    expanded,\n    toggleExpand,\n    animation,\n    navigationRef,\n    allowNavigationResize,\n    shouldAnimate,\n  } = context\n\n  const sliderRef = useRef<HTMLDivElement | null>(null)\n  const contentRef = useRef<HTMLDivElement | null>(null)\n\n  // It will handle the resize of the navigation when the user drag the vertical bar\n  useEffect(() => {\n    let prevX: number | undefined\n    let navRect: DOMRect | undefined\n    let shouldCollapseOnMouseUp = false\n    let shouldExpandOnMouseUp = false\n\n    const mouseMove = (event: MouseEvent) => {\n      if (prevX !== undefined) {\n        const navWidth = navRect?.width ?? 0\n        const newWidth = navWidth + (event.clientX - prevX)\n\n        if (navigationRef.current && expanded) {\n          navigationRef.current.style.width = `${newWidth}px`\n        }\n\n        if (newWidth <= NAVIGATION_MIN_WIDTH) {\n          shouldCollapseOnMouseUp = true\n        } else {\n          shouldCollapseOnMouseUp = false\n        }\n\n        if (newWidth >= NAVIGATION_COLLASPED_WIDTH && !expanded) {\n          shouldExpandOnMouseUp = true\n        } else {\n          shouldExpandOnMouseUp = false\n        }\n      }\n    }\n\n    const mousedown = (event: MouseEvent) => {\n      document.body.style.pointerEvents = 'none'\n      document.body.style.userSelect = 'none'\n\n      prevX = event.clientX\n      navRect = navigationRef.current?.getBoundingClientRect()\n\n      const mouseup = () => {\n        if (shouldCollapseOnMouseUp || shouldExpandOnMouseUp) {\n          toggleExpand()\n          onToggleExpand?.(!expanded)\n        }\n\n        if (navigationRef.current) {\n          if (!shouldCollapseOnMouseUp && !shouldExpandOnMouseUp) {\n            onWidthResize?.(navigationRef.current.offsetWidth)\n            setWidth?.(navigationRef.current.offsetWidth)\n          }\n\n          if (!expanded) {\n            navigationRef.current.style.width = ''\n          }\n        }\n\n        document.removeEventListener('mousemove', mouseMove)\n        window.removeEventListener('mouseup', mouseup)\n\n        document.body.style.pointerEvents = ''\n        document.body.style.userSelect = ''\n      }\n\n      document.addEventListener('mousemove', mouseMove)\n      window.addEventListener('mouseup', mouseup)\n    }\n    const sliderRefCurrent = sliderRef.current\n\n    sliderRefCurrent?.addEventListener('mousedown', mousedown)\n\n    return () => {\n      sliderRefCurrent?.removeEventListener('mousedown', mousedown)\n    }\n  }, [\n    expanded,\n    navigationRef,\n    onToggleExpand,\n    onWidthResize,\n    setWidth,\n    toggleExpand,\n  ])\n\n  return (\n    <StyledNav className={className} data-testid={dataTestId} id={id}>\n      <Container\n        data-animation={shouldAnimate ? animation : undefined}\n        data-expanded={expanded}\n        ref={navigationRef}\n        width={width}\n      >\n        {logo ? <Header logo={logo} /> : null}\n        <ContentContainer>\n          <Content\n            data-animation={shouldAnimate ? animation : undefined}\n            data-is-expanded={expanded}\n            gap={0.25}\n            ref={contentRef}\n          >\n            {children}\n          </Content>\n          {allowNavigationResize ? (\n            <Footer contentRef={contentRef} onToggleExpand={onToggleExpand} />\n          ) : null}\n        </ContentContainer>\n      </Container>\n      {allowNavigationResize ? (\n        <Slider data-testid=\"slider\" ref={sliderRef} />\n      ) : null}\n    </StyledNav>\n  )\n}\n"]} */"));
66
66
  const NavigationContent = ({
67
67
  children,
68
68
  logo,
69
69
  onWidthResize,
70
70
  className,
71
+ "data-testid": dataTestId,
71
72
  id,
72
73
  onToggleExpand
73
74
  }) => {
@@ -144,7 +145,7 @@ const NavigationContent = ({
144
145
  sliderRefCurrent?.removeEventListener("mousedown", mousedown);
145
146
  };
146
147
  }, [expanded, navigationRef, onToggleExpand, onWidthResize, setWidth, toggleExpand]);
147
- return /* @__PURE__ */ jsxs(StyledNav, { className, id, children: [
148
+ return /* @__PURE__ */ jsxs(StyledNav, { className, "data-testid": dataTestId, id, children: [
148
149
  /* @__PURE__ */ jsxs(Container, { "data-animation": shouldAnimate ? animation : void 0, "data-expanded": expanded, ref: navigationRef, width, children: [
149
150
  logo ? /* @__PURE__ */ jsx(Header, { logo }) : null,
150
151
  /* @__PURE__ */ jsxs(ContentContainer, { children: [
@@ -36,4 +36,5 @@ export type NavigationProps = {
36
36
  * This function will be called when the user toggle the expand/collapse button or with the slider.
37
37
  */
38
38
  onToggleExpand?: (expanded: boolean) => void;
39
+ 'data-testid'?: string;
39
40
  };
@@ -21,7 +21,7 @@ const StyledList = /* @__PURE__ */ _styled__default.default(ui.List, process.env
21
21
  theme
22
22
  }) => theme.sizing[700], ";max-width:", ({
23
23
  theme
24
- }) => theme.sizing[700], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L09mZmVyTGlzdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVStCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L09mZmVyTGlzdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBMaXN0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IHR5cGUgeyBDb21wb25lbnRQcm9wcyB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgQ2VsbCB9IGZyb20gJy4vY29tcG9uZW50cy9DZWxsJ1xuaW1wb3J0IHsgUm93IH0gZnJvbSAnLi9jb21wb25lbnRzL1JvdydcbmltcG9ydCB7IE9mZmVyTGlzdFByb3ZpZGVyIH0gZnJvbSAnLi9PZmZlckxpc3RQcm92aWRlcidcblxuY29uc3QgU3R5bGVkTGlzdCA9IHN0eWxlZChMaXN0KWBcbiAgIHRkOmZpcnN0LWNoaWxkLFxuICAgdGg6Zmlyc3QtY2hpbGQge1xuICAgIHdpZHRoOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgICBtaW4td2lkdGg6ICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgICBtYXgtd2lkdGg6ICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgfSBcbmBcblxudHlwZSBPZmZlckxpc3RQcm9wcyA9IE9taXQ8XG4gIENvbXBvbmVudFByb3BzPHR5cGVvZiBMaXN0PixcbiAgJ3NlbGVjdGFibGUnIHwgJ29uU2VsZWN0ZWRDaGFuZ2UnXG4+ICYge1xuICAvKipcbiAgICogTWFrZSBvZmZlckxpc3Qgc2VsZWN0YWJsZSBieSBjaG9vc2luZyBpdHMgdHlwZVxuICAgKi9cbiAgdHlwZT86ICdyYWRpbycgfCAnY2hlY2tib3gnXG4gIG9uQ2hhbmdlU2VsZWN0PzogKHNlbGVjdGVkOiBzdHJpbmcgfCBzdHJpbmdbXSkgPT4gdm9pZFxuICAvKipcbiAgICogUHJlLXNlbGVjdGVkIHJvd3MgKHVzaW5nIHRoZWlyIG9mZmVyTmFtZSkuIE11c3QgYmUgYW4gYXJyYXkgd2hlbiBgdHlwZSA9IFwiY2hlY2tib3hcImAuXG4gICAqL1xuICBzZWxlY3RlZD86IHN0cmluZyB8IHN0cmluZ1tdXG59XG5cbmV4cG9ydCBjb25zdCBPZmZlckxpc3QgPSAoe1xuICBleHBhbmRhYmxlLFxuICB0eXBlID0gJ3JhZGlvJyxcbiAgY29sdW1ucyxcbiAgY2hpbGRyZW4sXG4gIGxvYWRpbmcsXG4gIGF1dG9Db2xsYXBzZSxcbiAgc2VsZWN0ZWQsXG4gIG9uQ2hhbmdlU2VsZWN0LFxufTogT2ZmZXJMaXN0UHJvcHMpID0+IHtcbiAgY29uc3QgW3JhZGlvU2VsZWN0ZWRSb3csIHNldFJhZGlvU2VsZWN0ZWRSb3ddID0gdXNlU3RhdGU8c3RyaW5nIHwgdW5kZWZpbmVkPihcbiAgICB0eXBlb2Ygc2VsZWN0ZWQgPT09ICdzdHJpbmcnID8gc2VsZWN0ZWQgOiB1bmRlZmluZWQsXG4gIClcbiAgY29uc3QgW2NoZWNrYm94U2VsZWN0ZWRSb3dzLCBzZXRDaGVja2JveFNlbGVjdGVkUm93c10gPSB1c2VTdGF0ZTxzdHJpbmdbXT4oXG4gICAgQXJyYXkuaXNBcnJheShzZWxlY3RlZCkgPyBzZWxlY3RlZCA6IFtdLFxuICApXG5cbiAgY29uc3QgY29tcHV0ZWRDb2x1bW5zID0gW1xuICAgIHtcbiAgICAgIGxhYmVsOiAnJyxcbiAgICB9LFxuICAgIGV4cGFuZGFibGUgPyB7IGxhYmVsOiAnJyB9IDogbnVsbCxcbiAgICAuLi5jb2x1bW5zLFxuICBdLmZpbHRlcihlbGVtZW50ID0+ICEhZWxlbWVudClcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChzZWxlY3RlZCkge1xuICAgICAgaWYgKHR5cGVvZiBzZWxlY3RlZCA9PT0gJ3N0cmluZycgJiYgdHlwZSA9PT0gJ3JhZGlvJykge1xuICAgICAgICBzZXRSYWRpb1NlbGVjdGVkUm93KHNlbGVjdGVkKVxuICAgICAgfVxuICAgICAgaWYgKEFycmF5LmlzQXJyYXkoc2VsZWN0ZWQpICYmIHR5cGUgPT09ICdjaGVja2JveCcpIHtcbiAgICAgICAgc2V0Q2hlY2tib3hTZWxlY3RlZFJvd3Moc2VsZWN0ZWQpXG4gICAgICB9XG4gICAgfVxuICB9LCBbdHlwZSwgc2VsZWN0ZWRdKVxuXG4gIHJldHVybiAoXG4gICAgPE9mZmVyTGlzdFByb3ZpZGVyXG4gICAgICBhdXRvQ29sbGFwc2U9e2F1dG9Db2xsYXBzZX1cbiAgICAgIGNoZWNrYm94U2VsZWN0ZWRSb3dzPXtjaGVja2JveFNlbGVjdGVkUm93c31cbiAgICAgIGV4cGFuZGFibGU9e2V4cGFuZGFibGV9XG4gICAgICBsb2FkaW5nPXtsb2FkaW5nfVxuICAgICAgb25DaGFuZ2VTZWxlY3Q9e29uQ2hhbmdlU2VsZWN0fVxuICAgICAgcmFkaW9TZWxlY3RlZFJvdz17cmFkaW9TZWxlY3RlZFJvd31cbiAgICAgIHNlbGVjdGFibGU9e3R5cGV9XG4gICAgICBzZXRDaGVja2JveFNlbGVjdGVkUm93cz17c2V0Q2hlY2tib3hTZWxlY3RlZFJvd3N9XG4gICAgICBzZXRSYWRpb1NlbGVjdGVkUm93PXtzZXRSYWRpb1NlbGVjdGVkUm93fVxuICAgID5cbiAgICAgIDxTdHlsZWRMaXN0XG4gICAgICAgIGF1dG9Db2xsYXBzZT17YXV0b0NvbGxhcHNlfVxuICAgICAgICBjb2x1bW5zPXtjb21wdXRlZENvbHVtbnN9XG4gICAgICAgIGV4cGFuZGFibGU9e2ZhbHNlfVxuICAgICAgICBzZWxlY3RhYmxlPXtmYWxzZX1cbiAgICAgID5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgPC9TdHlsZWRMaXN0PlxuICAgIDwvT2ZmZXJMaXN0UHJvdmlkZXI+XG4gIClcbn1cblxuT2ZmZXJMaXN0LlJvdyA9IFJvd1xuT2ZmZXJMaXN0LkNlbGwgPSBDZWxsXG4iXX0= */"));
24
+ }) => theme.sizing[700], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L09mZmVyTGlzdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVStCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L09mZmVyTGlzdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBMaXN0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IHR5cGUgeyBDb21wb25lbnRQcm9wcyB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgQ2VsbCB9IGZyb20gJy4vY29tcG9uZW50cy9DZWxsJ1xuaW1wb3J0IHsgUm93IH0gZnJvbSAnLi9jb21wb25lbnRzL1JvdydcbmltcG9ydCB7IE9mZmVyTGlzdFByb3ZpZGVyIH0gZnJvbSAnLi9PZmZlckxpc3RQcm92aWRlcidcblxuY29uc3QgU3R5bGVkTGlzdCA9IHN0eWxlZChMaXN0KWBcbiAgIHRkOmZpcnN0LWNoaWxkLFxuICAgdGg6Zmlyc3QtY2hpbGQge1xuICAgIHdpZHRoOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgICBtaW4td2lkdGg6ICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgICBtYXgtd2lkdGg6ICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgfVxuYFxuXG50eXBlIE9mZmVyTGlzdFByb3BzID0gT21pdDxcbiAgQ29tcG9uZW50UHJvcHM8dHlwZW9mIExpc3Q+LFxuICAnc2VsZWN0YWJsZScgfCAnb25TZWxlY3RlZENoYW5nZSdcbj4gJiB7XG4gIC8qKlxuICAgKiBNYWtlIG9mZmVyTGlzdCBzZWxlY3RhYmxlIGJ5IGNob29zaW5nIGl0cyB0eXBlXG4gICAqL1xuICB0eXBlPzogJ3JhZGlvJyB8ICdjaGVja2JveCdcbiAgb25DaGFuZ2VTZWxlY3Q/OiAoc2VsZWN0ZWQ6IHN0cmluZyB8IHN0cmluZ1tdKSA9PiB2b2lkXG4gIC8qKlxuICAgKiBQcmUtc2VsZWN0ZWQgcm93cyAodXNpbmcgdGhlaXIgb2ZmZXJOYW1lKS4gTXVzdCBiZSBhbiBhcnJheSB3aGVuIGB0eXBlID0gXCJjaGVja2JveFwiYC5cbiAgICovXG4gIHNlbGVjdGVkPzogc3RyaW5nIHwgc3RyaW5nW11cbiAgWydkYXRhLXRlc3RpZCddPzogc3RyaW5nXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xufVxuXG5leHBvcnQgY29uc3QgT2ZmZXJMaXN0ID0gKHtcbiAgZXhwYW5kYWJsZSxcbiAgdHlwZSA9ICdyYWRpbycsXG4gIGNvbHVtbnMsXG4gIGNoaWxkcmVuLFxuICBsb2FkaW5nLFxuICBhdXRvQ29sbGFwc2UsXG4gIHNlbGVjdGVkLFxuICBvbkNoYW5nZVNlbGVjdCxcbiAgY2xhc3NOYW1lLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxufTogT2ZmZXJMaXN0UHJvcHMpID0+IHtcbiAgY29uc3QgW3JhZGlvU2VsZWN0ZWRSb3csIHNldFJhZGlvU2VsZWN0ZWRSb3ddID0gdXNlU3RhdGU8c3RyaW5nIHwgdW5kZWZpbmVkPihcbiAgICB0eXBlb2Ygc2VsZWN0ZWQgPT09ICdzdHJpbmcnID8gc2VsZWN0ZWQgOiB1bmRlZmluZWQsXG4gIClcbiAgY29uc3QgW2NoZWNrYm94U2VsZWN0ZWRSb3dzLCBzZXRDaGVja2JveFNlbGVjdGVkUm93c10gPSB1c2VTdGF0ZTxzdHJpbmdbXT4oXG4gICAgQXJyYXkuaXNBcnJheShzZWxlY3RlZCkgPyBzZWxlY3RlZCA6IFtdLFxuICApXG5cbiAgY29uc3QgY29tcHV0ZWRDb2x1bW5zID0gW1xuICAgIHtcbiAgICAgIGxhYmVsOiAnJyxcbiAgICB9LFxuICAgIGV4cGFuZGFibGUgPyB7IGxhYmVsOiAnJyB9IDogbnVsbCxcbiAgICAuLi5jb2x1bW5zLFxuICBdLmZpbHRlcihlbGVtZW50ID0+ICEhZWxlbWVudClcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChzZWxlY3RlZCkge1xuICAgICAgaWYgKHR5cGVvZiBzZWxlY3RlZCA9PT0gJ3N0cmluZycgJiYgdHlwZSA9PT0gJ3JhZGlvJykge1xuICAgICAgICBzZXRSYWRpb1NlbGVjdGVkUm93KHNlbGVjdGVkKVxuICAgICAgfVxuICAgICAgaWYgKEFycmF5LmlzQXJyYXkoc2VsZWN0ZWQpICYmIHR5cGUgPT09ICdjaGVja2JveCcpIHtcbiAgICAgICAgc2V0Q2hlY2tib3hTZWxlY3RlZFJvd3Moc2VsZWN0ZWQpXG4gICAgICB9XG4gICAgfVxuICB9LCBbdHlwZSwgc2VsZWN0ZWRdKVxuXG4gIHJldHVybiAoXG4gICAgPE9mZmVyTGlzdFByb3ZpZGVyXG4gICAgICBhdXRvQ29sbGFwc2U9e2F1dG9Db2xsYXBzZX1cbiAgICAgIGNoZWNrYm94U2VsZWN0ZWRSb3dzPXtjaGVja2JveFNlbGVjdGVkUm93c31cbiAgICAgIGV4cGFuZGFibGU9e2V4cGFuZGFibGV9XG4gICAgICBsb2FkaW5nPXtsb2FkaW5nfVxuICAgICAgb25DaGFuZ2VTZWxlY3Q9e29uQ2hhbmdlU2VsZWN0fVxuICAgICAgcmFkaW9TZWxlY3RlZFJvdz17cmFkaW9TZWxlY3RlZFJvd31cbiAgICAgIHNlbGVjdGFibGU9e3R5cGV9XG4gICAgICBzZXRDaGVja2JveFNlbGVjdGVkUm93cz17c2V0Q2hlY2tib3hTZWxlY3RlZFJvd3N9XG4gICAgICBzZXRSYWRpb1NlbGVjdGVkUm93PXtzZXRSYWRpb1NlbGVjdGVkUm93fVxuICAgID5cbiAgICAgIDxTdHlsZWRMaXN0XG4gICAgICAgIGF1dG9Db2xsYXBzZT17YXV0b0NvbGxhcHNlfVxuICAgICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgICAgY29sdW1ucz17Y29tcHV0ZWRDb2x1bW5zfVxuICAgICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAgICAgZXhwYW5kYWJsZT17ZmFsc2V9XG4gICAgICAgIHNlbGVjdGFibGU9e2ZhbHNlfVxuICAgICAgPlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L1N0eWxlZExpc3Q+XG4gICAgPC9PZmZlckxpc3RQcm92aWRlcj5cbiAgKVxufVxuXG5PZmZlckxpc3QuUm93ID0gUm93XG5PZmZlckxpc3QuQ2VsbCA9IENlbGxcbiJdfQ== */"));
25
25
  const OfferList = ({
26
26
  expandable,
27
27
  type = "radio",
@@ -30,7 +30,9 @@ const OfferList = ({
30
30
  loading,
31
31
  autoCollapse,
32
32
  selected,
33
- onChangeSelect
33
+ onChangeSelect,
34
+ className,
35
+ "data-testid": dataTestId
34
36
  }) => {
35
37
  const [radioSelectedRow, setRadioSelectedRow] = react.useState(typeof selected === "string" ? selected : void 0);
36
38
  const [checkboxSelectedRows, setCheckboxSelectedRows] = react.useState(Array.isArray(selected) ? selected : []);
@@ -49,7 +51,7 @@ const OfferList = ({
49
51
  }
50
52
  }
51
53
  }, [type, selected]);
52
- return /* @__PURE__ */ jsxRuntime.jsx(OfferListProvider.OfferListProvider, { autoCollapse, checkboxSelectedRows, expandable, loading, onChangeSelect, radioSelectedRow, selectable: type, setCheckboxSelectedRows, setRadioSelectedRow, children: /* @__PURE__ */ jsxRuntime.jsx(StyledList, { autoCollapse, columns: computedColumns, expandable: false, selectable: false, children }) });
54
+ return /* @__PURE__ */ jsxRuntime.jsx(OfferListProvider.OfferListProvider, { autoCollapse, checkboxSelectedRows, expandable, loading, onChangeSelect, radioSelectedRow, selectable: type, setCheckboxSelectedRows, setRadioSelectedRow, children: /* @__PURE__ */ jsxRuntime.jsx(StyledList, { autoCollapse, className, columns: computedColumns, "data-testid": dataTestId, expandable: false, selectable: false, children }) });
53
55
  };
54
56
  OfferList.Row = Row.Row;
55
57
  OfferList.Cell = Cell.Cell;
@@ -10,9 +10,11 @@ type OfferListProps = Omit<ComponentProps<typeof List>, 'selectable' | 'onSelect
10
10
  * Pre-selected rows (using their offerName). Must be an array when `type = "checkbox"`.
11
11
  */
12
12
  selected?: string | string[];
13
+ ['data-testid']?: string;
14
+ className?: string;
13
15
  };
14
16
  export declare const OfferList: {
15
- ({ expandable, type, columns, children, loading, autoCollapse, selected, onChangeSelect, }: OfferListProps): import("@emotion/react/jsx-runtime").JSX.Element;
17
+ ({ expandable, type, columns, children, loading, autoCollapse, selected, onChangeSelect, className, "data-testid": dataTestId, }: OfferListProps): import("@emotion/react/jsx-runtime").JSX.Element;
16
18
  Row: ({ children, disabled, id, banner, expandablePadding, offerName, expandable: expandableContent, selectDisabled, highlightAnimation, expanded, className, "data-dragging": dataDragging, "data-testid": dataTestId, style, badge, }: {
17
19
  children: import("react").ReactNode;
18
20
  id: string;
@@ -17,7 +17,7 @@ const StyledList = /* @__PURE__ */ _styled(List, process.env.NODE_ENV === "produ
17
17
  theme
18
18
  }) => theme.sizing[700], ";max-width:", ({
19
19
  theme
20
- }) => theme.sizing[700], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L09mZmVyTGlzdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVStCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L09mZmVyTGlzdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBMaXN0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IHR5cGUgeyBDb21wb25lbnRQcm9wcyB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgQ2VsbCB9IGZyb20gJy4vY29tcG9uZW50cy9DZWxsJ1xuaW1wb3J0IHsgUm93IH0gZnJvbSAnLi9jb21wb25lbnRzL1JvdydcbmltcG9ydCB7IE9mZmVyTGlzdFByb3ZpZGVyIH0gZnJvbSAnLi9PZmZlckxpc3RQcm92aWRlcidcblxuY29uc3QgU3R5bGVkTGlzdCA9IHN0eWxlZChMaXN0KWBcbiAgIHRkOmZpcnN0LWNoaWxkLFxuICAgdGg6Zmlyc3QtY2hpbGQge1xuICAgIHdpZHRoOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgICBtaW4td2lkdGg6ICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgICBtYXgtd2lkdGg6ICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgfSBcbmBcblxudHlwZSBPZmZlckxpc3RQcm9wcyA9IE9taXQ8XG4gIENvbXBvbmVudFByb3BzPHR5cGVvZiBMaXN0PixcbiAgJ3NlbGVjdGFibGUnIHwgJ29uU2VsZWN0ZWRDaGFuZ2UnXG4+ICYge1xuICAvKipcbiAgICogTWFrZSBvZmZlckxpc3Qgc2VsZWN0YWJsZSBieSBjaG9vc2luZyBpdHMgdHlwZVxuICAgKi9cbiAgdHlwZT86ICdyYWRpbycgfCAnY2hlY2tib3gnXG4gIG9uQ2hhbmdlU2VsZWN0PzogKHNlbGVjdGVkOiBzdHJpbmcgfCBzdHJpbmdbXSkgPT4gdm9pZFxuICAvKipcbiAgICogUHJlLXNlbGVjdGVkIHJvd3MgKHVzaW5nIHRoZWlyIG9mZmVyTmFtZSkuIE11c3QgYmUgYW4gYXJyYXkgd2hlbiBgdHlwZSA9IFwiY2hlY2tib3hcImAuXG4gICAqL1xuICBzZWxlY3RlZD86IHN0cmluZyB8IHN0cmluZ1tdXG59XG5cbmV4cG9ydCBjb25zdCBPZmZlckxpc3QgPSAoe1xuICBleHBhbmRhYmxlLFxuICB0eXBlID0gJ3JhZGlvJyxcbiAgY29sdW1ucyxcbiAgY2hpbGRyZW4sXG4gIGxvYWRpbmcsXG4gIGF1dG9Db2xsYXBzZSxcbiAgc2VsZWN0ZWQsXG4gIG9uQ2hhbmdlU2VsZWN0LFxufTogT2ZmZXJMaXN0UHJvcHMpID0+IHtcbiAgY29uc3QgW3JhZGlvU2VsZWN0ZWRSb3csIHNldFJhZGlvU2VsZWN0ZWRSb3ddID0gdXNlU3RhdGU8c3RyaW5nIHwgdW5kZWZpbmVkPihcbiAgICB0eXBlb2Ygc2VsZWN0ZWQgPT09ICdzdHJpbmcnID8gc2VsZWN0ZWQgOiB1bmRlZmluZWQsXG4gIClcbiAgY29uc3QgW2NoZWNrYm94U2VsZWN0ZWRSb3dzLCBzZXRDaGVja2JveFNlbGVjdGVkUm93c10gPSB1c2VTdGF0ZTxzdHJpbmdbXT4oXG4gICAgQXJyYXkuaXNBcnJheShzZWxlY3RlZCkgPyBzZWxlY3RlZCA6IFtdLFxuICApXG5cbiAgY29uc3QgY29tcHV0ZWRDb2x1bW5zID0gW1xuICAgIHtcbiAgICAgIGxhYmVsOiAnJyxcbiAgICB9LFxuICAgIGV4cGFuZGFibGUgPyB7IGxhYmVsOiAnJyB9IDogbnVsbCxcbiAgICAuLi5jb2x1bW5zLFxuICBdLmZpbHRlcihlbGVtZW50ID0+ICEhZWxlbWVudClcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChzZWxlY3RlZCkge1xuICAgICAgaWYgKHR5cGVvZiBzZWxlY3RlZCA9PT0gJ3N0cmluZycgJiYgdHlwZSA9PT0gJ3JhZGlvJykge1xuICAgICAgICBzZXRSYWRpb1NlbGVjdGVkUm93KHNlbGVjdGVkKVxuICAgICAgfVxuICAgICAgaWYgKEFycmF5LmlzQXJyYXkoc2VsZWN0ZWQpICYmIHR5cGUgPT09ICdjaGVja2JveCcpIHtcbiAgICAgICAgc2V0Q2hlY2tib3hTZWxlY3RlZFJvd3Moc2VsZWN0ZWQpXG4gICAgICB9XG4gICAgfVxuICB9LCBbdHlwZSwgc2VsZWN0ZWRdKVxuXG4gIHJldHVybiAoXG4gICAgPE9mZmVyTGlzdFByb3ZpZGVyXG4gICAgICBhdXRvQ29sbGFwc2U9e2F1dG9Db2xsYXBzZX1cbiAgICAgIGNoZWNrYm94U2VsZWN0ZWRSb3dzPXtjaGVja2JveFNlbGVjdGVkUm93c31cbiAgICAgIGV4cGFuZGFibGU9e2V4cGFuZGFibGV9XG4gICAgICBsb2FkaW5nPXtsb2FkaW5nfVxuICAgICAgb25DaGFuZ2VTZWxlY3Q9e29uQ2hhbmdlU2VsZWN0fVxuICAgICAgcmFkaW9TZWxlY3RlZFJvdz17cmFkaW9TZWxlY3RlZFJvd31cbiAgICAgIHNlbGVjdGFibGU9e3R5cGV9XG4gICAgICBzZXRDaGVja2JveFNlbGVjdGVkUm93cz17c2V0Q2hlY2tib3hTZWxlY3RlZFJvd3N9XG4gICAgICBzZXRSYWRpb1NlbGVjdGVkUm93PXtzZXRSYWRpb1NlbGVjdGVkUm93fVxuICAgID5cbiAgICAgIDxTdHlsZWRMaXN0XG4gICAgICAgIGF1dG9Db2xsYXBzZT17YXV0b0NvbGxhcHNlfVxuICAgICAgICBjb2x1bW5zPXtjb21wdXRlZENvbHVtbnN9XG4gICAgICAgIGV4cGFuZGFibGU9e2ZhbHNlfVxuICAgICAgICBzZWxlY3RhYmxlPXtmYWxzZX1cbiAgICAgID5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgPC9TdHlsZWRMaXN0PlxuICAgIDwvT2ZmZXJMaXN0UHJvdmlkZXI+XG4gIClcbn1cblxuT2ZmZXJMaXN0LlJvdyA9IFJvd1xuT2ZmZXJMaXN0LkNlbGwgPSBDZWxsXG4iXX0= */"));
20
+ }) => theme.sizing[700], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L09mZmVyTGlzdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVStCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L09mZmVyTGlzdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBMaXN0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IHR5cGUgeyBDb21wb25lbnRQcm9wcyB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgQ2VsbCB9IGZyb20gJy4vY29tcG9uZW50cy9DZWxsJ1xuaW1wb3J0IHsgUm93IH0gZnJvbSAnLi9jb21wb25lbnRzL1JvdydcbmltcG9ydCB7IE9mZmVyTGlzdFByb3ZpZGVyIH0gZnJvbSAnLi9PZmZlckxpc3RQcm92aWRlcidcblxuY29uc3QgU3R5bGVkTGlzdCA9IHN0eWxlZChMaXN0KWBcbiAgIHRkOmZpcnN0LWNoaWxkLFxuICAgdGg6Zmlyc3QtY2hpbGQge1xuICAgIHdpZHRoOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgICBtaW4td2lkdGg6ICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgICBtYXgtd2lkdGg6ICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgfVxuYFxuXG50eXBlIE9mZmVyTGlzdFByb3BzID0gT21pdDxcbiAgQ29tcG9uZW50UHJvcHM8dHlwZW9mIExpc3Q+LFxuICAnc2VsZWN0YWJsZScgfCAnb25TZWxlY3RlZENoYW5nZSdcbj4gJiB7XG4gIC8qKlxuICAgKiBNYWtlIG9mZmVyTGlzdCBzZWxlY3RhYmxlIGJ5IGNob29zaW5nIGl0cyB0eXBlXG4gICAqL1xuICB0eXBlPzogJ3JhZGlvJyB8ICdjaGVja2JveCdcbiAgb25DaGFuZ2VTZWxlY3Q/OiAoc2VsZWN0ZWQ6IHN0cmluZyB8IHN0cmluZ1tdKSA9PiB2b2lkXG4gIC8qKlxuICAgKiBQcmUtc2VsZWN0ZWQgcm93cyAodXNpbmcgdGhlaXIgb2ZmZXJOYW1lKS4gTXVzdCBiZSBhbiBhcnJheSB3aGVuIGB0eXBlID0gXCJjaGVja2JveFwiYC5cbiAgICovXG4gIHNlbGVjdGVkPzogc3RyaW5nIHwgc3RyaW5nW11cbiAgWydkYXRhLXRlc3RpZCddPzogc3RyaW5nXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xufVxuXG5leHBvcnQgY29uc3QgT2ZmZXJMaXN0ID0gKHtcbiAgZXhwYW5kYWJsZSxcbiAgdHlwZSA9ICdyYWRpbycsXG4gIGNvbHVtbnMsXG4gIGNoaWxkcmVuLFxuICBsb2FkaW5nLFxuICBhdXRvQ29sbGFwc2UsXG4gIHNlbGVjdGVkLFxuICBvbkNoYW5nZVNlbGVjdCxcbiAgY2xhc3NOYW1lLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxufTogT2ZmZXJMaXN0UHJvcHMpID0+IHtcbiAgY29uc3QgW3JhZGlvU2VsZWN0ZWRSb3csIHNldFJhZGlvU2VsZWN0ZWRSb3ddID0gdXNlU3RhdGU8c3RyaW5nIHwgdW5kZWZpbmVkPihcbiAgICB0eXBlb2Ygc2VsZWN0ZWQgPT09ICdzdHJpbmcnID8gc2VsZWN0ZWQgOiB1bmRlZmluZWQsXG4gIClcbiAgY29uc3QgW2NoZWNrYm94U2VsZWN0ZWRSb3dzLCBzZXRDaGVja2JveFNlbGVjdGVkUm93c10gPSB1c2VTdGF0ZTxzdHJpbmdbXT4oXG4gICAgQXJyYXkuaXNBcnJheShzZWxlY3RlZCkgPyBzZWxlY3RlZCA6IFtdLFxuICApXG5cbiAgY29uc3QgY29tcHV0ZWRDb2x1bW5zID0gW1xuICAgIHtcbiAgICAgIGxhYmVsOiAnJyxcbiAgICB9LFxuICAgIGV4cGFuZGFibGUgPyB7IGxhYmVsOiAnJyB9IDogbnVsbCxcbiAgICAuLi5jb2x1bW5zLFxuICBdLmZpbHRlcihlbGVtZW50ID0+ICEhZWxlbWVudClcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChzZWxlY3RlZCkge1xuICAgICAgaWYgKHR5cGVvZiBzZWxlY3RlZCA9PT0gJ3N0cmluZycgJiYgdHlwZSA9PT0gJ3JhZGlvJykge1xuICAgICAgICBzZXRSYWRpb1NlbGVjdGVkUm93KHNlbGVjdGVkKVxuICAgICAgfVxuICAgICAgaWYgKEFycmF5LmlzQXJyYXkoc2VsZWN0ZWQpICYmIHR5cGUgPT09ICdjaGVja2JveCcpIHtcbiAgICAgICAgc2V0Q2hlY2tib3hTZWxlY3RlZFJvd3Moc2VsZWN0ZWQpXG4gICAgICB9XG4gICAgfVxuICB9LCBbdHlwZSwgc2VsZWN0ZWRdKVxuXG4gIHJldHVybiAoXG4gICAgPE9mZmVyTGlzdFByb3ZpZGVyXG4gICAgICBhdXRvQ29sbGFwc2U9e2F1dG9Db2xsYXBzZX1cbiAgICAgIGNoZWNrYm94U2VsZWN0ZWRSb3dzPXtjaGVja2JveFNlbGVjdGVkUm93c31cbiAgICAgIGV4cGFuZGFibGU9e2V4cGFuZGFibGV9XG4gICAgICBsb2FkaW5nPXtsb2FkaW5nfVxuICAgICAgb25DaGFuZ2VTZWxlY3Q9e29uQ2hhbmdlU2VsZWN0fVxuICAgICAgcmFkaW9TZWxlY3RlZFJvdz17cmFkaW9TZWxlY3RlZFJvd31cbiAgICAgIHNlbGVjdGFibGU9e3R5cGV9XG4gICAgICBzZXRDaGVja2JveFNlbGVjdGVkUm93cz17c2V0Q2hlY2tib3hTZWxlY3RlZFJvd3N9XG4gICAgICBzZXRSYWRpb1NlbGVjdGVkUm93PXtzZXRSYWRpb1NlbGVjdGVkUm93fVxuICAgID5cbiAgICAgIDxTdHlsZWRMaXN0XG4gICAgICAgIGF1dG9Db2xsYXBzZT17YXV0b0NvbGxhcHNlfVxuICAgICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgICAgY29sdW1ucz17Y29tcHV0ZWRDb2x1bW5zfVxuICAgICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAgICAgZXhwYW5kYWJsZT17ZmFsc2V9XG4gICAgICAgIHNlbGVjdGFibGU9e2ZhbHNlfVxuICAgICAgPlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L1N0eWxlZExpc3Q+XG4gICAgPC9PZmZlckxpc3RQcm92aWRlcj5cbiAgKVxufVxuXG5PZmZlckxpc3QuUm93ID0gUm93XG5PZmZlckxpc3QuQ2VsbCA9IENlbGxcbiJdfQ== */"));
21
21
  const OfferList = ({
22
22
  expandable,
23
23
  type = "radio",
@@ -26,7 +26,9 @@ const OfferList = ({
26
26
  loading,
27
27
  autoCollapse,
28
28
  selected,
29
- onChangeSelect
29
+ onChangeSelect,
30
+ className,
31
+ "data-testid": dataTestId
30
32
  }) => {
31
33
  const [radioSelectedRow, setRadioSelectedRow] = useState(typeof selected === "string" ? selected : void 0);
32
34
  const [checkboxSelectedRows, setCheckboxSelectedRows] = useState(Array.isArray(selected) ? selected : []);
@@ -45,7 +47,7 @@ const OfferList = ({
45
47
  }
46
48
  }
47
49
  }, [type, selected]);
48
- return /* @__PURE__ */ jsx(OfferListProvider, { autoCollapse, checkboxSelectedRows, expandable, loading, onChangeSelect, radioSelectedRow, selectable: type, setCheckboxSelectedRows, setRadioSelectedRow, children: /* @__PURE__ */ jsx(StyledList, { autoCollapse, columns: computedColumns, expandable: false, selectable: false, children }) });
50
+ return /* @__PURE__ */ jsx(OfferListProvider, { autoCollapse, checkboxSelectedRows, expandable, loading, onChangeSelect, radioSelectedRow, selectable: type, setCheckboxSelectedRows, setRadioSelectedRow, children: /* @__PURE__ */ jsx(StyledList, { autoCollapse, className, columns: computedColumns, "data-testid": dataTestId, expandable: false, selectable: false, children }) });
49
51
  };
50
52
  OfferList.Row = Row;
51
53
  OfferList.Cell = Cell;
@@ -21,7 +21,7 @@ const Container = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env
21
21
  theme
22
22
  }) => theme.colors.neutral.backgroundWeak, ";height:100%;min-width:20rem;@media (min-width: ", ({
23
23
  theme
24
- }) => theme.breakpoints.large, "){min-width:27.5rem;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx"],"names":[],"mappings":"AAW+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Stack, Text, UnitInput } from '@ultraviolet/ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  min-width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    min-width: 27.5rem;\n  }\n`\n\nconst HeaderContainer = styled(Stack)<{ 'data-hidedetails': boolean }>`\n  height: ${({ theme }) => theme.sizing[900]};\n  padding: ${({ theme }) => theme.space[3]};\n  padding-bottom: ${({ theme }) => theme.space[2]};\n\n  &[data-hidedetails=\"false\"] {\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n`\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\n\nexport const OrderSummary = ({\n  header,\n  hideTimeUnit = false,\n  periodOptions = Units,\n  valueUnitInput = 1,\n  unitUnitInput = 'hours',\n  items,\n  locales = orderSummaryLocales,\n  currency = 'EUR',\n  localeFormat = 'en-US',\n  footer,\n  children,\n  discount = 0,\n  totalPriceInfo,\n  fractionDigits,\n  hideDetails = false,\n  onChange,\n  onChangeUnitInput,\n  totalPriceDescription,\n  additionalInfo,\n}: OrderSummaryProps) => {\n  const [timePeriodUnit, setTimePeriodUnit] = useState<TimeUnit>(unitUnitInput)\n  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput)\n\n  const categoriesPrice = useMemo(\n    () =>\n      items.reduce<PriceType>((acc, category) => {\n        const { categoryPrice, discountedPrice } = calculateCategoryPrice(\n          category,\n          hideTimeUnit,\n          timePeriodAmount,\n          timePeriodUnit,\n        )\n\n        return {\n          ...acc,\n          [category.category]: {\n            maxPrice: categoryPrice[1],\n            maxPriceWithDiscount: discountedPrice[1],\n            timeUnit: unitUnitInput,\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\n          },\n        }\n      }, {}),\n    [hideTimeUnit, items, timePeriodAmount, timePeriodUnit, unitUnitInput],\n  )\n\n  const totalPrice = useMemo(() => {\n    const price = Object.values(categoriesPrice).reduce<[number, number]>(\n      (acc, categoryPrice) => [\n        acc[0] + categoryPrice.totalPriceWithDiscount,\n        acc[1] + categoryPrice.maxPriceWithDiscount,\n      ],\n      [0, 0],\n    )\n\n    const computedPrice = {\n      maxPrice: Math.max(price[1], 0),\n      maxPriceWithDiscount: Math.max(\n        price[1] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      timeUnit: unitUnitInput,\n      totalPrice: Math.max(price[0], 0),\n      totalPriceWithDiscount: Math.max(\n        price[0] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      categoriesPrice,\n      currency,\n      fractionDigits,\n      hideTimeUnit,\n      items,\n      localeFormat,\n      locales,\n      timePeriodAmount,\n      timePeriodUnit,\n    }),\n    [\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    ],\n  )\n\n  const computePeriodOptions = useMemo(() => {\n    const computedPeriodOptions: { label: string; value: string }[] = []\n\n    periodOptions.forEach(option =>\n      computedPeriodOptions.push({\n        label: locales[`order.summary.units.${option}.label` as const],\n        value: option,\n      }),\n    )\n\n    return computedPeriodOptions\n  }, [periodOptions, locales])\n\n  useEffect(() => {\n    onChange?.(categoriesPrice, totalPrice)\n  }, [categoriesPrice, totalPrice, onChange])\n\n  return (\n    <OrderSummaryContext.Provider value={valueContext}>\n      <Container justifyContent={hideDetails ? 'flex-start' : 'space-between'}>\n        {header ? (\n          <HeaderContainer\n            data-hidedetails={hideDetails}\n            direction=\"row\"\n            justifyContent=\"space-between\"\n          >\n            <Text\n              as=\"h3\"\n              prominence=\"strong\"\n              sentiment=\"neutral\"\n              variant=\"headingSmallStrong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  dropdownAlign=\"center\"\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  options={computePeriodOptions}\n                  selectInputWidth=\"100%\"\n                  size=\"small\"\n                  templateColumns=\"2fr 3fr\"\n                  unitValue={unitUnitInput}\n                  value={valueUnitInput}\n                  width=\"155px\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          additionalInfo={additionalInfo}\n          discount={discount}\n          footer={footer}\n          hideDetails={hideDetails}\n          totalPrice={totalPrice}\n          totalPriceDescription={totalPriceDescription}\n          totalPriceInfo={totalPriceInfo}\n          unit={unitUnitInput}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
24
+ }) => theme.breakpoints.large, "){min-width:27.5rem;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx"],"names":[],"mappings":"AAW+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Stack, Text, UnitInput } from '@ultraviolet/ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  min-width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    min-width: 27.5rem;\n  }\n`\n\nconst HeaderContainer = styled(Stack)<{ 'data-hidedetails': boolean }>`\n  height: ${({ theme }) => theme.sizing[900]};\n  padding: ${({ theme }) => theme.space[3]};\n  padding-bottom: ${({ theme }) => theme.space[2]};\n\n  &[data-hidedetails=\"false\"] {\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n`\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\n\nexport const OrderSummary = ({\n  header,\n  hideTimeUnit = false,\n  periodOptions = Units,\n  valueUnitInput = 1,\n  unitUnitInput = 'hours',\n  items,\n  locales = orderSummaryLocales,\n  currency = 'EUR',\n  localeFormat = 'en-US',\n  footer,\n  children,\n  discount = 0,\n  totalPriceInfo,\n  fractionDigits,\n  hideDetails = false,\n  onChange,\n  onChangeUnitInput,\n  totalPriceDescription,\n  additionalInfo,\n  className,\n  'data-testid': dataTestId,\n}: OrderSummaryProps) => {\n  const [timePeriodUnit, setTimePeriodUnit] = useState<TimeUnit>(unitUnitInput)\n  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput)\n\n  const categoriesPrice = useMemo(\n    () =>\n      items.reduce<PriceType>((acc, category) => {\n        const { categoryPrice, discountedPrice } = calculateCategoryPrice(\n          category,\n          hideTimeUnit,\n          timePeriodAmount,\n          timePeriodUnit,\n        )\n\n        return {\n          ...acc,\n          [category.category]: {\n            maxPrice: categoryPrice[1],\n            maxPriceWithDiscount: discountedPrice[1],\n            timeUnit: unitUnitInput,\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\n          },\n        }\n      }, {}),\n    [hideTimeUnit, items, timePeriodAmount, timePeriodUnit, unitUnitInput],\n  )\n\n  const totalPrice = useMemo(() => {\n    const price = Object.values(categoriesPrice).reduce<[number, number]>(\n      (acc, categoryPrice) => [\n        acc[0] + categoryPrice.totalPriceWithDiscount,\n        acc[1] + categoryPrice.maxPriceWithDiscount,\n      ],\n      [0, 0],\n    )\n\n    const computedPrice = {\n      maxPrice: Math.max(price[1], 0),\n      maxPriceWithDiscount: Math.max(\n        price[1] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      timeUnit: unitUnitInput,\n      totalPrice: Math.max(price[0], 0),\n      totalPriceWithDiscount: Math.max(\n        price[0] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      categoriesPrice,\n      currency,\n      fractionDigits,\n      hideTimeUnit,\n      items,\n      localeFormat,\n      locales,\n      timePeriodAmount,\n      timePeriodUnit,\n    }),\n    [\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    ],\n  )\n\n  const computePeriodOptions = useMemo(() => {\n    const computedPeriodOptions: { label: string; value: string }[] = []\n\n    periodOptions.forEach(option =>\n      computedPeriodOptions.push({\n        label: locales[`order.summary.units.${option}.label` as const],\n        value: option,\n      }),\n    )\n\n    return computedPeriodOptions\n  }, [periodOptions, locales])\n\n  useEffect(() => {\n    onChange?.(categoriesPrice, totalPrice)\n  }, [categoriesPrice, totalPrice, onChange])\n\n  return (\n    <OrderSummaryContext.Provider value={valueContext}>\n      <Container\n        className={className}\n        data-testId={dataTestId}\n        justifyContent={hideDetails ? 'flex-start' : 'space-between'}\n      >\n        {header ? (\n          <HeaderContainer\n            data-hidedetails={hideDetails}\n            direction=\"row\"\n            justifyContent=\"space-between\"\n          >\n            <Text\n              as=\"h3\"\n              prominence=\"strong\"\n              sentiment=\"neutral\"\n              variant=\"headingSmallStrong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  dropdownAlign=\"center\"\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  options={computePeriodOptions}\n                  selectInputWidth=\"100%\"\n                  size=\"small\"\n                  templateColumns=\"2fr 3fr\"\n                  unitValue={unitUnitInput}\n                  value={valueUnitInput}\n                  width=\"155px\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          additionalInfo={additionalInfo}\n          discount={discount}\n          footer={footer}\n          hideDetails={hideDetails}\n          totalPrice={totalPrice}\n          totalPriceDescription={totalPriceDescription}\n          totalPriceInfo={totalPriceInfo}\n          unit={unitUnitInput}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
25
25
  const HeaderContainer = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
26
26
  target: "e14yhwy31"
27
27
  } : {
@@ -35,7 +35,7 @@ const HeaderContainer = /* @__PURE__ */ _styled__default.default(ui.Stack, proce
35
35
  theme
36
36
  }) => theme.space[2], ';&[data-hidedetails="false"]{border-bottom:1px solid ', ({
37
37
  theme
38
- }) => theme.colors.neutral.border, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx"],"names":[],"mappings":"AAqBsE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Stack, Text, UnitInput } from '@ultraviolet/ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  min-width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    min-width: 27.5rem;\n  }\n`\n\nconst HeaderContainer = styled(Stack)<{ 'data-hidedetails': boolean }>`\n  height: ${({ theme }) => theme.sizing[900]};\n  padding: ${({ theme }) => theme.space[3]};\n  padding-bottom: ${({ theme }) => theme.space[2]};\n\n  &[data-hidedetails=\"false\"] {\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n`\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\n\nexport const OrderSummary = ({\n  header,\n  hideTimeUnit = false,\n  periodOptions = Units,\n  valueUnitInput = 1,\n  unitUnitInput = 'hours',\n  items,\n  locales = orderSummaryLocales,\n  currency = 'EUR',\n  localeFormat = 'en-US',\n  footer,\n  children,\n  discount = 0,\n  totalPriceInfo,\n  fractionDigits,\n  hideDetails = false,\n  onChange,\n  onChangeUnitInput,\n  totalPriceDescription,\n  additionalInfo,\n}: OrderSummaryProps) => {\n  const [timePeriodUnit, setTimePeriodUnit] = useState<TimeUnit>(unitUnitInput)\n  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput)\n\n  const categoriesPrice = useMemo(\n    () =>\n      items.reduce<PriceType>((acc, category) => {\n        const { categoryPrice, discountedPrice } = calculateCategoryPrice(\n          category,\n          hideTimeUnit,\n          timePeriodAmount,\n          timePeriodUnit,\n        )\n\n        return {\n          ...acc,\n          [category.category]: {\n            maxPrice: categoryPrice[1],\n            maxPriceWithDiscount: discountedPrice[1],\n            timeUnit: unitUnitInput,\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\n          },\n        }\n      }, {}),\n    [hideTimeUnit, items, timePeriodAmount, timePeriodUnit, unitUnitInput],\n  )\n\n  const totalPrice = useMemo(() => {\n    const price = Object.values(categoriesPrice).reduce<[number, number]>(\n      (acc, categoryPrice) => [\n        acc[0] + categoryPrice.totalPriceWithDiscount,\n        acc[1] + categoryPrice.maxPriceWithDiscount,\n      ],\n      [0, 0],\n    )\n\n    const computedPrice = {\n      maxPrice: Math.max(price[1], 0),\n      maxPriceWithDiscount: Math.max(\n        price[1] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      timeUnit: unitUnitInput,\n      totalPrice: Math.max(price[0], 0),\n      totalPriceWithDiscount: Math.max(\n        price[0] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      categoriesPrice,\n      currency,\n      fractionDigits,\n      hideTimeUnit,\n      items,\n      localeFormat,\n      locales,\n      timePeriodAmount,\n      timePeriodUnit,\n    }),\n    [\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    ],\n  )\n\n  const computePeriodOptions = useMemo(() => {\n    const computedPeriodOptions: { label: string; value: string }[] = []\n\n    periodOptions.forEach(option =>\n      computedPeriodOptions.push({\n        label: locales[`order.summary.units.${option}.label` as const],\n        value: option,\n      }),\n    )\n\n    return computedPeriodOptions\n  }, [periodOptions, locales])\n\n  useEffect(() => {\n    onChange?.(categoriesPrice, totalPrice)\n  }, [categoriesPrice, totalPrice, onChange])\n\n  return (\n    <OrderSummaryContext.Provider value={valueContext}>\n      <Container justifyContent={hideDetails ? 'flex-start' : 'space-between'}>\n        {header ? (\n          <HeaderContainer\n            data-hidedetails={hideDetails}\n            direction=\"row\"\n            justifyContent=\"space-between\"\n          >\n            <Text\n              as=\"h3\"\n              prominence=\"strong\"\n              sentiment=\"neutral\"\n              variant=\"headingSmallStrong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  dropdownAlign=\"center\"\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  options={computePeriodOptions}\n                  selectInputWidth=\"100%\"\n                  size=\"small\"\n                  templateColumns=\"2fr 3fr\"\n                  unitValue={unitUnitInput}\n                  value={valueUnitInput}\n                  width=\"155px\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          additionalInfo={additionalInfo}\n          discount={discount}\n          footer={footer}\n          hideDetails={hideDetails}\n          totalPrice={totalPrice}\n          totalPriceDescription={totalPriceDescription}\n          totalPriceInfo={totalPriceInfo}\n          unit={unitUnitInput}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
38
+ }) => theme.colors.neutral.border, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx"],"names":[],"mappings":"AAqBsE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Stack, Text, UnitInput } from '@ultraviolet/ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  min-width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    min-width: 27.5rem;\n  }\n`\n\nconst HeaderContainer = styled(Stack)<{ 'data-hidedetails': boolean }>`\n  height: ${({ theme }) => theme.sizing[900]};\n  padding: ${({ theme }) => theme.space[3]};\n  padding-bottom: ${({ theme }) => theme.space[2]};\n\n  &[data-hidedetails=\"false\"] {\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n`\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\n\nexport const OrderSummary = ({\n  header,\n  hideTimeUnit = false,\n  periodOptions = Units,\n  valueUnitInput = 1,\n  unitUnitInput = 'hours',\n  items,\n  locales = orderSummaryLocales,\n  currency = 'EUR',\n  localeFormat = 'en-US',\n  footer,\n  children,\n  discount = 0,\n  totalPriceInfo,\n  fractionDigits,\n  hideDetails = false,\n  onChange,\n  onChangeUnitInput,\n  totalPriceDescription,\n  additionalInfo,\n  className,\n  'data-testid': dataTestId,\n}: OrderSummaryProps) => {\n  const [timePeriodUnit, setTimePeriodUnit] = useState<TimeUnit>(unitUnitInput)\n  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput)\n\n  const categoriesPrice = useMemo(\n    () =>\n      items.reduce<PriceType>((acc, category) => {\n        const { categoryPrice, discountedPrice } = calculateCategoryPrice(\n          category,\n          hideTimeUnit,\n          timePeriodAmount,\n          timePeriodUnit,\n        )\n\n        return {\n          ...acc,\n          [category.category]: {\n            maxPrice: categoryPrice[1],\n            maxPriceWithDiscount: discountedPrice[1],\n            timeUnit: unitUnitInput,\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\n          },\n        }\n      }, {}),\n    [hideTimeUnit, items, timePeriodAmount, timePeriodUnit, unitUnitInput],\n  )\n\n  const totalPrice = useMemo(() => {\n    const price = Object.values(categoriesPrice).reduce<[number, number]>(\n      (acc, categoryPrice) => [\n        acc[0] + categoryPrice.totalPriceWithDiscount,\n        acc[1] + categoryPrice.maxPriceWithDiscount,\n      ],\n      [0, 0],\n    )\n\n    const computedPrice = {\n      maxPrice: Math.max(price[1], 0),\n      maxPriceWithDiscount: Math.max(\n        price[1] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      timeUnit: unitUnitInput,\n      totalPrice: Math.max(price[0], 0),\n      totalPriceWithDiscount: Math.max(\n        price[0] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      categoriesPrice,\n      currency,\n      fractionDigits,\n      hideTimeUnit,\n      items,\n      localeFormat,\n      locales,\n      timePeriodAmount,\n      timePeriodUnit,\n    }),\n    [\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    ],\n  )\n\n  const computePeriodOptions = useMemo(() => {\n    const computedPeriodOptions: { label: string; value: string }[] = []\n\n    periodOptions.forEach(option =>\n      computedPeriodOptions.push({\n        label: locales[`order.summary.units.${option}.label` as const],\n        value: option,\n      }),\n    )\n\n    return computedPeriodOptions\n  }, [periodOptions, locales])\n\n  useEffect(() => {\n    onChange?.(categoriesPrice, totalPrice)\n  }, [categoriesPrice, totalPrice, onChange])\n\n  return (\n    <OrderSummaryContext.Provider value={valueContext}>\n      <Container\n        className={className}\n        data-testId={dataTestId}\n        justifyContent={hideDetails ? 'flex-start' : 'space-between'}\n      >\n        {header ? (\n          <HeaderContainer\n            data-hidedetails={hideDetails}\n            direction=\"row\"\n            justifyContent=\"space-between\"\n          >\n            <Text\n              as=\"h3\"\n              prominence=\"strong\"\n              sentiment=\"neutral\"\n              variant=\"headingSmallStrong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  dropdownAlign=\"center\"\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  options={computePeriodOptions}\n                  selectInputWidth=\"100%\"\n                  size=\"small\"\n                  templateColumns=\"2fr 3fr\"\n                  unitValue={unitUnitInput}\n                  value={valueUnitInput}\n                  width=\"155px\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          additionalInfo={additionalInfo}\n          discount={discount}\n          footer={footer}\n          hideDetails={hideDetails}\n          totalPrice={totalPrice}\n          totalPriceDescription={totalPriceDescription}\n          totalPriceInfo={totalPriceInfo}\n          unit={unitUnitInput}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
39
39
  const StyledStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
40
40
  target: "e14yhwy30"
41
41
  } : {
@@ -43,7 +43,7 @@ const StyledStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.e
43
43
  label: "StyledStack"
44
44
  })("background-color:", ({
45
45
  theme
46
- }) => theme.colors.neutral.background, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx"],"names":[],"mappings":"AA8BiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Stack, Text, UnitInput } from '@ultraviolet/ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  min-width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    min-width: 27.5rem;\n  }\n`\n\nconst HeaderContainer = styled(Stack)<{ 'data-hidedetails': boolean }>`\n  height: ${({ theme }) => theme.sizing[900]};\n  padding: ${({ theme }) => theme.space[3]};\n  padding-bottom: ${({ theme }) => theme.space[2]};\n\n  &[data-hidedetails=\"false\"] {\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n`\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\n\nexport const OrderSummary = ({\n  header,\n  hideTimeUnit = false,\n  periodOptions = Units,\n  valueUnitInput = 1,\n  unitUnitInput = 'hours',\n  items,\n  locales = orderSummaryLocales,\n  currency = 'EUR',\n  localeFormat = 'en-US',\n  footer,\n  children,\n  discount = 0,\n  totalPriceInfo,\n  fractionDigits,\n  hideDetails = false,\n  onChange,\n  onChangeUnitInput,\n  totalPriceDescription,\n  additionalInfo,\n}: OrderSummaryProps) => {\n  const [timePeriodUnit, setTimePeriodUnit] = useState<TimeUnit>(unitUnitInput)\n  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput)\n\n  const categoriesPrice = useMemo(\n    () =>\n      items.reduce<PriceType>((acc, category) => {\n        const { categoryPrice, discountedPrice } = calculateCategoryPrice(\n          category,\n          hideTimeUnit,\n          timePeriodAmount,\n          timePeriodUnit,\n        )\n\n        return {\n          ...acc,\n          [category.category]: {\n            maxPrice: categoryPrice[1],\n            maxPriceWithDiscount: discountedPrice[1],\n            timeUnit: unitUnitInput,\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\n          },\n        }\n      }, {}),\n    [hideTimeUnit, items, timePeriodAmount, timePeriodUnit, unitUnitInput],\n  )\n\n  const totalPrice = useMemo(() => {\n    const price = Object.values(categoriesPrice).reduce<[number, number]>(\n      (acc, categoryPrice) => [\n        acc[0] + categoryPrice.totalPriceWithDiscount,\n        acc[1] + categoryPrice.maxPriceWithDiscount,\n      ],\n      [0, 0],\n    )\n\n    const computedPrice = {\n      maxPrice: Math.max(price[1], 0),\n      maxPriceWithDiscount: Math.max(\n        price[1] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      timeUnit: unitUnitInput,\n      totalPrice: Math.max(price[0], 0),\n      totalPriceWithDiscount: Math.max(\n        price[0] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      categoriesPrice,\n      currency,\n      fractionDigits,\n      hideTimeUnit,\n      items,\n      localeFormat,\n      locales,\n      timePeriodAmount,\n      timePeriodUnit,\n    }),\n    [\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    ],\n  )\n\n  const computePeriodOptions = useMemo(() => {\n    const computedPeriodOptions: { label: string; value: string }[] = []\n\n    periodOptions.forEach(option =>\n      computedPeriodOptions.push({\n        label: locales[`order.summary.units.${option}.label` as const],\n        value: option,\n      }),\n    )\n\n    return computedPeriodOptions\n  }, [periodOptions, locales])\n\n  useEffect(() => {\n    onChange?.(categoriesPrice, totalPrice)\n  }, [categoriesPrice, totalPrice, onChange])\n\n  return (\n    <OrderSummaryContext.Provider value={valueContext}>\n      <Container justifyContent={hideDetails ? 'flex-start' : 'space-between'}>\n        {header ? (\n          <HeaderContainer\n            data-hidedetails={hideDetails}\n            direction=\"row\"\n            justifyContent=\"space-between\"\n          >\n            <Text\n              as=\"h3\"\n              prominence=\"strong\"\n              sentiment=\"neutral\"\n              variant=\"headingSmallStrong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  dropdownAlign=\"center\"\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  options={computePeriodOptions}\n                  selectInputWidth=\"100%\"\n                  size=\"small\"\n                  templateColumns=\"2fr 3fr\"\n                  unitValue={unitUnitInput}\n                  value={valueUnitInput}\n                  width=\"155px\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          additionalInfo={additionalInfo}\n          discount={discount}\n          footer={footer}\n          hideDetails={hideDetails}\n          totalPrice={totalPrice}\n          totalPriceDescription={totalPriceDescription}\n          totalPriceInfo={totalPriceInfo}\n          unit={unitUnitInput}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
46
+ }) => theme.colors.neutral.background, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx"],"names":[],"mappings":"AA8BiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Stack, Text, UnitInput } from '@ultraviolet/ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  min-width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    min-width: 27.5rem;\n  }\n`\n\nconst HeaderContainer = styled(Stack)<{ 'data-hidedetails': boolean }>`\n  height: ${({ theme }) => theme.sizing[900]};\n  padding: ${({ theme }) => theme.space[3]};\n  padding-bottom: ${({ theme }) => theme.space[2]};\n\n  &[data-hidedetails=\"false\"] {\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n`\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\n\nexport const OrderSummary = ({\n  header,\n  hideTimeUnit = false,\n  periodOptions = Units,\n  valueUnitInput = 1,\n  unitUnitInput = 'hours',\n  items,\n  locales = orderSummaryLocales,\n  currency = 'EUR',\n  localeFormat = 'en-US',\n  footer,\n  children,\n  discount = 0,\n  totalPriceInfo,\n  fractionDigits,\n  hideDetails = false,\n  onChange,\n  onChangeUnitInput,\n  totalPriceDescription,\n  additionalInfo,\n  className,\n  'data-testid': dataTestId,\n}: OrderSummaryProps) => {\n  const [timePeriodUnit, setTimePeriodUnit] = useState<TimeUnit>(unitUnitInput)\n  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput)\n\n  const categoriesPrice = useMemo(\n    () =>\n      items.reduce<PriceType>((acc, category) => {\n        const { categoryPrice, discountedPrice } = calculateCategoryPrice(\n          category,\n          hideTimeUnit,\n          timePeriodAmount,\n          timePeriodUnit,\n        )\n\n        return {\n          ...acc,\n          [category.category]: {\n            maxPrice: categoryPrice[1],\n            maxPriceWithDiscount: discountedPrice[1],\n            timeUnit: unitUnitInput,\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\n          },\n        }\n      }, {}),\n    [hideTimeUnit, items, timePeriodAmount, timePeriodUnit, unitUnitInput],\n  )\n\n  const totalPrice = useMemo(() => {\n    const price = Object.values(categoriesPrice).reduce<[number, number]>(\n      (acc, categoryPrice) => [\n        acc[0] + categoryPrice.totalPriceWithDiscount,\n        acc[1] + categoryPrice.maxPriceWithDiscount,\n      ],\n      [0, 0],\n    )\n\n    const computedPrice = {\n      maxPrice: Math.max(price[1], 0),\n      maxPriceWithDiscount: Math.max(\n        price[1] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      timeUnit: unitUnitInput,\n      totalPrice: Math.max(price[0], 0),\n      totalPriceWithDiscount: Math.max(\n        price[0] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      categoriesPrice,\n      currency,\n      fractionDigits,\n      hideTimeUnit,\n      items,\n      localeFormat,\n      locales,\n      timePeriodAmount,\n      timePeriodUnit,\n    }),\n    [\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    ],\n  )\n\n  const computePeriodOptions = useMemo(() => {\n    const computedPeriodOptions: { label: string; value: string }[] = []\n\n    periodOptions.forEach(option =>\n      computedPeriodOptions.push({\n        label: locales[`order.summary.units.${option}.label` as const],\n        value: option,\n      }),\n    )\n\n    return computedPeriodOptions\n  }, [periodOptions, locales])\n\n  useEffect(() => {\n    onChange?.(categoriesPrice, totalPrice)\n  }, [categoriesPrice, totalPrice, onChange])\n\n  return (\n    <OrderSummaryContext.Provider value={valueContext}>\n      <Container\n        className={className}\n        data-testId={dataTestId}\n        justifyContent={hideDetails ? 'flex-start' : 'space-between'}\n      >\n        {header ? (\n          <HeaderContainer\n            data-hidedetails={hideDetails}\n            direction=\"row\"\n            justifyContent=\"space-between\"\n          >\n            <Text\n              as=\"h3\"\n              prominence=\"strong\"\n              sentiment=\"neutral\"\n              variant=\"headingSmallStrong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  dropdownAlign=\"center\"\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  options={computePeriodOptions}\n                  selectInputWidth=\"100%\"\n                  size=\"small\"\n                  templateColumns=\"2fr 3fr\"\n                  unitValue={unitUnitInput}\n                  value={valueUnitInput}\n                  width=\"155px\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          additionalInfo={additionalInfo}\n          discount={discount}\n          footer={footer}\n          hideDetails={hideDetails}\n          totalPrice={totalPrice}\n          totalPriceDescription={totalPriceDescription}\n          totalPriceInfo={totalPriceInfo}\n          unit={unitUnitInput}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
47
47
  const OrderSummary = ({
48
48
  header,
49
49
  hideTimeUnit = false,
@@ -63,7 +63,9 @@ const OrderSummary = ({
63
63
  onChange,
64
64
  onChangeUnitInput,
65
65
  totalPriceDescription,
66
- additionalInfo
66
+ additionalInfo,
67
+ className,
68
+ "data-testid": dataTestId
67
69
  }) => {
68
70
  const [timePeriodUnit, setTimePeriodUnit] = react.useState(unitUnitInput);
69
71
  const [timePeriodAmount, setTimePeriodAmount] = react.useState(valueUnitInput);
@@ -116,7 +118,7 @@ const OrderSummary = ({
116
118
  react.useEffect(() => {
117
119
  onChange?.(categoriesPrice, totalPrice);
118
120
  }, [categoriesPrice, totalPrice, onChange]);
119
- return /* @__PURE__ */ jsxRuntime.jsx(Provider.OrderSummaryContext.Provider, { value: valueContext, children: /* @__PURE__ */ jsxRuntime.jsxs(Container, { justifyContent: hideDetails ? "flex-start" : "space-between", children: [
121
+ return /* @__PURE__ */ jsxRuntime.jsx(Provider.OrderSummaryContext.Provider, { value: valueContext, children: /* @__PURE__ */ jsxRuntime.jsxs(Container, { className, "data-testId": dataTestId, justifyContent: hideDetails ? "flex-start" : "space-between", children: [
120
122
  header ? /* @__PURE__ */ jsxRuntime.jsxs(HeaderContainer, { "data-hidedetails": hideDetails, direction: "row", justifyContent: "space-between", children: [
121
123
  /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: "h3", prominence: "strong", sentiment: "neutral", variant: "headingSmallStrong", children: header }),
122
124
  !hideTimeUnit && !hideDetails ? /* @__PURE__ */ jsxRuntime.jsx(StyledStack, { children: /* @__PURE__ */ jsxRuntime.jsx(ui.UnitInput, { dropdownAlign: "center", onChange: (value) => {
@@ -1,2 +1,2 @@
1
1
  import type { OrderSummaryProps } from './types';
2
- export declare const OrderSummary: ({ header, hideTimeUnit, periodOptions, valueUnitInput, unitUnitInput, items, locales, currency, localeFormat, footer, children, discount, totalPriceInfo, fractionDigits, hideDetails, onChange, onChangeUnitInput, totalPriceDescription, additionalInfo, }: OrderSummaryProps) => import("@emotion/react/jsx-runtime").JSX.Element;
2
+ export declare const OrderSummary: ({ header, hideTimeUnit, periodOptions, valueUnitInput, unitUnitInput, items, locales, currency, localeFormat, footer, children, discount, totalPriceInfo, fractionDigits, hideDetails, onChange, onChangeUnitInput, totalPriceDescription, additionalInfo, className, "data-testid": dataTestId, }: OrderSummaryProps) => import("@emotion/react/jsx-runtime").JSX.Element;
@@ -17,7 +17,7 @@ const Container = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "produ
17
17
  theme
18
18
  }) => theme.colors.neutral.backgroundWeak, ";height:100%;min-width:20rem;@media (min-width: ", ({
19
19
  theme
20
- }) => theme.breakpoints.large, "){min-width:27.5rem;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx"],"names":[],"mappings":"AAW+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Stack, Text, UnitInput } from '@ultraviolet/ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  min-width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    min-width: 27.5rem;\n  }\n`\n\nconst HeaderContainer = styled(Stack)<{ 'data-hidedetails': boolean }>`\n  height: ${({ theme }) => theme.sizing[900]};\n  padding: ${({ theme }) => theme.space[3]};\n  padding-bottom: ${({ theme }) => theme.space[2]};\n\n  &[data-hidedetails=\"false\"] {\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n`\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\n\nexport const OrderSummary = ({\n  header,\n  hideTimeUnit = false,\n  periodOptions = Units,\n  valueUnitInput = 1,\n  unitUnitInput = 'hours',\n  items,\n  locales = orderSummaryLocales,\n  currency = 'EUR',\n  localeFormat = 'en-US',\n  footer,\n  children,\n  discount = 0,\n  totalPriceInfo,\n  fractionDigits,\n  hideDetails = false,\n  onChange,\n  onChangeUnitInput,\n  totalPriceDescription,\n  additionalInfo,\n}: OrderSummaryProps) => {\n  const [timePeriodUnit, setTimePeriodUnit] = useState<TimeUnit>(unitUnitInput)\n  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput)\n\n  const categoriesPrice = useMemo(\n    () =>\n      items.reduce<PriceType>((acc, category) => {\n        const { categoryPrice, discountedPrice } = calculateCategoryPrice(\n          category,\n          hideTimeUnit,\n          timePeriodAmount,\n          timePeriodUnit,\n        )\n\n        return {\n          ...acc,\n          [category.category]: {\n            maxPrice: categoryPrice[1],\n            maxPriceWithDiscount: discountedPrice[1],\n            timeUnit: unitUnitInput,\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\n          },\n        }\n      }, {}),\n    [hideTimeUnit, items, timePeriodAmount, timePeriodUnit, unitUnitInput],\n  )\n\n  const totalPrice = useMemo(() => {\n    const price = Object.values(categoriesPrice).reduce<[number, number]>(\n      (acc, categoryPrice) => [\n        acc[0] + categoryPrice.totalPriceWithDiscount,\n        acc[1] + categoryPrice.maxPriceWithDiscount,\n      ],\n      [0, 0],\n    )\n\n    const computedPrice = {\n      maxPrice: Math.max(price[1], 0),\n      maxPriceWithDiscount: Math.max(\n        price[1] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      timeUnit: unitUnitInput,\n      totalPrice: Math.max(price[0], 0),\n      totalPriceWithDiscount: Math.max(\n        price[0] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      categoriesPrice,\n      currency,\n      fractionDigits,\n      hideTimeUnit,\n      items,\n      localeFormat,\n      locales,\n      timePeriodAmount,\n      timePeriodUnit,\n    }),\n    [\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    ],\n  )\n\n  const computePeriodOptions = useMemo(() => {\n    const computedPeriodOptions: { label: string; value: string }[] = []\n\n    periodOptions.forEach(option =>\n      computedPeriodOptions.push({\n        label: locales[`order.summary.units.${option}.label` as const],\n        value: option,\n      }),\n    )\n\n    return computedPeriodOptions\n  }, [periodOptions, locales])\n\n  useEffect(() => {\n    onChange?.(categoriesPrice, totalPrice)\n  }, [categoriesPrice, totalPrice, onChange])\n\n  return (\n    <OrderSummaryContext.Provider value={valueContext}>\n      <Container justifyContent={hideDetails ? 'flex-start' : 'space-between'}>\n        {header ? (\n          <HeaderContainer\n            data-hidedetails={hideDetails}\n            direction=\"row\"\n            justifyContent=\"space-between\"\n          >\n            <Text\n              as=\"h3\"\n              prominence=\"strong\"\n              sentiment=\"neutral\"\n              variant=\"headingSmallStrong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  dropdownAlign=\"center\"\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  options={computePeriodOptions}\n                  selectInputWidth=\"100%\"\n                  size=\"small\"\n                  templateColumns=\"2fr 3fr\"\n                  unitValue={unitUnitInput}\n                  value={valueUnitInput}\n                  width=\"155px\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          additionalInfo={additionalInfo}\n          discount={discount}\n          footer={footer}\n          hideDetails={hideDetails}\n          totalPrice={totalPrice}\n          totalPriceDescription={totalPriceDescription}\n          totalPriceInfo={totalPriceInfo}\n          unit={unitUnitInput}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
20
+ }) => theme.breakpoints.large, "){min-width:27.5rem;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx"],"names":[],"mappings":"AAW+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Stack, Text, UnitInput } from '@ultraviolet/ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  min-width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    min-width: 27.5rem;\n  }\n`\n\nconst HeaderContainer = styled(Stack)<{ 'data-hidedetails': boolean }>`\n  height: ${({ theme }) => theme.sizing[900]};\n  padding: ${({ theme }) => theme.space[3]};\n  padding-bottom: ${({ theme }) => theme.space[2]};\n\n  &[data-hidedetails=\"false\"] {\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n`\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\n\nexport const OrderSummary = ({\n  header,\n  hideTimeUnit = false,\n  periodOptions = Units,\n  valueUnitInput = 1,\n  unitUnitInput = 'hours',\n  items,\n  locales = orderSummaryLocales,\n  currency = 'EUR',\n  localeFormat = 'en-US',\n  footer,\n  children,\n  discount = 0,\n  totalPriceInfo,\n  fractionDigits,\n  hideDetails = false,\n  onChange,\n  onChangeUnitInput,\n  totalPriceDescription,\n  additionalInfo,\n  className,\n  'data-testid': dataTestId,\n}: OrderSummaryProps) => {\n  const [timePeriodUnit, setTimePeriodUnit] = useState<TimeUnit>(unitUnitInput)\n  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput)\n\n  const categoriesPrice = useMemo(\n    () =>\n      items.reduce<PriceType>((acc, category) => {\n        const { categoryPrice, discountedPrice } = calculateCategoryPrice(\n          category,\n          hideTimeUnit,\n          timePeriodAmount,\n          timePeriodUnit,\n        )\n\n        return {\n          ...acc,\n          [category.category]: {\n            maxPrice: categoryPrice[1],\n            maxPriceWithDiscount: discountedPrice[1],\n            timeUnit: unitUnitInput,\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\n          },\n        }\n      }, {}),\n    [hideTimeUnit, items, timePeriodAmount, timePeriodUnit, unitUnitInput],\n  )\n\n  const totalPrice = useMemo(() => {\n    const price = Object.values(categoriesPrice).reduce<[number, number]>(\n      (acc, categoryPrice) => [\n        acc[0] + categoryPrice.totalPriceWithDiscount,\n        acc[1] + categoryPrice.maxPriceWithDiscount,\n      ],\n      [0, 0],\n    )\n\n    const computedPrice = {\n      maxPrice: Math.max(price[1], 0),\n      maxPriceWithDiscount: Math.max(\n        price[1] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      timeUnit: unitUnitInput,\n      totalPrice: Math.max(price[0], 0),\n      totalPriceWithDiscount: Math.max(\n        price[0] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      categoriesPrice,\n      currency,\n      fractionDigits,\n      hideTimeUnit,\n      items,\n      localeFormat,\n      locales,\n      timePeriodAmount,\n      timePeriodUnit,\n    }),\n    [\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    ],\n  )\n\n  const computePeriodOptions = useMemo(() => {\n    const computedPeriodOptions: { label: string; value: string }[] = []\n\n    periodOptions.forEach(option =>\n      computedPeriodOptions.push({\n        label: locales[`order.summary.units.${option}.label` as const],\n        value: option,\n      }),\n    )\n\n    return computedPeriodOptions\n  }, [periodOptions, locales])\n\n  useEffect(() => {\n    onChange?.(categoriesPrice, totalPrice)\n  }, [categoriesPrice, totalPrice, onChange])\n\n  return (\n    <OrderSummaryContext.Provider value={valueContext}>\n      <Container\n        className={className}\n        data-testId={dataTestId}\n        justifyContent={hideDetails ? 'flex-start' : 'space-between'}\n      >\n        {header ? (\n          <HeaderContainer\n            data-hidedetails={hideDetails}\n            direction=\"row\"\n            justifyContent=\"space-between\"\n          >\n            <Text\n              as=\"h3\"\n              prominence=\"strong\"\n              sentiment=\"neutral\"\n              variant=\"headingSmallStrong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  dropdownAlign=\"center\"\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  options={computePeriodOptions}\n                  selectInputWidth=\"100%\"\n                  size=\"small\"\n                  templateColumns=\"2fr 3fr\"\n                  unitValue={unitUnitInput}\n                  value={valueUnitInput}\n                  width=\"155px\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          additionalInfo={additionalInfo}\n          discount={discount}\n          footer={footer}\n          hideDetails={hideDetails}\n          totalPrice={totalPrice}\n          totalPriceDescription={totalPriceDescription}\n          totalPriceInfo={totalPriceInfo}\n          unit={unitUnitInput}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
21
21
  const HeaderContainer = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
22
22
  target: "e14yhwy31"
23
23
  } : {
@@ -31,7 +31,7 @@ const HeaderContainer = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV ===
31
31
  theme
32
32
  }) => theme.space[2], ';&[data-hidedetails="false"]{border-bottom:1px solid ', ({
33
33
  theme
34
- }) => theme.colors.neutral.border, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx"],"names":[],"mappings":"AAqBsE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Stack, Text, UnitInput } from '@ultraviolet/ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  min-width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    min-width: 27.5rem;\n  }\n`\n\nconst HeaderContainer = styled(Stack)<{ 'data-hidedetails': boolean }>`\n  height: ${({ theme }) => theme.sizing[900]};\n  padding: ${({ theme }) => theme.space[3]};\n  padding-bottom: ${({ theme }) => theme.space[2]};\n\n  &[data-hidedetails=\"false\"] {\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n`\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\n\nexport const OrderSummary = ({\n  header,\n  hideTimeUnit = false,\n  periodOptions = Units,\n  valueUnitInput = 1,\n  unitUnitInput = 'hours',\n  items,\n  locales = orderSummaryLocales,\n  currency = 'EUR',\n  localeFormat = 'en-US',\n  footer,\n  children,\n  discount = 0,\n  totalPriceInfo,\n  fractionDigits,\n  hideDetails = false,\n  onChange,\n  onChangeUnitInput,\n  totalPriceDescription,\n  additionalInfo,\n}: OrderSummaryProps) => {\n  const [timePeriodUnit, setTimePeriodUnit] = useState<TimeUnit>(unitUnitInput)\n  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput)\n\n  const categoriesPrice = useMemo(\n    () =>\n      items.reduce<PriceType>((acc, category) => {\n        const { categoryPrice, discountedPrice } = calculateCategoryPrice(\n          category,\n          hideTimeUnit,\n          timePeriodAmount,\n          timePeriodUnit,\n        )\n\n        return {\n          ...acc,\n          [category.category]: {\n            maxPrice: categoryPrice[1],\n            maxPriceWithDiscount: discountedPrice[1],\n            timeUnit: unitUnitInput,\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\n          },\n        }\n      }, {}),\n    [hideTimeUnit, items, timePeriodAmount, timePeriodUnit, unitUnitInput],\n  )\n\n  const totalPrice = useMemo(() => {\n    const price = Object.values(categoriesPrice).reduce<[number, number]>(\n      (acc, categoryPrice) => [\n        acc[0] + categoryPrice.totalPriceWithDiscount,\n        acc[1] + categoryPrice.maxPriceWithDiscount,\n      ],\n      [0, 0],\n    )\n\n    const computedPrice = {\n      maxPrice: Math.max(price[1], 0),\n      maxPriceWithDiscount: Math.max(\n        price[1] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      timeUnit: unitUnitInput,\n      totalPrice: Math.max(price[0], 0),\n      totalPriceWithDiscount: Math.max(\n        price[0] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      categoriesPrice,\n      currency,\n      fractionDigits,\n      hideTimeUnit,\n      items,\n      localeFormat,\n      locales,\n      timePeriodAmount,\n      timePeriodUnit,\n    }),\n    [\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    ],\n  )\n\n  const computePeriodOptions = useMemo(() => {\n    const computedPeriodOptions: { label: string; value: string }[] = []\n\n    periodOptions.forEach(option =>\n      computedPeriodOptions.push({\n        label: locales[`order.summary.units.${option}.label` as const],\n        value: option,\n      }),\n    )\n\n    return computedPeriodOptions\n  }, [periodOptions, locales])\n\n  useEffect(() => {\n    onChange?.(categoriesPrice, totalPrice)\n  }, [categoriesPrice, totalPrice, onChange])\n\n  return (\n    <OrderSummaryContext.Provider value={valueContext}>\n      <Container justifyContent={hideDetails ? 'flex-start' : 'space-between'}>\n        {header ? (\n          <HeaderContainer\n            data-hidedetails={hideDetails}\n            direction=\"row\"\n            justifyContent=\"space-between\"\n          >\n            <Text\n              as=\"h3\"\n              prominence=\"strong\"\n              sentiment=\"neutral\"\n              variant=\"headingSmallStrong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  dropdownAlign=\"center\"\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  options={computePeriodOptions}\n                  selectInputWidth=\"100%\"\n                  size=\"small\"\n                  templateColumns=\"2fr 3fr\"\n                  unitValue={unitUnitInput}\n                  value={valueUnitInput}\n                  width=\"155px\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          additionalInfo={additionalInfo}\n          discount={discount}\n          footer={footer}\n          hideDetails={hideDetails}\n          totalPrice={totalPrice}\n          totalPriceDescription={totalPriceDescription}\n          totalPriceInfo={totalPriceInfo}\n          unit={unitUnitInput}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
34
+ }) => theme.colors.neutral.border, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx"],"names":[],"mappings":"AAqBsE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Stack, Text, UnitInput } from '@ultraviolet/ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  min-width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    min-width: 27.5rem;\n  }\n`\n\nconst HeaderContainer = styled(Stack)<{ 'data-hidedetails': boolean }>`\n  height: ${({ theme }) => theme.sizing[900]};\n  padding: ${({ theme }) => theme.space[3]};\n  padding-bottom: ${({ theme }) => theme.space[2]};\n\n  &[data-hidedetails=\"false\"] {\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n`\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\n\nexport const OrderSummary = ({\n  header,\n  hideTimeUnit = false,\n  periodOptions = Units,\n  valueUnitInput = 1,\n  unitUnitInput = 'hours',\n  items,\n  locales = orderSummaryLocales,\n  currency = 'EUR',\n  localeFormat = 'en-US',\n  footer,\n  children,\n  discount = 0,\n  totalPriceInfo,\n  fractionDigits,\n  hideDetails = false,\n  onChange,\n  onChangeUnitInput,\n  totalPriceDescription,\n  additionalInfo,\n  className,\n  'data-testid': dataTestId,\n}: OrderSummaryProps) => {\n  const [timePeriodUnit, setTimePeriodUnit] = useState<TimeUnit>(unitUnitInput)\n  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput)\n\n  const categoriesPrice = useMemo(\n    () =>\n      items.reduce<PriceType>((acc, category) => {\n        const { categoryPrice, discountedPrice } = calculateCategoryPrice(\n          category,\n          hideTimeUnit,\n          timePeriodAmount,\n          timePeriodUnit,\n        )\n\n        return {\n          ...acc,\n          [category.category]: {\n            maxPrice: categoryPrice[1],\n            maxPriceWithDiscount: discountedPrice[1],\n            timeUnit: unitUnitInput,\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\n          },\n        }\n      }, {}),\n    [hideTimeUnit, items, timePeriodAmount, timePeriodUnit, unitUnitInput],\n  )\n\n  const totalPrice = useMemo(() => {\n    const price = Object.values(categoriesPrice).reduce<[number, number]>(\n      (acc, categoryPrice) => [\n        acc[0] + categoryPrice.totalPriceWithDiscount,\n        acc[1] + categoryPrice.maxPriceWithDiscount,\n      ],\n      [0, 0],\n    )\n\n    const computedPrice = {\n      maxPrice: Math.max(price[1], 0),\n      maxPriceWithDiscount: Math.max(\n        price[1] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      timeUnit: unitUnitInput,\n      totalPrice: Math.max(price[0], 0),\n      totalPriceWithDiscount: Math.max(\n        price[0] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      categoriesPrice,\n      currency,\n      fractionDigits,\n      hideTimeUnit,\n      items,\n      localeFormat,\n      locales,\n      timePeriodAmount,\n      timePeriodUnit,\n    }),\n    [\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    ],\n  )\n\n  const computePeriodOptions = useMemo(() => {\n    const computedPeriodOptions: { label: string; value: string }[] = []\n\n    periodOptions.forEach(option =>\n      computedPeriodOptions.push({\n        label: locales[`order.summary.units.${option}.label` as const],\n        value: option,\n      }),\n    )\n\n    return computedPeriodOptions\n  }, [periodOptions, locales])\n\n  useEffect(() => {\n    onChange?.(categoriesPrice, totalPrice)\n  }, [categoriesPrice, totalPrice, onChange])\n\n  return (\n    <OrderSummaryContext.Provider value={valueContext}>\n      <Container\n        className={className}\n        data-testId={dataTestId}\n        justifyContent={hideDetails ? 'flex-start' : 'space-between'}\n      >\n        {header ? (\n          <HeaderContainer\n            data-hidedetails={hideDetails}\n            direction=\"row\"\n            justifyContent=\"space-between\"\n          >\n            <Text\n              as=\"h3\"\n              prominence=\"strong\"\n              sentiment=\"neutral\"\n              variant=\"headingSmallStrong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  dropdownAlign=\"center\"\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  options={computePeriodOptions}\n                  selectInputWidth=\"100%\"\n                  size=\"small\"\n                  templateColumns=\"2fr 3fr\"\n                  unitValue={unitUnitInput}\n                  value={valueUnitInput}\n                  width=\"155px\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          additionalInfo={additionalInfo}\n          discount={discount}\n          footer={footer}\n          hideDetails={hideDetails}\n          totalPrice={totalPrice}\n          totalPriceDescription={totalPriceDescription}\n          totalPriceInfo={totalPriceInfo}\n          unit={unitUnitInput}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
35
35
  const StyledStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
36
36
  target: "e14yhwy30"
37
37
  } : {
@@ -39,7 +39,7 @@ const StyledStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "pro
39
39
  label: "StyledStack"
40
40
  })("background-color:", ({
41
41
  theme
42
- }) => theme.colors.neutral.background, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx"],"names":[],"mappings":"AA8BiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Stack, Text, UnitInput } from '@ultraviolet/ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  min-width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    min-width: 27.5rem;\n  }\n`\n\nconst HeaderContainer = styled(Stack)<{ 'data-hidedetails': boolean }>`\n  height: ${({ theme }) => theme.sizing[900]};\n  padding: ${({ theme }) => theme.space[3]};\n  padding-bottom: ${({ theme }) => theme.space[2]};\n\n  &[data-hidedetails=\"false\"] {\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n`\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\n\nexport const OrderSummary = ({\n  header,\n  hideTimeUnit = false,\n  periodOptions = Units,\n  valueUnitInput = 1,\n  unitUnitInput = 'hours',\n  items,\n  locales = orderSummaryLocales,\n  currency = 'EUR',\n  localeFormat = 'en-US',\n  footer,\n  children,\n  discount = 0,\n  totalPriceInfo,\n  fractionDigits,\n  hideDetails = false,\n  onChange,\n  onChangeUnitInput,\n  totalPriceDescription,\n  additionalInfo,\n}: OrderSummaryProps) => {\n  const [timePeriodUnit, setTimePeriodUnit] = useState<TimeUnit>(unitUnitInput)\n  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput)\n\n  const categoriesPrice = useMemo(\n    () =>\n      items.reduce<PriceType>((acc, category) => {\n        const { categoryPrice, discountedPrice } = calculateCategoryPrice(\n          category,\n          hideTimeUnit,\n          timePeriodAmount,\n          timePeriodUnit,\n        )\n\n        return {\n          ...acc,\n          [category.category]: {\n            maxPrice: categoryPrice[1],\n            maxPriceWithDiscount: discountedPrice[1],\n            timeUnit: unitUnitInput,\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\n          },\n        }\n      }, {}),\n    [hideTimeUnit, items, timePeriodAmount, timePeriodUnit, unitUnitInput],\n  )\n\n  const totalPrice = useMemo(() => {\n    const price = Object.values(categoriesPrice).reduce<[number, number]>(\n      (acc, categoryPrice) => [\n        acc[0] + categoryPrice.totalPriceWithDiscount,\n        acc[1] + categoryPrice.maxPriceWithDiscount,\n      ],\n      [0, 0],\n    )\n\n    const computedPrice = {\n      maxPrice: Math.max(price[1], 0),\n      maxPriceWithDiscount: Math.max(\n        price[1] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      timeUnit: unitUnitInput,\n      totalPrice: Math.max(price[0], 0),\n      totalPriceWithDiscount: Math.max(\n        price[0] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      categoriesPrice,\n      currency,\n      fractionDigits,\n      hideTimeUnit,\n      items,\n      localeFormat,\n      locales,\n      timePeriodAmount,\n      timePeriodUnit,\n    }),\n    [\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    ],\n  )\n\n  const computePeriodOptions = useMemo(() => {\n    const computedPeriodOptions: { label: string; value: string }[] = []\n\n    periodOptions.forEach(option =>\n      computedPeriodOptions.push({\n        label: locales[`order.summary.units.${option}.label` as const],\n        value: option,\n      }),\n    )\n\n    return computedPeriodOptions\n  }, [periodOptions, locales])\n\n  useEffect(() => {\n    onChange?.(categoriesPrice, totalPrice)\n  }, [categoriesPrice, totalPrice, onChange])\n\n  return (\n    <OrderSummaryContext.Provider value={valueContext}>\n      <Container justifyContent={hideDetails ? 'flex-start' : 'space-between'}>\n        {header ? (\n          <HeaderContainer\n            data-hidedetails={hideDetails}\n            direction=\"row\"\n            justifyContent=\"space-between\"\n          >\n            <Text\n              as=\"h3\"\n              prominence=\"strong\"\n              sentiment=\"neutral\"\n              variant=\"headingSmallStrong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  dropdownAlign=\"center\"\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  options={computePeriodOptions}\n                  selectInputWidth=\"100%\"\n                  size=\"small\"\n                  templateColumns=\"2fr 3fr\"\n                  unitValue={unitUnitInput}\n                  value={valueUnitInput}\n                  width=\"155px\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          additionalInfo={additionalInfo}\n          discount={discount}\n          footer={footer}\n          hideDetails={hideDetails}\n          totalPrice={totalPrice}\n          totalPriceDescription={totalPriceDescription}\n          totalPriceInfo={totalPriceInfo}\n          unit={unitUnitInput}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
42
+ }) => theme.colors.neutral.background, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx"],"names":[],"mappings":"AA8BiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Stack, Text, UnitInput } from '@ultraviolet/ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  min-width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    min-width: 27.5rem;\n  }\n`\n\nconst HeaderContainer = styled(Stack)<{ 'data-hidedetails': boolean }>`\n  height: ${({ theme }) => theme.sizing[900]};\n  padding: ${({ theme }) => theme.space[3]};\n  padding-bottom: ${({ theme }) => theme.space[2]};\n\n  &[data-hidedetails=\"false\"] {\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n`\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\n\nexport const OrderSummary = ({\n  header,\n  hideTimeUnit = false,\n  periodOptions = Units,\n  valueUnitInput = 1,\n  unitUnitInput = 'hours',\n  items,\n  locales = orderSummaryLocales,\n  currency = 'EUR',\n  localeFormat = 'en-US',\n  footer,\n  children,\n  discount = 0,\n  totalPriceInfo,\n  fractionDigits,\n  hideDetails = false,\n  onChange,\n  onChangeUnitInput,\n  totalPriceDescription,\n  additionalInfo,\n  className,\n  'data-testid': dataTestId,\n}: OrderSummaryProps) => {\n  const [timePeriodUnit, setTimePeriodUnit] = useState<TimeUnit>(unitUnitInput)\n  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput)\n\n  const categoriesPrice = useMemo(\n    () =>\n      items.reduce<PriceType>((acc, category) => {\n        const { categoryPrice, discountedPrice } = calculateCategoryPrice(\n          category,\n          hideTimeUnit,\n          timePeriodAmount,\n          timePeriodUnit,\n        )\n\n        return {\n          ...acc,\n          [category.category]: {\n            maxPrice: categoryPrice[1],\n            maxPriceWithDiscount: discountedPrice[1],\n            timeUnit: unitUnitInput,\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\n          },\n        }\n      }, {}),\n    [hideTimeUnit, items, timePeriodAmount, timePeriodUnit, unitUnitInput],\n  )\n\n  const totalPrice = useMemo(() => {\n    const price = Object.values(categoriesPrice).reduce<[number, number]>(\n      (acc, categoryPrice) => [\n        acc[0] + categoryPrice.totalPriceWithDiscount,\n        acc[1] + categoryPrice.maxPriceWithDiscount,\n      ],\n      [0, 0],\n    )\n\n    const computedPrice = {\n      maxPrice: Math.max(price[1], 0),\n      maxPriceWithDiscount: Math.max(\n        price[1] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      timeUnit: unitUnitInput,\n      totalPrice: Math.max(price[0], 0),\n      totalPriceWithDiscount: Math.max(\n        price[0] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      categoriesPrice,\n      currency,\n      fractionDigits,\n      hideTimeUnit,\n      items,\n      localeFormat,\n      locales,\n      timePeriodAmount,\n      timePeriodUnit,\n    }),\n    [\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    ],\n  )\n\n  const computePeriodOptions = useMemo(() => {\n    const computedPeriodOptions: { label: string; value: string }[] = []\n\n    periodOptions.forEach(option =>\n      computedPeriodOptions.push({\n        label: locales[`order.summary.units.${option}.label` as const],\n        value: option,\n      }),\n    )\n\n    return computedPeriodOptions\n  }, [periodOptions, locales])\n\n  useEffect(() => {\n    onChange?.(categoriesPrice, totalPrice)\n  }, [categoriesPrice, totalPrice, onChange])\n\n  return (\n    <OrderSummaryContext.Provider value={valueContext}>\n      <Container\n        className={className}\n        data-testId={dataTestId}\n        justifyContent={hideDetails ? 'flex-start' : 'space-between'}\n      >\n        {header ? (\n          <HeaderContainer\n            data-hidedetails={hideDetails}\n            direction=\"row\"\n            justifyContent=\"space-between\"\n          >\n            <Text\n              as=\"h3\"\n              prominence=\"strong\"\n              sentiment=\"neutral\"\n              variant=\"headingSmallStrong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  dropdownAlign=\"center\"\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  options={computePeriodOptions}\n                  selectInputWidth=\"100%\"\n                  size=\"small\"\n                  templateColumns=\"2fr 3fr\"\n                  unitValue={unitUnitInput}\n                  value={valueUnitInput}\n                  width=\"155px\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          additionalInfo={additionalInfo}\n          discount={discount}\n          footer={footer}\n          hideDetails={hideDetails}\n          totalPrice={totalPrice}\n          totalPriceDescription={totalPriceDescription}\n          totalPriceInfo={totalPriceInfo}\n          unit={unitUnitInput}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
43
43
  const OrderSummary = ({
44
44
  header,
45
45
  hideTimeUnit = false,
@@ -59,7 +59,9 @@ const OrderSummary = ({
59
59
  onChange,
60
60
  onChangeUnitInput,
61
61
  totalPriceDescription,
62
- additionalInfo
62
+ additionalInfo,
63
+ className,
64
+ "data-testid": dataTestId
63
65
  }) => {
64
66
  const [timePeriodUnit, setTimePeriodUnit] = useState(unitUnitInput);
65
67
  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput);
@@ -112,7 +114,7 @@ const OrderSummary = ({
112
114
  useEffect(() => {
113
115
  onChange?.(categoriesPrice, totalPrice);
114
116
  }, [categoriesPrice, totalPrice, onChange]);
115
- return /* @__PURE__ */ jsx(OrderSummaryContext.Provider, { value: valueContext, children: /* @__PURE__ */ jsxs(Container, { justifyContent: hideDetails ? "flex-start" : "space-between", children: [
117
+ return /* @__PURE__ */ jsx(OrderSummaryContext.Provider, { value: valueContext, children: /* @__PURE__ */ jsxs(Container, { className, "data-testId": dataTestId, justifyContent: hideDetails ? "flex-start" : "space-between", children: [
116
118
  header ? /* @__PURE__ */ jsxs(HeaderContainer, { "data-hidedetails": hideDetails, direction: "row", justifyContent: "space-between", children: [
117
119
  /* @__PURE__ */ jsx(Text, { as: "h3", prominence: "strong", sentiment: "neutral", variant: "headingSmallStrong", children: header }),
118
120
  !hideTimeUnit && !hideDetails ? /* @__PURE__ */ jsx(StyledStack, { children: /* @__PURE__ */ jsx(UnitInput, { dropdownAlign: "center", onChange: (value) => {
@@ -108,5 +108,7 @@ export type OrderSummaryProps = {
108
108
  */
109
109
  onChange?: (price: PriceType, totalPrice: PriceTypeSingle) => void;
110
110
  hideDetails?: boolean;
111
+ className?: string;
112
+ ['data-testid']?: string;
111
113
  } & PeriodProps;
112
114
  export {};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ultraviolet/plus",
3
- "version": "3.0.0-beta.1",
3
+ "version": "3.0.0-beta.2",
4
4
  "description": "Ultraviolet Plus",
5
5
  "homepage": "https://github.com/scaleway/ultraviolet#readme",
6
6
  "repository": {
@@ -55,7 +55,7 @@
55
55
  "@emotion/styled": "11.14.1",
56
56
  "react": "18.x || 19.x",
57
57
  "react-dom": "18.x || 19.x",
58
- "@ultraviolet/ui": "3.0.0-beta.12"
58
+ "@ultraviolet/ui": "3.0.0-beta.13"
59
59
  },
60
60
  "devDependencies": {
61
61
  "@babel/core": "7.28.4",
@@ -66,7 +66,7 @@
66
66
  "react": "19.1.1",
67
67
  "react-dom": "19.1.1",
68
68
  "@ultraviolet/illustrations": "6.0.0-beta.1",
69
- "@ultraviolet/ui": "3.0.0-beta.12",
69
+ "@ultraviolet/ui": "3.0.0-beta.13",
70
70
  "@utils/test": "0.0.1"
71
71
  },
72
72
  "dependencies": {