ordering-components-external 13.2.33 → 13.2.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 (537) hide show
  1. package/.babelrc +22 -22
  2. package/.vscode/settings.json +3 -3
  3. package/_bundles/{7.ordering-component.dd1dbfe86e478023f67a.js → 7.ordering-component.6cdb5ba8147ea6e69b23.js} +1 -1
  4. package/_bundles/{ordering-component.dd1dbfe86e478023f67a.js → ordering-component.6cdb5ba8147ea6e69b23.js} +2 -2
  5. package/_modules/components/AddressDetails/index.js +26 -26
  6. package/_modules/components/AddressForm/index.js +50 -50
  7. package/_modules/components/AddressList/index.js +40 -40
  8. package/_modules/components/Analitycs/index.js +6 -6
  9. package/_modules/components/AnalyticsSegment/index.js +3 -3
  10. package/_modules/components/AppleLogin/index.js +26 -26
  11. package/_modules/components/BaseComponent/index.js +14 -14
  12. package/_modules/components/BusinessAndProductList/index.js +16 -16
  13. package/_modules/components/BusinessBasicInformation/index.js +20 -20
  14. package/_modules/components/BusinessController/index.js +50 -50
  15. package/_modules/components/BusinessInformation/BusinessOption/index.js +20 -20
  16. package/_modules/components/BusinessInformation/index.js +18 -18
  17. package/_modules/components/BusinessList/index.js +42 -42
  18. package/_modules/components/BusinessMenuListing/index.js +20 -20
  19. package/_modules/components/BusinessProductsCategories/index.js +16 -16
  20. package/_modules/components/BusinessProductsSearch/index.js +14 -14
  21. package/_modules/components/BusinessReviews/index.js +27 -27
  22. package/_modules/components/BusinessSearchList/index.js +18 -18
  23. package/_modules/components/BusinessSortControl/index.js +28 -28
  24. package/_modules/components/BusinessTypeFilter/index.js +26 -26
  25. package/_modules/components/BusinessesMap/index.js +27 -27
  26. package/_modules/components/Cart/index.js +38 -38
  27. package/_modules/components/CartStoresListing/index.js +4 -4
  28. package/_modules/components/Checkout/index.js +60 -60
  29. package/_modules/components/CmsContent/index.js +20 -20
  30. package/_modules/components/Contacts/index.js +28 -28
  31. package/_modules/components/CouponControl/index.js +22 -22
  32. package/_modules/components/DriverList/index.js +22 -22
  33. package/_modules/components/DriverTips/index.js +35 -35
  34. package/_modules/components/FacebookLoginButton/index.js +40 -40
  35. package/_modules/components/FacebookPixel/index.js +3 -3
  36. package/_modules/components/FavoriteList/index.js +28 -28
  37. package/_modules/components/FirebaseGoogleLoginButton/index.js +10 -10
  38. package/_modules/components/FloatingButton/index.js +20 -20
  39. package/_modules/components/ForgotPasswordForm/index.js +43 -43
  40. package/_modules/components/GiftCard/GiftCardOrdersList/index.js +4 -4
  41. package/_modules/components/GiftCard/PurchaseGiftCard/index.js +6 -6
  42. package/_modules/components/GiftCard/RedeemGiftCard/index.js +4 -4
  43. package/_modules/components/GiftCard/SendGiftCard/index.js +4 -4
  44. package/_modules/components/GoogleAutocompleteInput/index.js +18 -18
  45. package/_modules/components/GoogleIdentity/index.js +28 -28
  46. package/_modules/components/GoogleLoginButton/index.js +49 -49
  47. package/_modules/components/GoogleMaps/index.js +37 -37
  48. package/_modules/components/GpsButton/index.js +20 -20
  49. package/_modules/components/LanguageSelector/index.js +28 -28
  50. package/_modules/components/LoginForm/index.js +58 -58
  51. package/_modules/components/LogoutAction/index.js +17 -17
  52. package/_modules/components/MainSearch/index.js +31 -31
  53. package/_modules/components/MenuControl/index.js +51 -51
  54. package/_modules/components/Messages/index.js +22 -22
  55. package/_modules/components/MomentOption/index.js +51 -51
  56. package/_modules/components/MultiCartCreate/index.js +2 -2
  57. package/_modules/components/MultiCartsPaymethodsAndWallets/index.js +8 -8
  58. package/_modules/components/MultiCheckout/index.js +12 -12
  59. package/_modules/components/MultiOrdersDetails/index.js +6 -6
  60. package/_modules/components/MyOrders/index.js +24 -24
  61. package/_modules/components/MyOrdersList/index.js +26 -26
  62. package/_modules/components/NewOrderNotification/index.js +2 -2
  63. package/_modules/components/OrderChange/index.js +20 -20
  64. package/_modules/components/OrderDetails/index.js +43 -43
  65. package/_modules/components/OrderList/index.js +44 -44
  66. package/_modules/components/OrderReview/index.js +22 -22
  67. package/_modules/components/OrderTypeControl/index.js +18 -18
  68. package/_modules/components/OrdersControlFilters/index.js +6 -6
  69. package/_modules/components/OrdersDashboardComponents/Appointments/index.js +4 -4
  70. package/_modules/components/OrdersDashboardComponents/BusinessProductsListing/index.js +26 -26
  71. package/_modules/components/OrdersDashboardComponents/CheckPassword/index.js +24 -24
  72. package/_modules/components/OrdersDashboardComponents/CityList/index.js +20 -20
  73. package/_modules/components/OrdersDashboardComponents/CountryList/index.js +20 -20
  74. package/_modules/components/OrdersDashboardComponents/CustomOrderDetails/index.js +12 -12
  75. package/_modules/components/OrdersDashboardComponents/DashboardBusinessList/index.js +54 -54
  76. package/_modules/components/OrdersDashboardComponents/DashboardOrdersList/index.js +60 -60
  77. package/_modules/components/OrdersDashboardComponents/DriversList/index.js +58 -58
  78. package/_modules/components/OrdersDashboardComponents/ExportCSV/index.js +16 -16
  79. package/_modules/components/OrdersDashboardComponents/GiftCardsList/index.js +6 -6
  80. package/_modules/components/OrdersDashboardComponents/GoogleMapsApiKeySetting/index.js +4 -4
  81. package/_modules/components/OrdersDashboardComponents/LogisticInformation/index.js +20 -20
  82. package/_modules/components/OrdersDashboardComponents/Logistics/index.js +20 -20
  83. package/_modules/components/OrdersDashboardComponents/Messages/index.js +27 -27
  84. package/_modules/components/OrdersDashboardComponents/MetaFields/index.js +26 -26
  85. package/_modules/components/OrdersDashboardComponents/OrderDetails/index.js +36 -36
  86. package/_modules/components/OrdersDashboardComponents/OrderNotification/index.js +14 -14
  87. package/_modules/components/OrdersDashboardComponents/OrdersFilter/index.js +62 -62
  88. package/_modules/components/OrdersDashboardComponents/OrdersManage/index.js +56 -56
  89. package/_modules/components/OrdersDashboardComponents/PointsWalletLevels/index.js +25 -25
  90. package/_modules/components/OrdersDashboardComponents/ReviewCustomer/index.js +16 -16
  91. package/_modules/components/OrdersDashboardComponents/Schedule/index.js +46 -46
  92. package/_modules/components/OrdersDashboardComponents/SettingsList/index.js +39 -39
  93. package/_modules/components/OrdersDashboardComponents/UserFormDetails/index.js +66 -66
  94. package/_modules/components/OrdersDashboardComponents/UsersList/index.js +54 -54
  95. package/_modules/components/OrdersDashboardComponents/WebsocketStatus/index.js +4 -4
  96. package/_modules/components/PageBanner/index.js +4 -4
  97. package/_modules/components/PaymentOptionCash/index.js +24 -24
  98. package/_modules/components/PaymentOptionPaypal/index.js +24 -24
  99. package/_modules/components/PaymentOptionSquare/index.js +2 -2
  100. package/_modules/components/PaymentOptionStripe/index.js +32 -32
  101. package/_modules/components/PaymentOptionStripeDirect/index.js +24 -24
  102. package/_modules/components/PaymentOptionStripeLink/index.js +4 -4
  103. package/_modules/components/PaymentOptionStripeRedirect/StripeRedirectForm/index.js +19 -19
  104. package/_modules/components/PaymentOptionStripeRedirect/index.js +30 -30
  105. package/_modules/components/PaymentOptions/index.js +27 -27
  106. package/_modules/components/PaymethodList/index.js +20 -20
  107. package/_modules/components/PhoneAutocomplete/index.js +18 -18
  108. package/_modules/components/PlaceSpot/index.js +2 -2
  109. package/_modules/components/Popup/index.js +33 -33
  110. package/_modules/components/ProductComponent/index.js +27 -27
  111. package/_modules/components/ProductForm/index.js +159 -135
  112. package/_modules/components/ProductImages/index.js +18 -18
  113. package/_modules/components/ProductIngredient/index.js +17 -17
  114. package/_modules/components/ProductItemAccordion/index.js +8 -8
  115. package/_modules/components/ProductOption/index.js +8 -8
  116. package/_modules/components/ProductOptionSuboption/index.js +33 -33
  117. package/_modules/components/ProductShare/index.js +20 -20
  118. package/_modules/components/ProductsList/index.js +20 -20
  119. package/_modules/components/ProductsListing/index.js +39 -39
  120. package/_modules/components/ProfessionalInfo/index.js +24 -24
  121. package/_modules/components/QueryLoginSpoonity/index.js +20 -20
  122. package/_modules/components/ReCaptcha/index.js +4 -4
  123. package/_modules/components/ResetPassword/index.js +20 -20
  124. package/_modules/components/ReviewCustomer/index.js +16 -16
  125. package/_modules/components/ReviewDriver/index.js +20 -20
  126. package/_modules/components/ReviewProduct/index.js +22 -22
  127. package/_modules/components/SearchOptions/index.js +17 -17
  128. package/_modules/components/Sessions/index.js +21 -21
  129. package/_modules/components/SignupForm/index.js +57 -57
  130. package/_modules/components/SingleBusinessCard/index.js +28 -28
  131. package/_modules/components/SingleOrderCard/index.js +20 -20
  132. package/_modules/components/SingleProductCard/index.js +18 -18
  133. package/_modules/components/SingleProfessionalCard/index.js +18 -18
  134. package/_modules/components/SmartAppBanner/index.js +8 -8
  135. package/_modules/components/StoreProductList/index.js +22 -22
  136. package/_modules/components/StripeElementsForm/CardForm/index.js +25 -25
  137. package/_modules/components/StripeElementsForm/index.js +16 -16
  138. package/_modules/components/UpsellingPage/index.js +19 -19
  139. package/_modules/components/UserFormDetails/index.js +68 -68
  140. package/_modules/components/UserVerification/index.js +16 -16
  141. package/_modules/components/WebsocketStatus/index.js +4 -4
  142. package/_modules/components/WrapperGoogleMaps/index.js +3 -3
  143. package/_modules/contexts/ApiContext/index.js +8 -8
  144. package/_modules/contexts/BillingContext/index.js +7 -7
  145. package/_modules/contexts/BusinessContext/index.js +9 -9
  146. package/_modules/contexts/ConfigContext/index.js +9 -9
  147. package/_modules/contexts/EventContext/index.js +9 -9
  148. package/_modules/contexts/LanguageContext/index.js +13 -13
  149. package/_modules/contexts/OptimizationLoadContext/index.js +8 -8
  150. package/_modules/contexts/OrderContext/index.js +62 -62
  151. package/_modules/contexts/OrderingContext/index.js +7 -7
  152. package/_modules/contexts/OrderingThemeContext/index.js +11 -11
  153. package/_modules/contexts/ProductContext/index.js +13 -13
  154. package/_modules/contexts/SessionContext/index.js +9 -9
  155. package/_modules/contexts/SiteContext/index.js +9 -9
  156. package/_modules/contexts/UtilsContext/index.js +9 -9
  157. package/_modules/contexts/WebsocketContext/index.js +9 -9
  158. package/_modules/native/src/contexts/OrderingContext/index.js +7 -7
  159. package/cypress/fixtures/example.json +4 -4
  160. package/cypress/integration/naked/BusinessProductsCategories.spec.js +9 -9
  161. package/cypress/integration/naked/PhoneAutocomplete.spec.js +22 -22
  162. package/cypress/integration/naked/activeOrders.spec.js +15 -15
  163. package/cypress/integration/naked/addressDetails.spec.js +10 -10
  164. package/cypress/integration/naked/appleLogin.spec.js +14 -14
  165. package/cypress/integration/naked/businessBasicInformation.spec.js +14 -14
  166. package/cypress/integration/naked/businessController.spec.js +9 -9
  167. package/cypress/integration/naked/businessInformation.spec.js +19 -19
  168. package/cypress/integration/naked/businessProductsSearch.spec.js +9 -9
  169. package/cypress/integration/naked/businessReviews.spec.js +16 -16
  170. package/cypress/integration/naked/businessSortControl.spec.js +9 -9
  171. package/cypress/integration/naked/businessTypeFilter.spec.js +10 -10
  172. package/cypress/integration/naked/businessesMap.spec.js +13 -13
  173. package/cypress/integration/naked/cms.spec.js +9 -9
  174. package/cypress/integration/naked/config.spec.js +34 -34
  175. package/cypress/integration/naked/driverTips.spec.js +10 -10
  176. package/cypress/integration/naked/events.spec.js +13 -13
  177. package/cypress/integration/naked/facebookLogin.spec.js +13 -13
  178. package/cypress/integration/naked/floatingButton.spec.js +13 -13
  179. package/cypress/integration/naked/forgotPassword.spec.js +20 -20
  180. package/cypress/integration/naked/googleLogin.spec.js +11 -11
  181. package/cypress/integration/naked/languageExamples.spec.js +25 -25
  182. package/cypress/integration/naked/languageSelector.spec.js +10 -10
  183. package/cypress/integration/naked/login.spec.js +38 -38
  184. package/cypress/integration/naked/logout.spec.js +15 -15
  185. package/cypress/integration/naked/mainSearch.spec.js +9 -9
  186. package/cypress/integration/naked/menuControl.spec.js +9 -9
  187. package/cypress/integration/naked/messages.spec.js +25 -25
  188. package/cypress/integration/naked/momentOption.spec.js +10 -10
  189. package/cypress/integration/naked/myOrders.spec.js +11 -11
  190. package/cypress/integration/naked/myOrdersList.spec.js +9 -9
  191. package/cypress/integration/naked/orderContextAdvanced.spec.js +23 -23
  192. package/cypress/integration/naked/orderDetails.spec.js +11 -11
  193. package/cypress/integration/naked/paymentOptionCash.spec.js +21 -21
  194. package/cypress/integration/naked/paymentOptionStripe.spec.js +11 -11
  195. package/cypress/integration/naked/paymentOptionStripeDirect.spec.js +11 -11
  196. package/cypress/integration/naked/paymentOptions.spec.js +9 -9
  197. package/cypress/integration/naked/popupExample.spec.js +17 -17
  198. package/cypress/integration/naked/productImages.spec.js +11 -11
  199. package/cypress/integration/naked/productOptionExample.spec.js +21 -21
  200. package/cypress/integration/naked/productShare.spec.js +9 -9
  201. package/cypress/integration/naked/productsList.spec.js +9 -9
  202. package/cypress/integration/naked/resetPassword.spec.js +11 -11
  203. package/cypress/integration/naked/reviewOrders.spec.js +13 -13
  204. package/cypress/integration/naked/searchOptions.spec.js +18 -18
  205. package/cypress/integration/naked/signup.spec.js +31 -31
  206. package/cypress/integration/naked/upselling.spec.js +13 -13
  207. package/cypress/integration/naked/userDetails.spec.js +12 -12
  208. package/cypress/plugins/index.js +21 -21
  209. package/cypress/support/commands.js +35 -35
  210. package/cypress/support/index.js +20 -20
  211. package/cypress.json +12 -12
  212. package/example/App.js +263 -263
  213. package/example/components/ActiveOrdersUI/index.js +72 -72
  214. package/example/components/AddressDetailsUI/index.js +101 -101
  215. package/example/components/AddressFormUI/index.js +161 -161
  216. package/example/components/AddressListUI/index.js +33 -33
  217. package/example/components/AlertPopup/index.js +10 -10
  218. package/example/components/AlertUI/index.js +49 -49
  219. package/example/components/AlertUI/style.css +5 -5
  220. package/example/components/AppleLoginUI/index.js +40 -40
  221. package/example/components/BaseComponentUI/index.js +34 -34
  222. package/example/components/BusinessBasicInformationUI/index.js +118 -118
  223. package/example/components/BusinessControllerUI/index.js +89 -89
  224. package/example/components/BusinessInformationUI/BusinessOptionUI/index.js +83 -83
  225. package/example/components/BusinessInformationUI/index.js +83 -83
  226. package/example/components/BusinessProductsCategoriesUI/index.js +42 -42
  227. package/example/components/BusinessProductsSearchUI/index.js +38 -38
  228. package/example/components/BusinessReviewsUI/index.js +77 -77
  229. package/example/components/BusinessSortControlUI/index.js +47 -47
  230. package/example/components/BusinessTypeFilterUI/index.js +53 -53
  231. package/example/components/BusinessesMapUI/index.js +57 -57
  232. package/example/components/CartUI/index.js +154 -154
  233. package/example/components/ChangeView/index.js +19 -19
  234. package/example/components/CheckoutUI/index.js +206 -206
  235. package/example/components/CmsContentUI/index.js +52 -52
  236. package/example/components/ConfigsExample/index.js +118 -118
  237. package/example/components/CouponControlUI/index.js +63 -63
  238. package/example/components/DriverTipsUI/index.js +58 -58
  239. package/example/components/FacebookLoginButtonUI/index.js +48 -48
  240. package/example/components/FloatingButtonUI/index.js +145 -145
  241. package/example/components/ForgotPasswordFormUI/index.js +93 -93
  242. package/example/components/GoogleLoginUI/index.js +30 -30
  243. package/example/components/GpsButtonUI/index.js +22 -22
  244. package/example/components/Header/index.js +18 -18
  245. package/example/components/LanguageSelectorUI/index.js +57 -57
  246. package/example/components/LanguagesExample/index.js +51 -51
  247. package/example/components/LoginFormUI/index.js +159 -159
  248. package/example/components/LogoutButtonUI/index.js +21 -21
  249. package/example/components/MainSearchUI/index.js +131 -131
  250. package/example/components/MenuControlUI/index.js +103 -103
  251. package/example/components/MessagesUI/index.js +162 -162
  252. package/example/components/ModalUI/index.js +36 -36
  253. package/example/components/ModalUI/style.css +5 -5
  254. package/example/components/MomentOptionUI/index.js +68 -68
  255. package/example/components/MyOrdersListUI/index.js +51 -51
  256. package/example/components/MyOrdersUI/index.js +52 -52
  257. package/example/components/OrderChangeUI/index.js +54 -54
  258. package/example/components/OrderDetailsUI/index.js +174 -174
  259. package/example/components/OrderReviewUI/index.js +125 -125
  260. package/example/components/OrderTypeControlUI/index.js +32 -32
  261. package/example/components/PaymentOptionCashUI/index.js +60 -60
  262. package/example/components/PaymentOptionPaypalUI/index.js +50 -50
  263. package/example/components/PaymentOptionStripeDirectUI/index.js +89 -89
  264. package/example/components/PaymentOptionStripeRedirectUI/index.js +97 -97
  265. package/example/components/PaymentOptionStripeUI/index.js +129 -129
  266. package/example/components/PaymentOptionsUI/index.js +169 -169
  267. package/example/components/PhoneAutocompleteUI/index.js +67 -67
  268. package/example/components/PhoneAutocompleteUI/styles.css +49 -49
  269. package/example/components/ProductComponentUI/index.js +113 -113
  270. package/example/components/ProductFormUI/index.js +131 -131
  271. package/example/components/ProductImagesUI/index.js +82 -82
  272. package/example/components/ProductIngredientUI/index.js +21 -21
  273. package/example/components/ProductOptionSuboptionUI/index.js +65 -65
  274. package/example/components/ProductOptionUI/index.js +31 -31
  275. package/example/components/ProductShareUI/index.js +48 -48
  276. package/example/components/ProductsListUI/index.js +108 -108
  277. package/example/components/ProductsListingUI/index.js +42 -42
  278. package/example/components/ResetPasswordUI/index.js +121 -121
  279. package/example/components/SearchOptionsUI/index.js +82 -82
  280. package/example/components/SignupFormUI/index.js +117 -117
  281. package/example/components/SingleBusinessCardUI/index.js +82 -82
  282. package/example/components/SingleOrderCardUI/index.js +52 -52
  283. package/example/components/SingleProductCardUI/index.js +47 -47
  284. package/example/components/StripeElementsFormUI/CardFormUI/index.js +51 -51
  285. package/example/components/StripeElementsFormUI/CardFormUI/style.css +118 -118
  286. package/example/components/StripeElementsFormUI/index.js +38 -38
  287. package/example/components/StripeRedirectFormUI/index.js +99 -99
  288. package/example/components/TestComponent/index.js +5 -5
  289. package/example/components/UpsellingPageUI/index.js +26 -26
  290. package/example/components/UserDetailsUI/index.js +94 -94
  291. package/example/components/UserProfileUI/index.js +156 -156
  292. package/example/views/ActiveOrders/index.js +86 -86
  293. package/example/views/AddressDetailsExample/index.js +57 -57
  294. package/example/views/AppleLoginExample/index.js +51 -51
  295. package/example/views/BaseComponentExample/index.js +35 -35
  296. package/example/views/BusinessBasicInformationExample/index.js +43 -43
  297. package/example/views/BusinessControllerExample/index.js +55 -55
  298. package/example/views/BusinessInformationExample/index.js +68 -68
  299. package/example/views/BusinessProductsCategoriesExample/index.js +50 -50
  300. package/example/views/BusinessProductsSearchExample/index.js +39 -39
  301. package/example/views/BusinessReviewsExample/index.js +43 -43
  302. package/example/views/BusinessSortControlExample/index.js +53 -53
  303. package/example/views/BusinessTypeFilterExample/index.js +53 -53
  304. package/example/views/BusinessesMapExample/index.js +57 -57
  305. package/example/views/CheckoutExample/index.js +143 -143
  306. package/example/views/CmsContentExample/index.js +44 -44
  307. package/example/views/DriverTipsExample/index.js +47 -47
  308. package/example/views/EventsExample/index.js +26 -26
  309. package/example/views/FacebookLogin/index.js +63 -63
  310. package/example/views/FloatingButtonExample/index.js +47 -47
  311. package/example/views/ForgotPassword/index.js +77 -77
  312. package/example/views/GoogleLoginExample/index.js +85 -85
  313. package/example/views/Home/index.js +200 -200
  314. package/example/views/LanguageSelectorExample/index.js +55 -55
  315. package/example/views/Login/index.js +84 -84
  316. package/example/views/MainSearchExample/index.js +43 -43
  317. package/example/views/MenuControlExample/index.js +68 -68
  318. package/example/views/MessagesExample/index.js +58 -58
  319. package/example/views/MomentOptionExample/index.js +52 -52
  320. package/example/views/MyOrdersExample/index.js +35 -35
  321. package/example/views/MyOrdersListExample/index.js +50 -50
  322. package/example/views/OrderChangeExample/index.js +46 -46
  323. package/example/views/OrderContextExample/index.js +139 -139
  324. package/example/views/OrderDetailsExample/index.js +50 -50
  325. package/example/views/OrderReviewExample/index.js +64 -64
  326. package/example/views/PaymentOptionCashExample/index.js +51 -51
  327. package/example/views/PaymentOptionPaypalExample/index.js +71 -71
  328. package/example/views/PaymentOptionStripeDirectExample/index.js +43 -43
  329. package/example/views/PaymentOptionStripeExample/index.js +47 -47
  330. package/example/views/PaymentOptionStripeRedirectExample/index.js +56 -56
  331. package/example/views/PaymentOptionsExample/index.js +47 -47
  332. package/example/views/PhoneAutocompleteExample/index.js +34 -34
  333. package/example/views/PlacesExample/index.js +94 -94
  334. package/example/views/PopupExample/index.js +78 -78
  335. package/example/views/PopupExample/style.css +18 -18
  336. package/example/views/ProductDetail/index.js +323 -323
  337. package/example/views/ProductImagesExample/index.js +43 -43
  338. package/example/views/ProductOptionExample/index.js +88 -88
  339. package/example/views/ProductShareExample/index.js +51 -51
  340. package/example/views/ProductsListExample/index.js +77 -77
  341. package/example/views/ProductsListingExample/index.js +47 -47
  342. package/example/views/ResetPasswordExample/index.js +60 -60
  343. package/example/views/SearchOptionsExample/index.js +42 -42
  344. package/example/views/SessionManager/index.js +122 -122
  345. package/example/views/Signup/index.js +64 -64
  346. package/example/views/UpsellingPageExample/index.js +35 -35
  347. package/example/views/UserDetailsExample/index.js +69 -69
  348. package/example/views/UserProfile/index.js +73 -73
  349. package/index-example.js +23 -23
  350. package/index.html +13 -13
  351. package/native/index.js +257 -257
  352. package/native/src/NativeStrategy/index.js +20 -20
  353. package/native/src/contexts/OrderingContext/index.js +85 -85
  354. package/package.json +92 -92
  355. package/src/components/AddressDetails/index.js +149 -149
  356. package/src/components/AddressForm/index.js +380 -380
  357. package/src/components/AddressList/index.js +254 -254
  358. package/src/components/Analitycs/index.js +119 -119
  359. package/src/components/AnalyticsSegment/index.js +145 -145
  360. package/src/components/AppleLogin/index.js +164 -164
  361. package/src/components/BaseComponent/index.js +52 -52
  362. package/src/components/BusinessAndProductList/index.js +1005 -1005
  363. package/src/components/BusinessBasicInformation/index.js +119 -119
  364. package/src/components/BusinessController/index.js +351 -351
  365. package/src/components/BusinessInformation/BusinessOption/index.js +86 -86
  366. package/src/components/BusinessInformation/index.js +93 -93
  367. package/src/components/BusinessList/index.js +670 -670
  368. package/src/components/BusinessMenuListing/index.js +99 -99
  369. package/src/components/BusinessProductsCategories/index.js +60 -60
  370. package/src/components/BusinessProductsSearch/index.js +54 -54
  371. package/src/components/BusinessReviews/index.js +187 -187
  372. package/src/components/BusinessSearchList/index.js +364 -364
  373. package/src/components/BusinessSortControl/index.js +100 -100
  374. package/src/components/BusinessTypeFilter/index.js +142 -142
  375. package/src/components/BusinessesMap/index.js +110 -110
  376. package/src/components/Cart/index.js +211 -211
  377. package/src/components/CartStoresListing/index.js +157 -157
  378. package/src/components/Checkout/index.js +652 -652
  379. package/src/components/CmsContent/index.js +97 -97
  380. package/src/components/Contacts/index.js +512 -512
  381. package/src/components/CouponControl/index.js +171 -171
  382. package/src/components/DragAndDrop/index.js +41 -41
  383. package/src/components/DriverList/index.js +112 -112
  384. package/src/components/DriverTips/index.js +141 -141
  385. package/src/components/Emitter/index.js +36 -36
  386. package/src/components/ExamineClick/index.js +40 -40
  387. package/src/components/FacebookLoginButton/index.js +214 -214
  388. package/src/components/FacebookPixel/index.js +148 -148
  389. package/src/components/FavoriteList/index.js +278 -278
  390. package/src/components/FirebaseGoogleLoginButton/index.js +93 -93
  391. package/src/components/FloatingButton/index.js +70 -70
  392. package/src/components/ForgotPasswordForm/index.js +180 -180
  393. package/src/components/GiftCard/GiftCardOrdersList/index.js +155 -155
  394. package/src/components/GiftCard/PurchaseGiftCard/index.js +127 -127
  395. package/src/components/GiftCard/RedeemGiftCard/index.js +77 -77
  396. package/src/components/GiftCard/SendGiftCard/index.js +83 -83
  397. package/src/components/GoogleAutocompleteInput/index.js +154 -154
  398. package/src/components/GoogleIdentity/index.js +144 -144
  399. package/src/components/GoogleLoginButton/index.js +276 -276
  400. package/src/components/GoogleMaps/index.js +523 -523
  401. package/src/components/GpsButton/index.js +154 -154
  402. package/src/components/LanguageSelector/index.js +163 -163
  403. package/src/components/LoginForm/index.js +531 -531
  404. package/src/components/LogoutAction/index.js +211 -211
  405. package/src/components/MainSearch/index.js +149 -149
  406. package/src/components/MapView/index.js +116 -116
  407. package/src/components/MenuControl/index.js +238 -238
  408. package/src/components/Messages/index.js +166 -166
  409. package/src/components/MomentOption/index.js +322 -322
  410. package/src/components/MultiCartCreate/index.js +70 -70
  411. package/src/components/MultiCartsPaymethodsAndWallets/index.js +201 -201
  412. package/src/components/MultiCheckout/index.js +378 -378
  413. package/src/components/MultiOrdersDetails/index.js +109 -109
  414. package/src/components/MyOrders/index.js +150 -150
  415. package/src/components/MyOrdersList/index.js +104 -104
  416. package/src/components/NewOrderNotification/index.js +30 -30
  417. package/src/components/OrderChange/index.js +128 -128
  418. package/src/components/OrderDetails/index.js +684 -684
  419. package/src/components/OrderList/index.js +814 -814
  420. package/src/components/OrderListGroups/index.js +1256 -1256
  421. package/src/components/OrderReview/index.js +180 -180
  422. package/src/components/OrderTypeControl/index.js +75 -75
  423. package/src/components/OrderVerticalList/index.js +422 -422
  424. package/src/components/OrdersControlFilters/index.js +75 -75
  425. package/src/components/OrdersDashboardComponents/Appointments/index.js +72 -72
  426. package/src/components/OrdersDashboardComponents/BusinessProductsListing/index.js +629 -629
  427. package/src/components/OrdersDashboardComponents/CheckPassword/index.js +177 -177
  428. package/src/components/OrdersDashboardComponents/CityList/index.js +98 -98
  429. package/src/components/OrdersDashboardComponents/CountryList/index.js +162 -162
  430. package/src/components/OrdersDashboardComponents/CustomOrderDetails/index.js +238 -238
  431. package/src/components/OrdersDashboardComponents/DashboardBusinessList/index.js +617 -617
  432. package/src/components/OrdersDashboardComponents/DashboardOrdersList/index.js +943 -943
  433. package/src/components/OrdersDashboardComponents/DriversList/index.js +448 -448
  434. package/src/components/OrdersDashboardComponents/ExportCSV/index.js +192 -192
  435. package/src/components/OrdersDashboardComponents/GiftCardsList/index.js +189 -189
  436. package/src/components/OrdersDashboardComponents/GoogleMapsApiKeySetting/index.js +77 -77
  437. package/src/components/OrdersDashboardComponents/LogisticInformation/index.js +97 -97
  438. package/src/components/OrdersDashboardComponents/Logistics/index.js +174 -174
  439. package/src/components/OrdersDashboardComponents/Messages/index.js +384 -384
  440. package/src/components/OrdersDashboardComponents/MetaFields/index.js +186 -186
  441. package/src/components/OrdersDashboardComponents/OrderDetails/index.js +404 -404
  442. package/src/components/OrdersDashboardComponents/OrderNotification/index.js +70 -70
  443. package/src/components/OrdersDashboardComponents/OrdersFilter/index.js +362 -362
  444. package/src/components/OrdersDashboardComponents/OrdersManage/index.js +873 -873
  445. package/src/components/OrdersDashboardComponents/PointsWalletLevels/index.js +123 -123
  446. package/src/components/OrdersDashboardComponents/ReviewCustomer/index.js +113 -113
  447. package/src/components/OrdersDashboardComponents/Schedule/index.js +315 -315
  448. package/src/components/OrdersDashboardComponents/SettingsList/index.js +298 -298
  449. package/src/components/OrdersDashboardComponents/UserFormDetails/index.js +463 -463
  450. package/src/components/OrdersDashboardComponents/UsersList/index.js +944 -944
  451. package/src/components/OrdersDashboardComponents/WebsocketStatus/index.js +77 -77
  452. package/src/components/OrdersDashboardComponents/index.js +57 -57
  453. package/src/components/PageBanner/index.js +107 -107
  454. package/src/components/PaymentOptionCash/index.js +74 -74
  455. package/src/components/PaymentOptionPaypal/index.js +146 -146
  456. package/src/components/PaymentOptionSquare/index.js +336 -336
  457. package/src/components/PaymentOptionStripe/index.js +289 -289
  458. package/src/components/PaymentOptionStripeDirect/index.js +116 -116
  459. package/src/components/PaymentOptionStripeLink/index.js +101 -101
  460. package/src/components/PaymentOptionStripeRedirect/StripeRedirectForm/index.js +71 -71
  461. package/src/components/PaymentOptionStripeRedirect/index.js +122 -122
  462. package/src/components/PaymentOptionWallet/index.js +185 -185
  463. package/src/components/PaymentOptions/index.js +263 -263
  464. package/src/components/PaymethodList/index.js +119 -119
  465. package/src/components/PhoneAutocomplete/index.js +318 -318
  466. package/src/components/PlaceSpot/index.js +183 -183
  467. package/src/components/Popup/index.js +169 -169
  468. package/src/components/ProductComponent/index.js +269 -269
  469. package/src/components/ProductForm/index.js +1149 -1119
  470. package/src/components/ProductImages/index.js +64 -64
  471. package/src/components/ProductIngredient/index.js +72 -72
  472. package/src/components/ProductItemAccordion/index.js +72 -72
  473. package/src/components/ProductOption/index.js +42 -42
  474. package/src/components/ProductOptionSuboption/index.js +225 -225
  475. package/src/components/ProductShare/index.js +97 -97
  476. package/src/components/ProductsList/index.js +74 -74
  477. package/src/components/ProductsListing/index.js +166 -166
  478. package/src/components/ProfessionalInfo/index.js +156 -156
  479. package/src/components/PromotionsController/index.js +123 -123
  480. package/src/components/QueryLoginSpoonity/index.js +159 -159
  481. package/src/components/ReCaptcha/index.js +53 -53
  482. package/src/components/ResetPassword/index.js +111 -111
  483. package/src/components/ReviewCustomer/index.js +117 -117
  484. package/src/components/ReviewDriver/index.js +157 -157
  485. package/src/components/ReviewProduct/index.js +162 -162
  486. package/src/components/SearchOptions/index.js +69 -69
  487. package/src/components/Sessions/index.js +217 -217
  488. package/src/components/SignupForm/index.js +557 -557
  489. package/src/components/SingleBusinessCard/index.js +80 -80
  490. package/src/components/SingleOrderCard/index.js +160 -160
  491. package/src/components/SingleProductCard/index.js +130 -130
  492. package/src/components/SingleProfessionalCard/index.js +121 -121
  493. package/src/components/SmartAppBanner/index.js +71 -71
  494. package/src/components/StoreProductList/index.js +303 -303
  495. package/src/components/StripeElementsForm/CardForm/index.js +248 -248
  496. package/src/components/StripeElementsForm/index.js +78 -78
  497. package/src/components/UpsellingPage/index.js +156 -156
  498. package/src/components/UserFormDetails/index.js +742 -742
  499. package/src/components/UserVerification/index.js +246 -246
  500. package/src/components/WalletList/index.js +160 -160
  501. package/src/components/WebsocketStatus/index.js +80 -80
  502. package/src/components/WrapperGoogleMaps/index.js +67 -67
  503. package/src/constants/code-numbers.js +219 -219
  504. package/src/constants/timezones.js +427 -427
  505. package/src/contexts/ApiContext/index.js +59 -59
  506. package/src/contexts/BillingContext/index.js +28 -28
  507. package/src/contexts/BusinessContext/index.js +71 -71
  508. package/src/contexts/ConfigContext/index.js +217 -217
  509. package/src/contexts/CustomerContext/index.js +69 -69
  510. package/src/contexts/EventContext/index.js +31 -31
  511. package/src/contexts/LanguageContext/index.js +144 -144
  512. package/src/contexts/OptimizationLoadContext/index.js +95 -95
  513. package/src/contexts/OrderContext/index.js +1450 -1450
  514. package/src/contexts/OrderingContext/index.js +86 -86
  515. package/src/contexts/OrderingThemeContext/index.js +107 -107
  516. package/src/contexts/ProductContext/index.js +62 -62
  517. package/src/contexts/SessionContext/index.js +172 -172
  518. package/src/contexts/SiteContext/index.js +79 -79
  519. package/src/contexts/ToastContext/index.js +42 -42
  520. package/src/contexts/UtilsContext/index.js +343 -343
  521. package/src/contexts/ValidationsFieldsContext/index.js +65 -65
  522. package/src/contexts/WebsocketContext/index.js +95 -95
  523. package/src/contexts/WebsocketContext/socket.js +92 -92
  524. package/src/index.js +373 -373
  525. package/src/utils/index.js +32 -32
  526. package/src/webStrategy/index.js +18 -18
  527. package/webpack.dev.js +41 -41
  528. package/webpack.prod.js +64 -64
  529. /package/_bundles/{0.ordering-component.dd1dbfe86e478023f67a.js → 0.ordering-component.6cdb5ba8147ea6e69b23.js} +0 -0
  530. /package/_bundles/{1.ordering-component.dd1dbfe86e478023f67a.js → 1.ordering-component.6cdb5ba8147ea6e69b23.js} +0 -0
  531. /package/_bundles/{2.ordering-component.dd1dbfe86e478023f67a.js → 2.ordering-component.6cdb5ba8147ea6e69b23.js} +0 -0
  532. /package/_bundles/{4.ordering-component.dd1dbfe86e478023f67a.js → 4.ordering-component.6cdb5ba8147ea6e69b23.js} +0 -0
  533. /package/_bundles/{5.ordering-component.dd1dbfe86e478023f67a.js → 5.ordering-component.6cdb5ba8147ea6e69b23.js} +0 -0
  534. /package/_bundles/{6.ordering-component.dd1dbfe86e478023f67a.js → 6.ordering-component.6cdb5ba8147ea6e69b23.js} +0 -0
  535. /package/_bundles/{7.ordering-component.dd1dbfe86e478023f67a.js.LICENSE.txt → 7.ordering-component.6cdb5ba8147ea6e69b23.js.LICENSE.txt} +0 -0
  536. /package/_bundles/{8.ordering-component.dd1dbfe86e478023f67a.js → 8.ordering-component.6cdb5ba8147ea6e69b23.js} +0 -0
  537. /package/_bundles/{ordering-component.dd1dbfe86e478023f67a.js.LICENSE.txt → ordering-component.6cdb5ba8147ea6e69b23.js.LICENSE.txt} +0 -0
