@nlabs/gothamjs
Version:
Platform
132 lines (131 loc) • 16.1 kB
JavaScript
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
/**
* Copyright (c) 2018-Present, Nitrogen Labs, Inc.
* Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
*/ import React, { useState } from 'react';
import { useNavigate } from 'react-router';
const navItems = [
{
label: 'Home',
path: '/'
},
{
label: 'About',
path: '/about'
},
{
label: 'Contact',
path: '/contact'
}
];
export 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: children
})
]
});
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["/Users/nitrog7/Development/gothamjs/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"],"names":["React","useState","useNavigate","navItems","label","path","HomeView","children","title","mobileOpen","setMobileOpen","navigate","handleDrawerToggle","handleNavigation","div","className","header","button","type","aria-controls","aria-expanded","onClick","span","svg","xmlns","fill","viewBox","stroke","aria-hidden","strokeLinecap","strokeLinejoin","strokeWidth","d","h1","map","id","main"],"mappings":";AAAA;;;CAGC,GACD,OAAOA,SAAQC,QAAQ,QAAO,QAAQ;AACtC,SAAQC,WAAW,QAAO,eAAe;AAEzC,MAAMC,WAAW;IACf;QAAEC,OAAO;QAAQC,MAAM;IAAI;IAC3B;QAAED,OAAO;QAASC,MAAM;IAAS;IACjC;QAAED,OAAO;QAAWC,MAAM;IAAW;CACtC;AAOD,OAAO,MAAMC,WAAoC,CAAC,EAChDC,QAAQ,EACRC,QAAQ,UAAU,EACnB;IACC,MAAM,CAACC,YAAYC,cAAc,GAAGT,SAAS;IAC7C,MAAMU,WAAWT;IAEjB,MAAMU,qBAAqB;QACzBF,cAAc,CAACD;IACjB;IAEA,MAAMI,mBAAmB,CAACR;QACxBM,SAASN;QACTK,cAAc;IAChB;IAEA,qBACE,MAACI;QAAIC,WAAU;;0BAEb,MAACC;gBAAOD,WAAU;;kCAChB,KAACD;wBAAIC,WAAU;kCACb,cAAA,MAACD;4BAAIC,WAAU;;8CAEb,KAACD;oCAAIC,WAAU;8CACb,cAAA,MAACE;wCACCC,MAAK;wCACLH,WAAU;wCACVI,iBAAc;wCACdC,iBAAeX;wCACfY,SAAST;;0DAET,KAACU;gDAAKP,WAAU;0DAAU;;0DAE1B,KAACQ;gDACCR,WAAW,GAAGN,aAAa,WAAW,QAAQ,QAAQ,CAAC;gDACvDe,OAAM;gDACNC,MAAK;gDACLC,SAAQ;gDACRC,QAAO;gDACPC,eAAY;0DAEZ,cAAA,KAACvB;oDACCwB,eAAc;oDACdC,gBAAe;oDACfC,aAAa;oDACbC,GAAE;;;0DAIN,KAACT;gDACCR,WAAW,GAAGN,aAAa,UAAU,SAAS,QAAQ,CAAC;gDACvDe,OAAM;gDACNC,MAAK;gDACLC,SAAQ;gDACRC,QAAO;gDACPC,eAAY;0DAEZ,cAAA,KAACvB;oDACCwB,eAAc;oDACdC,gBAAe;oDACfC,aAAa;oDACbC,GAAE;;;;;;8CAOV,KAAClB;oCAAIC,WAAU;8CACb,cAAA,KAACD;wCAAIC,WAAU;kDACb,cAAA,KAACkB;4CAAGlB,WAAU;sDAAqBP;;;;8CAKvC,KAACM;oCAAIC,WAAU;8CACb,cAAA,KAACD;wCAAIC,WAAU;kDACZZ,SAAS+B,GAAG,CAAC,CAAC,EAAC9B,KAAK,EAAEC,IAAI,EAAC,iBAC1B,KAACY;gDAECI,SAAS,IAAMR,iBAAiBR;gDAChCU,WAAU;0DAETX;+CAJIC;;;;;;kCAajB,KAACS;wBACCC,WAAW,GAAGN,aAAa,UAAU,SAAS,UAAU,CAAC;wBACzD0B,IAAG;kCAEH,cAAA,KAACrB;4BAAIC,WAAU;sCACZZ,SAAS+B,GAAG,CAAC,CAAC,EAAC9B,KAAK,EAAEC,IAAI,EAAC,iBAC1B,KAACY;oCAECI,SAAS,IAAMR,iBAAiBR;oCAChCU,WAAU;8CAETX;mCAJIC;;;;;0BAYf,KAAC+B;gBAAKrB,WAAU;0BACbR;;;;AAIT,EAAE"}