@gbmtech/aurora-ui 0.2.52 → 0.2.53

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 (90) hide show
  1. package/dist/cjs/components/avatar.cjs +2 -0
  2. package/dist/cjs/components/avatar.cjs.map +1 -0
  3. package/dist/cjs/components/data-table/index.cjs +1 -1
  4. package/dist/cjs/components/sidebar/app-layout.cjs +3 -0
  5. package/dist/cjs/components/sidebar/app-layout.cjs.map +1 -0
  6. package/dist/cjs/components/sidebar/index.cjs +1 -0
  7. package/dist/cjs/components/sidebar/intl/messages.cjs +2 -0
  8. package/dist/cjs/components/sidebar/intl/messages.cjs.map +1 -0
  9. package/dist/cjs/components/sidebar/logo.cjs +2 -0
  10. package/dist/cjs/components/sidebar/logo.cjs.map +1 -0
  11. package/dist/cjs/components/sidebar/nav-modules.cjs +3 -0
  12. package/dist/cjs/components/sidebar/nav-modules.cjs.map +1 -0
  13. package/dist/cjs/components/sidebar/nav-sub-item.cjs +2 -0
  14. package/dist/cjs/components/sidebar/nav-sub-item.cjs.map +1 -0
  15. package/dist/cjs/components/sidebar/nav-user.cjs +3 -0
  16. package/dist/cjs/components/sidebar/nav-user.cjs.map +1 -0
  17. package/dist/cjs/components/sidebar/sidebar-icons.cjs +2 -0
  18. package/dist/cjs/components/sidebar/sidebar-icons.cjs.map +1 -0
  19. package/dist/cjs/components/sidebar/sidebar.cjs +3 -0
  20. package/dist/cjs/components/sidebar/sidebar.cjs.map +1 -0
  21. package/dist/cjs/hooks/use-mobile.cjs +2 -0
  22. package/dist/cjs/hooks/use-mobile.cjs.map +1 -0
  23. package/dist/cjs/index.cjs +1 -1
  24. package/dist/cjs/lib/dynamic-icon.cjs +3 -0
  25. package/dist/cjs/lib/dynamic-icon.cjs.map +1 -0
  26. package/dist/cjs/types/index.cjs +1 -1
  27. package/dist/cjs/types/module.cjs +1 -0
  28. package/dist/cjs/types/user.cjs +1 -0
  29. package/dist/esm/components/avatar.d.ts +7 -0
  30. package/dist/esm/components/avatar.d.ts.map +1 -0
  31. package/dist/esm/components/avatar.js +2 -0
  32. package/dist/esm/components/avatar.js.map +1 -0
  33. package/dist/esm/components/data-table/index.js +1 -1
  34. package/dist/esm/components/sidebar/app-layout.d.ts +10 -0
  35. package/dist/esm/components/sidebar/app-layout.d.ts.map +1 -0
  36. package/dist/esm/components/sidebar/app-layout.js +3 -0
  37. package/dist/esm/components/sidebar/app-layout.js.map +1 -0
  38. package/dist/esm/components/sidebar/index.d.ts +8 -0
  39. package/dist/esm/components/sidebar/index.d.ts.map +1 -0
  40. package/dist/esm/components/sidebar/index.js +1 -0
  41. package/dist/esm/components/sidebar/intl/messages.d.ts +22 -0
  42. package/dist/esm/components/sidebar/intl/messages.d.ts.map +1 -0
  43. package/dist/esm/components/sidebar/intl/messages.js +2 -0
  44. package/dist/esm/components/sidebar/intl/messages.js.map +1 -0
  45. package/dist/esm/components/sidebar/logo.d.ts +3 -0
  46. package/dist/esm/components/sidebar/logo.d.ts.map +1 -0
  47. package/dist/esm/components/sidebar/logo.js +2 -0
  48. package/dist/esm/components/sidebar/logo.js.map +1 -0
  49. package/dist/esm/components/sidebar/nav-modules.d.ts +7 -0
  50. package/dist/esm/components/sidebar/nav-modules.d.ts.map +1 -0
  51. package/dist/esm/components/sidebar/nav-modules.js +3 -0
  52. package/dist/esm/components/sidebar/nav-modules.js.map +1 -0
  53. package/dist/esm/components/sidebar/nav-sub-item.d.ts +7 -0
  54. package/dist/esm/components/sidebar/nav-sub-item.d.ts.map +1 -0
  55. package/dist/esm/components/sidebar/nav-sub-item.js +2 -0
  56. package/dist/esm/components/sidebar/nav-sub-item.js.map +1 -0
  57. package/dist/esm/components/sidebar/nav-user.d.ts +7 -0
  58. package/dist/esm/components/sidebar/nav-user.d.ts.map +1 -0
  59. package/dist/esm/components/sidebar/nav-user.js +3 -0
  60. package/dist/esm/components/sidebar/nav-user.js.map +1 -0
  61. package/dist/esm/components/sidebar/sidebar-icons.d.ts +5 -0
  62. package/dist/esm/components/sidebar/sidebar-icons.d.ts.map +1 -0
  63. package/dist/esm/components/sidebar/sidebar-icons.js +2 -0
  64. package/dist/esm/components/sidebar/sidebar-icons.js.map +1 -0
  65. package/dist/esm/components/sidebar/sidebar.d.ts +86 -0
  66. package/dist/esm/components/sidebar/sidebar.d.ts.map +1 -0
  67. package/dist/esm/components/sidebar/sidebar.js +3 -0
  68. package/dist/esm/components/sidebar/sidebar.js.map +1 -0
  69. package/dist/esm/hooks/use-mobile.d.ts +2 -0
  70. package/dist/esm/hooks/use-mobile.d.ts.map +1 -0
  71. package/dist/esm/hooks/use-mobile.js +2 -0
  72. package/dist/esm/hooks/use-mobile.js.map +1 -0
  73. package/dist/esm/index.d.ts +1 -0
  74. package/dist/esm/index.d.ts.map +1 -1
  75. package/dist/esm/index.js +1 -1
  76. package/dist/esm/lib/dynamic-icon.d.ts +9 -0
  77. package/dist/esm/lib/dynamic-icon.d.ts.map +1 -0
  78. package/dist/esm/lib/dynamic-icon.js +3 -0
  79. package/dist/esm/lib/dynamic-icon.js.map +1 -0
  80. package/dist/esm/types/index.d.ts +2 -0
  81. package/dist/esm/types/index.d.ts.map +1 -1
  82. package/dist/esm/types/index.js +1 -1
  83. package/dist/esm/types/module.d.ts +13 -0
  84. package/dist/esm/types/module.d.ts.map +1 -0
  85. package/dist/esm/types/module.js +0 -0
  86. package/dist/esm/types/user.d.ts +13 -0
  87. package/dist/esm/types/user.d.ts.map +1 -0
  88. package/dist/esm/types/user.js +0 -0
  89. package/dist/styles/index.css +14 -0
  90. package/package.json +8 -1
