From 959d38a4d4ffa76ebfe019674bb8c634d20d1a51 Mon Sep 17 00:00:00 2001 From: DuvCharles Date: Wed, 15 Nov 2023 08:54:19 +0100 Subject: [PATCH 1/4] :label: cart types --- lib/sylius/sylius-types/cart-types.ts | 35 +++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) create mode 100644 lib/sylius/sylius-types/cart-types.ts diff --git a/lib/sylius/sylius-types/cart-types.ts b/lib/sylius/sylius-types/cart-types.ts new file mode 100644 index 0000000000..c1b40a1230 --- /dev/null +++ b/lib/sylius/sylius-types/cart-types.ts @@ -0,0 +1,35 @@ +import { SyliusProduct, SyliusProductOptionValue, SyliusProductVariant } from './product-types'; + +export interface SyliusCart { + id: number; + tokenValue: string; + currencyCode: string; + taxTotal: number; + itemsTotal: number; + total: number; + taxExcludedTotal: number; + taxIncludedTotal: number; + shippingTotal: number; + orderPromotionTotal: number; + items: SyliusCartItem[]; +} + +export interface SyliusCartItem { + id: number; + productName: string; + quantity: number; + unitPrice: number; + discountedUnitPrice: number; + variant: SyliusProductVariant; + optionValues: SyliusProductOptionValue[]; + product: SyliusProduct; + adjustments: SyliusAdjustment[]; + total: number; +} + +export interface SyliusAdjustment { + id: number; + type: string; + label: string; + amount: number; +} From eed4aca792605871eb68735b5c791fcbd401b51d Mon Sep 17 00:00:00 2001 From: DuvCharles Date: Wed, 15 Nov 2023 08:54:39 +0100 Subject: [PATCH 2/4] sparkles: create cart normalizer --- lib/sylius/normalizer/cart-normalizer.ts | 50 +++++++++++++++++++++ lib/sylius/normalizer/product-normalizer.ts | 8 +--- lib/sylius/normalizer/utils-normalizer.ts | 6 +++ 3 files changed, 58 insertions(+), 6 deletions(-) create mode 100644 lib/sylius/normalizer/cart-normalizer.ts create mode 100644 lib/sylius/normalizer/utils-normalizer.ts diff --git a/lib/sylius/normalizer/cart-normalizer.ts b/lib/sylius/normalizer/cart-normalizer.ts new file mode 100644 index 0000000000..85209b8980 --- /dev/null +++ b/lib/sylius/normalizer/cart-normalizer.ts @@ -0,0 +1,50 @@ +import { SyliusCart, SyliusCartItem } from '../sylius-types/cart-types'; +import { SyliusProductOption, SyliusProductOptionValue } from '../sylius-types/product-types'; +import { Cart, CartItem } from '../types'; +import { normalizeProduct } from './product-normalizer'; +import { normalizePrice } from './utils-normalizer'; + +export const normalizeCart = (syliusCart: SyliusCart): Cart => { + return { + id: syliusCart.tokenValue, + checkoutUrl: '', + cost: { + subtotalAmount: normalizePrice(syliusCart.itemsTotal), + totalAmount: normalizePrice(syliusCart.total), + totalTaxAmount: normalizePrice(syliusCart.taxTotal) + }, + lines: syliusCart.items.map((item) => normalizeCartItem(item)), + totalQuantity: syliusCart.items.reduce((acc, item) => acc + item.quantity, 0) + }; +}; + +const normalizeCartItem = (syliusCartItem: SyliusCartItem): CartItem => { + return { + id: syliusCartItem.id.toString(), + quantity: syliusCartItem.quantity, + cost: { + totalAmount: normalizePrice(syliusCartItem.total) + }, + merchandise: { + id: syliusCartItem.variant.id.toString(), + title: syliusCartItem.variant.name, + selectedOptions: syliusCartItem.variant.optionValues.map((optionValue) => + normalizeOrderItemOptionValue(optionValue, syliusCartItem.product.options) + ), + product: normalizeProduct(syliusCartItem.product) + } + }; +}; + +const normalizeOrderItemOptionValue = ( + optionValue: SyliusProductOptionValue, + options: SyliusProductOption[] +): { name: string; value: string } => { + const rightOption = options.filter((option) => + option.values.some((value) => value.code === optionValue.code) + )[0]; + return { + name: rightOption?.name ?? '', + value: optionValue.value + }; +}; diff --git a/lib/sylius/normalizer/product-normalizer.ts b/lib/sylius/normalizer/product-normalizer.ts index e58e52bff5..f846fa2085 100644 --- a/lib/sylius/normalizer/product-normalizer.ts +++ b/lib/sylius/normalizer/product-normalizer.ts @@ -4,7 +4,8 @@ import { SyliusProductOption, SyliusProductVariant } from '../sylius-types/product-types'; -import { Image, Money, Product, ProductOption, ProductVariant } from '../types'; +import { Image, Product, ProductOption, ProductVariant } from '../types'; +import { normalizePrice } from './utils-normalizer'; export const normalizeProduct = (product: SyliusProduct): Product => ({ seo: { @@ -51,11 +52,6 @@ export const normalizeProductImage = (image: SyliusProductImage): Image => ({ height: 400 }); -const normalizePrice = (amount: number): Money => ({ - amount: (amount / 100).toString(), - currencyCode: 'EUR' -}); - const normalizePriceRange = (product: SyliusProduct) => { let minVariantPrice = 0; let maxVariantPrice = 0; diff --git a/lib/sylius/normalizer/utils-normalizer.ts b/lib/sylius/normalizer/utils-normalizer.ts new file mode 100644 index 0000000000..a9239e5a41 --- /dev/null +++ b/lib/sylius/normalizer/utils-normalizer.ts @@ -0,0 +1,6 @@ +import { Money } from '../types'; + +export const normalizePrice = (amount: number): Money => ({ + amount: (amount / 100).toString(), + currencyCode: 'EUR' +}); From 8d11cdf5322124952157a75680a7826ad6c03834 Mon Sep 17 00:00:00 2001 From: DuvCharles Date: Wed, 15 Nov 2023 08:54:55 +0100 Subject: [PATCH 3/4] :sparkles: create Cart method --- lib/sylius/index.ts | 21 +++++++++++++++------ 1 file changed, 15 insertions(+), 6 deletions(-) diff --git a/lib/sylius/index.ts b/lib/sylius/index.ts index 73c82b7ee1..3ac0dc8069 100644 --- a/lib/sylius/index.ts +++ b/lib/sylius/index.ts @@ -1,8 +1,15 @@ import { REST_METHODS, SYLIUS_API_ENDPOINT } from 'lib/constants'; +import { normalizeCart } from './normalizer/cart-normalizer'; import { normalizeCollection } from './normalizer/collection-normalizer'; import { normalizeProduct } from './normalizer/product-normalizer'; import { SyliusProduct, SyliusTaxon } from './sylius-types/product-types'; -import { AddToCartPayload, Collection, GetCollectionProductsPayload, GetProductsPayload } from './types'; +import { + AddToCartPayload, + Cart, + Collection, + GetCollectionProductsPayload, + GetProductsPayload +} from './types'; const DOMAIN = `${process.env.SYLIUS_STORE_DOMAIN}`; const ENDPOINT = `${DOMAIN}${SYLIUS_API_ENDPOINT}`; @@ -146,9 +153,11 @@ export const getCollectionProducts = async (payload: GetCollectionProductsPayloa }; // Cart -export const createCart = async () => { - const cart = await syliusRequest(REST_METHODS.POST, '/orders', { localeCode: 'fr_FR' }); - return cart; +export const createCart = async (): Promise => { + const data = await syliusRequest(REST_METHODS.POST, '/orders', { localeCode: 'fr_FR' }); + const syliusCart = data.body; + + return normalizeCart(syliusCart); }; export const getCart = (cartId: string) => { syliusRequest(REST_METHODS.GET, `/orders/${cartId}`); @@ -162,13 +171,13 @@ export const removeFromCart = () => {}; export const updateCart = () => {}; // Site -export const getMenu = async () => { +export const getMenu = async () => { const collections = await getCollections(); return [ { title: 'All', path: '/search' }, - ...collections.slice(0,2).map(({ title, path }) => ({ title, path })) + ...collections.slice(0, 2).map(({ title, path }) => ({ title, path })) ]; }; From 4ef3172c65c603fb773ce0f70641f174860ce171 Mon Sep 17 00:00:00 2001 From: DuvCharles Date: Fri, 17 Nov 2023 09:06:57 +0100 Subject: [PATCH 4/4] :art: naming and utils --- lib/sylius/normalizer/cart-normalizer.ts | 4 ++-- lib/sylius/normalizer/utils-normalizer.ts | 4 +++- 2 files changed, 5 insertions(+), 3 deletions(-) diff --git a/lib/sylius/normalizer/cart-normalizer.ts b/lib/sylius/normalizer/cart-normalizer.ts index 85209b8980..fa7568cd83 100644 --- a/lib/sylius/normalizer/cart-normalizer.ts +++ b/lib/sylius/normalizer/cart-normalizer.ts @@ -40,11 +40,11 @@ const normalizeOrderItemOptionValue = ( optionValue: SyliusProductOptionValue, options: SyliusProductOption[] ): { name: string; value: string } => { - const rightOption = options.filter((option) => + const selectedOption = options.filter((option) => option.values.some((value) => value.code === optionValue.code) )[0]; return { - name: rightOption?.name ?? '', + name: selectedOption?.name ?? '', value: optionValue.value }; }; diff --git a/lib/sylius/normalizer/utils-normalizer.ts b/lib/sylius/normalizer/utils-normalizer.ts index a9239e5a41..303d068ae0 100644 --- a/lib/sylius/normalizer/utils-normalizer.ts +++ b/lib/sylius/normalizer/utils-normalizer.ts @@ -1,6 +1,8 @@ import { Money } from '../types'; export const normalizePrice = (amount: number): Money => ({ - amount: (amount / 100).toString(), + amount: centsPriceToUnitsPrice(amount).toString(), currencyCode: 'EUR' }); + +export const centsPriceToUnitsPrice = (amount: number): number => amount / 100;