mirror of
https://github.com/vercel/commerce.git
synced 2025-03-30 17:05:52 +00:00
* Adding multiple initial files * Updated the default cart endpoint * Fixes * Updated CommerceAPI class for better usage * Adding more migration changes * Taking multiple steps into better API types * Adding more experimental types * Removed many testing types * Adding types, fixes and other updates * Updated commerce types * Updated types for hooks now using the API * Updated mutation types * Simplified cart types for the provider * Updated cart hooks * Remove normalizers from the hooks * Updated cart endpoint * Removed cart handlers * bug fixes * Improve quantity input behavior in cart item * Removed endpoints folder * Making progress on api operations * Moved method * Moved types * Changed the way ops are created * Added customer endpoint * Login endpoint * Added logout endpoint * Add missing logout files * Added signup endpoint * Removed customers old endpoints * Moved endpoints to nested folder * Removed old customer endpoint builders * Updated login operation * Updated login operation * Added getAllPages operation * Renamed endpoint operations to handlers * Changed import * Renamed operations to handlers in usage * Moved getAllPages everywhere * Moved getPage * Updated getPage usage * Moved getSiteInfo * Added def types for product * Updated type * moved products catalog endpoint * removed old catalog endpoint * Moved wishlist * Removed commerce.endpoint * Replaced references to commerce.endpoint * Updated catalog products * Moved checkout api * Added the get customer wishlist operation * Removed old wishlist stuff * Added getAllProductPaths operation * updated reference to operation * Moved getAllProducts * Updated getProduct operation * Removed old getConfig and references * Removed is-allowed-method from BC * Updated types for auth hooks * Updated useCustomer and core types * Updated useData and util hooks * Updated useSearch hook * Updated types for useWishlist * Added index for types * Fixes * Updated urls to the API * Renamed fetchInput to fetcherInput * Updated fetch type * Fixes in search hook * Updated Shopify Provider Structure (#340) * Add codegen, update fragments & schemas * Update checkout-create.ts * Update checkout-create.ts * Update README.md * Update product mutations & queries * Uptate customer fetch types * Update schemas * Start updates * Moved Page, AllPages & Site Info * Moved product, all products (paths) * Add translations, update operations & fixes * Update api endpoints, types & fixes * Add api checkout endpoint * Updates * Fixes * Update commerce.config.json Co-authored-by: B <curciobelen@gmail.com> * Added category type and normalizer * updated init script to exclude other providers * Excluded swell and venture temporarily * Fix category & color normalization * Fixed category normalizer in shopify * Don't use getSlug for category on /search * Update colors.ts Co-authored-by: cond0r <pinte_catalin@yahoo.com> Co-authored-by: B <curciobelen@gmail.com>
197 lines
4.7 KiB
TypeScript
197 lines
4.7 KiB
TypeScript
import type { Page } from '../types/page'
|
|
import type { Product } from '../types/product'
|
|
import type { Cart, LineItem } from '../types/cart'
|
|
import type { Category } from '../types/site'
|
|
|
|
import {
|
|
Product as ShopifyProduct,
|
|
Checkout,
|
|
CheckoutLineItemEdge,
|
|
SelectedOption,
|
|
ImageConnection,
|
|
ProductVariantConnection,
|
|
MoneyV2,
|
|
ProductOption,
|
|
Page as ShopifyPage,
|
|
PageEdge,
|
|
Collection,
|
|
} from '../schema'
|
|
import { colorMap } from '@lib/colors'
|
|
|
|
const money = ({ amount, currencyCode }: MoneyV2) => {
|
|
return {
|
|
value: +amount,
|
|
currencyCode,
|
|
}
|
|
}
|
|
|
|
const normalizeProductOption = ({
|
|
id,
|
|
name: displayName,
|
|
values,
|
|
}: ProductOption) => {
|
|
return {
|
|
__typename: 'MultipleChoiceOption',
|
|
id,
|
|
displayName: displayName.toLowerCase(),
|
|
values: values.map((value) => {
|
|
let output: any = {
|
|
label: value,
|
|
}
|
|
if (displayName.match(/colou?r/gi)) {
|
|
const mapedColor = colorMap[value.toLowerCase().replace(/ /g, '')]
|
|
if (mapedColor) {
|
|
output = {
|
|
...output,
|
|
hexColors: [mapedColor],
|
|
}
|
|
}
|
|
}
|
|
return output
|
|
}),
|
|
}
|
|
}
|
|
|
|
const normalizeProductImages = ({ edges }: ImageConnection) =>
|
|
edges?.map(({ node: { originalSrc: url, ...rest } }) => ({
|
|
url,
|
|
...rest,
|
|
}))
|
|
|
|
const normalizeProductVariants = ({ edges }: ProductVariantConnection) => {
|
|
return edges?.map(
|
|
({
|
|
node: {
|
|
id,
|
|
selectedOptions,
|
|
sku,
|
|
title,
|
|
priceV2,
|
|
compareAtPriceV2,
|
|
requiresShipping,
|
|
availableForSale,
|
|
},
|
|
}) => {
|
|
return {
|
|
id,
|
|
name: title,
|
|
sku: sku ?? id,
|
|
price: +priceV2.amount,
|
|
listPrice: +compareAtPriceV2?.amount,
|
|
requiresShipping,
|
|
availableForSale,
|
|
options: selectedOptions.map(({ name, value }: SelectedOption) => {
|
|
const options = normalizeProductOption({
|
|
id,
|
|
name,
|
|
values: [value],
|
|
})
|
|
return options
|
|
}),
|
|
}
|
|
}
|
|
)
|
|
}
|
|
|
|
export function normalizeProduct({
|
|
id,
|
|
title: name,
|
|
vendor,
|
|
images,
|
|
variants,
|
|
description,
|
|
descriptionHtml,
|
|
handle,
|
|
priceRange,
|
|
options,
|
|
metafields,
|
|
...rest
|
|
}: ShopifyProduct): Product {
|
|
return {
|
|
id,
|
|
name,
|
|
vendor,
|
|
path: `/${handle}`,
|
|
slug: handle?.replace(/^\/+|\/+$/g, ''),
|
|
price: money(priceRange?.minVariantPrice),
|
|
images: normalizeProductImages(images),
|
|
variants: variants ? normalizeProductVariants(variants) : [],
|
|
options: options
|
|
? options
|
|
.filter((o) => o.name !== 'Title') // By default Shopify adds a 'Title' name when there's only one option. We don't need it. https://community.shopify.com/c/Shopify-APIs-SDKs/Adding-new-product-variant-is-automatically-adding-quot-Default/td-p/358095
|
|
.map((o) => normalizeProductOption(o))
|
|
: [],
|
|
...(description && { description }),
|
|
...(descriptionHtml && { descriptionHtml }),
|
|
...rest,
|
|
}
|
|
}
|
|
|
|
export function normalizeCart(checkout: Checkout): Cart {
|
|
return {
|
|
id: checkout.id,
|
|
url: checkout.webUrl,
|
|
customerId: '',
|
|
email: '',
|
|
createdAt: checkout.createdAt,
|
|
currency: {
|
|
code: checkout.totalPriceV2?.currencyCode,
|
|
},
|
|
taxesIncluded: checkout.taxesIncluded,
|
|
lineItems: checkout.lineItems?.edges.map(normalizeLineItem),
|
|
lineItemsSubtotalPrice: +checkout.subtotalPriceV2?.amount,
|
|
subtotalPrice: +checkout.subtotalPriceV2?.amount,
|
|
totalPrice: checkout.totalPriceV2?.amount,
|
|
discounts: [],
|
|
}
|
|
}
|
|
|
|
function normalizeLineItem({
|
|
node: { id, title, variant, quantity },
|
|
}: CheckoutLineItemEdge): LineItem {
|
|
return {
|
|
id,
|
|
variantId: String(variant?.id),
|
|
productId: String(variant?.id),
|
|
name: `${title}`,
|
|
quantity,
|
|
variant: {
|
|
id: String(variant?.id),
|
|
sku: variant?.sku ?? '',
|
|
name: variant?.title!,
|
|
image: {
|
|
url: variant?.image?.originalSrc || '/product-img-placeholder.svg',
|
|
},
|
|
requiresShipping: variant?.requiresShipping ?? false,
|
|
price: variant?.priceV2?.amount,
|
|
listPrice: variant?.compareAtPriceV2?.amount,
|
|
},
|
|
path: String(variant?.product?.handle),
|
|
discounts: [],
|
|
options: variant?.title == 'Default Title' ? [] : variant?.selectedOptions,
|
|
}
|
|
}
|
|
|
|
export const normalizePage = (
|
|
{ title: name, handle, ...page }: ShopifyPage,
|
|
locale: string
|
|
): Page => ({
|
|
...page,
|
|
url: `/${locale}/${handle}`,
|
|
name,
|
|
})
|
|
|
|
export const normalizePages = (edges: PageEdge[], locale: string): Page[] =>
|
|
edges?.map((edge) => normalizePage(edge.node, locale))
|
|
|
|
export const normalizeCategory = ({
|
|
title: name,
|
|
handle,
|
|
id,
|
|
}: Collection): Category => ({
|
|
id,
|
|
name,
|
|
slug: handle,
|
|
path: `/${handle}`,
|
|
})
|