@nlabs/gothamjs
Version:
Platform
303 lines (302 loc) • 35.4 kB
JavaScript
'use client';
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
import { Dialog, DialogBackdrop, DialogPanel, Menu, MenuButton, MenuItem, MenuItems, TransitionChild } from '@headlessui/react';
import { cn } from '@nlabs/utils';
import { Menu as Bars3, Bell, Calendar, ChevronDown, Files, Folder, Home, PieChart, Search, Users, X } from 'lucide-react';
import { useState } from 'react';
import { Outlet } from 'react-router';
import { Config } from '../../config/appConfig.js';
const sideMenuItems = [
{
current: true,
href: '#',
icon: Home,
name: 'Dashboard'
},
{
current: false,
href: '#',
icon: Users,
name: 'Team'
},
{
current: false,
href: '#',
icon: Folder,
name: 'Projects'
},
{
current: false,
href: '#',
icon: Calendar,
name: 'Calendar'
},
{
current: false,
href: '#',
icon: Files,
name: 'Documents'
},
{
current: false,
href: '#',
icon: PieChart,
name: 'Reports'
}
];
const userMenuItems = [
{
href: '#',
name: 'Profile'
},
{
href: '#',
name: 'Sign out'
}
];
export const MenuView = ()=>{
const [sidebarOpen, setSidebarOpen] = useState(false);
const app = Config.get('app');
return /*#__PURE__*/ _jsxs("div", {
children: [
/*#__PURE__*/ _jsxs(Dialog, {
open: sidebarOpen,
onClose: setSidebarOpen,
className: "relative z-50 lg:hidden",
children: [
/*#__PURE__*/ _jsx(DialogBackdrop, {
transition: true,
className: "fixed inset-0 bg-gray-900/80 transition-opacity duration-300 ease-linear data-closed:opacity-0"
}),
/*#__PURE__*/ _jsx("div", {
className: "fixed inset-0 flex",
children: /*#__PURE__*/ _jsxs(DialogPanel, {
transition: true,
className: "relative mr-16 flex w-full max-w-xs flex-1 transform transition duration-300 ease-in-out data-closed:-translate-x-full",
children: [
/*#__PURE__*/ _jsx(TransitionChild, {
children: /*#__PURE__*/ _jsx("div", {
className: "absolute top-0 left-full flex w-16 justify-center pt-5 duration-300 ease-in-out data-closed:opacity-0",
children: /*#__PURE__*/ _jsxs("button", {
type: "button",
onClick: ()=>setSidebarOpen(false),
className: "-m-2.5 p-2.5",
children: [
/*#__PURE__*/ _jsx("span", {
className: "sr-only",
children: "Close sidebar"
}),
/*#__PURE__*/ _jsx(X, {
"aria-hidden": "true",
className: "size-6 text-white"
})
]
})
})
}),
/*#__PURE__*/ _jsxs("div", {
className: "flex grow flex-col gap-y-5 overflow-y-auto bg-gray-900 px-6 pb-2 ring-1 ring-white/10",
children: [
/*#__PURE__*/ _jsx("div", {
className: "flex h-16 shrink-0 items-center",
children: /*#__PURE__*/ _jsx("img", {
alt: app?.title,
src: app?.logo,
className: "h-8 w-auto"
})
}),
/*#__PURE__*/ _jsx("nav", {
className: "flex flex-1 flex-col",
children: /*#__PURE__*/ _jsx("ul", {
role: "list",
className: "-mx-2 flex-1 space-y-1",
children: sideMenuItems?.map((item)=>/*#__PURE__*/ _jsx("li", {
children: /*#__PURE__*/ _jsxs("a", {
href: item.href,
className: cn(item.current ? 'bg-gray-800 text-white' : 'text-gray-400 hover:bg-gray-800 hover:text-white', 'group flex gap-x-3 rounded-md p-2 text-sm/6 font-semibold'),
children: [
item.icon && /*#__PURE__*/ _jsx(item.icon, {
"aria-hidden": "true",
className: "size-6 shrink-0"
}),
item.name
]
})
}, item.name))
})
})
]
})
]
})
})
]
}),
/*#__PURE__*/ _jsxs("div", {
className: "hidden lg:fixed lg:inset-y-0 lg:left-0 lg:z-50 lg:block lg:w-20 lg:overflow-y-auto lg:bg-gray-900 lg:pb-4",
children: [
/*#__PURE__*/ _jsx("div", {
className: "flex h-16 shrink-0 items-center justify-center",
children: /*#__PURE__*/ _jsx("img", {
alt: "Your Company",
src: "https://tailwindcss.com/plus-assets/img/logos/mark.svg?color=indigo&shade=500",
className: "h-8 w-auto"
})
}),
/*#__PURE__*/ _jsx("nav", {
className: "mt-8",
children: /*#__PURE__*/ _jsx("ul", {
role: "list",
className: "flex flex-col items-center space-y-1",
children: sideMenuItems?.map((item)=>/*#__PURE__*/ _jsx("li", {
children: /*#__PURE__*/ _jsxs("a", {
href: item.href,
className: cn(item.current ? 'bg-gray-800 text-white' : 'text-gray-400 hover:bg-gray-800 hover:text-white', 'group flex gap-x-3 rounded-md p-3 text-sm/6 font-semibold'),
children: [
item.icon && /*#__PURE__*/ _jsx(item.icon, {
"aria-hidden": "true",
className: "size-6 shrink-0"
}),
/*#__PURE__*/ _jsx("span", {
className: "sr-only",
children: item.name
})
]
})
}, item.name))
})
})
]
}),
/*#__PURE__*/ _jsxs("div", {
className: "lg:pl-20",
children: [
/*#__PURE__*/ _jsxs("div", {
className: "sticky top-0 z-40 flex h-16 shrink-0 items-center gap-x-4 border-b border-gray-200 bg-white px-4 shadow-xs sm:gap-x-6 sm:px-6 lg:px-8",
children: [
/*#__PURE__*/ _jsxs("button", {
type: "button",
onClick: ()=>setSidebarOpen(true),
className: "-m-2.5 p-2.5 text-gray-700 lg:hidden",
children: [
/*#__PURE__*/ _jsx("span", {
className: "sr-only",
children: "Open sidebar"
}),
/*#__PURE__*/ _jsx(Bars3, {
"aria-hidden": "true",
className: "size-6"
})
]
}),
/*#__PURE__*/ _jsx("div", {
"aria-hidden": "true",
className: "h-6 w-px bg-gray-900/10 lg:hidden"
}),
/*#__PURE__*/ _jsxs("div", {
className: "flex flex-1 gap-x-4 self-stretch lg:gap-x-6",
children: [
/*#__PURE__*/ _jsxs("form", {
action: "#",
method: "GET",
className: "grid flex-1 grid-cols-1",
children: [
/*#__PURE__*/ _jsx("input", {
name: "search",
type: "search",
placeholder: "Search",
"aria-label": "Search",
className: "col-start-1 row-start-1 block size-full bg-white pl-8 text-base text-gray-900 outline-hidden placeholder:text-gray-400 sm:text-sm/6"
}),
/*#__PURE__*/ _jsx(Search, {
"aria-hidden": "true",
className: "pointer-events-none col-start-1 row-start-1 size-5 self-center text-gray-400"
})
]
}),
/*#__PURE__*/ _jsxs("div", {
className: "flex items-center gap-x-4 lg:gap-x-6",
children: [
/*#__PURE__*/ _jsxs("button", {
type: "button",
className: "-m-2.5 p-2.5 text-gray-400 hover:text-gray-500",
children: [
/*#__PURE__*/ _jsx("span", {
className: "sr-only",
children: "View notifications"
}),
/*#__PURE__*/ _jsx(Bell, {
"aria-hidden": "true",
className: "size-6"
})
]
}),
/*#__PURE__*/ _jsx("div", {
"aria-hidden": "true",
className: "hidden lg:block lg:h-6 lg:w-px lg:bg-gray-900/10"
}),
/*#__PURE__*/ _jsxs(Menu, {
as: "div",
className: "relative",
children: [
/*#__PURE__*/ _jsxs(MenuButton, {
className: "-m-1.5 flex items-center p-1.5",
children: [
/*#__PURE__*/ _jsx("span", {
className: "sr-only",
children: "Open user menu"
}),
/*#__PURE__*/ _jsx("img", {
alt: "",
src: "https://images.unsplash.com/photo-1472099645785-5658abf4ff4e?ixlib=rb-1.2.1&ixid=eyJhcHBfaWQiOjEyMDd9&auto=format&fit=facearea&facepad=2&w=256&h=256&q=80",
className: "size-8 rounded-full bg-gray-50"
}),
/*#__PURE__*/ _jsxs("span", {
className: "hidden lg:flex lg:items-center",
children: [
/*#__PURE__*/ _jsx("span", {
"aria-hidden": "true",
className: "ml-4 text-sm/6 font-semibold text-gray-900",
children: "Tom Cook"
}),
/*#__PURE__*/ _jsx(ChevronDown, {
"aria-hidden": "true",
className: "ml-2 size-5 text-gray-400"
})
]
})
]
}),
/*#__PURE__*/ _jsx(MenuItems, {
transition: true,
className: "absolute right-0 z-10 mt-2.5 w-32 origin-top-right rounded-md bg-white py-2 ring-1 shadow-lg ring-gray-900/5 transition focus:outline-hidden data-closed:scale-95 data-closed:transform data-closed:opacity-0 data-enter:duration-100 data-enter:ease-out data-leave:duration-75 data-leave:ease-in",
children: userMenuItems?.map((item)=>/*#__PURE__*/ _jsx(MenuItem, {
children: /*#__PURE__*/ _jsx("a", {
href: item.href,
className: "block px-3 py-1 text-sm/6 text-gray-900 data-focus:bg-gray-50 data-focus:outline-hidden",
children: item.name
})
}, item.name))
})
]
})
]
})
]
})
]
}),
/*#__PURE__*/ _jsx("main", {
className: "xl:pl-96",
children: /*#__PURE__*/ _jsx("div", {
className: "px-4 py-10 sm:px-6 lg:px-8 lg:py-6",
children: /*#__PURE__*/ _jsx(Outlet, {})
})
})
]
})
]
});
};
export default MenuView;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["/Users/nitrog7/Development/gothamjs/src/views/MenuView/MenuView.tsx"],"sourcesContent":["'use client';\nimport {\n  Dialog,\n  DialogBackdrop,\n  DialogPanel,\n  Menu,\n  MenuButton,\n  MenuItem,\n  MenuItems,\n  TransitionChild\n} from '@headlessui/react';\nimport {cn} from '@nlabs/utils';\nimport {\n  Menu as Bars3,\n  Bell,\n  Calendar,\n  ChevronDown,\n  Files,\n  Folder,\n  Home,\n  PieChart,\n  Search,\n  Users,\n  X\n} from 'lucide-react';\nimport {useState} from 'react';\nimport {Outlet} from 'react-router';\n\nimport {Config} from '../../config/appConfig.js';\n\nimport type {ElementType, FC} from 'react';\nimport type {GothamConfiguration} from '../Gotham/GothamProvider.js';\n\nconst sideMenuItems: MenuItems[] = [\n  { current: true, href: '#', icon: Home, name: 'Dashboard' },\n  { current: false, href: '#', icon: Users, name: 'Team' },\n  { current: false, href: '#', icon: Folder, name: 'Projects' },\n  { current: false, href: '#', icon: Calendar, name: 'Calendar' },\n  { current: false, href: '#', icon: Files, name: 'Documents' },\n  { current: false, href: '#', icon: PieChart, name: 'Reports' }\n];\n\nconst userMenuItems: MenuItems[] = [\n  { href: '#', name: 'Profile' },\n  { href: '#', name: 'Sign out' }\n];\n\nexport type MenuItems = {\n  readonly current?: boolean;\n  readonly href: string;\n  readonly icon?: ElementType;\n  readonly name: string;\n};\n\nexport interface MenuViewProps {\n  sideMenuItems: MenuItems[];\n  userMenuItems: MenuItems[];\n}\n\nexport const MenuView: FC<MenuViewProps> = () => {\n  const [sidebarOpen, setSidebarOpen] = useState(false);\n  const app: GothamConfiguration['app'] = Config.get('app') as GothamConfiguration['app'];\n\n  return (\n    <div>\n      <Dialog open={sidebarOpen} onClose={setSidebarOpen} className=\"relative z-50 lg:hidden\">\n        <DialogBackdrop\n          transition\n          className=\"fixed inset-0 bg-gray-900/80 transition-opacity duration-300 ease-linear data-closed:opacity-0\"\n        />\n\n        <div className=\"fixed inset-0 flex\">\n          <DialogPanel\n            transition\n            className=\"relative mr-16 flex w-full max-w-xs flex-1 transform transition duration-300 ease-in-out data-closed:-translate-x-full\"\n          >\n            <TransitionChild>\n              <div className=\"absolute top-0 left-full flex w-16 justify-center pt-5 duration-300 ease-in-out data-closed:opacity-0\">\n                <button type=\"button\" onClick={() => setSidebarOpen(false)} className=\"-m-2.5 p-2.5\">\n                  <span className=\"sr-only\">Close sidebar</span>\n                  <X aria-hidden=\"true\" className=\"size-6 text-white\" />\n                </button>\n              </div>\n            </TransitionChild>\n\n            <div className=\"flex grow flex-col gap-y-5 overflow-y-auto bg-gray-900 px-6 pb-2 ring-1 ring-white/10\">\n              <div className=\"flex h-16 shrink-0 items-center\">\n                <img\n                  alt={app?.title}\n                  src={app?.logo}\n                  className=\"h-8 w-auto\"\n                />\n              </div>\n              <nav className=\"flex flex-1 flex-col\">\n                <ul role=\"list\" className=\"-mx-2 flex-1 space-y-1\">\n                  {sideMenuItems?.map((item) => (\n                    <li key={item.name}>\n                      <a\n                        href={item.href}\n                        className={cn(\n                          item.current\n                            ? 'bg-gray-800 text-white'\n                            : 'text-gray-400 hover:bg-gray-800 hover:text-white',\n                          'group flex gap-x-3 rounded-md p-2 text-sm/6 font-semibold'\n                        )}\n                      >\n                        {item.icon && <item.icon aria-hidden=\"true\" className=\"size-6 shrink-0\" />}\n                        {item.name}\n                      </a>\n                    </li>\n                  ))}\n                </ul>\n              </nav>\n            </div>\n          </DialogPanel>\n        </div>\n      </Dialog>\n\n      {/* Static sidebar for desktop */}\n      <div className=\"hidden lg:fixed lg:inset-y-0 lg:left-0 lg:z-50 lg:block lg:w-20 lg:overflow-y-auto lg:bg-gray-900 lg:pb-4\">\n        <div className=\"flex h-16 shrink-0 items-center justify-center\">\n          <img\n            alt=\"Your Company\"\n            src=\"https://tailwindcss.com/plus-assets/img/logos/mark.svg?color=indigo&shade=500\"\n            className=\"h-8 w-auto\"\n          />\n        </div>\n        <nav className=\"mt-8\">\n          <ul role=\"list\" className=\"flex flex-col items-center space-y-1\">\n            {sideMenuItems?.map((item) => (\n              <li key={item.name}>\n                <a\n                  href={item.href}\n                  className={cn(\n                    item.current ? 'bg-gray-800 text-white' : 'text-gray-400 hover:bg-gray-800 hover:text-white',\n                    'group flex gap-x-3 rounded-md p-3 text-sm/6 font-semibold'\n                  )}\n                >\n                  {item.icon && <item.icon aria-hidden=\"true\" className=\"size-6 shrink-0\" />}\n                  <span className=\"sr-only\">{item.name}</span>\n                </a>\n              </li>\n            ))}\n          </ul>\n        </nav>\n      </div>\n\n      <div className=\"lg:pl-20\">\n        <div className=\"sticky top-0 z-40 flex h-16 shrink-0 items-center gap-x-4 border-b border-gray-200 bg-white px-4 shadow-xs sm:gap-x-6 sm:px-6 lg:px-8\">\n          <button type=\"button\" onClick={() => setSidebarOpen(true)} className=\"-m-2.5 p-2.5 text-gray-700 lg:hidden\">\n            <span className=\"sr-only\">Open sidebar</span>\n            <Bars3 aria-hidden=\"true\" className=\"size-6\" />\n          </button>\n\n          {/* Separator */}\n          <div aria-hidden=\"true\" className=\"h-6 w-px bg-gray-900/10 lg:hidden\" />\n\n          <div className=\"flex flex-1 gap-x-4 self-stretch lg:gap-x-6\">\n            <form action=\"#\" method=\"GET\" className=\"grid flex-1 grid-cols-1\">\n              <input\n                name=\"search\"\n                type=\"search\"\n                placeholder=\"Search\"\n                aria-label=\"Search\"\n                className=\"col-start-1 row-start-1 block size-full bg-white pl-8 text-base text-gray-900 outline-hidden placeholder:text-gray-400 sm:text-sm/6\"\n              />\n              <Search\n                aria-hidden=\"true\"\n                className=\"pointer-events-none col-start-1 row-start-1 size-5 self-center text-gray-400\"\n              />\n            </form>\n            <div className=\"flex items-center gap-x-4 lg:gap-x-6\">\n              <button type=\"button\" className=\"-m-2.5 p-2.5 text-gray-400 hover:text-gray-500\">\n                <span className=\"sr-only\">View notifications</span>\n                <Bell aria-hidden=\"true\" className=\"size-6\" />\n              </button>\n\n              {/* Separator */}\n              <div aria-hidden=\"true\" className=\"hidden lg:block lg:h-6 lg:w-px lg:bg-gray-900/10\" />\n\n              {/* Profile dropdown */}\n              <Menu as=\"div\" className=\"relative\">\n                <MenuButton className=\"-m-1.5 flex items-center p-1.5\">\n                  <span className=\"sr-only\">Open user menu</span>\n                  <img\n                    alt=\"\"\n                    src=\"https://images.unsplash.com/photo-1472099645785-5658abf4ff4e?ixlib=rb-1.2.1&ixid=eyJhcHBfaWQiOjEyMDd9&auto=format&fit=facearea&facepad=2&w=256&h=256&q=80\"\n                    className=\"size-8 rounded-full bg-gray-50\"\n                  />\n                  <span className=\"hidden lg:flex lg:items-center\">\n                    <span aria-hidden=\"true\" className=\"ml-4 text-sm/6 font-semibold text-gray-900\">\n                        Tom Cook\n                    </span>\n                    <ChevronDown aria-hidden=\"true\" className=\"ml-2 size-5 text-gray-400\" />\n                  </span>\n                </MenuButton>\n                <MenuItems\n                  transition\n                  className=\"absolute right-0 z-10 mt-2.5 w-32 origin-top-right rounded-md bg-white py-2 ring-1 shadow-lg ring-gray-900/5 transition focus:outline-hidden data-closed:scale-95 data-closed:transform data-closed:opacity-0 data-enter:duration-100 data-enter:ease-out data-leave:duration-75 data-leave:ease-in\"\n                >\n                  {userMenuItems?.map((item) => (\n                    <MenuItem key={item.name}>\n                      <a\n                        href={item.href}\n                        className=\"block px-3 py-1 text-sm/6 text-gray-900 data-focus:bg-gray-50 data-focus:outline-hidden\"\n                      >\n                        {item.name}\n                      </a>\n                    </MenuItem>\n                  ))}\n                </MenuItems>\n              </Menu>\n            </div>\n          </div>\n        </div>\n\n        <main className=\"xl:pl-96\">\n          <div className=\"px-4 py-10 sm:px-6 lg:px-8 lg:py-6\"><Outlet/></div>\n        </main>\n      </div>\n    </div>\n  );\n};\n\nexport default MenuView;"],"names":["Dialog","DialogBackdrop","DialogPanel","Menu","MenuButton","MenuItem","MenuItems","TransitionChild","cn","Bars3","Bell","Calendar","ChevronDown","Files","Folder","Home","PieChart","Search","Users","X","useState","Outlet","Config","sideMenuItems","current","href","icon","name","userMenuItems","MenuView","sidebarOpen","setSidebarOpen","app","get","div","open","onClose","className","transition","button","type","onClick","span","aria-hidden","img","alt","title","src","logo","nav","ul","role","map","item","li","a","form","action","method","input","placeholder","aria-label","as","main"],"mappings":"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"}