@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.
Files changed (327) hide show
  1. package/.turbo/turbo-build.log +4 -0
  2. package/CHANGELOG.md +13 -0
  3. package/LICENSE.md +21 -0
  4. package/components/Icons.tsx +35 -0
  5. package/components/add-to-cart-widget.tsx +183 -0
  6. package/components/buy/buy-card.tsx +259 -0
  7. package/components/buy/carousel-buy-card.tsx +242 -0
  8. package/components/buy/multi-family/all-variants-carousel.tsx +261 -0
  9. package/components/buy/multi-family/family-carousel/index.tsx +77 -0
  10. package/components/buy/multi-family/family-carousel/slide.tsx +83 -0
  11. package/components/buy/multi-family/family-carousel/state.ts +87 -0
  12. package/components/buy/multi-family/index.ts +2 -0
  13. package/components/buy/single-family-selector.tsx +90 -0
  14. package/components/buy/title-and-byline.tsx +25 -0
  15. package/components/cart/cart-panel/cart-line-item.tsx +76 -0
  16. package/components/cart/cart-panel/index.tsx +154 -0
  17. package/components/cart/cart-panel/promo-code.tsx +109 -0
  18. package/components/cart/cart-panel/total-area.tsx +60 -0
  19. package/components/checkout/payment-step-form/card-icon-row.tsx +26 -0
  20. package/components/checkout/payment-step-form/card-icons/amex.tsx +32 -0
  21. package/components/checkout/payment-step-form/card-icons/diners-club.tsx +13 -0
  22. package/components/checkout/payment-step-form/card-icons/discover.tsx +25 -0
  23. package/components/checkout/payment-step-form/card-icons/jcb.tsx +26 -0
  24. package/components/checkout/payment-step-form/card-icons/mastercard.tsx +27 -0
  25. package/components/checkout/payment-step-form/card-icons/visa.tsx +25 -0
  26. package/components/checkout/payment-step-form/cc-button.tsx +17 -0
  27. package/components/checkout/payment-step-form/contact-form.tsx +50 -0
  28. package/components/checkout/payment-step-form/crypto-icons/btc.tsx +11 -0
  29. package/components/checkout/payment-step-form/crypto-icons/eth.tsx +20 -0
  30. package/components/checkout/payment-step-form/crypto-icons/usdt.tsx +13 -0
  31. package/components/checkout/payment-step-form/index.tsx +122 -0
  32. package/components/checkout/payment-step-form/methods/bank-transfer.tsx +79 -0
  33. package/components/checkout/payment-step-form/methods/card.tsx +232 -0
  34. package/components/checkout/payment-step-form/methods/crypto.tsx +227 -0
  35. package/components/checkout/payment-step-form/methods/index.ts +23 -0
  36. package/components/checkout/shipping-step-form.tsx +175 -0
  37. package/components/index.ts +11 -0
  38. package/components/item/product-card.tsx +48 -0
  39. package/components/item-selector/button.tsx +188 -0
  40. package/components/item-selector/carousel/index.tsx +197 -0
  41. package/components/item-selector/carousel/slider.tsx +40 -0
  42. package/components/item-selector/index.ts +5 -0
  43. package/components/item-selector/quantity-indicator.tsx +48 -0
  44. package/components/node-tabs/index.tsx +91 -0
  45. package/components/node-tabs/node-image.tsx +31 -0
  46. package/dist/components/Icons.d.ts +18 -0
  47. package/dist/components/Icons.js +19 -0
  48. package/dist/components/Icons.js.map +1 -0
  49. package/dist/components/add-to-cart-widget.d.ts +11 -0
  50. package/dist/components/add-to-cart-widget.js +85 -0
  51. package/dist/components/add-to-cart-widget.js.map +1 -0
  52. package/dist/components/buy/buy-card.d.ts +30 -0
  53. package/dist/components/buy/buy-card.js +109 -0
  54. package/dist/components/buy/buy-card.js.map +1 -0
  55. package/dist/components/buy/carousel-buy-card.d.ts +12 -0
  56. package/dist/components/buy/carousel-buy-card.js +94 -0
  57. package/dist/components/buy/carousel-buy-card.js.map +1 -0
  58. package/dist/components/buy/multi-family/all-variants-carousel.d.ts +4 -0
  59. package/dist/components/buy/multi-family/all-variants-carousel.js +115 -0
  60. package/dist/components/buy/multi-family/all-variants-carousel.js.map +1 -0
  61. package/dist/components/buy/multi-family/family-carousel/index.d.ts +4 -0
  62. package/dist/components/buy/multi-family/family-carousel/index.js +27 -0
  63. package/dist/components/buy/multi-family/family-carousel/index.js.map +1 -0
  64. package/dist/components/buy/multi-family/family-carousel/slide.d.ts +11 -0
  65. package/dist/components/buy/multi-family/family-carousel/slide.js +35 -0
  66. package/dist/components/buy/multi-family/family-carousel/slide.js.map +1 -0
  67. package/dist/components/buy/multi-family/family-carousel/state.d.ts +20 -0
  68. package/dist/components/buy/multi-family/family-carousel/state.js +59 -0
  69. package/dist/components/buy/multi-family/family-carousel/state.js.map +1 -0
  70. package/dist/components/buy/multi-family/index.d.ts +2 -0
  71. package/dist/components/buy/multi-family/index.js +3 -0
  72. package/dist/components/buy/multi-family/index.js.map +1 -0
  73. package/dist/components/buy/single-family-selector.d.ts +15 -0
  74. package/dist/components/buy/single-family-selector.js +28 -0
  75. package/dist/components/buy/single-family-selector.js.map +1 -0
  76. package/dist/components/buy/title-and-byline.d.ts +8 -0
  77. package/dist/components/buy/title-and-byline.js +7 -0
  78. package/dist/components/buy/title-and-byline.js.map +1 -0
  79. package/dist/components/cart/cart-panel/cart-line-item.d.ts +11 -0
  80. package/dist/components/cart/cart-panel/cart-line-item.js +25 -0
  81. package/dist/components/cart/cart-panel/cart-line-item.js.map +1 -0
  82. package/dist/components/cart/cart-panel/index.d.ts +19 -0
  83. package/dist/components/cart/cart-panel/index.js +65 -0
  84. package/dist/components/cart/cart-panel/index.js.map +1 -0
  85. package/dist/components/cart/cart-panel/promo-code.d.ts +4 -0
  86. package/dist/components/cart/cart-panel/promo-code.js +62 -0
  87. package/dist/components/cart/cart-panel/promo-code.js.map +1 -0
  88. package/dist/components/cart/cart-panel/total-area.d.ts +7 -0
  89. package/dist/components/cart/cart-panel/total-area.js +14 -0
  90. package/dist/components/cart/cart-panel/total-area.js.map +1 -0
  91. package/dist/components/checkout/payment-step-form/card-icon-row.d.ts +2 -0
  92. package/dist/components/checkout/payment-step-form/card-icon-row.js +14 -0
  93. package/dist/components/checkout/payment-step-form/card-icon-row.js.map +1 -0
  94. package/dist/components/checkout/payment-step-form/card-icons/amex.d.ts +4 -0
  95. package/dist/components/checkout/payment-step-form/card-icons/amex.js +6 -0
  96. package/dist/components/checkout/payment-step-form/card-icons/amex.js.map +1 -0
  97. package/dist/components/checkout/payment-step-form/card-icons/diners-club.d.ts +4 -0
  98. package/dist/components/checkout/payment-step-form/card-icons/diners-club.js +6 -0
  99. package/dist/components/checkout/payment-step-form/card-icons/diners-club.js.map +1 -0
  100. package/dist/components/checkout/payment-step-form/card-icons/discover.d.ts +4 -0
  101. package/dist/components/checkout/payment-step-form/card-icons/discover.js +6 -0
  102. package/dist/components/checkout/payment-step-form/card-icons/discover.js.map +1 -0
  103. package/dist/components/checkout/payment-step-form/card-icons/jcb.d.ts +4 -0
  104. package/dist/components/checkout/payment-step-form/card-icons/jcb.js +6 -0
  105. package/dist/components/checkout/payment-step-form/card-icons/jcb.js.map +1 -0
  106. package/dist/components/checkout/payment-step-form/card-icons/mastercard.d.ts +4 -0
  107. package/dist/components/checkout/payment-step-form/card-icons/mastercard.js +6 -0
  108. package/dist/components/checkout/payment-step-form/card-icons/mastercard.js.map +1 -0
  109. package/dist/components/checkout/payment-step-form/card-icons/visa.d.ts +4 -0
  110. package/dist/components/checkout/payment-step-form/card-icons/visa.js +6 -0
  111. package/dist/components/checkout/payment-step-form/card-icons/visa.js.map +1 -0
  112. package/dist/components/checkout/payment-step-form/cc-button.d.ts +3 -0
  113. package/dist/components/checkout/payment-step-form/cc-button.js +6 -0
  114. package/dist/components/checkout/payment-step-form/cc-button.js.map +1 -0
  115. package/dist/components/checkout/payment-step-form/contact-form.d.ts +5 -0
  116. package/dist/components/checkout/payment-step-form/contact-form.js +6 -0
  117. package/dist/components/checkout/payment-step-form/contact-form.js.map +1 -0
  118. package/dist/components/checkout/payment-step-form/crypto-icons/btc.d.ts +4 -0
  119. package/dist/components/checkout/payment-step-form/crypto-icons/btc.js +6 -0
  120. package/dist/components/checkout/payment-step-form/crypto-icons/btc.js.map +1 -0
  121. package/dist/components/checkout/payment-step-form/crypto-icons/eth.d.ts +4 -0
  122. package/dist/components/checkout/payment-step-form/crypto-icons/eth.js +6 -0
  123. package/dist/components/checkout/payment-step-form/crypto-icons/eth.js.map +1 -0
  124. package/dist/components/checkout/payment-step-form/crypto-icons/usdt.d.ts +4 -0
  125. package/dist/components/checkout/payment-step-form/crypto-icons/usdt.js +6 -0
  126. package/dist/components/checkout/payment-step-form/crypto-icons/usdt.js.map +1 -0
  127. package/dist/components/checkout/payment-step-form/index.d.ts +4 -0
  128. package/dist/components/checkout/payment-step-form/index.js +77 -0
  129. package/dist/components/checkout/payment-step-form/index.js.map +1 -0
  130. package/dist/components/checkout/payment-step-form/methods/bank-transfer.d.ts +4 -0
  131. package/dist/components/checkout/payment-step-form/methods/bank-transfer.js +24 -0
  132. package/dist/components/checkout/payment-step-form/methods/bank-transfer.js.map +1 -0
  133. package/dist/components/checkout/payment-step-form/methods/card.d.ts +4 -0
  134. package/dist/components/checkout/payment-step-form/methods/card.js +160 -0
  135. package/dist/components/checkout/payment-step-form/methods/card.js.map +1 -0
  136. package/dist/components/checkout/payment-step-form/methods/crypto.d.ts +9 -0
  137. package/dist/components/checkout/payment-step-form/methods/crypto.js +137 -0
  138. package/dist/components/checkout/payment-step-form/methods/crypto.js.map +1 -0
  139. package/dist/components/checkout/payment-step-form/methods/index.d.ts +6 -0
  140. package/dist/components/checkout/payment-step-form/methods/index.js +21 -0
  141. package/dist/components/checkout/payment-step-form/methods/index.js.map +1 -0
  142. package/dist/components/checkout/shipping-step-form.d.ts +3 -0
  143. package/dist/components/checkout/shipping-step-form.js +53 -0
  144. package/dist/components/checkout/shipping-step-form.js.map +1 -0
  145. package/dist/components/index.d.ts +8 -0
  146. package/dist/components/index.js +9 -0
  147. package/dist/components/index.js.map +1 -0
  148. package/dist/components/item/product-card.d.ts +7 -0
  149. package/dist/components/item/product-card.js +9 -0
  150. package/dist/components/item/product-card.js.map +1 -0
  151. package/dist/components/item-selector/button.d.ts +4 -0
  152. package/dist/components/item-selector/button.js +47 -0
  153. package/dist/components/item-selector/button.js.map +1 -0
  154. package/dist/components/item-selector/carousel/index.d.ts +12 -0
  155. package/dist/components/item-selector/carousel/index.js +74 -0
  156. package/dist/components/item-selector/carousel/index.js.map +1 -0
  157. package/dist/components/item-selector/carousel/slider.d.ts +8 -0
  158. package/dist/components/item-selector/carousel/slider.js +12 -0
  159. package/dist/components/item-selector/carousel/slider.js.map +1 -0
  160. package/dist/components/item-selector/index.d.ts +2 -0
  161. package/dist/components/item-selector/index.js +3 -0
  162. package/dist/components/item-selector/index.js.map +1 -0
  163. package/dist/components/item-selector/quantity-indicator.d.ts +9 -0
  164. package/dist/components/item-selector/quantity-indicator.js +16 -0
  165. package/dist/components/item-selector/quantity-indicator.js.map +1 -0
  166. package/dist/components/node-tabs/index.d.ts +14 -0
  167. package/dist/components/node-tabs/index.js +42 -0
  168. package/dist/components/node-tabs/index.js.map +1 -0
  169. package/dist/components/node-tabs/node-image.d.ts +6 -0
  170. package/dist/components/node-tabs/node-image.js +13 -0
  171. package/dist/components/node-tabs/node-image.js.map +1 -0
  172. package/dist/index.d.ts +5 -0
  173. package/dist/index.js +5 -0
  174. package/dist/index.js.map +1 -0
  175. package/dist/service/context.d.ts +8 -0
  176. package/dist/service/context.js +19 -0
  177. package/dist/service/context.js.map +1 -0
  178. package/dist/service/debug.d.ts +10 -0
  179. package/dist/service/debug.js +30 -0
  180. package/dist/service/debug.js.map +1 -0
  181. package/dist/service/impls/standalone/actual-line-item.d.ts +40 -0
  182. package/dist/service/impls/standalone/actual-line-item.js +84 -0
  183. package/dist/service/impls/standalone/actual-line-item.js.map +1 -0
  184. package/dist/service/impls/standalone/get-instance.d.ts +2 -0
  185. package/dist/service/impls/standalone/get-instance.js +39 -0
  186. package/dist/service/impls/standalone/get-instance.js.map +1 -0
  187. package/dist/service/impls/standalone/index.d.ts +67 -0
  188. package/dist/service/impls/standalone/index.js +416 -0
  189. package/dist/service/impls/standalone/index.js.map +1 -0
  190. package/dist/service/impls/standalone/order/firebase.d.ts +2 -0
  191. package/dist/service/impls/standalone/order/firebase.js +13 -0
  192. package/dist/service/impls/standalone/order/firebase.js.map +1 -0
  193. package/dist/service/impls/standalone/order/index.d.ts +24 -0
  194. package/dist/service/impls/standalone/order/index.js +61 -0
  195. package/dist/service/impls/standalone/order/index.js.map +1 -0
  196. package/dist/service/impls/standalone/persistence.d.ts +4 -0
  197. package/dist/service/impls/standalone/persistence.js +22 -0
  198. package/dist/service/impls/standalone/persistence.js.map +1 -0
  199. package/dist/service/path-utils.d.ts +7 -0
  200. package/dist/service/path-utils.js +16 -0
  201. package/dist/service/path-utils.js.map +1 -0
  202. package/dist/service/sep.d.ts +6 -0
  203. package/dist/service/sep.js +6 -0
  204. package/dist/service/sep.js.map +1 -0
  205. package/dist/types/category-node.d.ts +36 -0
  206. package/dist/types/category-node.js +2 -0
  207. package/dist/types/category-node.js.map +1 -0
  208. package/dist/types/checkout.d.ts +33 -0
  209. package/dist/types/checkout.js +2 -0
  210. package/dist/types/checkout.js.map +1 -0
  211. package/dist/types/commerce-config.d.ts +11 -0
  212. package/dist/types/commerce-config.js +2 -0
  213. package/dist/types/commerce-config.js.map +1 -0
  214. package/dist/types/commerce-service.d.ts +109 -0
  215. package/dist/types/commerce-service.js +2 -0
  216. package/dist/types/commerce-service.js.map +1 -0
  217. package/dist/types/family.d.ts +16 -0
  218. package/dist/types/family.js +2 -0
  219. package/dist/types/family.js.map +1 -0
  220. package/dist/types/index.d.ts +13 -0
  221. package/dist/types/index.js +8 -0
  222. package/dist/types/index.js.map +1 -0
  223. package/dist/types/item-selector.d.ts +72 -0
  224. package/dist/types/item-selector.js +2 -0
  225. package/dist/types/item-selector.js.map +1 -0
  226. package/dist/types/line-item.d.ts +14 -0
  227. package/dist/types/line-item.js +2 -0
  228. package/dist/types/line-item.js.map +1 -0
  229. package/dist/types/multi-family-selector-props.d.ts +16 -0
  230. package/dist/types/multi-family-selector-props.js +2 -0
  231. package/dist/types/multi-family-selector-props.js.map +1 -0
  232. package/dist/types/product.d.ts +15 -0
  233. package/dist/types/product.js +2 -0
  234. package/dist/types/product.js.map +1 -0
  235. package/dist/types/promo.d.ts +7 -0
  236. package/dist/types/promo.js +2 -0
  237. package/dist/types/promo.js.map +1 -0
  238. package/dist/types/selection-ui-specifier.d.ts +40 -0
  239. package/dist/types/selection-ui-specifier.js +2 -0
  240. package/dist/types/selection-ui-specifier.js.map +1 -0
  241. package/dist/types/string-mutator.d.ts +9 -0
  242. package/dist/types/string-mutator.js +2 -0
  243. package/dist/types/string-mutator.js.map +1 -0
  244. package/dist/types/token-separators.d.ts +6 -0
  245. package/dist/types/token-separators.js +2 -0
  246. package/dist/types/token-separators.js.map +1 -0
  247. package/dist/util/analytics.d.ts +9 -0
  248. package/dist/util/analytics.js +10 -0
  249. package/dist/util/analytics.js.map +1 -0
  250. package/dist/util/countries.d.ts +7 -0
  251. package/dist/util/countries.js +197 -0
  252. package/dist/util/countries.js.map +1 -0
  253. package/dist/util/error.d.ts +1 -0
  254. package/dist/util/error.js +22 -0
  255. package/dist/util/error.js.map +1 -0
  256. package/dist/util/index.d.ts +15 -0
  257. package/dist/util/index.js +54 -0
  258. package/dist/util/index.js.map +1 -0
  259. package/dist/util/item-selector-options-accessor.d.ts +3 -0
  260. package/dist/util/item-selector-options-accessor.js +27 -0
  261. package/dist/util/item-selector-options-accessor.js.map +1 -0
  262. package/dist/util/line-item-ref.d.ts +8 -0
  263. package/dist/util/line-item-ref.js +15 -0
  264. package/dist/util/line-item-ref.js.map +1 -0
  265. package/dist/util/multi-family-selector-options-accessor.d.ts +3 -0
  266. package/dist/util/multi-family-selector-options-accessor.js +11 -0
  267. package/dist/util/multi-family-selector-options-accessor.js.map +1 -0
  268. package/dist/util/obs-string-mutator.d.ts +8 -0
  269. package/dist/util/obs-string-mutator.js +15 -0
  270. package/dist/util/obs-string-mutator.js.map +1 -0
  271. package/dist/util/product-media-accessor.d.ts +29 -0
  272. package/dist/util/product-media-accessor.js +22 -0
  273. package/dist/util/product-media-accessor.js.map +1 -0
  274. package/dist/util/promo-codes.d.ts +3 -0
  275. package/dist/util/promo-codes.js +100 -0
  276. package/dist/util/promo-codes.js.map +1 -0
  277. package/dist/util/selection-ui-specifiers.d.ts +3 -0
  278. package/dist/util/selection-ui-specifiers.js +24 -0
  279. package/dist/util/selection-ui-specifiers.js.map +1 -0
  280. package/dist/util/square-payment.d.ts +7 -0
  281. package/dist/util/square-payment.js +37 -0
  282. package/dist/util/square-payment.js.map +1 -0
  283. package/dist/util/use-sync-sku-param-w-current-item.d.ts +2 -0
  284. package/dist/util/use-sync-sku-param-w-current-item.js +61 -0
  285. package/dist/util/use-sync-sku-param-w-current-item.js.map +1 -0
  286. package/index.ts +13 -0
  287. package/libreapps-ui.d.ts +108 -0
  288. package/package.json +67 -0
  289. package/service/context.tsx +45 -0
  290. package/service/debug.ts +41 -0
  291. package/service/impls/standalone/actual-line-item.ts +136 -0
  292. package/service/impls/standalone/get-instance.ts +64 -0
  293. package/service/impls/standalone/index.ts +579 -0
  294. package/service/impls/standalone/order/firebase.ts +14 -0
  295. package/service/impls/standalone/order/index.ts +129 -0
  296. package/service/impls/standalone/persistence.ts +33 -0
  297. package/service/path-utils.ts +26 -0
  298. package/service/sep.ts +7 -0
  299. package/tsconfig.json +17 -0
  300. package/types/README.md +2 -0
  301. package/types/category-node.ts +50 -0
  302. package/types/checkout.ts +47 -0
  303. package/types/commerce-config.ts +13 -0
  304. package/types/commerce-service.ts +128 -0
  305. package/types/family.ts +26 -0
  306. package/types/index.ts +15 -0
  307. package/types/item-selector.ts +97 -0
  308. package/types/line-item.ts +29 -0
  309. package/types/multi-family-selector-props.ts +20 -0
  310. package/types/product.ts +21 -0
  311. package/types/promo.ts +10 -0
  312. package/types/selection-ui-specifier.ts +52 -0
  313. package/types/string-mutator.ts +14 -0
  314. package/types/token-separators.ts +7 -0
  315. package/util/analytics.ts +21 -0
  316. package/util/countries.ts +196 -0
  317. package/util/error.ts +34 -0
  318. package/util/index.ts +71 -0
  319. package/util/item-selector-options-accessor.ts +35 -0
  320. package/util/line-item-ref.ts +23 -0
  321. package/util/multi-family-selector-options-accessor.ts +15 -0
  322. package/util/obs-string-mutator.ts +22 -0
  323. package/util/product-media-accessor.ts +58 -0
  324. package/util/promo-codes.ts +106 -0
  325. package/util/selection-ui-specifiers.ts +30 -0
  326. package/util/square-payment.ts +50 -0
  327. 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,5 @@
1
+ export { default as ButtonItemSelector } from './button'
2
+ export {
3
+ default as CarouselItemSelector,
4
+ type CarouselItemSelectorPropsExt
5
+ } from './carousel'
@@ -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":"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"}
@@ -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;