Files
knur-app/components/load-route-button.tsx

29 lines
1.0 KiB
TypeScript
Raw Permalink Normal View History

2026-06-16 09:43:48 +02:00
"use client";
import { useActionState } from "react";
import { Map } from "lucide-react";
import { loadActivityRoute, type LoadRouteState } from "@/app/running/actions";
export function LoadRouteButton({ activityId }: { activityId: string }) {
const [state, formAction, pending] = useActionState(
async (): Promise<LoadRouteState> => loadActivityRoute(activityId),
null
);
return (
<div className="flex flex-col gap-2">
<form action={formAction}>
<button
type="submit"
disabled={pending}
className="flex items-center gap-1.5 rounded-md border border-muted/40 bg-surface px-3 py-2 text-sm font-medium text-fg/80 transition-colors hover:border-accent/60 hover:text-accent disabled:opacity-50"
>
<Map size={15} className={pending ? "animate-pulse" : ""} />
{pending ? "Pobieranie mapy..." : "Załaduj mapę trasy"}
</button>
</form>
{state && "error" in state ? <p className="text-sm text-accent">{state.error}</p> : null}
</div>
);
}