plane/web/pages/profile/preferences/email.tsx

43 lines
1.3 KiB
TypeScript
Raw Normal View History

import { ReactElement } from "react";
import useSWR from "swr";
// layouts
2024-03-19 14:38:35 +00:00
import { PageHead } from "@/components/core";
import { EmailNotificationForm } from "@/components/profile/preferences";
import { EmailSettingsLoader } from "@/components/ui";
import { ProfilePreferenceSettingsLayout } from "@/layouts/settings-layout/profile/preferences";
// ui
// components
// services
2024-03-19 14:38:35 +00:00
import { NextPageWithLayout } from "@/lib/types";
import { UserService } from "@/services/user.service";
// type
// services
const userService = new UserService();
const ProfilePreferencesThemePage: NextPageWithLayout = () => {
// fetching user email notification settings
const { data, isLoading } = useSWR("CURRENT_USER_EMAIL_NOTIFICATION_SETTINGS", () =>
userService.currentUserEmailNotificationSettings()
);
if (!data || isLoading) {
return <EmailSettingsLoader />;
}
return (
<>
<PageHead title="Profile - Email Preference" />
<div className="mx-auto mt-8 h-full w-full px-6 lg:px-20 pb-8 vertical-scrollbar scrollbar-md">
<EmailNotificationForm data={data} />
</div>
</>
);
};
ProfilePreferencesThemePage.getLayout = function getLayout(page: ReactElement) {
return <ProfilePreferenceSettingsLayout>{page}</ProfilePreferenceSettingsLayout>;
};
export default ProfilePreferencesThemePage;