UNPKG

@nlabs/gothamjs

Version:
113 lines (112 loc) 13.5 kB
import { useState } from "react"; import { useNavigate } from "react-router"; import { jsx, jsxs } from "react/jsx-runtime"; const navItems = [ { label: "Home", path: "/" }, { label: "About", path: "/about" }, { label: "Contact", path: "/contact" } ]; const HomeView = ({ children, title = "GothamJS" }) => { const [mobileOpen, setMobileOpen] = useState(false); const navigate = useNavigate(); const handleDrawerToggle = () => { setMobileOpen(!mobileOpen); }; const handleNavigation = (path) => { navigate(path); setMobileOpen(false); }; return /* @__PURE__ */ jsxs("div", { className: "flex flex-col min-h-screen", children: [ /* @__PURE__ */ jsxs("header", { className: "bg-indigo-600 text-white shadow-md", children: [ /* @__PURE__ */ jsx("div", { className: "container mx-auto px-4", children: /* @__PURE__ */ jsxs("div", { className: "flex items-center justify-between h-16", children: [ /* @__PURE__ */ jsx("div", { className: "flex items-center sm:hidden", children: /* @__PURE__ */ jsxs( "button", { type: "button", className: "inline-flex items-center justify-center p-2 rounded-md text-white hover:bg-indigo-500 focus:outline-none focus:ring-2 focus:ring-inset focus:ring-white", "aria-controls": "mobile-menu", "aria-expanded": mobileOpen, onClick: handleDrawerToggle, children: [ /* @__PURE__ */ jsx("span", { className: "sr-only", children: "Open main menu" }), /* @__PURE__ */ jsx( "svg", { className: `${mobileOpen ? "hidden" : "block"} h-6 w-6`, xmlns: "http://www.w3.org/2000/svg", fill: "none", viewBox: "0 0 24 24", stroke: "currentColor", "aria-hidden": "true", children: /* @__PURE__ */ jsx( "path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M4 6h16M4 12h16M4 18h16" } ) } ), /* @__PURE__ */ jsx( "svg", { className: `${mobileOpen ? "block" : "hidden"} h-6 w-6`, xmlns: "http://www.w3.org/2000/svg", fill: "none", viewBox: "0 0 24 24", stroke: "currentColor", "aria-hidden": "true", children: /* @__PURE__ */ jsx( "path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M6 18L18 6M6 6l12 12" } ) } ) ] } ) }), /* @__PURE__ */ jsx("div", { className: "flex-1 flex items-center justify-center sm:items-stretch sm:justify-start", children: /* @__PURE__ */ jsx("div", { className: "flex-shrink-0 flex items-center", children: /* @__PURE__ */ jsx("h1", { className: "text-xl font-bold", children: title }) }) }), /* @__PURE__ */ jsx("div", { className: "hidden sm:block sm:ml-6", children: /* @__PURE__ */ jsx("div", { className: "flex space-x-4", children: navItems.map(({ label, path }) => /* @__PURE__ */ jsx( "button", { onClick: () => handleNavigation(path), className: "text-white hover:bg-indigo-500 px-3 py-2 rounded-md text-sm font-medium", children: label }, path )) }) }) ] }) }), /* @__PURE__ */ jsx( "div", { className: `${mobileOpen ? "block" : "hidden"} sm:hidden`, id: "mobile-menu", children: /* @__PURE__ */ jsx("div", { className: "px-2 pt-2 pb-3 space-y-1", children: navItems.map(({ label, path }) => /* @__PURE__ */ jsx( "button", { onClick: () => handleNavigation(path), className: "text-white hover:bg-indigo-500 block px-3 py-2 rounded-md text-base font-medium w-full text-left", children: label }, path )) }) } ) ] }), /* @__PURE__ */ jsx("main", { className: "flex-grow p-4", children }) ] }); }; export { HomeView }; //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/views/HomeView/HomeView.tsx"],
  "sourcesContent": ["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport React, {useState} from 'react';\nimport {useNavigate} from 'react-router';\n\nconst navItems = [\n  { label: 'Home', path: '/' },\n  { label: 'About', path: '/about' },\n  { label: 'Contact', path: '/contact' }\n];\n\nexport interface HomeViewProps {\n  children?: React.ReactNode;\n  title?: string;\n}\n\nexport const HomeView: React.FC<HomeViewProps> = ({\n  children,\n  title = 'GothamJS'\n}) => {\n  const [mobileOpen, setMobileOpen] = useState(false);\n  const navigate = useNavigate();\n\n  const handleDrawerToggle = () => {\n    setMobileOpen(!mobileOpen);\n  };\n\n  const handleNavigation = (path: string) => {\n    navigate(path);\n    setMobileOpen(false);\n  };\n\n  return (\n    <div className=\"flex flex-col min-h-screen\">\n      {/* Navigation Bar */}\n      <header className=\"bg-indigo-600 text-white shadow-md\">\n        <div className=\"container mx-auto px-4\">\n          <div className=\"flex items-center justify-between h-16\">\n            {/* Mobile menu button */}\n            <div className=\"flex items-center sm:hidden\">\n              <button\n                type=\"button\"\n                className=\"inline-flex items-center justify-center p-2 rounded-md text-white hover:bg-indigo-500 focus:outline-none focus:ring-2 focus:ring-inset focus:ring-white\"\n                aria-controls=\"mobile-menu\"\n                aria-expanded={mobileOpen}\n                onClick={handleDrawerToggle}\n              >\n                <span className=\"sr-only\">Open main menu</span>\n                {/* Icon when menu is closed */}\n                <svg\n                  className={`${mobileOpen ? 'hidden' : 'block'} h-6 w-6`}\n                  xmlns=\"http://www.w3.org/2000/svg\"\n                  fill=\"none\"\n                  viewBox=\"0 0 24 24\"\n                  stroke=\"currentColor\"\n                  aria-hidden=\"true\"\n                >\n                  <path\n                    strokeLinecap=\"round\"\n                    strokeLinejoin=\"round\"\n                    strokeWidth={2}\n                    d=\"M4 6h16M4 12h16M4 18h16\"\n                  />\n                </svg>\n                {/* Icon when menu is open */}\n                <svg\n                  className={`${mobileOpen ? 'block' : 'hidden'} h-6 w-6`}\n                  xmlns=\"http://www.w3.org/2000/svg\"\n                  fill=\"none\"\n                  viewBox=\"0 0 24 24\"\n                  stroke=\"currentColor\"\n                  aria-hidden=\"true\"\n                >\n                  <path\n                    strokeLinecap=\"round\"\n                    strokeLinejoin=\"round\"\n                    strokeWidth={2}\n                    d=\"M6 18L18 6M6 6l12 12\"\n                  />\n                </svg>\n              </button>\n            </div>\n\n            {/* Logo */}\n            <div className=\"flex-1 flex items-center justify-center sm:items-stretch sm:justify-start\">\n              <div className=\"flex-shrink-0 flex items-center\">\n                <h1 className=\"text-xl font-bold\">{title}</h1>\n              </div>\n            </div>\n\n            {/* Desktop Navigation */}\n            <div className=\"hidden sm:block sm:ml-6\">\n              <div className=\"flex space-x-4\">\n                {navItems.map(({label, path}) => (\n                  <button\n                    key={path}\n                    onClick={() => handleNavigation(path)}\n                    className=\"text-white hover:bg-indigo-500 px-3 py-2 rounded-md text-sm font-medium\"\n                  >\n                    {label}\n                  </button>\n                ))}\n              </div>\n            </div>\n          </div>\n        </div>\n\n        {/* Mobile Navigation */}\n        <div\n          className={`${mobileOpen ? 'block' : 'hidden'} sm:hidden`}\n          id=\"mobile-menu\"\n        >\n          <div className=\"px-2 pt-2 pb-3 space-y-1\">\n            {navItems.map(({label, path}) => (\n              <button\n                key={path}\n                onClick={() => handleNavigation(path)}\n                className=\"text-white hover:bg-indigo-500 block px-3 py-2 rounded-md text-base font-medium w-full text-left\"\n              >\n                {label}\n              </button>\n            ))}\n          </div>\n        </div>\n      </header>\n\n      {/* Main Content */}\n      <main className=\"flex-grow p-4\">\n        {children}\n      </main>\n    </div>\n  );\n};\n"],
  "mappings": "AAIA,SAAe,gBAAe;AAC9B,SAAQ,mBAAkB;AAqCZ,SAOE,KAPF;AAnCd,MAAM,WAAW;AAAA,EACf,EAAE,OAAO,QAAQ,MAAM,IAAI;AAAA,EAC3B,EAAE,OAAO,SAAS,MAAM,SAAS;AAAA,EACjC,EAAE,OAAO,WAAW,MAAM,WAAW;AACvC;AAOO,MAAM,WAAoC,CAAC;AAAA,EAChD;AAAA,EACA,QAAQ;AACV,MAAM;AACJ,QAAM,CAAC,YAAY,aAAa,IAAI,SAAS,KAAK;AAClD,QAAM,WAAW,YAAY;AAE7B,QAAM,qBAAqB,MAAM;AAC/B,kBAAc,CAAC,UAAU;AAAA,EAC3B;AAEA,QAAM,mBAAmB,CAAC,SAAiB;AACzC,aAAS,IAAI;AACb,kBAAc,KAAK;AAAA,EACrB;AAEA,SACE,qBAAC,SAAI,WAAU,8BAEb;AAAA,yBAAC,YAAO,WAAU,sCAChB;AAAA,0BAAC,SAAI,WAAU,0BACb,+BAAC,SAAI,WAAU,0CAEb;AAAA,4BAAC,SAAI,WAAU,+BACb;AAAA,UAAC;AAAA;AAAA,YACC,MAAK;AAAA,YACL,WAAU;AAAA,YACV,iBAAc;AAAA,YACd,iBAAe;AAAA,YACf,SAAS;AAAA,YAET;AAAA,kCAAC,UAAK,WAAU,WAAU,4BAAc;AAAA,cAExC;AAAA,gBAAC;AAAA;AAAA,kBACC,WAAW,GAAG,aAAa,WAAW,OAAO;AAAA,kBAC7C,OAAM;AAAA,kBACN,MAAK;AAAA,kBACL,SAAQ;AAAA,kBACR,QAAO;AAAA,kBACP,eAAY;AAAA,kBAEZ;AAAA,oBAAC;AAAA;AAAA,sBACC,eAAc;AAAA,sBACd,gBAAe;AAAA,sBACf,aAAa;AAAA,sBACb,GAAE;AAAA;AAAA,kBACJ;AAAA;AAAA,cACF;AAAA,cAEA;AAAA,gBAAC;AAAA;AAAA,kBACC,WAAW,GAAG,aAAa,UAAU,QAAQ;AAAA,kBAC7C,OAAM;AAAA,kBACN,MAAK;AAAA,kBACL,SAAQ;AAAA,kBACR,QAAO;AAAA,kBACP,eAAY;AAAA,kBAEZ;AAAA,oBAAC;AAAA;AAAA,sBACC,eAAc;AAAA,sBACd,gBAAe;AAAA,sBACf,aAAa;AAAA,sBACb,GAAE;AAAA;AAAA,kBACJ;AAAA;AAAA,cACF;AAAA;AAAA;AAAA,QACF,GACF;AAAA,QAGA,oBAAC,SAAI,WAAU,6EACb,8BAAC,SAAI,WAAU,mCACb,8BAAC,QAAG,WAAU,qBAAqB,iBAAM,GAC3C,GACF;AAAA,QAGA,oBAAC,SAAI,WAAU,2BACb,8BAAC,SAAI,WAAU,kBACZ,mBAAS,IAAI,CAAC,EAAC,OAAO,KAAI,MACzB;AAAA,UAAC;AAAA;AAAA,YAEC,SAAS,MAAM,iBAAiB,IAAI;AAAA,YACpC,WAAU;AAAA,YAET;AAAA;AAAA,UAJI;AAAA,QAKP,CACD,GACH,GACF;AAAA,SACF,GACF;AAAA,MAGA;AAAA,QAAC;AAAA;AAAA,UACC,WAAW,GAAG,aAAa,UAAU,QAAQ;AAAA,UAC7C,IAAG;AAAA,UAEH,8BAAC,SAAI,WAAU,4BACZ,mBAAS,IAAI,CAAC,EAAC,OAAO,KAAI,MACzB;AAAA,YAAC;AAAA;AAAA,cAEC,SAAS,MAAM,iBAAiB,IAAI;AAAA,cACpC,WAAU;AAAA,cAET;AAAA;AAAA,YAJI;AAAA,UAKP,CACD,GACH;AAAA;AAAA,MACF;AAAA,OACF;AAAA,IAGA,oBAAC,UAAK,WAAU,iBACb,UACH;AAAA,KACF;AAEJ;",
  "names": []
}
