diff --git a/package.json b/package.json index 821e38f4..65858af0 100644 --- a/package.json +++ b/package.json @@ -39,7 +39,7 @@ "@markdoc/markdoc": "0.4.0", "@markdoc/next.js": "0.2.2", "@open-draft/until": "2.1.0", - "@pluralsh/design-system": "3.52.1", + "@pluralsh/design-system": "3.53.0", "@react-types/shared": "3.22.0", "@tanstack/react-table": "8.10.7", "@tanstack/react-virtual": "3.0.1", diff --git a/pages/community.tsx b/pages/community.tsx new file mode 100644 index 00000000..d6af5683 --- /dev/null +++ b/pages/community.tsx @@ -0,0 +1,243 @@ +import { + ArrowRightIcon, + Button, + Card, + Chip, + ColorModeProvider, + DocumentIcon, + GitHubLogoIcon, + IconFrame, + YouTubeIcon, +} from '@pluralsh/design-system' +import { type GetStaticProps, type InferGetStaticPropsType } from 'next' +import { useRouter } from 'next/router' + +import { useTheme } from 'styled-components' + +import { FooterVariant } from '@src/components/FooterFull' +import { GradientBG } from '@src/components/layout/GradientBG' +import { HeaderPad } from '@src/components/layout/HeaderPad' +import { StandardPageWidth } from '@src/components/layout/LayoutHelpers' +import { formatDateTime } from '@src/components/page-sections/EventsSection' +import { BasicPageHero } from '@src/components/PageHeros' +import { ResponsiveText } from '@src/components/Typography' +import { type PluralEvent, getEvents } from '@src/data/getEvents' +import { cn as classNames } from '@src/utils/cn' +import { combineErrors } from '@src/utils/combineErrors' +import { propsWithGlobalSettings } from '@src/utils/getGlobalProps' + +export default function Community({ + events, +}: InferGetStaticPropsType) { + return ( + <> + + + + {/* resources */} + + + Community Resources + +
+ {kinds.map((key) => ( + + ))} +
+
+ {/* events */} + +
+ + + Plural Events + + {events.length ? ( + + ) : ( + + + No planned events at this time + + + )} + +
+
+ + ) +} + +const resources = { + gitHub: { + url: 'https://github.com/pluralsh/plural', + title: 'GitHub', + icon: , + }, + youtube: { + url: 'https://www.youtube.com/channel/UCKpIHwAFwvXhM-RaR1h77Jw', + title: 'YouTube', + icon: , + }, + docs: { + url: 'https://docs.plural.sh', + title: 'Docs', + icon: , + }, +} as const + +const kinds = Object.keys(resources) as Array + +function ResourceLink({ kind }: { kind: keyof typeof resources }) { + const theme = useTheme() + + return ( + + ) +} + +function EventsGrid({ events }: { events: PluralEvent[] }) { + const locale = useRouter().locale || 'en-us' + + return ( + + ) +} + +export type CommunityPageProps = { + events: PluralEvent[] +} + +export const getStaticProps: GetStaticProps = async ( + _context +) => { + const { data: events, error: eventsError } = await getEvents() + + return propsWithGlobalSettings({ + metaTitle: 'Community', + metaDescription: 'Flexible plans for every stage of your business', + footerVariant: FooterVariant.kitchenSink, + errors: combineErrors([eventsError]), + events, + }) +} diff --git a/src/components/page-sections/EventsSection.tsx b/src/components/page-sections/EventsSection.tsx index 522616a7..dd852653 100644 --- a/src/components/page-sections/EventsSection.tsx +++ b/src/components/page-sections/EventsSection.tsx @@ -12,10 +12,9 @@ import { TextLimiter } from '../layout/TextLimiter' import { ResponsiveText } from '../Typography' const DATE_FORMAT = { - month: 'short', + month: 'long', day: 'numeric', year: 'numeric', - weekday: 'short', } as const const TIME_FORMAT = { @@ -32,8 +31,8 @@ function formatTime( showTimeZone = true, }: { locale: string - timeZone?: string - timeZoneShort?: string + timeZone?: string | null + timeZoneShort?: string | null showTimeZone?: boolean } ) { @@ -45,14 +44,19 @@ function formatTime( }${showTimeZone && timeZoneShort ? ` ${timeZoneShort}` : ''}` } -function formatDateTime( +export function formatDateTime( date: Date | null | undefined, { locale, showTime, timeZone, timeZoneShort, - }: { locale: string; showTime; timeZone?: string; timeZoneShort?: string } + }: { + locale: string + showTime + timeZone?: string | null + timeZoneShort?: string | null + } ) { if (!date) { return '' diff --git a/src/data/getSiteSettings.tsx b/src/data/getSiteSettings.tsx index f93c68ef..1125593e 100644 --- a/src/data/getSiteSettings.tsx +++ b/src/data/getSiteSettings.tsx @@ -174,14 +174,14 @@ export const getSiteSettings = (solutions?: Solution[]) => ({ url: '/contact', }, }, - // { - // id: '6-5', - // link: { - // id: '6-5', - // title: 'Community', - // url: '/community', - // }, - // }, + { + id: '6-5', + link: { + id: '6-5', + title: 'Community', + url: '/community', + }, + }, ], }, ], diff --git a/yarn.lock b/yarn.lock index bb8d8240..9b9569c6 100644 --- a/yarn.lock +++ b/yarn.lock @@ -4276,9 +4276,9 @@ __metadata: languageName: node linkType: hard -"@pluralsh/design-system@npm:3.52.1": - version: 3.52.1 - resolution: "@pluralsh/design-system@npm:3.52.1" +"@pluralsh/design-system@npm:3.53.0": + version: 3.53.0 + resolution: "@pluralsh/design-system@npm:3.53.0" dependencies: "@floating-ui/react-dom-interactions": 0.13.3 "@loomhq/loom-embed": 1.5.0 @@ -4326,7 +4326,7 @@ __metadata: react-dom: ">=18.3.1" react-transition-group: ">=4.4.5" styled-components: ">=5.3.11" - checksum: 1e802c690394138e35696e2e2e7b49d4af0a61bdabc27474118c65df2d0326b25031132906a0046d9e9b847a6ef99f3f9e6e8e4f4d38ea68af97eb1cc1d91969 + checksum: b0ee7c5e2ae382be6c62e724c9b9aba1655e16a3aa5b88450d1442808b8e33c9f6d2578e2ecae0f9eab5aca61f8bb679ad1cdfca42b22f64c75ecc903255e41f languageName: node linkType: hard @@ -13743,7 +13743,7 @@ __metadata: "@markdoc/next.js": 0.2.2 "@next/bundle-analyzer": 13.4.12 "@open-draft/until": 2.1.0 - "@pluralsh/design-system": 3.52.1 + "@pluralsh/design-system": 3.53.0 "@pluralsh/eslint-config-typescript": 2.5.183 "@pluralsh/stylelint-config": 2.0.10 "@radix-ui/react-slot": 1.0.2