@nlabs/gothamjs
Version:
Platform
194 lines (193 loc) • 27.2 kB
JavaScript
"use client";
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";
import { jsx, jsxs } from "react/jsx-runtime";
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" }
];
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, {}) }) })
] })
] });
};
var MenuView_default = MenuView;
export {
MenuView,
MenuView_default as default
};
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../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;"],
  "mappings": "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",
  "names": []
}
