2023-10-16 12:10:52 -05:00
|
|
|
import SettingsLayout from "@/layouts/SettingsLayout";
|
2023-11-10 21:32:56 -06:00
|
|
|
import { useState, useEffect } from "react";
|
|
|
|
import useAccountStore from "@/store/account";
|
2024-06-04 15:59:49 -05:00
|
|
|
import SubmitButton from "@/components/SubmitButton";
|
2023-11-10 21:32:56 -06:00
|
|
|
import { toast } from "react-hot-toast";
|
2024-02-07 09:20:25 -06:00
|
|
|
import Checkbox from "@/components/Checkbox";
|
2024-06-04 15:59:49 -05:00
|
|
|
import useLocalSettingsStore from "@/store/localSettings";
|
|
|
|
import { useTranslation } from "next-i18next";
|
|
|
|
import getServerSideProps from "@/lib/client/getServerSideProps"; // Import getServerSideProps for server-side data fetching
|
2024-02-08 00:42:58 -06:00
|
|
|
import { LinksRouteTo } from "@prisma/client";
|
2023-10-16 12:10:52 -05:00
|
|
|
|
2023-10-18 23:09:28 -05:00
|
|
|
export default function Appearance() {
|
2024-06-04 15:59:49 -05:00
|
|
|
const { t } = useTranslation();
|
2023-12-01 13:00:52 -06:00
|
|
|
const { updateSettings } = useLocalSettingsStore();
|
2024-02-07 09:20:25 -06:00
|
|
|
const [submitLoader, setSubmitLoader] = useState(false);
|
|
|
|
const { account, updateAccount } = useAccountStore();
|
2024-06-04 15:59:49 -05:00
|
|
|
const [user, setUser] = useState(account);
|
2024-02-07 09:20:25 -06:00
|
|
|
|
2024-06-04 15:59:49 -05:00
|
|
|
const [preventDuplicateLinks, setPreventDuplicateLinks] = useState<boolean>(
|
|
|
|
account.preventDuplicateLinks
|
2024-02-08 07:45:14 -06:00
|
|
|
);
|
2024-06-04 15:59:49 -05:00
|
|
|
const [archiveAsScreenshot, setArchiveAsScreenshot] = useState<boolean>(
|
|
|
|
account.archiveAsScreenshot
|
|
|
|
);
|
|
|
|
const [archiveAsPDF, setArchiveAsPDF] = useState<boolean>(
|
|
|
|
account.archiveAsPDF
|
|
|
|
);
|
2024-06-18 11:19:52 -05:00
|
|
|
|
|
|
|
const [archiveAsSinglefile, setArchiveAsSinglefile] = useState<boolean>(
|
|
|
|
account.archiveAsSinglefile
|
2024-02-08 07:45:14 -06:00
|
|
|
);
|
2024-02-07 09:20:25 -06:00
|
|
|
|
2024-06-04 15:59:49 -05:00
|
|
|
const [archiveAsWaybackMachine, setArchiveAsWaybackMachine] =
|
|
|
|
useState<boolean>(account.archiveAsWaybackMachine);
|
2024-06-18 11:19:52 -05:00
|
|
|
|
2024-06-04 15:59:49 -05:00
|
|
|
const [linksRouteTo, setLinksRouteTo] = useState(account.linksRouteTo);
|
2024-02-07 09:20:25 -06:00
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
setUser({
|
|
|
|
...account,
|
|
|
|
archiveAsScreenshot,
|
2024-03-15 13:41:41 -05:00
|
|
|
archiveAsSinglefile,
|
2024-02-07 09:20:25 -06:00
|
|
|
archiveAsPDF,
|
|
|
|
archiveAsWaybackMachine,
|
2024-02-08 07:45:14 -06:00
|
|
|
linksRouteTo,
|
2024-03-05 08:03:04 -06:00
|
|
|
preventDuplicateLinks,
|
2024-02-07 09:20:25 -06:00
|
|
|
});
|
2024-02-08 07:45:14 -06:00
|
|
|
}, [
|
|
|
|
account,
|
|
|
|
archiveAsScreenshot,
|
2024-03-15 13:41:41 -05:00
|
|
|
archiveAsSinglefile,
|
2024-02-08 07:45:14 -06:00
|
|
|
archiveAsPDF,
|
|
|
|
archiveAsWaybackMachine,
|
|
|
|
linksRouteTo,
|
2024-03-05 08:03:04 -06:00
|
|
|
preventDuplicateLinks,
|
2024-02-08 07:45:14 -06:00
|
|
|
]);
|
2024-02-07 09:20:25 -06:00
|
|
|
|
|
|
|
function objectIsEmpty(obj: object) {
|
|
|
|
return Object.keys(obj).length === 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
if (!objectIsEmpty(account)) {
|
|
|
|
setArchiveAsScreenshot(account.archiveAsScreenshot);
|
2024-03-15 13:41:41 -05:00
|
|
|
setArchiveAsSinglefile(account.archiveAsSinglefile);
|
2024-02-07 09:20:25 -06:00
|
|
|
setArchiveAsPDF(account.archiveAsPDF);
|
|
|
|
setArchiveAsWaybackMachine(account.archiveAsWaybackMachine);
|
2024-02-08 00:42:58 -06:00
|
|
|
setLinksRouteTo(account.linksRouteTo);
|
2024-03-05 08:03:04 -06:00
|
|
|
setPreventDuplicateLinks(account.preventDuplicateLinks);
|
2024-02-07 09:20:25 -06:00
|
|
|
}
|
|
|
|
}, [account]);
|
|
|
|
|
2023-11-10 21:32:56 -06:00
|
|
|
const submit = async () => {
|
|
|
|
setSubmitLoader(true);
|
|
|
|
|
2024-06-04 15:59:49 -05:00
|
|
|
const load = toast.loading(t("applying_changes"));
|
2023-11-10 21:32:56 -06:00
|
|
|
|
2024-06-04 15:59:49 -05:00
|
|
|
const response = await updateAccount({ ...user });
|
2023-11-10 21:32:56 -06:00
|
|
|
|
|
|
|
toast.dismiss(load);
|
|
|
|
|
|
|
|
if (response.ok) {
|
2024-06-04 15:59:49 -05:00
|
|
|
toast.success(t("settings_applied"));
|
|
|
|
} else {
|
|
|
|
toast.error(response.data as string);
|
|
|
|
}
|
2023-11-10 21:32:56 -06:00
|
|
|
setSubmitLoader(false);
|
|
|
|
};
|
|
|
|
|
2023-10-16 12:10:52 -05:00
|
|
|
return (
|
|
|
|
<SettingsLayout>
|
2024-06-04 15:59:49 -05:00
|
|
|
<p className="capitalize text-3xl font-thin inline">{t("preference")}</p>
|
2023-11-20 11:48:41 -06:00
|
|
|
|
2023-12-01 11:01:56 -06:00
|
|
|
<div className="divider my-3"></div>
|
2023-11-20 11:48:41 -06:00
|
|
|
|
2023-12-01 15:29:17 -06:00
|
|
|
<div className="flex flex-col gap-5">
|
2023-11-10 21:32:56 -06:00
|
|
|
<div>
|
2024-06-04 15:59:49 -05:00
|
|
|
<p className="mb-3">{t("select_theme")}</p>
|
2023-11-10 21:32:56 -06:00
|
|
|
<div className="flex gap-3 w-full">
|
|
|
|
<div
|
2024-02-08 07:45:14 -06:00
|
|
|
className={`w-full text-center outline-solid outline-neutral-content outline dark:outline-neutral-700 h-36 duration-100 rounded-md flex items-center justify-center cursor-pointer select-none bg-black ${
|
|
|
|
localStorage.getItem("theme") === "dark"
|
|
|
|
? "dark:outline-primary text-primary"
|
|
|
|
: "text-white"
|
|
|
|
}`}
|
2023-11-24 06:50:16 -06:00
|
|
|
onClick={() => updateSettings({ theme: "dark" })}
|
2023-11-10 21:32:56 -06:00
|
|
|
>
|
2023-12-17 22:32:33 -06:00
|
|
|
<i className="bi-moon-fill text-6xl"></i>
|
2024-06-04 15:59:49 -05:00
|
|
|
<p className="ml-2 text-2xl">{t("dark")}</p>
|
2023-11-10 21:32:56 -06:00
|
|
|
</div>
|
|
|
|
<div
|
2024-02-08 07:45:14 -06:00
|
|
|
className={`w-full text-center outline-solid outline-neutral-content outline dark:outline-neutral-700 h-36 duration-100 rounded-md flex items-center justify-center cursor-pointer select-none bg-white ${
|
|
|
|
localStorage.getItem("theme") === "light"
|
|
|
|
? "outline-primary text-primary"
|
|
|
|
: "text-black"
|
|
|
|
}`}
|
2023-11-24 06:50:16 -06:00
|
|
|
onClick={() => updateSettings({ theme: "light" })}
|
2023-11-10 21:32:56 -06:00
|
|
|
>
|
2023-12-17 22:32:33 -06:00
|
|
|
<i className="bi-sun-fill text-6xl"></i>
|
2024-06-04 15:59:49 -05:00
|
|
|
<p className="ml-2 text-2xl">{t("light")}</p>
|
2023-11-10 21:32:56 -06:00
|
|
|
</div>
|
|
|
|
</div>
|
2023-10-18 16:50:55 -05:00
|
|
|
</div>
|
2023-11-10 21:32:56 -06:00
|
|
|
|
2024-02-07 09:20:25 -06:00
|
|
|
<div>
|
|
|
|
<p className="capitalize text-3xl font-thin inline">
|
2024-06-04 15:59:49 -05:00
|
|
|
{t("archive_settings")}
|
2024-02-07 09:20:25 -06:00
|
|
|
</p>
|
|
|
|
<div className="divider my-3"></div>
|
2024-06-04 15:59:49 -05:00
|
|
|
<p>{t("formats_to_archive")}</p>
|
2024-02-07 09:20:25 -06:00
|
|
|
<div className="p-3">
|
|
|
|
<Checkbox
|
2024-06-04 15:59:49 -05:00
|
|
|
label={t("screenshot")}
|
2024-02-07 09:20:25 -06:00
|
|
|
state={archiveAsScreenshot}
|
|
|
|
onClick={() => setArchiveAsScreenshot(!archiveAsScreenshot)}
|
|
|
|
/>
|
|
|
|
|
2024-03-15 13:41:41 -05:00
|
|
|
<Checkbox
|
|
|
|
label="Singlefile"
|
|
|
|
state={archiveAsSinglefile}
|
|
|
|
onClick={() => setArchiveAsSinglefile(!archiveAsSinglefile)}
|
|
|
|
/>
|
|
|
|
|
2024-02-07 09:20:25 -06:00
|
|
|
<Checkbox
|
2024-06-04 15:59:49 -05:00
|
|
|
label={t("pdf")}
|
2024-02-07 09:20:25 -06:00
|
|
|
state={archiveAsPDF}
|
|
|
|
onClick={() => setArchiveAsPDF(!archiveAsPDF)}
|
|
|
|
/>
|
|
|
|
<Checkbox
|
2024-06-04 15:59:49 -05:00
|
|
|
label={t("archive_org_snapshot")}
|
2024-02-07 09:20:25 -06:00
|
|
|
state={archiveAsWaybackMachine}
|
|
|
|
onClick={() =>
|
|
|
|
setArchiveAsWaybackMachine(!archiveAsWaybackMachine)
|
|
|
|
}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div>
|
2024-06-04 15:59:49 -05:00
|
|
|
<p className="capitalize text-3xl font-thin inline">
|
|
|
|
{t("link_settings")}
|
|
|
|
</p>
|
2024-02-07 09:20:25 -06:00
|
|
|
<div className="divider my-3"></div>
|
2024-03-04 23:24:30 -06:00
|
|
|
<div className="mb-3">
|
|
|
|
<Checkbox
|
2024-06-04 15:59:49 -05:00
|
|
|
label={t("prevent_duplicate_links")}
|
2024-03-05 08:03:04 -06:00
|
|
|
state={preventDuplicateLinks}
|
|
|
|
onClick={() => setPreventDuplicateLinks(!preventDuplicateLinks)}
|
2024-03-04 23:24:30 -06:00
|
|
|
/>
|
|
|
|
</div>
|
2024-06-04 15:59:49 -05:00
|
|
|
<p>{t("clicking_on_links_should")}</p>
|
2024-02-08 00:42:58 -06:00
|
|
|
<div className="p-3">
|
2024-02-08 07:45:14 -06:00
|
|
|
<label
|
2024-02-08 07:48:22 -06:00
|
|
|
className="label cursor-pointer flex gap-2 justify-start w-fit"
|
2024-02-08 07:45:14 -06:00
|
|
|
tabIndex={0}
|
|
|
|
role="button"
|
|
|
|
>
|
|
|
|
<input
|
|
|
|
type="radio"
|
|
|
|
name="link-preference-radio"
|
|
|
|
className="radio checked:bg-primary"
|
|
|
|
value="Original"
|
|
|
|
checked={linksRouteTo === LinksRouteTo.ORIGINAL}
|
|
|
|
onChange={() => setLinksRouteTo(LinksRouteTo.ORIGINAL)}
|
|
|
|
/>
|
2024-06-04 15:59:49 -05:00
|
|
|
<span className="label-text">{t("open_original_content")}</span>
|
2024-02-08 07:45:14 -06:00
|
|
|
</label>
|
|
|
|
|
|
|
|
<label
|
2024-02-08 07:48:22 -06:00
|
|
|
className="label cursor-pointer flex gap-2 justify-start w-fit"
|
2024-02-08 07:45:14 -06:00
|
|
|
tabIndex={0}
|
|
|
|
role="button"
|
|
|
|
>
|
|
|
|
<input
|
|
|
|
type="radio"
|
|
|
|
name="link-preference-radio"
|
|
|
|
className="radio checked:bg-primary"
|
|
|
|
value="PDF"
|
|
|
|
checked={linksRouteTo === LinksRouteTo.PDF}
|
|
|
|
onChange={() => setLinksRouteTo(LinksRouteTo.PDF)}
|
|
|
|
/>
|
2024-06-04 15:59:49 -05:00
|
|
|
<span className="label-text">{t("open_pdf_if_available")}</span>
|
2024-02-08 07:45:14 -06:00
|
|
|
</label>
|
|
|
|
|
|
|
|
<label
|
2024-02-08 07:48:22 -06:00
|
|
|
className="label cursor-pointer flex gap-2 justify-start w-fit"
|
2024-02-08 07:45:14 -06:00
|
|
|
tabIndex={0}
|
|
|
|
role="button"
|
|
|
|
>
|
|
|
|
<input
|
|
|
|
type="radio"
|
|
|
|
name="link-preference-radio"
|
|
|
|
className="radio checked:bg-primary"
|
|
|
|
value="Readable"
|
|
|
|
checked={linksRouteTo === LinksRouteTo.READABLE}
|
|
|
|
onChange={() => setLinksRouteTo(LinksRouteTo.READABLE)}
|
|
|
|
/>
|
2024-06-04 15:59:49 -05:00
|
|
|
<span className="label-text">
|
|
|
|
{t("open_readable_if_available")}
|
|
|
|
</span>
|
2024-02-08 07:45:14 -06:00
|
|
|
</label>
|
|
|
|
|
2024-06-18 11:19:52 -05:00
|
|
|
<label
|
|
|
|
className="label cursor-pointer flex gap-2 justify-start w-fit"
|
|
|
|
tabIndex={0}
|
|
|
|
role="button"
|
|
|
|
>
|
|
|
|
<input
|
|
|
|
type="radio"
|
|
|
|
name="link-preference-radio"
|
|
|
|
className="radio checked:bg-primary"
|
|
|
|
value="Singlefile"
|
|
|
|
checked={linksRouteTo === LinksRouteTo.SINGLEFILE}
|
|
|
|
onChange={() => setLinksRouteTo(LinksRouteTo.SINGLEFILE)}
|
|
|
|
/>
|
|
|
|
<span className="label-text">Open Singlefile, if available</span>
|
2024-02-08 07:45:14 -06:00
|
|
|
</label>
|
|
|
|
|
2024-03-15 13:41:41 -05:00
|
|
|
<label
|
|
|
|
className="label cursor-pointer flex gap-2 justify-start w-fit"
|
|
|
|
tabIndex={0}
|
|
|
|
role="button"
|
|
|
|
>
|
|
|
|
<input
|
|
|
|
type="radio"
|
|
|
|
name="link-preference-radio"
|
|
|
|
className="radio checked:bg-primary"
|
|
|
|
value="Singlefile"
|
|
|
|
checked={linksRouteTo === LinksRouteTo.SINGLEFILE}
|
|
|
|
onChange={() => setLinksRouteTo(LinksRouteTo.SINGLEFILE)}
|
|
|
|
/>
|
|
|
|
<span className="label-text">Open Singlefile, if available</span>
|
|
|
|
</label>
|
|
|
|
|
2024-02-08 07:45:14 -06:00
|
|
|
<label
|
2024-02-08 07:48:22 -06:00
|
|
|
className="label cursor-pointer flex gap-2 justify-start w-fit"
|
2024-02-08 07:45:14 -06:00
|
|
|
tabIndex={0}
|
|
|
|
role="button"
|
|
|
|
>
|
|
|
|
<input
|
|
|
|
type="radio"
|
|
|
|
name="link-preference-radio"
|
|
|
|
className="radio checked:bg-primary"
|
|
|
|
value="Screenshot"
|
|
|
|
checked={linksRouteTo === LinksRouteTo.SCREENSHOT}
|
|
|
|
onChange={() => setLinksRouteTo(LinksRouteTo.SCREENSHOT)}
|
|
|
|
/>
|
2024-06-04 15:59:49 -05:00
|
|
|
<span className="label-text">
|
|
|
|
{t("open_screenshot_if_available")}
|
|
|
|
</span>
|
2024-02-08 07:45:14 -06:00
|
|
|
</label>
|
2024-02-08 00:42:58 -06:00
|
|
|
</div>
|
2024-02-07 09:20:25 -06:00
|
|
|
</div>
|
|
|
|
|
|
|
|
<SubmitButton
|
2023-11-10 21:32:56 -06:00
|
|
|
onClick={submit}
|
|
|
|
loading={submitLoader}
|
2024-06-04 15:59:49 -05:00
|
|
|
label={t("save_changes")}
|
2024-02-07 09:20:25 -06:00
|
|
|
className="mt-2 w-full sm:w-fit"
|
|
|
|
/>
|
2023-10-18 16:50:55 -05:00
|
|
|
</div>
|
2023-10-16 12:10:52 -05:00
|
|
|
</SettingsLayout>
|
|
|
|
);
|
|
|
|
}
|
2024-06-04 15:59:49 -05:00
|
|
|
|
|
|
|
export { getServerSideProps };
|