@makolabs/ripple 0.0.1-dev.3 → 0.0.1-dev.31

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 (116) hide show
  1. package/README.md +571 -98
  2. package/dist/button/Button.svelte +48 -0
  3. package/dist/button/Button.svelte.d.ts +4 -0
  4. package/dist/button/button.d.ts +113 -0
  5. package/dist/button/button.js +168 -0
  6. package/dist/charts/Chart.svelte +543 -0
  7. package/dist/charts/Chart.svelte.d.ts +4 -0
  8. package/dist/drawer/Drawer.svelte +224 -0
  9. package/dist/drawer/Drawer.svelte.d.ts +4 -0
  10. package/dist/drawer/drawer.d.ts +160 -0
  11. package/dist/drawer/drawer.js +80 -0
  12. package/dist/elements/alert/Alert.svelte +57 -0
  13. package/dist/elements/alert/Alert.svelte.d.ts +4 -0
  14. package/dist/elements/badge/Badge.svelte +43 -0
  15. package/dist/elements/badge/Badge.svelte.d.ts +4 -0
  16. package/dist/elements/badge/badge.d.ts +181 -0
  17. package/dist/elements/badge/badge.js +65 -0
  18. package/dist/elements/dropdown/Dropdown.svelte +267 -0
  19. package/dist/elements/dropdown/Dropdown.svelte.d.ts +4 -0
  20. package/dist/elements/dropdown/Select.svelte +314 -0
  21. package/dist/elements/dropdown/Select.svelte.d.ts +4 -0
  22. package/dist/elements/dropdown/dropdown.d.ts +251 -0
  23. package/dist/elements/dropdown/dropdown.js +95 -0
  24. package/dist/elements/dropdown/select.d.ts +200 -0
  25. package/dist/elements/dropdown/select.js +82 -0
  26. package/dist/elements/file-upload/FileUpload.svelte +130 -0
  27. package/dist/elements/file-upload/FileUpload.svelte.d.ts +4 -0
  28. package/dist/elements/file-upload/FilesPreview.svelte +93 -0
  29. package/dist/elements/file-upload/FilesPreview.svelte.d.ts +4 -0
  30. package/dist/elements/progress/Progress.svelte +145 -0
  31. package/dist/elements/progress/Progress.svelte.d.ts +4 -0
  32. package/dist/elements/timeline/Timeline.svelte +92 -0
  33. package/dist/elements/timeline/Timeline.svelte.d.ts +7 -0
  34. package/dist/forms/Checkbox.svelte +54 -0
  35. package/dist/forms/Checkbox.svelte.d.ts +4 -0
  36. package/dist/forms/DateRange.svelte +493 -0
  37. package/dist/forms/DateRange.svelte.d.ts +4 -0
  38. package/dist/forms/Form.svelte +39 -0
  39. package/dist/forms/Form.svelte.d.ts +4 -0
  40. package/dist/forms/Input.svelte +86 -0
  41. package/dist/forms/Input.svelte.d.ts +4 -0
  42. package/dist/forms/NumberInput.svelte +159 -0
  43. package/dist/forms/NumberInput.svelte.d.ts +4 -0
  44. package/dist/forms/RadioInputs.svelte +64 -0
  45. package/dist/forms/RadioInputs.svelte.d.ts +4 -0
  46. package/dist/forms/RadioPill.svelte +66 -0
  47. package/dist/forms/RadioPill.svelte.d.ts +4 -0
  48. package/dist/forms/Slider.svelte +342 -0
  49. package/dist/forms/Slider.svelte.d.ts +4 -0
  50. package/dist/forms/Tags.svelte +181 -0
  51. package/dist/forms/Tags.svelte.d.ts +4 -0
  52. package/dist/forms/Toggle.svelte +132 -0
  53. package/dist/forms/Toggle.svelte.d.ts +4 -0
  54. package/dist/forms/slider.d.ts +143 -0
  55. package/dist/forms/slider.js +62 -0
  56. package/dist/header/Breadcrumbs.svelte +73 -0
  57. package/dist/header/Breadcrumbs.svelte.d.ts +4 -0
  58. package/dist/header/PageHeader.svelte +30 -0
  59. package/dist/header/PageHeader.svelte.d.ts +4 -0
  60. package/dist/header/breadcrumbs.d.ts +226 -0
  61. package/dist/header/breadcrumbs.js +87 -0
  62. package/dist/helper/cls.d.ts +1 -0
  63. package/dist/helper/cls.js +4 -0
  64. package/dist/helper/date.d.ts +7 -0
  65. package/dist/helper/date.js +15 -0
  66. package/dist/helper/nav.svelte.d.ts +6 -0
  67. package/dist/helper/nav.svelte.js +23 -0
  68. package/dist/index.d.ts +731 -1
  69. package/dist/index.js +70 -1
  70. package/dist/layout/card/Card.svelte +41 -0
  71. package/dist/layout/card/Card.svelte.d.ts +4 -0
  72. package/dist/layout/card/StatsCard.svelte +266 -0
  73. package/dist/layout/card/StatsCard.svelte.d.ts +4 -0
  74. package/dist/layout/card/card.d.ts +128 -0
  75. package/dist/layout/card/card.js +51 -0
  76. package/dist/layout/card/stats-card.d.ts +191 -0
  77. package/dist/layout/card/stats-card.js +73 -0
  78. package/dist/layout/navbar/Navbar.svelte +206 -0
  79. package/dist/layout/navbar/Navbar.svelte.d.ts +4 -0
  80. package/dist/layout/navbar/navbar.d.ts +205 -0
  81. package/dist/layout/navbar/navbar.js +98 -0
  82. package/dist/layout/sidebar/NavGroup.svelte +97 -0
  83. package/dist/layout/sidebar/NavGroup.svelte.d.ts +4 -0
  84. package/dist/layout/sidebar/NavItem.svelte +29 -0
  85. package/dist/layout/sidebar/NavItem.svelte.d.ts +4 -0
  86. package/dist/layout/sidebar/Sidebar.svelte +139 -0
  87. package/dist/layout/sidebar/Sidebar.svelte.d.ts +4 -0
  88. package/dist/layout/table/Cells.svelte +111 -0
  89. package/dist/layout/table/Cells.svelte.d.ts +27 -0
  90. package/dist/layout/table/Table.svelte +413 -0
  91. package/dist/layout/table/Table.svelte.d.ts +4 -0
  92. package/dist/layout/table/table.d.ts +284 -0
  93. package/dist/layout/table/table.js +141 -0
  94. package/dist/layout/tabs/Tab.svelte +57 -0
  95. package/dist/layout/tabs/Tab.svelte.d.ts +4 -0
  96. package/dist/layout/tabs/TabContent.svelte +31 -0
  97. package/dist/layout/tabs/TabContent.svelte.d.ts +4 -0
  98. package/dist/layout/tabs/TabGroup.svelte +57 -0
  99. package/dist/layout/tabs/TabGroup.svelte.d.ts +4 -0
  100. package/dist/layout/tabs/tabs.d.ts +155 -0
  101. package/dist/layout/tabs/tabs.js +156 -0
  102. package/dist/modal/Modal.svelte +207 -0
  103. package/dist/modal/Modal.svelte.d.ts +4 -0
  104. package/dist/modal/modal.d.ts +211 -0
  105. package/dist/modal/modal.js +81 -0
  106. package/dist/sonner/sonner.svelte +13 -0
  107. package/dist/sonner/sonner.svelte.d.ts +4 -0
  108. package/dist/types/variants.d.ts +1 -0
  109. package/dist/types/variants.js +1 -0
  110. package/dist/variants.d.ts +30 -0
  111. package/dist/variants.js +36 -0
  112. package/package.json +104 -102
  113. package/dist/layout/Card.svelte +0 -179
  114. package/dist/layout/Card.svelte.d.ts +0 -208
  115. package/dist/layout/index.d.ts +0 -1
  116. package/dist/layout/index.js +0 -1
