@libreapps/commerce 7.5.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.turbo/turbo-build.log +4 -0
- package/CHANGELOG.md +13 -0
- package/LICENSE.md +21 -0
- package/components/Icons.tsx +35 -0
- package/components/add-to-cart-widget.tsx +183 -0
- package/components/buy/buy-card.tsx +259 -0
- package/components/buy/carousel-buy-card.tsx +242 -0
- package/components/buy/multi-family/all-variants-carousel.tsx +261 -0
- package/components/buy/multi-family/family-carousel/index.tsx +77 -0
- package/components/buy/multi-family/family-carousel/slide.tsx +83 -0
- package/components/buy/multi-family/family-carousel/state.ts +87 -0
- package/components/buy/multi-family/index.ts +2 -0
- package/components/buy/single-family-selector.tsx +90 -0
- package/components/buy/title-and-byline.tsx +25 -0
- package/components/cart/cart-panel/cart-line-item.tsx +76 -0
- package/components/cart/cart-panel/index.tsx +154 -0
- package/components/cart/cart-panel/promo-code.tsx +109 -0
- package/components/cart/cart-panel/total-area.tsx +60 -0
- package/components/checkout/payment-step-form/card-icon-row.tsx +26 -0
- package/components/checkout/payment-step-form/card-icons/amex.tsx +32 -0
- package/components/checkout/payment-step-form/card-icons/diners-club.tsx +13 -0
- package/components/checkout/payment-step-form/card-icons/discover.tsx +25 -0
- package/components/checkout/payment-step-form/card-icons/jcb.tsx +26 -0
- package/components/checkout/payment-step-form/card-icons/mastercard.tsx +27 -0
- package/components/checkout/payment-step-form/card-icons/visa.tsx +25 -0
- package/components/checkout/payment-step-form/cc-button.tsx +17 -0
- package/components/checkout/payment-step-form/contact-form.tsx +50 -0
- package/components/checkout/payment-step-form/crypto-icons/btc.tsx +11 -0
- package/components/checkout/payment-step-form/crypto-icons/eth.tsx +20 -0
- package/components/checkout/payment-step-form/crypto-icons/usdt.tsx +13 -0
- package/components/checkout/payment-step-form/index.tsx +122 -0
- package/components/checkout/payment-step-form/methods/bank-transfer.tsx +79 -0
- package/components/checkout/payment-step-form/methods/card.tsx +232 -0
- package/components/checkout/payment-step-form/methods/crypto.tsx +227 -0
- package/components/checkout/payment-step-form/methods/index.ts +23 -0
- package/components/checkout/shipping-step-form.tsx +175 -0
- package/components/index.ts +11 -0
- package/components/item/product-card.tsx +48 -0
- package/components/item-selector/button.tsx +188 -0
- package/components/item-selector/carousel/index.tsx +197 -0
- package/components/item-selector/carousel/slider.tsx +40 -0
- package/components/item-selector/index.ts +5 -0
- package/components/item-selector/quantity-indicator.tsx +48 -0
- package/components/node-tabs/index.tsx +91 -0
- package/components/node-tabs/node-image.tsx +31 -0
- package/dist/components/Icons.d.ts +18 -0
- package/dist/components/Icons.js +19 -0
- package/dist/components/Icons.js.map +1 -0
- package/dist/components/add-to-cart-widget.d.ts +11 -0
- package/dist/components/add-to-cart-widget.js +85 -0
- package/dist/components/add-to-cart-widget.js.map +1 -0
- package/dist/components/buy/buy-card.d.ts +30 -0
- package/dist/components/buy/buy-card.js +109 -0
- package/dist/components/buy/buy-card.js.map +1 -0
- package/dist/components/buy/carousel-buy-card.d.ts +12 -0
- package/dist/components/buy/carousel-buy-card.js +94 -0
- package/dist/components/buy/carousel-buy-card.js.map +1 -0
- package/dist/components/buy/multi-family/all-variants-carousel.d.ts +4 -0
- package/dist/components/buy/multi-family/all-variants-carousel.js +115 -0
- package/dist/components/buy/multi-family/all-variants-carousel.js.map +1 -0
- package/dist/components/buy/multi-family/family-carousel/index.d.ts +4 -0
- package/dist/components/buy/multi-family/family-carousel/index.js +27 -0
- package/dist/components/buy/multi-family/family-carousel/index.js.map +1 -0
- package/dist/components/buy/multi-family/family-carousel/slide.d.ts +11 -0
- package/dist/components/buy/multi-family/family-carousel/slide.js +35 -0
- package/dist/components/buy/multi-family/family-carousel/slide.js.map +1 -0
- package/dist/components/buy/multi-family/family-carousel/state.d.ts +20 -0
- package/dist/components/buy/multi-family/family-carousel/state.js +59 -0
- package/dist/components/buy/multi-family/family-carousel/state.js.map +1 -0
- package/dist/components/buy/multi-family/index.d.ts +2 -0
- package/dist/components/buy/multi-family/index.js +3 -0
- package/dist/components/buy/multi-family/index.js.map +1 -0
- package/dist/components/buy/single-family-selector.d.ts +15 -0
- package/dist/components/buy/single-family-selector.js +28 -0
- package/dist/components/buy/single-family-selector.js.map +1 -0
- package/dist/components/buy/title-and-byline.d.ts +8 -0
- package/dist/components/buy/title-and-byline.js +7 -0
- package/dist/components/buy/title-and-byline.js.map +1 -0
- package/dist/components/cart/cart-panel/cart-line-item.d.ts +11 -0
- package/dist/components/cart/cart-panel/cart-line-item.js +25 -0
- package/dist/components/cart/cart-panel/cart-line-item.js.map +1 -0
- package/dist/components/cart/cart-panel/index.d.ts +19 -0
- package/dist/components/cart/cart-panel/index.js +65 -0
- package/dist/components/cart/cart-panel/index.js.map +1 -0
- package/dist/components/cart/cart-panel/promo-code.d.ts +4 -0
- package/dist/components/cart/cart-panel/promo-code.js +62 -0
- package/dist/components/cart/cart-panel/promo-code.js.map +1 -0
- package/dist/components/cart/cart-panel/total-area.d.ts +7 -0
- package/dist/components/cart/cart-panel/total-area.js +14 -0
- package/dist/components/cart/cart-panel/total-area.js.map +1 -0
- package/dist/components/checkout/payment-step-form/card-icon-row.d.ts +2 -0
- package/dist/components/checkout/payment-step-form/card-icon-row.js +14 -0
- package/dist/components/checkout/payment-step-form/card-icon-row.js.map +1 -0
- package/dist/components/checkout/payment-step-form/card-icons/amex.d.ts +4 -0
- package/dist/components/checkout/payment-step-form/card-icons/amex.js +6 -0
- package/dist/components/checkout/payment-step-form/card-icons/amex.js.map +1 -0
- package/dist/components/checkout/payment-step-form/card-icons/diners-club.d.ts +4 -0
- package/dist/components/checkout/payment-step-form/card-icons/diners-club.js +6 -0
- package/dist/components/checkout/payment-step-form/card-icons/diners-club.js.map +1 -0
- package/dist/components/checkout/payment-step-form/card-icons/discover.d.ts +4 -0
- package/dist/components/checkout/payment-step-form/card-icons/discover.js +6 -0
- package/dist/components/checkout/payment-step-form/card-icons/discover.js.map +1 -0
- package/dist/components/checkout/payment-step-form/card-icons/jcb.d.ts +4 -0
- package/dist/components/checkout/payment-step-form/card-icons/jcb.js +6 -0
- package/dist/components/checkout/payment-step-form/card-icons/jcb.js.map +1 -0
- package/dist/components/checkout/payment-step-form/card-icons/mastercard.d.ts +4 -0
- package/dist/components/checkout/payment-step-form/card-icons/mastercard.js +6 -0
- package/dist/components/checkout/payment-step-form/card-icons/mastercard.js.map +1 -0
- package/dist/components/checkout/payment-step-form/card-icons/visa.d.ts +4 -0
- package/dist/components/checkout/payment-step-form/card-icons/visa.js +6 -0
- package/dist/components/checkout/payment-step-form/card-icons/visa.js.map +1 -0
- package/dist/components/checkout/payment-step-form/cc-button.d.ts +3 -0
- package/dist/components/checkout/payment-step-form/cc-button.js +6 -0
- package/dist/components/checkout/payment-step-form/cc-button.js.map +1 -0
- package/dist/components/checkout/payment-step-form/contact-form.d.ts +5 -0
- package/dist/components/checkout/payment-step-form/contact-form.js +6 -0
- package/dist/components/checkout/payment-step-form/contact-form.js.map +1 -0
- package/dist/components/checkout/payment-step-form/crypto-icons/btc.d.ts +4 -0
- package/dist/components/checkout/payment-step-form/crypto-icons/btc.js +6 -0
- package/dist/components/checkout/payment-step-form/crypto-icons/btc.js.map +1 -0
- package/dist/components/checkout/payment-step-form/crypto-icons/eth.d.ts +4 -0
- package/dist/components/checkout/payment-step-form/crypto-icons/eth.js +6 -0
- package/dist/components/checkout/payment-step-form/crypto-icons/eth.js.map +1 -0
- package/dist/components/checkout/payment-step-form/crypto-icons/usdt.d.ts +4 -0
- package/dist/components/checkout/payment-step-form/crypto-icons/usdt.js +6 -0
- package/dist/components/checkout/payment-step-form/crypto-icons/usdt.js.map +1 -0
- package/dist/components/checkout/payment-step-form/index.d.ts +4 -0
- package/dist/components/checkout/payment-step-form/index.js +77 -0
- package/dist/components/checkout/payment-step-form/index.js.map +1 -0
- package/dist/components/checkout/payment-step-form/methods/bank-transfer.d.ts +4 -0
- package/dist/components/checkout/payment-step-form/methods/bank-transfer.js +24 -0
- package/dist/components/checkout/payment-step-form/methods/bank-transfer.js.map +1 -0
- package/dist/components/checkout/payment-step-form/methods/card.d.ts +4 -0
- package/dist/components/checkout/payment-step-form/methods/card.js +160 -0
- package/dist/components/checkout/payment-step-form/methods/card.js.map +1 -0
- package/dist/components/checkout/payment-step-form/methods/crypto.d.ts +9 -0
- package/dist/components/checkout/payment-step-form/methods/crypto.js +137 -0
- package/dist/components/checkout/payment-step-form/methods/crypto.js.map +1 -0
- package/dist/components/checkout/payment-step-form/methods/index.d.ts +6 -0
- package/dist/components/checkout/payment-step-form/methods/index.js +21 -0
- package/dist/components/checkout/payment-step-form/methods/index.js.map +1 -0
- package/dist/components/checkout/shipping-step-form.d.ts +3 -0
- package/dist/components/checkout/shipping-step-form.js +53 -0
- package/dist/components/checkout/shipping-step-form.js.map +1 -0
- package/dist/components/index.d.ts +8 -0
- package/dist/components/index.js +9 -0
- package/dist/components/index.js.map +1 -0
- package/dist/components/item/product-card.d.ts +7 -0
- package/dist/components/item/product-card.js +9 -0
- package/dist/components/item/product-card.js.map +1 -0
- package/dist/components/item-selector/button.d.ts +4 -0
- package/dist/components/item-selector/button.js +47 -0
- package/dist/components/item-selector/button.js.map +1 -0
- package/dist/components/item-selector/carousel/index.d.ts +12 -0
- package/dist/components/item-selector/carousel/index.js +74 -0
- package/dist/components/item-selector/carousel/index.js.map +1 -0
- package/dist/components/item-selector/carousel/slider.d.ts +8 -0
- package/dist/components/item-selector/carousel/slider.js +12 -0
- package/dist/components/item-selector/carousel/slider.js.map +1 -0
- package/dist/components/item-selector/index.d.ts +2 -0
- package/dist/components/item-selector/index.js +3 -0
- package/dist/components/item-selector/index.js.map +1 -0
- package/dist/components/item-selector/quantity-indicator.d.ts +9 -0
- package/dist/components/item-selector/quantity-indicator.js +16 -0
- package/dist/components/item-selector/quantity-indicator.js.map +1 -0
- package/dist/components/node-tabs/index.d.ts +14 -0
- package/dist/components/node-tabs/index.js +42 -0
- package/dist/components/node-tabs/index.js.map +1 -0
- package/dist/components/node-tabs/node-image.d.ts +6 -0
- package/dist/components/node-tabs/node-image.js +13 -0
- package/dist/components/node-tabs/node-image.js.map +1 -0
- package/dist/index.d.ts +5 -0
- package/dist/index.js +5 -0
- package/dist/index.js.map +1 -0
- package/dist/service/context.d.ts +8 -0
- package/dist/service/context.js +19 -0
- package/dist/service/context.js.map +1 -0
- package/dist/service/debug.d.ts +10 -0
- package/dist/service/debug.js +30 -0
- package/dist/service/debug.js.map +1 -0
- package/dist/service/impls/standalone/actual-line-item.d.ts +40 -0
- package/dist/service/impls/standalone/actual-line-item.js +84 -0
- package/dist/service/impls/standalone/actual-line-item.js.map +1 -0
- package/dist/service/impls/standalone/get-instance.d.ts +2 -0
- package/dist/service/impls/standalone/get-instance.js +39 -0
- package/dist/service/impls/standalone/get-instance.js.map +1 -0
- package/dist/service/impls/standalone/index.d.ts +67 -0
- package/dist/service/impls/standalone/index.js +416 -0
- package/dist/service/impls/standalone/index.js.map +1 -0
- package/dist/service/impls/standalone/order/firebase.d.ts +2 -0
- package/dist/service/impls/standalone/order/firebase.js +13 -0
- package/dist/service/impls/standalone/order/firebase.js.map +1 -0
- package/dist/service/impls/standalone/order/index.d.ts +24 -0
- package/dist/service/impls/standalone/order/index.js +61 -0
- package/dist/service/impls/standalone/order/index.js.map +1 -0
- package/dist/service/impls/standalone/persistence.d.ts +4 -0
- package/dist/service/impls/standalone/persistence.js +22 -0
- package/dist/service/impls/standalone/persistence.js.map +1 -0
- package/dist/service/path-utils.d.ts +7 -0
- package/dist/service/path-utils.js +16 -0
- package/dist/service/path-utils.js.map +1 -0
- package/dist/service/sep.d.ts +6 -0
- package/dist/service/sep.js +6 -0
- package/dist/service/sep.js.map +1 -0
- package/dist/types/category-node.d.ts +36 -0
- package/dist/types/category-node.js +2 -0
- package/dist/types/category-node.js.map +1 -0
- package/dist/types/checkout.d.ts +33 -0
- package/dist/types/checkout.js +2 -0
- package/dist/types/checkout.js.map +1 -0
- package/dist/types/commerce-config.d.ts +11 -0
- package/dist/types/commerce-config.js +2 -0
- package/dist/types/commerce-config.js.map +1 -0
- package/dist/types/commerce-service.d.ts +109 -0
- package/dist/types/commerce-service.js +2 -0
- package/dist/types/commerce-service.js.map +1 -0
- package/dist/types/family.d.ts +16 -0
- package/dist/types/family.js +2 -0
- package/dist/types/family.js.map +1 -0
- package/dist/types/index.d.ts +13 -0
- package/dist/types/index.js +8 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/item-selector.d.ts +72 -0
- package/dist/types/item-selector.js +2 -0
- package/dist/types/item-selector.js.map +1 -0
- package/dist/types/line-item.d.ts +14 -0
- package/dist/types/line-item.js +2 -0
- package/dist/types/line-item.js.map +1 -0
- package/dist/types/multi-family-selector-props.d.ts +16 -0
- package/dist/types/multi-family-selector-props.js +2 -0
- package/dist/types/multi-family-selector-props.js.map +1 -0
- package/dist/types/product.d.ts +15 -0
- package/dist/types/product.js +2 -0
- package/dist/types/product.js.map +1 -0
- package/dist/types/promo.d.ts +7 -0
- package/dist/types/promo.js +2 -0
- package/dist/types/promo.js.map +1 -0
- package/dist/types/selection-ui-specifier.d.ts +40 -0
- package/dist/types/selection-ui-specifier.js +2 -0
- package/dist/types/selection-ui-specifier.js.map +1 -0
- package/dist/types/string-mutator.d.ts +9 -0
- package/dist/types/string-mutator.js +2 -0
- package/dist/types/string-mutator.js.map +1 -0
- package/dist/types/token-separators.d.ts +6 -0
- package/dist/types/token-separators.js +2 -0
- package/dist/types/token-separators.js.map +1 -0
- package/dist/util/analytics.d.ts +9 -0
- package/dist/util/analytics.js +10 -0
- package/dist/util/analytics.js.map +1 -0
- package/dist/util/countries.d.ts +7 -0
- package/dist/util/countries.js +197 -0
- package/dist/util/countries.js.map +1 -0
- package/dist/util/error.d.ts +1 -0
- package/dist/util/error.js +22 -0
- package/dist/util/error.js.map +1 -0
- package/dist/util/index.d.ts +15 -0
- package/dist/util/index.js +54 -0
- package/dist/util/index.js.map +1 -0
- package/dist/util/item-selector-options-accessor.d.ts +3 -0
- package/dist/util/item-selector-options-accessor.js +27 -0
- package/dist/util/item-selector-options-accessor.js.map +1 -0
- package/dist/util/line-item-ref.d.ts +8 -0
- package/dist/util/line-item-ref.js +15 -0
- package/dist/util/line-item-ref.js.map +1 -0
- package/dist/util/multi-family-selector-options-accessor.d.ts +3 -0
- package/dist/util/multi-family-selector-options-accessor.js +11 -0
- package/dist/util/multi-family-selector-options-accessor.js.map +1 -0
- package/dist/util/obs-string-mutator.d.ts +8 -0
- package/dist/util/obs-string-mutator.js +15 -0
- package/dist/util/obs-string-mutator.js.map +1 -0
- package/dist/util/product-media-accessor.d.ts +29 -0
- package/dist/util/product-media-accessor.js +22 -0
- package/dist/util/product-media-accessor.js.map +1 -0
- package/dist/util/promo-codes.d.ts +3 -0
- package/dist/util/promo-codes.js +100 -0
- package/dist/util/promo-codes.js.map +1 -0
- package/dist/util/selection-ui-specifiers.d.ts +3 -0
- package/dist/util/selection-ui-specifiers.js +24 -0
- package/dist/util/selection-ui-specifiers.js.map +1 -0
- package/dist/util/square-payment.d.ts +7 -0
- package/dist/util/square-payment.js +37 -0
- package/dist/util/square-payment.js.map +1 -0
- package/dist/util/use-sync-sku-param-w-current-item.d.ts +2 -0
- package/dist/util/use-sync-sku-param-w-current-item.js +61 -0
- package/dist/util/use-sync-sku-param-w-current-item.js.map +1 -0
- package/index.ts +13 -0
- package/libreapps-ui.d.ts +108 -0
- package/package.json +67 -0
- package/service/context.tsx +45 -0
- package/service/debug.ts +41 -0
- package/service/impls/standalone/actual-line-item.ts +136 -0
- package/service/impls/standalone/get-instance.ts +64 -0
- package/service/impls/standalone/index.ts +579 -0
- package/service/impls/standalone/order/firebase.ts +14 -0
- package/service/impls/standalone/order/index.ts +129 -0
- package/service/impls/standalone/persistence.ts +33 -0
- package/service/path-utils.ts +26 -0
- package/service/sep.ts +7 -0
- package/tsconfig.json +17 -0
- package/types/README.md +2 -0
- package/types/category-node.ts +50 -0
- package/types/checkout.ts +47 -0
- package/types/commerce-config.ts +13 -0
- package/types/commerce-service.ts +128 -0
- package/types/family.ts +26 -0
- package/types/index.ts +15 -0
- package/types/item-selector.ts +97 -0
- package/types/line-item.ts +29 -0
- package/types/multi-family-selector-props.ts +20 -0
- package/types/product.ts +21 -0
- package/types/promo.ts +10 -0
- package/types/selection-ui-specifier.ts +52 -0
- package/types/string-mutator.ts +14 -0
- package/types/token-separators.ts +7 -0
- package/util/analytics.ts +21 -0
- package/util/countries.ts +196 -0
- package/util/error.ts +34 -0
- package/util/index.ts +71 -0
- package/util/item-selector-options-accessor.ts +35 -0
- package/util/line-item-ref.ts +23 -0
- package/util/multi-family-selector-options-accessor.ts +15 -0
- package/util/obs-string-mutator.ts +22 -0
- package/util/product-media-accessor.ts +58 -0
- package/util/promo-codes.ts +106 -0
- package/util/selection-ui-specifiers.ts +30 -0
- package/util/square-payment.ts +50 -0
- package/util/use-sync-sku-param-w-current-item.ts +88 -0
|
@@ -0,0 +1,197 @@
|
|
|
1
|
+
'use client'
|
|
2
|
+
import React, { useCallback, useEffect, useRef, useState } from 'react'
|
|
3
|
+
import { reaction } from 'mobx'
|
|
4
|
+
import { observer } from 'mobx-react-lite'
|
|
5
|
+
|
|
6
|
+
import { cn } from '@libreapps/ui/util'
|
|
7
|
+
import type { Dimensions } from '@libreapps/ui/types'
|
|
8
|
+
|
|
9
|
+
import {
|
|
10
|
+
ApplyTypography,
|
|
11
|
+
type CarouselOptions,
|
|
12
|
+
type CarouselApi,
|
|
13
|
+
Carousel,
|
|
14
|
+
CarouselContent,
|
|
15
|
+
CarouselItem,
|
|
16
|
+
CarouselPrevious,
|
|
17
|
+
CarouselNext,
|
|
18
|
+
MediaStack,
|
|
19
|
+
} from '@libreapps/ui/primitives'
|
|
20
|
+
|
|
21
|
+
import type { ItemSelectorProps, LineItem } from '../../../types'
|
|
22
|
+
import { formatCurrencyValue, accessItemOptions } from '../../../util'
|
|
23
|
+
|
|
24
|
+
import QuantityIndicator from '../quantity-indicator'
|
|
25
|
+
import ItemCarouselSlider from './slider'
|
|
26
|
+
|
|
27
|
+
const DEFAULT_CONSTRAINT = {w: 250, h: 250}
|
|
28
|
+
|
|
29
|
+
interface CarouselItemSelectorPropsExt {
|
|
30
|
+
constrainTo: Dimensions
|
|
31
|
+
options?: CarouselOptions
|
|
32
|
+
/** Do not show Family and / or Item title and Price */
|
|
33
|
+
imageOnly?: boolean
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
const ItemSlide: React.FC<{
|
|
37
|
+
item: LineItem,
|
|
38
|
+
constrainTo: Dimensions
|
|
39
|
+
clx?: string
|
|
40
|
+
}> = ({
|
|
41
|
+
item,
|
|
42
|
+
constrainTo,
|
|
43
|
+
clx=''
|
|
44
|
+
}) => (
|
|
45
|
+
<CarouselItem className={cn('p-2 flex flex-col justify-center items-center', clx)}>
|
|
46
|
+
<MediaStack media={item} constrainTo={constrainTo} clx='my-4' />
|
|
47
|
+
</CarouselItem>
|
|
48
|
+
)
|
|
49
|
+
|
|
50
|
+
const CarouselItemSelector: React.FC<ItemSelectorProps> = observer(({
|
|
51
|
+
items,
|
|
52
|
+
selectSku,
|
|
53
|
+
selectedItemRef: itemRef,
|
|
54
|
+
clx='',
|
|
55
|
+
itemClx='',
|
|
56
|
+
options={},
|
|
57
|
+
ext={
|
|
58
|
+
options: {loop: true},
|
|
59
|
+
constrainTo: DEFAULT_CONSTRAINT,
|
|
60
|
+
imageOnly: false
|
|
61
|
+
} satisfies CarouselItemSelectorPropsExt
|
|
62
|
+
}) => {
|
|
63
|
+
|
|
64
|
+
const {
|
|
65
|
+
showPrice,
|
|
66
|
+
showQuantity,
|
|
67
|
+
showFamilyInOption,
|
|
68
|
+
showByline,
|
|
69
|
+
showSlider,
|
|
70
|
+
} = accessItemOptions(options)
|
|
71
|
+
|
|
72
|
+
const elbaApiRef = useRef<CarouselApi | undefined>(undefined)
|
|
73
|
+
const scrollToRef = useRef<((index: number) => void) | undefined>(undefined)
|
|
74
|
+
const dontRespondRef = useRef<boolean>(false)
|
|
75
|
+
|
|
76
|
+
const setApi = (api: CarouselApi) => {elbaApiRef.current = api}
|
|
77
|
+
const setScrollTo = (scrollTo: (index: number) => void) => { scrollToRef.current = scrollTo}
|
|
78
|
+
|
|
79
|
+
const carouselOptions = 'options' in ext ? ext.options : undefined
|
|
80
|
+
const constrainTo = 'constrainTo' in ext ? ext.constrainTo : DEFAULT_CONSTRAINT
|
|
81
|
+
const imageOnly = 'imageOnly' in ext ? ext.imageOnly : false
|
|
82
|
+
|
|
83
|
+
const onSelect = useCallback((emblaApi: CarouselApi) => {
|
|
84
|
+
if (dontRespondRef.current) {
|
|
85
|
+
dontRespondRef.current = false
|
|
86
|
+
return
|
|
87
|
+
}
|
|
88
|
+
const index = emblaApi.selectedScrollSnap()
|
|
89
|
+
if (index !== -1) {
|
|
90
|
+
selectSku(items[index].sku)
|
|
91
|
+
if (scrollToRef.current) {
|
|
92
|
+
scrollToRef.current(index)
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
dontRespondRef.current = false
|
|
96
|
+
}, [scrollToRef.current ])
|
|
97
|
+
|
|
98
|
+
useEffect(() => {
|
|
99
|
+
return reaction(
|
|
100
|
+
() => (itemRef.item),
|
|
101
|
+
(item) => {
|
|
102
|
+
if (elbaApiRef.current) {
|
|
103
|
+
const index = items.findIndex((el) => (el.sku === item?.sku))
|
|
104
|
+
if (index !== -1) {
|
|
105
|
+
dontRespondRef.current = true
|
|
106
|
+
elbaApiRef.current.scrollTo(index)
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
)
|
|
111
|
+
}, [])
|
|
112
|
+
|
|
113
|
+
const optionLabel = () => (
|
|
114
|
+
showFamilyInOption ?
|
|
115
|
+
(itemRef.item?.familyTitle + ', ' + itemRef.item?.optionLabel)
|
|
116
|
+
:
|
|
117
|
+
itemRef.item?.optionLabel
|
|
118
|
+
)
|
|
119
|
+
|
|
120
|
+
const debugBorder = (c: 'r' | 'g' | 'b'): string => {
|
|
121
|
+
return ''
|
|
122
|
+
|
|
123
|
+
switch (c) {
|
|
124
|
+
case 'r': return ' border border-[#ffaaaa] '
|
|
125
|
+
case 'g': return ' border border-[#aaffaa] '
|
|
126
|
+
case 'b': return ' border border-[#aaaaff] '
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
const onScrollIndexChange = (index: number) => {
|
|
131
|
+
dontRespondRef.current = true
|
|
132
|
+
selectSku(items![index].sku)
|
|
133
|
+
elbaApiRef.current?.scrollTo(index)
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
return (
|
|
137
|
+
<div className={cn('w-full flex flex-col items-center', clx)}>
|
|
138
|
+
<Carousel
|
|
139
|
+
options={showSlider ? {...carouselOptions, loop: false} : carouselOptions }
|
|
140
|
+
className={'w-full px-2' + debugBorder('r')}
|
|
141
|
+
onCarouselSelect={onSelect}
|
|
142
|
+
setApi={setApi}
|
|
143
|
+
>
|
|
144
|
+
<CarouselContent>
|
|
145
|
+
{items.map((item) => (
|
|
146
|
+
<ItemSlide key={item.sku} item={item} constrainTo={constrainTo} clx={itemClx} />
|
|
147
|
+
))}
|
|
148
|
+
</CarouselContent>
|
|
149
|
+
{!showSlider && (<>
|
|
150
|
+
<CarouselPrevious className='left-1'/>
|
|
151
|
+
<CarouselNext className='right-1'/>
|
|
152
|
+
</>)}
|
|
153
|
+
</Carousel>
|
|
154
|
+
|
|
155
|
+
{(!imageOnly && itemRef.item) && (<>
|
|
156
|
+
<ApplyTypography className='flex flex-col items-center [&>*]:!m-0 !gap-1 '>
|
|
157
|
+
<div className={
|
|
158
|
+
'flex items-center gap-1 [&>*]:!m-0 ' + debugBorder('g') +
|
|
159
|
+
(showFamilyInOption ? 'flex-col' : 'flex-row')
|
|
160
|
+
}>
|
|
161
|
+
<h6 className='font-semibold'>
|
|
162
|
+
{optionLabel() + (showPrice && !showFamilyInOption ? ',' : '')}
|
|
163
|
+
</h6>
|
|
164
|
+
<div className={
|
|
165
|
+
'flex items-center gap-1 [&>*]:!m-0 flex-row ' + debugBorder('b') +
|
|
166
|
+
(showFamilyInOption ? 'w-full justify-between' : '')
|
|
167
|
+
}>
|
|
168
|
+
{showPrice && (<p>{formatCurrencyValue(itemRef.item.price)}</p>)}
|
|
169
|
+
{showQuantity && (
|
|
170
|
+
<QuantityIndicator
|
|
171
|
+
item={itemRef.item}
|
|
172
|
+
clx='h-[22px] ml-4'
|
|
173
|
+
iconClx='fill-foreground'
|
|
174
|
+
digitClx='not-typography font-semibold text-primary-fg leading-none font-sans text-xs'
|
|
175
|
+
/>
|
|
176
|
+
)}
|
|
177
|
+
</div>
|
|
178
|
+
</div>
|
|
179
|
+
{showByline && itemRef.item.byline && (<p>{itemRef.item.byline}</p>)}
|
|
180
|
+
</ApplyTypography>
|
|
181
|
+
{showSlider && items.length > 1 && (
|
|
182
|
+
<ItemCarouselSlider
|
|
183
|
+
clx='mt-5 w-[320px]'
|
|
184
|
+
numStops={items.length}
|
|
185
|
+
setScrollTo={setScrollTo}
|
|
186
|
+
onIndexChange={onScrollIndexChange}
|
|
187
|
+
/>
|
|
188
|
+
)}
|
|
189
|
+
</>)}
|
|
190
|
+
</div>
|
|
191
|
+
)
|
|
192
|
+
})
|
|
193
|
+
|
|
194
|
+
export {
|
|
195
|
+
type CarouselItemSelectorPropsExt,
|
|
196
|
+
CarouselItemSelector as default
|
|
197
|
+
}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
'use client'
|
|
2
|
+
import React, { useEffect, useState } from 'react'
|
|
3
|
+
|
|
4
|
+
import { Slider } from '@libreapps/ui/primitives'
|
|
5
|
+
|
|
6
|
+
const ItemCarouselSlider: React.FC<{
|
|
7
|
+
clx?: string
|
|
8
|
+
setScrollTo: (scrollTo: (index: number) => void) => void
|
|
9
|
+
onIndexChange: (i: number) => void
|
|
10
|
+
numStops: number
|
|
11
|
+
}> = ({
|
|
12
|
+
clx='',
|
|
13
|
+
setScrollTo,
|
|
14
|
+
onIndexChange,
|
|
15
|
+
numStops,
|
|
16
|
+
}) => {
|
|
17
|
+
|
|
18
|
+
const [index, setIndex] = useState<number>(0)
|
|
19
|
+
useEffect(() => { setScrollTo(setIndex) }, [setScrollTo])
|
|
20
|
+
|
|
21
|
+
const onValueChange = (v: number[]) => { setIndex(v[0]); onIndexChange(v[0]) }
|
|
22
|
+
|
|
23
|
+
return (
|
|
24
|
+
<Slider
|
|
25
|
+
className={clx}
|
|
26
|
+
thumbClx='w-8 border-muted border-2 bg-level-1 focus-visible:ring-0 focus-visible:ring-offset-0 transition-none'
|
|
27
|
+
trackBgClx='bg-level-3'
|
|
28
|
+
rangeBgClx='bg-level-3'
|
|
29
|
+
thumbSlidingClx='bg-muted-2'
|
|
30
|
+
defaultValue={[0]}
|
|
31
|
+
min={0}
|
|
32
|
+
max={numStops - 1}
|
|
33
|
+
step={1}
|
|
34
|
+
value={[index]}
|
|
35
|
+
onValueChange={onValueChange}
|
|
36
|
+
/>
|
|
37
|
+
)
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
export default ItemCarouselSlider
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
'use client'
|
|
2
|
+
import React from 'react'
|
|
3
|
+
import { observer } from 'mobx-react-lite'
|
|
4
|
+
|
|
5
|
+
import { type LucideProps } from 'lucide-react'
|
|
6
|
+
|
|
7
|
+
import { cn } from '@libreapps/ui/util'
|
|
8
|
+
import type { LineItem } from '../../types'
|
|
9
|
+
|
|
10
|
+
// Generalize this.
|
|
11
|
+
const BagIcon: React.FC<LucideProps> = (props: LucideProps) => (
|
|
12
|
+
<svg fill="currentColor" viewBox='0 0 20 23' {...props}>
|
|
13
|
+
<path fillRule="evenodd" d="M5 5a5 5 0 0 1 10 0v1h-2V5a3 3 0 1 0-6 0v1H5V5Zm0 1v4h2V6h6v4h2V6h3.5a1 1 0 0 1 1 1v15a1 1 0 0 1-1 1h-17a1 1 0 0 1-1-1V7a1 1 0 0 1 1-1H5Z" clipRule="evenodd"/>
|
|
14
|
+
</svg>
|
|
15
|
+
)
|
|
16
|
+
|
|
17
|
+
const QuantityIndicator: React.FC<{
|
|
18
|
+
item: LineItem
|
|
19
|
+
clx?: string
|
|
20
|
+
iconClx?: string
|
|
21
|
+
digitClx?: string
|
|
22
|
+
}> = observer(({
|
|
23
|
+
item,
|
|
24
|
+
clx='',
|
|
25
|
+
iconClx='',
|
|
26
|
+
digitClx=''
|
|
27
|
+
}) => {
|
|
28
|
+
|
|
29
|
+
if (!item.isInCart) {
|
|
30
|
+
return <div />
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
return (
|
|
34
|
+
<div className={cn('relative aspect-square flex items-center justify-center', clx)} >
|
|
35
|
+
<div className={cn(
|
|
36
|
+
'z-above-content flex flex-col justify-center items-center',
|
|
37
|
+
'absolute left-0 right-0 top-0 bottom-0',
|
|
38
|
+
digitClx
|
|
39
|
+
)}>
|
|
40
|
+
<div className='h-[1px] w-full' />
|
|
41
|
+
<div style={{color: 'black' /* tailwind bug */}}>{item.quantity}</div>
|
|
42
|
+
</div>
|
|
43
|
+
<BagIcon className={cn('relative -top-[12%] h-full ', iconClx, )} aria-hidden="true" />
|
|
44
|
+
</div>
|
|
45
|
+
)
|
|
46
|
+
}) // -top-[3px]
|
|
47
|
+
|
|
48
|
+
export default QuantityIndicator
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
'use client'
|
|
2
|
+
import React, { useState } from 'react'
|
|
3
|
+
|
|
4
|
+
import { ToggleGroup, ToggleGroupItem} from "@libreapps/ui/primitives"
|
|
5
|
+
import { cn } from '@libreapps/ui/util'
|
|
6
|
+
|
|
7
|
+
import type { CategoryNode, StringMutator, StringArrayMutator } from '../../types'
|
|
8
|
+
import NodeImage from './node-image'
|
|
9
|
+
|
|
10
|
+
const NodeTabs: React.FC<{
|
|
11
|
+
levelNodes: CategoryNode[]
|
|
12
|
+
mutator: StringMutator | StringArrayMutator
|
|
13
|
+
multiple?: boolean
|
|
14
|
+
className?: string
|
|
15
|
+
buttonClx?: string
|
|
16
|
+
itemClx?: string
|
|
17
|
+
mobile?: boolean
|
|
18
|
+
tabSize?: string
|
|
19
|
+
show?: 'image' | 'label' | 'image-and-label'
|
|
20
|
+
}> = ({
|
|
21
|
+
levelNodes,
|
|
22
|
+
mutator,
|
|
23
|
+
multiple=false,
|
|
24
|
+
buttonClx='',
|
|
25
|
+
itemClx='',
|
|
26
|
+
className='',
|
|
27
|
+
mobile=false,
|
|
28
|
+
tabSize,
|
|
29
|
+
show='image-and-label'
|
|
30
|
+
}) => {
|
|
31
|
+
|
|
32
|
+
const [last, setLast] = useState<string | undefined>(undefined)
|
|
33
|
+
|
|
34
|
+
const handleChangeMultiple = (selected: string[]) => {
|
|
35
|
+
(mutator as StringArrayMutator).set(selected)
|
|
36
|
+
setLast(selected.length === 1 ? selected[0] : undefined)
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
const handleChangeSingle = (selected: string) => {
|
|
40
|
+
(mutator as StringMutator).set(selected)
|
|
41
|
+
if (selected) { setLast(selected) }
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
const roundedToSpread: any = {}
|
|
45
|
+
if (multiple) {
|
|
46
|
+
roundedToSpread.rounded = 'xl'
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
const val = multiple ?
|
|
50
|
+
(mutator as StringArrayMutator).get()
|
|
51
|
+
:
|
|
52
|
+
(mutator as StringMutator).get()
|
|
53
|
+
|
|
54
|
+
return (
|
|
55
|
+
<ToggleGroup
|
|
56
|
+
type={multiple ? 'multiple' : 'single'}
|
|
57
|
+
value={val}
|
|
58
|
+
variant='default'
|
|
59
|
+
size={tabSize ? tabSize : (mobile ? 'sm' : 'default')}
|
|
60
|
+
onValueChange={multiple ? handleChangeMultiple : handleChangeSingle}
|
|
61
|
+
className={className}
|
|
62
|
+
{...roundedToSpread}
|
|
63
|
+
>
|
|
64
|
+
{levelNodes.map((treeNode, index) => {
|
|
65
|
+
const roundedToSpread: any = {}
|
|
66
|
+
if (!multiple) {
|
|
67
|
+
roundedToSpread.rounded = 'none'
|
|
68
|
+
if (index === 0) { roundedToSpread.rounded = 'llg' }
|
|
69
|
+
else if (index === levelNodes.length - 1) { roundedToSpread.rounded = 'rlg' }
|
|
70
|
+
}
|
|
71
|
+
return (
|
|
72
|
+
<ToggleGroupItem
|
|
73
|
+
key={treeNode.skuToken}
|
|
74
|
+
value={treeNode.skuToken}
|
|
75
|
+
disabled={(last && last === treeNode.skuToken || treeNode.skuToken === mutator.get())}
|
|
76
|
+
aria-label={`Select ${treeNode.label}`}
|
|
77
|
+
{...roundedToSpread}
|
|
78
|
+
className={buttonClx}
|
|
79
|
+
>
|
|
80
|
+
<span className={cn('flex flex-row justify-center gap-1 h-6 items-center', itemClx)} >
|
|
81
|
+
{!(show === 'label') && (<NodeImage treeNode={treeNode} />) }
|
|
82
|
+
{(!(show === 'image') || !treeNode.img) && (<span className='whitespace-nowrap'>{treeNode.label}</span>)}
|
|
83
|
+
</span>
|
|
84
|
+
</ToggleGroupItem>
|
|
85
|
+
)
|
|
86
|
+
})}
|
|
87
|
+
</ToggleGroup>
|
|
88
|
+
)
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
export default NodeTabs
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import React from 'react'
|
|
2
|
+
import Image from 'next/image'
|
|
3
|
+
|
|
4
|
+
import type { CategoryNode } from '../../types'
|
|
5
|
+
|
|
6
|
+
const ICON_SIZE = 20
|
|
7
|
+
|
|
8
|
+
const NodeImage: React.FC<{
|
|
9
|
+
treeNode: CategoryNode
|
|
10
|
+
}> = ({
|
|
11
|
+
treeNode: {
|
|
12
|
+
img,
|
|
13
|
+
imgAR: ar,
|
|
14
|
+
label
|
|
15
|
+
}
|
|
16
|
+
}) => {
|
|
17
|
+
|
|
18
|
+
if (!img) { return null }
|
|
19
|
+
// treat as URL
|
|
20
|
+
return (typeof img === 'string') ? (
|
|
21
|
+
<Image
|
|
22
|
+
src={img as string}
|
|
23
|
+
alt={`Toggle ${label}`}
|
|
24
|
+
className={'block mr-1 '}
|
|
25
|
+
width={ar ? ar * ICON_SIZE : ICON_SIZE}
|
|
26
|
+
height={ICON_SIZE}
|
|
27
|
+
/>
|
|
28
|
+
) : (img as React.ReactNode)
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
export default NodeImage
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
declare const _default: {
|
|
2
|
+
shoppingCart: any;
|
|
3
|
+
menu: any;
|
|
4
|
+
chevronLeft: any;
|
|
5
|
+
chevronRight: any;
|
|
6
|
+
spinner: any;
|
|
7
|
+
check: any;
|
|
8
|
+
plus: any;
|
|
9
|
+
minus: any;
|
|
10
|
+
chevronDown: any;
|
|
11
|
+
chevronsLeft: any;
|
|
12
|
+
chevronsRight: any;
|
|
13
|
+
placeholder: any;
|
|
14
|
+
trash: any;
|
|
15
|
+
search: any;
|
|
16
|
+
barcode: any;
|
|
17
|
+
};
|
|
18
|
+
export default _default;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { ShoppingCart, Menu, ChevronLeft, ChevronRight, Loader2, Check, Plus, Minus, ChevronDown, ChevronsLeft, ChevronsRight, Image, Trash2, Search, Barcode } from "lucide-react";
|
|
2
|
+
export default {
|
|
3
|
+
shoppingCart: ShoppingCart,
|
|
4
|
+
menu: Menu,
|
|
5
|
+
chevronLeft: ChevronLeft,
|
|
6
|
+
chevronRight: ChevronRight,
|
|
7
|
+
spinner: Loader2,
|
|
8
|
+
check: Check,
|
|
9
|
+
plus: Plus,
|
|
10
|
+
minus: Minus,
|
|
11
|
+
chevronDown: ChevronDown,
|
|
12
|
+
chevronsLeft: ChevronsLeft,
|
|
13
|
+
chevronsRight: ChevronsRight,
|
|
14
|
+
placeholder: Image,
|
|
15
|
+
trash: Trash2,
|
|
16
|
+
search: Search,
|
|
17
|
+
barcode: Barcode
|
|
18
|
+
};
|
|
19
|
+
//# sourceMappingURL=Icons.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Icons.js","sourceRoot":"","sources":["../../components/Icons.tsx"],"names":[],"mappings":"AAAA,OAAO,EACL,YAAY,EACZ,IAAI,EACJ,WAAW,EACX,YAAY,EACZ,OAAO,EACP,KAAK,EACL,IAAI,EACJ,KAAK,EACL,WAAW,EACX,YAAY,EACZ,aAAa,EACb,KAAK,EACL,MAAM,EACN,MAAM,EACN,OAAO,EACR,MAAM,cAAc,CAAA;AAErB,eAAe;IACb,YAAY,EAAE,YAAY;IAC1B,IAAI,EAAE,IAAI;IACV,WAAW,EAAE,WAAW;IACxB,YAAY,EAAE,YAAY;IAC1B,OAAO,EAAE,OAAO;IAChB,KAAK,EAAE,KAAK;IACZ,IAAI,EAAE,IAAI;IACV,KAAK,EAAE,KAAK;IACZ,WAAW,EAAE,WAAW;IACxB,YAAY,EAAE,YAAY;IAC1B,aAAa,EAAE,aAAa;IAC5B,WAAW,EAAE,KAAK;IAClB,KAAK,EAAE,MAAM;IACb,MAAM,EAAE,MAAM;IACd,OAAO,EAAE,OAAO;CACjB,CAAA"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import type { LineItem } from '../types';
|
|
3
|
+
declare const AddToCartWidget: React.FC<{
|
|
4
|
+
item: LineItem;
|
|
5
|
+
disabled?: boolean;
|
|
6
|
+
className?: string;
|
|
7
|
+
buttonClx?: string;
|
|
8
|
+
variant?: 'minimal' | 'primary' | 'primary-smaller' | 'outline';
|
|
9
|
+
onQuantityChanged?: (sku: string, oldV: number, newV: number) => void;
|
|
10
|
+
}>;
|
|
11
|
+
export default AddToCartWidget;
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import React, { useEffect, useRef } from 'react';
|
|
4
|
+
import { reaction } from 'mobx';
|
|
5
|
+
import { observer } from 'mobx-react-lite';
|
|
6
|
+
import { Button, buttonVariants } from '@libreapps/ui/primitives';
|
|
7
|
+
import { cn } from '@libreapps/ui/util';
|
|
8
|
+
import Icons from './Icons';
|
|
9
|
+
import { sendFBEvent, sendGAEvent } from '../util/analytics';
|
|
10
|
+
const AddToCartWidget = observer(({ item, variant = 'primary', disabled = false, className = '', buttonClx = '', onQuantityChanged }) => {
|
|
11
|
+
const reactionDisposer = useRef(undefined);
|
|
12
|
+
useEffect(() => {
|
|
13
|
+
if (onQuantityChanged) {
|
|
14
|
+
reactionDisposer.current = reaction(() => (item.quantity), (quantity, previous) => {
|
|
15
|
+
onQuantityChanged(item.sku, quantity, previous);
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
return () => {
|
|
19
|
+
if (reactionDisposer.current) {
|
|
20
|
+
reactionDisposer.current();
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
}, []);
|
|
24
|
+
const ROUNDED_VAL = 'lg';
|
|
25
|
+
// no need to safelist, since its used widely
|
|
26
|
+
const ROUNDED_CLX = ` rounded-${ROUNDED_VAL} `;
|
|
27
|
+
const ghost = variant === 'minimal';
|
|
28
|
+
const outline = variant === 'outline';
|
|
29
|
+
const primary = variant === 'primary';
|
|
30
|
+
const priSmaller = variant === 'primary-smaller';
|
|
31
|
+
let iconClx = ghost ? 'h-4 w-4 md:h-3 md:w-3 text-muted-3 ' : (priSmaller ? 'h-4 w-6 px-0.5 opacity-70' : 'h-5 w-7 px-1 opacity-70 ');
|
|
32
|
+
iconClx += ghost ? 'group-hover:text-foreground' : 'group-hover:opacity-100';
|
|
33
|
+
let digitClx = ghost ? 'px-2 md:px-0.5 ' : 'sm:px-2 font-semibold ';
|
|
34
|
+
digitClx += (ghost || outline) ? 'text-foreground ' : 'text-primary-fg ';
|
|
35
|
+
if (disabled) {
|
|
36
|
+
return (_jsx("div", { className: cn('flex flex-row items-stretch' + ROUNDED_CLX + (!(primary || priSmaller) ? 'bg-transparent' : 'bg-primary'), className), children: _jsx("div", { className: 'text-sm flex items-center cursor-default ' + digitClx, children: item.quantity }) }));
|
|
37
|
+
}
|
|
38
|
+
const inc = (event) => {
|
|
39
|
+
item.increment();
|
|
40
|
+
event.stopPropagation(); // in case we're part of a larger selection UI
|
|
41
|
+
sendGAEvent('add_to_cart', {
|
|
42
|
+
items: [{
|
|
43
|
+
item_id: item.sku,
|
|
44
|
+
item_name: item.title,
|
|
45
|
+
item_category: item.familyId,
|
|
46
|
+
price: item.price,
|
|
47
|
+
quantity: item.quantity
|
|
48
|
+
}],
|
|
49
|
+
value: item.price,
|
|
50
|
+
currency: 'USD',
|
|
51
|
+
});
|
|
52
|
+
sendFBEvent('AddToCart', {
|
|
53
|
+
content_ids: [item.sku],
|
|
54
|
+
contents: [{
|
|
55
|
+
id: item.sku,
|
|
56
|
+
quantity: item.quantity
|
|
57
|
+
}],
|
|
58
|
+
content_name: item.title,
|
|
59
|
+
value: item.price,
|
|
60
|
+
currency: 'USD',
|
|
61
|
+
});
|
|
62
|
+
};
|
|
63
|
+
const dec = (event) => {
|
|
64
|
+
item.decrement();
|
|
65
|
+
event.stopPropagation(); // in case we're part of a larger selection UI
|
|
66
|
+
sendGAEvent('remove_from_cart', {
|
|
67
|
+
items: [{
|
|
68
|
+
item_id: item.sku,
|
|
69
|
+
item_name: item.title,
|
|
70
|
+
item_category: item.familyId,
|
|
71
|
+
price: item.price,
|
|
72
|
+
quantity: item.quantity
|
|
73
|
+
}],
|
|
74
|
+
value: item.price,
|
|
75
|
+
currency: 'USD',
|
|
76
|
+
});
|
|
77
|
+
};
|
|
78
|
+
return (item.isInCart ? (_jsxs("div", { className: cn('flex flex-row items-stretch justify-between ',
|
|
79
|
+
// should match 'xs' and 'default' button heights
|
|
80
|
+
(ghost || priSmaller ? 'h-8' : 'h-9'), ROUNDED_CLX, (primary || priSmaller ? 'bg-primary' : 'bg-transparent'), (outline ? 'border border-muted' : ''), className), children: [_jsx(Button, { "aria-label": 'Remove a ' + item.title + ' from the cart', size: ghost || priSmaller ? 'xs' : 'default', variant: primary || priSmaller ? 'primary' : 'ghost', rounded: ghost ? 'full' : ROUNDED_VAL, className: cn('lg:min-w-0 lg:px-2 grow justify-start group', (ghost || priSmaller ? 'px-1' : 'px-2'), (outline ? 'hover:bg-transparent' : ''), buttonClx, 'h-auto self-stretch' // must be smaller than normal
|
|
81
|
+
), onClick: dec, children: (item.quantity > 1) ? (_jsx(Icons.minus, { className: iconClx, "aria-hidden": 'true' })) : (_jsx(Icons.trash, { className: iconClx, "aria-hidden": 'true' })) }, 'left'), _jsxs("div", { className: cn('grow-0 shrink-0 flex items-center cursor-default xs:px-2', priSmaller || ghost ? 'text-xs' : 'text-sm', digitClx), children: [item.quantity, ghost ? '' : ' in Bag'] }), _jsx(Button, { "aria-label": 'Add another ' + item.title + ' to the cart', size: ghost || priSmaller ? 'xs' : 'default', variant: primary || priSmaller ? 'primary' : 'ghost', rounded: ghost ? 'full' : ROUNDED_VAL, className: cn('lg:min-w-0 lg:px-2 grow justify-end group', (ghost || priSmaller ? 'px-1' : 'px-2'), (outline ? 'hover:bg-transparent' : ''), buttonClx, 'h-auto self-stretch' // must be smaller than normal
|
|
82
|
+
), onClick: inc, children: _jsx(Icons.plus, { className: iconClx, "aria-hidden": 'true' }) }, 'right')] })) : (_jsxs(Button, { "aria-label": 'Add a ' + item.title + ' to cart', size: ghost || priSmaller ? 'xs' : 'default', variant: ghost ? 'ghost' : (primary || priSmaller ? 'primary' : 'outline'), rounded: ROUNDED_VAL, className: cn(buttonClx, className), onClick: inc, children: [_jsx("span", { className: 'm1-1', children: "Add" }), _jsx(Icons.plus, { className: 'h-5 w-5 ml-1', "aria-hidden": 'true' })] })));
|
|
83
|
+
});
|
|
84
|
+
export default AddToCartWidget;
|
|
85
|
+
//# sourceMappingURL=add-to-cart-widget.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"add-to-cart-widget.js","sourceRoot":"","sources":["../../components/add-to-cart-widget.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAA;;AACZ,OAAO,KAAK,EAAE,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,OAAO,CAAA;AAChD,OAAO,EAAE,QAAQ,EAA0B,MAAM,MAAM,CAAA;AACvD,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAA;AAE1C,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAA;AACjE,OAAO,EAAE,EAAE,EAAqB,MAAM,oBAAoB,CAAA;AAE1D,OAAO,KAAK,MAAM,SAAS,CAAA;AAE3B,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAA;AAE5D,MAAM,eAAe,GAOhB,QAAQ,CAAC,CAAC,EACb,IAAI,EACJ,OAAO,GAAC,SAAS,EACjB,QAAQ,GAAC,KAAK,EACd,SAAS,GAAC,EAAE,EACZ,SAAS,GAAC,EAAE,EACZ,iBAAiB,EAClB,EAAE,EAAE;IAEH,MAAM,gBAAgB,GAAG,MAAM,CAAgC,SAAS,CAAC,CAAA;IACzE,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,iBAAiB,EAAE,CAAC;YACtB,gBAAgB,CAAC,OAAO,GAAG,QAAQ,CACjC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,EACrB,CAAC,QAAgB,EAAE,QAAgB,EAAE,EAAE;gBACrC,iBAAiB,CAAC,IAAI,CAAC,GAAG,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAA;YACjD,CAAC,CACF,CAAA;QACH,CAAC;QACD,OAAO,GAAG,EAAE;YACV,IAAI,gBAAgB,CAAC,OAAO,EAAE,CAAC;gBAC7B,gBAAgB,CAAC,OAAO,EAAE,CAAA;YAC5B,CAAC;QACH,CAAC,CAAA;IACH,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,MAAM,WAAW,GAAG,IAAI,CAAA;IACtB,6CAA6C;IAC/C,MAAM,WAAW,GAAG,YAAY,WAAW,GAAG,CAAA;IAE9C,MAAM,KAAK,GAAG,OAAO,KAAK,SAAS,CAAA;IACnC,MAAM,OAAO,GAAG,OAAO,KAAK,SAAS,CAAA;IACrC,MAAM,OAAO,GAAG,OAAO,KAAK,SAAS,CAAA;IACrC,MAAM,UAAU,GAAG,OAAO,KAAK,iBAAiB,CAAA;IAEhD,IAAI,OAAO,GAAG,KAAK,CAAC,CAAC,CAAC,qCAAqC,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,2BAA2B,CAAC,CAAC,CAAC,0BAA0B,CAAC,CAAA;IACrI,OAAO,IAAI,KAAK,CAAC,CAAC,CAAC,6BAA6B,CAAC,CAAC,CAAC,yBAAyB,CAAA;IAE5E,IAAI,QAAQ,GAAG,KAAK,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,wBAAwB,CAAA;IACnE,QAAQ,IAAI,CAAC,KAAK,IAAI,OAAO,CAAC,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,kBAAkB,CAAA;IAExE,IAAI,QAAQ,EAAE,CAAC;QACb,OAAO,CACL,cAAK,SAAS,EAAE,EAAE,CAAC,6BAA6B,GAAG,WAAW,GAAI,CAAC,CAAC,CAAC,OAAO,IAAI,UAAU,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,YAAY,CAAC,EAAE,SAAS,CAAC,YACxI,cAAK,SAAS,EAAE,2CAA2C,GAAG,QAAQ,YAAI,IAAI,CAAC,QAAQ,GAAO,GAC1F,CACP,CAAA;IACH,CAAC;IAED,MAAM,GAAG,GAAG,CAAC,KAAoC,EAAE,EAAE;QACnD,IAAI,CAAC,SAAS,EAAE,CAAA;QAChB,KAAK,CAAC,eAAe,EAAE,CAAA,CAAC,8CAA8C;QACtE,WAAW,CAAC,aAAa,EAAE;YACzB,KAAK,EAAE,CAAC;oBACN,OAAO,EAAE,IAAI,CAAC,GAAG;oBACjB,SAAS,EAAE,IAAI,CAAC,KAAK;oBACrB,aAAa,EAAE,IAAI,CAAC,QAAQ;oBAC5B,KAAK,EAAE,IAAI,CAAC,KAAK;oBACjB,QAAQ,EAAE,IAAI,CAAC,QAAQ;iBACxB,CAAC;YACF,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,QAAQ,EAAE,KAAK;SAChB,CAAC,CAAA;QACF,WAAW,CAAC,WAAW,EAAE;YACvB,WAAW,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC;YACvB,QAAQ,EAAE,CAAC;oBACT,EAAE,EAAE,IAAI,CAAC,GAAG;oBACZ,QAAQ,EAAE,IAAI,CAAC,QAAQ;iBACxB,CAAC;YACF,YAAY,EAAE,IAAI,CAAC,KAAK;YACxB,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,QAAQ,EAAE,KAAK;SAChB,CAAC,CAAA;IACJ,CAAC,CAAA;IAED,MAAM,GAAG,GAAG,CAAC,KAAoC,EAAE,EAAE;QACnD,IAAI,CAAC,SAAS,EAAE,CAAA;QAChB,KAAK,CAAC,eAAe,EAAE,CAAA,CAAC,8CAA8C;QACtE,WAAW,CAAC,kBAAkB,EAAE;YAC9B,KAAK,EAAE,CAAC;oBACN,OAAO,EAAE,IAAI,CAAC,GAAG;oBACjB,SAAS,EAAE,IAAI,CAAC,KAAK;oBACrB,aAAa,EAAE,IAAI,CAAC,QAAQ;oBAC5B,KAAK,EAAE,IAAI,CAAC,KAAK;oBACjB,QAAQ,EAAE,IAAI,CAAC,QAAQ;iBACxB,CAAC;YACF,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,QAAQ,EAAE,KAAK;SAChB,CAAC,CAAA;IACJ,CAAC,CAAA;IAED,OAAO,CAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CACvB,eAAK,SAAS,EAAE,EAAE,CAChB,8CAA8C;QAC5C,iDAAiD;QACnD,CAAC,KAAK,IAAI,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,EACrC,WAAW,EACX,CAAC,OAAO,IAAI,UAAU,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,gBAAgB,CAAC,EACzD,CAAC,OAAO,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,EACtC,SAAS,CACV,aACC,KAAC,MAAM,kBACO,WAAW,GAAG,IAAI,CAAC,KAAK,GAAG,gBAAgB,EACvD,IAAI,EAAE,KAAK,IAAI,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,EAC5C,OAAO,EAAE,OAAO,IAAI,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,EACpD,OAAO,EAAE,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,WAAW,EACrC,SAAS,EAAE,EAAE,CACX,6CAA6C,EAC7C,CAAC,KAAK,IAAI,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,EACvC,CAAC,OAAO,CAAC,CAAC,CAAC,sBAAsB,CAAC,CAAC,CAAC,EAAE,CAAC,EACvC,SAAS,EACT,qBAAqB,CAAC,8BAA8B;iBACrD,EAED,OAAO,EAAE,GAAG,YAEb,CAAC,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CACrB,KAAC,KAAK,CAAC,KAAK,IAAC,SAAS,EAAE,OAAO,iBAAc,MAAM,GAAE,CACtD,CAAC,CAAC,CAAC,CACF,KAAC,KAAK,CAAC,KAAK,IAAC,SAAS,EAAE,OAAO,iBAAc,MAAM,GAAE,CACtD,IAPK,MAAM,CAQH,EACP,eAAK,SAAS,EAAE,EAAE,CAChB,0DAA0D,EAC1D,UAAU,IAAI,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,EAC3C,QAAQ,CACT,aACE,IAAI,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,IAClC,EACR,KAAC,MAAM,kBACO,cAAc,GAAG,IAAI,CAAC,KAAK,GAAG,cAAc,EACxD,IAAI,EAAE,KAAK,IAAI,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,EAE5C,OAAO,EAAE,OAAO,IAAI,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,EACpD,OAAO,EAAE,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,WAAW,EACrC,SAAS,EAAE,EAAE,CACX,2CAA2C,EAC3C,CAAC,KAAK,IAAI,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,EACvC,CAAC,OAAO,CAAC,CAAC,CAAC,sBAAsB,CAAC,CAAC,CAAC,EAAE,CAAC,EACvC,SAAS,EACT,qBAAqB,CAAC,8BAA8B;iBACrD,EACD,OAAO,EAAE,GAAG,YAGZ,KAAC,KAAK,CAAC,IAAI,IAAC,SAAS,EAAE,OAAO,iBAAc,MAAM,GAAE,IAFhD,OAAO,CAGJ,IACL,CACP,CAAC,CAAC,CAAC,CACF,MAAC,MAAM,kBACO,QAAQ,GAAG,IAAI,CAAC,KAAK,GAAG,UAAU,EAC9C,IAAI,EAAE,KAAK,IAAI,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,EAC5C,OAAO,EAAE,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,IAAI,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,EAC1E,OAAO,EAAE,WAAW,EACpB,SAAS,EAAE,EAAE,CAAC,SAAS,EAAE,SAAS,CAAC,EACnC,OAAO,EAAE,GAAG,aAEZ,eAAM,SAAS,EAAC,MAAM,oBAAW,EACjC,KAAC,KAAK,CAAC,IAAI,IAAC,SAAS,EAAC,cAAc,iBAAa,MAAM,GAAE,IAClD,CACV,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA;AAEF,eAAe,eAAe,CAAA"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import React, { type ComponentType } from 'react';
|
|
2
|
+
import type { ItemSelectorProps, ItemSelectorCompProps } from '../../types';
|
|
3
|
+
declare const BuyCard: React.FC<{
|
|
4
|
+
skuPath: string;
|
|
5
|
+
/** For any selectors that show a list of choices,
|
|
6
|
+
* starting with 'scrollAfter' elements,
|
|
7
|
+
* the list will scroll, and the card will
|
|
8
|
+
* have 'scrollHeightClx' applied to it to define and fix the height.
|
|
9
|
+
* This is most like something like '80vh'
|
|
10
|
+
* defaults are '5' and 'h-[70vh]'
|
|
11
|
+
* */
|
|
12
|
+
scrollAfter?: number;
|
|
13
|
+
scrollHeightClx?: string;
|
|
14
|
+
clx?: string;
|
|
15
|
+
famWidgetClx?: string;
|
|
16
|
+
addWidgetClx?: string;
|
|
17
|
+
selector: ComponentType<ItemSelectorProps>;
|
|
18
|
+
selectorProps?: ItemSelectorCompProps;
|
|
19
|
+
/** Show all items from all sibling families
|
|
20
|
+
* If skuPath defines a Family, the first of it's items will
|
|
21
|
+
* be selected. The facet widget will just select a the first
|
|
22
|
+
* item in the chosen Family without changings the overall set
|
|
23
|
+
* of choices. */
|
|
24
|
+
allVariants?: boolean;
|
|
25
|
+
familyTabAs?: 'image' | 'label' | 'image-and-label';
|
|
26
|
+
showItemMedia?: boolean;
|
|
27
|
+
onQuantityChanged?: (sku: string, oldV: number, newV: number) => void;
|
|
28
|
+
mobile?: boolean;
|
|
29
|
+
}>;
|
|
30
|
+
export default BuyCard;
|