|
|
|
import React, { useEffect } from 'react'
|
|
|
|
import { ToastContainer, toast } from 'react-toastify'
|
|
|
|
|
|
|
|
import { router, usePage } from '@inertiajs/react'
|
|
|
|
import { HiOutlineHome, HiOutlineUserCircle } from 'react-icons/hi'
|
|
|
|
import {
|
|
|
|
HiArrowPathRoundedSquare,
|
|
|
|
HiBars3,
|
|
|
|
HiGift,
|
|
|
|
HiOutlineGift,
|
|
|
|
HiOutlineShoppingCart,
|
|
|
|
} from 'react-icons/hi2'
|
|
|
|
|
|
|
|
export default function CustomerLayout({ children }) {
|
|
|
|
const {
|
|
|
|
props: {
|
|
|
|
auth: { user },
|
|
|
|
cart_count,
|
|
|
|
flash,
|
|
|
|
},
|
|
|
|
} = usePage()
|
|
|
|
|
|
|
|
const handleOnClick = (r) => {
|
|
|
|
router.get(route(r))
|
|
|
|
}
|
|
|
|
|
|
|
|
const isActive = (r) => {
|
|
|
|
if (route().current(r)) {
|
|
|
|
return 'text-blue-700'
|
|
|
|
}
|
|
|
|
|
|
|
|
return 'text-gray-600'
|
|
|
|
}
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
if (flash.message !== null) {
|
|
|
|
toast(flash.message.message, { type: flash.message.type })
|
|
|
|
}
|
|
|
|
}, [flash])
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div className="min-h-screen flex flex-col sm:justify-center items-center">
|
|
|
|
<div className="flex flex-col w-full bg-white shadow pb-20 min-h-[calc(90dvh)] max-w-md">
|
|
|
|
<div>{children}</div>
|
|
|
|
</div>
|
|
|
|
<div className="fixed bottom-0 flex flex-row justify-between w-full bg-gray-50 max-w-md">
|
|
|
|
<div
|
|
|
|
className={`pb-1 pt-2 px-5 hover:bg-blue-200 flex flex-col items-center ${isActive(
|
|
|
|
'home.index'
|
|
|
|
)}`}
|
|
|
|
onClick={() => handleOnClick('home.index')}
|
|
|
|
>
|
|
|
|
<HiOutlineHome className="h-6 w-6" />
|
|
|
|
<div className="text-xs font-light">Beranda</div>
|
|
|
|
</div>
|
|
|
|
<div
|
|
|
|
className={`pb-1 pt-2 px-5 hover:bg-blue-200 flex flex-col items-center ${isActive(
|
|
|
|
'cart.index'
|
|
|
|
)}`}
|
|
|
|
onClick={() => handleOnClick('cart.index')}
|
|
|
|
>
|
|
|
|
<div className="flex flex-row">
|
|
|
|
<HiOutlineShoppingCart className="h-6 w-6" />
|
|
|
|
<div>
|
|
|
|
<div className="bg-blue-300 text-blue-600 rounded-lg px-1 text-xs -ml-2">
|
|
|
|
{cart_count}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div className="text-xs font-light">Keranjang</div>
|
|
|
|
</div>
|
|
|
|
<div
|
|
|
|
className={`pb-1 pt-2 px-5 hover:bg-blue-200 flex flex-col items-center ${isActive(
|
|
|
|
'customer.coin.exchange'
|
|
|
|
)}`}
|
|
|
|
onClick={() => handleOnClick('customer.coin.exchange')}
|
|
|
|
>
|
|
|
|
<div className="flex flex-row">
|
|
|
|
<HiOutlineGift className="h-6 w-6" />
|
|
|
|
</div>
|
|
|
|
<div className="text-xs font-light">Coin</div>
|
|
|
|
</div>
|
|
|
|
<div
|
|
|
|
className={`pb-1 pt-2 px-5 hover:bg-blue-200 flex flex-col items-center ${isActive(
|
|
|
|
'transactions.*'
|
|
|
|
)}`}
|
|
|
|
onClick={() => handleOnClick('transactions.index')}
|
|
|
|
>
|
|
|
|
<HiArrowPathRoundedSquare className="h-6 w-6" />
|
|
|
|
<div className="text-xs font-light">Transaksi</div>
|
|
|
|
</div>
|
|
|
|
<div
|
|
|
|
className={`py-2 px-5 hover:bg-blue-200 flex flex-col items-center ${isActive(
|
|
|
|
'customer.profile.*'
|
|
|
|
)}`}
|
|
|
|
onClick={() =>
|
|
|
|
handleOnClick(
|
|
|
|
user !== null
|
|
|
|
? 'customer.profile.index'
|
|
|
|
: 'customer.login'
|
|
|
|
)
|
|
|
|
}
|
|
|
|
>
|
|
|
|
<HiBars3 className="h-6 w-6" />
|
|
|
|
<div className="text-xs font-light">Menu</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<ToastContainer />
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|