@@ -0,0 +1 @@
1
+ export*from"./app-layout.js";export*from"./logo.js";export*from"./nav-modules.js";export*from"./nav-sub-item.js";export*from"./nav-user.js";export*from"./sidebar.js";export*from"./sidebar-icons.js";
@@ -0,0 +1,22 @@
1
+ declare const _default: {
2
+ 'pt-br': {
3
+ home: string;
4
+ modules: string;
5
+ language: string;
6
+ 'sign-out': string;
7
+ };
8
+ 'en-us': {
9
+ home: string;
10
+ modules: string;
11
+ language: string;
12
+ 'sign-out': string;
13
+ };
14
+ es: {
15
+ home: string;
16
+ modules: string;
17
+ language: string;
18
+ 'sign-out': string;
19
+ };
20
+ };
21
+ export default _default;
22
+ //# sourceMappingURL=messages.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"messages.d.ts","sourceRoot":"","sources":["../../../../../src/components/sidebar/intl/messages.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA,wBAmBC"}
@@ -0,0 +1,2 @@
1
+ let e={"pt-br":{home:"P\xe1gina Inicial",modules:"M\xf3dulos",language:"Idioma","sign-out":"Sair"},"en-us":{home:"Home",modules:"Modules",language:"Language","sign-out":"Sign Out"},es:{home:"P\xe1gina de inicio",modules:"M\xf3dulos",language:"Idioma","sign-out":"Desconectar"}};export{e as default};
2
+ //# sourceMappingURL=messages.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"components\\sidebar\\intl\\messages.js","sources":["webpack://@gbmtech/aurora-ui/./src/components/sidebar/intl/messages.ts"],"sourcesContent":["export default {\n 'pt-br': {\n home: 'Página Inicial',\n modules: 'Módulos',\n language: 'Idioma',\n 'sign-out': 'Sair',\n },\n 'en-us': {\n home: 'Home',\n modules: 'Modules',\n language: 'Language',\n 'sign-out': 'Sign Out',\n },\n es: {\n home: 'Página de inicio',\n modules: 'Módulos',\n language: 'Idioma',\n 'sign-out': 'Desconectar',\n },\n}\n"],"names":[],"mappings":"AAAA,MAAe,CACb,QAAS,CACP,KAAM,oBACN,QAAS,aACT,SAAU,SACV,WAAY,MACd,EACA,QAAS,CACP,KAAM,OACN,QAAS,UACT,SAAU,WACV,WAAY,UACd,EACA,GAAI,CACF,KAAM,sBACN,QAAS,aACT,SAAU,SACV,WAAY,aACd,CACF,S"}
@@ -0,0 +1,3 @@
1
+ declare function Logo(): import("react/jsx-runtime").JSX.Element;
2
+ export { Logo };
3
+ //# sourceMappingURL=logo.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logo.d.ts","sourceRoot":"","sources":["../../../../src/components/sidebar/logo.tsx"],"names":[],"mappings":"AAAA,iBAAS,IAAI,4CA4BZ;AAED,OAAO,EAAE,IAAI,EAAE,CAAA"}
@@ -0,0 +1,2 @@
1
+ import*as C from"react/jsx-runtime";function t(){return(0,C.jsxs)("svg",{width:"28",height:"26",viewBox:"0 0 28 26",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[(0,C.jsx)("title",{children:"GBM Tech & Control"}),(0,C.jsx)("path",{d:"M24.1148 13.0128C24.1318 14.5091 23.8525 15.994 23.2932 17.3813C22.7339 18.7686 21.9057 20.0309 20.8565 21.095C19.8074 22.1592 18.5582 23.004 17.1812 23.5805C15.8042 24.1571 14.3268 24.454 12.8347 24.454C11.3425 24.454 9.8651 24.1571 8.48812 23.5805C7.11114 23.004 5.86191 22.1592 4.81277 21.095C3.76363 20.0309 2.93543 18.7686 2.37614 17.3813C1.81684 15.994 1.53756 14.5091 1.55448 13.0128C1.55551 10.5113 2.38323 8.08075 3.90819 6.1012C5.43315 4.12165 7.56934 2.70479 9.98265 2.07221C12.396 1.43964 14.9503 1.62703 17.2461 2.60508C19.5419 3.58312 21.4497 5.29667 22.6712 7.4777L23.6626 6.43987C21.9961 3.68258 19.343 1.66711 16.245 0.804907C13.147 -0.0572994 9.8376 0.298769 6.99248 1.80042C4.14735 3.30208 1.981 5.83609 0.935672 8.88516C-0.109661 11.9342 0.0448455 15.2684 1.36765 18.2071C2.69046 21.1458 5.08181 23.4675 8.05355 24.698C11.0253 25.9286 14.3533 25.9753 17.3582 24.8287C20.3632 23.6821 22.8184 21.4286 24.2228 18.5282C25.6271 15.6278 25.8747 12.2992 24.9149 9.22195L23.809 10.3848C24.0129 11.2458 24.1155 12.1278 24.1148 13.0128Z",fill:"white"}),(0,C.jsx)("path",{d:"M12.3962 21.0204C12.3022 21.0194 12.2093 20.9991 12.1233 20.9609C12.0373 20.9227 11.96 20.8672 11.8962 20.798L4.99542 13.2774C4.87222 13.1424 4.80751 12.9639 4.81553 12.7812C4.82355 12.5984 4.90364 12.4263 5.03818 12.3027C5.17273 12.1792 5.3507 12.1143 5.53296 12.1223C5.71521 12.1304 5.88682 12.2107 6.01002 12.3456L12.4078 19.3227L25.8237 5.22325C25.8847 5.15317 25.9593 5.09622 26.0429 5.05582C26.1265 5.01543 26.2173 4.99243 26.31 4.98821C26.4027 4.984 26.4953 4.99866 26.5822 5.0313C26.6691 5.06395 26.7485 5.11391 26.8156 5.17816C26.8827 5.24241 26.9361 5.31963 26.9727 5.40516C27.0092 5.49069 27.0281 5.58276 27.0282 5.6758C27.0283 5.76885 27.0096 5.86095 26.9732 5.94655C26.9368 6.03216 26.8835 6.10948 26.8166 6.17387L12.9021 20.8096C12.8366 20.8776 12.7579 20.9314 12.6709 20.9676C12.5839 21.0039 12.4904 21.0218 12.3962 21.0204Z",fill:"white"}),(0,C.jsx)("path",{d:"M26.3093 7.04745C27.105 7.04745 27.75 6.40058 27.75 5.60263C27.75 4.80467 27.105 4.1578 26.3093 4.1578C25.5136 4.1578 24.8685 4.80467 24.8685 5.60263C24.8685 6.40058 25.5136 7.04745 26.3093 7.04745Z",fill:"white"}),(0,C.jsx)("path",{d:"M5.41865 14.1684C6.21434 14.1684 6.85938 13.5215 6.85938 12.7235C6.85938 11.9256 6.21434 11.2787 5.41865 11.2787C4.62296 11.2787 3.97792 11.9256 3.97792 12.7235C3.97792 13.5215 4.62296 14.1684 5.41865 14.1684Z",fill:"white"})]})}export{t as Logo};
2
+ //# sourceMappingURL=logo.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"components\\sidebar\\logo.js","sources":["webpack://@gbmtech/aurora-ui/./src/components/sidebar/logo.tsx"],"sourcesContent":["function Logo() {\n return (\n <svg\n width=\"28\"\n height=\"26\"\n viewBox=\"0 0 28 26\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <title>GBM Tech & Control</title>\n <path\n d=\"M24.1148 13.0128C24.1318 14.5091 23.8525 15.994 23.2932 17.3813C22.7339 18.7686 21.9057 20.0309 20.8565 21.095C19.8074 22.1592 18.5582 23.004 17.1812 23.5805C15.8042 24.1571 14.3268 24.454 12.8347 24.454C11.3425 24.454 9.8651 24.1571 8.48812 23.5805C7.11114 23.004 5.86191 22.1592 4.81277 21.095C3.76363 20.0309 2.93543 18.7686 2.37614 17.3813C1.81684 15.994 1.53756 14.5091 1.55448 13.0128C1.55551 10.5113 2.38323 8.08075 3.90819 6.1012C5.43315 4.12165 7.56934 2.70479 9.98265 2.07221C12.396 1.43964 14.9503 1.62703 17.2461 2.60508C19.5419 3.58312 21.4497 5.29667 22.6712 7.4777L23.6626 6.43987C21.9961 3.68258 19.343 1.66711 16.245 0.804907C13.147 -0.0572994 9.8376 0.298769 6.99248 1.80042C4.14735 3.30208 1.981 5.83609 0.935672 8.88516C-0.109661 11.9342 0.0448455 15.2684 1.36765 18.2071C2.69046 21.1458 5.08181 23.4675 8.05355 24.698C11.0253 25.9286 14.3533 25.9753 17.3582 24.8287C20.3632 23.6821 22.8184 21.4286 24.2228 18.5282C25.6271 15.6278 25.8747 12.2992 24.9149 9.22195L23.809 10.3848C24.0129 11.2458 24.1155 12.1278 24.1148 13.0128Z\"\n fill=\"white\"\n />\n <path\n d=\"M12.3962 21.0204C12.3022 21.0194 12.2093 20.9991 12.1233 20.9609C12.0373 20.9227 11.96 20.8672 11.8962 20.798L4.99542 13.2774C4.87222 13.1424 4.80751 12.9639 4.81553 12.7812C4.82355 12.5984 4.90364 12.4263 5.03818 12.3027C5.17273 12.1792 5.3507 12.1143 5.53296 12.1223C5.71521 12.1304 5.88682 12.2107 6.01002 12.3456L12.4078 19.3227L25.8237 5.22325C25.8847 5.15317 25.9593 5.09622 26.0429 5.05582C26.1265 5.01543 26.2173 4.99243 26.31 4.98821C26.4027 4.984 26.4953 4.99866 26.5822 5.0313C26.6691 5.06395 26.7485 5.11391 26.8156 5.17816C26.8827 5.24241 26.9361 5.31963 26.9727 5.40516C27.0092 5.49069 27.0281 5.58276 27.0282 5.6758C27.0283 5.76885 27.0096 5.86095 26.9732 5.94655C26.9368 6.03216 26.8835 6.10948 26.8166 6.17387L12.9021 20.8096C12.8366 20.8776 12.7579 20.9314 12.6709 20.9676C12.5839 21.0039 12.4904 21.0218 12.3962 21.0204Z\"\n fill=\"white\"\n />\n <path\n d=\"M26.3093 7.04745C27.105 7.04745 27.75 6.40058 27.75 5.60263C27.75 4.80467 27.105 4.1578 26.3093 4.1578C25.5136 4.1578 24.8685 4.80467 24.8685 5.60263C24.8685 6.40058 25.5136 7.04745 26.3093 7.04745Z\"\n fill=\"white\"\n />\n <path\n d=\"M5.41865 14.1684C6.21434 14.1684 6.85938 13.5215 6.85938 12.7235C6.85938 11.9256 6.21434 11.2787 5.41865 11.2787C4.62296 11.2787 3.97792 11.9256 3.97792 12.7235C3.97792 13.5215 4.62296 14.1684 5.41865 14.1684Z\"\n fill=\"white\"\n />\n </svg>\n )\n}\n\nexport { Logo }\n"],"names":["Logo"],"mappings":"oCAAA,SAASA,IACP,MACE,WAAC,OACC,MAAM,KACN,OAAO,KACP,QAAQ,YACR,KAAK,OACL,MAAM,6B,UAEN,UAAC,S,SAAM,oB,GACP,UAAC,QACC,EAAE,yhCACF,KAAK,O,GAEP,UAAC,QACC,EAAE,00BACF,KAAK,O,GAEP,UAAC,QACC,EAAE,yMACF,KAAK,O,GAEP,UAAC,QACC,EAAE,oNACF,KAAK,O,KAIb,Q"}
@@ -0,0 +1,7 @@
1
+ import { Module } from '../../types';
2
+ interface NavModulesProps {
3
+ modules: Module[];
4
+ }
5
+ export declare function NavModules({ modules }: NavModulesProps): import("react/jsx-runtime").JSX.Element;
6
+ export {};
7
+ //# sourceMappingURL=nav-modules.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"nav-modules.d.ts","sourceRoot":"","sources":["../../../../src/components/sidebar/nav-modules.tsx"],"names":[],"mappings":"AAUA,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAA;AAehC,UAAU,eAAe;IACvB,OAAO,EAAE,MAAM,EAAE,CAAA;CAClB;AAED,wBAAgB,UAAU,CAAC,EAAE,OAAO,EAAE,EAAE,eAAe,2CAiDtD"}
@@ -0,0 +1,3 @@
1
+ 'use client'
2
+ import*as e from"react/jsx-runtime";import*as s from"@radix-ui/react-collapsible";import*as i from"lucide-react";import*as r from"next/link";import*as a from"./intl/messages.js";import*as n from"./nav-sub-item.js";import*as l from"./sidebar.js";import*as o from"./sidebar-icons.js";function d({modules:d}){let{lang:t}=(0,l.useSidebar)();return(0,e.jsxs)(l.SidebarGroup,{children:[(0,e.jsx)(l.SidebarGroupLabel,{children:a.default[t].modules}),(0,e.jsxs)(l.SidebarMenu,{children:[(0,e.jsx)(l.SidebarMenuItem,{children:(0,e.jsx)(l.SidebarMenuButton,{asChild:!0,children:(0,e.jsxs)(r.default,{href:"/home",children:[(0,e.jsx)(i.House,{}),(0,e.jsx)("span",{children:a.default[t].home})]})})}),d.map(r=>(0,e.jsx)(s.Collapsible,{asChild:!0,children:(0,e.jsxs)(l.SidebarMenuItem,{children:[(0,e.jsx)(s.CollapsibleTrigger,{asChild:!0,children:(0,e.jsxs)(l.SidebarMenuButton,{tooltip:r.name,children:[(0,e.jsx)(o.SidebarIcons,{icon:r.icon}),(0,e.jsx)("span",{children:r.name}),(0,e.jsx)(l.SidebarMenuAction,{className:"group-data-[state=open]/menu-item:rotate-90",asChild:!0,children:(0,e.jsxs)("div",{children:[(0,e.jsx)(i.ChevronRight,{className:"transition-transform"}),(0,e.jsx)("span",{className:"sr-only",children:"Toggle"})]})})]})}),r.submodules?.length&&(0,e.jsx)(s.CollapsibleContent,{children:(0,e.jsx)(l.SidebarMenuSub,{children:r.submodules?.map(s=>(0,e.jsx)(n.NavSubItem,{item:s},s.id))})})]})},r.id))]})]})}export{d as NavModules};
3
+ //# sourceMappingURL=nav-modules.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"components\\sidebar\\nav-modules.js","sources":["webpack://@gbmtech/aurora-ui/./src/components/sidebar/nav-modules.tsx"],"sourcesContent":["\n\nimport {\n Collapsible,\n CollapsibleContent,\n CollapsibleTrigger,\n} from '@radix-ui/react-collapsible'\nimport { ChevronRight, House } from 'lucide-react'\nimport Link from 'next/link'\n\nimport { Module } from '@/types'\nimport messages from './intl/messages'\nimport { NavSubItem } from './nav-sub-item'\nimport {\n SidebarGroup,\n SidebarGroupLabel,\n SidebarMenu,\n SidebarMenuAction,\n SidebarMenuButton,\n SidebarMenuItem,\n SidebarMenuSub,\n useSidebar,\n} from './sidebar'\nimport { SidebarIcons } from './sidebar-icons'\n\ninterface NavModulesProps {\n modules: Module[]\n}\n\nexport function NavModules({ modules }: NavModulesProps) {\n const { lang } = useSidebar()\n\n return (\n <SidebarGroup>\n <SidebarGroupLabel>{messages[lang].modules}</SidebarGroupLabel>\n <SidebarMenu>\n <SidebarMenuItem>\n <SidebarMenuButton asChild>\n <Link href=\"/home\">\n <House />\n <span>{messages[lang].home}</span>\n </Link>\n </SidebarMenuButton>\n </SidebarMenuItem>\n {modules.map(item => (\n <Collapsible key={item.id} asChild>\n <SidebarMenuItem>\n <CollapsibleTrigger asChild>\n <SidebarMenuButton tooltip={item.name}>\n <SidebarIcons icon={item.icon} />\n\n <span>{item.name}</span>\n <SidebarMenuAction\n className=\"group-data-[state=open]/menu-item:rotate-90\"\n asChild\n >\n <div>\n <ChevronRight className=\"transition-transform\" />\n <span className=\"sr-only\">Toggle</span>\n </div>\n </SidebarMenuAction>\n </SidebarMenuButton>\n </CollapsibleTrigger>\n {item.submodules?.length && (\n <CollapsibleContent>\n <SidebarMenuSub>\n {item.submodules?.map(subItem => (\n <NavSubItem key={subItem.id} item={subItem} />\n ))}\n </SidebarMenuSub>\n </CollapsibleContent>\n )}\n </SidebarMenuItem>\n </Collapsible>\n ))}\n </SidebarMenu>\n </SidebarGroup>\n )\n}\n"],"names":["NavModules","modules","lang","useSidebar","SidebarGroup","SidebarGroupLabel","messages","SidebarMenu","SidebarMenuItem","SidebarMenuButton","Link","House","item","Collapsible","CollapsibleTrigger","SidebarIcons","SidebarMenuAction","ChevronRight","CollapsibleContent","SidebarMenuSub","subItem","NavSubItem"],"mappings":";0RA6BO,SAASA,EAAW,CAAEC,QAAAA,CAAO,CAAmB,EACrD,GAAM,CAAEC,KAAAA,CAAI,CAAE,CAAGC,GAAAA,EAAAA,UAAAA,IAEjB,MACE,WAACC,EAAAA,YAAYA,CAAAA,C,UACX,UAACC,EAAAA,iBAAiBA,CAAAA,C,SAAEC,EAAAA,OAAQ,CAACJ,EAAK,CAAC,OAAO,GAC1C,WAACK,EAAAA,WAAWA,CAAAA,C,UACV,UAACC,EAAAA,eAAeA,CAAAA,C,SACd,UAACC,EAAAA,iBAAiBA,CAAAA,CAAC,QAAO,G,SACxB,WAACC,EAAAA,OAAIA,CAAAA,CAAC,KAAK,Q,UACT,UAACC,EAAAA,KAAKA,CAAAA,CAAAA,GACN,UAAC,Q,SAAML,EAAAA,OAAQ,CAACJ,EAAK,CAAC,IAAI,UAI/BD,EAAQ,GAAG,CAACW,GACX,UAACC,EAAAA,WAAWA,CAAAA,CAAe,QAAO,G,SAChC,WAACL,EAAAA,eAAeA,CAAAA,C,UACd,UAACM,EAAAA,kBAAkBA,CAAAA,CAAC,QAAO,G,SACzB,WAACL,EAAAA,iBAAiBA,CAAAA,CAAC,QAASG,EAAK,IAAI,C,UACnC,UAACG,EAAAA,YAAYA,CAAAA,CAAC,KAAMH,EAAK,IAAI,GAE7B,UAAC,Q,SAAMA,EAAK,IAAI,GAChB,UAACI,EAAAA,iBAAiBA,CAAAA,CAChB,UAAU,8CACV,QAAO,G,SAEP,WAAC,O,UACC,UAACC,EAAAA,YAAYA,CAAAA,CAAC,UAAU,sB,GACxB,UAAC,QAAK,UAAU,U,SAAU,Q,aAKjCL,EAAK,UAAU,EAAE,QAChB,UAACM,EAAAA,kBAAkBA,CAAAA,C,SACjB,UAACC,EAAAA,cAAcA,CAAAA,C,SACZP,EAAK,UAAU,EAAE,IAAIQ,GACpB,UAACC,EAAAA,UAAUA,CAAAA,CAAkB,KAAMD,C,EAAlBA,EAAQ,EAAE,E,SAtBrBR,EAAK,EAAE,G,KAiCnC,Q"}
@@ -0,0 +1,7 @@
1
+ import { Module } from '../../types';
2
+ interface NavItemProps {
3
+ item: Module;
4
+ }
5
+ export declare function NavSubItem({ item }: NavItemProps): import("react/jsx-runtime").JSX.Element;
6
+ export {};
7
+ //# sourceMappingURL=nav-sub-item.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"nav-sub-item.d.ts","sourceRoot":"","sources":["../../../../src/components/sidebar/nav-sub-item.tsx"],"names":[],"mappings":"AAQA,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAA;AAShC,UAAU,YAAY;IACpB,IAAI,EAAE,MAAM,CAAA;CACb;AAED,wBAAgB,UAAU,CAAC,EAAE,IAAI,EAAE,EAAE,YAAY,2CAsChD"}
@@ -0,0 +1,2 @@
1
+ import*as e from"react/jsx-runtime";import*as s from"@radix-ui/react-collapsible";import*as r from"lucide-react";import*as a from"next/link";import*as i from"./sidebar.js";function t({item:l}){return l.submodules?.length?(0,e.jsx)(i.SidebarMenuItem,{children:(0,e.jsxs)(s.Collapsible,{className:"group/collapsible [&[data-state=open]>button>div>svg:first-child]:rotate-90",children:[(0,e.jsx)(s.CollapsibleTrigger,{asChild:!0,children:(0,e.jsxs)(i.SidebarMenuButton,{children:[l.name,(0,e.jsx)(i.SidebarMenuAction,{asChild:!0,children:(0,e.jsxs)("div",{children:[(0,e.jsx)(r.ChevronRight,{className:"transition-transform"}),(0,e.jsx)("span",{className:"sr-only",children:"Toggle"})]})})]})}),(0,e.jsx)(s.CollapsibleContent,{children:(0,e.jsx)(i.SidebarMenuSub,{children:l.submodules.map(s=>(0,e.jsx)(t,{item:s},s.id))})})]})}):(0,e.jsx)(i.SidebarMenuSubItem,{children:(0,e.jsx)(i.SidebarMenuButton,{className:"data-[active=true]:bg-transparent",asChild:!0,children:(0,e.jsx)(a.default,{href:l.path,children:l.name})})})}export{t as NavSubItem};
2
+ //# sourceMappingURL=nav-sub-item.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"components\\sidebar\\nav-sub-item.js","sources":["webpack://@gbmtech/aurora-ui/./src/components/sidebar/nav-sub-item.tsx"],"sourcesContent":["import {\n Collapsible,\n CollapsibleContent,\n CollapsibleTrigger,\n} from '@radix-ui/react-collapsible'\nimport { ChevronRight } from 'lucide-react'\nimport Link from 'next/link'\n\nimport { Module } from '@/types'\nimport {\n SidebarMenuAction,\n SidebarMenuButton,\n SidebarMenuItem,\n SidebarMenuSub,\n SidebarMenuSubItem,\n} from './sidebar'\n\ninterface NavItemProps {\n item: Module\n}\n\nexport function NavSubItem({ item }: NavItemProps) {\n if (!item.submodules?.length) {\n return (\n <SidebarMenuSubItem>\n <SidebarMenuButton\n className=\"data-[active=true]:bg-transparent\"\n asChild\n >\n <Link href={item.path}>{item.name}</Link>\n </SidebarMenuButton>\n </SidebarMenuSubItem>\n )\n }\n\n return (\n <SidebarMenuItem>\n <Collapsible className=\"group/collapsible [&[data-state=open]>button>div>svg:first-child]:rotate-90\">\n <CollapsibleTrigger asChild>\n <SidebarMenuButton>\n {item.name}\n <SidebarMenuAction asChild>\n <div>\n <ChevronRight className=\"transition-transform\" />\n <span className=\"sr-only\">Toggle</span>\n </div>\n </SidebarMenuAction>\n </SidebarMenuButton>\n </CollapsibleTrigger>\n <CollapsibleContent>\n <SidebarMenuSub>\n {item.submodules.map(subItem => (\n <NavSubItem key={subItem.id} item={subItem} />\n ))}\n </SidebarMenuSub>\n </CollapsibleContent>\n </Collapsible>\n </SidebarMenuItem>\n )\n}\n"],"names":["NavSubItem","item","SidebarMenuItem","Collapsible","CollapsibleTrigger","SidebarMenuButton","SidebarMenuAction","ChevronRight","CollapsibleContent","SidebarMenuSub","subItem","SidebarMenuSubItem","Link"],"mappings":"4KAqBO,SAASA,EAAW,CAAEC,KAAAA,CAAI,CAAgB,SAC/C,AAAKA,EAAK,UAAU,EAAE,OAcpB,UAACC,EAAAA,eAAeA,CAAAA,C,SACd,WAACC,EAAAA,WAAWA,CAAAA,CAAC,UAAU,8E,UACrB,UAACC,EAAAA,kBAAkBA,CAAAA,CAAC,QAAO,G,SACzB,WAACC,EAAAA,iBAAiBA,CAAAA,C,UACfJ,EAAK,IAAI,CACV,UAACK,EAAAA,iBAAiBA,CAAAA,CAAC,QAAO,G,SACxB,WAAC,O,UACC,UAACC,EAAAA,YAAYA,CAAAA,CAAC,UAAU,sB,GACxB,UAAC,QAAK,UAAU,U,SAAU,Q,aAKlC,UAACC,EAAAA,kBAAkBA,CAAAA,C,SACjB,UAACC,EAAAA,cAAcA,CAAAA,C,SACZR,EAAK,UAAU,CAAC,GAAG,CAACS,AAAAA,GACnB,UAACV,EAAAA,CAA4B,KAAMU,C,EAAlBA,EAAQ,EAAE,E,UA5BnC,UAACC,EAAAA,kBAAkBA,CAAAA,C,SACjB,UAACN,EAAAA,iBAAiBA,CAAAA,CAChB,UAAU,oCACV,QAAO,G,SAEP,UAACO,EAAAA,OAAIA,CAAAA,CAAC,KAAMX,EAAK,IAAI,C,SAAGA,EAAK,IAAI,A,MA8B3C,Q"}
@@ -0,0 +1,7 @@
1
+ import type { User } from '../../types/user';
2
+ interface NavUser {
3
+ user: User;
4
+ }
5
+ export declare function NavUser({ user }: NavUser): import("react/jsx-runtime").JSX.Element;
6
+ export {};
7
+ //# sourceMappingURL=nav-user.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"nav-user.d.ts","sourceRoot":"","sources":["../../../../src/components/sidebar/nav-user.tsx"],"names":[],"mappings":"AAiBA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,cAAc,CAAA;AASxC,UAAU,OAAO;IACf,IAAI,EAAE,IAAI,CAAA;CACX;AAED,wBAAgB,OAAO,CAAC,EAAE,IAAI,EAAE,EAAE,OAAO,2CAiFxC"}
@@ -0,0 +1,3 @@
1
+ 'use client'
2
+ import*as e from"react/jsx-runtime";import*as s from"../dropdown-menu.js";import*as a from"lucide-react";import*as r from"../avatar.js";import*as n from"./intl/messages.js";import*as t from"./sidebar.js";function i({user:i}){let{isMobile:l,lang:d}=(0,t.useSidebar)();return(0,e.jsx)(t.SidebarMenu,{children:(0,e.jsx)(t.SidebarMenuItem,{children:(0,e.jsxs)(s.DropdownMenu,{children:[(0,e.jsx)(s.DropdownMenuTrigger,{asChild:!0,children:(0,e.jsxs)(t.SidebarMenuButton,{size:"lg",className:"data-[state=open]:bg-sidebar-accent data-[state=open]:text-sidebar-accent-foreground",children:[(0,e.jsxs)(r.Avatar,{className:"size-8 rounded-lg group-data-[collapsible=icon]:size-10",children:[(0,e.jsx)(r.AvatarImage,{src:void 0,alt:i.name}),(0,e.jsx)(r.AvatarFallback,{className:"rounded-lg",children:(0,e.jsx)(a.UserRound,{className:"size-4"})})]}),(0,e.jsxs)("div",{className:"grid flex-1 text-left text-sm leading-tight",children:[(0,e.jsx)("span",{className:"truncate font-medium",children:i.name}),(0,e.jsx)("span",{className:"truncate text-gbm-gray text-xs",children:i.email})]}),(0,e.jsx)(a.ChevronsUpDown,{className:"ml-auto size-4"})]})}),(0,e.jsxs)(s.DropdownMenuContent,{className:"w-[--radix-dropdown-menu-trigger-width] min-w-56 rounded-lg",side:l?"bottom":"right",align:"end",sideOffset:4,children:[(0,e.jsx)(s.DropdownMenuLabel,{className:"p-0 font-normal",children:(0,e.jsxs)("div",{className:"flex items-center gap-2 px-1 py-1.5 text-left text-sm",children:[(0,e.jsxs)(r.Avatar,{className:"h-8 w-8 rounded-lg",children:[(0,e.jsx)(r.AvatarImage,{src:void 0,alt:i.name}),(0,e.jsx)(r.AvatarFallback,{className:"rounded-lg",children:(0,e.jsx)(a.UserRound,{className:"size-4"})})]}),(0,e.jsxs)("div",{className:"grid flex-1 text-left text-sm leading-tight",children:[(0,e.jsx)("span",{className:"truncate font-semibold",children:i.name}),(0,e.jsx)("span",{className:"truncate text-xs",children:i.email})]})]})}),(0,e.jsx)(s.DropdownMenuGroup,{children:(0,e.jsxs)(s.DropdownMenuSub,{children:[(0,e.jsxs)(s.DropdownMenuSubTrigger,{children:[(0,e.jsx)(a.Languages,{className:"mr-2 size-4"}),n.default[d].language]}),(0,e.jsxs)(s.DropdownMenuSubContent,{children:[(0,e.jsxs)(s.DropdownMenuItem,{className:"gap-2",children:[(0,e.jsx)("img",{src:"/brazil.svg",alt:""}),"PT-BR"]}),(0,e.jsxs)(s.DropdownMenuItem,{className:"gap-2",children:[(0,e.jsx)("img",{src:"/united-states.svg",alt:""}),"EN-US"]}),(0,e.jsxs)(s.DropdownMenuItem,{className:"gap-2",children:[(0,e.jsx)("img",{src:"/spain.svg",alt:""}),"ES"]})]})]})}),(0,e.jsx)(s.DropdownMenuSeparator,{}),(0,e.jsx)(s.DropdownMenuItem,{asChild:!0,children:(0,e.jsxs)("a",{href:"/api/auth/sign-out",children:[(0,e.jsx)(a.LogOut,{className:"mr-2 size-4"}),n.default[d]["sign-out"]]})})]})]})})})}export{i as NavUser};
3
+ //# sourceMappingURL=nav-user.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"components\\sidebar\\nav-user.js","sources":["webpack://@gbmtech/aurora-ui/./src/components/sidebar/nav-user.tsx"],"sourcesContent":["\n\nimport {\n DropdownMenu,\n DropdownMenuContent,\n DropdownMenuGroup,\n DropdownMenuItem,\n DropdownMenuLabel,\n DropdownMenuSeparator,\n DropdownMenuSub,\n DropdownMenuSubContent,\n DropdownMenuSubTrigger,\n DropdownMenuTrigger,\n} from '@/components/dropdown-menu'\nimport { ChevronsUpDown, Languages, LogOut, UserRound } from 'lucide-react'\n\nimport { Avatar, AvatarFallback, AvatarImage } from '@/components/avatar'\nimport type { User } from '@/types/user'\nimport messages from './intl/messages'\nimport {\n SidebarMenu,\n SidebarMenuButton,\n SidebarMenuItem,\n useSidebar,\n} from './sidebar'\n\ninterface NavUser {\n user: User\n}\n\nexport function NavUser({ user }: NavUser) {\n const { isMobile, lang } = useSidebar()\n\n return (\n <SidebarMenu>\n <SidebarMenuItem>\n <DropdownMenu>\n <DropdownMenuTrigger asChild>\n <SidebarMenuButton\n size=\"lg\"\n className=\"data-[state=open]:bg-sidebar-accent data-[state=open]:text-sidebar-accent-foreground\"\n >\n <Avatar className=\"size-8 rounded-lg group-data-[collapsible=icon]:size-10\">\n <AvatarImage src={undefined} alt={user.name} />\n <AvatarFallback className=\"rounded-lg\">\n <UserRound className=\"size-4\" />\n </AvatarFallback>\n </Avatar>\n <div className=\"grid flex-1 text-left text-sm leading-tight\">\n <span className=\"truncate font-medium\">{user.name}</span>\n <span className=\"truncate text-gbm-gray text-xs\">\n {user.email}\n </span>\n </div>\n <ChevronsUpDown className=\"ml-auto size-4\" />\n </SidebarMenuButton>\n </DropdownMenuTrigger>\n <DropdownMenuContent\n className=\"w-[--radix-dropdown-menu-trigger-width] min-w-56 rounded-lg\"\n side={isMobile ? 'bottom' : 'right'}\n align=\"end\"\n sideOffset={4}\n >\n <DropdownMenuLabel className=\"p-0 font-normal\">\n <div className=\"flex items-center gap-2 px-1 py-1.5 text-left text-sm\">\n <Avatar className=\"h-8 w-8 rounded-lg\">\n <AvatarImage src={undefined} alt={user.name} />\n <AvatarFallback className=\"rounded-lg\">\n <UserRound className=\"size-4\" />\n </AvatarFallback>\n </Avatar>\n <div className=\"grid flex-1 text-left text-sm leading-tight\">\n <span className=\"truncate font-semibold\">{user.name}</span>\n <span className=\"truncate text-xs\">{user.email}</span>\n </div>\n </div>\n </DropdownMenuLabel>\n <DropdownMenuGroup>\n <DropdownMenuSub>\n <DropdownMenuSubTrigger>\n <Languages className=\"mr-2 size-4\" />\n {messages[lang].language}\n </DropdownMenuSubTrigger>\n <DropdownMenuSubContent>\n <DropdownMenuItem className=\"gap-2\">\n <img src=\"/brazil.svg\" alt=\"\" />\n PT-BR\n </DropdownMenuItem>\n <DropdownMenuItem className=\"gap-2\">\n <img src=\"/united-states.svg\" alt=\"\" />\n EN-US\n </DropdownMenuItem>\n <DropdownMenuItem className=\"gap-2\">\n <img src=\"/spain.svg\" alt=\"\" />\n ES\n </DropdownMenuItem>\n </DropdownMenuSubContent>\n </DropdownMenuSub>\n </DropdownMenuGroup>\n <DropdownMenuSeparator />\n <DropdownMenuItem asChild>\n <a href=\"/api/auth/sign-out\">\n <LogOut className=\"mr-2 size-4\" />\n {messages[lang]['sign-out']}\n </a>\n </DropdownMenuItem>\n </DropdownMenuContent>\n </DropdownMenu>\n </SidebarMenuItem>\n </SidebarMenu>\n )\n}\n"],"names":["NavUser","user","isMobile","lang","useSidebar","SidebarMenu","SidebarMenuItem","DropdownMenu","DropdownMenuTrigger","SidebarMenuButton","Avatar","AvatarImage","undefined","AvatarFallback","UserRound","ChevronsUpDown","DropdownMenuContent","DropdownMenuLabel","DropdownMenuGroup","DropdownMenuSub","DropdownMenuSubTrigger","Languages","messages","DropdownMenuSubContent","DropdownMenuItem","DropdownMenuSeparator","LogOut"],"mappings":";4MA8BO,SAASA,EAAQ,CAAEC,KAAAA,CAAI,CAAW,EACvC,GAAM,CAAEC,SAAAA,CAAQ,CAAEC,KAAAA,CAAI,CAAE,CAAGC,GAAAA,EAAAA,UAAAA,IAE3B,MACE,UAACC,EAAAA,WAAWA,CAAAA,C,SACV,UAACC,EAAAA,eAAeA,CAAAA,C,SACd,WAACC,EAAAA,YAAYA,CAAAA,C,UACX,UAACC,EAAAA,mBAAmBA,CAAAA,CAAC,QAAO,G,SAC1B,WAACC,EAAAA,iBAAiBA,CAAAA,CAChB,KAAK,KACL,UAAU,uF,UAEV,WAACC,EAAAA,MAAMA,CAAAA,CAAC,UAAU,0D,UAChB,UAACC,EAAAA,WAAWA,CAAAA,CAAC,IAAKC,KAAAA,EAAW,IAAKX,EAAK,IAAI,GAC3C,UAACY,EAAAA,cAAcA,CAAAA,CAAC,UAAU,a,SACxB,UAACC,EAAAA,SAASA,CAAAA,CAAC,UAAU,Q,QAGzB,WAAC,OAAI,UAAU,8C,UACb,UAAC,QAAK,UAAU,uB,SAAwBb,EAAK,IAAI,GACjD,UAAC,QAAK,UAAU,iC,SACbA,EAAK,KAAK,MAGf,UAACc,EAAAA,cAAcA,CAAAA,CAAC,UAAU,gB,QAG9B,WAACC,EAAAA,mBAAmBA,CAAAA,CAClB,UAAU,8DACV,KAAMd,EAAW,SAAW,QAC5B,MAAM,MACN,WAAY,E,UAEZ,UAACe,EAAAA,iBAAiBA,CAAAA,CAAC,UAAU,kB,SAC3B,WAAC,OAAI,UAAU,wD,UACb,WAACP,EAAAA,MAAMA,CAAAA,CAAC,UAAU,qB,UAChB,UAACC,EAAAA,WAAWA,CAAAA,CAAC,IAAKC,KAAAA,EAAW,IAAKX,EAAK,IAAI,GAC3C,UAACY,EAAAA,cAAcA,CAAAA,CAAC,UAAU,a,SACxB,UAACC,EAAAA,SAASA,CAAAA,CAAC,UAAU,Q,QAGzB,WAAC,OAAI,UAAU,8C,UACb,UAAC,QAAK,UAAU,yB,SAA0Bb,EAAK,IAAI,GACnD,UAAC,QAAK,UAAU,mB,SAAoBA,EAAK,KAAK,WAIpD,UAACiB,EAAAA,iBAAiBA,CAAAA,C,SAChB,WAACC,EAAAA,eAAeA,CAAAA,C,UACd,WAACC,EAAAA,sBAAsBA,CAAAA,C,UACrB,UAACC,EAAAA,SAASA,CAAAA,CAAC,UAAU,a,GACpBC,EAAAA,OAAQ,CAACnB,EAAK,CAAC,QAAQ,C,GAE1B,WAACoB,EAAAA,sBAAsBA,CAAAA,C,UACrB,WAACC,EAAAA,gBAAgBA,CAAAA,CAAC,UAAU,Q,UAC1B,UAAC,OAAI,IAAI,cAAc,IAAI,E,GAAK,Q,GAGlC,WAACA,EAAAA,gBAAgBA,CAAAA,CAAC,UAAU,Q,UAC1B,UAAC,OAAI,IAAI,qBAAqB,IAAI,E,GAAK,Q,GAGzC,WAACA,EAAAA,gBAAgBA,CAAAA,CAAC,UAAU,Q,UAC1B,UAAC,OAAI,IAAI,aAAa,IAAI,E,GAAK,K,WAMvC,UAACC,EAAAA,qBAAqBA,CAAAA,CAAAA,GACtB,UAACD,EAAAA,gBAAgBA,CAAAA,CAAC,QAAO,G,SACvB,WAAC,KAAE,KAAK,qB,UACN,UAACE,EAAAA,MAAMA,CAAAA,CAAC,UAAU,a,GACjBJ,EAAAA,OAAQ,CAACnB,EAAK,CAAC,WAAW,C,cAQ3C,Q"}
@@ -0,0 +1,5 @@
1
+ declare const SidebarIcons: import("react").MemoExoticComponent<({ icon }: {
2
+ icon: string;
3
+ }) => import("react/jsx-runtime").JSX.Element | null>;
4
+ export { SidebarIcons };
5
+ //# sourceMappingURL=sidebar-icons.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sidebar-icons.d.ts","sourceRoot":"","sources":["../../../../src/components/sidebar/sidebar-icons.tsx"],"names":[],"mappings":"AAOA,QAAA,MAAM,YAAY,iDAAmB;IAAE,IAAI,EAAE,MAAM,CAAA;CAAE,oDAmBnD,CAAA;AAEF,OAAO,EAAE,YAAY,EAAE,CAAA"}
@@ -0,0 +1,2 @@
1
+ import*as r from"react/jsx-runtime";import*as m from"lucide-react/dynamic";import*as o from"react";import*as i from"../../lib/dynamic-icon.js";import*as t from"../icons/rumo.js";import*as e from"../icons/vli.js";let s=(0,o.memo)(({icon:o})=>{let s=m.iconNames.find(r=>r===o);if(s)return(0,r.jsx)(i.default,{name:s});let a={Rumo:t.Rumo,VLI:e.VLI}[o];return a?(0,r.jsx)(a,{}):null});export{s as SidebarIcons};
2
+ //# sourceMappingURL=sidebar-icons.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"components\\sidebar\\sidebar-icons.js","sources":["webpack://@gbmtech/aurora-ui/./src/components/sidebar/sidebar-icons.tsx"],"sourcesContent":["import { iconNames } from 'lucide-react/dynamic'\nimport { memo } from 'react'\n\nimport DynamicIcon from '@/lib/dynamic-icon'\nimport { Rumo } from '../icons/rumo'\nimport { VLI } from '../icons/vli'\n\nconst SidebarIcons = memo(({ icon }: { icon: string }) => {\n const lucideIcon = iconNames.find(iconName => iconName === icon)\n\n if (lucideIcon) {\n return <DynamicIcon name={lucideIcon} />\n }\n\n const customIcons = {\n Rumo,\n VLI,\n }\n\n const CustomIcon = customIcons[icon as keyof typeof customIcons]\n\n if (!CustomIcon) {\n return null\n }\n\n return <CustomIcon />\n})\n\nexport { SidebarIcons }\n"],"names":["SidebarIcons","memo","icon","lucideIcon","iconNames","iconName","DynamicIcon","CustomIcon","customIcons","Rumo","VLI"],"mappings":"oNAOA,IAAMA,EAAeC,AAAAA,GAAAA,EAAAA,IAAAA,AAAAA,EAAK,CAAC,CAAEC,KAAAA,CAAI,CAAoB,IACnD,IAAMC,EAAaC,EAAAA,SAAAA,CAAAA,IAAc,CAACC,AAAAA,GAAYA,IAAaH,GAE3D,GAAIC,EACF,MAAO,UAACG,EAAAA,OAAWA,CAAAA,CAAC,KAAMH,C,GAQ5B,IAAMI,EAAaC,AALC,CAClBC,KAAIA,EAAAA,IAAAA,CACJC,IAAGA,EAAAA,GAAAA,AACL,CAE8B,CAACR,EAAiC,QAEhE,AAAKK,EAIE,UAACA,EAAAA,CAAAA,GAHC,IAIX,U"}
@@ -0,0 +1,86 @@
1
+ import * as React from 'react';
2
+ import { VariantProps } from '../../lib';
3
+ import { Button } from '../button';
4
+ import { Separator } from '../separator';
5
+ import { TooltipContent } from '../tooltip';
6
+ type SidebarContextProps = {
7
+ state: 'expanded' | 'collapsed';
8
+ open: boolean;
9
+ setOpen: (open: boolean) => void;
10
+ openMobile: boolean;
11
+ setOpenMobile: (open: boolean) => void;
12
+ isMobile: boolean;
13
+ toggleSidebar: () => void;
14
+ lang: 'pt-br' | 'en-us' | 'es';
15
+ };
16
+ declare function useSidebar(): SidebarContextProps;
17
+ declare function SidebarProvider({ defaultOpen, open: openProp, onOpenChange: setOpenProp, className, style, lang, children, ...props }: React.ComponentProps<'div'> & {
18
+ defaultOpen?: boolean;
19
+ open?: boolean;
20
+ onOpenChange?: (open: boolean) => void;
21
+ lang?: 'pt-br' | 'en-us' | 'es';
22
+ }): import("react/jsx-runtime").JSX.Element;
23
+ declare function Sidebar({ side, variant, collapsible, className, children, ...props }: React.ComponentProps<'div'> & {
24
+ side?: 'left' | 'right';
25
+ variant?: 'sidebar' | 'floating' | 'inset';
26
+ collapsible?: 'offcanvas' | 'icon' | 'none';
27
+ }): import("react/jsx-runtime").JSX.Element;
28
+ declare function SidebarTrigger({ className, onClick, ...props }: React.ComponentProps<typeof Button>): import("react/jsx-runtime").JSX.Element;
29
+ declare function SidebarInset({ className, ...props }: React.ComponentProps<'main'>): import("react/jsx-runtime").JSX.Element;
30
+ declare function SidebarHeader({ className, ...props }: React.ComponentProps<'div'>): import("react/jsx-runtime").JSX.Element;
31
+ declare function SidebarFooter({ className, ...props }: React.ComponentProps<'div'>): import("react/jsx-runtime").JSX.Element;
32
+ declare function SidebarSeparator({ className, ...props }: React.ComponentProps<typeof Separator>): import("react/jsx-runtime").JSX.Element;
33
+ declare function SidebarContent({ className, ...props }: React.ComponentProps<'div'>): import("react/jsx-runtime").JSX.Element;
34
+ declare function SidebarGroup({ className, ...props }: React.ComponentProps<'div'>): import("react/jsx-runtime").JSX.Element;
35
+ declare function SidebarGroupLabel({ className, asChild, ...props }: React.ComponentProps<'div'> & {
36
+ asChild?: boolean;
37
+ }): import("react/jsx-runtime").JSX.Element;
38
+ declare function SidebarMenu({ className, ...props }: React.ComponentProps<'ul'>): import("react/jsx-runtime").JSX.Element;
39
+ declare function SidebarMenuItem({ className, ...props }: React.ComponentProps<'li'>): import("react/jsx-runtime").JSX.Element;
40
+ declare const sidebarMenuButtonVariants: import("tailwind-variants").TVReturnType<{
41
+ variant: {
42
+ default: string;
43
+ outline: string;
44
+ };
45
+ size: {
46
+ default: string;
47
+ sm: string;
48
+ lg: string;
49
+ };
50
+ }, undefined, "peer/menu-button flex w-full items-center gap-2 overflow-hidden rounded-md p-2 text-left text-sm outline-hidden ring-sidebar-ring transition-[width,height,padding] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 active:bg-sidebar-accent active:text-sidebar-accent-foreground disabled:pointer-events-none disabled:opacity-50 group-has-data-[sidebar=menu-action]/menu-item:pr-8 aria-disabled:pointer-events-none aria-disabled:opacity-50 data-[active=true]:bg-sidebar-accent data-[active=true]:font-medium data-[active=true]:text-sidebar-accent-foreground data-[state=open]:hover:bg-sidebar-accent data-[state=open]:hover:text-sidebar-accent-foreground group-data-[collapsible=icon]:size-10! group-data-[collapsible=icon]:p-2.5! group-data-[collapsible=icon]:gap-3 [&>span:last-child]:truncate [&>svg]:size-4 [&>svg]:shrink-0 group-data-[collapsible=icon]:[&>svg]:size-5", {
51
+ variant: {
52
+ default: string;
53
+ outline: string;
54
+ };
55
+ size: {
56
+ default: string;
57
+ sm: string;
58
+ lg: string;
59
+ };
60
+ }, undefined, import("tailwind-variants").TVReturnType<{
61
+ variant: {
62
+ default: string;
63
+ outline: string;
64
+ };
65
+ size: {
66
+ default: string;
67
+ sm: string;
68
+ lg: string;
69
+ };
70
+ }, undefined, "peer/menu-button flex w-full items-center gap-2 overflow-hidden rounded-md p-2 text-left text-sm outline-hidden ring-sidebar-ring transition-[width,height,padding] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 active:bg-sidebar-accent active:text-sidebar-accent-foreground disabled:pointer-events-none disabled:opacity-50 group-has-data-[sidebar=menu-action]/menu-item:pr-8 aria-disabled:pointer-events-none aria-disabled:opacity-50 data-[active=true]:bg-sidebar-accent data-[active=true]:font-medium data-[active=true]:text-sidebar-accent-foreground data-[state=open]:hover:bg-sidebar-accent data-[state=open]:hover:text-sidebar-accent-foreground group-data-[collapsible=icon]:size-10! group-data-[collapsible=icon]:p-2.5! group-data-[collapsible=icon]:gap-3 [&>span:last-child]:truncate [&>svg]:size-4 [&>svg]:shrink-0 group-data-[collapsible=icon]:[&>svg]:size-5", unknown, unknown, undefined>>;
71
+ declare function SidebarMenuButton({ asChild, isActive, variant, size, tooltip, className, ...props }: React.ComponentProps<'button'> & {
72
+ asChild?: boolean;
73
+ isActive?: boolean;
74
+ tooltip?: string | React.ComponentProps<typeof TooltipContent>;
75
+ } & VariantProps<typeof sidebarMenuButtonVariants>): import("react/jsx-runtime").JSX.Element;
76
+ declare function SidebarMenuAction({ className, asChild, showOnHover, ...props }: React.ComponentProps<'button'> & {
77
+ asChild?: boolean;
78
+ showOnHover?: boolean;
79
+ }): import("react/jsx-runtime").JSX.Element;
80
+ declare function SidebarMenuSkeleton({ className, showIcon, ...props }: React.ComponentProps<'div'> & {
81
+ showIcon?: boolean;
82
+ }): import("react/jsx-runtime").JSX.Element;
83
+ declare function SidebarMenuSub({ className, ...props }: React.ComponentProps<'ul'>): import("react/jsx-runtime").JSX.Element;
84
+ declare function SidebarMenuSubItem({ className, ...props }: React.ComponentProps<'li'>): import("react/jsx-runtime").JSX.Element;
85
+ export { Sidebar, SidebarContent, SidebarFooter, SidebarGroup, SidebarGroupLabel, SidebarHeader, SidebarInset, SidebarMenu, SidebarMenuAction, SidebarMenuButton, SidebarMenuItem, SidebarMenuSkeleton, SidebarMenuSub, SidebarMenuSubItem, SidebarProvider, SidebarSeparator, SidebarTrigger, useSidebar, };
86
+ //# sourceMappingURL=sidebar.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sidebar.d.ts","sourceRoot":"","sources":["../../../../src/components/sidebar/sidebar.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ 'use client'
2
+ import*as e from"react/jsx-runtime";import*as a from"@radix-ui/react-slot";import*as t from"react";import*as r from"../../hooks/use-mobile.js";import*as i from"../../lib/index.js";import*as s from"lucide-react";import*as d from"../button.js";import*as n from"../separator.js";import*as o from"../sheet/index.js";import*as l from"../skeleton.js";import*as c from"../tooltip.js";let u=t.createContext(null);function b(){let e=t.useContext(u);if(!e)throw Error("useSidebar must be used within a SidebarProvider.");return e}function p({defaultOpen:a=!0,open:s,onOpenChange:d,className:n,style:o,lang:l="pt-br",children:b,...p}){let m=(0,r.useIsMobile)(),[f,g]=t.useState(!1),[h,x]=t.useState(a),v=s??h,w=t.useCallback(e=>{let a="function"==typeof e?e(v):e;d?d(a):x(a),document.cookie=`gbm_sidebar_open=${a}; path=/; max-age=604800`},[d,v]),j=t.useCallback(()=>m?g(e=>!e):w(e=>!e),[m,w,g]);t.useEffect(()=>{let e=e=>{"b"===e.key&&(e.metaKey||e.ctrlKey)&&(e.preventDefault(),j())};return window.addEventListener("keydown",e),()=>window.removeEventListener("keydown",e)},[j]);let S=v?"expanded":"collapsed",N=t.useMemo(()=>({state:S,open:v,setOpen:w,isMobile:m,openMobile:f,setOpenMobile:g,toggleSidebar:j,lang:l}),[S,v,w,m,f,g,j]);return(0,e.jsx)(u.Provider,{value:N,children:(0,e.jsx)(c.TooltipProvider,{delayDuration:0,children:(0,e.jsx)("div",{"data-slot":"sidebar-wrapper",style:{"--sidebar-width":"16rem","--sidebar-width-icon":"4.5rem",...o},className:(0,i.cn)("group/sidebar-wrapper flex min-h-svh w-full has-data-[variant=inset]:bg-sidebar",n),...p,children:b})})})}function m({side:a="left",variant:t="sidebar",collapsible:r="icon",className:s,children:d,...n}){let{isMobile:l,state:c,openMobile:u,setOpenMobile:p}=b();return"none"===r?(0,e.jsx)("div",{"data-slot":"sidebar",className:(0,i.cn)("flex h-full w-(--sidebar-width) flex-col bg-sidebar text-sidebar-foreground",s),...n,children:d}):l?(0,e.jsx)(o.Sheet,{open:u,onOpenChange:p,...n,children:(0,e.jsxs)(o.SheetContent,{"data-sidebar":"sidebar","data-slot":"sidebar","data-mobile":"true",className:"w-(--sidebar-width) bg-sidebar p-0 text-sidebar-foreground [&>button]:hidden",style:{"--sidebar-width":"18rem"},side:a,children:[(0,e.jsxs)(o.SheetHeader,{className:"sr-only",children:[(0,e.jsx)(o.SheetTitle,{children:"Sidebar"}),(0,e.jsx)(o.SheetDescription,{children:"Displays the mobile sidebar."})]}),(0,e.jsx)("div",{className:"flex h-full w-full flex-col",children:d})]})}):(0,e.jsxs)("div",{className:"group peer hidden text-sidebar-foreground md:block","data-state":c,"data-collapsible":"collapsed"===c?r:"","data-variant":t,"data-side":a,"data-slot":"sidebar",children:[(0,e.jsx)("div",{"data-slot":"sidebar-gap",className:(0,i.cn)("relative w-(--sidebar-width) bg-transparent transition-[width] duration-200 ease-linear","group-data-[collapsible=offcanvas]:w-0","group-data-[side=right]:rotate-180","floating"===t||"inset"===t?"group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4)))]":"group-data-[collapsible=icon]:w-(--sidebar-width-icon)")}),(0,e.jsx)("div",{"data-slot":"sidebar-container",className:(0,i.cn)("fixed inset-y-0 z-10 hidden h-svh w-(--sidebar-width) transition-[left,right,width] duration-200 ease-linear md:flex","left"===a?"left-0 group-data-[collapsible=offcanvas]:left-[calc(var(--sidebar-width)*-1)]":"right-0 group-data-[collapsible=offcanvas]:right-[calc(var(--sidebar-width)*-1)]","floating"===t||"inset"===t?"p-2 group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4))+2px)]":"group-data-[collapsible=icon]:w-(--sidebar-width-icon) group-data-[side=left]:border-r group-data-[side=right]:border-l",s),...n,children:(0,e.jsx)("div",{"data-sidebar":"sidebar","data-slot":"sidebar-inner",className:"flex h-full w-full flex-col bg-sidebar group-data-[variant=floating]:rounded-lg group-data-[variant=floating]:border group-data-[variant=floating]:border-sidebar-border group-data-[variant=floating]:shadow-sm",children:d})})]})}function f({className:a,onClick:t,...r}){let{toggleSidebar:n}=b();return(0,e.jsxs)(d.Button,{"data-sidebar":"trigger","data-slot":"sidebar-trigger",variant:"ghost",size:"icon",className:(0,i.cn)("size-7",a),onClick:e=>{t?.(e),n()},...r,children:[(0,e.jsx)(s.PanelLeftIcon,{}),(0,e.jsx)("span",{className:"sr-only",children:"Toggle Sidebar"})]})}function g({className:a,...t}){return(0,e.jsx)("main",{"data-slot":"sidebar-inset",className:(0,i.cn)("relative flex w-full flex-1 flex-col bg-background","md:peer-data-[variant=inset]:peer-data-[state=collapsed]:ml-2 md:peer-data-[variant=inset]:m-2 md:peer-data-[variant=inset]:ml-0 md:peer-data-[variant=inset]:rounded-xl md:peer-data-[variant=inset]:shadow-sm",a),...t})}function h({className:a,...t}){return(0,e.jsx)("div",{"data-slot":"sidebar-header","data-sidebar":"header",className:(0,i.cn)("flex flex-col gap-2 p-5 group-data-[collapsible=icon]:p-4",a),...t})}function x({className:a,...t}){return(0,e.jsx)("div",{"data-slot":"sidebar-footer","data-sidebar":"footer",className:(0,i.cn)("flex flex-col gap-2 p-5 group-data-[collapsible=icon]:p-4",a),...t})}function v({className:a,...t}){return(0,e.jsx)(n.Separator,{"data-slot":"sidebar-separator","data-sidebar":"separator",className:(0,i.cn)("mx-2 w-auto bg-sidebar-border",a),...t})}function w({className:a,...t}){return(0,e.jsx)("div",{"data-slot":"sidebar-content","data-sidebar":"content",className:(0,i.cn)("flex min-h-0 flex-1 flex-col gap-2 overflow-y-auto group-data-[collapsible=icon]:overflow-hidden",a),...t})}function j({className:a,...t}){return(0,e.jsx)("div",{"data-slot":"sidebar-group","data-sidebar":"group",className:(0,i.cn)("relative flex w-full min-w-0 flex-col px-5 group-data-[collapsible=icon]:p-4",a),...t})}function S({className:t,asChild:r=!1,...s}){let d=r?a.Slot:"div";return(0,e.jsx)(d,{"data-slot":"sidebar-group-label","data-sidebar":"group-label",className:(0,i.cn)("flex h-8 shrink-0 items-center rounded-md px-2 font-medium text-sidebar-foreground/70 text-xs outline-hidden ring-sidebar-ring transition-[margin,opacity] duration-200 ease-linear focus-visible:ring-2 [&>svg]:size-4 [&>svg]:shrink-0","group-data-[collapsible=icon]:-mt-8 group-data-[collapsible=icon]:opacity-0",t),...s})}function N({className:a,...t}){return(0,e.jsx)("ul",{"data-slot":"sidebar-menu","data-sidebar":"menu",className:(0,i.cn)("flex w-full min-w-0 flex-col gap-1",a),...t})}function y({className:a,...t}){return(0,e.jsx)("li",{"data-slot":"sidebar-menu-item","data-sidebar":"menu-item",className:(0,i.cn)("group/menu-item relative",a),...t})}let k=(0,i.tv)({base:"peer/menu-button flex w-full items-center gap-2 overflow-hidden rounded-md p-2 text-left text-sm outline-hidden ring-sidebar-ring transition-[width,height,padding] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 active:bg-sidebar-accent active:text-sidebar-accent-foreground disabled:pointer-events-none disabled:opacity-50 group-has-data-[sidebar=menu-action]/menu-item:pr-8 aria-disabled:pointer-events-none aria-disabled:opacity-50 data-[active=true]:bg-sidebar-accent data-[active=true]:font-medium data-[active=true]:text-sidebar-accent-foreground data-[state=open]:hover:bg-sidebar-accent data-[state=open]:hover:text-sidebar-accent-foreground group-data-[collapsible=icon]:size-10! group-data-[collapsible=icon]:p-2.5! group-data-[collapsible=icon]:gap-3 [&>span:last-child]:truncate [&>svg]:size-4 [&>svg]:shrink-0 group-data-[collapsible=icon]:[&>svg]:size-5",variants:{variant:{default:"hover:bg-sidebar-accent hover:text-sidebar-accent-foreground",outline:"bg-background shadow-[0_0_0_1px_hsl(var(--sidebar-border))] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground hover:shadow-[0_0_0_1px_hsl(var(--sidebar-accent))]"},size:{default:"text-sm",sm:"h-7 text-xs",lg:"h-12 text-sm group-data-[collapsible=icon]:p-0!"}},defaultVariants:{variant:"default",size:"default"}});function z({asChild:t=!1,isActive:r=!1,variant:s="default",size:d="default",tooltip:n,className:o,...l}){let u=t?a.Slot:"button",{isMobile:p,state:m}=b(),f=(0,e.jsx)(u,{"data-slot":"sidebar-menu-button","data-sidebar":"menu-button","data-size":d,"data-active":r,className:(0,i.cn)(k({variant:s,size:d}),o),...l});return n?("string"==typeof n&&(n={children:n}),(0,e.jsxs)(c.Tooltip,{children:[(0,e.jsx)(c.TooltipTrigger,{asChild:!0,children:f}),(0,e.jsx)(c.TooltipContent,{side:"right",align:"center",hidden:"collapsed"!==m||p,...n})]})):f}function M({className:t,asChild:r=!1,showOnHover:s=!1,...d}){let n=r?a.Slot:"button";return(0,e.jsx)(n,{"data-slot":"sidebar-menu-action","data-sidebar":"menu-action",className:(0,i.cn)("absolute top-1.5 right-1 flex aspect-square w-5 items-center justify-center rounded-md p-0 text-sidebar-foreground outline-hidden ring-sidebar-ring transition-transform hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 peer-hover/menu-button:text-sidebar-accent-foreground [&>svg]:size-4 [&>svg]:shrink-0","after:-inset-2 after:absolute md:after:hidden","peer-data-[size=sm]/menu-button:top-1","peer-data-[size=default]/menu-button:top-1.5","peer-data-[size=lg]/menu-button:top-2.5","group-data-[collapsible=icon]:hidden",s&&"group-focus-within/menu-item:opacity-100 group-hover/menu-item:opacity-100 data-[state=open]:opacity-100 peer-data-[active=true]/menu-button:text-sidebar-accent-foreground md:opacity-0",t),...d})}function C({className:a,showIcon:r=!1,...s}){let d=t.useMemo(()=>`${Math.floor(40*Math.random())+50}%`,[]);return(0,e.jsxs)("div",{"data-slot":"sidebar-menu-skeleton","data-sidebar":"menu-skeleton",className:(0,i.cn)("flex h-8 items-center gap-2 rounded-md px-2",a),...s,children:[r&&(0,e.jsx)(l.Skeleton,{className:"size-4 rounded-md","data-sidebar":"menu-skeleton-icon"}),(0,e.jsx)(l.Skeleton,{className:"h-4 max-w-(--skeleton-width) flex-1","data-sidebar":"menu-skeleton-text",style:{"--skeleton-width":d}})]})}function _({className:a,...t}){return(0,e.jsx)("ul",{"data-slot":"sidebar-menu-sub","data-sidebar":"menu-sub",className:(0,i.cn)("ml-3.5 flex min-w-0 translate-x-px flex-col gap-1 border-sidebar-border border-l py-0.5 pl-2.5","group-data-[collapsible=icon]:hidden",a),...t})}function T({className:a,...t}){return(0,e.jsx)("li",{"data-slot":"sidebar-menu-sub-item","data-sidebar":"menu-sub-item",className:(0,i.cn)("group/menu-sub-item relative",a),...t})}export{m as Sidebar,w as SidebarContent,x as SidebarFooter,j as SidebarGroup,S as SidebarGroupLabel,h as SidebarHeader,g as SidebarInset,N as SidebarMenu,M as SidebarMenuAction,z as SidebarMenuButton,y as SidebarMenuItem,C as SidebarMenuSkeleton,_ as SidebarMenuSub,T as SidebarMenuSubItem,p as SidebarProvider,v as SidebarSeparator,f as SidebarTrigger,b as useSidebar};
3
+ //# sourceMappingURL=sidebar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"components\\sidebar\\sidebar.js","sources":["webpack://@gbmtech/aurora-ui/./src/components/sidebar/sidebar.tsx"],"sourcesContent":["\n\nimport { Slot } from '@radix-ui/react-slot'\nimport * as React from 'react'\n\nimport { useIsMobile } from '@/hooks/use-mobile'\nimport { VariantProps, cn, tv } from '@/lib'\nimport { PanelLeftIcon } from 'lucide-react'\nimport { Button } from '../button'\nimport { Separator } from '../separator'\nimport {\n Sheet,\n SheetContent,\n SheetDescription,\n SheetHeader,\n SheetTitle,\n} from '../sheet'\nimport { Skeleton } from '../skeleton'\nimport {\n Tooltip,\n TooltipContent,\n TooltipProvider,\n TooltipTrigger,\n} from '../tooltip'\n\nconst SIDEBAR_COOKIE_NAME = 'gbm_sidebar_open'\nconst SIDEBAR_COOKIE_MAX_AGE = 60 * 60 * 24 * 7\nconst SIDEBAR_WIDTH = '16rem'\nconst SIDEBAR_WIDTH_MOBILE = '18rem'\nconst SIDEBAR_WIDTH_ICON = '4.5rem'\nconst SIDEBAR_KEYBOARD_SHORTCUT = 'b'\n\ntype SidebarContextProps = {\n state: 'expanded' | 'collapsed'\n open: boolean\n setOpen: (open: boolean) => void\n openMobile: boolean\n setOpenMobile: (open: boolean) => void\n isMobile: boolean\n toggleSidebar: () => void\n lang: 'pt-br' | 'en-us' | 'es'\n}\n\nconst SidebarContext = React.createContext<SidebarContextProps | null>(null)\n\nfunction useSidebar() {\n const context = React.useContext(SidebarContext)\n if (!context) {\n throw new Error('useSidebar must be used within a SidebarProvider.')\n }\n\n return context\n}\n\nfunction SidebarProvider({\n defaultOpen = true,\n open: openProp,\n onOpenChange: setOpenProp,\n className,\n style,\n lang = 'pt-br',\n children,\n ...props\n}: React.ComponentProps<'div'> & {\n defaultOpen?: boolean\n open?: boolean\n onOpenChange?: (open: boolean) => void\n lang?: 'pt-br' | 'en-us' | 'es'\n}) {\n const isMobile = useIsMobile()\n const [openMobile, setOpenMobile] = React.useState(false)\n\n // This is the internal state of the sidebar.\n // We use openProp and setOpenProp for control from outside the component.\n const [_open, _setOpen] = React.useState(defaultOpen)\n const open = openProp ?? _open\n const setOpen = React.useCallback(\n (value: boolean | ((value: boolean) => boolean)) => {\n const openState = typeof value === 'function' ? value(open) : value\n if (setOpenProp) {\n setOpenProp(openState)\n } else {\n _setOpen(openState)\n }\n\n // This sets the cookie to keep the sidebar state.\n document.cookie = `${SIDEBAR_COOKIE_NAME}=${openState}; path=/; max-age=${SIDEBAR_COOKIE_MAX_AGE}`\n },\n [setOpenProp, open]\n )\n\n // Helper to toggle the sidebar.\n const toggleSidebar = React.useCallback(() => {\n return isMobile ? setOpenMobile(open => !open) : setOpen(open => !open)\n }, [isMobile, setOpen, setOpenMobile])\n\n // Adds a keyboard shortcut to toggle the sidebar.\n React.useEffect(() => {\n const handleKeyDown = (event: KeyboardEvent) => {\n if (\n event.key === SIDEBAR_KEYBOARD_SHORTCUT &&\n (event.metaKey || event.ctrlKey)\n ) {\n event.preventDefault()\n toggleSidebar()\n }\n }\n\n window.addEventListener('keydown', handleKeyDown)\n return () => window.removeEventListener('keydown', handleKeyDown)\n }, [toggleSidebar])\n\n // We add a state so that we can do data-state=\"expanded\" or \"collapsed\".\n // This makes it easier to style the sidebar with Tailwind classes.\n const state = open ? 'expanded' : 'collapsed'\n\n const contextValue = React.useMemo<SidebarContextProps>(\n () => ({\n state,\n open,\n setOpen,\n isMobile,\n openMobile,\n setOpenMobile,\n toggleSidebar,\n lang,\n }),\n [state, open, setOpen, isMobile, openMobile, setOpenMobile, toggleSidebar]\n )\n\n return (\n <SidebarContext.Provider value={contextValue}>\n <TooltipProvider delayDuration={0}>\n <div\n data-slot=\"sidebar-wrapper\"\n style={\n {\n '--sidebar-width': SIDEBAR_WIDTH,\n '--sidebar-width-icon': SIDEBAR_WIDTH_ICON,\n ...style,\n } as React.CSSProperties\n }\n className={cn(\n 'group/sidebar-wrapper flex min-h-svh w-full has-data-[variant=inset]:bg-sidebar',\n className\n )}\n {...props}\n >\n {children}\n </div>\n </TooltipProvider>\n </SidebarContext.Provider>\n )\n}\n\nfunction Sidebar({\n side = 'left',\n variant = 'sidebar',\n collapsible = 'icon',\n className,\n children,\n ...props\n}: React.ComponentProps<'div'> & {\n side?: 'left' | 'right'\n variant?: 'sidebar' | 'floating' | 'inset'\n collapsible?: 'offcanvas' | 'icon' | 'none'\n}) {\n const { isMobile, state, openMobile, setOpenMobile } = useSidebar()\n\n if (collapsible === 'none') {\n return (\n <div\n data-slot=\"sidebar\"\n className={cn(\n 'flex h-full w-(--sidebar-width) flex-col bg-sidebar text-sidebar-foreground',\n className\n )}\n {...props}\n >\n {children}\n </div>\n )\n }\n\n if (isMobile) {\n return (\n <Sheet open={openMobile} onOpenChange={setOpenMobile} {...props}>\n <SheetContent\n data-sidebar=\"sidebar\"\n data-slot=\"sidebar\"\n data-mobile=\"true\"\n className=\"w-(--sidebar-width) bg-sidebar p-0 text-sidebar-foreground [&>button]:hidden\"\n style={\n {\n '--sidebar-width': SIDEBAR_WIDTH_MOBILE,\n } as React.CSSProperties\n }\n side={side}\n >\n <SheetHeader className=\"sr-only\">\n <SheetTitle>Sidebar</SheetTitle>\n <SheetDescription>Displays the mobile sidebar.</SheetDescription>\n </SheetHeader>\n <div className=\"flex h-full w-full flex-col\">{children}</div>\n </SheetContent>\n </Sheet>\n )\n }\n\n return (\n <div\n className=\"group peer hidden text-sidebar-foreground md:block\"\n data-state={state}\n data-collapsible={state === 'collapsed' ? collapsible : ''}\n data-variant={variant}\n data-side={side}\n data-slot=\"sidebar\"\n >\n {/* This is what handles the sidebar gap on desktop */}\n <div\n data-slot=\"sidebar-gap\"\n className={cn(\n 'relative w-(--sidebar-width) bg-transparent transition-[width] duration-200 ease-linear',\n 'group-data-[collapsible=offcanvas]:w-0',\n 'group-data-[side=right]:rotate-180',\n variant === 'floating' || variant === 'inset'\n ? 'group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4)))]'\n : 'group-data-[collapsible=icon]:w-(--sidebar-width-icon)'\n )}\n />\n <div\n data-slot=\"sidebar-container\"\n className={cn(\n 'fixed inset-y-0 z-10 hidden h-svh w-(--sidebar-width) transition-[left,right,width] duration-200 ease-linear md:flex',\n side === 'left'\n ? 'left-0 group-data-[collapsible=offcanvas]:left-[calc(var(--sidebar-width)*-1)]'\n : 'right-0 group-data-[collapsible=offcanvas]:right-[calc(var(--sidebar-width)*-1)]',\n // Adjust the padding for floating and inset variants.\n variant === 'floating' || variant === 'inset'\n ? 'p-2 group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4))+2px)]'\n : 'group-data-[collapsible=icon]:w-(--sidebar-width-icon) group-data-[side=left]:border-r group-data-[side=right]:border-l',\n className\n )}\n {...props}\n >\n <div\n data-sidebar=\"sidebar\"\n data-slot=\"sidebar-inner\"\n className=\"flex h-full w-full flex-col bg-sidebar group-data-[variant=floating]:rounded-lg group-data-[variant=floating]:border group-data-[variant=floating]:border-sidebar-border group-data-[variant=floating]:shadow-sm\"\n >\n {children}\n </div>\n </div>\n </div>\n )\n}\n\nfunction SidebarTrigger({\n className,\n onClick,\n ...props\n}: React.ComponentProps<typeof Button>) {\n const { toggleSidebar } = useSidebar()\n\n return (\n <Button\n data-sidebar=\"trigger\"\n data-slot=\"sidebar-trigger\"\n variant=\"ghost\"\n size=\"icon\"\n className={cn('size-7', className)}\n onClick={event => {\n onClick?.(event)\n toggleSidebar()\n }}\n {...props}\n >\n <PanelLeftIcon />\n <span className=\"sr-only\">Toggle Sidebar</span>\n </Button>\n )\n}\n\nfunction SidebarInset({ className, ...props }: React.ComponentProps<'main'>) {\n return (\n <main\n data-slot=\"sidebar-inset\"\n className={cn(\n 'relative flex w-full flex-1 flex-col bg-background',\n 'md:peer-data-[variant=inset]:peer-data-[state=collapsed]:ml-2 md:peer-data-[variant=inset]:m-2 md:peer-data-[variant=inset]:ml-0 md:peer-data-[variant=inset]:rounded-xl md:peer-data-[variant=inset]:shadow-sm',\n className\n )}\n {...props}\n />\n )\n}\n\nfunction SidebarHeader({ className, ...props }: React.ComponentProps<'div'>) {\n return (\n <div\n data-slot=\"sidebar-header\"\n data-sidebar=\"header\"\n className={cn(\n 'flex flex-col gap-2 p-5 group-data-[collapsible=icon]:p-4',\n className\n )}\n {...props}\n />\n )\n}\n\nfunction SidebarFooter({ className, ...props }: React.ComponentProps<'div'>) {\n return (\n <div\n data-slot=\"sidebar-footer\"\n data-sidebar=\"footer\"\n className={cn(\n 'flex flex-col gap-2 p-5 group-data-[collapsible=icon]:p-4',\n className\n )}\n {...props}\n />\n )\n}\n\nfunction SidebarSeparator({\n className,\n ...props\n}: React.ComponentProps<typeof Separator>) {\n return (\n <Separator\n data-slot=\"sidebar-separator\"\n data-sidebar=\"separator\"\n className={cn('mx-2 w-auto bg-sidebar-border', className)}\n {...props}\n />\n )\n}\n\nfunction SidebarContent({ className, ...props }: React.ComponentProps<'div'>) {\n return (\n <div\n data-slot=\"sidebar-content\"\n data-sidebar=\"content\"\n className={cn(\n 'flex min-h-0 flex-1 flex-col gap-2 overflow-y-auto group-data-[collapsible=icon]:overflow-hidden',\n className\n )}\n {...props}\n />\n )\n}\n\nfunction SidebarGroup({ className, ...props }: React.ComponentProps<'div'>) {\n return (\n <div\n data-slot=\"sidebar-group\"\n data-sidebar=\"group\"\n className={cn(\n 'relative flex w-full min-w-0 flex-col px-5 group-data-[collapsible=icon]:p-4',\n className\n )}\n {...props}\n />\n )\n}\n\nfunction SidebarGroupLabel({\n className,\n asChild = false,\n ...props\n}: React.ComponentProps<'div'> & { asChild?: boolean }) {\n const Comp = asChild ? Slot : 'div'\n\n return (\n <Comp\n data-slot=\"sidebar-group-label\"\n data-sidebar=\"group-label\"\n className={cn(\n 'flex h-8 shrink-0 items-center rounded-md px-2 font-medium text-sidebar-foreground/70 text-xs outline-hidden ring-sidebar-ring transition-[margin,opacity] duration-200 ease-linear focus-visible:ring-2 [&>svg]:size-4 [&>svg]:shrink-0',\n 'group-data-[collapsible=icon]:-mt-8 group-data-[collapsible=icon]:opacity-0',\n className\n )}\n {...props}\n />\n )\n}\n\nfunction SidebarMenu({ className, ...props }: React.ComponentProps<'ul'>) {\n return (\n <ul\n data-slot=\"sidebar-menu\"\n data-sidebar=\"menu\"\n className={cn('flex w-full min-w-0 flex-col gap-1', className)}\n {...props}\n />\n )\n}\n\nfunction SidebarMenuItem({ className, ...props }: React.ComponentProps<'li'>) {\n return (\n <li\n data-slot=\"sidebar-menu-item\"\n data-sidebar=\"menu-item\"\n className={cn('group/menu-item relative', className)}\n {...props}\n />\n )\n}\n\nconst sidebarMenuButtonVariants = tv({\n base: 'peer/menu-button flex w-full items-center gap-2 overflow-hidden rounded-md p-2 text-left text-sm outline-hidden ring-sidebar-ring transition-[width,height,padding] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 active:bg-sidebar-accent active:text-sidebar-accent-foreground disabled:pointer-events-none disabled:opacity-50 group-has-data-[sidebar=menu-action]/menu-item:pr-8 aria-disabled:pointer-events-none aria-disabled:opacity-50 data-[active=true]:bg-sidebar-accent data-[active=true]:font-medium data-[active=true]:text-sidebar-accent-foreground data-[state=open]:hover:bg-sidebar-accent data-[state=open]:hover:text-sidebar-accent-foreground group-data-[collapsible=icon]:size-10! group-data-[collapsible=icon]:p-2.5! group-data-[collapsible=icon]:gap-3 [&>span:last-child]:truncate [&>svg]:size-4 [&>svg]:shrink-0 group-data-[collapsible=icon]:[&>svg]:size-5',\n variants: {\n variant: {\n default: 'hover:bg-sidebar-accent hover:text-sidebar-accent-foreground',\n outline:\n 'bg-background shadow-[0_0_0_1px_hsl(var(--sidebar-border))] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground hover:shadow-[0_0_0_1px_hsl(var(--sidebar-accent))]',\n },\n size: {\n default: 'text-sm',\n sm: 'h-7 text-xs',\n lg: 'h-12 text-sm group-data-[collapsible=icon]:p-0!',\n },\n },\n defaultVariants: {\n variant: 'default',\n size: 'default',\n },\n})\n\nfunction SidebarMenuButton({\n asChild = false,\n isActive = false,\n variant = 'default',\n size = 'default',\n tooltip,\n className,\n ...props\n}: React.ComponentProps<'button'> & {\n asChild?: boolean\n isActive?: boolean\n tooltip?: string | React.ComponentProps<typeof TooltipContent>\n} & VariantProps<typeof sidebarMenuButtonVariants>) {\n const Comp = asChild ? Slot : 'button'\n const { isMobile, state } = useSidebar()\n\n const button = (\n <Comp\n data-slot=\"sidebar-menu-button\"\n data-sidebar=\"menu-button\"\n data-size={size}\n data-active={isActive}\n className={cn(sidebarMenuButtonVariants({ variant, size }), className)}\n {...props}\n />\n )\n\n if (!tooltip) {\n return button\n }\n\n if (typeof tooltip === 'string') {\n tooltip = {\n children: tooltip,\n }\n }\n\n return (\n <Tooltip>\n <TooltipTrigger asChild>{button}</TooltipTrigger>\n <TooltipContent\n side=\"right\"\n align=\"center\"\n hidden={state !== 'collapsed' || isMobile}\n {...tooltip}\n />\n </Tooltip>\n )\n}\n\nfunction SidebarMenuAction({\n className,\n asChild = false,\n showOnHover = false,\n ...props\n}: React.ComponentProps<'button'> & {\n asChild?: boolean\n showOnHover?: boolean\n}) {\n const Comp = asChild ? Slot : 'button'\n\n return (\n <Comp\n data-slot=\"sidebar-menu-action\"\n data-sidebar=\"menu-action\"\n className={cn(\n 'absolute top-1.5 right-1 flex aspect-square w-5 items-center justify-center rounded-md p-0 text-sidebar-foreground outline-hidden ring-sidebar-ring transition-transform hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 peer-hover/menu-button:text-sidebar-accent-foreground [&>svg]:size-4 [&>svg]:shrink-0',\n // Increases the hit area of the button on mobile.\n 'after:-inset-2 after:absolute md:after:hidden',\n 'peer-data-[size=sm]/menu-button:top-1',\n 'peer-data-[size=default]/menu-button:top-1.5',\n 'peer-data-[size=lg]/menu-button:top-2.5',\n 'group-data-[collapsible=icon]:hidden',\n showOnHover &&\n 'group-focus-within/menu-item:opacity-100 group-hover/menu-item:opacity-100 data-[state=open]:opacity-100 peer-data-[active=true]/menu-button:text-sidebar-accent-foreground md:opacity-0',\n className\n )}\n {...props}\n />\n )\n}\n\nfunction SidebarMenuSkeleton({\n className,\n showIcon = false,\n ...props\n}: React.ComponentProps<'div'> & {\n showIcon?: boolean\n}) {\n // Random width between 50 to 90%.\n const width = React.useMemo(() => {\n return `${Math.floor(Math.random() * 40) + 50}%`\n }, [])\n\n return (\n <div\n data-slot=\"sidebar-menu-skeleton\"\n data-sidebar=\"menu-skeleton\"\n className={cn('flex h-8 items-center gap-2 rounded-md px-2', className)}\n {...props}\n >\n {showIcon && (\n <Skeleton\n className=\"size-4 rounded-md\"\n data-sidebar=\"menu-skeleton-icon\"\n />\n )}\n <Skeleton\n className=\"h-4 max-w-(--skeleton-width) flex-1\"\n data-sidebar=\"menu-skeleton-text\"\n style={\n {\n '--skeleton-width': width,\n } as React.CSSProperties\n }\n />\n </div>\n )\n}\n\nfunction SidebarMenuSub({ className, ...props }: React.ComponentProps<'ul'>) {\n return (\n <ul\n data-slot=\"sidebar-menu-sub\"\n data-sidebar=\"menu-sub\"\n className={cn(\n 'ml-3.5 flex min-w-0 translate-x-px flex-col gap-1 border-sidebar-border border-l py-0.5 pl-2.5',\n 'group-data-[collapsible=icon]:hidden',\n className\n )}\n {...props}\n />\n )\n}\n\nfunction SidebarMenuSubItem({\n className,\n ...props\n}: React.ComponentProps<'li'>) {\n return (\n <li\n data-slot=\"sidebar-menu-sub-item\"\n data-sidebar=\"menu-sub-item\"\n className={cn('group/menu-sub-item relative', className)}\n {...props}\n />\n )\n}\n\nexport {\n Sidebar,\n SidebarContent,\n SidebarFooter,\n SidebarGroup,\n SidebarGroupLabel,\n SidebarHeader,\n SidebarInset,\n SidebarMenu,\n SidebarMenuAction,\n SidebarMenuButton,\n SidebarMenuItem,\n SidebarMenuSkeleton,\n SidebarMenuSub,\n SidebarMenuSubItem,\n SidebarProvider,\n SidebarSeparator,\n SidebarTrigger,\n useSidebar,\n}\n"],"names":["SidebarContext","React","useSidebar","context","Error","SidebarProvider","defaultOpen","openProp","setOpenProp","className","style","lang","children","props","isMobile","useIsMobile","openMobile","setOpenMobile","_open","_setOpen","open","setOpen","value","openState","document","toggleSidebar","handleKeyDown","event","window","state","contextValue","TooltipProvider","cn","Sidebar","side","variant","collapsible","Sheet","SheetContent","SheetHeader","SheetTitle","SheetDescription","SidebarTrigger","onClick","Button","PanelLeftIcon","SidebarInset","SidebarHeader","SidebarFooter","SidebarSeparator","Separator","SidebarContent","SidebarGroup","SidebarGroupLabel","asChild","Comp","Slot","SidebarMenu","SidebarMenuItem","sidebarMenuButtonVariants","tv","SidebarMenuButton","isActive","size","tooltip","button","Tooltip","TooltipTrigger","TooltipContent","SidebarMenuAction","showOnHover","SidebarMenuSkeleton","showIcon","width","Math","Skeleton","SidebarMenuSub","SidebarMenuSubItem"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export declare function useIsMobile(): boolean;
2
+ //# sourceMappingURL=use-mobile.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-mobile.d.ts","sourceRoot":"","sources":["../../../src/hooks/use-mobile.ts"],"names":[],"mappings":"AAIA,wBAAgB,WAAW,YAc1B"}
@@ -0,0 +1,2 @@
1
+ import*as e from"react";function t(){let[t,n]=(0,e.useState)(void 0);return(0,e.useEffect)(()=>{let e=window.matchMedia("(max-width: 767px)"),t=()=>{n(window.innerWidth<768)};return e.addEventListener("change",t),n(window.innerWidth<768),()=>e.removeEventListener("change",t)},[]),!!t}export{t as useIsMobile};
2
+ //# sourceMappingURL=use-mobile.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hooks\\use-mobile.js","sources":["webpack://@gbmtech/aurora-ui/./src/hooks/use-mobile.ts"],"sourcesContent":["import { useEffect, useState } from 'react'\n\nconst MOBILE_BREAKPOINT = 768\n\nexport function useIsMobile() {\n const [isMobile, setIsMobile] = useState<boolean | undefined>(undefined)\n\n useEffect(() => {\n const mql = window.matchMedia(`(max-width: ${MOBILE_BREAKPOINT - 1}px)`)\n const onChange = () => {\n setIsMobile(window.innerWidth < MOBILE_BREAKPOINT)\n }\n mql.addEventListener('change', onChange)\n setIsMobile(window.innerWidth < MOBILE_BREAKPOINT)\n return () => mql.removeEventListener('change', onChange)\n }, [])\n\n return !!isMobile\n}\n"],"names":["useIsMobile","isMobile","setIsMobile","useState","undefined","useEffect","mql","window","onChange"],"mappings":"wBAIO,SAASA,IACd,GAAM,CAACC,EAAUC,EAAY,CAAGC,AAAAA,GAAAA,EAAAA,QAAAA,AAAAA,EAA8BC,KAAAA,GAY9D,MAVAC,AAAAA,GAAAA,EAAAA,SAAAA,AAAAA,EAAU,KACR,IAAMC,EAAMC,OAAO,UAAU,CAAC,sBACxBC,EAAW,KACfN,EAAYK,OAAO,UAAU,CART,IAStB,EAGA,OAFAD,EAAI,gBAAgB,CAAC,SAAUE,GAC/BN,EAAYK,OAAO,UAAU,CAXP,KAYf,IAAMD,EAAI,mBAAmB,CAAC,SAAUE,EACjD,EAAG,EAAE,EAEE,CAAC,CAACP,CACX,Q"}
@@ -39,6 +39,7 @@ export * from './components/sheet';
39
39
  export * from './components/command';
