boreal-ui 0.0.878 → 0.0.880

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 (82) hide show
  1. package/dist/core/{Footer-BVK-IScY.js → Footer-BI7Bwc-6.js} +2 -4
  2. package/dist/core/Footer-BI7Bwc-6.js.map +1 -0
  3. package/dist/core/{Footer-CGTDSN42.cjs → Footer-CBtuZduq.cjs} +2 -4
  4. package/dist/core/Footer-CBtuZduq.cjs.map +1 -0
  5. package/dist/core/Footer.cjs.js +1 -1
  6. package/dist/core/Footer.js +1 -1
  7. package/dist/core/{ThemeContext-B42x9yzg.cjs → ThemeContext-AHk5GZwb.cjs} +27 -8
  8. package/dist/core/ThemeContext-AHk5GZwb.cjs.map +1 -0
  9. package/dist/core/{ThemeContext-B8DW9Nt1.js → ThemeContext-C7iPDzb0.js} +27 -8
  10. package/dist/core/ThemeContext-C7iPDzb0.js.map +1 -0
  11. package/dist/core/ThemeProvider.cjs.js +1 -1
  12. package/dist/core/ThemeProvider.js +1 -1
  13. package/dist/core/{Toolbar-Dz1rhlz_.cjs → Toolbar-BUkKkXBz.cjs} +9 -3
  14. package/dist/core/Toolbar-BUkKkXBz.cjs.map +1 -0
  15. package/dist/core/{Toolbar-ArPZcJS3.js → Toolbar-DQifkFqc.js} +9 -3
  16. package/dist/core/Toolbar-DQifkFqc.js.map +1 -0
  17. package/dist/core/Toolbar.cjs.js +1 -1
  18. package/dist/core/Toolbar.css +15 -0
  19. package/dist/core/Toolbar.js +1 -1
  20. package/dist/core/colorSchemes.cjs.js +2 -2
  21. package/dist/core/colorSchemes.cjs.js.map +1 -1
  22. package/dist/core/colorSchemes.js +2 -2
  23. package/dist/core/colorSchemes.js.map +1 -1
  24. package/dist/core/index.cjs.js +5 -5
  25. package/dist/core/index.js +7 -7
  26. package/dist/core/registerColorSheme.cjs.js +15 -2
  27. package/dist/core/registerColorSheme.cjs.js.map +1 -1
  28. package/dist/core/registerColorSheme.js +15 -2
  29. package/dist/core/registerColorSheme.js.map +1 -1
  30. package/dist/next/{Footer-D7OKOslE.js → Footer-Ct2O1TSA.js} +2 -4
  31. package/dist/next/Footer-Ct2O1TSA.js.map +1 -0
  32. package/dist/next/Footer.js +1 -1
  33. package/dist/next/{NextThemeProvider-9drpwxZe.js → NextThemeProvider-BST506fl.js} +2 -2
  34. package/dist/next/{NextThemeProvider-9drpwxZe.js.map → NextThemeProvider-BST506fl.js.map} +1 -1
  35. package/dist/next/{ThemeContext-OKK1n9VA.js → ThemeContext-CVJwo33B.js} +27 -8
  36. package/dist/next/ThemeContext-CVJwo33B.js.map +1 -0
  37. package/dist/next/ThemeProvider.js +1 -1
  38. package/dist/next/{Toolbar-CHF5nZ1h.js → Toolbar-DOVyHYvQ.js} +39 -31
  39. package/dist/next/Toolbar-DOVyHYvQ.js.map +1 -0
  40. package/dist/next/Toolbar.css +60 -42
  41. package/dist/next/Toolbar.js +1 -1
  42. package/dist/next/colorSchemes.js +2 -2
  43. package/dist/next/colorSchemes.js.map +1 -1
  44. package/dist/next/index.js +7 -7
  45. package/dist/next/registerColorSheme.js +15 -2
  46. package/dist/next/registerColorSheme.js.map +1 -1
  47. package/dist/tsconfig.build.tsbuildinfo +1 -1
  48. package/dist/types/Icons/index.d.ts +0 -1
  49. package/dist/types/Icons/index.d.ts.map +1 -1
  50. package/dist/types/components/Footer/FooterBase.d.ts.map +1 -1
  51. package/dist/types/components/Toolbar/Toolbar.types.d.ts +11 -1
  52. package/dist/types/components/Toolbar/Toolbar.types.d.ts.map +1 -1
  53. package/dist/types/components/Toolbar/ToolbarBase.d.ts.map +1 -1
  54. package/dist/types/components/Toolbar/core/Toolbar.d.ts.map +1 -1
  55. package/dist/types/context/ThemeContext.d.ts.map +1 -1
  56. package/dist/types/context/ThemeContext.types.d.ts +2 -0
  57. package/dist/types/context/ThemeContext.types.d.ts.map +1 -1
  58. package/dist/types/index.core.d.ts +1 -1
  59. package/dist/types/index.core.d.ts.map +1 -1
  60. package/dist/types/index.next.d.ts +1 -1
  61. package/dist/types/index.next.d.ts.map +1 -1
  62. package/dist/types/styles/Themes.d.ts +3 -5
  63. package/dist/types/styles/Themes.d.ts.map +1 -1
  64. package/dist/types/styles/colorSchemeRegistry.d.ts.map +1 -1
  65. package/package.json +1 -1
  66. package/dist/core/Footer-BVK-IScY.js.map +0 -1
  67. package/dist/core/Footer-CGTDSN42.cjs.map +0 -1
  68. package/dist/core/ThemeContext-B42x9yzg.cjs.map +0 -1
  69. package/dist/core/ThemeContext-B8DW9Nt1.js.map +0 -1
  70. package/dist/core/Toolbar-ArPZcJS3.js.map +0 -1
  71. package/dist/core/Toolbar-Dz1rhlz_.cjs.map +0 -1
  72. package/dist/core/registerColorSheme-BPX0H7hl.js +0 -21
  73. package/dist/core/registerColorSheme-BPX0H7hl.js.map +0 -1
  74. package/dist/core/registerColorSheme-nhYu5hbY.cjs +0 -20
  75. package/dist/core/registerColorSheme-nhYu5hbY.cjs.map +0 -1
  76. package/dist/next/Footer-D7OKOslE.js.map +0 -1
  77. package/dist/next/ThemeContext-OKK1n9VA.js.map +0 -1
  78. package/dist/next/Toolbar-CHF5nZ1h.js.map +0 -1
  79. package/dist/next/registerColorSheme-BPX0H7hl.js +0 -21
  80. package/dist/next/registerColorSheme-BPX0H7hl.js.map +0 -1
  81. package/dist/types/Icons/SeperatorIcon.d.ts +0 -3
  82. package/dist/types/Icons/SeperatorIcon.d.ts.map +0 -1
@@ -5,7 +5,7 @@ import { d as getDefaultTheme, b as getDefaultShadow, a as getDefaultRounding }
5
5
  import { c as capitalize } from "./capitalize-C0TSQSPh.js";
6
6
  import { I as IconButton } from "./IconButton-LlILBbQv.js";
7
7
  import { S as Select } from "./Select-btS45KZa.js";
