Skip to content

Commit

Permalink
fix(dashboard): period selector in dashboard (#6)
Browse files Browse the repository at this point in the history
Co-authored-by: Ricard Mallafre <[email protected]>
  • Loading branch information
github-actions[bot] and nikensss committed Mar 31, 2024
1 parent 9c8b2da commit f27ca1a
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 37 deletions.
64 changes: 29 additions & 35 deletions src/app/dashboard/month-and-year-selector.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,17 +2,19 @@

import { format, parse } from 'date-fns';
import { ChevronLeft, ChevronRight } from 'lucide-react';
import type { AppRouterInstance } from 'next/dist/shared/lib/app-router-context.shared-runtime';
import { usePathname, useRouter } from 'next/navigation';
import { useState } from 'react';
import { Button } from '~/components/ui/button';
import { Popover, PopoverContent, PopoverTrigger } from '~/components/ui/popover';
import { cn } from '~/lib/utils';

export default function MonthAndYearSelector({ month, year }: { month: string; year: string }) {
export default function MonthAndYearSelector(input: { month: string; year: string }) {
const router = useRouter();
const pathname = usePathname();

const [month, setMonth] = useState(input.month);
const [year, setYear] = useState(input.year);

const [isOpen, setIsOpen] = useState(false);

return (
Expand All @@ -23,59 +25,54 @@ export default function MonthAndYearSelector({ month, year }: { month: string; y
</Button>
</PopoverTrigger>
<PopoverContent className="flex select-none flex-col gap-1 p-1 shadow-lg">
<YearSelector {...{ month, year, router, pathname }} />
<MonthSelector onClick={() => setIsOpen(false)} {...{ month, year, router, pathname }} />
<YearSelector {...{ year, setYear }} />
<MonthSelector {...{ month, setMonth }} />
<Button
onClick={() => {
setIsOpen(false);
const searchParams = new URLSearchParams();
searchParams.set('month', month);
searchParams.set('year', year);
router.push(`${pathname}?${searchParams.toString()}`);
}}
>
Update
</Button>
</PopoverContent>
</Popover>
);
}

type MonthAndYearSelectorChild = {
month: string;
type YearSelectorProps = {
year: string;
router: AppRouterInstance;
pathname: string;
setYear: (year: string) => void;
};

function YearSelector({ month, year, router, pathname }: MonthAndYearSelectorChild) {
function YearSelector({ year, setYear }: YearSelectorProps) {
return (
<div className="border-primary-200 flex items-center rounded-lg border shadow-lg">
<div
className="group flex grow items-center justify-center p-2 pr-0 hover:cursor-pointer"
onClick={() => {
const params = new URLSearchParams();
params.set('year', `${parseInt(year) - 1}`);
params.set('month', month);
router.push(pathname + '?' + params.toString());
}}
onClick={() => setYear(`${parseInt(year) - 1}`)}
>
<ChevronLeft size={24} className="transition md:group-hover:-translate-x-1" />
</div>
<div>{year}</div>
<div
className="group flex grow items-center justify-center p-2 pl-0 hover:cursor-pointer"
onClick={() => {
const params = new URLSearchParams();
params.set('year', `${parseInt(year) + 1}`);
params.set('month', month);
router.push(pathname + '?' + params.toString());
}}
onClick={() => setYear(`${parseInt(year) + 1}`)}
>
<ChevronRight size={24} className="transition md:group-hover:translate-x-1" />
</div>
</div>
);
}

function MonthSelector({
month,
year,
router,
pathname,
onClick,
}: MonthAndYearSelectorChild & {
onClick: () => void;
}) {
type MonthSelectorProps = {
month: string;
setMonth: (month: string) => void;
};
function MonthSelector({ month, setMonth }: MonthSelectorProps) {
const months = [
'January',
'February',
Expand All @@ -97,11 +94,8 @@ function MonthSelector({
<Button
key={idx}
onClick={() => {
onClick();
const params = new URLSearchParams();
params.set('month', m);
params.set('year', year);
router.push(pathname + '?' + params.toString());
const selectedMonth = months[idx];
if (selectedMonth) setMonth(selectedMonth);
}}
variant="outline"
className={cn(
Expand Down
2 changes: 0 additions & 2 deletions src/app/dashboard/page.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -11,8 +11,6 @@ export default async function Dashboard({ searchParams }: { searchParams: Record
const month = searchParams?.month ?? format(new Date(), 'LLLL');
const year = searchParams?.year ?? format(new Date(), 'yyyy');

await new Promise((resolve) => setTimeout(resolve, 1000));

return (
<main className="flex-1 bg-white">
<section className="mb-2 grid grid-cols-2 gap-2">
Expand Down

0 comments on commit f27ca1a

Please sign in to comment.