mirror of
https://github.com/vercel/commerce.git
synced 2025-08-18 23:01:23 +00:00
.vscode
assets
components
config
framework
bigcommerce
commerce
local
saleor
shopify
swell
vendure
api
endpoints
operations
get-all-pages.ts
get-all-product-paths.ts
get-all-products.ts
get-customer-wishlist.ts
get-page.ts
get-product.ts
get-site-info.ts
login.ts
utils
index.ts
auth
cart
customer
product
types
utils
wishlist
.env.template
README.md
codegen.json
commerce.config.json
fetcher.ts
index.tsx
next.config.js
provider.ts
schema.d.ts
schema.graphql
lib
pages
public
.editorconfig
.env.template
.gitignore
.prettierignore
.prettierrc
README.md
codegen.bigcommerce.json
codegen.json
commerce.config.json
global.d.ts
license.md
next-env.d.ts
next.config.js
package.json
postcss.config.js
swell-js.d.ts
tailwind.config.js
tsconfig.json
yarn.lock
70 lines
2.1 KiB
TypeScript
70 lines
2.1 KiB
TypeScript
import { Product } from '@commerce/types/product'
|
|
import { OperationContext } from '@commerce/api/operations'
|
|
import { Provider, VendureConfig } from '../'
|
|
import { GetProductQuery } from '../../schema'
|
|
import { getProductQuery } from '../../utils/queries/get-product-query'
|
|
|
|
export default function getProductOperation({
|
|
commerce,
|
|
}: OperationContext<Provider>) {
|
|
async function getProduct({
|
|
query = getProductQuery,
|
|
variables,
|
|
config: cfg,
|
|
}: {
|
|
query?: string
|
|
variables: { slug: string }
|
|
config?: Partial<VendureConfig>
|
|
preview?: boolean
|
|
}): Promise<Product | {} | any> {
|
|
const config = commerce.getConfig(cfg)
|
|
|
|
const locale = config.locale
|
|
const { data } = await config.fetch<GetProductQuery>(query, { variables })
|
|
const product = data.product
|
|
|
|
if (product) {
|
|
const getOptionGroupName = (id: string): string => {
|
|
return product.optionGroups.find((og) => og.id === id)!.name
|
|
}
|
|
return {
|
|
product: {
|
|
id: product.id,
|
|
name: product.name,
|
|
description: product.description,
|
|
slug: product.slug,
|
|
images: product.assets.map((a) => ({
|
|
url: a.preview,
|
|
alt: a.name,
|
|
})),
|
|
variants: product.variants.map((v) => ({
|
|
id: v.id,
|
|
options: v.options.map((o) => ({
|
|
// This __typename property is required in order for the correct
|
|
// variant selection to work, see `components/product/helpers.ts`
|
|
// `getVariant()` function.
|
|
__typename: 'MultipleChoiceOption',
|
|
id: o.id,
|
|
displayName: getOptionGroupName(o.groupId),
|
|
values: [{ label: o.name }],
|
|
})),
|
|
})),
|
|
price: {
|
|
value: product.variants[0].priceWithTax / 100,
|
|
currencyCode: product.variants[0].currencyCode,
|
|
},
|
|
options: product.optionGroups.map((og) => ({
|
|
id: og.id,
|
|
displayName: og.name,
|
|
values: og.options.map((o) => ({ label: o.name })),
|
|
})),
|
|
} as Product,
|
|
}
|
|
}
|
|
|
|
return {}
|
|
}
|
|
|
|
return getProduct
|
|
}
|