This repository has been archived on 2024-10-29. You can view files and clone it, but cannot push or open issues or pull requests.

61 lines
1.8 KiB
TypeScript
Raw Normal View History

2022-08-31 20:44:33 +01:00
import type { NextPage } from 'next'
2022-04-09 11:33:28 +02:00
import useTranslation from 'next-translate/useTranslation'
2022-03-16 12:18:09 +01:00
import { Head } from '../../../components/Head'
import { Application } from '../../../components/Application'
2022-08-31 20:44:33 +01:00
import type { PagePropsWithAuthentication } from '../../../tools/authentication'
import {
authenticationFromServerSide,
2022-08-31 20:44:33 +01:00
AuthenticationProvider
2022-03-16 12:18:09 +01:00
} from '../../../tools/authentication'
2022-08-31 20:44:33 +01:00
import type { GuildMember } from '../../../contexts/GuildMember'
import { GuildMemberProvider } from '../../../contexts/GuildMember'
2022-03-16 12:18:09 +01:00
import { GuildsProvider } from '../../../contexts/Guilds'
import { GuildSettings } from '../../../components/Application/GuildSettings'
export interface GuildSettingsPageProps extends PagePropsWithAuthentication {
guildId: number
guildMember: GuildMember
}
const GuildSettingsPage: NextPage<GuildSettingsPageProps> = (props) => {
const { guildId, authentication, guildMember } = props
2022-04-09 11:33:28 +02:00
const { t } = useTranslation()
const path = { guildId }
return (
<AuthenticationProvider authentication={authentication}>
<GuildsProvider>
<GuildMemberProvider guildMember={guildMember} path={path}>
2022-04-09 11:33:28 +02:00
<Head title={`Thream | ${t('application:guild-settings')}`} />
<Application path={path} title={t('application:guild-settings')}>
<GuildSettings />
</Application>
</GuildMemberProvider>
</GuildsProvider>
</AuthenticationProvider>
)
}
export const getServerSideProps = authenticationFromServerSide({
shouldBeAuthenticated: true,
fetchData: async (context, api) => {
const guildId = Number(context?.params?.guildId)
if (isNaN(guildId)) {
return {
2022-08-30 21:30:06 +02:00
notFound: true
}
}
const { data: guildMember } = await api.get<GuildMember>(
`/guilds/${guildId}`
)
return {
guildId,
guildMember
}
}
})
export default GuildSettingsPage