@lerianstudio/sindarian-ui 1.0.0-beta.11 → 1.0.0-beta.12

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 (34) hide show
  1. package/dist/components/ui/button/index.d.ts +5 -1
  2. package/dist/components/ui/button/index.d.ts.map +1 -1
  3. package/dist/components/ui/button/index.js +2 -1
  4. package/dist/components/ui/sidebar/index.d.ts +9 -0
  5. package/dist/components/ui/sidebar/index.d.ts.map +1 -0
  6. package/dist/components/ui/sidebar/index.js +24 -0
  7. package/dist/components/ui/sidebar/sidebar-back-button.d.ts +3 -0
  8. package/dist/components/ui/sidebar/sidebar-back-button.d.ts.map +1 -0
  9. package/dist/components/ui/sidebar/sidebar-back-button.js +11 -0
  10. package/dist/components/ui/sidebar/sidebar-components.d.ts +23 -0
  11. package/dist/components/ui/sidebar/sidebar-components.d.ts.map +1 -0
  12. package/dist/components/ui/sidebar/sidebar-components.js +23 -0
  13. package/dist/components/ui/sidebar/sidebar-expand-button.d.ts +6 -0
  14. package/dist/components/ui/sidebar/sidebar-expand-button.d.ts.map +1 -0
  15. package/dist/components/ui/sidebar/sidebar-expand-button.js +19 -0
  16. package/dist/components/ui/sidebar/sidebar-item-button.d.ts +11 -0
  17. package/dist/components/ui/sidebar/sidebar-item-button.d.ts.map +1 -0
  18. package/dist/components/ui/sidebar/sidebar-item-button.js +23 -0
  19. package/dist/components/ui/sidebar/sidebar-item-icon-button.d.ts +11 -0
  20. package/dist/components/ui/sidebar/sidebar-item-icon-button.d.ts.map +1 -0
  21. package/dist/components/ui/sidebar/sidebar-item-icon-button.js +20 -0
  22. package/dist/components/ui/sidebar/sidebar-item.d.ts +12 -0
  23. package/dist/components/ui/sidebar/sidebar-item.d.ts.map +1 -0
  24. package/dist/components/ui/sidebar/sidebar-item.js +19 -0
  25. package/dist/components/ui/sidebar/sidebar-provider.d.ts +8 -0
  26. package/dist/components/ui/sidebar/sidebar-provider.d.ts.map +1 -0
  27. package/dist/components/ui/sidebar/sidebar-provider.js +24 -0
  28. package/dist/components/ui/sidebar/sidebar-root.d.ts +3 -0
  29. package/dist/components/ui/sidebar/sidebar-root.d.ts.map +1 -0
  30. package/dist/components/ui/sidebar/sidebar-root.js +24 -0
  31. package/dist/index.d.ts +1 -0
  32. package/dist/index.d.ts.map +1 -1
  33. package/dist/index.js +1 -0
  34. package/package.json +1 -1
@@ -5,6 +5,10 @@ declare const buttonVariants: (props?: ({
5
5
  fullWidth?: boolean | null | undefined;
6
6
  size?: "default" | "small" | null | undefined;
7
7
  } & import("class-variance-authority/types").ClassProp) | undefined) => string;
8
+ declare const iconVariants: (props?: ({
9
+ position?: "start" | "end" | "far-end" | null | undefined;
10
+ size?: "default" | "small" | null | undefined;
11
+ } & import("class-variance-authority/types").ClassProp) | undefined) => string;
8
12
  export type ButtonProps = React.ComponentProps<'button'> & VariantProps<typeof buttonVariants> & {
9
13
  asChild?: boolean;
10
14
  } & {
@@ -14,5 +18,5 @@ export type ButtonProps = React.ComponentProps<'button'> & VariantProps<typeof b
14
18
  readOnly?: boolean;
15
19
  };
16
20
  declare function Button({ className, variant, size, asChild, icon, iconPlacement, fullWidth, readOnly, onClick, ...props }: ButtonProps): import("react/jsx-runtime").JSX.Element;
