push code to check

This commit is contained in:
Tan Le
2021-10-07 10:46:20 +07:00
parent 46e834bf0d
commit 8b5637a247
4 changed files with 81 additions and 16 deletions

View File

@@ -2,7 +2,7 @@ import { Product } from '@commerce/types/product'
import { OperationContext } from '@commerce/api/operations' import { OperationContext } from '@commerce/api/operations'
import { Provider, VendureConfig } from '../' import { Provider, VendureConfig } from '../'
import { GetProductQuery } from '../../schema' import { GetProductQuery } from '../../schema'
import { getProductQuery } from '../../utils/queries/get-product-query' import { getProductQuery, getProductDetailQuery } from '../../utils/queries/get-product-query'
export default function getProductOperation({ export default function getProductOperation({
commerce, commerce,

View File

@@ -26,6 +26,7 @@
"body-scroll-lock": "^3.1.5", "body-scroll-lock": "^3.1.5",
"classnames": "^2.3.1", "classnames": "^2.3.1",
"cookie": "^0.4.1", "cookie": "^0.4.1",
"dns": "^0.2.2",
"email-validator": "^2.0.4", "email-validator": "^2.0.4",
"eslint": "^7.32.0", "eslint": "^7.32.0",
"eslint-config-next": "^11.1.2", "eslint-config-next": "^11.1.2",
@@ -35,6 +36,7 @@
"lodash.debounce": "^4.0.8", "lodash.debounce": "^4.0.8",
"lodash.random": "^3.2.0", "lodash.random": "^3.2.0",
"lodash.throttle": "^4.1.1", "lodash.throttle": "^4.1.1",
"net": "^1.0.2",
"next": "^11.0.0", "next": "^11.0.0",
"next-seo": "^4.26.0", "next-seo": "^4.26.0",
"next-themes": "^0.0.14", "next-themes": "^0.0.14",

View File

@@ -1,17 +1,17 @@
import commerce from '@lib/api/commerce'; import commerce from '@lib/api/commerce';
import { GetStaticPropsContext } from 'next'; import { GetStaticPropsContext } from 'next';
import { Layout } from 'src/components/common'; import { Layout } from 'src/components/common';
import { ProductCard } from '@commerce/types/product';
interface Props { interface Props {
products: any productDetail: ProductCard[],
} }
export default function Home({ products }: Props) { export default function Home({ productDetail }: Props) {
return ( return (
<> <>
<p> <p>
TOTAL: {products?.length} TOTAL: {productDetail}
</p> </p>
{JSON.stringify(products[0])} {/* {JSON.stringify(productDetail)} */}
</> </>
) )
} }
@@ -23,10 +23,11 @@ export async function getServerSideProps({
locales, locales,
}: GetStaticPropsContext) { }: GetStaticPropsContext) {
const config = { locale, locales } const config = { locale, locales }
const productsPromise = commerce.getAllProducts({
const productsPromise = commerce.getProduct({
// const productsPromise = commerce.getAllFacets({ // const productsPromise = commerce.getAllFacets({
variables: { variables: {
first: 70, slug: "hand-trowel"
// filter: { // filter: {
// name: { // name: {
// contains: 'ca' // contains: 'ca'
@@ -34,16 +35,15 @@ export async function getServerSideProps({
// } // }
}, },
config, config,
preview, // preview,
// Saleor provider only // Saleor provider only
...({ featured: true } as any), ...({ featured: true } as any),
}) })
const { products } = await productsPromise const { product } = await productsPromise
const productDetail = JSON.stringify(product)
return { return {
props: { products }, props: { productDetail },
} }
} }

View File

@@ -2,13 +2,19 @@ import React from 'react'
import ProductImgs from './components/ProductImgs/ProductImgs' import ProductImgs from './components/ProductImgs/ProductImgs'
import ProductInfo from './components/ProductInfo/ProductInfo' import ProductInfo from './components/ProductInfo/ProductInfo'
import s from './ProductInfoDetail.module.scss' import s from './ProductInfoDetail.module.scss'
import { GetStaticPropsContext, GetStaticPathsContext, InferGetStaticPropsType } from 'next'
import commerce from '@lib/api/commerce'
import { PromiseWithKey } from 'src/utils/types.utils'
import { getAllPromies } from 'src/utils/funtion.utils'
import { ProductCard } from '@commerce/types/product';
import { useRouter } from 'next/router'
interface Props { interface Props {
className?: string productDetail: ProductCard[],
children?: any
} }
const ProductInfoDetail = ({ }: Props) => { const ProductInfoDetail = ({ product }: InferGetStaticPropsType<typeof getStaticProps>) => {
console.log(product)
return ( return (
<section className={s.productInfoDetail}> <section className={s.productInfoDetail}>
<ProductImgs/> <ProductImgs/>
@@ -17,4 +23,61 @@ const ProductInfoDetail = ({ }: Props) => {
) )
} }
export async function getStaticProps({
params,
locale,
locales,
preview,
}: GetStaticPropsContext<{ slug: string }>) {
const config = { locale, locales }
const pagesPromise = commerce.getAllPages({ config, preview })
const siteInfoPromise = commerce.getSiteInfo({ config, preview })
const productPromise = commerce.getProduct({
variables: { slug: params!.slug },
config,
preview,
})
// const allProductsPromise = commerce.getAllProducts({
// variables: { first: 4 },
// config,
// preview,
// })
const { pages } = await pagesPromise
const { categories } = await siteInfoPromise
const { product } = await productPromise
// const { products: relatedProducts } = await allProductsPromise
if (!product) {
throw new Error(`Product with slug '${params!.slug}' not found`)
}
return {
props: {
pages,
product,
// relatedProducts,
categories,
},
revalidate: 200,
}
}
// export async function getStaticPaths({ locales }: GetStaticPathsContext) {
// const { products } = await commerce.getAllProductPaths()
// return {
// paths: locales
// ? locales.reduce<string[]>((arr, locale) => {
// // Add a product path for every locale
// products.forEach((product: any) => {
// arr.push(`/${locale}/product${product.path}`)
// })
// return arr
// }, [])
// : products.map((product: any) => `/product${product.path}`),
// fallback: 'blocking',
// }
// }
export default ProductInfoDetail export default ProductInfoDetail