UNPKG

create-vanjs

Version:

🍦 Quick tool for scaffolding your first VanJS project

65 lines (61 loc) 2.36 kB
import { A, useRouteData } from "@vanjs/router"; import { Meta, Title } from "@vanjs/meta"; import { getDashboardStats } from "@/api"; export const route = { load: async () => { return await getDashboardStats(); }, }; export const Page = () => { Title("Dashboard"); Meta({ name: "description", content: "Administrator description" }); const data = useRouteData(); return ( <> <div class="h-screen"> <div class="p-4 m-auto"> <h1 class="text-5xl font-bold my-8">Hello Administrator!</h1> <div class="flex flex-col md:flex-row gap-4"> <div class="w-full lg:w-1/2 stats bg-base-100 border border-base-300"> <div class="stat"> <div class="stat-title">This month sales</div> <div class="stat-value">{data?.monthlySales || "--"}</div> <div class="stat-actions"> <A href="/admin/not-found" class="btn btn-xs"> Not found </A> </div> </div> <div class="stat"> <div class="stat-title">Conversion rate</div> <div class="stat-value">{data?.conversionRate || "--"}</div> <div class="stat-actions"> <button type="button" class="btn btn-xs btn-success"> Cashflow </button> <button type="button" class="btn btn-xs">Trends</button> </div> </div> </div> <div class="w-full lg:w-1/2 stats bg-base-100 border border-base-300"> <div class="stat"> <div class="stat-title">Monthly Views</div> <div class="stat-value">{data?.monthlyViews || "--"}</div> <div class="stat-actions"> <button type="button" class="btn btn-xs">Analytics</button> </div> </div> <div class="stat"> <div class="stat-title">Today's Views</div> <div class="stat-value">{data?.todayViews || "--"}</div> <div class="stat-actions"> <button type="button" class="btn btn-xs">Estaimated</button> </div> </div> </div> </div> </div> </div> </> ); };