17
- export { Button, buttonVariants };
21
+ export { Button, buttonVariants, iconVariants };
18
22
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/button/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAE9B,OAAO,EAAO,KAAK,YAAY,EAAE,MAAM,0BAA0B,CAAA;AAIjE,QAAA,MAAM,cAAc;;;;8EA0BlB,CAAA;AAoBF,MAAM,MAAM,WAAW,GAAG,KAAK,CAAC,cAAc,CAAC,QAAQ,CAAC,GACtD,YAAY,CAAC,OAAO,cAAc,CAAC,GAAG;IACpC,OAAO,CAAC,EAAE,OAAO,CAAA;CAClB,GAAG;IACF,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACtB,aAAa,CAAC,EAAE,OAAO,GAAG,KAAK,GAAG,SAAS,CAAA;IAC3C,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,CAAA;AAEH,iBAAS,MAAM,CAAC,EACd,SAAS,EACT,OAAO,EACP,IAAI,EACJ,OAAe,EACf,IAAI,EACJ,aAAuB,EACvB,SAAiB,EACjB,QAAgB,EAChB,OAAO,EACP,GAAG,KAAK,EACT,EAAE,WAAW,2CAgCb;AAED,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/button/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAE9B,OAAO,EAAO,KAAK,YAAY,EAAE,MAAM,0BAA0B,CAAA;AAIjE,QAAA,MAAM,cAAc;;;;8EA0BlB,CAAA;AAEF,QAAA,MAAM,YAAY;;;8EAgBhB,CAAA;AAEF,MAAM,MAAM,WAAW,GAAG,KAAK,CAAC,cAAc,CAAC,QAAQ,CAAC,GACtD,YAAY,CAAC,OAAO,cAAc,CAAC,GAAG;IACpC,OAAO,CAAC,EAAE,OAAO,CAAA;CAClB,GAAG;IACF,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACtB,aAAa,CAAC,EAAE,OAAO,GAAG,KAAK,GAAG,SAAS,CAAA;IAC3C,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,CAAA;AAEH,iBAAS,MAAM,CAAC,EACd,SAAS,EACT,OAAO,EACP,IAAI,EACJ,OAAe,EACf,IAAI,EACJ,aAAuB,EACvB,SAAiB,EACjB,QAAgB,EAChB,OAAO,EACP,GAAG,KAAK,EACT,EAAE,WAAW,2CAgCb;AAED,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,YAAY,EAAE,CAAA"}
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.buttonVariants = void 0;
3
+ exports.iconVariants = exports.buttonVariants = void 0;
4
4
  exports.Button = Button;
5
5
  const jsx_runtime_1 = require("react/jsx-runtime");
6
6
  const react_slot_1 = require("@radix-ui/react-slot");
@@ -50,6 +50,7 @@ const iconVariants = (0, class_variance_authority_1.cva)('', {
50
50
  size: 'default'
51
51
  }
52
52
  });