@@ -0,0 +1,191 @@
1
+ import { Color } from '../../variants.js';
2
+ export declare const statsCard: import("tailwind-variants").TVReturnType<{
3
+ color: {
4
+ [Color.DEFAULT]: {
5
+ label: string;
6
+ value: string;
7
+ trend: string;
8
+ previousValue: string;
9
+ };
10
+ [Color.PRIMARY]: {
11
+ label: string;
12
+ value: string;
13
+ trend: string;
14
+ previousValue: string;
15
+ };
16
+ [Color.SECONDARY]: {
17
+ label: string;
18
+ value: string;
19
+ trend: string;
20
+ previousValue: string;
21
+ };
22
+ [Color.INFO]: {
23
+ label: string;
24
+ value: string;
25
+ trend: string;
26
+ previousValue: string;
27
+ };
28
+ [Color.SUCCESS]: {
29
+ label: string;
30
+ value: string;
31
+ trend: string;
32
+ previousValue: string;
33
+ };
34
+ [Color.WARNING]: {
35
+ label: string;
36
+ value: string;
37
+ trend: string;
38
+ previousValue: string;
39
+ };
40
+ [Color.DANGER]: {
41
+ label: string;
42
+ value: string;
43
+ trend: string;
44
+ previousValue: string;
45
+ };
46
+ };
47
+ trendDirection: {
48
+ up: {
49
+ trend: string;
50
+ };
51
+ down: {
52
+ trend: string;
53
+ };
54
+ neutral: {
55
+ trend: string;
56
+ };
57
+ };
58
+ }, {
59
+ base: string;
60
+ label: string;
61
+ value: string;
62
+ trend: string;
63
+ previousValue: string;
64
+ unit: string;
65
+ }, undefined, {
66
+ color: {
67
+ [Color.DEFAULT]: {
68
+ label: string;
69
+ value: string;
70
+ trend: string;
71
+ previousValue: string;
72
+ };
73
+ [Color.PRIMARY]: {
74
+ label: string;
75
+ value: string;
76
+ trend: string;
77
+ previousValue: string;
78
+ };
79
+ [Color.SECONDARY]: {
80
+ label: string;
81
+ value: string;
82
+ trend: string;
83
+ previousValue: string;
84
+ };
85
+ [Color.INFO]: {
86
+ label: string;
87
+ value: string;
88
+ trend: string;
89
+ previousValue: string;
90
+ };
91
+ [Color.SUCCESS]: {
92
+ label: string;
93
+ value: string;
94
+ trend: string;
95
+ previousValue: string;
96
+ };
97
+ [Color.WARNING]: {
98
+ label: string;
99
+ value: string;
100
+ trend: string;
101
+ previousValue: string;
102
+ };
103
+ [Color.DANGER]: {
104
+ label: string;
105
+ value: string;
106
+ trend: string;
107
+ previousValue: string;
108
+ };
109
+ };
110
+ trendDirection: {
111
+ up: {
112
+ trend: string;
113
+ };
114
+ down: {
115
+ trend: string;
116
+ };
117
+ neutral: {
118
+ trend: string;
119
+ };
120
+ };
121
+ }, {
122
+ base: string;
123
+ label: string;
124
+ value: string;
125
+ trend: string;
126
+ previousValue: string;
127
+ unit: string;
128
+ }, import("tailwind-variants").TVReturnType<{
129
+ color: {
130
+ [Color.DEFAULT]: {
131
+ label: string;
132
+ value: string;
133
+ trend: string;
134
+ previousValue: string;
135
+ };
136
+ [Color.PRIMARY]: {
137
+ label: string;
138
+ value: string;
139
+ trend: string;
140
+ previousValue: string;
141
+ };
142
+ [Color.SECONDARY]: {
143
+ label: string;
144
+ value: string;
145
+ trend: string;
146
+ previousValue: string;
147
+ };
148
+ [Color.INFO]: {
149
+ label: string;
150
+ value: string;
151
+ trend: string;
152
+ previousValue: string;
153
+ };
154
+ [Color.SUCCESS]: {
155
+ label: string;
156
+ value: string;
157
+ trend: string;
158
+ previousValue: string;
159
+ };
160
+ [Color.WARNING]: {
161
+ label: string;
162
+ value: string;
163
+ trend: string;
164
+ previousValue: string;
165
+ };
166
+ [Color.DANGER]: {
167
+ label: string;
168
+ value: string;
169
+ trend: string;
170
+ previousValue: string;
171
+ };
172
+ };
173
+ trendDirection: {
174
+ up: {
175
+ trend: string;
176
+ };
177
+ down: {
178
+ trend: string;
179
+ };
180
+ neutral: {
181
+ trend: string;
182
+ };
183
+ };
184
+ }, {
185
+ base: string;
186
+ label: string;
187
+ value: string;
188
+ trend: string;
189
+ previousValue: string;
190
+ unit: string;
191
+ }, undefined, unknown, unknown, undefined>>;
@@ -0,0 +1,73 @@
1
+ import { tv } from 'tailwind-variants';
2
+ import { Color } from '../../variants.js';
3
+ export const statsCard = tv({
4
+ slots: {
5
+ base: '',
6
+ label: '',
7
+ value: '',
8
+ trend: '',
9
+ previousValue: '',
10
+ unit: '',
11
+ },
12
+ variants: {
13
+ color: {
14
+ [Color.DEFAULT]: {
15
+ label: 'text-default-500',
16
+ value: 'text-default-900',
17
+ trend: 'text-default-600',
18
+ previousValue: 'text-default-500'
19
+ },
20
+ [Color.PRIMARY]: {
21
+ label: 'text-primary-500',
22
+ value: 'text-primary-600',
23
+ trend: 'text-primary-600',
24
+ previousValue: 'text-primary-400'
25
+ },
26
+ [Color.SECONDARY]: {
27
+ label: 'text-secondary-500',
28
+ value: 'text-secondary-600',
29
+ trend: 'text-secondary-600',
30
+ previousValue: 'text-secondary-400'
31
+ },
32
+ [Color.INFO]: {
33
+ label: 'text-info-500',
34
+ value: 'text-info-600',
35
+ trend: 'text-info-600',
36
+ previousValue: 'text-info-400'
37
+ },
38
+ [Color.SUCCESS]: {
39
+ label: 'text-success-500',
40
+ value: 'text-success-600',
41
+ trend: 'text-success-600',
42
+ previousValue: 'text-success-400'
43
+ },
44
+ [Color.WARNING]: {
45
+ label: 'text-warning-500',
46
+ value: 'text-warning-600',
47
+ trend: 'text-warning-600',
48
+ previousValue: 'text-warning-400'
49
+ },
50
+ [Color.DANGER]: {
51
+ label: 'text-danger-500',
52
+ value: 'text-danger-600',
53
+ trend: 'text-danger-600',
54
+ previousValue: 'text-danger-400'
55
+ }
56
+ },
57
+ trendDirection: {
58
+ up: {
59
+ trend: 'text-success-600'
60
+ },
61
+ down: {
62
+ trend: 'text-danger-600'
63
+ },
64
+ neutral: {
65
+ trend: 'text-default-600'
66
+ }
67
+ }
68
+ },
69
+ defaultVariants: {
70
+ color: Color.DEFAULT,
71
+ trendDirection: 'neutral'
72
+ }
73
+ });
@@ -0,0 +1,206 @@
1
+ <script lang="ts">
2
+ import { cn } from '../../helper/cls.js';
3
+ import { navbar, type NavbarProps } from './navbar.js';
4
+ import { onNavigate } from '$app/navigation';
5
+ import { isRouteActive } from '../../helper/nav.svelte.js';
6
+ import { slide } from 'svelte/transition';
7
+
8
+ let { logo, links = [], class: className = '', brand, children, actions }: NavbarProps = $props();
9
+
10
+ let mobileMenuOpen = $state(false);
11
+ let scrolled = $state(false);
12
+ let isScrollingDown = $state(false);
13
+
14
+ onNavigate(() => {
15
+ mobileMenuOpen = false;
16
+ });
17
+
18
+ const {
19
+ base,
20
+ wrapper,
21
+ container,
22
+ brand: brandSlot,
23
+ menu,
24
+ mobileMenu,
25
+ mobileMenuButton,
26
+ mobileMenuContainer,
27
+ links: linksSlot,
28
+ link,
29
+ mobileLink,
30
+ actions: actionsSlot
31
+ } = $derived(navbar());
32
+
33
+ const baseClass = $derived(
34
+ cn(base(), className, {
35
+ 'shadow-md': scrolled,
36
+ 'translate-y-0': !isScrollingDown || mobileMenuOpen,
37
+ '-translate-y-full': isScrollingDown && !mobileMenuOpen && scrolled
38
+ })
39
+ );
40
+ const wrapperClasses = $derived(cn(wrapper()));
41
+ const containerClasses = $derived(cn(container()));
42
+ const brandClasses = $derived(cn(brandSlot()));
43
+ const menuClasses = $derived(cn(menu()));
44
+ const mobileMenuClasses = $derived(cn(mobileMenu()));
45
+ const mobileMenuButtonClasses = $derived(cn(mobileMenuButton()));
46
+ const mobileMenuContainerClasses = $derived(cn(mobileMenuContainer()));
47
+ const linksClasses = $derived(cn(linksSlot()));
48
+ const linkClasses = $derived(cn(link()));
49
+ const mobileLinkClasses = $derived(cn(mobileLink()));
50
+ const actionsClasses = $derived(cn(actionsSlot()));
51
+
52
+ const processedLinks = $derived(
53
+ links.map((link) => ({
54
+ ...link,
55
+ current: isRouteActive(link.href)
56
+ }))
57
+ );
58
+
59
+ function toggleMobileMenu() {
60
+ mobileMenuOpen = !mobileMenuOpen;
61
+ }
62
+
63
+ $effect(() => {
64
+ if (typeof window !== 'undefined' && mobileMenuOpen) {
65
+ const handleEscape = (e: KeyboardEvent) => {
66
+ if (e.key === 'Escape') {
67
+ mobileMenuOpen = false;
68
+ }
69
+ };
70
+
71
+ window.addEventListener('keydown', handleEscape);
72
+
73
+ return () => {
74
+ window.removeEventListener('keydown', handleEscape);
75
+ };
76
+ }
77
+ });
78
+ </script>
79
+
80
+ <nav
81
+ class={baseClass}
82
+ aria-label="Main navigation"
83
+ class:sticky={scrolled}
84
+ class:top-0={scrolled}
85
+ class:z-10={true}
86
+ class:transition-transform={true}
87
+ class:duration-300={true}
88
+ >
89
+ <div class={wrapperClasses}>
90
+ <div class={containerClasses}>
91
+ <div class={brandClasses}>
92
+ {#if brand}
93
+ {@render brand()}
94
+ {:else if typeof logo === 'string'}
95
+ <a href="/" class="flex items-center">
96
+ <img src={logo} alt="Logo" class="h-8 w-auto" />
97
+ </a>
98
+ {:else if logo}
99
+ {@const LogoComponent = logo}
100
+ <a href="/" class="flex items-center">
101
+ <LogoComponent class="h-8 w-auto" />
102
+ </a>
103
+ {/if}
104
+ </div>
105
+
106
+ <!-- Mobile menu button -->
107
+ <div class="flex items-center sm:hidden">
108
+ <button
109
+ type="button"
110
+ class={mobileMenuButtonClasses}
111
+ aria-controls="mobile-menu"
112
+ aria-expanded={mobileMenuOpen}
113
+ onclick={toggleMobileMenu}
114
+ >
115
+ <span class="sr-only">Open main menu</span>
116
+ {#if mobileMenuOpen}
117
+ <svg
118
+ xmlns="http://www.w3.org/2000/svg"
119
+ class="h-6 w-6"
120
+ fill="none"
121
+ viewBox="0 0 24 24"
122
+ stroke="currentColor"
123
+ >
124
+ <path
125
+ stroke-linecap="round"
126
+ stroke-linejoin="round"
127
+ stroke-width="2"
128
+ d="M6 18L18 6M6 6l12 12"
129
+ />
130
+ </svg>
131
+ {:else}
132
+ <svg
133
+ xmlns="http://www.w3.org/2000/svg"
134
+ class="h-6 w-6"
135
+ fill="none"
136
+ viewBox="0 0 24 24"
137
+ stroke="currentColor"
138
+ >
139
+ <path
140
+ stroke-linecap="round"
141
+ stroke-linejoin="round"
142
+ stroke-width="2"
143
+ d="M4 6h16M4 12h16M4 18h16"
144
+ />
145
+ </svg>
146
+ {/if}
147
+ </button>
148
+ </div>
149
+
150
+ <!-- Desktop menu -->
151
+ <div class={menuClasses}>
152
+ <div class={linksClasses}>
153
+ {#each processedLinks as navItem (navItem.href)}
154
+ <a
155
+ href={navItem.href}
156
+ class={cn(linkClasses, navItem.current ? navbar({ active: true }).link() : '')}
157
+ aria-current={navItem.current ? 'page' : undefined}
158
+ >
159
+ {#if navItem.icon}
160
+ {@const Icon = navItem.icon}
161
+ <Icon class="h-4 w-4" />
162
+ {/if}
163
+ {navItem.label}
164
+ </a>
165
+ {/each}
166
+ {#if children}
167
+ {@render children()}
168
+ {/if}
169
+ </div>
170
+ </div>
171
+
172
+ {#if actions}
173
+ <div class={actionsClasses}>
174
+ {@render actions()}
175
+ </div>
176
+ {/if}
177
+ </div>
178
+ </div>
179
+
180
+ {#if mobileMenuOpen}
181
+ <div class={mobileMenuClasses} id="mobile-menu" transition:slide={{ duration: 200, axis: 'y' }}>
182
+ <div class={mobileMenuContainerClasses}>
183
+ {#each processedLinks as navItem (navItem.href)}
184
+ <a
185
+ href={navItem.href}
186
+ class={cn(
187
+ mobileLinkClasses,
188
+ navItem.current ? navbar({ active: true }).mobileLink() : ''
189
+ )}
190
+ aria-current={navItem.current ? 'page' : undefined}
191
+ >
192
+ {#if navItem.icon}
193
+ {@const Icon = navItem.icon}
194
+ <span class="flex items-center">
195
+ <Icon class="mr-2 h-4 w-4" />
196
+ {navItem.label}
197
+ </span>
198
+ {:else}
199
+ {navItem.label}
200
+ {/if}
201
+ </a>
202
+ {/each}
203
+ </div>
204
+ </div>
205
+ {/if}
206
+ </nav>
@@ -0,0 +1,4 @@
1
+ import { type NavbarProps } from './navbar.js';
2
+ declare const Navbar: import("svelte").Component<NavbarProps, {}, "">;
3
+ type Navbar = ReturnType<typeof Navbar>;
4
+ export default Navbar;
@@ -0,0 +1,205 @@
1
+ import type { ClassValue } from 'tailwind-variants';
2
+ import type { Snippet } from 'svelte';
3
+ import type { Component } from 'svelte';
4
+ export type NavbarLinkItem = {
5
+ label: string;
6
+ href: string;
7
+ icon?: Component;
8
+ current?: boolean;
9
+ children?: NavbarLinkItem[];
10
+ };
11
+ export declare const navbar: import("tailwind-variants").TVReturnType<{
12
+ color: {
13
+ default: {
14
+ base: string;
15
+ mobileMenuButton: string;
16
+ link: string;
17
+ mobileLink: string;
18
+ selectItem: string;
19
+ };
20
+ primary: {
21
+ base: string;
22
+ mobileMenuButton: string;
23
+ link: string;
24
+ mobileLink: string;
25
+ selectItem: string;
26
+ };
27
+ secondary: {
28
+ base: string;
29
+ mobileMenuButton: string;
30
+ link: string;
31
+ mobileLink: string;
32
+ selectItem: string;
33
+ };
34
+ };
35
+ size: {
36
+ sm: {
37
+ container: string;
38
+ link: string;
39
+ mobileLink: string;
40
+ };
41
+ base: {
42
+ container: string;
43
+ link: string;
44
+ mobileLink: string;
45
+ };
46
+ lg: {
47
+ container: string;
48
+ link: string;
49
+ mobileLink: string;
50
+ };
51
+ };
52
+ active: {
53
+ true: {};
54
+ };
55
+ }, {
56
+ base: string;
57
+ wrapper: string;
58
+ container: string;
59
+ brand: string;
60
+ menu: string;
61
+ mobileMenu: string;
62
+ mobileMenuButton: string;
63
+ mobileMenuContainer: string;
64
+ links: string;
65
+ link: string;
66
+ mobileLink: string;
67
+ actions: string;
68
+ avatar: string;
69
+ selectButton: string;
70
+ selectMenu: string;
71
+ selectItem: string;
72
+ divider: string;
73
+ }, undefined, {
74
+ color: {
75
+ default: {
76
+ base: string;
77
+ mobileMenuButton: string;
78
+ link: string;
79
+ mobileLink: string;
80
+ selectItem: string;
81
+ };
82
+ primary: {
83
+ base: string;
84
+ mobileMenuButton: string;
85
+ link: string;
86
+ mobileLink: string;
87
+ selectItem: string;
88
+ };
89
+ secondary: {
90
+ base: string;
91
+ mobileMenuButton: string;
92
+ link: string;
93
+ mobileLink: string;
94
+ selectItem: string;
95
+ };
96
+ };
97
+ size: {
98
+ sm: {
99
+ container: string;
100
+ link: string;
101
+ mobileLink: string;
102
+ };
103
+ base: {
104
+ container: string;
105
+ link: string;
106
+ mobileLink: string;
107
+ };
108
+ lg: {
109
+ container: string;
110
+ link: string;
111
+ mobileLink: string;
112
+ };
113
+ };
114
+ active: {
115
+ true: {};
116
+ };
117
+ }, {
118
+ base: string;
119
+ wrapper: string;
120
+ container: string;
121
+ brand: string;
122
+ menu: string;
123
+ mobileMenu: string;
124
+ mobileMenuButton: string;
125
+ mobileMenuContainer: string;
126
+ links: string;
127
+ link: string;
128
+ mobileLink: string;
129
+ actions: string;
130
+ avatar: string;
131
+ selectButton: string;
132
+ selectMenu: string;
133
+ selectItem: string;
134
+ divider: string;
135
+ }, import("tailwind-variants").TVReturnType<{
136
+ color: {
137
+ default: {
138
+ base: string;
139
+ mobileMenuButton: string;
140
+ link: string;
141
+ mobileLink: string;
142
+ selectItem: string;
143
+ };
144
+ primary: {
145
+ base: string;
146
+ mobileMenuButton: string;
147
+ link: string;
148
+ mobileLink: string;
149
+ selectItem: string;
150
+ };
151
+ secondary: {
152
+ base: string;
153
+ mobileMenuButton: string;
154
+ link: string;
155
+ mobileLink: string;
156
+ selectItem: string;
157
+ };
158
+ };
159
+ size: {
160
+ sm: {
161
+ container: string;
162
+ link: string;
163
+ mobileLink: string;
164
+ };
165
+ base: {
166
+ container: string;
167
+ link: string;
168
+ mobileLink: string;
169
+ };
170
+ lg: {
171
+ container: string;
172
+ link: string;
173
+ mobileLink: string;
174
+ };
175
+ };
176
+ active: {
177
+ true: {};
178
+ };
179
+ }, {
180
+ base: string;
181
+ wrapper: string;
182
+ container: string;
183
+ brand: string;
184
+ menu: string;
185
+ mobileMenu: string;
186
+ mobileMenuButton: string;
187
+ mobileMenuContainer: string;
188
+ links: string;
189
+ link: string;
190
+ mobileLink: string;
191
+ actions: string;
192
+ avatar: string;
193
+ selectButton: string;
194
+ selectMenu: string;
195
+ selectItem: string;
196
+ divider: string;
197
+ }, undefined, unknown, unknown, undefined>>;
198
+ export type NavbarProps = {
199
+ logo?: string | Component;
200
+ links?: NavbarLinkItem[];
201
+ class?: ClassValue;
202
+ brand?: Snippet;
203
+ children?: Snippet;
204
+ actions?: Snippet;
205
+ };