@ultraviolet/plus 3.0.0-beta.12 → 3.0.0-beta.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (97) hide show
  1. package/dist/components/ContentCardGroup/styles.css.cjs +1 -0
  2. package/dist/components/ContentCardGroup/styles.css.js +1 -0
  3. package/dist/components/Conversation/styles.css.cjs +0 -1
  4. package/dist/components/Conversation/styles.css.js +0 -1
  5. package/dist/components/EstimateCost/Components/Item.cjs +32 -115
  6. package/dist/components/EstimateCost/Components/Item.js +34 -115
  7. package/dist/components/EstimateCost/Components/LineThrough.cjs +6 -14
  8. package/dist/components/EstimateCost/Components/LineThrough.d.ts +3 -5
  9. package/dist/components/EstimateCost/Components/LineThrough.js +6 -12
  10. package/dist/components/EstimateCost/Components/NumberInput.cjs +2 -2
  11. package/dist/components/EstimateCost/Components/NumberInput.js +2 -2
  12. package/dist/components/EstimateCost/Components/Region.cjs +2 -12
  13. package/dist/components/EstimateCost/Components/Region.js +2 -10
  14. package/dist/components/EstimateCost/Components/Regular.cjs +5 -20
  15. package/dist/components/EstimateCost/Components/Regular.js +5 -18
  16. package/dist/components/EstimateCost/Components/Strong.cjs +7 -22
  17. package/dist/components/EstimateCost/Components/Strong.d.ts +1 -9
  18. package/dist/components/EstimateCost/Components/Strong.js +8 -21
  19. package/dist/components/EstimateCost/Components/Unit.cjs +3 -22
  20. package/dist/components/EstimateCost/Components/Unit.js +3 -20
  21. package/dist/components/EstimateCost/Components/Zone.cjs +2 -12
  22. package/dist/components/EstimateCost/Components/Zone.js +2 -10
  23. package/dist/components/EstimateCost/Components/components.css.cjs +123 -0
  24. package/dist/components/EstimateCost/Components/components.css.d.ts +77 -0
  25. package/dist/components/EstimateCost/Components/components.css.js +123 -0
  26. package/dist/components/EstimateCost/EstimateCost.cjs +15 -20
  27. package/dist/components/EstimateCost/EstimateCost.d.ts +9 -15
  28. package/dist/components/EstimateCost/EstimateCost.js +15 -18
  29. package/dist/components/EstimateCost/EstimateCostContent.cjs +21 -72
  30. package/dist/components/EstimateCost/EstimateCostContent.js +22 -71
  31. package/dist/components/EstimateCost/OverlayComponent.cjs +13 -51
  32. package/dist/components/EstimateCost/OverlayComponent.js +14 -50
  33. package/dist/components/EstimateCost/constants.cjs +0 -4
  34. package/dist/components/EstimateCost/constants.js +0 -4
  35. package/dist/components/EstimateCost/styles.css.cjs +50 -0
  36. package/dist/components/EstimateCost/styles.css.d.ts +76 -0
  37. package/dist/components/EstimateCost/styles.css.js +50 -0
  38. package/dist/components/Navigation/Footer.cjs +4 -19
  39. package/dist/components/Navigation/Footer.js +4 -17
  40. package/dist/components/Navigation/Header.cjs +2 -20
  41. package/dist/components/Navigation/Header.js +2 -18
  42. package/dist/components/Navigation/NavigationContent.cjs +13 -64
  43. package/dist/components/Navigation/NavigationContent.js +14 -63
  44. package/dist/components/Navigation/animations.css.d.ts +6 -0
  45. package/dist/components/Navigation/components/Group.cjs +6 -33
  46. package/dist/components/Navigation/components/Group.js +6 -31
  47. package/dist/components/Navigation/components/Item.cjs +83 -237
  48. package/dist/components/Navigation/components/Item.js +84 -236
  49. package/dist/components/Navigation/components/PinnedItems.cjs +7 -45
  50. package/dist/components/Navigation/components/PinnedItems.js +7 -43
  51. package/dist/components/Navigation/components/Separator.cjs +2 -12
  52. package/dist/components/Navigation/components/Separator.js +2 -10
  53. package/dist/components/Navigation/components/items.css.cjs +47 -0
  54. package/dist/components/Navigation/components/items.css.d.ts +70 -0
  55. package/dist/components/Navigation/components/items.css.js +47 -0
  56. package/dist/components/Navigation/components/styles.css.cjs +17 -0
  57. package/dist/components/Navigation/components/styles.css.d.ts +23 -0
  58. package/dist/components/Navigation/components/styles.css.js +17 -0
  59. package/dist/components/Navigation/constants.cjs +0 -27
  60. package/dist/components/Navigation/constants.d.ts +0 -12
  61. package/dist/components/Navigation/constants.js +1 -28
  62. package/dist/components/Navigation/styles.css.cjs +23 -0
  63. package/dist/components/Navigation/styles.css.d.ts +33 -0
  64. package/dist/components/Navigation/styles.css.js +23 -0
  65. package/dist/components/Navigation/variables.css.cjs +4 -0
  66. package/dist/components/Navigation/variables.css.d.ts +1 -0
  67. package/dist/components/Navigation/variables.css.js +4 -0
  68. package/dist/components/OrderSummary/NonScrollableContent.cjs +2 -14
  69. package/dist/components/OrderSummary/NonScrollableContent.js +2 -12
  70. package/dist/components/OrderSummary/ScrollableContent.cjs +5 -41
  71. package/dist/components/OrderSummary/ScrollableContent.js +5 -39
  72. package/dist/components/OrderSummary/index.cjs +4 -38
  73. package/dist/components/OrderSummary/index.js +5 -37
  74. package/dist/components/OrderSummary/styles.css.cjs +19 -0
  75. package/dist/components/OrderSummary/styles.css.d.ts +8 -0
  76. package/dist/components/OrderSummary/styles.css.js +19 -0
  77. package/dist/components/Plans/FeatureHint.cjs +2 -20
  78. package/dist/components/Plans/FeatureHint.js +2 -18
  79. package/dist/components/Plans/index.cjs +40 -91
  80. package/dist/components/Plans/index.js +44 -93
  81. package/dist/components/Plans/styles.css.cjs +16 -0
  82. package/dist/components/Plans/styles.css.d.ts +56 -0
  83. package/dist/components/Plans/styles.css.js +16 -0
  84. package/dist/components/SteppedListCard/Step.cjs +2 -33
  85. package/dist/components/SteppedListCard/Step.js +2 -31
  86. package/dist/components/SteppedListCard/SteppedListCard.cjs +3 -31
  87. package/dist/components/SteppedListCard/SteppedListCard.js +4 -30
  88. package/dist/components/SteppedListCard/SteppedListContent.cjs +4 -40
  89. package/dist/components/SteppedListCard/SteppedListContent.js +5 -39
  90. package/dist/components/SteppedListCard/styles.css.cjs +17 -0
  91. package/dist/components/SteppedListCard/styles.css.d.ts +7 -0
  92. package/dist/components/SteppedListCard/styles.css.js +17 -0
  93. package/dist/plus.css +1 -1
  94. package/package.json +6 -6
  95. package/dist/components/EstimateCost/componentStyle.cjs +0 -221
  96. package/dist/components/EstimateCost/componentStyle.d.ts +0 -106
  97. package/dist/components/EstimateCost/componentStyle.js +0 -219
