import React, { useEffect } from "react";
import { useMutation, useQuery, useQueryClient } from "@tanstack/react-query";
import { useNavigate } from "react-router-dom";
import { Button } from "./components/ui/button";
import { Input } from "./components/ui/input";
import {
Select,
SelectContent,
SelectItem,
SelectTrigger,
SelectValue,
} from "./components/ui/select";
import { Switch } from "./components/ui/switch";
import Logo from "./Logo";
import Spinner from "./Spinner";
import usePluginSettings, {
DEFAULT_BADGE_CACHE_EXPIRE_MS,
} from "./utils/settings";
import { useTheme } from "./utils/ThemeProvider";
import { useTRPC } from "./utils/trpc";
export default function OptionsPage() {
const api = useTRPC();
const queryClient = useQueryClient();
const navigate = useNavigate();
const { settings, setSettings } = usePluginSettings();
const { setTheme, theme } = useTheme();
const { data: whoami, error: whoAmIError } = useQuery(
api.users.whoami.queryOptions(undefined, {
enabled: settings.address != "",
}),
);
const { mutate: deleteKey } = useMutation(
api.apiKeys.revoke.mutationOptions(),
);
const invalidateWhoami = () => {
queryClient.refetchQueries(api.users.whoami.queryFilter());
};
useEffect(() => {
invalidateWhoami();
}, [settings]);
let loggedInMessage: React.ReactNode;
if (whoAmIError) {
if (whoAmIError.data?.code == "UNAUTHORIZED") {
loggedInMessage = Not logged in;
} else {
loggedInMessage = (
Something went wrong: {whoAmIError.message}
);
}
} else if (whoami) {
loggedInMessage = {whoami.email};
} else {
loggedInMessage =