mirror of
https://github.com/vercel/commerce.git
synced 2025-05-18 23:46:58 +00:00
126 lines
3.1 KiB
TypeScript
126 lines
3.1 KiB
TypeScript
import type {
|
|
GetStaticPathsContext,
|
|
GetStaticPropsContext,
|
|
InferGetStaticPropsType,
|
|
|
|
} from 'next'
|
|
|
|
import commerce from '@lib/api/commerce'
|
|
import { Layout } from '@components/common'
|
|
|
|
import { getAgilityPageProps, getAgilityPaths } from "@agility/nextjs/node"
|
|
import { handlePreview } from "@agility/nextjs"
|
|
|
|
import AgilityPage from "components/agility-global/AgilityPage"
|
|
import getModuleData from "@lib/module-data"
|
|
import SiteData from '@lib/global-data/SiteData'
|
|
|
|
|
|
export async function getStaticProps({ preview, params, locale, locales, defaultLocale }: GetStaticPropsContext<{ slug: string[] }>) {
|
|
try {
|
|
let productCode: string | null = null
|
|
|
|
//check if this page is a product...
|
|
if (params?.slug.length === 2
|
|
&& params?.slug[0] === "product") {
|
|
productCode = params.slug[1]
|
|
params.slug[1] = "product-details"
|
|
}
|
|
|
|
//add any global data accessor here
|
|
const globalComponents = {
|
|
"sitedata": SiteData
|
|
}
|
|
|
|
const agilityProps = await getAgilityPageProps({ preview, params, locale, getModule: getModuleData, defaultLocale, globalComponents });
|
|
|
|
let rebuildFrequency = 10
|
|
|
|
let productDetail: any = null
|
|
|
|
if (productCode) {
|
|
|
|
const config = { locale, locales }
|
|
|
|
const { product } = await commerce.getProduct({
|
|
variables: { slug: productCode },
|
|
config,
|
|
preview,
|
|
})
|
|
|
|
if (product !== null) {
|
|
|
|
//moderate hack: use the Product as the dynamic page item for product detail pages
|
|
agilityProps.dynamicPageItem = product
|
|
rebuildFrequency = 60 * 60 //once per hour for products
|
|
} else {
|
|
throw new Error(`Product not found`)
|
|
}
|
|
}
|
|
|
|
if (!agilityProps) {
|
|
// We throw to make sure this fails at build time as this is never expected to happen
|
|
throw new Error(`Page not found`)
|
|
}
|
|
|
|
return {
|
|
props: { agilityProps },
|
|
revalidate: rebuildFrequency
|
|
}
|
|
} catch (err) {
|
|
var e = new Error();
|
|
const st = e.stack;
|
|
|
|
console.log("Error getting page props", params, err)
|
|
|
|
return {
|
|
props: {
|
|
error: `Params: ${params}, Error: ${err}, Stack: ${st}`,
|
|
agilityProps: null
|
|
},
|
|
revalidate: 60000
|
|
}
|
|
}
|
|
}
|
|
|
|
export async function getStaticPaths({ defaultLocale, locales }: GetStaticPathsContext) {
|
|
|
|
//get the paths configured in agility
|
|
let agilityPaths = await getAgilityPaths({ preview: false, defaultLocale, locales })
|
|
|
|
//remove product/product-details from the agility paths (special details page...)
|
|
agilityPaths = agilityPaths.filter(p => p !== "/product/product-details")
|
|
|
|
//get the product paths from the commerce api
|
|
const { products } = await commerce.getAllProductPaths()
|
|
|
|
let productPaths = []
|
|
if (locales) {
|
|
productPaths = locales.reduce<string[]>((arr, locale) => {
|
|
// Add a product path for every locale
|
|
products.forEach((product: any) => {
|
|
arr.push(`/${locale}/product${product.path}`)
|
|
})
|
|
return arr
|
|
}, [])
|
|
} else {
|
|
productPaths = products.map((product: any) => `/product${product.path}`)
|
|
}
|
|
|
|
const paths = [...agilityPaths, ...productPaths]
|
|
|
|
return {
|
|
paths,
|
|
fallback: 'blocking',
|
|
}
|
|
}
|
|
|
|
export default function Pages(props: InferGetStaticPropsType<typeof getStaticProps>) {
|
|
|
|
return (
|
|
<AgilityPage {...props} />
|
|
)
|
|
}
|
|
|
|
Pages.Layout = Layout
|