@@ -2,71 +2,15 @@
2
2
  "use strict";
3
3
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
4
4
  const jsxRuntime = require("@emotion/react/jsx-runtime");
5
- const _styled = require("@emotion/styled/base");
6
5
  const ui = require("@ultraviolet/ui");
6
+ const dynamic = require("@vanilla-extract/dynamic");
7
7
  const react = require("react");
8
8
  const constants = require("./constants.cjs");
9
9
  const Footer = require("./Footer.cjs");
10
10
  const Header = require("./Header.cjs");
11
11
  const NavigationProvider = require("./NavigationProvider.cjs");
12
- const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
13
- const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
14
- function _EMOTION_STRINGIFIED_CSS_ERROR__() {
15
- return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
16
- }
17
- const StyledNav = /* @__PURE__ */ _styled__default.default("nav", process.env.NODE_ENV === "production" ? {
18
- target: "esezfu54"
19
- } : {
20
- target: "esezfu54",
21
- label: "StyledNav"
22
- })("display:flex;flex-direction:row;position:relative;border-right:1px solid ", ({
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  '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
- const Container = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
26
- shouldForwardProp: (prop) => !["width"].includes(prop),
27
- target: "esezfu53"
28
- } : {
29
- shouldForwardProp: (prop) => !["width"].includes(prop),
30
- target: "esezfu53",
31
- label: "Container"
32
- })("background:", ({
33
- theme
34
- }) => theme.colors.neutral.background, ";display:flex;flex-direction:column;width:", ({
35
- width
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
- 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  '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
- const ContentContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
40
- target: "esezfu52"
41
- } : {
42
- target: "esezfu52",
43
- label: "ContentContainer"
44
- })(process.env.NODE_ENV === "production" ? {
45
- name: "12is9id",
46
- styles: "overflow:hidden;display:flex;flex-direction:column;flex-grow:1"
47
- } : {
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  '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
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
51
- });
52
- const Content = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
53
- target: "esezfu51"
54
- } : {
55
- target: "esezfu51",
56
- label: "Content"
57
- })('overflow-y:auto;overflow-x:hidden;flex-grow:1;&[data-is-expanded="false"]{align-items:center;padding:', ({
58
- theme
59
- }) => theme.space["2"], ';}&[data-is-expanded="true"],&[data-animation="expand"]{padding:', ({
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  '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
- const Slider = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
63
- target: "esezfu50"
64
- } : {
65
- target: "esezfu50",
66
- label: "Slider"
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
- 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  '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"]} */"));
12
+ const styles_css = require("./styles.css.cjs");
13
+ const variables_css = require("./variables.css.cjs");
70
14
  const NavigationContent = ({
71
15
  children,
72
16
  logo,
@@ -149,15 +93,20 @@ const NavigationContent = ({
149
93
  sliderRefCurrent?.removeEventListener("mousedown", mousedown);
150
94
  };
151
95
  }, [expanded, navigationRef, onToggleExpand, onWidthResize, setWidth, toggleExpand]);
152
- return /* @__PURE__ */ jsxRuntime.jsxs(StyledNav, { className, "data-testid": dataTestId, id, children: [
153
- /* @__PURE__ */ jsxRuntime.jsxs(Container, { "data-animation": shouldAnimate ? animation : void 0, "data-expanded": expanded, ref: navigationRef, width, children: [
96
+ return /* @__PURE__ */ jsxRuntime.jsxs("nav", { className: `${className ? `${className} ` : ""}${styles_css.navigation}`, "data-testid": dataTestId, id, children: [
97
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: styles_css.navigationContainer({
98
+ animation: shouldAnimate ? animation : void 0,
99
+ expanded
100
+ }), ref: navigationRef, style: dynamic.assignInlineVars({
101
+ [variables_css.widthNavigationContainer]: `${width}px`
102
+ }), children: [
154
103
  logo ? /* @__PURE__ */ jsxRuntime.jsx(Header.Header, { logo }) : null,
155
- /* @__PURE__ */ jsxRuntime.jsxs(ContentContainer, { children: [
156
- /* @__PURE__ */ jsxRuntime.jsx(Content, { "data-animation": shouldAnimate ? animation : void 0, "data-is-expanded": expanded, gap: 0.25, ref: contentRef, children }),
104
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: `${styles_css.navigationContentContainer}${expanded ? "" : ` ${styles_css.navigationContentContainerCollapsed}`}`, children: [
105
+ /* @__PURE__ */ jsxRuntime.jsx(ui.Stack, { className: styles_css.navigationContent, gap: 0.25, ref: contentRef, children }),
157
106
  allowNavigationResize ? /* @__PURE__ */ jsxRuntime.jsx(Footer.Footer, { contentRef, onToggleExpand }) : null
158
107
  ] })
159
108
  ] }),
160
- allowNavigationResize ? /* @__PURE__ */ jsxRuntime.jsx(Slider, { "data-testid": "slider", ref: sliderRef }) : null
109
+ allowNavigationResize ? /* @__PURE__ */ jsxRuntime.jsx("div", { className: styles_css.navigationSlider, "data-testid": "slider", ref: sliderRef }) : null
161
110
  ] });
162
111
  };
163
112
  exports.NavigationContent = NavigationContent;
@@ -1,68 +1,14 @@
1
1
  "use client";
2
2
  import { jsxs, jsx } from "@emotion/react/jsx-runtime";
3
- import _styled from "@emotion/styled/base";
4
3
  import { Stack } from "@ultraviolet/ui";
4
+ import { assignInlineVars } from "@vanilla-extract/dynamic";
5
5
  import { useRef, useEffect } from "react";
6
- import { NAVIGATION_MAX_WIDTH, NAVIGATION_MIN_WIDTH, NAVIGATION_COLLASPED_WIDTH, ANIMATION_DURATION } from "./constants.js";
6
+ import { NAVIGATION_MIN_WIDTH, NAVIGATION_COLLASPED_WIDTH } from "./constants.js";
7
7
  import { Footer } from "./Footer.js";
8
8
  import { Header } from "./Header.js";
9
9
  import { useNavigation } from "./NavigationProvider.js";
10
- function _EMOTION_STRINGIFIED_CSS_ERROR__() {
11
- return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
12
- }
13
- const StyledNav = /* @__PURE__ */ _styled("nav", process.env.NODE_ENV === "production" ? {
14
- target: "esezfu54"
15
- } : {
16
- target: "esezfu54",
17
- label: "StyledNav"
18
- })("display:flex;flex-direction:row;position:relative;border-right:1px solid ", ({
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  '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
- const Container = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
22
- shouldForwardProp: (prop) => !["width"].includes(prop),
23
- target: "esezfu53"
24
- } : {
25
- shouldForwardProp: (prop) => !["width"].includes(prop),
26
- target: "esezfu53",
27
- label: "Container"
28
- })("background:", ({
29
- theme
30
- }) => theme.colors.neutral.background, ";display:flex;flex-direction:column;width:", ({
31
- width
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
- 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  '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
- const ContentContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
36
- target: "esezfu52"
37
- } : {
38
- target: "esezfu52",
39
- label: "ContentContainer"
40
- })(process.env.NODE_ENV === "production" ? {
41
- name: "12is9id",
42
- styles: "overflow:hidden;display:flex;flex-direction:column;flex-grow:1"
43
- } : {
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  '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
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
47
- });
48
- const Content = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
49
- target: "esezfu51"
50
- } : {
51
- target: "esezfu51",
52
- label: "Content"
53
- })('overflow-y:auto;overflow-x:hidden;flex-grow:1;&[data-is-expanded="false"]{align-items:center;padding:', ({
54
- theme
55
- }) => theme.space["2"], ';}&[data-is-expanded="true"],&[data-animation="expand"]{padding:', ({
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  '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
- const Slider = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
59
- target: "esezfu50"
60
- } : {
61
- target: "esezfu50",
62
- label: "Slider"
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
- 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  '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"]} */"));
10
+ import { navigation, navigationContainer, navigationContentContainer, navigationContentContainerCollapsed, navigationContent, navigationSlider } from "./styles.css.js";
11
+ import { widthNavigationContainer } from "./variables.css.js";
66
12
  const NavigationContent = ({
67
13
  children,
68
14
  logo,
@@ -145,15 +91,20 @@ const NavigationContent = ({
145
91
  sliderRefCurrent?.removeEventListener("mousedown", mousedown);
146
92
  };
147
93
  }, [expanded, navigationRef, onToggleExpand, onWidthResize, setWidth, toggleExpand]);
148
- return /* @__PURE__ */ jsxs(StyledNav, { className, "data-testid": dataTestId, id, children: [
149
- /* @__PURE__ */ jsxs(Container, { "data-animation": shouldAnimate ? animation : void 0, "data-expanded": expanded, ref: navigationRef, width, children: [
94
+ return /* @__PURE__ */ jsxs("nav", { className: `${className ? `${className} ` : ""}${navigation}`, "data-testid": dataTestId, id, children: [
95
+ /* @__PURE__ */ jsxs("div", { className: navigationContainer({
96
+ animation: shouldAnimate ? animation : void 0,
97
+ expanded
98
+ }), ref: navigationRef, style: assignInlineVars({
99
+ [widthNavigationContainer]: `${width}px`
100
+ }), children: [
150
101
  logo ? /* @__PURE__ */ jsx(Header, { logo }) : null,
151
- /* @__PURE__ */ jsxs(ContentContainer, { children: [
152
- /* @__PURE__ */ jsx(Content, { "data-animation": shouldAnimate ? animation : void 0, "data-is-expanded": expanded, gap: 0.25, ref: contentRef, children }),
102
+ /* @__PURE__ */ jsxs("div", { className: `${navigationContentContainer}${expanded ? "" : ` ${navigationContentContainerCollapsed}`}`, children: [
103
+ /* @__PURE__ */ jsx(Stack, { className: navigationContent, gap: 0.25, ref: contentRef, children }),
153
104
  allowNavigationResize ? /* @__PURE__ */ jsx(Footer, { contentRef, onToggleExpand }) : null
154
105
  ] })
155
106
  ] }),
156
- allowNavigationResize ? /* @__PURE__ */ jsx(Slider, { "data-testid": "slider", ref: sliderRef }) : null
107
+ allowNavigationResize ? /* @__PURE__ */ jsx("div", { className: navigationSlider, "data-testid": "slider", ref: sliderRef }) : null
157
108
  ] });
158
109
  };
159
110
  export {
@@ -0,0 +1,6 @@
1
+ /**
2
+ * ANIMATIONS
3
+ * collapse and expand animation duration of the whole nav in ms
4
+ */
5
+ export declare const shrinkHeight: string;
6
+ export declare const groupAnimation: string;
@@ -2,39 +2,10 @@
2
2
  "use strict";
3
3
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
4
4
  const jsxRuntime = require("@emotion/react/jsx-runtime");
5
- const _styled = require("@emotion/styled/base");
6
5
  const ui = require("@ultraviolet/ui");
7
6
  const react = require("react");
8
- const constants = require("../constants.cjs");
9
7
  const NavigationProvider = require("../NavigationProvider.cjs");
10
- const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
11
- const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
12
- const StyledText = /* @__PURE__ */ _styled__default.default(ui.Text, process.env.NODE_ENV === "production" ? {
13
- target: "eh4zgrv2"
14
- } : {
15
- target: "eh4zgrv2",
16
- label: "StyledText"
17
- })("padding-bottom:", ({
18
- theme
19
- }) => theme.space["1"], ";padding-left:", ({
20
- theme
21
- }) => theme.space["1"], ";transition:opacity ", constants.ANIMATION_DURATION, "ms ease-in-out,height ", constants.ANIMATION_DURATION, "ms ease-in-out;height:", ({
22
- theme
23
- }) => `calc(${theme.typography.bodySmallStrong.lineHeight} + ${theme.space["1"]})`, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvTmF2aWdhdGlvbi9jb21wb25lbnRzL0dyb3VwLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFjK0IiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvcGx1cy9zcmMvY29tcG9uZW50cy9OYXZpZ2F0aW9uL2NvbXBvbmVudHMvR3JvdXAudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgU3RhY2ssIFRleHQgfSBmcm9tICdAdWx0cmF2aW9sZXQvdWknXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgQ2hpbGRyZW4gfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IEFOSU1BVElPTl9EVVJBVElPTiwgZ3JvdXBBbmltYXRpb24gfSBmcm9tICcuLi9jb25zdGFudHMnXG5pbXBvcnQgeyB1c2VOYXZpZ2F0aW9uIH0gZnJvbSAnLi4vTmF2aWdhdGlvblByb3ZpZGVyJ1xuXG50eXBlIEdyb3VwUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgbGFiZWw6IHN0cmluZ1xufVxuXG5jb25zdCBTdHlsZWRUZXh0ID0gc3R5bGVkKFRleHQpYFxuICBwYWRkaW5nLWJvdHRvbTogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfTtcbiAgcGFkZGluZy1sZWZ0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuXG4gIHRyYW5zaXRpb246XG4gICAgb3BhY2l0eSAke0FOSU1BVElPTl9EVVJBVElPTn1tcyBlYXNlLWluLW91dCxcbiAgICBoZWlnaHQgJHtBTklNQVRJT05fRFVSQVRJT059bXMgZWFzZS1pbi1vdXQ7XG4gIGhlaWdodDogJHsoeyB0aGVtZSB9KSA9PlxuICAgIGBjYWxjKCR7dGhlbWUudHlwb2dyYXBoeS5ib2R5U21hbGxTdHJvbmcubGluZUhlaWdodH0gKyAke3RoZW1lLnNwYWNlWycxJ119KWB9OyAvLyBUaGlzIGlzIG9ubHkgZm9yIGFuaW1hdGlvblxuYFxuXG5jb25zdCBTdHlsZWRTdGFjayA9IHN0eWxlZChTdGFjaylgXG4gIHBhZGRpbmctdG9wOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuYFxuXG5jb25zdCBDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICAmW2RhdGEtYW5pbWF0aW9uPSdleHBhbmQnXVtkYXRhLWFuaW1hdGlvbi10eXBlPVwiY29tcGxleFwiXSB7XG4gICAgJHtTdHlsZWRUZXh0fSB7XG4gICAgICBhbmltYXRpb246ICR7Z3JvdXBBbmltYXRpb259ICR7QU5JTUFUSU9OX0RVUkFUSU9OfW1zIGVhc2UtaW4tb3V0O1xuICAgIH1cbiAgfVxuXG4gICZbZGF0YS1hbmltYXRpb249J2NvbGxhcHNlJ11bZGF0YS1hbmltYXRpb24tdHlwZT1cImNvbXBsZXhcIl0ge1xuICAgICR7U3R5bGVkVGV4dH0ge1xuICAgICAgYW5pbWF0aW9uOiAke2dyb3VwQW5pbWF0aW9ufSAke0FOSU1BVElPTl9EVVJBVElPTn1tcyBlYXNlLWluLW91dCByZXZlcnNlO1xuICAgIH1cbiAgfVxuYFxuXG5leHBvcnQgY29uc3QgR3JvdXAgPSAoeyBjaGlsZHJlbiwgbGFiZWwgfTogR3JvdXBQcm9wcykgPT4ge1xuICBjb25zdCBjb250ZXh0ID0gdXNlTmF2aWdhdGlvbigpXG5cbiAgaWYgKCFjb250ZXh0KSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgJ05hdmlnYXRpb24uR3JvdXAgY2FuIG9ubHkgYmUgdXNlZCBpbnNpZGUgYSBOYXZpZ2F0aW9uUHJvdmlkZXIuJyxcbiAgICApXG4gIH1cblxuICBjb25zdCB7IGV4cGFuZGVkLCBhbmltYXRpb24sIGFuaW1hdGlvblR5cGUgfSA9IGNvbnRleHRcblxuICBjb25zdCBpc0RpcGxheSA9ICFhbmltYXRpb24gJiYgZXhwYW5kZWRcblxuICBpZiAoQ2hpbGRyZW4uY291bnQoY2hpbGRyZW4pID4gMCkge1xuICAgIHJldHVybiAoXG4gICAgICA8Q29udGFpbmVyXG4gICAgICAgIGRhdGEtYW5pbWF0aW9uPXthbmltYXRpb259XG4gICAgICAgIGRhdGEtYW5pbWF0aW9uLXR5cGU9e2FuaW1hdGlvblR5cGV9XG4gICAgICAgIHN0eWxlPXt7IHdpZHRoOiBhbmltYXRpb24gPyAnMTAwJScgOiB1bmRlZmluZWQgfX1cbiAgICAgID5cbiAgICAgICAgPFN0eWxlZFN0YWNrIGRpcmVjdGlvbj1cImNvbHVtblwiPlxuICAgICAgICAgIHtpc0RpcGxheSA/IChcbiAgICAgICAgICAgIDxTdHlsZWRUZXh0XG4gICAgICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgICAgIHByb21pbmVuY2U9XCJ3ZWFrXCJcbiAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgIHZhcmlhbnQ9XCJib2R5U21hbGxTdHJvbmdcIlxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7bGFiZWx9XG4gICAgICAgICAgICA8L1N0eWxlZFRleHQ+XG4gICAgICAgICAgKSA6IG51bGx9XG4gICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICA8L1N0eWxlZFN0YWNrPlxuICAgICAgPC9Db250YWluZXI+XG4gICAgKVxuICB9XG5cbiAgcmV0dXJuIG51bGxcbn1cbiJdfQ== */"));
24
- const StyledStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
25
- target: "eh4zgrv1"
26
- } : {
27
- target: "eh4zgrv1",
28
- label: "StyledStack"
29
- })("padding-top:", ({
30
- theme
31
- }) => theme.space["1"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvTmF2aWdhdGlvbi9jb21wb25lbnRzL0dyb3VwLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5QmlDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvTmF2aWdhdGlvbi9jb21wb25lbnRzL0dyb3VwLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IFN0YWNrLCBUZXh0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IENoaWxkcmVuIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBBTklNQVRJT05fRFVSQVRJT04sIGdyb3VwQW5pbWF0aW9uIH0gZnJvbSAnLi4vY29uc3RhbnRzJ1xuaW1wb3J0IHsgdXNlTmF2aWdhdGlvbiB9IGZyb20gJy4uL05hdmlnYXRpb25Qcm92aWRlcidcblxudHlwZSBHcm91cFByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGxhYmVsOiBzdHJpbmdcbn1cblxuY29uc3QgU3R5bGVkVGV4dCA9IHN0eWxlZChUZXh0KWBcbiAgcGFkZGluZy1ib3R0b206ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG4gIHBhZGRpbmctbGVmdDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfTtcblxuICB0cmFuc2l0aW9uOlxuICAgIG9wYWNpdHkgJHtBTklNQVRJT05fRFVSQVRJT059bXMgZWFzZS1pbi1vdXQsXG4gICAgaGVpZ2h0ICR7QU5JTUFUSU9OX0RVUkFUSU9OfW1zIGVhc2UtaW4tb3V0O1xuICBoZWlnaHQ6ICR7KHsgdGhlbWUgfSkgPT5cbiAgICBgY2FsYygke3RoZW1lLnR5cG9ncmFwaHkuYm9keVNtYWxsU3Ryb25nLmxpbmVIZWlnaHR9ICsgJHt0aGVtZS5zcGFjZVsnMSddfSlgfTsgLy8gVGhpcyBpcyBvbmx5IGZvciBhbmltYXRpb25cbmBcblxuY29uc3QgU3R5bGVkU3RhY2sgPSBzdHlsZWQoU3RhY2spYFxuICBwYWRkaW5nLXRvcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfTtcbmBcblxuY29uc3QgQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgJltkYXRhLWFuaW1hdGlvbj0nZXhwYW5kJ11bZGF0YS1hbmltYXRpb24tdHlwZT1cImNvbXBsZXhcIl0ge1xuICAgICR7U3R5bGVkVGV4dH0ge1xuICAgICAgYW5pbWF0aW9uOiAke2dyb3VwQW5pbWF0aW9ufSAke0FOSU1BVElPTl9EVVJBVElPTn1tcyBlYXNlLWluLW91dDtcbiAgICB9XG4gIH1cblxuICAmW2RhdGEtYW5pbWF0aW9uPSdjb2xsYXBzZSddW2RhdGEtYW5pbWF0aW9uLXR5cGU9XCJjb21wbGV4XCJdIHtcbiAgICAke1N0eWxlZFRleHR9IHtcbiAgICAgIGFuaW1hdGlvbjogJHtncm91cEFuaW1hdGlvbn0gJHtBTklNQVRJT05fRFVSQVRJT059bXMgZWFzZS1pbi1vdXQgcmV2ZXJzZTtcbiAgICB9XG4gIH1cbmBcblxuZXhwb3J0IGNvbnN0IEdyb3VwID0gKHsgY2hpbGRyZW4sIGxhYmVsIH06IEdyb3VwUHJvcHMpID0+IHtcbiAgY29uc3QgY29udGV4dCA9IHVzZU5hdmlnYXRpb24oKVxuXG4gIGlmICghY29udGV4dCkge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICdOYXZpZ2F0aW9uLkdyb3VwIGNhbiBvbmx5IGJlIHVzZWQgaW5zaWRlIGEgTmF2aWdhdGlvblByb3ZpZGVyLicsXG4gICAgKVxuICB9XG5cbiAgY29uc3QgeyBleHBhbmRlZCwgYW5pbWF0aW9uLCBhbmltYXRpb25UeXBlIH0gPSBjb250ZXh0XG5cbiAgY29uc3QgaXNEaXBsYXkgPSAhYW5pbWF0aW9uICYmIGV4cGFuZGVkXG5cbiAgaWYgKENoaWxkcmVuLmNvdW50KGNoaWxkcmVuKSA+IDApIHtcbiAgICByZXR1cm4gKFxuICAgICAgPENvbnRhaW5lclxuICAgICAgICBkYXRhLWFuaW1hdGlvbj17YW5pbWF0aW9ufVxuICAgICAgICBkYXRhLWFuaW1hdGlvbi10eXBlPXthbmltYXRpb25UeXBlfVxuICAgICAgICBzdHlsZT17eyB3aWR0aDogYW5pbWF0aW9uID8gJzEwMCUnIDogdW5kZWZpbmVkIH19XG4gICAgICA+XG4gICAgICAgIDxTdHlsZWRTdGFjayBkaXJlY3Rpb249XCJjb2x1bW5cIj5cbiAgICAgICAgICB7aXNEaXBsYXkgPyAoXG4gICAgICAgICAgICA8U3R5bGVkVGV4dFxuICAgICAgICAgICAgICBhcz1cInNwYW5cIlxuICAgICAgICAgICAgICBwcm9taW5lbmNlPVwid2Vha1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgICB2YXJpYW50PVwiYm9keVNtYWxsU3Ryb25nXCJcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAge2xhYmVsfVxuICAgICAgICAgICAgPC9TdHlsZWRUZXh0PlxuICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgPC9TdHlsZWRTdGFjaz5cbiAgICAgIDwvQ29udGFpbmVyPlxuICAgIClcbiAgfVxuXG4gIHJldHVybiBudWxsXG59XG4iXX0= */"));
32
- const Container = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
33
- target: "eh4zgrv0"
34
- } : {
35
- target: "eh4zgrv0",
36
- label: "Container"
37
- })(`&[data-animation='expand'][data-animation-type="complex"]{`, StyledText, "{animation:", constants.groupAnimation, " ", constants.ANIMATION_DURATION, `ms ease-in-out;}}&[data-animation='collapse'][data-animation-type="complex"]{`, StyledText, "{animation:", constants.groupAnimation, " ", constants.ANIMATION_DURATION, "ms ease-in-out reverse;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvTmF2aWdhdGlvbi9jb21wb25lbnRzL0dyb3VwLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2QjRCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvTmF2aWdhdGlvbi9jb21wb25lbnRzL0dyb3VwLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IFN0YWNrLCBUZXh0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IENoaWxkcmVuIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBBTklNQVRJT05fRFVSQVRJT04sIGdyb3VwQW5pbWF0aW9uIH0gZnJvbSAnLi4vY29uc3RhbnRzJ1xuaW1wb3J0IHsgdXNlTmF2aWdhdGlvbiB9IGZyb20gJy4uL05hdmlnYXRpb25Qcm92aWRlcidcblxudHlwZSBHcm91cFByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGxhYmVsOiBzdHJpbmdcbn1cblxuY29uc3QgU3R5bGVkVGV4dCA9IHN0eWxlZChUZXh0KWBcbiAgcGFkZGluZy1ib3R0b206ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG4gIHBhZGRpbmctbGVmdDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfTtcblxuICB0cmFuc2l0aW9uOlxuICAgIG9wYWNpdHkgJHtBTklNQVRJT05fRFVSQVRJT059bXMgZWFzZS1pbi1vdXQsXG4gICAgaGVpZ2h0ICR7QU5JTUFUSU9OX0RVUkFUSU9OfW1zIGVhc2UtaW4tb3V0O1xuICBoZWlnaHQ6ICR7KHsgdGhlbWUgfSkgPT5cbiAgICBgY2FsYygke3RoZW1lLnR5cG9ncmFwaHkuYm9keVNtYWxsU3Ryb25nLmxpbmVIZWlnaHR9ICsgJHt0aGVtZS5zcGFjZVsnMSddfSlgfTsgLy8gVGhpcyBpcyBvbmx5IGZvciBhbmltYXRpb25cbmBcblxuY29uc3QgU3R5bGVkU3RhY2sgPSBzdHlsZWQoU3RhY2spYFxuICBwYWRkaW5nLXRvcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfTtcbmBcblxuY29uc3QgQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgJltkYXRhLWFuaW1hdGlvbj0nZXhwYW5kJ11bZGF0YS1hbmltYXRpb24tdHlwZT1cImNvbXBsZXhcIl0ge1xuICAgICR7U3R5bGVkVGV4dH0ge1xuICAgICAgYW5pbWF0aW9uOiAke2dyb3VwQW5pbWF0aW9ufSAke0FOSU1BVElPTl9EVVJBVElPTn1tcyBlYXNlLWluLW91dDtcbiAgICB9XG4gIH1cblxuICAmW2RhdGEtYW5pbWF0aW9uPSdjb2xsYXBzZSddW2RhdGEtYW5pbWF0aW9uLXR5cGU9XCJjb21wbGV4XCJdIHtcbiAgICAke1N0eWxlZFRleHR9IHtcbiAgICAgIGFuaW1hdGlvbjogJHtncm91cEFuaW1hdGlvbn0gJHtBTklNQVRJT05fRFVSQVRJT059bXMgZWFzZS1pbi1vdXQgcmV2ZXJzZTtcbiAgICB9XG4gIH1cbmBcblxuZXhwb3J0IGNvbnN0IEdyb3VwID0gKHsgY2hpbGRyZW4sIGxhYmVsIH06IEdyb3VwUHJvcHMpID0+IHtcbiAgY29uc3QgY29udGV4dCA9IHVzZU5hdmlnYXRpb24oKVxuXG4gIGlmICghY29udGV4dCkge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICdOYXZpZ2F0aW9uLkdyb3VwIGNhbiBvbmx5IGJlIHVzZWQgaW5zaWRlIGEgTmF2aWdhdGlvblByb3ZpZGVyLicsXG4gICAgKVxuICB9XG5cbiAgY29uc3QgeyBleHBhbmRlZCwgYW5pbWF0aW9uLCBhbmltYXRpb25UeXBlIH0gPSBjb250ZXh0XG5cbiAgY29uc3QgaXNEaXBsYXkgPSAhYW5pbWF0aW9uICYmIGV4cGFuZGVkXG5cbiAgaWYgKENoaWxkcmVuLmNvdW50KGNoaWxkcmVuKSA+IDApIHtcbiAgICByZXR1cm4gKFxuICAgICAgPENvbnRhaW5lclxuICAgICAgICBkYXRhLWFuaW1hdGlvbj17YW5pbWF0aW9ufVxuICAgICAgICBkYXRhLWFuaW1hdGlvbi10eXBlPXthbmltYXRpb25UeXBlfVxuICAgICAgICBzdHlsZT17eyB3aWR0aDogYW5pbWF0aW9uID8gJzEwMCUnIDogdW5kZWZpbmVkIH19XG4gICAgICA+XG4gICAgICAgIDxTdHlsZWRTdGFjayBkaXJlY3Rpb249XCJjb2x1bW5cIj5cbiAgICAgICAgICB7aXNEaXBsYXkgPyAoXG4gICAgICAgICAgICA8U3R5bGVkVGV4dFxuICAgICAgICAgICAgICBhcz1cInNwYW5cIlxuICAgICAgICAgICAgICBwcm9taW5lbmNlPVwid2Vha1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgICB2YXJpYW50PVwiYm9keVNtYWxsU3Ryb25nXCJcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAge2xhYmVsfVxuICAgICAgICAgICAgPC9TdHlsZWRUZXh0PlxuICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgPC9TdHlsZWRTdGFjaz5cbiAgICAgIDwvQ29udGFpbmVyPlxuICAgIClcbiAgfVxuXG4gIHJldHVybiBudWxsXG59XG4iXX0= */"));
8
+ const styles_css = require("./styles.css.cjs");
38
9
  const Group = ({
39
10
  children,
40
11
  label
@@ -50,10 +21,12 @@ const Group = ({
50
21
  } = context;
51
22
  const isDiplay = !animation && expanded;
52
23
  if (react.Children.count(children) > 0) {
53
- return /* @__PURE__ */ jsxRuntime.jsx(Container, { "data-animation": animation, "data-animation-type": animationType, style: {
24
+ return /* @__PURE__ */ jsxRuntime.jsx("div", { style: {
54
25
  width: animation ? "100%" : void 0
55
- }, children: /* @__PURE__ */ jsxRuntime.jsxs(StyledStack, { direction: "column", children: [
56
- isDiplay ? /* @__PURE__ */ jsxRuntime.jsx(StyledText, { as: "span", prominence: "weak", sentiment: "neutral", variant: "bodySmallStrong", children: label }) : null,
26
+ }, children: /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { className: styles_css.navigationGroupStack, direction: "column", children: [
27
+ isDiplay ? /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: "span", className: styles_css.navigationGroupText({
28
+ animation: animationType === "complex" ? animation : false
29
+ }), prominence: "weak", sentiment: "neutral", variant: "bodySmallStrong", children: label }) : null,
57
30
  children
58
31
  ] }) });
59
32
  }
@@ -1,36 +1,9 @@
1
1
  "use client";
2
2
  import { jsx, jsxs } from "@emotion/react/jsx-runtime";
3
- import _styled from "@emotion/styled/base";
4
3
  import { Stack, Text } from "@ultraviolet/ui";
5
4
  import { Children } from "react";
6
- import { groupAnimation, ANIMATION_DURATION } from "../constants.js";
7
5
  import { useNavigation } from "../NavigationProvider.js";
8
- const StyledText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
9
- target: "eh4zgrv2"
10
- } : {
11
- target: "eh4zgrv2",
12
- label: "StyledText"
13
- })("padding-bottom:", ({
14
- theme
15
- }) => theme.space["1"], ";padding-left:", ({
16
- theme
17
- }) => theme.space["1"], ";transition:opacity ", ANIMATION_DURATION, "ms ease-in-out,height ", ANIMATION_DURATION, "ms ease-in-out;height:", ({
18
- theme
19
- }) => `calc(${theme.typography.bodySmallStrong.lineHeight} + ${theme.space["1"]})`, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvTmF2aWdhdGlvbi9jb21wb25lbnRzL0dyb3VwLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFjK0IiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvcGx1cy9zcmMvY29tcG9uZW50cy9OYXZpZ2F0aW9uL2NvbXBvbmVudHMvR3JvdXAudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgU3RhY2ssIFRleHQgfSBmcm9tICdAdWx0cmF2aW9sZXQvdWknXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgQ2hpbGRyZW4gfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IEFOSU1BVElPTl9EVVJBVElPTiwgZ3JvdXBBbmltYXRpb24gfSBmcm9tICcuLi9jb25zdGFudHMnXG5pbXBvcnQgeyB1c2VOYXZpZ2F0aW9uIH0gZnJvbSAnLi4vTmF2aWdhdGlvblByb3ZpZGVyJ1xuXG50eXBlIEdyb3VwUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgbGFiZWw6IHN0cmluZ1xufVxuXG5jb25zdCBTdHlsZWRUZXh0ID0gc3R5bGVkKFRleHQpYFxuICBwYWRkaW5nLWJvdHRvbTogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfTtcbiAgcGFkZGluZy1sZWZ0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuXG4gIHRyYW5zaXRpb246XG4gICAgb3BhY2l0eSAke0FOSU1BVElPTl9EVVJBVElPTn1tcyBlYXNlLWluLW91dCxcbiAgICBoZWlnaHQgJHtBTklNQVRJT05fRFVSQVRJT059bXMgZWFzZS1pbi1vdXQ7XG4gIGhlaWdodDogJHsoeyB0aGVtZSB9KSA9PlxuICAgIGBjYWxjKCR7dGhlbWUudHlwb2dyYXBoeS5ib2R5U21hbGxTdHJvbmcubGluZUhlaWdodH0gKyAke3RoZW1lLnNwYWNlWycxJ119KWB9OyAvLyBUaGlzIGlzIG9ubHkgZm9yIGFuaW1hdGlvblxuYFxuXG5jb25zdCBTdHlsZWRTdGFjayA9IHN0eWxlZChTdGFjaylgXG4gIHBhZGRpbmctdG9wOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuYFxuXG5jb25zdCBDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICAmW2RhdGEtYW5pbWF0aW9uPSdleHBhbmQnXVtkYXRhLWFuaW1hdGlvbi10eXBlPVwiY29tcGxleFwiXSB7XG4gICAgJHtTdHlsZWRUZXh0fSB7XG4gICAgICBhbmltYXRpb246ICR7Z3JvdXBBbmltYXRpb259ICR7QU5JTUFUSU9OX0RVUkFUSU9OfW1zIGVhc2UtaW4tb3V0O1xuICAgIH1cbiAgfVxuXG4gICZbZGF0YS1hbmltYXRpb249J2NvbGxhcHNlJ11bZGF0YS1hbmltYXRpb24tdHlwZT1cImNvbXBsZXhcIl0ge1xuICAgICR7U3R5bGVkVGV4dH0ge1xuICAgICAgYW5pbWF0aW9uOiAke2dyb3VwQW5pbWF0aW9ufSAke0FOSU1BVElPTl9EVVJBVElPTn1tcyBlYXNlLWluLW91dCByZXZlcnNlO1xuICAgIH1cbiAgfVxuYFxuXG5leHBvcnQgY29uc3QgR3JvdXAgPSAoeyBjaGlsZHJlbiwgbGFiZWwgfTogR3JvdXBQcm9wcykgPT4ge1xuICBjb25zdCBjb250ZXh0ID0gdXNlTmF2aWdhdGlvbigpXG5cbiAgaWYgKCFjb250ZXh0KSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgJ05hdmlnYXRpb24uR3JvdXAgY2FuIG9ubHkgYmUgdXNlZCBpbnNpZGUgYSBOYXZpZ2F0aW9uUHJvdmlkZXIuJyxcbiAgICApXG4gIH1cblxuICBjb25zdCB7IGV4cGFuZGVkLCBhbmltYXRpb24sIGFuaW1hdGlvblR5cGUgfSA9IGNvbnRleHRcblxuICBjb25zdCBpc0RpcGxheSA9ICFhbmltYXRpb24gJiYgZXhwYW5kZWRcblxuICBpZiAoQ2hpbGRyZW4uY291bnQoY2hpbGRyZW4pID4gMCkge1xuICAgIHJldHVybiAoXG4gICAgICA8Q29udGFpbmVyXG4gICAgICAgIGRhdGEtYW5pbWF0aW9uPXthbmltYXRpb259XG4gICAgICAgIGRhdGEtYW5pbWF0aW9uLXR5cGU9e2FuaW1hdGlvblR5cGV9XG4gICAgICAgIHN0eWxlPXt7IHdpZHRoOiBhbmltYXRpb24gPyAnMTAwJScgOiB1bmRlZmluZWQgfX1cbiAgICAgID5cbiAgICAgICAgPFN0eWxlZFN0YWNrIGRpcmVjdGlvbj1cImNvbHVtblwiPlxuICAgICAgICAgIHtpc0RpcGxheSA/IChcbiAgICAgICAgICAgIDxTdHlsZWRUZXh0XG4gICAgICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgICAgIHByb21pbmVuY2U9XCJ3ZWFrXCJcbiAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgIHZhcmlhbnQ9XCJib2R5U21hbGxTdHJvbmdcIlxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7bGFiZWx9XG4gICAgICAgICAgICA8L1N0eWxlZFRleHQ+XG4gICAgICAgICAgKSA6IG51bGx9XG4gICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICA8L1N0eWxlZFN0YWNrPlxuICAgICAgPC9Db250YWluZXI+XG4gICAgKVxuICB9XG5cbiAgcmV0dXJuIG51bGxcbn1cbiJdfQ== */"));
20
- const StyledStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
21
- target: "eh4zgrv1"
22
- } : {
23
- target: "eh4zgrv1",
24
- label: "StyledStack"
25
- })("padding-top:", ({
26
- theme
27
- }) => theme.space["1"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvTmF2aWdhdGlvbi9jb21wb25lbnRzL0dyb3VwLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5QmlDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvTmF2aWdhdGlvbi9jb21wb25lbnRzL0dyb3VwLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IFN0YWNrLCBUZXh0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IENoaWxkcmVuIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBBTklNQVRJT05fRFVSQVRJT04sIGdyb3VwQW5pbWF0aW9uIH0gZnJvbSAnLi4vY29uc3RhbnRzJ1xuaW1wb3J0IHsgdXNlTmF2aWdhdGlvbiB9IGZyb20gJy4uL05hdmlnYXRpb25Qcm92aWRlcidcblxudHlwZSBHcm91cFByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGxhYmVsOiBzdHJpbmdcbn1cblxuY29uc3QgU3R5bGVkVGV4dCA9IHN0eWxlZChUZXh0KWBcbiAgcGFkZGluZy1ib3R0b206ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG4gIHBhZGRpbmctbGVmdDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfTtcblxuICB0cmFuc2l0aW9uOlxuICAgIG9wYWNpdHkgJHtBTklNQVRJT05fRFVSQVRJT059bXMgZWFzZS1pbi1vdXQsXG4gICAgaGVpZ2h0ICR7QU5JTUFUSU9OX0RVUkFUSU9OfW1zIGVhc2UtaW4tb3V0O1xuICBoZWlnaHQ6ICR7KHsgdGhlbWUgfSkgPT5cbiAgICBgY2FsYygke3RoZW1lLnR5cG9ncmFwaHkuYm9keVNtYWxsU3Ryb25nLmxpbmVIZWlnaHR9ICsgJHt0aGVtZS5zcGFjZVsnMSddfSlgfTsgLy8gVGhpcyBpcyBvbmx5IGZvciBhbmltYXRpb25cbmBcblxuY29uc3QgU3R5bGVkU3RhY2sgPSBzdHlsZWQoU3RhY2spYFxuICBwYWRkaW5nLXRvcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfTtcbmBcblxuY29uc3QgQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgJltkYXRhLWFuaW1hdGlvbj0nZXhwYW5kJ11bZGF0YS1hbmltYXRpb24tdHlwZT1cImNvbXBsZXhcIl0ge1xuICAgICR7U3R5bGVkVGV4dH0ge1xuICAgICAgYW5pbWF0aW9uOiAke2dyb3VwQW5pbWF0aW9ufSAke0FOSU1BVElPTl9EVVJBVElPTn1tcyBlYXNlLWluLW91dDtcbiAgICB9XG4gIH1cblxuICAmW2RhdGEtYW5pbWF0aW9uPSdjb2xsYXBzZSddW2RhdGEtYW5pbWF0aW9uLXR5cGU9XCJjb21wbGV4XCJdIHtcbiAgICAke1N0eWxlZFRleHR9IHtcbiAgICAgIGFuaW1hdGlvbjogJHtncm91cEFuaW1hdGlvbn0gJHtBTklNQVRJT05fRFVSQVRJT059bXMgZWFzZS1pbi1vdXQgcmV2ZXJzZTtcbiAgICB9XG4gIH1cbmBcblxuZXhwb3J0IGNvbnN0IEdyb3VwID0gKHsgY2hpbGRyZW4sIGxhYmVsIH06IEdyb3VwUHJvcHMpID0+IHtcbiAgY29uc3QgY29udGV4dCA9IHVzZU5hdmlnYXRpb24oKVxuXG4gIGlmICghY29udGV4dCkge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICdOYXZpZ2F0aW9uLkdyb3VwIGNhbiBvbmx5IGJlIHVzZWQgaW5zaWRlIGEgTmF2aWdhdGlvblByb3ZpZGVyLicsXG4gICAgKVxuICB9XG5cbiAgY29uc3QgeyBleHBhbmRlZCwgYW5pbWF0aW9uLCBhbmltYXRpb25UeXBlIH0gPSBjb250ZXh0XG5cbiAgY29uc3QgaXNEaXBsYXkgPSAhYW5pbWF0aW9uICYmIGV4cGFuZGVkXG5cbiAgaWYgKENoaWxkcmVuLmNvdW50KGNoaWxkcmVuKSA+IDApIHtcbiAgICByZXR1cm4gKFxuICAgICAgPENvbnRhaW5lclxuICAgICAgICBkYXRhLWFuaW1hdGlvbj17YW5pbWF0aW9ufVxuICAgICAgICBkYXRhLWFuaW1hdGlvbi10eXBlPXthbmltYXRpb25UeXBlfVxuICAgICAgICBzdHlsZT17eyB3aWR0aDogYW5pbWF0aW9uID8gJzEwMCUnIDogdW5kZWZpbmVkIH19XG4gICAgICA+XG4gICAgICAgIDxTdHlsZWRTdGFjayBkaXJlY3Rpb249XCJjb2x1bW5cIj5cbiAgICAgICAgICB7aXNEaXBsYXkgPyAoXG4gICAgICAgICAgICA8U3R5bGVkVGV4dFxuICAgICAgICAgICAgICBhcz1cInNwYW5cIlxuICAgICAgICAgICAgICBwcm9taW5lbmNlPVwid2Vha1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgICB2YXJpYW50PVwiYm9keVNtYWxsU3Ryb25nXCJcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAge2xhYmVsfVxuICAgICAgICAgICAgPC9TdHlsZWRUZXh0PlxuICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgPC9TdHlsZWRTdGFjaz5cbiAgICAgIDwvQ29udGFpbmVyPlxuICAgIClcbiAgfVxuXG4gIHJldHVybiBudWxsXG59XG4iXX0= */"));
28
- const Container = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
29
- target: "eh4zgrv0"
30
- } : {
31
- target: "eh4zgrv0",
32
- label: "Container"
33
- })(`&[data-animation='expand'][data-animation-type="complex"]{`, StyledText, "{animation:", groupAnimation, " ", ANIMATION_DURATION, `ms ease-in-out;}}&[data-animation='collapse'][data-animation-type="complex"]{`, StyledText, "{animation:", groupAnimation, " ", ANIMATION_DURATION, "ms ease-in-out reverse;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvTmF2aWdhdGlvbi9jb21wb25lbnRzL0dyb3VwLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2QjRCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvTmF2aWdhdGlvbi9jb21wb25lbnRzL0dyb3VwLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IFN0YWNrLCBUZXh0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IENoaWxkcmVuIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBBTklNQVRJT05fRFVSQVRJT04sIGdyb3VwQW5pbWF0aW9uIH0gZnJvbSAnLi4vY29uc3RhbnRzJ1xuaW1wb3J0IHsgdXNlTmF2aWdhdGlvbiB9IGZyb20gJy4uL05hdmlnYXRpb25Qcm92aWRlcidcblxudHlwZSBHcm91cFByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGxhYmVsOiBzdHJpbmdcbn1cblxuY29uc3QgU3R5bGVkVGV4dCA9IHN0eWxlZChUZXh0KWBcbiAgcGFkZGluZy1ib3R0b206ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG4gIHBhZGRpbmctbGVmdDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfTtcblxuICB0cmFuc2l0aW9uOlxuICAgIG9wYWNpdHkgJHtBTklNQVRJT05fRFVSQVRJT059bXMgZWFzZS1pbi1vdXQsXG4gICAgaGVpZ2h0ICR7QU5JTUFUSU9OX0RVUkFUSU9OfW1zIGVhc2UtaW4tb3V0O1xuICBoZWlnaHQ6ICR7KHsgdGhlbWUgfSkgPT5cbiAgICBgY2FsYygke3RoZW1lLnR5cG9ncmFwaHkuYm9keVNtYWxsU3Ryb25nLmxpbmVIZWlnaHR9ICsgJHt0aGVtZS5zcGFjZVsnMSddfSlgfTsgLy8gVGhpcyBpcyBvbmx5IGZvciBhbmltYXRpb25cbmBcblxuY29uc3QgU3R5bGVkU3RhY2sgPSBzdHlsZWQoU3RhY2spYFxuICBwYWRkaW5nLXRvcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfTtcbmBcblxuY29uc3QgQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgJltkYXRhLWFuaW1hdGlvbj0nZXhwYW5kJ11bZGF0YS1hbmltYXRpb24tdHlwZT1cImNvbXBsZXhcIl0ge1xuICAgICR7U3R5bGVkVGV4dH0ge1xuICAgICAgYW5pbWF0aW9uOiAke2dyb3VwQW5pbWF0aW9ufSAke0FOSU1BVElPTl9EVVJBVElPTn1tcyBlYXNlLWluLW91dDtcbiAgICB9XG4gIH1cblxuICAmW2RhdGEtYW5pbWF0aW9uPSdjb2xsYXBzZSddW2RhdGEtYW5pbWF0aW9uLXR5cGU9XCJjb21wbGV4XCJdIHtcbiAgICAke1N0eWxlZFRleHR9IHtcbiAgICAgIGFuaW1hdGlvbjogJHtncm91cEFuaW1hdGlvbn0gJHtBTklNQVRJT05fRFVSQVRJT059bXMgZWFzZS1pbi1vdXQgcmV2ZXJzZTtcbiAgICB9XG4gIH1cbmBcblxuZXhwb3J0IGNvbnN0IEdyb3VwID0gKHsgY2hpbGRyZW4sIGxhYmVsIH06IEdyb3VwUHJvcHMpID0+IHtcbiAgY29uc3QgY29udGV4dCA9IHVzZU5hdmlnYXRpb24oKVxuXG4gIGlmICghY29udGV4dCkge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICdOYXZpZ2F0aW9uLkdyb3VwIGNhbiBvbmx5IGJlIHVzZWQgaW5zaWRlIGEgTmF2aWdhdGlvblByb3ZpZGVyLicsXG4gICAgKVxuICB9XG5cbiAgY29uc3QgeyBleHBhbmRlZCwgYW5pbWF0aW9uLCBhbmltYXRpb25UeXBlIH0gPSBjb250ZXh0XG5cbiAgY29uc3QgaXNEaXBsYXkgPSAhYW5pbWF0aW9uICYmIGV4cGFuZGVkXG5cbiAgaWYgKENoaWxkcmVuLmNvdW50KGNoaWxkcmVuKSA+IDApIHtcbiAgICByZXR1cm4gKFxuICAgICAgPENvbnRhaW5lclxuICAgICAgICBkYXRhLWFuaW1hdGlvbj17YW5pbWF0aW9ufVxuICAgICAgICBkYXRhLWFuaW1hdGlvbi10eXBlPXthbmltYXRpb25UeXBlfVxuICAgICAgICBzdHlsZT17eyB3aWR0aDogYW5pbWF0aW9uID8gJzEwMCUnIDogdW5kZWZpbmVkIH19XG4gICAgICA+XG4gICAgICAgIDxTdHlsZWRTdGFjayBkaXJlY3Rpb249XCJjb2x1bW5cIj5cbiAgICAgICAgICB7aXNEaXBsYXkgPyAoXG4gICAgICAgICAgICA8U3R5bGVkVGV4dFxuICAgICAgICAgICAgICBhcz1cInNwYW5cIlxuICAgICAgICAgICAgICBwcm9taW5lbmNlPVwid2Vha1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgICB2YXJpYW50PVwiYm9keVNtYWxsU3Ryb25nXCJcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAge2xhYmVsfVxuICAgICAgICAgICAgPC9TdHlsZWRUZXh0PlxuICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgPC9TdHlsZWRTdGFjaz5cbiAgICAgIDwvQ29udGFpbmVyPlxuICAgIClcbiAgfVxuXG4gIHJldHVybiBudWxsXG59XG4iXX0= */"));
6
+ import { navigationGroupStack, navigationGroupText } from "./styles.css.js";
34
7
  const Group = ({
35
8
  children,
36
9
  label
@@ -46,10 +19,12 @@ const Group = ({
46
19
  } = context;
47
20
  const isDiplay = !animation && expanded;
48
21
  if (Children.count(children) > 0) {
49
- return /* @__PURE__ */ jsx(Container, { "data-animation": animation, "data-animation-type": animationType, style: {
22
+ return /* @__PURE__ */ jsx("div", { style: {
50
23
  width: animation ? "100%" : void 0
51
- }, children: /* @__PURE__ */ jsxs(StyledStack, { direction: "column", children: [
52
- isDiplay ? /* @__PURE__ */ jsx(StyledText, { as: "span", prominence: "weak", sentiment: "neutral", variant: "bodySmallStrong", children: label }) : null,
24
+ }, children: /* @__PURE__ */ jsxs(Stack, { className: navigationGroupStack, direction: "column", children: [
25
+ isDiplay ? /* @__PURE__ */ jsx(Text, { as: "span", className: navigationGroupText({
26
+ animation: animationType === "complex" ? animation : false
27
+ }), prominence: "weak", sentiment: "neutral", variant: "bodySmallStrong", children: label }) : null,
53
28
  children
54
29
  ] }) });
55
30
  }