@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,52 @@
1
+ import type { ItemSelectorOptions } from './item-selector'
2
+
3
+ type SingleFamilySelector = 'buttons' | 'carousel'
4
+ type MultiFamilySelector = 'family-carousel' | 'all-variants-carousel'
5
+
6
+ type MultiFamilySelectorOptions = {
7
+ /**
8
+ * Show title of parent node of families.
9
+ * eg,
10
+ * Lux Credit
11
+ * Black Card
12
+ *
13
+ * vs just Black Card
14
+ *
15
+ * ( parent CategoryNode.label)
16
+ *
17
+ * (goes to one line if only one family)
18
+ * default: true
19
+ * */
20
+ showParentTitle?: boolean
21
+
22
+ /** parent CategoryNode.subNodesLabel
23
+ *
24
+ * default: 'none'
25
+ */
26
+ parentByline?: 'none' | 'own-line' | 'comma-sep' | 'colon-sep'
27
+
28
+ /** show horiz image buttons of
29
+ * all sibling items below item info
30
+ * default: true*/
31
+ showItemSwatches?: boolean
32
+ }
33
+
34
+ interface SelectionUISpecifier {
35
+ multiFamily?: {
36
+ type: MultiFamilySelector
37
+ selectorOptions?: MultiFamilySelectorOptions
38
+ itemOptions?: ItemSelectorOptions
39
+ }
40
+ singleFamily?: {
41
+ type: SingleFamilySelector
42
+ options?: ItemSelectorOptions
43
+ }
44
+ }
45
+
46
+ export {
47
+ type SelectionUISpecifier,
48
+ type ItemSelectorOptions,
49
+ type SingleFamilySelector,
50
+ type MultiFamilySelector,
51
+ type MultiFamilySelectorOptions
52
+ }
@@ -0,0 +1,14 @@
1
+ interface StringMutator {
2
+ get(): string | null
3
+ set(v: string | null): void
4
+ }
5
+
6
+ interface StringArrayMutator {
7
+ get(): string[] | null
8
+ set(v: string[] | null): void
9
+ }
10
+
11
+ export type {
12
+ StringMutator,
13
+ StringArrayMutator
14
+ }
@@ -0,0 +1,7 @@
1
+ interface TokenSeparators {
2
+ readonly tok: string
3
+ readonly subTok: string
4
+ readonly decimal: string
5
+ }
6
+
7
+ export { type TokenSeparators as default }
@@ -0,0 +1,21 @@
1
+ declare global {
2
+ interface Window {
3
+ fbq: Function;
4
+ gtag: Function;
5
+ }
6
+ }
7
+
8
+ // https://developers.facebook.com/docs/meta-pixel/reference
9
+ const sendFBEvent = (name: string, options = {}) => {
10
+ window.fbq('track', name, options)
11
+ }
12
+
13
+ // https://developers.google.com/analytics/devguides/collection/ga4/ecommerce?client_type=gtag
14
+ const sendGAEvent = (name: string, options = {}) => {
15
+ window.gtag('event', name, options)
16
+ }
17
+
18
+ export {
19
+ sendFBEvent,
20
+ sendGAEvent,
21
+ }
@@ -0,0 +1,196 @@
1
+ //https://stefangabos.github.io/world_countries/
2
+ export default [
3
+ {"id":4,"alpha2":"af","alpha3":"afg","name":"Afghanistan"},
4
+ {"id":8,"alpha2":"al","alpha3":"alb","name":"Albania"},
5
+ {"id":12,"alpha2":"dz","alpha3":"dza","name":"Algeria"},
6
+ {"id":20,"alpha2":"ad","alpha3":"and","name":"Andorra"},
7
+ {"id":24,"alpha2":"ao","alpha3":"ago","name":"Angola"},
8
+ {"id":28,"alpha2":"ag","alpha3":"atg","name":"Antigua and Barbuda"},
9
+ {"id":32,"alpha2":"ar","alpha3":"arg","name":"Argentina"},
10
+ {"id":51,"alpha2":"am","alpha3":"arm","name":"Armenia"},
11
+ {"id":36,"alpha2":"au","alpha3":"aus","name":"Australia"},
12
+ {"id":40,"alpha2":"at","alpha3":"aut","name":"Austria"},
13
+ {"id":31,"alpha2":"az","alpha3":"aze","name":"Azerbaijan"},
14
+ {"id":44,"alpha2":"bs","alpha3":"bhs","name":"Bahamas"},
15
+ {"id":48,"alpha2":"bh","alpha3":"bhr","name":"Bahrain"},
16
+ {"id":50,"alpha2":"bd","alpha3":"bgd","name":"Bangladesh"},
17
+ {"id":52,"alpha2":"bb","alpha3":"brb","name":"Barbados"},
18
+ {"id":112,"alpha2":"by","alpha3":"blr","name":"Belarus"},
19
+ {"id":56,"alpha2":"be","alpha3":"bel","name":"Belgium"},
20
+ {"id":84,"alpha2":"bz","alpha3":"blz","name":"Belize"},
21
+ {"id":204,"alpha2":"bj","alpha3":"ben","name":"Benin"},
22
+ {"id":64,"alpha2":"bt","alpha3":"btn","name":"Bhutan"},
23
+ {"id":68,"alpha2":"bo","alpha3":"bol","name":"Bolivia"},
24
+ {"id":70,"alpha2":"ba","alpha3":"bih","name":"Bosnia and Herzegovina"},
25
+ {"id":72,"alpha2":"bw","alpha3":"bwa","name":"Botswana"},
26
+ {"id":76,"alpha2":"br","alpha3":"bra","name":"Brazil"},
27
+ {"id":96,"alpha2":"bn","alpha3":"brn","name":"Brunei Darussalam"},
28
+ {"id":100,"alpha2":"bg","alpha3":"bgr","name":"Bulgaria"},
29
+ {"id":854,"alpha2":"bf","alpha3":"bfa","name":"Burkina Faso"},
30
+ {"id":108,"alpha2":"bi","alpha3":"bdi","name":"Burundi"},
31
+ {"id":132,"alpha2":"cv","alpha3":"cpv","name":"Cabo Verde"},
32
+ {"id":116,"alpha2":"kh","alpha3":"khm","name":"Cambodia"},
33
+ {"id":120,"alpha2":"cm","alpha3":"cmr","name":"Cameroon"},
34
+ {"id":124,"alpha2":"ca","alpha3":"can","name":"Canada"},
35
+ {"id":140,"alpha2":"cf","alpha3":"caf","name":"Central African Republic"},
36
+ {"id":148,"alpha2":"td","alpha3":"tcd","name":"Chad"},
37
+ {"id":152,"alpha2":"cl","alpha3":"chl","name":"Chile"},
38
+ {"id":156,"alpha2":"cn","alpha3":"chn","name":"China"},
39
+ {"id":170,"alpha2":"co","alpha3":"col","name":"Colombia"},
40
+ {"id":174,"alpha2":"km","alpha3":"com","name":"Comoros"},
41
+ {"id":178,"alpha2":"cg","alpha3":"cog","name":"Congo"},
42
+ {"id":188,"alpha2":"cr","alpha3":"cri","name":"Costa Rica"},
43
+ {"id":384,"alpha2":"ci","alpha3":"civ","name":"Côte d'Ivoire"},
44
+ {"id":191,"alpha2":"hr","alpha3":"hrv","name":"Croatia"},
45
+ {"id":192,"alpha2":"cu","alpha3":"cub","name":"Cuba"},
46
+ {"id":196,"alpha2":"cy","alpha3":"cyp","name":"Cyprus"},
47
+ {"id":203,"alpha2":"cz","alpha3":"cze","name":"Czechia"},
48
+ {"id":180,"alpha2":"cd","alpha3":"cod","name":"Democratic Republic of the Congo"},
49
+ {"id":208,"alpha2":"dk","alpha3":"dnk","name":"Denmark"},
50
+ {"id":262,"alpha2":"dj","alpha3":"dji","name":"Djibouti"},
51
+ {"id":212,"alpha2":"dm","alpha3":"dma","name":"Dominica"},
52
+ {"id":214,"alpha2":"do","alpha3":"dom","name":"Dominican Republic"},
53
+ {"id":218,"alpha2":"ec","alpha3":"ecu","name":"Ecuador"},
54
+ {"id":818,"alpha2":"eg","alpha3":"egy","name":"Egypt"},
55
+ {"id":222,"alpha2":"sv","alpha3":"slv","name":"El Salvador"},
56
+ {"id":226,"alpha2":"gq","alpha3":"gnq","name":"Equatorial Guinea"},
57
+ {"id":232,"alpha2":"er","alpha3":"eri","name":"Eritrea"},
58
+ {"id":233,"alpha2":"ee","alpha3":"est","name":"Estonia"},
59
+ {"id":748,"alpha2":"sz","alpha3":"swz","name":"Eswatini"},
60
+ {"id":231,"alpha2":"et","alpha3":"eth","name":"Ethiopia"},
61
+ {"id":242,"alpha2":"fj","alpha3":"fji","name":"Fiji"},
62
+ {"id":246,"alpha2":"fi","alpha3":"fin","name":"Finland"},
63
+ {"id":250,"alpha2":"fr","alpha3":"fra","name":"France"},
64
+ {"id":266,"alpha2":"ga","alpha3":"gab","name":"Gabon"},
65
+ {"id":270,"alpha2":"gm","alpha3":"gmb","name":"Gambia"},
66
+ {"id":268,"alpha2":"ge","alpha3":"geo","name":"Georgia"},
67
+ {"id":276,"alpha2":"de","alpha3":"deu","name":"Germany"},
68
+ {"id":288,"alpha2":"gh","alpha3":"gha","name":"Ghana"},
69
+ {"id":300,"alpha2":"gr","alpha3":"grc","name":"Greece"},
70
+ {"id":308,"alpha2":"gd","alpha3":"grd","name":"Grenada"},
71
+ {"id":320,"alpha2":"gt","alpha3":"gtm","name":"Guatemala"},
72
+ {"id":324,"alpha2":"gn","alpha3":"gin","name":"Guinea"},
73
+ {"id":624,"alpha2":"gw","alpha3":"gnb","name":"Guinea-Bissau"},
74
+ {"id":328,"alpha2":"gy","alpha3":"guy","name":"Guyana"},
75
+ {"id":332,"alpha2":"ht","alpha3":"hti","name":"Haiti"},
76
+ {"id":340,"alpha2":"hn","alpha3":"hnd","name":"Honduras"},
77
+ {"id":348,"alpha2":"hu","alpha3":"hun","name":"Hungary"},
78
+ {"id":352,"alpha2":"is","alpha3":"isl","name":"Iceland"},
79
+ {"id":356,"alpha2":"in","alpha3":"ind","name":"India"},
80
+ {"id":360,"alpha2":"id","alpha3":"idn","name":"Indonesia"},
81
+ {"id":364,"alpha2":"ir","alpha3":"irn","name":"Iran"},
82
+ {"id":368,"alpha2":"iq","alpha3":"irq","name":"Iraq"},
83
+ {"id":372,"alpha2":"ie","alpha3":"irl","name":"Ireland"},
84
+ {"id":376,"alpha2":"il","alpha3":"isr","name":"Israel"},
85
+ {"id":380,"alpha2":"it","alpha3":"ita","name":"Italy"},
86
+ {"id":388,"alpha2":"jm","alpha3":"jam","name":"Jamaica"},
87
+ {"id":392,"alpha2":"jp","alpha3":"jpn","name":"Japan"},
88
+ {"id":400,"alpha2":"jo","alpha3":"jor","name":"Jordan"},
89
+ {"id":398,"alpha2":"kz","alpha3":"kaz","name":"Kazakhstan"},
90
+ {"id":404,"alpha2":"ke","alpha3":"ken","name":"Kenya"},
91
+ {"id":296,"alpha2":"ki","alpha3":"kir","name":"Kiribati"},
92
+ {"id":414,"alpha2":"kw","alpha3":"kwt","name":"Kuwait"},
93
+ {"id":417,"alpha2":"kg","alpha3":"kgz","name":"Kyrgyzstan"},
94
+ {"id":418,"alpha2":"la","alpha3":"lao","name":"Lao People's Democratic Republic"},
95
+ {"id":428,"alpha2":"lv","alpha3":"lva","name":"Latvia"},
96
+ {"id":422,"alpha2":"lb","alpha3":"lbn","name":"Lebanon"},
97
+ {"id":426,"alpha2":"ls","alpha3":"lso","name":"Lesotho"},
98
+ {"id":430,"alpha2":"lr","alpha3":"lbr","name":"Liberia"},
99
+ {"id":434,"alpha2":"ly","alpha3":"lby","name":"Libya"},
100
+ {"id":438,"alpha2":"li","alpha3":"lie","name":"Liechtenstein"},
101
+ {"id":440,"alpha2":"lt","alpha3":"ltu","name":"Lithuania"},
102
+ {"id":442,"alpha2":"lu","alpha3":"lux","name":"Luxembourg"},
103
+ {"id":450,"alpha2":"mg","alpha3":"mdg","name":"Madagascar"},
104
+ {"id":454,"alpha2":"mw","alpha3":"mwi","name":"Malawi"},
105
+ {"id":458,"alpha2":"my","alpha3":"mys","name":"Malaysia"},
106
+ {"id":462,"alpha2":"mv","alpha3":"mdv","name":"Maldives"},
107
+ {"id":466,"alpha2":"ml","alpha3":"mli","name":"Mali"},
108
+ {"id":470,"alpha2":"mt","alpha3":"mlt","name":"Malta"},
109
+ {"id":584,"alpha2":"mh","alpha3":"mhl","name":"Marshall Islands"},
110
+ {"id":478,"alpha2":"mr","alpha3":"mrt","name":"Mauritania"},
111
+ {"id":480,"alpha2":"mu","alpha3":"mus","name":"Mauritius"},
112
+ {"id":484,"alpha2":"mx","alpha3":"mex","name":"Mexico"},
113
+ {"id":583,"alpha2":"fm","alpha3":"fsm","name":"Micronesia"},
114
+ {"id":498,"alpha2":"md","alpha3":"mda","name":"Moldova"},
115
+ {"id":492,"alpha2":"mc","alpha3":"mco","name":"Monaco"},
116
+ {"id":496,"alpha2":"mn","alpha3":"mng","name":"Mongolia"},
117
+ {"id":499,"alpha2":"me","alpha3":"mne","name":"Montenegro"},
118
+ {"id":504,"alpha2":"ma","alpha3":"mar","name":"Morocco"},
119
+ {"id":508,"alpha2":"mz","alpha3":"moz","name":"Mozambique"},
120
+ {"id":104,"alpha2":"mm","alpha3":"mmr","name":"Myanmar"},
121
+ {"id":516,"alpha2":"na","alpha3":"nam","name":"Namibia"},
122
+ {"id":520,"alpha2":"nr","alpha3":"nru","name":"Nauru"},
123
+ {"id":524,"alpha2":"np","alpha3":"npl","name":"Nepal"},
124
+ {"id":528,"alpha2":"nl","alpha3":"nld","name":"Netherlands"},
125
+ {"id":554,"alpha2":"nz","alpha3":"nzl","name":"New Zealand"},
126
+ {"id":558,"alpha2":"ni","alpha3":"nic","name":"Nicaragua"},
127
+ {"id":562,"alpha2":"ne","alpha3":"ner","name":"Niger"},
128
+ {"id":566,"alpha2":"ng","alpha3":"nga","name":"Nigeria"},
129
+ {"id":408,"alpha2":"kp","alpha3":"prk","name":"North Korea"},
130
+ {"id":807,"alpha2":"mk","alpha3":"mkd","name":"North Macedonia"},
131
+ {"id":578,"alpha2":"no","alpha3":"nor","name":"Norway"},
132
+ {"id":512,"alpha2":"om","alpha3":"omn","name":"Oman"},
133
+ {"id":586,"alpha2":"pk","alpha3":"pak","name":"Pakistan"},
134
+ {"id":585,"alpha2":"pw","alpha3":"plw","name":"Palau"},
135
+ {"id":591,"alpha2":"pa","alpha3":"pan","name":"Panama"},
136
+ {"id":598,"alpha2":"pg","alpha3":"png","name":"Papua New Guinea"},
137
+ {"id":600,"alpha2":"py","alpha3":"pry","name":"Paraguay"},
138
+ {"id":604,"alpha2":"pe","alpha3":"per","name":"Peru"},
139
+ {"id":608,"alpha2":"ph","alpha3":"phl","name":"Philippines"},
140
+ {"id":616,"alpha2":"pl","alpha3":"pol","name":"Poland"},
141
+ {"id":620,"alpha2":"pt","alpha3":"prt","name":"Portugal"},
142
+ {"id":634,"alpha2":"qa","alpha3":"qat","name":"Qatar"},
143
+ {"id":642,"alpha2":"ro","alpha3":"rou","name":"Romania"},
144
+ {"id":643,"alpha2":"ru","alpha3":"rus","name":"Russian Federation"},
145
+ {"id":646,"alpha2":"rw","alpha3":"rwa","name":"Rwanda"},
146
+ {"id":659,"alpha2":"kn","alpha3":"kna","name":"Saint Kitts and Nevis"},
147
+ {"id":662,"alpha2":"lc","alpha3":"lca","name":"Saint Lucia"},
148
+ {"id":670,"alpha2":"vc","alpha3":"vct","name":"Saint Vincent and the Grenadines"},
149
+ {"id":882,"alpha2":"ws","alpha3":"wsm","name":"Samoa"},
150
+ {"id":674,"alpha2":"sm","alpha3":"smr","name":"San Marino"},
151
+ {"id":678,"alpha2":"st","alpha3":"stp","name":"Sao Tome and Principe"},
152
+ {"id":682,"alpha2":"sa","alpha3":"sau","name":"Saudi Arabia"},
153
+ {"id":686,"alpha2":"sn","alpha3":"sen","name":"Senegal"},
154
+ {"id":688,"alpha2":"rs","alpha3":"srb","name":"Serbia"},
155
+ {"id":690,"alpha2":"sc","alpha3":"syc","name":"Seychelles"},
156
+ {"id":694,"alpha2":"sl","alpha3":"sle","name":"Sierra Leone"},
157
+ {"id":702,"alpha2":"sg","alpha3":"sgp","name":"Singapore"},
158
+ {"id":703,"alpha2":"sk","alpha3":"svk","name":"Slovakia"},
159
+ {"id":705,"alpha2":"si","alpha3":"svn","name":"Slovenia"},
160
+ {"id":90,"alpha2":"sb","alpha3":"slb","name":"Solomon Islands"},
161
+ {"id":706,"alpha2":"so","alpha3":"som","name":"Somalia"},
162
+ {"id":710,"alpha2":"za","alpha3":"zaf","name":"South Africa"},
163
+ {"id":410,"alpha2":"kr","alpha3":"kor","name":"South Korea"},
164
+ {"id":728,"alpha2":"ss","alpha3":"ssd","name":"South Sudan"},
165
+ {"id":724,"alpha2":"es","alpha3":"esp","name":"Spain"},
166
+ {"id":144,"alpha2":"lk","alpha3":"lka","name":"Sri Lanka"},
167
+ {"id":729,"alpha2":"sd","alpha3":"sdn","name":"Sudan"},
168
+ {"id":740,"alpha2":"sr","alpha3":"sur","name":"Suriname"},
169
+ {"id":752,"alpha2":"se","alpha3":"swe","name":"Sweden"},
170
+ {"id":756,"alpha2":"ch","alpha3":"che","name":"Switzerland"},
171
+ {"id":760,"alpha2":"sy","alpha3":"syr","name":"Syria"},
172
+ {"id":762,"alpha2":"tj","alpha3":"tjk","name":"Tajikistan"},
173
+ {"id":834,"alpha2":"tz","alpha3":"tza","name":"Tanzania"},
174
+ {"id":764,"alpha2":"th","alpha3":"tha","name":"Thailand"},
175
+ {"id":626,"alpha2":"tl","alpha3":"tls","name":"Timor-Leste"},
176
+ {"id":768,"alpha2":"tg","alpha3":"tgo","name":"Togo"},
177
+ {"id":776,"alpha2":"to","alpha3":"ton","name":"Tonga"},
178
+ {"id":780,"alpha2":"tt","alpha3":"tto","name":"Trinidad and Tobago"},
179
+ {"id":788,"alpha2":"tn","alpha3":"tun","name":"Tunisia"},
180
+ {"id":792,"alpha2":"tr","alpha3":"tur","name":"Türkiye"},
181
+ {"id":795,"alpha2":"tm","alpha3":"tkm","name":"Turkmenistan"},
182
+ {"id":798,"alpha2":"tv","alpha3":"tuv","name":"Tuvalu"},
183
+ {"id":800,"alpha2":"ug","alpha3":"uga","name":"Uganda"},
184
+ {"id":804,"alpha2":"ua","alpha3":"ukr","name":"Ukraine"},
185
+ {"id":784,"alpha2":"ae","alpha3":"are","name":"United Arab Emirates"},
186
+ {"id":826,"alpha2":"gb","alpha3":"gbr","name":"United Kingdom"},
187
+ {"id":840,"alpha2":"us","alpha3":"usa","name":"United States of America"},
188
+ {"id":858,"alpha2":"uy","alpha3":"ury","name":"Uruguay"},
189
+ {"id":860,"alpha2":"uz","alpha3":"uzb","name":"Uzbekistan"},
190
+ {"id":548,"alpha2":"vu","alpha3":"vut","name":"Vanuatu"},
191
+ {"id":862,"alpha2":"ve","alpha3":"ven","name":"Venezuela"},
192
+ {"id":704,"alpha2":"vn","alpha3":"vnm","name":"Viet Nam"},
193
+ {"id":887,"alpha2":"ye","alpha3":"yem","name":"Yemen"},
194
+ {"id":894,"alpha2":"zm","alpha3":"zmb","name":"Zambia"},
195
+ {"id":716,"alpha2":"zw","alpha3":"zwe","name":"Zimbabwe"}
196
+ ]
package/util/error.ts ADDED
@@ -0,0 +1,34 @@
1
+
2
+ // https://kentcdodds.com/blog/get-a-catch-block-error-message-with-typescript
3
+
4
+ type ErrorWithMessage = {
5
+ message: string
6
+ }
7
+
8
+ const isErrorWithMessage = (error: unknown): error is ErrorWithMessage => {
9
+ return (
10
+ typeof error === 'object' &&
11
+ error !== null &&
12
+ 'message' in error &&
13
+ typeof (error as Record<string, unknown>).message === 'string'
14
+ )
15
+ }
16
+
17
+ const toErrorWithMessage = (maybeError: unknown): ErrorWithMessage => {
18
+
19
+ if (isErrorWithMessage(maybeError)) {
20
+ return maybeError
21
+ }
22
+
23
+ try {
24
+ return new Error(JSON.stringify(maybeError))
25
+ }
26
+ catch {
27
+ // fallback in case there's an error stringifying the maybeError
28
+ // like with circular references for example.
29
+ return new Error(String(maybeError))
30
+ }
31
+ }
32
+
33
+ export const getErrorMessage = (error: unknown) => (toErrorWithMessage(error).message)
34
+
package/util/index.ts ADDED
@@ -0,0 +1,71 @@
1
+ import type { StringMutator, CommerceService } from '../types'
2
+
3
+ export function toTitleCase(str: string) {
4
+ return str.replace(
5
+ /\w\S*/g,
6
+ (txt) => txt.charAt(0).toUpperCase() + txt.slice(1).toLowerCase()
7
+ )
8
+ }
9
+
10
+ export function slugify(str: string) {
11
+ return str
12
+ .toLowerCase()
13
+ .replace(/ /g, '-')
14
+ .replace(/[^\w-]+/g, '')
15
+ .replace(/--+/g, '-')
16
+ }
17
+
18
+ export function unslugify(str: string) {
19
+ return str.replace(/-/g, ' ')
20
+ }
21
+
22
+
23
+ export function formatCurrencyValue(price: number): string {
24
+ const str = price.toLocaleString('en-US', {
25
+ style: 'currency',
26
+ currency: 'USD',
27
+ });
28
+ return (str.endsWith('.00')) ? str.replace('.00', '') : str
29
+ }
30
+
31
+ export const getFacetValuesMutator = (level: number, cmmc: CommerceService): StringMutator => {
32
+
33
+ const setLevel = (value: string, level: number ): void => {
34
+ const facets = cmmc.selectedPaths
35
+ facets[level] = [value]
36
+ cmmc.selectPaths(facets)
37
+ const subFacets = cmmc.getSelectedNodesAtLevel(level)
38
+ if (subFacets) {
39
+ const facets = cmmc.selectedPaths
40
+ facets[level + 1] = [subFacets[0].skuToken]
41
+ cmmc.selectPaths(facets)
42
+ }
43
+ }
44
+
45
+ const getLevelValueSafe = (level: number): string | null => {
46
+ const facets = cmmc.selectedPaths
47
+ if (!(level in facets) || facets[level].length === 0 ) {
48
+ return null
49
+ }
50
+ return facets[level][0]
51
+ }
52
+
53
+ return {
54
+ get: (): string | null => (getLevelValueSafe(level)),
55
+ set: (v: string): void => {setLevel(v, level)}
56
+ } satisfies StringMutator
57
+ }
58
+
59
+ export { default as useSyncSkuParamWithCurrentItem } from './use-sync-sku-param-w-current-item'
60
+ export { default as processSquareCardPayment } from './square-payment'
61
+ export { default as ObsStringMutator } from './obs-string-mutator'
62
+ export { default as ProductMediaAccessor } from './product-media-accessor'
63
+
64
+ export * from './selection-ui-specifiers'
65
+
66
+ export { getErrorMessage } from './error'
67
+
68
+ export { default as accessItemOptions } from './item-selector-options-accessor'
69
+ export { default as accessMultiSelectorOptions } from './multi-family-selector-options-accessor'
70
+
71
+ export { default as LineItemRef} from './line-item-ref'
@@ -0,0 +1,35 @@
1
+ import type { ItemSelectorOptions } from '../types'
2
+
3
+ export default (options: ItemSelectorOptions | undefined = {}): Required<ItemSelectorOptions> => {
4
+
5
+ const familyTitle = 'familyTitle' in options ? options.familyTitle! : 'short'
6
+ const showFamilyByline = 'showFamilyByline' in options ? options.showFamilyByline! : false
7
+
8
+ const showFamilyInOption = 'showFamilyInOption' in options ? options.showFamilyInOption! : false
9
+ const showByline = 'showByline' in options ? options.showByline! : true
10
+
11
+ const showPrice = 'showPrice' in options ? options.showPrice! : true
12
+ const showQuantity = 'showQuantity' in options ? options.showQuantity! : false
13
+
14
+ const buttonType = 'buttonType' in options ? options.buttonType! : 'text'
15
+ const horizButtons = 'horizButtons' in options ? options.horizButtons! : false
16
+ const showSlider = 'showSlider' in options ? options.showSlider! : true
17
+
18
+ const showButtonIfOnlyOne = 'showButtonIfOnlyOne' in options ? options.showButtonIfOnlyOne! : true
19
+
20
+ const sort = 'sort' in options ? options.sort! : 'none'
21
+
22
+ return {
23
+ showFamilyInOption,
24
+ familyTitle,
25
+ showFamilyByline,
26
+ showByline,
27
+ showPrice,
28
+ showQuantity,
29
+ buttonType,
30
+ horizButtons,
31
+ showSlider,
32
+ showButtonIfOnlyOne,
33
+ sort,
34
+ }
35
+ }
@@ -0,0 +1,23 @@
1
+ import { observable, action, computed, makeObservable } from 'mobx'
2
+
3
+ import type { LineItem, ObsLineItemRef } from '../types'
4
+
5
+ class LineItemRef implements ObsLineItemRef {
6
+
7
+ _item: LineItem | undefined = undefined
8
+
9
+ constructor() {
10
+
11
+ makeObservable(this, {
12
+ _item: observable,
13
+ item: computed,
14
+ set: action
15
+ })
16
+ }
17
+
18
+ get item(): LineItem | undefined { return this._item }
19
+
20
+ set = (v: LineItem | undefined): void => { this._item = v }
21
+ }
22
+
23
+ export default LineItemRef
@@ -0,0 +1,15 @@
1
+ import type { MultiFamilySelectorOptions } from '../types'
2
+
3
+ export default (options: MultiFamilySelectorOptions | undefined = {}): Required<MultiFamilySelectorOptions> => {
4
+
5
+ const showParentTitle = 'showParentTitle' in options ? options.showParentTitle! : true
6
+ const showItemSwatches = 'showItemSwatches' in options ? options.showItemSwatches! : true
7
+
8
+ const parentByline = 'parentByline' in options ? options.parentByline! : 'none'
9
+
10
+ return {
11
+ showParentTitle,
12
+ showItemSwatches,
13
+ parentByline,
14
+ }
15
+ }
@@ -0,0 +1,22 @@
1
+ import {makeObservable, observable, action} from 'mobx'
2
+
3
+ import type { StringMutator } from '../types'
4
+
5
+ class ObsStringMutator implements StringMutator {
6
+
7
+ _s: string | null
8
+
9
+ constructor(s: string) {
10
+ this._s = s
11
+ makeObservable(this, {
12
+ _s: observable,
13
+ set: action,
14
+ //get: computed .// no need
15
+ })
16
+ }
17
+
18
+ set(v: string | null): void { this._s = v }
19
+ get(): string | null { return this._s }
20
+ }
21
+
22
+ export default ObsStringMutator
@@ -0,0 +1,58 @@
1
+ import type { AnimationDef, ImageDef, MediaStackDef, VideoDef } from '@libreapps/ui/types'
2
+
3
+ interface FamilyMediaData {
4
+ img?: Record<string, ImageDef>
5
+ video?: Record<string, VideoDef>
6
+ anim?: Record<string, AnimationDef>
7
+ optionImg?: Record<string, ImageDef>
8
+ }
9
+
10
+ class ProductMediaAccessor {
11
+
12
+ _data: FamilyMediaData
13
+
14
+ constructor(data: FamilyMediaData) {
15
+ this._data = data
16
+ }
17
+
18
+ img = (key: string): ImageDef | undefined => (
19
+ (this._data.img) ? this._data.img[key] : undefined
20
+ )
21
+
22
+ spreadableImg = (key: string): { img?: ImageDef } => (
23
+ (this._data.img) ? {img: this._data.img[key]} : {}
24
+ )
25
+
26
+ video = (key: string): VideoDef | undefined => (
27
+ (this._data.video) ? this._data.video[key] : undefined
28
+ )
29
+
30
+ spreadableVideo = (key: string): { video?: VideoDef } => (
31
+ (this._data.video) ? {video: this._data.video[key]} : {}
32
+ )
33
+
34
+ anim = (key: string): AnimationDef | undefined => (
35
+ (this._data.anim) ? this._data.anim[key] : undefined
36
+ )
37
+
38
+ spreadableAnim = (key: string): { animation?: AnimationDef } => (
39
+ (this._data.anim) ? {animation: this._data.anim[key]} : {}
40
+ )
41
+
42
+ mediaStack = (key: string): MediaStackDef => ({
43
+ ...this.spreadableImg(key),
44
+ ...this.spreadableVideo(key),
45
+ ...this.spreadableAnim(key)
46
+ })
47
+
48
+
49
+ optionImg = (key: string): ImageDef | undefined => (
50
+ (this._data.optionImg) ? this._data.optionImg[key] : undefined
51
+ )
52
+
53
+ spreadableOptionImg = (key: string): { optionImg?: ImageDef } => {
54
+ return (this._data.optionImg) ? { optionImg: this._data.optionImg[key]} : {}
55
+ }
56
+ }
57
+
58
+ export default ProductMediaAccessor