ordering-components-external 13.0.33 → 13.0.34

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 (554) hide show
  1. package/.babelrc +22 -22
  2. package/.vscode/settings.json +3 -3
  3. package/_bundles/0.ordering-component.3760baa5b9906f197b42.js +1 -0
  4. package/_bundles/{1.ordering-component.ddd8b5557b901fb64803.js → 1.ordering-component.3760baa5b9906f197b42.js} +1 -1
  5. package/_bundles/{2.ordering-component.ddd8b5557b901fb64803.js → 2.ordering-component.3760baa5b9906f197b42.js} +1 -1
  6. package/_bundles/{4.ordering-component.ddd8b5557b901fb64803.js → 4.ordering-component.3760baa5b9906f197b42.js} +1 -1
  7. package/_bundles/{5.ordering-component.ddd8b5557b901fb64803.js → 5.ordering-component.3760baa5b9906f197b42.js} +1 -1
  8. package/_bundles/{6.ordering-component.ddd8b5557b901fb64803.js → 6.ordering-component.3760baa5b9906f197b42.js} +1 -1
  9. package/_bundles/7.ordering-component.3760baa5b9906f197b42.js +2 -0
  10. package/_bundles/{8.ordering-component.ddd8b5557b901fb64803.js → 8.ordering-component.3760baa5b9906f197b42.js} +1 -1
  11. package/_bundles/ordering-component.3760baa5b9906f197b42.js +2 -0
  12. package/_bundles/{ordering-component.ddd8b5557b901fb64803.js.LICENSE.txt → ordering-component.3760baa5b9906f197b42.js.LICENSE.txt} +0 -2
  13. package/_modules/components/AddressDetails/index.js +44 -45
  14. package/_modules/components/AddressForm/index.js +67 -68
  15. package/_modules/components/AddressList/index.js +52 -53
  16. package/_modules/components/Analitycs/index.js +11 -13
  17. package/_modules/components/AnalyticsSegment/index.js +9 -10
  18. package/_modules/components/AppleLogin/index.js +38 -40
  19. package/_modules/components/BaseComponent/index.js +15 -16
  20. package/_modules/components/BusinessAndProductList/index.js +114 -124
  21. package/_modules/components/BusinessBasicInformation/index.js +31 -32
  22. package/_modules/components/BusinessController/index.js +73 -74
  23. package/_modules/components/BusinessInformation/BusinessOption/index.js +21 -22
  24. package/_modules/components/BusinessInformation/index.js +25 -26
  25. package/_modules/components/BusinessList/index.js +77 -78
  26. package/_modules/components/BusinessMenuListing/index.js +30 -31
  27. package/_modules/components/BusinessProductsCategories/index.js +17 -18
  28. package/_modules/components/BusinessProductsSearch/index.js +15 -16
  29. package/_modules/components/BusinessReviews/index.js +38 -39
  30. package/_modules/components/BusinessSearchList/index.js +39 -40
  31. package/_modules/components/BusinessSortControl/index.js +33 -34
  32. package/_modules/components/BusinessTypeFilter/index.js +36 -37
  33. package/_modules/components/BusinessesMap/index.js +35 -36
  34. package/_modules/components/Cart/index.js +52 -53
  35. package/_modules/components/CartStoresListing/index.js +17 -18
  36. package/_modules/components/Checkout/index.js +101 -102
  37. package/_modules/components/CmsContent/index.js +31 -32
  38. package/_modules/components/Contacts/index.js +46 -47
  39. package/_modules/components/CouponControl/index.js +33 -34
  40. package/_modules/components/DragAndDrop/index.js +6 -7
  41. package/_modules/components/DriverList/index.js +32 -33
  42. package/_modules/components/DriverTips/index.js +44 -45
  43. package/_modules/components/Emitter/index.js +5 -6
  44. package/_modules/components/ExamineClick/index.js +5 -6
  45. package/_modules/components/FacebookLoginButton/index.js +51 -52
  46. package/_modules/components/FacebookPixel/index.js +13 -14
  47. package/_modules/components/FavoriteList/index.js +46 -47
  48. package/_modules/components/FirebaseGoogleLoginButton/index.js +23 -24
  49. package/_modules/components/FloatingButton/index.js +21 -22
  50. package/_modules/components/ForgotPasswordForm/index.js +55 -56
  51. package/_modules/components/GiftCard/GiftCardOrdersList/index.js +16 -17
  52. package/_modules/components/GiftCard/PurchaseGiftCard/index.js +16 -17
  53. package/_modules/components/GiftCard/RedeemGiftCard/index.js +15 -16
  54. package/_modules/components/GiftCard/SendGiftCard/index.js +15 -16
  55. package/_modules/components/GoogleAutocompleteInput/index.js +28 -29
  56. package/_modules/components/GoogleIdentity/index.js +39 -40
  57. package/_modules/components/GoogleLoginButton/index.js +61 -64
  58. package/_modules/components/GoogleMaps/index.js +50 -52
  59. package/_modules/components/GpsButton/index.js +27 -29
  60. package/_modules/components/LanguageSelector/index.js +40 -41
  61. package/_modules/components/LoginForm/index.js +86 -87
  62. package/_modules/components/LogoutAction/index.js +31 -32
  63. package/_modules/components/MainSearch/index.js +42 -43
  64. package/_modules/components/MapView/index.js +8 -10
  65. package/_modules/components/MenuControl/index.js +66 -67
  66. package/_modules/components/Messages/index.js +34 -35
  67. package/_modules/components/MomentOption/index.js +57 -58
  68. package/_modules/components/MultiCartCreate/index.js +8 -9
  69. package/_modules/components/MultiCartsPaymethodsAndWallets/index.js +18 -19
  70. package/_modules/components/MultiCheckout/index.js +44 -45
  71. package/_modules/components/MultiOrdersDetails/index.js +21 -22
  72. package/_modules/components/MyOrders/index.js +34 -35
  73. package/_modules/components/MyOrdersList/index.js +32 -33
  74. package/_modules/components/NewOrderNotification/index.js +6 -7
  75. package/_modules/components/OrderChange/index.js +30 -31
  76. package/_modules/components/OrderDetails/index.js +70 -71
  77. package/_modules/components/OrderList/index.js +86 -90
  78. package/_modules/components/OrderListGroups/index.js +97 -99
  79. package/_modules/components/OrderReview/index.js +38 -39
  80. package/_modules/components/OrderTypeControl/index.js +23 -24
  81. package/_modules/components/OrderVerticalList/index.js +18 -19
  82. package/_modules/components/OrdersControlFilters/index.js +16 -17
  83. package/_modules/components/OrdersDashboardComponents/Appointments/index.js +14 -15
  84. package/_modules/components/OrdersDashboardComponents/BusinessProductsListing/index.js +54 -55
  85. package/_modules/components/OrdersDashboardComponents/CheckPassword/index.js +35 -36
  86. package/_modules/components/OrdersDashboardComponents/CityList/index.js +31 -32
  87. package/_modules/components/OrdersDashboardComponents/CountryList/index.js +31 -32
  88. package/_modules/components/OrdersDashboardComponents/CustomOrderDetails/index.js +25 -26
  89. package/_modules/components/OrdersDashboardComponents/DashboardBusinessList/index.js +78 -79
  90. package/_modules/components/OrdersDashboardComponents/DashboardOrdersList/index.js +79 -80
  91. package/_modules/components/OrdersDashboardComponents/DriversList/index.js +70 -71
  92. package/_modules/components/OrdersDashboardComponents/ExportCSV/index.js +27 -28
  93. package/_modules/components/OrdersDashboardComponents/GiftCardsList/index.js +17 -18
  94. package/_modules/components/OrdersDashboardComponents/GoogleMapsApiKeySetting/index.js +17 -18
  95. package/_modules/components/OrdersDashboardComponents/LogisticInformation/index.js +30 -31
  96. package/_modules/components/OrdersDashboardComponents/Logistics/index.js +30 -31
  97. package/_modules/components/OrdersDashboardComponents/Messages/index.js +41 -42
  98. package/_modules/components/OrdersDashboardComponents/MetaFields/index.js +38 -39
  99. package/_modules/components/OrdersDashboardComponents/OrderDetails/index.js +55 -56
  100. package/_modules/components/OrdersDashboardComponents/OrderNotification/index.js +19 -20
  101. package/_modules/components/OrdersDashboardComponents/OrdersFilter/index.js +72 -73
  102. package/_modules/components/OrdersDashboardComponents/OrdersManage/index.js +78 -79
  103. package/_modules/components/OrdersDashboardComponents/PointsWalletLevels/index.js +36 -37
  104. package/_modules/components/OrdersDashboardComponents/ReviewCustomer/index.js +26 -27
  105. package/_modules/components/OrdersDashboardComponents/Schedule/index.js +55 -56
  106. package/_modules/components/OrdersDashboardComponents/SettingsList/index.js +53 -54
  107. package/_modules/components/OrdersDashboardComponents/UserFormDetails/index.js +77 -78
  108. package/_modules/components/OrdersDashboardComponents/UsersList/index.js +77 -78
  109. package/_modules/components/OrdersDashboardComponents/WebsocketStatus/index.js +9 -10
  110. package/_modules/components/PageBanner/index.js +22 -23
  111. package/_modules/components/PaymentOptionCash/index.js +25 -26
  112. package/_modules/components/PaymentOptionPaypal/index.js +35 -36
  113. package/_modules/components/PaymentOptionSquare/index.js +13 -14
  114. package/_modules/components/PaymentOptionStripe/index.js +45 -46
  115. package/_modules/components/PaymentOptionStripeDirect/index.js +30 -31
  116. package/_modules/components/PaymentOptionStripeRedirect/StripeRedirectForm/index.js +22 -23
  117. package/_modules/components/PaymentOptionStripeRedirect/index.js +36 -37
  118. package/_modules/components/PaymentOptionWallet/index.js +12 -13
  119. package/_modules/components/PaymentOptions/index.js +40 -41
  120. package/_modules/components/PaymethodList/index.js +30 -31
  121. package/_modules/components/PhoneAutocomplete/index.js +37 -38
  122. package/_modules/components/PlaceSpot/index.js +16 -17
  123. package/_modules/components/Popup/index.js +38 -39
  124. package/_modules/components/ProductComponent/index.js +32 -33
  125. package/_modules/components/ProductForm/index.js +172 -173
  126. package/_modules/components/ProductImages/index.js +19 -20
  127. package/_modules/components/ProductIngredient/index.js +18 -19
  128. package/_modules/components/ProductOption/index.js +9 -10
  129. package/_modules/components/ProductOptionSuboption/index.js +42 -43
  130. package/_modules/components/ProductShare/index.js +25 -27
  131. package/_modules/components/ProductsList/index.js +25 -26
  132. package/_modules/components/ProductsListing/index.js +49 -50
  133. package/_modules/components/ProfessionalInfo/index.js +34 -35
  134. package/_modules/components/PromotionsController/index.js +11 -12
  135. package/_modules/components/QueryLoginSpoonity/index.js +34 -35
  136. package/_modules/components/ReCaptcha/index.js +9 -10
  137. package/_modules/components/ResetPassword/index.js +30 -31
  138. package/_modules/components/ReviewCustomer/index.js +26 -27
  139. package/_modules/components/ReviewDriver/index.js +35 -36
  140. package/_modules/components/ReviewProduct/index.js +37 -38
  141. package/_modules/components/SearchOptions/index.js +22 -23
  142. package/_modules/components/Sessions/index.js +32 -33
  143. package/_modules/components/SignupForm/index.js +83 -84
  144. package/_modules/components/SingleBusinessCard/index.js +29 -30
  145. package/_modules/components/SingleOrderCard/index.js +32 -33
  146. package/_modules/components/SingleProductCard/index.js +28 -29
  147. package/_modules/components/SingleProfessionalCard/index.js +28 -29
  148. package/_modules/components/SmartAppBanner/index.js +16 -17
  149. package/_modules/components/StoreProductList/index.js +50 -51
  150. package/_modules/components/StripeElementsForm/CardForm/index.js +45 -46
  151. package/_modules/components/StripeElementsForm/index.js +22 -23
  152. package/_modules/components/UpsellingPage/index.js +27 -28
  153. package/_modules/components/UserFormDetails/index.js +97 -98
  154. package/_modules/components/UserVerification/index.js +31 -32
  155. package/_modules/components/WalletList/index.js +11 -12
  156. package/_modules/components/WebsocketStatus/index.js +9 -10
  157. package/_modules/components/WrapperGoogleMaps/index.js +8 -9
  158. package/_modules/constants/code-numbers.js +2 -3
  159. package/_modules/constants/timezones.js +2 -3
  160. package/_modules/contexts/ApiContext/index.js +20 -23
  161. package/_modules/contexts/BillingContext/index.js +13 -15
  162. package/_modules/contexts/BusinessContext/index.js +24 -27
  163. package/_modules/contexts/ConfigContext/index.js +27 -39
  164. package/_modules/contexts/CustomerContext/index.js +15 -18
  165. package/_modules/contexts/EventContext/index.js +16 -19
  166. package/_modules/contexts/LanguageContext/index.js +29 -32
  167. package/_modules/contexts/OptimizationLoadContext/index.js +23 -26
  168. package/_modules/contexts/OrderContext/index.js +135 -139
  169. package/_modules/contexts/OrderingContext/index.js +13 -15
  170. package/_modules/contexts/OrderingThemeContext/index.js +24 -27
  171. package/_modules/contexts/ProductContext/index.js +25 -29
  172. package/_modules/contexts/SessionContext/index.js +24 -27
  173. package/_modules/contexts/SiteContext/index.js +22 -25
  174. package/_modules/contexts/ToastContext/index.js +8 -10
  175. package/_modules/contexts/UtilsContext/index.js +26 -29
  176. package/_modules/contexts/ValidationsFieldsContext/index.js +16 -19
  177. package/_modules/contexts/WebsocketContext/index.js +23 -26
  178. package/_modules/contexts/WebsocketContext/socket.js +5 -6
  179. package/_modules/native/src/NativeStrategy/index.js +6 -7
  180. package/_modules/native/src/contexts/OrderingContext/index.js +13 -15
  181. package/_modules/utils/index.js +3 -5
  182. package/_modules/webStrategy/index.js +6 -7
  183. package/cypress/fixtures/example.json +4 -4
  184. package/cypress/integration/naked/BusinessProductsCategories.spec.js +9 -9
  185. package/cypress/integration/naked/PhoneAutocomplete.spec.js +22 -22
  186. package/cypress/integration/naked/activeOrders.spec.js +15 -15
  187. package/cypress/integration/naked/addressDetails.spec.js +10 -10
  188. package/cypress/integration/naked/appleLogin.spec.js +14 -14
  189. package/cypress/integration/naked/businessBasicInformation.spec.js +14 -14
  190. package/cypress/integration/naked/businessController.spec.js +9 -9
  191. package/cypress/integration/naked/businessInformation.spec.js +19 -19
  192. package/cypress/integration/naked/businessProductsSearch.spec.js +9 -9
  193. package/cypress/integration/naked/businessReviews.spec.js +16 -16
  194. package/cypress/integration/naked/businessSortControl.spec.js +9 -9
  195. package/cypress/integration/naked/businessTypeFilter.spec.js +10 -10
  196. package/cypress/integration/naked/businessesMap.spec.js +13 -13
  197. package/cypress/integration/naked/cms.spec.js +9 -9
  198. package/cypress/integration/naked/config.spec.js +34 -34
  199. package/cypress/integration/naked/driverTips.spec.js +10 -10
  200. package/cypress/integration/naked/events.spec.js +13 -13
  201. package/cypress/integration/naked/facebookLogin.spec.js +13 -13
  202. package/cypress/integration/naked/floatingButton.spec.js +13 -13
  203. package/cypress/integration/naked/forgotPassword.spec.js +20 -20
  204. package/cypress/integration/naked/googleLogin.spec.js +11 -11
  205. package/cypress/integration/naked/languageExamples.spec.js +25 -25
  206. package/cypress/integration/naked/languageSelector.spec.js +10 -10
  207. package/cypress/integration/naked/login.spec.js +38 -38
  208. package/cypress/integration/naked/logout.spec.js +15 -15
  209. package/cypress/integration/naked/mainSearch.spec.js +9 -9
  210. package/cypress/integration/naked/menuControl.spec.js +9 -9
  211. package/cypress/integration/naked/messages.spec.js +25 -25
  212. package/cypress/integration/naked/momentOption.spec.js +10 -10
  213. package/cypress/integration/naked/myOrders.spec.js +11 -11
  214. package/cypress/integration/naked/myOrdersList.spec.js +9 -9
  215. package/cypress/integration/naked/orderContextAdvanced.spec.js +23 -23
  216. package/cypress/integration/naked/orderDetails.spec.js +11 -11
  217. package/cypress/integration/naked/paymentOptionCash.spec.js +21 -21
  218. package/cypress/integration/naked/paymentOptionStripe.spec.js +11 -11
  219. package/cypress/integration/naked/paymentOptionStripeDirect.spec.js +11 -11
  220. package/cypress/integration/naked/paymentOptions.spec.js +9 -9
  221. package/cypress/integration/naked/popupExample.spec.js +17 -17
  222. package/cypress/integration/naked/productImages.spec.js +11 -11
  223. package/cypress/integration/naked/productOptionExample.spec.js +21 -21
  224. package/cypress/integration/naked/productShare.spec.js +9 -9
  225. package/cypress/integration/naked/productsList.spec.js +9 -9
  226. package/cypress/integration/naked/resetPassword.spec.js +11 -11
  227. package/cypress/integration/naked/reviewOrders.spec.js +13 -13
  228. package/cypress/integration/naked/searchOptions.spec.js +18 -18
  229. package/cypress/integration/naked/signup.spec.js +31 -31
  230. package/cypress/integration/naked/upselling.spec.js +13 -13
  231. package/cypress/integration/naked/userDetails.spec.js +12 -12
  232. package/cypress/plugins/index.js +21 -21
  233. package/cypress/support/commands.js +35 -35
  234. package/cypress/support/index.js +20 -20
  235. package/cypress.json +12 -12
  236. package/example/App.js +263 -263
  237. package/example/components/ActiveOrdersUI/index.js +72 -72
  238. package/example/components/AddressDetailsUI/index.js +101 -101
  239. package/example/components/AddressFormUI/index.js +161 -161
  240. package/example/components/AddressListUI/index.js +33 -33
  241. package/example/components/AlertPopup/index.js +10 -10
  242. package/example/components/AlertUI/index.js +49 -49
  243. package/example/components/AlertUI/style.css +5 -5
  244. package/example/components/AppleLoginUI/index.js +40 -40
  245. package/example/components/BaseComponentUI/index.js +34 -34
  246. package/example/components/BusinessBasicInformationUI/index.js +118 -118
  247. package/example/components/BusinessControllerUI/index.js +89 -89
  248. package/example/components/BusinessInformationUI/BusinessOptionUI/index.js +83 -83
  249. package/example/components/BusinessInformationUI/index.js +83 -83
  250. package/example/components/BusinessProductsCategoriesUI/index.js +42 -42
  251. package/example/components/BusinessProductsSearchUI/index.js +38 -38
  252. package/example/components/BusinessReviewsUI/index.js +77 -77
  253. package/example/components/BusinessSortControlUI/index.js +47 -47
  254. package/example/components/BusinessTypeFilterUI/index.js +53 -53
  255. package/example/components/BusinessesMapUI/index.js +57 -57
  256. package/example/components/CartUI/index.js +154 -154
  257. package/example/components/ChangeView/index.js +19 -19
  258. package/example/components/CheckoutUI/index.js +206 -206
  259. package/example/components/CmsContentUI/index.js +52 -52
  260. package/example/components/ConfigsExample/index.js +118 -118
  261. package/example/components/CouponControlUI/index.js +63 -63
  262. package/example/components/DriverTipsUI/index.js +58 -58
  263. package/example/components/FacebookLoginButtonUI/index.js +48 -48
  264. package/example/components/FloatingButtonUI/index.js +145 -145
  265. package/example/components/ForgotPasswordFormUI/index.js +93 -93
  266. package/example/components/GoogleLoginUI/index.js +30 -30
  267. package/example/components/GpsButtonUI/index.js +22 -22
  268. package/example/components/Header/index.js +18 -18
  269. package/example/components/LanguageSelectorUI/index.js +57 -57
  270. package/example/components/LanguagesExample/index.js +51 -51
  271. package/example/components/LoginFormUI/index.js +159 -159
  272. package/example/components/LogoutButtonUI/index.js +21 -21
  273. package/example/components/MainSearchUI/index.js +131 -131
  274. package/example/components/MenuControlUI/index.js +103 -103
  275. package/example/components/MessagesUI/index.js +162 -162
  276. package/example/components/ModalUI/index.js +36 -36
  277. package/example/components/ModalUI/style.css +5 -5
  278. package/example/components/MomentOptionUI/index.js +68 -68
  279. package/example/components/MyOrdersListUI/index.js +51 -51
  280. package/example/components/MyOrdersUI/index.js +52 -52
  281. package/example/components/OrderChangeUI/index.js +54 -54
  282. package/example/components/OrderDetailsUI/index.js +174 -174
  283. package/example/components/OrderReviewUI/index.js +125 -125
  284. package/example/components/OrderTypeControlUI/index.js +32 -32
  285. package/example/components/PaymentOptionCashUI/index.js +60 -60
  286. package/example/components/PaymentOptionPaypalUI/index.js +50 -50
  287. package/example/components/PaymentOptionStripeDirectUI/index.js +89 -89
  288. package/example/components/PaymentOptionStripeRedirectUI/index.js +97 -97
  289. package/example/components/PaymentOptionStripeUI/index.js +129 -129
  290. package/example/components/PaymentOptionsUI/index.js +169 -169
  291. package/example/components/PhoneAutocompleteUI/index.js +67 -67
  292. package/example/components/PhoneAutocompleteUI/styles.css +49 -49
  293. package/example/components/ProductComponentUI/index.js +113 -113
  294. package/example/components/ProductFormUI/index.js +131 -131
  295. package/example/components/ProductImagesUI/index.js +82 -82
  296. package/example/components/ProductIngredientUI/index.js +21 -21
  297. package/example/components/ProductOptionSuboptionUI/index.js +65 -65
  298. package/example/components/ProductOptionUI/index.js +31 -31
  299. package/example/components/ProductShareUI/index.js +48 -48
  300. package/example/components/ProductsListUI/index.js +108 -108
  301. package/example/components/ProductsListingUI/index.js +42 -42
  302. package/example/components/ResetPasswordUI/index.js +121 -121
  303. package/example/components/SearchOptionsUI/index.js +82 -82
  304. package/example/components/SignupFormUI/index.js +117 -117
  305. package/example/components/SingleBusinessCardUI/index.js +82 -82
  306. package/example/components/SingleOrderCardUI/index.js +52 -52
  307. package/example/components/SingleProductCardUI/index.js +47 -47
  308. package/example/components/StripeElementsFormUI/CardFormUI/index.js +51 -51
  309. package/example/components/StripeElementsFormUI/CardFormUI/style.css +118 -118
  310. package/example/components/StripeElementsFormUI/index.js +38 -38
  311. package/example/components/StripeRedirectFormUI/index.js +99 -99
  312. package/example/components/TestComponent/index.js +5 -5
  313. package/example/components/UpsellingPageUI/index.js +26 -26
  314. package/example/components/UserDetailsUI/index.js +94 -94
  315. package/example/components/UserProfileUI/index.js +156 -156
  316. package/example/views/ActiveOrders/index.js +86 -86
  317. package/example/views/AddressDetailsExample/index.js +57 -57
  318. package/example/views/AppleLoginExample/index.js +51 -51
  319. package/example/views/BaseComponentExample/index.js +35 -35
  320. package/example/views/BusinessBasicInformationExample/index.js +43 -43
  321. package/example/views/BusinessControllerExample/index.js +55 -55
  322. package/example/views/BusinessInformationExample/index.js +68 -68
  323. package/example/views/BusinessProductsCategoriesExample/index.js +50 -50
  324. package/example/views/BusinessProductsSearchExample/index.js +39 -39
  325. package/example/views/BusinessReviewsExample/index.js +43 -43
  326. package/example/views/BusinessSortControlExample/index.js +53 -53
  327. package/example/views/BusinessTypeFilterExample/index.js +53 -53
  328. package/example/views/BusinessesMapExample/index.js +57 -57
  329. package/example/views/CheckoutExample/index.js +143 -143
  330. package/example/views/CmsContentExample/index.js +44 -44
  331. package/example/views/DriverTipsExample/index.js +47 -47
  332. package/example/views/EventsExample/index.js +26 -26
  333. package/example/views/FacebookLogin/index.js +63 -63
  334. package/example/views/FloatingButtonExample/index.js +47 -47
  335. package/example/views/ForgotPassword/index.js +77 -77
  336. package/example/views/GoogleLoginExample/index.js +85 -85
  337. package/example/views/Home/index.js +200 -200
  338. package/example/views/LanguageSelectorExample/index.js +55 -55
  339. package/example/views/Login/index.js +84 -84
  340. package/example/views/MainSearchExample/index.js +43 -43
  341. package/example/views/MenuControlExample/index.js +68 -68
  342. package/example/views/MessagesExample/index.js +58 -58
  343. package/example/views/MomentOptionExample/index.js +52 -52
  344. package/example/views/MyOrdersExample/index.js +35 -35
  345. package/example/views/MyOrdersListExample/index.js +50 -50
  346. package/example/views/OrderChangeExample/index.js +46 -46
  347. package/example/views/OrderContextExample/index.js +139 -139
  348. package/example/views/OrderDetailsExample/index.js +50 -50
  349. package/example/views/OrderReviewExample/index.js +64 -64
  350. package/example/views/PaymentOptionCashExample/index.js +51 -51
  351. package/example/views/PaymentOptionPaypalExample/index.js +71 -71
  352. package/example/views/PaymentOptionStripeDirectExample/index.js +43 -43
  353. package/example/views/PaymentOptionStripeExample/index.js +47 -47
  354. package/example/views/PaymentOptionStripeRedirectExample/index.js +56 -56
  355. package/example/views/PaymentOptionsExample/index.js +47 -47
  356. package/example/views/PhoneAutocompleteExample/index.js +34 -34
  357. package/example/views/PlacesExample/index.js +94 -94
  358. package/example/views/PopupExample/index.js +78 -78
  359. package/example/views/PopupExample/style.css +18 -18
  360. package/example/views/ProductDetail/index.js +323 -323
  361. package/example/views/ProductImagesExample/index.js +43 -43
  362. package/example/views/ProductOptionExample/index.js +88 -88
  363. package/example/views/ProductShareExample/index.js +51 -51
  364. package/example/views/ProductsListExample/index.js +77 -77
  365. package/example/views/ProductsListingExample/index.js +47 -47
  366. package/example/views/ResetPasswordExample/index.js +60 -60
  367. package/example/views/SearchOptionsExample/index.js +42 -42
  368. package/example/views/SessionManager/index.js +122 -122
  369. package/example/views/Signup/index.js +64 -64
  370. package/example/views/UpsellingPageExample/index.js +35 -35
  371. package/example/views/UserDetailsExample/index.js +69 -69
  372. package/example/views/UserProfile/index.js +73 -73
  373. package/index-example.js +37 -37
  374. package/index.html +13 -13
  375. package/native/index.js +255 -255
  376. package/native/src/NativeStrategy/index.js +20 -20
  377. package/native/src/contexts/OrderingContext/index.js +85 -85
  378. package/package.json +94 -94
  379. package/src/components/AddressDetails/index.js +149 -149
  380. package/src/components/AddressForm/index.js +333 -333
  381. package/src/components/AddressList/index.js +212 -212
  382. package/src/components/Analitycs/index.js +119 -119
  383. package/src/components/AnalyticsSegment/index.js +136 -136
  384. package/src/components/AppleLogin/index.js +164 -164
  385. package/src/components/BaseComponent/index.js +52 -52
  386. package/src/components/BusinessAndProductList/index.js +981 -981
  387. package/src/components/BusinessBasicInformation/index.js +119 -119
  388. package/src/components/BusinessController/index.js +351 -351
  389. package/src/components/BusinessInformation/BusinessOption/index.js +86 -86
  390. package/src/components/BusinessInformation/index.js +93 -93
  391. package/src/components/BusinessList/index.js +670 -670
  392. package/src/components/BusinessMenuListing/index.js +99 -99
  393. package/src/components/BusinessProductsCategories/index.js +60 -60
  394. package/src/components/BusinessProductsSearch/index.js +54 -54
  395. package/src/components/BusinessReviews/index.js +187 -187
  396. package/src/components/BusinessSearchList/index.js +363 -363
  397. package/src/components/BusinessSortControl/index.js +100 -100
  398. package/src/components/BusinessTypeFilter/index.js +142 -142
  399. package/src/components/BusinessesMap/index.js +110 -110
  400. package/src/components/Cart/index.js +210 -210
  401. package/src/components/CartStoresListing/index.js +157 -157
  402. package/src/components/Checkout/index.js +618 -618
  403. package/src/components/CmsContent/index.js +97 -97
  404. package/src/components/Contacts/index.js +512 -512
  405. package/src/components/CouponControl/index.js +171 -171
  406. package/src/components/DragAndDrop/index.js +41 -41
  407. package/src/components/DriverList/index.js +112 -112
  408. package/src/components/DriverTips/index.js +141 -141
  409. package/src/components/Emitter/index.js +36 -36
  410. package/src/components/ExamineClick/index.js +40 -40
  411. package/src/components/FacebookLoginButton/index.js +214 -214
  412. package/src/components/FacebookPixel/index.js +148 -148
  413. package/src/components/FavoriteList/index.js +268 -268
  414. package/src/components/FirebaseGoogleLoginButton/index.js +93 -93
  415. package/src/components/FloatingButton/index.js +70 -70
  416. package/src/components/ForgotPasswordForm/index.js +180 -180
  417. package/src/components/GiftCard/GiftCardOrdersList/index.js +155 -155
  418. package/src/components/GiftCard/PurchaseGiftCard/index.js +123 -123
  419. package/src/components/GiftCard/RedeemGiftCard/index.js +73 -73
  420. package/src/components/GiftCard/SendGiftCard/index.js +78 -78
  421. package/src/components/GoogleAutocompleteInput/index.js +154 -154
  422. package/src/components/GoogleIdentity/index.js +144 -144
  423. package/src/components/GoogleLoginButton/index.js +276 -276
  424. package/src/components/GoogleMaps/index.js +489 -489
  425. package/src/components/GpsButton/index.js +127 -127
  426. package/src/components/LanguageSelector/index.js +163 -163
  427. package/src/components/LoginForm/index.js +521 -521
  428. package/src/components/LogoutAction/index.js +165 -165
  429. package/src/components/MainSearch/index.js +149 -149
  430. package/src/components/MapView/index.js +110 -110
  431. package/src/components/MenuControl/index.js +238 -238
  432. package/src/components/Messages/index.js +166 -166
  433. package/src/components/MomentOption/index.js +322 -322
  434. package/src/components/MultiCartCreate/index.js +70 -70
  435. package/src/components/MultiCartsPaymethodsAndWallets/index.js +201 -201
  436. package/src/components/MultiCheckout/index.js +371 -371
  437. package/src/components/MultiOrdersDetails/index.js +109 -109
  438. package/src/components/MyOrders/index.js +150 -150
  439. package/src/components/MyOrdersList/index.js +104 -104
  440. package/src/components/NewOrderNotification/index.js +30 -30
  441. package/src/components/OrderChange/index.js +128 -128
  442. package/src/components/OrderDetails/index.js +684 -684
  443. package/src/components/OrderList/index.js +781 -781
  444. package/src/components/OrderListGroups/index.js +1168 -1168
  445. package/src/components/OrderReview/index.js +180 -180
  446. package/src/components/OrderTypeControl/index.js +75 -75
  447. package/src/components/OrderVerticalList/index.js +422 -422
  448. package/src/components/OrdersControlFilters/index.js +75 -75
  449. package/src/components/OrdersDashboardComponents/Appointments/index.js +72 -72
  450. package/src/components/OrdersDashboardComponents/BusinessProductsListing/index.js +629 -629
  451. package/src/components/OrdersDashboardComponents/CheckPassword/index.js +177 -177
  452. package/src/components/OrdersDashboardComponents/CityList/index.js +98 -98
  453. package/src/components/OrdersDashboardComponents/CountryList/index.js +162 -162
  454. package/src/components/OrdersDashboardComponents/CustomOrderDetails/index.js +238 -238
  455. package/src/components/OrdersDashboardComponents/DashboardBusinessList/index.js +617 -617
  456. package/src/components/OrdersDashboardComponents/DashboardOrdersList/index.js +943 -943
  457. package/src/components/OrdersDashboardComponents/DriversList/index.js +448 -448
  458. package/src/components/OrdersDashboardComponents/ExportCSV/index.js +192 -192
  459. package/src/components/OrdersDashboardComponents/GiftCardsList/index.js +189 -189
  460. package/src/components/OrdersDashboardComponents/GoogleMapsApiKeySetting/index.js +77 -77
  461. package/src/components/OrdersDashboardComponents/LogisticInformation/index.js +97 -97
  462. package/src/components/OrdersDashboardComponents/Logistics/index.js +174 -174
  463. package/src/components/OrdersDashboardComponents/Messages/index.js +384 -384
  464. package/src/components/OrdersDashboardComponents/MetaFields/index.js +186 -186
  465. package/src/components/OrdersDashboardComponents/OrderDetails/index.js +404 -404
  466. package/src/components/OrdersDashboardComponents/OrderNotification/index.js +70 -70
  467. package/src/components/OrdersDashboardComponents/OrdersFilter/index.js +362 -362
  468. package/src/components/OrdersDashboardComponents/OrdersManage/index.js +873 -873
  469. package/src/components/OrdersDashboardComponents/PointsWalletLevels/index.js +123 -123
  470. package/src/components/OrdersDashboardComponents/ReviewCustomer/index.js +113 -113
  471. package/src/components/OrdersDashboardComponents/Schedule/index.js +315 -315
  472. package/src/components/OrdersDashboardComponents/SettingsList/index.js +298 -298
  473. package/src/components/OrdersDashboardComponents/UserFormDetails/index.js +463 -463
  474. package/src/components/OrdersDashboardComponents/UsersList/index.js +944 -944
  475. package/src/components/OrdersDashboardComponents/WebsocketStatus/index.js +77 -77
  476. package/src/components/OrdersDashboardComponents/index.js +57 -57
  477. package/src/components/PageBanner/index.js +107 -107
  478. package/src/components/PaymentOptionCash/index.js +74 -74
  479. package/src/components/PaymentOptionPaypal/index.js +146 -146
  480. package/src/components/PaymentOptionSquare/index.js +336 -336
  481. package/src/components/PaymentOptionStripe/index.js +289 -289
  482. package/src/components/PaymentOptionStripeDirect/index.js +116 -116
  483. package/src/components/PaymentOptionStripeRedirect/StripeRedirectForm/index.js +71 -71
  484. package/src/components/PaymentOptionStripeRedirect/index.js +122 -122
  485. package/src/components/PaymentOptionWallet/index.js +185 -185
  486. package/src/components/PaymentOptions/index.js +248 -248
  487. package/src/components/PaymethodList/index.js +119 -119
  488. package/src/components/PhoneAutocomplete/index.js +311 -311
  489. package/src/components/PlaceSpot/index.js +176 -176
  490. package/src/components/Popup/index.js +169 -169
  491. package/src/components/ProductComponent/index.js +269 -269
  492. package/src/components/ProductForm/index.js +1090 -1090
  493. package/src/components/ProductImages/index.js +64 -64
  494. package/src/components/ProductIngredient/index.js +72 -72
  495. package/src/components/ProductOption/index.js +42 -42
  496. package/src/components/ProductOptionSuboption/index.js +180 -180
  497. package/src/components/ProductShare/index.js +97 -97
  498. package/src/components/ProductsList/index.js +74 -74
  499. package/src/components/ProductsListing/index.js +166 -166
  500. package/src/components/ProfessionalInfo/index.js +156 -156
  501. package/src/components/PromotionsController/index.js +123 -123
  502. package/src/components/QueryLoginSpoonity/index.js +159 -159
  503. package/src/components/ReCaptcha/index.js +53 -53
  504. package/src/components/ResetPassword/index.js +111 -111
  505. package/src/components/ReviewCustomer/index.js +117 -117
  506. package/src/components/ReviewDriver/index.js +157 -157
  507. package/src/components/ReviewProduct/index.js +162 -162
  508. package/src/components/SearchOptions/index.js +69 -69
  509. package/src/components/Sessions/index.js +217 -217
  510. package/src/components/SignupForm/index.js +547 -547
  511. package/src/components/SingleBusinessCard/index.js +80 -80
  512. package/src/components/SingleOrderCard/index.js +160 -160
  513. package/src/components/SingleProductCard/index.js +130 -130
  514. package/src/components/SingleProfessionalCard/index.js +121 -121
  515. package/src/components/SmartAppBanner/index.js +71 -71
  516. package/src/components/StoreProductList/index.js +303 -303
  517. package/src/components/StripeElementsForm/CardForm/index.js +248 -248
  518. package/src/components/StripeElementsForm/index.js +78 -78
  519. package/src/components/UpsellingPage/index.js +120 -120
  520. package/src/components/UserFormDetails/index.js +688 -688
  521. package/src/components/UserVerification/index.js +242 -242
  522. package/src/components/WalletList/index.js +160 -160
  523. package/src/components/WebsocketStatus/index.js +80 -80
  524. package/src/components/WrapperGoogleMaps/index.js +67 -67
  525. package/src/constants/code-numbers.js +218 -218
  526. package/src/constants/timezones.js +427 -427
  527. package/src/contexts/ApiContext/index.js +59 -59
  528. package/src/contexts/BillingContext/index.js +28 -28
  529. package/src/contexts/BusinessContext/index.js +71 -71
  530. package/src/contexts/ConfigContext/index.js +215 -215
  531. package/src/contexts/CustomerContext/index.js +69 -69
  532. package/src/contexts/EventContext/index.js +31 -31
  533. package/src/contexts/LanguageContext/index.js +144 -144
  534. package/src/contexts/OptimizationLoadContext/index.js +95 -95
  535. package/src/contexts/OrderContext/index.js +1448 -1448
  536. package/src/contexts/OrderingContext/index.js +86 -86
  537. package/src/contexts/OrderingThemeContext/index.js +107 -107
  538. package/src/contexts/ProductContext/index.js +62 -62
  539. package/src/contexts/SessionContext/index.js +172 -172
  540. package/src/contexts/SiteContext/index.js +79 -79
  541. package/src/contexts/ToastContext/index.js +42 -42
  542. package/src/contexts/UtilsContext/index.js +352 -352
  543. package/src/contexts/ValidationsFieldsContext/index.js +65 -65
  544. package/src/contexts/WebsocketContext/index.js +91 -91
  545. package/src/contexts/WebsocketContext/socket.js +92 -92
  546. package/src/index.js +369 -369
  547. package/src/utils/index.js +32 -32
  548. package/src/webStrategy/index.js +18 -18
  549. package/webpack.dev.js +41 -41
  550. package/webpack.prod.js +64 -64
  551. package/_bundles/0.ordering-component.ddd8b5557b901fb64803.js +0 -1
  552. package/_bundles/7.ordering-component.ddd8b5557b901fb64803.js +0 -2
  553. package/_bundles/ordering-component.ddd8b5557b901fb64803.js +0 -2
  554. /package/_bundles/{7.ordering-component.ddd8b5557b901fb64803.js.LICENSE.txt → 7.ordering-component.3760baa5b9906f197b42.js.LICENSE.txt} +0 -0