53
+ exports.iconVariants = iconVariants;
53
54
  function Button({ className, variant, size, asChild = false, icon, iconPlacement = 'start', fullWidth = false, readOnly = false, onClick, ...props }) {
54
55
  const Comp = asChild ? react_slot_1.Slot : 'button';
55
56
  const handleClick = (e) => {
@@ -0,0 +1,9 @@
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
+ //# 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"}
@@ -0,0 +1,24 @@
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);
@@ -0,0 +1,3 @@
1
+ import { SidebarItem } from './sidebar-item';
2
+ export declare function SidebarBackButton({ ...props }: React.ComponentProps<typeof SidebarItem>): import("react/jsx-runtime").JSX.Element;
3
+ //# sourceMappingURL=sidebar-back-button.d.ts.map
@@ -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;AAI5C,wBAAgB,iBAAiB,CAAC,EAChC,GAAG,KAAK,EACT,EAAE,KAAK,CAAC,cAAc,CAAC,OAAO,WAAW,CAAC,2CAS1C"}
@@ -0,0 +1,11 @@
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
+ const separator_1 = require("../separator");
7
+ const sidebar_provider_1 = require("./sidebar-provider");
8
+ function SidebarBackButton({ ...props }) {
9
+ const { isCollapsed } = (0, sidebar_provider_1.useSidebar)();
10
+ return ((0, jsx_runtime_1.jsxs)("div", { className: "flex w-full flex-col gap-1.5 pt-1.5", children: [(0, jsx_runtime_1.jsx)(sidebar_item_1.SidebarItem, { ...props }), isCollapsed && (0, jsx_runtime_1.jsx)(separator_1.Separator, {})] }));
11
+ }
@@ -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,4CAWrB,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 h-[60px] w-full items-center bg-white px-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 bg-white px-4 pt-4', 'group-data-[collapsed=true]/sidebar:items-center group-data-[collapsed=true]/sidebar:px-2', 'group-data-[collapsed=false]/sidebar:min-w-[244px]', 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)('grid gap-1', 'group-data[collapsed=true]/sidebar:justify-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,6 @@
1
+ type SidebarExpandButtonProps = {
2
+ tooltip?: string;
3
+ };
4
+ export declare const SidebarExpandButton: ({ tooltip }: SidebarExpandButtonProps) => import("react/jsx-runtime").JSX.Element;
5
+ export {};
6
+ //# sourceMappingURL=sidebar-expand-button.d.ts.map
@@ -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,11 @@
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
+ disabled?: boolean;
9
+ };
10
+ export declare function SidebarItemButton({ className, title, icon, href, active, disabled, ...props }: SidebarItemButtonProps): import("react/jsx-runtime").JSX.Element;
11
+ //# 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;CACnB,CAAA;AAED,wBAAgB,iBAAiB,CAAC,EAChC,SAAS,EACT,KAAK,EACL,IAAI,EACJ,IAAI,EACJ,MAAM,EACN,QAAgB,EAChB,GAAG,KAAK,EACT,EAAE,sBAAsB,2CA2CxB"}
@@ -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, 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', 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) {
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,11 @@
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
+ disabled?: boolean;
8
+ };
9
+ export declare const SidebarItemIconButton: ({ title, icon, href, active, disabled, ...props }: SidebarItemIconButtonProps) => import("react/jsx-runtime").JSX.Element;
10
+ export {};
11
+ //# 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;CACnB,CAAA;AAED,eAAO,MAAM,qBAAqB,GAAI,mDAOnC,0BAA0B,4CAmC5B,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, disabled, ...props }) => {
15
+ const sharedClassName = (0, utils_1.cn)((0, button_1.buttonVariants)({
16
+ variant: active ? 'tertiary' : 'outline'
17
+ }), (0, icon_button_1.iconButtonVariants)(), 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 ? ((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,12 @@
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
+ };
11
+ export declare const SidebarItem: ({ active, disabled, href, ...props }: SidebarItemProps) => import("react/jsx-runtime").JSX.Element;
12
+ //# 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;CACnB,CAAA;AAEH,eAAO,MAAM,WAAW,GAAI,sCAKzB,gBAAgB,4CA2BlB,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, disabled, href, ...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, disabled: disabled, ...props }));
16
+ }
17
+ return ((0, jsx_runtime_1.jsx)(sidebar_item_button_1.SidebarItemButton, { "data-slot": "sidebar-item", href: href, active: isActive(href) || active, disabled: disabled, ...props }));
18
+ };
19
+ exports.SidebarItem = SidebarItem;
@@ -0,0 +1,8 @@
1
+ import React from 'react';
2
+ export type SidebarContextProps = {
3
+ isCollapsed: boolean;
4
+ toggleSidebar: () => void;
5
+ };
6
+ export declare const useSidebar: () => SidebarContextProps;
7
+ export declare const SidebarProvider: ({ children }: React.PropsWithChildren) => import("react/jsx-runtime").JSX.Element;
8
+ //# 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;AAEzB,MAAM,MAAM,mBAAmB,GAAG;IAChC,WAAW,EAAE,OAAO,CAAA;IACpB,aAAa,EAAE,MAAM,IAAI,CAAA;CAC1B,CAAA;AAMD,eAAO,MAAM,UAAU,2BAMtB,CAAA;AAED,eAAO,MAAM,eAAe,GAAI,cAAc,KAAK,CAAC,iBAAiB,4CAUpE,CAAA"}
@@ -0,0 +1,24 @@
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 SidebarContext = react_1.default.createContext(undefined);
11
+ const useSidebar = () => {
12
+ const context = react_1.default.useContext(SidebarContext);
13
+ if (!context) {
14
+ throw new Error('useSidebar must be used within a SidebarProvider');
15
+ }
16
+ return context;
17
+ };
18
+ exports.useSidebar = useSidebar;
19
+ const SidebarProvider = ({ children }) => {
20
+ const [isCollapsed, setIsCollapsed] = react_1.default.useState(true);
21
+ const toggleSidebar = () => setIsCollapsed(!isCollapsed);
22
+ return ((0, jsx_runtime_1.jsx)(SidebarContext.Provider, { value: { isCollapsed, toggleSidebar }, children: children }));
23
+ };
24
+ exports.SidebarProvider = SidebarProvider;
@@ -0,0 +1,3 @@
1
+ import React from 'react';
2
+ export declare const SidebarRoot: ({ className, ...props }: React.ComponentProps<"nav">) => import("react/jsx-runtime").JSX.Element;
3
+ //# sourceMappingURL=sidebar-root.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sidebar-root.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/sidebar/sidebar-root.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAA;AAoBzB,eAAO,MAAM,WAAW,GAAI,yBAGzB,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,4CAW7B,CAAA"}
@@ -0,0 +1,24 @@
1
+ 'use client';
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.SidebarRoot = void 0;
5
+ const jsx_runtime_1 = require("react/jsx-runtime");
6
+ const class_variance_authority_1 = require("class-variance-authority");
7
+ const sidebar_provider_1 = require("./sidebar-provider");
8
+ const utils_1 = require("../../../lib/utils");
9
+ const sidebarVariants = (0, class_variance_authority_1.cva)('group/sidebar shadow-sidebar dark:bg-cod-gray-950 relative flex flex-col transition-all duration-100', {
10
+ variants: {
11
+ collapsed: {
12
+ true: 'w-fit',
13
+ false: 'w-[244px]'
14
+ }
15
+ },
16
+ defaultVariants: {
17
+ collapsed: false
18
+ }
19
+ });
20
+ const SidebarRoot = ({ className, ...props }) => {
21
+ const { isCollapsed } = (0, sidebar_provider_1.useSidebar)();
22
+ return ((0, jsx_runtime_1.jsx)("nav", { "data-slot": "sidebar-root", className: (0, utils_1.cn)(sidebarVariants({ collapsed: isCollapsed }), className), "data-collapsed": isCollapsed, ...props }));
23
+ };
24
+ exports.SidebarRoot = SidebarRoot;
package/dist/index.d.ts CHANGED
@@ -23,6 +23,7 @@ export * from './components/ui/progress';
23
23
  export * from './components/ui/select';
