wip: Add concept page

This commit is contained in:
Sol Irvine
2023-08-20 21:50:24 +09:00
parent e8be366eaa
commit bcfa92c747
7 changed files with 139 additions and 0 deletions

View File

@@ -0,0 +1,63 @@
'use client';
import clsx from 'clsx';
import Logo from 'components/icons/logo';
import { useTranslations } from 'next-intl';
import Image from 'next/image';
import ConceptImage001 from './images/concept-image-001.png';
import ConceptImage002 from './images/concept-image-002.png';
export default function ConceptDetail() {
const t = useTranslations('Index');
return (
<div className="w-full px-6">
<div className="max-w-screen-2x relative mx-auto">
<Image
src={ConceptImage001}
priority={true}
alt="A picture of the Narai Black bottle resting on a mossy forest floor."
className={clsx('h-full w-full object-cover')}
/>
</div>
<div
className={clsx(
'font-multilingual mx-auto flex w-full flex-col space-y-12 py-12 text-left font-extralight md:flex-row md:space-x-6 md:space-y-0 md:py-24 md:pb-24'
)}
>
<div className="md:w-1/2">
<h2 className="max-w-sm pb-12 text-4xl md:text-5xl">{t('concept.title')}</h2>
<p className="font-multilingual text-lg font-extralight">
{t('concept.para001')} {t('concept.para002')} {t('concept.para003')}
</p>
</div>
<div className="flex flex-row items-start justify-end md:w-1/2">
<div className="pb-24">
<Logo className="h-30 w-48" />
</div>
</div>
</div>
<div className="mx-auto flex max-w-screen-2xl flex-col space-y-24">
<div className="font-multilingual font-extralight md:w-1/2">
<p className="pb-6 text-xl font-normal">{t('concept.subtitle001')}</p>
<p className="pb-24 text-lg leading-relaxed">{t('concept.para004')}</p>
<p className="pb-6 text-xl font-normal">{t('concept.subtitle002')}</p>
<p className="pb-4 text-lg leading-relaxed">{t('concept.para005')}</p>
<p className="pb-4 text-lg leading-relaxed">
{t('concept.para006')} {t('concept.para007')} {t('concept.para008')}
</p>
<p className="pb-4 text-lg leading-relaxed">{t('concept.para009')}</p>
<p className="text-lg leading-relaxed">{t('concept.para010')}</p>
</div>
<Image
src={ConceptImage002}
priority={true}
alt="A picture of the forest tree tops."
className={clsx('h-full w-full object-cover')}
/>
</div>
</div>
);
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.6 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.0 MiB

View File

@@ -0,0 +1,5 @@
import { Suspense } from 'react';
export default function Layout({ children }: { children: React.ReactNode }) {
return <Suspense>{children}</Suspense>;
}

View File

@@ -0,0 +1,41 @@
import Footer from 'components/layout/footer';
import { SupportedLocale } from 'components/layout/navbar/language-control';
import Navbar from 'components/layout/navbar';
import { getCart } from 'lib/shopify';
import { cookies } from 'next/headers';
import { Suspense } from 'react';
import ConceptDetail from './concept-detail';
export const runtime = 'edge';
const { SITE_NAME } = process.env;
export const metadata = {
title: SITE_NAME,
description: SITE_NAME,
openGraph: {
type: 'website'
}
};
export default async function Page({ params }: { params: { locale?: SupportedLocale } }) {
const cartId = cookies().get('cartId')?.value;
let cart;
if (cartId) {
cart = await getCart(cartId);
}
return (
<div>
<Navbar cart={cart} locale={params?.locale} compact />
<div className="pt-24 md:pt-48">
<ConceptDetail />
</div>
<Suspense>
<Footer cart={cart} />
</Suspense>
</div>
);
}