@@ -1,422 +1,422 @@
1
- import React, { useEffect, useState } from 'react'
2
- import { useSession } from '../../contexts/SessionContext'
3
- import { useApi } from '../../contexts/ApiContext'
4
- import { useWebsocket } from '../../contexts/WebsocketContext'
5
- import { ToastType, useToast } from '../../contexts/ToastContext'
6
- import { useLanguage } from '../../contexts/LanguageContext'
7
- import { useEvent } from '../../contexts/EventContext'
8
- import { useOrder } from '../../contexts/OrderContext'
9
-
10
- export const OrderVerticalList = (props) => {
11
- const {
12
- UIComponent,
13
- orderBy,
14
- businessId,
15
- useDefualtSessionManager,
16
- paginationSettings,
17
- asDashboard,
18
- orderGroupStatusCustom,
19
- onNavigationRedirect
20
- } = props
21
-
22
- const [ordering] = useApi()
23
- const [session] = useSession()
24
- const [events] = useEvent()
25
- const socket = useWebsocket()
26
- const [, t] = useLanguage()
27
- const [, { reorder }] = useOrder()
28
- const [, { showToast }] = useToast()
29
-
30
- const ordersStatusArray = ['upcoming', 'active', 'past', 'all']
31
-
32
- const ordersGroupStatus = {
33
- upcoming: orderGroupStatusCustom?.upcoming ?? [13],
34
- active: orderGroupStatusCustom?.active ?? [0, 3, 4, 7, 8, 9, 14, 15, 18, 19, 20, 21, 22, 23, 24, 25, 26],
35
- past: orderGroupStatusCustom?.past ?? [1, 2, 5, 6, 10, 11, 12, 16, 17],
36
- all: orderGroupStatusCustom?.all ?? [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26]
37
- }
38
-
39
- const orderObjDefault = {
40
- loading: true,
41
- error: null,
42
- pagination: {
43
- currentPage: (paginationSettings.controlType === 'pages' && paginationSettings.initialPage && paginationSettings.initialPage >= 1)
44
- ? paginationSettings.initialPage - 1
45
- : 0,
46
- pageSize: paginationSettings.pageSize ?? 10,
47
- total: null
48
- }
49
- }
50
-
51
- const [reorderLoading, setReorderLoading] = useState(false)
52
- let [ordersGroup, setOrdersGroup] = useState({
53
- ...orderObjDefault,
54
- all: { orders: [] },
55
- upcoming: { orders: [] },
56
- active: { orders: [] },
57
- past: { orders: [] },
58
- })
59
-
60
- const accessToken = useDefualtSessionManager ? session.token : props.accessToken
61
- const requestsState = {}
62
-
63
- const getOrders = async ({ page, pageSize = paginationSettings.pageSize, orderStatus }) => {
64
- const options = {
65
- query: {
66
- orderBy,
67
- page: page,
68
- page_size: pageSize
69
- }
70
- }
71
-
72
- options.query.where = []
73
- if (orderStatus) {
74
- options.query.where.push({ attribute: 'status', value: orderStatus })
75
-
76
- options.query.where.push({
77
- attribute: 'id',
78
- value: {
79
- condition: '!=',
80
- value: ordersGroup?.all?.orders?.map((o) => o.id)
81
- }
82
- })
83
- }
84
-
85
- if (businessId) {
86
- options.query.where.push({ attribute: 'business_id', value: businessId })
87
- }
88
-
89
- const source = {}
90
- requestsState.orders = source
91
- options.cancelToken = source
92
-
93
- const functionFetch = asDashboard
94
- ? ordering.setAccessToken(accessToken).orders().asDashboard()
95
- : ordering.setAccessToken(accessToken).orders()
96
- return await functionFetch.get(options)
97
- }
98
-
99
- const loadOrders = async ({ newFetch } = {}) => {
100
- if (
101
- !newFetch &&
102
- ordersGroup.pagination.currentPage === ordersGroup.pagination?.totalPages &&
103
- ordersGroup.pagination.total !== null
104
- ) {
105
- return
106
- }
107
-
108
- if (newFetch) {
109
- const options = {}
110
- ordersStatusArray.map(tab => {
111
- options[tab] = { orders: [] }
112
- })
113
- ordersGroup = { ...orderObjDefault, ...options }
114
- }
115
-
116
- const pageSize = paginationSettings.pageSize
117
-
118
- try {
119
- setOrdersGroup({ ...ordersGroup, loading: true })
120
- const { content: { error, result, pagination } } = await getOrders({
121
- page: 1,
122
- pageSize,
123
- orderStatus: ordersGroupStatus.all,
124
- newFetch
125
- })
126
-
127
- const tabOptions = {}
128
- ordersStatusArray.map(tab => {
129
- tabOptions[tab] = {
130
- orders: error
131
- ? newFetch
132
- ? []
133
- : sortOrders(ordersGroup[tab].orders)
134
- : newFetch
135
- ? sortOrders(result.filter((order) => ordersGroupStatus[tab].includes(order.status)))
136
- : sortOrders(ordersGroup[tab].orders.concat(result.filter(order => ordersGroupStatus[tab].includes(order.status))))
137
- }
138
- })
139
-
140
- setOrdersGroup({
141
- ...ordersGroup,
142
- loading: false,
143
- error: error ? result : null,
144
- ...tabOptions,
145
- pagination: {
146
- ...ordersGroup.pagination,
147
- currentPage: pagination.current_page,
148
- pageSize: pagination.page_size,
149
- totalPages: pagination.total_pages,
150
- total: pagination.total,
151
- from: pagination.from,
152
- to: pagination.to
153
- }
154
- })
155
- } catch (err) {
156
- if (err.constructor.name !== 'Cancel') {
157
- setOrdersGroup({
158
- ...ordersGroup,
159
- loading: false,
160
- error: [err?.message ?? 'ERROR']
161
- })
162
- }
163
- }
164
- }
165
-
166
- const loadMoreOrders = async () => {
167
- try {
168
- setOrdersGroup({ ...ordersGroup, loading: true })
169
- const { content: { error, result, pagination } } = await getOrders({
170
- page: ordersGroup.pagination.currentPage + 1,
171
- orderStatus: ordersGroupStatus.all,
172
- })
173
-
174
- const tabOptions = {}
175
- ordersStatusArray.map(tab => {
176
- tabOptions[tab] = {
177
- orders: error
178
- ? sortOrders(ordersGroup[tab].orders)
179
- : sortOrders(ordersGroup[tab].orders.concat(result.filter(order => ordersGroupStatus[tab].includes(order.status)))),
180
- }
181
- })
182
-
183
- setOrdersGroup({
184
- ...ordersGroup,
185
- loading: false,
186
- error: error ? result : null,
187
- ...tabOptions,
188
- pagination: !error
189
- ? {
190
- ...ordersGroup.pagination,
191
- currentPage: pagination.current_page,
192
- pageSize: pagination.page_size,
193
- totalPages: pagination.total_pages,
194
- total: pagination.total,
195
- from: pagination.from,
196
- to: pagination.to
197
- }
198
- : ordersGroup.pagination
199
- })
200
- } catch (err) {
201
- if (err.constructor.name !== 'Cancel') {
202
- setOrdersGroup({
203
- ...ordersGroup,
204
- loading: false,
205
- error: [err?.message ?? 'ERROR']
206
- })
207
- }
208
- }
209
- }
210
-
211
- const sortOrders = (orders, sortBy = 'desc') => {
212
- const ordersSorted = orders.sort((a, b) => {
213
- if (sortBy === 'desc') {
214
- return b.id - a.id
215
- }
216
- return a.id - b.id
217
- })
218
-
219
- return ordersSorted
220
- }
221
-
222
- const getStatusById = (id) => {
223
- if (!id && id !== 0) return
224
- const upcoming = orderGroupStatusCustom?.upcoming ?? [13]
225
- const active = orderGroupStatusCustom?.active ?? [0, 3, 4, 7, 8, 9, 14, 15, 18, 19, 20, 21, 23, 26]
226
-
227
- const status = upcoming.includes(id)
228
- ? 'upcoming'
229
- : active.includes(id)
230
- ? 'active'
231
- : 'past'
232
-
233
- return status
234
- }
235
-
236
- const actionOrderToTab = (orderAux, status, type) => {
237
- const orderList = ordersGroup[status].orders
238
- let orders
239
- const order = {
240
- ...orderAux,
241
- showNotification: true
242
- }
243
- if (type === 'update') {
244
- const indexToUpdate = orderList.findIndex((o) => o.id === order.id)
245
- orderList[indexToUpdate] = order
246
- orders = orderList
247
- } else {
248
- orders = type === 'add'
249
- ? [order, ...orderList]
250
- : orderList.filter((_order) => _order.id !== order.id)
251
- }
252
-
253
- ordersGroup[status].orders = sortOrders(orders)
254
-
255
- if (type !== 'update') {
256
- ordersGroup.pagination = {
257
- ...ordersGroup.pagination,
258
- total: ordersGroup.pagination.total + (type === 'add' ? 1 : -1)
259
- }
260
- }
261
- }
262
-
263
- const handleReorder = async (orderId) => {
264
- setReorderLoading(true)
265
- try {
266
- const { error, result } = await reorder(orderId)
267
- if (!error) {
268
- onNavigationRedirect && onNavigationRedirect('CheckoutNavigator', { cartUuid: result.uuid })
269
- setReorderLoading(false)
270
- return
271
- }
272
- setReorderLoading(false)
273
-
274
- } catch (err) {
275
- showToast(ToastType.Error, t('ERROR', err.message))
276
- setReorderLoading(false)
277
- }
278
- }
279
-
280
- useEffect(() => {
281
- loadOrders({newFetch: ordersGroup.pagination.total === null })
282
- }, [])
283
-
284
- useEffect(() => {
285
- if (ordersGroup.loading) return
286
-
287
- const handleUpdateOrder = (order) => {
288
- events.emit('order_updated', order)
289
- let orderFound = null
290
-
291
- for (let i = 0; i < ordersStatusArray.length; i++) {
292
- const status = ordersStatusArray[i]
293
- orderFound = ordersGroup[status].orders.find((_order) => _order.id === order.id)
294
- if (orderFound) break
295
- }
296
-
297
- showToast(
298
- ToastType.Info,
299
- t('SPECIFIC_ORDER_UPDATED', 'Your order number _NUMBER_ has updated').replace('_NUMBER_', order.id),
300
- 1000
301
- )
302
-
303
- if (!orderFound) {
304
- if (
305
- !order?.products ||
306
- !order?.summary ||
307
- typeof order?.status !== 'number' ||
308
- !order?.customer ||
309
- !order?.business ||
310
- !order?.paymethod
311
- ) {
312
- return
313
- }
314
- delete order.total
315
- delete order.subtotal
316
-
317
- actionOrderToTab(order, getStatusById(order?.status), 'add')
318
-
319
- return
320
- }
321
-
322
- if (
323
- orderFound.id === order.id &&
324
- orderFound?.driver?.id !== order?.driver?.id &&
325
- session?.user?.level === 4
326
- ) {
327
- actionOrderToTab(orderFound, getStatusById(orderFound.status), 'remove')
328
- }
329
-
330
- if (orderFound.id === order.id) {
331
- delete order.total
332
- delete order.subtotal
333
- }
334
-
335
- if (!order?.status && order?.status !== 0) {
336
- Object.assign(orderFound, order)
337
- } else {
338
- const newOrderStatus = getStatusById(order?.status) ?? ''
339
- const currentOrderStatus = getStatusById(orderFound?.status) ?? ''
340
-
341
- Object.assign(orderFound, order)
342
-
343
- if (newOrderStatus !== currentOrderStatus) {
344
- actionOrderToTab(orderFound, currentOrderStatus, 'remove')
345
-
346
- const total = ordersGroup.pagination.total ?? null
347
-
348
- if (total !== null) {
349
- actionOrderToTab(orderFound, newOrderStatus, 'add')
350
- }
351
- } else {
352
- actionOrderToTab(orderFound, newOrderStatus, 'update')
353
- }
354
- }
355
- }
356
-
357
- const handleAddNewOrder = (order) => {
358
- events.emit('order_added', order)
359
- showToast(
360
- ToastType.Info,
361
- t('SPECIFIC_ORDER_ORDERED', 'Order _NUMBER_ has been ordered').replace('_NUMBER_', order.id),
362
- 1000
363
- )
364
- const status = getStatusById(order?.status) ?? ''
365
- actionOrderToTab(order, status, 'add')
366
- actionOrderToTab(order, 'all', 'add')
367
- }
368
-
369
- socket.on('orders_register', handleAddNewOrder)
370
- socket.on('update_order', handleUpdateOrder)
371
- return () => {
372
- socket.off('orders_register', handleAddNewOrder)
373
- socket.off('update_order', handleUpdateOrder)
374
- }
375
- }, [ordersGroup, socket, session])
376
-
377
- useEffect(() => {
378
- if (!session.user) return
379
- socket.on('disconnect', () => {
380
- const ordersRoom = session?.user?.level === 0 ? 'orders' : `orders_${session?.user?.id}`
381
- socket.join(ordersRoom)
382
- })
383
- const ordersRoom = session?.user?.level === 0 ? 'orders' : `orders_${session?.user?.id}`
384
- socket.join(ordersRoom)
385
- return () => {
386
- socket.leave(ordersRoom)
387
- }
388
- }, [socket, session])
389
-
390
- useEffect(() => {
391
- const request = requestsState.orders
392
- return () => {
393
- request && request.cancel && request.cancel()
394
- }
395
- }, [requestsState.orders])
396
-
397
- return (
398
- <>
399
- {UIComponent && (
400
- <UIComponent
401
- {...props}
402
- ordersGroup={ordersGroup}
403
- reorderLoading={reorderLoading}
404
- setOrdersGroup={setOrdersGroup}
405
- loadOrders={loadOrders}
406
- loadMoreOrders={loadMoreOrders}
407
- handleReorder={handleReorder}
408
- />
409
- )}
410
- </>
411
- )
412
- }
413
-
414
- OrderVerticalList.defaultProps = {
415
- orderBy: '-id',
416
- orderDirection: 'desc',
417
- paginationSettings: { initialPage: 1, pageSize: 10, controlType: 'infinity' },
418
- beforeComponents: [],
419
- afterComponents: [],
420
- beforeElements: [],
421
- afterElements: []
422
- }
1
+ import React, { useEffect, useState } from 'react'
2
+ import { useSession } from '../../contexts/SessionContext'
3
+ import { useApi } from '../../contexts/ApiContext'
4
+ import { useWebsocket } from '../../contexts/WebsocketContext'
5
+ import { ToastType, useToast } from '../../contexts/ToastContext'
6
+ import { useLanguage } from '../../contexts/LanguageContext'
7
+ import { useEvent } from '../../contexts/EventContext'
8
+ import { useOrder } from '../../contexts/OrderContext'
9
+
10
+ export const OrderVerticalList = (props) => {
11
+ const {
12
+ UIComponent,
13
+ orderBy,
14
+ businessId,
15
+ useDefualtSessionManager,
16
+ paginationSettings,
17
+ asDashboard,
18
+ orderGroupStatusCustom,
19
+ onNavigationRedirect
20
+ } = props
21
+
22
+ const [ordering] = useApi()
23
+ const [session] = useSession()
24
+ const [events] = useEvent()
25
+ const socket = useWebsocket()
26
+ const [, t] = useLanguage()
27
+ const [, { reorder }] = useOrder()
28
+ const [, { showToast }] = useToast()
29
+
30
+ const ordersStatusArray = ['upcoming', 'active', 'past', 'all']
31
+
32
+ const ordersGroupStatus = {
33
+ upcoming: orderGroupStatusCustom?.upcoming ?? [13],
34
+ active: orderGroupStatusCustom?.active ?? [0, 3, 4, 7, 8, 9, 14, 15, 18, 19, 20, 21, 22, 23, 24, 25, 26],
35
+ past: orderGroupStatusCustom?.past ?? [1, 2, 5, 6, 10, 11, 12, 16, 17],
36
+ all: orderGroupStatusCustom?.all ?? [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26]
37
+ }
38
+
39
+ const orderObjDefault = {
40
+ loading: true,
41
+ error: null,
42
+ pagination: {
43
+ currentPage: (paginationSettings.controlType === 'pages' && paginationSettings.initialPage && paginationSettings.initialPage >= 1)
44
+ ? paginationSettings.initialPage - 1
45
+ : 0,
46
+ pageSize: paginationSettings.pageSize ?? 10,
47
+ total: null
48
+ }
49
+ }
50
+
51
+ const [reorderLoading, setReorderLoading] = useState(false)
52
+ let [ordersGroup, setOrdersGroup] = useState({
53
+ ...orderObjDefault,
54
+ all: { orders: [] },
55
+ upcoming: { orders: [] },
56
+ active: { orders: [] },
57
+ past: { orders: [] },
58
+ })
59
+
60
+ const accessToken = useDefualtSessionManager ? session.token : props.accessToken
61
+ const requestsState = {}
62
+
63
+ const getOrders = async ({ page, pageSize = paginationSettings.pageSize, orderStatus }) => {
64
+ const options = {
65
+ query: {
66
+ orderBy,
67
+ page: page,
68
+ page_size: pageSize
69
+ }
70
+ }
71
+
72
+ options.query.where = []
73
+ if (orderStatus) {
74
+ options.query.where.push({ attribute: 'status', value: orderStatus })
75
+
76
+ options.query.where.push({
77
+ attribute: 'id',
78
+ value: {
79
+ condition: '!=',
80
+ value: ordersGroup?.all?.orders?.map((o) => o.id)
81
+ }
82
+ })
83
+ }
84
+
85
+ if (businessId) {
86
+ options.query.where.push({ attribute: 'business_id', value: businessId })
87
+ }
88
+
89
+ const source = {}
90
+ requestsState.orders = source
91
+ options.cancelToken = source
92
+
93
+ const functionFetch = asDashboard
94
+ ? ordering.setAccessToken(accessToken).orders().asDashboard()
95
+ : ordering.setAccessToken(accessToken).orders()
96
+ return await functionFetch.get(options)
97
+ }
98
+
99
+ const loadOrders = async ({ newFetch } = {}) => {
100
+ if (
101
+ !newFetch &&
102
+ ordersGroup.pagination.currentPage === ordersGroup.pagination?.totalPages &&
103
+ ordersGroup.pagination.total !== null
104
+ ) {
105
+ return
106
+ }
107
+
108
+ if (newFetch) {
109
+ const options = {}
110
+ ordersStatusArray.map(tab => {
111
+ options[tab] = { orders: [] }
112
+ })
113
+ ordersGroup = { ...orderObjDefault, ...options }
114
+ }
115
+
116
+ const pageSize = paginationSettings.pageSize
117
+
118
+ try {
119
+ setOrdersGroup({ ...ordersGroup, loading: true })
120
+ const { content: { error, result, pagination } } = await getOrders({
121
+ page: 1,
122
+ pageSize,
123
+ orderStatus: ordersGroupStatus.all,
124
+ newFetch
125
+ })
126
+
127
+ const tabOptions = {}
128
+ ordersStatusArray.map(tab => {
129
+ tabOptions[tab] = {
130
+ orders: error
131
+ ? newFetch
132
+ ? []
133
+ : sortOrders(ordersGroup[tab].orders)
134
+ : newFetch
135
+ ? sortOrders(result.filter((order) => ordersGroupStatus[tab].includes(order.status)))
136
+ : sortOrders(ordersGroup[tab].orders.concat(result.filter(order => ordersGroupStatus[tab].includes(order.status))))
137
+ }
138
+ })
139
+
140
+ setOrdersGroup({
141
+ ...ordersGroup,
142
+ loading: false,
143
+ error: error ? result : null,
144
+ ...tabOptions,
145
+ pagination: {
146
+ ...ordersGroup.pagination,
147
+ currentPage: pagination.current_page,
148
+ pageSize: pagination.page_size,
149
+ totalPages: pagination.total_pages,
150
+ total: pagination.total,
151
+ from: pagination.from,
152
+ to: pagination.to
153
+ }
154
+ })
155
+ } catch (err) {
156
+ if (err.constructor.name !== 'Cancel') {
157
+ setOrdersGroup({
158
+ ...ordersGroup,
159
+ loading: false,
160
+ error: [err?.message ?? 'ERROR']
161
+ })
162
+ }
163
+ }
164
+ }
165
+
166
+ const loadMoreOrders = async () => {
167
+ try {
168
+ setOrdersGroup({ ...ordersGroup, loading: true })
169
+ const { content: { error, result, pagination } } = await getOrders({
170
+ page: ordersGroup.pagination.currentPage + 1,
171
+ orderStatus: ordersGroupStatus.all,
172
+ })
173
+
174
+ const tabOptions = {}
175
+ ordersStatusArray.map(tab => {
176
+ tabOptions[tab] = {
177
+ orders: error
178
+ ? sortOrders(ordersGroup[tab].orders)
179
+ : sortOrders(ordersGroup[tab].orders.concat(result.filter(order => ordersGroupStatus[tab].includes(order.status)))),
180
+ }
181
+ })
182
+
183
+ setOrdersGroup({
184
+ ...ordersGroup,
185
+ loading: false,
186
+ error: error ? result : null,
187
+ ...tabOptions,
188
+ pagination: !error
189
+ ? {
190
+ ...ordersGroup.pagination,
191
+ currentPage: pagination.current_page,
192
+ pageSize: pagination.page_size,
193
+ totalPages: pagination.total_pages,
194
+ total: pagination.total,
195
+ from: pagination.from,
196
+ to: pagination.to
197
+ }
198
+ : ordersGroup.pagination
199
+ })
200
+ } catch (err) {
201
+ if (err.constructor.name !== 'Cancel') {
202
+ setOrdersGroup({
203
+ ...ordersGroup,
204
+ loading: false,
205
+ error: [err?.message ?? 'ERROR']
206
+ })
207
+ }
208
+ }
209
+ }
210
+
211
+ const sortOrders = (orders, sortBy = 'desc') => {
212
+ const ordersSorted = orders.sort((a, b) => {
213
+ if (sortBy === 'desc') {
214
+ return b.id - a.id
215
+ }
216
+ return a.id - b.id
217
+ })
218
+
219
+ return ordersSorted
220
+ }
221
+
222
+ const getStatusById = (id) => {
223
+ if (!id && id !== 0) return
224
+ const upcoming = orderGroupStatusCustom?.upcoming ?? [13]
225
+ const active = orderGroupStatusCustom?.active ?? [0, 3, 4, 7, 8, 9, 14, 15, 18, 19, 20, 21, 23, 26]
226
+
227
+ const status = upcoming.includes(id)
228
+ ? 'upcoming'
229
+ : active.includes(id)
230
+ ? 'active'
231
+ : 'past'
232
+
233
+ return status
234
+ }
235
+
236
+ const actionOrderToTab = (orderAux, status, type) => {
237
+ const orderList = ordersGroup[status].orders
238
+ let orders
239
+ const order = {
240
+ ...orderAux,
241
+ showNotification: true
242
+ }
243
+ if (type === 'update') {
244
+ const indexToUpdate = orderList.findIndex((o) => o.id === order.id)
245
+ orderList[indexToUpdate] = order
246
+ orders = orderList
247
+ } else {
248
+ orders = type === 'add'
249
+ ? [order, ...orderList]
250
+ : orderList.filter((_order) => _order.id !== order.id)
251
+ }
252
+
253
+ ordersGroup[status].orders = sortOrders(orders)
254
+
255
+ if (type !== 'update') {
256
+ ordersGroup.pagination = {
257
+ ...ordersGroup.pagination,
258
+ total: ordersGroup.pagination.total + (type === 'add' ? 1 : -1)
259
+ }
260
+ }
261
+ }
262
+
263
+ const handleReorder = async (orderId) => {
264
+ setReorderLoading(true)
265
+ try {
266
+ const { error, result } = await reorder(orderId)
267
+ if (!error) {
268
+ onNavigationRedirect && onNavigationRedirect('CheckoutNavigator', { cartUuid: result.uuid })
269
+ setReorderLoading(false)
270
+ return
271
+ }
272
+ setReorderLoading(false)
273
+
274
+ } catch (err) {
275
+ showToast(ToastType.Error, t('ERROR', err.message))
276
+ setReorderLoading(false)
277
+ }
278
+ }
279
+
280
+ useEffect(() => {
281
+ loadOrders({newFetch: ordersGroup.pagination.total === null })
282
+ }, [])
283
+
284
+ useEffect(() => {
285
+ if (ordersGroup.loading) return
286
+
287
+ const handleUpdateOrder = (order) => {
288
+ events.emit('order_updated', order)
289
+ let orderFound = null
290
+
291
+ for (let i = 0; i < ordersStatusArray.length; i++) {
292
+ const status = ordersStatusArray[i]
293
+ orderFound = ordersGroup[status].orders.find((_order) => _order.id === order.id)
294
+ if (orderFound) break
295
+ }
296
+
297
+ showToast(
298
+ ToastType.Info,
299
+ t('SPECIFIC_ORDER_UPDATED', 'Your order number _NUMBER_ has updated').replace('_NUMBER_', order.id),
300
+ 1000
301
+ )
302
+
303
+ if (!orderFound) {
304
+ if (
305
+ !order?.products ||
306
+ !order?.summary ||
307
+ typeof order?.status !== 'number' ||
308
+ !order?.customer ||
309
+ !order?.business ||
310
+ !order?.paymethod
311
+ ) {
312
+ return
313
+ }
314
+ delete order.total
315
+ delete order.subtotal
316
+
317
+ actionOrderToTab(order, getStatusById(order?.status), 'add')
318
+
319
+ return
320
+ }
321
+
322
+ if (
323
+ orderFound.id === order.id &&
324
+ orderFound?.driver?.id !== order?.driver?.id &&
325
+ session?.user?.level === 4
326
+ ) {
327
+ actionOrderToTab(orderFound, getStatusById(orderFound.status), 'remove')
328
+ }
329
+
330
+ if (orderFound.id === order.id) {
331
+ delete order.total
332
+ delete order.subtotal
333
+ }
334
+
335
+ if (!order?.status && order?.status !== 0) {
336
+ Object.assign(orderFound, order)
337
+ } else {
338
+ const newOrderStatus = getStatusById(order?.status) ?? ''
339
+ const currentOrderStatus = getStatusById(orderFound?.status) ?? ''
340
+
341
+ Object.assign(orderFound, order)
342
+
343
+ if (newOrderStatus !== currentOrderStatus) {
344
+ actionOrderToTab(orderFound, currentOrderStatus, 'remove')
345
+
346
+ const total = ordersGroup.pagination.total ?? null
347
+
348
+ if (total !== null) {
349
+ actionOrderToTab(orderFound, newOrderStatus, 'add')
350
+ }
351
+ } else {
352
+ actionOrderToTab(orderFound, newOrderStatus, 'update')
353
+ }
354
+ }
355
+ }
356
+
357
+ const handleAddNewOrder = (order) => {
358
+ events.emit('order_added', order)
359
+ showToast(
360
+ ToastType.Info,
361
+ t('SPECIFIC_ORDER_ORDERED', 'Order _NUMBER_ has been ordered').replace('_NUMBER_', order.id),
362
+ 1000
363
+ )
364
+ const status = getStatusById(order?.status) ?? ''
365
+ actionOrderToTab(order, status, 'add')
366
+ actionOrderToTab(order, 'all', 'add')
367
+ }
368
+
369
+ socket.on('orders_register', handleAddNewOrder)
370
+ socket.on('update_order', handleUpdateOrder)
371
+ return () => {
372
+ socket.off('orders_register', handleAddNewOrder)
373
+ socket.off('update_order', handleUpdateOrder)
374
+ }
375
+ }, [ordersGroup, socket, session])
376
+
377
+ useEffect(() => {
378
+ if (!session.user) return
379
+ socket.on('disconnect', () => {
380
+ const ordersRoom = session?.user?.level === 0 ? 'orders' : `orders_${session?.user?.id}`
381
+ socket.join(ordersRoom)
382
+ })
383
+ const ordersRoom = session?.user?.level === 0 ? 'orders' : `orders_${session?.user?.id}`
384
+ socket.join(ordersRoom)
385
+ return () => {
386
+ socket.leave(ordersRoom)
387
+ }
388
+ }, [socket, session])
389
+
390
+ useEffect(() => {
391
+ const request = requestsState.orders
392
+ return () => {
393
+ request && request.cancel && request.cancel()
394
+ }
395
+ }, [requestsState.orders])
396
+
397
+ return (
398
+ <>
399
+ {UIComponent && (
400
+ <UIComponent
401
+ {...props}
402
+ ordersGroup={ordersGroup}
403
+ reorderLoading={reorderLoading}
404
+ setOrdersGroup={setOrdersGroup}
405
+ loadOrders={loadOrders}
406
+ loadMoreOrders={loadMoreOrders}
407
+ handleReorder={handleReorder}
408
+ />
409
+ )}
410
+ </>
411
+ )
412
+ }
413
+
414
+ OrderVerticalList.defaultProps = {
415
+ orderBy: '-id',
416
+ orderDirection: 'desc',
417
+ paginationSettings: { initialPage: 1, pageSize: 10, controlType: 'infinity' },
418
+ beforeComponents: [],
419
+ afterComponents: [],
420
+ beforeElements: [],
421
+ afterElements: []
422
+ }