✨ Migrate to TanStack Query (React Query) and TanStack Router (#637)
This commit is contained in:
50
new-frontend/src/routes/_layout/settings.tsx
Normal file
50
new-frontend/src/routes/_layout/settings.tsx
Normal file
@@ -0,0 +1,50 @@
|
||||
import { Container, Heading, Tab, TabList, TabPanel, TabPanels, Tabs } from '@chakra-ui/react';
|
||||
import { createFileRoute } from '@tanstack/react-router';
|
||||
import { useQueryClient } from 'react-query';
|
||||
|
||||
import { UserOut } from '../../client';
|
||||
import Appearance from '../../components/UserSettings/Appearance';
|
||||
import ChangePassword from '../../components/UserSettings/ChangePassword';
|
||||
import DeleteAccount from '../../components/UserSettings/DeleteAccount';
|
||||
import UserInformation from '../../components/UserSettings/UserInformation';
|
||||
|
||||
const tabsConfig = [
|
||||
{ title: 'My profile', component: UserInformation },
|
||||
{ title: 'Password', component: ChangePassword },
|
||||
{ title: 'Appearance', component: Appearance },
|
||||
{ title: 'Danger zone', component: DeleteAccount },
|
||||
];
|
||||
|
||||
export const Route = createFileRoute('/_layout/settings')({
|
||||
component: UserSettings,
|
||||
})
|
||||
|
||||
function UserSettings() {
|
||||
const queryClient = useQueryClient();
|
||||
const currentUser = queryClient.getQueryData<UserOut>('currentUser');
|
||||
const finalTabs = currentUser?.is_superuser ? tabsConfig.slice(0, 3) : tabsConfig;
|
||||
|
||||
return (
|
||||
<Container maxW='full'>
|
||||
<Heading size='lg' textAlign={{ base: 'center', md: 'left' }} py={12}>
|
||||
User Settings
|
||||
</Heading>
|
||||
<Tabs variant='enclosed'>
|
||||
<TabList>
|
||||
{finalTabs.map((tab, index) => (
|
||||
<Tab key={index}>{tab.title}</Tab>
|
||||
))}
|
||||
</TabList>
|
||||
<TabPanels>
|
||||
{finalTabs.map((tab, index) => (
|
||||
<TabPanel key={index}>
|
||||
<tab.component />
|
||||
</TabPanel>
|
||||
))}
|
||||
</TabPanels>
|
||||
</Tabs>
|
||||
</Container>
|
||||
);
|
||||
}
|
||||
|
||||
export default UserSettings;
|
Reference in New Issue
Block a user