UNPKG

@nlabs/gothamjs

Version:
303 lines (302 loc) 35.4 kB
'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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"}