aethex-forge/client/components/admin/BannerSettings.tsx
Builder.io f4909df626 Add API_BASE and fix relative URLs in BannerSettings.tsx
cgen-2116cd5c80674cf2bbc019cbbd517aab
2025-11-13 02:56:42 +00:00

90 lines
2.9 KiB
TypeScript

import { useEffect, useState } from "react";
import { Button } from "@/components/ui/button";
import { Switch } from "@/components/ui/switch";
const API_BASE = import.meta.env.VITE_API_BASE || "";
export default function BannerSettings() {
const [text, setText] = useState("ROBLOX AUTH SOON");
const [enabled, setEnabled] = useState(true);
const [saving, setSaving] = useState(false);
const [style, setStyle] = useState<string>("quest");
useEffect(() => {
fetch(`${API_BASE}/api/site-settings?key=home_banner`)
.then((r) => (r.ok ? r.json() : null))
.then((v) => {
if (v && typeof v === "object") {
setText(String((v as any).text || "ROBLOX AUTH SOON"));
setEnabled((v as any).enabled !== false);
if ((v as any).style) setStyle(String((v as any).style));
}
})
.catch(() => void 0);
}, []);
const save = async () => {
setSaving(true);
try {
const resp = await fetch(`${API_BASE}/api/site-settings`, {
method: "POST",
headers: { "Content-Type": "application/json" },
body: JSON.stringify({
key: "home_banner",
value: { text, enabled, style },
}),
});
if (!resp.ok) throw new Error("Save failed");
} finally {
setSaving(false);
}
};
return (
<div className="space-y-3">
<div className="grid gap-2 md:grid-cols-4">
<label className="text-sm text-muted-foreground md:col-span-1">
Enabled
</label>
<div className="md:col-span-3">
<Switch checked={enabled} onCheckedChange={setEnabled} />
</div>
</div>
<div className="grid gap-2 md:grid-cols-4">
<label className="text-sm text-muted-foreground md:col-span-1">
Banner text
</label>
<div className="md:col-span-3">
<input
className="w-full bg-background/50 border border-border/40 rounded px-2 py-1 text-sm"
value={text}
onChange={(e) => setText(e.target.value)}
placeholder="Banner message"
/>
</div>
</div>
<div className="grid gap-2 md:grid-cols-4">
<label className="text-sm text-muted-foreground md:col-span-1">
Style
</label>
<div className="md:col-span-3">
<select
className="w-full bg-background/50 border border-border/40 rounded px-2 py-1 text-sm"
value={style}
onChange={(e) => setStyle(e.target.value)}
>
<option value="quest">Quest</option>
<option value="info">Info</option>
<option value="arcade">Arcade</option>
<option value="alert">Alert</option>
</select>
</div>
</div>
<div className="flex justify-end">
<Button size="sm" onClick={save} disabled={saving}>
{saving ? "Saving…" : "Save banner"}
</Button>
</div>
</div>
);
}