mirror of
https://github.com/vercel/commerce.git
synced 2025-03-28 08:15:54 +00:00
* Moved everything * Figuring out how to make imports work * Updated exports * Added missing exports * Added @vercel/commerce-local to `site` * Updated commerce config * Updated exports and commerce config * Updated commerce hoc * Fixed exports in local * Added publish config * Updated imports in site * It's actually working * Don't use debugger in dev for better speeds * Improved DX when editing packages * Set up eslint with husky * Updated prettier config * Added prettier setup to every package * Moved bigcommerce * Moved Bigcommerce to src and package updates * Updated setup of bigcommerce * Moved definitions script * Moved commercejs * Move to src * Fixed types in commercejs * Moved kibocommerce * Moved kibocommerce to src * Added package/tsconfig to kibocommerce * Fixed imports and other things * Moved ordercloud * Moved ordercloud to src * Fixed imports * Added missing prettier files * Moved Saleor * Moved Saleor to src * Fixed imports * Replaced all imports to @commerce * Added prettierignore/rc to all providers * Moved shopify to src * Build shopify in packages * Moved Spree * Moved spree to src * Updated spree * Moved swell * Moved swell to src * Fixed type imports in swell * Moved Vendure to packages * Moved vendure to src * Fixed imports in vendure * Added codegen to saleor * Updated codegen setup for shopify * Added codegen to vendure * Added codegen to kibocommerce * Added all packages to site's deps * Updated codegen setup in bigcommerce * Minor fixes * Updated providers' names in site * Updated packages based on Bel's changes * Updated turbo to latest * Fixed ts complains * Set npm engine in root * New lockfile install * remove engines * Regen lockfile * Switched from npm to yarn * Updated typesVersions in all packages * Moved dep * Updated SWR to the just released 1.2.0 * Removed "isolatedModules" from packages * Updated list of providers and default * Updated swell declaration * Removed next import from kibocommerce * Added COMMERCE_PROVIDER log * Added another log * Updated turbo config * Updated docs * Removed test logs Co-authored-by: Jared Palmer <jared@jaredpalmer.com>
87 lines
2.3 KiB
TypeScript
87 lines
2.3 KiB
TypeScript
import type {
|
|
GetStaticPathsContext,
|
|
GetStaticPropsContext,
|
|
InferGetStaticPropsType,
|
|
} from 'next'
|
|
import commerce from '@lib/api/commerce'
|
|
import { Text } from '@components/ui'
|
|
import { Layout } from '@components/common'
|
|
import getSlug from '@lib/get-slug'
|
|
import { missingLocaleInPages } from '@lib/usage-warns'
|
|
import type { Page } from '@commerce/types/page'
|
|
import { useRouter } from 'next/router'
|
|
|
|
export async function getStaticProps({
|
|
preview,
|
|
params,
|
|
locale,
|
|
locales,
|
|
}: GetStaticPropsContext<{ pages: string[] }>) {
|
|
const config = { locale, locales }
|
|
const pagesPromise = commerce.getAllPages({ config, preview })
|
|
const siteInfoPromise = commerce.getSiteInfo({ config, preview })
|
|
const { pages } = await pagesPromise
|
|
const { categories } = await siteInfoPromise
|
|
const path = params?.pages.join('/')
|
|
const slug = locale ? `${locale}/${path}` : path
|
|
const pageItem = pages.find((p: Page) =>
|
|
p.url ? getSlug(p.url) === slug : false
|
|
)
|
|
const data =
|
|
pageItem &&
|
|
(await commerce.getPage({
|
|
variables: { id: pageItem.id! },
|
|
config,
|
|
preview,
|
|
}))
|
|
|
|
const page = data?.page
|
|
|
|
if (!page) {
|
|
// We throw to make sure this fails at build time as this is never expected to happen
|
|
throw new Error(`Page with slug '${slug}' not found`)
|
|
}
|
|
|
|
return {
|
|
props: { pages, page, categories },
|
|
revalidate: 60 * 60, // Every hour
|
|
}
|
|
}
|
|
|
|
export async function getStaticPaths({ locales }: GetStaticPathsContext) {
|
|
const config = { locales }
|
|
const { pages }: { pages: Page[] } = await commerce.getAllPages({ config })
|
|
const [invalidPaths, log] = missingLocaleInPages()
|
|
const paths = pages
|
|
.map((page) => page.url)
|
|
.filter((url) => {
|
|
if (!url || !locales) return url
|
|
// If there are locales, only include the pages that include one of the available locales
|
|
if (locales.includes(getSlug(url).split('/')[0])) return url
|
|
|
|
invalidPaths.push(url)
|
|
})
|
|
log()
|
|
|
|
return {
|
|
paths,
|
|
fallback: 'blocking',
|
|
}
|
|
}
|
|
|
|
export default function Pages({
|
|
page,
|
|
}: InferGetStaticPropsType<typeof getStaticProps>) {
|
|
const router = useRouter()
|
|
|
|
return router.isFallback ? (
|
|
<h1>Loading...</h1> // TODO (BC) Add Skeleton Views
|
|
) : (
|
|
<div className="max-w-2xl mx-8 sm:mx-auto py-20">
|
|
{page?.body && <Text html={page.body} />}
|
|
</div>
|
|
)
|
|
}
|
|
|
|
Pages.Layout = Layout
|