24
24
  export * from './components/ui/separator';
25
25
  export * from './components/ui/sheet';
26
+ export * from './components/ui/sidebar';
26
27
  export * from './components/ui/skeleton';
27
28
  export * from './components/ui/stepper';
28
29
  export * from './hooks/use-stepper';
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.tsx"],"names":[],"mappings":"AAGA,cAAc,uBAAuB,CAAA;AACrC,cAAc,8BAA8B,CAAA;AAC5C,cAAc,mCAAmC,CAAA;AACjD,cAAc,wBAAwB,CAAA;AACtC,cAAc,uBAAuB,CAAA;AACrC,cAAc,4BAA4B,CAAA;AAC1C,cAAc,wBAAwB,CAAA;AACtC,cAAc,6BAA6B,CAAA;AAC3C,cAAc,sBAAsB,CAAA;AACpC,cAAc,0BAA0B,CAAA;AACxC,cAAc,6BAA6B,CAAA;AAC3C,cAAc,yBAAyB,CAAA;AACvC,cAAc,wBAAwB,CAAA;AACtC,cAAc,+BAA+B,CAAA;AAC7C,cAAc,uBAAuB,CAAA;AACrC,cAAc,uBAAuB,CAAA;AACrC,cAAc,gCAAgC,CAAA;AAC9C,cAAc,iCAAiC,CAAA;AAC/C,cAAc,uBAAuB,CAAA;AACrC,cAAc,mCAAmC,CAAA;AACjD,cAAc,yBAAyB,CAAA;AACvC,cAAc,0BAA0B,CAAA;AACxC,cAAc,wBAAwB,CAAA;AACtC,cAAc,2BAA2B,CAAA;AACzC,cAAc,uBAAuB,CAAA;AACrC,cAAc,0BAA0B,CAAA;AACxC,cAAc,yBAAyB,CAAA;AACvC,cAAc,qBAAqB,CAAA;AACnC,cAAc,wBAAwB,CAAA;AACtC,cAAc,uBAAuB,CAAA;AACrC,cAAc,sBAAsB,CAAA;AACpC,cAAc,0BAA0B,CAAA;AACxC,cAAc,uBAAuB,CAAA;AACrC,cAAc,+BAA+B,CAAA;AAC7C,cAAc,mBAAmB,CAAA;AACjC,cAAc,yBAAyB,CAAA;AACvC,cAAc,sBAAsB,CAAA;AAGpC,OAAO,EAAE,UAAU,IAAI,qBAAqB,EAAE,MAAM,yBAAyB,CAAA;AAC7E,cAAc,8CAA8C,CAAA;AAC5D,cAAc,mBAAmB,CAAA;AACjC,cAAc,qBAAqB,CAAA;AACnC,cAAc,yBAAyB,CAAA;AACvC,cAAc,gCAAgC,CAAA;AAC9C,cAAc,mBAAmB,CAAA;AACjC,cAAc,mBAAmB,CAAA;AACjC,cAAc,0BAA0B,CAAA;AACxC,cAAc,yBAAyB,CAAA;AACvC,cAAc,oBAAoB,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.tsx"],"names":[],"mappings":"AAGA,cAAc,uBAAuB,CAAA;AACrC,cAAc,8BAA8B,CAAA;AAC5C,cAAc,mCAAmC,CAAA;AACjD,cAAc,wBAAwB,CAAA;AACtC,cAAc,uBAAuB,CAAA;AACrC,cAAc,4BAA4B,CAAA;AAC1C,cAAc,wBAAwB,CAAA;AACtC,cAAc,6BAA6B,CAAA;AAC3C,cAAc,sBAAsB,CAAA;AACpC,cAAc,0BAA0B,CAAA;AACxC,cAAc,6BAA6B,CAAA;AAC3C,cAAc,yBAAyB,CAAA;AACvC,cAAc,wBAAwB,CAAA;AACtC,cAAc,+BAA+B,CAAA;AAC7C,cAAc,uBAAuB,CAAA;AACrC,cAAc,uBAAuB,CAAA;AACrC,cAAc,gCAAgC,CAAA;AAC9C,cAAc,iCAAiC,CAAA;AAC/C,cAAc,uBAAuB,CAAA;AACrC,cAAc,mCAAmC,CAAA;AACjD,cAAc,yBAAyB,CAAA;AACvC,cAAc,0BAA0B,CAAA;AACxC,cAAc,wBAAwB,CAAA;AACtC,cAAc,2BAA2B,CAAA;AACzC,cAAc,uBAAuB,CAAA;AACrC,cAAc,yBAAyB,CAAA;AACvC,cAAc,0BAA0B,CAAA;AACxC,cAAc,yBAAyB,CAAA;AACvC,cAAc,qBAAqB,CAAA;AACnC,cAAc,wBAAwB,CAAA;AACtC,cAAc,uBAAuB,CAAA;AACrC,cAAc,sBAAsB,CAAA;AACpC,cAAc,0BAA0B,CAAA;AACxC,cAAc,uBAAuB,CAAA;AACrC,cAAc,+BAA+B,CAAA;AAC7C,cAAc,mBAAmB,CAAA;AACjC,cAAc,yBAAyB,CAAA;AACvC,cAAc,sBAAsB,CAAA;AAGpC,OAAO,EAAE,UAAU,IAAI,qBAAqB,EAAE,MAAM,yBAAyB,CAAA;AAC7E,cAAc,8CAA8C,CAAA;AAC5D,cAAc,mBAAmB,CAAA;AACjC,cAAc,qBAAqB,CAAA;AACnC,cAAc,yBAAyB,CAAA;AACvC,cAAc,gCAAgC,CAAA;AAC9C,cAAc,mBAAmB,CAAA;AACjC,cAAc,mBAAmB,CAAA;AACjC,cAAc,0BAA0B,CAAA;AACxC,cAAc,yBAAyB,CAAA;AACvC,cAAc,oBAAoB,CAAA"}
package/dist/index.js CHANGED
@@ -42,6 +42,7 @@ __exportStar(require("./components/ui/progress"), exports);
42
42
  __exportStar(require("./components/ui/select"), exports);
43
43
  __exportStar(require("./components/ui/separator"), exports);
44
44
  __exportStar(require("./components/ui/sheet"), exports);
45
+ __exportStar(require("./components/ui/sidebar"), exports);
45
46
  __exportStar(require("./components/ui/skeleton"), exports);
46
47
  __exportStar(require("./components/ui/stepper"), exports);
47
48
  __exportStar(require("./hooks/use-stepper"), exports);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@lerianstudio/sindarian-ui",
3
- "version": "1.0.0-beta.11",
3
+ "version": "1.0.0-beta.12",
4
4
  "description": "Sindarian UI - A UI library for Midaz Console",
5
5
  "license": "ISC",
6
6
  "author": {