@@ -1,1448 +1,1448 @@
1
- import React, { createContext, useContext, useState, useEffect } from 'react'
2
- import { useSession } from '../SessionContext'
3
- import { useApi } from '../ApiContext'
4
- import { useWebsocket } from '../WebsocketContext'
5
- import { useLanguage } from '../LanguageContext'
6
- import { useEvent } from '../EventContext'
7
- import { useConfig } from '../ConfigContext'
8
- import { useCustomer } from '../CustomerContext'
9
- import { ToastType, useToast } from '../ToastContext'
10
- import dayjs from 'dayjs'
11
- import utc from 'dayjs/plugin/utc'
12
-
13
- dayjs.extend(utc)
14
-
15
- /**
16
- * Create OrderContext
17
- * This context will manage the current order with options internally and provide an easy interface
18
- */
19
- export const OrderContext = createContext()
20
-
21
- /**
22
- * Custom provider to order manager
23
- * This provider has a reducer for manage order state
24
- * @param {props} props
25
- */
26
- export const OrderProvider = ({ Alert, children, strategy, isAlsea, isDisableToast, franchiseId, isDisabledDefaultOpts, businessSlug, userAgent }) => {
27
- const [confirmAlert, setConfirm] = useState({ show: false })
28
- const [alert, setAlert] = useState({ show: false })
29
- const [ordering] = useApi()
30
- const socket = useWebsocket()
31
- const [languageState, t] = useLanguage()
32
- const [events] = useEvent()
33
- const [configState] = useConfig()
34
- const [session, { logout }] = useSession()
35
- const [customerState, { setUserCustomer }] = useCustomer()
36
- const [, { showToast }] = useToast()
37
-
38
- const configTypes = configState?.configs?.order_types_allowed?.value.split('|').map(value => Number(value)) || []
39
-
40
- const orderTypes = {
41
- delivery: 1,
42
- pickup: 2,
43
- eatin: 3,
44
- curbside: 4,
45
- drivethru: 5
46
- }
47
-
48
- const [state, setState] = useState({
49
- loading: true,
50
- options: isDisabledDefaultOpts
51
- ? { type: null, moment: null, city_id: null }
52
- : {
53
- type: orderTypes[configState?.configs?.default_order_type?.value],
54
- moment: null,
55
- city_id: null
56
- },
57
- carts: {},
58
- confirmAlert,
59
- alert
60
- })
61
-
62
- /**
63
- * Refresh order options and carts from API
64
- */
65
- const refreshOrderOptions = async () => {
66
- try {
67
- if (!state.loading) {
68
- setState({ ...state, loading: true })
69
- }
70
- const countryCodeFromLocalStorage = await strategy.getItem('country-code')
71
- const customerFromLocalStorage = await strategy.getItem('user-customer', true)
72
- const userCustomerId = customerFromLocalStorage?.id
73
- const options = {}
74
- if (userCustomerId) {
75
- options.query = {
76
- user_id: userCustomerId
77
- }
78
- }
79
- if (franchiseId) {
80
- options.query = {
81
- ...options.query,
82
- franchise_id: franchiseId
83
- }
84
- }
85
-
86
- const countryCode = countryCodeFromLocalStorage && countryCodeFromLocalStorage !== state?.options?.address?.country_code
87
- ? countryCodeFromLocalStorage
88
- : state?.options?.address?.country_code
89
-
90
- if (countryCode) {
91
- options.headers = {
92
- 'X-Socket-Id-X': socket?.getId(),
93
- 'X-Country-Code-X': countryCode
94
- }
95
- }
96
-
97
- const res = await ordering.setAccessToken(session.token).orderOptions().get(options)
98
- const error = res?.content?.error
99
- const result = res?.content?.result
100
-
101
- if (!error) {
102
- const { carts, ...options } = result
103
- state.carts = {}
104
- carts.forEach(cart => {
105
- state.carts[`businessId:${cart.business_id}`] = cart
106
- })
107
- state.options = {
108
- ...state.options,
109
- ...options
110
- }
111
-
112
- if (!countryCodeFromLocalStorage && options?.address?.country_code) {
113
- await updateOrderOptions({ country_code: options?.address?.country_code })
114
- }
115
- }
116
- if (error) {
117
- setAlert({ show: true, content: result })
118
- if (res?.status === 401) {
119
- session.auth && logout()
120
- }
121
- }
122
- const localOptions = await strategy.getItem('options', true)
123
- if (localOptions) {
124
- const options = {}
125
- if (Object.keys(localOptions.address).length > 0) {
126
- const conditions = [
127
- { attribute: 'address', value: localOptions?.address?.address }
128
- ]
129
- const userId = userCustomerId || session.user.id
130
- const addressesResponse = await ordering.setAccessToken(session.token).users(userId).addresses().where(conditions).get()
131
- let address = addressesResponse.content.result.find(address => {
132
- localOptions.address.internal_number = localOptions.address?.internal_number || null
133
- localOptions.address.zipcode = localOptions.address?.zipcode || null
134
- localOptions.address.address_notes = localOptions.address?.address_notes || null
135
-
136
- return address?.location?.lat === localOptions?.address?.location.lat &&
137
- address?.location?.lng === localOptions?.address?.location?.lng &&
138
- address?.internal_number === localOptions?.address?.internal_number &&
139
- address?.zipcode === localOptions?.address?.zipcode &&
140
- address?.address_notes === localOptions?.address?.address_notes
141
- })
142
- if (!address) {
143
- Object.keys(localOptions.address).forEach(key => localOptions?.address?.[key] === null && delete localOptions?.address?.[key])
144
- const { content: { error, result } } = await ordering.setAccessToken(session.token).users(userId).addresses().save(localOptions.address)
145
- if (!error) {
146
- address = result
147
- }
148
- } else {
149
- await ordering.setAccessToken(session.token).users(userId).addresses(address.id).save({ default: true })
150
- }
151
- address && (options.address_id = address.id)
152
- }
153
- if (localOptions.type) {
154
- options.type = localOptions.type
155
- }
156
- if (localOptions.moment) {
157
- options.moment = dayjs.utc(localOptions.moment, 'YYYY-MM-DD HH:mm:ss').unix()
158
- }
159
- if (localOptions?.address_id) {
160
- options.address_id = localOptions?.address_id
161
- }
162
- if (localOptions?.city_id) {
163
- options.city_id = localOptions?.city_id
164
- }
165
- if (options && Object.keys(options).length > 0) {
166
- updateOrderOptions(options)
167
- } else {
168
- setState({ ...state, loading: false })
169
- }
170
- await strategy.removeItem('options')
171
- } else {
172
- setState({ ...state, loading: false })
173
- }
174
- } catch (err) {
175
- const message = err?.message?.includes('Internal error')
176
- ? 'INTERNAL_ERROR'
177
- : !err.message
178
- ? t('NETWORK_ERROR', 'Network error')
179
- : err.message
180
- setAlert({ show: true, content: [message] })
181
- setState({ ...state, loading: false })
182
- }
183
- }
184
-
185
- const checkAddress = (address) => {
186
- const props = ['address', 'address_notes', 'zipcode', 'location', 'internal_number']
187
- const values = []
188
- props.forEach(prop => {
189
- if (state.options?.address && state.options?.address?.[prop]) {
190
- if (prop === 'location') {
191
- values.push(address?.[prop]?.lat === state.options?.address?.[prop]?.lat &&
192
- address?.[prop]?.lng === state.options?.address?.[prop]?.lng)
193
- } else {
194
- values.push(address?.[prop] === state.options?.address?.[prop])
195
- }
196
- } else {
197
- values.push(!address?.[prop])
198
- }
199
- })
200
- return values.every(value => value)
201
- }
202
-
203
- /**
204
- * Change order address
205
- */
206
- const changeAddress = async (addressId, params) => {
207
- const isCountryCodeChanged = state.options?.address?.country_code !== params?.country_code
208
- if (typeof addressId === 'object') {
209
- const optionsStorage = await strategy.getItem('options', true)
210
- const options = {
211
- ...state.options,
212
- ...optionsStorage,
213
- address: {
214
- ...optionsStorage?.address,
215
- ...addressId
216
- }
217
- }
218
- if (!session.auth) {
219
- options.type = state?.options?.type
220
- }
221
- await strategy.setItem('options', options, true)
222
- setState({
223
- ...state,
224
- options
225
- })
226
- return
227
- }
228
-
229
- const _params = { country_code: params?.country_code }
230
-
231
- params?.type && (_params.type = params?.type)
232
-
233
- if (params && params?.address && !checkAddress(params?.address)) {
234
- _params.address_id = params?.address?.id
235
- await updateOrderOptions(_params)
236
- if (isCountryCodeChanged) {
237
- events.emit('country_code_changed', params?.country_code)
238
- }
239
- return
240
- }
241
- addressId && (_params.address_id = addressId)
242
- if (params && params?.isEdit) {
243
- if (addressId !== state.options.address_id) {
244
- return
245
- }
246
- await updateOrderOptions(_params)
247
- if (isCountryCodeChanged) {
248
- events.emit('country_code_changed', params?.country_code)
249
- }
250
- return
251
- }
252
- await updateOrderOptions(_params)
253
- if (isCountryCodeChanged) {
254
- events.emit('country_code_changed', params?.country_code)
255
- }
256
- }
257
-
258
- /**
259
- * Change order type
260
- */
261
- const changeType = async (type) => {
262
- const options = {
263
- ...state.options,
264
- type
265
- }
266
- if (state.options.type === type) {
267
- return
268
- }
269
-
270
- const cityId = state.options?.city_id
271
- const params = { type }
272
-
273
- if (cityId && type !== 2) {
274
- params.city_id = null
275
- }
276
-
277
- if (!session.auth) {
278
- const _options = { ...options, ...params }
279
- await strategy.setItem('options', _options, true)
280
- setState({
281
- ...state,
282
- options: _options
283
- })
284
- }
285
-
286
- updateOrderOptions(params)
287
- }
288
-
289
- /**
290
- * Change order moment
291
- */
292
- const changeMoment = async (moment) => {
293
- const momentUnix = moment ? moment.getTime() / 1000 : null
294
- const momentFormatted = momentUnix ? dayjs.unix(momentUnix).utc().format('YYYY-MM-DD HH:mm:ss') : null
295
-
296
- const options = {
297
- ...state.options,
298
- moment: momentFormatted
299
- }
300
- if (state.options.moment === momentFormatted) {
301
- return
302
- }
303
-
304
- if (!session.auth) {
305
- await strategy.setItem('options', options, true)
306
- setState({
307
- ...state,
308
- options
309
- })
310
- }
311
-
312
- updateOrderOptions({ moment: momentUnix })
313
- }
314
-
315
- /**
316
- * Change order city
317
- */
318
- const changeCityFilter = async (id) => {
319
- const options = {
320
- ...state.options,
321
- city_id: id
322
- }
323
- if (state.options.city_id === id) {
324
- return
325
- }
326
-
327
- if (!session.auth) {
328
- await strategy.setItem('options', options, true)
329
- setState({
330
- ...state,
331
- options
332
- })
333
- }
334
-
335
- updateOrderOptions({ city_id: id })
336
- }
337
- /**
338
- * Update order option data
339
- * @param {object} changes Changes to update order options
340
- */
341
- const updateOrderOptions = async (changes) => {
342
- if (session.auth) {
343
- const countryCodeFromLocalStorage = await strategy.getItem('country-code')
344
- const customerFromLocalStorage = await strategy.getItem('user-customer', true)
345
- const userCustomerId = customerFromLocalStorage?.id
346
- const body = {
347
- ...changes,
348
- user_id: userCustomerId || session.user.id
349
- }
350
- try {
351
- setState({ ...state, loading: true })
352
- const options = {}
353
- state.loading = true
354
- options.headers = {
355
- 'X-App-X': ordering.appId,
356
- 'X-Socket-Id-X': socket?.getId()
357
- }
358
- const countryCode = changes?.country_code && changes?.country_code !== state?.options?.address?.country_code
359
- ? changes?.country_code
360
- : countryCodeFromLocalStorage ?? changes?.country_code ?? state?.options?.address?.country_code
361
-
362
- if (countryCode) {
363
- options.headers = {
364
- ...options.headers,
365
- 'X-Country-Code-X': countryCode
366
- }
367
- await strategy.setItem('country-code', countryCode)
368
- }
369
- if (franchiseId) {
370
- options.query = {
371
- ...options.query,
372
- franchise_id: franchiseId
373
- }
374
- }
375
- if (body?.country_code) {
376
- delete body?.country_code
377
- }
378
- const { content: { error, result } } = await ordering
379
- .setAccessToken(session.token)
380
- .orderOptions()
381
- .save(body, options)
382
- if (!error) {
383
- const { carts, ...options } = result
384
- state.carts = {}
385
- carts.forEach(cart => {
386
- state.carts[`businessId:${cart.business_id}`] = cart
387
- })
388
- state.options = {
389
- ...state.options,
390
- ...options
391
- }
392
- } else {
393
- setAlert({ show: true, content: result })
394
- }
395
- setState({ ...state, loading: false })
396
- state.loading = false
397
- return !error
398
- } catch (err) {
399
- const message = err?.message?.includes('Internal error')
400
- ? 'INTERNAL_ERROR'
401
- : err.message
402
- setAlert({ show: true, content: [message] })
403
- setState({ ...state, loading: false })
404
- state.loading = false
405
- return false
406
- }
407
- }
408
- }
409
-
410
- /**
411
- * Add product to cart
412
- * @param {object} product product for add
413
- * @param {object} cart cart of the product
414
- * @param {boolean} isQuickAddProduct option to add product when clicks
415
- */
416
- const addProduct = async (
417
- product,
418
- cart,
419
- isQuickAddProduct,
420
- isPlatformProduct = false
421
- ) => {
422
- try {
423
- setState({ ...state, loading: true })
424
- const countryCode = await strategy.getItem('country-code')
425
- const customerFromLocalStorage = await strategy.getItem('user-customer', true)
426
- const userCustomerId = customerFromLocalStorage?.id
427
- let body
428
- const headers = {
429
- 'X-Socket-Id-X': socket?.getId(),
430
- 'X-Country-Code-X': countryCode
431
- }
432
- if (!isPlatformProduct) {
433
- body = {
434
- product,
435
- business_id: cart.business_id,
436
- user_id: userCustomerId || session.user.id
437
- }
438
- } else {
439
- body = {
440
- platform_product: { ...product }
441
- }
442
- }
443
-
444
- const { content: { error, result } } = await ordering.setAccessToken(session.token).carts().addProduct(body, { headers })
445
-
446
- if (!error) {
447
- state.carts[`businessId:${result.business_id}`] = result
448
- events.emit('cart_product_added', product, result)
449
- if (product?.favorite) {
450
- events.emit('wishlist_product_added_to_cart', product, result)
451
- }
452
- events.emit('cart_updated', result)
453
- events.emit('product_added', product, result)
454
- isQuickAddProduct && !isDisableToast && showToast(ToastType.Success, t('PRODUCT_ADDED_NOTIFICATION', 'Product _PRODUCT_ added succesfully').replace('_PRODUCT_', product.name))
455
- } else {
456
- setAlert({ show: true, content: result })
457
- }
458
- setState({ ...state, loading: false })
459
- if (isPlatformProduct) {
460
- return { error, result }
461
- } else {
462
- return !error
463
- }
464
- } catch (err) {
465
- setState({ ...state, loading: false })
466
- if (isPlatformProduct) {
467
- return { error: true, result: err.message }
468
- } else {
469
- return false
470
- }
471
- }
472
- }
473
-
474
- /**
475
- * Add multi products to cart / (domino's)
476
- * @param {object} product product for add
477
- * @param {object} cart cart of the product
478
- * @param {boolean} isQuickAddProduct option to add product when clicks
479
- */
480
- const addMultiProduct = async (
481
- product,
482
- cart,
483
- isQuickAddProduct
484
- ) => {
485
- try {
486
- setState({ ...state, loading: true })
487
- const countryCode = await strategy.getItem('country-code')
488
- const customerFromLocalStorage = await strategy.getItem('user-customer', true)
489
- const userCustomerId = customerFromLocalStorage?.id
490
- const headers = {
491
- 'X-Socket-Id-X': socket?.getId(),
492
- 'X-Country-Code-X': countryCode
493
- }
494
- const body = {
495
- products: JSON.stringify(product),
496
- business_id: cart.business_id,
497
- user_id: userCustomerId || session.user.id
498
- }
499
- const response = await fetch(`${ordering.root}/carts/multi_product`, {
500
- method: 'POST',
501
- body: JSON.stringify({
502
- ...body,
503
- products: JSON.stringify([product])
504
- }),
505
- headers: {
506
- ...headers,
507
- Authorization: `Bearer ${session.token}`,
508
- 'Content-Type': 'application/json'
509
- }
510
- })
511
- const { result, error } = await response.json()
512
- if (!error) {
513
- state.carts[`businessId:${result.business_id}`] = result
514
- events.emit('cart_product_added', product, result)
515
- if (product?.favorite) {
516
- events.emit('wishlist_product_added_to_cart', product, result)
517
- }
518
- events.emit('cart_updated', result)
519
- events.emit('product_added', product, result)
520
- isQuickAddProduct && !isDisableToast && showToast(ToastType.Success, t('PRODUCT_ADDED_NOTIFICATION', 'Product _PRODUCT_ added succesfully').replace('_PRODUCT_', product.name))
521
- } else {
522
- setAlert({ show: true, content: result })
523
- }
524
- setState({ ...state, loading: false })
525
- return !error
526
- } catch (err) {
527
- setState({ ...state, loading: false })
528
- return false
529
- }
530
- }
531
-
532
- /**
533
- * Remove product to cart
534
- */
535
- const removeProduct = async (product, cart) => {
536
- try {
537
- setState({ ...state, loading: true })
538
- const countryCode = await strategy.getItem('country-code')
539
- const customerFromLocalStorage = await strategy.getItem('user-customer', true)
540
- const userCustomerId = customerFromLocalStorage?.id
541
- const body = {
542
- product: {
543
- id: product.id,
544
- code: product.code,
545
- business_id: product.business_id
546
- },
547
- business_id: cart.business_id,
548
- user_id: userCustomerId || session.user.id
549
- }
550
- const { content: { error, result } } = await ordering.setAccessToken(session.token).carts().removeProduct(body, {
551
- headers: {
552
- 'X-App-X': ordering.appId,
553
- 'X-Socket-Id-X': socket?.getId(),
554
- 'X-Country-Code-X': countryCode
555
- }
556
- })
557
- if (!error) {
558
- state.carts[`businessId:${result.business_id}`] = result
559
- events.emit('cart_product_removed', product, result)
560
- events.emit('cart_updated', result)
561
- } else {
562
- setAlert({ show: true, content: result })
563
- }
564
- setState({ ...state, loading: false })
565
- return !error
566
- } catch (err) {
567
- setState({ ...state, loading: false })
568
- return false
569
- }
570
- }
571
-
572
- /**
573
- * Clear products of cart
574
- */
575
- const clearCart = async (uuid, configurations = {}) => {
576
- try {
577
- setState({ ...state, loading: !configurations?.disableLoading })
578
- const countryCode = await strategy.getItem('country-code')
579
- const customerFromLocalStorage = await strategy.getItem('user-customer', true)
580
- const userCustomerId = customerFromLocalStorage?.id
581
- const body = JSON.stringify({
582
- uuid,
583
- user_id: userCustomerId || session.user.id
584
- })
585
- const response = await fetch(`${ordering.root}/carts/clear`, {
586
- method: 'POST',
587
- headers: {
588
- 'Content-Type': 'application/json',
589
- Authorization: `Bearer ${session.token}`,
590
- 'X-App-X': ordering.appId,
591
- 'X-Socket-Id-X': socket?.getId(),
592
- 'X-Country-Code-X': countryCode
593
- },
594
- body
595
- })
596
- const { error, result } = await response.json()
597
- if (!error) {
598
- state.carts[`businessId:${result.business_id}`] = result
599
- } else {
600
- setAlert({ show: true, content: result })
601
- }
602
- setState({ ...state, loading: false })
603
- return { error, result }
604
- } catch (err) {
605
- setState({ ...state, loading: false })
606
- return false
607
- }
608
- }
609
-
610
- /**
611
- * Update product to cart
612
- */
613
- const updateProduct = async (product, cart, isQuickAddProduct) => {
614
- try {
615
- setState({ ...state, loading: true })
616
- const countryCode = await strategy.getItem('country-code')
617
- const customerFromLocalStorage = await strategy.getItem('user-customer', true)
618
- const userCustomerId = customerFromLocalStorage?.id
619
- const body = {
620
- product,
621
- business_id: cart.business_id,
622
- user_id: userCustomerId || session.user.id
623
- }
624
- const { content: { error, result } } = await ordering.setAccessToken(session.token).carts().updateProduct(body, {
625
- headers: {
626
- 'X-Socket-Id-X': socket?.getId(),
627
- 'X-Country-Code-X': countryCode
628
- }
629
- })
630
- if (!error) {
631
- state.carts[`businessId:${result.business_id}`] = result
632
- events.emit('cart_product_updated', product, result)
633
- events.emit('cart_updated', result)
634
- isQuickAddProduct && !isDisableToast && showToast(ToastType.Success, t('PRODUCT_UPDATED_NOTIFICATION', 'Product _PRODUCT_ updated succesfully').replace('_PRODUCT_', product.name))
635
- } else {
636
- setAlert({ show: true, content: result })
637
- }
638
- setState({ ...state, loading: false })
639
- return !error
640
- } catch (err) {
641
- setState({ ...state, loading: false })
642
- return false
643
- }
644
- }
645
-
646
- /**
647
- * Apply coupon to cart
648
- */
649
- const applyCoupon = async (couponData, customParams) => {
650
- if (!couponData.business_id) {
651
- throw new Error('`business_id` is required.')
652
- }
653
- if (typeof couponData.coupon === 'undefined') {
654
- throw new Error('`coupon` is required.')
655
- }
656
- if (state.carts[`businessId:${couponData.business_id}`]?.coupon === couponData.coupon) {
657
- return
658
- }
659
-
660
- try {
661
- setState({ ...state, loading: true })
662
- const countryCode = await strategy.getItem('country-code')
663
- if (customParams && isAlsea) {
664
- const response = await fetch('https://alsea-plugins.ordering.co/alseaplatform/vcoupon2.php', {
665
- method: 'POST',
666
- body: JSON.stringify({
667
- userId: customParams.userId,
668
- businessId: customParams.businessId,
669
- couponId: couponData.coupon
670
- }),
671
- headers: {
672
- Accept: 'application/json',
673
- 'Content-Type': 'application/x-www-form-urlencoded',
674
- 'Access-Control-Allow-Origin': '*',
675
- 'X-App-X': ordering.appId,
676
- 'X-Socket-Id-X': socket?.getId(),
677
- 'X-Country-Code-X': countryCode
678
- }
679
- })
680
- const result = await response.json()
681
-
682
- if (result.message !== 'Cup\u00f3n v\u00e1lido') {
683
- setAlert({ show: true, content: result.message === 'Not found' ? ['ERROR_INVALID_COUPON'] : [result.message] })
684
- setState({ ...state, loading: false })
685
- return
686
- }
687
- }
688
- const customerFromLocalStorage = await strategy.getItem('user-customer', true)
689
- const userCustomerId = customerFromLocalStorage?.id
690
- const body = {
691
- business_id: couponData.business_id,
692
- coupon: couponData.coupon,
693
- user_id: userCustomerId || session.user.id
694
- }
695
- const { content } = await ordering
696
- .setAccessToken(session.token)
697
- .carts()
698
- .applyCoupon(body, {
699
- headers: {
700
- 'X-App-X': ordering.appId,
701
- 'X-Socket-Id-X': socket?.getId(),
702
- 'X-Country-Code-X': countryCode
703
- }
704
- })
705
- const result = content
706
- if (!result.error) {
707
- state.carts[`businessId:${result.result.business_id}`] = result.result
708
- events.emit('cart_updated', result.result)
709
- } else {
710
- setAlert({ show: true, content: result.result })
711
- }
712
- setState({ ...state, loading: false })
713
- return !result.error
714
- } catch (err) {
715
- setState({ ...state, loading: false })
716
- return false
717
- }
718
- }
719
-
720
- const applyOffer = async (offerData) => {
721
- if (!offerData.business_id) {
722
- throw new Error('`business_id` is required.')
723
- }
724
- if (typeof offerData.coupon === 'undefined') {
725
- throw new Error('`coupon` is required.')
726
- }
727
- try {
728
- setState({ ...state, loading: true })
729
- const countryCode = await strategy.getItem('country-code')
730
- const response = await fetch(`${ordering.root}/carts/add_offer`, {
731
- method: 'POST',
732
- body: JSON.stringify({
733
- user_id: offerData.userId,
734
- business_id: offerData.business_id,
735
- coupon: offerData.coupon,
736
- force: offerData.force ?? false
737
- }),
738
- headers: {
739
- 'Content-Type': 'application/json',
740
- Authorization: `Bearer ${session.token}`,
741
- 'X-App-X': ordering.appId,
742
- 'X-Socket-Id-X': socket?.getId(),
743
- 'X-Country-Code-X': countryCode
744
- }
745
- })
746
- const result = await response.json()
747
- if (!result.error) {
748
- state.carts[`businessId:${result.result.business_id}`] = result.result
749
- events.emit('cart_updated', result.result)
750
- events.emit('offer_applied', { ...result.result, ...offerData })
751
- } else {
752
- setAlert({ show: true, content: result.result })
753
- events.emit('offer_denied', { ...offerData, reason: result.result })
754
- }
755
- setState({ ...state, loading: false })
756
- return !result.error
757
- } catch (err) {
758
- setState({ ...state, loading: false })
759
- return false
760
- }
761
- }
762
-
763
- const removeOffer = async (offerData) => {
764
- if (!offerData.business_id) {
765
- throw new Error('`business_id` is required.')
766
- }
767
- if (typeof offerData.offer_id === 'undefined') {
768
- throw new Error('`offer_id` is required.')
769
- }
770
- try {
771
- const countryCode = await strategy.getItem('country-code')
772
- setState({ ...state, loading: true })
773
- const offerRemoveData = {
774
- business_id: offerData.business_id,
775
- offer_id: offerData.offer_id
776
- }
777
- if (offerData.user_id) offerRemoveData.user_id = offerData.user_id
778
- const response = await fetch(`${ordering.root}/carts/remove_offer`, {
779
- method: 'POST',
780
- body: JSON.stringify(offerRemoveData),
781
- headers: {
782
- 'Content-Type': 'application/json',
783
- Authorization: `Bearer ${session.token}`,
784
- 'X-App-X': ordering.appId,
785
- 'X-Socket-Id-X': socket?.getId(),
786
- 'X-Country-Code-X': countryCode
787
- }
788
- })
789
- const result = await response.json()
790
- if (!result.error) {
791
- state.carts[`businessId:${result.result.business_id}`] = result.result
792
- events.emit('cart_updated', result.result)
793
- events.emit('offer_removed', offerData)
794
- } else {
795
- setAlert({ show: true, content: result.result })
796
- }
797
- setState({ ...state, loading: false })
798
- return !result.error
799
- } catch (err) {
800
- setState({ ...state, loading: false })
801
- return false
802
- }
803
- }
804
-
805
- /**
806
- * Apply coupon to cart
807
- */
808
- const changeDriverTip = async (businessId, driverTipRate = 0, isFixedPrice) => {
809
- if (!businessId) {
810
- throw new Error('`businessId` is required.')
811
- }
812
- if (!driverTipRate && driverTipRate !== 0) {
813
- throw new Error('`driverTipRate` is required.')
814
- }
815
- if (!state.carts[`businessId:${businessId}`] || state.carts[`businessId:${businessId}`]?.driver_tip_rate === driverTipRate) {
816
- return
817
- }
818
- try {
819
- setState({ ...state, loading: true })
820
- const countryCode = await strategy.getItem('country-code')
821
- const customerFromLocalStorage = await strategy.getItem('user-customer', true)
822
- const userCustomerId = customerFromLocalStorage?.id
823
- const body = {
824
- business_id: businessId,
825
- [isFixedPrice ? 'driver_tip' : 'driver_tip_rate']: driverTipRate,
826
- user_id: userCustomerId || session.user.id
827
- }
828
- const { content: { error, result } } = await ordering.setAccessToken(session.token).carts().changeDriverTip(body, {
829
- headers: {
830
- 'X-Socket-Id-X': socket?.getId(),
831
- 'X-Country-Code-X': countryCode
832
- }
833
- })
834
- if (!error) {
835
- state.carts[`businessId:${result.business_id}`] = result
836
- events.emit('cart_updated', result)
837
- } else {
838
- setAlert({ show: true, content: result })
839
- }
840
- setState({ ...state, loading: false })
841
- return !error
842
- } catch (err) {
843
- setState({ ...state, loading: false })
844
- return false
845
- }
846
- }
847
-
848
- /**
849
- * Change payment method
850
- */
851
- const changePaymethod = async (businessId, paymethodId, paymethodData) => {
852
- if (!businessId) {
853
- throw new Error('`businessId` is required.')
854
- }
855
- if (!paymethodId) {
856
- throw new Error('`paymethodId` is required.')
857
- }
858
- if (!paymethodData) {
859
- throw new Error('`paymethodData` is required.')
860
- }
861
- if (!state.carts[`businessId:${businessId}`] || state.carts[`businessId:${businessId}`]?.paymethodId === paymethodId) {
862
- return
863
- }
864
- try {
865
- setState({ ...state, loading: true })
866
- const countryCode = await strategy.getItem('country-code')
867
- const customerFromLocalStorage = await strategy.getItem('user-customer', true)
868
- const userCustomerId = customerFromLocalStorage?.id
869
- const body = {
870
- business_id: businessId,
871
- paymethod_id: paymethodId,
872
- paymethod_data: paymethodData,
873
- user_id: userCustomerId ?? session.user.id
874
- }
875
- const { content: { error, result } } = await ordering.setAccessToken(session.token).carts().changePaymethod(body, {
876
- headers: {
877
- 'X-Socket-Id-X': socket?.getId(),
878
- 'X-Country-Code-X': countryCode
879
- }
880
- })
881
- if (!error) {
882
- state.carts[`businessId:${result.business_id}`] = result
883
- events.emit('cart_updated', result)
884
- }
885
- setState({ ...state, loading: false })
886
- return !error
887
- } catch (err) {
888
- return false
889
- }
890
- }
891
-
892
- /**
893
- * Place cart
894
- */
895
- const placeCart = async (cardId, data) => {
896
- try {
897
- setState({ ...state, loading: true })
898
- const countryCode = await strategy.getItem('country-code')
899
- const customerFromLocalStorage = await strategy.getItem('user-customer', true)
900
- const userCustomerId = customerFromLocalStorage?.id
901
- const body = {
902
- ...data,
903
- user_id: userCustomerId || session.user.id
904
- }
905
- let headers = {
906
- 'X-Socket-Id-X': socket?.getId(),
907
- 'X-Country-Code-X': countryCode
908
- }
909
- if (userAgent) {
910
- headers = { ...headers, 'User-Agent': userAgent }
911
- }
912
- const { content: { error, result } } = await ordering.setAccessToken(session.token).carts(cardId).place(body, { headers: headers })
913
- if (!error) {
914
- if (result.status !== 1) {
915
- state.carts[`businessId:${result.business_id}`] = result
916
- events.emit('cart_updated', result)
917
- } else {
918
- delete state.carts[`businessId:${result.business_id}`]
919
- const orderObject = {
920
- id: result.order.uuid,
921
- business: { name: result.business.name },
922
- total: result.total,
923
- tax_total: result.tax,
924
- delivery_zone_price: result.delivery_price,
925
- business_id: result.business_id,
926
- paymethod: result.paymethod_data.gateway
927
- }
928
- events.emit('order_placed', orderObject)
929
- }
930
- } else {
931
- setAlert({ show: true, content: result })
932
- setState({ ...state, loading: false })
933
- return
934
- }
935
- setState({ ...state, loading: false })
936
- return { error, result }
937
- } catch (err) {
938
- setState({ ...state, loading: false })
939
- return {
940
- error: true,
941
- result: [err.message]
942
- }
943
- }
944
- }
945
-
946
- /**
947
- * Place multi carts
948
- */
949
- const placeMultiCarts = async (data, cartUuid) => {
950
- try {
951
- setState({ ...state, loading: true })
952
- const countryCode = await strategy.getItem('country-code')
953
- const customerFromLocalStorage = await strategy.getItem('user-customer', true)
954
- const userCustomerId = customerFromLocalStorage?.id
955
- const body = {
956
- ...data,
957
- user_id: userCustomerId || session.user.id
958
- }
959
- const requestOptions = {
960
- method: 'POST',
961
- headers: {
962
- 'Content-Type': 'application/json',
963
- Authorization: `bearer ${session.token}`,
964
- 'X-App-X': ordering.appId,
965
- 'X-Socket-Id-X': socket?.getId(),
966
- 'X-Country-Code-X': countryCode
967
- },
968
- body: JSON.stringify(body)
969
- }
970
-
971
- const response = await fetch(`${ordering.root}/cart_groups/${cartUuid}/place`, requestOptions)
972
- const { error, result } = await response.json()
973
- if (!error) {
974
- result.carts.forEach(cart => {
975
- delete state.carts[`businessId:${cart.business_id}`]
976
- const orderObject = {
977
- id: cart.uuid,
978
- business: { name: cart.business.name },
979
- total: cart.total,
980
- tax_total: cart.tax,
981
- delivery_zone_price: cart.delivery_price,
982
- business_id: cart.business_id
983
- }
984
- events.emit('order_placed', orderObject)
985
- })
986
- } else {
987
- setAlert({ show: true, content: result })
988
- }
989
- setState({ ...state, loading: false })
990
- return { error, result }
991
- } catch (err) {
992
- setState({ ...state, loading: false })
993
- return {
994
- error: true,
995
- result: [err.message]
996
- }
997
- }
998
- }
999
-
1000
- /**
1001
- * Confirm cart
1002
- */
1003
- const confirmCart = async (cardId, data) => {
1004
- try {
1005
- setState({ ...state, loading: true })
1006
- const countryCode = await strategy.getItem('country-code')
1007
- const customerFromLocalStorage = await strategy.getItem('user-customer', true)
1008
- const userCustomerId = customerFromLocalStorage?.id
1009
- const body = {
1010
- ...data,
1011
- user_id: userCustomerId || session.user.id
1012
- }
1013
- let fetchurl
1014
- if (body.user_id === userCustomerId || data) {
1015
- fetchurl = await ordering.setAccessToken(session.token).carts(cardId).confirmWithData(body, {
1016
- headers: {
1017
- 'X-App-X': ordering.appId,
1018
- 'X-Socket-Id-X': socket?.getId(),
1019
- 'X-Country-Code-X': countryCode
1020
- }
1021
- })
1022
- } else {
1023
- fetchurl = await ordering.setAccessToken(session.token).carts(cardId).confirm(body, {
1024
- headers: {
1025
- 'X-App-X': ordering.appId,
1026
- 'X-Socket-Id-X': socket?.getId(),
1027
- 'X-Country-Code-X': countryCode
1028
- }
1029
- })
1030
- }
1031
- const { content: { error, result, cart } } = fetchurl
1032
- if (!error) {
1033
- if (result.status !== 1) {
1034
- state.carts[`businessId:${result.business_id}`] = result
1035
- events.emit('cart_updated', result)
1036
- } else {
1037
- delete state.carts[`businessId:${result.business_id}`]
1038
- }
1039
- } else if (cart) {
1040
- state.carts[`businessId:${cart.business_id}`] = cart
1041
- events.emit('cart_updated', cart)
1042
- }
1043
- setState({ ...state, loading: false })
1044
- return { error, result }
1045
- } catch (err) {
1046
- setState({ ...state, loading: false })
1047
- return {
1048
- error: true,
1049
- result: [err.message]
1050
- }
1051
- }
1052
- }
1053
-
1054
- /**
1055
- * Confirm multi carts
1056
- */
1057
- const confirmMultiCarts = async (cartUuid) => {
1058
- try {
1059
- setState({ ...state, loading: true })
1060
- const countryCode = await strategy.getItem('country-code')
1061
- const requestOptions = {
1062
- method: 'POST',
1063
- headers: {
1064
- 'Content-Type': 'application/json',
1065
- Authorization: `bearer ${session.token}`,
1066
- 'X-App-X': ordering.appId,
1067
- 'X-Socket-Id-X': socket?.getId(),
1068
- 'X-Country-Code-X': countryCode
1069
- }
1070
- }
1071
- const response = await fetch(`${ordering.root}/cart_groups/${cartUuid}/confirm`, requestOptions)
1072
- const { result, error } = await response.json()
1073
- if (!error) {
1074
- result.carts.forEach(cart => {
1075
- if (result.status !== 'completed') {
1076
- state.carts[`businessId:${cart.business_id}`] = result
1077
- events.emit('cart_updated', result)
1078
- } else {
1079
- delete state.carts[`businessId:${cart.business_id}`]
1080
- }
1081
- })
1082
- }
1083
- setState({ ...state, loading: false })
1084
- return { error, result }
1085
- } catch (err) {
1086
- setState({ ...state, loading: false })
1087
- return {
1088
- error: true,
1089
- result: [err.message]
1090
- }
1091
- }
1092
- }
1093
-
1094
- /**
1095
- * Reorder an order and get cart
1096
- */
1097
- const reorder = async (orderId, offAlert, configurations = {}) => {
1098
- try {
1099
- setState({ ...state, loading: !configurations?.disableLoading })
1100
- const countryCode = await strategy.getItem('country-code')
1101
- const customerFromLocalStorage = await strategy.getItem('user-customer', true)
1102
- const userCustomerId = customerFromLocalStorage?.id
1103
- const query = userCustomerId
1104
- ? { user_id: userCustomerId }
1105
- : null
1106
- const options = {
1107
- headers: {
1108
- 'X-App-X': ordering.appId,
1109
- 'X-Socket-Id-X': socket?.getId(),
1110
- 'X-Country-Code-X': countryCode
1111
- }
1112
- }
1113
- if (query) {
1114
- options.query = query
1115
- }
1116
- const { content: { error, result } } = await ordering.setAccessToken(session.token).orders(orderId).reorder(options)
1117
- if (!error) {
1118
- state.carts[`businessId:${result.business_id}`] = result
1119
- events.emit('cart_added', result)
1120
- } else if (!offAlert) {
1121
- setAlert({ show: true, content: result })
1122
- }
1123
- setState({ ...state, loading: false })
1124
- return { error, result }
1125
- } catch (err) {
1126
- setState({ ...state, loading: false })
1127
- return { error: true, result: [err.message] }
1128
- }
1129
- }
1130
-
1131
- const setOptionFromLocalStorage = async () => {
1132
- const optionsLocalStorage = await strategy.getItem('options', true)
1133
- setState({
1134
- ...state,
1135
- loading: false,
1136
- options: isDisabledDefaultOpts
1137
- ? { type: null, moment: null }
1138
- : {
1139
- type: optionsLocalStorage?.type || orderTypes[configState?.configs?.default_order_type?.value],
1140
- moment: optionsLocalStorage?.moment || null,
1141
- address: optionsLocalStorage?.address || state?.options?.address || {},
1142
- city_id: optionsLocalStorage?.city_id || null
1143
- }
1144
- })
1145
- }
1146
-
1147
- /**
1148
- * get Latest past Order that has no review
1149
- */
1150
- const getLastOrderHasNoReview = async () => {
1151
- if (session?.token) {
1152
- const pastOrderTypes = [1, 2, 5, 6, 10, 11, 12, 15, 16, 17]
1153
- const where = [{ attribute: 'status', value: pastOrderTypes }]
1154
- if (franchiseId) {
1155
- where.push({
1156
- attribute: 'ref_business',
1157
- conditions: [
1158
- {
1159
- attribute: 'franchise_id',
1160
- value: {
1161
- condition: '=',
1162
- value: franchiseId
1163
- }
1164
- }
1165
- ]
1166
- })
1167
- }
1168
- if (typeof businessSlug === 'number' && businessSlug) {
1169
- where.push({
1170
- attribute: 'ref_business',
1171
- conditions: [
1172
- {
1173
- attribute: 'id',
1174
- value: {
1175
- condition: '=',
1176
- value: businessSlug
1177
- }
1178
- }
1179
- ]
1180
- })
1181
- }
1182
- if (typeof businessSlug === 'string' && businessSlug) {
1183
- where.push({
1184
- attribute: 'ref_business',
1185
- conditions: [
1186
- {
1187
- attribute: 'slug',
1188
- value: {
1189
- condition: '=',
1190
- value: businessSlug
1191
- }
1192
- }
1193
- ]
1194
- })
1195
- }
1196
- if (typeof businessSlug === 'number' && businessSlug) {
1197
- where.push({
1198
- attribute: 'ref_business',
1199
- conditions: [
1200
- {
1201
- attribute: 'id',
1202
- value: {
1203
- condition: '=',
1204
- value: businessSlug
1205
- }
1206
- }
1207
- ]
1208
- })
1209
- }
1210
- if (typeof businessSlug === 'string' && businessSlug) {
1211
- where.push({
1212
- attribute: 'ref_business',
1213
- conditions: [
1214
- {
1215
- attribute: 'slug',
1216
- value: {
1217
- condition: '=',
1218
- value: businessSlug
1219
- }
1220
- }
1221
- ]
1222
- })
1223
- }
1224
- const options = {
1225
- query: {
1226
- orderBy: '-delivery_datetime',
1227
- page: 1,
1228
- page_size: 10,
1229
- where
1230
- }
1231
- }
1232
- const { content: { result, error } } = await ordering.setAccessToken(session?.token).orders().get(options)
1233
-
1234
- if (!error && result?.length > 0) {
1235
- const _noRviewOrder = result?.find(order => !order?.review)
1236
- if (_noRviewOrder?.cart_group_id) {
1237
- where.push({ attribute: 'cart_group_id', value: _noRviewOrder?.cart_group_id })
1238
- const options = {
1239
- query: {
1240
- where,
1241
- page: 1,
1242
- page_size: 10
1243
- }
1244
- }
1245
- const { content: { result, error } } = await ordering.setAccessToken(session?.token).orders().get(options)
1246
- if (!error) {
1247
- const noReviewOrders = result.filter(order => !order?.review)
1248
- return noReviewOrders
1249
- } else {
1250
- return null
1251
- }
1252
- } else {
1253
- return _noRviewOrder
1254
- }
1255
- } else {
1256
- return null
1257
- }
1258
- } else {
1259
- return null
1260
- }
1261
- }
1262
-
1263
- const setStateValues = (values) => {
1264
- setState({ ...state, ...values })
1265
- }
1266
-
1267
- const setUserCustomerOptions = async (params) => {
1268
- setState({ ...state, loading: true })
1269
- const options = params.options ?? {}
1270
- await setUserCustomer(params.customer ?? {}, true)
1271
- await updateOrderOptions(options)
1272
- setState({ ...state, loading: false })
1273
- }
1274
-
1275
- useEffect(() => {
1276
- if (session.loading || languageState.loading) return
1277
- if (session.auth) {
1278
- refreshOrderOptions()
1279
- }
1280
- }, [session.auth, session.loading, languageState.loading])
1281
-
1282
- useEffect(() => {
1283
- if (session.loading || configState.loading) return
1284
- if (!session.auth) {
1285
- setOptionFromLocalStorage()
1286
- }
1287
- }, [session.auth, session.loading, configState])
1288
-
1289
- useEffect(() => {
1290
- if (configTypes?.length > 0 && state.options.type && !configTypes.includes(state.options.type)) {
1291
- const validDefaultValue = configTypes.includes(configState?.configs?.default_order_type?.type)
1292
- updateOrderOptions(validDefaultValue ? { type: configState?.configs?.default_order_type?.type } : { type: configTypes[0] })
1293
- }
1294
- }, [configTypes?.length, state.options.type])
1295
-
1296
- /**
1297
- * Update carts from sockets
1298
- */
1299
- useEffect(() => {
1300
- const handleCartUpdate = (cart) => {
1301
- if (!isDisableToast) {
1302
- showToast(ToastType.Info, t('UPDATING_CART_INFO', 'Updating cart information...'))
1303
- }
1304
-
1305
- if (cart.status === 1) {
1306
- if (state.carts[`businessId:${cart.business_id}`]) {
1307
- delete state.carts[`businessId:${cart.business_id}`]
1308
- }
1309
- } else {
1310
- const cartFinded = Object.values(state.carts).find(_cart => _cart?.uuid === cart?.uuid)
1311
- const oldBusinessId = cartFinded?.business_id
1312
- const newBusinessId = cart?.business_id
1313
-
1314
- if (!oldBusinessId || oldBusinessId === newBusinessId) {
1315
- state.carts[`businessId:${cart.business_id}`] = {
1316
- ...state.carts[`businessId:${cart.business_id}`],
1317
- ...cart
1318
- }
1319
- } else {
1320
- delete state.carts[`businessId:${oldBusinessId}`]
1321
- state.carts[`businessId:${newBusinessId}`] = cart
1322
- }
1323
- }
1324
- }
1325
- const handleOrderOptionUpdate = ({ carts, ...options }) => {
1326
- if (!isDisableToast) {
1327
- showToast(ToastType.Info, t('UPDATING_ORDER_OPTIONS', 'Updating order options...'))
1328
- }
1329
-
1330
- const newCarts = {}
1331
- carts.forEach(cart => {
1332
- newCarts[`businessId:${cart.business_id}`] = cart
1333
- })
1334
- const newState = {
1335
- ...state,
1336
- options: {
1337
- ...state.options,
1338
- ...options
1339
- },
1340
- carts: {
1341
- ...state.carts,
1342
- ...newCarts
1343
- }
1344
- }
1345
- setState({ ...newState, loading: false })
1346
- }
1347
- socket.on('carts_update', handleCartUpdate)
1348
- socket.on('order_options_update', handleOrderOptionUpdate)
1349
- return () => {
1350
- socket.off('carts_update', handleCartUpdate)
1351
- socket.off('order_options_update', handleOrderOptionUpdate)
1352
- }
1353
- }, [state, socket])
1354
-
1355
- /**
1356
- * Join to carts room
1357
- */
1358
- useEffect(() => {
1359
- if (!session.auth || session.loading) return
1360
- socket.join(`carts_${customerState?.user?.id || session?.user?.id}`)
1361
- socket.join(`orderoptions_${customerState?.user?.id || session?.user?.id}`)
1362
- return () => {
1363
- socket.leave(`carts_${customerState?.user?.id || session?.user?.id}`)
1364
- socket.leave(`orderoptions_${customerState?.user?.id || session?.user?.id}`)
1365
- }
1366
- }, [socket, session.auth, session.loading, customerState?.user?.id, session?.user?.id])
1367
-
1368
- const functions = {
1369
- refreshOrderOptions,
1370
- changeAddress,
1371
- changeType,
1372
- changeMoment,
1373
- addProduct,
1374
- removeProduct,
1375
- updateProduct,
1376
- clearCart,
1377
- applyCoupon,
1378
- applyOffer,
1379
- removeOffer,
1380
- changeDriverTip,
1381
- placeCart,
1382
- confirmCart,
1383
- reorder,
1384
- setAlert,
1385
- setConfirm,
1386
- changePaymethod,
1387
- setUserCustomerOptions,
1388
- setStateValues,
1389
- placeMultiCarts,
1390
- getLastOrderHasNoReview,
1391
- changeCityFilter,
1392
- confirmMultiCarts,
1393
- addMultiProduct
1394
- }
1395
-
1396
- const copyState = JSON.parse(JSON.stringify(state))
1397
-
1398
- return (
1399
- <OrderContext.Provider value={[copyState, functions]}>
1400
- {
1401
- Alert && (
1402
- <Alert
1403
- open={alert.show}
1404
- title={alert.title || t('ERROR', 'Error')}
1405
- onAccept={() => setAlert({ show: false })}
1406
- onClose={() => setAlert({ show: false })}
1407
- content={alert.content}
1408
- />
1409
- )
1410
- }
1411
- {children}
1412
- </OrderContext.Provider>
1413
- )
1414
- }
1415
-
1416
- /**
1417
- * Hook to get and update order state
1418
- */
1419
- export const useOrder = () => {
1420
- const orderManager = useContext(OrderContext)
1421
- const warningMessage = () => {
1422
- console.warn('Must use OrderProvider to wrappe the app.')
1423
- }
1424
- /**
1425
- * Functions to avoid fails
1426
- */
1427
- const functionsPlaceholders = {
1428
- refreshOrderOptions: warningMessage,
1429
- changeAddress: warningMessage,
1430
- changeType: warningMessage,
1431
- changeMoment: warningMessage,
1432
- addProduct: warningMessage,
1433
- removeProduct: warningMessage,
1434
- updateProduct: warningMessage,
1435
- clearCart: warningMessage,
1436
- applyCoupon: warningMessage,
1437
- placeCart: warningMessage,
1438
- confirmCart: warningMessage,
1439
- setAlert: warningMessage,
1440
- setConfirm: warningMessage,
1441
- changeDriverTip: warningMessage,
1442
- reorder: warningMessage,
1443
- changePaymethod: warningMessage,
1444
- setStateValues: warningMessage,
1445
- getLastOrderHasNoReview: warningMessage
1446
- }
1447
- return orderManager || [{}, functionsPlaceholders]
1448
- }
1
+ import React, { createContext, useContext, useState, useEffect } from 'react'
2
+ import { useSession } from '../SessionContext'
3
+ import { useApi } from '../ApiContext'
4
+ import { useWebsocket } from '../WebsocketContext'
5
+ import { useLanguage } from '../LanguageContext'
6
+ import { useEvent } from '../EventContext'
7
+ import { useConfig } from '../ConfigContext'
8
+ import { useCustomer } from '../CustomerContext'
9
+ import { ToastType, useToast } from '../ToastContext'
10
+ import dayjs from 'dayjs'
11
+ import utc from 'dayjs/plugin/utc'
12
+
13
+ dayjs.extend(utc)
14
+
15
+ /**
16
+ * Create OrderContext
17
+ * This context will manage the current order with options internally and provide an easy interface
18
+ */
19
+ export const OrderContext = createContext()
20
+
21
+ /**
22
+ * Custom provider to order manager
23
+ * This provider has a reducer for manage order state
24
+ * @param {props} props
25
+ */
26
+ export const OrderProvider = ({ Alert, children, strategy, isAlsea, isDisableToast, franchiseId, isDisabledDefaultOpts, businessSlug, userAgent }) => {
27
+ const [confirmAlert, setConfirm] = useState({ show: false })
28
+ const [alert, setAlert] = useState({ show: false })
29
+ const [ordering] = useApi()
30
+ const socket = useWebsocket()
31
+ const [languageState, t] = useLanguage()
32
+ const [events] = useEvent()
33
+ const [configState] = useConfig()
34
+ const [session, { logout }] = useSession()
35
+ const [customerState, { setUserCustomer }] = useCustomer()
36
+ const [, { showToast }] = useToast()
37
+
38
+ const configTypes = configState?.configs?.order_types_allowed?.value.split('|').map(value => Number(value)) || []
39
+
40
+ const orderTypes = {
41
+ delivery: 1,
42
+ pickup: 2,
43
+ eatin: 3,
44
+ curbside: 4,
45
+ drivethru: 5
46
+ }
47
+
48
+ const [state, setState] = useState({
49
+ loading: true,
50
+ options: isDisabledDefaultOpts
51
+ ? { type: null, moment: null, city_id: null }
52
+ : {
53
+ type: orderTypes[configState?.configs?.default_order_type?.value],
54
+ moment: null,
55
+ city_id: null
56
+ },
57
+ carts: {},
58
+ confirmAlert,
59
+ alert
60
+ })
61
+
62
+ /**
63
+ * Refresh order options and carts from API
64
+ */
65
+ const refreshOrderOptions = async () => {
66
+ try {
67
+ if (!state.loading) {
68
+ setState({ ...state, loading: true })
69
+ }
70
+ const countryCodeFromLocalStorage = await strategy.getItem('country-code')
71
+ const customerFromLocalStorage = await strategy.getItem('user-customer', true)
72
+ const userCustomerId = customerFromLocalStorage?.id
73
+ const options = {}
74
+ if (userCustomerId) {
75
+ options.query = {
76
+ user_id: userCustomerId
77
+ }
78
+ }
79
+ if (franchiseId) {
80
+ options.query = {
81
+ ...options.query,
82
+ franchise_id: franchiseId
83
+ }
84
+ }
85
+
86
+ const countryCode = countryCodeFromLocalStorage && countryCodeFromLocalStorage !== state?.options?.address?.country_code
87
+ ? countryCodeFromLocalStorage
88
+ : state?.options?.address?.country_code
89
+
90
+ if (countryCode) {
91
+ options.headers = {
92
+ 'X-Socket-Id-X': socket?.getId(),
93
+ 'X-Country-Code-X': countryCode
94
+ }
95
+ }
96
+
97
+ const res = await ordering.setAccessToken(session.token).orderOptions().get(options)
98
+ const error = res?.content?.error
99
+ const result = res?.content?.result
100
+
101
+ if (!error) {
102
+ const { carts, ...options } = result
103
+ state.carts = {}
104
+ carts.forEach(cart => {
105
+ state.carts[`businessId:${cart.business_id}`] = cart
106
+ })
107
+ state.options = {
108
+ ...state.options,
109
+ ...options
110
+ }
111
+
112
+ if (!countryCodeFromLocalStorage && options?.address?.country_code) {
113
+ await updateOrderOptions({ country_code: options?.address?.country_code })
114
+ }
115
+ }
116
+ if (error) {
117
+ setAlert({ show: true, content: result })
118
+ if (res?.status === 401) {
119
+ session.auth && logout()
120
+ }
121
+ }
122
+ const localOptions = await strategy.getItem('options', true)
123
+ if (localOptions) {
124
+ const options = {}
125
+ if (Object.keys(localOptions.address).length > 0) {
126
+ const conditions = [
127
+ { attribute: 'address', value: localOptions?.address?.address }
128
+ ]
129
+ const userId = userCustomerId || session.user.id
130
+ const addressesResponse = await ordering.setAccessToken(session.token).users(userId).addresses().where(conditions).get()
131
+ let address = addressesResponse.content.result.find(address => {
132
+ localOptions.address.internal_number = localOptions.address?.internal_number || null
133
+ localOptions.address.zipcode = localOptions.address?.zipcode || null
134
+ localOptions.address.address_notes = localOptions.address?.address_notes || null
135
+
136
+ return address?.location?.lat === localOptions?.address?.location.lat &&
137
+ address?.location?.lng === localOptions?.address?.location?.lng &&
138
+ address?.internal_number === localOptions?.address?.internal_number &&
139
+ address?.zipcode === localOptions?.address?.zipcode &&
140
+ address?.address_notes === localOptions?.address?.address_notes
141
+ })
142
+ if (!address) {
143
+ Object.keys(localOptions.address).forEach(key => localOptions?.address?.[key] === null && delete localOptions?.address?.[key])
144
+ const { content: { error, result } } = await ordering.setAccessToken(session.token).users(userId).addresses().save(localOptions.address)
145
+ if (!error) {
146
+ address = result
147
+ }
148
+ } else {
149
+ await ordering.setAccessToken(session.token).users(userId).addresses(address.id).save({ default: true })
150
+ }
151
+ address && (options.address_id = address.id)
152
+ }
153
+ if (localOptions.type) {
154
+ options.type = localOptions.type
155
+ }
156
+ if (localOptions.moment) {
157
+ options.moment = dayjs.utc(localOptions.moment, 'YYYY-MM-DD HH:mm:ss').unix()
158
+ }
159
+ if (localOptions?.address_id) {
160
+ options.address_id = localOptions?.address_id
161
+ }
162
+ if (localOptions?.city_id) {
163
+ options.city_id = localOptions?.city_id
164
+ }
165
+ if (options && Object.keys(options).length > 0) {
166
+ updateOrderOptions(options)
167
+ } else {
168
+ setState({ ...state, loading: false })
169
+ }
170
+ await strategy.removeItem('options')
171
+ } else {
172
+ setState({ ...state, loading: false })
173
+ }
174
+ } catch (err) {
175
+ const message = err?.message?.includes('Internal error')
176
+ ? 'INTERNAL_ERROR'
177
+ : !err.message
178
+ ? t('NETWORK_ERROR', 'Network error')
179
+ : err.message
180
+ setAlert({ show: true, content: [message] })
181
+ setState({ ...state, loading: false })
182
+ }
183
+ }
184
+
185
+ const checkAddress = (address) => {
186
+ const props = ['address', 'address_notes', 'zipcode', 'location', 'internal_number']
187
+ const values = []
188
+ props.forEach(prop => {
189
+ if (state.options?.address && state.options?.address?.[prop]) {
190
+ if (prop === 'location') {
191
+ values.push(address?.[prop]?.lat === state.options?.address?.[prop]?.lat &&
192
+ address?.[prop]?.lng === state.options?.address?.[prop]?.lng)
193
+ } else {
194
+ values.push(address?.[prop] === state.options?.address?.[prop])
195
+ }
196
+ } else {
197
+ values.push(!address?.[prop])
198
+ }
199
+ })
200
+ return values.every(value => value)
201
+ }
202
+
203
+ /**
204
+ * Change order address
205
+ */
206
+ const changeAddress = async (addressId, params) => {
207
+ const isCountryCodeChanged = state.options?.address?.country_code !== params?.country_code
208
+ if (typeof addressId === 'object') {
209
+ const optionsStorage = await strategy.getItem('options', true)
210
+ const options = {
211
+ ...state.options,
212
+ ...optionsStorage,
213
+ address: {
214
+ ...optionsStorage?.address,
215
+ ...addressId
216
+ }
217
+ }
218
+ if (!session.auth) {
219
+ options.type = state?.options?.type
220
+ }
221
+ await strategy.setItem('options', options, true)
222
+ setState({
223
+ ...state,
224
+ options
225
+ })
226
+ return
227
+ }
228
+
229
+ const _params = { country_code: params?.country_code }
230
+
231
+ params?.type && (_params.type = params?.type)
232
+
233
+ if (params && params?.address && !checkAddress(params?.address)) {
234
+ _params.address_id = params?.address?.id
235
+ await updateOrderOptions(_params)
236
+ if (isCountryCodeChanged) {
237
+ events.emit('country_code_changed', params?.country_code)
238
+ }
239
+ return
240
+ }
241
+ addressId && (_params.address_id = addressId)
242
+ if (params && params?.isEdit) {
243
+ if (addressId !== state.options.address_id) {
244
+ return
245
+ }
246
+ await updateOrderOptions(_params)
247
+ if (isCountryCodeChanged) {
248
+ events.emit('country_code_changed', params?.country_code)
249
+ }
250
+ return
251
+ }
252
+ await updateOrderOptions(_params)
253
+ if (isCountryCodeChanged) {
254
+ events.emit('country_code_changed', params?.country_code)
255
+ }
256
+ }
257
+
258
+ /**
259
+ * Change order type
260
+ */
261
+ const changeType = async (type) => {
262
+ const options = {
263
+ ...state.options,
264
+ type
265
+ }
266
+ if (state.options.type === type) {
267
+ return
268
+ }
269
+
270
+ const cityId = state.options?.city_id
271
+ const params = { type }
272
+
273
+ if (cityId && type !== 2) {
274
+ params.city_id = null
275
+ }
276
+
277
+ if (!session.auth) {
278
+ const _options = { ...options, ...params }
279
+ await strategy.setItem('options', _options, true)
280
+ setState({
281
+ ...state,
282
+ options: _options
283
+ })
284
+ }
285
+
286
+ updateOrderOptions(params)
287
+ }
288
+
289
+ /**
290
+ * Change order moment
291
+ */
292
+ const changeMoment = async (moment) => {
293
+ const momentUnix = moment ? moment.getTime() / 1000 : null
294
+ const momentFormatted = momentUnix ? dayjs.unix(momentUnix).utc().format('YYYY-MM-DD HH:mm:ss') : null
295
+
296
+ const options = {
297
+ ...state.options,
298
+ moment: momentFormatted
299
+ }
300
+ if (state.options.moment === momentFormatted) {
301
+ return
302
+ }
303
+
304
+ if (!session.auth) {
305
+ await strategy.setItem('options', options, true)
306
+ setState({
307
+ ...state,
308
+ options
309
+ })
310
+ }
311
+
312
+ updateOrderOptions({ moment: momentUnix })
313
+ }
314
+
315
+ /**
316
+ * Change order city
317
+ */
318
+ const changeCityFilter = async (id) => {
319
+ const options = {
320
+ ...state.options,
321
+ city_id: id
322
+ }
323
+ if (state.options.city_id === id) {
324
+ return
325
+ }
326
+
327
+ if (!session.auth) {
328
+ await strategy.setItem('options', options, true)
329
+ setState({
330
+ ...state,
331
+ options
332
+ })
333
+ }
334
+
335
+ updateOrderOptions({ city_id: id })
336
+ }
337
+ /**
338
+ * Update order option data
339
+ * @param {object} changes Changes to update order options
340
+ */
341
+ const updateOrderOptions = async (changes) => {
342
+ if (session.auth) {
343
+ const countryCodeFromLocalStorage = await strategy.getItem('country-code')
344
+ const customerFromLocalStorage = await strategy.getItem('user-customer', true)
345
+ const userCustomerId = customerFromLocalStorage?.id
346
+ const body = {
347
+ ...changes,
348
+ user_id: userCustomerId || session.user.id
349
+ }
350
+ try {
351
+ setState({ ...state, loading: true })
352
+ const options = {}
353
+ state.loading = true
354
+ options.headers = {
355
+ 'X-App-X': ordering.appId,
356
+ 'X-Socket-Id-X': socket?.getId()
357
+ }
358
+ const countryCode = changes?.country_code && changes?.country_code !== state?.options?.address?.country_code
359
+ ? changes?.country_code
360
+ : countryCodeFromLocalStorage ?? changes?.country_code ?? state?.options?.address?.country_code
361
+
362
+ if (countryCode) {
363
+ options.headers = {
364
+ ...options.headers,
365
+ 'X-Country-Code-X': countryCode
366
+ }
367
+ await strategy.setItem('country-code', countryCode)
368
+ }
369
+ if (franchiseId) {
370
+ options.query = {
371
+ ...options.query,
372
+ franchise_id: franchiseId
373
+ }
374
+ }
375
+ if (body?.country_code) {
376
+ delete body?.country_code
377
+ }
378
+ const { content: { error, result } } = await ordering
379
+ .setAccessToken(session.token)
380
+ .orderOptions()
381
+ .save(body, options)
382
+ if (!error) {
383
+ const { carts, ...options } = result
384
+ state.carts = {}
385
+ carts.forEach(cart => {
386
+ state.carts[`businessId:${cart.business_id}`] = cart
387
+ })
388
+ state.options = {
389
+ ...state.options,
390
+ ...options
391
+ }
392
+ } else {
393
+ setAlert({ show: true, content: result })
394
+ }
395
+ setState({ ...state, loading: false })
396
+ state.loading = false
397
+ return !error
398
+ } catch (err) {
399
+ const message = err?.message?.includes('Internal error')
400
+ ? 'INTERNAL_ERROR'
401
+ : err.message
402
+ setAlert({ show: true, content: [message] })
403
+ setState({ ...state, loading: false })
404
+ state.loading = false
405
+ return false
406
+ }
407
+ }
408
+ }
409
+
410
+ /**
411
+ * Add product to cart
412
+ * @param {object} product product for add
413
+ * @param {object} cart cart of the product
414
+ * @param {boolean} isQuickAddProduct option to add product when clicks
415
+ */
416
+ const addProduct = async (
417
+ product,
418
+ cart,
419
+ isQuickAddProduct,
420
+ isPlatformProduct = false
421
+ ) => {
422
+ try {
423
+ setState({ ...state, loading: true })
424
+ const countryCode = await strategy.getItem('country-code')
425
+ const customerFromLocalStorage = await strategy.getItem('user-customer', true)
426
+ const userCustomerId = customerFromLocalStorage?.id
427
+ let body
428
+ const headers = {
429
+ 'X-Socket-Id-X': socket?.getId(),
430
+ 'X-Country-Code-X': countryCode
431
+ }
432
+ if (!isPlatformProduct) {
433
+ body = {
434
+ product,
435
+ business_id: cart.business_id,
436
+ user_id: userCustomerId || session.user.id
437
+ }
438
+ } else {
439
+ body = {
440
+ platform_product: { ...product }
441
+ }
442
+ }
443
+
444
+ const { content: { error, result } } = await ordering.setAccessToken(session.token).carts().addProduct(body, { headers })
445
+
446
+ if (!error) {
447
+ state.carts[`businessId:${result.business_id}`] = result
448
+ events.emit('cart_product_added', product, result)
449
+ if (product?.favorite) {
450
+ events.emit('wishlist_product_added_to_cart', product, result)
451
+ }
452
+ events.emit('cart_updated', result)
453
+ events.emit('product_added', product, result)
454
+ isQuickAddProduct && !isDisableToast && showToast(ToastType.Success, t('PRODUCT_ADDED_NOTIFICATION', 'Product _PRODUCT_ added succesfully').replace('_PRODUCT_', product.name))
455
+ } else {
456
+ setAlert({ show: true, content: result })
457
+ }
458
+ setState({ ...state, loading: false })
459
+ if (isPlatformProduct) {
460
+ return { error, result }
461
+ } else {
462
+ return !error
463
+ }
464
+ } catch (err) {
465
+ setState({ ...state, loading: false })
466
+ if (isPlatformProduct) {
467
+ return { error: true, result: err.message }
468
+ } else {
469
+ return false
470
+ }
471
+ }
472
+ }
473
+
474
+ /**
475
+ * Add multi products to cart / (domino's)
476
+ * @param {object} product product for add
477
+ * @param {object} cart cart of the product
478
+ * @param {boolean} isQuickAddProduct option to add product when clicks
479
+ */
480
+ const addMultiProduct = async (
481
+ product,
482
+ cart,
483
+ isQuickAddProduct
484
+ ) => {
485
+ try {
486
+ setState({ ...state, loading: true })
487
+ const countryCode = await strategy.getItem('country-code')
488
+ const customerFromLocalStorage = await strategy.getItem('user-customer', true)
489
+ const userCustomerId = customerFromLocalStorage?.id
490
+ const headers = {
491
+ 'X-Socket-Id-X': socket?.getId(),
492
+ 'X-Country-Code-X': countryCode
493
+ }
494
+ const body = {
495
+ products: JSON.stringify(product),
496
+ business_id: cart.business_id,
497
+ user_id: userCustomerId || session.user.id
498
+ }
499
+ const response = await fetch(`${ordering.root}/carts/multi_product`, {
500
+ method: 'POST',
501
+ body: JSON.stringify({
502
+ ...body,
503
+ products: JSON.stringify([product])
504
+ }),
505
+ headers: {
506
+ ...headers,
507
+ Authorization: `Bearer ${session.token}`,
508
+ 'Content-Type': 'application/json'
509
+ }
510
+ })
511
+ const { result, error } = await response.json()
512
+ if (!error) {
513
+ state.carts[`businessId:${result.business_id}`] = result
514
+ events.emit('cart_product_added', product, result)
515
+ if (product?.favorite) {
516
+ events.emit('wishlist_product_added_to_cart', product, result)
517
+ }
518
+ events.emit('cart_updated', result)
519
+ events.emit('product_added', product, result)
520
+ isQuickAddProduct && !isDisableToast && showToast(ToastType.Success, t('PRODUCT_ADDED_NOTIFICATION', 'Product _PRODUCT_ added succesfully').replace('_PRODUCT_', product.name))
521
+ } else {
522
+ setAlert({ show: true, content: result })
523
+ }
524
+ setState({ ...state, loading: false })
525
+ return !error
526
+ } catch (err) {
527
+ setState({ ...state, loading: false })
528
+ return false
529
+ }
530
+ }
531
+
532
+ /**
533
+ * Remove product to cart
534
+ */
535
+ const removeProduct = async (product, cart) => {
536
+ try {
537
+ setState({ ...state, loading: true })
538
+ const countryCode = await strategy.getItem('country-code')
539
+ const customerFromLocalStorage = await strategy.getItem('user-customer', true)
540
+ const userCustomerId = customerFromLocalStorage?.id
541
+ const body = {
542
+ product: {
543
+ id: product.id,
544
+ code: product.code,
545
+ business_id: product.business_id
546
+ },
547
+ business_id: cart.business_id,
548
+ user_id: userCustomerId || session.user.id
549
+ }
550
+ const { content: { error, result } } = await ordering.setAccessToken(session.token).carts().removeProduct(body, {
551
+ headers: {
552
+ 'X-App-X': ordering.appId,
553
+ 'X-Socket-Id-X': socket?.getId(),
554
+ 'X-Country-Code-X': countryCode
555
+ }
556
+ })
557
+ if (!error) {
558
+ state.carts[`businessId:${result.business_id}`] = result
559
+ events.emit('cart_product_removed', product, result)
560
+ events.emit('cart_updated', result)
561
+ } else {
562
+ setAlert({ show: true, content: result })
563
+ }
564
+ setState({ ...state, loading: false })
565
+ return !error
566
+ } catch (err) {
567
+ setState({ ...state, loading: false })
568
+ return false
569
+ }
570
+ }
571
+
572
+ /**
573
+ * Clear products of cart
574
+ */
575
+ const clearCart = async (uuid, configurations = {}) => {
576
+ try {
577
+ setState({ ...state, loading: !configurations?.disableLoading })
578
+ const countryCode = await strategy.getItem('country-code')
579
+ const customerFromLocalStorage = await strategy.getItem('user-customer', true)
580
+ const userCustomerId = customerFromLocalStorage?.id
581
+ const body = JSON.stringify({
582
+ uuid,
583
+ user_id: userCustomerId || session.user.id
584
+ })
585
+ const response = await fetch(`${ordering.root}/carts/clear`, {
586
+ method: 'POST',
587
+ headers: {
588
+ 'Content-Type': 'application/json',
589
+ Authorization: `Bearer ${session.token}`,
590
+ 'X-App-X': ordering.appId,
591
+ 'X-Socket-Id-X': socket?.getId(),
592
+ 'X-Country-Code-X': countryCode
593
+ },
594
+ body
595
+ })
596
+ const { error, result } = await response.json()
597
+ if (!error) {
598
+ state.carts[`businessId:${result.business_id}`] = result
599
+ } else {
600
+ setAlert({ show: true, content: result })
601
+ }
602
+ setState({ ...state, loading: false })
603
+ return { error, result }
604
+ } catch (err) {
605
+ setState({ ...state, loading: false })
606
+ return false
607
+ }
608
+ }
609
+
610
+ /**
611
+ * Update product to cart
612
+ */
613
+ const updateProduct = async (product, cart, isQuickAddProduct) => {
614
+ try {
615
+ setState({ ...state, loading: true })
616
+ const countryCode = await strategy.getItem('country-code')
617
+ const customerFromLocalStorage = await strategy.getItem('user-customer', true)
618
+ const userCustomerId = customerFromLocalStorage?.id
619
+ const body = {
620
+ product,
621
+ business_id: cart.business_id,
622
+ user_id: userCustomerId || session.user.id
623
+ }
624
+ const { content: { error, result } } = await ordering.setAccessToken(session.token).carts().updateProduct(body, {
625
+ headers: {
626
+ 'X-Socket-Id-X': socket?.getId(),
627
+ 'X-Country-Code-X': countryCode
628
+ }
629
+ })
630
+ if (!error) {
631
+ state.carts[`businessId:${result.business_id}`] = result
632
+ events.emit('cart_product_updated', product, result)
633
+ events.emit('cart_updated', result)
634
+ isQuickAddProduct && !isDisableToast && showToast(ToastType.Success, t('PRODUCT_UPDATED_NOTIFICATION', 'Product _PRODUCT_ updated succesfully').replace('_PRODUCT_', product.name))
635
+ } else {
636
+ setAlert({ show: true, content: result })
637
+ }
638
+ setState({ ...state, loading: false })
639
+ return !error
640
+ } catch (err) {
641
+ setState({ ...state, loading: false })
642
+ return false
643
+ }
644
+ }
645
+
646
+ /**
647
+ * Apply coupon to cart
648
+ */
649
+ const applyCoupon = async (couponData, customParams) => {
650
+ if (!couponData.business_id) {
651
+ throw new Error('`business_id` is required.')
652
+ }
653
+ if (typeof couponData.coupon === 'undefined') {
654
+ throw new Error('`coupon` is required.')
655
+ }
656
+ if (state.carts[`businessId:${couponData.business_id}`]?.coupon === couponData.coupon) {
657
+ return
658
+ }
659
+
660
+ try {
661
+ setState({ ...state, loading: true })
662
+ const countryCode = await strategy.getItem('country-code')
663
+ if (customParams && isAlsea) {
664
+ const response = await fetch('https://alsea-plugins.ordering.co/alseaplatform/vcoupon2.php', {
665
+ method: 'POST',
666
+ body: JSON.stringify({
667
+ userId: customParams.userId,
668
+ businessId: customParams.businessId,
669
+ couponId: couponData.coupon
670
+ }),
671
+ headers: {
672
+ Accept: 'application/json',
673
+ 'Content-Type': 'application/x-www-form-urlencoded',
674
+ 'Access-Control-Allow-Origin': '*',
675
+ 'X-App-X': ordering.appId,
676
+ 'X-Socket-Id-X': socket?.getId(),
677
+ 'X-Country-Code-X': countryCode
678
+ }
679
+ })
680
+ const result = await response.json()
681
+
682
+ if (result.message !== 'Cup\u00f3n v\u00e1lido') {
683
+ setAlert({ show: true, content: result.message === 'Not found' ? ['ERROR_INVALID_COUPON'] : [result.message] })
684
+ setState({ ...state, loading: false })
685
+ return
686
+ }
687
+ }
688
+ const customerFromLocalStorage = await strategy.getItem('user-customer', true)
689
+ const userCustomerId = customerFromLocalStorage?.id
690
+ const body = {
691
+ business_id: couponData.business_id,
692
+ coupon: couponData.coupon,
693
+ user_id: userCustomerId || session.user.id
694
+ }
695
+ const { content } = await ordering
696
+ .setAccessToken(session.token)
697
+ .carts()
698
+ .applyCoupon(body, {
699
+ headers: {
700
+ 'X-App-X': ordering.appId,
701
+ 'X-Socket-Id-X': socket?.getId(),
702
+ 'X-Country-Code-X': countryCode
703
+ }
704
+ })
705
+ const result = content
706
+ if (!result.error) {
707
+ state.carts[`businessId:${result.result.business_id}`] = result.result
708
+ events.emit('cart_updated', result.result)
709
+ } else {
710
+ setAlert({ show: true, content: result.result })
711
+ }
712
+ setState({ ...state, loading: false })
713
+ return !result.error
714
+ } catch (err) {
715
+ setState({ ...state, loading: false })
716
+ return false
717
+ }
718
+ }
719
+
720
+ const applyOffer = async (offerData) => {
721
+ if (!offerData.business_id) {
722
+ throw new Error('`business_id` is required.')
723
+ }
724
+ if (typeof offerData.coupon === 'undefined') {
725
+ throw new Error('`coupon` is required.')
726
+ }
727
+ try {
728
+ setState({ ...state, loading: true })
729
+ const countryCode = await strategy.getItem('country-code')
730
+ const response = await fetch(`${ordering.root}/carts/add_offer`, {
731
+ method: 'POST',
732
+ body: JSON.stringify({
733
+ user_id: offerData.userId,
734
+ business_id: offerData.business_id,
735
+ coupon: offerData.coupon,
736
+ force: offerData.force ?? false
737
+ }),
738
+ headers: {
739
+ 'Content-Type': 'application/json',
740
+ Authorization: `Bearer ${session.token}`,
741
+ 'X-App-X': ordering.appId,
742
+ 'X-Socket-Id-X': socket?.getId(),
743
+ 'X-Country-Code-X': countryCode
744
+ }
745
+ })
746
+ const result = await response.json()
747
+ if (!result.error) {
748
+ state.carts[`businessId:${result.result.business_id}`] = result.result
749
+ events.emit('cart_updated', result.result)
750
+ events.emit('offer_applied', { ...result.result, ...offerData })
751
+ } else {
752
+ setAlert({ show: true, content: result.result })
753
+ events.emit('offer_denied', { ...offerData, reason: result.result })
754
+ }
755
+ setState({ ...state, loading: false })
756
+ return !result.error
757
+ } catch (err) {
758
+ setState({ ...state, loading: false })
759
+ return false
760
+ }
761
+ }
762
+
763
+ const removeOffer = async (offerData) => {
764
+ if (!offerData.business_id) {
765
+ throw new Error('`business_id` is required.')
766
+ }
767
+ if (typeof offerData.offer_id === 'undefined') {
768
+ throw new Error('`offer_id` is required.')
769
+ }
770
+ try {
771
+ const countryCode = await strategy.getItem('country-code')
772
+ setState({ ...state, loading: true })
773
+ const offerRemoveData = {
774
+ business_id: offerData.business_id,
775
+ offer_id: offerData.offer_id
776
+ }
777
+ if (offerData.user_id) offerRemoveData.user_id = offerData.user_id
778
+ const response = await fetch(`${ordering.root}/carts/remove_offer`, {
779
+ method: 'POST',
780
+ body: JSON.stringify(offerRemoveData),
781
+ headers: {
782
+ 'Content-Type': 'application/json',
783
+ Authorization: `Bearer ${session.token}`,
784
+ 'X-App-X': ordering.appId,
785
+ 'X-Socket-Id-X': socket?.getId(),
786
+ 'X-Country-Code-X': countryCode
787
+ }
788
+ })
789
+ const result = await response.json()
790
+ if (!result.error) {
791
+ state.carts[`businessId:${result.result.business_id}`] = result.result
792
+ events.emit('cart_updated', result.result)
793
+ events.emit('offer_removed', offerData)
794
+ } else {
795
+ setAlert({ show: true, content: result.result })
796
+ }
797
+ setState({ ...state, loading: false })
798
+ return !result.error
799
+ } catch (err) {
800
+ setState({ ...state, loading: false })
801
+ return false
802
+ }
803
+ }
804
+
805
+ /**
806
+ * Apply coupon to cart
807
+ */
808
+ const changeDriverTip = async (businessId, driverTipRate = 0, isFixedPrice) => {
809
+ if (!businessId) {
810
+ throw new Error('`businessId` is required.')
811
+ }
812
+ if (!driverTipRate && driverTipRate !== 0) {
813
+ throw new Error('`driverTipRate` is required.')
814
+ }
815
+ if (!state.carts[`businessId:${businessId}`] || state.carts[`businessId:${businessId}`]?.driver_tip_rate === driverTipRate) {
816
+ return
817
+ }
818
+ try {
819
+ setState({ ...state, loading: true })
820
+ const countryCode = await strategy.getItem('country-code')
821
+ const customerFromLocalStorage = await strategy.getItem('user-customer', true)
822
+ const userCustomerId = customerFromLocalStorage?.id
823
+ const body = {
824
+ business_id: businessId,
825
+ [isFixedPrice ? 'driver_tip' : 'driver_tip_rate']: driverTipRate,
826
+ user_id: userCustomerId || session.user.id
827
+ }
828
+ const { content: { error, result } } = await ordering.setAccessToken(session.token).carts().changeDriverTip(body, {
829
+ headers: {
830
+ 'X-Socket-Id-X': socket?.getId(),
831
+ 'X-Country-Code-X': countryCode
832
+ }
833
+ })
834
+ if (!error) {
835
+ state.carts[`businessId:${result.business_id}`] = result
836
+ events.emit('cart_updated', result)
837
+ } else {
838
+ setAlert({ show: true, content: result })
839
+ }
840
+ setState({ ...state, loading: false })
841
+ return !error
842
+ } catch (err) {
843
+ setState({ ...state, loading: false })
844
+ return false
845
+ }
846
+ }
847
+
848
+ /**
849
+ * Change payment method
850
+ */
851
+ const changePaymethod = async (businessId, paymethodId, paymethodData) => {
852
+ if (!businessId) {
853
+ throw new Error('`businessId` is required.')
854
+ }
855
+ if (!paymethodId) {
856
+ throw new Error('`paymethodId` is required.')
857
+ }
858
+ if (!paymethodData) {
859
+ throw new Error('`paymethodData` is required.')
860
+ }
861
+ if (!state.carts[`businessId:${businessId}`] || state.carts[`businessId:${businessId}`]?.paymethodId === paymethodId) {
862
+ return
863
+ }
864
+ try {
865
+ setState({ ...state, loading: true })
866
+ const countryCode = await strategy.getItem('country-code')
867
+ const customerFromLocalStorage = await strategy.getItem('user-customer', true)
868
+ const userCustomerId = customerFromLocalStorage?.id
869
+ const body = {
870
+ business_id: businessId,
871
+ paymethod_id: paymethodId,
872
+ paymethod_data: paymethodData,
873
+ user_id: userCustomerId ?? session.user.id
874
+ }
875
+ const { content: { error, result } } = await ordering.setAccessToken(session.token).carts().changePaymethod(body, {
876
+ headers: {
877
+ 'X-Socket-Id-X': socket?.getId(),
878
+ 'X-Country-Code-X': countryCode
879
+ }
880
+ })
881
+ if (!error) {
882
+ state.carts[`businessId:${result.business_id}`] = result
883
+ events.emit('cart_updated', result)
884
+ }
885
+ setState({ ...state, loading: false })
886
+ return !error
887
+ } catch (err) {
888
+ return false
889
+ }
890
+ }
891
+
892
+ /**
893
+ * Place cart
894
+ */
895
+ const placeCart = async (cardId, data) => {
896
+ try {
897
+ setState({ ...state, loading: true })
898
+ const countryCode = await strategy.getItem('country-code')
899
+ const customerFromLocalStorage = await strategy.getItem('user-customer', true)
900
+ const userCustomerId = customerFromLocalStorage?.id
901
+ const body = {
902
+ ...data,
903
+ user_id: userCustomerId || session.user.id
904
+ }
905
+ let headers = {
906
+ 'X-Socket-Id-X': socket?.getId(),
907
+ 'X-Country-Code-X': countryCode
908
+ }
909
+ if (userAgent) {
910
+ headers = { ...headers, 'User-Agent': userAgent }
911
+ }
912
+ const { content: { error, result } } = await ordering.setAccessToken(session.token).carts(cardId).place(body, { headers: headers })
913
+ if (!error) {
914
+ if (result.status !== 1) {
915
+ state.carts[`businessId:${result.business_id}`] = result
916
+ events.emit('cart_updated', result)
917
+ } else {
918
+ delete state.carts[`businessId:${result.business_id}`]
919
+ const orderObject = {
920
+ id: result.order.uuid,
921
+ business: { name: result.business.name },
922
+ total: result.total,
923
+ tax_total: result.tax,
924
+ delivery_zone_price: result.delivery_price,
925
+ business_id: result.business_id,
926
+ paymethod: result.paymethod_data.gateway
927
+ }
928
+ events.emit('order_placed', orderObject)
929
+ }
930
+ } else {
931
+ setAlert({ show: true, content: result })
932
+ setState({ ...state, loading: false })
933
+ return
934
+ }
935
+ setState({ ...state, loading: false })
936
+ return { error, result }
937
+ } catch (err) {
938
+ setState({ ...state, loading: false })
939
+ return {
940
+ error: true,
941
+ result: [err.message]
942
+ }
943
+ }
944
+ }
945
+
946
+ /**
947
+ * Place multi carts
948
+ */
949
+ const placeMultiCarts = async (data, cartUuid) => {
950
+ try {
951
+ setState({ ...state, loading: true })
952
+ const countryCode = await strategy.getItem('country-code')
953
+ const customerFromLocalStorage = await strategy.getItem('user-customer', true)
954
+ const userCustomerId = customerFromLocalStorage?.id
955
+ const body = {
956
+ ...data,
957
+ user_id: userCustomerId || session.user.id
958
+ }
959
+ const requestOptions = {
960
+ method: 'POST',
961
+ headers: {
962
+ 'Content-Type': 'application/json',
963
+ Authorization: `bearer ${session.token}`,
964
+ 'X-App-X': ordering.appId,
965
+ 'X-Socket-Id-X': socket?.getId(),
966
+ 'X-Country-Code-X': countryCode
967
+ },
968
+ body: JSON.stringify(body)
969
+ }
970
+
971
+ const response = await fetch(`${ordering.root}/cart_groups/${cartUuid}/place`, requestOptions)
972
+ const { error, result } = await response.json()
973
+ if (!error) {
974
+ result.carts.forEach(cart => {
975
+ delete state.carts[`businessId:${cart.business_id}`]
976
+ const orderObject = {
977
+ id: cart.uuid,
978
+ business: { name: cart.business.name },
979
+ total: cart.total,
980
+ tax_total: cart.tax,
981
+ delivery_zone_price: cart.delivery_price,
982
+ business_id: cart.business_id
983
+ }
984
+ events.emit('order_placed', orderObject)
985
+ })
986
+ } else {
987
+ setAlert({ show: true, content: result })
988
+ }
989
+ setState({ ...state, loading: false })
990
+ return { error, result }
991
+ } catch (err) {
992
+ setState({ ...state, loading: false })
993
+ return {
994
+ error: true,
995
+ result: [err.message]
996
+ }
997
+ }
998
+ }
999
+
1000
+ /**
1001
+ * Confirm cart
1002
+ */
1003
+ const confirmCart = async (cardId, data) => {
1004
+ try {
1005
+ setState({ ...state, loading: true })
1006
+ const countryCode = await strategy.getItem('country-code')
1007
+ const customerFromLocalStorage = await strategy.getItem('user-customer', true)
1008
+ const userCustomerId = customerFromLocalStorage?.id
1009
+ const body = {
1010
+ ...data,
1011
+ user_id: userCustomerId || session.user.id
1012
+ }
1013
+ let fetchurl
1014
+ if (body.user_id === userCustomerId || data) {
1015
+ fetchurl = await ordering.setAccessToken(session.token).carts(cardId).confirmWithData(body, {
1016
+ headers: {
1017
+ 'X-App-X': ordering.appId,
1018
+ 'X-Socket-Id-X': socket?.getId(),
1019
+ 'X-Country-Code-X': countryCode
1020
+ }
1021
+ })
1022
+ } else {
1023
+ fetchurl = await ordering.setAccessToken(session.token).carts(cardId).confirm(body, {
1024
+ headers: {
1025
+ 'X-App-X': ordering.appId,
1026
+ 'X-Socket-Id-X': socket?.getId(),
1027
+ 'X-Country-Code-X': countryCode
1028
+ }
1029
+ })
1030
+ }
1031
+ const { content: { error, result, cart } } = fetchurl
1032
+ if (!error) {
1033
+ if (result.status !== 1) {
1034
+ state.carts[`businessId:${result.business_id}`] = result
1035
+ events.emit('cart_updated', result)
1036
+ } else {
1037
+ delete state.carts[`businessId:${result.business_id}`]
1038
+ }
1039
+ } else if (cart) {
1040
+ state.carts[`businessId:${cart.business_id}`] = cart
1041
+ events.emit('cart_updated', cart)
1042
+ }
1043
+ setState({ ...state, loading: false })
1044
+ return { error, result }
1045
+ } catch (err) {
1046
+ setState({ ...state, loading: false })
1047
+ return {
1048
+ error: true,
1049
+ result: [err.message]
1050
+ }
1051
+ }
1052
+ }
1053
+
1054
+ /**
1055
+ * Confirm multi carts
1056
+ */
1057
+ const confirmMultiCarts = async (cartUuid) => {
1058
+ try {
1059
+ setState({ ...state, loading: true })
1060
+ const countryCode = await strategy.getItem('country-code')
1061
+ const requestOptions = {
1062
+ method: 'POST',
1063
+ headers: {
1064
+ 'Content-Type': 'application/json',
1065
+ Authorization: `bearer ${session.token}`,
1066
+ 'X-App-X': ordering.appId,
1067
+ 'X-Socket-Id-X': socket?.getId(),
1068
+ 'X-Country-Code-X': countryCode
1069
+ }
1070
+ }
1071
+ const response = await fetch(`${ordering.root}/cart_groups/${cartUuid}/confirm`, requestOptions)
1072
+ const { result, error } = await response.json()
1073
+ if (!error) {
1074
+ result.carts.forEach(cart => {
1075
+ if (result.status !== 'completed') {
1076
+ state.carts[`businessId:${cart.business_id}`] = result
1077
+ events.emit('cart_updated', result)
1078
+ } else {
1079
+ delete state.carts[`businessId:${cart.business_id}`]
1080
+ }
1081
+ })
1082
+ }
1083
+ setState({ ...state, loading: false })
1084
+ return { error, result }
1085
+ } catch (err) {
1086
+ setState({ ...state, loading: false })
1087
+ return {
1088
+ error: true,
1089
+ result: [err.message]
1090
+ }
1091
+ }
1092
+ }
1093
+
1094
+ /**
1095
+ * Reorder an order and get cart
1096
+ */
1097
+ const reorder = async (orderId, offAlert, configurations = {}) => {
1098
+ try {
1099
+ setState({ ...state, loading: !configurations?.disableLoading })
1100
+ const countryCode = await strategy.getItem('country-code')
1101
+ const customerFromLocalStorage = await strategy.getItem('user-customer', true)
1102
+ const userCustomerId = customerFromLocalStorage?.id
1103
+ const query = userCustomerId
1104
+ ? { user_id: userCustomerId }
1105
+ : null
1106
+ const options = {
1107
+ headers: {
1108
+ 'X-App-X': ordering.appId,
1109
+ 'X-Socket-Id-X': socket?.getId(),
1110
+ 'X-Country-Code-X': countryCode
1111
+ }
1112
+ }
1113
+ if (query) {
1114
+ options.query = query
1115
+ }
1116
+ const { content: { error, result } } = await ordering.setAccessToken(session.token).orders(orderId).reorder(options)
1117
+ if (!error) {
1118
+ state.carts[`businessId:${result.business_id}`] = result
1119
+ events.emit('cart_added', result)
1120
+ } else if (!offAlert) {
1121
+ setAlert({ show: true, content: result })
1122
+ }
1123
+ setState({ ...state, loading: false })
1124
+ return { error, result }
1125
+ } catch (err) {
1126
+ setState({ ...state, loading: false })
1127
+ return { error: true, result: [err.message] }
1128
+ }
1129
+ }
1130
+
1131
+ const setOptionFromLocalStorage = async () => {
1132
+ const optionsLocalStorage = await strategy.getItem('options', true)
1133
+ setState({
1134
+ ...state,
1135
+ loading: false,
1136
+ options: isDisabledDefaultOpts
1137
+ ? { type: null, moment: null }
1138
+ : {
1139
+ type: optionsLocalStorage?.type || orderTypes[configState?.configs?.default_order_type?.value],
1140
+ moment: optionsLocalStorage?.moment || null,
1141
+ address: optionsLocalStorage?.address || state?.options?.address || {},
1142
+ city_id: optionsLocalStorage?.city_id || null
1143
+ }
1144
+ })
1145
+ }
1146
+
1147
+ /**
1148
+ * get Latest past Order that has no review
1149
+ */
1150
+ const getLastOrderHasNoReview = async () => {
1151
+ if (session?.token) {
1152
+ const pastOrderTypes = [1, 2, 5, 6, 10, 11, 12, 15, 16, 17]
1153
+ const where = [{ attribute: 'status', value: pastOrderTypes }]
1154
+ if (franchiseId) {
1155
+ where.push({
1156
+ attribute: 'ref_business',
1157
+ conditions: [
1158
+ {
1159
+ attribute: 'franchise_id',
1160
+ value: {
1161
+ condition: '=',
1162
+ value: franchiseId
1163
+ }
1164
+ }
1165
+ ]
1166
+ })
1167
+ }
1168
+ if (typeof businessSlug === 'number' && businessSlug) {
1169
+ where.push({
1170
+ attribute: 'ref_business',
1171
+ conditions: [
1172
+ {
1173
+ attribute: 'id',
1174
+ value: {
1175
+ condition: '=',
1176
+ value: businessSlug
1177
+ }
1178
+ }
1179
+ ]
1180
+ })
1181
+ }
1182
+ if (typeof businessSlug === 'string' && businessSlug) {
1183
+ where.push({
1184
+ attribute: 'ref_business',
1185
+ conditions: [
1186
+ {
1187
+ attribute: 'slug',
1188
+ value: {
1189
+ condition: '=',
1190
+ value: businessSlug
1191
+ }
1192
+ }
1193
+ ]
1194
+ })
1195
+ }
1196
+ if (typeof businessSlug === 'number' && businessSlug) {
1197
+ where.push({
1198
+ attribute: 'ref_business',
1199
+ conditions: [
1200
+ {
1201
+ attribute: 'id',
1202
+ value: {
1203
+ condition: '=',
1204
+ value: businessSlug
1205
+ }
1206
+ }
1207
+ ]
1208
+ })
1209
+ }
1210
+ if (typeof businessSlug === 'string' && businessSlug) {
1211
+ where.push({
1212
+ attribute: 'ref_business',
1213
+ conditions: [
1214
+ {
1215
+ attribute: 'slug',
1216
+ value: {
1217
+ condition: '=',
1218
+ value: businessSlug
1219
+ }
1220
+ }
1221
+ ]
1222
+ })
1223
+ }
1224
+ const options = {
1225
+ query: {
1226
+ orderBy: '-delivery_datetime',
1227
+ page: 1,
1228
+ page_size: 10,
1229
+ where
1230
+ }
1231
+ }
1232
+ const { content: { result, error } } = await ordering.setAccessToken(session?.token).orders().get(options)
1233
+
1234
+ if (!error && result?.length > 0) {
1235
+ const _noRviewOrder = result?.find(order => !order?.review)
1236
+ if (_noRviewOrder?.cart_group_id) {
1237
+ where.push({ attribute: 'cart_group_id', value: _noRviewOrder?.cart_group_id })
1238
+ const options = {
1239
+ query: {
1240
+ where,
1241
+ page: 1,
1242
+ page_size: 10
1243
+ }
1244
+ }
1245
+ const { content: { result, error } } = await ordering.setAccessToken(session?.token).orders().get(options)
1246
+ if (!error) {
1247
+ const noReviewOrders = result.filter(order => !order?.review)
1248
+ return noReviewOrders
1249
+ } else {
1250
+ return null
1251
+ }
1252
+ } else {
1253
+ return _noRviewOrder
1254
+ }
1255
+ } else {
1256
+ return null
1257
+ }
1258
+ } else {
1259
+ return null
1260
+ }
1261
+ }
1262
+
1263
+ const setStateValues = (values) => {
1264
+ setState({ ...state, ...values })
1265
+ }
1266
+
1267
+ const setUserCustomerOptions = async (params) => {
1268
+ setState({ ...state, loading: true })
1269
+ const options = params.options ?? {}
1270
+ await setUserCustomer(params.customer ?? {}, true)
1271
+ await updateOrderOptions(options)
1272
+ setState({ ...state, loading: false })
1273
+ }
1274
+
1275
+ useEffect(() => {
1276
+ if (session.loading || languageState.loading) return
1277
+ if (session.auth) {
1278
+ refreshOrderOptions()
1279
+ }
1280
+ }, [session.auth, session.loading, languageState.loading])
1281
+
1282
+ useEffect(() => {
1283
+ if (session.loading || configState.loading) return
1284
+ if (!session.auth) {
1285
+ setOptionFromLocalStorage()
1286
+ }
1287
+ }, [session.auth, session.loading, configState])
1288
+
1289
+ useEffect(() => {
1290
+ if (configTypes?.length > 0 && state.options.type && !configTypes.includes(state.options.type)) {
1291
+ const validDefaultValue = configTypes.includes(configState?.configs?.default_order_type?.type)
1292
+ updateOrderOptions(validDefaultValue ? { type: configState?.configs?.default_order_type?.type } : { type: configTypes[0] })
1293
+ }
1294
+ }, [configTypes?.length, state.options.type])
1295
+
1296
+ /**
1297
+ * Update carts from sockets
1298
+ */
1299
+ useEffect(() => {
1300
+ const handleCartUpdate = (cart) => {
1301
+ if (!isDisableToast) {
1302
+ showToast(ToastType.Info, t('UPDATING_CART_INFO', 'Updating cart information...'))
1303
+ }
1304
+
1305
+ if (cart.status === 1) {
1306
+ if (state.carts[`businessId:${cart.business_id}`]) {
1307
+ delete state.carts[`businessId:${cart.business_id}`]
1308
+ }
1309
+ } else {
1310
+ const cartFinded = Object.values(state.carts).find(_cart => _cart?.uuid === cart?.uuid)
1311
+ const oldBusinessId = cartFinded?.business_id
1312
+ const newBusinessId = cart?.business_id
1313
+
1314
+ if (!oldBusinessId || oldBusinessId === newBusinessId) {
1315
+ state.carts[`businessId:${cart.business_id}`] = {
1316
+ ...state.carts[`businessId:${cart.business_id}`],
1317
+ ...cart
1318
+ }
1319
+ } else {
1320
+ delete state.carts[`businessId:${oldBusinessId}`]
1321
+ state.carts[`businessId:${newBusinessId}`] = cart
1322
+ }
1323
+ }
1324
+ }
1325
+ const handleOrderOptionUpdate = ({ carts, ...options }) => {
1326
+ if (!isDisableToast) {
1327
+ showToast(ToastType.Info, t('UPDATING_ORDER_OPTIONS', 'Updating order options...'))
1328
+ }
1329
+
1330
+ const newCarts = {}
1331
+ carts.forEach(cart => {
1332
+ newCarts[`businessId:${cart.business_id}`] = cart
1333
+ })
1334
+ const newState = {
1335
+ ...state,
1336
+ options: {
1337
+ ...state.options,
1338
+ ...options
1339
+ },
1340
+ carts: {
1341
+ ...state.carts,
1342
+ ...newCarts
1343
+ }
1344
+ }
1345
+ setState({ ...newState, loading: false })
1346
+ }
1347
+ socket.on('carts_update', handleCartUpdate)
1348
+ socket.on('order_options_update', handleOrderOptionUpdate)
1349
+ return () => {
1350
+ socket.off('carts_update', handleCartUpdate)
1351
+ socket.off('order_options_update', handleOrderOptionUpdate)
1352
+ }
1353
+ }, [state, socket])
1354
+
1355
+ /**
1356
+ * Join to carts room
1357
+ */
1358
+ useEffect(() => {
1359
+ if (!session.auth || session.loading) return
1360
+ socket.join(`carts_${customerState?.user?.id || session?.user?.id}`)
1361
+ socket.join(`orderoptions_${customerState?.user?.id || session?.user?.id}`)
1362
+ return () => {
1363
+ socket.leave(`carts_${customerState?.user?.id || session?.user?.id}`)
1364
+ socket.leave(`orderoptions_${customerState?.user?.id || session?.user?.id}`)
1365
+ }
1366
+ }, [socket, session.auth, session.loading, customerState?.user?.id, session?.user?.id])
1367
+
1368
+ const functions = {
1369
+ refreshOrderOptions,
1370
+ changeAddress,
1371
+ changeType,
1372
+ changeMoment,
1373
+ addProduct,
1374
+ removeProduct,
1375
+ updateProduct,
1376
+ clearCart,
1377
+ applyCoupon,
1378
+ applyOffer,
1379
+ removeOffer,
1380
+ changeDriverTip,
1381
+ placeCart,
1382
+ confirmCart,
1383
+ reorder,
1384
+ setAlert,
1385
+ setConfirm,
1386
+ changePaymethod,
1387
+ setUserCustomerOptions,
1388
+ setStateValues,
1389
+ placeMultiCarts,
1390
+ getLastOrderHasNoReview,
1391
+ changeCityFilter,
1392
+ confirmMultiCarts,
1393
+ addMultiProduct
1394
+ }
1395
+
1396
+ const copyState = JSON.parse(JSON.stringify(state))
1397
+
1398
+ return (
1399
+ <OrderContext.Provider value={[copyState, functions]}>
1400
+ {
1401
+ Alert && (
1402
+ <Alert
1403
+ open={alert.show}
1404
+ title={alert.title || t('ERROR', 'Error')}
1405
+ onAccept={() => setAlert({ show: false })}
1406
+ onClose={() => setAlert({ show: false })}
1407
+ content={alert.content}
1408
+ />
1409
+ )
1410
+ }
1411
+ {children}
1412
+ </OrderContext.Provider>
1413
+ )
1414
+ }
1415
+
1416
+ /**
1417
+ * Hook to get and update order state
1418
+ */
1419
+ export const useOrder = () => {
1420
+ const orderManager = useContext(OrderContext)
1421
+ const warningMessage = () => {
1422
+ console.warn('Must use OrderProvider to wrappe the app.')
1423
+ }
1424
+ /**
1425
+ * Functions to avoid fails
1426
+ */
1427
+ const functionsPlaceholders = {
1428
+ refreshOrderOptions: warningMessage,
1429
+ changeAddress: warningMessage,
1430
+ changeType: warningMessage,
1431
+ changeMoment: warningMessage,
1432
+ addProduct: warningMessage,
1433
+ removeProduct: warningMessage,
1434
+ updateProduct: warningMessage,
1435
+ clearCart: warningMessage,
1436
+ applyCoupon: warningMessage,
1437
+ placeCart: warningMessage,
1438
+ confirmCart: warningMessage,
1439
+ setAlert: warningMessage,
1440
+ setConfirm: warningMessage,
1441
+ changeDriverTip: warningMessage,
1442
+ reorder: warningMessage,
1443
+ changePaymethod: warningMessage,
1444
+ setStateValues: warningMessage,
1445
+ getLastOrderHasNoReview: warningMessage
1446
+ }
1447
+ return orderManager || [{}, functionsPlaceholders]
1448
+ }