mirror of
https://github.com/linkwarden/linkwarden.git
synced 2026-03-03 00:27:01 +00:00
* build(deps): bump the npm_and_yarn group across 5 directories with 22 updates Bumps the npm_and_yarn group with 18 updates in the / directory: | Package | From | To | | --- | --- | --- | | [axios](https://github.com/axios/axios) | `1.5.1` | `1.12.0` | | [dompurify](https://github.com/cure53/DOMPurify) | `3.0.6` | `3.2.4` | | [formidable](https://github.com/node-formidable/formidable) | `3.5.1` | `3.5.4` | | [next](https://github.com/vercel/next.js) | `13.4.12` | `14.2.35` | | [next-auth](https://github.com/nextauthjs/next-auth) | `4.22.1` | `4.24.12` | | [playwright](https://github.com/microsoft/playwright) | `1.55.0` | `1.55.1` | | [@mozilla/readability](https://github.com/mozilla/readability) | `0.4.4` | `0.6.0` | | [ai](https://github.com/vercel/ai) | `4.3.9` | `5.0.52` | | [nodemailer](https://github.com/nodemailer/nodemailer) | `6.9.3` | `7.0.11` | | [brace-expansion](https://github.com/juliangruber/brace-expansion) | `1.1.11` | `1.1.12` | | [braces](https://github.com/micromatch/braces) | `3.0.2` | `3.0.3` | | [form-data](https://github.com/form-data/form-data) | `3.0.3` | `3.0.4` | | [js-yaml](https://github.com/nodeca/js-yaml) | `3.14.1` | `3.14.2` | | [micromatch](https://github.com/micromatch/micromatch) | `4.0.5` | `4.0.8` | | [min-document](https://github.com/Raynos/min-document) | `2.19.0` | `2.19.2` | | [nanoid](https://github.com/ai/nanoid) | `3.3.6` | `3.3.8` | | [node-forge](https://github.com/digitalbazaar/forge) | `1.3.1` | `1.3.3` | | [tar](https://github.com/isaacs/node-tar) | `6.1.13` | `6.2.1` | Bumps the npm_and_yarn group with 1 update in the /apps/web directory: [next](https://github.com/vercel/next.js). Bumps the npm_and_yarn group with 2 updates in the /apps/worker directory: [@mozilla/readability](https://github.com/mozilla/readability) and [ai](https://github.com/vercel/ai). Bumps the npm_and_yarn group with 1 update in the /packages/lib directory: [nodemailer](https://github.com/nodemailer/nodemailer). Bumps the npm_and_yarn group with 1 update in the /packages/router directory: [next](https://github.com/vercel/next.js). Updates `axios` from 1.5.1 to 1.12.0 - [Release notes](https://github.com/axios/axios/releases) - [Changelog](https://github.com/axios/axios/blob/v1.x/CHANGELOG.md) - [Commits](https://github.com/axios/axios/compare/v1.5.1...v1.12.0) Updates `dompurify` from 3.0.6 to 3.2.4 - [Release notes](https://github.com/cure53/DOMPurify/releases) - [Commits](https://github.com/cure53/DOMPurify/compare/3.0.6...3.2.4) Updates `formidable` from 3.5.1 to 3.5.4 - [Release notes](https://github.com/node-formidable/formidable/releases) - [Changelog](https://github.com/node-formidable/formidable/blob/master/CHANGELOG.md) - [Commits](https://github.com/node-formidable/formidable/commits) Updates `next` from 13.4.12 to 14.2.35 - [Release notes](https://github.com/vercel/next.js/releases) - [Changelog](https://github.com/vercel/next.js/blob/canary/release.js) - [Commits](https://github.com/vercel/next.js/compare/v13.4.12...v14.2.35) Updates `next-auth` from 4.22.1 to 4.24.12 - [Release notes](https://github.com/nextauthjs/next-auth/releases) - [Commits](https://github.com/nextauthjs/next-auth/compare/next-auth@4.22.1...next-auth@4.24.12) Updates `playwright` from 1.55.0 to 1.55.1 - [Release notes](https://github.com/microsoft/playwright/releases) - [Commits](https://github.com/microsoft/playwright/compare/v1.55.0...v1.55.1) Updates `postcss` from 8.4.26 to 8.5.3 - [Release notes](https://github.com/postcss/postcss/releases) - [Changelog](https://github.com/postcss/postcss/blob/main/CHANGELOG.md) - [Commits](https://github.com/postcss/postcss/compare/8.4.26...8.5.3) Updates `@mozilla/readability` from 0.4.4 to 0.6.0 - [Changelog](https://github.com/mozilla/readability/blob/main/CHANGELOG.md) - [Commits](https://github.com/mozilla/readability/compare/0.4.4...0.6.0) Updates `ai` from 4.3.9 to 5.0.52 - [Release notes](https://github.com/vercel/ai/releases) - [Changelog](https://github.com/vercel/ai/blob/main/CHANGELOG.md) - [Commits](https://github.com/vercel/ai/compare/ai@4.3.9...ai@5.0.52) Updates `nodemailer` from 6.9.3 to 7.0.11 - [Release notes](https://github.com/nodemailer/nodemailer/releases) - [Changelog](https://github.com/nodemailer/nodemailer/blob/master/CHANGELOG.md) - [Commits](https://github.com/nodemailer/nodemailer/compare/v6.9.3...v7.0.11) Updates `@babel/runtime` from 7.21.5 to 7.27.0 - [Release notes](https://github.com/babel/babel/releases) - [Changelog](https://github.com/babel/babel/blob/main/CHANGELOG.md) - [Commits](https://github.com/babel/babel/commits/v7.27.0/packages/babel-runtime) Updates `brace-expansion` from 1.1.11 to 1.1.12 - [Release notes](https://github.com/juliangruber/brace-expansion/releases) - [Commits](https://github.com/juliangruber/brace-expansion/compare/1.1.11...v1.1.12) Updates `braces` from 3.0.2 to 3.0.3 - [Changelog](https://github.com/micromatch/braces/blob/master/CHANGELOG.md) - [Commits](https://github.com/micromatch/braces/compare/3.0.2...3.0.3) Updates `follow-redirects` from 1.15.3 to 1.15.11 - [Release notes](https://github.com/follow-redirects/follow-redirects/releases) - [Commits](https://github.com/follow-redirects/follow-redirects/compare/v1.15.3...v1.15.11) Updates `form-data` from 3.0.3 to 3.0.4 - [Release notes](https://github.com/form-data/form-data/releases) - [Changelog](https://github.com/form-data/form-data/blob/master/CHANGELOG.md) - [Commits](https://github.com/form-data/form-data/compare/v3.0.3...v3.0.4) Updates `jose` from 4.14.4 to 4.15.9 - [Release notes](https://github.com/panva/jose/releases) - [Changelog](https://github.com/panva/jose/blob/v4.15.9/CHANGELOG.md) - [Commits](https://github.com/panva/jose/compare/v4.14.4...v4.15.9) Updates `js-yaml` from 3.14.1 to 3.14.2 - [Changelog](https://github.com/nodeca/js-yaml/blob/master/CHANGELOG.md) - [Commits](https://github.com/nodeca/js-yaml/compare/3.14.1...3.14.2) Updates `micromatch` from 4.0.5 to 4.0.8 - [Release notes](https://github.com/micromatch/micromatch/releases) - [Changelog](https://github.com/micromatch/micromatch/blob/master/CHANGELOG.md) - [Commits](https://github.com/micromatch/micromatch/compare/4.0.5...4.0.8) Updates `min-document` from 2.19.0 to 2.19.2 - [Commits](https://github.com/Raynos/min-document/compare/v2.19.0...v2.19.2) Updates `nanoid` from 3.3.6 to 3.3.8 - [Release notes](https://github.com/ai/nanoid/releases) - [Changelog](https://github.com/ai/nanoid/blob/main/CHANGELOG.md) - [Commits](https://github.com/ai/nanoid/compare/3.3.6...3.3.8) Updates `node-forge` from 1.3.1 to 1.3.3 - [Changelog](https://github.com/digitalbazaar/forge/blob/main/CHANGELOG.md) - [Commits](https://github.com/digitalbazaar/forge/compare/v1.3.1...v1.3.3) Updates `tar` from 6.1.13 to 6.2.1 - [Release notes](https://github.com/isaacs/node-tar/releases) - [Changelog](https://github.com/isaacs/node-tar/blob/main/CHANGELOG.md) - [Commits](https://github.com/isaacs/node-tar/compare/v6.1.13...v6.2.1) Updates `next` from 13.4.12 to 14.2.35 - [Release notes](https://github.com/vercel/next.js/releases) - [Changelog](https://github.com/vercel/next.js/blob/canary/release.js) - [Commits](https://github.com/vercel/next.js/compare/v13.4.12...v14.2.35) Updates `@mozilla/readability` from 0.4.4 to 0.6.0 - [Changelog](https://github.com/mozilla/readability/blob/main/CHANGELOG.md) - [Commits](https://github.com/mozilla/readability/compare/0.4.4...0.6.0) Updates `ai` from 4.3.19 to 5.0.113 - [Release notes](https://github.com/vercel/ai/releases) - [Changelog](https://github.com/vercel/ai/blob/main/CHANGELOG.md) - [Commits](https://github.com/vercel/ai/compare/ai@4.3.9...ai@5.0.52) Updates `nodemailer` from 6.10.1 to 7.0.11 - [Release notes](https://github.com/nodemailer/nodemailer/releases) - [Changelog](https://github.com/nodemailer/nodemailer/blob/master/CHANGELOG.md) - [Commits](https://github.com/nodemailer/nodemailer/compare/v6.9.3...v7.0.11) Updates `next` from 13.4.12 to 14.2.35 - [Release notes](https://github.com/vercel/next.js/releases) - [Changelog](https://github.com/vercel/next.js/blob/canary/release.js) - [Commits](https://github.com/vercel/next.js/compare/v13.4.12...v14.2.35) --- updated-dependencies: - dependency-name: axios dependency-version: 1.12.0 dependency-type: direct:production dependency-group: npm_and_yarn - dependency-name: dompurify dependency-version: 3.2.4 dependency-type: direct:production dependency-group: npm_and_yarn - dependency-name: formidable dependency-version: 3.5.4 dependency-type: direct:production dependency-group: npm_and_yarn - dependency-name: next dependency-version: 14.2.35 dependency-type: direct:production dependency-group: npm_and_yarn - dependency-name: next-auth dependency-version: 4.24.12 dependency-type: direct:production dependency-group: npm_and_yarn - dependency-name: playwright dependency-version: 1.55.1 dependency-type: direct:production dependency-group: npm_and_yarn - dependency-name: postcss dependency-version: 8.5.3 dependency-type: direct:development dependency-group: npm_and_yarn - dependency-name: "@mozilla/readability" dependency-version: 0.6.0 dependency-type: direct:production dependency-group: npm_and_yarn - dependency-name: ai dependency-version: 5.0.52 dependency-type: direct:production dependency-group: npm_and_yarn - dependency-name: nodemailer dependency-version: 7.0.11 dependency-type: direct:production dependency-group: npm_and_yarn - dependency-name: "@babel/runtime" dependency-version: 7.27.0 dependency-type: indirect dependency-group: npm_and_yarn - dependency-name: brace-expansion dependency-version: 1.1.12 dependency-type: indirect dependency-group: npm_and_yarn - dependency-name: braces dependency-version: 3.0.3 dependency-type: indirect dependency-group: npm_and_yarn - dependency-name: follow-redirects dependency-version: 1.15.11 dependency-type: indirect dependency-group: npm_and_yarn - dependency-name: form-data dependency-version: 3.0.4 dependency-type: indirect dependency-group: npm_and_yarn - dependency-name: jose dependency-version: 4.15.9 dependency-type: indirect dependency-group: npm_and_yarn - dependency-name: js-yaml dependency-version: 3.14.2 dependency-type: indirect dependency-group: npm_and_yarn - dependency-name: micromatch dependency-version: 4.0.8 dependency-type: indirect dependency-group: npm_and_yarn - dependency-name: min-document dependency-version: 2.19.2 dependency-type: indirect dependency-group: npm_and_yarn - dependency-name: nanoid dependency-version: 3.3.8 dependency-type: indirect dependency-group: npm_and_yarn - dependency-name: node-forge dependency-version: 1.3.3 dependency-type: indirect dependency-group: npm_and_yarn - dependency-name: tar dependency-version: 6.2.1 dependency-type: indirect dependency-group: npm_and_yarn - dependency-name: next dependency-version: 14.2.35 dependency-type: direct:production dependency-group: npm_and_yarn - dependency-name: "@mozilla/readability" dependency-version: 0.6.0 dependency-type: direct:production dependency-group: npm_and_yarn - dependency-name: ai dependency-version: 5.0.113 dependency-type: direct:production dependency-group: npm_and_yarn - dependency-name: nodemailer dependency-version: 7.0.11 dependency-type: direct:production dependency-group: npm_and_yarn - dependency-name: next dependency-version: 14.2.35 dependency-type: direct:production dependency-group: npm_and_yarn ... Signed-off-by: dependabot[bot] <support@github.com> * bug fixes and improvements * always show navbar in reader view * bug fix and small performance improvement * minor fix * Refactor link selection management and bulk actions - Replaced the use of selectedLinks with selectedIds in the link store for better performance and clarity. - Updated LinkListOptions, BulkDeleteLinksModal, and BulkEditLinksModal components to utilize the new selection management. - Modified LinkCard, LinkMasonry, and LinkList components to handle selection state through props. - Enhanced updateLinks API to support bulk updates with improved tag management. - Cleaned up unused imports and code related to previous selection methods. * move refetching logic to Links component * move disableDraggable and user hook out of each card to improve efficiency * cleaner code * memoize components and increase performance * fix: update announcement links to use the correct domain * feat: add favicon field to Link model + update packages + bug fix * feat: implement favicon fetching API and update Link model for favicon support * feat: add priority attribute to Image components in Sidebar * Refactor pages to use consistent layout handling (yes, I forgot to do that until now :P) * bump version * Refactor setting pages to use consistent layout handling * upgrade yarn to 4.12.0 * fix DnD bug * Enhance announcement handling by adding support for announcement messages * slimmed down the docker image size * update Node and yarn versions in playwright tests workflow * small fix * fix attempt 2 --------- Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
373 lines
12 KiB
TypeScript
373 lines
12 KiB
TypeScript
import { useState, useEffect, ChangeEvent, ReactElement } from "react";
|
|
import { AccountSettings } from "@linkwarden/types";
|
|
import { toast } from "react-hot-toast";
|
|
import SettingsLayout from "@/layouts/SettingsLayout";
|
|
import TextInput from "@/components/TextInput";
|
|
import { resizeImage } from "@/lib/client/resizeImage";
|
|
import ProfilePhoto from "@/components/ProfilePhoto";
|
|
import React from "react";
|
|
import Link from "next/link";
|
|
import Checkbox from "@/components/Checkbox";
|
|
import EmailChangeVerificationModal from "@/components/ModalContent/EmailChangeVerificationModal";
|
|
import { Button } from "@/components/ui/button";
|
|
import { i18n } from "next-i18next.config";
|
|
import { useTranslation } from "next-i18next";
|
|
import getServerSideProps from "@/lib/client/getServerSideProps";
|
|
import { useUpdateUser, useUser } from "@linkwarden/router/user";
|
|
import { z } from "zod";
|
|
import ImportDropdown from "@/components/ImportDropdown";
|
|
import { useConfig } from "@linkwarden/router/config";
|
|
import {
|
|
DropdownMenu,
|
|
DropdownMenuTrigger,
|
|
DropdownMenuContent,
|
|
DropdownMenuItem,
|
|
DropdownMenuSeparator,
|
|
} from "@/components/ui/dropdown-menu";
|
|
import { Separator } from "@/components/ui/separator";
|
|
import { NextPageWithLayout } from "../_app";
|
|
|
|
const Page: NextPageWithLayout = () => {
|
|
const [emailChangeVerificationModal, setEmailChangeVerificationModal] =
|
|
useState(false);
|
|
const [submitLoader, setSubmitLoader] = useState(false);
|
|
const { data: account } = useUser();
|
|
const updateUser = useUpdateUser();
|
|
const [user, setUser] = useState<any>(
|
|
account?.id
|
|
? account
|
|
: ({
|
|
// @ts-ignore
|
|
id: null,
|
|
name: "",
|
|
username: "",
|
|
email: "",
|
|
emailVerified: null,
|
|
password: undefined,
|
|
image: "",
|
|
isPrivate: false,
|
|
// @ts-ignore
|
|
createdAt: null,
|
|
whitelistedUsers: [],
|
|
} as unknown as AccountSettings)
|
|
);
|
|
|
|
const { data: config } = useConfig();
|
|
|
|
const { t } = useTranslation();
|
|
|
|
const [whitelistedUsersTextbox, setWhiteListedUsersTextbox] = useState("");
|
|
|
|
useEffect(() => {
|
|
if (!account?.id) return;
|
|
|
|
setUser({
|
|
...account,
|
|
whitelistedUsers: stringToArray(whitelistedUsersTextbox),
|
|
});
|
|
}, [account, whitelistedUsersTextbox]);
|
|
|
|
const handleImageUpload = async (e: ChangeEvent<HTMLInputElement>) => {
|
|
const file = e.target.files?.[0];
|
|
if (!file) return toast.error(t("image_upload_no_file_error"));
|
|
|
|
const fileExtension = file.name.split(".").pop()?.toLowerCase();
|
|
const allowedExtensions = ["png", "jpeg", "jpg"];
|
|
if (allowedExtensions.includes(fileExtension as string)) {
|
|
const resizedFile = await resizeImage(file);
|
|
if (
|
|
resizedFile.size < 1048576 // 1048576 Bytes == 1MB
|
|
) {
|
|
const reader = new FileReader();
|
|
reader.onload = () => {
|
|
setUser({ ...user, image: reader.result as string });
|
|
};
|
|
reader.readAsDataURL(resizedFile);
|
|
} else {
|
|
toast.error(t("image_upload_size_error"));
|
|
}
|
|
} else {
|
|
toast.error(t("image_upload_format_error"));
|
|
}
|
|
};
|
|
|
|
const submit = async (password?: string) => {
|
|
if (!/^[a-z0-9_-]{3,50}$/.test(user.username || "")) {
|
|
return toast.error(t("username_invalid_guide"));
|
|
}
|
|
|
|
const emailSchema = z.string().trim().email().toLowerCase();
|
|
const emailValidation = emailSchema.safeParse(user.email || "");
|
|
if (config?.EMAIL_PROVIDER && !emailValidation.success) {
|
|
return toast.error(t("email_invalid"));
|
|
}
|
|
|
|
setSubmitLoader(true);
|
|
|
|
const load = toast.loading(t("applying_settings"));
|
|
|
|
await updateUser.mutateAsync(
|
|
{
|
|
...user,
|
|
password: password ? password : undefined,
|
|
},
|
|
{
|
|
onSettled: (data, error) => {
|
|
setSubmitLoader(false);
|
|
toast.dismiss(load);
|
|
|
|
if (error) {
|
|
toast.error(error.message);
|
|
} else {
|
|
if (data.response.email !== user.email) {
|
|
toast.success(t("email_change_request"));
|
|
setEmailChangeVerificationModal(false);
|
|
}
|
|
|
|
toast.success(t("settings_applied"));
|
|
}
|
|
},
|
|
}
|
|
);
|
|
|
|
if (user.locale !== account?.locale) {
|
|
setTimeout(() => {
|
|
location.reload();
|
|
}, 1000);
|
|
}
|
|
};
|
|
|
|
useEffect(() => {
|
|
setWhiteListedUsersTextbox(account?.whitelistedUsers?.join(", ") || "");
|
|
}, [account]);
|
|
|
|
const stringToArray = (str: string) => {
|
|
return str?.replace(/\s+/g, "").split(",");
|
|
};
|
|
|
|
return (
|
|
<>
|
|
<p className="capitalize text-3xl font-thin inline">
|
|
{t("accountSettings")}
|
|
</p>
|
|
|
|
<Separator className="my-3" />
|
|
|
|
<div className="flex flex-col gap-5">
|
|
<div className="grid sm:grid-cols-2 gap-3 auto-rows-auto">
|
|
<div className="flex flex-col gap-3">
|
|
<div>
|
|
<p className="mb-2">{t("display_name")}</p>
|
|
<TextInput
|
|
value={user.name || ""}
|
|
className="bg-base-200"
|
|
onChange={(e) => setUser({ ...user, name: e.target.value })}
|
|
/>
|
|
</div>
|
|
<div>
|
|
<p className="mb-2">{t("username")}</p>
|
|
<TextInput
|
|
value={user.username || ""}
|
|
className="bg-base-200"
|
|
onChange={(e) => setUser({ ...user, username: e.target.value })}
|
|
/>
|
|
</div>
|
|
{config?.EMAIL_PROVIDER && (
|
|
<div>
|
|
<p className="mb-2">{t("email")}</p>
|
|
<TextInput
|
|
value={user.email || ""}
|
|
type="email"
|
|
className="bg-base-200"
|
|
onChange={(e) => setUser({ ...user, email: e.target.value })}
|
|
/>
|
|
</div>
|
|
)}
|
|
<div>
|
|
<p className="mb-2">{t("language")}</p>
|
|
<select
|
|
value={user.locale || ""}
|
|
onChange={(e) => {
|
|
setUser({ ...user, locale: e.target.value });
|
|
}}
|
|
className="select border border-neutral-content focus:outline-none focus:border-primary duration-100 w-full bg-base-200 rounded-[0.375rem] min-h-0 h-[2.625rem] leading-4 p-2"
|
|
>
|
|
{i18n.locales.map((locale) => (
|
|
<option key={locale} value={locale} className="capitalize">
|
|
{new Intl.DisplayNames(locale, { type: "language" }).of(
|
|
locale
|
|
) || ""}
|
|
</option>
|
|
))}
|
|
<option disabled>{t("more_coming_soon")}</option>
|
|
</select>
|
|
</div>
|
|
</div>
|
|
|
|
<div className="sm:row-span-2 sm:justify-self-center my-3">
|
|
<p className="mb-2 sm:text-center">{t("profile_photo")}</p>
|
|
<div className="w-28 h-28 flex gap-3 sm:flex-col items-center">
|
|
<ProfilePhoto
|
|
priority={true}
|
|
src={user.image ? user.image : undefined}
|
|
large={true}
|
|
/>
|
|
|
|
<DropdownMenu>
|
|
<DropdownMenuTrigger asChild>
|
|
<Button variant="metal" size="sm" className="text-sm">
|
|
<i className="bi-pencil-square text-md"></i>
|
|
{t("edit")}
|
|
</Button>
|
|
</DropdownMenuTrigger>
|
|
|
|
<DropdownMenuContent
|
|
align="start"
|
|
className="bg-base-200 border border-neutral-content rounded-box p-1"
|
|
>
|
|
<DropdownMenuItem onSelect={(e) => e.preventDefault()}>
|
|
<i className="bi-upload text-md"></i>
|
|
<label className="w-full flex items-center justify-between cursor-pointer whitespace-nowrap">
|
|
{t("upload_new_photo")}
|
|
<input
|
|
type="file"
|
|
name="photo"
|
|
id="upload-photo"
|
|
accept=".png, .jpeg, .jpg"
|
|
className="hidden"
|
|
onChange={handleImageUpload}
|
|
/>
|
|
</label>
|
|
</DropdownMenuItem>
|
|
|
|
{user.image && (
|
|
<>
|
|
<DropdownMenuSeparator />
|
|
<DropdownMenuItem
|
|
onClick={() => {
|
|
setUser({
|
|
...user,
|
|
image: "",
|
|
});
|
|
}}
|
|
className="text-error"
|
|
>
|
|
<i className="bi-trash text-md"></i>
|
|
{t("remove_photo")}
|
|
</DropdownMenuItem>
|
|
</>
|
|
)}
|
|
</DropdownMenuContent>
|
|
</DropdownMenu>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div className="sm:-mt-3">
|
|
<Checkbox
|
|
label={t("make_profile_private")}
|
|
state={user.isPrivate}
|
|
onClick={() => setUser({ ...user, isPrivate: !user.isPrivate })}
|
|
/>
|
|
|
|
<p className="text-neutral text-sm">{t("profile_privacy_info")}</p>
|
|
|
|
{user.isPrivate && (
|
|
<div className="pl-5">
|
|
<p className="mt-2">{t("whitelisted_users")}</p>
|
|
<p className="text-neutral text-sm mb-3">
|
|
{t("whitelisted_users_info")}
|
|
</p>
|
|
<textarea
|
|
className="w-full resize-none border rounded-md duration-100 bg-base-200 p-2 outline-none border-neutral-content focus:border-primary"
|
|
placeholder={t("whitelisted_users_placeholder")}
|
|
value={whitelistedUsersTextbox}
|
|
onChange={(e) => setWhiteListedUsersTextbox(e.target.value)}
|
|
/>
|
|
</div>
|
|
)}
|
|
</div>
|
|
|
|
<Button
|
|
variant="accent"
|
|
onClick={() => {
|
|
if (account?.email !== user.email) {
|
|
setEmailChangeVerificationModal(true);
|
|
} else {
|
|
submit();
|
|
}
|
|
}}
|
|
disabled={submitLoader}
|
|
className="mt-2 w-full sm:w-fit"
|
|
>
|
|
{t("save_changes")}
|
|
</Button>
|
|
|
|
<div>
|
|
<div className="flex items-center gap-2 w-full rounded-md h-8">
|
|
<p className="truncate w-full pr-7 text-3xl font-thin">
|
|
{t("import_export")}
|
|
</p>
|
|
</div>
|
|
|
|
<Separator className="my-3" />
|
|
|
|
<div className="flex gap-3 flex-col">
|
|
<div>
|
|
<p className="mb-2">{t("import_data")}</p>
|
|
<ImportDropdown />
|
|
</div>
|
|
|
|
<div>
|
|
<p className="mb-2">{t("download_data")}</p>
|
|
<Link className="w-fit" href="/api/v1/migration">
|
|
<div className="select-none relative duration-200 rounded-lg text-sm text-center w-fit flex justify-center items-center gap-2 disabled:pointer-events-none disabled:opacity-50 bg-neutral-content text-base-content hover:bg-neutral-content/80 border border-neutral/30 h-10 px-4 py-2">
|
|
<i className="bi-cloud-download text-xl duration-100"></i>
|
|
<p>{t("export_data")}</p>
|
|
</div>
|
|
</Link>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div>
|
|
<div className="flex items-center gap-2 w-full rounded-md h-8">
|
|
<p className="text-red-500 dark:text-red-500 truncate w-full pr-7 text-3xl font-thin">
|
|
{t("delete_account")}
|
|
</p>
|
|
</div>
|
|
|
|
<Separator className="my-3" />
|
|
|
|
<p>
|
|
{t("delete_account_warning")}
|
|
{process.env.NEXT_PUBLIC_STRIPE &&
|
|
" " + t("cancel_subscription_notice")}
|
|
</p>
|
|
</div>
|
|
|
|
<Link href="/settings/delete" className="underline">
|
|
{t("account_deletion_page")}
|
|
</Link>
|
|
</div>
|
|
|
|
{emailChangeVerificationModal && (
|
|
<EmailChangeVerificationModal
|
|
onClose={() => setEmailChangeVerificationModal(false)}
|
|
onSubmit={submit}
|
|
oldEmail={account?.email || ""}
|
|
newEmail={user.email || ""}
|
|
/>
|
|
)}
|
|
</>
|
|
);
|
|
};
|
|
|
|
Page.getLayout = function getLayout(page: ReactElement) {
|
|
return <SettingsLayout>{page}</SettingsLayout>;
|
|
};
|
|
|
|
export default Page;
|
|
|
|
export { getServerSideProps };
|