8
- import { T as ThemeContext } from "./ThemeContext-B8DW9Nt1.js";
8
+ import { T as ThemeContext } from "./ThemeContext-C7iPDzb0.js";
9
9
  import './Footer.css';const FooterBase = ({
10
10
  theme = getDefaultTheme(),
11
11
  attachment = "static",
@@ -23,7 +23,6 @@ import './Footer.css';const FooterBase = ({
23
23
  ThemeSelect,
24
24
  classMap,
25
25
  LinkWrapper = ({ href, children, ...rest2 }) => /* @__PURE__ */ jsx("a", { href, ...rest2, children }),
26
- // New accessibility props
27
26
  "aria-label": ariaLabel,
28
27
  "aria-labelledby": ariaLabelledBy,
29
28
  "aria-describedby": ariaDescribedBy,
@@ -33,7 +32,6 @@ import './Footer.css';const FooterBase = ({
33
32
  logoAriaLabel = "Logo",
34
33
  logoDecorative = false,
35
34
  labelId,
36
- // Pass-through HTML props
37
35
  ...rest
38
36
  }) => {
39
37
  const footerClass = useMemo(
@@ -271,4 +269,4 @@ export {
271
269
  Footer as F,
272
270
  UserThemeSettings as U
273
271
  };
274
- //# sourceMappingURL=Footer-BVK-IScY.js.map
272
+ //# sourceMappingURL=Footer-BI7Bwc-6.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Footer-BI7Bwc-6.js","sources":["../../src/components/Footer/FooterBase.tsx","../../src/components/Select/ThemeSelect/core/ThemeSelect.tsx","../../src/components/Footer/core/Footer.tsx"],"sourcesContent":["import React, { useMemo } from \"react\";\r\nimport { BaseFooterProps, LogoSource } from \"./Footer.types\";\r\nimport { combineClassNames } from \"../../utils/classNames\";\r\nimport { getDefaultTheme } from \"../../config/boreal-style-config\";\r\nimport { capitalize } from \"@/utils/capitalize\";\r\n\r\nconst FooterBase: React.FC<BaseFooterProps> = ({\r\n theme = getDefaultTheme(),\r\n attachment = \"static\",\r\n shadow = \"none\",\r\n rounding = \"none\",\r\n className = \"\",\r\n \"data-testid\": testId = \"footer\",\r\n copyright,\r\n links = [],\r\n logo,\r\n socialLinks = [],\r\n showThemeSelect = false,\r\n IconButton,\r\n ImageComponent = \"img\",\r\n ThemeSelect,\r\n classMap,\r\n LinkWrapper = ({ href, children, ...rest }) => (\r\n <a href={href} {...rest}>\r\n {children}\r\n </a>\r\n ),\r\n \"aria-label\": ariaLabel,\r\n \"aria-labelledby\": ariaLabelledBy,\r\n \"aria-describedby\": ariaDescribedBy,\r\n navAriaLabel = \"Footer site links\",\r\n socialNavAriaLabel = \"Social media\",\r\n themeSelectAriaLabel = \"Theme selector\",\r\n logoAriaLabel = \"Logo\",\r\n logoDecorative = false,\r\n labelId,\r\n ...rest\r\n}) => {\r\n const footerClass = useMemo(\r\n () =>\r\n combineClassNames(\r\n classMap.footer,\r\n classMap[theme],\r\n shadow !== \"none\" && classMap[`shadow${capitalize(shadow)}`],\r\n rounding !== \"none\" && classMap[`round${capitalize(rounding)}`],\r\n classMap[`attachment${capitalize(attachment)}`],\r\n className,\r\n ),\r\n [classMap, theme, shadow, rounding, attachment, className],\r\n );\r\n\r\n const isLogoImage = (\r\n value: unknown,\r\n ): value is { src: string; width?: number; height?: number } =>\r\n typeof value === \"object\" &&\r\n value !== null &&\r\n \"src\" in (value as Record<string, unknown>);\r\n\r\n const isImgLike = typeof logo === \"string\" || isLogoImage(logo);\r\n\r\n const imgLogo = isImgLike\r\n ? typeof logo === \"string\"\r\n ? { src: logo }\r\n : logo\r\n : undefined;\r\n\r\n const logoSrc = imgLogo?.src;\r\n const logoW = imgLogo?.width ?? 20;\r\n const logoH = imgLogo?.height ?? 20;\r\n\r\n return (\r\n <footer\r\n className={footerClass}\r\n data-testid={testId}\r\n role=\"contentinfo\"\r\n aria-label={ariaLabel}\r\n aria-labelledby={ariaLabelledBy ?? labelId}\r\n aria-describedby={ariaDescribedBy}\r\n {...rest}\r\n >\r\n <div className={classMap.content}>\r\n <div className={classMap.left} data-testid={`${testId}-left`}>\r\n {isImgLike && logoSrc ? (\r\n typeof ImageComponent === \"string\" ? (\r\n <img\r\n className={classMap.logo}\r\n data-testid={`${testId}-logo`}\r\n loading=\"lazy\"\r\n src={logoSrc}\r\n alt={logoDecorative ? \"\" : logoAriaLabel}\r\n aria-hidden={logoDecorative ? true : undefined}\r\n height={logoH}\r\n width={logoW}\r\n />\r\n ) : (\r\n <ImageComponent\r\n className={classMap.logo}\r\n data-testid={`${testId}-logo`}\r\n src={logoSrc}\r\n alt={logoDecorative ? \"\" : logoAriaLabel}\r\n aria-hidden={logoDecorative ? true : undefined}\r\n height={logoH}\r\n width={logoW}\r\n />\r\n )\r\n ) : logo ? (\r\n <span\r\n className={classMap.logo}\r\n role={logoDecorative ? undefined : \"img\"}\r\n aria-label={logoDecorative ? undefined : logoAriaLabel}\r\n aria-hidden={logoDecorative ? true : undefined}\r\n data-testid={`${testId}-logo`}\r\n >\r\n {\r\n logo as Exclude<\r\n LogoSource,\r\n string | { src: string; width?: number; height?: number }\r\n >\r\n }\r\n </span>\r\n ) : null}\r\n\r\n {copyright && (\r\n <div\r\n className={classMap.copyright ?? classMap.left}\r\n data-testid={`${testId}-copyright`}\r\n >\r\n <p id={labelId}>{copyright}</p>\r\n </div>\r\n )}\r\n </div>\r\n\r\n {links.length > 0 && (\r\n <nav\r\n className={classMap.links}\r\n aria-label={navAriaLabel}\r\n data-testid={`${testId}-nav`}\r\n >\r\n <ul>\r\n {links.map((link, i) => {\r\n const slug = (link.label || link.href || `link-${i}`)\r\n .toLowerCase()\r\n .replace(/\\s+/g, \"-\");\r\n\r\n if (link.disabled) {\r\n return (\r\n <li key={`${link.href ?? slug}-${i}`}>\r\n <span\r\n className={classMap.link}\r\n data-testid={`${testId}-link-${slug}`}\r\n aria-disabled=\"true\"\r\n title={link.title}\r\n >\r\n {link.label}\r\n </span>\r\n </li>\r\n );\r\n }\r\n\r\n return (\r\n <li key={`${link.href ?? slug}-${i}`}>\r\n <LinkWrapper\r\n href={link.href}\r\n className={classMap.link}\r\n data-testid={`${testId}-link-${slug}`}\r\n aria-label={link[\"aria-label\"]}\r\n aria-current={link[\"aria-current\"]}\r\n title={link.title}\r\n rel={link.rel}\r\n target={link.target}\r\n >\r\n {link.label}\r\n </LinkWrapper>\r\n </li>\r\n );\r\n })}\r\n </ul>\r\n </nav>\r\n )}\r\n\r\n {showThemeSelect && (\r\n <div\r\n className={classMap.themeToggle}\r\n data-testid={`${testId}-theme-select`}\r\n aria-label={themeSelectAriaLabel}\r\n >\r\n <ThemeSelect\r\n theme=\"clear\"\r\n shadow=\"none\"\r\n aria-label={themeSelectAriaLabel}\r\n />\r\n </div>\r\n )}\r\n\r\n {socialLinks.length > 0 && (\r\n <nav\r\n className={classMap.social}\r\n aria-label={socialNavAriaLabel}\r\n data-testid={`${testId}-social`}\r\n >\r\n {socialLinks.map((social, index) => (\r\n <IconButton\r\n key={`${social.href ?? social.title}-${index}`}\r\n icon={social.icon}\r\n href={social.href}\r\n isExternal={social.isExternal ?? true}\r\n shadow=\"none\"\r\n aria-label={social[\"aria-label\"] ?? social.title}\r\n title={social.tooltip ?? social.title}\r\n theme=\"clear\"\r\n disabled={social.disabled}\r\n rel={social.rel}\r\n target={social.target}\r\n data-testid={`${testId}-social-${social.title\r\n .toLowerCase()\r\n .replace(/\\s+/g, \"-\")}`}\r\n />\r\n ))}\r\n </nav>\r\n )}\r\n </div>\r\n </footer>\r\n );\r\n};\r\n\r\nFooterBase.displayName = \"FooterBase\";\r\nexport default FooterBase;\r\n","import { useContext, useMemo, forwardRef } from \"react\";\r\nimport Select from \"../../core/Select\";\r\nimport { ThemeContext } from \"../../../../context/ThemeContext\";\r\nimport {\r\n getDefaultRounding,\r\n getDefaultShadow,\r\n getDefaultTheme,\r\n} from \"@/config/boreal-style-config\";\r\nimport { ThemeSelectProps } from \"../../Select.types\";\r\n\r\nconst UserThemeSettings = forwardRef<HTMLSelectElement, ThemeSelectProps>(\r\n (\r\n {\r\n theme = getDefaultTheme(),\r\n shadow = getDefaultShadow(),\r\n rounding = getDefaultRounding(),\r\n \"data-testid\": testId = \"theme-select\",\r\n state = \"\",\r\n },\r\n ref,\r\n ) => {\r\n const ctx = useContext(ThemeContext);\r\n if (!ctx)\r\n throw new Error(\"ThemeContext is undefined. Wrap with ThemeProvider.\");\r\n\r\n const { selectedScheme, setSelectedScheme, schemes } = ctx;\r\n\r\n const options = useMemo(\r\n () =>\r\n schemes.map((scheme, index) => ({\r\n value: String(index),\r\n label: scheme.name,\r\n })),\r\n [schemes],\r\n );\r\n\r\n return (\r\n <div className=\"control-container\">\r\n <Select\r\n ref={ref}\r\n theme={theme}\r\n state={state}\r\n shadow={shadow}\r\n rounding={rounding}\r\n options={options}\r\n data-testid={testId}\r\n value={String(selectedScheme)}\r\n aria-label=\"Select Theme\"\r\n onChange={(value: string | number) =>\r\n setSelectedScheme(parseInt(String(value), 10))\r\n }\r\n />\r\n </div>\r\n );\r\n },\r\n);\r\nUserThemeSettings.displayName = \"UserThemeSettings\";\r\nexport default UserThemeSettings;\r\n","import React from \"react\";\r\nimport FooterBase from \"../FooterBase\";\r\nimport { FooterProps } from \"../Footer.types\";\r\nimport IconButton from \"../../IconButton/core/IconButton\";\r\nimport ThemeSelect from \"../../Select/ThemeSelect/core/ThemeSelect\";\r\nimport \"./Footer.scss\";\r\n\r\nconst classes = {\r\n footer: \"footer\",\r\n\r\n primary: \"footer_primary\",\r\n secondary: \"footer_secondary\",\r\n tertiary: \"footer_tertiary\",\r\n quaternary: \"footer_quaternary\",\r\n clear: \"footer_clear\",\r\n\r\n shadowNone: \"footer_shadow-None\",\r\n shadowLight: \"footer_shadow-Light\",\r\n shadowMedium: \"footer_shadow-Medium\",\r\n shadowStrong: \"footer_shadow-Strong\",\r\n shadowIntense: \"footer_shadow-Intense\",\r\n\r\n roundNone: \"footer_round-None\",\r\n roundSmall: \"footer_round-Small\",\r\n roundMedium: \"footer_round-Medium\",\r\n roundLarge: \"footer_round-Large\",\r\n\r\n attachmentStatic: \"footer_attachment-static\",\r\n attachmentFixed: \"footer_attachment-fixed\",\r\n attachmentSticky: \"footer_attachment-sticky\",\r\n\r\n content: \"footer_content\",\r\n logo: \"footer_logo\",\r\n left: \"footer_left\",\r\n links: \"footer_links\",\r\n link: \"footer_link\",\r\n social: \"footer_social\",\r\n\r\n themeToggle: \"footer_theme_toggle\",\r\n};\r\n\r\nconst Footer: React.FC<FooterProps> = (props) => {\r\n return (\r\n <FooterBase\r\n {...props}\r\n IconButton={IconButton}\r\n ThemeSelect={ThemeSelect}\r\n classMap={classes}\r\n />\r\n );\r\n};\r\nFooter.displayName = \"Footer\";\r\nexport default Footer;\r\n"],"names":["IconButton","rest","ThemeSelect"],"mappings":"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"}
@@ -6,7 +6,7 @@ const borealStyleConfig = require("./boreal-style-config-C1UIwOFN.cjs");
6
6
  const capitalize = require("./capitalize-DoV-nOmN.cjs");
7
7
  const IconButton = require("./IconButton-CFSu6aoV.cjs");
8
8
  const Select = require("./Select-BAv-TDRc.cjs");
9
- const ThemeContext = require("./ThemeContext-B42x9yzg.cjs");
9
+ const ThemeContext = require("./ThemeContext-AHk5GZwb.cjs");
10
10
  const FooterBase = ({
11
11
  theme = borealStyleConfig.getDefaultTheme(),
12
12
  attachment = "static",
@@ -24,7 +24,6 @@ const FooterBase = ({
24
24
  ThemeSelect,
25
25
  classMap,
26
26
  LinkWrapper = ({ href, children, ...rest2 }) => /* @__PURE__ */ jsxRuntime.jsx("a", { href, ...rest2, children }),
27
- // New accessibility props
28
27
  "aria-label": ariaLabel,
29
28
  "aria-labelledby": ariaLabelledBy,
30
29
  "aria-describedby": ariaDescribedBy,
@@ -34,7 +33,6 @@ const FooterBase = ({
34
33
  logoAriaLabel = "Logo",
35
34
  logoDecorative = false,
36
35
  labelId,
37
- // Pass-through HTML props
38
36
  ...rest
39
37
  }) => {
40
38
  const footerClass = React.useMemo(
@@ -270,4 +268,4 @@ const Footer = (props) => {
270
268
  Footer.displayName = "Footer";
271
269
  exports.Footer = Footer;
272
270
  exports.UserThemeSettings = UserThemeSettings;
273
- //# sourceMappingURL=Footer-CGTDSN42.cjs.map
271
+ //# sourceMappingURL=Footer-CBtuZduq.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Footer-CBtuZduq.cjs","sources":["../../src/components/Footer/FooterBase.tsx","../../src/components/Select/ThemeSelect/core/ThemeSelect.tsx","../../src/components/Footer/core/Footer.tsx"],"sourcesContent":["import React, { useMemo } from \"react\";\r\nimport { BaseFooterProps, LogoSource } from \"./Footer.types\";\r\nimport { combineClassNames } from \"../../utils/classNames\";\r\nimport { getDefaultTheme } from \"../../config/boreal-style-config\";\r\nimport { capitalize } from \"@/utils/capitalize\";\r\n\r\nconst FooterBase: React.FC<BaseFooterProps> = ({\r\n theme = getDefaultTheme(),\r\n attachment = \"static\",\r\n shadow = \"none\",\r\n rounding = \"none\",\r\n className = \"\",\r\n \"data-testid\": testId = \"footer\",\r\n copyright,\r\n links = [],\r\n logo,\r\n socialLinks = [],\r\n showThemeSelect = false,\r\n IconButton,\r\n ImageComponent = \"img\",\r\n ThemeSelect,\r\n classMap,\r\n LinkWrapper = ({ href, children, ...rest }) => (\r\n <a href={href} {...rest}>\r\n {children}\r\n </a>\r\n ),\r\n \"aria-label\": ariaLabel,\r\n \"aria-labelledby\": ariaLabelledBy,\r\n \"aria-describedby\": ariaDescribedBy,\r\n navAriaLabel = \"Footer site links\",\r\n socialNavAriaLabel = \"Social media\",\r\n themeSelectAriaLabel = \"Theme selector\",\r\n logoAriaLabel = \"Logo\",\r\n logoDecorative = false,\r\n labelId,\r\n ...rest\r\n}) => {\r\n const footerClass = useMemo(\r\n () =>\r\n combineClassNames(\r\n classMap.footer,\r\n classMap[theme],\r\n shadow !== \"none\" && classMap[`shadow${capitalize(shadow)}`],\r\n rounding !== \"none\" && classMap[`round${capitalize(rounding)}`],\r\n classMap[`attachment${capitalize(attachment)}`],\r\n className,\r\n ),\r\n [classMap, theme, shadow, rounding, attachment, className],\r\n );\r\n\r\n const isLogoImage = (\r\n value: unknown,\r\n ): value is { src: string; width?: number; height?: number } =>\r\n typeof value === \"object\" &&\r\n value !== null &&\r\n \"src\" in (value as Record<string, unknown>);\r\n\r\n const isImgLike = typeof logo === \"string\" || isLogoImage(logo);\r\n\r\n const imgLogo = isImgLike\r\n ? typeof logo === \"string\"\r\n ? { src: logo }\r\n : logo\r\n : undefined;\r\n\r\n const logoSrc = imgLogo?.src;\r\n const logoW = imgLogo?.width ?? 20;\r\n const logoH = imgLogo?.height ?? 20;\r\n\r\n return (\r\n <footer\r\n className={footerClass}\r\n data-testid={testId}\r\n role=\"contentinfo\"\r\n aria-label={ariaLabel}\r\n aria-labelledby={ariaLabelledBy ?? labelId}\r\n aria-describedby={ariaDescribedBy}\r\n {...rest}\r\n >\r\n <div className={classMap.content}>\r\n <div className={classMap.left} data-testid={`${testId}-left`}>\r\n {isImgLike && logoSrc ? (\r\n typeof ImageComponent === \"string\" ? (\r\n <img\r\n className={classMap.logo}\r\n data-testid={`${testId}-logo`}\r\n loading=\"lazy\"\r\n src={logoSrc}\r\n alt={logoDecorative ? \"\" : logoAriaLabel}\r\n aria-hidden={logoDecorative ? true : undefined}\r\n height={logoH}\r\n width={logoW}\r\n />\r\n ) : (\r\n <ImageComponent\r\n className={classMap.logo}\r\n data-testid={`${testId}-logo`}\r\n src={logoSrc}\r\n alt={logoDecorative ? \"\" : logoAriaLabel}\r\n aria-hidden={logoDecorative ? true : undefined}\r\n height={logoH}\r\n width={logoW}\r\n />\r\n )\r\n ) : logo ? (\r\n <span\r\n className={classMap.logo}\r\n role={logoDecorative ? undefined : \"img\"}\r\n aria-label={logoDecorative ? undefined : logoAriaLabel}\r\n aria-hidden={logoDecorative ? true : undefined}\r\n data-testid={`${testId}-logo`}\r\n >\r\n {\r\n logo as Exclude<\r\n LogoSource,\r\n string | { src: string; width?: number; height?: number }\r\n >\r\n }\r\n </span>\r\n ) : null}\r\n\r\n {copyright && (\r\n <div\r\n className={classMap.copyright ?? classMap.left}\r\n data-testid={`${testId}-copyright`}\r\n >\r\n <p id={labelId}>{copyright}</p>\r\n </div>\r\n )}\r\n </div>\r\n\r\n {links.length > 0 && (\r\n <nav\r\n className={classMap.links}\r\n aria-label={navAriaLabel}\r\n data-testid={`${testId}-nav`}\r\n >\r\n <ul>\r\n {links.map((link, i) => {\r\n const slug = (link.label || link.href || `link-${i}`)\r\n .toLowerCase()\r\n .replace(/\\s+/g, \"-\");\r\n\r\n if (link.disabled) {\r\n return (\r\n <li key={`${link.href ?? slug}-${i}`}>\r\n <span\r\n className={classMap.link}\r\n data-testid={`${testId}-link-${slug}`}\r\n aria-disabled=\"true\"\r\n title={link.title}\r\n >\r\n {link.label}\r\n </span>\r\n </li>\r\n );\r\n }\r\n\r\n return (\r\n <li key={`${link.href ?? slug}-${i}`}>\r\n <LinkWrapper\r\n href={link.href}\r\n className={classMap.link}\r\n data-testid={`${testId}-link-${slug}`}\r\n aria-label={link[\"aria-label\"]}\r\n aria-current={link[\"aria-current\"]}\r\n title={link.title}\r\n rel={link.rel}\r\n target={link.target}\r\n >\r\n {link.label}\r\n </LinkWrapper>\r\n </li>\r\n );\r\n })}\r\n </ul>\r\n </nav>\r\n )}\r\n\r\n {showThemeSelect && (\r\n <div\r\n className={classMap.themeToggle}\r\n data-testid={`${testId}-theme-select`}\r\n aria-label={themeSelectAriaLabel}\r\n >\r\n <ThemeSelect\r\n theme=\"clear\"\r\n shadow=\"none\"\r\n aria-label={themeSelectAriaLabel}\r\n />\r\n </div>\r\n )}\r\n\r\n {socialLinks.length > 0 && (\r\n <nav\r\n className={classMap.social}\r\n aria-label={socialNavAriaLabel}\r\n data-testid={`${testId}-social`}\r\n >\r\n {socialLinks.map((social, index) => (\r\n <IconButton\r\n key={`${social.href ?? social.title}-${index}`}\r\n icon={social.icon}\r\n href={social.href}\r\n isExternal={social.isExternal ?? true}\r\n shadow=\"none\"\r\n aria-label={social[\"aria-label\"] ?? social.title}\r\n title={social.tooltip ?? social.title}\r\n theme=\"clear\"\r\n disabled={social.disabled}\r\n rel={social.rel}\r\n target={social.target}\r\n data-testid={`${testId}-social-${social.title\r\n .toLowerCase()\r\n .replace(/\\s+/g, \"-\")}`}\r\n />\r\n ))}\r\n </nav>\r\n )}\r\n </div>\r\n </footer>\r\n );\r\n};\r\n\r\nFooterBase.displayName = \"FooterBase\";\r\nexport default FooterBase;\r\n","import { useContext, useMemo, forwardRef } from \"react\";\r\nimport Select from \"../../core/Select\";\r\nimport { ThemeContext } from \"../../../../context/ThemeContext\";\r\nimport {\r\n getDefaultRounding,\r\n getDefaultShadow,\r\n getDefaultTheme,\r\n} from \"@/config/boreal-style-config\";\r\nimport { ThemeSelectProps } from \"../../Select.types\";\r\n\r\nconst UserThemeSettings = forwardRef<HTMLSelectElement, ThemeSelectProps>(\r\n (\r\n {\r\n theme = getDefaultTheme(),\r\n shadow = getDefaultShadow(),\r\n rounding = getDefaultRounding(),\r\n \"data-testid\": testId = \"theme-select\",\r\n state = \"\",\r\n },\r\n ref,\r\n ) => {\r\n const ctx = useContext(ThemeContext);\r\n if (!ctx)\r\n throw new Error(\"ThemeContext is undefined. Wrap with ThemeProvider.\");\r\n\r\n const { selectedScheme, setSelectedScheme, schemes } = ctx;\r\n\r\n const options = useMemo(\r\n () =>\r\n schemes.map((scheme, index) => ({\r\n value: String(index),\r\n label: scheme.name,\r\n })),\r\n [schemes],\r\n );\r\n\r\n return (\r\n <div className=\"control-container\">\r\n <Select\r\n ref={ref}\r\n theme={theme}\r\n state={state}\r\n shadow={shadow}\r\n rounding={rounding}\r\n options={options}\r\n data-testid={testId}\r\n value={String(selectedScheme)}\r\n aria-label=\"Select Theme\"\r\n onChange={(value: string | number) =>\r\n setSelectedScheme(parseInt(String(value), 10))\r\n }\r\n />\r\n </div>\r\n );\r\n },\r\n);\r\nUserThemeSettings.displayName = \"UserThemeSettings\";\r\nexport default UserThemeSettings;\r\n","import React from \"react\";\r\nimport FooterBase from \"../FooterBase\";\r\nimport { FooterProps } from \"../Footer.types\";\r\nimport IconButton from \"../../IconButton/core/IconButton\";\r\nimport ThemeSelect from \"../../Select/ThemeSelect/core/ThemeSelect\";\r\nimport \"./Footer.scss\";\r\n\r\nconst classes = {\r\n footer: \"footer\",\r\n\r\n primary: \"footer_primary\",\r\n secondary: \"footer_secondary\",\r\n tertiary: \"footer_tertiary\",\r\n quaternary: \"footer_quaternary\",\r\n clear: \"footer_clear\",\r\n\r\n shadowNone: \"footer_shadow-None\",\r\n shadowLight: \"footer_shadow-Light\",\r\n shadowMedium: \"footer_shadow-Medium\",\r\n shadowStrong: \"footer_shadow-Strong\",\r\n shadowIntense: \"footer_shadow-Intense\",\r\n\r\n roundNone: \"footer_round-None\",\r\n roundSmall: \"footer_round-Small\",\r\n roundMedium: \"footer_round-Medium\",\r\n roundLarge: \"footer_round-Large\",\r\n\r\n attachmentStatic: \"footer_attachment-static\",\r\n attachmentFixed: \"footer_attachment-fixed\",\r\n attachmentSticky: \"footer_attachment-sticky\",\r\n\r\n content: \"footer_content\",\r\n logo: \"footer_logo\",\r\n left: \"footer_left\",\r\n links: \"footer_links\",\r\n link: \"footer_link\",\r\n social: \"footer_social\",\r\n\r\n themeToggle: \"footer_theme_toggle\",\r\n};\r\n\r\nconst Footer: React.FC<FooterProps> = (props) => {\r\n return (\r\n <FooterBase\r\n {...props}\r\n IconButton={IconButton}\r\n ThemeSelect={ThemeSelect}\r\n classMap={classes}\r\n />\r\n );\r\n};\r\nFooter.displayName = \"Footer\";\r\nexport default Footer;\r\n"],"names":["getDefaultTheme","IconButton","rest","jsx","useMemo","combineClassNames","capitalize","jsxs","forwardRef","getDefaultShadow","getDefaultRounding","useContext","ThemeContext","Select","ThemeSelect"],"mappings":"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"}
@@ -1,4 +1,4 @@
1
1
  "use strict";
2
- const Footer = require("./Footer-CGTDSN42.cjs");
2
+ const Footer = require("./Footer-CBtuZduq.cjs");
3
3
  module.exports = Footer.Footer;
4
4
  //# sourceMappingURL=Footer.cjs.js.map
@@ -1,4 +1,4 @@
1
- import { F } from "./Footer-BVK-IScY.js";
1
+ import { F } from "./Footer-BI7Bwc-6.js";
2
2
  export {
3
3
  F as default
4
4
  };
@@ -1,12 +1,24 @@
1
1
  "use strict";
2
2
  const jsxRuntime = require("react/jsx-runtime");
3
3
  const React = require("react");
4
- const registerColorSheme = require("./registerColorSheme-nhYu5hbY.cjs");
5
4
  const borealStyleConfig = require("./boreal-style-config-C1UIwOFN.cjs");
5
+ const colorSchemes = require("./colorSchemes.cjs.js");
6
6
  const ThemeContext = React.createContext(
7
7
  void 0
8
8
  );
9
9
  const STORAGE_KEY = "boreal:selectedSchemeName";
10
+ function mergeSchemes(baseSchemes, customSchemes) {
11
+ const merged = [...baseSchemes];
12
+ for (const scheme of customSchemes) {
13
+ const index = merged.findIndex((s) => s.name === scheme.name);
14
+ if (index >= 0) {
15
+ merged[index] = scheme;
16
+ } else {
17
+ merged.push(scheme);
18
+ }
19
+ }
20
+ return merged;
21
+ }
10
22
  function shallowEqualByName(a, b) {
11
23
  if (a === b) return true;
12
24
  if (a.length !== b.length) return false;
@@ -22,9 +34,15 @@ function getSchemeIndexByName(schemes, name) {
22
34
  const ThemeProvider = ({
23
35
  children,
24
36
  customSchemes = [],
25
- initialSchemeName
37
+ initialSchemeName,
38
+ useOnlyCustomSchemes = false
26
39
  }) => {
27
- const [schemes, setSchemes] = React.useState(() => registerColorSheme.getAllColorSchemes());
40
+ const [schemes, setSchemes] = React.useState(() => {
41
+ if (useOnlyCustomSchemes) {
42
+ return [...customSchemes];
43
+ }
44
+ return mergeSchemes([...colorSchemes.defaultColorSchemes], customSchemes);
45
+ });
28
46
  const [selectedScheme, setSelectedScheme] = React.useState(0);
29
47
  const [hasResolvedInitialScheme, setHasResolvedInitialScheme] = React.useState(false);
30
48
  const customSchemesKey = React.useMemo(
@@ -32,15 +50,16 @@ const ThemeProvider = ({
32
50
  [customSchemes]
33
51
  );
34
52
  React.useEffect(() => {
53
+ let parsedCustomSchemes = [];
35
54
  try {
36
55
  const parsed = JSON.parse(customSchemesKey);
37
- if (Array.isArray(parsed) && parsed.length > 0) {
38
- registerColorSheme.registerColorScheme(parsed);
56
+ if (Array.isArray(parsed)) {
57
+ parsedCustomSchemes = parsed;
39
58
  }
40
59
  } catch {
41
60
  console.error("Failed to parse custom schemes");
42
61
  }
43
- const nextSchemes = registerColorSheme.getAllColorSchemes();
62
+ const nextSchemes = useOnlyCustomSchemes ? [...parsedCustomSchemes] : mergeSchemes([...colorSchemes.defaultColorSchemes], parsedCustomSchemes);
44
63
  setSchemes(
45
64
  (prev) => shallowEqualByName(prev, nextSchemes) ? prev : nextSchemes
46
65
  );
@@ -70,7 +89,7 @@ const ThemeProvider = ({
70
89
  }
71
90
  setSelectedScheme(nextIndex);
72
91
  setHasResolvedInitialScheme(true);
73
- }, [customSchemesKey, initialSchemeName]);
92
+ }, [customSchemesKey, initialSchemeName, useOnlyCustomSchemes]);
74
93
  React.useLayoutEffect(() => {
75
94
  if (!hasResolvedInitialScheme) return;
76
95
  const allSchemes = schemes;
@@ -220,4 +239,4 @@ const ThemeProvider = ({
220
239
  };
221
240
  exports.ThemeContext = ThemeContext;
222
241
  exports.ThemeProvider = ThemeProvider;
223
- //# sourceMappingURL=ThemeContext-B42x9yzg.cjs.map
242
+ //# sourceMappingURL=ThemeContext-AHk5GZwb.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ThemeContext-AHk5GZwb.cjs","sources":["../../src/context/ThemeContext.tsx"],"sourcesContent":["\"use client\";\r\nimport React, {\r\n createContext,\r\n useState,\r\n useEffect,\r\n useLayoutEffect,\r\n useMemo,\r\n} from \"react\";\r\nimport { getDefaultColorSchemeName } from \"../config/boreal-style-config\";\r\nimport { ThemeContextType, ThemeProviderProps } from \"./ThemeContext.types\";\r\nimport { defaultColorSchemes } from \"../styles/Themes\";\r\nimport { ColorScheme } from \"@/types\";\r\n\r\nexport const ThemeContext = createContext<ThemeContextType | undefined>(\r\n undefined,\r\n);\r\n\r\nconst STORAGE_KEY = \"boreal:selectedSchemeName\";\r\n\r\nfunction mergeSchemes(\r\n baseSchemes: ColorScheme[],\r\n customSchemes: ColorScheme[],\r\n): ColorScheme[] {\r\n const merged = [...baseSchemes];\r\n\r\n for (const scheme of customSchemes) {\r\n const index = merged.findIndex((s) => s.name === scheme.name);\r\n\r\n if (index >= 0) {\r\n merged[index] = scheme;\r\n } else {\r\n merged.push(scheme);\r\n }\r\n }\r\n\r\n return merged;\r\n}\r\n\r\nfunction shallowEqualByName(a: { name: string }[], b: { name: string }[]) {\r\n if (a === b) return true;\r\n if (a.length !== b.length) return false;\r\n for (let i = 0; i < a.length; i++) {\r\n if (a[i].name !== b[i].name) return false;\r\n }\r\n return true;\r\n}\r\n\r\nfunction getSchemeIndexByName(\r\n schemes: { name: string }[],\r\n name?: string | null,\r\n): number {\r\n if (!name) return -1;\r\n return schemes.findIndex((scheme) => scheme.name === name);\r\n}\r\n\r\nconst ThemeProvider: React.FC<ThemeProviderProps> = ({\r\n children,\r\n customSchemes = [],\r\n initialSchemeName,\r\n useOnlyCustomSchemes = false,\r\n}) => {\r\n const [schemes, setSchemes] = useState<ColorScheme[]>(() => {\r\n if (useOnlyCustomSchemes) {\r\n return [...customSchemes];\r\n }\r\n\r\n return mergeSchemes([...defaultColorSchemes], customSchemes);\r\n });\r\n const [selectedScheme, setSelectedScheme] = useState<number>(0);\r\n const [hasResolvedInitialScheme, setHasResolvedInitialScheme] =\r\n useState(false);\r\n\r\n const customSchemesKey = useMemo(\r\n () => JSON.stringify(customSchemes ?? []),\r\n [customSchemes],\r\n );\r\n\r\n useEffect(() => {\r\n let parsedCustomSchemes: ColorScheme[] = [];\r\n\r\n try {\r\n const parsed = JSON.parse(customSchemesKey);\r\n if (Array.isArray(parsed)) {\r\n parsedCustomSchemes = parsed;\r\n }\r\n } catch {\r\n console.error(\"Failed to parse custom schemes\");\r\n }\r\n\r\n const nextSchemes = useOnlyCustomSchemes\r\n ? [...parsedCustomSchemes]\r\n : mergeSchemes([...defaultColorSchemes], parsedCustomSchemes);\r\n\r\n setSchemes((prev) =>\r\n shallowEqualByName(prev, nextSchemes) ? prev : nextSchemes,\r\n );\r\n\r\n let nextIndex = 0;\r\n let savedName: string | null = null;\r\n\r\n if (typeof window !== \"undefined\") {\r\n try {\r\n savedName = localStorage.getItem(STORAGE_KEY);\r\n } catch {\r\n console.error(\"Failed to load saved theme name\");\r\n }\r\n }\r\n\r\n const savedIndex = getSchemeIndexByName(nextSchemes, savedName);\r\n const initialIndex = getSchemeIndexByName(nextSchemes, initialSchemeName);\r\n const defaultIndex = getSchemeIndexByName(\r\n nextSchemes,\r\n getDefaultColorSchemeName(),\r\n );\r\n\r\n if (initialIndex !== -1) {\r\n nextIndex = initialIndex;\r\n } else if (savedIndex !== -1) {\r\n nextIndex = savedIndex;\r\n } else if (defaultIndex !== -1) {\r\n nextIndex = defaultIndex;\r\n } else {\r\n nextIndex = 0;\r\n }\r\n\r\n setSelectedScheme(nextIndex);\r\n setHasResolvedInitialScheme(true);\r\n }, [customSchemesKey, initialSchemeName, useOnlyCustomSchemes]);\r\n\r\n useLayoutEffect(() => {\r\n if (!hasResolvedInitialScheme) return;\r\n\r\n const allSchemes = schemes;\r\n const fallbackIndex = getSchemeIndexByName(\r\n allSchemes,\r\n getDefaultColorSchemeName(),\r\n );\r\n\r\n const safeFallbackIndex = fallbackIndex !== -1 ? fallbackIndex : 0;\r\n\r\n const scheme = allSchemes[selectedScheme] ?? allSchemes[safeFallbackIndex];\r\n\r\n if (!scheme) return;\r\n\r\n const {\r\n primaryColor,\r\n secondaryColor,\r\n tertiaryColor,\r\n quaternaryColor,\r\n backgroundColor,\r\n forceTextColor,\r\n } = scheme;\r\n\r\n const hexToHSL = (hex: string) => {\r\n const r = parseInt(hex.slice(1, 3), 16) / 255;\r\n const g = parseInt(hex.slice(3, 5), 16) / 255;\r\n const b = parseInt(hex.slice(5, 7), 16) / 255;\r\n const max = Math.max(r, g, b),\r\n min = Math.min(r, g, b);\r\n let h = 0,\r\n s = 0;\r\n const l = (max + min) / 2;\r\n if (max !== min) {\r\n const d = max - min;\r\n s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\r\n switch (max) {\r\n case r:\r\n h = (g - b) / d + (g < b ? 6 : 0);\r\n break;\r\n case g:\r\n h = (b - r) / d + 2;\r\n break;\r\n case b:\r\n h = (r - g) / d + 4;\r\n break;\r\n }\r\n h /= 6;\r\n }\r\n return {\r\n h: Math.round(h * 360),\r\n s: Math.round(s * 100),\r\n l: Math.round(l * 100),\r\n };\r\n };\r\n\r\n const hslToHex = (h: number, s: number, l: number): string => {\r\n s /= 100;\r\n l /= 100;\r\n const k = (n: number) => (n + h / 30) % 12;\r\n const a = s * Math.min(l, 1 - l);\r\n const f = (n: number) =>\r\n Math.round(\r\n 255 *\r\n (l - a * Math.max(-1, Math.min(k(n) - 3, Math.min(9 - k(n), 1)))),\r\n );\r\n return `#${[f(0), f(8), f(4)]\r\n .map((x) => x.toString(16).padStart(2, \"0\"))\r\n .join(\"\")}`;\r\n };\r\n\r\n const adjustLightness = (hex: string, percent: number): string => {\r\n const { h, s, l } = hexToHSL(hex);\r\n return hslToHex(h, s, Math.min(100, Math.max(0, l + percent)));\r\n };\r\n\r\n const relativeLuminance = (hex: string): number => {\r\n const rgb = [1, 3, 5].map((i) => {\r\n const c = parseInt(hex.slice(i, i + 2), 16) / 255;\r\n return c <= 0.03928 ? c / 12.92 : Math.pow((c + 0.055) / 1.055, 2.4);\r\n });\r\n return 0.2126 * rgb[0] + 0.7152 * rgb[1] + 0.0722 * rgb[2];\r\n };\r\n\r\n const contrastRatio = (a: string, b: string): number => {\r\n const lum1 = relativeLuminance(a);\r\n const lum2 = relativeLuminance(b);\r\n const lighter = Math.max(lum1, lum2);\r\n const darker = Math.min(lum1, lum2);\r\n return (lighter + 0.05) / (darker + 0.05);\r\n };\r\n\r\n const getAccessibleTextColor = (bg: string): string =>\r\n contrastRatio(bg, \"#000000\") >= 4.5 ? \"#000000\" : \"#FFFFFF\";\r\n\r\n const getAdaptiveBorderColor = (\r\n backgroundHex: string,\r\n amountLight = 14,\r\n amountDark = 14,\r\n ): string => {\r\n const { h, s, l } = hexToHSL(backgroundHex);\r\n\r\n const nextLightness =\r\n l >= 50 ? Math.max(0, l - amountDark) : Math.min(100, l + amountLight);\r\n\r\n const nextSaturation = s > 8 ? Math.max(0, s - 8) : s;\r\n\r\n return hslToHex(h, nextSaturation, nextLightness);\r\n };\r\n\r\n const vars = {\r\n \"--primary-color\": primaryColor,\r\n \"--primary-color-light\": adjustLightness(primaryColor, 10),\r\n \"--primary-color-hover\": adjustLightness(primaryColor, -10),\r\n \"--text-color-primary\":\r\n forceTextColor ?? getAccessibleTextColor(primaryColor),\r\n \"--text-color-primary-contrast\":\r\n forceTextColor ?? getAccessibleTextColor(backgroundColor),\r\n \"--text-color\": getAccessibleTextColor(backgroundColor),\r\n \"--text-color-light\": adjustLightness(\r\n getAccessibleTextColor(backgroundColor),\r\n 20,\r\n ),\r\n \"--text-color-lighter\": adjustLightness(\r\n getAccessibleTextColor(backgroundColor),\r\n 40,\r\n ),\r\n \"--secondary-color\": secondaryColor,\r\n \"--secondary-color-light\": adjustLightness(secondaryColor, 10),\r\n \"--secondary-color-hover\": adjustLightness(secondaryColor, -10),\r\n \"--text-color-secondary\": getAccessibleTextColor(secondaryColor),\r\n \"--tertiary-color\": tertiaryColor,\r\n \"--tertiary-color-light\": adjustLightness(tertiaryColor, 10),\r\n \"--tertiary-color-hover\": adjustLightness(tertiaryColor, -10),\r\n \"--text-color-tertiary\": getAccessibleTextColor(tertiaryColor),\r\n \"--quaternary-color\": quaternaryColor,\r\n \"--quaternary-color-light\": adjustLightness(quaternaryColor, 10),\r\n \"--quaternary-color-hover\": adjustLightness(quaternaryColor, -10),\r\n \"--text-color-quaternary\": getAccessibleTextColor(quaternaryColor),\r\n \"--background-color\": backgroundColor,\r\n \"--background-color-dark\": adjustLightness(backgroundColor, -10),\r\n \"--background-color-darker\": adjustLightness(backgroundColor, -25),\r\n \"--background-color-light\": adjustLightness(backgroundColor, 10),\r\n \"--background-color-lighter\": adjustLightness(backgroundColor, 20),\r\n \"--link-color\": getAccessibleTextColor(backgroundColor),\r\n \"--link-hover-color\": adjustLightness(\r\n getAccessibleTextColor(backgroundColor),\r\n -20,\r\n ),\r\n \"--link-hover-color-primary\": adjustLightness(primaryColor, -10),\r\n \"--link-hover-color-secondary\": adjustLightness(secondaryColor, -10),\r\n \"--link-hover-color-tertiary\": adjustLightness(tertiaryColor, -10),\r\n \"--link-hover-color-quaternary\": adjustLightness(quaternaryColor, -10),\r\n \"--focus-outline-color\": getAccessibleTextColor(backgroundColor),\r\n \"--divider-color\": getAdaptiveBorderColor(backgroundColor),\r\n \"--border-color\": getAdaptiveBorderColor(backgroundColor),\r\n \"--border-color-subtle\": getAdaptiveBorderColor(backgroundColor, 10, 10),\r\n \"--border-color-strong\": getAdaptiveBorderColor(backgroundColor, 20, 20),\r\n } as const;\r\n\r\n const rootStyle = document.documentElement.style;\r\n for (const [k, v] of Object.entries(vars)) {\r\n rootStyle.setProperty(k, v);\r\n }\r\n\r\n try {\r\n localStorage.setItem(STORAGE_KEY, scheme.name);\r\n } catch {\r\n console.error(\"Failed to save theme name\");\r\n }\r\n }, [selectedScheme, schemes, hasResolvedInitialScheme]);\r\n\r\n return (\r\n <ThemeContext.Provider\r\n value={{ selectedScheme, setSelectedScheme, schemes }}\r\n >\r\n {children}\r\n </ThemeContext.Provider>\r\n );\r\n};\r\n\r\nexport default ThemeProvider;\r\n"],"names":["createContext","useState","defaultColorSchemes","useMemo","useEffect","getDefaultColorSchemeName","useLayoutEffect","jsx"],"mappings":"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"}
@@ -1,11 +1,23 @@
1
1
  import { jsx } from "react/jsx-runtime";
2
2
  import { createContext, useState, useMemo, useEffect, useLayoutEffect } from "react";
3
- import { g as getAllColorSchemes, r as registerColorScheme } from "./registerColorSheme-BPX0H7hl.js";
4
3
  import { g as getDefaultColorSchemeName } from "./boreal-style-config-DsaRlxmw.js";
4
+ import { defaultColorSchemes } from "./colorSchemes.js";
5
5
  const ThemeContext = createContext(
6
6
  void 0
7
7
  );
8
8
  const STORAGE_KEY = "boreal:selectedSchemeName";
9
+ function mergeSchemes(baseSchemes, customSchemes) {
10
+ const merged = [...baseSchemes];
11
+ for (const scheme of customSchemes) {
12
+ const index = merged.findIndex((s) => s.name === scheme.name);
13
+ if (index >= 0) {
14
+ merged[index] = scheme;
15
+ } else {
16
+ merged.push(scheme);
17
+ }
18
+ }
19
+ return merged;
20
+ }
9
21
  function shallowEqualByName(a, b) {
10
22
  if (a === b) return true;
11
23
  if (a.length !== b.length) return false;
@@ -21,9 +33,15 @@ function getSchemeIndexByName(schemes, name) {
21
33
  const ThemeProvider = ({
22
34
  children,
23
35
  customSchemes = [],
24
- initialSchemeName
36
+ initialSchemeName,
37
+ useOnlyCustomSchemes = false
25
38
  }) => {
26
- const [schemes, setSchemes] = useState(() => getAllColorSchemes());
39
+ const [schemes, setSchemes] = useState(() => {
40
+ if (useOnlyCustomSchemes) {
41
+ return [...customSchemes];
42
+ }
43
+ return mergeSchemes([...defaultColorSchemes], customSchemes);
44
+ });
27
45
  const [selectedScheme, setSelectedScheme] = useState(0);
28
46
  const [hasResolvedInitialScheme, setHasResolvedInitialScheme] = useState(false);
29
47
  const customSchemesKey = useMemo(
@@ -31,15 +49,16 @@ const ThemeProvider = ({
31
49
  [customSchemes]
32
50
  );
33
51
  useEffect(() => {
52
+ let parsedCustomSchemes = [];
34
53
  try {
35
54
  const parsed = JSON.parse(customSchemesKey);
36
- if (Array.isArray(parsed) && parsed.length > 0) {
37
- registerColorScheme(parsed);
55
+ if (Array.isArray(parsed)) {
56
+ parsedCustomSchemes = parsed;
38
57
  }
39
58
  } catch {
40
59
  console.error("Failed to parse custom schemes");
41
60
  }
42
- const nextSchemes = getAllColorSchemes();
61
+ const nextSchemes = useOnlyCustomSchemes ? [...parsedCustomSchemes] : mergeSchemes([...defaultColorSchemes], parsedCustomSchemes);
43
62
  setSchemes(
44
63
  (prev) => shallowEqualByName(prev, nextSchemes) ? prev : nextSchemes
45
64
  );
@@ -69,7 +88,7 @@ const ThemeProvider = ({
69
88
  }
70
89
  setSelectedScheme(nextIndex);
71
90
  setHasResolvedInitialScheme(true);
72
- }, [customSchemesKey, initialSchemeName]);
91
+ }, [customSchemesKey, initialSchemeName, useOnlyCustomSchemes]);
73
92
  useLayoutEffect(() => {
74
93
  if (!hasResolvedInitialScheme) return;
75
94
  const allSchemes = schemes;
@@ -221,4 +240,4 @@ export {
221
240
  ThemeContext as T,
222
241
  ThemeProvider as a
223
242
  };
224
- //# sourceMappingURL=ThemeContext-B8DW9Nt1.js.map
243
+ //# sourceMappingURL=ThemeContext-C7iPDzb0.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ThemeContext-C7iPDzb0.js","sources":["../../src/context/ThemeContext.tsx"],"sourcesContent":["\"use client\";\r\nimport React, {\r\n createContext,\r\n useState,\r\n useEffect,\r\n useLayoutEffect,\r\n useMemo,\r\n} from \"react\";\r\nimport { getDefaultColorSchemeName } from \"../config/boreal-style-config\";\r\nimport { ThemeContextType, ThemeProviderProps } from \"./ThemeContext.types\";\r\nimport { defaultColorSchemes } from \"../styles/Themes\";\r\nimport { ColorScheme } from \"@/types\";\r\n\r\nexport const ThemeContext = createContext<ThemeContextType | undefined>(\r\n undefined,\r\n);\r\n\r\nconst STORAGE_KEY = \"boreal:selectedSchemeName\";\r\n\r\nfunction mergeSchemes(\r\n baseSchemes: ColorScheme[],\r\n customSchemes: ColorScheme[],\r\n): ColorScheme[] {\r\n const merged = [...baseSchemes];\r\n\r\n for (const scheme of customSchemes) {\r\n const index = merged.findIndex((s) => s.name === scheme.name);\r\n\r\n if (index >= 0) {\r\n merged[index] = scheme;\r\n } else {\r\n merged.push(scheme);\r\n }\r\n }\r\n\r\n return merged;\r\n}\r\n\r\nfunction shallowEqualByName(a: { name: string }[], b: { name: string }[]) {\r\n if (a === b) return true;\r\n if (a.length !== b.length) return false;\r\n for (let i = 0; i < a.length; i++) {\r\n if (a[i].name !== b[i].name) return false;\r\n }\r\n return true;\r\n}\r\n\r\nfunction getSchemeIndexByName(\r\n schemes: { name: string }[],\r\n name?: string | null,\r\n): number {\r\n if (!name) return -1;\r\n return schemes.findIndex((scheme) => scheme.name === name);\r\n}\r\n\r\nconst ThemeProvider: React.FC<ThemeProviderProps> = ({\r\n children,\r\n customSchemes = [],\r\n initialSchemeName,\r\n useOnlyCustomSchemes = false,\r\n}) => {\r\n const [schemes, setSchemes] = useState<ColorScheme[]>(() => {\r\n if (useOnlyCustomSchemes) {\r\n return [...customSchemes];\r\n }\r\n\r\n return mergeSchemes([...defaultColorSchemes], customSchemes);\r\n });\r\n const [selectedScheme, setSelectedScheme] = useState<number>(0);\r\n const [hasResolvedInitialScheme, setHasResolvedInitialScheme] =\r\n useState(false);\r\n\r\n const customSchemesKey = useMemo(\r\n () => JSON.stringify(customSchemes ?? []),\r\n [customSchemes],\r\n );\r\n\r\n useEffect(() => {\r\n let parsedCustomSchemes: ColorScheme[] = [];\r\n\r\n try {\r\n const parsed = JSON.parse(customSchemesKey);\r\n if (Array.isArray(parsed)) {\r\n parsedCustomSchemes = parsed;\r\n }\r\n } catch {\r\n console.error(\"Failed to parse custom schemes\");\r\n }\r\n\r\n const nextSchemes = useOnlyCustomSchemes\r\n ? [...parsedCustomSchemes]\r\n : mergeSchemes([...defaultColorSchemes], parsedCustomSchemes);\r\n\r\n setSchemes((prev) =>\r\n shallowEqualByName(prev, nextSchemes) ? prev : nextSchemes,\r\n );\r\n\r\n let nextIndex = 0;\r\n let savedName: string | null = null;\r\n\r\n if (typeof window !== \"undefined\") {\r\n try {\r\n savedName = localStorage.getItem(STORAGE_KEY);\r\n } catch {\r\n console.error(\"Failed to load saved theme name\");\r\n }\r\n }\r\n\r\n const savedIndex = getSchemeIndexByName(nextSchemes, savedName);\r\n const initialIndex = getSchemeIndexByName(nextSchemes, initialSchemeName);\r\n const defaultIndex = getSchemeIndexByName(\r\n nextSchemes,\r\n getDefaultColorSchemeName(),\r\n );\r\n\r\n if (initialIndex !== -1) {\r\n nextIndex = initialIndex;\r\n } else if (savedIndex !== -1) {\r\n nextIndex = savedIndex;\r\n } else if (defaultIndex !== -1) {\r\n nextIndex = defaultIndex;\r\n } else {\r\n nextIndex = 0;\r\n }\r\n\r\n setSelectedScheme(nextIndex);\r\n setHasResolvedInitialScheme(true);\r\n }, [customSchemesKey, initialSchemeName, useOnlyCustomSchemes]);\r\n\r\n useLayoutEffect(() => {\r\n if (!hasResolvedInitialScheme) return;\r\n\r\n const allSchemes = schemes;\r\n const fallbackIndex = getSchemeIndexByName(\r\n allSchemes,\r\n getDefaultColorSchemeName(),\r\n );\r\n\r\n const safeFallbackIndex = fallbackIndex !== -1 ? fallbackIndex : 0;\r\n\r\n const scheme = allSchemes[selectedScheme] ?? allSchemes[safeFallbackIndex];\r\n\r\n if (!scheme) return;\r\n\r\n const {\r\n primaryColor,\r\n secondaryColor,\r\n tertiaryColor,\r\n quaternaryColor,\r\n backgroundColor,\r\n forceTextColor,\r\n } = scheme;\r\n\r\n const hexToHSL = (hex: string) => {\r\n const r = parseInt(hex.slice(1, 3), 16) / 255;\r\n const g = parseInt(hex.slice(3, 5), 16) / 255;\r\n const b = parseInt(hex.slice(5, 7), 16) / 255;\r\n const max = Math.max(r, g, b),\r\n min = Math.min(r, g, b);\r\n let h = 0,\r\n s = 0;\r\n const l = (max + min) / 2;\r\n if (max !== min) {\r\n const d = max - min;\r\n s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\r\n switch (max) {\r\n case r:\r\n h = (g - b) / d + (g < b ? 6 : 0);\r\n break;\r\n case g:\r\n h = (b - r) / d + 2;\r\n break;\r\n case b:\r\n h = (r - g) / d + 4;\r\n break;\r\n }\r\n h /= 6;\r\n }\r\n return {\r\n h: Math.round(h * 360),\r\n s: Math.round(s * 100),\r\n l: Math.round(l * 100),\r\n };\r\n };\r\n\r\n const hslToHex = (h: number, s: number, l: number): string => {\r\n s /= 100;\r\n l /= 100;\r\n const k = (n: number) => (n + h / 30) % 12;\r\n const a = s * Math.min(l, 1 - l);\r\n const f = (n: number) =>\r\n Math.round(\r\n 255 *\r\n (l - a * Math.max(-1, Math.min(k(n) - 3, Math.min(9 - k(n), 1)))),\r\n );\r\n return `#${[f(0), f(8), f(4)]\r\n .map((x) => x.toString(16).padStart(2, \"0\"))\r\n .join(\"\")}`;\r\n };\r\n\r\n const adjustLightness = (hex: string, percent: number): string => {\r\n const { h, s, l } = hexToHSL(hex);\r\n return hslToHex(h, s, Math.min(100, Math.max(0, l + percent)));\r\n };\r\n\r\n const relativeLuminance = (hex: string): number => {\r\n const rgb = [1, 3, 5].map((i) => {\r\n const c = parseInt(hex.slice(i, i + 2), 16) / 255;\r\n return c <= 0.03928 ? c / 12.92 : Math.pow((c + 0.055) / 1.055, 2.4);\r\n });\r\n return 0.2126 * rgb[0] + 0.7152 * rgb[1] + 0.0722 * rgb[2];\r\n };\r\n\r\n const contrastRatio = (a: string, b: string): number => {\r\n const lum1 = relativeLuminance(a);\r\n const lum2 = relativeLuminance(b);\r\n const lighter = Math.max(lum1, lum2);\r\n const darker = Math.min(lum1, lum2);\r\n return (lighter + 0.05) / (darker + 0.05);\r\n };\r\n\r\n const getAccessibleTextColor = (bg: string): string =>\r\n contrastRatio(bg, \"#000000\") >= 4.5 ? \"#000000\" : \"#FFFFFF\";\r\n\r\n const getAdaptiveBorderColor = (\r\n backgroundHex: string,\r\n amountLight = 14,\r\n amountDark = 14,\r\n ): string => {\r\n const { h, s, l } = hexToHSL(backgroundHex);\r\n\r\n const nextLightness =\r\n l >= 50 ? Math.max(0, l - amountDark) : Math.min(100, l + amountLight);\r\n\r\n const nextSaturation = s > 8 ? Math.max(0, s - 8) : s;\r\n\r\n return hslToHex(h, nextSaturation, nextLightness);\r\n };\r\n\r\n const vars = {\r\n \"--primary-color\": primaryColor,\r\n \"--primary-color-light\": adjustLightness(primaryColor, 10),\r\n \"--primary-color-hover\": adjustLightness(primaryColor, -10),\r\n \"--text-color-primary\":\r\n forceTextColor ?? getAccessibleTextColor(primaryColor),\r\n \"--text-color-primary-contrast\":\r\n forceTextColor ?? getAccessibleTextColor(backgroundColor),\r\n \"--text-color\": getAccessibleTextColor(backgroundColor),\r\n \"--text-color-light\": adjustLightness(\r\n getAccessibleTextColor(backgroundColor),\r\n 20,\r\n ),\r\n \"--text-color-lighter\": adjustLightness(\r\n getAccessibleTextColor(backgroundColor),\r\n 40,\r\n ),\r\n \"--secondary-color\": secondaryColor,\r\n \"--secondary-color-light\": adjustLightness(secondaryColor, 10),\r\n \"--secondary-color-hover\": adjustLightness(secondaryColor, -10),\r\n \"--text-color-secondary\": getAccessibleTextColor(secondaryColor),\r\n \"--tertiary-color\": tertiaryColor,\r\n \"--tertiary-color-light\": adjustLightness(tertiaryColor, 10),\r\n \"--tertiary-color-hover\": adjustLightness(tertiaryColor, -10),\r\n \"--text-color-tertiary\": getAccessibleTextColor(tertiaryColor),\r\n \"--quaternary-color\": quaternaryColor,\r\n \"--quaternary-color-light\": adjustLightness(quaternaryColor, 10),\r\n \"--quaternary-color-hover\": adjustLightness(quaternaryColor, -10),\r\n \"--text-color-quaternary\": getAccessibleTextColor(quaternaryColor),\r\n \"--background-color\": backgroundColor,\r\n \"--background-color-dark\": adjustLightness(backgroundColor, -10),\r\n \"--background-color-darker\": adjustLightness(backgroundColor, -25),\r\n \"--background-color-light\": adjustLightness(backgroundColor, 10),\r\n \"--background-color-lighter\": adjustLightness(backgroundColor, 20),\r\n \"--link-color\": getAccessibleTextColor(backgroundColor),\r\n \"--link-hover-color\": adjustLightness(\r\n getAccessibleTextColor(backgroundColor),\r\n -20,\r\n ),\r\n \"--link-hover-color-primary\": adjustLightness(primaryColor, -10),\r\n \"--link-hover-color-secondary\": adjustLightness(secondaryColor, -10),\r\n \"--link-hover-color-tertiary\": adjustLightness(tertiaryColor, -10),\r\n \"--link-hover-color-quaternary\": adjustLightness(quaternaryColor, -10),\r\n \"--focus-outline-color\": getAccessibleTextColor(backgroundColor),\r\n \"--divider-color\": getAdaptiveBorderColor(backgroundColor),\r\n \"--border-color\": getAdaptiveBorderColor(backgroundColor),\r\n \"--border-color-subtle\": getAdaptiveBorderColor(backgroundColor, 10, 10),\r\n \"--border-color-strong\": getAdaptiveBorderColor(backgroundColor, 20, 20),\r\n } as const;\r\n\r\n const rootStyle = document.documentElement.style;\r\n for (const [k, v] of Object.entries(vars)) {\r\n rootStyle.setProperty(k, v);\r\n }\r\n\r\n try {\r\n localStorage.setItem(STORAGE_KEY, scheme.name);\r\n } catch {\r\n console.error(\"Failed to save theme name\");\r\n }\r\n }, [selectedScheme, schemes, hasResolvedInitialScheme]);\r\n\r\n return (\r\n <ThemeContext.Provider\r\n value={{ selectedScheme, setSelectedScheme, schemes }}\r\n >\r\n {children}\r\n </ThemeContext.Provider>\r\n );\r\n};\r\n\r\nexport default ThemeProvider;\r\n"],"names":[],"mappings":";;;;AAaO,MAAM,eAAe;AAAA,EAC1B;AACF;AAEA,MAAM,cAAc;AAEpB,SAAS,aACP,aACA,eACe;AACf,QAAM,SAAS,CAAC,GAAG,WAAW;AAE9B,aAAW,UAAU,eAAe;AAClC,UAAM,QAAQ,OAAO,UAAU,CAAC,MAAM,EAAE,SAAS,OAAO,IAAI;AAE5D,QAAI,SAAS,GAAG;AACd,aAAO,KAAK,IAAI;AAAA,IAClB,OAAO;AACL,aAAO,KAAK,MAAM;AAAA,IACpB;AAAA,EACF;AAEA,SAAO;AACT;AAEA,SAAS,mBAAmB,GAAuB,GAAuB;AACxE,MAAI,MAAM,EAAG,QAAO;AACpB,MAAI,EAAE,WAAW,EAAE,OAAQ,QAAO;AAClC,WAAS,IAAI,GAAG,IAAI,EAAE,QAAQ,KAAK;AACjC,QAAI,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC,EAAE,KAAM,QAAO;AAAA,EACtC;AACA,SAAO;AACT;AAEA,SAAS,qBACP,SACA,MACQ;AACR,MAAI,CAAC,KAAM,QAAO;AAClB,SAAO,QAAQ,UAAU,CAAC,WAAW,OAAO,SAAS,IAAI;AAC3D;AAEA,MAAM,gBAA8C,CAAC;AAAA,EACnD;AAAA,EACA,gBAAgB,CAAA;AAAA,EAChB;AAAA,EACA,uBAAuB;AACzB,MAAM;AACJ,QAAM,CAAC,SAAS,UAAU,IAAI,SAAwB,MAAM;AAC1D,QAAI,sBAAsB;AACxB,aAAO,CAAC,GAAG,aAAa;AAAA,IAC1B;AAEA,WAAO,aAAa,CAAC,GAAG,mBAAmB,GAAG,aAAa;AAAA,EAC7D,CAAC;AACD,QAAM,CAAC,gBAAgB,iBAAiB,IAAI,SAAiB,CAAC;AAC9D,QAAM,CAAC,0BAA0B,2BAA2B,IAC1D,SAAS,KAAK;AAEhB,QAAM,mBAAmB;AAAA,IACvB,MAAM,KAAK,UAAU,iBAAiB,EAAE;AAAA,IACxC,CAAC,aAAa;AAAA,EAAA;AAGhB,YAAU,MAAM;AACd,QAAI,sBAAqC,CAAA;AAEzC,QAAI;AACF,YAAM,SAAS,KAAK,MAAM,gBAAgB;AAC1C,UAAI,MAAM,QAAQ,MAAM,GAAG;AACzB,8BAAsB;AAAA,MACxB;AAAA,IACF,QAAQ;AACN,cAAQ,MAAM,gCAAgC;AAAA,IAChD;AAEA,UAAM,cAAc,uBAChB,CAAC,GAAG,mBAAmB,IACvB,aAAa,CAAC,GAAG,mBAAmB,GAAG,mBAAmB;AAE9D;AAAA,MAAW,CAAC,SACV,mBAAmB,MAAM,WAAW,IAAI,OAAO;AAAA,IAAA;AAGjD,QAAI,YAAY;AAChB,QAAI,YAA2B;AAE/B,QAAI,OAAO,WAAW,aAAa;AACjC,UAAI;AACF,oBAAY,aAAa,QAAQ,WAAW;AAAA,MAC9C,QAAQ;AACN,gBAAQ,MAAM,iCAAiC;AAAA,MACjD;AAAA,IACF;AAEA,UAAM,aAAa,qBAAqB,aAAa,SAAS;AAC9D,UAAM,eAAe,qBAAqB,aAAa,iBAAiB;AACxE,UAAM,eAAe;AAAA,MACnB;AAAA,MACA,0BAAA;AAAA,IAA0B;AAG5B,QAAI,iBAAiB,IAAI;AACvB,kBAAY;AAAA,IACd,WAAW,eAAe,IAAI;AAC5B,kBAAY;AAAA,IACd,WAAW,iBAAiB,IAAI;AAC9B,kBAAY;AAAA,IACd,OAAO;AACL,kBAAY;AAAA,IACd;AAEA,sBAAkB,SAAS;AAC3B,gCAA4B,IAAI;AAAA,EAClC,GAAG,CAAC,kBAAkB,mBAAmB,oBAAoB,CAAC;AAE9D,kBAAgB,MAAM;AACpB,QAAI,CAAC,yBAA0B;AAE/B,UAAM,aAAa;AACnB,UAAM,gBAAgB;AAAA,MACpB;AAAA,MACA,0BAAA;AAAA,IAA0B;AAG5B,UAAM,oBAAoB,kBAAkB,KAAK,gBAAgB;AAEjE,UAAM,SAAS,WAAW,cAAc,KAAK,WAAW,iBAAiB;AAEzE,QAAI,CAAC,OAAQ;AAEb,UAAM;AAAA,MACJ;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IAAA,IACE;AAEJ,UAAM,WAAW,CAAC,QAAgB;AAChC,YAAM,IAAI,SAAS,IAAI,MAAM,GAAG,CAAC,GAAG,EAAE,IAAI;AAC1C,YAAM,IAAI,SAAS,IAAI,MAAM,GAAG,CAAC,GAAG,EAAE,IAAI;AAC1C,YAAM,IAAI,SAAS,IAAI,MAAM,GAAG,CAAC,GAAG,EAAE,IAAI;AAC1C,YAAM,MAAM,KAAK,IAAI,GAAG,GAAG,CAAC,GAC1B,MAAM,KAAK,IAAI,GAAG,GAAG,CAAC;AACxB,UAAI,IAAI,GACN,IAAI;AACN,YAAM,KAAK,MAAM,OAAO;AACxB,UAAI,QAAQ,KAAK;AACf,cAAM,IAAI,MAAM;AAChB,YAAI,IAAI,MAAM,KAAK,IAAI,MAAM,OAAO,KAAK,MAAM;AAC/C,gBAAQ,KAAA;AAAA,UACN,KAAK;AACH,iBAAK,IAAI,KAAK,KAAK,IAAI,IAAI,IAAI;AAC/B;AAAA,UACF,KAAK;AACH,iBAAK,IAAI,KAAK,IAAI;AAClB;AAAA,UACF,KAAK;AACH,iBAAK,IAAI,KAAK,IAAI;AAClB;AAAA,QAAA;AAEJ,aAAK;AAAA,MACP;AACA,aAAO;AAAA,QACL,GAAG,KAAK,MAAM,IAAI,GAAG;AAAA,QACrB,GAAG,KAAK,MAAM,IAAI,GAAG;AAAA,QACrB,GAAG,KAAK,MAAM,IAAI,GAAG;AAAA,MAAA;AAAA,IAEzB;AAEA,UAAM,WAAW,CAAC,GAAW,GAAW,MAAsB;AAC5D,WAAK;AACL,WAAK;AACL,YAAM,IAAI,CAAC,OAAe,IAAI,IAAI,MAAM;AACxC,YAAM,IAAI,IAAI,KAAK,IAAI,GAAG,IAAI,CAAC;AAC/B,YAAM,IAAI,CAAC,MACT,KAAK;AAAA,QACH,OACG,IAAI,IAAI,KAAK,IAAI,IAAI,KAAK,IAAI,EAAE,CAAC,IAAI,GAAG,KAAK,IAAI,IAAI,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;AAAA,MAAA;AAErE,aAAO,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,CAAC,EACzB,IAAI,CAAC,MAAM,EAAE,SAAS,EAAE,EAAE,SAAS,GAAG,GAAG,CAAC,EAC1C,KAAK,EAAE,CAAC;AAAA,IACb;AAEA,UAAM,kBAAkB,CAAC,KAAa,YAA4B;AAChE,YAAM,EAAE,GAAG,GAAG,EAAA,IAAM,SAAS,GAAG;AAChC,aAAO,SAAS,GAAG,GAAG,KAAK,IAAI,KAAK,KAAK,IAAI,GAAG,IAAI,OAAO,CAAC,CAAC;AAAA,IAC/D;AAEA,UAAM,oBAAoB,CAAC,QAAwB;AACjD,YAAM,MAAM,CAAC,GAAG,GAAG,CAAC,EAAE,IAAI,CAAC,MAAM;AAC/B,cAAM,IAAI,SAAS,IAAI,MAAM,GAAG,IAAI,CAAC,GAAG,EAAE,IAAI;AAC9C,eAAO,KAAK,UAAU,IAAI,QAAQ,KAAK,KAAK,IAAI,SAAS,OAAO,GAAG;AAAA,MACrE,CAAC;AACD,aAAO,SAAS,IAAI,CAAC,IAAI,SAAS,IAAI,CAAC,IAAI,SAAS,IAAI,CAAC;AAAA,IAC3D;AAEA,UAAM,gBAAgB,CAAC,GAAW,MAAsB;AACtD,YAAM,OAAO,kBAAkB,CAAC;AAChC,YAAM,OAAO,kBAAkB,CAAC;AAChC,YAAM,UAAU,KAAK,IAAI,MAAM,IAAI;AACnC,YAAM,SAAS,KAAK,IAAI,MAAM,IAAI;AAClC,cAAQ,UAAU,SAAS,SAAS;AAAA,IACtC;AAEA,UAAM,yBAAyB,CAAC,OAC9B,cAAc,IAAI,SAAS,KAAK,MAAM,YAAY;AAEpD,UAAM,yBAAyB,CAC7B,eACA,cAAc,IACd,aAAa,OACF;AACX,YAAM,EAAE,GAAG,GAAG,EAAA,IAAM,SAAS,aAAa;AAE1C,YAAM,gBACJ,KAAK,KAAK,KAAK,IAAI,GAAG,IAAI,UAAU,IAAI,KAAK,IAAI,KAAK,IAAI,WAAW;AAEvE,YAAM,iBAAiB,IAAI,IAAI,KAAK,IAAI,GAAG,IAAI,CAAC,IAAI;AAEpD,aAAO,SAAS,GAAG,gBAAgB,aAAa;AAAA,IAClD;AAEA,UAAM,OAAO;AAAA,MACX,mBAAmB;AAAA,MACnB,yBAAyB,gBAAgB,cAAc,EAAE;AAAA,MACzD,yBAAyB,gBAAgB,cAAc,GAAG;AAAA,MAC1D,wBACE,kBAAkB,uBAAuB,YAAY;AAAA,MACvD,iCACE,kBAAkB,uBAAuB,eAAe;AAAA,MAC1D,gBAAgB,uBAAuB,eAAe;AAAA,MACtD,sBAAsB;AAAA,QACpB,uBAAuB,eAAe;AAAA,QACtC;AAAA,MAAA;AAAA,MAEF,wBAAwB;AAAA,QACtB,uBAAuB,eAAe;AAAA,QACtC;AAAA,MAAA;AAAA,MAEF,qBAAqB;AAAA,MACrB,2BAA2B,gBAAgB,gBAAgB,EAAE;AAAA,MAC7D,2BAA2B,gBAAgB,gBAAgB,GAAG;AAAA,MAC9D,0BAA0B,uBAAuB,cAAc;AAAA,MAC/D,oBAAoB;AAAA,MACpB,0BAA0B,gBAAgB,eAAe,EAAE;AAAA,MAC3D,0BAA0B,gBAAgB,eAAe,GAAG;AAAA,MAC5D,yBAAyB,uBAAuB,aAAa;AAAA,MAC7D,sBAAsB;AAAA,MACtB,4BAA4B,gBAAgB,iBAAiB,EAAE;AAAA,MAC/D,4BAA4B,gBAAgB,iBAAiB,GAAG;AAAA,MAChE,2BAA2B,uBAAuB,eAAe;AAAA,MACjE,sBAAsB;AAAA,MACtB,2BAA2B,gBAAgB,iBAAiB,GAAG;AAAA,MAC/D,6BAA6B,gBAAgB,iBAAiB,GAAG;AAAA,MACjE,4BAA4B,gBAAgB,iBAAiB,EAAE;AAAA,MAC/D,8BAA8B,gBAAgB,iBAAiB,EAAE;AAAA,MACjE,gBAAgB,uBAAuB,eAAe;AAAA,MACtD,sBAAsB;AAAA,QACpB,uBAAuB,eAAe;AAAA,QACtC;AAAA,MAAA;AAAA,MAEF,8BAA8B,gBAAgB,cAAc,GAAG;AAAA,MAC/D,gCAAgC,gBAAgB,gBAAgB,GAAG;AAAA,MACnE,+BAA+B,gBAAgB,eAAe,GAAG;AAAA,MACjE,iCAAiC,gBAAgB,iBAAiB,GAAG;AAAA,MACrE,yBAAyB,uBAAuB,eAAe;AAAA,MAC/D,mBAAmB,uBAAuB,eAAe;AAAA,MACzD,kBAAkB,uBAAuB,eAAe;AAAA,MACxD,yBAAyB,uBAAuB,iBAAiB,IAAI,EAAE;AAAA,MACvE,yBAAyB,uBAAuB,iBAAiB,IAAI,EAAE;AAAA,IAAA;AAGzE,UAAM,YAAY,SAAS,gBAAgB;AAC3C,eAAW,CAAC,GAAG,CAAC,KAAK,OAAO,QAAQ,IAAI,GAAG;AACzC,gBAAU,YAAY,GAAG,CAAC;AAAA,IAC5B;AAEA,QAAI;AACF,mBAAa,QAAQ,aAAa,OAAO,IAAI;AAAA,IAC/C,QAAQ;AACN,cAAQ,MAAM,2BAA2B;AAAA,IAC3C;AAAA,EACF,GAAG,CAAC,gBAAgB,SAAS,wBAAwB,CAAC;AAEtD,SACE;AAAA,IAAC,aAAa;AAAA,IAAb;AAAA,MACC,OAAO,EAAE,gBAAgB,mBAAmB,QAAA;AAAA,MAE3C;AAAA,IAAA;AAAA,EAAA;AAGP;"}
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const ThemeContext = require("./ThemeContext-B42x9yzg.cjs");
3
+ const ThemeContext = require("./ThemeContext-AHk5GZwb.cjs");
4
4
  exports.ThemeContext = ThemeContext.ThemeContext;
5
5
  exports.ThemeProvider = ThemeContext.ThemeProvider;
6
6
  //# sourceMappingURL=ThemeProvider.cjs.js.map
@@ -1,4 +1,4 @@
1
- import { T, a } from "./ThemeContext-B8DW9Nt1.js";
1
+ import { T, a } from "./ThemeContext-C7iPDzb0.js";
2
2
  export {
3
3
  T as ThemeContext,
4
4
  a as ThemeProvider
@@ -13,9 +13,11 @@ const ToolbarBase = ({
13
13
  right,
14
14
  avatar,
15
15
  theme = borealStyleConfig.getDefaultTheme(),
16
+ attachment = "static",
16
17
  shadow = borealStyleConfig.getDefaultShadow(),
17
18
  rounding = borealStyleConfig.getDefaultRounding(),
18
19
  className = "",
20
+ titleClassName = "",
19
21
  "data-testid": testId = "toolbar",
20
22
  "aria-label": ariaLabelProp,
21
23
  "aria-labelledby": ariaLabelledBy,
@@ -34,11 +36,12 @@ const ToolbarBase = ({
34
36
  () => classNames.combineClassNames(
35
37
  classMap.toolbar,
36
38
  classMap[theme],
39
+ classMap[attachment],
37
40
  className,
38
41
  shadow && classMap[`shadow${capitalize.capitalize(shadow)}`],
39
42
  rounding && classMap[`round${capitalize.capitalize(rounding)}`]
40
43
  ),
41
- [classMap, theme, className, shadow, rounding]
44
+ [classMap, theme, attachment, className, shadow, rounding]
42
45
  );
43
46
  const resolvedAriaLabel = ariaLabelledBy ? void 0 : ariaLabelProp ?? ariaLabel;
44
47
  const avatarAriaHidden = avatar && !avatar.name && !avatar.onClick && !avatar["aria-label"] ? true : void 0;
@@ -76,7 +79,7 @@ const ToolbarBase = ({
76
79
  TitleTag,
77
80
  {
78
81
  id: resolvedTitleId,
79
- className: classMap.title,
82
+ className: classNames.combineClassNames(classMap.title, titleClassName),
80
83
  "data-testid": `${testId}-title`,
81
84
  children: title
82
85
  }
@@ -125,6 +128,9 @@ const ToolbarBase = ({
125
128
  ToolbarBase.displayName = "ToolbarBase";
126
129
  const classes = {
127
130
  toolbar: "toolbar",
131
+ fixed: "toolbar_fixed",
132
+ sticky: "toolbar_sticky",
133
+ static: "toolbar_static",
128
134
  section: "toolbar_section",
129
135
  title: "toolbar_title",
130
136
  avatarWrapper: "toolbar_avatarWrapper",
@@ -146,4 +152,4 @@ const classes = {
146
152
  const Toolbar = (props) => /* @__PURE__ */ jsxRuntime.jsx(ToolbarBase, { ...props, AvatarComponent: Avatar.Avatar, classMap: classes });
147
153
  Toolbar.displayName = "Toolbar";
148
154
  exports.Toolbar = Toolbar;
149
- //# sourceMappingURL=Toolbar-Dz1rhlz_.cjs.map
155
+ //# sourceMappingURL=Toolbar-BUkKkXBz.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Toolbar-BUkKkXBz.cjs","sources":["../../src/components/Toolbar/ToolbarBase.tsx","../../src/components/Toolbar/core/Toolbar.tsx"],"sourcesContent":["import React, { JSX, useMemo } from \"react\";\r\nimport { combineClassNames } from \"../../utils/classNames\";\r\nimport { ToolbarBaseProps } from \"./Toolbar.types\";\r\nimport { capitalize } from \"../../utils/capitalize\";\r\nimport {\r\n getDefaultRounding,\r\n getDefaultShadow,\r\n getDefaultTheme,\r\n} from \"../../config/boreal-style-config\";\r\n\r\nconst ToolbarBase: React.FC<ToolbarBaseProps> = ({\r\n title,\r\n titleId,\r\n left,\r\n center,\r\n right,\r\n avatar,\r\n theme = getDefaultTheme(),\r\n attachment = \"static\",\r\n shadow = getDefaultShadow(),\r\n rounding = getDefaultRounding(),\r\n className = \"\",\r\n titleClassName = \"\",\r\n \"data-testid\": testId = \"toolbar\",\r\n \"aria-label\": ariaLabelProp,\r\n \"aria-labelledby\": ariaLabelledBy,\r\n \"aria-describedby\": ariaDescribedBy,\r\n leftAriaLabel = \"Toolbar left section\",\r\n centerAriaLabel = \"Toolbar center section\",\r\n rightAriaLabel = \"Toolbar right section\",\r\n AvatarComponent,\r\n classMap,\r\n \"aria-label\": ariaLabel = \"Toolbar\",\r\n headingLevel = 1,\r\n}): JSX.Element => {\r\n const safeHeading = Math.min(6, Math.max(1, headingLevel));\r\n const TitleTag = `h${safeHeading}` as keyof JSX.IntrinsicElements;\r\n\r\n const toolbarClass = useMemo(\r\n () =>\r\n combineClassNames(\r\n classMap.toolbar,\r\n classMap[theme],\r\n classMap[attachment],\r\n className,\r\n shadow && classMap[`shadow${capitalize(shadow)}`],\r\n rounding && classMap[`round${capitalize(rounding)}`],\r\n ),\r\n [classMap, theme, attachment, className, shadow, rounding],\r\n );\r\n\r\n const resolvedAriaLabel = ariaLabelledBy\r\n ? undefined\r\n : (ariaLabelProp ?? ariaLabel);\r\n\r\n const avatarAriaHidden =\r\n avatar && !avatar.name && !avatar.onClick && !avatar[\"aria-label\"]\r\n ? true\r\n : undefined;\r\n\r\n const resolvedTitleId = title ? (titleId ?? `${testId}-title`) : undefined;\r\n\r\n return (\r\n <div\r\n className={toolbarClass}\r\n role=\"toolbar\"\r\n aria-orientation=\"horizontal\"\r\n aria-label={resolvedAriaLabel}\r\n aria-labelledby={ariaLabelledBy}\r\n aria-describedby={ariaDescribedBy}\r\n data-testid={testId}\r\n >\r\n <div\r\n className={classMap.section}\r\n role=\"group\"\r\n aria-label={leftAriaLabel}\r\n data-testid={`${testId}-left`}\r\n >\r\n {left}\r\n </div>\r\n\r\n <div\r\n className={classMap.section}\r\n role=\"group\"\r\n aria-label={centerAriaLabel}\r\n data-testid={`${testId}-center`}\r\n >\r\n {title && (\r\n <TitleTag\r\n id={resolvedTitleId}\r\n className={combineClassNames(classMap.title, titleClassName)}\r\n data-testid={`${testId}-title`}\r\n >\r\n {title}\r\n </TitleTag>\r\n )}\r\n {center}\r\n </div>\r\n\r\n <div\r\n className={classMap.section}\r\n role=\"group\"\r\n aria-label={rightAriaLabel}\r\n data-testid={`${testId}-right`}\r\n >\r\n {right}\r\n {avatar && (\r\n <div\r\n className={classMap.avatarWrapper}\r\n data-testid={`${testId}-avatar`}\r\n >\r\n <AvatarComponent\r\n name={avatar.name}\r\n src={avatar.src}\r\n size={avatar.size || \"medium\"}\r\n shape={avatar.shape || \"circle\"}\r\n theme={avatar.theme}\r\n outline={avatar.outline}\r\n onClick={avatar.onClick}\r\n aria-label={avatar[\"aria-label\"]}\r\n aria-hidden={avatarAriaHidden}\r\n />\r\n </div>\r\n )}\r\n </div>\r\n </div>\r\n );\r\n};\r\n\r\nToolbarBase.displayName = \"ToolbarBase\";\r\nexport default ToolbarBase;\r\n","import React from \"react\";\r\nimport \"./Toolbar.scss\";\r\nimport Avatar from \"../../Avatar/core/Avatar\";\r\nimport ToolbarBase from \"../ToolbarBase\";\r\nimport { ToolbarProps } from \"../Toolbar.types\";\r\n\r\nconst classes = {\r\n toolbar: \"toolbar\",\r\n\r\n fixed: \"toolbar_fixed\",\r\n sticky: \"toolbar_sticky\",\r\n static: \"toolbar_static\",\r\n\r\n section: \"toolbar_section\",\r\n title: \"toolbar_title\",\r\n avatarWrapper: \"toolbar_avatarWrapper\",\r\n\r\n primary: \"toolbar_primary\",\r\n secondary: \"toolbar_secondary\",\r\n tertiary: \"toolbar_tertiary\",\r\n quaternary: \"toolbar_quaternary\",\r\n\r\n clear: \"toolbar_clear\",\r\n\r\n shadowNone: \"toolbar_shadow-None\",\r\n shadowLight: \"toolbar_shadow-Light\",\r\n shadowMedium: \"toolbar_shadow-Medium\",\r\n shadowStrong: \"toolbar_shadow-Strong\",\r\n shadowIntense: \"toolbar_shadow-Intense\",\r\n\r\n roundNone: \"toolbar_round-None\",\r\n roundSmall: \"toolbar_round-Small\",\r\n roundMedium: \"toolbar_round-Medium\",\r\n roundLarge: \"toolbar_round-Large\",\r\n};\r\n\r\nconst Toolbar: React.FC<ToolbarProps> = (props) => (\r\n <ToolbarBase {...props} AvatarComponent={Avatar} classMap={classes} />\r\n);\r\nToolbar.displayName = \"Toolbar\";\r\nexport default Toolbar;\r\n"],"names":["getDefaultTheme","getDefaultShadow","getDefaultRounding","useMemo","combineClassNames","capitalize","jsxs","jsx","Avatar"],"mappings":"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"}
@@ -12,9 +12,11 @@ import './Toolbar.css';const ToolbarBase = ({
12
12
  right,
13
13
  avatar,
14
14
  theme = getDefaultTheme(),
15
+ attachment = "static",
15
16
  shadow = getDefaultShadow(),
16
17
  rounding = getDefaultRounding(),
17
18
  className = "",
19
+ titleClassName = "",
18
20
  "data-testid": testId = "toolbar",
19
21
  "aria-label": ariaLabelProp,
20
22
  "aria-labelledby": ariaLabelledBy,
@@ -33,11 +35,12 @@ import './Toolbar.css';const ToolbarBase = ({
33
35
  () => combineClassNames(
34
36
  classMap.toolbar,
35
37
  classMap[theme],
38
+ classMap[attachment],
36
39
  className,
37
40
  shadow && classMap[`shadow${capitalize(shadow)}`],
38
41
  rounding && classMap[`round${capitalize(rounding)}`]
39
42
  ),
40
- [classMap, theme, className, shadow, rounding]
43
+ [classMap, theme, attachment, className, shadow, rounding]
41
44
  );
42
45
  const resolvedAriaLabel = ariaLabelledBy ? void 0 : ariaLabelProp ?? ariaLabel;
43
46
  const avatarAriaHidden = avatar && !avatar.name && !avatar.onClick && !avatar["aria-label"] ? true : void 0;
@@ -75,7 +78,7 @@ import './Toolbar.css';const ToolbarBase = ({
75
78
  TitleTag,
76
79
  {
77
80
  id: resolvedTitleId,
78
- className: classMap.title,
81
+ className: combineClassNames(classMap.title, titleClassName),
79
82
  "data-testid": `${testId}-title`,
80
83
  children: title
81
84
  }
@@ -124,6 +127,9 @@ import './Toolbar.css';const ToolbarBase = ({
124
127
  ToolbarBase.displayName = "ToolbarBase";
125
128
  const classes = {
126
129
  toolbar: "toolbar",
130
+ fixed: "toolbar_fixed",
131
+ sticky: "toolbar_sticky",
132
+ static: "toolbar_static",
127
133
  section: "toolbar_section",
128
134
  title: "toolbar_title",
129
135
  avatarWrapper: "toolbar_avatarWrapper",
@@ -147,4 +153,4 @@ Toolbar.displayName = "Toolbar";
147
153
  export {
148
154
  Toolbar as T
149
155
  };
150
- //# sourceMappingURL=Toolbar-ArPZcJS3.js.map
156
+ //# sourceMappingURL=Toolbar-DQifkFqc.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Toolbar-DQifkFqc.js","sources":["../../src/components/Toolbar/ToolbarBase.tsx","../../src/components/Toolbar/core/Toolbar.tsx"],"sourcesContent":["import React, { JSX, useMemo } from \"react\";\r\nimport { combineClassNames } from \"../../utils/classNames\";\r\nimport { ToolbarBaseProps } from \"./Toolbar.types\";\r\nimport { capitalize } from \"../../utils/capitalize\";\r\nimport {\r\n getDefaultRounding,\r\n getDefaultShadow,\r\n getDefaultTheme,\r\n} from \"../../config/boreal-style-config\";\r\n\r\nconst ToolbarBase: React.FC<ToolbarBaseProps> = ({\r\n title,\r\n titleId,\r\n left,\r\n center,\r\n right,\r\n avatar,\r\n theme = getDefaultTheme(),\r\n attachment = \"static\",\r\n shadow = getDefaultShadow(),\r\n rounding = getDefaultRounding(),\r\n className = \"\",\r\n titleClassName = \"\",\r\n \"data-testid\": testId = \"toolbar\",\r\n \"aria-label\": ariaLabelProp,\r\n \"aria-labelledby\": ariaLabelledBy,\r\n \"aria-describedby\": ariaDescribedBy,\r\n leftAriaLabel = \"Toolbar left section\",\r\n centerAriaLabel = \"Toolbar center section\",\r\n rightAriaLabel = \"Toolbar right section\",\r\n AvatarComponent,\r\n classMap,\r\n \"aria-label\": ariaLabel = \"Toolbar\",\r\n headingLevel = 1,\r\n}): JSX.Element => {\r\n const safeHeading = Math.min(6, Math.max(1, headingLevel));\r\n const TitleTag = `h${safeHeading}` as keyof JSX.IntrinsicElements;\r\n\r\n const toolbarClass = useMemo(\r\n () =>\r\n combineClassNames(\r\n classMap.toolbar,\r\n classMap[theme],\r\n classMap[attachment],\r\n className,\r\n shadow && classMap[`shadow${capitalize(shadow)}`],\r\n rounding && classMap[`round${capitalize(rounding)}`],\r\n ),\r\n [classMap, theme, attachment, className, shadow, rounding],\r\n );\r\n\r\n const resolvedAriaLabel = ariaLabelledBy\r\n ? undefined\r\n : (ariaLabelProp ?? ariaLabel);\r\n\r\n const avatarAriaHidden =\r\n avatar && !avatar.name && !avatar.onClick && !avatar[\"aria-label\"]\r\n ? true\r\n : undefined;\r\n\r\n const resolvedTitleId = title ? (titleId ?? `${testId}-title`) : undefined;\r\n\r\n return (\r\n <div\r\n className={toolbarClass}\r\n role=\"toolbar\"\r\n aria-orientation=\"horizontal\"\r\n aria-label={resolvedAriaLabel}\r\n aria-labelledby={ariaLabelledBy}\r\n aria-describedby={ariaDescribedBy}\r\n data-testid={testId}\r\n >\r\n <div\r\n className={classMap.section}\r\n role=\"group\"\r\n aria-label={leftAriaLabel}\r\n data-testid={`${testId}-left`}\r\n >\r\n {left}\r\n </div>\r\n\r\n <div\r\n className={classMap.section}\r\n role=\"group\"\r\n aria-label={centerAriaLabel}\r\n data-testid={`${testId}-center`}\r\n >\r\n {title && (\r\n <TitleTag\r\n id={resolvedTitleId}\r\n className={combineClassNames(classMap.title, titleClassName)}\r\n data-testid={`${testId}-title`}\r\n >\r\n {title}\r\n </TitleTag>\r\n )}\r\n {center}\r\n </div>\r\n\r\n <div\r\n className={classMap.section}\r\n role=\"group\"\r\n aria-label={rightAriaLabel}\r\n data-testid={`${testId}-right`}\r\n >\r\n {right}\r\n {avatar && (\r\n <div\r\n className={classMap.avatarWrapper}\r\n data-testid={`${testId}-avatar`}\r\n >\r\n <AvatarComponent\r\n name={avatar.name}\r\n src={avatar.src}\r\n size={avatar.size || \"medium\"}\r\n shape={avatar.shape || \"circle\"}\r\n theme={avatar.theme}\r\n outline={avatar.outline}\r\n onClick={avatar.onClick}\r\n aria-label={avatar[\"aria-label\"]}\r\n aria-hidden={avatarAriaHidden}\r\n />\r\n </div>\r\n )}\r\n </div>\r\n </div>\r\n );\r\n};\r\n\r\nToolbarBase.displayName = \"ToolbarBase\";\r\nexport default ToolbarBase;\r\n","import React from \"react\";\r\nimport \"./Toolbar.scss\";\r\nimport Avatar from \"../../Avatar/core/Avatar\";\r\nimport ToolbarBase from \"../ToolbarBase\";\r\nimport { ToolbarProps } from \"../Toolbar.types\";\r\n\r\nconst classes = {\r\n toolbar: \"toolbar\",\r\n\r\n fixed: \"toolbar_fixed\",\r\n sticky: \"toolbar_sticky\",\r\n static: \"toolbar_static\",\r\n\r\n section: \"toolbar_section\",\r\n title: \"toolbar_title\",\r\n avatarWrapper: \"toolbar_avatarWrapper\",\r\n\r\n primary: \"toolbar_primary\",\r\n secondary: \"toolbar_secondary\",\r\n tertiary: \"toolbar_tertiary\",\r\n quaternary: \"toolbar_quaternary\",\r\n\r\n clear: \"toolbar_clear\",\r\n\r\n shadowNone: \"toolbar_shadow-None\",\r\n shadowLight: \"toolbar_shadow-Light\",\r\n shadowMedium: \"toolbar_shadow-Medium\",\r\n shadowStrong: \"toolbar_shadow-Strong\",\r\n shadowIntense: \"toolbar_shadow-Intense\",\r\n\r\n roundNone: \"toolbar_round-None\",\r\n roundSmall: \"toolbar_round-Small\",\r\n roundMedium: \"toolbar_round-Medium\",\r\n roundLarge: \"toolbar_round-Large\",\r\n};\r\n\r\nconst Toolbar: React.FC<ToolbarProps> = (props) => (\r\n <ToolbarBase {...props} AvatarComponent={Avatar} classMap={classes} />\r\n);\r\nToolbar.displayName = \"Toolbar\";\r\nexport default Toolbar;\r\n"],"names":[],"mappings":"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"}
@@ -1,4 +1,4 @@
1
1
  "use strict";
2
- const Toolbar = require("./Toolbar-Dz1rhlz_.cjs");
2
+ const Toolbar = require("./Toolbar-BUkKkXBz.cjs");
3
3
  module.exports = Toolbar.Toolbar;
4
4
  //# sourceMappingURL=Toolbar.cjs.js.map
@@ -244,6 +244,21 @@
244
244
  background-color: transparent;
245
245
  color: var(--text-color-primary);
246
246
  }
247
+ .toolbar_static {
248
+ position: static;
249
+ }
250
+ .toolbar_fixed {
251
+ position: fixed;
252
+ top: 0;
253
+ left: 0;
254
+ right: 0;
255
+ z-index: var(--z-index-fixed, 1000);
256
+ }
257
+ .toolbar_sticky {
258
+ position: sticky;
259
+ top: 0;
260
+ z-index: var(--z-index-sticky, 999);
261
+ }
247
262
  .toolbar_section {
248
263
  flex: 1;
249
264
  display: flex;
@@ -1,4 +1,4 @@
1
- import { T } from "./Toolbar-ArPZcJS3.js";
1
+ import { T } from "./Toolbar-DQifkFqc.js";
2
2
  export {
3
3
  T as default
4
4
  };
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const colorSchemes = [
3
+ const defaultColorSchemes = [
4
4
  {
5
5
  name: "Autumn Glow",
6
6
  primaryColor: "#c58686",
@@ -202,5 +202,5 @@ const colorSchemes = [
202
202
  backgroundColor: "#c2bfbf"
203
203
  }
204
204
  ];
205
- exports.colorSchemes = colorSchemes;
205
+ exports.defaultColorSchemes = defaultColorSchemes;
206
206
  //# sourceMappingURL=colorSchemes.cjs.js.map