@lerianstudio/sindarian-ui 1.0.0-beta.3 → 1.0.0-beta.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.
- package/dist/components/breadcrumb/index.js +2 -2
- package/dist/components/card/account-card/index.d.ts +32 -0
- package/dist/components/card/account-card/index.d.ts.map +1 -0
- package/dist/components/card/account-card/index.js +69 -0
- package/dist/components/card/basic-card/index.d.ts +6 -0
- package/dist/components/card/basic-card/index.d.ts.map +1 -0
- package/dist/components/card/basic-card/index.js +20 -0
- package/dist/components/card/dashboard-card/index.d.ts +5 -0
- package/dist/components/card/dashboard-card/index.d.ts.map +1 -0
- package/dist/components/card/dashboard-card/index.js +20 -0
- package/dist/components/card/entity-card/index.d.ts +21 -0
- package/dist/components/card/entity-card/index.d.ts.map +1 -0
- package/dist/components/card/entity-card/index.js +60 -0
- package/dist/components/card/index.d.ts +5 -0
- package/dist/components/card/index.d.ts.map +1 -0
- package/dist/components/card/index.js +20 -0
- package/dist/components/dialog/confirmation-dialog/index.d.ts +15 -0
- package/dist/components/dialog/confirmation-dialog/index.d.ts.map +1 -0
- package/dist/components/dialog/confirmation-dialog/index.js +28 -0
- package/dist/components/dialog/confirmation-dialog/use-confirm-dialog.d.ts +31 -0
- package/dist/components/dialog/confirmation-dialog/use-confirm-dialog.d.ts.map +1 -0
- package/dist/components/dialog/confirmation-dialog/use-confirm-dialog.js +55 -0
- package/dist/components/dialog/index.d.ts +4 -0
- package/dist/components/dialog/index.d.ts.map +1 -0
- package/dist/components/dialog/index.js +19 -0
- package/dist/components/dialog/large-dialog/index.d.ts +11 -0
- package/dist/components/dialog/large-dialog/index.d.ts.map +1 -0
- package/dist/components/dialog/large-dialog/index.js +21 -0
- package/dist/components/form/date-picker-field/index.d.ts +19 -0
- package/dist/components/form/date-picker-field/index.d.ts.map +1 -0
- package/dist/components/form/date-picker-field/index.js +22 -0
- package/dist/components/form/date-range-field/index.d.ts +20 -0
- package/dist/components/form/date-range-field/index.d.ts.map +1 -0
- package/dist/components/form/date-range-field/index.js +22 -0
- package/dist/components/form/index.d.ts +2 -0
- package/dist/components/form/index.d.ts.map +1 -1
- package/dist/components/form/index.js +2 -0
- package/dist/components/form/input-field/index.d.ts +4 -1
- package/dist/components/form/input-field/index.d.ts.map +1 -1
- package/dist/components/form/input-field/index.js +3 -3
- package/dist/components/form/pagination-limit-field/index.d.ts +2 -1
- package/dist/components/form/pagination-limit-field/index.d.ts.map +1 -1
- package/dist/components/form/pagination-limit-field/index.js +2 -2
- package/dist/components/form/password-field/index.d.ts +5 -4
- package/dist/components/form/password-field/index.d.ts.map +1 -1
- package/dist/components/form/password-field/index.js +8 -7
- package/dist/components/form/select-field/index.d.ts +3 -1
- package/dist/components/form/select-field/index.d.ts.map +1 -1
- package/dist/components/form/select-field/index.js +8 -2
- package/dist/components/form/switch-field/index.d.ts +2 -1
- package/dist/components/form/switch-field/index.d.ts.map +1 -1
- package/dist/components/form/switch-field/index.js +2 -2
- package/dist/components/page/index.d.ts.map +1 -1
- package/dist/components/page/index.js +3 -3
- package/dist/components/page-header/index.d.ts.map +1 -1
- package/dist/components/page-header/index.js +6 -4
- package/dist/components/pagination/index.js +1 -1
- package/dist/components/table/id-table-cell.d.ts +3 -2
- package/dist/components/table/id-table-cell.d.ts.map +1 -1
- package/dist/components/table/id-table-cell.js +2 -2
- package/dist/components/table/locked-table-actions.js +1 -1
- package/dist/components/ui/alert/index.d.ts +5 -1
- package/dist/components/ui/alert/index.d.ts.map +1 -1
- package/dist/components/ui/alert/index.js +22 -8
- package/dist/components/ui/alert/styles.css +68 -0
- package/dist/components/ui/badge/index.d.ts +1 -1
- package/dist/components/ui/breadcrumb/index.d.ts.map +1 -1
- package/dist/components/ui/breadcrumb/index.js +5 -5
- package/dist/components/ui/breadcrumb/styles.css +27 -0
- package/dist/components/ui/button/index.d.ts +8 -3
- package/dist/components/ui/button/index.d.ts.map +1 -1
- package/dist/components/ui/button/index.js +21 -29
- package/dist/components/ui/button/styles.css +64 -0
- package/dist/components/ui/calendar/index.d.ts +9 -0
- package/dist/components/ui/calendar/index.d.ts.map +1 -0
- package/dist/components/ui/calendar/index.js +115 -0
- package/dist/components/ui/card/index.js +1 -1
- package/dist/components/ui/command/index.d.ts +1 -1
- package/dist/components/ui/command/index.d.ts.map +1 -1
- package/dist/components/ui/command/index.js +52 -2
- package/dist/components/ui/dialog/index.d.ts.map +1 -1
- package/dist/components/ui/dialog/index.js +6 -6
- package/dist/components/ui/dialog/styles.css +34 -0
- package/dist/components/ui/field/index.d.ts +25 -0
- package/dist/components/ui/field/index.d.ts.map +1 -0
- package/dist/components/ui/field/index.js +79 -0
- package/dist/components/ui/form.d.ts.map +1 -1
- package/dist/components/ui/form.js +1 -0
- package/dist/components/ui/icon-button/index.d.ts +13 -0
- package/dist/components/ui/icon-button/index.d.ts.map +1 -0
- package/dist/components/ui/icon-button/index.js +35 -0
- package/dist/components/ui/icon-button/styles.css +33 -0
- package/dist/components/ui/input/adornment.d.ts +9 -0
- package/dist/components/ui/input/adornment.d.ts.map +1 -0
- package/dist/components/ui/input/adornment.js +21 -0
- package/dist/components/ui/input/index.d.ts +16 -2
- package/dist/components/ui/input/index.d.ts.map +1 -1
- package/dist/components/ui/input/index.js +90 -2
- package/dist/components/ui/input/styles.css +68 -0
- package/dist/components/ui/multiple-select/index.d.ts +6 -6
- package/dist/components/ui/paper-collapsible/index.d.ts +9 -0
- package/dist/components/ui/paper-collapsible/index.d.ts.map +1 -0
- package/dist/components/ui/paper-collapsible/index.js +24 -0
- package/dist/components/ui/progress/index.d.ts +1 -1
- package/dist/components/ui/progress/index.d.ts.map +1 -1
- package/dist/components/ui/select/index.d.ts +1 -2
- package/dist/components/ui/select/index.d.ts.map +1 -1
- package/dist/components/ui/select/index.js +9 -18
- package/dist/components/ui/select/styles.css +57 -0
- package/dist/components/ui/sidebar/index.d.ts +10 -0
- package/dist/components/ui/sidebar/index.d.ts.map +1 -0
- package/dist/components/ui/sidebar/index.js +25 -0
- package/dist/components/ui/sidebar/sidebar-back-button.d.ts +3 -0
- package/dist/components/ui/sidebar/sidebar-back-button.d.ts.map +1 -0
- package/dist/components/ui/sidebar/sidebar-back-button.js +8 -0
- package/dist/components/ui/sidebar/sidebar-components.d.ts +23 -0
- package/dist/components/ui/sidebar/sidebar-components.d.ts.map +1 -0
- package/dist/components/ui/sidebar/sidebar-components.js +23 -0
- package/dist/components/ui/sidebar/sidebar-expand-button.d.ts +6 -0
- package/dist/components/ui/sidebar/sidebar-expand-button.d.ts.map +1 -0
- package/dist/components/ui/sidebar/sidebar-expand-button.js +19 -0
- package/dist/components/ui/sidebar/sidebar-item-button.d.ts +12 -0
- package/dist/components/ui/sidebar/sidebar-item-button.d.ts.map +1 -0
- package/dist/components/ui/sidebar/sidebar-item-button.js +23 -0
- package/dist/components/ui/sidebar/sidebar-item-collapsible.d.ts +12 -0
- package/dist/components/ui/sidebar/sidebar-item-collapsible.d.ts.map +1 -0
- package/dist/components/ui/sidebar/sidebar-item-collapsible.js +52 -0
- package/dist/components/ui/sidebar/sidebar-item-icon-button.d.ts +12 -0
- package/dist/components/ui/sidebar/sidebar-item-icon-button.d.ts.map +1 -0
- package/dist/components/ui/sidebar/sidebar-item-icon-button.js +20 -0
- package/dist/components/ui/sidebar/sidebar-item.d.ts +13 -0
- package/dist/components/ui/sidebar/sidebar-item.d.ts.map +1 -0
- package/dist/components/ui/sidebar/sidebar-item.js +19 -0
- package/dist/components/ui/sidebar/sidebar-provider.d.ts +12 -0
- package/dist/components/ui/sidebar/sidebar-provider.d.ts.map +1 -0
- package/dist/components/ui/sidebar/sidebar-provider.js +59 -0
- package/dist/components/ui/sidebar/sidebar-provider.test.d.ts +2 -0
- package/dist/components/ui/sidebar/sidebar-provider.test.d.ts.map +1 -0
- package/dist/components/ui/sidebar/sidebar-provider.test.js +167 -0
- package/dist/components/ui/sidebar/sidebar-root.d.ts +3 -0
- package/dist/components/ui/sidebar/sidebar-root.d.ts.map +1 -0
- package/dist/components/ui/sidebar/sidebar-root.js +24 -0
- package/dist/components/ui/stepper/index.d.ts.map +1 -1
- package/dist/components/ui/stepper/index.js +4 -4
- package/dist/components/ui/stepper/styles.css +41 -0
- package/dist/components/ui/tabs/index.d.ts.map +1 -1
- package/dist/components/ui/tabs/index.js +4 -4
- package/dist/components/ui/tabs/styles.css +31 -0
- package/dist/components/ui/toast/toaster.js +1 -1
- package/dist/globals.css +218 -0
- package/dist/hooks/use-time.d.ts +6 -0
- package/dist/hooks/use-time.d.ts.map +1 -0
- package/dist/hooks/use-time.js +20 -0
- package/dist/index.d.ts +7 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +8 -1
- package/dist/lib/storage/get-storage-object.d.ts +2 -0
- package/dist/lib/storage/get-storage-object.d.ts.map +1 -0
- package/dist/lib/storage/get-storage-object.js +19 -0
- package/dist/lib/storage/get-storage.d.ts +2 -0
- package/dist/lib/storage/get-storage.d.ts.map +1 -0
- package/dist/lib/storage/get-storage.js +17 -0
- package/dist/lib/storage/index.d.ts +3 -0
- package/dist/lib/storage/index.d.ts.map +1 -0
- package/dist/lib/storage/index.js +18 -0
- package/dist/public/arm.gif +0 -0
- package/dist/public/clap.gif +0 -0
- package/dist/public/confetti-ball.gif +0 -0
- package/dist/public/countries.json +21200 -21200
- package/dist/public/dizzy.gif +0 -0
- package/dist/public/electricity.gif +0 -0
- package/dist/public/gear.gif +0 -0
- package/dist/public/gem.gif +0 -0
- package/dist/public/pencil.gif +0 -0
- package/dist/public/robot.gif +0 -0
- package/dist/public/rocket.gif +0 -0
- package/dist/public/software.gif +0 -0
- package/dist/public/solar-system.gif +0 -0
- package/dist/public/unicorn.gif +0 -0
- package/package.json +32 -29
- package/dist/components/ui/input-with-icon/index.d.ts +0 -12
- package/dist/components/ui/input-with-icon/index.d.ts.map +0 -1
- package/dist/components/ui/input-with-icon/index.js +0 -57
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
@theme inline {
|
|
2
|
+
--spacing-select-h: calc(var(--spacing) * 10);
|
|
3
|
+
--spacing-select-px: calc(var(--spacing) * 3);
|
|
4
|
+
--spacing-select-py: calc(var(--spacing) * 2);
|
|
5
|
+
|
|
6
|
+
--color-select-foreground: var(--color-zinc-700);
|
|
7
|
+
--color-select-placeholder: var(--color-shadcn-400);
|
|
8
|
+
--color-select-border: var(--color-shadcn-300);
|
|
9
|
+
--color-select-chevron: var(--color-shadcn-400);
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
@layer components {
|
|
13
|
+
.select-trigger {
|
|
14
|
+
@apply flex items-center justify-between h-select-h w-full px-select-px py-select-py text-sm font-medium text-select-foreground border border-select-border rounded-md data-placeholder:text-select-placeholder focus:ring-2 focus:ring-offset-0 focus:outline-hidden focus-visible:outline-hidden;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
.select-read-only {
|
|
18
|
+
@apply data-read-only:cursor-default data-read-only:select-text data-read-only:bg-zinc-100 data-read-only:opacity-50 data-read-only:pointer-events-none data-read-only:focus:outline-hidden data-read-only:focus:ring-0;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
.select-disabled {
|
|
22
|
+
@apply disabled:cursor-not-allowed disabled:opacity-50;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
.select-chevron {
|
|
26
|
+
@apply text-select-chevron size-4;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
.select-scroll-button {
|
|
30
|
+
@apply flex cursor-default items-center justify-center py-1;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
.select-content {
|
|
34
|
+
@apply bg-popover text-popover-foreground relative z-50 max-h-96 min-w-32 overflow-hidden rounded-md border shadow-md;
|
|
35
|
+
@apply data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
.select-content-popper {
|
|
39
|
+
@apply data-[side=bottom]:translate-y-1 data-[side=left]:-translate-x-1 data-[side=right]:translate-x-1 data-[side=top]:-translate-y-1;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
.select-empty {
|
|
43
|
+
@apply text-muted-foreground hidden py-6 text-center text-sm group-data-[empty=true]/select:block;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
.select-label {
|
|
47
|
+
@apply py-1.5 pr-8 pl-2 text-sm font-semibold;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
.select-item {
|
|
51
|
+
@apply focus:bg-accent focus:text-accent-foreground relative flex w-full cursor-default items-center rounded-sm py-1.5 pr-8 pl-2 text-sm outline-hidden select-none data-disabled:pointer-events-none data-disabled:opacity-50;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
.select-separator {
|
|
55
|
+
@apply bg-muted -mx-1 my-1 h-px;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export * from './sidebar-root';
|
|
2
|
+
export * from './sidebar-components';
|
|
3
|
+
export * from './sidebar-item-icon-button';
|
|
4
|
+
export * from './sidebar-item-button';
|
|
5
|
+
export * from './sidebar-item';
|
|
6
|
+
export * from './sidebar-expand-button';
|
|
7
|
+
export * from './sidebar-back-button';
|
|
8
|
+
export * from './sidebar-provider';
|
|
9
|
+
export * from './sidebar-item-collapsible';
|
|
10
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/sidebar/index.tsx"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAA;AAC9B,cAAc,sBAAsB,CAAA;AACpC,cAAc,4BAA4B,CAAA;AAC1C,cAAc,uBAAuB,CAAA;AACrC,cAAc,gBAAgB,CAAA;AAC9B,cAAc,yBAAyB,CAAA;AACvC,cAAc,uBAAuB,CAAA;AACrC,cAAc,oBAAoB,CAAA;AAClC,cAAc,4BAA4B,CAAA"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./sidebar-root"), exports);
|
|
18
|
+
__exportStar(require("./sidebar-components"), exports);
|
|
19
|
+
__exportStar(require("./sidebar-item-icon-button"), exports);
|
|
20
|
+
__exportStar(require("./sidebar-item-button"), exports);
|
|
21
|
+
__exportStar(require("./sidebar-item"), exports);
|
|
22
|
+
__exportStar(require("./sidebar-expand-button"), exports);
|
|
23
|
+
__exportStar(require("./sidebar-back-button"), exports);
|
|
24
|
+
__exportStar(require("./sidebar-provider"), exports);
|
|
25
|
+
__exportStar(require("./sidebar-item-collapsible"), exports);
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sidebar-back-button.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/sidebar/sidebar-back-button.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAE5C,wBAAgB,iBAAiB,CAAC,EAChC,GAAG,KAAK,EACT,EAAE,KAAK,CAAC,cAAc,CAAC,OAAO,WAAW,CAAC,2CAM1C"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SidebarBackButton = SidebarBackButton;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const sidebar_item_1 = require("./sidebar-item");
|
|
6
|
+
function SidebarBackButton({ ...props }) {
|
|
7
|
+
return ((0, jsx_runtime_1.jsx)("div", { className: "flex w-full flex-col", children: (0, jsx_runtime_1.jsx)(sidebar_item_1.SidebarItem, { ...props }) }));
|
|
8
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export type SidebarHeaderProps = React.ComponentProps<'div'> & {
|
|
3
|
+
className?: string;
|
|
4
|
+
collapsed?: boolean;
|
|
5
|
+
};
|
|
6
|
+
export declare const SidebarHeader: ({ className, collapsed, ...props }: SidebarHeaderProps) => import("react/jsx-runtime").JSX.Element;
|
|
7
|
+
export type SidebarContentProps = React.ComponentProps<'div'> & {
|
|
8
|
+
className?: string;
|
|
9
|
+
};
|
|
10
|
+
export declare const SidebarContent: ({ className, ...props }: SidebarContentProps) => import("react/jsx-runtime").JSX.Element;
|
|
11
|
+
export type SidebarGroupProps = {
|
|
12
|
+
className?: string;
|
|
13
|
+
} & React.ComponentProps<'nav'>;
|
|
14
|
+
export declare const SidebarGroup: ({ className, ...props }: SidebarGroupProps) => import("react/jsx-runtime").JSX.Element;
|
|
15
|
+
export type SidebarGroupTitleProps = React.PropsWithChildren & {
|
|
16
|
+
collapsed?: boolean;
|
|
17
|
+
};
|
|
18
|
+
export declare const SidebarGroupTitle: ({ children }: SidebarGroupTitleProps) => import("react/jsx-runtime").JSX.Element;
|
|
19
|
+
export type SidebarFooterProps = {
|
|
20
|
+
className?: string;
|
|
21
|
+
} & React.ComponentProps<'nav'>;
|
|
22
|
+
export declare const SidebarFooter: ({ className, ...props }: SidebarFooterProps) => import("react/jsx-runtime").JSX.Element;
|
|
23
|
+
//# sourceMappingURL=sidebar-components.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sidebar-components.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/sidebar/sidebar-components.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAKzB,MAAM,MAAM,kBAAkB,GAAG,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,GAAG;IAC7D,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,SAAS,CAAC,EAAE,OAAO,CAAA;CACpB,CAAA;AAED,eAAO,MAAM,aAAa,GAAI,oCAI3B,kBAAkB,4CAWpB,CAAA;AAED,MAAM,MAAM,mBAAmB,GAAG,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,GAAG;IAC9D,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB,CAAA;AAED,eAAO,MAAM,cAAc,GAAI,yBAG5B,mBAAmB,4CAUrB,CAAA;AAED,MAAM,MAAM,iBAAiB,GAAG;IAC9B,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB,GAAG,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,CAAA;AAE/B,eAAO,MAAM,YAAY,GAAI,yBAAyB,iBAAiB,4CAUtE,CAAA;AAED,MAAM,MAAM,sBAAsB,GAAG,KAAK,CAAC,iBAAiB,GAAG;IAC7D,SAAS,CAAC,EAAE,OAAO,CAAA;CACpB,CAAA;AAED,eAAO,MAAM,iBAAiB,GAAI,cAAc,sBAAsB,4CAcrE,CAAA;AAED,MAAM,MAAM,kBAAkB,GAAG;IAC/B,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB,GAAG,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,CAAA;AAE/B,eAAO,MAAM,aAAa,GAAI,yBAAyB,kBAAkB,4CASxE,CAAA"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SidebarFooter = exports.SidebarGroupTitle = exports.SidebarGroup = exports.SidebarContent = exports.SidebarHeader = void 0;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const utils_1 = require("../../../lib/utils");
|
|
6
|
+
const sidebar_provider_1 = require("./sidebar-provider");
|
|
7
|
+
const separator_1 = require("../separator");
|
|
8
|
+
const SidebarHeader = ({ className, collapsed, ...props }) => ((0, jsx_runtime_1.jsx)("div", { "data-slot": "sidebar-header", "data-collapsed": collapsed, className: (0, utils_1.cn)('dark:bg-cod-gray-950 flex w-full flex-col items-center bg-white p-4', collapsed && 'justify-center p-0', className), ...props }));
|
|
9
|
+
exports.SidebarHeader = SidebarHeader;
|
|
10
|
+
const SidebarContent = ({ className, ...props }) => ((0, jsx_runtime_1.jsx)("div", { "data-slot": "sidebar-content", className: (0, utils_1.cn)('group flex flex-1 flex-col gap-4 overflow-hidden overflow-y-auto bg-white px-4 pt-4 transition-all duration-300 ease-in-out', 'group-data-[collapsed=true]/sidebar:items-center group-data-[collapsed=true]/sidebar:px-2', className), ...props }));
|
|
11
|
+
exports.SidebarContent = SidebarContent;
|
|
12
|
+
const SidebarGroup = ({ className, ...props }) => ((0, jsx_runtime_1.jsx)("nav", { "data-slot": "sidebar-group", className: (0, utils_1.cn)('flex flex-col gap-1', 'group-data-[collapsed=true]/sidebar:items-center', className), ...props }));
|
|
13
|
+
exports.SidebarGroup = SidebarGroup;
|
|
14
|
+
const SidebarGroupTitle = ({ children }) => {
|
|
15
|
+
const { isCollapsed } = (0, sidebar_provider_1.useSidebar)();
|
|
16
|
+
if (isCollapsed) {
|
|
17
|
+
return (0, jsx_runtime_1.jsx)(separator_1.Separator, {});
|
|
18
|
+
}
|
|
19
|
+
return ((0, jsx_runtime_1.jsx)("div", { "data-slot": "sidebar-group-title", className: "my-2 px-2", children: (0, jsx_runtime_1.jsx)("p", { className: "text-xs font-semibold tracking-[1.1px] text-zinc-500 uppercase", children: children }) }));
|
|
20
|
+
};
|
|
21
|
+
exports.SidebarGroupTitle = SidebarGroupTitle;
|
|
22
|
+
const SidebarFooter = ({ className, ...props }) => ((0, jsx_runtime_1.jsx)("nav", { "data-slot": "sidebar-footer", className: (0, utils_1.cn)('border-shadcn-200 flex w-full justify-center border-t bg-white p-4', className), ...props }));
|
|
23
|
+
exports.SidebarFooter = SidebarFooter;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sidebar-expand-button.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/sidebar/sidebar-expand-button.tsx"],"names":[],"mappings":"AAcA,KAAK,wBAAwB,GAAG;IAC9B,OAAO,CAAC,EAAE,MAAM,CAAA;CACjB,CAAA;AAED,eAAO,MAAM,mBAAmB,GAAI,aAAa,wBAAwB,4CAqCxE,CAAA"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
"use strict";
|
|
3
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
4
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
5
|
+
};
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.SidebarExpandButton = void 0;
|
|
8
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
9
|
+
const react_1 = __importDefault(require("react"));
|
|
10
|
+
const lucide_react_1 = require("lucide-react");
|
|
11
|
+
const sidebar_provider_1 = require("./sidebar-provider");
|
|
12
|
+
const sidebar_components_1 = require("./sidebar-components");
|
|
13
|
+
const tooltip_1 = require("../../ui/tooltip");
|
|
14
|
+
const icon_button_1 = require("../icon-button");
|
|
15
|
+
const SidebarExpandButton = ({ tooltip }) => {
|
|
16
|
+
const { isCollapsed, toggleSidebar } = (0, sidebar_provider_1.useSidebar)();
|
|
17
|
+
return ((0, jsx_runtime_1.jsxs)(react_1.default.Fragment, { children: [!isCollapsed && ((0, jsx_runtime_1.jsx)("div", { "data-slot": "sidebar-expand-button", className: "border-shadcn-200 flex w-full bg-white", children: (0, jsx_runtime_1.jsx)("div", { className: "absolute right-[-20px] bottom-4", children: (0, jsx_runtime_1.jsx)(icon_button_1.IconButton, { variant: "secondary", rounded: true, onClick: toggleSidebar, children: (0, jsx_runtime_1.jsx)(lucide_react_1.PanelLeftClose, { className: "text-shadcn-400" }) }) }) })), isCollapsed && ((0, jsx_runtime_1.jsx)(sidebar_components_1.SidebarFooter, { children: (0, jsx_runtime_1.jsx)(tooltip_1.TooltipProvider, { children: (0, jsx_runtime_1.jsxs)(tooltip_1.Tooltip, { children: [(0, jsx_runtime_1.jsx)(tooltip_1.TooltipTrigger, { className: "group/expand-button text-shadcn-400 hover:bg-accent rounded-sm bg-transparent p-2", onClick: toggleSidebar, children: (0, jsx_runtime_1.jsx)(lucide_react_1.PanelRightClose, { className: "group-hover/expand-button:text-white dark:text-white" }) }), (0, jsx_runtime_1.jsx)(tooltip_1.TooltipContent, { side: "right", children: tooltip || 'Expand' })] }) }) }))] }));
|
|
18
|
+
};
|
|
19
|
+
exports.SidebarExpandButton = SidebarExpandButton;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import Link from 'next/link';
|
|
3
|
+
export type SidebarItemButtonProps = React.ComponentProps<typeof Link> & {
|
|
4
|
+
className?: string;
|
|
5
|
+
title: string;
|
|
6
|
+
icon?: React.ReactNode;
|
|
7
|
+
active?: boolean;
|
|
8
|
+
inactive?: boolean;
|
|
9
|
+
disabled?: boolean;
|
|
10
|
+
};
|
|
11
|
+
export declare function SidebarItemButton({ className, title, icon, href, active, inactive, disabled, ...props }: SidebarItemButtonProps): import("react/jsx-runtime").JSX.Element;
|
|
12
|
+
//# sourceMappingURL=sidebar-item-button.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sidebar-item-button.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/sidebar/sidebar-item-button.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,IAAI,MAAM,WAAW,CAAA;AAI5B,MAAM,MAAM,sBAAsB,GAAG,KAAK,CAAC,cAAc,CAAC,OAAO,IAAI,CAAC,GAAG;IACvE,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,KAAK,EAAE,MAAM,CAAA;IACb,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACtB,MAAM,CAAC,EAAE,OAAO,CAAA;IAChB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,CAAA;AAED,wBAAgB,iBAAiB,CAAC,EAChC,SAAS,EACT,KAAK,EACL,IAAI,EACJ,IAAI,EACJ,MAAM,EACN,QAAQ,EACR,QAAgB,EAChB,GAAG,KAAK,EACT,EAAE,sBAAsB,2CA4CxB"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
"use strict";
|
|
3
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
4
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
5
|
+
};
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.SidebarItemButton = SidebarItemButton;
|
|
8
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
9
|
+
const link_1 = __importDefault(require("next/link"));
|
|
10
|
+
const button_1 = require("../../ui/button");
|
|
11
|
+
const utils_1 = require("../../../lib/utils");
|
|
12
|
+
function SidebarItemButton({ className, title, icon, href, active, inactive, disabled = false, ...props }) {
|
|
13
|
+
const sharedClassName = (0, utils_1.cn)((0, button_1.buttonVariants)({
|
|
14
|
+
variant: active ? 'tertiary' : 'outline',
|
|
15
|
+
fullWidth: true,
|
|
16
|
+
size: 'small'
|
|
17
|
+
}), 'group/link flex items-center justify-start', inactive && 'hover:border-transparent', disabled && 'cursor-default opacity-30', className);
|
|
18
|
+
const content = ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [icon && ((0, jsx_runtime_1.jsx)("span", { className: (0, utils_1.cn)((0, button_1.iconVariants)({ position: 'start', size: 'small' })), children: icon })), title] }));
|
|
19
|
+
if (disabled || inactive) {
|
|
20
|
+
return ((0, jsx_runtime_1.jsx)("div", { "data-slot": "sidebar-item-button", className: sharedClassName, children: content }));
|
|
21
|
+
}
|
|
22
|
+
return ((0, jsx_runtime_1.jsx)(link_1.default, { "data-slot": "sidebar-item-button", href: href, className: sharedClassName, ...props, children: content }));
|
|
23
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Collapsible, CollapsibleContent, CollapsibleTrigger } from '@radix-ui/react-collapsible';
|
|
3
|
+
import { SidebarItemButton } from './sidebar-item-button';
|
|
4
|
+
import { SidebarItemIconButton } from './sidebar-item-icon-button';
|
|
5
|
+
export type SidebarItemCollapsibleProps = React.ComponentProps<typeof Collapsible> & {
|
|
6
|
+
name?: string;
|
|
7
|
+
};
|
|
8
|
+
export declare function SidebarItemCollapsible({ name, className, ...props }: SidebarItemCollapsibleProps): import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
export type SidebarItemCollapsibleTriggerProps = React.ComponentProps<typeof CollapsibleTrigger> & Omit<React.ComponentProps<typeof SidebarItemButton>, 'href'> & Omit<React.ComponentProps<typeof SidebarItemIconButton>, 'href'>;
|
|
10
|
+
export declare function SidebarItemCollapsibleTrigger({ className, icon, title, children, ...props }: SidebarItemCollapsibleTriggerProps): import("react/jsx-runtime").JSX.Element;
|
|
11
|
+
export declare function SidebarItemCollapsibleContent({ className, children, ...props }: React.ComponentProps<typeof CollapsibleContent>): import("react/jsx-runtime").JSX.Element;
|
|
12
|
+
//# sourceMappingURL=sidebar-item-collapsible.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sidebar-item-collapsible.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/sidebar/sidebar-item-collapsible.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EACL,WAAW,EACX,kBAAkB,EAClB,kBAAkB,EACnB,MAAM,6BAA6B,CAAA;AAIpC,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAA;AAEzD,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAA;AAElE,MAAM,MAAM,2BAA2B,GAAG,KAAK,CAAC,cAAc,CAC5D,OAAO,WAAW,CACnB,GAAG;IACF,IAAI,CAAC,EAAE,MAAM,CAAA;CACd,CAAA;AAED,wBAAgB,sBAAsB,CAAC,EACrC,IAAI,EACJ,SAAS,EACT,GAAG,KAAK,EACT,EAAE,2BAA2B,2CA+B7B;AAED,MAAM,MAAM,kCAAkC,GAAG,KAAK,CAAC,cAAc,CACnE,OAAO,kBAAkB,CAC1B,GACC,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,OAAO,iBAAiB,CAAC,EAAE,MAAM,CAAC,GAC5D,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,OAAO,qBAAqB,CAAC,EAAE,MAAM,CAAC,CAAA;AAElE,wBAAgB,6BAA6B,CAAC,EAC5C,SAAS,EACT,IAAI,EACJ,KAAK,EACL,QAAQ,EACR,GAAG,KAAK,EACT,EAAE,kCAAkC,2CAgCpC;AAED,wBAAgB,6BAA6B,CAAC,EAC5C,SAAS,EACT,QAAQ,EACR,GAAG,KAAK,EACT,EAAE,KAAK,CAAC,cAAc,CAAC,OAAO,kBAAkB,CAAC,2CA0BjD"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.SidebarItemCollapsible = SidebarItemCollapsible;
|
|
7
|
+
exports.SidebarItemCollapsibleTrigger = SidebarItemCollapsibleTrigger;
|
|
8
|
+
exports.SidebarItemCollapsibleContent = SidebarItemCollapsibleContent;
|
|
9
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
10
|
+
const react_1 = __importDefault(require("react"));
|
|
11
|
+
const utils_1 = require("../../../lib/utils");
|
|
12
|
+
const react_collapsible_1 = require("@radix-ui/react-collapsible");
|
|
13
|
+
const lucide_react_1 = require("lucide-react");
|
|
14
|
+
const sidebar_provider_1 = require("./sidebar-provider");
|
|
15
|
+
const separator_1 = require("../separator");
|
|
16
|
+
const sidebar_item_button_1 = require("./sidebar-item-button");
|
|
17
|
+
const button_1 = require("../button");
|
|
18
|
+
const sidebar_item_icon_button_1 = require("./sidebar-item-icon-button");
|
|
19
|
+
function SidebarItemCollapsible({ name, className, ...props }) {
|
|
20
|
+
const { isCollapsed, getItemCollapsed, setItemCollapsed } = (0, sidebar_provider_1.useSidebar)();
|
|
21
|
+
const [open, setOpen] = react_1.default.useState(name ? getItemCollapsed(name) : false);
|
|
22
|
+
const handleOpenChange = (open) => {
|
|
23
|
+
setOpen(open);
|
|
24
|
+
if (name) {
|
|
25
|
+
setItemCollapsed(name, open);
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
react_1.default.useEffect(() => {
|
|
29
|
+
if (name) {
|
|
30
|
+
setOpen(getItemCollapsed(name));
|
|
31
|
+
}
|
|
32
|
+
}, [name, getItemCollapsed]);
|
|
33
|
+
return ((0, jsx_runtime_1.jsx)(react_collapsible_1.Collapsible, { open: open, onOpenChange: handleOpenChange, "data-slot": "sidebar-item-collapsible", className: (0, utils_1.cn)({
|
|
34
|
+
'bg-shadcn-100 rounded-md': isCollapsed
|
|
35
|
+
}, className), ...props }));
|
|
36
|
+
}
|
|
37
|
+
function SidebarItemCollapsibleTrigger({ className, icon, title, children, ...props }) {
|
|
38
|
+
const { isCollapsed } = (0, sidebar_provider_1.useSidebar)();
|
|
39
|
+
return ((0, jsx_runtime_1.jsxs)(react_collapsible_1.CollapsibleTrigger, { "data-slot": "sidebar-item-collapsible-trigger", className: (0, utils_1.cn)('flex w-full flex-row p-0', 'transition-all hover:underline [&[data-state=open]>svg]:rotate-90', (0, button_1.buttonVariants)({
|
|
40
|
+
variant: 'outline',
|
|
41
|
+
fullWidth: true,
|
|
42
|
+
size: 'small'
|
|
43
|
+
}), {
|
|
44
|
+
'size-10': isCollapsed
|
|
45
|
+
}, className), ...props, children: [isCollapsed && ((0, jsx_runtime_1.jsx)(sidebar_item_icon_button_1.SidebarItemIconButton, { title: title, icon: icon, href: "", inactive: true })), !isCollapsed && ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(sidebar_item_button_1.SidebarItemButton, { title: title, icon: icon, href: '', inactive: true }), (0, jsx_runtime_1.jsx)(lucide_react_1.ChevronRight, { className: "mr-1 size-6 shrink-0 cursor-pointer text-zinc-900 transition-transform duration-200" })] }))] }));
|
|
46
|
+
}
|
|
47
|
+
function SidebarItemCollapsibleContent({ className, children, ...props }) {
|
|
48
|
+
const { isCollapsed } = (0, sidebar_provider_1.useSidebar)();
|
|
49
|
+
return ((0, jsx_runtime_1.jsx)(react_collapsible_1.CollapsibleContent, { "data-slot": "sidebar-item-collapsible-content", className: (0, utils_1.cn)('mt-1 flex flex-col gap-1', 'data-[state=closed]:animate-collapsible-up data-[state=open]:animate-collapsible-down overflow-hidden transition-all duration-200 ease-in-out', {
|
|
50
|
+
'items-center': isCollapsed
|
|
51
|
+
}, className), ...props, children: isCollapsed ? (children) : ((0, jsx_runtime_1.jsxs)("div", { className: "flex items-stretch gap-3", children: [(0, jsx_runtime_1.jsx)(separator_1.Separator, { className: "ml-5 h-auto", orientation: "vertical" }), (0, jsx_runtime_1.jsx)("div", { className: "flex w-full flex-col gap-1", children: children })] })) }));
|
|
52
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import Link from 'next/link';
|
|
3
|
+
type SidebarItemIconButtonProps = React.ComponentProps<typeof Link> & {
|
|
4
|
+
title: string;
|
|
5
|
+
icon: React.ReactNode;
|
|
6
|
+
active?: boolean;
|
|
7
|
+
inactive?: boolean;
|
|
8
|
+
disabled?: boolean;
|
|
9
|
+
};
|
|
10
|
+
export declare const SidebarItemIconButton: ({ title, icon, href, active, inactive, disabled, ...props }: SidebarItemIconButtonProps) => import("react/jsx-runtime").JSX.Element;
|
|
11
|
+
export {};
|
|
12
|
+
//# sourceMappingURL=sidebar-item-icon-button.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sidebar-item-icon-button.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/sidebar/sidebar-item-icon-button.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,IAAI,MAAM,WAAW,CAAA;AAW5B,KAAK,0BAA0B,GAAG,KAAK,CAAC,cAAc,CAAC,OAAO,IAAI,CAAC,GAAG;IACpE,KAAK,EAAE,MAAM,CAAA;IACb,IAAI,EAAE,KAAK,CAAC,SAAS,CAAA;IACrB,MAAM,CAAC,EAAE,OAAO,CAAA;IAChB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,CAAA;AAED,eAAO,MAAM,qBAAqB,GAAI,6DAQnC,0BAA0B,4CAoC5B,CAAA"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
"use strict";
|
|
3
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
4
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
5
|
+
};
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.SidebarItemIconButton = void 0;
|
|
8
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
9
|
+
const link_1 = __importDefault(require("next/link"));
|
|
10
|
+
const button_1 = require("../../ui/button");
|
|
11
|
+
const tooltip_1 = require("../../ui/tooltip");
|
|
12
|
+
const utils_1 = require("../../../lib/utils");
|
|
13
|
+
const icon_button_1 = require("../icon-button");
|
|
14
|
+
const SidebarItemIconButton = ({ title, icon, href, active, inactive, disabled, ...props }) => {
|
|
15
|
+
const sharedClassName = (0, utils_1.cn)((0, button_1.buttonVariants)({
|
|
16
|
+
variant: active ? 'tertiary' : 'outline'
|
|
17
|
+
}), (0, icon_button_1.iconButtonVariants)(), inactive && 'hover:border-transparent', disabled && 'cursor-default opacity-30');
|
|
18
|
+
return ((0, jsx_runtime_1.jsx)(tooltip_1.TooltipProvider, { children: (0, jsx_runtime_1.jsxs)(tooltip_1.Tooltip, { delayDuration: 0, children: [(0, jsx_runtime_1.jsx)(tooltip_1.TooltipTrigger, { asChild: true, children: disabled || inactive ? ((0, jsx_runtime_1.jsx)("div", { "data-slot": "sidebar-item-icon-button", className: sharedClassName, children: icon })) : ((0, jsx_runtime_1.jsx)(link_1.default, { "data-slot": "sidebar-item-icon-button", href: href, className: sharedClassName, ...props, children: icon })) }), (0, jsx_runtime_1.jsx)(tooltip_1.TooltipContent, { side: "right", children: title })] }) }));
|
|
19
|
+
};
|
|
20
|
+
exports.SidebarItemIconButton = SidebarItemIconButton;
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { SidebarItemButton } from './sidebar-item-button';
|
|
3
|
+
import { SidebarItemIconButton } from './sidebar-item-icon-button';
|
|
4
|
+
export type SidebarItemProps = React.ComponentProps<typeof SidebarItemButton> & React.ComponentProps<typeof SidebarItemIconButton> & {
|
|
5
|
+
title: string;
|
|
6
|
+
icon: React.ReactNode;
|
|
7
|
+
href: string;
|
|
8
|
+
active?: boolean;
|
|
9
|
+
disabled?: boolean;
|
|
10
|
+
children?: React.ReactNode;
|
|
11
|
+
};
|
|
12
|
+
export declare const SidebarItem: ({ active, href, children, ...props }: SidebarItemProps) => import("react/jsx-runtime").JSX.Element;
|
|
13
|
+
//# sourceMappingURL=sidebar-item.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sidebar-item.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/sidebar/sidebar-item.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAA;AACzD,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAA;AAGlE,MAAM,MAAM,gBAAgB,GAAG,KAAK,CAAC,cAAc,CAAC,OAAO,iBAAiB,CAAC,GAC3E,KAAK,CAAC,cAAc,CAAC,OAAO,qBAAqB,CAAC,GAAG;IACnD,KAAK,EAAE,MAAM,CAAA;IACb,IAAI,EAAE,KAAK,CAAC,SAAS,CAAA;IACrB,IAAI,EAAE,MAAM,CAAA;IACZ,MAAM,CAAC,EAAE,OAAO,CAAA;IAChB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;CAC3B,CAAA;AAEH,eAAO,MAAM,WAAW,GAAI,sCAKzB,gBAAgB,4CAyBlB,CAAA"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
"use strict";
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.SidebarItem = void 0;
|
|
5
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
6
|
+
const navigation_1 = require("next/navigation");
|
|
7
|
+
const sidebar_item_button_1 = require("./sidebar-item-button");
|
|
8
|
+
const sidebar_item_icon_button_1 = require("./sidebar-item-icon-button");
|
|
9
|
+
const sidebar_provider_1 = require("./sidebar-provider");
|
|
10
|
+
const SidebarItem = ({ active, href, children, ...props }) => {
|
|
11
|
+
const pathname = (0, navigation_1.usePathname)();
|
|
12
|
+
const { isCollapsed } = (0, sidebar_provider_1.useSidebar)();
|
|
13
|
+
const isActive = (href) => pathname === href;
|
|
14
|
+
if (isCollapsed) {
|
|
15
|
+
return ((0, jsx_runtime_1.jsx)(sidebar_item_icon_button_1.SidebarItemIconButton, { "data-slot": "sidebar-item", href: href, active: isActive(href) || active, ...props }));
|
|
16
|
+
}
|
|
17
|
+
return ((0, jsx_runtime_1.jsx)(sidebar_item_button_1.SidebarItemButton, { "data-slot": "sidebar-item", href: href, active: isActive(href) || active, ...props }));
|
|
18
|
+
};
|
|
19
|
+
exports.SidebarItem = SidebarItem;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export type SidebarContextProps = {
|
|
3
|
+
isCollapsed: boolean;
|
|
4
|
+
items: Record<string, boolean>;
|
|
5
|
+
setItems: React.Dispatch<React.SetStateAction<Record<string, boolean>>>;
|
|
6
|
+
getItemCollapsed: (key: string) => boolean;
|
|
7
|
+
setItemCollapsed: (key: string, value: boolean) => void;
|
|
8
|
+
toggleSidebar: () => void;
|
|
9
|
+
};
|
|
10
|
+
export declare const useSidebar: () => SidebarContextProps;
|
|
11
|
+
export declare const SidebarProvider: ({ children }: React.PropsWithChildren) => import("react/jsx-runtime").JSX.Element;
|
|
12
|
+
//# sourceMappingURL=sidebar-provider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sidebar-provider.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/sidebar/sidebar-provider.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAA;AAGzB,MAAM,MAAM,mBAAmB,GAAG;IAChC,WAAW,EAAE,OAAO,CAAA;IACpB,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;IAC9B,QAAQ,EAAE,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,cAAc,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,CAAA;IACvE,gBAAgB,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,OAAO,CAAA;IAC1C,gBAAgB,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,KAAK,IAAI,CAAA;IACvD,aAAa,EAAE,MAAM,IAAI,CAAA;CAC1B,CAAA;AAMD,eAAO,MAAM,UAAU,2BAMtB,CAAA;AAED,eAAO,MAAM,eAAe,GAAI,cAAc,KAAK,CAAC,iBAAiB,4CAqDpE,CAAA"}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
"use strict";
|
|
3
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
4
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
5
|
+
};
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.SidebarProvider = exports.useSidebar = void 0;
|
|
8
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
9
|
+
const react_1 = __importDefault(require("react"));
|
|
10
|
+
const storage_1 = require("../../../lib/storage");
|
|
11
|
+
const SidebarContext = react_1.default.createContext(undefined);
|
|
12
|
+
const useSidebar = () => {
|
|
13
|
+
const context = react_1.default.useContext(SidebarContext);
|
|
14
|
+
if (!context) {
|
|
15
|
+
throw new Error('useSidebar must be used within a SidebarProvider');
|
|
16
|
+
}
|
|
17
|
+
return context;
|
|
18
|
+
};
|
|
19
|
+
exports.useSidebar = useSidebar;
|
|
20
|
+
const SidebarProvider = ({ children }) => {
|
|
21
|
+
const [hydrated, setHydrated] = react_1.default.useState(false);
|
|
22
|
+
const [collapsed, setCollapsed] = react_1.default.useState(false);
|
|
23
|
+
const [items, _setItems] = react_1.default.useState({});
|
|
24
|
+
const toggleSidebar = () => setCollapsed((collapsed) => !collapsed);
|
|
25
|
+
const getItemCollapsed = (key) => {
|
|
26
|
+
return items[key] || false;
|
|
27
|
+
};
|
|
28
|
+
const setItemCollapsed = (key, value) => {
|
|
29
|
+
_setItems((items) => ({ ...items, [key]: value }));
|
|
30
|
+
};
|
|
31
|
+
// Read from localStorage after hydration to avoid SSR mismatch
|
|
32
|
+
react_1.default.useEffect(() => {
|
|
33
|
+
setCollapsed((0, storage_1.getStorage)('sidebar-collapsed', false) === 'true');
|
|
34
|
+
_setItems((0, storage_1.getStorageObject)('sidebar-items', {}));
|
|
35
|
+
setHydrated(true);
|
|
36
|
+
}, []);
|
|
37
|
+
// Only persist to localStorage after hydration to avoid overwriting stored values
|
|
38
|
+
react_1.default.useEffect(() => {
|
|
39
|
+
if (!hydrated) {
|
|
40
|
+
return;
|
|
41
|
+
}
|
|
42
|
+
localStorage.setItem('sidebar-collapsed', JSON.stringify(collapsed));
|
|
43
|
+
}, [collapsed, hydrated]);
|
|
44
|
+
react_1.default.useEffect(() => {
|
|
45
|
+
if (!hydrated) {
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
localStorage.setItem('sidebar-items', JSON.stringify(items));
|
|
49
|
+
}, [items, hydrated]);
|
|
50
|
+
return ((0, jsx_runtime_1.jsx)(SidebarContext.Provider, { value: {
|
|
51
|
+
isCollapsed: collapsed,
|
|
52
|
+
items,
|
|
53
|
+
setItems: _setItems,
|
|
54
|
+
getItemCollapsed,
|
|
55
|
+
setItemCollapsed,
|
|
56
|
+
toggleSidebar
|
|
57
|
+
}, children: children }));
|
|
58
|
+
};
|
|
59
|
+
exports.SidebarProvider = SidebarProvider;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sidebar-provider.test.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/sidebar/sidebar-provider.test.tsx"],"names":[],"mappings":""}
|