clipfusion/src/app/(dashboard)/settings/storage/page.tsx

67 lines
2.9 KiB
TypeScript

"use client";
import { usePersistenceContext } from "@/app/persistence-provider";
import AscendingCard from "@/components/ascending-card";
import ScrollFadingTitle from "@/components/scroll-fading-title";
import Search from "@/components/search";
import SidebarTriggerAdjustable from "@/components/sidebar-trigger-adjustable";
import StaticBackButton from "@/components/static-back-button";
import StaticSidebarTrigger from "@/components/static-sidebar-trigger";
import StickyTopContainer from "@/components/sticky-top-container";
import { Button } from "@/components/ui/button";
import { Label } from "@/components/ui/label";
import WideContainer from "@/components/wide-container";
import { useIsMobile } from "@/hooks/use-mobile";
import { cn } from "@/lib/utils";
import { ReactNode, useEffect, useState } from "react";
function PersistentStorageControl({
status
}: {
status: string | null
}): ReactNode {
const { persist } = usePersistenceContext();
if (status == null) return <Label className="text-muted-foreground">No information</Label>;
if (status == "never") return <Label className="text-red-500">Unavailable</Label>;
if (status == "prompt") return <Button onClick={persist}>Enable</Button>;
return <Label className="text-green-400">Enabled</Label>;
};
export default function Storage() {
const [status, setStatus] = useState<string | null>(null);
const isMobile = useIsMobile();
const iPadAirBreakpoint = useIsMobile(820);
const backButtonAdjust = (!isMobile && iPadAirBreakpoint) ? "pl-16" : "";
useEffect(() => {
setStatus(localStorage.getItem("persistence-status"));
}, []);
return (
<div className="p-5 w-full h-full">
<div className="flex flex-row items-center justify-start gap-2">
<StaticSidebarTrigger/>
<StaticBackButton/>
<ScrollFadingTitle>
<h2 className="font-bold break-keep text-xl sm:text-2xl md:text-3xl lg:text-4xl leading-none">Storage</h2>
</ScrollFadingTitle>
</div>
<StickyTopContainer>
<SidebarTriggerAdjustable adjustWidth={isMobile ? 22 : 0} className={`flex items-center justify-center ${backButtonAdjust}`}>
<WideContainer>
<Search />
</WideContainer>
</SidebarTriggerAdjustable>
</StickyTopContainer>
<div className={cn("flex flex-col items-center justify-start gap-1 md:lg:gap-2 mt-2", backButtonAdjust)}>
<WideContainer>
<AscendingCard className="flex flex-row justify-between items-center p-4">
<div className="flex flex-row gap-2 ">
<Label>Persistent Storage</Label>
</div>
<PersistentStorageControl status={status} />
</AscendingCard>
</WideContainer>
</div>
</div>
)
}