1
Fork 0
mirror of https://github.com/Steffo99/festa.git synced 2025-01-08 06:49:44 +00:00
festa/pages/events/[slug].tsx

95 lines
3.4 KiB
TypeScript
Raw Normal View History

2022-06-11 03:08:49 +00:00
import { NextPage, NextPageContext } from 'next'
import { useTranslation } from 'next-i18next'
import { serverSideTranslations } from 'next-i18next/serverSideTranslations'
import { default as Head } from 'next/head'
2022-06-09 21:43:38 +00:00
import defaultPostcard from "../../public/postcards/adi-goldstein-Hli3R6LKibo-unsplash.jpg"
2022-06-11 03:08:49 +00:00
import { Postcard } from '../../components/postcard/changer'
import { ViewEvent } from '../../components/events/views/event'
import useSWR from 'swr'
import { Event } from '@prisma/client'
2022-07-16 16:18:41 +00:00
import { EditableText } from '../../components/generic/editable/inputs'
import { EditingContext, EditingMode } from '../../components/generic/editable/base'
2022-07-16 18:02:03 +00:00
import { useCallback, useContext, useState } from 'react'
2022-07-16 16:18:41 +00:00
import { ToolBar } from '../../components/generic/toolbar/bar'
import { ToolToggleEditing } from '../../components/events/toolbar/toolToggleEditing'
import { ToolToggleVisibility } from '../../components/postcard/toolbar/toolToggleVisibility'
import { WIPBanner } from '../../components/generic/wip/banner'
2022-07-16 18:02:03 +00:00
import { AuthContext } from '../../components/auth/base'
import { useDefinedContext } from '../../utils/definedContext'
2022-07-17 00:31:04 +00:00
import { asleep } from '../../utils/asleep'
2022-06-03 01:55:02 +00:00
export async function getServerSideProps(context: NextPageContext) {
return {
props: {
2022-06-11 03:08:49 +00:00
slug: context.query.slug,
2022-06-03 01:55:02 +00:00
...(await serverSideTranslations(context.locale ?? "it-IT", ["common"]))
}
}
}
2022-06-11 03:08:49 +00:00
type PageEventProps = {
slug: string
2022-06-03 01:55:02 +00:00
}
2022-06-11 03:08:49 +00:00
const PageEvent: NextPage<PageEventProps> = ({ slug }) => {
2022-06-08 17:14:00 +00:00
const { t } = useTranslation()
2022-07-16 18:02:03 +00:00
const { data, error, mutate } = useSWR<Event>(`/api/events/${slug}`)
const [auth, _setAuth] = useDefinedContext(AuthContext)
2022-06-10 03:21:02 +00:00
2022-07-16 16:18:41 +00:00
const displayTitle = data?.name ?? slug
const displayPostcard = data?.postcard ?? defaultPostcard
const displayDescription = data?.description ?? ""
2022-07-16 18:02:03 +00:00
const saveEdits = useCallback(
2022-07-17 00:31:04 +00:00
async () => {
await asleep(1000)
2022-07-16 18:02:03 +00:00
mutate()
},
[]
)
2022-07-16 16:18:41 +00:00
2022-06-04 03:13:19 +00:00
return <>
<Head>
2022-07-16 16:18:41 +00:00
<title key="title">{displayTitle} - {t("siteTitle")}</title>
2022-06-11 03:08:49 +00:00
<link rel="preload" href={`/api/events/${slug}`} as="fetch" />
2022-06-04 03:13:19 +00:00
</Head>
2022-06-11 03:08:49 +00:00
<Postcard
2022-07-16 16:18:41 +00:00
src={displayPostcard}
2022-06-11 03:08:49 +00:00
/>
2022-07-16 16:18:41 +00:00
<WIPBanner />
<EditingContext.Provider value={useState<EditingMode>(EditingMode.VIEW)}>
<ViewEvent
title={<>
<EditableText
value={displayTitle}
2022-07-16 18:02:03 +00:00
onChange={e => mutate(async state => state ? { ...state, name: e.target.value } : undefined, { revalidate: false })}
2022-07-16 16:18:41 +00:00
/>
</>}
postcard={<></>}
description={<>
<EditableText
value={displayDescription}
2022-07-16 18:02:03 +00:00
onChange={e => mutate(async state => state ? { ...state, description: e.target.value } : undefined, { revalidate: false })}
2022-07-16 16:18:41 +00:00
/>
</>}
daterange={<></>}
/>
<ToolBar vertical="vadapt" horizontal="right">
<ToolToggleVisibility />
2022-07-16 18:02:03 +00:00
{data && auth?.userId === data?.creatorId &&
<ToolToggleEditing
onEditEnd={saveEdits}
/>
}
2022-07-16 16:18:41 +00:00
</ToolBar>
</EditingContext.Provider>
2022-06-04 03:13:19 +00:00
</>
2022-06-11 03:08:49 +00:00
}
export default PageEvent