40
40
  export * from './components/popover';
41
41
  export * from './components/autocomplete';
42
+ export * from './components/sidebar';
42
43
  export * from './utils/phosphor-icon-map';
43
44
  export * from './lib/utils';
44
45
  export * from './lib/format';
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AACA,cAAc,2BAA2B,CAAA;AACzC,cAAc,qBAAqB,CAAA;AACnC,cAAc,qBAAqB,CAAA;AACnC,cAAc,6BAA6B,CAAA;AAC3C,cAAc,oBAAoB,CAAA;AAClC,cAAc,0BAA0B,CAAA;AACxC,cAAc,sBAAsB,CAAA;AACpC,cAAc,qBAAqB,CAAA;AACnC,cAAc,oBAAoB,CAAA;AAClC,cAAc,uBAAuB,CAAA;AACrC,cAAc,yBAAyB,CAAA;AACvC,cAAc,mBAAmB,CAAA;AACjC,cAAc,mBAAmB,CAAA;AACjC,cAAc,4BAA4B,CAAA;AAC1C,cAAc,2BAA2B,CAAA;AACzC,cAAc,qBAAqB,CAAA;AACnC,cAAc,oBAAoB,CAAA;AAClC,cAAc,+BAA+B,CAAA;AAC7C,cAAc,uBAAuB,CAAA;AACrC,cAAc,uBAAuB,CAAA;AACrC,cAAc,0BAA0B,CAAA;AACxC,cAAc,qCAAqC,CAAA;AACnD,cAAc,+BAA+B,CAAA;AAC7C,cAAc,0CAA0C,CAAA;AACxD,cAAc,oBAAoB,CAAA;AAClC,cAAc,0BAA0B,CAAA;AACxC,cAAc,yBAAyB,CAAA;AACvC,cAAc,uBAAuB,CAAA;AACrC,cAAc,wBAAwB,CAAA;AACtC,cAAc,wBAAwB,CAAA;AACtC,cAAc,uBAAuB,CAAA;AACrC,cAAc,yBAAyB,CAAA;AACvC,cAAc,0BAA0B,CAAA;AACxC,cAAc,yBAAyB,CAAA;AACvC,cAAc,sBAAsB,CAAA;AACpC,cAAc,0BAA0B,CAAA;AACxC,cAAc,2BAA2B,CAAA;AACzC,cAAc,oBAAoB,CAAA;AAClC,cAAc,sBAAsB,CAAA;AACpC,cAAc,sBAAsB,CAAA;AACpC,cAAc,2BAA2B,CAAA;AAEzC,cAAc,2BAA2B,CAAA;AACzC,cAAc,aAAa,CAAA;AAC3B,cAAc,cAAc,CAAA;AAE5B,cAAc,wBAAwB,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AACA,cAAc,2BAA2B,CAAA;AACzC,cAAc,qBAAqB,CAAA;AACnC,cAAc,qBAAqB,CAAA;AACnC,cAAc,6BAA6B,CAAA;AAC3C,cAAc,oBAAoB,CAAA;AAClC,cAAc,0BAA0B,CAAA;AACxC,cAAc,sBAAsB,CAAA;AACpC,cAAc,qBAAqB,CAAA;AACnC,cAAc,oBAAoB,CAAA;AAClC,cAAc,uBAAuB,CAAA;AACrC,cAAc,yBAAyB,CAAA;AACvC,cAAc,mBAAmB,CAAA;AACjC,cAAc,mBAAmB,CAAA;AACjC,cAAc,4BAA4B,CAAA;AAC1C,cAAc,2BAA2B,CAAA;AACzC,cAAc,qBAAqB,CAAA;AACnC,cAAc,oBAAoB,CAAA;AAClC,cAAc,+BAA+B,CAAA;AAC7C,cAAc,uBAAuB,CAAA;AACrC,cAAc,uBAAuB,CAAA;AACrC,cAAc,0BAA0B,CAAA;AACxC,cAAc,qCAAqC,CAAA;AACnD,cAAc,+BAA+B,CAAA;AAC7C,cAAc,0CAA0C,CAAA;AACxD,cAAc,oBAAoB,CAAA;AAClC,cAAc,0BAA0B,CAAA;AACxC,cAAc,yBAAyB,CAAA;AACvC,cAAc,uBAAuB,CAAA;AACrC,cAAc,wBAAwB,CAAA;AACtC,cAAc,wBAAwB,CAAA;AACtC,cAAc,uBAAuB,CAAA;AACrC,cAAc,yBAAyB,CAAA;AACvC,cAAc,0BAA0B,CAAA;AACxC,cAAc,yBAAyB,CAAA;AACvC,cAAc,sBAAsB,CAAA;AACpC,cAAc,0BAA0B,CAAA;AACxC,cAAc,2BAA2B,CAAA;AACzC,cAAc,oBAAoB,CAAA;AAClC,cAAc,sBAAsB,CAAA;AACpC,cAAc,sBAAsB,CAAA;AACpC,cAAc,2BAA2B,CAAA;AACzC,cAAc,sBAAsB,CAAA;AAEpC,cAAc,2BAA2B,CAAA;AACzC,cAAc,aAAa,CAAA;AAC3B,cAAc,cAAc,CAAA;AAE5B,cAAc,wBAAwB,CAAA"}
package/dist/esm/index.js CHANGED
@@ -1 +1 @@
1
- export*from"./components/alert-dialog.js";export*from"./components/dialog.js";export*from"./components/button.js";export*from"./components/input-password.js";export*from"./components/input.js";export*from"./components/tokens-grid.js";export*from"./components/tooltip.js";export*from"./components/switch.js";export*from"./components/label.js";export*from"./components/checkbox.js";export*from"./components/breadcrumb.js";export*from"./components/tabs/index.js";export*from"./components/form.js";export*from"./components/dropdown-menu.js";export*from"./components/multi-select.js";export*from"./components/select.js";export*from"./components/table.js";export*from"./components/table-expandable.js";export*from"./components/textarea.js";export*from"./components/calendar.js";export*from"./components/date-picker.js";export*from"./components/date-picker-with-range.js";export*from"./components/date-time-picker.js";export*from"./components/date-time-picker-with-range.js";export*from"./components/title.js";export*from"./components/page-layout/index.js";export*from"./components/pagination.js";export*from"./components/skeleton.js";export*from"./components/separator.js";export*from"./components/input-otp.js";export*from"./components/combobox.js";export*from"./components/mask-input.js";export*from"./components/scroll-area.js";export*from"./components/data-table/index.js";export*from"./components/spinner.js";export*from"./components/radio-group.js";export*from"./components/context-menu.js";export*from"./components/sheet/index.js";export*from"./components/command.js";export*from"./components/popover.js";export*from"./components/autocomplete/index.js";export*from"./utils/phosphor-icon-map.js";export*from"./lib/utils.js";export*from"./lib/format.js";export*from"./hooks/use-data-table.js";
1
+ export*from"./components/alert-dialog.js";export*from"./components/dialog.js";export*from"./components/button.js";export*from"./components/input-password.js";export*from"./components/input.js";export*from"./components/tokens-grid.js";export*from"./components/tooltip.js";export*from"./components/switch.js";export*from"./components/label.js";export*from"./components/checkbox.js";export*from"./components/breadcrumb.js";export*from"./components/tabs/index.js";export*from"./components/form.js";export*from"./components/dropdown-menu.js";export*from"./components/multi-select.js";export*from"./components/select.js";export*from"./components/table.js";export*from"./components/table-expandable.js";export*from"./components/textarea.js";export*from"./components/calendar.js";export*from"./components/date-picker.js";export*from"./components/date-picker-with-range.js";export*from"./components/date-time-picker.js";export*from"./components/date-time-picker-with-range.js";export*from"./components/title.js";export*from"./components/page-layout/index.js";export*from"./components/pagination.js";export*from"./components/skeleton.js";export*from"./components/separator.js";export*from"./components/input-otp.js";export*from"./components/combobox.js";export*from"./components/mask-input.js";export*from"./components/scroll-area.js";export*from"./components/data-table/index.js";export*from"./components/spinner.js";export*from"./components/radio-group.js";export*from"./components/context-menu.js";export*from"./components/sheet/index.js";export*from"./components/command.js";export*from"./components/popover.js";export*from"./components/autocomplete/index.js";export*from"./components/sidebar/index.js";export*from"./utils/phosphor-icon-map.js";export*from"./lib/utils.js";export*from"./lib/format.js";export*from"./hooks/use-data-table.js";
@@ -0,0 +1,9 @@
1
+ import dynamicIconImports from 'lucide-react/dynamicIconImports';
2
+ type IconName = keyof typeof dynamicIconImports;
3
+ type DynamicIconProps = {
4
+ name: IconName;
5
+ className?: string;
6
+ };
7
+ declare const DynamicIcon: import("react").MemoExoticComponent<({ name, ...props }: DynamicIconProps) => import("react/jsx-runtime").JSX.Element | null>;
8
+ export default DynamicIcon;
9
+ //# sourceMappingURL=dynamic-icon.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dynamic-icon.d.ts","sourceRoot":"","sources":["../../../src/lib/dynamic-icon.tsx"],"names":[],"mappings":"AACA,OAAO,kBAAkB,MAAM,iCAAiC,CAAA;AAIhE,KAAK,QAAQ,GAAG,MAAM,OAAO,kBAAkB,CAAA;AAY/C,KAAK,gBAAgB,GAAG;IACtB,IAAI,EAAE,QAAQ,CAAA;IACd,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB,CAAA;AAED,QAAA,MAAM,WAAW,2DAA6B,gBAAgB,oDAM5D,CAAA;AAEF,eAAe,WAAW,CAAA"}
@@ -0,0 +1,3 @@
1
+ 'use client'
2
+ import*as t from"react/jsx-runtime";import*as e from"lucide-react/dynamicIconImports";import*as r from"next/dynamic";import*as a from"react";let m=Object.keys(e.default),o={};for(let t of m){let a=(0,r.default)(e.default[t]);o[t]=a}let l=(0,a.memo)(({name:e,...r})=>{let a=o[e];return a?(0,t.jsx)(a,{...r}):null});export{l as default};
3
+ //# sourceMappingURL=dynamic-icon.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lib\\dynamic-icon.js","sources":["webpack://@gbmtech/aurora-ui/./src/lib/dynamic-icon.tsx"],"sourcesContent":["\nimport dynamicIconImports from 'lucide-react/dynamicIconImports'\nimport dynamic from 'next/dynamic'\nimport { type FC, memo } from 'react'\n\ntype IconName = keyof typeof dynamicIconImports\n\nconst icons = Object.keys(dynamicIconImports) as IconName[]\n\ntype ReactComponent = FC<{ className?: string }>\nconst icons_components = {} as Record<IconName, ReactComponent>\n\nfor (const name of icons) {\n const NewIcon = dynamic(dynamicIconImports[name]) as ReactComponent\n icons_components[name] = NewIcon\n}\n\ntype DynamicIconProps = {\n name: IconName\n className?: string\n}\n\nconst DynamicIcon = memo(({ name, ...props }: DynamicIconProps) => {\n const Icon = icons_components[name]\n\n if (!Icon) return null\n\n return <Icon {...props} />\n})\n\nexport default DynamicIcon\n"],"names":["icons","Object","dynamicIconImports","icons_components","name","NewIcon","dynamic","memo","props","Icon"],"mappings":";6IAOA,IAAMA,EAAQC,OAAO,IAAI,CAACC,EAAAA,OAAkBA,EAGtCC,EAAmB,CAAC,EAE1B,IAAK,IAAMC,KAAQJ,EAAO,CACxB,IAAMK,EAAUC,GAAAA,EAAAA,OAAAA,EAAQJ,EAAAA,OAAkB,CAACE,EAAK,CAChDD,CAAAA,CAAgB,CAACC,EAAK,CAAGC,CAC3B,CAeA,MARoBE,GAAAA,EAAAA,IAAAA,EAAK,CAAC,CAAEH,KAAAA,CAAI,CAAE,GAAGI,EAAyB,IAC5D,IAAMC,EAAON,CAAgB,CAACC,EAAK,QAEnC,EAEO,UAACK,EAAAA,CAAM,GAAGD,CAAK,GAFJ,IAGpB,U"}
@@ -1,2 +1,4 @@
1
1
  export * from './data-table';
