You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

252 lines
12 KiB
JavaScript

3 years ago
import React, { useState } from 'react'
import { ToastContainer } from 'react-toastify'
import { Link } from '@inertiajs/inertia-react'
3 years ago
3 years ago
import Dropdown from '@/Components/Dropdown'
import NavLink from '@/Components/NavLink'
import ResponsiveNavLink from '@/Components/ResponsiveNavLink'
import AppLogo from '@/Components/AppLogo'
import FormUserModal from '@/Modals/FormUserModal'
import { useModalState } from '@/Hooks'
export default function Authenticated({ auth, header, children }) {
const [showingNavigationDropdown, setShowingNavigationDropdown] = useState(false);
3 years ago
const {isOpen, toggle} = useModalState(false)
return (
<div className="min-h-screen bg-gray-100">
<nav className="bg-white border-b border-gray-100">
<div className="max-w-7xl mx-auto px-4 sm:px-6 lg:px-8">
<div className="flex justify-between h-16">
<div className="flex">
<div className="shrink-0 flex items-center">
<Link href="/">
3 years ago
<AppLogo />
</Link>
</div>
<div className="hidden space-x-8 sm:-my-px sm:ml-10 sm:flex">
3 years ago
<NavLink
href={route('dashboard')}
active={route().current('dashboard')}
>
Dashboard
</NavLink>
3 years ago
<NavLink
href={route('products.index')}
active={route().current('products.index')}
>
Barang
</NavLink>
<NavLink
href={route('employees.index')}
active={route().current('employees.index')}
>
Karyawan
</NavLink>
<NavLink
href={route('users.index')}
active={route().current('users.index')}
>
Users
</NavLink>
<NavLink
href={route('payrolls.index')}
active={route().current('payrolls.*')}
3 years ago
>
Gaji
</NavLink>
<NavLink
href={route('report')}
active={route().current('report')}
>
Laporan
</NavLink>
</div>
</div>
<div className="hidden sm:flex sm:items-center sm:ml-6">
<div className="ml-3 relative">
<Dropdown>
<Dropdown.Trigger>
<span className="inline-flex rounded-md">
<button
type="button"
className="inline-flex items-center px-3 py-2 border border-transparent text-sm leading-4 font-medium rounded-md text-gray-500 bg-white hover:text-gray-700 focus:outline-none transition ease-in-out duration-150"
>
{auth.user.name}
<svg
className="ml-2 -mr-0.5 h-4 w-4"
xmlns="http://www.w3.org/2000/svg"
viewBox="0 0 20 20"
fill="currentColor"
>
<path
fillRule="evenodd"
d="M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z"
clipRule="evenodd"
/>
</svg>
</button>
</span>
</Dropdown.Trigger>
<Dropdown.Content>
3 years ago
<div
onClick={toggle}
className="block w-full px-4 py-2 text-left text-sm leading-5 text-gray-700 hover:bg-gray-100 focus:outline-none focus:bg-gray-100 transition duration-150 ease-in-out"
3 years ago
>
Profile
3 years ago
</div>
3 years ago
<Dropdown.Link
href={route('logout')}
method="post"
as="button"
>
Log Out
</Dropdown.Link>
</Dropdown.Content>
</Dropdown>
</div>
</div>
<div className="-mr-2 flex items-center sm:hidden">
<button
3 years ago
onClick={() =>
setShowingNavigationDropdown(
(previousState) => !previousState
)
}
className="inline-flex items-center justify-center p-2 rounded-md text-gray-400 hover:text-gray-500 hover:bg-gray-100 focus:outline-none focus:bg-gray-100 focus:text-gray-500 transition duration-150 ease-in-out"
>
3 years ago
<svg
className="h-6 w-6"
stroke="currentColor"
fill="none"
viewBox="0 0 24 24"
>
<path
3 years ago
className={
!showingNavigationDropdown
? 'inline-flex'
: 'hidden'
}
strokeLinecap="round"
strokeLinejoin="round"
strokeWidth="2"
d="M4 6h16M4 12h16M4 18h16"
/>
<path
3 years ago
className={
showingNavigationDropdown
? 'inline-flex'
: 'hidden'
}
strokeLinecap="round"
strokeLinejoin="round"
strokeWidth="2"
d="M6 18L18 6M6 6l12 12"
/>
</svg>
</button>
</div>
</div>
</div>
3 years ago
<div
className={
(showingNavigationDropdown ? 'block' : 'hidden') +
' sm:hidden'
}
>
<div className="pt-2 pb-3 space-y-1">
3 years ago
<ResponsiveNavLink
href={route('dashboard')}
active={route().current('dashboard')}
>
Dashboard
</ResponsiveNavLink>
3 years ago
<ResponsiveNavLink
href={route('products.index')}
active={route().current('products.index')}
>
Barang
</ResponsiveNavLink>
<ResponsiveNavLink
href={route('employees.index')}
active={route().current('employees.index')}
>
Karyawan
</ResponsiveNavLink>
<ResponsiveNavLink
href={route('users.index')}
active={route().current('users.index')}
>
Users
</ResponsiveNavLink>
<ResponsiveNavLink
href={route('payrolls.index')}
active={route().current('payrolls.*')}
3 years ago
>
Gaji
</ResponsiveNavLink>
<ResponsiveNavLink
href={route('report')}
active={route().current('report')}
>
Laporan
</ResponsiveNavLink>
</div>
<div className="pt-4 pb-1 border-t border-gray-200">
3 years ago
<div className="px-4" onClick={toggle}>
3 years ago
<div
className="font-medium text-base text-gray-800
"
>
{auth.user.name}
</div>
<div className="font-medium text-sm text-gray-500">
{auth.user.email}
</div>
</div>
<div className="mt-3 space-y-1">
3 years ago
<ResponsiveNavLink
method="post"
href={route('logout')}
as="button"
>
Log Out
</ResponsiveNavLink>
</div>
</div>
</div>
</nav>
{header && (
<header className="bg-white shadow">
3 years ago
<div className="max-w-7xl mx-auto py-6 px-4 sm:px-6 lg:px-8">
{header}
</div>
</header>
)}
3 years ago
<main className="max-w-7xl mx-auto">{children}</main>
<ToastContainer
position="top-right"
autoClose={5000}
theme="colored"
hideProgressBar={false}
newestOnTop={false}
closeOnClick
rtl={false}
pauseOnFocusLoss
draggable
pauseOnHover
/>
<FormUserModal isOpen={isOpen} toggle={toggle} user={auth.user} />
</div>
3 years ago
)
}