2
+ export * from './module';
3
+ export * from './user';
2
4
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/types/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/types/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAA;AAC5B,cAAc,UAAU,CAAA;AACxB,cAAc,QAAQ,CAAA"}
@@ -1 +1 @@
1
- export*from"./data-table.js";
1
+ export*from"./data-table.js";export*from"./module.js";export*from"./user.js";
@@ -0,0 +1,13 @@
1
+ export interface Module {
2
+ id: number;
3
+ name: string;
4
+ icon: string;
5
+ order: number;
6
+ read: boolean;
7
+ create: boolean;
8
+ edit: boolean;
9
+ delete: boolean;
10
+ path: string;
11
+ submodules: Module[];
12
+ }
13
+ //# sourceMappingURL=module.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"module.d.ts","sourceRoot":"","sources":["../../../src/types/module.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,MAAM;IACrB,EAAE,EAAE,MAAM,CAAA;IACV,IAAI,EAAE,MAAM,CAAA;IACZ,IAAI,EAAE,MAAM,CAAA;IACZ,KAAK,EAAE,MAAM,CAAA;IACb,IAAI,EAAE,OAAO,CAAA;IACb,MAAM,EAAE,OAAO,CAAA;IACf,IAAI,EAAE,OAAO,CAAA;IACb,MAAM,EAAE,OAAO,CAAA;IACf,IAAI,EAAE,MAAM,CAAA;IACZ,UAAU,EAAE,MAAM,EAAE,CAAA;CACrB"}
File without changes
@@ -0,0 +1,13 @@
1
+ export interface User {
2
+ id: number;
3
+ name: string;
4
+ email: string;
5
+ username: string;
6
+ groupId: number;
7
+ createdAt: string;
8
+ updatedAt: string;
9
+ isActive: boolean;
10
+ type: string;
11
+ multiTerminal: boolean;
12
+ }
13
+ //# sourceMappingURL=user.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"user.d.ts","sourceRoot":"","sources":["../../../src/types/user.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,IAAI;IACnB,EAAE,EAAE,MAAM,CAAA;IACV,IAAI,EAAE,MAAM,CAAA;IACZ,KAAK,EAAE,MAAM,CAAA;IACb,QAAQ,EAAE,MAAM,CAAA;IAChB,OAAO,EAAE,MAAM,CAAA;IACf,SAAS,EAAE,MAAM,CAAA;IACjB,SAAS,EAAE,MAAM,CAAA;IACjB,QAAQ,EAAE,OAAO,CAAA;IACjB,IAAI,EAAE,MAAM,CAAA;IACZ,aAAa,EAAE,OAAO,CAAA;CACvB"}
File without changes
@@ -32,6 +32,10 @@
32
32
  -moz-appearance: textfield;
33
33
  }
34
34
  }
35
+
36
+ .lucide {
37
+ stroke-width: 1.25;
38
+ }
35
39
  }
36
40
 
37
41
  /**
@@ -180,7 +184,17 @@
180
184
  --color-purple-700: #4d2180;
181
185
  --color-purple-800: #351856;
182
186
  --color-purple-900: #2a1440;
187
+
188
+ --color-sidebar: #ffffff;
189
+ --color-sidebar-foreground: oklch(0.145 0 0);
190
+ --color-sidebar-primary: oklch(0.205 0 0);
191
+ --color-sidebar-primary-foreground: oklch(0.985 0 0);
192
+ --color-sidebar-accent: oklch(0.97 0 0);
193
+ --color-sidebar-accent-foreground: oklch(0.205 0 0);
194
+ --color-sidebar-border: oklch(0.922 0 0);
195
+ --color-sidebar-ring: oklch(0.708 0 0);
183
196
  }
197
+
184
198
  /**
185
199
  * Keyframe Animations
186
200
  * -----------------------------------------------------------------------------